:root{
  --teal:#0F4A54;
  --teal-deep:#0B3942;
  --gold:#1C8A9C;
  --cyan:#5CC2D4;
  --mist:#F4F3EE;
  --ink:#0F2A30;
  --muted:#6a818a;
  --white:#ffffff;
  --line:#e1e9ec;
  --ok:#1f9d6b;
  --ok-bg:#e6f5ee;
  --pend:#b8860b;
  --pend-bg:#fbf2d6;
  --danger:#c0492f;
  --shadow:0 14px 34px rgba(15,74,84,.16);
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;overscroll-behavior:none;}
body{
  font-family:'Montserrat',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--teal);
}
/* Live responsive web app: fill the screen on phones, no fake device frame. */
.phone{
  position:relative;width:100%;height:100%;
  background:var(--teal);border-radius:0;box-shadow:none;
  overflow:hidden;display:flex;flex-direction:column;
}
/* Fake "9:41" status bar hidden on the live app (real devices show their own). */
.statusbar{display:none;}
/* Desktop / wide screens: present as a centered app column, not full-bleed. */
@media (min-width:600px){
  body{
    background:linear-gradient(160deg,#efece4 0%,#e7e2d8 60%,#ddd7cb 100%);
    display:flex;align-items:center;justify-content:center;padding:24px;
  }
  .phone{
    width:min(420px,100%);height:min(880px,94vh);
    border-radius:34px;box-shadow:var(--shadow);
  }
}
.sb-right{display:flex;align-items:center;gap:6px;}
.sb-bars{display:flex;align-items:flex-end;gap:2px;height:11px;}
.sb-bars i{width:3px;background:#eafaff;border-radius:1px;}
.sb-bars i:nth-child(1){height:4px;}
.sb-bars i:nth-child(2){height:6px;}
.sb-bars i:nth-child(3){height:8px;}
.sb-bars i:nth-child(4){height:11px;}
.sb-batt{width:22px;height:11px;border:1.5px solid #eafaff;border-radius:3px;position:relative;}
.sb-batt::after{content:"";position:absolute;right:-3px;top:3px;width:2px;height:5px;background:#eafaff;border-radius:1px;}
.sb-batt i{position:absolute;left:1.5px;top:1.5px;bottom:1.5px;width:70%;background:#eafaff;border-radius:1px;}

.body{position:relative;flex:1;overflow:hidden;}
.screen{position:absolute;inset:0;display:none;flex-direction:column;}
.screen.active{display:flex;}

.appbar{
  flex-shrink:0;background:var(--teal);color:#fff;
  padding:20px 20px 18px;display:flex;align-items:center;justify-content:space-between;
  border-bottom-left-radius:22px;border-bottom-right-radius:22px;
}
.appbar h1{font-size:20px;font-weight:700;letter-spacing:.2px;}
.appbar .sub{font-size:12px;color:#bfe6ec;font-weight:500;margin-top:2px;}
.avatar{
  width:40px;height:40px;border-radius:50%;background:var(--cyan);color:var(--teal-deep);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;
  border:2px solid rgba(255,255,255,.5);
}
.appbar-right{display:flex;align-items:center;gap:12px;}
.appbar-logo{height:36px;width:auto;display:block;opacity:.95;position:relative;top:4px;}
.scroll{flex:1;overflow-y:auto;background:var(--mist);padding:18px 16px 26px;}
.scroll::-webkit-scrollbar{width:0;}

.card{background:var(--white);border-radius:20px;padding:18px;box-shadow:0 6px 18px rgba(15,74,84,.07);border:1px solid var(--line);}
.card + .card{margin-top:14px;}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--cyan);}
.muted{color:var(--muted);}
.section-title{font-size:13px;font-weight:700;color:var(--ink);margin:22px 4px 10px;letter-spacing:.2px;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:15px;padding:14px 16px;border-radius:14px;transition:transform .05s ease, filter .15s ease;}
.btn:active{transform:scale(.99);}
.btn[disabled]{opacity:.55;cursor:default;}
.btn-gold{background:var(--gold);color:#fff;}
.btn-gold:hover{filter:brightness(1.03);}
.btn-teal{background:var(--teal);color:#fff;}
.btn-outline{background:transparent;border:1.6px solid var(--teal);color:var(--teal);}
.btn-ghost{background:transparent;color:var(--danger);font-weight:600;}
.btn-sm{width:auto;padding:10px 16px;font-size:13px;border-radius:11px;}
.btn-row{display:flex;gap:10px;margin-top:14px;}

.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;padding:5px 10px;border-radius:999px;}
.pill-cyan{background:#e3f5f8;color:#0c7c8c;}
.pill-gold{background:var(--pend-bg);color:var(--pend);}
.pill-ok{background:var(--ok-bg);color:var(--ok);}

.hero{background:linear-gradient(150deg,var(--teal) 0%,var(--teal-deep) 100%);color:#fff;border-radius:22px;padding:20px;position:relative;overflow:hidden;}
.hero::after{content:"";position:absolute;right:-40px;top:-40px;width:150px;height:150px;background:radial-gradient(circle,rgba(92,194,212,.35),transparent 70%);}
.hero .eyebrow{color:var(--cyan);}
.hero .big{font-size:23px;font-weight:800;margin-top:8px;line-height:1.15;}
.hero .time{color:var(--cyan);}
.hero .meta{display:flex;align-items:center;gap:9px;margin-top:12px;font-size:13.5px;color:#dff1f4;}
.hero .meta svg{flex-shrink:0;opacity:.9;}
.hero .btn-outline{border-color:rgba(255,255,255,.6);color:#fff;}

.quick{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.qcard{background:#fff;border-radius:18px;padding:15px;border:1px solid var(--line);cursor:pointer;text-align:left;box-shadow:0 5px 14px rgba(15,74,84,.06);transition:transform .06s ease;}
.qcard:active{transform:scale(.98);}
.qicon{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--mist);margin-bottom:10px;}
.qcard h4{font-size:14px;font-weight:700;}
.qcard p{font-size:12px;color:var(--muted);margin-top:3px;font-weight:500;}

.progress{height:9px;border-radius:999px;background:#e4edef;overflow:hidden;}
.progress > span{display:block;height:100%;background:linear-gradient(90deg,var(--cyan),var(--teal));border-radius:999px;}
.pips{display:flex;align-items:center;gap:4px;margin-top:13px;}
.pip{flex:1;height:11px;border-radius:3px;background:#dbe6e9;}
.pip.on{background:var(--cyan);}
.pip-goal{margin-left:4px;flex-shrink:0;}
.ex-row{display:flex;gap:13px;align-items:flex-start;}
.ex-sep{border-top:1px solid var(--line);margin-top:14px;padding-top:14px;}
.ex-thumb{width:46px;height:46px;border-radius:13px;background:#e3f5f8;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ex-info{flex:1;}
.ex-info h4{font-size:14px;font-weight:700;}
.ex-sets{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:2px;}
.ex-instr{font-size:12.5px;color:var(--ink);line-height:1.5;margin-top:7px;font-weight:500;}
.ex-link{display:inline-block;margin-top:8px;font-size:12px;font-weight:700;color:var(--teal);}
.ex-soon{display:inline-block;margin-top:8px;font-size:11.5px;font-weight:600;color:#9fb0b5;}
.pc-card{padding:0;overflow:hidden;}
.pc-head{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:none;font-family:inherit;cursor:pointer;padding:16px 18px;text-align:left;}
.pc-head h4{font-size:14.5px;font-weight:700;color:var(--ink);}
.pc-chev{color:var(--cyan);font-size:13px;font-weight:800;}
.pc-body{padding:0 18px 16px;}
.streak-card{background:linear-gradient(135deg,#0f545f,#1c8a9c);border:none;border-radius:18px;padding:16px 18px;box-shadow:0 10px 24px rgba(15,85,96,.22);margin:6px 0 16px;}
.streak-main{display:flex;align-items:center;gap:14px;}
.streak-flame{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;flex:none;}
.streak-n{font-size:17px;font-weight:800;color:#fff;letter-spacing:.2px;}
.streak-sub{font-size:12.5px;color:rgba(255,255,255,.82);font-weight:600;margin-top:3px;}
.reward-card{background:linear-gradient(150deg,#e3f5f8,#d2eef3);border:1px solid #bfe6ec;border-radius:18px;padding:18px;margin-bottom:14px;}
.reward-card h3{font-size:23px;font-weight:800;color:var(--teal);margin-top:4px;}
.reward-card p{font-size:13px;color:#0c6473;font-weight:500;margin-top:6px;line-height:1.5;}
.badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(84px,1fr));gap:18px 6px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px 14px;box-shadow:0 6px 18px rgba(15,74,84,.07);}
.badge{display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;}
.medal{width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;}
.medal svg{width:26px;height:26px;position:relative;z-index:2;}
.badge.earned .medal{background:radial-gradient(circle at 36% 30%,#fff7d6,#f6cb55 46%,#d29a2c 82%);box-shadow:0 6px 15px rgba(190,130,22,.38),inset 0 -3px 6px rgba(150,95,12,.45),inset 0 2px 4px rgba(255,255,255,.65);}
.badge.earned .medal svg{color:#7a4d05;}
.badge.earned .medal::after{content:"";position:absolute;inset:6px;border-radius:50%;border:2px solid rgba(255,255,255,.5);z-index:1;}
.badge.earned .shine{position:absolute;top:9px;left:13px;width:15px;height:8px;background:rgba(255,255,255,.62);border-radius:50%;transform:rotate(-32deg);filter:blur(1px);z-index:2;}
.badge.locked .medal{background:radial-gradient(circle at 36% 30%,#f0f3f3,#c7cfcf 72%);box-shadow:0 3px 8px rgba(120,130,130,.18),inset 0 -3px 6px rgba(120,130,130,.28);}
.badge.locked .medal svg{color:#a4afaf;}
.badge.locked .medal::after{content:"";position:absolute;inset:6px;border-radius:50%;border:2px solid rgba(255,255,255,.35);}
.badge span{font-size:11px;font-weight:700;color:#7d8a8a;line-height:1.25;max-width:80px;}
.badge.earned span{color:var(--ink);}
.tick{margin-top:10px;display:inline-flex;align-items:center;gap:6px;background:transparent;border:1.5px solid var(--cyan);color:var(--teal);font-family:inherit;font-weight:700;font-size:12.5px;padding:8px 14px;border-radius:11px;cursor:pointer;}
.tick.done{background:var(--ok-bg);border-color:#bfe6d3;color:var(--ok);}
.ptoast{position:absolute;left:50%;bottom:84px;transform:translateX(-50%) translateY(8px);background:var(--ink);color:#fff;font-weight:700;font-size:13px;padding:11px 18px;border-radius:13px;box-shadow:0 8px 22px rgba(15,42,48,.3);opacity:0;transition:opacity .2s,transform .2s;z-index:50;pointer-events:none;white-space:nowrap;}
.ptoast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.mind-soon-cover{background:linear-gradient(150deg,#0f545f,#1c8a9c);color:#fff;border-radius:18px;padding:26px 22px;text-align:center;margin-top:14px;box-shadow:0 10px 24px rgba(15,85,96,.2);}
.mind-soon-cover .mind-soon-badge{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;background:rgba(255,255,255,.18);color:#fff;padding:6px 13px;border-radius:999px;position:static;}
.mind-soon-cover h3{font-size:20px;font-weight:800;margin-top:13px;color:#fff;}
.mind-soon-cover p{font-size:13.5px;font-weight:500;color:rgba(255,255,255,.85);margin-top:9px;line-height:1.55;}
.mind-row{display:flex;gap:11px;align-items:center;}
.mind-info{flex:1;}
.mind-info h4{font-size:14px;font-weight:700;}
.mind-info p{font-size:12px;color:var(--muted);font-weight:600;margin-top:2px;}
.mind-audio{width:100%;margin-top:11px;height:40px;}
.mind-soon{margin-top:10px;font-size:11.5px;font-weight:600;color:#9fb0b5;}
.mind-soon-pill{font-size:10px;font-weight:700;color:var(--pend);background:var(--pend-bg);border-radius:999px;padding:4px 9px;white-space:nowrap;flex-shrink:0;letter-spacing:.3px;text-transform:uppercase;}
.mind-textbody{font-size:13px;color:var(--ink);line-height:1.6;margin-top:10px;font-weight:500;}

.seg{display:flex;background:#e7eef0;border-radius:13px;padding:4px;gap:4px;}
.seg button{flex:1;border:none;background:transparent;font-family:inherit;font-weight:700;font-size:13px;color:var(--muted);padding:9px;border-radius:10px;cursor:pointer;}
.seg button.on{background:#fff;color:var(--teal);box-shadow:0 2px 6px rgba(15,74,84,.12);}

.appt{display:flex;gap:13px;align-items:flex-start;}
.appt + .appt{margin-top:16px;padding-top:16px;border-top:1px solid var(--line);}
.datechip{flex-shrink:0;width:50px;text-align:center;background:var(--mist);border-radius:13px;padding:8px 0;border:1px solid var(--line);}
.datechip .d{font-size:19px;font-weight:800;color:var(--teal);line-height:1;}
.datechip .m{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--muted);margin-top:3px;letter-spacing:.5px;}
.appt .info h4{font-size:14.5px;font-weight:700;}
.appt .info p{font-size:12.5px;color:var(--muted);margin-top:3px;font-weight:500;}

.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.cal-head .nav{width:32px;height:32px;border-radius:10px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--teal);font-weight:700;}
.cal-head h3{font-size:15px;font-weight:700;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.cal-grid .dow{font-size:10.5px;font-weight:700;color:var(--muted);text-align:center;padding-bottom:4px;text-transform:uppercase;}
.day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:12px;font-size:13.5px;font-weight:600;color:var(--ink);position:relative;background:#fff;border:1px solid var(--line);cursor:default;}
.day.empty{background:transparent;border:none;}
.day.past,.day.closed{color:#c2cfd2;background:#f6f9fa;border-color:#eef3f4;}
.day.avail{cursor:pointer;}
.day.avail .dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);position:absolute;bottom:7px;}
.day.today{border:1.6px solid var(--cyan);color:var(--teal);font-weight:800;}
.day.booked{background:#e3f2f4;border-color:var(--gold);color:#0c6473;font-weight:800;}
.day.booked .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);position:absolute;bottom:7px;}
.day.sel{background:var(--teal);color:#fff;border-color:var(--teal);}
.day.sel .dot{background:#fff;}
.legend{display:flex;gap:16px;margin-top:14px;font-size:11.5px;color:var(--muted);font-weight:500;flex-wrap:wrap;}
.legend span{display:flex;align-items:center;gap:6px;}
.legend .k{width:9px;height:9px;border-radius:50%;}

.slots{margin-top:16px;display:none;}
.slots.show{display:block;}
.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:10px;}
.slot{border:1.4px solid var(--line);background:#fff;border-radius:11px;padding:11px 4px;text-align:center;font-size:12.5px;font-weight:700;color:var(--teal);cursor:pointer;}
.slot:active{background:var(--mist);}
.slot.sel{background:var(--teal);color:#fff;border-color:var(--teal);}

.banner{display:none;margin-top:16px;background:var(--ok-bg);border:1px solid #bfe6d3;color:#0f6b48;border-radius:14px;padding:13px 14px;font-size:13px;font-weight:600;align-items:flex-start;gap:9px;}
.banner.show{display:flex;}
.banner.err{background:#fdecea;border-color:#f3c5bd;color:#9a3520;}

.phase{margin-top:18px;}
.phase-head{display:flex;align-items:center;justify-content:space-between;margin:0 4px 10px;}
.phase-head h3{font-size:14px;font-weight:700;}
.lock-note{font-size:12.5px;color:var(--muted);font-weight:500;line-height:1.5;}

.balance{background:linear-gradient(150deg,var(--teal),var(--teal-deep));color:#fff;border-radius:22px;padding:22px;text-align:center;position:relative;overflow:hidden;}
.balance::after{content:"";position:absolute;left:-30px;bottom:-50px;width:160px;height:160px;background:radial-gradient(circle,rgba(234,200,30,.25),transparent 70%);}
.balance .eyebrow{color:var(--cyan);}
.balance .amount{font-size:38px;font-weight:800;margin:8px 0 2px;}
.balance .due{font-size:12.5px;color:#cfe9ee;font-weight:600;}
.invoice{display:flex;align-items:center;gap:12px;}
.invoice + .invoice{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);}
.invoice .ic{width:40px;height:40px;border-radius:11px;background:var(--mist);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.invoice .info{flex:1;}
.invoice .info h4{font-size:13.5px;font-weight:700;}
.invoice .info p{font-size:11.5px;color:var(--muted);margin-top:2px;font-weight:500;}
.invoice .amt{text-align:right;}
.invoice .amt .v{font-size:14px;font-weight:800;}
.note{background:#eef6f8;border:1px dashed var(--cyan);border-radius:14px;padding:14px;font-size:12.5px;color:#0c6473;line-height:1.5;font-weight:500;}
.note b{color:var(--teal);}

.login{flex:1;display:flex;flex-direction:column;justify-content:center;padding:30px 26px;overflow-y:auto;background:#FAF8F3;}
.logo-img{width:280px;}
.brand{text-align:center;margin-bottom:26px;}
.brand .logo{font-size:34px;font-weight:800;color:#fff;letter-spacing:.5px;}
.brand .logo span{color:var(--gold);}
.brand .tag{color:#cfeaef;font-size:13px;font-weight:500;margin-top:4px;letter-spacing:.4px;}
.logo-img{display:block;width:300px;max-width:92%;height:auto;margin:0 auto;}
.login .card h2{font-size:19px;font-weight:800;}
.login .card .lead{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.5;font-weight:500;}
.field{margin-top:16px;}
.field label{font-size:12px;font-weight:700;color:var(--ink);}
.field input{width:100%;margin-top:7px;border:1.5px solid var(--line);border-radius:13px;padding:14px;font-family:inherit;font-size:15px;color:var(--ink);background:#fdfefe;}
.field input:focus{outline:none;border-color:var(--cyan);}
.helper{font-size:12px;color:var(--muted);margin-top:10px;line-height:1.5;font-weight:500;display:flex;gap:7px;align-items:flex-start;}
.code-row{display:flex;gap:9px;justify-content:space-between;margin-top:7px;}
.code-row input{width:100%;text-align:center;font-size:22px;font-weight:800;padding:13px 0;border:1.5px solid var(--line);border-radius:13px;background:#fdfefe;font-family:inherit;}
.code-row input:focus{outline:none;border-color:var(--cyan);}
.linkbtn{background:none;border:none;color:var(--cyan);font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;margin-top:16px;width:100%;}
.tie{font-size:11px;color:#8a948f;text-align:center;margin-top:18px;font-weight:500;line-height:1.5;}
.formerr{color:#ffd9cf;font-size:12.5px;font-weight:600;margin-top:12px;min-height:16px;}

.tabbar{flex-shrink:0;display:none;background:#fff;border-top:1px solid var(--line);padding:8px 6px 14px;justify-content:space-around;}
.tabbar.show{display:flex;}
.tab{background:none;border:none;font-family:inherit;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);flex:1;padding:4px 0;font-size:10.5px;font-weight:700;}
.tab svg{stroke:var(--muted);}
.tab.on{color:var(--teal);}
.tab.on svg{stroke:var(--teal);}

.dev-banner{display:none;font-size:12px;color:#5a7882;font-weight:600;text-align:center;max-width:404px;line-height:1.5;}
.dev-banner b{color:var(--teal);}
.loading{padding:30px 10px;text-align:center;color:var(--muted);font-size:13px;font-weight:600;}
.quote-card{cursor:pointer;background:#E4F4F7;border:1px solid #cfe9ee;border-radius:16px;padding:16px;margin-bottom:14px;}
.quote-q{font-family:'Fredoka','Montserrat',sans-serif;font-size:20px;font-weight:600;color:#0b3940;line-height:1.3;letter-spacing:-.01em;}
.quote-foot{display:flex;align-items:center;gap:7px;margin-top:12px;font-size:11px;font-weight:700;color:var(--teal);}
.quote-foot svg{flex-shrink:0;}
.quote-arrow{margin-left:auto;font-size:13px;}
.mind-hero{background:linear-gradient(150deg,var(--teal),var(--teal-deep));color:#fff;border-radius:22px;padding:22px;}
.mind-hero .eyebrow{color:var(--cyan);opacity:1;}
.mind-hero h3{font-size:20px;font-weight:800;margin-top:6px;color:#fff;}
.mind-hero p{font-size:13px;line-height:1.55;margin-top:10px;font-weight:500;color:#dff1f4;}
.mind-featured{cursor:pointer;}
.mind-play{width:46px;height:46px;border-radius:50%;background:var(--teal);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.mind-item{display:flex;align-items:center;gap:13px;cursor:pointer;}
.mind-item + .mind-item{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);}
.mind-thumb{width:46px;height:46px;border-radius:13px;background:#e3f5f8;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.mind-item .info{flex:1;}
.mind-item .info h4{font-size:14px;font-weight:700;}
.mind-item .info p{font-size:12px;color:var(--muted);font-weight:600;margin-top:2px;}
.mind-chev{color:#c2cfd2;flex-shrink:0;}
