@import url(https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css);:root{--bg:#eef3f8;--primary:#05c46b;--primary-dark:#095;--text:#09131f;--muted:#6c7a92;--border:#09131f14;--card:#fffffff0;--radius-lg:28px;color-scheme:light;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{-ms-overflow-style:none;scrollbar-width:none}::-webkit-scrollbar{background:#0000!important;display:none!important;height:0!important;width:0!important}body,html{-ms-overflow-style:none;background:#eef3f8;background:var(--bg);height:100%;margin:0;scrollbar-width:none}body::-webkit-scrollbar,html::-webkit-scrollbar{display:none;height:0;width:0}#root{-ms-overflow-style:none;min-height:100vh;scrollbar-width:none;width:100%}#root::-webkit-scrollbar{display:none!important;height:0!important;width:0!important}.app-root{display:flex;flex-direction:column;margin:0 auto;max-width:420px;min-height:100vh;width:100%}@media (min-width:421px){.app-root{margin:0;max-width:100%}}.app-error-banner{background:#ffe0e0;color:#d14343;font-size:14px;font-weight:600;padding:12px 20px;text-align:center}.mobile-shell{background:#fffffff0;background:var(--card);border-radius:0;box-shadow:none;display:flex;flex-direction:column;min-height:100vh;overflow:hidden;width:100%}.mobile-shell.splash{align-items:center;background:linear-gradient(135deg,#00d775,#00b362);color:#fff;justify-content:center;text-align:center}.mobile-shell.main{background:linear-gradient(180deg,#f8fbff,#f2f7ff);display:flex;flex-direction:column}.screen-section{color:#09131f;color:var(--text)}.page-heading{margin-bottom:20px}.page-heading .date{color:#6c7a92;color:var(--muted);font-size:13px;margin:0}.page-heading h2{font-size:22px;font-weight:700;line-height:1.4;margin:6px 0 0}.page-subtitle{color:#6c7a92;color:var(--muted);font-size:14px;margin:4px 0 0}.stat-pill{background:#09131f0d;border-radius:18px;padding:16px 18px}.stat-pill p{color:#6c7a92;color:var(--muted);font-size:13px;margin:0}.stat-pill strong{color:#09131f;color:var(--text);display:block;font-size:16px;margin-top:4px}.stat-pill.streak{background:#ebfff5}.stat-pill.total{background:#f0f6ff}.stat-pill.rank{background:#fef4ff}.stat-pill.danger{background:#fff5f5}.stat-pill.highlight{background:#fff8e6}.empty-state{background:#09131f0a;border-radius:28px;border-radius:var(--radius-lg);font-size:14px;padding:32px 20px;text-align:center}.app-loading,.empty-state{color:#6c7a92;color:var(--muted)}.app-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.app-spinner{animation:spin .8s linear infinite;border:4px solid #05c46b1a;border-radius:50%;border-top-color:#05c46b;height:40px;width:40px}@media (max-width:420px){.app-root{padding:24px 8px}.mobile-shell{border-radius:24px}.screen{padding:0 18px 20px}}.toast-container{display:flex;flex-direction:column;gap:12px;pointer-events:none;position:fixed;right:20px;top:80px;z-index:10000}.toast{animation:slideIn .3s ease-out;background:#fff;border-left:4px solid;border-radius:12px;box-shadow:0 4px 20px #09131f26,0 2px 8px #09131f1a;max-width:400px;min-width:280px;pointer-events:auto}.toast.toast-success{border-left-color:#05c46b}.toast.toast-error{border-left-color:#ff4757}.toast.toast-warning{border-left-color:#ffa502}.toast.toast-info{border-left-color:#3742fa}.toast-content{align-items:center;display:flex;gap:12px;justify-content:space-between;padding:14px 16px}.toast-message{color:var(--text);flex:1 1;font-size:14px;font-weight:500;line-height:1.4}.toast-close{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--muted);cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:20px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:20px}.toast-close:hover{background:#09131f14;color:var(--text)}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:640px){.toast-container{left:16px;right:16px;top:70px}.toast{max-width:100%;min-width:auto}}.app-header{display:flex;flex-direction:column;gap:14px;padding:24px 26px 18px}.header-top{gap:16px;justify-content:space-between}.brand,.header-top{align-items:center;display:flex}.brand{gap:10px}.app-logo{flex-shrink:0;justify-content:center}.app-logo,.brand-copy{align-items:center;display:flex}.brand-name{color:var(--text);font-size:18px;font-weight:700}.brand-name-accent{color:#05c46b}.header-actions{gap:12px}.header-actions,.header-user{align-items:center;display:flex}.header-user{gap:10px}.header-user-avatar{align-items:center;background:#05c46b;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;overflow:hidden;position:relative;transition:opacity .2s ease;width:40px}.header-user-avatar:hover{opacity:.8}.header-user-avatar img{height:100%;object-fit:cover;width:100%}.header-user-avatar-loading{align-items:center;background:#0009;border-radius:50%;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0}.loading-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.header-user-info{align-items:flex-end;display:flex;flex-direction:column;gap:2px}.header-user-name{color:var(--text);font-size:13px;font-weight:600}.header-user-meta{color:var(--muted);font-size:12px}.header-settings{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border:1px solid #09131f14;border-radius:16px;padding:16px}.header-settings-form{display:flex;flex-direction:column;gap:12px}.header-settings-form label{color:var(--muted);font-size:12px}.header-settings-form input{border:1px solid #09131f26;border-radius:12px;font-size:14px;height:40px;padding:0 12px}.header-settings-actions{display:flex;gap:8px;justify-content:flex-end}.header-settings-actions button,.header-settings-form button.danger{border:none;border-radius:12px;cursor:pointer;font-weight:600;padding:10px 16px}.header-settings-actions button{background:#09131f0f;color:var(--text)}.header-settings-actions button.primary{background:#05c46b;color:#fff}.header-settings-form button.danger{background:#ff63471f;color:#ff5c5c}.delete-photo-button{background:#ff63471a;border:none;border-radius:12px;color:#ff5c5c;cursor:pointer;font-size:14px;font-weight:600;margin-top:8px;padding:10px 16px;transition:all .2s ease;width:100%}.delete-photo-button:hover:not(:disabled){background:#ff634726}.delete-photo-button:disabled{cursor:not-allowed;opacity:.6}.icon-button{align-items:center;background:#09131f0f;border:none;border-radius:16px;color:var(--text);cursor:pointer;display:inline-flex;height:40px;justify-content:center;width:40px}.icon-button svg{display:block;flex-shrink:0;height:22px;width:22px}.bottom-nav{grid-gap:10px;background:#fff;border-top:1px solid #09131f0f;bottom:0;box-shadow:0 -12px 15px #09131f05;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);left:0;padding:12px 18px calc(18px + env(safe-area-inset-bottom));position:fixed;right:0;z-index:20}.bottom-nav button{align-items:center;background:none;border:none;color:var(--muted);cursor:pointer;display:flex;flex-direction:column;font-size:12px;font-weight:600;gap:6px;justify-content:center;padding:6px 0}.bottom-nav button.active{color:var(--primary)}.bottom-nav svg{display:block;flex-shrink:0;height:22px;width:22px}.bottom-nav svg.active{color:var(--primary)}.screen{-ms-overflow-style:none!important;flex:1 1;min-height:0;overflow-y:auto;padding:0 24px calc(110px + env(safe-area-inset-bottom));position:relative;scrollbar-width:none!important}.screen::-webkit-scrollbar{height:0!important;width:0!important}.screen::-webkit-scrollbar,.screen::-webkit-scrollbar-track{background:#0000!important;display:none!important}.screen::-webkit-scrollbar-thumb{background:#0000!important;display:none!important}@media (max-width:420px){.app-header{padding:15px 18px 16px}.header-user-avatar{font-size:14px;height:36px;width:36px}.header-user{gap:8px}}.calendar-container{background:linear-gradient(135deg,#fff,#f8fffc);border:2px solid #05c46b1a;border-radius:20px;padding:24px;transition:all .2s ease}.calendar-header{border-bottom:1px solid #09131f14;display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding-bottom:16px}.calendar-navigation{align-items:center;display:flex;gap:16px;justify-content:space-between}.calendar-header h3{color:var(--text);flex:1 1;font-size:18px;font-weight:700;letter-spacing:-.3px;margin:0;text-align:center}.calendar-nav-button{align-items:center;background:#09131f0f;border:none;border-radius:8px;color:var(--text);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;padding:0;position:relative;transition:all .2s ease;width:28px}.calendar-nav-button:before{border-right:2px solid;border-top:2px solid;content:"";height:7px;position:absolute;transition:all .2s ease;width:7px}.calendar-nav-button-prev:before{transform:rotate(-135deg)}.calendar-nav-button-next:before{transform:rotate(45deg)}.calendar-nav-button:hover:not(:disabled){background:#09131f1f;color:#0b6bff}.calendar-nav-button:disabled{cursor:not-allowed;opacity:.25}.calendar-today-button{align-self:center;background:linear-gradient(135deg,#0b6bff1a,#0956cc14);border:1px solid #0b6bff33;border-radius:10px;color:#0b6bff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 16px;transition:all .2s ease}.calendar-today-button:hover{background:linear-gradient(135deg,#0b6bff26,#0956cc1f);transform:translateY(-1px)}.calendar-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(7,1fr);margin-bottom:20px}.calendar-weekday{color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.5px;padding:10px 0;text-align:center;text-transform:uppercase}.calendar-day{align-items:center;aspect-ratio:1;background:#09131f0a;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.calendar-day:hover:not(.empty){background:#09131f0f;transform:scale(1.05)}.calendar-day.empty{background:#0000;cursor:default}.calendar-day.verified{background:linear-gradient(135deg,#05c46b33,#03a35826);border:2px solid #05c46b4d}.calendar-day.verified:hover{background:linear-gradient(135deg,#05c46b40,#03a35833);transform:scale(1.08)}.calendar-day.today{background:linear-gradient(135deg,#0b6bff33,#0956cc26);border:2px solid #0b6bff66;font-weight:700}.calendar-day.today:hover{transform:scale(1.08)}.calendar-day.today.verified{background:linear-gradient(135deg,#05c46b4d,#03a35840);border:2px solid #05c46b80}.calendar-day.today.verified:hover{box-shadow:0 4px 12px #05c46b66}.calendar-day-number{color:var(--text);font-size:14px;font-weight:600;transition:color .2s ease}.calendar-day.verified .calendar-day-number{color:#028858;font-weight:700}.calendar-day.today .calendar-day-number{color:#0b6bff}.calendar-day-badge{background:linear-gradient(135deg,#05c46b,#04b85a);border-radius:50%;bottom:4px;box-shadow:0 1px 4px #05c46b66;height:12px;position:absolute;right:4px;width:12px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.calendar-legend{border-top:1px solid #09131f14;display:flex;flex-wrap:wrap;gap:24px;justify-content:center;padding-top:16px}.legend-item{align-items:center;color:var(--muted);display:flex;font-size:12px;font-weight:500;gap:8px}.legend-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.legend-dot.verified{background:linear-gradient(135deg,#05c46b,#04b85a);box-shadow:0 2px 4px #05c46b4d}.legend-dot.today{background:linear-gradient(135deg,#0b6bff,#0a5ce6);box-shadow:0 2px 4px #0b6bff4d}@media (max-width:420px){.calendar-container{border-radius:18px;padding:20px}.calendar-header{margin-bottom:18px;padding-bottom:14px}.calendar-header h3{font-size:17px}.calendar-nav-button{height:26px;width:26px}.calendar-nav-button:before{border-width:1.5px;height:6px;width:6px}.calendar-grid{gap:8px;margin-bottom:18px}.calendar-day{border-radius:12px}.calendar-day-number{font-size:13px}.calendar-day-badge{bottom:3px;height:10px;right:3px;width:10px}.calendar-legend{gap:16px;padding-top:14px}}.character-container{background:#0000;border:none;border-radius:0;flex-direction:column;gap:0;padding:0}.character-container,.character-display{align-items:center;display:flex;position:relative}.character-display{justify-content:center;margin:8px 0 20px}.character-emoji{animation:float 3s ease-in-out infinite;font-size:80px;line-height:1;transition:transform .3s ease}.character-emoji.stage-bronze{font-size:70px}.character-emoji.stage-silver{font-size:80px}.character-emoji.stage-gold{font-size:90px}.character-emoji.stage-platinum{font-size:100px}.character-emoji.stage-diamond{font-size:110px}.character-emoji.stage-master{font-size:120px}.character-streak-badge{background:#05c46b;border-radius:12px;color:#fff;font-size:12px;font-weight:600;left:0;padding:6px 12px;position:absolute;top:0;white-space:nowrap;z-index:1}.character-info{flex:1 1;min-width:0;text-align:center;width:100%}.character-name{color:var(--text);font-size:22px;font-weight:700;letter-spacing:-.3px;margin:0 0 8px}.character-description{color:var(--muted);font-size:14px;line-height:1.5;margin:0 0 20px}.character-progress{width:100%}.character-progress-label{color:var(--muted);font-size:13px;font-weight:500;margin-bottom:10px;text-align:center}.character-progress-bar{background:#09131f14;border-radius:10px;height:8px;overflow:hidden;width:100%}.character-progress-fill{background:linear-gradient(90deg,#05c46b,#02b95d);border-radius:10px;height:100%;transition:width .5s ease}@media (max-width:420px){.character-container{flex-direction:column;gap:0}.character-display{margin:16px 0 12px}.character-emoji{font-size:60px!important}.character-emoji.stage-bronze{font-size:56px!important}.character-emoji.stage-silver{font-size:60px!important}.character-emoji.stage-gold{font-size:70px!important}.character-emoji.stage-platinum{font-size:80px!important}.character-emoji.stage-diamond{font-size:90px!important}.character-emoji.stage-master{font-size:100px!important}.character-name{font-size:18px}.character-description{font-size:13px}}.skeleton{animation:skeleton-loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,#09131f0f,#09131f1a 50%,#09131f0f);background-size:200% 100%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:#fff;border:1px solid #09131f14;border-radius:12px;display:flex;gap:16px;padding:16px}.skeleton-content{display:flex;flex:1 1;flex-direction:column;gap:8px;justify-content:center}.skeleton-pill{width:100%}.status-card{background:linear-gradient(145deg,#f5fff9,#ebfff5);border:none;border-radius:20px;box-shadow:0 4px 20px #05c46b14,0 1px 3px #05c46b1a;color:var(--text);margin-bottom:18px;padding:32px 28px;position:relative}.status-card h3{font-size:24px;font-weight:700;margin:8px 0 5px}.status-points{font-size:26px;font-weight:600;margin:10px 0}.status-progress{align-items:left;background:#ffffff40;border-radius:12px;height:8px;overflow:hidden;width:100%}.status-progress-bar{background:#fff;border-radius:inherit;height:100%}.stat-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:26px}.home-highlights{display:flex;flex-direction:column;gap:14px;margin-bottom:40px}.home-highlights h3{font-size:16px;font-weight:600;margin:0}.info-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb3;box-shadow:0 2px 8px #05c46b26;height:36px;position:absolute;right:20px;top:20px;transition:all .2s ease;width:36px}.info-button:hover{background:#ffffffe6;transform:scale(1.05)}.home-modal{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:24px;position:fixed;z-index:999}.home-modal-content{background:#fff;border-radius:20px;box-shadow:0 8px 24px #09131f1f;display:flex;flex-direction:column;gap:16px;max-height:calc(100vh - 48px);overflow:hidden;padding:20px;width:min(400px,100%)}.home-modal-content header{align-items:center;display:flex;gap:12px;justify-content:space-between}.home-modal-content header h3{color:var(--text);font-size:16px;font-weight:700;margin:0}.home-modal-content header button{background:#09131f0f;border:none;border-radius:8px;color:var(--text);cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background .2s ease}.home-modal-content header button:hover{background:#09131f1a}.home-modal-body{display:flex;flex:1 1;flex-direction:column;gap:0;min-height:0;overflow-y:auto}.home-grade-list{display:flex;flex-direction:column;gap:8px}.home-grade-card{align-items:center;background:#fff;border:1px solid #09131f14;border-radius:12px;display:flex;gap:12px;justify-content:space-between;padding:16px 18px;transition:all .2s ease}.home-grade-card:hover{background:#09131f05}.home-grade-card.active{background:#05c46b0f;border-color:#05c46b33}.home-grade-card-left{align-items:center;display:flex;flex:1 1;gap:14px}.home-grade-card-emoji{flex-shrink:0;font-size:28px;line-height:1}.home-grade-card-content{display:flex;flex-direction:column;gap:4px}.home-grade-card-content h4{color:var(--text);font-size:15px;font-weight:600;letter-spacing:-.2px;margin:0}.home-grade-card-content span{color:var(--muted);font-size:13px;font-weight:400}.home-grade-card-badge{background:#05c46b;border-radius:12px;color:#fff;flex-shrink:0;font-size:12px;font-weight:600;padding:4px 10px}.home-verification-section{background:#fff;border-radius:20px;display:flex;flex-direction:column;gap:16px;margin-bottom:18px;padding:20px}.home-verification-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.home-verification-header h3{color:var(--text);font-size:16px;font-weight:700;margin:0}.home-verification-badge{border-radius:12px;font-size:12px;font-weight:600;padding:6px 12px}.home-verification-badge.available{background:#05c46b26;color:#039a53}.home-verification-badge.completed{background:#09131f14;color:var(--muted)}.home-verification-message{color:var(--muted);font-size:14px;line-height:1.5;margin:0}.home-verification-button{background:#05c46b;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s ease}.home-verification-button:hover{background:#039a53;transform:translateY(-1px)}.home-verification-button:active{transform:translateY(0)}.home-guide-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.home-guide-card{background:#fff;border:2px solid #0000;border-radius:18px;box-shadow:0 12px 30px #09131f14;display:flex;gap:14px;padding:18px 20px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.home-guide-card.grade-card{flex-direction:column;gap:10px}.home-guide-card.active{border-color:#81818166}.home-guide-icon{align-items:center;background:#09131f0f;border-radius:16px;display:flex;flex-shrink:0;font-size:22px;height:46px;justify-content:center;line-height:1;min-width:46px;width:46px}.home-guide-text h4{font-size:15px;font-weight:700;margin:0}.home-guide-text span{color:var(--muted);display:block;font-size:12px;margin-top:4px}.home-guide-text p{color:var(--text);font-size:13px;line-height:1.45;margin:10px 0 0}.home-guide-card.accent-master{background:linear-gradient(135deg,#fff2e1,#ffe3c1)}.home-guide-card.accent-diamond{background:linear-gradient(135deg,#fff0f5,#ffe0ec)}.home-guide-card.accent-platinum{background:linear-gradient(135deg,#ecfff5,#dfffee)}.home-guide-card.accent-gold{background:linear-gradient(135deg,#fff9d5,#fff27f)}.home-guide-card.accent-silver{background:linear-gradient(135deg,#f1f5ff,#e4e9ff)}.home-guide-card.accent-bronze{background:linear-gradient(135deg,#fff4eb,#ffe5d6)}.home-guide-card.accent-primary{background:linear-gradient(135deg,#ecfff5,#d7ffe7)}.home-guide-card.accent-sunny{background:linear-gradient(135deg,#fff8e6,#ffeed1)}.home-guide-card.accent-clean{background:linear-gradient(135deg,#f4f8ff,#e6f0ff)}.home-guide-card.accent-warning{background:linear-gradient(135deg,#fff2f2,#ffe0e0)}.page-bottom-fact{background:#e9f4ff;border-radius:15px;color:var(--text);font-size:11px;line-height:1.4;margin-bottom:16px;margin-top:24px;padding:15px 16px}.page-bottom-fact strong{color:#0b6bff;display:block;font-size:13px;font-weight:600;margin-bottom:2px}.page-bottom-fact p{color:var(--text);font-size:12px;margin:0;opacity:.85}@media (max-width:520px){.home-modal{padding:16px}.home-modal-content{max-height:calc(100vh - 32px);padding:16px 18px;width:min(340px,100%)}.home-modal-content header h3{font-size:15px}.home-modal-content header button{font-size:12px;padding:5px 10px}.home-verification-section{padding:16px}.home-verification-header h3{font-size:15px}.home-verification-message{font-size:13px}.home-verification-button{font-size:13px;padding:10px 18px}.home-grade-card{padding:14px 16px}.home-grade-card-emoji{font-size:24px}.home-grade-card-content h4{font-size:14px}.home-grade-card-content span{font-size:12px}.home-grade-card-badge{font-size:11px;padding:3px 8px}}.verification-main-section{margin-bottom:24px}.verification-action-section{display:flex;flex-direction:column;gap:20px;padding:15px 0}.verification-action-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.verification-action-title-row{align-items:center;display:flex;gap:8px;margin-bottom:8px}.verification-status-message{color:var(--muted);font-size:14px;line-height:1.5;margin:0 0 6px}.verification-next-time{color:coral;font-size:12px;font-weight:500;margin:0}.verification-status-badge{border-radius:12px;flex-shrink:0;font-size:12px;font-weight:600;padding:6px 14px;white-space:nowrap}.verification-status-badge.available{background:#05c46b26;color:#05c46b}.verification-status-badge.completed{background:#ff7f5026;color:coral}.verification-action-header h3{color:var(--text);font-size:18px;font-weight:700;margin:0}.verification-action-header .info-button{background:#05c46b29;color:#05c46b;position:static}.verification-preview{aspect-ratio:4/3;background:#f5f5f5;border-radius:16px;margin-top:20px;overflow:hidden;position:relative}.verification-preview-image{display:block;height:100%;object-fit:cover;width:100%}.verification-preview-overlay{align-items:center;background:#0009;color:#fff;display:flex;flex-direction:column;gap:12px;inset:0;justify-content:center;position:absolute}.verification-loading-spinner{animation:spin .8s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;width:40px}.verification-preview-overlay p{font-size:14px;font-weight:600;margin:0}.recent-verifications-section{margin-bottom:24px}.recent-verifications-header{margin-bottom:16px}.recent-verifications-header h3{color:var(--text);font-size:18px;font-weight:700;margin:0 0 6px}.recent-verifications-header p{color:var(--muted);font-size:13px;margin:0}.recent-verifications-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.recent-verification-item{aspect-ratio:1;background:#f5f5f5;border-radius:12px;box-shadow:0 4px 12px #09131f14;overflow:hidden;position:relative;transition:transform .2s ease,box-shadow .2s ease}.recent-verification-image{display:block;height:100%;object-fit:cover;width:100%}.recent-verification-placeholder{align-items:center;background:linear-gradient(135deg,#09131f14,#09131f0a);display:flex;font-size:32px;height:100%;justify-content:center;width:100%}.recent-verification-info{background:linear-gradient(0deg,#000000b3,#0000);bottom:0;color:#fff;left:0;padding:8px;position:absolute;right:0}.recent-verification-date{font-size:11px;font-weight:600;line-height:1.4;margin:0}.recent-verification-confidence{font-size:10px;margin:2px 0 0;opacity:.9}.recent-verifications-empty{color:var(--muted);font-size:14px;padding:40px 20px;text-align:center}.recent-verifications-loading{padding:60px 20px}.recent-verifications-error,.recent-verifications-loading{align-items:center;color:var(--muted);display:flex;flex-direction:column;font-size:14px;gap:16px;text-align:center}.recent-verifications-error{padding:40px 20px}.retry-button{background:linear-gradient(135deg,#05c46b,#04b85a);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.retry-button:hover{box-shadow:0 4px 12px #05c46b4d;transform:translateY(-1px)}.loading-spinner-small{animation:spin .8s linear infinite;border:3px solid #09131f1a;border-radius:50%;border-top-color:#05c46b;height:32px;width:32px}.verification-action-button{align-items:center;background:#05c46b26;border:none;border-radius:16px;color:#05c46b;cursor:pointer;display:flex;font-size:15px;font-weight:700;gap:8px;height:48px;justify-content:center;padding:0 24px;width:100%}.verification-action-button:active:not(:disabled){transform:translateY(0)}.verification-action-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.verification-action-button svg{display:block;flex-shrink:0;height:20px;width:20px}.info-button{align-items:center;background:#05c46b1f;border:none;border-radius:12px;color:#05c46b;cursor:pointer;display:inline-flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.info-button svg{display:block;flex-shrink:0;height:18px;width:18px}.verification-modal{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:999}.verification-modal-content{background:linear-gradient(145deg,#fff,#f5f9ff);border-radius:24px;box-shadow:0 20px 48px #09131f26;display:flex;flex-direction:column;gap:18px;padding:24px 26px;width:min(520px,100%)}.verification-modal-content header{align-items:flex-start;display:flex;gap:18px;justify-content:space-between}.verification-modal-content header h3{font-size:18px;font-weight:700;margin:0}.verification-modal-content header p{color:var(--muted);font-size:13px;margin:6px 0 0}.verification-modal-content header button{background:#09131f14;border:none;border-radius:14px;cursor:pointer;flex-shrink:0;font-weight:600;padding:8px 14px;white-space:nowrap}.verification-modal-body{display:flex;flex-direction:column;gap:14px}.verification-guide-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.verification-guide-card{background:#fff;border:none;border-radius:18px;display:flex;gap:14px;padding:18px 20px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.verification-guide-icon{align-items:center;background:#09131f0f;border-radius:16px;display:flex;flex-shrink:0;font-size:22px;height:46px;justify-content:center;line-height:1;min-width:46px;width:46px}.verification-guide-text{flex:1 1}.verification-guide-text h4{font-size:15px;font-weight:700;margin:0}.verification-guide-text p{color:var(--text);font-size:13px;line-height:1.45;margin:10px 0 0}.verification-guide-card.accent-primary{background:linear-gradient(135deg,#ecfff5,#d7ffe7)}.verification-guide-card.accent-sunny{background:linear-gradient(135deg,#fff8e6,#ffeed1)}.verification-guide-card.accent-clean{background:linear-gradient(135deg,#f4f8ff,#e6f0ff)}.verification-guide-card.accent-warning{background:linear-gradient(135deg,#fff2f2,#ffe0e0)}@media (max-width:520px){.verification-action-section{padding:20px 0}.verification-action-button{font-size:14px;height:44px}.recent-verifications-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.verification-modal,.verification-modal-content{padding:20px}.verification-guide-grid{gap:12px;grid-template-columns:1fr}.verification-guide-card{padding:14px 16px}.verification-guide-text h4{font-size:15px}.verification-guide-text p{font-size:14px;margin-top:6px}.verification-modal-content header button{font-size:13px;padding:8px 12px}}.verification-success-modal{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.verification-success-modal-content{background:linear-gradient(145deg,#fff,#f5f9ff);border-radius:24px;box-shadow:0 20px 48px #09131f4d;display:flex;flex-direction:column;gap:20px;max-height:90vh;overflow-y:auto;padding:24px;width:min(420px,100%)}.verification-success-modal-header{align-items:center;display:flex;gap:16px;justify-content:space-between}.verification-success-modal-header h3{color:var(--text);font-size:20px;font-weight:700;margin:0}.verification-success-modal-close{align-items:center;background:#09131f14;border:none;border-radius:8px;color:var(--text);cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:32px;justify-content:center;transition:background .2s ease;width:32px}.verification-success-modal-close:hover{background:#09131f1f}.verification-success-modal-body{display:flex;flex-direction:column;gap:16px;min-height:0;padding:0}.verification-success-image-wrapper{aspect-ratio:4/3;background:#f5f5f5;border-radius:16px;box-shadow:0 8px 24px #09131f1f;overflow:hidden;position:relative;width:100%}.verification-success-image{display:block;height:100%;object-fit:cover;object-position:center;width:100%}.verification-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;border-radius:16px;display:flex;inset:0;justify-content:center;position:absolute}.verification-loading-overlay .verification-loading-spinner{animation:spin .8s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:48px;width:48px}.verification-error-message{background:linear-gradient(135deg,#ff4d4d1a,#ff4d4d0d);border:1px solid #ff4d4d33;border-radius:12px;color:#ff4d4d;font-size:14px;font-weight:600;line-height:1.6;margin:0;padding:14px 18px;text-align:center}@media (max-width:520px){.verification-success-modal{padding:16px}.verification-success-modal-content{gap:16px;padding:20px}.verification-success-modal-header h3{font-size:18px}.verification-loading-overlay .verification-loading-spinner{border-width:3px;height:40px;width:40px}.verification-error-message{font-size:13px;padding:12px 16px}}.community{padding-bottom:0}.group-page,.ranking-page{padding:0}.group-content,.ranking-content{padding:20px 24px}@media (max-width:640px){.subtab-nav{padding:0 16px}.group-content,.ranking-content{padding:0 16px 20px}}.group-page{padding:0}.group-content{padding:0 26px 20px}@media (max-width:640px){.group-content{padding:0 0 20px}}.group-empty-state{align-items:center;display:flex;flex-direction:column;gap:12px;padding:60px 26px;text-align:center}.group-empty-state h3{color:var(--text);font-size:22px;font-weight:700;letter-spacing:-.3px;margin:0}.group-empty-state p{color:var(--muted);font-size:15px;line-height:1.6;margin:0;max-width:320px}.group-empty-actions{display:flex;flex-direction:row;gap:10px;justify-content:center;margin-top:28px;max-width:320px;width:100%}@media (max-width:640px){.group-empty-state{gap:10px;padding:48px 20px}.group-empty-state h3{font-size:20px}.group-empty-state p{font-size:14px;max-width:280px}.group-empty-actions{gap:8px;margin-top:24px;max-width:100%}}.group-button{border:none;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:10px 20px;transition:all .2s ease}@media (max-width:640px){.group-button{border-radius:12px;font-size:14px;padding:12px 20px}}.group-button-primary{background:#05c46b;box-shadow:0 2px 8px #05c46b33;color:#fff}.group-button-primary:hover{background:#04a85a;box-shadow:0 4px 12px #05c46b4d;transform:translateY(-1px)}.group-button-primary:active{box-shadow:0 2px 6px #05c46b33;transform:translateY(0)}.group-button-secondary{background:#05c46b14;border:1px solid #05c46b26;color:#05c46b}.group-button-secondary:hover{background:#05c46b1f;border-color:#05c46b40;transform:translateY(-1px)}.group-button-secondary:active{transform:translateY(0)}.group-info-card{background:#fff;border-radius:16px;margin-bottom:24px;padding:20px}@media (max-width:640px){.group-info-card{border-radius:12px;margin-bottom:20px;padding:16px}}.group-info-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}@media (max-width:640px){.group-info-header{margin-bottom:12px}}.group-info-header h3{color:var(--text);font-size:22px;font-weight:700;margin:0 0 6px}@media (max-width:640px){.group-info-header h3{font-size:18px;margin-bottom:4px}}.group-code{color:var(--muted);font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;letter-spacing:1px;margin:0;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.group-code:hover{color:#05c46b;opacity:.9}.group-code.copied{color:#05c46b}.group-code.copied:after{animation:fadeInOut 2s ease;background:#09131fe6;border-radius:6px;color:#fff;content:"복사됨!";font-size:11px;left:0;padding:4px 8px;position:absolute;top:-24px;white-space:nowrap}@keyframes fadeInOut{0%{opacity:0;transform:translateY(4px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}.group-info-badge{background:#05c46b1a;border:1px solid #05c46b26;border-radius:8px;color:#05c46b;font-size:12px;font-weight:600;padding:6px 12px}.group-settings-btn{align-items:center;background:none;border:none;border-radius:10px;color:var(--text);cursor:pointer;display:flex;justify-content:center;min-height:36px;min-width:36px;opacity:.7;padding:8px;transition:all .2s ease}.group-settings-btn:hover{background:#09131f0d;opacity:1}.group-settings-btn:active{background:#09131f14}.group-settings-btn svg{height:20px;width:20px}@media (max-width:640px){.group-info-badge{font-size:11px;padding:5px 10px}}.group-announcement{background:#0000;border:none;border-radius:0;margin-top:20px;padding:0}@media (max-width:640px){.group-announcement{margin-top:16px}}.group-announcement-header{align-items:center;display:flex;gap:8px;margin-bottom:12px}.group-announcement-icon{font-size:18px;line-height:1}.group-announcement-label{color:var(--text);font-size:13px;font-weight:700;letter-spacing:-.3px}.group-announcement-content{background:#09131f05;border:1px solid #09131f0f;border-radius:12px;color:var(--text);font-size:14px;line-height:1.6;margin:0;padding:16px 18px;white-space:pre-wrap}@media (max-width:640px){.group-announcement-content{border-radius:10px;font-size:13px;padding:14px 16px}}.group-info-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:20px}@media (max-width:640px){.group-info-stats{gap:10px;margin-top:16px}}.group-section{margin-bottom:32px}@media (max-width:640px){.group-section{margin-bottom:16px}}.group-section-title{color:var(--text);font-size:18px;font-weight:700;margin:0 0 16px}@media (max-width:640px){.group-section-title{font-size:16px;margin-bottom:12px}}.group-members-list{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));max-height:600px;overflow-y:auto;padding-right:4px}.group-members-list::-webkit-scrollbar{width:6px}.group-members-list::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.group-members-list::-webkit-scrollbar-thumb{background:var(--muted);border-radius:3px;opacity:.3}.group-members-list::-webkit-scrollbar-thumb:hover{opacity:.5}@media (max-width:640px){.group-members-list{gap:8px;grid-template-columns:1fr;max-height:500px}}.group-member-item{align-items:center;background:#fff;border:1px solid #09131f14;border-radius:12px;display:flex;gap:12px;min-width:0;padding:12px;transition:all .2s ease}@media (max-width:640px){.group-member-item{border-radius:12px;gap:10px;padding:12px}}.group-member-item:hover{border-color:#05c46b33;box-shadow:0 2px 8px #05c46b1a}@media (max-width:640px){.group-member-item:active{background:#05c46b05}}.group-member-avatar{align-items:center;background:#05c46b;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:48px;justify-content:center;overflow:hidden;width:48px}@media (max-width:640px){.group-member-avatar{font-size:16px;height:44px;width:44px}}.group-member-avatar img{height:100%;object-fit:cover;width:100%}.group-member-info{flex:1 1;min-width:0}.group-member-name{align-items:center;color:var(--text);display:flex;font-size:15px;font-weight:600;gap:6px;margin-bottom:4px}@media (max-width:640px){.group-member-name{font-size:14px;margin-bottom:3px}}.group-member-badge{background:#05c46b26;border-radius:8px;color:#05c46b;font-size:11px;font-weight:600;padding:2px 8px;white-space:nowrap}@media (max-width:640px){.group-member-badge{font-size:10px;padding:2px 6px}}.group-member-meta{color:var(--muted);font-size:12px}@media (max-width:640px){.group-member-meta{font-size:11px}}.group-member-lp-info{align-items:flex-end;display:flex;flex-direction:column;gap:4px;text-align:right}.group-member-total-lp{color:#05c46b;font-size:16px;font-weight:700}.group-member-today-lp{align-items:center;color:var(--muted);display:flex;font-size:12px;gap:4px}.group-member-today-lp.empty{opacity:.5}.group-member-today-lp>span:first-child{color:var(--primary);font-weight:600}.group-member-bonus-lp{background:#10b9811a;border-radius:4px;color:#10b981;font-size:11px;font-weight:600;padding:2px 6px}.group-member-verified-badge{color:#10b981;font-size:12px;font-weight:700;margin-left:4px}@media (max-width:640px){.group-member-total-lp{font-size:15px}.group-member-today-lp{font-size:11px}.group-member-bonus-lp{font-size:10px;padding:1px 5px}}.group-empty-members{color:var(--muted);font-size:14px;padding:40px 20px;text-align:center}.group-verification-gallery{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}@media (max-width:640px){.group-verification-gallery{gap:6px;grid-template-columns:repeat(2,1fr)}}.group-verification-item{aspect-ratio:1;background:#09131f0d;border-radius:12px;overflow:hidden;position:relative}@media (max-width:640px){.group-verification-item{border-radius:10px}}.group-verification-item img{height:100%;object-fit:cover;width:100%}.group-verification-overlay{align-items:flex-end;background:linear-gradient(0deg,#000000d9,#0006,#0000);bottom:0;display:flex;left:0;padding:12px 8px 8px;position:absolute;right:0}@media (max-width:640px){.group-verification-overlay{padding:10px 6px 6px}}.group-verification-info{display:flex;flex-direction:column;gap:2px;width:100%}.group-verification-name{color:#fff;font-size:13px;font-weight:700;line-height:1.2;text-shadow:0 1px 2px #00000080}@media (max-width:640px){.group-verification-name{font-size:12px}}.group-verification-time{color:#ffffffd9;font-size:10px;font-weight:500;text-shadow:0 1px 2px #00000080}@media (max-width:640px){.group-verification-time{font-size:9px}}.group-empty-verifications{color:var(--muted);font-size:14px;padding:40px 20px;text-align:center}.group-delete-button{background:#ef44441a;border:2px solid #ef444433;border-radius:16px;color:#ef4444;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s ease;width:100%}@media (max-width:640px){.group-delete-button{border-radius:14px;font-size:15px;min-height:48px;padding:16px 24px}}.group-delete-button:hover:not(:disabled){background:#ef444426;border-color:#ef44444d}.group-delete-button:disabled{cursor:not-allowed;opacity:.6}.group-modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.group-modal-content{animation:slideUp .3s ease;background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:calc(100vh - 40px);max-width:420px;overflow:hidden;width:100%}.group-modal-header{align-items:center;border-bottom:1px solid #09131f1a;display:flex;flex-shrink:0;justify-content:space-between;padding:24px}.group-modal-header h3{color:var(--text);font-size:20px;font-weight:700;margin:0}.group-modal-close{align-items:center;background:none;border:none;border-radius:8px;color:var(--muted);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.group-modal-close:hover{background:#09131f0d}.group-modal-form{display:flex;flex-direction:column;gap:20px;padding:24px}.group-modal-field{display:flex;flex-direction:column;gap:8px}.group-modal-field label{color:var(--text);font-size:14px;font-weight:600}.group-modal-field input{background:#fff;border:2px solid #09131f1a;border-radius:12px;font-size:16px;padding:14px 16px;transition:all .2s ease}.group-modal-field input:focus{border-color:#05c46b;box-shadow:0 0 0 3px #05c46b1a;outline:none}.group-modal-hint{color:var(--muted)}.group-modal-error,.group-modal-hint{font-size:12px;line-height:1.4;margin:0}.group-modal-error{color:#ef4444}.group-modal-actions{display:flex;gap:12px;margin-top:8px}.group-modal-button{border:none;border-radius:12px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s ease}.group-modal-button:disabled{cursor:not-allowed;opacity:.6}.group-modal-button-cancel{background:#09131f0d;color:var(--text)}.group-modal-button-cancel:hover:not(:disabled){background:#09131f1a}.group-modal-button-primary{background:#05c46b;color:#fff}.group-modal-button-primary:hover:not(:disabled){background:#04a85a}.group-modal-success-content{display:flex;flex-direction:column;gap:24px;padding:24px}.group-code-display{display:flex;flex-direction:column;gap:12px;text-align:center}.group-code-label{color:var(--muted);font-size:14px;font-weight:600;margin:0}.group-code-box{align-items:center;background:linear-gradient(135deg,#f5fff9,#ecfff5);border:2px solid #05c46b33;border-radius:16px;display:flex;gap:12px;justify-content:space-between;padding:16px}.group-code-text{color:#05c46b;flex:1 1;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:28px;font-weight:700;letter-spacing:3px;text-align:center}.group-code-copy-btn{background:#05c46b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.group-code-copy-btn:hover{background:#04a85a}.group-code-hint{color:var(--muted);font-size:12px;line-height:1.4;margin:0}@media (max-width:640px){.group-modal-overlay{padding:10px}.group-modal-content{border-radius:20px;max-width:100%}.group-modal-form,.group-modal-header,.group-modal-success-content{padding:20px}.group-code-text{font-size:24px;letter-spacing:2px}}.group-settings-content{padding:20px}.group-settings-section{margin-bottom:24px}.group-settings-section:last-child{margin-bottom:0}.group-settings-section h4{color:var(--text);font-size:16px;font-weight:700;margin:0 0 12px}.group-settings-name-display{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;justify-content:space-between;padding:12px}.group-settings-name-edit{display:flex;flex-direction:column;gap:8px}.group-settings-name-edit input{background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;padding:12px}.group-settings-name-actions{display:flex;gap:8px;justify-content:flex-end}.group-settings-name-actions button{background:var(--bg-secondary);border:none;border-radius:6px;color:var(--text);cursor:pointer;font-size:14px;padding:8px 16px}.group-settings-edit-btn,.group-settings-name-actions button.primary{background:var(--primary);color:#fff}.group-settings-edit-btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;padding:6px 12px}.group-settings-members{display:flex;flex-direction:column;gap:8px}.group-settings-member-item{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;justify-content:space-between;padding:12px}.group-settings-member-info{align-items:center;display:flex;flex:1 1;gap:12px}.group-settings-member-avatar{align-items:center;background:var(--primary);border-radius:50%;color:#fff;display:flex;font-weight:600;height:40px;justify-content:center;overflow:hidden;width:40px}.group-settings-member-avatar img{height:100%;object-fit:cover;width:100%}.group-settings-member-name{align-items:center;color:var(--text);display:flex;font-size:14px;font-weight:600;gap:6px}.group-settings-leader-badge{background:var(--primary);border-radius:4px;color:#fff;font-size:10px;font-weight:600;padding:2px 6px}.group-settings-member-meta{color:var(--muted);font-size:12px;margin-top:2px}.group-settings-remove-btn{background:#ef44441a;border:none;border-radius:6px;color:#ef4444;cursor:pointer;font-size:12px;padding:6px 12px}.group-settings-danger-btn{background:#ef44441a;border:none;border-radius:8px;color:#ef4444;cursor:pointer;font-size:14px;font-weight:600;padding:12px;width:100%}.group-lp-info-content{max-height:70vh;overflow-y:auto;padding:20px}.group-lp-info-section{margin-bottom:24px}.group-lp-info-section:last-child{margin-bottom:0}.group-lp-info-section h4{color:var(--text);font-size:16px;font-weight:700;margin:0 0 12px}.group-lp-total{align-items:baseline;display:flex;gap:8px}.group-lp-value{color:var(--primary);font-size:32px;font-weight:700}.group-lp-label{color:var(--muted);font-size:16px}.group-lp-bonus{border-radius:12px;padding:16px}.group-lp-bonus-success{align-items:center;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;gap:12px}.group-lp-bonus-pending{align-items:flex-start;background:var(--bg-secondary);color:var(--text);display:flex;gap:12px}.group-lp-bonus-icon{font-size:32px}.group-lp-bonus-title{font-size:16px;font-weight:700;margin-bottom:4px}.group-lp-bonus-amount{font-size:20px;font-weight:700}.group-lp-bonus-desc{color:var(--muted);font-size:13px;margin-bottom:8px}.group-lp-bonus-progress{color:var(--muted);font-size:12px}.group-lp-methods{display:flex;flex-direction:column;gap:12px}.group-lp-method-item{align-items:flex-start;background:var(--bg-secondary);border-radius:8px;display:flex;gap:12px;padding:12px}.group-lp-method-icon{font-size:24px}.group-lp-method-title{color:var(--text);font-size:14px;font-weight:600;margin-bottom:4px}.group-lp-method-desc{color:var(--muted);font-size:12px}.ranking-page{padding:0}.ranking-tabs{display:flex;gap:8px;margin-bottom:20px;padding:0 26px 20px}.ranking-tab{background:#09131f0a;border:none;border-radius:12px;color:var(--muted);cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 20px;transition:all .2s ease}.ranking-tab:hover{background:#09131f0f;color:var(--text)}.ranking-tab.active{background:#05c46b;color:#fff}.ranking-my-rank{background:#ebfff5;border:none;border-radius:16px;margin:0 26px 20px;padding:18px}.ranking-my-rank-header{align-items:center;color:var(--muted);display:flex;font-size:13px;font-weight:600;justify-content:space-between;margin-bottom:12px}.ranking-my-rank-header strong{color:#05c46b;font-size:20px;font-weight:700}.ranking-my-rank-content{margin-top:0}.ranking-list{padding:0 26px 20px}.ranking-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.ranking-list-header h4{color:var(--text);font-size:18px;font-weight:700;margin:0}.ranking-list-count{color:var(--muted);font-size:13px}.ranking-items{display:flex;flex-direction:column;gap:8px}.ranking-item{align-items:center;background:#fff;border:none;border-radius:12px;display:flex;gap:12px;padding:14px}.ranking-item-highlight{background:#ebfff5;border:none}.ranking-item-me{background:#05c46b0f}.ranking-rank{align-items:center;color:var(--text);display:flex;flex-shrink:0;font-size:16px;font-weight:700;justify-content:center;text-align:center;width:36px}.ranking-rank.top-1,.ranking-rank.top-2,.ranking-rank.top-3{font-size:20px}.ranking-item-highlight .ranking-rank{color:#05c46b;font-size:18px}.ranking-avatar{align-items:center;background:#05c46b;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:48px;justify-content:center;overflow:hidden;width:48px}.ranking-avatar img{height:100%;object-fit:cover;width:100%}.ranking-info{flex:1 1;min-width:0;overflow:hidden}.ranking-name{align-items:center;color:var(--text);display:flex;font-size:15px;font-weight:600;gap:6px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking-badge{background:#05c46b26;border-radius:6px;color:#05c46b;flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px}.ranking-meta{color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking-lp{color:#05c46b;flex-shrink:0;font-size:16px;font-weight:700;white-space:nowrap}.ranking-empty{color:var(--muted);font-size:14px;padding:60px 20px;text-align:center}@media (max-width:640px){.ranking-tabs{gap:6px;margin-bottom:16px;padding:0 0 16px}.ranking-tab{border-radius:10px;font-size:14px;padding:10px 16px}.ranking-my-rank{border-radius:12px;margin:0 0 16px;padding:14px}.ranking-my-rank-header{margin-bottom:10px}.ranking-my-rank-header strong{font-size:18px}.ranking-list{padding:0 0 20px}.ranking-list-header{margin-bottom:12px}.ranking-list-header h4{font-size:16px}.ranking-list-count{font-size:12px}.ranking-items{gap:6px}.ranking-item{border-radius:10px;gap:10px;padding:12px}.ranking-rank{font-size:14px;width:32px}.ranking-rank.top-1,.ranking-rank.top-2,.ranking-rank.top-3{font-size:18px}.ranking-item-highlight .ranking-rank{font-size:16px}.ranking-avatar{font-size:16px;height:44px;width:44px}.ranking-name{font-size:14px;margin-bottom:3px}.ranking-meta{font-size:11px}.ranking-lp{font-size:14px}}.stats{padding-bottom:0}.subtab-nav{border-bottom:1px solid #09131f14;display:flex;gap:8px;margin-bottom:20px;padding:0 24px}.subtab-button{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--muted);cursor:pointer;font-size:14px;font-weight:600;margin-bottom:-1px;padding:12px 20px;transition:all .2s ease}.subtab-button:hover{color:var(--text)}.subtab-button.active{border-bottom-color:#05c46b;color:#05c46b}.subtab-content{min-height:400px}.achievements-page,.insights-page{padding:0}.achievements-content,.insights-content{padding:0 24px}.insights-content .insights-summary{margin-bottom:24px;margin-top:0}.insights-content .insights-section{margin-bottom:30px}.achievements-content .page-heading-row{margin-bottom:20px}.achievements-content .page-heading-row h3{color:var(--text);font-size:20px;font-weight:700;margin:0}.achievements-content .achievement-grid{margin-top:0}@media (max-width:640px){.subtab-nav{padding:0 16px}.achievements-content,.insights-content{padding:0 8px 16px}}.insights-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:24px}.insights-section{margin-bottom:30px}.trend-list{display:flex;flex-direction:column;gap:10px;list-style:none;margin:0;padding:0}.trend-list li{grid-gap:12px;align-items:center;display:grid;font-size:13px;gap:12px;grid-template-columns:80px 1fr 56px}.trend-bar{background:#09131f14;border-radius:8px;height:8px;overflow:hidden}.trend-bar-fill{background:linear-gradient(135deg,#00d775,#00a85c);height:100%}.trend-count{font-weight:600;text-align:right}.insight-delta{align-items:center;background:linear-gradient(135deg,#05c46b1f,#03a35814);border-radius:18px;display:flex;justify-content:space-between;padding:16px 18px}.delta-card h3{color:#028858;font-size:15px;font-weight:700;margin:0}.delta-card p{color:var(--text);font-size:14px;font-weight:600;margin:6px 0 0}.delta-details{color:var(--muted);font-size:13px;text-align:right}.delta-details strong{color:#028858;display:block;font-size:14px;margin-top:4px}.insights-loading{align-items:center;color:var(--muted);display:flex;flex-direction:column;font-size:14px;gap:16px;padding:60px 20px;text-align:center}.insights-loading .loading-spinner-small{animation:spin .8s linear infinite;border:3px solid #09131f1a;border-radius:50%;border-top-color:#05c46b;height:32px;width:32px}.insights-error{align-items:center;color:var(--muted);display:flex;flex-direction:column;font-size:14px;gap:16px;padding:40px 20px;text-align:center}.achievement-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.achievement-card{background:linear-gradient(150deg,#fffffff2,#fff);border:none;border-radius:20px;display:flex;flex-direction:column;gap:10px;min-height:140px;overflow:hidden;padding:18px 16px;position:relative}.achievement-decoration{background:radial-gradient(circle,#ffffff4d,#0000 70%);border-radius:50%;height:120px;pointer-events:none;position:absolute;right:-40px;top:-40px;width:120px}.achievement-content{display:flex;flex:1 1;flex-direction:column;gap:10px;z-index:1}.achievement-emoji{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:28px;line-height:1;margin-bottom:4px}.achievement-lock{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#09131f1f;border-radius:50%;box-shadow:0 2px 8px #09131f1a;color:var(--muted);display:flex;height:28px;justify-content:center;position:absolute;right:10px;top:10px;width:28px;z-index:2}.achievement-lock svg{display:block;flex-shrink:0;height:14px;width:14px}.achievement-badge{align-items:center;background:#05c46b2a;border-radius:50%;color:#05c46b;display:flex;font-size:14px;font-weight:700;height:28px;justify-content:center;position:absolute;right:10px;top:10px;width:28px;z-index:2}.achievement-card h3{color:var(--text);font-size:14px;font-weight:700;line-height:1.3;margin:0}.achievement-card p{color:var(--muted);flex:1 1;font-size:12px;line-height:1.4;margin:0}.achievement-card.medal{background:linear-gradient(150deg,#fff8e1,#ffe082);border-color:#f57c0026;color:#f57c00}.achievement-card.streak{background:linear-gradient(150deg,#fce4ec,#f8bbd0);border-color:#c2185b26;color:#c2185b}.achievement-card.lp{background:linear-gradient(150deg,#e3f2fd,#bbdefb);border-color:#1976d226;color:#1976d2}.achievement-card.green{background:linear-gradient(150deg,#e8f5e9,#c8e6c9);border-color:#388e3c26;color:#388e3c}.achievement-card.purple{background:linear-gradient(150deg,#f3e5f5,#e1bee7);border-color:#7b1fa226;color:#7b1fa2}.achievement-card.orange{background:linear-gradient(150deg,#fff3e0,#ffe0b2);border-color:#e64a1926;color:#e64a19}.achievement-card.blue{background:linear-gradient(150deg,#e0f2f1,#b2dfdb);border-color:#00796b26;color:#00796b}.achievement-card.locked{background:linear-gradient(150deg,#09131f0d,#09131f08);border-color:#09131f14;opacity:.65}.achievement-card.locked h3,.achievement-card.locked p{color:var(--muted)}.achievement-card.locked .achievement-emoji{filter:grayscale(100%);opacity:.4}.achievement-card.locked.medal{background:linear-gradient(150deg,#f57c001a,#f57c000d)}.achievement-card.locked.streak{background:linear-gradient(150deg,#c2185b1a,#c2185b0d)}.achievement-card.locked.lp{background:linear-gradient(150deg,#1976d21a,#1976d20d)}.achievement-card.locked.green{background:linear-gradient(150deg,#388e3c1a,#388e3c0d)}.achievement-card.locked.purple{background:linear-gradient(150deg,#7b1fa21a,#7b1fa20d)}.achievement-card.locked.orange{background:linear-gradient(150deg,#e64a191a,#e64a190d)}.achievement-card.locked.blue{background:linear-gradient(150deg,#00796b1a,#00796b0d)}.page-heading-row{align-items:center;display:flex;gap:16px;justify-content:space-between;width:100%}.share-button{background:#05c46b1a;border:none;border-radius:16px;color:#039a53;cursor:pointer;font-size:14px;font-weight:600;line-height:1.5;padding:10px 18px;transition:all .2s;white-space:nowrap}.share-button:hover{background:#05c46b59}.share-button:active{transform:translateY(0)}@media (max-width:640px){.achievement-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.achievement-card{border-radius:16px;gap:8px;min-height:120px;padding:14px 12px}.achievement-emoji{font-size:24px}.achievement-card h3{font-size:13px}.achievement-card p{font-size:11px}.achievement-badge,.achievement-lock{height:24px;right:8px;top:8px;width:24px}.achievement-lock svg{height:12px;width:12px}.achievement-badge{font-size:12px}.page-heading-row{align-items:flex-start;flex-direction:column}.share-button{font-size:13px;padding:8px 16px;width:100%}}.share-card{background:#fff;border:4px solid #0000000f;border-radius:24px;min-height:400px;overflow:hidden;padding:0;width:375px}.share-card,.share-card-content-wrapper{box-sizing:border-box;margin:0;position:relative}.share-card-content-wrapper{color:#09131f;display:flex;flex-direction:column;height:100%;padding:24px 20px;width:100%;z-index:2}.share-card-header{flex-shrink:0;margin-bottom:25px;text-align:center}.share-card-logo{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:12px}.share-card-logo-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0;height:40px;width:40px}.share-card-logo-text{align-items:baseline;display:inline-flex;font-size:32px;font-weight:900;letter-spacing:-.5px}.share-card-logo-be{color:#09131f}.share-card-logo-echo{color:#05c46b}.share-card-subtitle{color:#6b7280;font-size:13px;font-weight:600;letter-spacing:.3px}.share-card-main{display:flex;flex:1 1;flex-direction:column;gap:20px;min-height:0;overflow:hidden}.share-card-grade-section{background:none;border:none;border-radius:16px;flex-shrink:0;justify-content:center;padding:20px 24px}.share-card-grade-info,.share-card-grade-section{align-items:center;display:flex;flex-direction:column}.share-card-grade-info{gap:16px;width:100%}.share-card-grade-badge-row{align-items:center;display:flex;gap:16px;justify-content:space-between;width:100%}.share-card-emoji-wrapper{align-items:center;display:flex;flex-shrink:0;justify-content:center;position:relative}.share-card-emoji-glow{border-radius:50%;filter:blur(12px);height:60px;opacity:.3;position:absolute;width:60px;z-index:0}.share-card-emoji{filter:drop-shadow(0 2px 6px rgba(0,0,0,.1));font-size:40px;line-height:1;position:relative;z-index:1}.share-card-grade-badge{border-radius:20px;color:#fff;font-size:16px;font-weight:800;letter-spacing:.3px;padding:8px 20px}.share-card-grade-lp{align-items:baseline;display:flex;gap:6px}.share-card-lp-value{color:#05c46b;font-size:32px;font-weight:900;line-height:1}.share-card-lp-unit{color:#6b7280;font-size:18px;font-weight:700}.share-card-stats{grid-gap:12px;display:grid;flex-shrink:0;gap:12px;grid-template-columns:repeat(3,1fr)}.share-card-stat{background:#05c46b16;border-radius:14px;padding:20px 16px;text-align:center;transition:transform .2s,box-shadow .2s}.share-card-stat-icon{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1));font-size:24px;margin-bottom:8px}.share-card-stat-value{align-items:center;color:#09131f;display:flex;font-size:32px;font-weight:900;justify-content:center;line-height:1;margin-bottom:6px;min-height:38px}.share-card-stat-label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.2px}.share-card-footer{border-top:none;flex-shrink:0;margin-top:auto;padding-top:16px;text-align:center}.share-card-watermark{align-items:baseline;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:1.5px;margin-top:0}.share-card-watermark-be{color:#6b7280}.share-card-watermark-echo{color:#05c46b}.share-card[data-grade=bronze] .share-card-grade-badge{background:linear-gradient(135deg,#cd7f32,#a67c52 80%)}.share-card[data-grade=silver] .share-card-grade-badge{background:linear-gradient(135deg,silver,#a8a8a8)}.share-card[data-grade=gold] .share-card-grade-badge{background:linear-gradient(135deg,gold,#d4af37)}.share-card[data-grade=platinum] .share-card-grade-badge{background:linear-gradient(135deg,#e5e4e2,#b8b8b8);color:#4a5568}.share-card[data-grade=diamond] .share-card-grade-badge{background:linear-gradient(135deg,#5ba3f5,#4a90e2)}.share-card[data-grade=master] .share-card-grade-badge{background:linear-gradient(135deg,#05c46b,#02b95d)}@media (max-width:640px){.share-card{height:400px;max-height:calc(100vw - 40px);max-width:calc(100vw - 40px);width:375px}.share-card-content-wrapper{padding:20px 16px}.share-card-header{margin-bottom:20px}.share-card-logo{gap:8px}.share-card-logo-icon{height:32px;width:32px}.share-card-logo-text{align-items:baseline;display:inline-flex;font-size:26px;letter-spacing:-.3px}.share-card-emoji{font-size:56px}.share-card-emoji-glow{height:90px;width:90px}.share-card-grade-section{padding:20px}.share-card-grade-badge-row,.share-card-grade-info{gap:12px}.share-card-emoji{font-size:32px}.share-card-emoji-glow{height:50px;width:50px}.share-card-grade-badge{font-size:16px;padding:10px 24px}.share-card-lp-value{font-size:32px}.share-card-lp-unit{font-size:18px}.share-card-stats{gap:12px}.share-card-stat{padding:16px 12px}.share-card-stat-icon{font-size:20px}.share-card-stat-value{font-size:28px;min-height:34px}.share-card-stat-label{font-size:11px}}.share-modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.share-modal-content{align-self:center;animation:slideUp .3s ease;background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;margin:auto;max-height:calc(100vh - 40px);max-width:420px;overflow:hidden;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.share-modal-header{align-items:center;border-bottom:1px solid #09131f1a;display:flex;flex-shrink:0;justify-content:space-between;padding:24px}.share-modal-header h3{color:#09131f;color:var(--text,#09131f);font-size:20px;font-weight:700;margin:0}.share-modal-close{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;color:var(--muted,#6b7280);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.share-modal-close:hover{background:#09131f0d}.share-modal-body{-webkit-overflow-scrolling:touch;align-items:flex-start;display:flex;flex:1 1 auto;justify-content:center;min-height:0;overflow-x:hidden;overflow-y:auto;padding:24px 20px}.share-modal-actions{border-top:1px solid #09131f1a;display:flex;flex-direction:row;flex-shrink:0;gap:12px;padding:24px}.share-modal-button{border:none;border-radius:12px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:14px 24px;transition:all .3s}.share-button-primary{background:#05c46bbc;color:#fff}.share-button-primary:hover{background:#05c46b;color:#fff}.share-button-primary:disabled{cursor:not-allowed;opacity:.6}.share-button-twitter{background:#515151;color:#fff}.share-button-twitter:hover{background:#272727;color:#fff}@media (max-width:640px){.share-modal-overlay{align-items:center;padding:10px}.share-modal-content{border-radius:20px;margin:auto;max-height:calc(100vh - 20px);max-width:100%}.share-modal-header{flex-shrink:0;padding:20px}.share-modal-body{flex:1 1;min-height:0;padding:20px 16px}.share-modal-actions{flex-shrink:0;padding:20px}}.login-page{align-items:center;background:linear-gradient(135deg,#f5fff9,#ecfff5);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#fff;border-radius:24px;box-shadow:0 20px 60px #09131f1a;max-width:400px;padding:40px 32px;width:100%}.login-header{margin-bottom:40px;text-align:center}.login-logo{font-size:64px;margin-bottom:16px}.login-header h1{color:var(--text);font-size:32px;font-weight:700;margin:0 0 8px}.login-subtitle{color:var(--muted);font-size:14px;margin:0}.login-method-tabs{background:#09131f0d;border-radius:12px;display:flex;gap:8px;margin-bottom:24px;padding:4px}.login-method-tab{background:#0000;border:none;border-radius:8px;color:var(--muted);cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s ease}.login-method-tab.active{background:#fff;box-shadow:0 2px 4px #09131f1a;color:var(--text)}.login-mode-tabs{display:flex;gap:8px;margin-bottom:24px}.login-mode-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--muted);cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 16px;transition:all .2s ease}.login-mode-tab.active{border-bottom-color:#05c46b;color:#05c46b}.login-content{gap:20px}.login-content,.login-form{display:flex;flex-direction:column}.login-form{gap:16px}.login-form-field{display:flex;flex-direction:column;gap:8px}.login-form-field label{color:var(--text);font-size:14px;font-weight:600}.login-form-field input{background:#fff;border:2px solid #09131f1a;border-radius:12px;font-family:inherit;font-size:16px;padding:14px 16px;transition:all .2s ease}.login-form-field input:focus{border-color:#05c46b;box-shadow:0 0 0 3px #05c46b1a;outline:none}.login-form-field input:disabled{cursor:not-allowed;opacity:.6}.login-forgot-password{align-self:flex-end;background:none;border:none;color:#05c46b;cursor:pointer;font-size:12px;margin-top:-4px;padding:0;text-decoration:underline}.login-forgot-password:hover{color:#04a85a}.login-button,.login-form-actions{display:flex;gap:12px}.login-button{align-items:center;border:none;border-radius:12px;cursor:pointer;font-size:16px;font-weight:600;justify-content:center;padding:16px 24px;position:relative;transition:all .2s ease;width:100%}.login-button:disabled{cursor:not-allowed;opacity:.7}.login-button-google{background:#fff;border:2px solid #09131f1a;box-shadow:0 2px 8px #09131f0d;color:var(--text)}.login-button-google:hover:not(:disabled){border-color:#09131f33;box-shadow:0 4px 12px #09131f1a}.login-button-google svg{flex-shrink:0}.login-button-primary{background:#05c46b;color:#fff}.login-button-primary:hover:not(:disabled){background:#04a85a}.login-button-secondary{background:#09131f0d;color:var(--text)}.login-button-secondary:hover:not(:disabled){background:#09131f1a}.login-error{background:#fee;border-radius:8px;color:#c33;font-size:14px;margin:0;padding:12px;text-align:center}.login-info{border-top:1px solid #09131f14;padding-top:20px;text-align:center}.login-info p{color:var(--muted);font-size:13px;line-height:1.6;margin:0}.login-loading{align-items:center;color:var(--muted);display:flex;flex-direction:column;gap:16px;justify-content:center}.login-spinner,.login-spinner-small{animation:spin .8s linear infinite;border:4px solid #05c46b1a;border-radius:50%;border-top-color:#05c46b;height:40px;width:40px}.login-spinner-small{border-width:2px;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:640px){.login-container{padding:32px 24px}.login-logo{font-size:56px}.login-header h1{font-size:28px}}*,:after,:before{box-sizing:border-box}body{background:#eef3f8;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0}button,input{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#09131f2e;border-radius:999px}
/*# sourceMappingURL=main.389127ef.css.map*/