:root{
  --violet:#6C5CE7;--violet-d:#5B3BE0;--deep:#1B1340;--ink:#1A1726;--bg:#F7F6FC;
  --muted:#6E6A86;--soft:#8A85A6;--line:#ECEAF5;--lav:#EFEDFB;--amber:#FFB020;
  --radius:18px;--shadow:0 14px 40px rgba(26,23,38,.08);
  font-family:'Manrope','Segoe UI',system-ui,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1140px;margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;gap:8px;height:50px;padding:0 22px;border-radius:14px;
  font-weight:700;font-size:15px;cursor:pointer;border:none;transition:.15s}
.btn.primary{background:var(--violet);color:#fff}
.btn.primary:hover{background:var(--violet-d);transform:translateY(-1px)}
.btn.ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn.ghost:hover{border-color:var(--violet);color:var(--violet)}
.btn.light{background:rgba(255,255,255,.14);color:#fff}
.btn.light:hover{background:rgba(255,255,255,.22)}

/* NAV */
.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.nav .inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav .logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px}
.nav .logo .m{width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,#5B3BE0,#8A6CFF);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}
.nav .links{display:flex;align-items:center;gap:6px}
.nav .links a{padding:9px 13px;border-radius:10px;font-weight:600;font-size:14px;color:var(--ink)}
.nav .links a:hover,.nav .links a.active{background:var(--lav);color:var(--violet)}
.nav .cta{display:flex;align-items:center;gap:10px}
.burger{display:none;font-size:26px;background:none;border:none;cursor:pointer;color:var(--ink)}
@media(max-width:900px){
  .nav .links{display:none;position:absolute;top:68px;left:0;right:0;background:#fff;flex-direction:column;
    padding:10px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav .links.open{display:flex}
  .nav .links a{width:100%}
  .nav .cta .btn:not(.primary){display:none}
  .burger{display:block}
}

/* HERO */
.hero{background:linear-gradient(150deg,#1B1340 0%,#5B3BE0 58%,#8A6CFF 100%);color:#fff;
  border-radius:0 0 34px 34px;overflow:hidden;position:relative}
.hero .inner{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;padding:54px 0 60px}
.hero h1{font-size:44px;line-height:1.1;font-weight:800;margin:0 0 14px}
.hero p{font-size:17px;color:rgba(255,255,255,.85);margin:0 0 26px;max-width:520px}
.hero .badges{display:flex;gap:12px;flex-wrap:wrap}
.store{display:flex;align-items:center;gap:10px;background:#fff;color:var(--ink);height:54px;padding:0 18px;
  border-radius:14px;font-weight:700}
.store .em{font-size:22px}
.store small{display:block;font-size:11px;color:var(--muted);font-weight:600}
.hero .art{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);border-radius:24px;
  padding:22px;min-height:280px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.hero .art .row{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.92);color:var(--ink);
  border-radius:14px;padding:12px}
.hero .art .row .ic{width:44px;height:44px;border-radius:12px;background:var(--lav);display:flex;
  align-items:center;justify-content:center;font-size:22px}
@media(max-width:900px){.hero .inner{grid-template-columns:1fr;padding:36px 0 40px}.hero h1{font-size:32px}.hero .art{display:none}}

/* SECTIONS */
.sec{padding:56px 0}
.sec h2{font-size:30px;font-weight:800;margin:0 0 6px;text-align:center}
.sec .lead{color:var(--muted);text-align:center;margin:0 auto 34px;max-width:560px}
.grid{display:grid;gap:16px}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.cat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:18px;text-align:center;transition:.15s;cursor:pointer}
.cat:hover{transform:translateY(-4px)}
.cat .ic{width:62px;height:62px;border-radius:18px;background:var(--lav);margin:0 auto 12px;
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.cat .ic img{width:34px;height:34px;object-fit:contain}
.cat b{font-size:14px}
.cat span{display:block;color:var(--soft);font-size:12px;margin-top:3px}

.step{text-align:center;padding:10px}
.step .n{width:54px;height:54px;border-radius:50%;background:var(--violet);color:#fff;font-weight:800;font-size:20px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.step b{display:block;margin-bottom:4px}
.step p{color:var(--muted);font-size:14px;margin:0}

.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;display:flex;gap:12px}
.pcard .pimg{width:58px;height:58px;border-radius:15px;background:var(--lav);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;color:var(--violet);font-weight:800;font-size:22px;overflow:hidden}
.pcard .pimg img{width:100%;height:100%;object-fit:cover}
.pcard b{font-size:15px}
.pcard .s{color:var(--muted);font-size:13px;margin-top:2px}
.pcard .r{color:var(--soft);font-size:12px;margin-top:6px}
.pcard .r .st{color:var(--amber)}

/* CTA band */
.band{background:linear-gradient(150deg,#1B1340,#5B3BE0);color:#fff;border-radius:26px;padding:40px;text-align:center}
.band h2{color:#fff;margin:0 0 8px;font-size:28px;font-weight:800}
.band p{color:rgba(255,255,255,.85);margin:0 0 22px}

/* page header (inner pages) */
.phead{background:linear-gradient(150deg,#1B1340,#5B3BE0,#8A6CFF);color:#fff;padding:44px 0;border-radius:0 0 30px 30px}
.phead h1{font-size:34px;font-weight:800;margin:0 0 6px}
.phead p{color:rgba(255,255,255,.85);margin:0}

/* faq */
.faq-i{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:12px;overflow:hidden}
.faq-i summary{padding:16px 18px;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between}
.faq-i summary::-webkit-details-marker{display:none}
.faq-i[open] summary{color:var(--violet)}
.faq-i p{padding:0 18px 16px;margin:0;color:var(--muted)}

/* contact form */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:700px){.frow{grid-template-columns:1fr}}
.inp{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;font-size:14px;background:#fff;outline:none}
.inp:focus{border-color:var(--violet);box-shadow:0 0 0 4px rgba(108,92,231,.12)}
textarea.inp{min-height:130px;resize:vertical}

/* footer */
.footer{background:var(--ink);color:#cfc9ec;margin-top:60px;padding:46px 0 26px}
.footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:26px}
@media(max-width:800px){.footer .cols{grid-template-columns:1fr}}
.footer h4{color:#fff;font-size:15px;margin:0 0 12px}
.footer a{display:block;color:#cfc9ec;padding:4px 0;font-size:14px}
.footer a:hover{color:#fff}
.footer .bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:28px;padding-top:18px;
  display:flex;justify-content:space-between;color:#9a93c4;font-size:13px;flex-wrap:wrap;gap:10px}
.muted{color:var(--muted)}.center{text-align:center}.loading{padding:30px;text-align:center;color:var(--muted)}

/* auth pages */
.authwrap{max-width:460px;margin:0 auto}
.authwrap .card{padding:26px}
.authwrap label{display:block;font-size:13px;font-weight:700;margin:0 0 6px;color:var(--ink)}
.authwrap .fld{margin-bottom:14px}
.msg{font-size:13px;margin-top:12px;padding:10px 12px;border-radius:12px;display:none}
.msg.error{display:block;background:#FCEBEB;color:#A32D2D}
.msg.ok{display:block;background:#E1F5EE;color:#0F6E56}
.auth-alt{text-align:center;margin-top:16px;color:var(--muted);font-size:14px}

/* booking page */
.bookwrap{max-width:620px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.bookwrap label.svc{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:12px;margin-bottom:10px;cursor:pointer;transition:.15s}
.bookwrap label.svc:hover{border-color:var(--violet)}
.bookwrap label.svc input{width:18px;height:18px;accent-color:var(--violet)}
.svc-t{flex:1;min-width:0}.svc-t b{display:block;font-size:14px}.svc-t small{color:var(--soft);font-size:12px}
.svc-p{font-weight:800;color:var(--violet);font-size:15px}
.bk-total{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--lav);
  border-radius:12px;margin:8px 0 18px;font-weight:600}
.bk-total b{font-size:20px;color:var(--violet)}
.bookwrap .fld{margin-bottom:14px}
.bookwrap label{display:block;font-size:13px;font-weight:700;margin:0 0 6px}
.bk-note{background:#FFF8EC;border:1px solid #FFE2B0;color:#7A5B12;border-radius:12px;padding:11px 14px;
  font-size:13px;margin:0 0 16px}
.pay-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
@media(max-width:560px){.pay-opts{grid-template-columns:1fr}}
.pay-opt{display:flex;align-items:center;gap:10px;border:1.5px solid var(--line);border-radius:12px;
  padding:12px;cursor:pointer;transition:.15s}
.pay-opt:hover{border-color:var(--violet)}
.pay-opt input{width:18px;height:18px;accent-color:var(--violet)}
.pay-opt b{display:block;font-size:14px}.pay-opt small{color:var(--soft);font-size:12px}
#cardWrap{margin-bottom:14px}

/* provider profile */
.pp-hero{background:linear-gradient(150deg,#1B1340,#5B3BE0,#8A6CFF);color:#fff;padding:40px 0;border-radius:0 0 30px 30px}
.pp-hero-in{display:flex;gap:24px;align-items:center}
.pp-ava{width:112px;height:112px;border-radius:28px;background:rgba(255,255,255,.16);flex:0 0 auto;overflow:hidden;
  display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:800;color:#fff;border:2px solid rgba(255,255,255,.3)}
.pp-ava img{width:100%;height:100%;object-fit:cover}
.pp-meta h1{margin:0 0 4px;font-size:30px;font-weight:800}
.pp-title{color:rgba(255,255,255,.85);font-size:16px;margin-bottom:8px}
.pp-rate{display:flex;align-items:center;gap:6px;font-size:15px}.pp-rate b{font-size:16px}.pp-rate span{color:rgba(255,255,255,.8)}
.pp-cta{display:flex;gap:10px;margin-top:16px}
@media(max-width:700px){.pp-hero-in{flex-direction:column;text-align:center}.pp-cta{justify-content:center;flex-wrap:wrap}.pp-rate{justify-content:center}}
.pp-grid{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}
@media(max-width:900px){.pp-grid{grid-template-columns:1fr}}
.pp-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:18px}
.pp-card h3{margin:0 0 14px;font-size:18px;font-weight:800}
.pp-svc{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line)}
.pp-svc:last-child{border-bottom:none}
.pp-svc b{font-size:15px}.pp-svc span{display:block;color:var(--soft);font-size:12px;margin-top:2px}
.pp-svc p{margin:5px 0 0;color:var(--muted);font-size:13px}
.pp-price{font-weight:800;color:var(--violet);font-size:17px;white-space:nowrap}.pp-price small{color:var(--soft);font-weight:600;font-size:12px}
.pp-gal{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pp-gal img{width:100%;height:120px;object-fit:cover;border-radius:12px}
.pp-rev{padding:14px 0;border-bottom:1px solid var(--line)}.pp-rev:last-child{border-bottom:none}
.pp-rev-h{display:flex;align-items:center;gap:10px}.pp-rev-h b{font-size:14px}
.pp-rev p{margin:8px 0 0;color:var(--muted);font-size:14px}
.pp-stick{position:sticky;top:84px;text-align:center}
.pp-big{font-size:42px;font-weight:800;color:var(--ink)}.pp-big span{font-size:20px;color:var(--soft)}

/* messages */
.msg-wrap{display:grid;grid-template-columns:300px 1fr;gap:16px;height:calc(100vh - 320px);min-height:420px}
@media(max-width:760px){.msg-wrap{grid-template-columns:1fr;height:auto}.msg-list{max-height:200px}.msg-panel{height:60vh}}
.msg-list{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow-y:auto;padding:8px}
.msg-c{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:none;
  padding:10px;border-radius:12px;cursor:pointer;color:var(--ink);font-family:inherit}
.msg-c:hover,.msg-c.active{background:var(--lav)}
.msg-c b{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cimg{width:40px;height:40px;border-radius:50%;flex:0 0 auto;background:var(--lav);color:var(--violet);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;overflow:hidden}
.cimg img{width:100%;height:100%;object-fit:cover}
.msg-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden}
.msg-empty{margin:auto;color:var(--muted);padding:30px;text-align:center}
.msg-head{align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);font-size:16px}
.msg-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px;background:#FBFAFE}
.bub{max-width:72%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.4;word-wrap:break-word}
.bub .t{display:block;font-size:10px;opacity:.6;margin-top:4px}
.bub.me{align-self:flex-end;background:var(--violet);color:#fff;border-bottom-right-radius:5px}
.bub.them{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px}
.msg-input{display:flex;gap:10px;padding:12px;border-top:1px solid var(--line)}
.msg-input input{flex:1;height:46px;border:1.5px solid var(--line);border-radius:14px;padding:0 14px;font-size:14px;background:#FBFAFE;outline:none}
.msg-input input:focus{border-color:var(--violet);background:#fff}

/* booking status badges */
.bk-badge{display:inline-block;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:700}
.bk-badge.open{background:#FFF1D6;color:#8A5A00}
.bk-badge.acc{background:#E6EeFF;color:#3858C8}
.bk-badge.done{background:#E1F5EE;color:#0F6E56}
.bk-badge.canc{background:#FCEBEB;color:#A32D2D}
.bk-filter{margin-bottom:16px}

/* account hub links (profile) */
.acct-links{max-width:460px;margin:16px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:560px){.acct-links{grid-template-columns:1fr}}
.acct-links a{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px;font-weight:700;font-size:14px;color:var(--ink);box-shadow:var(--shadow)}
.acct-links a:hover{border-color:var(--violet);color:var(--violet)}
