/* ============ JOAT · COSMIC PURPLE/BLUE THEME ============ */
:root{
  --bg:#06060f;--bg2:#0b0a1f;--surface:rgba(255,255,255,0.045);--surface-2:rgba(255,255,255,0.07);
  --border:rgba(255,255,255,0.10);--border-glow:rgba(139,124,255,0.35);
  --txt:#eef0ff;--txt-dim:#a6a8c8;--txt-faint:#6f7196;
  --violet:#8b5cff;--violet2:#b388ff;--cyan:#34e0ff;--pink:#ff5fa2;--green:#3ddc97;--amber:#ffb547;
  --grad:linear-gradient(135deg,#8b5cff 0%,#34e0ff 100%);
  --grad-soft:linear-gradient(135deg,rgba(139,92,255,.18),rgba(52,224,255,.12));
  --radius:18px;--shadow:0 20px 60px -20px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--txt);line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased;min-height:100vh}
.bg-aura{position:fixed;inset:0;z-index:-2;background:radial-gradient(60% 50% at 15% 10%,rgba(139,92,255,.25),transparent 60%),radial-gradient(50% 45% at 85% 15%,rgba(52,224,255,.18),transparent 60%),radial-gradient(60% 60% at 50% 100%,rgba(255,95,162,.12),transparent 60%),linear-gradient(180deg,#06060f,#0b0a1f)}
.bg-grid{position:fixed;inset:0;z-index:-1;opacity:.4;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:54px 54px;-webkit-mask-image:radial-gradient(circle at 50% 0%,#000,transparent 80%);mask-image:radial-gradient(circle at 50% 0%,#000,transparent 80%)}
::selection{background:var(--violet);color:#fff}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}

.glass{background:var(--surface);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border:1px solid var(--border);border-radius:var(--radius)}
.card{background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:.35s cubic-bezier(.2,.8,.2,1)}
.card:hover{transform:translateY(-4px);border-color:var(--border-glow);box-shadow:0 20px 50px -25px rgba(139,92,255,.6)}
.gradient-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;letter-spacing:.3px;padding:6px 12px;border-radius:999px;background:var(--grad-soft);border:1px solid var(--border);color:var(--violet2)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:15px;padding:13px 24px;border-radius:14px;transition:.25s;white-space:nowrap}
.btn-primary{background:var(--grad);color:#0a0820;box-shadow:0 10px 30px -8px rgba(139,92,255,.6);font-weight:700}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px -8px rgba(52,224,255,.6)}
.btn-ghost{background:var(--surface-2);border:1px solid var(--border);color:var(--txt)}
.btn-ghost:hover{border-color:var(--border-glow);background:var(--surface)}
.btn-sm{padding:9px 16px;font-size:13px;border-radius:11px}

.wrap{max-width:1240px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--cyan);margin-bottom:14px}
h1,h2,h3,h4{line-height:1.12;letter-spacing:-.02em;font-weight:800}
.h-sec{font-size:clamp(30px,4.5vw,46px);margin-bottom:14px}
.sub{color:var(--txt-dim);font-size:18px;max-width:620px}
.center{text-align:center;margin-left:auto;margin-right:auto}

nav{position:sticky;top:0;z-index:100;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:rgba(6,6,15,.6);border-bottom:1px solid var(--border)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;align-items:center;gap:11px;font-weight:800;font-size:20px;letter-spacing:-.5px;cursor:pointer}
.logo .mark{width:36px;height:36px;border-radius:11px;background:var(--grad);display:grid;place-items:center;font-size:15px;font-weight:900;color:#0a0820;box-shadow:0 6px 18px -4px rgba(139,92,255,.7)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:14.5px;color:var(--txt-dim);font-weight:500;transition:.2s}
.nav-links a:hover{color:var(--txt)}
.nav-cta{display:flex;align-items:center;gap:12px}
@media(max-width:880px){.nav-links{display:none}}

.hero{position:relative;padding:90px 0 70px;text-align:center}
.hero h1{font-size:clamp(38px,7vw,76px);margin:18px auto 22px;font-weight:900}
.hero .sub{font-size:clamp(17px,2.2vw,22px);margin:0 auto 34px}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;gap:46px;justify-content:center;margin-top:64px;flex-wrap:wrap}
.hero-stats .n{font-size:36px;font-weight:900}
.hero-stats .l{color:var(--txt-faint);font-size:14px}
.float{animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.grid{display:grid;gap:22px}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g-3,.g-4,.g-2{grid-template-columns:1fr}.hero-stats{gap:28px}}
.ic{width:52px;height:52px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--border);display:grid;place-items:center;font-size:24px;margin-bottom:16px}
.step-num{font-size:13px;font-weight:800;color:var(--cyan);letter-spacing:1px}

.chips{display:flex;flex-wrap:wrap;gap:12px}
.chip{padding:11px 18px;border-radius:13px;background:var(--surface);border:1px solid var(--border);font-weight:600;font-size:14.5px;transition:.25s;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.chip:hover{border-color:var(--border-glow);background:var(--surface-2);transform:translateY(-2px)}
.chip.active{background:var(--grad);color:#0a0820;border-color:transparent}

.vendor-card{overflow:hidden;padding:0;cursor:pointer;display:block}
.vendor-card .cover{height:150px;background-size:cover;background-position:center;position:relative}
.vendor-card .cover .cat{position:absolute;top:12px;left:12px}
.vendor-card .body{padding:18px}
.vendor-card .name{font-weight:700;font-size:17px;display:flex;align-items:center;gap:6px}
.rating{display:inline-flex;align-items:center;gap:5px;font-size:13.5px;color:var(--amber);font-weight:700}
.rating .rev{color:var(--txt-faint);font-weight:500}
.price-tag{font-weight:800;font-size:15px}

.quote{font-size:16px;color:var(--txt);line-height:1.65}
.author{display:flex;align-items:center;gap:12px;margin-top:18px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-weight:800;color:#0a0820}

.price-card.featured{border-color:var(--border-glow);box-shadow:0 0 0 1px var(--border-glow),0 30px 70px -30px rgba(139,92,255,.7);position:relative}
.price-card .amt{font-size:42px;font-weight:900;margin:8px 0}
.price-card ul{list-style:none;margin:20px 0;display:flex;flex-direction:column;gap:11px}
.price-card li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--txt-dim)}
.price-card li .ck{color:var(--green);font-weight:800}

footer{border-top:1px solid var(--border);padding:54px 0 36px;margin-top:60px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-grid h5{font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--txt-faint);margin-bottom:14px}
.foot-grid a{display:block;color:var(--txt-dim);font-size:14px;margin-bottom:9px}
.foot-grid a:hover{color:var(--txt)}
.divider{height:1px;background:var(--border);margin:24px 0}

/* dashboard shell */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:248px;flex-shrink:0;border-right:1px solid var(--border);padding:22px 16px;position:sticky;top:0;height:100vh;overflow-y:auto;background:rgba(11,10,31,.4)}
.side-link{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;color:var(--txt-dim);font-size:14.5px;font-weight:500;margin-bottom:4px;cursor:pointer;transition:.2s}
.side-link:hover{background:var(--surface);color:var(--txt)}
.side-link.active{background:var(--grad-soft);color:var(--txt);border:1px solid var(--border);font-weight:600}
.side-link .i{width:22px;text-align:center}
.side-sec{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--txt-faint);margin:18px 14px 8px}
.main{flex:1;padding:30px 36px;max-width:100%;overflow-x:hidden}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:14px}
.topbar h2{font-size:26px}
.search{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 15px;min-width:200px;color:var(--txt-faint)}
.search input{background:none;border:none;outline:none;color:var(--txt);width:100%;font-size:14px}
@media(max-width:820px){.sidebar{display:none}.main{padding:22px 18px}}

.stat{padding:20px}
.stat .label{color:var(--txt-faint);font-size:13px;font-weight:600}
.stat .val{font-size:30px;font-weight:900;margin:7px 0 4px}
.stat .delta{font-size:13px;font-weight:700}
.up{color:var(--green)}.down{color:var(--pink)}

.bar{height:9px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.bar>i{display:block;height:100%;background:var(--grad);border-radius:999px;transition:width 1s cubic-bezier(.2,.8,.2,1)}
.ring{width:120px;height:120px;border-radius:50%;display:grid;place-items:center}
.ring .inner{width:92px;height:92px;border-radius:50%;background:var(--bg2);display:grid;place-items:center;text-align:center}
.ring .inner .pc{font-size:26px;font-weight:900}

.check-row{display:flex;align-items:center;gap:14px;padding:15px 18px;border-radius:14px;background:var(--surface);border:1px solid var(--border);margin-bottom:10px;transition:.2s;flex-wrap:wrap}
.check-row:hover{border-color:var(--border-glow)}
.cbox{width:23px;height:23px;border-radius:7px;border:2px solid var(--txt-faint);flex-shrink:0;cursor:pointer;display:grid;place-items:center;font-size:13px;transition:.2s}
.cbox.done{background:var(--green);border-color:var(--green);color:#06060f}
.check-row.done .ctitle{text-decoration:line-through;color:var(--txt-faint)}
.ctitle{font-weight:600;flex:1;min-width:140px}
.badge{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--txt-dim);display:inline-block}
.badge.green{color:var(--green);border-color:rgba(61,220,151,.3);background:rgba(61,220,151,.08)}
.badge.amber{color:var(--amber);border-color:rgba(255,181,71,.3);background:rgba(255,181,71,.08)}
.badge.cyan{color:var(--cyan);border-color:rgba(52,224,255,.3);background:rgba(52,224,255,.08)}
.badge.pink{color:var(--pink);border-color:rgba(255,95,162,.3);background:rgba(255,95,162,.08)}

.field{margin-bottom:18px}
.field label{display:block;font-size:13.5px;font-weight:600;margin-bottom:7px;color:var(--txt-dim)}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border-radius:12px;background:var(--surface);border:1px solid var(--border);color:var(--txt);font-size:15px;outline:none;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--violet);background:var(--surface-2)}
.field select option{background:#0b0a1f}
.req-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:640px){.req-grid{grid-template-columns:repeat(2,1fr)}}
.req-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;background:var(--surface);border:1px solid var(--border);cursor:pointer;font-size:14px;font-weight:500;transition:.2s}
.req-item:hover{border-color:var(--border-glow)}
.req-item.on{background:var(--grad-soft);border-color:var(--border-glow)}
.req-item .tick{width:19px;height:19px;border-radius:6px;border:2px solid var(--txt-faint);display:grid;place-items:center;font-size:11px}
.req-item.on .tick{background:var(--violet);border-color:var(--violet);color:#fff}
.req-item input[type=checkbox]{display:none}

.budget-row{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.budget-row .bl{width:130px;font-weight:600;font-size:14px;flex-shrink:0}
.budget-row .bb{flex:1;height:14px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.budget-row .bb>i{display:block;height:100%;border-radius:999px}
.budget-row .bv{width:90px;text-align:right;font-weight:700;font-size:14px;flex-shrink:0}

.tl{position:relative;padding-left:34px}
.tl::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--violet),var(--cyan))}
.tl-item{position:relative;margin-bottom:24px}
.tl-item::before{content:"";position:absolute;left:-30px;top:5px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:3px solid var(--violet)}
.tl-item.done::before{background:var(--green);border-color:var(--green)}
.tl-when{font-size:12.5px;font-weight:800;color:var(--cyan);letter-spacing:.5px}

.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:12px;letter-spacing:.6px;text-transform:uppercase;color:var(--txt-faint);padding:12px 14px;border-bottom:1px solid var(--border);font-weight:700}
.tbl td{padding:14px;border-bottom:1px solid var(--border);font-size:14px}
.tbl tr:hover td{background:var(--surface)}

.portal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:760px){.portal-grid{grid-template-columns:1fr}}
.portal-opt{padding:30px 24px;text-align:center;cursor:pointer}
.portal-opt .ic{margin:0 auto 18px;width:64px;height:64px;font-size:30px}

.tag-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.flex{display:flex}.between{justify-content:space-between}.center-v{align-items:center}.gap{gap:14px}.wrap-f{flex-wrap:wrap}
.mt{margin-top:18px}.mb{margin-bottom:18px}
.fade-in{animation:fadeIn .5s ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.alert{padding:13px 18px;border-radius:12px;margin-bottom:18px;font-size:14.5px;border:1px solid var(--border)}
.alert.error{background:rgba(255,95,162,.1);border-color:rgba(255,95,162,.35);color:#ffc4dc}
.alert.ok{background:rgba(61,220,151,.1);border-color:rgba(61,220,151,.35);color:#bff7df}

.stepper{display:flex;gap:8px;margin-bottom:30px;flex-wrap:wrap}
.stepper .st{flex:1;min-width:120px}
.stepper .st .dot{height:5px;border-radius:999px;background:var(--surface-2);margin-bottom:9px}
.stepper .st.on .dot{background:var(--grad)}
.stepper .st .t{font-size:13px;font-weight:600;color:var(--txt-faint)}
.stepper .st.on .t{color:var(--txt)}
