/* Prestige Car Wash — shared design system (mobile-first) */
:root{
  --bg:#0b0f16; --panel:#121824; --panel2:#0e1420; --ink:#eef3fb; --mut:#8ba0bd;
  --line:#222e42; --brand:#28c3ff; --brand2:#0a84ff; --gold:#e8c86a; --good:#3ad29f; --warn:#ffb454; --bad:#ff6b6b;
  --cols:4; --fs:1; --radius:14px; --maxw:1280px;
  --shadow:0 8px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(1200px 600px at 70% -10%, #14324a 0%, var(--bg) 55%) fixed;
  color:var(--ink); font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.5; -webkit-font-smoothing:antialiased;
}
a{color:var(--brand);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}

/* top nav */
.nav{position:sticky;top:0;z-index:40;background:rgba(11,15,22,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .row{display:flex;align-items:center;gap:16px;height:60px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.5px}
.brand .mk{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;font-size:16px}
.brand small{color:var(--gold);font-weight:600;letter-spacing:2px;font-size:10px;text-transform:uppercase}
.nav .links{display:flex;gap:18px;margin-left:auto;align-items:center}
.nav .links a{color:var(--mut);font-weight:600;font-size:14px}
.nav .links a:hover,.nav .links a.on{color:var(--ink)}
.btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#001018;font-weight:700;padding:10px 16px;border-radius:999px;border:0;cursor:pointer;font-size:14px}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn:hover{filter:brightness(1.07)}
.hamb{display:none;background:none;border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:8px 10px;font-size:18px;cursor:pointer}

/* hero */
.hero{position:relative;padding:70px 0 54px;text-align:center}
.hero h1{font-size:clamp(30px,6vw,58px);line-height:1.05;margin:0 0 14px;font-weight:900;letter-spacing:-.5px}
.hero p.lead{font-size:clamp(15px,2.4vw,20px);color:var(--mut);max-width:660px;margin:0 auto 26px}
.hero .cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.pill{display:inline-block;background:var(--panel);border:1px solid var(--line);color:var(--gold);border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px}

/* generic sections */
.section{padding:40px 0}
.section h2{font-size:clamp(22px,3.5vw,32px);margin:0 0 6px;font-weight:800}
.section .sub{color:var(--mut);margin:0 0 22px}

/* grid + cards */
.controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.controls label{font-size:12px;color:var(--mut);display:flex;align-items:center;gap:8px;font-weight:600}
.controls select,.controls input[type=search]{background:var(--panel);border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:8px 10px;font-size:14px}
.controls input[type=range]{accent-color:var(--brand)}
.layout{display:grid;grid-template-columns:240px 1fr;gap:20px;align-items:start}
.filters{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;position:sticky;top:76px}
.filters h4{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--mut)}
.facet{border-top:1px solid var(--line);padding:10px 0}
.facet summary{cursor:pointer;font-weight:700;font-size:14px;list-style:none}
.facet .opt{display:flex;justify-content:space-between;align-items:center;padding:6px 4px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--mut)}
.facet .opt:hover{background:var(--panel2);color:var(--ink)}
.facet .opt.on{color:var(--ink)}
.facet .opt .n{background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:1px 8px;font-size:11px;color:var(--brand)}
.grid{display:grid;grid-template-columns:repeat(var(--cols),1fr);gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .15s,border-color .15s}
.card:hover{transform:translateY(-3px);border-color:var(--brand)}
.card .media{aspect-ratio:4/3;background:linear-gradient(135deg,#0f2233,#0a1520);position:relative;overflow:hidden;display:grid;place-items:center}
.card .media video,.card .media img{width:100%;height:100%;object-fit:cover}
.card .media .ph{color:var(--mut);font-size:12px;text-align:center;padding:10px}
.card .body{padding:calc(12px * var(--fs))}
.card .ttl{font-weight:800;font-size:calc(15px * var(--fs));margin:0 0 4px}
.card .cat{font-size:11px;color:var(--gold);text-transform:uppercase;letter-spacing:1px;font-weight:700}
.card .blurb{color:var(--mut);font-size:calc(12.5px * var(--fs));margin:6px 0 10px}
.card .price{font-weight:900;font-size:calc(18px * var(--fs));color:var(--brand)}
.card .row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.tag{font-size:10.5px;background:var(--panel2);border:1px solid var(--line);color:var(--mut);border-radius:999px;padding:2px 8px}

/* footer */
.foot{border-top:1px solid var(--line);margin-top:40px;padding:28px 0;color:var(--mut);font-size:13px}
.foot a{color:var(--mut)}

/* filters drawer (mobile) */
.drawer-backdrop{display:none}
.filters-toggle{display:none}

/* ---------- responsive / mobile ---------- */
@media (max-width:900px){
  .nav .links{position:fixed;inset:60px 0 auto 0;flex-direction:column;background:var(--panel);border-bottom:1px solid var(--line);padding:14px 18px;gap:14px;display:none}
  .nav .links.open{display:flex}
  .nav .links a{font-size:16px}
  .hamb{display:inline-block;margin-left:auto}
  .layout{grid-template-columns:1fr}
  .filters-toggle{display:inline-flex}
  .filters{position:fixed;inset:0 20% 0 0;z-index:60;border-radius:0;transform:translateX(-105%);transition:transform .22s;overflow:auto}
  .filters.open{transform:none}
  .drawer-backdrop.open{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55}
  .grid{grid-template-columns:repeat(min(var(--cols),2),1fr)!important}
}
@media (max-width:520px){
  .grid{grid-template-columns:1fr!important}
  .controls{gap:8px}
}

/* ---------- daily specials banner (injected by pcw-shared.js) ---------- */
.specialbar{background:linear-gradient(90deg,#8a6d1f,#c8a03a 30%,#e8c86a 50%,#c8a03a 70%,#8a6d1f);color:#1a1405;font-weight:700;font-size:13.5px}
.specialbar .sbrow{display:flex;align-items:center;gap:12px;padding:8px 18px}
.specialbar .sbtag{background:#1a1405;color:var(--gold);border-radius:999px;padding:3px 10px;font-size:10.5px;letter-spacing:1px;text-transform:uppercase;white-space:nowrap}
.specialbar .sbtext{flex:1;min-width:0}
.specialbar .sbcta{color:#1a1405;font-weight:900;white-space:nowrap;text-decoration:underline}
.specialbar .sbx{background:none;border:0;color:#1a1405;font-size:18px;cursor:pointer;line-height:1;padding:2px 6px}
@media(max-width:640px){.specialbar .sbrow{flex-wrap:wrap;gap:6px;padding:8px 12px}.specialbar .sbcta{margin-left:auto}}

/* ---------- login button (injected next to the hamburger) ---------- */
.loginbtn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:13px;font-weight:700;color:var(--mut);white-space:nowrap}
.loginbtn:hover{color:var(--ink);border-color:var(--brand)}
@media(max-width:900px){.loginbtn span{display:none}.loginbtn{padding:7px 10px}}

/* ---------- weather + live cam chips ---------- */
.wxcard .wxtemp{font-size:34px;font-weight:900;color:var(--brand)}
.wxcard .wxmsg{color:var(--good);font-weight:700;font-size:13px;margin-top:6px}
.camframe{width:100%;aspect-ratio:16/9;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel2);display:grid;place-items:center;color:var(--mut);font-size:14px;text-align:center;padding:10px}
.camframe iframe,.camframe video{width:100%;height:100%;border:0;display:block;object-fit:cover}

/* ---------- tip page ---------- */
.tipwrap{max-width:440px;margin:0 auto;padding:30px 18px 80px}
.tipcode{display:flex;gap:10px;justify-content:center;margin:18px 0}
.tipcode input{width:150px;text-align:center;font-size:34px;letter-spacing:12px;font-weight:900;background:var(--panel);border:1px solid var(--line);color:var(--ink);border-radius:14px;padding:12px 6px}
.tipwho{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--brand);border-radius:16px;padding:16px;margin:14px 0}
.tipwho .avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;font-size:24px;font-weight:900;color:#001018}
.amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:16px 0}
.amounts button{background:var(--panel);border:1px solid var(--line);color:var(--ink);border-radius:12px;padding:16px 0;font-size:17px;font-weight:800;cursor:pointer}
.amounts button.on{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#001018;border-color:transparent}
.tipsplit{font-size:13px;color:var(--mut);display:flex;align-items:center;gap:8px;margin:12px 0}
.tippay{width:100%;font-size:17px;justify-content:center;padding:16px}
@media(max-width:520px){.amounts{grid-template-columns:repeat(2,1fr)}}

/* ---------- sticky click-to-call FAB (injected by pcw-shared.js) ---------- */
.callfab{position:fixed;right:16px;bottom:16px;z-index:70;display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--good),#1fa87e);color:#00140d;font-weight:800;padding:14px 20px;border-radius:999px;box-shadow:0 10px 30px rgba(0,0,0,.5);font-size:15px;text-decoration:none}
.callfab:hover{filter:brightness(1.08)}
.callfab .ring{font-size:18px;animation:pcwring 2.4s ease-in-out infinite}
@keyframes pcwring{0%,88%,100%{transform:rotate(0)}90%{transform:rotate(14deg)}92%{transform:rotate(-12deg)}94%{transform:rotate(10deg)}96%{transform:rotate(-8deg)}98%{transform:rotate(4deg)}}
@media(max-width:640px){.callfab{right:12px;bottom:12px;padding:13px 16px}}

/* ---------- membership pricing cards ---------- */
.plan{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:26px 22px;display:flex;flex-direction:column;gap:14px}
.plan.popular{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold),var(--shadow)}
.plan .flag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:#1a1405;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;border-radius:999px;padding:4px 14px}
.plan .pname{font-weight:900;font-size:20px}
.plan .pprice{font-size:38px;font-weight:900;color:var(--brand)}
.plan .pprice small{font-size:14px;color:var(--mut);font-weight:600}
.plan ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px}
.plan ul li{font-size:13.5px;color:var(--mut);padding-left:22px;position:relative}
.plan ul li::before{content:"✓";position:absolute;left:0;color:var(--good);font-weight:800}
.plan .who{font-size:12px;color:var(--gold);text-transform:uppercase;letter-spacing:1px;font-weight:700}

/* ---------- coupon cards ---------- */
.coupon{position:relative;background:var(--panel);border:1.5px dashed var(--brand);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:8px;overflow:hidden}
.coupon::before,.coupon::after{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:var(--bg);border:1.5px dashed var(--brand);top:50%;transform:translateY(-50%)}
.coupon::before{left:-12px}.coupon::after{right:-12px}
.coupon .cval{font-size:26px;font-weight:900;color:var(--gold)}
.coupon .ccode{align-self:flex-start;background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:5px 12px;font-family:ui-monospace,Menlo,monospace;font-weight:700;letter-spacing:2px;color:var(--brand);cursor:pointer}
.coupon .cfine{font-size:11px;color:var(--mut)}

/* ---------- visit page ---------- */
.mapframe{width:100%;aspect-ratio:16/9;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel)}
.mapframe iframe{width:100%;height:100%;border:0;display:block}
.eatcard .walk{font-size:11px;color:var(--good);font-weight:700}

/* ---------- reviews ---------- */
.review{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:8px;break-inside:avoid;margin-bottom:14px}
.review .stars{color:var(--gold);letter-spacing:2px;font-size:14px}
.review .rtext{font-size:14px;line-height:1.55}
.review .rmeta{font-size:12px;color:var(--mut);display:flex;justify-content:space-between;gap:8px}
.review .rsrc{text-transform:uppercase;letter-spacing:1px;font-weight:700;font-size:10.5px}
.revwall{columns:3 300px;column-gap:14px}
