@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700;900&display=swap");*{box-sizing:border-box;margin:0;padding:0}:root{--accent:#A51C30;--orange:#000000;--yellow:#333333;--gray-bg:#f5f5f5;--white:#ffffff;--text:#111;--sub:#888;--radius:16px;--shadow:0 4px 20px rgba(0,0,0,0.08)}body,html{font-family:Noto Sans KR,-apple-system,sans-serif;background:#fff;min-height:100vh;color:var(--text)}.app{background:#fff}.app,.login-wrap{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.login-wrap{width:100%;position:relative;background:#000;justify-content:space-between;overflow:hidden}.login-bg-layer{position:absolute;inset:0;background:#fff;opacity:0;transition:opacity .6s ease;z-index:0}.login-bg-visible{opacity:1}.login-logo-fixed{position:absolute;left:50%;top:38%;transform:translateX(-50%) translateY(-50%);z-index:1}.egg-stack{position:relative}.egg-scene,.egg-stack{width:320px;height:320px}.egg-scene{position:absolute;top:0;left:0;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease}.egg-img{width:320px;height:320px;object-fit:contain}.sym-visible{opacity:1}.sym-hidden{opacity:0}.login-bottom{position:absolute;bottom:0;left:0;right:0;z-index:1;padding:0 28px 48px;display:flex;flex-direction:column;gap:12px;transition:opacity .5s ease,transform .5s ease}.bottom-hidden{opacity:0;transform:translateY(20px);pointer-events:none}.bottom-visible{opacity:1;transform:translateY(0)}.login-btns{display:flex;flex-direction:row;gap:10px}.login-btns .login-btn-main,.login-btns .login-btn-sub{flex:1 1;padding:12px 8px;font-size:14px}.auth-tabs{display:flex;border-bottom:1.5px solid #eee;margin-bottom:16px}.auth-tab{flex:1 1;padding:12px;text-align:center;font-size:15px;font-weight:600;color:#bbb;background:none;cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1.5px;font-family:Noto Sans KR,sans-serif;transition:all .2s}.auth-tab.active{color:#111;border-bottom-color:#111}.login-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:2;opacity:0;pointer-events:none;transition:opacity .3s ease}.overlay-visible{opacity:1;pointer-events:auto}.auth-back-arrow{position:absolute;top:20px;left:20px;z-index:10;background:none;border:none;font-size:24px;color:#fff;cursor:pointer;padding:4px 8px;transition:opacity .3s ease}.arrow-visible{opacity:1}.arrow-hidden{opacity:0;pointer-events:none}.form-panel{z-index:3;background:#fff;border-radius:24px 24px 0 0;padding-top:28px}.auth-title{font-size:22px;font-weight:900;color:#111;margin-bottom:12px}.auth-form{display:flex;flex-direction:column;gap:10px}.auth-input{width:100%;padding:16px;border-radius:12px;border:1.5px solid #e0e0e0;font-size:15px;font-family:Noto Sans KR,sans-serif;outline:none;background:#fafafa;transition:border-color .2s;box-sizing:border-box}.auth-input:focus{border-color:#111;background:#fff}.pw-row{position:relative;display:flex;align-items:center;width:100%}.pw-row .auth-input{padding-right:48px}.pw-eye{right:12px;background:none;border:none;cursor:pointer;padding:0;line-height:1}.pw-eye,.pw-match-check{position:absolute;font-size:16px}.pw-match-check{right:40px;color:#2e7d32;font-weight:700}.address-row{display:flex;gap:8px;width:100%}.address-input{flex:1 1}.nickname-row{display:flex;gap:8px;width:100%}.nickname-input{flex:1 1}.nickname-check-btn{padding:0 16px;background:#111;color:#fff;border:none;border-radius:12px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}.nickname-msg{font-size:12px;margin:-4px 0 0 2px}.nickname-ok{color:#2e7d32}.nickname-err{color:#e53935}.signup-panel{max-height:85vh;overflow-y:auto}.consent-box{display:flex;flex-direction:column;gap:8px;padding:12px;background:#f5f5f5;border-radius:12px}.consent-row{display:flex;align-items:flex-start;gap:8px;cursor:pointer}.consent-row input[type=checkbox]{width:16px;height:16px;margin-top:2px;flex-shrink:0;accent-color:#111}.consent-row span{font-size:12px;color:#555;line-height:1.5}.auth-error{color:#e53935;font-size:13px;text-align:center}.login-btn-main{width:100%;padding:18px;border-radius:999px;background:#111;color:#fff;font-size:16px;font-weight:700;border:none;cursor:pointer;letter-spacing:.02em;transition:opacity .2s}.login-btn-main:hover{opacity:.85}.login-btn-sub{width:100%;padding:18px;border-radius:999px;background:rgba(255,255,255,.7);color:#111;font-size:16px;font-weight:700;border:1.5px solid rgba(0,0,0,.12);cursor:pointer;letter-spacing:.02em;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-btn-sub:hover{background:rgba(255,255,255,.9)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-header{background:#fff;border-bottom:1px solid #f0f0f0;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;position:-webkit-sticky;position:sticky;top:0;z-index:20}.header-logo{height:36px;width:auto;object-fit:contain}.header-profile-btn{background:none;border:none;cursor:pointer;color:#111;padding:4px;display:flex;align-items:center}.my-page-header{display:flex;justify-content:space-between;align-items:center;padding:8px 4px 20px}.my-page-header-left{display:flex;flex-direction:column;gap:4px}.my-page-lv{font-size:13px;font-weight:700;color:var(--accent)}.my-page-nickname{font-size:26px;font-weight:900;color:#111}.my-char-circle{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.tab-nav{display:flex;background:white;border-bottom:1px solid #eee;position:-webkit-sticky;position:sticky;top:0;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.06)}.tab-btn{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 4px;background:none;cursor:pointer;font-size:16px;color:#bbb;font-family:Noto Sans KR,sans-serif;transition:all .2s;border:none;border-bottom:2px solid transparent}.tab-btn span{font-size:10px}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}.tab-content{padding:16px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px}.egg-spinner{font-size:48px;animation:bounce .8s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}.loading-state{text-align:center;padding:40px;color:var(--sub)}.member-selector{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.member-chip{padding:6px 12px;border-radius:20px;border:1px solid #ddd;background:white;font-size:12px;cursor:pointer;font-family:Noto Sans KR,sans-serif;transition:all .2s}.member-chip.active{background:var(--accent);color:white;border-color:var(--accent)}.character-card{border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow)}.card-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.lv-badge{background:var(--orange);color:white;padding:4px 10px;border-radius:12px;font-size:13px;font-weight:700}.nickname{font-size:20px;font-weight:700}.realname{font-size:14px;color:var(--sub)}.character-display{text-align:center;margin:20px 0}.character-emoji{font-size:64px;line-height:1}.exp-bar-container{display:flex;align-items:center;gap:8px;margin-bottom:16px}.exp-label{font-size:11px;color:var(--sub);white-space:nowrap}.exp-bar{flex:1 1;height:8px;background:rgba(0,0,0,.1);border-radius:4px;overflow:hidden}.exp-fill{height:100%;background:var(--orange);border-radius:4px;transition:width .5s ease}.exp-pct{font-size:11px;color:var(--sub);white-space:nowrap}.stats-row{display:flex;gap:8px}.stat-item{flex:1 1;background:rgba(255,255,255,.6);border-radius:12px;padding:10px;text-align:center}.stat-value{display:block;font-size:15px;font-weight:700}.stat-label{display:block;font-size:10px;color:var(--sub);margin-top:2px}.radar-section{background:white;border-radius:var(--radius);padding:16px;margin-bottom:16px;box-shadow:var(--shadow)}.section-title{font-size:15px;font-weight:700;margin-bottom:12px}.radar-container{width:200px;margin:0 auto 16px}.radar-chart{width:100%;height:100%}.score-breakdown{display:flex;flex-direction:column;gap:8px}.score-item{display:flex;align-items:center;gap:8px}.score-label{width:70px;font-size:12px}.score-bar-mini{flex:1 1;height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.score-bar-mini div{height:100%;background:var(--orange);border-radius:3px}.score-num{width:28px;text-align:right;font-size:12px;font-weight:600}.season-stats-section{background:white;border-radius:var(--radius);padding:16px;margin-bottom:16px;box-shadow:var(--shadow)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.stat-box{background:var(--gray-bg);border-radius:12px;padding:12px;text-align:center}.stat-box-val{font-size:16px;font-weight:700;color:var(--accent)}.stat-box-label{font-size:11px;color:var(--sub);margin-top:4px}.ranking{padding-bottom:20px}.ranking-header{text-align:center;margin-bottom:16px}.ranking-header h2{font-size:20px;font-weight:700}.ranking-sub{font-size:12px;color:var(--sub);margin-top:4px}.ranking-list{display:flex;flex-direction:column;gap:8px}.ranking-row{display:flex;align-items:center;gap:12px;background:white;border-radius:14px;padding:14px 16px;cursor:pointer;box-shadow:var(--shadow);transition:transform .1s}.ranking-row:active{transform:scale(.98)}.rank-num{font-size:20px;width:32px;text-align:center}.rank-egg{font-size:24px}.rank-info{flex:1 1}.rank-name{font-size:16px;font-weight:600}.rank-lv{font-size:12px;color:var(--accent)}.rank-scores{text-align:right}.rank-score-main{font-size:16px;font-weight:700;color:var(--accent)}.rank-dist{font-size:12px;color:var(--sub)}.challenge-board{padding-bottom:20px}.challenge-header{text-align:center;margin-bottom:16px}.challenge-header h2{font-size:20px;font-weight:700}.challenge-period{font-size:13px;color:var(--sub);margin-top:4px}.challenge-goal{font-size:12px;color:var(--accent);margin-top:4px}.teams-container{display:flex;flex-direction:column;gap:16px}.team-card{background:white;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);border-left:4px solid var(--orange)}.team-card.cleared{border-left-color:#4caf50}.team-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.team-header h3{font-size:18px;font-weight:700}.badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.badge.cleared{background:#e8f5e9;color:#2e7d32}.badge.deficit{background:#fff3e0;color:#e65100}.team-members{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.team-member-chip{background:var(--gray-bg);border-radius:12px;padding:4px 10px;font-size:12px}.team-progress .progress-bar{height:10px;background:#f0f0f0;border-radius:5px;overflow:hidden;margin-bottom:6px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#c94060);border-radius:5px;transition:width .5s ease}.progress-labels{display:flex;justify-content:space-between;font-size:13px;font-weight:600}.shortfall-info{text-align:right;font-size:12px;color:#e65100;margin-top:6px}.calendar-page{padding-bottom:20px}.calendar-container{background:white;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.calendar-nav button{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;color:var(--accent)}.calendar-nav h3{font-size:15px;font-weight:700}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px}.calendar-dow{text-align:center;font-size:11px;color:var(--sub);padding:4px 0;font-weight:600}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;gap:1px}.calendar-day.has-run{cursor:pointer;background:#fff8f5}.calendar-day.today .day-num{background:var(--orange);color:white;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}.calendar-day.selected{background:#fff3e0;border:1px solid var(--orange)}.day-num{font-size:13px;font-weight:500}.fire-icon{font-size:12px}.monthly-summary{display:flex;justify-content:space-around;padding:12px 0;border-top:1px solid #f0f0f0;margin-top:12px;font-size:14px;font-weight:600;color:var(--accent)}.day-detail{margin-top:12px;padding:12px;background:var(--gray-bg);border-radius:12px}.day-detail h4{font-size:14px;font-weight:700;margin-bottom:10px}.activity-item{background:white;border-radius:10px;padding:10px;margin-bottom:8px}.act-name{font-size:14px;font-weight:600;margin-bottom:6px}.act-stats{display:flex;gap:12px;font-size:12px;color:var(--sub);flex-wrap:wrap}.empty-state{text-align:center;padding:60px 20px;color:var(--sub)}.empty-state p{font-size:16px;margin-bottom:8px}.empty-sub{font-size:13px}.my-page-wrap{padding-bottom:24px}.settings-section{display:flex;flex-direction:column;gap:12px;padding:16px;margin-top:8px}.settings-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.06)}.settings-card-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #f0f0f0}.settings-card-title{font-size:15px;font-weight:700}.settings-edit-btn{font-size:13px;color:#A51C30;background:none;border:none;cursor:pointer;font-weight:600}.info-rows{padding:8px 0}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #f9f9f9}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;color:#888;min-width:70px}.info-value{font-size:14px;color:#111;text-align:right;flex:1 1}.info-address{font-size:12px}.nickname-edit-row{display:flex;gap:6px;align-items:center}.info-input{border:1.5px solid #e0e0e0;border-radius:8px;padding:6px 10px;font-size:14px;outline:none;width:120px}.info-save-btn{background:#111;color:#fff;border:none;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer}.info-cancel-btn{background:none;border:1px solid #ddd;border-radius:8px;padding:6px 10px;font-size:13px;cursor:pointer;color:#666}.info-msg{font-size:12px;color:#A51C30;padding:0 16px 8px}.settings-link-row{display:flex;justify-content:space-between;align-items:center;padding:16px;text-decoration:none;color:#111;font-size:15px;width:100%;background:none;border:none;border-bottom:1px solid #f0f0f0;cursor:pointer}.settings-link-row:last-child{border-bottom:none}.settings-chevron{color:#ccc;font-size:18px}.logout-btn{color:#111}.delete-btn{color:#e53935}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:100}.modal-box{background:#fff;border-radius:20px;padding:28px 24px;width:300px;text-align:center}.modal-title{font-size:18px;font-weight:700;margin-bottom:10px}.modal-desc{font-size:14px;color:#666;margin-bottom:24px;line-height:1.5}.modal-btns{display:flex;gap:10px}.modal-cancel{border-radius:12px;border:1.5px solid #ddd;background:#fff;color:#666}.modal-cancel,.modal-confirm{flex:1 1;padding:14px;font-size:15px;font-weight:600;cursor:pointer}.modal-confirm{border-radius:12px;border:none;background:#e53935;color:#fff}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:#fff;border-top:1px solid #efefef;display:flex;z-index:50;box-shadow:0 -2px 12px rgba(0,0,0,.06)}.bottom-nav-btn{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px 12px;border:none;background:none;cursor:pointer;color:#bbb;font-family:Noto Sans KR,sans-serif;font-size:10px;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.bottom-nav-btn.active{color:var(--accent);font-weight:700}.bottom-nav-btn svg{transition:stroke .15s}.tab-content{flex:1 1;overflow-y:auto;padding:16px 16px 80px}.profile-modal{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:24px 16px 40px;position:relative}.modal-overlay{align-items:flex-end}.profile-modal-close{position:absolute;top:16px;right:16px;background:#f0f0f0;border:none;border-radius:50%;width:32px;height:32px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#555}.profile-modal-card{border-radius:var(--radius);padding:16px;margin-bottom:12px}.profile-modal-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.profile-modal-radar{margin-bottom:12px}.profile-modal-radar,.profile-modal-season{background:white;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.policy-page{max-width:600px;margin:0 auto;padding:40px 20px}.policy-page h1{font-size:22px;font-weight:700;margin-bottom:20px}.policy-page p{font-size:15px;color:#555;line-height:1.7}