@import"https://fonts.googleapis.com/css2?family=Permanent+Marker&family=Lora:wght@400;600&family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #2F4538;--surf: rgba(255,255,255,.07);--surf2: rgba(255,255,255,.04);--surf3: rgba(255,255,255,.11);--card: #F5F5E8;--card2: #EEEEDD;--border: rgba(245,245,220,.12);--border2: rgba(245,245,220,.22);--border-mint: #98D8AA;--text: #F5F5DC;--text2: rgba(245,245,220,.75);--text3: rgba(245,245,220,.5);--ink: #1A1A1A;--ink2: #4A4A4A;--ink3: #8A8A8A;--mint: #98D8AA;--mint-bg: rgba(152,216,170,.15);--mint-bd: rgba(152,216,170,.35);--yellow: #FFE9A3;--yellow-bg: rgba(255,233,163,.12);--yellow-bd: rgba(255,233,163,.35);--pink: #FFB6C1;--pink-bg: rgba(255,182,193,.12);--teal: #7DD3C0;--red: #E57373;--red-bg: rgba(229,115,115,.12);--red-bd: rgba(229,115,115,.35);--font-chalk: "Permanent Marker", cursive;--font-serif: "Lora", Georgia, serif;--font-sans: "Inter", system-ui, sans-serif;--radius: 16px;--radius-sm: 14px;--radius-xs: 12px;--radius-2xs: 8px;--shadow-card: 0 4px 20px rgba(0,0,0,.25), 0 1px 4px rgba(0,0,0,.15);--shadow-login: 0 8px 40px rgba(0,0,0,.35)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);line-height:1.6;min-height:100vh;background-image:radial-gradient(ellipse at 20% 50%,rgba(80,120,90,.18) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(60,100,75,.12) 0%,transparent 50%)}.page{min-height:100vh;display:flex;flex-direction:column}.page-center{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;gap:2rem}.standalone-header{display:flex;flex-direction:column;align-items:center;gap:.35rem}.brand-word-large{font-family:var(--font-chalk);font-size:2.75rem;color:var(--mint);letter-spacing:1px}.brand-sub{font-size:.8125rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-top:2px}.top-bar{background:#ffffff0d;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:100}.top-bar-inner{max-width:960px;margin:0 auto;padding:1rem 3.5rem;display:flex;align-items:center;justify-content:space-between}.top-bar-brand{display:flex;align-items:center;gap:.875rem}.top-bar-right{display:flex;align-items:center;gap:1rem}.child-select{background:var(--surf);border:1.5px solid var(--border2);border-radius:var(--radius-2xs);color:var(--text);font-family:var(--font-sans);font-size:.875rem;font-weight:600;padding:.45rem .875rem;cursor:pointer;outline:none;transition:border-color .2s ease}.child-select:focus{border-color:var(--mint)}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--mint-bg);border:1.5px solid var(--mint-bd);color:var(--text);font-size:.875rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-logout{background:transparent;border:1.5px solid var(--mint-bd);border-radius:var(--radius-2xs);color:var(--text);font-family:var(--font-sans);font-size:.875rem;font-weight:600;padding:.5rem 1.25rem;cursor:pointer;transition:background .2s ease,border-color .2s ease}.btn-logout:hover{background:var(--mint-bg);border-color:var(--mint)}.main-content{max-width:960px;margin:0 auto;width:100%;padding:2.5rem 3.5rem 5rem;display:flex;flex-direction:column;gap:3rem}.child-heading{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap}.child-heading-name{font-family:var(--font-chalk);font-size:2.25rem;color:var(--text);letter-spacing:.5px;line-height:1.1}.child-heading-sub{font-size:.875rem;color:var(--text3)}.motivation-banner{display:flex;align-items:center;gap:1rem;padding:1.125rem 1.5rem;background:#98d8aa1f;border:1px solid rgba(152,216,170,.35);border-radius:var(--radius-xs);color:var(--text)}.motivation-icon{font-size:1.5rem;flex-shrink:0}.motivation-text{font-size:.9375rem;font-weight:500;color:var(--text2);line-height:1.4}.tab-nav{display:inline-flex;gap:0;background:#0000002e;border:1px solid var(--border);border-radius:10px;padding:3px;width:fit-content}.tab-btn{background:transparent;border:none;border-radius:8px;color:var(--text3);font-family:var(--font-sans);font-size:.9375rem;font-weight:600;padding:.45rem 1.5rem;cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease;white-space:nowrap}.tab-btn:hover:not(.active){color:var(--text2)}.tab-btn.active{background:var(--mint);color:#1a1a1a;box-shadow:0 1px 4px #00000038,0 0 0 .5px #00000014}.section{display:flex;flex-direction:column;gap:1.25rem}.section-title{font-family:var(--font-chalk);font-size:2rem;color:var(--text);letter-spacing:.5px;line-height:1.15;margin-bottom:.25rem}.section-hint{font-size:.875rem;color:var(--text3);margin-top:-.75rem}.student-block{display:flex;flex-direction:column;gap:2.5rem}.today-inactive{padding:1.125rem 1.5rem;background:var(--yellow-bg);border:1px solid var(--yellow-bd);border-radius:var(--radius-xs);font-size:.9375rem;color:var(--text2)}.today-inactive-body{display:flex;flex-direction:column;gap:.2rem}.last-active{font-size:.8125rem;color:var(--text3)}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.stat-card{background:var(--card);border-radius:var(--radius);padding:1.75rem;display:flex;align-items:flex-start;gap:1rem;box-shadow:var(--shadow-card);transition:transform .2s ease,box-shadow .2s ease;border-top:3px solid var(--card2)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0000004d}.stat-icon{width:56px;height:56px;border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.stat-body{display:flex;flex-direction:column;padding-top:.1rem;min-width:0}.stat-value{font-size:2.75rem;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.04em;color:var(--ink);margin-bottom:.4rem}.stat-label{font-size:.9375rem;font-weight:600;color:var(--ink2);line-height:1.4}.stat-sub{font-size:.75rem;color:var(--ink3);margin-top:.4rem}.week-goal-card{background:var(--card);border-radius:var(--radius);padding:1.5rem 2rem;box-shadow:var(--shadow-card);border-top:3px solid var(--card2);display:flex;flex-direction:column;gap:.875rem}.week-goal-header{display:flex;align-items:center;justify-content:space-between}.week-goal-label{font-size:.9375rem;font-weight:600;color:var(--ink2)}.week-goal-value{font-size:.9375rem;font-weight:700;color:var(--ink)}.week-goal-bar-bg{height:10px;background:#00000014;border-radius:999px;overflow:hidden}.week-goal-bar-fill{height:100%;background:linear-gradient(90deg,#98d8aa,#7dd3c0);border-radius:999px;transition:width .4s ease;min-width:0}.week-goal-sub{font-size:.8125rem;color:var(--ink3)}.week-chart-wrapper{background:var(--card);border-radius:var(--radius);padding:1.75rem 2rem 1.5rem;box-shadow:var(--shadow-card);border-top:3px solid var(--card2)}.week-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.5rem}.week-chart-title{font-size:.9375rem;font-weight:600;color:var(--ink2)}.week-chart-legend{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--ink3)}.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.week-chart-area{position:relative;margin-bottom:.5rem}.week-chart{display:flex;align-items:flex-end;gap:1rem;height:140px;position:relative;z-index:1;border-bottom:2px solid rgba(0,0,0,.1);padding-bottom:0}.chart-goal-line{position:absolute;left:0;right:0;border-top:2px dashed rgba(152,216,170,.6);z-index:2;pointer-events:none}.chart-goal-label{position:absolute;left:4px;top:-18px;font-size:.6875rem;font-weight:600;color:#639922;background:var(--card);padding:0 4px}.chart-avg-line{position:absolute;left:0;right:0;border-top:1.5px dashed rgba(0,0,0,.18);z-index:2;pointer-events:none}.chart-avg-label{position:absolute;left:4px;top:-17px;font-size:.6875rem;color:var(--ink3);background:var(--card);padding:0 4px}.week-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:0;height:100%;justify-content:flex-end}.week-bar-wrap{flex:1;display:flex;align-items:flex-end;width:100%;justify-content:center}.week-bar{width:100%;max-width:44px;border-radius:6px 6px 0 0;min-height:6px;transition:opacity .2s ease}.week-bar:hover{opacity:.8}.week-bar.is-today{outline:2.5px solid #2C2C2C;outline-offset:-2px}.week-label{font-size:.8125rem;font-weight:600;color:var(--ink3)}.week-label.today{color:var(--ink);font-weight:800;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#98d8aa;text-decoration-thickness:2px}.week-total{font-size:.875rem;color:var(--ink3);padding-top:1rem;margin-top:.5rem;border-top:1px solid rgba(0,0,0,.08)}.vok-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.125rem}.vok-card{background:var(--card);border-radius:var(--radius-sm);border-left:4px solid var(--red);padding:1.5rem;display:flex;flex-direction:column;box-shadow:var(--shadow-card);transition:transform .2s ease}.vok-card:hover{transform:translateY(-2px)}.vok-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.625rem}.vok-kat{font-size:.6875rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.2rem .55rem;border-radius:6px}.diff-bar-row{display:flex;gap:3px;align-items:center}.diff-bar-seg{width:12px;height:4px;border-radius:999px}.vok-word{font-size:1.2rem;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:.375rem}.vok-translation{font-size:.9rem;color:var(--ink2);line-height:1.4}.empty-state{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text2)}.empty-state-success{background:#98d8aa14;border-color:#98d8aa40}.empty-icon{font-size:2rem;margin-bottom:.25rem}.empty-title{font-size:1rem;font-weight:600;color:var(--text)}.empty-desc{font-size:.875rem;color:var(--text3);max-width:360px;line-height:1.6}.info-box{background:var(--card);border-radius:24px;padding:3rem 3.5rem;max-width:480px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;box-shadow:var(--shadow-login);border-top:4px solid var(--card2)}.info-box.error{border-left:5px solid var(--red)}.info-icon{font-size:3rem;display:block;margin-bottom:.25rem}.info-icon-lucide{display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}.info-title{font-family:var(--font-serif);font-size:1.75rem;font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.2}.info-text{font-size:.9375rem;color:var(--ink2);line-height:1.7;max-width:360px}.info-sub{font-size:.8125rem;color:var(--ink3)}.btn-reload{margin-top:.5rem;background:transparent;border:1.5px solid rgba(0,0,0,.2);color:var(--ink);padding:.7rem 1.5rem;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s ease,border-color .2s ease}.btn-reload:hover{background:#0000000d;border-color:#00000059}.btn-primary{width:100%;background:#98d8aa;border:none;border-radius:var(--radius-sm);color:#1a1a1a;font-family:var(--font-sans);font-size:1.0625rem;font-weight:700;padding:1rem 2rem;cursor:pointer;transition:background .2s ease,transform .1s ease}.btn-primary:hover{background:#a8e8ba;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.spinner{width:48px;height:48px;border:3px solid rgba(245,245,220,.15);border-top-color:var(--mint);border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:.875rem;color:var(--text3)}.login-field{width:100%;display:flex;flex-direction:column;gap:.4rem}.login-input{width:100%;background:#fafaf0;border:1.5px solid rgba(0,0,0,.18);border-radius:var(--radius-sm);color:var(--ink);font-family:var(--font-sans);font-size:1rem;padding:1rem 1.25rem;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.login-input::placeholder{color:var(--ink3)}.login-input:focus{border-color:#98d8aa;box-shadow:0 0 0 3px #98d8aa33}.login-input.invalid{border-color:var(--red)}.login-error{font-size:.8125rem;color:var(--red);text-align:left}.page-footer{font-size:.875rem;color:var(--text2);padding:2rem 0 0;border-top:1px solid var(--border2);margin-top:1rem;display:flex;flex-direction:column;align-items:center;gap:.625rem;text-align:center}.footer-links{display:flex;align-items:center;gap:.875rem;flex-wrap:wrap;justify-content:center;color:var(--text2);font-size:.875rem}.footer-links a{color:var(--text2);text-decoration:none;transition:color .2s ease}.footer-links a:hover{color:var(--mint);text-decoration:underline}.footer-sep{color:var(--text3)}.page-footer-copy{font-size:.8125rem;color:var(--text2)}.info-box .brand-word-large{font-family:var(--font-chalk);color:#2f4538}.info-box .brand-sub{color:var(--ink3)}@keyframes spin{to{transform:rotate(360deg)}}.week-chart-xlabels{display:flex;gap:1rem;margin-top:6px}.week-chart-xlabels .week-label{flex:1;text-align:center}.week-chart-outer{display:flex;align-items:stretch;gap:.5rem;position:relative}.week-chart-yaxis{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;padding-bottom:20px;width:28px;flex-shrink:0}.yaxis-label{font-size:.6875rem;color:var(--ink3);font-variant-numeric:tabular-nums;line-height:1}.chart-tooltip{position:absolute;transform:translate(-50%,-100%);background:#1a1a1a;color:beige;font-size:.75rem;font-weight:600;padding:.35rem .65rem;border-radius:6px;white-space:nowrap;pointer-events:none;z-index:10;box-shadow:0 2px 8px #0000004d}.chart-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1a1a1a}@media (max-width: 1200px){.vok-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.top-bar-inner,.main-content{padding-left:1.5rem;padding-right:1.5rem}.stats-row,.vok-grid{grid-template-columns:1fr}.section-title{font-size:1.75rem}.stat-value{font-size:2.25rem}.info-box{padding:2rem 1.75rem}.week-chart-legend{display:none}.week-goal-card{padding:1.25rem 1.5rem}}@media (max-width: 480px){.main-content{padding:1.5rem 1rem 3rem}.top-bar-inner{padding-left:1rem;padding-right:1rem}.section-title{font-size:1.5rem}.stat-value{font-size:2rem}.tab-btn{padding:.45rem 1rem;font-size:.875rem}.footer-links{gap:.5rem;font-size:.75rem}}.login-card{background:#ffffff0d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1.5px solid rgba(245,245,220,.12);border-radius:24px;padding:44px 40px;max-width:440px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;box-shadow:0 16px 64px #0006}.login-card .info-title{font-family:var(--font-sans);font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.login-card .info-text{color:var(--text2);font-size:.9rem}.login-card .info-icon-lucide svg{color:var(--mint)}.login-card-subtitle{font-size:.6875rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--text3)}.login-card .login-input{background:#00000040;border:2px solid rgba(245,245,220,.15);color:var(--text);font-size:.9375rem}.login-card .login-input::placeholder{color:#f5f5dc4d}.login-card .login-input:focus{border-color:var(--mint);box-shadow:0 0 0 4px #98d8aa1f}.login-card .login-input.invalid{border-color:var(--red)}.login-card .btn-primary{background:#98d8aa38;border:2px solid rgba(152,216,170,.45);color:var(--text);border-radius:14px;font-size:1rem;box-shadow:0 4px 16px #98d8aa2e}.login-card .btn-primary:hover{background:#98d8aa59;border-color:#98d8aaa6;transform:translateY(-1px)}
