/* as quoted. — asquoted.co.uk — design system v2 — mobile-first */
@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Geist:wght@300;400;500;600&display=swap');

:root {
  --bg:#F5F1EA;--bg-card:#FFFFFF;--bg-soft:#EFE9DE;
  --ink:#1A1A1A;--ink-2:#4A4540;--ink-3:#8B8680;
  --line:rgba(26,26,26,0.10);--line-strong:rgba(26,26,26,0.18);
  --accent:#1C3F3A;--accent-soft:#E4EBE8;
  --success:#2D5F2C;--success-soft:#E7EFE3;
  --warn:#8A5A12;--warn-soft:#F4E9D2;
  --danger:#8A2727;--danger-soft:#F1DBDB;
  --serif:'Instrument Serif','Iowan Old Style','Baskerville',Georgia,serif;
  --sans:'Geist',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:'SF Mono',Monaco,'Cascadia Code',monospace;
  --nav-h:72px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{
  /* App-feel: no rubber-band bounce past the page, smooth iOS scrolling */
  overscroll-behavior:none;
  -webkit-text-size-adjust:100%;
}
body{
  margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overscroll-behavior-y:none;
  touch-action:manipulation; /* kills 300ms tap delay + double-tap zoom */
  overflow-x:hidden; /* guard: nothing bleeds past the screen edge */
}
/* Long words (e.g. asquoted.co.uk) wrap instead of forcing overflow */
h1,h2,h3,p,.hero-eyebrow,.section-eyebrow{overflow-wrap:break-word;}

/* ── App-feel animations ─────────────────────────────────── */
@keyframes stepIn {
  from { opacity:0; transform:translateY(12px); }
  to   { opacity:1; transform:translateY(0); }
}
.flow-step:not([hidden]) { animation: stepIn 0.28s cubic-bezier(0.22,1,0.36,1); }

@keyframes thumbIn {
  from { opacity:0; transform:scale(0.92); }
  to   { opacity:1; transform:scale(1); }
}
.photo-slot.done .photo-slot-thumb,
.upload-row.done .upload-row-thumb img { animation: thumbIn 0.3s cubic-bezier(0.22,1,0.36,1); }

@media (prefers-reduced-motion: reduce) {
  .flow-step:not([hidden]), .photo-slot.done .photo-slot-thumb,
  .upload-row.done .upload-row-thumb img { animation:none; }
}
a{color:inherit;text-decoration:none;}
a:hover{color:var(--accent);}

/* 16px on all inputs prevents iOS auto-zoom on focus */
input,select,textarea{
  font-family:var(--sans);font-size:16px;color:var(--ink);
  background:var(--bg-card);border:1px solid var(--line-strong);
  border-radius:8px;padding:14px 16px;width:100%;
  outline:none;-webkit-appearance:none;appearance:none;transition:border-color 0.15s;
}
input:focus,select:focus,textarea:focus{border-color:var(--accent);}
select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%231A1A1A' stroke-width='1.5' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:44px;
}
button{font-family:var(--sans);font-size:16px;min-height:44px;cursor:pointer;border:none;background:none;color:inherit;}

.container{max-width:1100px;margin:0 auto;padding:0 24px;}
.container-narrow{max-width:720px;margin:0 auto;padding:0 24px;}

/* Header */
.site-header{padding:18px 0;border-bottom:1px solid var(--line);}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;}
.brand{font-family:var(--serif);font-size:24px;letter-spacing:-0.02em;}
.brand-mark{font-style:italic;}
.brand-dot{color:var(--accent);}
.nav{display:flex;gap:20px;align-items:center;}
.nav a{font-size:14px;color:var(--ink-2);}
.nav .cta-link{background:var(--ink);color:var(--bg);padding:10px 18px;border-radius:999px;font-size:14px;}

/* Footer */
.site-footer{margin-top:80px;padding:40px 0 28px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-3);}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;}
.footer-links{display:flex;gap:20px;}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border-radius:999px;font-size:15px;font-weight:500;min-height:48px;transition:all 0.15s;border:1px solid transparent;}
.btn-primary{background:var(--ink);color:var(--bg);}
.btn-primary:hover{background:var(--accent);}
.btn-secondary{background:transparent;color:var(--ink);border-color:var(--line-strong);}
.btn-secondary:hover{border-color:var(--ink);}
.btn-ghost{background:transparent;color:var(--ink-2);}
.btn-ghost:hover{color:var(--ink);}
.btn-sm{padding:10px 18px;font-size:14px;min-height:40px;}

/* Hero */
.hero{padding:52px 24px 36px;}
.hero-eyebrow{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;}
.hero h1{font-family:var(--serif);font-size:clamp(40px,7vw,84px);line-height:1.02;letter-spacing:-0.025em;margin:0 0 20px;max-width:14ch;font-weight:400;}
.hero h1 em{font-style:italic;color:var(--accent);}
.hero-lede{font-size:18px;line-height:1.5;color:var(--ink-2);max-width:52ch;margin:0 0 32px;}
.hero-cta-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.hero-stats{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(3,1fr);gap:40px;}

/* Section */
.section{padding:40px 0;}
.section-eyebrow{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;}
.section h2{font-family:var(--serif);font-size:clamp(32px,5vw,56px);line-height:1.05;letter-spacing:-0.02em;font-weight:400;margin:0 0 22px;}
.section h2 em{font-style:italic;color:var(--accent);}
.section-lede{font-size:17px;line-height:1.55;color:var(--ink-2);max-width:52ch;margin:0 0 36px;}

/* Compare / steps */
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.compare-card{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:24px;}
.compare-card.them{background:var(--bg-soft);}
.compare-card h3{font-family:var(--serif);font-size:22px;margin:0 0 16px;font-weight:400;}
.compare-card.them h3{color:var(--ink-3);}
.compare-list{list-style:none;padding:0;margin:0;}
.compare-list li{padding:10px 0;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-2);line-height:1.5;}
.compare-list li:last-child{border-bottom:0;}
.tick{color:var(--success);flex-shrink:0;}
.cross{color:var(--ink-3);flex-shrink:0;}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px;}
.step-card{border-top:1px solid var(--ink);padding-top:14px;}
.step-number{font-family:var(--serif);font-size:13px;font-style:italic;color:var(--accent);margin-bottom:8px;}
.step-card h4{font-family:var(--serif);font-size:22px;font-weight:400;margin:0 0 8px;}
.step-card p{font-size:14px;color:var(--ink-2);margin:0;line-height:1.55;}

/* =====================
   SELL FLOW — MOBILE FIRST
   ===================== */

/* Sticky top progress bar */
.flow-top{
  position:sticky;top:0;z-index:50;
  background:rgba(245,241,234,0.85);
  -webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  padding:12px 20px 10px;
}
.flow-stepper{display:flex;gap:3px;margin-bottom:8px;}
.flow-stepper-bar{flex:1;height:3px;border-radius:2px;background:var(--line);transition:background 0.3s;}
.flow-stepper-bar.active{background:var(--accent);}
.flow-step-meta{font-size:12px;color:var(--ink-3);letter-spacing:0.04em;}

/* Fixed bottom nav — always reachable on mobile */
.flow-nav{
  position:fixed;bottom:0;left:0;right:0;
  background:rgba(245,241,234,0.88);
  -webkit-backdrop-filter:blur(14px);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
  padding:12px 20px;
  padding-bottom:max(12px,env(safe-area-inset-bottom));
  display:flex;gap:10px;align-items:center;z-index:100;
}
.flow-nav .btn{flex:1;}
.flow-nav .btn-ghost{flex:0 0 auto;padding:14px;}

/* Native-feel press feedback on every interactive element */
.btn:active,
.flow-nav button:active,
.declaration-options button:active,
.upload-row:active,
.video-slot:active {
  transform:scale(0.97);
  transition:transform 0.08s ease-out;
}
.btn, .declaration-options button { transition: transform 0.15s ease, background 0.15s, color 0.15s, border-color 0.15s; }

/* Content area — padded above nav */
.flow-body{
  padding:24px 20px 16px;max-width:640px;margin:0 auto;
  /* bottom padding so last field isn't behind fixed nav */
  padding-bottom:calc(var(--nav-h) + 40px);
}

.flow-h{font-family:var(--serif);font-size:32px;line-height:1.1;letter-spacing:-0.02em;font-weight:400;margin:0 0 8px;}
.flow-lede{font-size:15px;color:var(--ink-2);margin:0 0 22px;line-height:1.55;}

.flow-field{margin-bottom:16px;}
.flow-field label{display:block;font-size:14px;color:var(--ink-2);font-weight:500;margin-bottom:8px;}
.flow-field .helper{font-size:12px;color:var(--ink-3);margin-top:6px;line-height:1.4;}
.flow-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}

.indicative{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:14px 16px;display:flex;align-items:baseline;justify-content:space-between;margin-top:6px;}
.indicative-label{font-size:13px;color:var(--ink-3);}
.indicative-range{font-family:var(--serif);font-size:24px;letter-spacing:-0.01em;}

/* =====================
   FILE UPLOAD — Screenshot rows
   ===================== */
.upload-row{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;background:var(--bg-card);
  border:1px solid var(--line);border-radius:10px;
  margin-bottom:10px;position:relative;cursor:pointer;
  transition:border-color 0.15s;overflow:hidden;
}
.upload-row:active{opacity:0.85;}
.upload-row.done{background:var(--success-soft);border-color:var(--success);}
/* Full-area file input overlay */
.upload-row input[type=file]{
  position:absolute;inset:0;opacity:0;cursor:pointer;font-size:16px;
}
.upload-row-thumb{
  width:40px;height:40px;flex-shrink:0;
  background:var(--bg-soft);border-radius:8px;
  overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-style:italic;color:var(--ink-2);font-size:14px;
}
.upload-row.done .upload-row-thumb{background:transparent;}
.upload-row-thumb img{width:100%;height:100%;object-fit:cover;display:none;}
.upload-row-body{flex:1;min-width:0;}
.upload-row-title{font-size:14px;font-weight:500;margin:0;}
.upload-row-hint{font-size:12px;color:var(--ink-3);margin:2px 0 0;}
.upload-row.done .upload-row-hint{color:var(--success);}
.upload-row-status{font-size:13px;color:var(--ink-3);flex-shrink:0;}
.upload-row.done .upload-row-status{color:var(--success);font-weight:500;}

/* =====================
   FILE UPLOAD — Photo grid (camera capture)
   ===================== */
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;}
.photo-slot{
  aspect-ratio:1;border-radius:10px;
  background:var(--bg-card);border:1.5px dashed var(--line-strong);
  cursor:pointer;position:relative;overflow:hidden;
  transition:all 0.15s;
}
.photo-slot:active{transform:scale(0.96);}
.photo-slot.done{border-style:solid;border-color:var(--success);}
/* Thumbnail fills the slot */
.photo-slot-thumb{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
/* Overlay text/icon */
.photo-slot-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:4px;padding:6px;
}
.photo-slot.done .photo-slot-overlay{background:rgba(26,26,26,0.32);}
.photo-slot-icon{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-3);line-height:1;}
.photo-slot.done .photo-slot-icon{color:#fff;font-style:normal;font-size:18px;}
.photo-slot-label{font-size:10px;color:var(--ink-3);text-align:center;line-height:1.3;padding:0 2px;}
.photo-slot.done .photo-slot-label{color:#fff;font-weight:500;}
/* Full-area file input */
.photo-slot input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;font-size:16px;}

/* =====================
   VIDEO UPLOAD
   ===================== */
.video-slot{
  background:var(--bg-card);border:1.5px dashed var(--line-strong);
  border-radius:12px;padding:28px 20px;text-align:center;
  cursor:pointer;position:relative;overflow:hidden;transition:all 0.15s;
}
.video-slot:active{opacity:0.8;}
.video-slot.done{border-style:solid;border-color:var(--success);background:var(--success-soft);}
.video-slot input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;font-size:16px;}
.video-slot-icon{font-family:var(--serif);font-style:italic;font-size:38px;color:var(--ink-3);margin-bottom:10px;line-height:1;}
.video-slot.done .video-slot-icon{color:var(--success);}
.video-slot-title{font-size:15px;font-weight:500;margin-bottom:4px;}
.video-slot.done .video-slot-title{color:var(--success);}
.video-slot-hint{font-size:12px;color:var(--ink-3);line-height:1.5;max-width:36ch;margin:0 auto;}
.video-slot-filename{font-size:13px;color:var(--success);margin-top:10px;font-weight:500;}

/* =====================
   DECLARATIONS
   ===================== */
.declaration{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 0;border-bottom:1px solid var(--line);}
.declaration:last-child{border-bottom:0;}
.declaration-label{font-size:15px;flex:1;line-height:1.4;}
.declaration-options{display:flex;gap:6px;flex-shrink:0;}
.declaration-options button{padding:8px 16px;border-radius:999px;border:1px solid var(--line-strong);background:transparent;font-size:14px;font-weight:500;min-height:40px;min-width:54px;}
.declaration-options button.active{background:var(--ink);color:var(--bg);border-color:var(--ink);}

/* Callout */
.callout{border-radius:10px;padding:12px 14px;font-size:13px;line-height:1.55;}
.callout-info{background:var(--accent-soft);color:var(--accent);}
.callout-warn{background:var(--warn-soft);color:var(--warn);}
.callout-success{background:var(--success-soft);color:var(--success);}

/* Pending quote card (replaces instant quote) */
.pending-card{background:var(--bg-card);border:1px solid var(--line);border-radius:16px;padding:32px 22px;text-align:center;margin-bottom:20px;position:relative;overflow:hidden;}
.pending-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent);}
.pending-eyebrow{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.pending-label{font-size:15px;color:var(--ink-2);margin-bottom:6px;}
.pending-range{font-family:var(--serif);font-size:44px;line-height:1;font-weight:400;letter-spacing:-0.02em;}
.pending-range em{font-style:italic;color:var(--accent);}
.pending-note{font-size:13px;color:var(--ink-3);margin-top:14px;line-height:1.5;}

/* Confirmation */
.confirm-mark{width:60px;height:60px;margin:0 auto 18px;background:var(--success);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:28px;}
.confirm-ref{font-family:var(--mono);font-size:13px;color:var(--ink-2);background:var(--bg-soft);padding:4px 10px;border-radius:6px;display:inline-block;}
.confirm-steps{background:var(--bg-soft);border-radius:12px;padding:20px;margin-top:22px;}
.confirm-step{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);}
.confirm-step:last-child{border-bottom:0;}
.confirm-step-num{font-family:var(--serif);font-style:italic;font-size:17px;color:var(--accent);flex-shrink:0;width:20px;}
.confirm-step-title{font-weight:500;font-size:14px;margin:0 0 2px;}
.confirm-step-detail{font-size:13px;color:var(--ink-2);margin:0;}

/* =====================
   ADMIN
   ===================== */
.admin-shell{padding:24px 0 80px;}
.admin-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px;}
.admin-header h1{font-family:var(--serif);font-size:38px;font-weight:400;margin:0;letter-spacing:-0.02em;}
.admin-actions{display:flex;gap:8px;}
.admin-actions button{font-size:13px;padding:8px 14px;border-radius:999px;background:transparent;border:1px solid var(--line-strong);cursor:pointer;font-family:inherit;color:var(--ink);}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px;}
.stat-card{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:14px;}
.stat-label{font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:5px;}
.stat-value{font-family:var(--serif);font-size:28px;font-weight:400;letter-spacing:-0.02em;line-height:1;}
.admin-tools{display:flex;gap:8px;margin-bottom:14px;align-items:center;flex-wrap:wrap;}
.admin-search{flex:1;min-width:160px;max-width:260px;}
.admin-filter{font-size:13px;padding:7px 13px;border-radius:999px;background:transparent;border:1px solid var(--line-strong);cursor:pointer;font-family:inherit;color:var(--ink);}
.pager-btn{font-size:13px;padding:8px 16px;border-radius:999px;background:transparent;border:1px solid var(--line-strong);cursor:pointer;font-family:inherit;color:var(--ink);min-height:40px;}
.pager-btn:hover:not([disabled]){border-color:var(--ink);}
.admin-filter.active{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.submission{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:16px 20px;margin-bottom:10px;display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;cursor:pointer;transition:border-color 0.15s;}
.submission:hover{border-color:rgba(26,26,26,0.3);}
.submission-model{font-family:var(--serif);font-size:19px;font-weight:400;margin:0 0 3px;}
.submission-model span{color:var(--ink-3);font-size:14px;}
.submission-meta{font-size:12px;color:var(--ink-3);line-height:1.5;}
.submission-flags{margin-top:8px;display:flex;gap:5px;flex-wrap:wrap;}
.flag{font-size:10px;padding:2px 8px;border-radius:999px;background:var(--warn-soft);color:var(--warn);font-weight:500;}
.submission-right{text-align:right;}
.submission-quote{font-family:var(--serif);font-size:26px;font-weight:400;letter-spacing:-0.01em;}
.submission-conditions{font-size:11px;color:var(--ink-3);margin-top:3px;}
.status-badge{display:inline-block;font-size:10px;padding:3px 8px;border-radius:999px;margin-top:5px;font-weight:500;}
.status-awaiting-shipment{background:var(--warn-soft);color:var(--warn);}
.status-quote-sent{background:var(--accent-soft);color:var(--accent);}
.status-accepted{background:var(--success-soft);color:var(--success);}
.status-paid{background:var(--success-soft);color:var(--success);}
.status-declined{background:var(--danger-soft);color:var(--danger);}

.empty-state{text-align:center;padding:56px 24px;background:var(--bg-card);border-radius:12px;border:1px dashed var(--line-strong);}
.empty-mark{font-family:var(--serif);font-style:italic;font-size:48px;color:var(--ink-3);margin-bottom:12px;}
.quote-send-box{background:var(--accent-soft);border-radius:10px;padding:18px;margin-top:24px;}
.quote-send-box h4{font-family:var(--serif);font-size:18px;font-weight:400;margin:0 0 10px;color:var(--accent);}
.quote-send-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.quote-send-input{max-width:130px !important;width:130px !important;}
.quote-send-btn{background:var(--accent);color:#fff;padding:12px 18px;border-radius:999px;font-size:14px;font-weight:500;white-space:nowrap;min-height:48px;cursor:pointer;border:0;font-family:var(--sans);}

@media(max-width:680px){
  /* Comfortable, even side gutters on phones */
  .container,.container-narrow{padding:0 20px;}

  /* Hero: smaller cap on the headline so it never touches the edges */
  .hero{padding:40px 20px 28px;}
  .hero h1{font-size:clamp(34px,8.5vw,48px);line-height:1.06;letter-spacing:-0.02em;max-width:none;}
  .hero-lede{font-size:16px;}
  .hero-eyebrow{margin-bottom:18px;}

  /* Hero stats: tighter spacing on phones */
  .hero-stats{margin-top:28px;gap:20px;}

  /* Section headings scale down so they breathe inside the gutters */
  .section{padding:36px 0;}
  .section h2{font-size:clamp(28px,7vw,40px);line-height:1.08;}
  .section-lede{font-size:16px;}

  /* CTA buttons go full-width and stack for easy thumbing */
  .hero .btn,.section .btn{width:100%;justify-content:center;}
  .hero-cta-row{flex-direction:column;align-items:stretch;}

  /* Layout simplifications */
  .compare-grid,.steps-grid{grid-template-columns:1fr;}
  .admin-stats{grid-template-columns:repeat(2,1fr);}
  .submission{grid-template-columns:1fr;gap:10px;}
  .submission-right{text-align:left;}
  .flow-field-row{grid-template-columns:1fr;}
  .nav a:not(.cta-link){display:none;}

  /* Tighten the header so the logo + CTA sit comfortably */
  .site-header{padding:16px 0;}
  .brand{font-size:22px;}
  .nav .cta-link{padding:9px 15px;font-size:13px;}
}

/* Very small phones (iPhone SE, ~320–375px) */
@media(max-width:380px){
  .container,.container-narrow{padding:0 18px;}
  .hero{padding:40px 18px 28px;}
  .hero h1{font-size:30px;}
  .hero-stats{grid-template-columns:1fr 1fr;gap:20px;}
}
@media(min-width:681px){
  .flow-body{padding:32px 32px calc(var(--nav-h) + 56px);}
  .flow-h{font-size:38px;}
  .photo-grid{gap:12px;}
}

/* ── Content / legal pages ──────────────────────────────── */
.content-page{max-width:720px;margin:0 auto;padding:48px 24px 80px;}
.content-page h1{font-family:var(--serif);font-size:clamp(32px,6vw,48px);font-weight:400;letter-spacing:-0.02em;line-height:1.1;margin:0 0 8px;}
.content-page .updated{font-size:13px;color:var(--ink-3);margin:0 0 36px;}
.content-page h2{font-family:var(--serif);font-size:24px;font-weight:400;letter-spacing:-0.01em;margin:36px 0 12px;}
.content-page h3{font-size:16px;font-weight:600;margin:24px 0 8px;color:var(--ink);}
.content-page p{font-size:15px;line-height:1.7;color:var(--ink-2);margin:0 0 14px;}
.content-page ul{margin:0 0 14px;padding-left:22px;}
.content-page li{font-size:15px;line-height:1.7;color:var(--ink-2);margin-bottom:6px;}
.content-page a{color:var(--accent);}
.content-page strong{color:var(--ink);}
.content-page .intro{font-size:17px;line-height:1.6;color:var(--ink-2);margin-bottom:28px;}
.content-page .callout-box{background:var(--bg-soft);border-radius:10px;padding:16px 18px;margin:18px 0;font-size:14px;line-height:1.65;color:var(--ink-2);}

/* FAQ accordion */
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:18px 0;font-family:var(--sans);font-size:16px;font-weight:500;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:auto;}
.faq-q::after{content:'+';font-size:22px;color:var(--accent);flex-shrink:0;transition:transform 0.2s;font-weight:400;}
.faq-item.open .faq-q::after{content:'−';}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.25s ease;}
.faq-item.open .faq-a{max-height:600px;}
.faq-a-inner{padding:0 0 18px;font-size:15px;line-height:1.7;color:var(--ink-2);}
.faq-a-inner p{margin:0 0 10px;}
.faq-a-inner p:last-child{margin:0;}
