@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css";@import"https://fonts.googleapis.com/css2?family=Fraunces:wght@600;700&family=Gamja+Flower&family=IBM+Plex+Mono:wght@400;600&family=IBM+Plex+Sans+KR:wght@300;400;500;600&family=Jua&family=Lexend:wght@300;400;500;600;700;800;900&family=Noto+Sans+KR:wght@300;400;500;700;900&display=swap";@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght@200..700&display=swap";:root{color-scheme:light;--bg: #f6f1ea;--bg-strong: #f3e6d6;--panel: #fffdf8;--panel-strong: #f9f1e5;--text: #1f1b16;--muted: #6f6559;--accent: #f47c2a;--accent-strong: #d85a16;--accent-soft: rgba(244, 124, 42, .18);--stroke: rgba(31, 27, 22, .12);--shadow: 0 18px 45px rgba(39, 25, 14, .18);--radius: 20px;--font-body: "Pretendard", "IBM Plex Sans KR", "Apple SD Gothic Neo", sans-serif;--font-display: "Lexend", "Pretendard", "Apple SD Gothic Neo", sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#fff7eb,#f3e6d6 40%,#efe1d1);color:var(--text);font-family:var(--font-body);-webkit-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}input,textarea,select,[contenteditable=true],[contenteditable=""]{-webkit-user-select:text;-ms-user-select:text;user-select:text;-webkit-touch-callout:default}.ce-select-mode,.ce-select-mode *,.dq-evp-passage,.dq-evp-passage *,.ms-review-wrapper,.ms-review-wrapper *{-webkit-user-select:text;-ms-user-select:text;user-select:text}body:before{content:"";position:fixed;inset:-30% 0 0;background:radial-gradient(circle at 30% 10%,rgba(244,124,42,.26),transparent 45%),radial-gradient(circle at 70% 20%,rgba(78,138,96,.08),transparent 50%);pointer-events:none;z-index:-1}html,body{overflow-x:hidden}#root{min-height:100vh}.page{padding:32px clamp(16px,4vw,48px) 80px;max-width:1400px;margin:0 auto;display:grid;gap:32px}.global-logo-bar{padding:16px clamp(16px,4vw,48px) 0;display:flex;align-items:center;gap:12px}.global-logo-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.global-logo-link img{height:28px;width:auto;max-width:100%;display:block}.global-home-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:10px;background:#ffaa5c1f;color:#8a5f4f;font-size:13px;font-weight:700;text-decoration:none;transition:background .15s}.global-home-btn:hover{background:#ffaa5c40}.global-home-btn .material-symbols-outlined{font-size:18px}.hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.9fr);gap:24px}.hero-intro,.hero-panel,.panel{background:var(--panel);border:1px solid var(--stroke);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);position:relative;overflow:hidden}.hero-intro:after{content:"";position:absolute;inset:-30% -10% auto auto;width:220px;height:220px;background:radial-gradient(circle,rgba(217,91,43,.25),transparent 65%);pointer-events:none}.hero-panel{display:grid;gap:14px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:140px;height:48px;border-radius:14px;background:transparent;box-shadow:var(--shadow);margin-bottom:16px}.brand-mark img{width:100%;height:100%;object-fit:contain}.hero-title{font-family:var(--font-display);font-size:28px;margin:0 0 6px}.hero-sub{margin:0 0 18px;color:var(--muted);font-size:15px}.hero-metrics{display:flex;gap:18px;flex-wrap:wrap}.hero-metrics .label{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);display:block}.hero-metrics .value{font-weight:600;font-size:14px}.hero-actions{display:flex;gap:10px;flex-wrap:wrap}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;padding:12px;border-radius:16px;background:var(--panel-strong);border:1px solid rgba(31,27,22,.08)}.status-grid .label{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.status-grid .value{font-weight:600;margin-top:4px;display:block}.status-grid .meta{font-size:12px;color:var(--muted)}.notice{padding:14px 18px;border-radius:14px;border:1px solid var(--stroke);background:var(--panel);font-size:14px}.notice.success{background:#458a5b1f;border-color:#458a5b66}.notice.error{background:#ca30301f;border-color:#ca303066}.session-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.panel h2{font-family:var(--font-display);margin-top:0;margin-bottom:12px}.stack{display:grid;gap:10px}.workspace{display:grid;grid-template-columns:minmax(240px,320px) minmax(0,1fr);gap:24px;align-items:start}.filters{position:sticky;top:20px;display:grid;gap:12px}.filter-row{display:flex;flex-wrap:wrap;gap:10px}.filter-chip{border-radius:999px;border:1px solid var(--stroke);padding:6px 12px;background:transparent;cursor:pointer;font-size:12px;transition:all .2s ease}.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.filter-meta{font-size:12px;color:var(--muted)}.groups{display:grid;gap:24px}.action-group{background:var(--panel);border:1px solid var(--stroke);border-radius:var(--radius);padding:20px;display:grid;gap:16px;box-shadow:var(--shadow)}.group-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.group-head h3{margin:0 0 6px;font-family:var(--font-display)}.group-head p{margin:0;color:var(--muted);font-size:13px}.count{background:var(--accent-soft);color:var(--accent-strong);padding:6px 10px;border-radius:999px;font-size:12px}.action-list{display:grid;gap:12px}.action{border:1px solid rgba(31,27,22,.12);border-radius:16px;background:#fff;overflow:hidden}.action summary{list-style:none;cursor:pointer;padding:16px;display:grid;gap:10px}.action summary::-webkit-details-marker{display:none}.action[open] summary{background:var(--panel-strong);border-bottom:1px solid rgba(31,27,22,.08)}.action-head{display:flex;gap:12px;align-items:center}.action-head h4{margin:0 0 4px;font-size:16px}.action-head p{margin:0;color:var(--muted);font-size:12px}.method{padding:6px 10px;border-radius:999px;font-size:11px;letter-spacing:.08em;font-weight:700;text-transform:uppercase}.method.get{background:#226ea826;color:#226ea8}.method.post{background:#458a5b33;color:#458a5b}.method.patch{background:#c6833033;color:#c68330}.method.delete{background:#ca303033;color:#ca3030}.action-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.path{font-family:IBM Plex Mono,Courier New,monospace;font-size:12px;color:var(--muted)}.action-tags{display:flex;gap:8px}.tag{padding:4px 8px;border-radius:999px;font-size:11px;background:#1958821f;color:#195882}.scope-public{background:#464c5826;color:#4a4f59}.scope-user{background:#19588226;color:#195882}.scope-paid{background:#d95b2b2e;color:#b84b21}.scope-admin{background:#9c3f912e;color:#8a2d7d}.action-body{padding:16px 18px 20px;display:grid;gap:12px}.action-note{font-size:12px;color:var(--muted);margin:0}.input-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.field{display:grid;gap:6px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}input,textarea,select{border-radius:12px;padding:10px 12px;border:1px solid rgba(31,27,22,.18);background:#fff;font-family:inherit}textarea{resize:vertical;font-size:13px}input:focus,textarea:focus,select:focus{outline:2px solid rgba(217,91,43,.35);border-color:#d95b2bcc}.action-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{padding:10px 16px;border-radius:999px;border:none;background:var(--accent);color:#fff;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #d95b2b4d}.btn.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}.inline-error{color:#ca3030;font-size:13px}.response{background:#1a1410;color:#fef8ef;border-radius:12px;padding:12px;font-size:12px}.response-meta{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:#fff9;margin-bottom:6px}.response pre{margin:0;white-space:pre-wrap;word-break:break-word;font-family:IBM Plex Mono,Courier New,monospace}.ws-panel{display:grid;gap:18px}.ws-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.ws-head p{margin:6px 0 0;color:var(--muted);font-size:13px}.ws-status{padding:6px 12px;border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.1em;background:#464c5826;color:#4a4f59}.ws-status.connected{background:#458a5b33;color:#458a5b}.ws-status.connecting{background:#c6833033;color:#c68330}.ws-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px}.ws-controls{display:grid;gap:12px}.ws-actions,.ws-samples{display:flex;gap:10px;flex-wrap:wrap}.ws-log{background:var(--panel-strong);border-radius:16px;padding:16px;display:grid;gap:8px;max-height:320px;overflow-y:auto}.log-entry{display:grid;grid-template-columns:auto auto 1fr;gap:10px;font-size:12px;color:var(--text);padding:6px 8px;border-radius:10px;background:#ffffffa6}.log-entry .time{color:var(--muted);font-variant-numeric:tabular-nums}.log-entry.sent{border:1px solid rgba(69,138,91,.4)}.log-entry.error{border:1px solid rgba(202,48,48,.4)}.log-entry.system{border:1px solid rgba(25,88,130,.4)}.muted{color:var(--muted);font-size:14px;margin:0}@media(max-width:1100px){.hero,.workspace,.ws-grid{grid-template-columns:1fr}.filters{position:static}}@media(max-width:720px){.hero-intro,.hero-panel,.panel{padding:20px}.hero-title{font-size:24px}.log-entry{grid-template-columns:1fr}}.landing-page{--landing-primary: #ff8f2b;--landing-primary-dark: #e0700f;--landing-secondary: #6da475;--landing-bg: #fff6ee;--landing-ink: #131811;--landing-soft: #fff0e2;--landing-border: rgba(19, 24, 17, .12);background:var(--landing-bg);color:var(--landing-ink);font-family:var(--font-body);min-height:100vh;word-break:keep-all}.landing-page *{box-sizing:border-box}.landing-wrap{max-width:1180px;margin:0 auto;padding:0 24px}.landing-display{font-family:var(--font-display)}.landing-nav{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f8faf8e6;border-bottom:1px solid var(--landing-border)}.landing-nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px}.landing-brand{display:flex;align-items:center;gap:10px}.landing-logo{height:42px;width:auto;object-fit:contain}.landing-nav-links{display:flex;align-items:center;gap:24px;font-weight:600;color:var(--landing-secondary)}.landing-nav-links a{color:inherit;text-decoration:none;transition:color .2s}.landing-nav-links a:hover{color:var(--landing-primary-dark)}.landing-nav-auth{display:flex;align-items:center;gap:8px}.landing-nav-cta{padding:10px 22px;border-radius:999px;background:var(--landing-primary);color:var(--landing-ink);text-decoration:none;font-weight:800;box-shadow:0 10px 30px #ff9a3d40;white-space:nowrap}.landing-nav-logout{padding:10px 18px;border-radius:999px;background:none;border:2px solid rgba(0,0,0,.15);color:var(--landing-ink);font-weight:700;font-size:14px;cursor:pointer;white-space:nowrap;transition:background .15s}.landing-nav-logout:hover{background:#0000000d}.landing-mobile-logout{display:block;width:100%;padding:12px;border:2px solid rgba(0,0,0,.12);border-radius:12px;background:none;font-weight:700;font-size:15px;cursor:pointer;color:var(--landing-ink)}.landing-hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--landing-ink);padding:8px;font-size:0}.landing-hamburger .material-symbols-outlined{font-size:28px}.landing-mobile-menu{display:none;flex-direction:column;padding:12px 24px 20px;border-top:1px solid var(--landing-border);background:#f8faf8fa}.landing-mobile-menu a{display:block;padding:12px 0;text-decoration:none;color:var(--landing-ink);font-weight:600;border-bottom:1px solid var(--landing-border)}.landing-mobile-menu a:last-child{border-bottom:none}.landing-mobile-login{margin-top:8px;text-align:center;padding:12px 20px;border-radius:999px;background:var(--landing-primary);color:var(--landing-ink)!important;font-weight:800}.landing-hero{position:relative;min-height:620px;display:grid;align-items:center;overflow:hidden}.landing-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(110deg,#000000a6,#0003);z-index:1}.landing-hero:after{content:"";position:absolute;inset:0;background-image:url(/landing-hero.jpg);background-size:cover;background-position:center;z-index:0}.landing-hero-content{position:relative;z-index:2;color:#fff;display:grid;gap:28px;max-width:600px;padding:80px 0}.landing-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:6px 16px;background:#ffffff2e;border:1px solid rgba(255,255,255,.3);font-size:12px;letter-spacing:.08em;font-weight:700;width:fit-content}.landing-hero h1{margin:0;font-size:clamp(34px,4vw,64px);line-height:1.05;font-weight:900}.landing-hero-title-line{display:block;white-space:normal}.landing-hero p{margin:0;font-size:18px;line-height:1.6;color:#ffffffe0}.landing-hero-actions{display:flex;gap:12px;flex-wrap:wrap}.landing-btn-primary,.landing-btn-ghost{border-radius:999px;padding:16px 28px;font-weight:800;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:transform .15s,box-shadow .15s;border:none;cursor:pointer;font-size:16px}.landing-btn-primary{background:var(--landing-primary);color:var(--landing-ink);box-shadow:0 16px 40px #ff9a3d59}.landing-btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 48px #ff9a3d73}.landing-btn-ghost{background:#ffffff29;border:1px solid rgba(255,255,255,.3);color:#fff}.landing-stats-bar{background:var(--landing-primary);padding:24px 0}.landing-stats-inner{display:flex;justify-content:center;gap:48px;flex-wrap:wrap}.landing-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.landing-stat strong{font-size:28px;font-weight:900;font-family:var(--font-display);color:var(--landing-ink)}.landing-stat span{font-size:14px;font-weight:600;color:#131811b3}.landing-section{padding:90px 0}.landing-alt-bg{background:#f2f7f1}.landing-section-title{text-align:center;max-width:640px;margin:0 auto 50px;display:grid;gap:12px}.landing-section-title h2{margin:0;font-size:clamp(28px,3vw,44px);font-weight:900}.landing-section-title p{margin:0;color:var(--landing-secondary);font-size:18px}.landing-tag{display:inline-block;padding:4px 12px;border-radius:999px;background:var(--landing-soft);color:var(--landing-primary-dark);font-size:13px;font-weight:700}.landing-more-wrap{text-align:center;margin-top:36px}.landing-more-link{display:inline-flex;align-items:center;gap:6px;color:var(--landing-primary-dark);text-decoration:none;font-weight:700;font-size:16px;transition:gap .2s}.landing-more-link:hover{gap:10px}.landing-more-link .material-symbols-outlined{font-size:20px}.landing-card-img{width:100%;aspect-ratio:4 / 3;border-radius:16px;overflow:hidden;background:transparent}.landing-card-img img{width:100%;height:100%;object-fit:cover;display:block}.landing-card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px}.landing-card{background:#fff;border-radius:24px;padding:32px 24px;border:1px solid #e2eadf;box-shadow:0 8px 24px #1318110f;display:grid;gap:12px;text-align:center}.landing-card-icon{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin:0 auto;background:#ff9a3d1f}.landing-card-icon .material-symbols-outlined{font-size:28px;color:var(--landing-primary)}.landing-card h3{margin:0;font-size:18px;font-weight:800}.landing-card p{margin:0;font-size:14px;line-height:1.6;color:#555}.landing-mode-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.landing-mode-card{background:#fff;border-radius:20px;padding:28px 24px;border:1px solid #e2eadf;box-shadow:0 8px 24px #1318110f;display:grid;gap:10px;text-align:center}.landing-mode-card .landing-card-img{aspect-ratio:4 / 3;border-radius:14px}.landing-mode-card .material-symbols-outlined{font-size:36px;color:var(--landing-primary);margin:0 auto}.landing-mode-card h3{margin:0;font-size:17px;font-weight:800}.landing-mode-card p{margin:0;font-size:14px;line-height:1.5;color:#555}.landing-tier-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}.landing-tier-card{background:#fff;border-radius:24px;padding:32px 20px;border:1px solid #e2eadf;box-shadow:0 8px 24px #1318110f;display:grid;gap:8px;text-align:center;justify-items:center}.landing-tier-card .landing-card-img{aspect-ratio:1 / 1;border-radius:50%;width:120px;background:#f0f4ef}.landing-tier-icon{width:56px;height:56px;border-radius:50%;display:grid;place-items:center}.landing-tier-icon .material-symbols-outlined{font-size:28px}.landing-tier-card h3{margin:0;font-size:18px;font-weight:800}.landing-tier-levels{font-size:13px;font-weight:700;color:var(--landing-primary-dark);background:#ff8f2b1a;padding:4px 12px;border-radius:999px}.landing-tier-card p{margin:0;font-size:14px;color:#555}.landing-pricing{background:#f2f7f1}.landing-pricing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}.landing-plan{background:#fff;border-radius:32px;padding:32px;border:1px solid #dde6d8;display:grid;gap:20px;position:relative;overflow:hidden}.landing-plan.featured{border:2px solid var(--landing-primary);box-shadow:0 24px 50px #ff9a3d40;transform:scale(1.03)}.landing-plan-badge{position:absolute;top:16px;right:-24px;transform:rotate(12deg);background:var(--landing-primary);color:var(--landing-ink);padding:6px 18px;border-radius:999px;font-weight:800;font-size:12px}.landing-plan .landing-pill{background:#ff8f2b26;border-color:#ff8f2b4d;color:var(--landing-primary-dark)}.landing-plan h3{margin:0;font-size:26px}.landing-plan-price-row{display:flex;align-items:baseline;gap:4px}.landing-plan-price{font-size:36px;font-weight:900}.landing-plan-discount{padding:6px 14px;border-radius:12px;background:#ff8f2b1a;color:var(--landing-primary-dark);font-size:13px;font-weight:700;text-align:center}.landing-plan ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;color:var(--landing-secondary)}.landing-plan li{display:flex;align-items:center;gap:10px}.landing-plan li .material-symbols-outlined{font-size:18px;color:var(--landing-primary)}.landing-plan button,.landing-plan a{text-align:center;border-radius:20px;padding:14px 20px;font-weight:800;text-decoration:none;border:2px solid #e0e8db;color:var(--landing-ink);background:#f7faf6;transition:background .2s}.landing-plan.featured a{background:var(--landing-primary);border-color:var(--landing-primary)}.landing-faq-list{max-width:740px;margin:0 auto;display:grid;gap:12px}.landing-faq-item{background:#fff;border-radius:16px;border:1px solid #e2eadf;overflow:hidden}.landing-faq-item summary{padding:20px 24px;font-weight:700;font-size:16px;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between}.landing-faq-item summary::-webkit-details-marker{display:none}.landing-faq-item summary:after{content:"+";font-size:22px;font-weight:300;color:var(--landing-primary);flex-shrink:0;margin-left:16px}.landing-faq-item[open] summary:after{content:"−"}.landing-faq-item p{margin:0;padding:0 24px 20px;line-height:1.7;color:#555}.landing-cta{background:linear-gradient(135deg,#142210,#1a3a15,#142210);color:#fff;padding:90px 0;position:relative;overflow:hidden}.landing-cta-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.landing-cta-text{display:grid;gap:20px}.landing-cta-text h2{margin:0;font-size:clamp(28px,3vw,40px);font-weight:900}.landing-cta-text p{margin:0;font-size:18px;color:#fffc}.landing-contact-info{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:32px;display:grid;gap:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.landing-contact-info h3{margin:0;font-size:20px;font-weight:800}.landing-contact-info>p{margin:0;font-size:15px;color:#ffffffb3}.landing-contact-methods{display:grid;gap:12px}.landing-contact-method{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:16px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);text-decoration:none;color:#fff;transition:background .2s,transform .15s}.landing-contact-method:hover{background:#ffffff26;transform:translateY(-1px)}.landing-contact-method .material-symbols-outlined{font-size:28px;color:var(--landing-primary);flex-shrink:0}.landing-contact-method div{display:flex;flex-direction:column;gap:2px}.landing-contact-method strong{font-size:14px;font-weight:700}.landing-contact-method span{font-size:16px;font-weight:800;color:var(--landing-primary)}.landing-footer{padding:60px 0 0;background:#fff;border-top:1px solid #e6efe2}.landing-footer-grid{display:grid;grid-template-columns:2fr 3fr;gap:32px}.landing-footer-nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.landing-footer-nav h4{margin:0 0 8px;font-size:14px}.landing-footer-nav a{display:block;text-decoration:none;color:var(--landing-secondary);font-size:14px;margin-bottom:6px;transition:color .2s}.landing-footer-nav a:hover{color:var(--landing-primary-dark)}.landing-footer-bottom{margin-top:40px;padding:20px 0;border-top:1px solid #e6efe2;text-align:center}.landing-footer-bottom p{margin:0;font-size:13px;color:#999}.landing-footer-biz{margin-top:8px!important;font-size:12px!important;color:#bbb!important}@media(max-width:1024px){.landing-nav-links,.landing-nav-cta,.landing-nav-auth{display:none}.landing-hamburger{display:block}.landing-mobile-menu{display:flex}.landing-hero{min-height:520px}.landing-card-grid,.landing-tier-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-cta-inner{grid-template-columns:1fr;text-align:center}.landing-cta-text{justify-items:center}.landing-footer-grid{grid-template-columns:1fr}.landing-footer-nav{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:720px){.landing-wrap{padding:0 18px}.landing-hero-content{padding:60px 0}.landing-hero h1{font-size:clamp(28px,6vw,40px)}.landing-hero-actions{flex-direction:column;align-items:stretch}.landing-stats-inner{gap:24px}.landing-stat strong{font-size:22px}.landing-section{padding:70px 0}.landing-card-grid{grid-template-columns:1fr 1fr}.landing-mode-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}.landing-tier-grid{grid-template-columns:1fr 1fr}.landing-pricing-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}.landing-plan.featured{transform:none}.landing-footer-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-section-title h2{font-size:clamp(22px,5vw,32px)}.landing-contact-info{padding:24px}}@media(max-width:480px){.landing-card-grid{grid-template-columns:1fr}.landing-tier-grid{grid-template-columns:1fr;max-width:320px;margin:0 auto}.landing-card-img{aspect-ratio:3 / 2;border-radius:12px}.landing-tier-card .landing-card-img{width:100px}}.auth-page{--auth-orange: #f47c2a;--auth-orange-dark: #d85a16;--auth-green: #6da475;--auth-ink: #2b221d;background:radial-gradient(circle at 15% 10%,rgba(240,108,36,.35),transparent 45%),radial-gradient(circle at 90% 20%,rgba(78,138,96,.12),transparent 50%),linear-gradient(130deg,#fff1e5,#ffe4cd 80%,#edf6ef);min-height:100vh;max-width:100%;overflow-x:hidden;color:var(--auth-ink);font-family:var(--font-body)}.auth-shell{display:grid;grid-template-columns:1.1fr .9fr;min-height:100vh}.auth-hero{padding:80px 70px;display:grid;align-content:center;gap:24px;background-image:linear-gradient(120deg,#fff4e8eb,#ffefe0bf 45%,#ffead673),url(/auth-hero.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}.auth-hero h1{margin:0;font-size:clamp(32px,4vw,56px);font-weight:800;font-family:var(--font-display)}.auth-hero p{margin:0;font-size:18px;line-height:1.6;color:#5a4a43}.auth-highlight{display:inline-flex;gap:8px;align-items:center;padding:6px 16px;border-radius:999px;background:#f06c2426;font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase}.auth-panel{background:#ffffffeb;border-left:1px solid rgba(240,108,36,.12);padding:80px 60px;display:grid;align-content:center}.auth-card{background:#fff;border-radius:28px;border:1px solid rgba(240,108,36,.2);padding:28px;display:grid;gap:16px;box-shadow:0 20px 40px #f06c2426}.auth-card h2{margin:0;font-size:24px;font-weight:700}.auth-card form{display:grid;gap:14px}.auth-card label{display:grid;gap:6px;font-size:13px;color:#6b5b53}.auth-card input,.auth-card select{width:100%;min-width:0;padding:12px 14px;border-radius:14px;border:1px solid rgba(43,34,29,.16);font-size:15px}.auth-actions{display:grid;gap:10px;margin-top:6px}.auth-primary{border:none;border-radius:14px;padding:12px;background:var(--auth-orange);color:#fff;font-weight:700;font-size:16px;cursor:pointer}.auth-primary:disabled{opacity:.6;cursor:default}.auth-secondary{border:1px solid rgba(240,108,36,.3);border-radius:14px;padding:12px;background:#fff7ef;color:var(--auth-ink);font-weight:600;text-decoration:none;text-align:center}.auth-links{display:flex;justify-content:space-between;font-size:13px;color:#6b5b53}.auth-links a{color:inherit;text-decoration:none}.auth-error{color:#c0392b;font-size:13px}.auth-success{color:#27ae60;font-size:13px;background:#27ae601a;padding:12px 16px;border-radius:10px}.auth-notice{background:#f06c241a;border:1px solid rgba(240,108,36,.2);border-radius:10px;padding:12px 16px;font-size:13px;color:#8b5a30;line-height:1.5}.auth-info{background:#3498db1a;border:1px solid rgba(52,152,219,.2);border-radius:10px;padding:12px 16px;font-size:13px;color:#2471a3;line-height:1.5}.pending-card{text-align:center}.pending-icon{display:flex;justify-content:center;margin-bottom:8px}.pending-icon .material-symbols-outlined{font-size:64px;color:var(--auth-orange);animation:pendingPulse 2s ease-in-out infinite}@keyframes pendingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.pending-message{font-size:16px;color:var(--auth-ink);margin:0}.pending-description{font-size:14px;color:#6b5b53;line-height:1.6;margin:0}.pending-user-info{font-size:14px;color:var(--auth-ink);background:#f06c2414;padding:12px 16px;border-radius:10px;margin:8px 0}.pending-actions{display:grid;gap:10px;margin-top:8px}.pending-actions .auth-primary{display:flex;align-items:center;justify-content:center;gap:8px}.pending-actions .auth-primary .material-symbols-outlined{font-size:18px}.pending-notice{font-size:12px;color:#999;margin-top:8px}@media(max-width:960px){.auth-shell{grid-template-columns:1fr}.auth-hero{padding:60px 40px 20px}.auth-panel{padding:30px 40px 60px}}@media(max-width:640px){.auth-hero{padding:36px 20px 10px}.auth-hero h1{font-size:26px}.auth-panel{padding:16px 16px 40px}.auth-card{padding:20px;border-radius:20px}}.sp-page{max-width:900px;margin:0 auto;padding:20px 16px 100px}.sp-header{margin-bottom:20px}.sp-header h1{font-size:1.3rem;color:#3e2c1e;display:flex;align-items:center;gap:8px}.sp-plan-select{margin-top:8px}.sp-plan-select select{padding:8px 12px;border-radius:8px;border:1px solid #ddd;font-size:.85rem;background:#fff}.sp-exam-scope{margin-top:8px;padding:10px 14px;background:#fef3e5;border-radius:8px;font-size:.82rem;color:#6d4c41;border-left:3px solid #ff7f2a}.sp-tabs{display:flex;gap:0;border-bottom:2px solid #eee;margin-bottom:20px}.sp-tab{padding:10px 20px;background:none;border:none;font-size:.85rem;color:#999;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:6px;font-weight:600}.sp-tab:hover{color:#666}.sp-tab.active{color:#f06c24;border-bottom-color:#f06c24}.sp-matrix-wrap{overflow-x:auto;margin-bottom:20px}.sp-matrix{min-width:500px;width:100%;border-collapse:collapse;font-size:.82rem}.sp-matrix th,.sp-matrix td{padding:10px 8px;text-align:center;border:1px solid rgba(0,0,0,.06)}.sp-matrix thead th{background:#f5f0eb;color:#6d4c41;font-weight:700;font-size:.78rem;position:sticky;top:0;z-index:2}.sp-matrix thead th:first-child{text-align:left;min-width:120px;max-width:120px;width:120px;position:sticky;left:0;top:0;z-index:4;background:#f5f0eb}.sp-matrix tbody th:first-child,.sp-matrix tbody th.sp-scope-header{position:sticky;left:0;z-index:1;background:#faf7f4}.sp-matrix thead th:not(:first-child):not(.sp-add-col-th),.sp-matrix tbody td{min-width:130px;max-width:130px;width:130px}.sp-matrix tbody th{text-align:left;background:#faf7f4;color:#5d4037;font-weight:600}.sp-matrix td{cursor:pointer;transition:background .15s}.sp-matrix td:hover{background:#ff7f2a0f}.sp-matrix.admin-theme th,.sp-matrix.admin-theme td{border-color:#ffffff0f}.sp-matrix.admin-theme thead th{background:#ffffff0d;color:#8a7468}.sp-matrix.admin-theme thead th:first-child{background:#ffffff0d}.sp-matrix.admin-theme tbody th,.sp-matrix.admin-theme tbody th.sp-scope-header{background:#ffffff08;color:#ccc}.sp-matrix.admin-theme td{color:#d4c8be}.sp-matrix.admin-theme td:hover{background:#ff7f2a1a}.cell-stage{display:inline-block;padding:5px 12px;border-radius:14px;font-size:.78rem;font-weight:700;white-space:nowrap;letter-spacing:-.02em}.cell-stage.stage-unassigned{background:#9e9e9e0f;color:#888;border:1.5px dashed rgba(158,158,158,.5)}.cell-stage.stage-pending{background:#ffc10733;color:#8a6d00}.cell-stage.stage-overdue{background:#78787838;color:#4a4a4a;border:1px solid rgba(120,120,120,.4)}.cell-stage.stage-done{background:#2196f333;color:#0d47a1}.cell-stage.stage-reviewed{background:#4caf5047;color:#1b5e20}.cell-stage.stage-student-submitted{background:#2196f32e;color:#0d47a1;border:1px solid rgba(33,150,243,.4)}.cell-stage.stage-student-partial{background:#ff98002e;color:#b76d00;border:1px solid rgba(255,152,0,.55)}.cell-stage.stage-admin-completed{background:#4caf5047;color:#1b5e20;border:1px solid rgba(76,175,80,.5)}.cell-stage.stage-admin-reviewed{background:#8bc34a38;color:#33691e;border:1px solid rgba(139,195,74,.5)}.cell-stage.stage-disabled{background:repeating-linear-gradient(-45deg,#7878782e,#7878782e 4px,#7878781a 4px 8px);color:#777;border:1px solid rgba(120,120,120,.35)}.sp-matrix tbody td:hover .cell-stage.stage-unassigned,.sp-matrix tbody td:hover .cell-stage.stage-overdue{border-color:var(--admin-accent, #2d6a4f)}.cell-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:.72rem;font-weight:700;white-space:nowrap}.cell-badge.unassigned{background:#9e9e9e0f;color:#888;border:1.5px dashed rgba(158,158,158,.5);cursor:pointer}.cell-badge.unassigned:hover{background:#2d6a4f14;border-color:var(--admin-accent, #2d6a4f);color:var(--admin-accent-strong, #1f4a37)}.cell-badge.pending{background:#ffc1072e;color:#8a6d00}.cell-badge.in_progress,.cell-badge.submitted{background:#2196f32e;color:#1565c0}.cell-badge.partial{background:#ff98002e;color:#ef6c00}.cell-badge.completed{background:#4caf5047;color:#2e7d32;font-weight:700}.cell-badge.scored{background:#ff980038;color:#ef6c00}.cell-badge.passed,.cell-badge.reviewed{background:#4caf5047;color:#2e7d32;font-weight:700}.cell-badge.retry{background:#f443362e;color:#c62828}.cell-badge.approved{background:#4caf5047;color:#2e7d32;font-weight:700}.cell-badge.rejected{background:#f443362e;color:#c62828}.cell-badge.grading{background:#ff98002e;color:#ef6c00}.cell-badge.failed{background:#f4433638;color:#c62828}.cell-badge.overdue{background:#78787833!important;color:#555!important;border:1px solid rgba(120,120,120,.4)!important;font-weight:500!important;cursor:pointer}.cell-overdue-tag{display:inline-block;margin-left:4px;padding:1px 5px;background:#f443362e;color:#c62828;border-radius:4px;font-size:.68rem;font-weight:600}.cell-asgn-label{opacity:.9;font-weight:500}.cell-verdict{display:block;font-size:.62rem;font-weight:600;line-height:1.2;margin-top:1px}.sp-matrix td.cell-unassigned{border:1px dashed rgba(158,158,158,.4)}.sp-matrix td.cell-partial{border:2px solid rgba(255,152,0,.4);position:relative}.sp-matrix td.cell-student-submitted{background:#2196f31a;border:2px solid rgba(33,150,243,.45);position:relative}.sp-matrix td.cell-student-partial{background:#ff98001a;border:2px solid rgba(255,152,0,.55);position:relative}.sp-matrix td.cell-admin-completed{background:#4caf501a;border:2px solid rgba(76,175,80,.45)}.sp-matrix td.cell-admin-reviewed{background:#8bc34a1a;border:2px solid rgba(139,195,74,.45)}.sp-matrix td.cell-disabled{background:repeating-linear-gradient(-45deg,#b4b4b41a,#b4b4b41a 6px,#b4b4b42e 6px 12px);cursor:not-allowed!important;opacity:.7}.sp-matrix td.cell-disabled:hover{background:repeating-linear-gradient(-45deg,#b4b4b41a,#b4b4b41a 6px,#b4b4b42e 6px 12px)!important}.sp-calendar{background:#fff;border-radius:12px;padding:16px;border:1px solid #eee}.sp-calendar.admin-theme{background:#ffffff08;border-color:#ffffff0f}.sp-cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sp-cal-header h3{font-size:1rem;color:#3e2c1e}.sp-calendar.admin-theme .sp-cal-header h3{color:#e8ddd4}.sp-cal-nav{display:flex;gap:8px}.sp-cal-nav button{background:none;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:4px 10px;cursor:pointer;color:inherit}.sp-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.sp-cal-day-name{text-align:center;font-size:.72rem;color:#999;padding:4px;font-weight:600}.sp-cal-day{min-height:60px;padding:4px;border-radius:6px;font-size:.75rem;border:1px solid transparent}.sp-cal-day.in-range{background:#ff7f2a0a}.sp-cal-day.today{border-color:#ff7f2a}.sp-cal-day.other-month{opacity:.3}.sp-cal-day-num{font-weight:600;margin-bottom:2px}.sp-cal-event{display:block;padding:1px 4px;border-radius:3px;font-size:.68rem;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#ff7f2a1f;color:#e06820}.sp-calendar.admin-theme .sp-cal-event{background:#ff7f2a26;color:#ff9f5a}.sp-submit-page{max-width:600px;margin:0 auto;padding:20px 16px 100px}.sp-submit-info{padding:14px;background:#fef3e5;border-radius:8px;margin-bottom:16px;font-size:.85rem;color:#6d4c41}.sp-reject-reason{padding:12px;background:#f4433614;border-left:3px solid #ef5350;border-radius:6px;margin-bottom:16px;font-size:.82rem;color:#c62828}.sp-file-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-bottom:16px}.sp-file-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;background:#f5f0eb}.sp-upload-area{border:2px dashed #ddd;border-radius:12px;padding:30px;text-align:center;cursor:pointer;color:#999;margin-bottom:16px;transition:border-color .2s}.sp-upload-area:hover{border-color:#f06c24}.sp-upload-area .material-symbols-outlined{font-size:36px;display:block;margin-bottom:8px}.sp-submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#ff7f2a,#e06820);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer}.sp-submit-btn:disabled{opacity:.5;cursor:not-allowed}.sp-reminder-overlay{position:fixed;inset:0;background:#0000008c;z-index:900;display:flex;align-items:center;justify-content:center;padding:20px}.sp-reminder-card{background:#fff;border-radius:16px;padding:28px;max-width:380px;width:100%;text-align:center}.sp-reminder-card h2{font-size:1.1rem;color:#3e2c1e;margin-bottom:12px}.sp-reminder-card p{font-size:.85rem;color:#666;margin-bottom:6px}.sp-reminder-actions{display:flex;flex-direction:column;gap:8px;margin-top:20px}.sp-reminder-actions button{padding:12px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;border:none}.sp-reminder-go{background:linear-gradient(135deg,#ff7f2a,#e06820);color:#fff}.sp-reminder-dismiss{background:#f5f0eb;color:#8a7468}.sp-reminder-upcoming{margin:12px 0 8px;padding:10px;background:#fff8f0;border-radius:8px;border:1px solid rgba(255,127,42,.15)}.sp-reminder-upcoming-title{font-size:13px;font-weight:700;color:#ff7f2a;margin-bottom:8px}.sp-reminder-upcoming-item{display:flex;align-items:center;gap:6px;padding:4px 0;font-size:13px;color:#3e2c1e}.sp-reminder-upcoming-type{display:inline-block;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:600;background:#ff7f2a1a;color:#e06820;white-space:nowrap}.sp-reminder-upcoming-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sp-reminder-upcoming-date{font-size:12px;color:#c04040;font-weight:600;white-space:nowrap}.sp-cal-event-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#f06c24;margin-left:4px;vertical-align:middle}.sp-cal-day.has-events{background:#f06c2414}.sp-event-modal{background:#fff;border-radius:16px;padding:20px;max-width:400px;width:100%;max-height:70vh;overflow-y:auto}.sp-event-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sp-event-modal-header h3{font-size:1rem;color:#3e2c1e;margin:0}.sp-event-modal-header button{background:none;border:none;cursor:pointer;color:#999}.sp-event-list{list-style:none;padding:0;margin:0}.sp-event-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid #f0ebe6}.sp-event-item:last-child{border-bottom:none}.sp-event-icon{font-size:20px}.sp-event-detail{display:flex;flex-direction:column;gap:2px}.sp-event-type{font-weight:700;font-size:.85rem}.sp-event-ref{font-size:.78rem;color:#666}.sp-event-memo{font-size:.75rem;color:#999}.sp-content-search-modal{background:#fff;border-radius:16px;padding:20px;max-width:520px;width:100%;max-height:80vh;display:flex;flex-direction:column;position:relative}.sp-csm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sp-csm-header h3{font-size:1rem;color:#3e2c1e;margin:0}.sp-csm-tabs{display:flex;gap:4px;margin-bottom:12px;border-bottom:2px solid #f0ebe6;padding-bottom:0}.sp-csm-tab{padding:8px 16px;border:none;background:none;font-size:13px;font-weight:600;color:#8a7468;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px}.sp-csm-tab.active{color:#ff7f2a;border-bottom-color:#ff7f2a}.sp-csm-close{background:none;border:none;cursor:pointer;color:#999}.sp-csm-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.sp-csm-filters select,.sp-csm-filters input{flex:1;min-width:120px;padding:8px 10px;border-radius:8px;border:1px solid #ddd;font-size:.82rem}.sp-csm-list{flex:1;overflow-y:auto;max-height:400px}.sp-csm-item{padding:10px 12px;border-bottom:1px solid #f0ebe6;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .15s}.sp-csm-item:hover{background:#ff7f2a0f}.sp-csm-item-title{font-size:.85rem;color:#3e2c1e}.sp-csm-item-area{font-size:.72rem;color:#999;background:#f5f0eb;padding:2px 8px;border-radius:10px}.sp-csm-empty{text-align:center;padding:30px;color:#999;font-size:.85rem}.sp-matrix-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;margin-bottom:8px;background:var(--admin-panel-light, #f5f9f3);border:1px solid rgba(31,58,44,.12);border-radius:8px}.sp-toolbar-input,.sp-toolbar-select{padding:6px 10px;font-size:13px;border:1px solid rgba(31,58,44,.2);border-radius:5px;background:#fff;color:var(--admin-ink, #1a2920);font-family:inherit}.sp-toolbar-input{min-width:180px}.sp-toolbar-select{cursor:pointer}.sp-toolbar-reset{margin-left:auto;padding:6px 12px;font-size:12px;background:#fff;color:var(--admin-muted, #555);border:1px dashed rgba(31,58,44,.3);border-radius:5px;cursor:pointer}.sp-toolbar-reset:hover{background:#fafafa;color:var(--admin-ink, #1a2920)}.start-page{--meadow-light: #e4f4e7;--meadow-green: #ffb26b;--meadow-dark: #f07f1a;--earth-brown: #8a5f4f;--earth-dark: #4a2f24;--sun-yellow: #ffd16b;--carrot-orange: #ff944d;--sky-blue: #81d4fa;--card-bg: #ffffff;--card-border: #f3d6bf;background:linear-gradient(135deg,#f5f7f0d9,#ffe6cfd9),url(/farm-bg.jpg) center/cover fixed no-repeat;color:var(--earth-dark);font-family:var(--font-body);min-height:100vh}.start-page h1,.start-page h2,.start-page h3,.start-page strong{font-family:var(--font-display);font-weight:700}.start-page *{box-sizing:border-box}.start-shell{max-width:1100px;margin:0 auto;padding:24px 20px 120px;position:relative}.start-header{background:#ffffffe6;border-radius:28px;padding:24px;border:2px solid rgba(255,170,92,.35);box-shadow:0 12px 24px #ffaa5c33;display:grid;gap:18px}.start-header-top{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center}.start-avatar{width:70px;height:70px;border-radius:50%;background:#ddd center/cover no-repeat;border:3px solid #fff;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.start-avatar .start-avatar-fallback{font-size:28px;color:#999}.start-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.start-level-label{font-size:13px;font-weight:700;color:var(--carrot-orange);background:#ff944d26;padding:2px 8px;border-radius:999px}.start-greeting h1{margin:0 0 6px;font-size:26px}.start-greeting span{color:var(--meadow-dark)}.start-xp{font-size:12px;font-weight:700;display:flex;justify-content:space-between}.start-progress{height:10px;border-radius:999px;background:var(--meadow-light);overflow:hidden;border:1px solid rgba(255,170,92,.4)}.start-progress span{display:block;height:100%;width:45%;background:linear-gradient(90deg,var(--meadow-green),var(--meadow-dark))}.start-season-score{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:14px;color:var(--earth-brown)}.start-season-score .material-symbols-outlined{font-size:18px;color:#e8a020}.start-season-label{font-weight:500;color:#8a7a6a}.start-season-score strong{font-size:18px;color:#d48a10}.start-season-score:hover{opacity:.8}.start-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.start-stat{background:#e4f4e7e6;border-radius:16px;padding:10px;display:grid;gap:6px;place-items:center;border:1px solid rgba(125,191,122,.3);font-weight:700}.start-stat span{font-size:14px;color:var(--earth-brown)}.start-sub-btn{margin-top:6px;padding:6px 14px;border:1px solid rgba(0,0,0,.15);border-radius:10px;background:#fff;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;color:var(--earth-brown);font-weight:600}.start-sub-btn--sm{margin-top:0;padding:4px 10px;font-size:12px}.start-section-block{margin-top:28px}.start-section-title{display:flex;align-items:center;gap:8px;font-size:18px;margin:0 0 14px;padding-bottom:8px;border-bottom:2px solid rgba(243,214,191,.6)}.start-free-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.start-free-card{background:#fff;border-radius:20px;padding:16px;border:2px solid var(--card-border);display:flex;gap:14px;cursor:pointer;box-shadow:0 8px 18px #ffaa5c26;transition:all .2s}.start-free-card:hover{box-shadow:0 10px 24px #ffaa5c47;transform:translateY(-2px)}.start-free-card-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;flex-shrink:0}.start-free-card-icon.quiz{background:linear-gradient(135deg,#ffb26b,#f07f1a);color:#fff}.start-free-card-icon.reading{background:linear-gradient(135deg,#81d4fa,#4fc3f7);color:#fff}.start-free-card-body{display:grid;gap:4px}.start-free-card-body .badge{display:inline-flex;align-items:center;gap:4px;background:var(--meadow-green);color:#fff;font-size:12px;padding:4px 8px;border-radius:8px;width:fit-content}.start-free-card-body h3{margin:0;font-size:16px}.start-free-card-body p{margin:0;font-size:13px}.start-learn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.start-learn-card{background:#fff;border-radius:20px;padding:18px;border:2px solid var(--card-border);cursor:pointer;position:relative;box-shadow:0 6px 14px #ffaa5c1f;transition:all .15s;display:grid;gap:6px}.start-learn-card:hover{box-shadow:0 8px 20px #ffaa5c47;transform:translateY(-2px)}.start-learn-card.--locked{opacity:.5;filter:grayscale(.6)}.start-learn-card.--locked:hover{box-shadow:0 6px 14px #ffaa5c1f;transform:none}.start-learn-card .material-symbols-outlined{font-size:28px;color:var(--meadow-dark)}.start-learn-card h3{margin:0;font-size:16px}.start-learn-card p{margin:0;font-size:12px;color:var(--earth-brown)}.start-duel-banner{display:grid;grid-template-columns:1.5fr 1fr;border-radius:24px;overflow:hidden;box-shadow:0 10px 24px #ff505033}.start-duel-banner-left{background:linear-gradient(140deg,#ff8a80,#e53935);color:#fff;padding:24px;display:grid;gap:8px}.start-duel-banner-left strong{font-size:18px}.start-duel-banner-left p{margin:0;font-size:14px;opacity:.9}.start-duel-banner-left button{background:#fff;color:#d32f2f;border:none;padding:10px 20px;border-radius:999px;font-weight:800;cursor:pointer;width:fit-content}.start-duel-ranking-mini{background:#fffffff2;padding:18px}.start-duel-ranking-mini h4{margin:0 0 10px;font-size:14px;color:var(--earth-dark)}.start-duel-ranking-mini ol{margin:0;padding:0 0 0 20px;font-size:13px;display:grid;gap:6px}.start-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.start-stats-card{background:#fff;border-radius:18px;padding:16px;border:2px solid rgba(255,241,118,.5);cursor:pointer;text-align:center;box-shadow:0 4px 12px #ffaa5c1a;transition:all .15s}.start-stats-card:hover{box-shadow:0 6px 18px #ffaa5c38}.start-stats-card .material-symbols-outlined{font-size:28px;color:var(--meadow-dark)}.start-stats-card h3{margin:6px 0 4px;font-size:14px}.start-stats-card p{margin:0;font-size:12px;color:var(--earth-brown)}.start-rank-list{list-style:none;padding:0;margin:6px 0 0;font-size:12px;display:grid;gap:3px;text-align:left}.start-quick-actions{display:flex;gap:10px;margin-top:14px}.start-quick-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:2px solid var(--card-border);border-radius:12px;background:#fff;font-size:13px;font-weight:700;color:var(--earth-brown);cursor:pointer;transition:all .15s}.start-quick-btn:hover{background:#ffaa5c1a;border-color:#ffaa5c80}.start-quick-btn .material-symbols-outlined{font-size:18px;color:var(--meadow-dark)}.start-external-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.start-external-card{background:#fff;border-radius:20px;padding:20px;border:2px solid var(--card-border);cursor:pointer;text-align:center;transition:all .15s;display:grid;place-items:center;gap:8px}.start-external-card:hover{box-shadow:0 6px 18px #ffaa5c38;transform:translateY(-2px)}.start-external-card.start-shop{background:linear-gradient(135deg,#fff1e0,#ffe0c2);border-color:#f07f1a59}.start-external-card h3{margin:0;font-size:16px}.start-external-card p{margin:0;font-size:13px;color:var(--earth-brown)}.start-grid{display:grid;grid-template-columns:2.2fr 1fr;gap:24px;margin-top:24px}.start-section{display:grid;gap:14px}.start-section h2{display:flex;align-items:center;gap:8px;font-size:22px;margin:0}.start-card{background:var(--card-bg);border-radius:24px;padding:18px;border:2px solid rgba(243,214,191,.9);box-shadow:0 10px 20px #ffaa5c2e;display:grid;gap:12px}.start-card .badge{display:inline-flex;align-items:center;gap:4px;background:var(--meadow-green);color:#fff;font-size:12px;padding:4px 8px;border-radius:8px}.start-card h3{margin:0;font-size:20px}.start-card-notice{margin:4px 0 0;font-size:11px;color:#999}.start-progress-mini{height:6px;background:#f2f2f2;border-radius:999px;overflow:hidden}.start-progress-mini span{display:block;height:100%;width:30%;background:var(--meadow-green)}.start-card button{border:none;background:var(--meadow-green);color:#fff;border-radius:12px;padding:8px 14px;font-weight:800;cursor:pointer;width:fit-content}.start-card-button{border:none;background:var(--meadow-green);color:#fff;border-radius:12px;padding:8px 14px;font-weight:800;cursor:pointer;width:fit-content;text-decoration:none;display:inline-flex}.start-basket{background:linear-gradient(140deg,#8d6e63,#5d4037);color:#fff;border-radius:24px;padding:18px;border:4px solid #5d4037;display:grid;gap:12px}.start-basket button{border:none;background:var(--meadow-green);color:#fff;font-weight:900;border-radius:14px;padding:10px 16px;cursor:pointer}.start-side{display:grid;gap:16px}.start-rank{background:#fff;border-radius:22px;padding:18px;border:2px solid rgba(255,241,118,.6)}.start-rank ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:14px}.start-rank-link{margin-top:12px;display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;background:var(--meadow-dark);color:#fff;font-size:13px;font-weight:700;text-decoration:none;width:fit-content}.start-shop{background:linear-gradient(135deg,#fff1e0,#ffe0c2);border-color:#f07f1a59}.start-shop-title{display:flex;align-items:center;gap:8px}.start-shop-title span{color:var(--meadow-dark)}.start-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:2px solid var(--card-border);display:none;justify-content:space-around;padding:10px 8px 16px;z-index:30}.start-nav a{text-decoration:none;color:var(--earth-brown);font-size:11px;font-weight:700;display:grid;justify-items:center;gap:4px}.start-nav a.active{color:var(--meadow-dark)}.start-paid-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.start-paid-card{background:var(--card-bg);border-radius:20px;padding:16px;border:2px solid var(--card-border);box-shadow:0 6px 14px #ffaa5c1f;display:grid;gap:6px;cursor:pointer;transition:box-shadow .15s;position:relative}.start-paid-card:hover{box-shadow:0 8px 20px #ffaa5c47}.start-paid-card .material-symbols-outlined{font-size:28px;color:var(--meadow-dark)}.start-paid-card h3{margin:0;font-size:16px}.start-paid-card p{margin:0;font-size:12px;color:var(--earth-brown)}.start-paid-card--locked{opacity:.5;filter:grayscale(.6)}.start-paid-card--locked:hover{box-shadow:0 6px 14px #ffaa5c1f}.start-lock-badge{position:absolute;top:8px;right:8px;background:#0000008c;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px}.start-card-admin-badge{display:inline-block;font-size:11px;color:#b45309;background:#fef3c7;padding:2px 8px;border-radius:4px;margin-top:4px}.start-seed-log{list-style:none;padding:0;margin:0;display:grid;gap:6px;font-size:13px}.harvest-overlay{position:fixed;inset:0;background:#00000073;display:grid;place-items:center;z-index:100}.harvest-modal{background:#fff;border-radius:24px;padding:28px;width:340px;max-width:92vw;display:grid;gap:16px;position:relative}.harvest-modal h2{margin:0;font-size:22px}.harvest-close{position:absolute;top:12px;right:12px;border:none;background:none;cursor:pointer;font-size:20px}.harvest-field{display:grid;gap:6px;font-weight:700;font-size:14px}.harvest-field select{padding:8px 12px;border-radius:12px;border:2px solid var(--card-border);font-size:14px}.harvest-toggle{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}.harvest-error{color:#d32f2f;font-size:13px}.harvest-result{display:flex;align-items:center;gap:8px;color:#2e7d32;font-weight:700}.harvest-submit{border:none;background:linear-gradient(135deg,#ffb26b,#f07f1a);color:#fff;font-weight:800;border-radius:14px;padding:12px;cursor:pointer;font-size:15px}.harvest-submit:disabled{opacity:.6;cursor:not-allowed}.result-overlay{position:fixed;inset:0;background:#0006;display:grid;place-items:center;z-index:9500}.hcm-card{max-width:380px;width:92vw;background:#fff;border-radius:24px;padding:24px;display:grid;gap:0;box-shadow:0 12px 32px #0000002e}.hcm-title{margin:0 0 16px;font-size:20px;text-align:center}.hcm-result-emoji{text-align:center;font-size:48px;margin-bottom:8px}.hcm-result-text{font-size:15px;line-height:1.8;text-align:center}.hcm-highlight{color:#f07f1a;font-size:18px}.hcm-btn-row{display:flex;gap:8px;justify-content:center;margin-top:16px}.hcm-btn{border:none;background:#ff8f2b;color:#fff;padding:10px 20px;border-radius:10px;cursor:pointer;font-weight:700;font-size:14px}.hcm-btn-secondary{background:#aaa}.hcm-btn:disabled{opacity:.5;cursor:not-allowed}.hcm-section{margin-bottom:16px}.hcm-section-label{font-size:12px;color:#888;margin-bottom:6px;text-align:center}.hcm-picker{display:flex;align-items:center;justify-content:center;gap:12px}.hcm-arrow{width:36px;height:36px;border:none;border-radius:10px;background:#fff5eb;color:#f07f1a;font-size:18px;font-weight:900;cursor:pointer;display:grid;place-items:center;transition:background .15s}.hcm-arrow:disabled{background:#eee;color:#ccc;cursor:not-allowed}.hcm-seed-display{text-align:center;min-width:120px}.hcm-seed-emoji{font-size:40px}.hcm-seed-name{font-weight:700;font-size:16px;margin-top:4px}.hcm-seed-count{font-size:12px;color:#888}.hcm-qty-display{text-align:center;min-width:100px;padding:8px 0;background:#f9f5f0;border-radius:12px}.hcm-qty-number{font-size:24px;font-weight:800;color:#f07f1a}.hcm-qty-label{font-size:11px;color:#888}.hcm-max-info{font-size:11px;color:#aaa;text-align:center;margin-top:4px}.hcm-insufficient{text-align:center;padding:12px 0;font-size:13px;color:#c0392b;margin-bottom:16px}.hcm-fertilizer{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;margin-bottom:16px}.hcm-fertilizer-enabled{cursor:pointer;color:#333}.hcm-fertilizer-disabled{cursor:not-allowed;color:#bbb}.hcm-preview{padding:12px 16px;background:#f9f5f0;border-radius:14px;margin-bottom:16px;text-align:center;line-height:1.8;font-size:14px}.hcm-preview-arrow{font-size:18px}.hcm-fertilizer-tag{color:#e67e22;font-size:12px}.hcm-error{color:#c0392b;font-size:13px;text-align:center;margin-bottom:12px}.start-daily-shell{max-width:500px;margin:0 auto;padding:60px 16px}.start-daily-shell h1{text-align:center;margin-bottom:8px}.start-daily-shell>p{text-align:center;color:#8a7468;margin-bottom:32px}.start-daily-grid{display:grid;gap:16px}.start-daily-grid .start-card{cursor:pointer}.badge-reading{background:#81d4fa}.lr-loading{padding:40px;text-align:center;font-family:var(--font-body)}.lr-error{color:#888}.start-modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.start-modal-card{max-width:360px;width:92vw;background:#fff;border-radius:24px;padding:24px;box-shadow:0 12px 32px #0000002e;display:grid}.start-modal-card h2{margin:0 0 12px;font-size:20px}.start-select{padding:6px 10px;border:1px solid rgba(0,0,0,.15);border-radius:10px;font-size:13px;color:#222;background:#fff;cursor:pointer;font-family:var(--font-body)}.start-formula-box{margin-top:12px;padding:10px 12px;background:#f06c2414;border-radius:12px;font-size:12px;color:#6b5b50}.start-label{font-size:13px;color:#6b5b50}.start-inv-row{display:flex;align-items:center;gap:8px;font-size:14px}.start-inv-row .inv-emoji{font-size:20px}.start-inv-row strong{min-width:50px}.start-modal-close{margin-top:12px;padding:8px 20px;border:none;border-radius:12px;background:var(--meadow-green, #ffb26b);color:#fff;font-weight:700;cursor:pointer}.start-flex-row{display:flex;align-items:center;gap:8px}.start-flex-wrap{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px;font-size:13px}.progress-bar{background:#eee;border-radius:8px;height:8px;overflow:hidden}.progress-bar-fill{background:#ff8f2b;border-radius:8px;height:100%;transition:width .3s}.start-btn-primary{padding:10px 20px;background:#ff8f2b;color:#fff;border:none;border-radius:8px;font-weight:700;cursor:pointer}.start-btn-secondary{padding:10px 20px;background:#eee;border:none;border-radius:8px;font-weight:700;cursor:pointer}.start-btn-ghost{margin-top:12px;padding:8px 16px;background:none;border:1px solid #ddd;border-radius:8px;cursor:pointer;width:100%}.page-center{max-width:700px;margin:80px auto;padding:0 20px;text-align:center}.page-center .text-muted{color:#8a7468;margin-top:12px}.page-center .text-error{color:#c0392b;margin-top:12px}.page-center .link-action{display:inline-block;margin-top:24px;color:#ff8f2b;font-weight:700;text-decoration:none}.common-table{width:100%;border-collapse:collapse;font-size:14px}.common-table thead tr{border-bottom:2px solid #d4c5b9;color:#6b5b50}.common-table th,.common-table td{padding:10px 8px;text-align:center;white-space:nowrap}.common-table tbody tr{border-bottom:1px solid #e8ddd4}@media(max-width:1024px){.start-grid{grid-template-columns:1fr}.start-side{grid-template-columns:repeat(2,minmax(0,1fr))}.start-stats-grid{grid-template-columns:repeat(2,1fr)}.start-duel-banner{grid-template-columns:1fr}}@media(max-width:768px){.start-shell{padding:20px 16px 120px}.start-header-top{grid-template-columns:auto 1fr}.start-cta{flex-direction:column;align-items:flex-start}.start-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.start-side{grid-template-columns:1fr}.start-nav{display:flex}.start-paid-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.start-free-row{grid-template-columns:1fr 1fr}.start-learn-grid{grid-template-columns:repeat(2,1fr)}.start-quick-actions{flex-wrap:wrap}}@media(max-width:480px){.start-free-card{flex-direction:column;gap:10px}.start-free-card-icon{width:44px;height:44px}}.search-bar{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #dfe1e5;border-radius:24px;padding:6px 12px;transition:box-shadow .2s;min-width:0;max-width:100%;overflow:hidden}.search-bar:hover{box-shadow:0 1px 6px #2021242e}.search-bar:focus-within{box-shadow:0 1px 6px #20212447;border-color:#dfe1e500}.search-bar input{flex:1;border:none;outline:none;font-size:14px;background:transparent;font-family:var(--font-body);color:var(--earth-dark);min-width:0}.search-bar input::placeholder{color:#9aa0a6}.search-bar input:disabled{cursor:pointer}.search-bar-icon{color:#9aa0a6;font-size:20px!important;flex-shrink:0}.search-bar-filter{border:none;background:none;cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;color:#5f6368;transition:background .15s}.search-bar-filter:hover{background:#0000000f}.search-bar-filter .material-symbols-outlined{font-size:20px}.search-bar-submit{border:none;background:var(--meadow-dark);color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .15s}.search-bar-submit:disabled{opacity:.4;cursor:not-allowed}.search-bar-submit .material-symbols-outlined{font-size:18px}.search-adv-field{margin-top:12px}.search-adv-field .start-label{display:block;margin-bottom:6px;font-weight:600}.search-adv-options{display:flex;flex-wrap:wrap;gap:6px}.search-adv-chip{padding:5px 12px;border:1px solid #ddd;border-radius:16px;background:#fff;font-size:13px;cursor:pointer;color:#555;transition:all .15s;font-family:var(--font-body)}.search-adv-chip:hover{border-color:var(--meadow-dark);color:var(--meadow-dark)}.search-adv-chip.--active{background:var(--meadow-dark);color:#fff;border-color:var(--meadow-dark)}.search-results-page{max-width:800px;margin:0 auto;padding:24px 20px 120px}.search-filters{display:flex;gap:6px;margin-top:16px;overflow-x:auto;padding-bottom:4px}.search-filter-tab{padding:6px 14px;border:1px solid #ddd;border-radius:20px;background:#fff;font-size:13px;cursor:pointer;color:#555;white-space:nowrap;transition:all .15s;font-family:var(--font-body)}.search-filter-tab:hover{border-color:var(--meadow-dark)}.search-filter-tab.--active{background:var(--meadow-dark);color:#fff;border-color:var(--meadow-dark)}.search-result-count{margin-top:16px;font-size:13px;color:#8a7468}.search-result-list{margin-top:8px}.search-result-item{padding:14px 0;border-bottom:1px solid #f0e8e0;cursor:pointer;transition:background .1s}.search-result-item:hover{background:#ffaa5c0f}.search-result-meta{display:inline-flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}.search-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.search-badge.--type{background:#f07f1a26;color:#c06000}.search-badge.--level{background:#81d4fa40;color:#0277bd}.search-badge.--area{background:#c8e6c999;color:#2e7d32}.search-result-title{font-size:15px;font-weight:600;color:var(--earth-dark)}.search-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px;font-size:14px}.search-pagination button{padding:8px 16px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-weight:600;font-family:var(--font-body)}.search-pagination button:disabled{opacity:.4;cursor:not-allowed}.search-paywall{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.search-paywall h2{margin:16px 0 8px;font-size:22px}.search-paywall p{color:#8a7468;font-size:14px}.search-empty{display:flex;flex-direction:column;align-items:center;padding:60px 20px;text-align:center}.search-empty p{margin:8px 0 0;font-size:15px;color:#666}@media(max-width:768px){.start-sub-btn--sm{padding:3px 7px;font-size:11px;gap:2px}.start-sub-btn--sm .material-symbols-outlined{font-size:13px!important}.search-bar input{font-size:13px}.search-results-page{padding:16px 16px 120px}}.notice-bell{position:relative;width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:transparent;border:none;cursor:pointer;transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent}.notice-bell:hover{background:#0000000a}.notice-bell:active{transform:scale(.92)}.notice-bell-icon{font-size:20px;line-height:1}.notice-bell-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#f06c24;color:#fff;font-size:10px;font-weight:800;line-height:18px;text-align:center;letter-spacing:-.02em;box-shadow:0 2px 4px #f06c244d,0 0 0 1.5px var(--bg, #F4EFE6);pointer-events:none}.notice-modal-backdrop{position:fixed;inset:0;background:#281e1473;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;border:none;cursor:pointer}.notice-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(92vw,480px);max-height:80vh;background:#fffaf0;border-radius:22px;box-shadow:0 20px 60px #281e1440;z-index:1001;display:flex;flex-direction:column;overflow:hidden}.notice-modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(216,203,177,.4);background:linear-gradient(155deg,#fff6e2,#f4efe6)}.notice-modal-head h2{margin:0;font-size:16px;font-weight:800;letter-spacing:-.02em;color:#2a2520}.notice-modal-close{width:32px;height:32px;border-radius:10px;background:transparent;border:none;cursor:pointer;font-size:14px;color:#6b6359;display:grid;place-items:center;transition:background .12s ease}.notice-modal-close:hover{background:#0000000d}.notice-modal-body{flex:1 1 auto;overflow-y:auto;padding:8px 0}.notice-loading,.notice-empty{padding:40px 16px;text-align:center;color:#9a8f82;font-size:14px}.notice-list{list-style:none;margin:0;padding:0}.notice-item{border-bottom:1px solid rgba(216,203,177,.3)}.notice-item:last-child{border-bottom:none}.notice-item.unread .notice-item-title{font-weight:700;color:#2a2520}.notice-item.read .notice-item-title{color:#6b6359;font-weight:500}.notice-item-head{display:grid;grid-template-columns:1fr auto;grid-template-areas:"meta time" "title title";gap:4px 12px;width:100%;padding:12px 20px;background:transparent;border:none;cursor:pointer;text-align:left;transition:background .12s ease}.notice-item-head:hover{background:#fffaf099}.notice-item-meta{grid-area:meta;display:flex;align-items:center;gap:6px;font-size:11px}.notice-item-meta .pin{font-size:12px}.notice-item-meta .scope{padding:1px 6px;border-radius:4px;font-weight:700;letter-spacing:.02em}.notice-item-meta .scope.global{background:#fbe2d2;color:#d8580e}.notice-item-meta .scope.org{background:#ddefd5;color:#4a6f3d}.notice-item-meta .dot{width:6px;height:6px;border-radius:50%;background:#f06c24;margin-left:auto}.notice-item-time{grid-area:time;font-size:11px;color:#9a8f82;white-space:nowrap}.notice-item-title{grid-area:title;margin:0;font-size:14px;line-height:1.4;letter-spacing:-.01em}.notice-item-body{padding:4px 20px 16px;font-size:13.5px;color:#2a2520;line-height:1.6;background:#fffaf066;border-top:1px dashed rgba(216,203,177,.5)}.notice-item-body p{margin:0 0 8px}.notice-item-body p:last-child{margin-bottom:0}@media(prefers-reduced-motion:reduce){.notice-bell,.notice-bell *,.notice-modal,.notice-modal *{animation:none!important;transition:none!important}}.student-home,.student-home *,.student-home *:before,.student-home *:after{box-sizing:border-box}.student-home{--bg: #F4EFE6;--bg-deep: #ECE3D2;--surface: #FFFAF0;--surface-elev: #FFFFFF;--fg: #2A2520;--muted: #6B6359;--subtle: #9A8F82;--border: #E8DFCF;--border-warm: #D8CBB1;--accent: #F06C24;--accent-deep: #D8580E;--accent-soft: #FBE2D2;--tutor-bubble: #FFFAF0;--shadow-clay: 0 4px 12px rgba(140, 90, 40, .1), 0 1px 3px rgba(140, 90, 40, .06);--shadow-clay-lg: 0 10px 28px rgba(140, 90, 40, .13), 0 2px 6px rgba(140, 90, 40, .06);--shadow-press: 0 2px 6px rgba(140, 90, 40, .08);--r-sm: 12px;--r: 16px;--r-lg: 22px;--hdr-h: 64px;--tab-h: 60px;--sidebar-w: 260px;--aside-w: 320px;margin:0;padding:0;font-family:Pretendard Variable,Pretendard,Apple SD Gothic Neo,Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,Roboto,sans-serif;font-size:15px;line-height:1.5;color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.011em;text-rendering:optimizeLegibility;overscroll-behavior-y:none;overflow:hidden;-webkit-text-size-adjust:100%;width:100%;height:100vh;height:100dvh}.student-home.wallet-shell,.student-home.report-shell,.student-home.scroll-shell{height:auto!important;min-height:100vh;min-height:100dvh;overflow:visible!important;padding-bottom:calc(env(safe-area-inset-bottom) + 24px)}.student-home button{font:inherit;color:inherit;cursor:pointer;background:none;border:none;padding:0}.student-home input,.student-home textarea{font:inherit;color:inherit;border:none;background:transparent;outline:none;-webkit-appearance:none;appearance:none}.student-home a{color:inherit;text-decoration:none}.student-home ::selection{background:var(--accent-soft);color:var(--fg)}.app{width:100%;height:100vh;height:100dvh;background:var(--bg);display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;position:relative;isolation:isolate}.app:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.32 0 0 0 0.10 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:220px 220px;pointer-events:none;mix-blend-mode:multiply;opacity:.45;z-index:0}.app>*{position:relative;z-index:1}.clay{position:relative;background:linear-gradient(155deg,#fff6e2,#efddb7);border-radius:var(--r);display:grid;place-items:center;isolation:isolate;overflow:hidden;box-shadow:inset 1.5px 2px 3px #fffaf0d9,inset -2px -3px 5px #a06e322e,0 5px 12px #8c5a281a,0 1px 3px #8c5a280f}.clay:before{content:"";position:absolute;top:6%;left:16%;width:50%;height:26%;background:linear-gradient(to bottom,rgba(255,255,255,.55),transparent 80%);border-radius:50%;filter:blur(3px);pointer-events:none}.clay>.lbl{position:relative;z-index:2;font-size:10.5px;font-weight:600;color:#3c32288c;letter-spacing:.01em;line-height:1.2;text-align:center;padding:0 4px}.clay-yellow{background:linear-gradient(155deg,#ffe9c2,#f4c97a)}.clay-blue{background:linear-gradient(155deg,#dfeefb,#91c2e5)}.clay-red{background:linear-gradient(155deg,#fbdddd,#ed9f9f)}.clay-green{background:linear-gradient(155deg,#ddefd5,#94c68b)}.clay-orange{background:linear-gradient(155deg,#fbd8b6,#ed9554)}.clay-purple{background:linear-gradient(155deg,#e5d9f2,#b7a0da)}.clay-rose{background:linear-gradient(155deg,#f8dce2,#dc9cab)}.clay-cream{background:linear-gradient(155deg,#fff2dc,#f0dbb1)}.clay-yellow .lbl,.clay-orange .lbl,.clay-rose .lbl,.clay-red .lbl,.clay-cream .lbl{color:#50321e99}.clay-blue .lbl{color:#28466499}.clay-green .lbl{color:#32503299}.clay-purple .lbl{color:#46376499}.top-bar{display:flex;align-items:center;gap:10px;padding:calc(env(safe-area-inset-top) + 10px) 14px 10px;background:linear-gradient(to bottom,#f4efe6f5,#f4efe6db);-webkit-backdrop-filter:saturate(140%) blur(14px);backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid rgba(216,203,177,.4);min-height:var(--hdr-h)}.hamburger{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;flex-shrink:0;transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent}.hamburger:active{background:#0000000a;transform:scale(.92)}.hamburger span{width:20px;height:2px;background:var(--fg);border-radius:2px;position:relative;display:block}.hamburger span:before,.hamburger span:after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--fg);border-radius:2px}.hamburger span:before{top:-7px}.hamburger span:after{top:7px}.brand{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:0 4px}.brand .logo{width:32px;height:32px;border-radius:10px;flex-shrink:0;background:linear-gradient(155deg,#F4854A 0%,var(--accent-deep) 100%);box-shadow:inset 1.5px 2px 3px #ffdcb4b3,inset -2px -3px 4px #8c32004d,0 3px 8px #f06c2438;display:grid;place-items:center;color:#fff;font-size:16px;font-weight:800;letter-spacing:-.04em}.brand .name{font-size:16px;font-weight:800;letter-spacing:-.02em;color:var(--fg)}.brand .ver{font-size:10px;font-weight:700;color:var(--accent-deep);background:var(--accent-soft);padding:2px 6px;border-radius:999px;margin-left:2px;line-height:1}.hdr-spacer{flex:1}.hdr-user{display:flex;align-items:center;gap:10px;padding:5px 12px 5px 5px;border-radius:999px;background:#fffaf080;border:1px solid var(--border);transition:background .12s ease;-webkit-tap-highlight-color:transparent;min-height:44px}.hdr-user:active{background:var(--surface-elev)}.hdr-user .clay{width:32px;height:32px;border-radius:50%;flex-shrink:0}.hdr-user .clay>.lbl{font-size:9px}.hdr-user .info{line-height:1.15;min-width:0;text-align:left}.hdr-user .info .name{font-size:13px;font-weight:700;color:var(--fg);white-space:nowrap}.hdr-user .meta{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:4px}.hdr-user .meta .lvl{font-size:10px;font-weight:700;color:#6e4a12;background:linear-gradient(120deg,#fff1cf,#ffe1a4);padding:1px 6px;border-radius:999px;line-height:1.4;border:1px solid rgba(212,156,60,.25)}.hdr-actions{display:flex;gap:4px;flex-shrink:0}.icon-btn{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;position:relative;transition:transform .12s ease,background .12s ease;-webkit-tap-highlight-color:transparent}.icon-btn:active{transform:scale(.92);background:#0000000a}.icon-btn .clay{width:32px;height:32px;border-radius:11px}.icon-btn .clay>.lbl{font-size:9px}.icon-count{position:absolute;top:2px;right:2px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;line-height:1;padding:3px 5px;border-radius:8px;min-width:18px;text-align:center;border:1.5px solid var(--bg);box-shadow:0 2px 4px #f06c244d}.icon-dot{position:absolute;top:4px;right:4px;width:16px;height:16px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;border-radius:50%;display:grid;place-items:center;border:1.5px solid var(--bg);line-height:1}.body{display:grid;grid-template-columns:1fr;overflow:hidden;position:relative}.sidebar{background:#fffaf080;border-right:1px solid var(--border);overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 12px calc(env(safe-area-inset-bottom) + 16px);scrollbar-width:thin;scrollbar-color:var(--border-warm) transparent}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border-warm);border-radius:999px}.sb-group{margin-bottom:18px}.sb-group:last-child{margin-bottom:0}.sb-title{font-size:10.5px;font-weight:600;color:#8c6e50b8;line-height:1;padding:14px 14px 6px;margin-top:4px;display:flex;align-items:center;gap:6px;letter-spacing:.06em;text-transform:none;border-top:1px dashed rgba(140,110,80,.18)}.sb-group:first-child .sb-title{border-top:0;padding-top:6px;margin-top:0}.sb-title .clay{display:none}.sb-title-text{font-size:10.5px;font-weight:600;opacity:.85}.sb-item{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:12px;color:var(--fg);font-size:14.5px;font-weight:600;min-height:44px;transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent;position:relative}.sb-item:active{transform:scale(.985)}.sb-item:hover,.sb-item:focus-visible{background:#fffaf0cc}.sb-item.active{background:var(--accent-soft);color:var(--accent-deep);font-weight:700}.sb-item.active:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.sb-item .icon{width:22px;flex-shrink:0;text-align:center;font-size:15px;line-height:1}.sb-item .badge{margin-left:auto;font-size:10px;font-weight:700;background:var(--accent);color:#fff;padding:2px 7px;border-radius:999px;line-height:1.4}.sb-item .badge.live{background:#e04a4a;display:inline-flex;align-items:center;gap:3px}.sb-item .badge.live:before{content:"";width:5px;height:5px;background:#fff;border-radius:50%;animation:livePulse 1.6s infinite}.sb-item .badge.soft{background:#9aafdc40;color:#4860a0}.sb-item .badge.neutral{background:#d8cbb180;color:var(--muted)}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.center{display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding-bottom:calc(env(safe-area-inset-bottom) + 24px)}.mobile-features-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:14px 16px 6px}.mobile-features-head h2{margin:0;font-size:15px;font-weight:800;letter-spacing:-.015em}.mobile-features-head .more{font-size:12px;color:var(--muted);font-weight:500;padding:8px;margin:-8px}.mobile-features-head .more:after{content:" ›"}.mobile-features{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;padding:4px 16px 12px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.mobile-features::-webkit-scrollbar{display:none}.feature-card{flex:0 0 142px;scroll-snap-align:start;background:var(--surface);border-radius:var(--r-lg);padding:12px;box-shadow:var(--shadow-clay);transition:transform .14s ease,box-shadow .14s ease;position:relative;min-height:178px;display:flex;flex-direction:column;gap:10px;text-align:left;-webkit-tap-highlight-color:transparent}.feature-card:active{transform:scale(.97);box-shadow:var(--shadow-press)}.feature-card.tint-yellow{background:linear-gradient(155deg,#ffefc8,#ffe5a8)}.feature-card.tint-blue{background:linear-gradient(155deg,#daedfa,#bcddf2)}.feature-card.tint-red{background:linear-gradient(155deg,#fedddd,#fbc2c2)}.feature-card.tint-green{background:linear-gradient(155deg,#dbefd2,#bfe3b2)}.feature-card .clay{width:76px;height:76px;border-radius:20px;align-self:flex-start}.feature-card .clay>.lbl{font-size:9.5px;line-height:1.2}.feature-name{font-size:13.5px;font-weight:700;line-height:1.25;letter-spacing:-.01em}.feature-tag{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;color:#3c2814a6;margin-top:auto;line-height:1.2}.live-dot{width:6px;height:6px;background:#e04a4a;border-radius:50%;box-shadow:0 0 #e04a4a99;animation:liveBeat 1.6s infinite}@keyframes liveBeat{0%{box-shadow:0 0 #e04a4a8c}70%{box-shadow:0 0 0 6px #e04a4a00}to{box-shadow:0 0 #e04a4a00}}.chat-shell{display:flex;flex-direction:column;margin:6px 12px 12px;background:linear-gradient(165deg,#fffaf0,#fff1da 60%,#ffe7c0);border:1px solid var(--border-warm);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-clay-lg);position:relative;flex:1 1 auto;min-height:540px}.chat-shell.chat-shell-fullbleed{margin:0;border:0;border-radius:0;box-shadow:none;background:var(--bg);min-height:0;flex:1 1 auto}.chat-shell.chat-shell-fullbleed:before,.chat-shell.chat-shell-fullbleed:after{display:none}.student-home .paid-mode-toggle{display:inline-flex;gap:4px;margin:14px 18px 6px;padding:4px;background:#d8cbb147;border-radius:999px;width:fit-content}.student-home .paid-mode-btn{padding:7px 16px;border-radius:999px;font-size:13px;font-weight:700;color:var(--muted);transition:all .14s ease}.student-home .paid-mode-btn.active{background:var(--fg);color:#fff;box-shadow:0 2px 6px #281e142e}.student-home .paid-dash-search{display:flex;align-items:center;gap:8px;margin:6px 18px 0;padding:10px 14px;background:#fff;border:1px solid var(--border-warm);border-radius:14px;box-shadow:0 2px 6px #281e140d}.student-home .paid-dash-search-icon{font-size:16px;opacity:.7}.student-home .paid-dash-search input{flex:1;border:0;outline:none;background:transparent;font-size:14px;color:var(--fg)}.student-home .paid-dash-search input::placeholder{color:var(--muted)}.student-home .paid-dash-search-btn{padding:7px 16px;border-radius:999px;background:var(--accent);color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.student-home .paid-dash-section{margin:14px 18px 0;padding:14px 16px;background:#fffaf0b3;border:1px solid var(--border-warm);border-radius:18px}.student-home .paid-dash-section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}.student-home .paid-dash-section-head h2{font-size:15px;font-weight:800;margin:0}.student-home .paid-dash-section-head .more{font-size:12px;color:var(--accent-deep)}.student-home .paid-dash-note{color:var(--muted);font-size:13px;padding:8px 4px;margin:0}.student-home .paid-dash-plan-list{display:flex;flex-direction:column;gap:6px}.student-home .paid-dash-plan-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:#fff;border:1px solid #ebe1d2;cursor:pointer;text-align:left;transition:transform .1s ease,background .1s ease}.student-home .paid-dash-plan-row:hover{background:#fff8ef;transform:translateY(-1px)}.student-home .paid-dash-plan-row.done{opacity:.6}.student-home .paid-dash-plan-row .plan-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-warm);flex-shrink:0}.student-home .paid-dash-plan-row .plan-check.done{background:var(--accent);border-color:var(--accent)}.student-home .paid-dash-plan-row .plan-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.student-home .paid-dash-plan-row .plan-title{font-size:13.5px;font-weight:700}.student-home .paid-dash-plan-row .plan-meta{font-size:11.5px;color:var(--muted)}.student-home .paid-dash-plan-row .plan-due{font-size:11px;font-weight:700;color:var(--accent-deep);background:var(--accent-soft);padding:2px 8px;border-radius:999px}.student-home .paid-dash-plan-row .plan-due.soft{color:var(--muted);background:#d8cbb166}.student-home .paid-dash-quick{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:4px 12px}@media(min-width:768px){.student-home .paid-dash-quick{grid-template-columns:repeat(4,1fr)}}.student-home .paid-dash-quick-card{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fff;border:1px solid #ebe1d2;border-radius:14px;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;text-align:left}.student-home .paid-dash-quick-card:hover{transform:translateY(-2px);box-shadow:0 6px 14px #281e1414}.student-home .paid-dash-quick-card .clay{width:44px;height:44px;border-radius:12px;flex-shrink:0}.student-home .paid-dash-quick-card .clay>.lbl{font-size:9px}.student-home .paid-dash-quick-card .qc-text{display:flex;flex-direction:column;gap:2px;min-width:0}.student-home .paid-dash-quick-card .qc-text strong{font-size:13.5px;font-weight:800}.student-home .paid-dash-quick-card .qc-text span{font-size:11.5px;color:var(--muted)}.chat-shell:before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(255,220,130,.45),transparent 70%);border-radius:50%;pointer-events:none;z-index:0}.chat-shell:after{content:"";position:absolute;bottom:60px;left:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(240,108,36,.1),transparent 70%);border-radius:50%;pointer-events:none;z-index:0}.chat-meta{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(216,203,177,.4);background:#ffffff80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;z-index:2}.chat-meta .clay{width:40px;height:40px;border-radius:13px;flex-shrink:0}.chat-meta .clay>.lbl{font-size:10px}.chat-meta .info{flex:1;min-width:0;line-height:1.2}.chat-meta .title{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:14.5px;font-weight:800;color:var(--fg);letter-spacing:-.01em}.chat-meta .title .ai-tag{font-size:9.5px;font-weight:700;color:var(--accent-deep);background:var(--accent-soft);padding:2px 6px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase;line-height:1.4}.chat-meta .switch{font-size:11.5px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:4px;flex-wrap:wrap;line-height:1.4}.chat-meta .switch strong{color:var(--fg);font-weight:700}.chat-meta .switch .swap{color:var(--accent-deep);font-weight:700;cursor:pointer;margin-left:auto;padding:4px 8px;margin-right:-4px;border-radius:999px}.chat-meta .switch .swap:hover{background:var(--accent-soft)}.chat-meta .menu-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;color:var(--muted);transition:background .12s ease;-webkit-tap-highlight-color:transparent}.chat-meta .menu-btn:active{background:#0000000a}.chat-meta .menu-btn:after{content:"⋯";font-size:18px;line-height:1;letter-spacing:1px}.chat-history{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding:16px 14px 8px;display:flex;flex-direction:column;gap:14px;position:relative;z-index:1;scrollbar-width:thin;scrollbar-color:var(--border-warm) transparent;min-height:0}.chat-history::-webkit-scrollbar{width:6px}.chat-history::-webkit-scrollbar-thumb{background:var(--border-warm);border-radius:999px}.day-label{align-self:center;font-size:11px;font-weight:600;color:var(--subtle);background:#fff9;border:1px solid var(--border);padding:4px 10px;border-radius:999px;letter-spacing:.02em}.msg{display:flex;gap:8px;max-width:100%;align-items:flex-end}.msg-tutor{justify-content:flex-start}.msg-user{justify-content:flex-end}.msg-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0}.msg-avatar .lbl{font-size:14px}.msg-tutor .msg-stack{display:flex;flex-direction:column;gap:6px;max-width:min(560px,calc(100% - 48px))}.msg-user .msg-stack{display:flex;flex-direction:column;gap:6px;align-items:flex-end;max-width:min(560px,80%)}.msg-name{font-size:11px;font-weight:700;color:var(--muted);margin-left:14px;letter-spacing:.01em;line-height:1}.bubble{padding:12px 14px;font-size:14.5px;line-height:1.55;word-break:keep-all;overflow-wrap:break-word;box-shadow:var(--shadow-press);position:relative}.msg-tutor .bubble{background:var(--tutor-bubble);color:var(--fg);border:1px solid var(--border);border-radius:4px 18px 18px}.msg-user .bubble{background:linear-gradient(155deg,#F4854A 0%,var(--accent-deep) 100%);color:#fff;border-radius:18px 18px 4px;box-shadow:0 4px 12px #f06c2440,0 1px 3px #8c3c0026}.bubble p{margin:0}.bubble p+p{margin-top:8px}.bubble strong{font-weight:700}.msg-tutor .bubble strong{color:var(--accent-deep)}.msg-user .bubble strong{color:#fffffffa;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}.bubble h4{margin:12px 0 0;font-size:13px;font-weight:800;color:var(--fg);letter-spacing:-.01em;display:flex;align-items:center;gap:6px}.bubble h4:first-child{margin-top:0}.bubble h4+p{margin-top:4px}.bubble h4 .ico{font-size:14px}.bubble blockquote{margin:8px 0 0;padding:10px 12px;background:var(--accent-soft);border-radius:10px;border-left:3px solid var(--accent);font-style:normal;color:#503214e0;font-size:14px}.bubble blockquote strong{color:var(--accent-deep)}.bubble .lex-meta{margin-top:12px;padding-top:10px;border-top:1px dashed var(--border-warm);font-size:12.5px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px 14px}.bubble .lex-meta span strong{color:var(--fg);font-weight:700;margin-right:4px}.bubble.first-greet{border-radius:4px 18px 18px;padding:14px 14px 12px}.reco-stack{display:flex;flex-direction:column;gap:6px;margin-top:12px}.reco-card{display:flex;align-items:center;gap:10px;background:#fffaf0d9;border:1px solid var(--border);border-radius:14px;padding:8px 10px 8px 8px;min-height:52px;transition:transform .12s ease,box-shadow .12s ease,background .12s ease;-webkit-tap-highlight-color:transparent;text-align:left;width:100%}.reco-card:active{transform:scale(.985);background:#fff;box-shadow:var(--shadow-press)}.reco-card .clay{width:36px;height:36px;border-radius:11px;flex-shrink:0}.reco-card .clay>.lbl{font-size:9px}.reco-text{flex:1;min-width:0;line-height:1.3}.reco-title{font-size:13.5px;font-weight:700;color:var(--fg);line-height:1.25;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.reco-meta{font-size:11.5px;color:var(--subtle);margin-top:2px;line-height:1.3;display:block}.reco-card .chev{color:var(--subtle);font-size:18px;line-height:1;flex-shrink:0}.reco-flag{font-size:9.5px;font-weight:700;background:var(--accent);color:#fff;padding:2px 6px;border-radius:6px;line-height:1.3;flex-shrink:0;display:inline-block}.bubble.typing{padding:14px 16px;display:inline-flex;align-items:center;gap:5px}.bubble.typing .dot{width:7px;height:7px;background:var(--subtle);border-radius:50%;animation:typingBounce 1.2s infinite ease-in-out}.bubble.typing .dot:nth-child(2){animation-delay:.18s}.bubble.typing .dot:nth-child(3){animation-delay:.36s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-5px);opacity:1}}.chat-input{flex-shrink:0;padding:10px 12px calc(env(safe-area-inset-bottom) + 10px);border-top:1px solid rgba(216,203,177,.4);background:#fffaf0b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:3}.input-bar{display:flex;align-items:center;gap:6px;background:var(--surface-elev);border:1px solid var(--border);border-radius:26px;padding:4px;box-shadow:var(--shadow-clay);min-height:56px;transition:border-color .14s ease,box-shadow .14s ease}.input-bar:focus-within{border-color:var(--accent);box-shadow:var(--shadow-clay),0 0 0 4px #f06c241f}.attach-btn{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(155deg,#ffe9c2,#f4c97a);box-shadow:inset 1.5px 2px 3px #fffaf0d9,inset -2px -3px 5px #a06e322e;flex-shrink:0;transition:transform .12s ease;-webkit-tap-highlight-color:transparent}.attach-btn:active{transform:scale(.92)}.attach-btn svg{width:22px;height:22px;color:#78501ec7}.input-bar input{flex:1;height:44px;padding:0 8px;font-size:15px;color:var(--fg);min-width:0}.input-bar input::placeholder{color:var(--subtle)}.send-btn{width:48px;height:48px;border-radius:50%;background:linear-gradient(155deg,#F4854A 0%,var(--accent-deep) 100%);color:#fff;display:grid;place-items:center;flex-shrink:0;box-shadow:inset 0 1px #ffffff40,0 4px 10px #f06c2466,0 1px 2px #8c3c0033;transition:transform .12s ease,box-shadow .12s ease;-webkit-tap-highlight-color:transparent}.send-btn:active{transform:scale(.92);box-shadow:inset 0 1px #ffffff40,0 2px 4px #f06c244d}.send-btn svg{width:20px;height:20px;display:block}.quick-suggestions{display:flex;gap:6px;margin-top:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.quick-suggestions::-webkit-scrollbar{display:none}.quick-chip{flex-shrink:0;font-size:12px;color:var(--muted);font-weight:600;background:#ffffffb3;border:1px solid var(--border);padding:8px 11px;border-radius:999px;transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent;white-space:nowrap;line-height:1;min-height:32px}.quick-chip:active{transform:scale(.96);background:var(--accent-soft);color:var(--accent-deep)}.widgets-stack{padding:4px 12px 16px;display:flex;flex-direction:column;gap:12px}.right-aside{background:#fffaf066;border-left:1px solid var(--border);overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 14px calc(env(safe-area-inset-bottom) + 16px);display:none;flex-direction:column;gap:14px;scrollbar-width:thin;scrollbar-color:var(--border-warm) transparent}.right-aside::-webkit-scrollbar{width:6px}.right-aside::-webkit-scrollbar-thumb{background:var(--border-warm);border-radius:999px}.widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;box-shadow:var(--shadow-clay)}.widget-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:12px}.widget-title{margin:0;font-size:14.5px;font-weight:800;letter-spacing:-.015em}.widget-cta{font-size:12px;color:var(--accent-deep);font-weight:700;padding:8px 12px;margin:-8px -12px;border-radius:999px;-webkit-tap-highlight-color:transparent}.widget-cta:active{background:var(--accent-soft)}.wallet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.wallet-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px 6px;border-radius:var(--r);transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent;cursor:pointer;position:relative}.wallet-item:active{transform:scale(.96);background:#00000008}.wallet-item .clay{width:40px;height:40px;border-radius:12px}.wallet-item .clay>.lbl{font-size:9px}.wallet-item.primary .clay{box-shadow:inset 1.5px 2px 3px #fffaf0d9,inset -2px -3px 5px #a06e322e,0 0 0 2px var(--accent),0 4px 10px #f06c2433}.wallet-item.primary:after{content:"AI 결제";position:absolute;top:0;right:0;font-size:8px;font-weight:800;letter-spacing:.02em;background:var(--accent);color:#fff;padding:2px 5px;border-radius:999px;line-height:1.3;box-shadow:0 2px 4px #f06c244d}.wallet-name{font-size:11px;color:var(--muted);margin-top:4px;line-height:1}.wallet-item.primary .wallet-name{color:var(--accent-deep);font-weight:700}.wallet-count{font-size:13px;font-weight:700;color:var(--fg);line-height:1;font-variant-numeric:tabular-nums}.wallet-cta-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding-top:12px;border-top:1px dashed var(--border-warm)}.wallet-total{font-size:12px;color:var(--muted)}.wallet-total strong{font-size:15px;color:var(--fg);font-weight:800;margin-left:4px;font-variant-numeric:tabular-nums}.btn-charge{background:var(--fg);color:var(--bg);padding:11px 18px;border-radius:999px;font-size:13px;font-weight:700;min-height:44px;transition:transform .12s ease,background .12s ease,color .12s ease;-webkit-tap-highlight-color:transparent;box-shadow:0 4px 10px #281e142e}.btn-charge:active{transform:scale(.96);background:var(--accent-deep);color:#fff;box-shadow:0 2px 6px #d8580e4d}.plan-meta-row{margin:-4px 0 12px;font-size:12px;color:var(--muted);line-height:1.4}.plan-meta-row strong{color:var(--accent-deep);font-weight:700}.plan-list{display:flex;flex-direction:column;gap:6px}.plan-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-radius:10px;transition:background .12s ease;-webkit-tap-highlight-color:transparent;cursor:pointer}.plan-row:active{background:#00000008}.plan-check{width:20px;height:20px;border-radius:7px;border:1.5px dashed var(--border-warm);background:#fff9;flex-shrink:0}.plan-check.done{border:1.5px solid #94C68B;background:#94c68b;position:relative}.plan-check.done:after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M5 10.2l3 3 7-7' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E")}.plan-text{flex:1;min-width:0;line-height:1.3}.plan-title{font-size:13.5px;font-weight:600;color:var(--fg);display:block}.plan-row.done .plan-title{color:var(--subtle);text-decoration:line-through}.plan-meta{font-size:11px;color:var(--subtle);margin-top:2px;display:block}.plan-due{font-size:10.5px;font-weight:700;color:var(--accent-deep);background:var(--accent-soft);padding:3px 7px;border-radius:6px;line-height:1;flex-shrink:0}.plan-due.soft{background:#9aafdc2e;color:#4860a0}.rank-list{display:flex;flex-direction:column;gap:8px}.rank-row{display:flex;align-items:center;gap:10px}.rank-row.me{background:linear-gradient(120deg,var(--accent-soft),rgba(251,226,210,.3));margin:0 -10px;padding:8px 10px;border-radius:12px;border:1.5px solid rgba(240,108,36,.3)}.rank-pos{width:22px;text-align:center;font-size:13px;font-weight:800;flex-shrink:0;line-height:1}.rank-pos.gold{font-size:18px}.rank-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;overflow:hidden}.rank-avatar>.lbl{font-size:9px}.rank-avatar.has-profile>img{width:100%;height:100%;object-fit:cover;border-radius:50%;-webkit-user-select:none;user-select:none;pointer-events:none}.rank-name{flex:1;font-size:13.5px;font-weight:600;color:var(--fg);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rank-row.me .rank-name{color:var(--accent-deep);font-weight:800}.rank-row.me .rank-name:after{content:" (나)";font-size:11px;opacity:.85}.rank-score{font-size:12.5px;font-weight:700;color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0}.rank-row.me .rank-score{color:var(--accent-deep)}.rank-foot{margin:12px 0 0;padding-top:12px;border-top:1px dashed var(--border-warm);font-size:11.5px;color:var(--muted);line-height:1.4}.rank-foot strong{color:var(--accent-deep);font-weight:700}.tab-bar{display:grid;grid-template-columns:repeat(5,1fr);background:#f8f4ebd9;-webkit-backdrop-filter:saturate(140%) blur(20px);backdrop-filter:saturate(140%) blur(20px);border-top:1px solid var(--border);height:calc(var(--tab-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}.tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 4px 4px;min-height:44px;color:var(--subtle);transition:transform .12s ease,color .12s ease;-webkit-tap-highlight-color:transparent;position:relative}.tab:active{transform:scale(.94)}.tab .clay{width:28px;height:28px;border-radius:9px;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.tab .clay>.lbl{font-size:8px}.tab-label{font-size:10.5px;font-weight:600;line-height:1;letter-spacing:-.01em}.tab[aria-current=page]{color:var(--accent-deep)}.tab[aria-current=page] .clay{transform:translateY(-2px);box-shadow:inset 1.5px 2px 3px #fff5e6f2,inset -2px -3px 5px #b45a1e38,0 6px 12px #f06c244d,0 1px 3px #8c3c0026}.tab[aria-current=page]:before{content:"";position:absolute;top:4px;left:50%;transform:translate(-50%);width:28px;height:4px;background:var(--accent);border-radius:0 0 999px 999px;box-shadow:0 1px 4px #f06c2466}.tab[aria-current=page] .tab-label{font-weight:700}.scrim{position:absolute;inset:0;background:#281e1473;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .22s ease;z-index:50}.app[data-drawer=open] .scrim{opacity:1;pointer-events:auto}@media(max-width:767px){html,body{overflow-x:hidden;max-width:100vw}.student-home{height:auto;min-height:100vh;min-height:100dvh;overflow:visible;max-width:100vw}.student-home,.student-home *,.student-home *:before,.student-home *:after{box-sizing:border-box;max-width:100%}.student-home .app{height:auto;min-height:100vh;min-height:100dvh;overflow:visible}.body{grid-template-columns:1fr;grid-template-rows:auto;overflow:visible}.sidebar{position:absolute;top:0;bottom:0;left:0;width:min(280px,86vw);transform:translate(-100%);transition:transform .26s cubic-bezier(.32,.72,.24,1.08);z-index:60;background:var(--bg);box-shadow:8px 0 24px #281e1400;padding-top:calc(env(safe-area-inset-top) + 16px);will-change:transform}.app[data-drawer=open] .sidebar{transform:translate(0);box-shadow:8px 0 32px #281e1433}.right-aside{display:none}.center{grid-column:1;position:relative;z-index:1;overflow:visible}.student-home .mobile-features-head,.student-home .mobile-features{position:relative;z-index:2}.student-home .mobile-features{max-width:100vw;overflow-x:auto;padding-left:12px;padding-right:12px}.student-home .feature-card{flex:0 0 132px!important;min-height:158px!important;padding:10px!important}.student-home .feature-card .clay{width:56px!important;height:56px!important}.student-home .feature-card .feature-name{font-size:12.5px!important}.student-home .feature-card .feature-tag{font-size:10px!important}.chat-shell{min-height:56vh;max-height:75vh;max-width:calc(100vw - 16px);margin:6px 8px 12px;position:relative;z-index:0;isolation:isolate;overflow:hidden}.chat-shell .chat-history{max-width:100%}.chat-shell .bubble{max-width:100%;word-break:break-word;overflow-wrap:anywhere}.chat-shell .reco-stack,.chat-shell .reco-card,.chat-shell .input-bar{max-width:100%}.chat-history{overflow-y:auto;-webkit-overflow-scrolling:touch}.widgets-stack.mobile-widgets{padding-bottom:calc(var(--tab-h) + env(safe-area-inset-bottom) + 24px)}.tab-bar{position:sticky;bottom:0;z-index:30}.chat-history{padding:14px 12px 8px}.input-bar{padding:4px}.tab-bar{display:grid}.hdr-user .info{display:none}.hdr-user{padding:4px;border-radius:50%;background:transparent;border:none;gap:0}.brand .ver{display:none}.brand .name{font-size:15px}.top-bar{gap:6px;padding:calc(env(safe-area-inset-top) + 10px) 10px 10px;flex-wrap:wrap;min-width:0}.hdr-actions{flex-wrap:wrap;flex-shrink:1;min-width:0;gap:2px}.admin-override-row{flex-basis:100%;margin-top:4px;order:99}.top-bar>*{min-width:0}.student-home .paid-dash-search{min-width:0}.student-home .paid-dash-search input{min-width:0;flex:1 1 0}.student-home .paid-dash-quick-card,.student-home .paid-dash-quick-card .qc-text{min-width:0}.student-home .paid-dash-quick-card .qc-text strong,.student-home .paid-dash-quick-card .qc-text span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-home .big-card,.student-home .big-card .body-text,.student-home .paid-dash-section-head,.student-home .paid-dash-section-head h2,.student-home .widget-head,.student-home .widget-title,.student-home .wallet-item{min-width:0}.student-home .hdr-actions{max-width:100%;min-width:0}.student-home .paid-dash-plan-row{min-width:0}.student-home .paid-dash-plan-row .plan-text{min-width:0;flex:1 1 0}.student-home .paid-dash-plan-row .plan-text .plan-title,.student-home .paid-dash-plan-row .plan-text .plan-meta{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-home .paid-dash-plan-row .plan-due{flex-shrink:0;min-width:0}.student-home .paid-dash-section-head .more,.student-home .widget-head .widget-cta{flex-shrink:0;min-width:0;white-space:nowrap}.student-home .top-bar,.student-home .body,.student-home .center,.student-home .free-section-head,.student-home .free-grid,.student-home .paid-dash-quick,.student-home .widgets-stack.mobile-widgets,.student-home .tab-bar,.student-home .locked-grid{width:100%;min-width:0;max-width:100vw}.student-home .greeting-block,.student-home .paid-dash-search,.student-home .paid-dash-section{margin-left:12px;margin-right:12px;min-width:0;box-sizing:border-box}}@media(min-width:768px){.app{grid-template-rows:auto 1fr}.body{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:1fr}.sidebar{display:block}.hamburger{display:none}.center{overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;min-height:0}.mobile-features-head,.mobile-features,.widgets-stack.mobile-widgets{display:none}.chat-shell{flex:1;margin:14px;min-height:0}.chat-history{padding:18px 20px 12px}.input-bar{padding:5px}.tab-bar,.scrim{display:none}.top-bar{padding:12px 18px;min-height:68px;border-bottom:1px solid var(--border)}.brand .name{font-size:17px}.hdr-user .info{display:block}.quick-suggestions{margin-top:10px}.msg-tutor .msg-stack{max-width:min(640px,calc(100% - 48px))}.msg-user .msg-stack{max-width:min(580px,75%)}}@media(min-width:1200px){.app{max-width:1600px;margin:0 auto;box-shadow:0 0 60px #281e140d}.body{grid-template-columns:var(--sidebar-w) 1fr var(--aside-w)}.right-aside{display:flex}.chat-shell{margin:16px}.chat-history{padding:22px 28px 14px}.bubble{font-size:15px}.top-bar{padding:14px 22px}.student-home{background:var(--bg-deep)}.student-home:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'%3E%3Cfilter id='nb'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.55 0 0 0 0 0.45 0 0 0 0 0.32 0 0 0 0.10 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nb)'/%3E%3C/svg%3E");background-size:240px;pointer-events:none;mix-blend-mode:multiply;opacity:.4;z-index:0}}@media(max-width:359px){.feature-card{flex:0 0 132px;min-height:168px}.feature-card .clay{width:64px;height:64px;border-radius:16px}.brand .name{font-size:14px}}@media(prefers-reduced-motion:reduce){.student-home *,.student-home *:before,.student-home *:after{animation:none!important;transition:none!important}}.student-home .cta-pill{display:inline-flex;align-items:center;gap:6px;height:40px;padding:0 16px 0 12px;background:linear-gradient(155deg,#F4854A 0%,var(--accent-deep) 100%);color:#fff;border-radius:999px;font-size:13px;font-weight:800;letter-spacing:-.015em;box-shadow:inset 0 1px #ffffff40,0 4px 10px #f06c2452,0 1px 2px #8c3c002e;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease;flex-shrink:0;position:relative;animation:ctaPulse 2.4s infinite}.student-home .cta-pill:active{transform:scale(.96);box-shadow:inset 0 1px #ffffff40,0 2px 6px #f06c244d}.student-home .cta-pill .spark{width:22px;height:22px;border-radius:50%;background:#ffffff38;display:grid;place-items:center;font-size:13px;font-weight:800;line-height:1}@keyframes ctaPulse{0%,to{box-shadow:inset 0 1px #ffffff40,0 4px 10px #f06c2452,0 1px 2px #8c3c002e}50%{box-shadow:inset 0 1px #ffffff40,0 4px 10px #f06c248c,0 0 0 4px #f06c241a}}.student-home .icon-count.zero{background:#8c5a2873;box-shadow:0 2px 4px #8c5a2833}.student-home .icon-lock-mini{position:absolute;bottom:0;right:0;width:16px;height:16px;background:var(--fg);color:#fff;font-size:8px;line-height:1;border-radius:50%;display:grid;place-items:center;border:1.5px solid var(--bg)}.student-home .sb-item.locked{color:#3c322873;font-weight:500}.student-home .sb-item.locked .icon{opacity:.55;filter:saturate(.6)}.student-home .sb-item.locked:hover{background:#8c5a280f}.student-home .sb-item .badge.free{background:linear-gradient(120deg,#94c68b,#6fa868);color:#fff;letter-spacing:-.01em}.student-home .sb-item .lock-tag{margin-left:auto;display:inline-flex;align-items:center;gap:3px;font-size:10.5px;font-weight:700;color:#3c32288c;background:#d8cbb173;padding:2px 7px 2px 5px;border-radius:999px;line-height:1.4}.student-home .sb-item .lock-tag:before{content:"🔒";font-size:10px}.student-home .sb-upgrade{margin:16px 4px 4px;padding:14px;background:linear-gradient(155deg,#fff6e2,#ffe0b8);border:1px solid #E8C68A;border-radius:18px;box-shadow:var(--shadow-clay);position:relative;overflow:hidden}.student-home .sb-upgrade:before{content:"";position:absolute;top:-20px;right:-20px;width:80px;height:80px;background:radial-gradient(circle,rgba(240,108,36,.18),transparent 70%);border-radius:50%;pointer-events:none}.student-home .sb-upgrade .icon-row{display:flex;gap:-6px;margin-bottom:8px;position:relative;z-index:1}.student-home .sb-upgrade .icon-row .clay{width:28px;height:28px;border-radius:9px;margin-right:-8px;border:2px solid #FFF6E2}.student-home .sb-upgrade .title{font-size:13px;font-weight:800;color:var(--fg);letter-spacing:-.015em;line-height:1.3;position:relative;z-index:1}.student-home .sb-upgrade .meta{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.4;position:relative;z-index:1}.student-home .sb-upgrade .btn{display:flex;align-items:center;justify-content:center;gap:4px;width:100%;margin-top:10px;height:44px;border-radius:14px;background:linear-gradient(155deg,#F4854A 0%,var(--accent-deep) 100%);color:#fff;font-weight:800;font-size:12.5px;box-shadow:inset 0 1px #ffffff40,0 3px 8px #f06c2452;-webkit-tap-highlight-color:transparent;transition:transform .12s ease}.student-home .sb-upgrade .btn:active{transform:scale(.97)}.student-home .greeting-block{margin:12px 12px 4px;padding:16px 16px 16px 14px;background:linear-gradient(165deg,#fffaf0,#fff1da 60%,#ffe7c0);border:1px solid var(--border-warm);border-radius:22px;box-shadow:var(--shadow-clay);display:flex;align-items:center;gap:14px;position:relative;overflow:hidden;min-height:124px}.student-home .greeting-block:before{content:"";position:absolute;top:-30px;right:-30px;width:130px;height:130px;background:radial-gradient(circle,rgba(255,220,130,.45),transparent 70%);border-radius:50%;pointer-events:none}.student-home .greeting-block:after{content:"";position:absolute;bottom:-36px;left:-10px;width:140px;height:70px;background:radial-gradient(ellipse at center,rgba(148,198,139,.28),transparent 70%);border-radius:50%;pointer-events:none}.student-home .greeting-art{width:92px;height:92px;border-radius:22px;flex-shrink:0;position:relative;z-index:1;background:linear-gradient(155deg,#ddefd5,#94c68b);box-shadow:inset 1.5px 2px 3px #fffaf0d9,inset -2px -3px 5px #50823c40,0 5px 12px #50823c2e;display:grid;place-items:center;overflow:hidden}.student-home .greeting-art:before{content:"";position:absolute;top:8%;left:16%;width:50%;height:26%;background:linear-gradient(to bottom,rgba(255,255,255,.55),transparent 80%);border-radius:50%;filter:blur(3px)}.student-home .greeting-art .ph{text-align:center;position:relative;z-index:2;line-height:1.3}.student-home .greeting-art .ph-emoji{font-size:38px;display:block}.student-home .greeting-art .ph-tag{font-size:9px;font-weight:700;letter-spacing:.06em;color:#325032a6;text-transform:uppercase;margin-top:2px}.student-home .greeting-art>img{width:100%;height:100%;object-fit:contain;position:relative;z-index:2;-webkit-user-select:none;user-select:none;pointer-events:none}.student-home .greeting-art.has-profile>img{object-fit:cover}.student-home .clay-img{overflow:hidden;display:grid;place-items:center}.student-home .clay-img>img{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.student-home .greeting-text{flex:1;min-width:0;position:relative;z-index:1}.student-home .greeting-eyebrow{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:800;color:#3c643cd9;background:#94c68b38;border:1px solid rgba(120,170,110,.3);padding:3px 8px 3px 7px;border-radius:999px;letter-spacing:.04em;line-height:1.3;text-transform:uppercase}.student-home .greeting-eyebrow .dot{width:5px;height:5px;border-radius:50%;background:#6fa868}.student-home .greeting-title{margin:8px 0 4px;font-size:17px;font-weight:800;color:var(--fg);letter-spacing:-.02em;line-height:1.3;word-break:keep-all}.student-home .greeting-title strong{color:var(--accent-deep);font-weight:800}.student-home .greeting-meta{font-size:12px;color:var(--muted);line-height:1.5;word-break:keep-all}.student-home .greeting-meta strong{color:var(--fg);font-weight:700}.student-home .free-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:18px 16px 6px}.student-home .free-section-head h2{margin:0;font-size:16px;font-weight:800;letter-spacing:-.02em}.student-home .free-section-head .sub{font-size:12px;color:var(--muted);margin-top:2px;font-weight:500;line-height:1.4}.student-home .free-section-head h2+.sub{margin-top:4px;display:block}.student-home .free-grid{padding:4px 12px;display:grid;grid-template-columns:1fr;gap:12px}.student-home .big-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface);border-radius:22px;box-shadow:var(--shadow-clay);text-align:left;transition:transform .14s ease,box-shadow .14s ease;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden;min-height:116px;width:100%}.student-home .big-card:active{transform:scale(.98);box-shadow:var(--shadow-press)}.student-home .big-card.tint-yellow{background:linear-gradient(155deg,#ffefc8,#ffe5a8)}.student-home .big-card.tint-blue{background:linear-gradient(155deg,#daedfa,#bcddf2)}.student-home .big-card.tint-green{background:linear-gradient(155deg,#dbefd2,#bfe3b2)}.student-home .big-card.tint-red{background:linear-gradient(155deg,#fedddd,#fbc2c2)}.student-home .big-card .clay{width:84px;height:84px;border-radius:22px;flex-shrink:0}.student-home .big-card .clay>.lbl{font-size:10.5px;line-height:1.3}.student-home .big-card .body-text{flex:1;min-width:0;line-height:1.3;display:flex;flex-direction:column;align-items:flex-start}.student-home .big-card .free-tag{display:inline-flex;align-items:center;font-size:9.5px;font-weight:800;line-height:1.3;background:linear-gradient(120deg,#94c68b,#6fa868);color:#fff;padding:2px 7px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}.student-home .big-card h3{margin:0 0 4px;font-size:16px;font-weight:800;letter-spacing:-.02em;color:var(--fg);line-height:1.25}.student-home .big-card .meta{font-size:12.5px;color:#3c2814b3;line-height:1.4;width:100%}.student-home .big-card .cta{display:inline-flex;align-items:center;gap:4px;margin-top:auto;align-self:flex-end;height:32px;padding:0 14px;background:var(--fg);color:var(--bg);border-radius:999px;font-size:12.5px;font-weight:800;letter-spacing:-.01em;box-shadow:0 3px 8px #281e142e;flex-shrink:0}.student-home .big-card .cta:after{content:"→"}.student-home .locked-grid{padding:4px 12px;display:grid;grid-template-columns:1fr;gap:10px}.student-home .locked-card{display:flex;align-items:center;gap:12px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-press);transition:transform .14s ease,box-shadow .14s ease;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden;text-align:left;width:100%}.student-home .locked-card:active{transform:scale(.98)}.student-home .locked-card .clay{width:56px;height:56px;border-radius:16px;flex-shrink:0;filter:saturate(.55) brightness(1.04);opacity:.85}.student-home .locked-card .lock-overlay{position:absolute;left:14px;top:14px;width:56px;height:56px;border-radius:16px;display:grid;place-items:center;background:#281e142e;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);pointer-events:none;z-index:2}.student-home .locked-card .lock-overlay:before{content:"🔒";font-size:20px;line-height:1;filter:drop-shadow(0 2px 4px rgba(40,30,20,.3))}.student-home .locked-card .text{flex:1;min-width:0;line-height:1.35}.student-home .locked-card h3{margin:0 0 3px;font-size:14.5px;font-weight:800;color:var(--fg);letter-spacing:-.015em;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.student-home .locked-card .pro-tag{font-size:9px;font-weight:800;line-height:1.3;color:var(--accent-deep);background:var(--accent-soft);padding:2px 6px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase}.student-home .locked-card .tagline{font-size:12.5px;color:var(--muted);line-height:1.45;word-break:keep-all}.student-home .locked-card .open-link{margin-top:6px;font-size:12px;font-weight:700;color:var(--accent-deep);display:inline-flex;align-items:center;gap:3px}.student-home .sticky-cta{position:relative;margin:16px 12px;padding:14px 16px;background:linear-gradient(155deg,#F4854A 0%,var(--accent-deep) 100%);border-radius:22px;color:#fff;box-shadow:0 12px 30px #d8580e52,0 4px 10px #8c3c002e,inset 0 1px #fff3;display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;z-index:4;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease;text-align:left;overflow:hidden}.student-home .sticky-cta:before{content:"";position:absolute;top:-20px;right:-20px;width:140px;height:140px;background:radial-gradient(circle,rgba(255,230,200,.2),transparent 70%);border-radius:50%;pointer-events:none}.student-home .sticky-cta:active{transform:scale(.985);box-shadow:0 8px 20px #d8580e59}.student-home .sticky-cta-text{line-height:1.3;min-width:0;position:relative;z-index:2;color:#fff;display:flex;flex-direction:column;gap:4px}.student-home .sticky-cta-title{display:block;font-size:15px;font-weight:800;letter-spacing:-.015em;word-break:keep-all;color:#fff}.student-home .sticky-cta-meta{display:block;font-size:11.5px;opacity:.92;font-weight:600;line-height:1.3;color:#fff}.student-home .sticky-cta-meta strong{font-weight:800;opacity:1}.student-home .sticky-cta-arrow{width:44px;height:44px;border-radius:50%;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.28);display:grid;place-items:center;flex-shrink:0;color:#fff;font-size:18px;font-weight:700;position:relative;z-index:1}.student-home .widget.locked{background:linear-gradient(155deg,#f8f2e5,#efe5d0);border-color:var(--border-warm)}.student-home .widget-locked-shell{display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px 8px 10px;text-align:center}.student-home .widget-locked-shell .lock-art{width:56px;height:56px;border-radius:16px;background:linear-gradient(155deg,#fff6e2,#efddb7);box-shadow:inset 1.5px 2px 3px #fffaf0d9,inset -2px -3px 5px #a06e322e,0 5px 12px #8c5a281a;display:grid;place-items:center;position:relative}.student-home .widget-locked-shell .lock-art:after{content:"🔒";font-size:22px;filter:drop-shadow(0 1px 2px rgba(40,30,20,.2))}.student-home .widget-locked-shell .title{font-size:13px;font-weight:800;color:var(--fg);letter-spacing:-.01em}.student-home .widget-locked-shell .sub{font-size:11.5px;color:var(--muted);line-height:1.4;word-break:keep-all}.student-home .widget-locked-shell .link{font-size:11.5px;font-weight:700;color:var(--accent-deep);margin-top:2px}.student-home .rank-foot{margin:12px 0 0;padding-top:12px;border-top:1px dashed var(--border-warm);font-size:11.5px;color:var(--muted);line-height:1.4}.student-home .rank-foot strong{color:var(--accent-deep);font-weight:700}.student-home .tab.locked .clay{filter:saturate(.5) brightness(1.04);opacity:.7}.student-home .tab.locked .tab-label{color:#3c322873}.student-home .tab .tab-lock{position:absolute;bottom:-2px;right:-3px;width:14px;height:14px;border-radius:50%;background:var(--fg);color:#fff;display:grid;place-items:center;font-size:7px;line-height:1;border:1.5px solid rgba(248,244,235,.95)}.student-home .toast{position:fixed;left:50%;bottom:calc(var(--tab-h) + env(safe-area-inset-bottom) + 14px);transform:translate(-50%) translateY(20px);max-width:calc(100vw - 32px);padding:12px 16px 12px 14px;background:var(--fg);color:var(--bg);border-radius:999px;box-shadow:0 10px 28px #281e144d,0 2px 6px #281e142e;font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:10px;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .22s cubic-bezier(.32,.72,.24,1.08);z-index:100;white-space:nowrap}.student-home .toast.show{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.student-home .toast .ico{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:11px;flex-shrink:0}.student-home .toast .cta-link{margin-left:4px;color:#ffd9b8;font-weight:800;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1.5px}.student-home .study-mode-backdrop{position:fixed;inset:0;background:#14100c66;border:0;padding:0;z-index:9000;cursor:pointer}.student-home .study-mode-sheet{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom) + 88px);transform:translate(-50%);width:min(420px,calc(100vw - 24px));background:#fff;border-radius:18px;box-shadow:0 20px 60px #14100c40;z-index:9001;padding:14px 14px 18px;overflow:hidden}.student-home .study-mode-head{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 12px}.student-home .study-mode-head h3{font-size:16px;font-weight:700;margin:0}.student-home .study-mode-close{width:32px;height:32px;border-radius:50%;border:0;background:#f3eee5;cursor:pointer;font-size:14px}.student-home .study-mode-list{display:flex;flex-direction:column;gap:10px}.student-home .study-mode-item{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:14px;border:1px solid #ebe1d2;background:#fff8ef;cursor:pointer;text-align:left}.student-home .study-mode-item:hover{background:#fff1d9;transform:translateY(-1px)}.student-home .study-mode-text{display:flex;flex-direction:column;gap:2px}.student-home .study-mode-title{font-size:15px;font-weight:700;color:#2b2014}.student-home .study-mode-desc{font-size:12.5px;color:#6b5b48}@media(min-width:768px){.student-home .study-mode-sheet{bottom:50%;transform:translate(-50%,50%)}}@media(max-width:767px){.student-home .cta-pill{height:44px;padding:0 14px 0 10px;font-size:12.5px}.student-home .sb-upgrade{display:none}}@media(min-width:768px){.student-home .toast{bottom:calc(env(safe-area-inset-bottom) + 22px)}.student-home .greeting-block{margin:18px 18px 6px;padding:22px 24px 22px 22px;min-height:156px;gap:22px}.student-home .greeting-art{width:124px;height:124px}.student-home .greeting-art .ph-emoji{font-size:48px}.student-home .greeting-title{font-size:22px}.student-home .greeting-meta{font-size:13px}.student-home .free-section-head{padding:24px 18px 8px}.student-home .free-section-head h2{font-size:18px}.student-home .free-grid{padding:4px 18px;grid-template-columns:1fr 1fr;gap:14px}.student-home .big-card{min-height:144px;padding:20px}.student-home .big-card .clay{width:96px;height:96px;border-radius:24px}.student-home .big-card h3{font-size:17px}.student-home .big-card .meta{font-size:13px}.student-home .locked-grid{padding:4px 18px;grid-template-columns:1fr 1fr;gap:12px}.student-home .sticky-cta{margin:14px 18px 18px;padding:18px 22px}.student-home .sticky-cta-title{font-size:17px}.student-home .sticky-cta-meta{font-size:12.5px}}@media(max-width:359px){.student-home .greeting-art{width:76px;height:76px}.student-home .greeting-art .ph-emoji{font-size:32px}.student-home .greeting-title{font-size:16px}.student-home .big-card .clay{width:72px;height:72px}.student-home .big-card{padding:14px}.student-home .big-card h3{font-size:15px}}.welcome-hero{width:100%;max-width:360px;height:auto;display:block;margin:0 auto 12px;border-radius:18px;-webkit-user-select:none;user-select:none;pointer-events:none}.parent-empty{margin:0 12px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.parent-empty p{margin:0;font-size:13px;color:var(--muted)}.parent-empty-illu{width:120px;height:120px;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;opacity:.92}.parent-empty-illu--small{width:80px;height:80px}.agent-greeting-illu{display:block;width:100%;max-width:280px;height:auto;margin:0 auto 12px;-webkit-user-select:none;user-select:none;pointer-events:none}.agent-empty{text-align:center;padding:12px 8px}.agent-empty p{margin:6px 0 0;font-size:12.5px;color:var(--muted)}.agent-empty-illu{width:100px;height:100px;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;opacity:.85;display:block;margin:0 auto}.child-pill-wrap{position:relative;flex-shrink:0;z-index:200}.child-pill{display:flex;align-items:center;gap:9px;padding:5px 10px 5px 5px;border-radius:999px;background:linear-gradient(120deg,#ffefc8,#ffe5a8);border:1px solid rgba(212,156,60,.3);transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent;min-height:44px;position:relative}.child-pill:active{transform:scale(.97)}.child-pill:hover{background:linear-gradient(120deg,#ffe5a8,#ffd881)}.child-pill[aria-expanded=true]{background:linear-gradient(120deg,#ffd881,#f4c44c)}.child-pill .clay{width:32px;height:32px;border-radius:50%;flex-shrink:0}.child-pill .clay>.lbl{font-size:9px}.child-pill .info{line-height:1.15;min-width:0;text-align:left}.child-pill .info .kicker{display:block;font-size:9.5px;font-weight:700;color:#6e4a12b3;letter-spacing:.06em;text-transform:uppercase;line-height:1}.child-pill .info .name{display:block;font-size:13px;font-weight:800;color:#5c3d08;line-height:1.3;margin-top:2px;white-space:nowrap}.child-pill .caret{color:#6e4a12b3;font-size:12px;line-height:1;flex-shrink:0;transition:transform .2s ease}.child-pill[aria-expanded=true] .caret{transform:rotate(180deg)}.child-menu{position:fixed;top:64px;right:240px;min-width:240px;background:var(--surface-elev);border:1px solid var(--border);border-radius:16px;box-shadow:0 14px 32px #281e1426,0 4px 10px #281e1414;padding:8px;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .18s ease,transform .18s cubic-bezier(.32,.72,.24,1.08);z-index:99999}.child-menu[data-open=true]{opacity:1;transform:translateY(0);pointer-events:auto}.child-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px;border-radius:12px;text-align:left;transition:background .12s ease;-webkit-tap-highlight-color:transparent;min-height:48px}.child-menu-item:hover{background:#fffaf0e6}.child-menu-item.selected{background:var(--accent-soft)}.child-menu-item .clay{width:32px;height:32px;border-radius:50%;flex-shrink:0}.child-menu-item .clay>.lbl{font-size:9px}.child-menu-item .info{flex:1;line-height:1.3;min-width:0}.child-menu-item .info .name{display:block;font-size:13.5px;font-weight:700;color:var(--fg)}.child-menu-item.selected .info .name{color:var(--accent-deep)}.child-menu-item .info .meta{display:block;font-size:11px;color:var(--muted)}.child-menu-item .check{color:var(--accent-deep);font-size:14px;font-weight:800;flex-shrink:0;opacity:0}.child-menu-item.selected .check{opacity:1}.child-menu-divider{height:1px;background:var(--border);margin:6px 4px}.child-menu-add{display:flex;align-items:center;gap:10px;width:100%;padding:10px;border-radius:12px;color:var(--accent-deep);font-weight:700;font-size:13px;transition:background .12s ease;-webkit-tap-highlight-color:transparent;min-height:44px}.child-menu-add:hover{background:var(--accent-soft)}.child-menu-add .plus{width:32px;height:32px;border-radius:50%;background:var(--accent-soft);color:var(--accent-deep);display:grid;place-items:center;font-size:18px;font-weight:800;flex-shrink:0;line-height:1}.hdr-user .role-tag{font-size:10px;font-weight:700;color:#463764d9;background:#b7a0da40;border:1px solid rgba(140,110,200,.25);padding:1px 6px;border-radius:999px;line-height:1.4}.sb-context{margin:0 4px 14px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-press);display:flex;align-items:center;gap:10px}.sb-context .clay{width:40px;height:40px;border-radius:50%;flex-shrink:0}.sb-context .clay>.lbl{font-size:10px}.sb-context .text{flex:1;min-width:0;line-height:1.3}.sb-context .kicker{display:block;font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;line-height:1}.sb-context .name{display:block;font-size:14px;font-weight:800;color:var(--fg);margin-top:4px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-context .name .level{font-size:10px;font-weight:700;color:#6e4a12;background:linear-gradient(120deg,#fff1cf,#ffe1a4);padding:1px 6px;border-radius:999px;line-height:1.4;border:1px solid rgba(212,156,60,.25);margin-left:4px;vertical-align:1px}.sb-context .meta{display:block;font-size:11px;color:var(--muted);margin-top:3px;line-height:1.3}.welcome{margin:12px 12px 6px;padding:16px;background:linear-gradient(165deg,#fffaf0,#fff1da 60%,#ffe7c0);border:1px solid var(--border-warm);border-radius:22px;box-shadow:var(--shadow-clay);display:grid;grid-template-columns:1fr;gap:14px;position:relative;overflow:hidden}.welcome:before{content:"";position:absolute;top:-30px;right:-30px;width:130px;height:130px;background:radial-gradient(circle,rgba(255,220,130,.45),transparent 70%);border-radius:50%;pointer-events:none}.welcome-text{position:relative;z-index:1;line-height:1.3}.welcome-eyebrow{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:800;color:#3c643cd9;background:#94c68b38;border:1px solid rgba(120,170,110,.3);padding:3px 8px 3px 7px;border-radius:999px;letter-spacing:.04em;line-height:1.3;text-transform:uppercase}.welcome-eyebrow .dot{width:5px;height:5px;border-radius:50%;background:#6fa868}.welcome-title{margin:8px 0 4px;font-size:18px;font-weight:800;color:var(--fg);letter-spacing:-.02em;line-height:1.3;word-break:keep-all}.welcome-title strong{color:var(--accent-deep);font-weight:800}.welcome-meta{font-size:12.5px;color:var(--muted);line-height:1.5;word-break:keep-all}.welcome-meta .date{color:var(--fg);font-weight:700}.child-card{position:relative;z-index:1;background:var(--surface-elev);border:1px solid var(--border);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-press)}.child-card .row{display:flex;align-items:center;gap:12px}.child-card .clay{width:56px;height:56px;border-radius:18px;flex-shrink:0}.child-card .clay>.lbl{font-size:10px}.child-card .head{flex:1;min-width:0;line-height:1.25}.child-card .head .name{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:16px;font-weight:800;color:var(--fg);letter-spacing:-.02em}.child-card .head .level{font-size:10.5px;font-weight:700;color:#6e4a12;background:linear-gradient(120deg,#fff1cf,#ffe1a4);padding:2px 7px;border-radius:999px;line-height:1.4;border:1px solid rgba(212,156,60,.25)}.child-card .stats{display:flex;align-items:center;gap:6px 12px;flex-wrap:wrap;margin-top:4px;font-size:12px;color:var(--muted)}.child-card .stats strong{color:var(--fg);font-weight:700}.child-card .stat-streak{display:inline-flex;align-items:center;gap:4px;color:var(--accent-deep);font-weight:700}.child-card .progress{display:flex;flex-direction:column;gap:6px}.child-card .progress-head{display:flex;align-items:baseline;justify-content:space-between;font-size:12px;color:var(--muted)}.child-card .progress-head strong{font-size:14px;font-weight:800;color:var(--accent-deep);font-variant-numeric:tabular-nums}.child-card .progress-bar{height:8px;border-radius:999px;background:var(--bg-deep);overflow:hidden;box-shadow:inset 0 1px 2px #8c5a281f}.child-card .progress-fill{height:100%;background:linear-gradient(90deg,#94C68B 0%,#F4C97A 50%,var(--accent) 100%);border-radius:999px;box-shadow:0 0 8px #f06c244d;transition:width .6s cubic-bezier(.32,.72,.24,1.08)}.child-card .cta-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:10px;border-top:1px dashed var(--border-warm)}.child-card .cta-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:800;color:var(--accent-deep);padding:12px 6px;margin:-8px -6px;-webkit-tap-highlight-color:transparent;min-height:44px;border-radius:999px}.child-card .cta-link:hover{background:var(--accent-soft)}.child-card .cta-link:after{content:"→";font-weight:700}.child-card .cta-link:active{color:var(--fg)}.child-card .cta-meta{font-size:11px;color:var(--subtle)}.child-card .cta-meta strong{color:var(--fg);font-weight:700}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:18px 16px 8px}.section-head .head-text{line-height:1.3;min-width:0}.section-head h2{margin:0;font-size:16px;font-weight:800;letter-spacing:-.02em}.section-head .sub{display:block;font-size:12px;color:var(--muted);margin-top:4px;font-weight:500;line-height:1.4}.section-head .more{font-size:12.5px;color:var(--accent-deep);font-weight:700;padding:12px 14px;margin:-8px -14px;border-radius:999px;-webkit-tap-highlight-color:transparent;flex-shrink:0;min-height:44px;display:inline-flex;align-items:center}.section-head .more:after{content:" →"}.section-head .more:active{background:var(--accent-soft)}.chat-list{margin:0 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-press)}.chat-row{display:flex;align-items:flex-start;gap:12px;padding:14px;width:100%;text-align:left;transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent;border-bottom:1px solid var(--border);position:relative;min-height:64px}.chat-row:last-child{border-bottom:none}.chat-row:active{background:#00000006;transform:scale(.998)}.chat-row.unread{background:#fbe2d233}.chat-row .avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;position:relative}.chat-row .avatar>.lbl{font-size:10px}.chat-row .avatar .pin{position:absolute;right:-2px;bottom:-2px;width:18px;height:18px;border-radius:50%;background:var(--surface);border:1.5px solid var(--bg);display:grid;place-items:center;font-size:10px;line-height:1}.chat-row .body-text{flex:1;min-width:0;line-height:1.35}.chat-row .top-row{display:flex;align-items:baseline;gap:6px;min-width:0}.chat-row .name{font-size:14px;font-weight:800;color:var(--fg);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.chat-row .role-tag{font-size:9.5px;font-weight:800;padding:2px 6px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase;line-height:1.3;flex-shrink:0;white-space:nowrap}.chat-row .role-tag.teacher{color:#2f5184;background:#96c3e64d;border:1px solid rgba(95,145,200,.35)}.chat-row .role-tag.parents{color:#944d5f;background:#dc9cab40;border:1px solid rgba(190,105,130,.3)}.chat-row .role-tag.system{color:#7a5710;background:#f4c97a4d;border:1px solid rgba(200,145,50,.3)}.chat-row .ts{margin-left:auto;flex-shrink:0;font-size:11px;color:var(--subtle);font-variant-numeric:tabular-nums;white-space:nowrap}.chat-row.unread .ts{color:var(--accent-deep);font-weight:700}.chat-row .snippet{font-size:13px;color:var(--muted);margin-top:3px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;word-break:break-all}.chat-row.unread .snippet{color:var(--fg);font-weight:600}.chat-row .author{color:var(--fg);font-weight:700}.chat-row .unread-badge{margin-left:8px;flex-shrink:0;background:var(--accent);color:#fff;font-size:11px;font-weight:800;min-width:20px;height:20px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 4px #f06c244d;font-variant-numeric:tabular-nums}.chat-row .right-stack{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;margin-left:auto}.chat-row .right-stack .ts{margin-left:0}.timeline{margin:0 12px;padding:0;display:flex;flex-direction:column;gap:10px}.timeline-day{display:flex;align-items:center;gap:8px;margin-top:4px}.timeline-day-label{font-size:12px;font-weight:800;color:var(--muted);letter-spacing:.02em;line-height:1}.timeline-day-rule{flex:1;height:1px;background:linear-gradient(to right,var(--border-warm),transparent)}.timeline-items{display:flex;flex-direction:column;gap:8px}.timeline-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;text-align:left;transition:background .12s ease,transform .12s ease;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-press);min-height:60px}.timeline-row:active{background:#00000005;transform:scale(.99)}.timeline-row .clay{width:36px;height:36px;border-radius:11px;flex-shrink:0}.timeline-row .clay>.lbl{font-size:9px}.timeline-row .body-text{flex:1;min-width:0;line-height:1.35}.timeline-row .title{display:block;font-size:13.5px;font-weight:700;color:var(--fg);letter-spacing:-.01em;line-height:1.3}.timeline-row .title strong{color:var(--accent-deep);font-weight:800}.timeline-row .meta{display:block;font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.3}.timeline-row .ts{flex-shrink:0;font-size:11px;color:var(--subtle);font-variant-numeric:tabular-nums;white-space:nowrap;align-self:center}.timeline-row.highlight{background:linear-gradient(120deg,#94c68b33,#fffaf0d9);border-color:#78aa6e59}.timeline-row.highlight .title strong{color:#2f6b30}.score-block{display:flex;align-items:center;gap:12px;padding:4px 4px 12px;border-bottom:1px dashed var(--border-warm);margin-bottom:12px}.score-block .clay{width:48px;height:48px;border-radius:14px;flex-shrink:0}.score-block .clay>.lbl{font-size:9px}.score-block .text{flex:1;min-width:0;line-height:1.3}.score-block .text .label{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;line-height:1}.score-block .text .val{display:block;font-size:22px;font-weight:800;color:var(--fg);margin-top:4px;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.score-block .delta{font-size:11.5px;font-weight:700;color:#2f6b30;background:#9acf9138;padding:4px 8px;border-radius:999px;border:1px solid rgba(120,170,110,.25);flex-shrink:0;align-self:center;line-height:1.3}.pending-list{display:flex;flex-direction:column;gap:8px}.pending-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#fbe2d24d;border:1px solid rgba(240,108,36,.25);border-radius:12px;transition:transform .12s ease,background .12s ease;-webkit-tap-highlight-color:transparent;cursor:pointer;min-height:56px}.pending-row:active{transform:scale(.98);background:#fbe2d280}.pending-row .clay{width:32px;height:32px;border-radius:10px;flex-shrink:0}.pending-row .clay>.lbl{font-size:9px}.pending-row .text{flex:1;min-width:0;line-height:1.3}.pending-row .title{display:block;font-size:13px;font-weight:700;color:var(--fg);line-height:1.25}.pending-row .meta{display:block;font-size:11px;color:var(--muted);margin-top:2px}.pending-row .due{font-size:10.5px;font-weight:800;color:var(--accent-deep);background:#fff;padding:3px 7px;border-radius:6px;line-height:1;flex-shrink:0;border:1px solid rgba(240,108,36,.25)}.pending-foot{margin:12px 0 0;padding-top:12px;border-top:1px dashed var(--border-warm);font-size:11.5px;color:var(--muted);line-height:1.4}.pending-foot strong{color:var(--accent-deep);font-weight:700}@media(max-width:767px){.child-pill{padding:4px 8px 4px 4px}.child-pill .info .kicker{font-size:8.5px}.child-pill .info .name{font-size:12.5px}.child-menu{top:60px;right:12px}}@media(min-width:768px){.welcome{margin:18px 18px 6px;padding:22px 24px;grid-template-columns:1fr 360px;gap:24px;align-items:center}.welcome-title{font-size:22px}.welcome-meta{font-size:13px}.child-card{padding:16px}.child-card .head .name{font-size:17px}.child-card .clay{width:64px;height:64px;border-radius:20px}.section-head{padding:24px 18px 8px}.section-head h2{font-size:18px}.chat-list,.timeline{margin:0 18px}.chat-row{padding:16px 18px}.chat-row .avatar{width:48px;height:48px}.chat-row .name{font-size:15px}.chat-row .snippet{font-size:13.5px}.timeline-row{padding:14px 18px}.timeline-row .clay{width:40px;height:40px;border-radius:12px}.timeline-row .title{font-size:14px}}@media(max-width:359px){.child-pill .info{display:none}.child-pill{padding:4px;gap:4px}.welcome-title{font-size:16px}.child-card .head .name{font-size:15px}}.parent-wallet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:4px}.parent-wallet-cell{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 4px;background:var(--surface);border:1px solid var(--border);border-radius:12px}.parent-wallet-cell .clay{width:38px;height:38px;font-size:11px}.parent-wallet-count{font-size:13px;font-weight:800;color:var(--accent-deep);letter-spacing:.2px}
