
:root {
  --bg:#0d0a1e; --bg2:#16122a; --card:#1d1830; --card2:#252040;
  --border:rgba(210,190,255,.10); --border2:rgba(210,190,255,.20);
  --text:#f2eeff; --muted:#9b8fc0; --dim:#5a5075;
  --lav:#c8b4ff; --lav2:#a98ef5; --lav3:#7b5ce0; --indigo:#4f46e5; --indigo2:#6366f1;
  --pink:#f2a8cf; --pink2:#d97ab0;
  --gold:#f5d98a; --mint:#8fe0c4; --peach:#f5c09a;
  --sky:#96c8f5; --rose:#ff9eb5;
  --r:22px; --rsm:14px; --rxs:8px;
  --sh:0 16px 48px rgba(0,0,0,.45);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;height:100%;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 55% 45% at 88% 8%,rgba(169,142,245,.13),transparent),radial-gradient(ellipse 45% 40% at 8% 92%,rgba(143,224,196,.08),transparent),radial-gradient(ellipse 35% 55% at 50% 50%,rgba(242,168,207,.05),transparent);}
.screen{display:none;position:fixed;inset:0;z-index:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:50px;background:var(--bg);}
.screen.active{display:block;animation:sIn .45s cubic-bezier(.22,1,.36,1) both;}
@keyframes sIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes pop{0%{transform:scale(.75);opacity:0}70%{transform:scale(1.07)}100%{transform:scale(1);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.s1{animation:fadeUp .5s .05s ease both}.s2{animation:fadeUp .5s .12s ease both}.s3{animation:fadeUp .5s .19s ease both}
.s4{animation:fadeUp .5s .26s ease both}.s5{animation:fadeUp .5s .33s ease both}.s6{animation:fadeUp .5s .40s ease both}
.serif{font-family:'Cormorant Garamond',serif;}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:100px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.88rem;transition:transform .15s,box-shadow .15s,opacity .15s;-webkit-tap-highlight-color:transparent;}
.btn:active{transform:scale(.96);}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;}
.btn-primary{background:linear-gradient(135deg,var(--lav2),var(--indigo));color:#fff;padding:14px 28px;box-shadow:0 10px 28px rgba(99,102,241,.35);}
.btn-primary:hover:not(:disabled){box-shadow:0 14px 36px rgba(99,102,241,.50);transform:translateY(-2px);}
.btn-ghost{background:rgba(255,255,255,.06);border:1.5px solid var(--border2);color:var(--muted);padding:10px 20px;}
.btn-ghost:hover{color:var(--text);border-color:var(--lav);}
.btn-soft{background:rgba(200,180,255,.1);border:1px solid rgba(200,180,255,.2);color:var(--lav);padding:9px 18px;font-size:.82rem;}
.btn-soft:hover{background:rgba(200,180,255,.18);}
.btn-full{width:100%;}
.btn-icon{padding:11px;border-radius:50%;font-size:1.1rem;}
.spinner{width:15px;height:15px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none;}
.loading .spinner{display:block;}.loading .btn-label{display:none;}
/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px;}
.card-lav{border-left:3px solid var(--lav2);background:linear-gradient(135deg,var(--card) 70%,rgba(169,142,245,.07));}
.card-pink{border-left:3px solid var(--pink2);background:linear-gradient(135deg,var(--card) 70%,rgba(242,168,207,.07));}
.card-mint{border-left:3px solid var(--mint);background:linear-gradient(135deg,var(--card) 70%,rgba(143,224,196,.07));}
.card-gold{border-left:3px solid var(--gold);background:linear-gradient(135deg,var(--card) 70%,rgba(245,217,138,.07));}
.card-sky{border-left:3px solid var(--sky);background:linear-gradient(135deg,var(--card) 70%,rgba(150,200,245,.07));}
/* FORM */
.sp-toolbar{
  position:fixed;
  bottom:0;left:0;right:0;
  background:rgba(22,18,42,.97);
  border-top:1px solid rgba(200,180,255,.15);
  padding:8px 10px;
  display:flex;
  align-items:center;
  gap:6px;
  z-index:999;
  flex-wrap:nowrap;
  backdrop-filter:blur(12px);
  visibility:hidden;
  pointer-events:none;
}
.sp-toolbar.visible{visibility:visible;pointer-events:auto;}
.sp-key{
  background:rgba(200,180,255,.12);
  border:1px solid rgba(200,180,255,.2);
  border-radius:8px;
  color:var(--lav);
  font-size:1.1rem;
  font-weight:600;
  padding:6px 10px;
  cursor:pointer;
  flex-shrink:0;
  transition:background .15s;
  font-family:'DM Sans',sans-serif;
}
.sp-key:active{background:rgba(200,180,255,.3);}
.sp-caps{
  background:rgba(200,180,255,.08);
  border:1px solid rgba(200,180,255,.15);
  border-radius:8px;
  color:var(--muted);
  font-size:.7rem;
  font-weight:700;
  padding:6px 8px;
  cursor:pointer;
  flex-shrink:0;
  letter-spacing:.05em;
  margin-left:auto;
}
.sp-caps.active{background:rgba(200,180,255,.25);color:var(--lav);border-color:var(--lav);}
textarea,input[type=text]{width:100%;background:var(--card2);border:1.5px solid var(--border2);border-radius:var(--rsm);padding:14px 16px;font-family:'DM Sans',sans-serif;font-size:.92rem;font-weight:400;color:var(--text);outline:none;transition:border-color .2s,background .2s;-webkit-text-fill-color:var(--text);}
textarea{resize:none;line-height:1.65;min-height:120px;}
textarea::placeholder,input::placeholder{color:var(--dim);}
textarea:focus,input:focus{border-color:var(--lav2);background:rgba(37,32,64,.9);}
/* LABELS */
.label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;display:block;}
.pill{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:100px;font-size:.72rem;font-weight:700;border:1px solid var(--border2);background:rgba(200,180,255,.07);color:var(--lav);}
/* FEEDBACK */
.feedback{display:none;background:linear-gradient(135deg,rgba(200,180,255,.1),rgba(242,168,207,.07));border:1.5px solid rgba(200,180,255,.2);border-radius:var(--r);padding:20px;animation:fadeUp .4s ease both;}
.feedback.show{display:block;}
.feedback-title{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--lav);margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.feedback-body{font-size:.88rem;line-height:1.75;color:var(--text);font-weight:400;}
.feedback-body strong{color:var(--lav);font-weight:600;}
/* PANEL */
.ph{display:flex;align-items:center;gap:12px;padding:20px 20px 14px;position:sticky;top:0;background:linear-gradient(to bottom,var(--bg) 85%,transparent);z-index:20;border-bottom:1px solid var(--border);}
.screen:not(.active) .ph{position:relative!important;top:auto!important;}
.ph-back{background:var(--card2);border:1px solid var(--border2);border-radius:100px;padding:8px 16px;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;}
.ph-back:hover{color:var(--text);border-color:var(--lav);}
.ph-title{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:var(--text);}
.pb{padding:18px 20px;display:flex;flex-direction:column;gap:14px;}
/* MISC */
.wc{font-size:.72rem;color:var(--dim);text-align:right;font-weight:600;margin-top:-6px;}
.wc.ok{color:var(--mint);}
.pbar-wrap{background:rgba(255,255,255,.05);border-radius:100px;height:6px;overflow:hidden;}
.pbar-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--lav2),var(--indigo));transition:width .5s cubic-bezier(.22,1,.36,1);}
.gen-msg{display:flex;align-items:center;gap:12px;padding:16px;background:rgba(200,180,255,.06);border:1px solid var(--border2);border-radius:var(--rsm);font-size:.82rem;color:var(--muted);font-weight:500;}
.gen-spin{width:16px;height:16px;border:2px solid rgba(200,180,255,.2);border-top-color:var(--lav);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0;}
.mino-loading{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;width:100%;}
.mino-loading img{height:72px;width:auto;animation:minoBounce 1s ease-in-out infinite;}
.mino-loading .mino-msg{font-family:'Great Vibes',cursive;font-size:1.2rem;color:var(--pink);text-align:center;}
.mino-loading .mino-dots span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--lav);margin:0 2px;animation:dotPulse 1.2s ease-in-out infinite;}
.mino-loading .mino-dots span:nth-child(2){animation-delay:.2s;}
.mino-loading .mino-dots span:nth-child(3){animation-delay:.4s;}
@keyframes minoBounce{0%,100%{opacity:.85;filter:drop-shadow(0 4px 12px rgba(242,168,207,.3));}50%{opacity:1;filter:drop-shadow(0 6px 20px rgba(242,168,207,.7));}}
@keyframes dotPulse{0%,100%{opacity:.3;transform:scale(.8);}50%{opacity:1;transform:scale(1.2);}}
/* CELEBRATION */
.cel-overlay{display:none;position:fixed;inset:0;z-index:100;background:rgba(15,12,24,.92);align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:40px;}
.cel-overlay.show{display:flex;animation:sIn .4s ease both;}
.cel-emoji{font-size:4.5rem;animation:pop .6s ease both;margin-bottom:14px;}
.cel-title{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:700;font-style:italic;background:linear-gradient(135deg,#fff,var(--lav),var(--indigo2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;}
.cel-sub{color:var(--muted);font-size:.9rem;margin-bottom:26px;line-height:1.6;}
/* HOME */
/* HOME REDESIGN */
.home-top-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 6px;}
.home-menu-btn{background:rgba(255,255,255,.07);border:1px solid var(--border2);border-radius:12px;padding:9px 13px;font-size:1rem;color:var(--muted);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;}
.home-menu-btn:active{transform:scale(.94);background:rgba(200,180,255,.12);}
.stats-inline{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.05);border:1px solid var(--border2);border-radius:100px;padding:7px 14px;}
.stats-divider{width:1px;height:13px;background:var(--border2);margin:0 4px;}
.ptas-label{font-size:.7rem;font-weight:700;color:var(--gold);margin-left:2px;}
/* pills: 2-column grid, compact */
.module-pills{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px 14px 10px;}
.module-pill{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:100px;border:1px solid var(--border2);background:rgba(255,255,255,.04);font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:600;color:var(--text);cursor:pointer;transition:transform .12s,background .12s;-webkit-tap-highlight-color:transparent;}
.module-pill:active{transform:scale(.95);}
.pill-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.section-rule{border-left:3px solid var(--lav2);padding-left:12px;margin-bottom:8px;}
.topic-card{background:var(--card);border:1px solid var(--border2);border-left:3px solid var(--lav2);border-radius:var(--rsm);padding:14px 16px;margin-bottom:8px;}
.pill-lav{border-color:rgba(169,142,245,.3);background:rgba(169,142,245,.07);}
.pill-lav:active{background:rgba(169,142,245,.18);}
.pill-mint{border-color:rgba(143,224,196,.3);background:rgba(143,224,196,.06);}
.pill-mint:active{background:rgba(143,224,196,.15);}
.pill-pink{border-color:rgba(242,168,207,.3);background:rgba(242,168,207,.06);}
.pill-pink:active{background:rgba(242,168,207,.15);}
.pill-sky{border-color:rgba(150,200,245,.3);background:rgba(150,200,245,.06);}
.pill-sky:active{background:rgba(150,200,245,.15);}
.pill-gold{border-color:rgba(245,217,138,.3);background:rgba(245,217,138,.06);}
.pill-gold:active{background:rgba(245,217,138,.15);}
.pill-peach{border-color:rgba(245,192,154,.3);background:rgba(245,192,154,.06);}
.pill-peach:active{background:rgba(245,192,154,.15);}
.home-footer{padding:4px 22px 8px;text-align:center;font-size:.76rem;color:var(--dim);}
.home-footer strong{color:var(--lav);font-weight:500;}
/* tenses + tilde */
.gr-tabs{display:flex;gap:8px;margin-bottom:4px;flex-wrap:wrap;}
.gr-tab{padding:7px 14px;border-radius:100px;border:1.5px solid var(--border2);background:rgba(255,255,255,.04);font-size:.76rem;font-weight:700;color:var(--muted);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;}
.gr-tab.active{background:rgba(169,142,245,.18);border-color:rgba(169,142,245,.5);color:var(--lav);}
.tilde-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:4px;}
.tilde-btn{background:rgba(255,255,255,.05);border:1.5px solid var(--border2);border-radius:12px;padding:12px 6px;font-size:1.1rem;font-weight:700;color:var(--text);text-align:center;cursor:pointer;transition:all .12s;-webkit-tap-highlight-color:transparent;}
.tilde-btn:active{background:rgba(169,142,245,.2);transform:scale(.93);}
.tenses-list{display:flex;flex-direction:column;gap:8px;}
.tense-chip{background:rgba(169,142,245,.07);border:1.5px solid rgba(169,142,245,.2);border-radius:14px;padding:12px 14px;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;}
.tense-chip:active{background:rgba(169,142,245,.18);}
.home-orb{width:86px;height:86px;border-radius:50%;background:linear-gradient(135deg,var(--lav2),var(--pink2),var(--gold));display:flex;align-items:center;justify-content:center;font-size:2.2rem;margin:0 auto 18px;box-shadow:0 18px 50px rgba(169,142,245,.4),0 0 0 1px rgba(200,180,255,.1);animation:pop .7s ease both,float 4s 1s ease-in-out infinite;}
.home-title{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#fff,var(--lav),var(--indigo2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.05;margin-bottom:6px;}
.home-tagline{color:var(--muted);font-size:.88rem;margin-bottom:22px;}
.stats-row{display:flex;flex-direction:row;align-items:center;gap:20px;padding:8px 20px 10px;border-bottom:1px solid var(--border);margin-bottom:6px;}
.stat-box{display:flex;align-items:center;gap:6px;background:none;border:none;padding:0;}
.stat-num{font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:700;color:var(--text);line-height:1;}
.stat-lbl{display:none;}
.stat-icon{font-size:1.2rem;line-height:1;}
.modes-section{padding:18px 20px 0;}
.modes-label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;}
.modes-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.mode-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:17px 15px;cursor:pointer;transition:transform .18s,border-color .18s,box-shadow .18s;position:relative;overflow:hidden;}
.mode-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;opacity:0;transition:opacity .18s;}
.mode-card:hover{transform:translateY(-3px);border-color:var(--border2);box-shadow:0 10px 28px rgba(0,0,0,.3);}
.mode-card:hover::after{opacity:1;}
.mode-card:active{transform:scale(.97);}
.mc-icon{font-size:1.45rem;margin-bottom:7px;display:block;}
.mc-name{font-size:.86rem;font-weight:700;color:var(--text);margin-bottom:2px;}
.mc-desc{font-size:.71rem;color:var(--dim);line-height:1.35;}
.mc-lav::after{background:var(--lav2);}.mc-pink::after{background:var(--pink2);}
.mc-gold::after{background:var(--gold);}.mc-mint::after{background:var(--mint);}
.mc-sky::after{background:var(--sky);}.mc-rose::after{background:var(--rose);}
.mc-peach::after{background:var(--peach);}.mc-white::after{background:rgba(255,255,255,.4);}
.home-footer{padding:28px 22px 0;text-align:center;font-size:.8rem;color:var(--dim);line-height:1.7;}
.home-footer strong{color:var(--lav);font-weight:500;}
.focus-toggle{display:flex;width:fit-content;align-items:center;gap:8px;padding:8px 16px;border-radius:100px;background:rgba(255,255,255,.06);border:1px solid rgba(200,180,255,.35);font-size:.76rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;margin:12px auto 0;}
.focus-toggle.on{color:var(--mint);border-color:rgba(143,224,196,.3);background:rgba(143,224,196,.07);}
body.focus .home-orb{animation:none;}
body.focus .home-tagline,body.focus .home-footer{display:none;}
/* DRAWER */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s;visibility:hidden;}
.drawer-overlay.open{opacity:1;pointer-events:all;visibility:visible;}
.drawer{position:fixed;top:0;left:0;bottom:0;width:82%;max-width:320px;background:var(--bg2);z-index:101;transform:translateX(-100%);transition:transform .35s cubic-bezier(.22,1,.36,1);overflow-y:auto;padding-bottom:40px;}
.drawer.open{transform:translateX(0);}
.drawer-header{padding:28px 20px 16px;border-bottom:1px solid var(--border);}
.drawer-title{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--lav);}
.drawer-sub{font-size:.75rem;color:var(--muted);margin-top:2px;}
.drawer-section{padding:12px 0;}
.drawer-section-label{font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);padding:8px 20px 4px;}
.drawer-item{display:flex;align-items:center;gap:14px;padding:13px 20px;cursor:pointer;transition:background .15s;}
.drawer-item:hover,.drawer-item:active{background:rgba(169,142,245,.08);}
.drawer-item-icon{font-size:1.3rem;width:32px;text-align:center;flex-shrink:0;}
.drawer-item-text{flex:1;}
.drawer-item-name{font-size:.9rem;font-weight:600;color:var(--text);}
.drawer-item-desc{font-size:.72rem;color:var(--muted);margin-top:1px;}
.drawer-divider{height:1px;background:var(--border);margin:4px 20px;}
.vocab-list{display:flex;flex-direction:column;gap:10px;}
.vocab-item{background:var(--card);border:1.5px solid var(--border);border-radius:var(--rsm);padding:14px 17px;display:flex;justify-content:space-between;align-items:center;gap:12px;cursor:pointer;transition:border-color .2s;}
.vocab-item:hover{border-color:var(--lav2);}
.vocab-item.revealed{border-color:rgba(200,180,255,.3);background:linear-gradient(135deg,var(--card),rgba(200,180,255,.05));}
.vword{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:var(--lav);}
.vmeaning{font-size:.8rem;color:var(--muted);text-align:right;max-width:58%;display:none;font-weight:400;}
.vmeaning.show{display:block;color:var(--text);animation:fadeUp .3s ease both;}
.vtap{font-size:.7rem;color:var(--dim);flex-shrink:0;}
.vocab-theme{font-size:.72rem;color:var(--lav2);font-weight:700;letter-spacing:.06em;text-transform:uppercase;}
/* VOCAB TEST MODE */
.vtest-mode-toggle{display:flex;gap:8px;padding:0 0 4px;}
.vmode-btn{flex:1;padding:9px 12px;border-radius:var(--rxs);border:1.5px solid var(--border2);background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .18s;}
.vmode-btn.active{border-color:var(--lav2);background:rgba(169,142,245,.12);color:var(--lav);}
.vtest-card{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--r);padding:24px 20px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;}
.vtest-meaning{font-size:1.05rem;font-weight:600;color:var(--text);line-height:1.5;}
.vtest-hint{font-size:.82rem;color:var(--lav);font-style:italic;font-weight:600;min-height:24px;text-align:center;display:block;}
.vtest-input{width:100%;background:var(--card2);border:2px solid var(--border2);border-radius:var(--rsm);padding:13px 16px;font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:600;color:var(--text);outline:none;text-align:center;transition:border-color .2s;}
.vtest-input:focus{border-color:var(--lav2);}
.vtest-input.correct{border-color:var(--mint)!important;background:rgba(143,224,196,.1)!important;color:var(--mint)!important;}
.vtest-input.wrong{border-color:var(--rose)!important;background:rgba(255,158,181,.1)!important;color:var(--rose)!important;}
.vtest-result{font-size:.88rem;line-height:1.6;min-height:24px;font-weight:500;}
.vtest-result.correct{color:var(--mint);}
.vtest-result.wrong{color:var(--rose);}
.vtest-counter{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;color:var(--dim);}
.vtest-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);transition:background .3s;}
.vtest-dot.correct{background:var(--mint);}
.vtest-dot.wrong{background:var(--rose);}
.vtest-dot.current{background:var(--lav2);box-shadow:0 0 6px var(--lav2);}
.vtest-score{text-align:center;padding:24px 20px;background:linear-gradient(135deg,rgba(200,180,255,.1),rgba(242,168,207,.07));border:1.5px solid var(--border2);border-radius:var(--r);display:none;}
.vtest-score-num{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:700;line-height:1;}
.vtest-score-lbl{font-size:.8rem;color:var(--muted);margin-top:4px;}
.vtest-score-msg{font-size:.88rem;color:var(--text);margin-top:10px;font-weight:500;line-height:1.6;}
.vbank-item{background:var(--card);border:1px solid var(--border);border-radius:var(--rxs);padding:11px 14px;display:flex;justify-content:space-between;align-items:center;gap:8px;}
.vbank-word{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-weight:600;color:var(--lav);}
.vbank-meaning{font-size:.75rem;color:var(--muted);text-align:right;flex:1;}
.vbank-badge{font-size:.62rem;font-weight:700;padding:3px 7px;border-radius:100px;}
.vbank-badge.known{background:rgba(143,224,196,.15);color:var(--mint);}
.vbank-badge.learning{background:rgba(255,158,181,.15);color:var(--rose);}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
/* READING */
.passage{font-size:.9rem;line-height:1.85;color:var(--text);font-weight:400;}
.passage strong{color:var(--sky);}
.q-item{display:flex;flex-direction:column;gap:8px;}
.q-row{display:flex;gap:9px;align-items:flex-start;}
.q-num{width:24px;height:24px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;background:rgba(150,200,245,.15);color:var(--sky);}
.q-text{font-size:.88rem;font-weight:600;color:var(--text);line-height:1.5;}
.q-wc{font-size:.68rem;color:var(--dim);text-align:right;font-weight:600;}
/* GRAMMAR */
.gram-banner{background:linear-gradient(135deg,rgba(169,142,245,.12),rgba(242,168,207,.08));border:1px solid var(--border2);border-radius:var(--r);padding:18px 20px;display:flex;align-items:center;gap:14px;}
.gram-icon{font-size:2rem;flex-shrink:0;}
.gram-name{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:700;color:var(--lav);}
.gram-desc{font-size:.78rem;color:var(--muted);margin-top:2px;}
.gram-score{text-align:center;padding:22px;background:linear-gradient(135deg,rgba(200,180,255,.1),rgba(242,168,207,.07));border:1.5px solid var(--border2);border-radius:var(--r);}
.gram-score-num{font-family:'Cormorant Garamond',serif;font-size:3.5rem;font-weight:700;color:var(--lav);line-height:1;}
.gram-score-lbl{font-size:.78rem;color:var(--muted);margin-top:4px;}
.gram-score-msg{font-size:.88rem;color:var(--text);margin-top:10px;font-weight:500;}
.ex-item{background:var(--card2);border:1.5px solid var(--border);border-radius:var(--rsm);padding:16px;}
.ex-type{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:6px;}
.ex-q{font-size:.9rem;color:var(--text);margin-bottom:10px;line-height:1.55;font-weight:500;}
.ex-options{display:flex;flex-direction:column;gap:7px;}
.ex-opt{background:rgba(255,255,255,.04);border:1px solid var(--border2);border-radius:var(--rxs);padding:10px 14px;font-size:.84rem;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;font-weight:500;color:var(--text);text-align:left;}
.ex-opt:hover{border-color:var(--lav2);color:var(--lav);}
.ex-opt.correct{border-color:var(--mint)!important;background:rgba(143,224,196,.12)!important;color:var(--mint)!important;}
.ex-opt.wrong{border-color:var(--rose)!important;background:rgba(255,158,181,.12)!important;color:var(--rose)!important;}
.ex-input{width:100%;background:var(--card);border:1.5px solid var(--border2);border-radius:var(--rxs);padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:.88rem;color:var(--text);outline:none;}
.ex-input:focus{border-color:var(--lav2);}
.ex-explanation{display:none;margin-top:10px;font-size:.8rem;line-height:1.6;padding:10px 13px;border-radius:var(--rxs);background:rgba(200,180,255,.08);color:var(--muted);border-left:2px solid var(--lav2);}
.ex-explanation.show{display:block;animation:fadeUp .3s ease both;}
/* CHAT */
.chat-window{display:flex;flex-direction:column;gap:11px;min-height:200px;max-height:380px;overflow-y:auto;padding:4px 2px;scrollbar-width:thin;scrollbar-color:rgba(200,180,255,.2) transparent;}
.msg{max-width:86%;padding:12px 15px;font-size:.87rem;line-height:1.6;font-weight:400;animation:fadeUp .3s ease both;}
.msg.user{align-self:flex-end;background:linear-gradient(135deg,var(--lav2),var(--indigo));color:#fff;border-bottom-right-radius:4px;}
.msg.ai{align-self:flex-start;background:var(--card2);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px;}
.msg.ai strong{color:var(--lav);}
.msg.typing{opacity:.5;font-style:italic;color:var(--dim);animation:shimmer 1.2s infinite;}
.chat-input-row{display:flex;gap:9px;align-items:flex-end;flex-wrap:nowrap;}
#chat-input{flex:1;min-width:0;min-height:44px;max-height:100px;resize:none;}
.chat-suggestions{display:flex;flex-wrap:wrap;gap:7px;}
.chat-sug{background:rgba(200,180,255,.09);border:1px solid rgba(200,180,255,.2);border-radius:100px;padding:6px 13px;font-size:.74rem;font-weight:600;color:var(--lav);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;}
.chat-sug:hover{background:rgba(200,180,255,.18);}
/* EXAM */
.timer-box{background:var(--card);border:1.5px solid var(--peach);border-radius:var(--r);padding:14px 24px;text-align:center;font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:700;color:var(--peach);letter-spacing:.04em;}
.timer-box.urgent{color:var(--rose);border-color:var(--rose);animation:shimmer .9s infinite;}
.diff-row{display:flex;gap:9px;}
.diff-btn{flex:1;background:var(--card);border:1.5px solid var(--border);border-radius:var(--rsm);padding:12px 8px;text-align:center;cursor:pointer;transition:all .18s;font-family:'DM Sans',sans-serif;}
.diff-btn:hover{border-color:var(--lav2);}
.diff-btn.sel{border-color:var(--peach);background:rgba(245,192,154,.08);color:var(--peach);}
.diff-code{font-weight:700;font-size:.9rem;color:var(--text);}
.diff-desc{font-size:.65rem;color:var(--dim);margin-top:2px;}
.diff-btn.sel .diff-code{color:var(--peach);}
/* PROGRESS */
.prog-ring-wrap{display:flex;justify-content:center;margin:6px 0;}
.prog-ring{transform:rotate(0deg);}
.prog-ring-bg{fill:none;stroke:rgba(255,255,255,.06);stroke-width:8;}
.prog-ring-fill{fill:none;stroke:url(#ring-grad);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.22,1,.36,1);}
.prog-ring-text{text-anchor:middle;dominant-baseline:middle;}
.prog-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.prog-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--rsm);padding:15px;text-align:center;}
.prog-stat-num{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:700;color:var(--lav);line-height:1;}
.prog-stat-lbl{font-size:.68rem;color:var(--dim);margin-top:3px;}
.mastery-item{display:flex;flex-direction:column;gap:5px;}
.mastery-label{display:flex;justify-content:space-between;font-size:.78rem;font-weight:500;}
.mastery-label span:last-child{color:var(--muted);}
/* WEAK AREAS */
.wa-item{background:var(--card);border:1px solid var(--border);border-radius:var(--rsm);padding:14px 16px;display:flex;flex-direction:column;gap:9px;}
.wa-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;}
.wa-topic{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.4;}
.wa-src{font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:3px 9px;border-radius:100px;flex-shrink:0;}
.wa-src.grammar{background:rgba(143,224,196,.1);color:var(--mint);}
.wa-src.writing{background:rgba(242,168,207,.1);color:var(--pink);}
.wa-src.reading{background:rgba(150,200,245,.1);color:var(--sky);}
.wa-src.speaking{background:rgba(245,192,154,.1);color:var(--peach);}
.wa-src.vocab{background:rgba(200,180,255,.1);color:var(--lav);}
.wa-src.manual{background:rgba(255,255,255,.06);color:var(--muted);}
.wa-actions{display:flex;gap:8px;}
.wa-btn{flex:1;border:none;border-radius:100px;padding:8px 10px;font-family:'DM Sans',sans-serif;font-size:.74rem;font-weight:700;cursor:pointer;transition:all .15s;}
.wa-btn.practice{background:var(--lav2);color:#fff;}
.wa-btn.dismiss{background:rgba(255,255,255,.05);color:var(--muted);border:1px solid var(--border);}
.wa-btn:hover{transform:translateY(-1px);}
.wa-empty{text-align:center;padding:28px 16px;color:var(--dim);font-size:.84rem;line-height:1.7;}
.flag-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(242,168,207,.08);border:1px solid rgba(242,168,207,.2);border-radius:100px;padding:6px 14px;font-family:'DM Sans',sans-serif;font-size:.74rem;font-weight:700;color:var(--pink);cursor:pointer;transition:all .2s;}
.flag-btn:hover{background:rgba(242,168,207,.16);}
/* SPEAKING */
.speaking-topic-card{background:linear-gradient(135deg,rgba(143,224,196,.08),rgba(150,200,245,.06));border:1.5px solid rgba(143,224,196,.18);border-radius:var(--r);padding:24px;text-align:center;}
.speaking-topic-label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--mint);margin-bottom:10px;}
.speaking-topic-text{font-size:.98rem;font-weight:600;color:var(--text);line-height:1.6;margin-bottom:6px;}
.speak-timer{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:700;color:var(--mint);text-align:center;transition:color .3s;}
.speak-timer.warn{color:var(--rose);}
.mic-btn{width:70px;height:70px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--lav2),var(--indigo));font-size:1.6rem;cursor:pointer;margin:0 auto;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(169,142,245,.4);transition:transform .15s,box-shadow .15s;}
.mic-btn:hover{transform:scale(1.07);}
.mic-btn.recording{animation:shimmer .8s infinite;box-shadow:0 0 0 8px rgba(169,142,245,.2),0 10px 28px rgba(169,142,245,.4);}

.mission-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.88rem;font-weight:600;}
.mission-row:last-child{border-bottom:none;}
.stat-num.gold{color:var(--gold);}
.stat-box-gold{border-color:rgba(245,217,138,.2);background:linear-gradient(135deg,var(--card),rgba(245,217,138,.05));}

.logo-page{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:32px;position:relative;overflow:hidden;}
.logo-orb{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(169,142,245,.24) 0%,rgba(242,168,207,.10) 38%,transparent 72%);filter:blur(18px);animation:float 5s ease-in-out infinite;}

.home-logo{width:88%;max-width:340px;height:auto;margin:0 auto 4px;display:block;animation:fadeUp .5s ease both;filter:drop-shadow(0 8px 24px rgba(169,142,245,.35));}
.main-logo{position:relative;z-index:2;width:92%;max-width:480px;height:auto;margin-bottom:0;animation:pop .9s ease both;filter:drop-shadow(0 18px 45px rgba(169,142,245,.45));}
.brand-title{position:relative;z-index:2;font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:700;line-height:1;background:linear-gradient(135deg,#ffffff,#c8b4ff,#f2a8cf);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;}
.brand-sub{position:relative;z-index:2;font-size:.9rem;color:var(--muted);margin-bottom:14px;letter-spacing:.04em;}
.brand-line{position:relative;z-index:2;font-size:.82rem;color:var(--dim);margin-bottom:28px;}
.load-shell{position:relative;z-index:2;width:230px;height:8px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden;}

.svg-icon,.lucide{display:inline-block;vertical-align:middle;flex-shrink:0;}
/* old-peseta */


.svg-icon{display:inline-block;vertical-align:middle;flex-shrink:0;}
.icon-lav{color:var(--lav);}
.icon-pink{color:var(--pink);}
.icon-gold{color:var(--gold);}
.icon-mint{color:var(--mint);}
.icon-muted{color:var(--muted);}
.icon-white{color:#fff;}



.mb-logo{width:100%;max-width:480px;margin:0 auto 8px;text-align:center;padding:20px 10px;}
.mb-logo .mb{font-family:'Montserrat',sans-serif;font-size:clamp(80px,22vw,160px);font-weight:700;letter-spacing:-10px;line-height:0.9;background:linear-gradient(135deg,#ff37ff 0%,#8a5cff 45%,#44b8ff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.mb-logo .brand{font-family:'Montserrat',sans-serif;margin-top:4px;font-size:clamp(32px,8vw,58px);font-weight:700;color:#ffffff;letter-spacing:-1px;text-shadow:0 0 20px rgba(255,255,255,0.3);}
.mb-logo .heart{background:linear-gradient(180deg,#c86bff,#7d42ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.mb-logo .cast{font-family:'Montserrat',sans-serif;margin-top:10px;font-size:clamp(18px,4.5vw,38px);font-weight:700;letter-spacing:10px;background:linear-gradient(90deg,#ff39f8,#9b59ff,#49b7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;filter:brightness(1.2);}
.mb-logo .script{font-family:'Great Vibes',cursive;margin-top:4px;font-size:clamp(38px,10vw,68px);color:#f088ff;text-shadow:0 0 15px rgba(240,136,255,1),0 0 30px rgba(191,76,255,.7),0 0 45px rgba(150,50,255,.4);}
.mb-logo .tagline{margin:10px auto;width:85%;border:1.5px solid rgba(210,120,255,1);border-radius:40px;padding:8px 16px;color:#ffffff;font-family:'Montserrat',sans-serif;font-size:clamp(10px,2.4vw,15px);font-weight:600;letter-spacing:1.5px;text-shadow:0 0 8px rgba(255,255,255,0.2);}
.mb-logo .features{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;color:#f1e7ff;font-family:'Montserrat',sans-serif;font-size:clamp(8px,1.8vw,11px);}


.setup-overlay{display:none !important;position:fixed;inset:0;z-index:200;background:var(--bg);align-items:center;justify-content:center;padding:30px;flex-direction:column;text-align:center;}
.setup-overlay.show{display:flex;}
.setup-card{background:var(--card);border:1px solid var(--border2);border-radius:var(--r);padding:28px 24px;max-width:380px;width:100%;}
.setup-title{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:8px;}
.setup-sub{font-size:.85rem;color:var(--muted);line-height:1.6;margin-bottom:20px;}
.setup-input{width:100%;background:var(--card2);border:1.5px solid var(--border2);border-radius:var(--rsm);padding:14px 16px;font-family:'DM Sans',sans-serif;font-size:.92rem;color:var(--text);outline:none;margin-bottom:12px;}
.setup-input:focus{border-color:var(--lav2);}
.setup-hint{font-size:.72rem;color:var(--dim);margin-bottom:20px;line-height:1.5;}











@keyframes bounceIn{0%{transform:translateY(30px) scale(.8);opacity:0}70%{transform:translateY(-5px) scale(1.05);opacity:1}100%{transform:translateY(0) scale(1);opacity:1}}

.crew-inline img{animation:bounceIn .6s ease both;}






.talking-bubble{transition:opacity .4s ease;}
.talking-bubble.fade{opacity:0;}

.load-fill{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,var(--lav2),var(--indigo),var(--gold));transition:width .25s linear;}
@media(max-width:480px){
.home-logo{width:88%;max-width:340px;height:auto;margin:0 auto 4px;display:block;animation:fadeUp .5s ease both;filter:drop-shadow(0 8px 24px rgba(169,142,245,.35));}
.main-logo{font-size:4rem;}.brand-title{font-size:2.45rem;}}
.route-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.85rem;font-weight:600;}
.route-reward{color:var(--mint);font-weight:700;}
.done-task{opacity:.45;text-decoration:line-through;color:var(--dim);}
/* RESPONSIVE */
@media(min-width:480px){.home-title{font-size:3rem;}.modes-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:768px){.stats-row{grid-template-columns:repeat(4,1fr);}.modes-grid{grid-template-columns:repeat(4,1fr);}.pb,.ph{max-width:680px;margin:0 auto;}.home-hero{padding-top:60px;}}

.mascot-name,.crew-name,.mascot-label,[class*="mascot-name"]{display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important;text-align:center!important;margin:0 auto!important;position:static!important;left:auto!important;transform:none!important;padding-left:0!important;padding-right:0!important;}

/* CULTURA Y TRADICIONES */
.cultura-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 12px;border-radius:16px;border:1.5px solid var(--border2);background:rgba(255,255,255,.03);cursor:pointer;transition:all .15s;text-align:left;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;}
.cultura-card:hover,.cultura-card:active{background:rgba(169,142,245,.1);border-color:rgba(169,142,245,.35);}
.cultura-card-icon{font-size:1.6rem;margin-bottom:2px;}
.cultura-card-title{font-size:.82rem;font-weight:700;color:var(--text);line-height:1.2;}
.cultura-card-sub{font-size:.68rem;color:var(--muted);line-height:1.4;}

/* PRONUNCIACIÓN */
.pronun-word-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:rgba(169,142,245,.06);border:1px solid var(--border2);cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent;}
.pronun-word-row:hover,.pronun-word-row:active{background:rgba(169,142,245,.15);}
.pronun-word{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:700;color:var(--text);flex:1;}
.pronun-ipa{font-size:.72rem;color:var(--muted);font-style:italic;}
.pronun-play{font-size:1rem;margin-left:auto;opacity:.7;}

/* WISHING WELL */
.well-cat{display:flex;align-items:center;gap:8px;padding:11px 13px;border-radius:14px;border:1.5px solid var(--border2);background:rgba(169,142,245,.06);font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:600;color:var(--text);cursor:pointer;transition:all .15s;text-align:left;-webkit-tap-highlight-color:transparent;}
.well-cat:hover,.well-cat:active{background:rgba(169,142,245,.16);border-color:rgba(169,142,245,.4);color:var(--lav);}
.well-drop-q{background:linear-gradient(135deg,var(--lav2),var(--indigo));color:#fff;border-radius:16px 16px 4px 16px;padding:11px 15px;font-size:.84rem;font-weight:500;align-self:flex-end;max-width:88%;animation:fadeUp .3s ease both;}
.well-drop-a{background:var(--card2);border:1px solid var(--border);border-radius:4px 16px 16px 16px;padding:14px 16px;font-size:.85rem;line-height:1.75;color:var(--text);animation:fadeUp .35s ease both;}
.well-drop-a strong{color:var(--lav);}
.well-generating{display:flex;align-items:center;gap:10px;padding:14px 16px;background:rgba(200,180,255,.06);border:1px solid var(--border2);border-radius:var(--rsm);font-size:.82rem;color:var(--muted);}

@media(prefers-reduced-motion:reduce){.well-cat{transition:none;}}


#mirella-head.bounce { animation: headBounce .5s cubic-bezier(.34,1.56,.64,1); }
.express-pill{background:rgba(169,142,245,.1);border:1.5px solid rgba(169,142,245,.2);border-radius:100px;padding:5px 11px;font-size:.72rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0;}
.crew-member{display:flex;flex-direction:column;align-items:center;min-width:0;overflow:visible;}
.crew-img-wrap{width:22vw;max-width:100px;height:22vw;max-height:155px;display:flex;align-items:flex-end;justify-content:center;overflow:visible;}
.crew-img-wrap img{max-width:100%;max-height:100%;object-fit:contain;}
.crew-name{width:100%;text-align:center;margin-top:4px;font-family:'Great Vibes',cursive;font-size:clamp(.85rem,3.5vw,1.05rem);color:rgba(210,190,255,.9);display:block;}
.express-pill.active{background:rgba(169,142,245,.25);border-color:var(--lav);color:var(--lav);}
.express-pill:hover{border-color:var(--lav2);color:var(--lav2);}
@keyframes headBounce { 0%{transform:translateY(0)} 40%{transform:translateY(-18px)} 70%{transform:translateY(-6px)} 100%{transform:translateY(0)} }
