@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@500;600;700&display=swap');
/* ===== Oryen — refined calm, premium design ===== */
:root{
  --bg:#0a0f1f; --bg-2:#0e1530; --surface:#141d36; --surface-2:#19223f; --surface-3:#202c4d;
  --border:#283356; --border-soft:rgba(255,255,255,.06);
  --text:#f0f3fb; --muted:#a6b1d0; --muted-2:#6f7da6;
  --accent:#3b6ef8; --accent-2:#6f97ff; --accent-soft:rgba(59,110,248,.14);
  --grad:linear-gradient(135deg,#3b6ef8 0%,#4f86ff 100%);
  --good:#37d6a0; --good-soft:rgba(55,214,160,.12); --warn:#f5b14c; --warn-soft:rgba(245,177,76,.12);
  --danger:#fb7185;
  --shadow:0 14px 44px rgba(0,0,0,.4); --shadow-sm:0 4px 18px rgba(0,0,0,.28);
  --radius:18px; --radius-sm:12px; --radius-lg:24px;
  --serif:'Playfair Display',Georgia,serif; --sans:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.65;
  -webkit-font-smoothing:antialiased;min-height:100vh;
  background-image:
    radial-gradient(1000px 600px at 85% -8%,rgba(122,92,255,.12),transparent 60%),
    radial-gradient(900px 600px at -5% 5%,rgba(59,110,248,.12),transparent 55%),
    radial-gradient(700px 500px at 50% 110%,rgba(59,110,248,.06),transparent 60%);
  background-attachment:fixed;}
#app{animation:pageFade .35s ease both}
@keyframes pageFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;margin:0 0 .5em;letter-spacing:-.015em;color:var(--text)}
h1{font-size:clamp(2rem,5vw,3.2rem)}h2{font-size:clamp(1.5rem,3.5vw,2.1rem)}h3{font-size:1.25rem}
p{margin:0 0 1rem;color:var(--muted)}
a{color:var(--accent-2);text-decoration:none;cursor:pointer;transition:color .18s ease}
a:hover{color:var(--text)}
.container{width:100%;max-width:1140px;margin:0 auto;padding:0 24px}
.narrow{max-width:760px}.muted{color:var(--muted)}.center{text-align:center}
small,.small{font-size:.85rem}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:.97rem;
  padding:12px 22px;border-radius:999px;border:1px solid transparent;cursor:pointer;background:var(--grad);color:#fff;
  box-shadow:0 6px 18px rgba(59,110,248,.28);transition:transform .18s ease,box-shadow .18s ease,filter .18s ease,background-color .18s ease,border-color .18s ease}
.btn:hover{background:linear-gradient(135deg,#2f63f0 0%,#3b6ef8 100%);transform:translateY(-2px) scale(1.015);box-shadow:0 12px 30px rgba(59,110,248,.5);filter:none}
.btn:active{transform:translateY(0) scale(.99)}
.btn.secondary{background:var(--surface-2);border-color:var(--border);color:var(--text);box-shadow:none}
.btn.secondary:hover{background:var(--surface-3);border-color:#37456f;filter:none}
.btn.ghost{background:transparent;color:var(--muted);box-shadow:none}
.btn.ghost:hover{color:var(--text);background:var(--surface-2)}
.btn.danger{background:transparent;border-color:rgba(251,113,133,.45);color:var(--danger);box-shadow:none}
.btn.danger:hover{background:rgba(251,113,133,.12);filter:none}
.btn.full{width:100%}.btn.lg{padding:15px 30px;font-size:1.05rem}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none;filter:none}

/* ---- cards ---- */
.card{position:relative;background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);
  border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.08),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.card.hoverable{transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.card.hoverable:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#37456f}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(10,15,31,.8);border-bottom:1px solid var(--border-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px}
.brand{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:var(--text);letter-spacing:-.02em;display:flex;align-items:center;gap:11px;white-space:nowrap}
.brand .dot{width:14px;height:14px;border-radius:50%;background:var(--grad);box-shadow:0 0 16px rgba(59,110,248,.7)}
.nav-links{display:flex;align-items:center;gap:6px;overflow-x:auto;scrollbar-width:none}
.nav-links::-webkit-scrollbar{display:none}
.nav-link{position:relative;display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-weight:500;font-size:.92rem;
  padding:9px 14px;border-radius:999px;white-space:nowrap;transition:color .18s ease,background .18s ease}
.nav-link .ic{font-size:1.05rem;line-height:1}
.nav-link:hover{color:var(--text);background:var(--surface-2)}
.nav-link.active{color:#fff;background:var(--accent-soft);box-shadow:inset 0 0 0 1px rgba(59,110,248,.45)}

/* ---- forms ---- */
label{display:block;font-size:.88rem;font-weight:600;color:var(--muted);margin-bottom:8px;letter-spacing:.01em}
input[type=text],input[type=email],input[type=password],textarea,select{width:100%;font-family:var(--sans);font-size:1rem;color:var(--text);
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;
  transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}
input::placeholder,textarea::placeholder{color:var(--muted-2)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);background:var(--bg)}
textarea{resize:vertical;min-height:120px;line-height:1.6}
.field{margin-bottom:18px}

/* ---- sliders ---- */
.slider-row{margin-bottom:24px}
.slider-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.slider-head .name{font-weight:600;color:var(--text);font-size:1.05rem}
.slider-head .val{font-family:var(--serif);font-size:1.6rem;color:var(--accent-2);min-width:2ch;text-align:right;transition:transform .15s ease}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:10px;border-radius:999px;
  background:linear-gradient(90deg,#3b6ef8 var(--fill,50%),var(--surface-3) var(--fill,50%));cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:#fff;border:5px solid var(--accent);box-shadow:0 3px 12px rgba(0,0,0,.45);transition:transform .16s ease,box-shadow .16s ease}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.16);box-shadow:0 0 0 9px var(--accent-soft)}
input[type=range]::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:#fff;border:5px solid var(--accent);box-shadow:0 3px 12px rgba(0,0,0,.45)}

/* ---- toast / flash ---- */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface-3);border:1px solid var(--border);color:var(--text);
  padding:13px 24px;border-radius:999px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;z-index:200;font-weight:600}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.success{border-color:rgba(55,214,160,.55)}
.flash-success{animation:flashGreen 1s ease}
@keyframes flashGreen{0%{box-shadow:0 0 0 0 var(--good-soft)}30%{box-shadow:0 0 0 6px var(--good-soft);border-color:var(--good)}100%{box-shadow:var(--shadow-sm)}}

/* ---- loading dots ---- */
.dots{display:inline-flex;gap:6px;align-items:center}
.dots span{width:9px;height:9px;border-radius:50%;background:var(--accent-2);animation:bounce 1.2s infinite ease-in-out both}
.dots span:nth-child(2){animation-delay:.18s}.dots span:nth-child(3){animation-delay:.36s}
@keyframes bounce{0%,80%,100%{transform:scale(.5);opacity:.4}40%{transform:scale(1);opacity:1}}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(16px);animation:reveal .55s cubic-bezier(.2,.7,.2,1) forwards}
.reveal.d1{animation-delay:.07s}.reveal.d2{animation-delay:.14s}.reveal.d3{animation-delay:.21s}.reveal.d4{animation-delay:.28s}
@keyframes reveal{to{opacity:1;transform:none}}

/* ---- auth ---- */
.auth-wrap{min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;padding:48px 20px}
.auth-card{width:100%;max-width:430px}.auth-card h1{font-size:2.1rem;margin-bottom:6px}
.form-error{color:var(--danger);font-size:.9rem;min-height:1.2em;margin:4px 0 12px}

/* ---- landing ---- */
.hero{padding:96px 0 64px;text-align:center}
.hero .eyebrow{color:var(--accent-2);font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:.8rem}
.hero h1{margin:20px auto;max-width:17ch;background:linear-gradient(180deg,#fff,#c7d2f0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lead{font-size:1.2rem;max-width:56ch;margin:0 auto 34px;color:var(--muted)}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.section{padding:72px 0}.section h2{text-align:center;margin-bottom:12px}
.section .sub{text-align:center;max-width:54ch;margin:0 auto 48px;font-size:1.05rem}
.grid{display:grid;gap:22px}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.feature .ico{width:52px;height:52px;border-radius:14px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:1.5rem}
.feature h3{font-size:1.3rem}

/* ---- pricing ---- */
.price-card{max-width:460px;margin:0 auto;text-align:center}
.price-card .amount{font-family:var(--serif);font-size:3.6rem;color:var(--text);margin:6px 0}
.price-card .amount span{font-size:1.1rem;color:var(--muted);font-family:var(--sans)}
.price-list{list-style:none;padding:0;margin:24px 0 28px;text-align:left}
.price-list li{padding:10px 0 10px 32px;position:relative;color:var(--muted)}
.price-list li::before{content:"";position:absolute;left:6px;top:17px;width:10px;height:2px;border-radius:2px;background:var(--accent)}
.trial-pill{display:inline-block;background:var(--good-soft);color:var(--good);font-weight:600;font-size:.85rem;padding:7px 16px;border-radius:999px;margin-bottom:18px;box-shadow:inset 0 0 0 1px rgba(55,214,160,.3)}

/* ---- page head ---- */
.page-head{padding:44px 0 14px}.page-head h1{margin-bottom:6px}
.page-head .lead-line{display:flex;align-items:center;gap:14px}
.page-head .ph-ic{width:48px;height:48px;border-radius:14px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex:none}

/* ---- dashboard tiles & stats ---- */
.tile{display:block;position:relative}
.tile .ico{font-size:1.8rem;margin-bottom:14px}
.tile h3{font-size:1.3rem;margin-bottom:6px}.tile p{margin:0;font-size:.95rem}
.tile .arrow{position:absolute;top:26px;right:26px;color:var(--muted-2);transition:transform .22s ease,color .22s ease;font-size:1.2rem}
.tile:hover .arrow{transform:translateX(4px);color:var(--accent-2)}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
.stat{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px 16px;text-align:center}
.stat .ic{font-size:1.2rem;margin-bottom:4px}
.stat .n{font-family:var(--serif);font-size:2rem;color:var(--accent-2);line-height:1.1}
.stat .l{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

/* ---- insight callouts ---- */
.insight{padding:16px 18px;border-radius:14px;margin-bottom:12px;background:var(--surface-2);border:1px solid var(--border)}
.insight .lab{font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;font-weight:700;margin-bottom:5px;display:flex;align-items:center;gap:7px;color:var(--muted)}
.insight p{color:var(--text);margin:0}
.insight.good{background:var(--good-soft);border-color:rgba(55,214,160,.3)}
.insight.good .lab{color:var(--good)}
.insight.warn{background:var(--warn-soft);border-color:rgba(245,177,76,.3)}
.insight.warn .lab{color:var(--warn)}
.insight.next{background:var(--accent-soft);border-color:rgba(59,110,248,.4)}
.insight.next .lab{color:var(--accent-2)}

/* ---- coach prompt ---- */
.coach-prompt{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--accent-soft);border:1px solid rgba(59,110,248,.35);border-radius:var(--radius);padding:18px 22px;margin-top:24px;flex-wrap:wrap}
.coach-prompt p{margin:0;color:var(--text)}

/* ---- lists ---- */
.item-list{list-style:none;padding:0;margin:0}
.item-list li{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:15px 17px;margin-bottom:10px;display:flex;justify-content:space-between;gap:12px;align-items:flex-start;animation:reveal .4s ease both;transition:border-color .18s ease}
.item-list li:hover{border-color:#37456f}
.item-list .time{color:var(--muted-2);font-size:.8rem;white-space:nowrap}
.icon-btn{background:none;border:none;color:var(--muted-2);cursor:pointer;font-size:1.05rem;transition:color .18s ease,transform .18s ease;padding:2px 6px;border-radius:8px;flex:none}
.icon-btn:hover{color:var(--danger);transform:scale(1.15);background:rgba(251,113,133,.1)}

/* ---- coach ---- */
.coach-layout{display:grid;grid-template-columns:288px 1fr;gap:20px;height:calc(100vh - 72px - 40px);margin-top:20px}
.chat-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;overflow-y:auto;display:flex;flex-direction:column}
.session-item{padding:11px 13px;border-radius:var(--radius-sm);cursor:pointer;color:var(--muted);font-size:.92rem;margin-bottom:4px;transition:background .18s ease,color .18s ease;display:flex;justify-content:space-between;gap:8px;align-items:center}
.session-item:hover{background:var(--surface-2);color:var(--text)}
.session-item.active{background:var(--accent-soft);color:var(--text);box-shadow:inset 0 0 0 1px rgba(59,110,248,.35)}
.session-item .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.chat-main{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.chat-scroll{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:14px}
.msg{max-width:78%;padding:14px 18px;border-radius:18px;line-height:1.55;animation:msgIn .35s ease both;white-space:pre-wrap}
@keyframes msgIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.msg.user{align-self:flex-end;background:var(--grad);color:#fff;border-bottom-right-radius:6px;box-shadow:0 6px 18px rgba(59,110,248,.28)}
.msg.ai{align-self:flex-start;background:var(--surface-2);color:var(--text);border-bottom-left-radius:6px;border:1px solid var(--border)}
.chat-input{display:flex;gap:10px;padding:16px;border-top:1px solid var(--border-soft)}
.chat-input textarea{min-height:0;height:50px;max-height:140px;border-radius:14px;overflow-y:hidden}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);padding:40px}

/* ---- onboarding ---- */
.onboard-step{animation:reveal .4s ease both}
.choice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:20px 0}
.choice{padding:18px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-2);cursor:pointer;transition:all .2s ease;font-weight:500}
.choice:hover{border-color:var(--accent);transform:translateY(-2px)}
.choice.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:inset 0 0 0 1px rgba(59,110,248,.4)}

/* ---- legal / footer ---- */
.legal{padding:54px 0 80px}.legal h2{text-align:left;font-size:1.4rem;margin-top:34px}.legal p,.legal li{color:var(--muted)}
.footer{border-top:1px solid var(--border-soft);padding:42px 0;margin-top:48px}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer a{color:var(--muted);margin-left:22px}.footer a:hover{color:var(--text)}

/* ---- banner ---- */
.banner{background:var(--accent-soft);border:1px solid rgba(59,110,248,.35);border-radius:var(--radius-sm);padding:13px 16px;margin:16px auto;font-size:.92rem;color:var(--text)}

/* ---- responsive ---- */
@media(max-width:860px){
  .grid.cols-3,.grid.cols-4,.grid.cols-2{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .nav-inner{height:64px}
  .nav-link .lb{display:none}
  .nav-link{padding:9px 11px}
  .nav-link .ic{font-size:1.2rem}
  .coach-layout{grid-template-columns:1fr;height:auto}.chat-sidebar{max-height:210px}.chat-main{height:72vh}
  .choice-grid{grid-template-columns:1fr}.msg{max-width:90%}
  .container{padding:0 18px}
}


/* ---- layout: in-app nav centered (only #nav); marketing nav stays brand-left / links-right ---- */
#nav .nav-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:72px;gap:16px}
#nav .brand{justify-self:start}
#nav .nav-links{justify-self:center}
.page-head{text-align:center}
.page-head .lead-line{justify-content:center;display:block}
main.container{text-align:center}
main.container .card{text-align:center}
main.container .slider-head{text-align:left}
main.container .item-list li{text-align:left}
main.container .insight{text-align:left}
main.container .session-item{text-align:left}
main.container .chat-scroll{text-align:left}
.price-list{text-align:left}
input,textarea,select{text-align:left}
.icon-btn{font-size:.8rem;font-weight:600;color:var(--muted);padding:5px 12px;border:1px solid var(--border);border-radius:999px;background:transparent}
.icon-btn:hover{color:var(--danger);background:rgba(251,113,133,.1);border-color:rgba(251,113,133,.4);transform:none}
@media(max-width:860px){.nav-inner{display:flex;justify-content:space-between}}


.card.hoverable.tile:hover{border-color:var(--accent);box-shadow:0 20px 46px rgba(59,110,248,.32);background:linear-gradient(180deg,#16223f 0%,#1b2746 100%)}
.card.hoverable.tile:hover .arrow{color:var(--accent-2)}

/* ---- custom confirm modal ---- */
.modal-overlay{position:fixed;inset:0;background:rgba(5,8,18,.62);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:300;opacity:0;transition:opacity .2s ease;padding:20px}
.modal-overlay.show{opacity:1}
.modal{background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);border:1px solid var(--border);border-radius:var(--radius);padding:28px;max-width:400px;width:100%;box-shadow:var(--shadow);text-align:center;transform:translateY(12px) scale(.97);transition:transform .2s ease}
.modal-overlay.show .modal{transform:none}
.modal h3{margin:0 0 8px}
.modal p{color:var(--muted);margin:0 0 22px}
.modal-actions{display:flex;gap:10px;justify-content:center}
.modal-actions .btn{min-width:120px}
