/* App CSS — layered on top of existing /css/styles.css.
 * Supports BOTH light and dark modes with equal contrast & readability (spec §41).
 * Every var used in the app has both a light and dark value; nothing depends on OS-dictated colors.
 */
:root{
  --brand:#0052CC;
  --brand-dark:#003d99;
  --brand-soft:rgba(0,82,204,.08);
  --wa:#25D366;
  --wa-dark:#1ebe5b;

  /* LIGHT (default) */
  --bg:#ffffff;
  --bg-soft:#f6f8fb;
  --ink:#111111;
  --text:#111111;
  --muted:#6b7280;
  --border:#e5e7eb;
  --card-bg:#ffffff;
  --input-bg:#ffffff;
  --input-ink:#111111;
  --input-border:#d1d5db;
  --placeholder:#9ca3af;
  --shadow:0 6px 24px rgba(17,24,39,.08);

  /* Status colors (spec §58) */
  --status-pending:#F59E0B;
  --status-quoted:#3B82F6;
  --status-payment_pending:#F97316;
  --status-paid:#22C55E;
  --status-confirmed:#16A34A;
  --status-completed:#065F46;
  --status-cancelled:#DC2626;

  --success:#16a34a;
  --warn:#d97706;
  --danger:#dc2626;
  --radius:12px;

  /* Legacy styles.css var overrides */
  --bg-primary:#ffffff;
  --bg-secondary:#f8f9fa;
  --bg-light:#f8f9fa;
  --text-primary:#111111;
  --text-secondary:#666666;
  --text-muted:#9a9a9a;
  --border-color:#e0e0e0;
  --footer-bg:#0d0f14;
  --footer-text:#e0e0e0;
}

@media (prefers-color-scheme: dark) {
  :root{
    --bg:#0f1115;
    --bg-soft:#171a21;
    --ink:#f4f6fa;
    --text:#f4f6fa;
    --muted:#9aa3b2;
    --border:#2a2f3a;
    --card-bg:#1a1d25;
    --input-bg:#14171e;
    --input-ink:#f4f6fa;
    --input-border:#3a4150;
    --placeholder:#6b7280;
    --shadow:0 6px 24px rgba(0,0,0,.55);

    --bg-primary:#0f1115;
    --bg-secondary:#171a21;
    --bg-light:#171a21;
    --text-primary:#f4f6fa;
    --text-secondary:#c9cfd9;
    --text-muted:#9aa3b2;
    --border-color:#2a2f3a;
    --footer-bg:#070809;
    --footer-text:#e0e0e0;
  }
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html, body { background-color:var(--bg); color:var(--ink); }
body{
  margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.6;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:12px;padding:4px 0;text-decoration:none;}
.brand:hover{text-decoration:none;}
.brand-name{font-weight:800;letter-spacing:.02em;color:var(--ink);font-size:17px;line-height:1.1;white-space:nowrap;}
.brand img, .logo, .footer-logo{
  height:45px;width:45px;min-width:45px;object-fit:cover;border-radius:50%;
  display:block;background:#ffffff;padding:2px;border:1px solid var(--border);
}
.footer-logo{margin-bottom:10px;}
@media (max-width:480px){
  .brand-name{font-size:14px;letter-spacing:0;}
}
.nav-menu{display:flex;align-items:center;gap:20px}
.nav-menu a{color:var(--ink);font-weight:500}
.nav-menu a.active{color:var(--brand)}
.btn-cta{background:var(--brand);color:#fff!important;padding:10px 18px;border-radius:999px;font-weight:600}
.btn-cta:hover{background:var(--brand-dark);text-decoration:none}
.nav-toggle{display:none;background:none;border:0;width:40px;height:40px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer}
.nav-toggle span{display:block;height:2px;background:var(--ink)}
@media (max-width:840px){
  .nav-toggle{display:flex}
  .nav-menu{position:fixed;inset:68px 0 auto 0;background:var(--bg);flex-direction:column;align-items:stretch;padding:16px 20px;transform:translateY(-120%);transition:transform .25s ease;border-bottom:1px solid var(--border)}
  body.nav-open .nav-menu{transform:translateY(0)}
  .nav-menu a{padding:12px 6px;border-bottom:1px solid var(--border)}
  .btn-cta{text-align:center;margin-top:6px}
}

/* Hero */
/* ===== Hero (Blacklane-style) — full-bleed luxury photo + floating card ===== */
.hero{
  position:relative;
  padding:0;
  color:#fff;
  display:flex;
  align-items:center;
  min-height:640px;
  background-color:#0b1a3a;
  background-image:
    /* Soft right-side darken so the white card has contrast against the photo */
    linear-gradient(95deg, rgba(6,16,36,.55) 0%, rgba(6,16,36,.20) 35%, rgba(6,16,36,.35) 100%),
    url('/images/hero-image.webp');
  background-position:center, 60% center;
  background-repeat:no-repeat, no-repeat;
  background-size:cover, cover;
}
.hero .hero-text{
  position:relative;z-index:1;
  flex:1 1 auto;
  align-self:center;
  padding:80px 32px 80px max(20px, calc((100vw - 1200px) / 2 + 20px));
  max-width:none;
  margin:0;
}
.hero .hero-text > *{max-width:540px;}
/* Eyebrow tag — small categorical marker above the headline */
.hero .hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;
  background:rgba(255,255,255,.10);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.18);
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:#e6edf7;margin-bottom:18px;
}
.hero .hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.18);}

.hero h1{
  font-size:56px;line-height:1.04;letter-spacing:-0.025em;font-weight:700;
  margin:0 0 16px;
  text-shadow:0 2px 24px rgba(0,0,0,.25);
}
.hero p.lead{
  font-size:18px;line-height:1.55;opacity:.92;margin:0 0 28px;max-width:50ch;
}

.hero .hero-trust{
  margin:14px 0 0;font-size:13px;color:rgba(255,255,255,.78);
  display:flex;flex-wrap:wrap;gap:6px 14px;
}

/* Floating booking card — Blacklane-style, generous padding, deep shadow */
.hero #quick-book{
  flex:0 0 360px;
  align-self:center;
  position:relative;z-index:2;
  padding:0;
  margin-right:16px;
}
.hero #quick-book .quick-book{
  width:100%;
  background:var(--card-bg);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:12px;
  padding:20px 18px 18px;
  box-shadow:0 24px 48px -12px rgba(0,0,0,.45), 0 8px 16px -8px rgba(0,0,0,.35);
}
.hero #quick-book .quick-book h3{
  font-size:18px;font-weight:700;margin:0 0 2px;color:var(--text);letter-spacing:-0.01em;
}
.hero #quick-book .quick-book h3 + .quick-book-sub,
.hero #quick-book .quick-book-sub{
  font-size:12px;color:var(--muted);margin:0 0 12px;
}
.hero #quick-book .quick-book .field{margin-bottom:8px;gap:4px;}
.hero #quick-book .quick-book .field label{
  color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
}
.hero #quick-book .quick-book .field input,
.hero #quick-book .quick-book .field select,
.hero #quick-book .quick-book .field textarea{
  background:var(--input-bg);color:var(--input-ink);border:1px solid var(--input-border);
  padding:9px 11px;font-size:14px;border-radius:8px;
}
.hero #quick-book .quick-book .field textarea{min-height:54px;}
.hero #quick-book .quick-book .row2{gap:8px;}
.hero #quick-book .quick-book button[type=submit]{padding:11px 14px !important;font-size:14px !important;margin-top:4px;}
.hero #quick-book .quick-book .field input:focus,
.hero #quick-book .quick-book .field textarea:focus{
  border-color:var(--brand);outline:0;box-shadow:0 0 0 3px rgba(0,82,204,.18);
}
.hero h1{font-size:44px;line-height:1.12;margin:0 0 14px}
.hero p.lead{font-size:18px;opacity:.95;margin:0 0 22px;max-width:52ch}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:12px}
.btn{display:inline-block;padding:12px 22px;border-radius:10px;font-weight:600;border:0;cursor:pointer;font-size:15px}
.btn-primary{background:#fff;color:var(--brand)}
.btn-primary:hover{background:#e8eefc;text-decoration:none}
.btn-outline{background:transparent;color:#fff;border:2px solid #fff}
.btn-outline:hover{background:#fff;color:var(--brand);text-decoration:none}
.hero-badges{
  list-style:none;padding:0;margin:28px 0 0;
  display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:10px 18px;
  font-size:14px;
  max-width:540px;
}
.hero-badges li{
  display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.94);
  line-height:1.3;
}
.hero-badges li svg{
  width:18px;height:18px;flex:none;color:#22c55e;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.25));
}
/* Small laptops / large tablets */
@media (max-width:1024px) and (min-width:769px){
  .hero{min-height:520px}
  .hero #quick-book{flex-basis:320px;margin-right:12px;}
  .hero .hero-text{padding:56px 24px 56px 24px;}
  .hero h1{font-size:42px}
  .hero p.lead{font-size:16px}
  .hero-badges{grid-template-columns:1fr;gap:8px;font-size:13px;margin-top:20px;}
  .hero .hero-trust{font-size:12px;}
}

/* Below 768px — stack vertically, form sits below text as a normal card. */
@media (max-width:768px){
  .hero{
    flex-direction:column;
    align-items:stretch;
    min-height:0;
    padding-bottom:32px;
  }
  .hero .hero-text{
    padding:56px 20px 32px;
    align-self:auto;
  }
  .hero .hero-text > *{max-width:none;}
  .hero h1{font-size:36px;}
  .hero #quick-book{
    flex:0 0 auto;
    margin:0 20px;
    padding:0;
  }
}

@media (max-width:600px){
  .hero{padding-bottom:24px;}
  .hero .hero-text{padding:36px 16px 24px}
  .hero h1{font-size:32px;line-height:1.15;margin-bottom:10px;letter-spacing:-0.02em;}
  .hero p.lead{font-size:15px;margin-bottom:18px}
  .hero .hero-eyebrow{font-size:11px;padding:5px 10px;margin-bottom:14px;}
  .hero .cta-row{gap:8px}
  .hero .cta-row .btn,.hero .cta-row .btn-wa{flex:1 1 auto;justify-content:center;text-align:center;padding:12px 16px;font-size:15px}
  .hero .hero-trust{font-size:12px;gap:4px 10px;}
  .hero-badges{grid-template-columns:1fr;gap:8px;font-size:13px;margin-top:18px;}
  .hero-badges li svg{width:16px;height:16px;}
  .hero #quick-book{margin:0 12px;}
  .hero #quick-book .quick-book{padding:20px 16px;border-radius:12px;}
  .hero #quick-book .quick-book h3{font-size:18px}
  .hero #quick-book .quick-book .field{margin-bottom:10px}
  .hero #quick-book .quick-book .row2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
}

/* Booking form card in hero — adapts to dark/light via theme vars (§101) */
.quick-book, .form-card, .booking-form, .form-wrap{
  background:var(--card-bg);color:var(--text);
  padding:24px;border-radius:12px;border:1px solid var(--border);
  box-shadow:var(--shadow);
}
.quick-book h3, .form-card h3, .booking-form h3, .form-wrap h3{margin:0 0 14px;font-size:18px;color:var(--text);}
.quick-book .field label, .form-card .field label, .booking-form .field label, .form-wrap .field label{color:var(--muted);}
.quick-book .field input,.quick-book .field select,.quick-book .field textarea,
.form-card .field input,.form-card .field select,.form-card .field textarea,
.booking-form .field input,.booking-form .field select,.booking-form .field textarea,
.form-wrap .field input,.form-wrap .field select,.form-wrap .field textarea{
  background:var(--input-bg);color:var(--input-ink);border-color:var(--input-border);
}
.quick-book .field input::placeholder,.quick-book .field textarea::placeholder,
.form-card .field input::placeholder,.form-card .field textarea::placeholder,
.booking-form .field input::placeholder,.booking-form .field textarea::placeholder,
.form-wrap .field input::placeholder,.form-wrap .field textarea::placeholder{color:var(--placeholder);}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.field label{font-size:13px;color:var(--muted);font-weight:500}
.field input,.field select,.field textarea{
  border:1px solid var(--input-border);border-radius:10px;padding:12px 14px;font-size:15px;
  background:var(--input-bg);color:var(--input-ink);font-family:inherit;
  -webkit-appearance:none;appearance:none;
}
.field input[type="date"],
.field input[type="time"]{
  -webkit-appearance:auto;
  appearance:auto;
  cursor:pointer;
  padding-right:42px;
}
.field input[type="date"]::-webkit-calendar-picker-indicator,
.field input[type="time"]::-webkit-calendar-picker-indicator{
  opacity:1;
  cursor:pointer;
}
@media (prefers-color-scheme: dark){
  .field input[type="date"]::-webkit-calendar-picker-indicator,
  .field input[type="time"]::-webkit-calendar-picker-indicator{
    filter:invert(1) brightness(1.25);
  }
}
.field input::placeholder,.field textarea::placeholder{color:var(--placeholder);opacity:1;}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--brand);outline-offset:1px;border-color:var(--brand)}
/* Select dropdown caret (since we removed native appearance) */
.field select{background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 20px) 50%,calc(100% - 15px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:38px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:480px){.row2{grid-template-columns:1fr}}

/* Sections */
section{padding:56px 0}
section h2{font-size:30px;margin:0 0 8px;text-align:center}
section .sub{text-align:center;color:var(--muted);max-width:64ch;margin:0 auto 32px}

/* Cards */
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:transform .15s ease, box-shadow .15s ease}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.card h3{margin:0 0 8px;font-size:18px}
.card p{margin:0;color:var(--muted);font-size:14px}
.icon-tile{width:44px;height:44px;border-radius:10px;background:rgba(0,82,204,.08);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-weight:700}

/* ===== Vehicle / fleet cards ===== */
.vehicle{text-align:center;padding:16px 16px 20px;}
.vehicle.card{display:flex;flex-direction:column;align-items:stretch;overflow:hidden;}
.vehicle.card p{max-width:34ch;margin-left:auto;margin-right:auto;}

/* Photo well — rounded soft-tinted box that frames the vehicle photo */
.vehicle .photo,
.vehicle img{
  display:block;width:100%;
  aspect-ratio:16/10;
  object-fit:contain;
  border-radius:14px;
  background:linear-gradient(180deg, #f1f5f9 0%, #e2e8f0 100%);
  padding:10px;
  margin:0 auto 14px;
  max-height:none;
  box-shadow:inset 0 0 0 1px rgba(15,23,42,.05);
}
@media (prefers-color-scheme: dark){
  .vehicle img{
    background:linear-gradient(180deg, #1e2230 0%, #14171e 100%);
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
  }
}

.vehicle .mt-2{margin-top:auto;padding-top:14px;}

.fleet-book-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 20px;
  border-radius:999px;
  background:var(--brand);
  color:#fff !important;
  font-size:14px;
  font-weight:700;
  line-height:1;
  text-decoration:none;
  transition:background .15s ease, transform .15s ease;
}
.fleet-book-btn:hover{background:var(--brand-dark);text-decoration:none;color:#fff !important;transform:translateY(-1px);}

@media (max-width:768px){
  .vehicle{padding:14px 14px 18px;}
  .vehicle img{aspect-ratio:16/11;padding:8px;border-radius:12px;}
  .vehicle.card h3{font-size:17px;margin-top:2px;}
  .vehicle.card p{font-size:13.5px;line-height:1.45;}
}
@media (max-width:560px){
  .vehicle .mt-2{width:100%;}
  .fleet-book-btn{width:100%;min-height:46px;}
}

/* Route cards */
.route-card{border:1px solid var(--border);border-radius:var(--radius);padding:22px;background:var(--bg)}
.route-card h3{margin:0 0 6px}
.route-card .muted{color:var(--muted);font-size:14px}
.route-card .tag{display:inline-block;background:rgba(0,82,204,.08);color:var(--brand);padding:3px 10px;border-radius:999px;font-size:12px;margin-top:8px}

/* Footer */
.site-footer{background:#0d0f14;color:#d4d7de;margin-top:56px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1.4fr 1.4fr;gap:32px;padding:42px 20px 20px}
.footer-grid h4{color:#fff;font-size:15px;margin:0 0 10px}
.footer-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.footer-grid a{color:#bcc2cc}
.footer-grid a:hover{color:#fff}
.footer-grid .muted{color:#9aa3b2}
.footer-grid .legal{flex-direction:row;gap:14px;margin-top:10px}
.copyright{text-align:center;padding:14px;border-top:1px solid #1c2029;color:#9aa3b2;font-size:13px}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* Floating action stack — keeps Book and WhatsApp aligned together.
   Hidden by default; the .is-visible class (added by app.js after the user
   scrolls past 120px) reveals them with a smooth fade + slide-up. */
.floating-actions{
  position:fixed;
  right:calc(20px + env(safe-area-inset-right));
  bottom:calc(20px + env(safe-area-inset-bottom));
  z-index:1100;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:12px;
  opacity:0;
  transform:translateY(16px);
  pointer-events:none;
  transition:opacity .28s ease, transform .28s ease;
}
.floating-actions.is-visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.floating-actions a{transition:transform .15s ease, box-shadow .15s ease, background .15s ease;}
.floating-actions a:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.32);}
@media (prefers-reduced-motion: reduce){
  .floating-actions{transition:opacity .15s linear;transform:none;}
  .floating-actions a:hover{transform:none;}
}

/* Pro WhatsApp float (spec §102) — icon-only circle */
.wa-float{position:static;}
.wa-float a{
  display:flex;align-items:center;justify-content:center;gap:0;
  background:var(--wa);color:#ffffff;
  width:54px;height:54px;padding:0;border-radius:50%;
  text-decoration:none;font-weight:600;font-size:15px;line-height:1;
  box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.wa-float a:hover{background:var(--wa-dark);text-decoration:none;color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.35);}
.wa-float img, .wa-float svg{width:20px;height:20px;display:block;flex:0 0 20px;}
@media (max-width:768px){
  .wa-float a{width:54px;height:54px;}
}

/* Sticky Book pill — secondary, sits left of WhatsApp on desktop */
.fab-book{
  display:flex;align-items:center;justify-content:center;
  background:var(--brand);color:#fff;padding:12px 22px;
  border-radius:999px;font-size:14px;font-weight:700;line-height:1;
  text-decoration:none;box-shadow:0 6px 16px rgba(0,0,0,.25);
}
.fab-book:hover{background:var(--brand-dark);color:#fff;text-decoration:none;}
@media (max-width:768px){
  .floating-actions{
    right:calc(16px + env(safe-area-inset-right));
    bottom:calc(16px + env(safe-area-inset-bottom));
    gap:10px;
  }
  .fab-book{width:54px;height:54px;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0;font-size:13px;}
}

/* Forms page */
.page-head{padding:40px 0 10px;text-align:center}
.page-head h1{margin:0 0 8px;font-size:36px}
.page-head p{color:var(--muted);max-width:64ch;margin:0 auto}

/* ===== Legal pages (privacy, terms) ===== */
.legal-doc{max-width:820px;margin:0 auto;padding:8px 4px 40px;}
.legal-doc .legal-meta{
  display:flex;flex-wrap:wrap;gap:8px 24px;font-size:13px;color:var(--muted);
  padding:14px 18px;border:1px solid var(--border);border-radius:10px;
  background:var(--bg-soft);margin-bottom:24px;line-height:1.5;
}
.legal-doc .legal-meta strong{color:var(--text);margin-right:4px;}
.legal-doc .legal-meta > span{display:inline-block;}
.legal-doc .legal-toc{
  border:1px solid var(--border);border-radius:10px;padding:20px 24px;margin:0 0 32px;
  background:var(--card-bg);
}
.legal-doc .legal-toc h2{
  font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);
  margin:0 0 12px;font-weight:700;
}
.legal-doc .legal-toc ol{
  margin:0;padding:0;list-style:none;counter-reset:toc;
  /* Use a 2-col grid (predictable) instead of CSS columns (which split items mid-line) */
  display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:8px 32px;
  font-size:14px;line-height:1.5;
}
.legal-doc .legal-toc li{
  counter-increment:toc;
  display:grid;grid-template-columns:28px 1fr;align-items:baseline;gap:8px;
  break-inside:avoid;page-break-inside:avoid;
}
.legal-doc .legal-toc li::before{
  content:counter(toc) ".";color:var(--muted);font-variant-numeric:tabular-nums;
  font-weight:600;text-align:right;
}
.legal-doc .legal-toc a{color:var(--brand);text-decoration:none;display:block;line-height:1.4;}
.legal-doc .legal-toc a:hover{text-decoration:underline;}
@media (max-width:640px){
  .legal-doc .legal-toc{padding:16px 18px;}
  .legal-doc .legal-toc ol{grid-template-columns:1fr;gap:6px;}
}
.legal-doc h2.legal-section{
  font-size:20px;margin:36px 0 10px;padding-top:16px;
  border-top:1px solid var(--border);
  scroll-margin-top:80px;
  /* Indented hanging number layout — title wraps cleanly on its own line */
  display:grid;grid-template-columns:auto 1fr;align-items:baseline;gap:10px;
  line-height:1.3;
}
.legal-doc h2.legal-section .num{
  color:var(--brand);font-variant-numeric:tabular-nums;font-weight:700;
  min-width:30px;
}
.legal-doc h3{font-size:16px;margin:18px 0 6px;color:var(--text);}
.legal-doc p, .legal-doc li{font-size:15.5px;line-height:1.7;color:var(--text-secondary, var(--text));}
.legal-doc ul, .legal-doc ol{margin:8px 0 14px;padding-left:22px;}
.legal-doc li{margin-bottom:4px;}
.legal-doc a{color:var(--brand);text-decoration:underline;text-underline-offset:3px;}
.legal-doc strong{color:var(--text);}
.legal-doc .legal-note{
  background:var(--bg-soft);border-left:3px solid var(--brand);
  padding:12px 16px;border-radius:6px;margin:14px 0;font-size:14px;
}
@media (max-width:600px){
  .legal-doc{padding:8px 0 28px;}
  .legal-doc .legal-toc ol{columns:1;}
  .legal-doc h2.legal-section{font-size:18px;margin-top:28px;}
  .legal-doc p, .legal-doc li{font-size:15px;}
}
.form-wrap{max-width:820px;margin:0 auto;background:var(--bg);border:1px solid var(--border);padding:26px;border-radius:var(--radius);box-shadow:var(--shadow)}
.notice{padding:14px 16px;border-radius:10px;margin:12px 0;font-size:14px}
.notice.ok{background:rgba(22,163,74,.08);color:var(--success);border:1px solid rgba(22,163,74,.25)}
.notice.err{background:rgba(220,38,38,.08);color:var(--danger);border:1px solid rgba(220,38,38,.25)}

/* Admin */
.admin-layout{min-height:100vh;background:var(--bg-soft);padding:24px 16px}
.admin-topbar{max-width:1280px;margin:0 auto 18px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.admin-topbar h1{margin:0;font-size:22px}

/* Admin nav — desktop top bar */
.admin-nav{display:flex;align-items:center;gap:8px}
.admin-nav-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;background:var(--bg-soft);color:var(--ink);border:1px solid var(--border);font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s}
.admin-nav-link svg{width:16px;height:16px;flex:0 0 16px}
.admin-nav-link:hover{background:var(--brand-soft);color:var(--brand);border-color:var(--brand);text-decoration:none}
.admin-nav-link.is-active{background:var(--brand);color:#fff;border-color:var(--brand)}
.admin-nav-link.is-active:hover{background:var(--brand-dark);color:#fff;border-color:var(--brand-dark)}
.admin-nav-link.is-logout{color:#dc2626;border-color:rgba(220,38,38,.35)}
.admin-nav-link.is-logout:hover{background:rgba(220,38,38,.08);color:#dc2626;border-color:#dc2626}
.admin-nav-bottom{display:none}

/* Admin nav — mobile bottom bar */
@media (max-width: 720px){
  .admin-layout{padding:16px 12px calc(76px + env(safe-area-inset-bottom)) 12px}
  .admin-topbar{margin-bottom:12px}
  .admin-topbar h1{font-size:18px;flex:1 1 auto}
  .admin-nav-top{display:none}
  .admin-nav-bottom{
    display:grid;grid-template-columns:repeat(3,1fr);gap:0;
    position:fixed;left:0;right:0;bottom:0;z-index:50;
    background:var(--bg);border-top:1px solid var(--border);
    padding:6px 4px calc(6px + env(safe-area-inset-bottom)) 4px;
    box-shadow:0 -2px 12px rgba(0,0,0,.06);
  }
  .admin-nav-bottom .admin-nav-link{
    flex-direction:column;gap:3px;padding:8px 4px;
    background:transparent;border:0;border-radius:8px;
    color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.02em;
    min-height:54px;justify-content:center;
  }
  .admin-nav-bottom .admin-nav-link svg{width:22px;height:22px;flex:0 0 22px}
  .admin-nav-bottom .admin-nav-link:hover{background:transparent;color:var(--brand);border-color:transparent}
  .admin-nav-bottom .admin-nav-link.is-active{background:var(--brand-soft);color:var(--brand);border:0}
  .admin-nav-bottom .admin-nav-link.is-logout{color:#dc2626;border:0}
  .admin-nav-bottom .admin-nav-link.is-logout:hover{background:rgba(220,38,38,.08)}
}
.admin-card{max-width:1280px;margin:0 auto;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid var(--border);text-align:left;font-size:14px;vertical-align:top}
.table th{background:var(--bg-soft);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}
.badge.pending{background:#fef3c7;color:#92400e}
.badge.quoted{background:#dbeafe;color:#1e40af}
.badge.payment_pending{background:#fde68a;color:#92400e}
.badge.paid{background:#bbf7d0;color:#166534}
.badge.confirmed{background:#bfdbfe;color:#1e3a8a}
.badge.completed{background:#e0e7ff;color:#312e81}
.badge.cancelled{background:#fee2e2;color:#991b1b}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.filters select,.filters input{border:1px solid var(--border);border-radius:10px;padding:9px 12px;font-size:14px;background:var(--bg);color:var(--ink)}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:8px;background:var(--brand);color:#fff;border:0;cursor:pointer}
.btn-sm:hover{background:var(--brand-dark);text-decoration:none;color:#fff}
.btn-ghost{background:transparent;color:var(--brand);border:1px solid var(--brand)}

/* Reusable circular WhatsApp icon (spec §78) */
.whatsapp-button {
  width: 50px; height: 50px;
  background-color: var(--wa);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex: 0 0 50px;
}
.whatsapp-button img, .whatsapp-button svg { width: 24px; height: 24px; display: block; }

/* Inline WhatsApp icon embedded inside text buttons (smaller variant) */
.whatsapp-button-inline {
  width: 22px; height: 22px;
  background-color: var(--wa);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  flex: 0 0 22px;
}
.whatsapp-button-inline svg { width: 14px; height: 14px; display: block; }

/* WhatsApp-styled CTA buttons */
.btn-wa{background:var(--wa);color:#ffffff !important;border:0;padding:12px 22px;border-radius:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;font-size:15px;line-height:1;}
.btn-wa:hover{background:var(--wa-dark);text-decoration:none;color:#ffffff;}
.btn-wa img,.btn-wa svg{width:20px;height:20px;flex:0 0 20px;display:block;}
.btn-wa-outline{background:transparent;color:#25D366 !important;border:2px solid #25D366;padding:10px 20px;border-radius:10px;font-weight:700;display:inline-flex;align-items:center;gap:10px;}
.btn-wa-outline:hover{background:#25D366;color:#ffffff !important;text-decoration:none;}
.btn-wa.pulse{position:relative;isolation:isolate;}
.btn-wa.pulse::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:#25D366;opacity:0;pointer-events:none;z-index:-1;
  animation:wa-pulse 1.6s ease-out 2 forwards;will-change:transform,opacity;
}
@keyframes wa-pulse{
  0%{transform:scale(1);opacity:.5;}
  100%{transform:scale(1.35);opacity:0;}
}

/* Consistent icon sizing */
.icon{width:20px;height:20px;vertical-align:middle;flex:0 0 20px;}
.button-icon{display:inline-flex;align-items:center;gap:8px;}

/* Utility */
.muted{color:var(--muted)}
.center{text-align:center}
.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.hidden{display:none!important}
