/* ============================================================
   Summit Fix Handyman — "Honest workshop" light editorial theme
   Paper + ink, hi-vis orange accent, navy trust tone.
   Display: Bricolage Grotesque · Body: Hanken Grotesk
   ============================================================ */

:root {
  --paper:      #f4eee2;
  --paper-2:    #faf6ed;
  --card:       #fffdf8;
  --ink:        #1b1a16;
  --ink-soft:   #6a6357;
  --navy:       #12324d;
  --navy-soft:  #2c4f6e;
  --accent:     #ff5a1f;
  --accent-deep:#d8430a;
  --accent-soft:#ffe5d4;
  --amber:      #f2a900;
  --line:       rgba(27,26,22,0.12);
  --line-strong:rgba(27,26,22,0.22);
  --shadow:     22px 22px 0 -8px rgba(18,50,77,0.08);
  --r:          18px;
  --maxw:       1180px;
}

* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:'Hanken Grotesk', system-ui, sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  position:relative;
}

/* Grain + faint blueprint grid wash */
body::before {
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:0.04; mix-blend-mode:multiply;
}

h1,h2,h3,h4 { font-family:'Bricolage Grotesque', system-ui, sans-serif; font-weight:700; line-height:1.02; letter-spacing:-0.02em; color:var(--ink); }
a { color:inherit; text-decoration:none; }
img,svg { display:block; }

.wrap { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; position:relative; z-index:1; }
.section { padding:96px 0; position:relative; z-index:1; }
@media (max-width:700px){ .section{ padding:64px 0; } }

/* ── Eyebrow / labels ───────────────────────────────────── */
.eyebrow {
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:'Bricolage Grotesque', sans-serif;
  font-size:.72rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--accent-deep);
}
.eyebrow::before { content:''; width:26px; height:2px; background:var(--accent); }

/* Peak chevron motif */
.peaks { display:flex; gap:5px; align-items:flex-end; }
.peaks i { width:0; height:0; border-left:6px solid transparent; border-right:6px solid transparent; border-bottom:11px solid var(--accent); display:block; opacity:.9; }
.peaks i:nth-child(2){ border-bottom-height:16px; transform:scaleY(1.5); }
.peaks i:nth-child(3){ transform:scaleY(1.9); }

/* ── Buttons ────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:'Bricolage Grotesque', sans-serif; font-weight:700; font-size:.98rem;
  padding:1rem 1.5rem; border-radius:999px; border:2px solid transparent;
  cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, background .18s, color .18s;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-primary { background:var(--accent); color:#fff; box-shadow:0 12px 28px -10px rgba(255,90,31,.6); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 18px 40px -12px rgba(255,90,31,.75); }
.btn-dark { background:var(--navy); color:#fff; }
.btn-dark:hover { transform:translateY(-3px); background:#0d2438; }
.btn-ghost { background:transparent; color:var(--ink); border-color:var(--line-strong); }
.btn-ghost:hover { border-color:var(--ink); transform:translateY(-3px); }

/* ── Header ─────────────────────────────────────────────── */
header {
  position:sticky; top:0; z-index:50;
  background:rgba(244,238,226,0.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, background .3s, box-shadow .3s;
}
header.scrolled { border-bottom-color:var(--line); box-shadow:0 6px 24px -16px rgba(18,50,77,.5); }
.nav { display:flex; align-items:center; justify-content:space-between; height:78px; }

.logo { display:inline-flex; align-items:center; gap:.6rem; }
.logo-mark { width:40px; height:40px; flex:none; }
.logo-text { display:flex; flex-direction:column; line-height:1; }
.logo-text b { font-family:'Bricolage Grotesque', sans-serif; font-weight:800; font-size:1.18rem; letter-spacing:-0.01em; color:var(--navy); }
.logo-text span { font-size:.6rem; letter-spacing:.34em; text-transform:uppercase; color:var(--ink-soft); font-weight:600; margin-top:3px; }

.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-links a { font-weight:600; font-size:.95rem; color:var(--ink); position:relative; }
.nav-links a::after { content:''; position:absolute; left:0; bottom:-6px; width:0; height:2px; background:var(--accent); transition:width .25s; }
.nav-links a:hover::after { width:100%; }
.nav-cta { display:flex; align-items:center; gap:.9rem; }
.nav-phone { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; color:var(--navy); font-size:1rem; }
@media (max-width:920px){ .nav-links{ display:none; } }

.burger { display:none; width:46px; height:46px; border:1px solid var(--line-strong); border-radius:12px; background:var(--card); align-items:center; justify-content:center; cursor:pointer; }
.burger span { display:block; width:20px; height:2px; background:var(--ink); position:relative; }
.burger span::before,.burger span::after{ content:''; position:absolute; left:0; width:20px; height:2px; background:var(--ink); transition:.25s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }
@media (max-width:920px){ .burger{ display:flex; } .nav-cta .btn-ghost{ display:none; } }
@media (max-width:560px){ .nav-cta .btn-primary{ display:none; } }

/* Mobile menu */
.mobile-menu { position:fixed; inset:0; z-index:60; background:var(--navy); display:flex; flex-direction:column; padding:28px 24px; transform:translateY(-100%); transition:transform .4s cubic-bezier(.5,0,.2,1); visibility:hidden; }
.mobile-menu.open { transform:translateY(0); visibility:visible; }
.mobile-menu .mm-top { display:flex; justify-content:space-between; align-items:center; }
.mobile-menu .mm-top .logo-text b{ color:#fff; } .mobile-menu .mm-top .logo-text span{ color:rgba(255,255,255,.6); }
.mm-close { width:46px; height:46px; border:1px solid rgba(255,255,255,.3); border-radius:12px; background:transparent; color:#fff; font-size:1.4rem; cursor:pointer; }
.mobile-menu nav { display:flex; flex-direction:column; gap:.4rem; margin-top:auto; margin-bottom:auto; }
.mobile-menu nav a { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:2rem; color:#fff; padding:.4rem 0; border-bottom:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; align-items:center; }
.mobile-menu nav a span{ color:var(--amber); font-size:.85rem; font-family:'Hanken Grotesk'; }
.mobile-menu .mm-foot { display:flex; flex-direction:column; gap:.8rem; }

/* ── Hero ───────────────────────────────────────────────── */
.hero { position:relative; padding:72px 0 96px; overflow:hidden; }
.hero::before {
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 90% at 80% 0%, #000 0%, transparent 65%);
  mask-image:radial-gradient(120% 90% at 80% 0%, #000 0%, transparent 65%);
  opacity:.5;
}
.hero-grid { display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center; }
@media (max-width:900px){ .hero-grid{ grid-template-columns:1fr; gap:36px; } }

.hero h1 { font-size:clamp(2.7rem,7vw,5rem); margin:22px 0 0; }
.hero h1 .hl { color:var(--accent); position:relative; white-space:nowrap; }
.hero h1 .hl::after { content:''; position:absolute; left:0; right:0; bottom:6px; height:14px; background:var(--accent-soft); z-index:-1; transform:skewX(-12deg); }
.hero p.lead { font-size:1.22rem; color:var(--ink-soft); margin-top:26px; max-width:34ch; }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero-trust { display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:34px; font-size:.92rem; font-weight:600; color:var(--ink-soft); }
.hero-trust span { display:inline-flex; align-items:center; gap:.45rem; }
.hero-trust .stars { color:var(--amber); letter-spacing:1px; }
@media (max-width:560px){
  .hero-actions { flex-direction:column; align-items:stretch; }
  .hero-actions .btn { justify-content:center; }
}

/* Hero image card + floating ticket */
.hero-media { position:relative; }
.hero-photo {
  width:100%; height:auto; display:block; border-radius:22px;
  border:1px solid var(--line);
  box-shadow:24px 24px 0 -8px rgba(255,90,31,.16), 0 34px 60px -34px rgba(18,50,77,.5);
}
.ticket-float {
  position:absolute; left:-20px; bottom:-30px;
  width:min(72%, 268px); padding:20px 24px 22px;
  box-shadow:0 24px 50px -18px rgba(18,50,77,.55);
}
.ticket-float .t-price { font-size:3.4rem; }
.ticket-float .t-price small { font-size:1.2rem; }
@media (max-width:900px){
  .ticket-float { position:static; width:100%; margin-top:16px; padding:24px 26px 26px; }
  .ticket-float .t-price { font-size:4rem; }
}

/* Price ticket */
.ticket {
  position:relative; background:var(--ink); color:#fff; border-radius:20px; padding:30px 32px 34px;
  box-shadow:24px 24px 0 -6px rgba(255,90,31,.18); overflow:hidden;
}
.ticket::before, .ticket::after { content:''; position:absolute; width:26px; height:26px; border-radius:50%; background:var(--paper); }
.ticket::before { top:50%; left:-13px; transform:translateY(-50%); }
.ticket::after { top:50%; right:-13px; transform:translateY(-50%); }
.ticket .perf { position:absolute; top:0; bottom:0; left:50%; border-left:2px dashed rgba(255,255,255,.18); }
.ticket .t-label { font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; color:var(--amber); font-weight:700; }
.ticket .t-price { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:5rem; line-height:.9; margin:10px 0 4px; }
.ticket .t-price small { font-size:1.6rem; vertical-align:super; color:var(--accent); }
.ticket .t-sub { color:rgba(255,255,255,.66); font-size:.95rem; }
.ticket .t-row { display:flex; align-items:center; gap:.6rem; margin-top:18px; padding-top:18px; border-top:1px dashed rgba(255,255,255,.2); font-size:.88rem; color:rgba(255,255,255,.82); }
.ticket .t-row b{ color:#fff; }

/* ── Marquee strip ──────────────────────────────────────── */
.strip { background:var(--navy); color:#fff; padding:16px 0; overflow:hidden; white-space:nowrap; }
.strip .track { display:inline-flex; gap:0; animation:slide 28s linear infinite; }
.strip .track span { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:1.05rem; letter-spacing:.01em; padding:0 26px; display:inline-flex; align-items:center; gap:26px; }
.strip .track span::after { content:'✦'; color:var(--amber); }
@keyframes slide { to { transform:translateX(-50%); } }

/* ── Section heading block ──────────────────────────────── */
.head { max-width:620px; margin-bottom:48px; }
.head.center { margin-left:auto; margin-right:auto; text-align:center; }
.head h2 { font-size:clamp(2rem,4.5vw,3.2rem); margin-top:16px; }
.head p { color:var(--ink-soft); margin-top:16px; font-size:1.08rem; }

/* ── Services ───────────────────────────────────────────── */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:900px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .services-grid{ grid-template-columns:1fr; } }
.svc {
  background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  padding:28px 26px 30px; position:relative; overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, border-color .3s;
}
.svc::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--accent); transform:scaleY(0); transform-origin:top; transition:transform .35s; }
.svc:hover { transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--line-strong); }
.svc:hover::before { transform:scaleY(1); }
.svc .num { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:.8rem; color:var(--accent-deep); letter-spacing:.1em; }
.svc .ico { width:52px; height:52px; border-radius:14px; background:var(--accent-soft); display:flex; align-items:center; justify-content:center; color:var(--accent-deep); margin:14px 0 16px; }
.svc .ico svg{ width:26px; height:26px; }
.svc h3 { font-size:1.3rem; }
.svc p { color:var(--ink-soft); margin-top:8px; font-size:.97rem; }
.svc-foot { margin-top:40px; text-align:center; font-size:1.05rem; color:var(--ink-soft); }
.svc-foot b{ color:var(--ink); }

/* ── Pricing ────────────────────────────────────────────── */
.pricing { background:var(--navy); color:#fff; border-radius:32px; padding:64px 56px; position:relative; overflow:hidden; }
.pricing::after { content:''; position:absolute; right:-80px; bottom:-80px; width:320px; height:320px; background:radial-gradient(circle,rgba(255,90,31,.4),transparent 70%); }
.pricing-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; position:relative; z-index:1; }
@media (max-width:820px){ .pricing{ padding:44px 28px; } .pricing-grid{ grid-template-columns:1fr; gap:32px; } }
.pricing h2 { color:#fff; font-size:clamp(2rem,4.5vw,3rem); }
.pricing h2 .hl{ color:var(--amber); }
.pricing p { color:rgba(255,255,255,.72); margin-top:18px; font-size:1.08rem; }
.price-list { list-style:none; display:flex; flex-direction:column; gap:2px; }
.price-list li { display:flex; align-items:center; gap:14px; padding:16px 4px; border-bottom:1px dashed rgba(255,255,255,.16); }
.price-list li svg{ width:22px; height:22px; color:var(--amber); flex:none; }
.price-list li b{ color:#fff; } .price-list li span{ color:rgba(255,255,255,.7); font-size:.95rem; }
.price-list .amt { margin-left:auto; font-family:'Bricolage Grotesque',sans-serif; font-weight:800; color:var(--amber); }

/* ── Why / trust ────────────────────────────────────────── */
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:860px){ .why-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .why-grid{ grid-template-columns:1fr; } }
.why { padding:6px 4px; }
.why .why-ico { width:46px; height:46px; color:var(--accent); margin-bottom:14px; }
.why h3 { font-size:1.18rem; }
.why p { color:var(--ink-soft); margin-top:8px; font-size:.95rem; }

/* ── Steps ──────────────────────────────────────────────── */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:step; }
@media (max-width:760px){ .steps{ grid-template-columns:1fr; } }
.step { position:relative; padding:34px 28px; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); }
.step .s-num { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:3.2rem; color:var(--accent); line-height:1; opacity:.9; }
.step h3 { font-size:1.3rem; margin-top:10px; }
.step p { color:var(--ink-soft); margin-top:8px; font-size:.97rem; }

/* ── Reviews ────────────────────────────────────────────── */
.reviews-head { display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:40px; }
.gbadge { display:inline-flex; align-items:center; gap:14px; background:var(--card); border:1px solid var(--line); border-radius:16px; padding:16px 20px; box-shadow:0 8px 24px -16px rgba(18,50,77,.4); }
.gbadge .g { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:2rem; color:var(--ink); line-height:1; }
.gbadge .stars { color:var(--amber); font-size:1rem; letter-spacing:1px; }
.gbadge .sub { font-size:.82rem; color:var(--ink-soft); }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:860px){ .reviews-grid{ grid-template-columns:1fr; } }
.review { background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:26px 24px; position:relative; transition:transform .3s, box-shadow .3s; }
.review:hover { transform:translateY(-5px); box-shadow:var(--shadow); }
.review .qstars { color:var(--amber); letter-spacing:1px; font-size:.95rem; }
.review p { margin-top:12px; color:var(--ink); font-size:1rem; }
.review .who { display:flex; align-items:center; gap:12px; margin-top:18px; padding-top:16px; border-top:1px solid var(--line); }
.review .ava { width:38px; height:38px; border-radius:50%; background:var(--navy); color:#fff; display:flex; align-items:center; justify-content:center; font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:.9rem; flex:none; }
.review .who b{ display:block; font-size:.95rem; } .review .who small{ color:var(--ink-soft); font-size:.78rem; }

/* ── Contact ────────────────────────────────────────────── */
.contact { background:var(--ink); color:#fff; border-radius:32px; padding:64px 56px; position:relative; overflow:hidden; }
.contact::before { content:''; position:absolute; left:0; top:0; right:0; height:6px; background:linear-gradient(90deg,var(--accent),var(--amber)); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; }
@media (max-width:820px){ .contact{ padding:44px 28px; } .contact-grid{ grid-template-columns:1fr; gap:36px; } }
.contact h2 { color:#fff; font-size:clamp(2rem,4.5vw,3rem); }
.contact .lead { color:rgba(255,255,255,.7); margin-top:18px; font-size:1.08rem; }
.cmethods { display:flex; flex-direction:column; gap:14px; }
.cmethod { display:flex; align-items:center; gap:16px; padding:18px 20px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:16px; transition:background .25s, transform .25s, border-color .25s; }
.cmethod:hover { background:rgba(255,255,255,.09); transform:translateX(4px); border-color:rgba(255,255,255,.3); }
.cmethod .cm-ico { width:46px; height:46px; border-radius:12px; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; flex:none; }
.cmethod .cm-ico svg{ width:22px; height:22px; }
.cmethod small { display:block; color:rgba(255,255,255,.55); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; }
.cmethod b { font-family:'Bricolage Grotesque',sans-serif; font-size:1.2rem; }
.areas { margin-top:8px; }
.areas h4 { font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--amber); margin-bottom:14px; }
.area-pills { display:flex; flex-wrap:wrap; gap:8px; }
.area-pills span { font-size:.85rem; padding:7px 13px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.85); }
.contact .hours { margin-top:24px; color:rgba(255,255,255,.7); font-size:.95rem; display:flex; align-items:center; gap:.5rem; }

/* ── Footer ─────────────────────────────────────────────── */
footer { padding:56px 0 40px; }
.foot-grid { display:flex; flex-wrap:wrap; justify-content:space-between; gap:30px; align-items:flex-start; }
.foot-about { max-width:340px; }
.foot-about p { color:var(--ink-soft); font-size:.95rem; margin-top:14px; }
.foot-col h5 { font-family:'Bricolage Grotesque',sans-serif; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); margin-bottom:14px; }
.foot-col a, .foot-col p { display:block; color:var(--ink-soft); font-size:.95rem; margin-bottom:9px; }
.foot-col a:hover { color:var(--accent-deep); }
.foot-bot { margin-top:44px; padding-top:24px; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; font-size:.85rem; color:var(--ink-soft); }
.foot-bot a{ color:var(--accent-deep); font-weight:600; }

/* ── Sticky mobile call bar ─────────────────────────────── */
.callbar { position:fixed; left:0; right:0; bottom:0; z-index:55; display:none; gap:10px; padding:10px 14px calc(10px + env(safe-area-inset-bottom)); background:rgba(244,238,226,.94); backdrop-filter:blur(10px); border-top:1px solid var(--line); }
.callbar .btn{ flex:1; justify-content:center; padding:.85rem .5rem; font-size:.9rem; }
@media (max-width:760px){ .callbar{ display:flex; } body{ padding-bottom:76px; } }

/* ── Logo image tile (HANDYMAN4YOU emblem) ──────────────── */
.logo-mark { width:46px; height:46px; flex:none; border-radius:12px; object-fit:cover; background:#fff; border:1px solid var(--line); box-shadow:0 4px 12px -6px rgba(18,50,77,.4); }
.mobile-menu .logo-text b{ color:#fff; } .mobile-menu .logo-text span{ color:rgba(255,255,255,.6); }

/* ── Big quote (promise block) ──────────────────────────── */
.big-quote { font-family:'Bricolage Grotesque',sans-serif; font-weight:600; font-size:clamp(1.5rem,3vw,2.1rem); line-height:1.22; letter-spacing:-0.01em; color:#fff; margin-top:14px; }
.big-quote .hl { color:var(--amber); }

/* ── Reviews: twin badges + CTA ─────────────────────────── */
.badge-stack { display:flex; flex-direction:column; gap:12px; }
.reviews-cta { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:40px; }

/* ── Booking / availability ─────────────────────────────── */
.booking-grid { display:grid; grid-template-columns:1.45fr 1fr; gap:22px; align-items:start; }
@media (max-width:860px){ .booking-grid{ grid-template-columns:1fr; } }

.cal-card { background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px 24px 22px; box-shadow:0 10px 30px -22px rgba(18,50,77,.5); }
.cal-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.cal-title { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:1.25rem; color:var(--navy); }
.cal-nav { width:40px; height:40px; border-radius:11px; border:1px solid var(--line); background:var(--paper-2); color:var(--navy); font-size:1.3rem; line-height:1; cursor:pointer; transition:background .2s,border-color .2s; }
.cal-nav:hover { background:var(--accent-soft); border-color:var(--accent); color:var(--accent-deep); }
.cal-nav:disabled { opacity:.3; cursor:default; }
.cal-dow { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-bottom:6px; }
.cal-dow span { text-align:center; font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.cal-cell { aspect-ratio:1/1; border-radius:10px; display:flex; align-items:center; justify-content:center; font-weight:600; font-size:.95rem; border:1px solid transparent; }
.cal-cell.empty { background:transparent; }
.cal-cell.past { color:var(--line-strong); }
.cal-cell.closed { color:#b9b2a4; background:repeating-linear-gradient(45deg, rgba(27,26,22,0.03) 0 4px, transparent 4px 8px); }
.cal-cell.booked { color:#a99f8d; background:rgba(27,26,22,0.045); text-decoration:line-through; text-decoration-thickness:1px; }
.cal-cell.open { color:var(--accent-deep); background:var(--accent-soft); border-color:rgba(255,90,31,.35); cursor:pointer; font-weight:800; transition:transform .15s, box-shadow .15s; }
.cal-cell.open:hover { transform:translateY(-2px); box-shadow:0 8px 16px -8px rgba(255,90,31,.6); }
.cal-cell.selected { background:var(--accent); color:#fff; border-color:var(--accent); box-shadow:0 8px 18px -6px rgba(255,90,31,.6); }
.cal-legend { display:flex; flex-wrap:wrap; gap:16px; margin-top:16px; font-size:.8rem; color:var(--ink-soft); }
.cal-legend span { display:inline-flex; align-items:center; gap:.4rem; }
.cal-legend .dot { width:11px; height:11px; border-radius:3px; display:inline-block; }
.cal-legend .dot.open { background:var(--accent-soft); border:1px solid rgba(255,90,31,.5); }
.cal-legend .dot.booked { background:rgba(27,26,22,0.12); }
.cal-legend .dot.closed { background:repeating-linear-gradient(45deg,#ddd 0 3px,transparent 3px 6px); }
.cal-foot { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:12px; margin-top:18px; padding-top:18px; border-top:1px dashed var(--line-strong); }
#calMsg { font-weight:600; color:var(--navy); font-size:.95rem; }
#calMsg b { color:var(--accent-deep); }

.coverage-card { background:var(--navy); color:#fff; border-radius:var(--r); padding:30px 28px; }
.coverage-card h3 { color:#fff; font-size:1.5rem; }
.coverage-card > p { color:rgba(255,255,255,.7); margin-top:8px; font-size:.98rem; }
.cov-form { display:flex; gap:10px; margin-top:18px; }
.cov-form input { flex:1; min-width:0; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.2); border-radius:12px; padding:.85rem 1rem; color:#fff; font-family:inherit; font-size:1rem; text-transform:uppercase; }
.cov-form input::placeholder { color:rgba(255,255,255,.45); text-transform:none; }
.cov-form input:focus { outline:none; border-color:var(--amber); }
.cov-result { margin-top:16px; padding:14px 16px; border-radius:12px; font-weight:600; font-size:.95rem; }
.cov-result.yes { background:rgba(242,169,0,.16); border:1px solid rgba(242,169,0,.5); color:#ffe7b0; }
.cov-result.maybe { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.2); color:#fff; }
.cov-areas { margin-top:24px; }
.cov-areas h4 { font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--amber); margin-bottom:12px; }
.cov-areas .area-pills span { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); color:rgba(255,255,255,.85); }

/* ── Contact mini-badges + enquiry form ─────────────────── */
.contact-badges { display:flex; flex-wrap:wrap; gap:12px; margin-top:22px; }
.mini-badge { display:inline-flex; align-items:center; gap:.5rem; padding:9px 15px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16); font-size:.85rem; color:rgba(255,255,255,.85); transition:border-color .2s, background .2s; }
.mini-badge:hover { border-color:rgba(255,255,255,.4); background:rgba(255,255,255,.1); }
.mini-badge b { font-family:'Bricolage Grotesque',sans-serif; color:var(--amber); }
.enquiry { display:flex; flex-direction:column; gap:14px; align-self:start; }
.enquiry label { display:block; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.6); font-weight:600; }
.enquiry input, .enquiry textarea { width:100%; margin-top:7px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16); border-radius:12px; padding:.85rem 1rem; color:#fff; font-family:inherit; font-size:1rem; resize:vertical; }
.enquiry input::placeholder, .enquiry textarea::placeholder { color:rgba(255,255,255,.4); }
.enquiry input:focus, .enquiry textarea:focus { outline:none; border-color:var(--amber); background:rgba(255,255,255,.09); }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:480px){ .field-row{ grid-template-columns:1fr; } }
.enquiry-note { font-size:.9rem; color:var(--amber); font-weight:600; min-height:1px; margin:0; }

/* ── Reveal animation ───────────────────────────────────── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } .strip .track{ animation:none; } }
