:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#f8fafc;background:#06132d;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html{min-width:320px;min-height:100%;background:radial-gradient(circle at 12% 8%,rgba(37,99,235,.3),transparent 32rem),radial-gradient(circle at 88% 22%,rgba(168,85,247,.2),transparent 30rem),#06132d}body{margin:0;min-width:320px;min-height:100vh}button{font:inherit}button:focus-visible{outline:3px solid rgba(96,165,250,.95);outline-offset:3px}.app-shell{min-height:100vh;padding:24px;display:grid;place-items:center}.home-layout,.session-layout{width:min(1120px,100%);border:1px solid rgba(148,163,184,.2);border-radius:32px;background:linear-gradient(145deg,#0f244bf2,#07142df5);box-shadow:0 34px 100px #0208177a;overflow:hidden}.home-layout{padding:28px}.session-layout{padding:28px;max-width:920px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px}.brand{display:flex;align-items:center;gap:12px}.brand>div{display:grid;gap:3px}.brand strong{font-size:1rem}.brand small{color:#93c5fd;font-weight:800;letter-spacing:.12em}.brand-mark{width:76px;height:76px;border-radius:24px;display:grid;place-items:center;background:linear-gradient(145deg,#3b82f6,#1d4ed8);box-shadow:0 18px 44px #2563eb6b;font-size:1.45rem;font-weight:1000;letter-spacing:-.06em}.brand-mark-small{width:48px;height:48px;border-radius:16px;font-size:1rem}.text-action{border:0;padding:8px 0;color:#bfdbfe;background:transparent;font-weight:850;cursor:pointer}.text-action:hover{color:#fff}.hero{padding:68px 0 42px;max-width:780px}.eyebrow{display:inline-flex;align-items:center;gap:8px;color:#60a5fa;font-size:.78rem;font-weight:950;letter-spacing:.16em;text-transform:uppercase}.hero h1,.session-heading h1,.completion-card h1{margin:14px 0 16px;font-size:clamp(2.35rem,6vw,5rem);line-height:.98;letter-spacing:-.055em}.hero p,.session-heading p,.completion-card>p{margin:0;color:#cbd5e1;font-size:clamp(1rem,2vw,1.18rem);line-height:1.7}.usage-badge{margin-top:28px;width:fit-content;display:flex;align-items:center;gap:12px;padding:10px 17px 10px 11px;border:1px solid rgba(96,165,250,.4);border-radius:999px;background:#1e40af2e}.usage-badge strong{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:#2563eb;font-size:1.15rem}.usage-badge span{color:#dbeafe;font-weight:800}.session-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.session-card{min-height:360px;padding:24px;border:1px solid rgba(148,163,184,.2);border-radius:26px;background:#0f172aad;display:flex;flex-direction:column;transition:transform .18s ease,border-color .18s ease,background .18s ease}.session-card.available{border-color:#60a5fab8;background:linear-gradient(160deg,#2563eb38,#0f172ab8);transform:translateY(-5px)}.session-card.completed{border-color:#34d39957}.session-card.locked{opacity:.58}.session-number{color:#60a5fa;font-size:.82rem;font-weight:1000;letter-spacing:.18em}.card-state{margin-top:16px;width:fit-content;padding:6px 10px;border-radius:999px;background:#94a3b81f;color:#cbd5e1;font-size:.7rem;font-weight:950;letter-spacing:.1em;text-transform:uppercase}.available .card-state{background:#2563eb47;color:#bfdbfe}.completed .card-state{background:#10b9812e;color:#a7f3d0}.session-card h2{margin:21px 0 5px;font-size:1.45rem;letter-spacing:-.03em}.session-card>p{margin:0;color:#94a3b8}.word-list{margin:23px 0;display:flex;flex-wrap:wrap;gap:8px}.word-list span{padding:6px 9px;border-radius:10px;background:#ffffff12;color:#dbeafe;font-size:.78rem;font-weight:750}.card-action,.primary-action,.danger-action{border:0;border-radius:999px;padding:15px 20px;color:#fff;font-weight:950;cursor:pointer;transition:transform .16s ease,filter .16s ease}.card-action{margin-top:auto;background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.card-action:disabled{background:#94a3b82e;color:#94a3b8;cursor:not-allowed}.card-action:not(:disabled):hover,.primary-action:hover,.danger-action:hover{transform:translateY(-2px);filter:brightness(1.08)}.demo-footer{margin-top:28px;padding-top:22px;border-top:1px solid rgba(148,163,184,.16);color:#94a3b8;font-size:.88rem;line-height:1.6}.home-error{margin-top:22px;padding:16px 18px;border:1px solid rgba(248,113,113,.36);border-radius:18px;background:#7f1d1d33}.home-error p{margin:5px 0 0;color:#fecaca}.session-heading{padding:60px 0 34px;text-align:center}.session-heading p{max-width:680px;margin-inline:auto}.participants{display:grid;grid-template-columns:1fr 1fr;gap:18px}.participant{min-height:210px;padding:24px;border:1px solid rgba(148,163,184,.18);border-radius:26px;background:#0f172aad;display:grid;place-items:center;align-content:center;gap:7px;transition:border-color .18s ease,background .18s ease,transform .18s ease}.participant.active{transform:translateY(-4px)}.participant.coach.active{border-color:#60a5fabf;background:#2563eb38}.participant.student.active{border-color:#4ade80ad;background:#16a34a2e}.participant-icon{font-size:3.2rem}.participant small{color:#94a3b8;font-weight:950;letter-spacing:.12em}.participant strong{font-size:1.15rem}.status-panel{margin-top:20px;padding:18px 20px;border:1px solid rgba(148,163,184,.2);border-radius:20px;background:#0f172ab8;display:flex;align-items:flex-start;gap:13px}.status-dot{margin-top:5px;width:12px;height:12px;flex:0 0 auto;border-radius:50%;background:#94a3b8;box-shadow:0 0 0 7px #94a3b81a}.status-coach .status-dot{background:#60a5fa;box-shadow:0 0 0 7px #60a5fa1f}.status-student .status-dot{background:#4ade80;box-shadow:0 0 0 7px #4ade801f}.status-error .status-dot{background:#f87171;box-shadow:0 0 0 7px #f871711f}.status-panel p{margin:5px 0 0;color:#cbd5e1;line-height:1.5}.microphone-meter{margin-top:14px;height:9px;border-radius:999px;background:#94a3b81f;overflow:hidden}.microphone-meter>div{height:100%;min-width:2px;border-radius:inherit;background:linear-gradient(90deg,#22c55e,#60a5fa);transition:width .1s linear}.session-note{margin:15px auto 0;max-width:680px;color:#94a3b8;font-size:.82rem;line-height:1.5;text-align:center}.danger-action{margin:24px auto 0;display:block;background:linear-gradient(135deg,#ef4444,#b91c1c)}.completion-card{width:min(680px,100%);padding:clamp(28px,6vw,58px);border:1px solid rgba(96,165,250,.3);border-radius:32px;background:radial-gradient(circle at top right,rgba(59,130,246,.25),transparent 20rem),linear-gradient(145deg,#0f244bfa,#07142dfa);box-shadow:0 34px 100px #02081785;text-align:center}.completion-card .brand-mark{margin:0 auto 28px}.completion-card h1{font-size:clamp(2.3rem,7vw,4.6rem)}.completion-list{margin:30px 0;display:grid;gap:10px;text-align:left}.completion-list>div{padding:14px 16px;border:1px solid rgba(52,211,153,.24);border-radius:16px;background:#10b9811a;display:flex;align-items:center;gap:13px}.completion-list>div>span{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#10b981;font-weight:1000}.completion-list div div{display:grid;gap:2px}.completion-list small{color:#a7f3d0}.primary-action{width:100%;background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.completion-card>.text-action{margin-top:15px}@media(max-width:840px){.session-grid{grid-template-columns:1fr}.session-card{min-height:auto}.session-card.available{transform:none}}@media(max-width:640px){.app-shell{padding:0;place-items:stretch}.home-layout,.session-layout,.completion-card{min-height:100vh;border:0;border-radius:0}.home-layout,.session-layout{padding:20px}.topbar{align-items:flex-start}.topbar .text-action{max-width:130px;text-align:right}.hero{padding:50px 0 32px}.participants{grid-template-columns:1fr}.participant{min-height:150px}.completion-card{display:flex;flex-direction:column;justify-content:center}}
