:root{--primary: #ff6b35;--secondary: #004e89;--accent: #ffbe0b;--success: #2ec4b6;--bg: #fdf0d5;--dark: #1a1a2e;--border: 4px solid #1a1a2e;--shadow: 6px 6px 0px #1a1a2e;--shadow-sm: 4px 4px 0px #1a1a2e}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans KR,sans-serif;background-color:var(--bg);background-image:radial-gradient(circle at 20% 80%,rgba(255,107,53,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(0,78,137,.1) 0%,transparent 50%);min-height:100vh;padding:0}.container{max-width:1200px;margin:0 auto;padding:0 20px}@media(max-width:600px){.container{padding:0 15px}}.header{text-align:center;margin-bottom:30px;margin-top:20px}.title{font-family:Black Han Sans,sans-serif;font-size:3rem;color:var(--dark);text-shadow:4px 4px 0px var(--primary);margin-bottom:10px}.subtitle{font-size:1.1rem;color:var(--secondary);font-weight:700}.stats-card{background:var(--primary);border:var(--border);box-shadow:var(--shadow);padding:25px 35px;margin-bottom:30px;display:flex;justify-content:center;align-items:center;gap:40px;flex-wrap:wrap;position:sticky;top:60px;z-index:99;transition:all .25s ease}.stats-card.compact{padding:10px 25px;gap:30px;box-shadow:0 4px 12px #0003}.stat-item{text-align:center}.stat-label{font-size:.9rem;color:var(--dark);font-weight:700;text-transform:uppercase;letter-spacing:1px;transition:font-size .25s ease}.stats-card.compact .stat-label{font-size:.75rem}.stat-value{font-family:Black Han Sans,sans-serif;font-size:3.5rem;color:#fff;text-shadow:3px 3px 0px var(--dark);line-height:1;transition:all .25s ease}.stats-card.compact .stat-value{font-size:2rem;text-shadow:2px 2px 0px var(--dark)}@keyframes pulse-pop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.stat-value.pulse{animation:pulse-pop .3s ease}.stat-unit{font-size:1.5rem}.controls{display:flex;gap:15px;margin-bottom:25px;flex-wrap:wrap}.filter-btn{font-family:Noto Sans KR,sans-serif;font-weight:700;font-size:.95rem;padding:12px 24px;border:3px solid var(--dark);background:#fff;cursor:pointer;box-shadow:var(--shadow-sm);transition:all .1s ease}.filter-btn:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark)}.filter-btn.active{background:var(--accent)}.save-btn{position:absolute;top:50%;right:15px;transform:translateY(-50%);font-family:Noto Sans KR,sans-serif;font-weight:700;font-size:.85rem;padding:8px 16px;border:2px solid var(--dark);background:#fff;color:var(--dark);cursor:pointer;box-shadow:2px 2px 0 var(--dark);transition:all .2s ease}.save-btn:hover:not(:disabled){transform:translateY(-50%) translate(1px,1px);box-shadow:1px 1px 0 var(--dark);background:var(--accent)}.save-btn:disabled{background:#ffffff80;color:#1a1a2e66;border-color:#1a1a2e4d;box-shadow:none;cursor:not-allowed}.stats-card.compact .save-btn{padding:6px 14px;font-size:.8rem}.year-section{margin-bottom:40px}.year-title{font-family:Black Han Sans,sans-serif;font-size:2rem;color:var(--dark);text-shadow:3px 3px 0px var(--primary);margin-bottom:20px;padding-bottom:10px;border-bottom:4px solid var(--dark)}.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:30px}.event-card{background:#fff;border:var(--border);box-shadow:var(--shadow);cursor:pointer;transition:all .15s ease;position:relative;overflow:hidden}.event-card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--dark)}.event-card.selected{background:var(--accent)}.event-cover-wrapper{position:relative;width:100%;height:160px;border-bottom:3px solid var(--dark)}.event-cover{width:100%;height:100%;object-fit:cover}.event-cover-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--secondary) 0%,var(--primary) 100%);display:flex;align-items:center;justify-content:center;font-size:3rem}.event-type-overlay{position:absolute;bottom:10px;left:10px;font-size:.75rem;padding:4px 10px;border:2px solid var(--dark);font-weight:700;border-radius:4px;box-shadow:2px 2px 0 var(--dark)}.event-type-overlay.바다수영{background:#004e89a6;color:#fff}.event-type-overlay.하이킹{background:#2ec4b6a6;color:#fff}.event-type-overlay.여행{background:#ff6b35a6;color:#fff}.event-checkbox{position:absolute;top:10px;left:10px;width:28px;height:28px;background:#fff;border:3px solid var(--dark);border-radius:6px;box-shadow:2px 2px 0 var(--dark);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s ease;color:#fff;z-index:10}.event-checkbox:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--dark);background:var(--accent)}.event-checkbox.checked{background:var(--success)}.event-checkbox svg{width:18px;height:18px}.event-content{padding:12px 15px 15px}.event-date{font-size:.85rem;color:var(--secondary);font-weight:700;margin-bottom:5px}.event-title{font-size:1.1rem;font-weight:900;color:var(--dark);margin-bottom:8px;line-height:1.3}.event-meta{display:flex;justify-content:space-between;align-items:center}.event-type{font-size:.8rem;padding:5px 12px;border:2px solid var(--dark);font-weight:700}.event-type.바다수영{background:var(--secondary);color:#fff}.event-type.하이킹{background:var(--success);color:#fff}.event-type.여행{background:var(--primary);color:#fff}.event-distance{font-family:Black Han Sans,sans-serif;font-size:1.3rem;color:var(--primary);margin-left:auto;text-align:right}.youtube-buttons{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap;align-items:center}.youtube-label{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:red;margin-right:4px;flex-shrink:0}.youtube-label svg{width:100%;height:100%}.youtube-btn{position:relative;display:block;width:36px;height:36px;border-radius:50%;overflow:hidden;border:2px solid var(--dark);box-shadow:2px 2px 0 var(--dark);transition:all .15s ease}.youtube-btn:hover{transform:translate(2px,2px);box-shadow:0 0 0 var(--dark)}.youtube-thumb{width:100%;height:100%;object-fit:cover}.share-card-wrapper{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:none;justify-content:center;align-items:center;z-index:1000;padding:20px}.share-card-wrapper.active{display:flex}.share-card-container{background:#fff;border:var(--border);box-shadow:var(--shadow);width:400px;max-width:95vw}.share-card{padding:20px;background:var(--bg);aspect-ratio:1 / 1;display:flex;flex-direction:column}.share-card-header{text-align:center;margin-bottom:12px}.share-card-title{font-family:Black Han Sans,sans-serif;font-size:1.6rem;color:var(--dark);text-shadow:2px 2px 0px var(--primary)}.share-card-year{font-size:.85rem;color:var(--secondary);font-weight:700}.share-stats-row{display:flex;gap:10px;margin-bottom:12px}.share-stats{flex:1;background:var(--primary);border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark);padding:8px 10px;text-align:center}.share-stats-label{font-size:.7rem;color:var(--dark);font-weight:700}.share-stats-value{font-family:Black Han Sans,sans-serif;font-size:1.8rem;color:#fff;text-shadow:2px 2px 0px var(--dark);line-height:1}.share-calendar{flex:1;display:flex;flex-direction:column;gap:6px}.share-month-row{display:flex;align-items:center;gap:10px;background:#fff;border:2px solid var(--dark);padding:8px 12px;box-shadow:2px 2px 0 var(--dark)}.share-month-label{font-family:Black Han Sans,sans-serif;font-size:.9rem;color:var(--dark);width:42px;flex-shrink:0}.share-month-dots{display:flex;gap:5px;flex:1;flex-wrap:wrap}.share-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--dark);flex-shrink:0}.share-dot.바다수영{background:#48cae4}.share-dot.하이킹{background:#ffb5a7}.share-dot.여행{background:#c8b6ff}.share-dot.empty{background:#00000014;border-color:#00000026}.share-month-km{font-family:Black Han Sans,sans-serif;font-size:.95rem;color:var(--primary);min-width:50px;text-align:right;flex-shrink:0}.share-activity-summary{display:flex;justify-content:center;gap:15px;margin-top:8px;padding:10px;background:#fff;border:2px solid var(--dark);box-shadow:2px 2px 0 var(--dark)}.share-activity-item{display:flex;align-items:center;gap:4px;font-weight:700;font-size:.8rem}.share-activity-type{color:var(--secondary)}.share-activity-count{font-family:Black Han Sans,sans-serif;color:var(--dark)}.share-card-footer{text-align:center;margin-top:12px;font-size:.75rem;color:var(--secondary);font-weight:700}.share-card-actions{display:flex;gap:10px;padding:20px;background:#fff;border-top:3px solid var(--dark)}.share-card-actions button{flex:1;font-family:Noto Sans KR,sans-serif;font-weight:700;font-size:.95rem;padding:12px 20px;border:3px solid var(--dark);cursor:pointer;box-shadow:var(--shadow-sm);transition:all .1s ease}.share-card-actions button:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark)}.download-btn{background:var(--success);color:#fff}.close-btn{background:#fff;color:var(--dark)}.empty-state{text-align:center;padding:60px 20px;background:#fff;border:var(--border);box-shadow:var(--shadow);grid-column:1 / -1}.empty-state-emoji{font-size:4rem;margin-bottom:15px}.empty-state-text{font-size:1.2rem;color:var(--dark);font-weight:700}.home-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;padding:40px 20px;background:#fff;border:var(--border);box-shadow:var(--shadow)}.home-loading .loading-spinner{width:50px;height:50px;border:4px solid rgba(0,0,0,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:20px}.home-loading .loading-text{font-size:1.1rem;color:var(--dark);font-weight:600}@media(max-width:600px){.title{font-size:2rem}.stat-value{font-size:2.5rem}.stats-card{padding:15px 70px 15px 20px;gap:20px}.stats-card.compact{padding:10px 70px 10px 15px}.controls{gap:8px}.filter-btn{padding:8px 12px;font-size:.85rem}.save-btn{right:10px;padding:6px 12px;font-size:.75rem}.event-grid{grid-template-columns:1fr}}.image-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:2000;justify-content:center;align-items:center;flex-direction:column;padding:20px}.image-modal.active{display:flex}.image-modal-close{position:absolute;top:20px;right:25px;font-size:40px;color:#fff;background:none;border:none;cursor:pointer;width:50px;height:50px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.image-modal-close:hover{transform:scale(1.2);color:var(--accent)}.image-modal-content{max-width:90%;max-height:80vh;object-fit:contain;border:4px solid white;border-radius:8px;box-shadow:0 10px 50px #00000080}.image-modal-caption{color:#fff;font-size:1.2rem;font-weight:700;margin-top:15px;text-align:center;text-shadow:1px 1px 3px rgba(0,0,0,.5)}.help-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;z-index:2000;justify-content:center;align-items:center;padding:20px}.help-modal.active{display:flex}.help-modal-content{background:var(--bg);border:4px solid var(--dark);box-shadow:8px 8px 0 var(--dark);width:100%;max-width:400px;animation:helpModalIn .3s ease}@keyframes helpModalIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.help-modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:var(--secondary);border-bottom:4px solid var(--dark)}.help-modal-title{font-family:Black Han Sans,sans-serif;font-size:1.4rem;color:#fff;text-shadow:2px 2px 0px var(--dark)}.help-modal-close{width:32px;height:32px;background:#fff;border:3px solid var(--dark);box-shadow:2px 2px 0 var(--dark);font-size:1.3rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.help-modal-close:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--dark);background:var(--accent)}.help-list{list-style:none;padding:20px;display:flex;flex-direction:column;gap:12px}.help-list li{display:flex;align-items:flex-start;gap:12px;padding:12px 15px;background:#fff;border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark);font-weight:600;font-size:.95rem;color:var(--dark);line-height:1.4}.help-icon{font-size:1.2rem;flex-shrink:0}.help-modal-ok{display:block;width:calc(100% - 40px);margin:0 20px 20px;padding:12px;font-family:Noto Sans KR,sans-serif;font-weight:700;font-size:1rem;background:var(--success);color:#fff;border:3px solid var(--dark);box-shadow:4px 4px 0 var(--dark);cursor:pointer;transition:all .15s ease}.help-modal-ok:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark)}.hamburger-btn{position:fixed;top:20px;left:20px;width:48px;height:48px;background:#fff;border:3px solid var(--dark);box-shadow:var(--shadow-sm);cursor:pointer;z-index:200;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:10px;transition:all .2s ease}.hamburger-btn:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark);background:var(--accent)}.hamburger-btn.active{background:var(--primary)}.hamburger-line{display:block;width:24px;height:3px;background:var(--dark);border-radius:2px;transition:all .3s ease}.hamburger-btn.active .hamburger-line:nth-child(1){transform:translateY(8px) rotate(45deg)}.hamburger-btn.active .hamburger-line:nth-child(2){opacity:0}.hamburger-btn.active .hamburger-line:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.side-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:150;opacity:0;visibility:hidden;transition:all .3s ease}.side-menu-overlay.active{opacity:1;visibility:visible}.side-menu{position:fixed;top:0;left:0;width:300px;max-width:85vw;height:100%;background:var(--bg);border-right:4px solid var(--dark);box-shadow:10px 0 30px #0003;z-index:250;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.side-menu.active{transform:translate(0)}.side-menu-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:var(--primary);border-bottom:4px solid var(--dark)}.side-menu-logo{font-family:Black Han Sans,sans-serif;font-size:1.5rem;color:#fff;text-shadow:2px 2px 0px var(--dark)}.side-menu-close{width:36px;height:36px;background:#fff;border:3px solid var(--dark);box-shadow:2px 2px 0 var(--dark);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.side-menu-close:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--dark);background:var(--accent)}.side-menu-list{list-style:none;flex:1;padding:15px 0;overflow-y:auto}.side-menu-list li{margin:5px 15px}.side-menu-link{display:flex;align-items:center;gap:12px;padding:15px 18px;background:#fff;border:3px solid var(--dark);box-shadow:var(--shadow-sm);text-decoration:none;color:var(--dark);font-weight:700;font-size:1rem;transition:all .15s ease}.side-menu-link:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark);background:var(--accent)}.side-menu-icon{font-size:1.3rem;flex-shrink:0}.side-menu-btn{width:100%;cursor:pointer;border:3px solid var(--dark);font-family:inherit;font-size:inherit}.side-menu-internal{border-bottom:3px solid var(--dark);padding-bottom:0}.side-menu-footer{padding:20px;text-align:center;font-size:.85rem;color:var(--secondary);font-weight:700;border-top:3px solid var(--dark);background:#fff}@media(max-width:600px){.hamburger-btn{width:36px;height:36px;top:12px;left:12px;padding:7px;border-width:2px;box-shadow:2px 2px 0 var(--dark);gap:3px}.hamburger-line{width:16px;height:2px}.hamburger-btn.active .hamburger-line:nth-child(1){transform:translateY(5px) rotate(45deg)}.hamburger-btn.active .hamburger-line:nth-child(3){transform:translateY(-5px) rotate(-45deg)}}.memory-view{position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden}.memory-bg{position:absolute;top:0;left:0;right:0;bottom:0;background-size:cover;background-position:center;z-index:0}.memory-bg:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to top,#000000d9,#0006 40%,#0003 60%,#0000004d)}.memory-bg-gradient{background:linear-gradient(135deg,var(--secondary) 0%,var(--primary) 100%)}.memory-nav{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:20px;z-index:10}.memory-back-btn{width:48px;height:48px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease}.memory-back-btn:hover{background:#ffffff40;transform:scale(1.05)}.memory-back-btn svg{width:24px;height:24px}.memory-select-btn{width:48px;height:48px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease}.memory-select-btn:hover{background:#ffffff40;transform:scale(1.05)}.memory-select-btn.checked{background:var(--success);border-color:var(--success)}.memory-select-btn svg{width:24px;height:24px}.memory-content{position:absolute;left:0;right:0;padding:30px 25px 40px;z-index:5}.memory-content-top{top:80px;bottom:auto;padding-bottom:60px}.memory-content-bottom{bottom:0;top:auto;padding-top:60px;padding-bottom:40px}.memory-info{max-width:600px;margin:0 auto}.memory-type{display:inline-block;font-size:.85rem;padding:6px 14px;border-radius:20px;font-weight:700;margin-bottom:15px;letter-spacing:.5px}.memory-type.바다수영{background:#004e89cc;color:#fff}.memory-type.하이킹{background:#2ec4b6cc;color:#fff}.memory-type.여행{background:#ff6b35cc;color:#fff}.memory-date-row{display:flex;align-items:center;gap:15px;margin-bottom:10px}.memory-date{font-size:1.1rem;color:#fffc;font-weight:600;letter-spacing:1px}.memory-distance-inline{font-family:Black Han Sans,sans-serif;font-size:1.3rem;color:var(--accent);text-shadow:1px 1px 4px rgba(0,0,0,.5)}.memory-title{font-family:sans-serif;font-size:2.5rem;color:#fff;line-height:1.2;margin-bottom:15px;text-shadow:2px 2px 8px rgba(0,0,0,.5)}.memory-distance{display:inline-flex;align-items:center;gap:8px;font-family:Black Han Sans,sans-serif;font-size:1.5rem;color:var(--accent);margin-bottom:20px}.memory-distance svg{width:24px;height:24px;opacity:.9}.memory-youtube{margin-top:10px}.memory-youtube .youtube-buttons{justify-content:flex-start}.memory-youtube .youtube-btn{width:44px;height:44px;border-color:#ffffff4d;box-shadow:0 2px 10px #0000004d}.memory-youtube .youtube-label{width:28px;height:28px}.memory-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:5}.memory-loading .loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}.memory-loading .loading-text{color:#fff;font-size:1.1rem;font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}.memory-not-found{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;background:#fff;border:var(--border);box-shadow:var(--shadow);padding:60px 40px;z-index:5}.not-found-emoji{font-size:4rem;margin-bottom:15px}.not-found-text{font-size:1.2rem;color:var(--dark);font-weight:700;margin-bottom:20px}.back-to-list-btn{font-family:Noto Sans KR,sans-serif;font-weight:700;font-size:1rem;padding:12px 25px;background:var(--primary);color:#fff;border:3px solid var(--dark);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .15s ease}.back-to-list-btn:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark)}@media(max-width:600px){.memory-nav{padding:15px}.memory-back-btn,.memory-select-btn{width:42px;height:42px}.memory-back-btn svg,.memory-select-btn svg{width:20px;height:20px}.memory-content{padding:20px 20px 30px}.memory-content-top{top:60px;padding-bottom:40px}.memory-content-bottom{padding-top:40px;padding-bottom:30px}.memory-distance-inline{font-size:1.1rem}.memory-title{font-size:1.8rem}.memory-date{font-size:1rem}.memory-distance{font-size:1.3rem}.memory-type{font-size:.8rem;padding:5px 12px}}.member-page{min-height:100vh;padding-bottom:40px}.member-nav{display:flex;justify-content:space-between;align-items:center;padding:20px;max-width:800px;margin:0 auto}.member-back-btn{width:48px;height:48px;background:#fff;border:3px solid var(--dark);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--dark);transition:all .15s ease}.member-back-btn:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark);background:var(--accent)}.member-back-btn svg{width:24px;height:24px}.member-profile-header{display:flex;flex-direction:column;align-items:center;gap:15px;padding:20px;max-width:800px;margin:0 auto 20px}.member-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:4px solid var(--dark);box-shadow:var(--shadow-sm)}.member-avatar-placeholder{width:80px;height:80px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:Black Han Sans,sans-serif;font-size:2rem;border:4px solid var(--dark);box-shadow:var(--shadow-sm)}.member-title{font-size:1.8rem;color:var(--dark);text-shadow:3px 3px 0px var(--primary);text-align:center}.member-loading,.member-error,.member-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:40px 20px}.member-loading .loading-spinner{width:50px;height:50px;border:4px solid rgba(0,0,0,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:20px}.member-loading .loading-text{font-size:1.1rem;color:var(--dark);font-weight:600}.error-emoji,.empty-emoji{font-size:4rem;margin-bottom:15px}.error-text,.empty-text{font-size:1.2rem;color:var(--dark);font-weight:700;margin-bottom:20px}.member-summary-card{max-width:400px;margin:0 auto 30px;padding:20px;background:var(--bg);border:4px solid var(--dark);box-shadow:var(--shadow)}.summary-header{text-align:center;margin-bottom:15px}.summary-title{font-family:Black Han Sans,sans-serif;font-size:1.6rem;color:var(--dark);text-shadow:2px 2px 0px var(--primary)}.summary-subtitle{font-size:.9rem;color:var(--secondary);font-weight:700}.summary-stats-row{display:flex;gap:10px;margin-bottom:15px}.summary-stat{flex:1;background:var(--primary);border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark);padding:10px 12px;text-align:center}.summary-stat-label{font-size:.75rem;color:var(--dark);font-weight:700}.summary-stat-value{font-family:Black Han Sans,sans-serif;font-size:1.8rem;color:#fff;text-shadow:2px 2px 0px var(--dark);line-height:1}.summary-stat-value span{font-size:2rem}.summary-calendar{display:flex;flex-direction:column;gap:16px;margin-bottom:12px}.summary-year-group{display:flex;flex-direction:column;gap:6px}.summary-year-label{font-family:Black Han Sans,sans-serif;font-size:1rem;color:var(--dark);padding:4px 0;border-bottom:2px solid var(--dark);margin-bottom:2px}.summary-month-row{display:flex;align-items:center;gap:10px;background:#fff;border:2px solid var(--dark);padding:8px 12px;box-shadow:2px 2px 0 var(--dark)}.summary-month-label{font-family:Black Han Sans,sans-serif;font-size:.9rem;color:var(--dark);width:42px;flex-shrink:0}.summary-month-dots{display:flex;gap:5px;flex:1;flex-wrap:wrap}.summary-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--dark);flex-shrink:0}.summary-dot.바다수영{background:#48cae4}.summary-dot.하이킹{background:#ffb5a7}.summary-dot.여행{background:#c8b6ff}.summary-month-km{font-family:Black Han Sans,sans-serif;font-size:.95rem;color:var(--primary);min-width:50px;text-align:right;flex-shrink:0}.summary-activity{display:grid;grid-template-columns:repeat(2,auto);justify-content:center;gap:8px 20px;padding:12px;background:#fff;border:2px solid var(--dark);box-shadow:2px 2px 0 var(--dark)}.summary-activity-item{display:flex;align-items:center;gap:4px;font-weight:700;font-size:.85rem}.summary-activity-type{color:var(--secondary)}.summary-activity-count{font-family:Black Han Sans,sans-serif;color:var(--dark)}.member-events-section{max-width:1200px;margin:0 auto;padding:0 20px}.member-events-section .event-grid{grid-template-columns:repeat(4,1fr)}.member-events-title{font-family:Black Han Sans,sans-serif;font-size:1.5rem;color:var(--dark);text-shadow:2px 2px 0px var(--accent);margin-bottom:20px;padding-bottom:10px;border-bottom:3px solid var(--dark)}.member-events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}.member-event-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a;transition:all .2s ease}.member-event-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #00000026}.member-event-card.바다수영{border-top:4px solid var(--secondary)}.member-event-card.하이킹{border-top:4px solid var(--success)}.member-event-card.여행{border-top:4px solid var(--primary)}.member-event-cover{position:relative;width:100%;height:140px;overflow:hidden}.member-event-cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.member-event-card:hover .member-event-cover img{transform:scale(1.05)}.member-event-cover-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--secondary) 0%,var(--primary) 100%)}.member-event-overlay{position:absolute;bottom:0;left:0;right:0;padding:10px;background:linear-gradient(to top,rgba(0,0,0,.6),transparent)}.member-event-type{display:inline-block;font-size:.75rem;padding:4px 10px;border-radius:12px;font-weight:700;color:#fff}.member-event-card.바다수영 .member-event-type{background:var(--secondary)}.member-event-card.하이킹 .member-event-type{background:var(--success)}.member-event-card.여행 .member-event-type{background:var(--primary)}.member-event-info{padding:15px}.member-event-date{font-size:.8rem;color:var(--secondary);font-weight:600;margin-bottom:5px}.member-event-title{font-size:1rem;font-weight:800;color:var(--dark);line-height:1.3;margin-bottom:8px}.member-event-distance{font-family:Black Han Sans,sans-serif;font-size:1.2rem;color:var(--primary)}@media(max-width:1024px){.member-events-section .event-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.member-events-section .event-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.member-nav{padding:15px}.member-back-btn{width:40px;height:40px}.member-profile-header{padding:15px;gap:12px}.member-avatar,.member-avatar-placeholder{width:64px;height:64px;font-size:1.5rem}.member-title{font-size:1.4rem}.member-summary-card{margin:0 15px 25px}.member-events-section{padding:0 15px}.member-events-section .event-grid{grid-template-columns:1fr}}.members-list-page{min-height:100vh;padding-bottom:40px}.members-list-nav{display:flex;justify-content:space-between;align-items:center;padding:20px;max-width:1200px;margin:0 auto}.members-list-back-btn{width:48px;height:48px;background:#fff;border:3px solid var(--dark);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--dark);transition:all .15s ease}.members-list-back-btn:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark);background:var(--accent)}.members-list-back-btn svg{width:24px;height:24px}.members-list-title{font-family:Black Han Sans,sans-serif;font-size:1.8rem;color:var(--dark);text-shadow:3px 3px 0px var(--primary)}.members-list-loading,.members-list-error,.members-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:40px 20px}.members-list-loading .loading-spinner{width:50px;height:50px;border:4px solid rgba(0,0,0,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:20px}.members-list-loading .loading-text{font-size:1.1rem;color:var(--dark);font-weight:600}.members-list-container{max-width:1200px;margin:0 auto;padding:0 20px}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.member-card{display:flex;align-items:center;gap:15px;padding:16px 20px;background:#fff;border:3px solid var(--dark);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .15s ease;text-align:left;width:100%;font-family:inherit}.member-card:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--dark);background:var(--accent)}.member-card-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;border:3px solid var(--dark);flex-shrink:0}.member-card-avatar-placeholder{width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:Black Han Sans,sans-serif;font-size:1.5rem;border:3px solid var(--dark);flex-shrink:0}.member-card-info{flex:1;min-width:0}.member-card-name{font-weight:800;font-size:1.1rem;color:var(--dark);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-card-events{font-size:.9rem;color:var(--secondary);font-weight:600}@media(max-width:600px){.members-list-nav{padding:15px}.members-list-back-btn{width:40px;height:40px}.members-list-title{font-size:1.4rem}.members-list-container{padding:0 15px}.members-grid{grid-template-columns:1fr;gap:15px}.member-card{padding:12px 15px;gap:12px}.member-card-avatar,.member-card-avatar-placeholder{width:48px;height:48px;font-size:1.2rem}.member-card-name{font-size:1rem}.member-card-events{font-size:.85rem}}.navbar{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#fff;border-bottom:3px solid var(--dark);box-shadow:0 4px 0 var(--dark)}.navbar-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.navbar-logo{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--primary);border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark);cursor:pointer;transition:all .15s ease;flex-shrink:0;color:#fff}.navbar-logo:hover{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark);background:var(--accent);color:var(--dark)}.navbar-logo svg{width:22px;height:22px}.navbar-breadcrumbs{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden}.breadcrumb-separator{color:var(--dark);opacity:.4;font-weight:700;flex-shrink:0}.breadcrumb-link{font-family:inherit;font-size:.9rem;font-weight:700;color:var(--secondary);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s ease;white-space:nowrap}.breadcrumb-link:hover{background:var(--accent);color:var(--dark)}.breadcrumb-current{font-size:.9rem;font-weight:800;color:var(--dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.navbar-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.navbar-profile{position:relative;display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:0;transition:opacity .15s ease}.navbar-profile:hover{opacity:.8}.navbar-profile-name{font-weight:700;font-size:.9rem;color:var(--dark);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-avatar-wrapper{position:relative;width:40px;height:40px;flex-shrink:0}.navbar-avatar-loading{position:absolute;top:0;left:0}.navbar-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:3px solid var(--dark);box-shadow:2px 2px 0 var(--dark);opacity:0}.navbar-avatar.loaded{opacity:1}.navbar-avatar-placeholder{width:40px;height:40px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;border:3px solid var(--dark);box-shadow:2px 2px 0 var(--dark)}.navbar-login{font-family:inherit;font-size:.9rem;font-weight:700;padding:8px 16px;background:var(--secondary);color:#fff;border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark);cursor:pointer;transition:all .15s ease}.navbar-login:hover{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark);background:var(--accent);color:var(--dark)}.navbar-hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:40px;height:40px;background:#fff;border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark);cursor:pointer;transition:all .15s ease;flex-shrink:0}.navbar-hamburger:hover{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark);background:var(--accent)}.hamburger-line{width:18px;height:2px;background:var(--dark);transition:all .2s ease}.navbar-profile-wrapper{position:relative}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:#fff;border:3px solid var(--dark);box-shadow:4px 4px 0 var(--dark);z-index:200}.dropdown-header{padding:12px 16px;border-bottom:2px solid var(--dark);background:var(--bg)}.dropdown-name{font-weight:800;font-size:.95rem;color:var(--dark)}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:none;border:none;font-family:inherit;font-size:.9rem;font-weight:600;color:var(--dark);cursor:pointer;transition:background .15s ease;text-align:left}.dropdown-item:hover{background:var(--accent)}.dropdown-icon{font-size:1rem;width:20px;text-align:center}.dropdown-badge{margin-left:auto;background:var(--primary);color:#fff;font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:10px}.dropdown-divider{height:2px;background:var(--dark);margin:0}.dropdown-item-logout:hover{background:#ffebee}.page-header{padding:30px 20px 20px;max-width:1200px;margin:0 auto}.page-title{font-family:Black Han Sans,sans-serif;font-size:2rem;color:var(--dark);text-shadow:3px 3px 0px var(--primary)}@media(max-width:600px){.navbar{padding:10px 15px}.navbar-logo{width:36px;height:36px}.navbar-logo svg{width:18px;height:18px}.breadcrumb-link,.breadcrumb-current{font-size:.8rem}.breadcrumb-current{max-width:120px}.navbar-profile-name{display:none}.navbar-avatar-wrapper{width:36px;height:36px}.navbar-avatar,.navbar-avatar-placeholder{width:36px;height:36px;font-size:.9rem}.navbar-login{font-size:.8rem;padding:6px 12px}.navbar-hamburger{width:36px;height:36px;gap:3px}.hamburger-line{width:16px}.profile-dropdown{min-width:180px;right:-10px}.dropdown-item{padding:10px 14px;font-size:.85rem}.page-header{padding:20px 15px 15px}.page-title{font-size:1.6rem}}.modal-overlay.svelte-jjze72{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:300}.profile-edit-modal.svelte-jjze72{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:360px;background:#fff;border:4px solid var(--dark);box-shadow:8px 8px 0 var(--dark);z-index:301}.modal-header.svelte-jjze72{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:3px solid var(--dark);background:var(--bg)}.modal-title.svelte-jjze72{font-family:Black Han Sans,sans-serif;font-size:1.3rem;color:var(--dark);margin:0}.modal-close.svelte-jjze72{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--dark);line-height:1}.modal-body.svelte-jjze72{padding:20px;display:flex;flex-direction:column;gap:16px}.avatar-edit.svelte-jjze72{display:flex;align-items:center;gap:16px}.edit-avatar.svelte-jjze72{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark)}.edit-avatar-placeholder.svelte-jjze72{width:72px;height:72px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;border:3px solid var(--dark);box-shadow:3px 3px 0 var(--dark)}.btn-upload.svelte-jjze72{padding:8px 14px;background:var(--secondary);border:2px solid var(--dark);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:2px 2px 0 var(--dark);transition:all .15s ease}.btn-upload.svelte-jjze72:hover:not(:disabled){transform:translate(1px,1px);box-shadow:1px 1px 0 var(--dark)}.btn-upload.svelte-jjze72:disabled{opacity:.6;cursor:not-allowed}.edit-field.svelte-jjze72{display:flex;flex-direction:column;gap:6px}.edit-field.svelte-jjze72 label:where(.svelte-jjze72){font-size:.85rem;font-weight:700;color:var(--dark)}.edit-field.svelte-jjze72 input:where(.svelte-jjze72){padding:10px 12px;border:3px solid var(--dark);font-size:1rem;font-family:inherit}.edit-field.svelte-jjze72 input:where(.svelte-jjze72):focus{outline:none;box-shadow:3px 3px 0 var(--dark)}.modal-footer.svelte-jjze72{display:flex;gap:10px;padding:16px 20px;border-top:3px solid var(--dark);background:var(--bg)}.btn-cancel.svelte-jjze72,.btn-save.svelte-jjze72{flex:1;padding:12px 16px;border:3px solid var(--dark);font-size:.95rem;font-weight:700;cursor:pointer;box-shadow:3px 3px 0 var(--dark);transition:all .15s ease}.btn-cancel.svelte-jjze72{background:#fff;color:var(--dark)}.btn-save.svelte-jjze72{background:var(--accent);color:var(--dark)}.btn-cancel.svelte-jjze72:hover:not(:disabled),.btn-save.svelte-jjze72:hover:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark)}.btn-cancel.svelte-jjze72:disabled,.btn-save.svelte-jjze72:disabled{opacity:.6;cursor:not-allowed}.login-modal-overlay.svelte-1at1vew{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:300;padding:20px}.login-modal.svelte-1at1vew{width:100%;max-width:340px;background:#fff;border:4px solid var(--dark);box-shadow:8px 8px 0 var(--dark);animation:svelte-1at1vew-modalIn .2s ease}@keyframes svelte-1at1vew-modalIn{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.login-modal-header.svelte-1at1vew{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:3px solid var(--dark);background:var(--secondary)}.login-modal-title.svelte-1at1vew{font-family:Black Han Sans,sans-serif;font-size:1.2rem;color:#fff;text-shadow:2px 2px 0 var(--dark);margin:0}.login-modal-close.svelte-1at1vew{background:#fff;border:2px solid var(--dark);box-shadow:2px 2px 0 var(--dark);width:28px;height:28px;font-size:1.3rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.login-modal-close.svelte-1at1vew:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--dark);background:var(--accent)}.login-modal-body.svelte-1at1vew{padding:30px 20px;text-align:center;background:var(--bg)}.login-modal-icon.svelte-1at1vew{font-size:3rem;margin-bottom:15px}.login-modal-message.svelte-1at1vew{font-size:1rem;font-weight:600;color:var(--dark);line-height:1.5;margin:0}.login-modal-footer.svelte-1at1vew{display:flex;gap:10px;padding:16px 20px;border-top:3px solid var(--dark);background:#fff}.btn-cancel.svelte-1at1vew,.btn-login.svelte-1at1vew{flex:1;padding:12px 16px;border:3px solid var(--dark);font-family:inherit;font-size:.95rem;font-weight:700;cursor:pointer;box-shadow:3px 3px 0 var(--dark);transition:all .15s ease}.btn-cancel.svelte-1at1vew{background:#fff;color:var(--dark)}.btn-login.svelte-1at1vew{background:var(--primary);color:#fff}.btn-cancel.svelte-1at1vew:hover:not(:disabled),.btn-login.svelte-1at1vew:hover:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark)}.btn-cancel.svelte-1at1vew:disabled,.btn-login.svelte-1at1vew:disabled{opacity:.6;cursor:not-allowed}
