/* ============================================================
   SNIPS — styles
   Ink navy #1B2735 · Signal red #E04646 · Paper #FFFFFF
   Display: Playfair Display · Body: Inter
   ============================================================ */
:root{
  --ink:#1b2735;
  --ink2:#27374a;
  --red:#e04646;
  --red-dk:#c43434;
  --paper:#fff;
  --mist:#f5f6f8;
  --line:#e6e9ee;
  --mut:#74808f;
  --ok:#2fae6e;
  --ok-bg:#e9f7f0;
  --bad-bg:#fdecec;
  --r:10px;
  --disp:'Playfair Display',Georgia,serif;
  --body:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif;
  --shadow:0 10px 30px rgba(27,39,53,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased}
img{max-width:100%}
a{color:inherit}
button{font-family:var(--body);cursor:pointer}
.wrap{max-width:1140px;margin:0 auto;padding:0 20px}
h1,h2,h3{font-weight:600}
.serif{font-family:var(--disp)}

/* ---------- header ---------- */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;gap:26px;height:64px}
.hdr .brand img{height:30px;display:block}
.hdr nav{display:flex;gap:22px;font-size:14px;color:var(--mut);flex:1}
.hdr nav a{text-decoration:none;padding:6px 0;border-bottom:2px solid transparent}
.hdr nav a:hover,.hdr nav a.on{color:var(--ink);border-color:var(--red)}
.hdr .auth{display:flex;align-items:center;gap:14px;font-size:14px}
.hdr .auth a{text-decoration:none;color:var(--ink)}
.btn{display:inline-block;border:0;border-radius:var(--r);padding:11px 20px;font-size:14px;font-weight:600;text-decoration:none;text-align:center;transition:filter .15s,transform .12s}
.btn:active{transform:translateY(1px)}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{filter:brightness(1.06)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:8px}
.btn[disabled]{opacity:.45;cursor:not-allowed;filter:none}
.pill-user{background:var(--mist);border-radius:999px;padding:8px 14px;font-size:13px;border:1px solid var(--line);cursor:pointer}

/* ---------- hero ---------- */
.hero{position:relative;color:#fff;background:
  linear-gradient(115deg,rgba(20,28,40,.92) 0%,rgba(27,39,53,.72) 55%,rgba(27,39,53,.45) 100%),
  repeating-linear-gradient(135deg,#222e3e 0 14px,#1b2735 14px 28px)}
.hero-in{padding:74px 0 86px;max-width:600px}
.hero .loc{font-size:13px;letter-spacing:.06em;opacity:.85;margin-bottom:10px}
.hero h1{font-family:var(--disp);font-size:clamp(30px,4.6vw,46px);line-height:1.15;margin-bottom:12px}
.hero p{font-size:15.5px;opacity:.85;margin-bottom:26px;line-height:1.6}
.searchbar{display:flex;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.searchbar input{flex:1;border:0;padding:16px 18px;font:15px var(--body);color:var(--ink);min-width:0}
.searchbar input:focus{outline:none}
.searchbar .btn{border-radius:0;padding:0 26px}
.hero .tools{position:absolute;right:4%;top:18%;font-size:54px;opacity:.16;letter-spacing:.4em;user-select:none}

/* ---------- sections ---------- */
section.block{padding:46px 0}
.block-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:22px}
.block-head h2{font-family:var(--disp);font-size:25px}
.block-head a{font-size:13.5px;color:var(--red);text-decoration:none;font-weight:600}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* salon card */
.card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(27,39,53,.14)}
.card .ph{height:130px;display:flex;align-items:center;justify-content:center;font-size:52px;color:#fff}
.card .bd{padding:14px 16px 16px;display:flex;flex-direction:column;gap:7px;flex:1}
.card .nm{font-weight:600;font-size:15.5px;display:flex;justify-content:space-between;gap:8px}
.fav{background:none;border:0;font-size:17px;line-height:1;color:#cdd4dc}
.fav.on{color:var(--red)}
.card .ad{font-size:12.5px;color:var(--mut)}
.rate{font-size:12.5px;color:var(--ink)}
.rate b{color:#e8a13c}
.badge{display:inline-block;font-size:11px;font-weight:600;border-radius:999px;padding:4px 10px}
.badge.del{background:var(--ok-bg);color:var(--ok)}
.badge.ret{background:#fff6e8;color:#b97f1f}
.badge.off{background:var(--mist);color:var(--mut)}
.card .ft{display:flex;gap:8px;margin-top:auto;padding-top:10px}

/* services band */
.band{background:var(--ink);color:#fff;padding:44px 0 50px}
.band h2{font-family:var(--disp);text-align:center;font-size:24px;margin-bottom:28px}
.cats{display:grid;grid-template-columns:repeat(8,1fr);gap:12px}
.cat{background:#243140;border:1px solid #324155;border-radius:12px;padding:16px 6px 13px;text-align:center;color:#dbe3ec;text-decoration:none;transition:background .15s,transform .15s}
.cat:hover{background:#2c3b4d;transform:translateY(-3px)}
.cat .ic{font-size:26px;display:block;margin-bottom:7px}
.cat span{font-size:11.5px}

/* why choose / partner */
.why .grid3 .why-it{background:var(--mist);border-radius:14px;padding:22px;font-size:14px;line-height:1.6}
.why-it b{display:block;margin-bottom:6px;font-size:15px}
.partner{background:var(--mist)}
.partner .split{display:grid;grid-template-columns:1.1fr 1fr;gap:36px;align-items:center}
.partner ul{list-style:none;display:grid;gap:12px;font-size:14.5px}
.partner li::before{content:"✓";color:var(--ok);font-weight:700;margin-right:9px}
.qrish{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;text-align:center;box-shadow:var(--shadow)}
.qrish .big{font-size:64px}

/* ---------- auth pages ---------- */
.auth-stage{min-height:calc(100vh - 64px);display:grid;grid-template-columns:1.15fr .85fr;background:
  linear-gradient(180deg,#fdfdfd,#f2f3f5)}
.auth-left{padding:9vh 6vw;display:flex;flex-direction:column;justify-content:center}
.auth-left h1{font-family:var(--disp);font-size:clamp(28px,3.4vw,40px);margin-bottom:10px}
.auth-left p{color:var(--mut);font-size:15.5px;max-width:380px;line-height:1.6}
.tool-row{margin-top:7vh;font-size:46px;letter-spacing:.35em;opacity:.5}
.auth-right{display:flex;align-items:center;justify-content:center;padding:40px 24px}
.dark-card{background:var(--ink);color:#fff;width:min(360px,100%);border-radius:14px;padding:26px 24px;box-shadow:0 30px 60px rgba(27,39,53,.35)}
.dark-card h3{font-size:17px;margin-bottom:16px}
.dark-card label{display:block;font-size:11.5px;letter-spacing:.05em;color:#9fb0c2;margin:11px 0 5px}
.dark-card input{width:100%;background:#27374a;border:1px solid #3a4c61;border-radius:9px;color:#fff;padding:12px;font:14px var(--body)}
.dark-card input::placeholder{color:#7e8fa3}
.dark-card input:focus{outline:none;border-color:var(--red)}
.dark-card .btn{width:100%;margin-top:18px}
.dark-card .alt{margin-top:14px;text-align:center;font-size:12.5px;color:#9fb0c2}
.dark-card .alt a{color:#fff}
.form-err{margin-top:12px;font-size:12.5px;color:#ffb3b3;min-height:16px}
.form-ok{color:#9fe7c0}
.demo-box{margin-top:16px;border-top:1px dashed #3a4c61;padding-top:12px;font-size:11.5px;color:#9fb0c2;line-height:1.7}
.demo-box b{color:#dbe3ec}

/* ---------- search page ---------- */
.search-top{background:var(--mist);padding:22px 0;border-bottom:1px solid var(--line)}
.search-top .row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.search-top input,.search-top select{padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:14px var(--body);background:#fff}
.search-top input{flex:1;min-width:200px}
.search-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:26px 0 50px}
.mapbox{position:relative;border-radius:14px;min-height:430px;overflow:hidden;border:1px solid var(--line);
  background:
   repeating-linear-gradient(0deg,transparent 0 46px,#dfe6ec 46px 48px),
   repeating-linear-gradient(90deg,transparent 0 64px,#dfe6ec 64px 66px),
   linear-gradient(135deg,#eef3f1,#e4ecf2)}
.mapbox::after{content:"Yolanda Crossing";position:absolute;left:14px;top:12px;font-size:12px;color:#8a98a6;letter-spacing:.08em}
.pin{position:absolute;transform:translate(-50%,-100%);background:none;border:0;font-size:26px;filter:drop-shadow(0 3px 4px rgba(0,0,0,.25));transition:transform .15s}
.pin:hover,.pin.on{transform:translate(-50%,-100%) scale(1.28)}
.results{display:flex;flex-direction:column;gap:14px;max-height:560px;overflow:auto;padding-right:4px}
.res{display:flex;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;align-items:center}
.res.on{border-color:var(--red);box-shadow:0 0 0 3px rgba(224,70,70,.08)}
.res .th{flex:0 0 78px;height:78px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff}
.res .meta{flex:1;font-size:13px;color:var(--mut);display:grid;gap:4px}
.res .meta .nm{font-size:15px;font-weight:600;color:var(--ink)}

/* ---------- salon detail / booking ---------- */
.salon-hero{background:var(--ink);color:#fff;padding:34px 0}
.salon-hero .row{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap}
.salon-hero h1{font-family:var(--disp);font-size:28px}
.salon-hero .sub{color:#a9b7c6;font-size:13.5px;margin-top:6px}
.salon-body{display:grid;grid-template-columns:1.4fr .9fr;gap:26px;padding:30px 0 60px}
.svc-list{display:flex;flex-direction:column;gap:12px}
.svc{display:flex;justify-content:space-between;gap:14px;border:1px solid var(--line);border-radius:12px;padding:14px 16px;align-items:center;background:#fff}
.svc .l{flex:1}
.svc .l b{font-size:14.5px}
.svc .l .d{font-size:12.5px;color:var(--mut);margin-top:3px}
.svc .pr{font-weight:700;white-space:nowrap}
.svc .mins{font-size:11.5px;color:var(--mut)}
.svc .add{min-width:74px}
.svc.in .add{background:var(--bad-bg);color:var(--red);border:0}
.sticky-side{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}
.sumcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow)}
.sumcard h3{font-size:15px;margin-bottom:12px}
.sum-row{display:flex;justify-content:space-between;font-size:13.5px;padding:6px 0;color:var(--ink)}
.sum-row.mut{color:var(--mut)}
.sum-row.tot{border-top:1px solid var(--line);margin-top:8px;padding-top:12px;font-weight:700;font-size:15px}
.sum-row .x{color:var(--red);background:none;border:0;font-size:12px}
.note{font-size:12.5px;color:var(--mut);line-height:1.55}
.note.warn{background:#fff6e8;color:#9a6a14;border-radius:10px;padding:10px 12px}
.note.okay{background:var(--ok-bg);color:#1f7a4c;border-radius:10px;padding:10px 12px}

/* calendar + slots */
.cal{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:600}
.cal-head button{background:none;border:1px solid var(--line);border-radius:8px;width:30px;height:30px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center;font-size:13px}
.cal-grid .dow{color:var(--mut);font-size:11px;padding:6px 0}
.cal-grid button{border:0;background:none;border-radius:9px;padding:9px 0;font-size:13px}
.cal-grid button:hover:not([disabled]){background:var(--mist)}
.cal-grid button.sel{background:var(--ok);color:#fff;font-weight:700}
.cal-grid button[disabled]{color:#c6cdd5;cursor:default}
.slot-group{margin-top:16px}
.slot-group h4{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--mut);margin-bottom:8px}
.slots{display:flex;flex-wrap:wrap;gap:8px}
.slot{border:1px solid var(--ok);color:var(--ok);background:#fff;border-radius:8px;padding:8px 12px;font-size:12.5px}
.slot.sel{background:var(--ok);color:#fff}
.slot.booked{border-color:var(--red);color:var(--red);background:var(--bad-bg);cursor:not-allowed}
.deliv-row{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:13.5px}
.deliv-row input{width:18px;height:18px;accent-color:var(--ok)}

/* steps */
.steps{display:flex;gap:8px;margin:22px 0 18px;font-size:12px;color:var(--mut)}
.steps .st{flex:1;text-align:center;border-top:3px solid var(--line);padding-top:8px}
.steps .st.on{border-color:var(--red);color:var(--ink);font-weight:600}

/* ---------- payment / receipt ---------- */
.pay-layout{display:grid;grid-template-columns:1.2fr .9fr;gap:26px;padding:34px 0 60px}
.pay-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px}
.pay-card h3{margin-bottom:14px;font-size:16px}
.pay-card label{display:block;font-size:12px;color:var(--mut);margin:12px 0 5px}
.pay-card input,.pay-card select{width:100%;padding:12px;border:1px solid var(--line);border-radius:9px;font:14px var(--body)}
.pay-card input:focus{outline:none;border-color:var(--ink)}
.gap2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.coupon-row{display:flex;gap:10px;margin-top:6px}
.coupon-row input{flex:1}
.receipt{max-width:560px;margin:46px auto 70px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px;box-shadow:var(--shadow)}
.receipt .ok-burst{width:64px;height:64px;border-radius:50%;background:var(--ok-bg);color:var(--ok);font-size:30px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.receipt h2{text-align:center;font-family:var(--disp)}
.receipt .rno{text-align:center;color:var(--mut);font-size:13px;margin:6px 0 18px}
.receipt table{width:100%;border-collapse:collapse;font-size:13.5px}
.receipt td{padding:7px 0;border-bottom:1px dashed var(--line)}
.receipt td:last-child{text-align:right}
.receipt .actions{display:flex;gap:10px;justify-content:center;margin-top:22px}

/* ---------- account / dashboards (dark sidebar like the mock-ups) ---------- */
.dash{display:grid;grid-template-columns:230px 1fr;min-height:calc(100vh - 64px)}
.side{background:var(--ink);color:#cfd9e4;padding:22px 0}
.side .who{padding:0 20px 16px;border-bottom:1px solid #2c3b4d;margin-bottom:10px}
.side .who b{color:#fff;display:block;font-size:14.5px}
.side .who span{font-size:11.5px;color:#8fa0b3}
.side a{display:flex;gap:10px;align-items:center;padding:11px 20px;font-size:13.5px;text-decoration:none;color:#cfd9e4;border-left:3px solid transparent}
.side a.on{background:#243140;border-color:var(--red);color:#fff}
.side a:hover{background:#223040}
.side .out{margin-top:18px;color:#ff9e9e}
.main{padding:28px;background:var(--mist)}
.main h2{font-family:var(--disp);font-size:22px;margin-bottom:18px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px}
.stat .v{font-size:22px;font-weight:700}
.stat .k{font-size:12px;color:var(--mut);margin-top:3px}
.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:18px}
.panel h3{font-size:15px;margin-bottom:12px}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--mut);font-weight:600;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--line)}
.tbl td{padding:11px 10px;border-bottom:1px solid var(--mist);vertical-align:middle}
.tag{display:inline-block;font-size:11px;font-weight:600;border-radius:999px;padding:3px 9px}
.tag.ok{background:var(--ok-bg);color:var(--ok)}
.tag.warn{background:#fff6e8;color:#b97f1f}
.tag.bad{background:var(--bad-bg);color:var(--red)}
.tag.mut{background:var(--mist);color:var(--mut)}
.progress{height:8px;border-radius:99px;background:var(--mist);overflow:hidden}
.progress i{display:block;height:100%;background:var(--ok)}
.empty{padding:34px;text-align:center;color:var(--mut);font-size:13.5px}

/* messages */
.msg-thread{display:flex;flex-direction:column;gap:10px;max-height:340px;overflow:auto;padding:4px}
.msg{max-width:75%;padding:10px 13px;border-radius:12px;font-size:13.5px;line-height:1.5}
.msg.them{background:var(--mist);align-self:flex-start}
.msg.me{background:var(--ink);color:#fff;align-self:flex-end}
.msg-send{display:flex;gap:10px;margin-top:12px}
.msg-send input{flex:1;padding:11px;border:1px solid var(--line);border-radius:9px;font:13.5px var(--body)}

/* ---------- footer (dark, 4 columns like the mock-ups) ---------- */
.ftr{background:var(--ink);color:#a9b7c6;margin-top:auto}
.ftr-in{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.3fr;gap:26px;padding:44px 0 36px}
.ftr img{height:26px;margin-bottom:12px}
.ftr h4{color:#fff;font-size:13px;margin-bottom:12px;letter-spacing:.04em}
.ftr a{display:block;font-size:12.5px;color:#a9b7c6;text-decoration:none;padding:4px 0}
.ftr a:hover{color:#fff}
.ftr p{font-size:12.5px;line-height:1.7}
.ftr .sub{display:flex;gap:8px;margin-top:10px}
.ftr .sub input{flex:1;background:#243140;border:1px solid #324155;border-radius:8px;color:#fff;padding:10px;font:12.5px var(--body)}
.ftr .base{border-top:1px solid #2c3b4d;padding:16px 0;font-size:12px;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ftr .base .net a{display:inline;padding:0 8px;opacity:.75}
.ftr .base .net a:hover{opacity:1}

/* toast + modal */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--ink);color:#fff;border-radius:10px;padding:12px 20px;font-size:13.5px;opacity:0;transition:all .3s;z-index:90;box-shadow:0 14px 40px rgba(0,0,0,.3)}
.toast.show{opacity:1;transform:translateX(-50%)}
.spin{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:rot .7s linear infinite;vertical-align:-3px;margin-right:8px}
@keyframes rot{to{transform:rotate(360deg)}}

button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--red);outline-offset:2px}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .grid3,.grid4{grid-template-columns:repeat(2,1fr)}
  .cats{grid-template-columns:repeat(4,1fr)}
  .search-layout,.salon-body,.pay-layout,.partner .split{grid-template-columns:1fr}
  .auth-stage{grid-template-columns:1fr}
  .auth-left{padding:7vh 8vw 2vh}
  .stats{grid-template-columns:repeat(2,1fr)}
  .ftr-in{grid-template-columns:1fr 1fr}
  .mapbox{min-height:300px}
}
@media (max-width:640px){
  .hdr nav{display:none}
  .grid3,.grid4{grid-template-columns:1fr}
  .dash{grid-template-columns:1fr}
  .side{display:flex;overflow-x:auto;padding:0}
  .side .who{display:none}
  .side a{white-space:nowrap;border-left:0;border-bottom:3px solid transparent}
  .side a.on{border-color:var(--red)}
  .side .out{margin:0}
  .sticky-side{position:static}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}
