*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --p50:#FBEAF0;--p100:#F4C0D1;--p200:#ED93B1;--p400:#D4537E;--p600:#993556;--p800:#72243E;
  --t50:#E1F5EE;--t400:#1D9E75;--t800:#085041;
  --a50:#FAEEDA;--a400:#BA7517;
  --u50:#EEEDFE;--u400:#534AB7;
  --bg:#FDF8F9;--card:#FFFFFF;--tx:#1a1014;--tx2:#6B4A56;--tx3:#A07080;
  --bd:rgba(212,83,126,0.12);--bd2:rgba(212,83,126,0.22);
  --shadow:0 2px 12px rgba(212,83,126,0.08);
}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--tx);display:flex;justify-content:center;min-height:100vh;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.app{max-width:480px;width:100%;display:flex;flex-direction:column;min-height:100vh;}
.screen{display:none;flex-direction:column;flex:1;}
.screen.active{display:flex;}
.hero{padding:36px 22px 20px;position:relative;overflow:hidden;}
.hero-deco{position:absolute;top:-30px;right:-30px;width:200px;height:200px;border-radius:50%;background:var(--p50);pointer-events:none;}
.hero-deco2{position:absolute;top:60px;right:30px;width:90px;height:90px;border-radius:50%;background:var(--p100);opacity:0.35;pointer-events:none;}
.lang-row{display:flex;justify-content:flex-end;margin-bottom:18px;position:relative;z-index:2;}
.lang-wrap{display:flex;background:var(--card);border:0.5px solid var(--bd2);border-radius:20px;overflow:hidden;}
.lang-btn{padding:5px 14px;font-size:12px;font-weight:500;border:none;background:transparent;color:var(--tx3);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;}
.lang-btn.on{background:var(--p400);color:white;border-radius:20px;}
.badge{display:inline-flex;align-items:center;gap:5px;background:var(--p50);border:0.5px solid var(--p200);color:var(--p600);font-size:11px;padding:4px 10px;border-radius:20px;margin-bottom:16px;position:relative;z-index:1;}
.dot-on{width:6px;height:6px;border-radius:50%;background:var(--t400);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-family:'DM Serif Display',serif;font-size:40px;line-height:1.05;position:relative;z-index:1;letter-spacing:-0.5px;}
.hero h1 em{font-style:italic;color:var(--p400);}
.hero-sub{font-size:14px;color:var(--tx2);line-height:1.65;margin-top:12px;max-width:300px;position:relative;z-index:1;}
.xp-strip{margin:0 16px 14px;background:var(--card);border:0.5px solid var(--bd);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:12px;}
.xp-icon{font-size:18px;}
.xp-info{flex:1;}
.xp-lbl{font-size:10px;color:var(--tx3);margin-bottom:4px;}
.xp-bar{height:5px;background:var(--p50);border-radius:3px;overflow:hidden;}
.xp-fill{height:100%;background:linear-gradient(90deg,var(--p400),var(--p200));border-radius:3px;width:0%;transition:width 1.2s ease;}
.xp-count{font-size:12px;font-weight:500;color:var(--p400);white-space:nowrap;}
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:0 16px 16px;}
.feat{position:relative;padding:10px 8px;text-align:center;}
.feat+.feat::before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:0.5px;background:var(--bd);}
.feat-ico{font-size:22px;margin-bottom:7px;}
.feat-lbl{font-size:11px;color:var(--tx2);line-height:1.4;}
.home-body{padding:0 16px 28px;display:flex;flex-direction:column;gap:10px;}
.app-logout{display:none;margin-right:8px;background:var(--card);color:var(--p600);border:0.5px solid var(--bd2);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;box-shadow:var(--shadow);}
.app-logout:hover{background:var(--p50);}
.auth-page{background:var(--bg);align-items:center;padding:26px 18px;}
.auth-shell{width:100%;max-width:414px;}
.auth-panel{background:rgba(255,255,255,0.96);border:0.5px solid var(--bd);border-radius:18px;padding:32px 24px 26px;box-shadow:0 14px 40px rgba(153,53,86,0.1);}
.auth-mark{display:inline-flex;align-items:center;background:var(--p50);border:0.5px solid var(--p200);color:var(--p600);font-size:12px;font-weight:500;padding:6px 13px;border-radius:20px;margin-bottom:20px;}
.auth-panel h1{font-family:'DM Serif Display',serif;font-size:36px;line-height:1.08;margin-bottom:10px;color:var(--tx);}
.auth-lead{font-size:14px;color:var(--tx);line-height:1.58;margin-bottom:14px;max-width:320px;}
.auth-copy{font-size:12px;color:var(--tx2);line-height:1.58;}
.auth-copy-main{font-size:14px;font-weight:700;color:var(--p600);line-height:1.4;margin-top:4px;}
.auth-copy+.auth-copy{margin-top:8px;max-width:330px;}
.auth-note{font-size:11px;color:var(--tx3);line-height:1.55;text-align:center;}
.auth-form{margin-top:22px;display:flex;flex-direction:column;gap:10px;}
.auth-form input{width:100%;border:0.5px solid var(--bd2);border-radius:10px;padding:12px 13px;font-size:14px;font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--tx);outline:none;transition:border-color .15s,background .15s,box-shadow .15s;}
.auth-form input::placeholder{color:var(--tx3);}
.auth-form input:focus{border-color:var(--p400);background:var(--card);box-shadow:0 0 0 3px rgba(212,83,126,0.12);}
.auth-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:2px;}
.auth-actions.single{grid-template-columns:1fr;}
.auth-actions button{border:none;border-radius:10px;padding:11px 12px;font-size:13px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .15s,color .15s,opacity .15s,transform .15s;}
.auth-actions button:first-child{background:var(--p400);color:white;}
.auth-actions button:first-child:hover:not(:disabled){background:var(--p600);transform:translateY(-1px);}
.auth-actions button:last-child{background:var(--p50);color:var(--p600);border:0.5px solid var(--bd2);}
.auth-actions button:last-child:hover:not(:disabled){background:var(--p100);transform:translateY(-1px);}
.auth-actions button:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(212,83,126,0.16);}
.auth-actions button:disabled{cursor:not-allowed;opacity:.68;transform:none;}
.auth-link-btn,.auth-resend{width:100%;background:transparent;border:none;color:var(--p600);font-size:12px;font-weight:500;font-family:'DM Sans',sans-serif;cursor:pointer;padding:4px 0;text-align:left;}
.auth-resend{display:none;}
.auth-resend.show{display:block;}
.auth-link-btn:hover,.auth-resend:hover{text-decoration:underline;}
.auth-link-btn:disabled,.auth-resend:disabled{cursor:not-allowed;opacity:.65;text-decoration:none;}
.auth-link-btn:focus-visible,.auth-resend:focus-visible{outline:none;text-decoration:underline;}
.auth-msg{font-size:12px;color:var(--p600);line-height:1.35;min-height:0;margin-top:-6px;padding-top:0;}
.auth-form.hidden{display:none;}
.auth-reset-form{display:none;}
.auth-reset-form.show{display:flex;}
.reset-copy{font-weight:400;color:var(--tx2);}
.auth-note:first-of-type{margin-top:8px;padding-top:10px;border-top:0.5px solid var(--bd);}
.auth-note+.auth-note{margin-top:6px;}
.setup-card{background:var(--card);border:0.5px solid var(--bd);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);}
.setup-hd{background:var(--p50);padding:14px 16px;}
.setup-hd-title{font-size:14px;font-weight:500;color:var(--tx);}
.setup-hd-sub{font-size:12px;color:var(--tx2);margin-top:3px;}
.sdiv{height:0.5px;background:var(--bd);margin:0 16px;}
.sq{padding:14px 16px;}
.sq-label{font-size:13px;font-weight:500;color:var(--tx);margin-bottom:10px;}
.age-row{display:flex;gap:6px;flex-wrap:wrap;}
.age-btn{flex:1;min-width:55px;text-align:center;padding:8px 4px;border-radius:8px;border:0.5px solid var(--bd2);font-size:12px;color:var(--tx2);cursor:pointer;background:var(--bg);transition:all .15s;font-family:'DM Sans',sans-serif;}
.age-btn:hover{background:var(--p50);border-color:var(--p200);color:var(--p600);}
.age-btn.on{background:var(--p400);border-color:var(--p400);color:white;font-weight:500;}
.scene-row{display:flex;flex-wrap:wrap;gap:6px;}
.sc-btn{padding:6px 12px;border-radius:20px;border:0.5px solid var(--bd2);font-size:12px;color:var(--tx2);cursor:pointer;background:var(--bg);transition:all .15s;font-family:'DM Sans',sans-serif;}
.sc-btn:hover{background:var(--p50);border-color:var(--p200);color:var(--p600);}
.sc-btn.on{background:var(--p50);border-color:var(--p400);color:var(--p600);font-weight:500;}
.connector{display:flex;justify-content:center;padding:4px 0;}
.conn-line{width:1.5px;height:20px;background:var(--bd2);border-radius:2px;}
.step2-label{font-size:11px;font-weight:500;color:var(--tx3);text-transform:uppercase;letter-spacing:0.6px;text-align:center;margin-bottom:2px;}
.parallel{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.p-card{background:var(--card);border:0.5px solid var(--bd);border-radius:16px;padding:16px 14px;cursor:pointer;display:flex;flex-direction:column;gap:5px;transition:all .18s;box-shadow:var(--shadow);}
.p-card:hover{border-color:var(--p200);transform:translateY(-2px);box-shadow:0 10px 28px rgba(212,83,126,.14);}
.p-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:4px;}
.p-icon.pk{background:var(--p50);}.p-icon.tl{background:var(--t50);}
.p-title{font-size:13px;font-weight:500;color:var(--tx);}
.p-desc{font-size:11px;color:var(--tx2);line-height:1.4;}
.p-cta{font-size:11px;color:var(--p400);font-weight:500;margin-top:4px;}
.p-cta-tl{font-size:11px;color:var(--t400);font-weight:500;margin-top:4px;}
.home-footer{padding:10px 16px 28px;text-align:center;font-size:11px;color:var(--tx3);}
.topbar{background:var(--card);border-bottom:0.5px solid var(--bd);padding:12px 14px;display:flex;align-items:center;gap:9px;flex-shrink:0;}
.back-btn{width:30px;height:30px;border-radius:50%;background:var(--p50);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--p600);font-size:18px;flex-shrink:0;line-height:1;}
.maya-av{width:34px;height:34px;border-radius:50%;background:var(--p50);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px;}
.tb-name{font-size:14px;font-weight:500;color:var(--tx);}
.tb-sub{font-size:12px;color:var(--t400);display:flex;align-items:center;gap:3px;}
.tb-dot{width:5px;height:5px;border-radius:50%;background:var(--t400);}
.mode-tag{margin-left:auto;background:var(--p50);color:var(--p600);font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;}
.mode-tag-tl{margin-left:auto;background:var(--t50);color:var(--t400);font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;}
.ai-usage{display:none;background:rgba(255,255,255,.72);border-bottom:0.5px solid var(--bd);color:var(--tx3);font-size:10px;line-height:1.4;padding:5px 14px;text-align:right;}
.ai-usage.show{display:block;}
.chat-screen{height:100vh;}
.messages{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:10px;}
.msg{display:flex;flex-direction:column;gap:2px;}
.msg.user{align-items:flex-end;}.msg.bot{align-items:flex-start;}
.bubble{max-width:85%;padding:10px 13px;border-radius:14px;font-size:14px;line-height:1.55;}
.msg.user .bubble{background:var(--p400);color:white;border-bottom-right-radius:3px;}
.msg.bot .bubble{background:var(--card);color:var(--tx);border:0.5px solid var(--bd);border-bottom-left-radius:3px;}
.sc-bubble{max-width:90%;background:var(--p50);border-left:3px solid var(--p400);border-radius:0 14px 14px 3px;padding:11px 13px;font-size:14px;line-height:1.55;color:var(--tx);}
.sc-lbl{font-size:9px;font-weight:500;color:var(--p600);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:4px;}
.fb-combined{padding:0!important;overflow:hidden;max-width:90%!important;}
.fb-s{padding:11px 13px;font-size:14px;line-height:1.55;}
.fb-s1{background:#FEF6F0;}.fb-s2{background:#FAEAF1;}.fb-s3{background:#F4C0D1;}
.fb-div{height:0.5px;background:rgba(212,83,126,0.15);}
.fb-lbl{display:block;font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:5px;}
.fb-l1{color:#C47A5A;}.fb-l2{color:var(--p600);}.fb-l3{color:var(--p800);}
.msg-time{font-size:10px;color:var(--tx3);padding:0 3px;}
.chips-wrap{padding:3px 12px 8px;display:flex;flex-wrap:wrap;gap:5px;}
.chip{background:var(--card);border:0.5px solid var(--bd2);color:var(--tx2);border-radius:20px;padding:6px 12px;font-size:13px;cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;transition:all .12s;}
.chip:hover,.chip.accent{background:var(--p50);color:var(--p600);border-color:var(--p200);}
.input-bar{background:var(--card);border-top:0.5px solid var(--bd);padding:8px 10px 10px;display:flex;gap:7px;align-items:flex-end;flex-shrink:0;}
.input-bar textarea{flex:1;border:0.5px solid var(--bd2);border-radius:20px;padding:8px 13px;font-size:14px;font-family:'DM Sans',sans-serif;resize:none;outline:none;background:var(--bg);color:var(--tx);line-height:1.4;min-height:36px;max-height:80px;overflow-y:auto;}
.input-bar textarea:focus{border-color:var(--p400);background:var(--card);}
.input-bar textarea:disabled{cursor:not-allowed;background:#F7F0F2;color:var(--tx3);opacity:1;}
.send-btn{width:36px;height:36px;border-radius:50%;background:var(--p400);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;}
.send-btn:hover{background:var(--p600);}
.send-btn:disabled{cursor:not-allowed;background:var(--p100);opacity:.7;}
.typing-wrap{display:flex;align-items:center;gap:4px;padding:9px 12px;background:var(--card);border:0.5px solid var(--bd);border-radius:14px;border-bottom-left-radius:3px;width:fit-content;}
.tdot{width:5px;height:5px;border-radius:50%;background:var(--tx3);animation:bounce 1.2s infinite;}
.tdot:nth-child(2){animation-delay:.2s;}.tdot:nth-child(3){animation-delay:.4s;}
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-4px)}}
.trainer-body{flex:1;overflow-y:auto;padding:16px 14px 28px;}
.prog-row{display:flex;align-items:center;gap:6px;margin-bottom:14px;}
.prog-dots{display:flex;gap:4px;}
.pdot{width:6px;height:6px;border-radius:50%;background:var(--bd2);}
.pdot.done{background:var(--p400);}.pdot.active{background:var(--p200);}
.prog-lbl{font-size:11px;color:var(--tx3);margin-left:auto;}
.scene-card{background:var(--card);border:0.5px solid var(--bd);border-radius:14px;overflow:hidden;margin-bottom:12px;box-shadow:var(--shadow);}
.scene-hd{background:var(--p50);padding:14px 16px;display:flex;align-items:center;gap:10px;}
.scene-emoji{width:38px;height:38px;background:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;}
.scene-type{font-size:10px;font-weight:500;color:var(--p600);text-transform:uppercase;letter-spacing:0.4px;}
.scene-title{font-size:13px;font-weight:500;color:var(--tx);}
.scene-body{padding:16px;}
.h-lbl{font-size:10px;color:var(--tx3);font-weight:500;margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px;}
.h-q{background:#F5F0F2;border-left:3px solid var(--p400);border-radius:0 8px 8px 0;padding:10px 13px;font-size:13px;font-style:italic;line-height:1.55;color:var(--tx);margin-bottom:10px;}
.ex-txt{font-size:12px;color:var(--tx2);line-height:1.55;margin-bottom:16px;}
.strat-label{font-size:10px;font-weight:500;color:var(--tx3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px;}
.strat-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.strat-row{display:flex;align-items:flex-start;gap:9px;padding:10px 12px;background:var(--bg);border-radius:8px;border:0.5px solid var(--bd);}
.strat-tag{font-size:9px;font-weight:500;padding:2px 8px;border-radius:7px;white-space:nowrap;flex-shrink:0;margin-top:1px;}
.tag-verbal{background:var(--t50);color:var(--t400);}
.tag-mental{background:var(--u50);color:var(--u400);}
.tag-physical{background:var(--a50);color:var(--a400);}
.strat-text{font-size:12px;color:var(--tx);line-height:1.45;}
.tip-box{background:var(--bg);border:0.5px solid var(--bd);border-radius:8px;padding:10px 13px;font-size:12px;line-height:1.5;color:var(--tx2);margin-bottom:12px;display:none;}
.tip-box.show{display:block;}
.trainer-actions{display:flex;gap:8px;}
.btn-tip{background:var(--bg);border:0.5px solid var(--bd2);border-radius:8px;padding:9px 13px;font-size:12px;cursor:pointer;color:var(--tx2);font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap;}
.btn-tip:hover{background:var(--p50);color:var(--p600);}
.btn-prev{background:var(--bg);border:0.5px solid var(--bd2);border-radius:8px;padding:9px 13px;font-size:12px;cursor:pointer;color:var(--tx2);font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap;}
.btn-prev:hover{background:var(--p50);color:var(--p600);}
.btn-prev:disabled{opacity:0.3;cursor:default;pointer-events:none;}
.btn-next{flex:1;background:var(--p400);color:white;border:none;border-radius:8px;padding:9px 14px;font-size:13px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .15s;}
.btn-next:hover{background:var(--p600);}
.done-card{background:var(--card);border:0.5px solid var(--bd);border-radius:14px;padding:32px 20px;text-align:center;}
.done-title{font-family:'DM Serif Display',serif;font-size:22px;color:var(--tx);margin-bottom:6px;}
.done-text{font-size:13px;color:var(--tx2);line-height:1.6;margin-bottom:18px;}
.load-card{background:var(--card);border:0.5px solid var(--bd);border-radius:14px;padding:40px 20px;text-align:center;}
.spinner{width:32px;height:32px;border:3px solid var(--p100);border-top-color:var(--p400);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 14px;}
@keyframes spin{to{transform:rotate(360deg)}}
.load-msg{font-size:13px;color:var(--tx2);}
.load-hint{font-size:11px;color:var(--tx3);margin-top:6px;}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.screen.active{animation:fadeUp .28s ease both;}
