/* ============================================================
   Maxicom Universal Design System v2.0 — premium UX
   Editorial trading-house voice with modern polish.
   Mobile sticky · RTL support · Reduced-motion aware.
   ============================================================ */

:root{
  /* ---- Brand palette — deeper, more layered ---- */
  --green:#1f3d33;
  --green-2:#2a4f42;
  --green-3:#3a6657;
  --green-light:#5a8c7c;
  --green-deep:#0d2620;
  --gold:#b8924a;
  --gold-2:#d1a85a;
  --gold-light:#e3c98c;
  --gold-soft:#f3e9d2;
  --rust:#a14b2a;
  --rust-2:#c66a45;
  --plum:#5a334a;

  /* ---- Ink / text ---- */
  --ink:#10211c;
  --ink-2:#2a3d36;
  --ink-3:#4a5b53;
  --muted:#6b7b73;
  --muted-2:#8a958f;

  /* ---- Surface ---- */
  --paper:#faf6ec;
  --paper-2:#fdfaf3;
  --paper-3:#f5f0df;
  --line:#e8e1cd;
  --line-2:#d4ccb2;
  --bg:#ffffff;
  --bg-alt:#fbf9f3;
  --bg-deep:#f7f1df;
  --bg-dark:#0e2620;
  --bg-charcoal:#1a2723;

  /* ---- Status ---- */
  --ok:#1f7a4a; --warn:#9a6b00; --bad:#a4231b;
  --ok-bg:#e7f4ec; --warn-bg:#fff7df; --bad-bg:#fdecea;

  /* ---- Type ---- */
  --serif:"Source Serif 4",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:"Source Serif 4",Georgia,"Times New Roman",serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;

  /* ---- Layout ---- */
  --container:1200px;
  --container-narrow:760px;
  --container-prose:680px;

  /* ---- Radius ---- */
  --r-sm:4px; --r-md:8px; --r-lg:14px; --r-xl:20px;

  /* ---- Layered shadows ---- */
  --shadow-xs:0 1px 1px rgba(20,30,25,.04);
  --shadow-sm:0 1px 3px rgba(20,30,25,.06), 0 1px 2px rgba(20,30,25,.04);
  --shadow-md:0 4px 14px rgba(20,30,25,.08), 0 2px 6px rgba(20,30,25,.04);
  --shadow-lg:0 12px 32px rgba(20,30,25,.10), 0 6px 14px rgba(20,30,25,.06);
  --shadow-xl:0 24px 48px rgba(20,30,25,.12), 0 10px 20px rgba(20,30,25,.06);
  --shadow-glow:0 0 0 1px rgba(184,146,74,.18), 0 6px 24px rgba(184,146,74,.12);

  /* ---- Curves ---- */
  --ease-out:cubic-bezier(.2,.8,.2,1);
  --ease-in-out:cubic-bezier(.4,0,.2,1);
}

/* ============ Reset / base ============ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:15.5px;line-height:1.6;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none;transition:color .2s var(--ease-out)}
a:hover{color:var(--rust)}
hr{border:0;border-top:1px solid var(--line);margin:32px 0}
::selection{background:var(--gold-soft);color:var(--ink)}

/* ============ RTL ============ */
[dir="rtl"]{font-family:"Noto Naskh Arabic","SF Arabic",-apple-system,sans-serif}
[dir="rtl"] .container,[dir="rtl"] section{direction:rtl}
[dir="rtl"] .nav-cta::after{content:"\2190";margin-right:6px;margin-left:0}
[dir="rtl"] .skip-to-main{right:auto;left:8px}
[dir="rtl"] .mobile-quickbar{direction:rtl}
[dir="rtl"] .btn-primary::after,[dir="rtl"] .arrow-link::after{content:"\2190"}
[dir="rtl"] .ornament-arrow{transform:scaleX(-1)}

/* ============ Typography — premium scale ============ */
h1,h2,h3,h4,h5{font-family:var(--serif);color:var(--green);font-weight:500;letter-spacing:-.018em;margin:0 0 14px}
h1{font-size:clamp(34px,4.6vw,52px);line-height:1.04;letter-spacing:-.025em;font-weight:500}
h1 em{font-style:italic;color:var(--rust);font-weight:400}
h1 .strong{font-weight:700;color:var(--green-deep)}
h2{font-size:clamp(26px,3.2vw,36px);line-height:1.12;font-weight:500;letter-spacing:-.018em}
h2 em{font-style:italic;color:var(--rust);font-weight:400}
h2 .strong{font-weight:700;color:var(--green-deep)}
h3{font-size:clamp(18px,1.7vw,22px);line-height:1.3;font-weight:600;letter-spacing:-.005em}
h3 em{font-style:italic;color:var(--rust)}
h4{font-size:16.5px;line-height:1.35;font-weight:700;letter-spacing:.01em}

p{margin:0 0 16px}
.lead{
  font-family:var(--serif);font-size:clamp(17px,1.8vw,21px);line-height:1.55;
  color:var(--ink-2);margin:8px 0 14px;max-width:720px;font-weight:400;
}
/* "Supporting detail" — the regulator-citation tail that follows the punchy lead.
   Smaller, lower-contrast, sans-serif, so it reads as evidence rather than
   competing with the punchy lead sentence. */
.lead-detail{
  font-family:var(--sans);font-size:13.5px;line-height:1.6;
  color:var(--muted);max-width:720px;margin:0 0 22px;font-weight:400;
  border-left:2px solid var(--gold-light);padding:4px 0 4px 12px;
  background:rgba(184,146,74,.03);
}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin:0 0 12px;
}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--gold);display:inline-block;opacity:.7}
.eyebrow.center{justify-content:center;display:flex}
.eyebrow.center::after{content:"";width:18px;height:1px;background:var(--gold);display:inline-block;opacity:.7}
.eyebrow.no-line::before,.eyebrow.no-line::after{display:none}

/* ============ Layout ============ */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 24px}
.pad{padding:72px 0;position:relative}
.pad-tight{padding:36px 0}
.pad-lg{padding:96px 0}
.pad.alt{background:var(--bg-alt)}
.pad.cream{background:var(--paper)}
.pad.deep{background:linear-gradient(180deg,var(--paper),var(--bg-deep) 60%,var(--paper-3));position:relative}
.pad.deep::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 0%,rgba(184,146,74,.08),transparent 50%);pointer-events:none}
.pad.dark{background:var(--bg-dark);color:#f5f1e8;position:relative;overflow:hidden}
.pad.dark::before{content:"";position:absolute;top:-20%;right:-10%;width:50%;height:80%;background:radial-gradient(ellipse,rgba(184,146,74,.10),transparent 60%);pointer-events:none}
.pad.dark h1,.pad.dark h2,.pad.dark h3{color:#f5f1e8}
.pad.dark h2 em{color:var(--gold-2)}

.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
@media (max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr;gap:32px}}
@media (max-width:680px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ============ Skip link & accessibility ============ */
.skip-to-main{position:absolute;top:8px;right:8px;left:8px;padding:10px 16px;background:var(--green-deep);color:#fff;text-align:center;border-radius:var(--r-sm);font-size:13px;font-weight:600;transform:translateY(-110%);transition:transform .2s var(--ease-out);z-index:100}
.skip-to-main:focus{transform:translateY(0);color:#fff;outline:2px solid var(--gold);outline-offset:2px}
*:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:3px}

/* ============ Header — refined sticky with backdrop ============ */
header.site-header{
  background:rgba(255,255,255,.92);backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;
}
header.site-header::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-light) 20%,var(--gold-light) 80%,transparent);opacity:.5}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:14px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:14px;line-height:1.1;color:var(--ink);text-decoration:none;transition:opacity .2s var(--ease-out)}
.brand:hover{opacity:.85}
.brand-mark{width:44px;height:44px;flex:0 0 auto;display:block;transition:transform .3s var(--ease-out)}
.brand:hover .brand-mark{transform:scale(1.04)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand .name{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--green-deep);letter-spacing:.04em}
.brand .sub{font-size:10.5px;color:var(--muted);letter-spacing:.16em;margin-top:4px;text-transform:uppercase;font-weight:600}
[dir="rtl"] .brand .name{letter-spacing:0;font-weight:600}
[dir="rtl"] .brand .sub{letter-spacing:.05em}

.nav-toggle{display:none}
.nav-hamburger{display:none;width:38px;height:38px;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;border:1px solid var(--line);border-radius:var(--r-sm);background:#fff;transition:border-color .2s}
.nav-hamburger:hover{border-color:var(--gold)}
.nav-hamburger span{display:block;width:18px;height:2px;background:var(--green);border-radius:1px;transition:transform .2s,opacity .2s}

.nav-links{display:flex;gap:2px;align-items:center;flex-wrap:wrap}
.nav-item{position:relative}
.nav-trigger{
  display:inline-flex;align-items:center;gap:5px;padding:10px 14px;
  font-size:14px;color:var(--ink-2);font-weight:500;cursor:pointer;
  border-radius:var(--r-sm);user-select:none;transition:all .15s var(--ease-out);
  letter-spacing:.005em;
}
.nav-trigger:hover,.nav-item.is-open .nav-trigger{color:var(--green-deep);background:var(--paper)}
.nav-trigger .caret{font-size:9px;color:var(--muted);transition:transform .2s var(--ease-out)}
.nav-item.is-open .nav-trigger .caret{transform:rotate(180deg)}

.nav-dropdown{
  display:none;position:absolute;top:calc(100% + 6px);left:0;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  min-width:260px;padding:10px;box-shadow:var(--shadow-lg);z-index:60;
  animation:dropFade .18s var(--ease-out);
}
@keyframes dropFade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.nav-item:hover .nav-dropdown,.nav-item.is-open .nav-dropdown{display:block}
.nav-dropdown a{display:flex;align-items:center;padding:8px 12px;font-size:13px;color:var(--ink-2);border-radius:var(--r-sm);transition:all .15s var(--ease-out);font-weight:500}
.nav-dropdown a:hover{background:var(--paper);color:var(--green-deep);transform:translateX(2px)}
.nav-dropdown a.hub{font-weight:700;color:var(--green-deep);border-bottom:1px solid var(--line);margin-bottom:5px;padding-bottom:9px}
.nav-dropdown a.hub::after{content:"\2192";margin-left:auto;color:var(--gold);font-size:13px;opacity:.6}

.nav-cta{
  display:inline-flex;align-items:center;gap:7px;padding:10px 18px;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
  color:#fff;font-weight:600;font-size:13.5px;border-radius:var(--r-sm);
  transition:all .2s var(--ease-out);letter-spacing:.01em;
  box-shadow:0 1px 2px rgba(31,61,51,.15);
}
.nav-cta:hover{background:linear-gradient(135deg,var(--green-deep) 0%,var(--green) 100%);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(31,61,51,.25)}
.nav-cta::after{content:"\2192";font-size:12px;transition:transform .2s var(--ease-out)}
.nav-cta:hover::after{transform:translateX(2px)}

.lang-switch{display:inline-flex;gap:6px;align-items:center;font-size:12px;color:var(--muted);margin-left:10px;border-left:1px solid var(--line);padding-left:12px}
.lang-switch a{color:var(--muted);padding:4px 8px;border-radius:var(--r-sm);transition:all .15s}
.lang-switch a.active{background:var(--paper);color:var(--green-deep);font-weight:700}
.lang-switch a:hover{background:var(--paper);color:var(--green-deep)}

@media (max-width:980px){
  .nav-hamburger{display:flex;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:0;cursor:pointer}
  .nav-hamburger:hover,.nav-hamburger:focus-visible{border-color:var(--gold)}
  .nav-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-links{display:none;width:100%;flex-direction:column;align-items:stretch;border-top:1px solid var(--line);padding-top:12px;margin-top:12px}
  /* Both JS-driven (.is-nav-open) and CSS-only (:checked) fallbacks open the menu */
  .site-header.is-nav-open .nav-links,
  .nav-toggle:checked ~ .container .nav-links{display:flex}
  .nav-item{width:100%}
  .nav-dropdown{position:static;border:0;box-shadow:none;padding-left:14px;display:none;animation:none}
  .nav-item.is-open .nav-dropdown{display:block}
}

/* ============ Hero — premium dramatic layout ============ */
.page-hero{
  background:linear-gradient(180deg,var(--paper-2) 0%,var(--paper) 50%,var(--bg-deep) 100%);
  border-bottom:1px solid var(--line);padding:56px 0 48px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;top:-20%;right:-10%;width:50%;height:80%;
  background:radial-gradient(ellipse,rgba(184,146,74,.10),transparent 60%);
  pointer-events:none;
}
.page-hero::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-light) 30%,var(--gold-light) 70%,transparent);
  opacity:.5;
}
.page-hero .crumbs{
  font-family:var(--sans);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin-bottom:18px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.page-hero .crumbs a{color:var(--muted);font-weight:500;transition:color .15s}
.page-hero .crumbs a:hover{color:var(--green-deep)}
.page-hero .crumbs strong{color:var(--green-deep);font-weight:700}
.page-hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start;position:relative;z-index:1}
@media (max-width:980px){.page-hero-grid{grid-template-columns:1fr;gap:28px}}

.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;padding:13px 22px;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
  color:#fff;font-weight:600;border-radius:var(--r-sm);border:0;cursor:pointer;
  font-size:14.5px;letter-spacing:.01em;
  box-shadow:0 1px 3px rgba(31,61,51,.15), 0 1px 2px rgba(31,61,51,.10);
  transition:all .25s var(--ease-out);position:relative;overflow:hidden;
}
.btn-primary::before{
  content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transition:left .6s var(--ease-out);
}
.btn-primary:hover{background:linear-gradient(135deg,var(--green-deep) 0%,var(--green) 100%);color:#fff;transform:translateY(-1px);box-shadow:0 6px 18px rgba(31,61,51,.22), 0 3px 8px rgba(31,61,51,.12)}
.btn-primary:hover::before{left:100%}
.btn-primary::after{content:"\2192";font-size:13px;transition:transform .2s var(--ease-out);position:relative;z-index:1}
.btn-primary:hover::after{transform:translateX(3px)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;padding:13px 22px;
  background:rgba(255,255,255,.6);backdrop-filter:saturate(180%) blur(8px);
  color:var(--green-deep);font-weight:600;border-radius:var(--r-sm);
  border:1px solid var(--green-light);cursor:pointer;font-size:14.5px;letter-spacing:.01em;
  transition:all .2s var(--ease-out);
}
.btn-ghost:hover{background:var(--green-deep);color:#fff;border-color:var(--green-deep);transform:translateY(-1px);box-shadow:var(--shadow-md)}

.hero-meta{
  display:flex;flex-wrap:wrap;gap:24px;margin-top:30px;padding-top:24px;
  border-top:1px solid var(--line);position:relative;
}
.hero-meta::before{
  content:"";position:absolute;left:0;top:-1px;width:60px;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
}
.hero-meta div{font-size:12.5px;color:var(--ink-3);max-width:180px}
.hero-meta div b{display:block;color:var(--green-deep);font-size:14.5px;margin-bottom:3px;font-family:var(--serif);font-weight:600;letter-spacing:-.005em}

.hero-aside{
  background:linear-gradient(180deg,#fff 0%,var(--paper-2) 100%);
  border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 30px;
  box-shadow:var(--shadow-md);position:relative;
}
.hero-aside::before{
  content:"";position:absolute;top:0;left:24px;right:24px;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:0 0 2px 2px;
}
.hero-aside h2{
  font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:18px;
}
.hero-aside dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:12px 22px}
.hero-aside dt{
  font-family:var(--sans);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:700;padding-top:5px;
}
.hero-aside dd{margin:0;font-family:var(--serif);font-size:15.5px;color:var(--ink-2);line-height:1.45}
.hero-aside dd em{font-style:italic;color:var(--rust)}

/* ============ Marquee strip — refined ============ */
.marquee{
  background:linear-gradient(90deg,var(--green-deep),var(--green) 50%,var(--green-deep));
  color:var(--gold-soft);overflow:hidden;border-bottom:1px solid var(--green-deep);
}
.marquee-row{display:flex;gap:42px;padding:13px 0;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;flex-wrap:wrap}
.marquee-row span{display:inline-flex;align-items:center;gap:8px;color:var(--gold-soft)}
.marquee-row span::before{content:"\25c6";color:var(--gold-2);font-size:9px}

/* ============ Section heads — with ornament ============ */
.section-head{text-align:center;max-width:780px;margin:0 auto 38px;position:relative}
.section-head h2{font-size:clamp(28px,3.4vw,38px);margin-bottom:12px}
.section-head .lead{margin:10px auto 0;font-size:17px;color:var(--ink-3)}
.section-head .ornament{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px}
.section-head .ornament::before,.section-head .ornament::after{content:"";display:block;width:32px;height:1px;background:var(--gold-light)}
.section-head .ornament span{width:6px;height:6px;background:var(--gold);transform:rotate(45deg)}

/* ============ Practice rows (services) — premium editorial ============ */
.svc-rows{display:flex;flex-direction:column;gap:0;margin-top:30px}
.svc-row{
  display:grid;grid-template-columns:64px 1.6fr 240px;gap:30px;
  padding:36px 0;border-top:1px solid var(--line);align-items:start;
  transition:padding .25s var(--ease-out);position:relative;
}
.svc-row::before{
  content:"";position:absolute;left:0;top:-1px;width:0;height:1px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  transition:width .4s var(--ease-out);
}
.svc-row:hover::before{width:100%}
.svc-row:hover .svc-num{color:var(--rust);transform:scale(1.05)}
.svc-row:last-child{border-bottom:1px solid var(--line)}
.svc-num{
  font-family:var(--serif);font-style:italic;font-size:32px;color:var(--gold);font-weight:400;
  line-height:1;transition:all .25s var(--ease-out);
}
.svc-content h3{margin-bottom:12px;font-size:22px}
.svc-content h3 em{font-style:italic;color:var(--rust)}
.svc-content p{font-size:15px;color:var(--ink-2);line-height:1.65}
.svc-content .svc-link,.arrow-link{
  display:inline-flex;align-items:center;gap:6px;margin-top:12px;
  font-size:13.5px;font-weight:600;color:var(--green-deep);
  border-bottom:1px solid var(--gold);padding-bottom:2px;transition:all .2s var(--ease-out);
}
.svc-content .svc-link::after,.arrow-link::after{content:"\2192";transition:transform .2s var(--ease-out)}
.svc-content .svc-link:hover::after,.arrow-link:hover::after{transform:translateX(3px)}
.svc-content .svc-link:hover,.arrow-link:hover{color:var(--rust);border-bottom-color:var(--rust)}
.svc-tag{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.svc-tag b{display:block;color:var(--gold);font-size:11.5px;margin-bottom:10px;letter-spacing:.18em}
.svc-tag .meta-line{display:block;padding:6px 0;border-bottom:1px dotted var(--line);font-weight:500;line-height:1.4}
.svc-tag .meta-line:last-child{border-bottom:0}
@media (max-width:780px){.svc-row{grid-template-columns:1fr;gap:14px;padding:28px 0}.svc-num{font-size:24px}}

/* ============ Tri-grid cards — premium hover ============ */
.tri-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:24px}
@media (max-width:980px){.tri-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.tri-grid{grid-template-columns:1fr}}
.tri-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  padding:22px 24px;transition:all .3s var(--ease-out);position:relative;overflow:hidden;
  box-shadow:var(--shadow-xs);
}
.tri-card::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease-out);
}
.tri-card:hover{border-color:var(--gold-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.tri-card:hover::before{transform:scaleX(1)}
.tri-card h3{font-size:17px;margin-bottom:8px;color:var(--green-deep)}
.tri-card h4{font-size:15px;margin-bottom:6px;color:var(--green-deep);font-weight:700}
.tri-card p{font-size:13.5px;color:var(--ink-2);line-height:1.6;margin-bottom:8px}
.tri-card a{display:inline-flex;align-items:center;gap:5px;margin-top:8px;font-size:12.5px;font-weight:600;color:var(--green-deep);border-bottom:1px solid var(--gold);padding-bottom:1px;transition:all .2s}
.tri-card a:hover{color:var(--rust);border-bottom-color:var(--rust)}

/* ============ Standards table — refined ============ */
.std-table{
  width:100%;border-collapse:collapse;font-size:14px;background:#fff;
  border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.std-table td{padding:16px 18px;vertical-align:top;border-bottom:1px solid var(--line)}
.std-table td:first-child{font-family:var(--serif);font-weight:600;color:var(--green-deep);width:220px}
.std-table tr:last-child td{border-bottom:0}
.std-table tr:hover td{background:var(--paper-2)}

/* ============ Prose blocks — editorial typography ============ */
.prose{font-family:var(--serif);font-size:17px;line-height:1.68;color:var(--ink-2);max-width:var(--container-prose)}
.prose p{margin-bottom:16px}
.prose strong{color:var(--green-deep);font-weight:600}
.prose em{font-style:italic;color:var(--rust)}
.prose a{font-weight:600;border-bottom:1px solid var(--gold);transition:all .2s}
.prose a:hover{color:var(--rust);border-bottom-color:var(--rust)}
.prose ul,.prose ol{padding-left:24px;margin:16px 0}
.prose li{margin-bottom:8px}
.prose h2,.prose h3{margin-top:32px;margin-bottom:12px;font-family:var(--serif)}

/* ============ Inner page section h3 — visual rhythm ============ */
.pad h3{
  font-size:22px;margin-top:36px;margin-bottom:12px;
  padding-left:16px;border-left:3px solid var(--gold);
  font-family:var(--serif);font-weight:600;color:var(--green-deep);
}
.pad h3:first-child{margin-top:0}
.pad p{font-size:15.5px;line-height:1.7;color:var(--ink-2);margin-bottom:14px}

/* ============ FAQ accordion — modern ============ */
.faq-list{max-width:840px;margin:30px auto 0}
.faq-list details{
  border:1px solid var(--line);border-radius:var(--r-md);background:#fff;
  margin-bottom:10px;transition:all .25s var(--ease-out);overflow:hidden;
}
.faq-list details:hover{border-color:var(--gold-light)}
.faq-list details[open]{box-shadow:var(--shadow-sm);border-color:var(--gold-light)}
.faq-list summary{
  padding:18px 22px;font-family:var(--serif);font-size:16px;font-weight:600;
  color:var(--green-deep);cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  transition:color .15s;
}
.faq-list summary:hover{color:var(--rust)}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{
  content:"+";font-size:24px;color:var(--gold);font-weight:300;
  transition:transform .25s var(--ease-out);
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;
  border-radius:50%;background:var(--paper);
}
.faq-list details[open] summary::after{content:"\2013";background:var(--gold-soft)}
.faq-answer{
  padding:0 22px 20px;font-family:var(--serif);font-size:15px;line-height:1.7;
  color:var(--ink-2);animation:fadeIn .3s var(--ease-out);
}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.faq-answer p{margin-bottom:10px}

/* ============ E-E-A-T band — refined ============ */
.eeat{
  background:linear-gradient(180deg,var(--paper),var(--paper-3));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:18px 0;font-size:13px;color:var(--ink-2);position:relative;
}
.eeat::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-light) 30%,var(--gold-light) 70%,transparent);
  opacity:.5;
}
.eeat-row{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center;max-width:var(--container);margin:0 auto;padding:0 24px}
.eeat-stamp{display:flex;align-items:center;gap:12px}
.eeat-stamp svg{flex:0 0 auto;width:28px;height:28px;color:var(--gold)}
.eeat-stamp em{font-style:italic;color:var(--gold);font-weight:600}

/* ============ Closing CTA section — premium with depth ============ */
.cta-section{
  padding:80px 0;background:linear-gradient(180deg,var(--paper),var(--bg-deep) 60%,var(--paper-3));
  text-align:center;border-top:1px solid var(--line);position:relative;overflow:hidden;
}
.cta-section::before{
  content:"";position:absolute;top:-30%;left:-10%;width:60%;height:60%;
  background:radial-gradient(ellipse,rgba(184,146,74,.12),transparent 60%);pointer-events:none;
}
.cta-section::after{
  content:"";position:absolute;bottom:-30%;right:-10%;width:60%;height:60%;
  background:radial-gradient(ellipse,rgba(31,61,51,.08),transparent 60%);pointer-events:none;
}
.cta-section .container{position:relative;z-index:1}
.cta-section .ornament{display:flex;justify-content:center;align-items:center;gap:12px;margin-bottom:18px}
.cta-section .ornament .line{display:block;width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.cta-section .ornament .dia{width:10px;height:10px;background:var(--gold);transform:rotate(45deg);box-shadow:0 0 0 4px var(--paper)}
.cta-section .label{font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:14px}
.cta-section h2{font-size:clamp(32px,4vw,42px);line-height:1.1;margin-bottom:14px}
.cta-section h2 em{font-style:italic;color:var(--rust)}
.cta-section p{font-family:var(--serif);font-size:18px;color:var(--ink-2);max-width:620px;margin:0 auto 22px}
.cta-trio{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:22px}
.cta-btn{display:inline-flex;align-items:center;gap:7px;padding:13px 22px;border-radius:var(--r-sm);font-weight:600;font-size:14.5px;text-decoration:none;transition:all .25s var(--ease-out)}
.cta-btn:hover{transform:translateY(-1px)}
.cta-meta{margin-top:18px;font-size:13px;color:var(--muted)}

/* ============ Footer — refined dark with depth ============ */
footer.site-footer{
  background:linear-gradient(180deg,var(--bg-charcoal) 0%,var(--bg-dark) 100%);
  color:#d8d2c2;padding:0;border-top:1px solid #2a3a32;position:relative;
}
footer.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-light) 30%,var(--gold-light) 70%,transparent);opacity:.3;
}
.footer-brand-band{padding:48px 0 32px;border-bottom:1px solid #2a3a32}
.footer-brand-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;max-width:var(--container);margin:0 auto;padding:0 24px}
@media (max-width:780px){.footer-brand-row{grid-template-columns:1fr;gap:24px}}
.foot-brand{font-family:var(--serif);font-size:26px;color:#f5f1e8;font-weight:600;margin-bottom:10px;letter-spacing:-.005em}
.foot-brand .amp{color:var(--gold);font-style:italic}
.footer-brand-row p{font-size:14px;line-height:1.65;color:#a8a695;max-width:440px}
.footer-brand-row h3{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
  margin-bottom:14px;font-family:var(--sans);font-weight:700;
}
.footer-brand-row a{color:#d8d2c2;border-bottom:1px solid transparent;transition:all .15s var(--ease-out)}
.footer-brand-row a:hover{border-bottom-color:var(--gold);color:var(--gold)}
.footer-cta-btn{
  display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:10px 16px;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));
  color:var(--bg-dark);font-weight:700;font-size:13px;letter-spacing:.04em;
  border-radius:var(--r-sm);transition:all .2s var(--ease-out);
}
.footer-cta-btn:hover{background:linear-gradient(135deg,var(--gold-2),var(--gold));border:0;color:var(--bg-dark);transform:translateY(-1px);box-shadow:0 4px 14px rgba(184,146,74,.3)}

.footer-sitemap{padding:42px 0;background:rgba(255,255,255,.02);border-bottom:1px solid #2a3a32}
.footer-sitemap-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:28px;max-width:var(--container);margin:0 auto;padding:0 24px}
@media (max-width:980px){.footer-sitemap-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.footer-sitemap-grid{grid-template-columns:repeat(2,1fr)}}
.footer-sitemap h3{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-family:var(--sans);font-weight:700}
.footer-sitemap a{display:block;font-size:13px;color:#a8a695;padding:4px 0;border-bottom:0;transition:color .15s}
.footer-sitemap a:hover{color:#f5f1e8}

.footer-copyright{padding:22px 0;font-size:12px;color:#828071}
.footer-copyright .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-copyright a{color:#828071}
.footer-copyright a:hover{color:var(--gold)}

/* ============ Mobile sticky quickbar — premium ============ */
/* IMPORTANT: <nav> contains <a> children DIRECTLY (no .container wrapper).
   So .mobile-quickbar ITSELF must be the flex container — the previous
   '.mobile-quickbar .container{display:flex}' never matched anything,
   causing buttons to stack vertically on mobile and cover half the page.
   Bug visible 2026-05-17; fixed by making .mobile-quickbar display:flex. */
.mobile-quickbar{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:rgba(255,255,255,.95);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);
  border-top:1px solid var(--line);box-shadow:0 -4px 16px rgba(0,0,0,.06);z-index:40;
  flex-direction:row;align-items:stretch;justify-content:stretch;
}
.mobile-quickbar::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-light),transparent);opacity:.6;
}
.qb-link{
  flex:1 1 0;padding:14px 6px;text-align:center;border-right:1px solid var(--line);
  color:var(--ink-2);text-decoration:none;font-size:11.5px;
  transition:background .15s var(--ease-out);min-width:0;
}
.qb-link:hover,.qb-link:active{background:var(--paper)}
.qb-link:last-child{border-right:0}
.qb-icon{display:block;font-size:20px;margin-bottom:3px;line-height:1}
.qb-label{display:block;font-weight:600;color:var(--green-deep);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qb-wa .qb-label{color:#25D366}
/* Show as FLEX (not block) on mobile so qb-link flex:1 actually works */
@media (max-width:780px){.mobile-quickbar{display:flex}body{padding-bottom:72px}}

/* ============ Utility / small ============ */
.text-mute{color:var(--muted)}
.text-small{font-size:13px}
.tag{
  display:inline-flex;align-items:center;gap:5px;font-size:10.5px;letter-spacing:.13em;
  text-transform:uppercase;background:#fff;border:1px solid var(--line);color:var(--ink-2);
  padding:4px 10px;border-radius:var(--r-sm);font-weight:600;
}
.tag.gold{background:var(--paper);border-color:var(--gold);color:var(--gold)}
.tag.green{background:var(--ok-bg);border-color:#bcdcca;color:var(--ok)}
.kicker{
  display:inline-block;background:var(--paper);color:var(--green-deep);
  padding:4px 12px;border-radius:var(--r-sm);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;font-weight:700;margin-bottom:10px;border:1px solid var(--line-2);
}

/* ============ Case study card ============ */
.case-card{
  background:rgba(245,241,232,.05);border:1px solid rgba(245,241,232,.18);
  border-radius:var(--r-md);padding:40px 36px;
}
.case-row{display:grid;grid-template-columns:1fr 1.6fr;gap:20px;padding:18px 0;border-bottom:1px solid rgba(245,241,232,.14)}
.case-row:last-child{border-bottom:0}
.case-row .label{font-family:var(--sans);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;opacity:.6;font-weight:600}
.case-row .value{font-family:var(--serif);font-size:19px;color:#f5f1e8}
.case-row .value em{font-style:italic;color:var(--gold)}

/* ============ Figures / infographics — premium framing ============ */
figure{margin:32px auto;text-align:center}
figure svg{
  max-width:100%;height:auto;border:1px solid var(--line);border-radius:var(--r-lg);
  background:#fff;padding:18px;box-shadow:var(--shadow-md);
  transition:box-shadow .3s var(--ease-out);
}
figure:hover svg{box-shadow:var(--shadow-lg)}
figcaption{
  font-family:var(--serif);font-size:13.5px;color:var(--muted);margin-top:12px;
  font-style:italic;max-width:680px;margin-left:auto;margin-right:auto;line-height:1.5;
}

/* ============ Form widget — modern premium ============ */
.rfq-form{
  background:linear-gradient(180deg,#fff,var(--paper-2));
  border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 32px 28px;
  box-shadow:var(--shadow-md);position:relative;overflow:hidden;
}
.rfq-form::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-2),var(--gold));
}
.rfq-form h3{font-family:var(--serif);font-size:21px;color:var(--green-deep);margin-bottom:8px}
.rfq-form .form-intro{font-size:14px;color:var(--ink-3);margin-bottom:22px;max-width:540px}
.rfq-form label{display:block;margin-bottom:14px}
.rfq-form .form-label{display:block;font-size:12px;font-weight:700;color:var(--ink-2);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}
.rfq-form input,.rfq-form textarea,.rfq-form select{
  font-family:var(--sans);width:100%;padding:11px 14px;font-size:14.5px;color:var(--ink);
  background:#fff;border:1px solid var(--line-2);border-radius:var(--r-sm);
  transition:all .2s var(--ease-out);
}
.rfq-form input:focus,.rfq-form textarea:focus,.rfq-form select:focus{
  outline:0;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,146,74,.15);
}
.rfq-form textarea{min-height:110px;resize:vertical;line-height:1.55}
.rfq-form input[type="file"]{padding:8px;background:var(--paper-2)}
.rfq-form .form-submit{
  display:inline-flex;align-items:center;gap:8px;padding:13px 24px;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
  color:#fff;font-weight:700;font-size:14.5px;border-radius:var(--r-sm);border:0;cursor:pointer;
  transition:all .25s var(--ease-out);letter-spacing:.02em;margin-top:6px;
  box-shadow:0 1px 3px rgba(31,61,51,.15);
}
.rfq-form .form-submit:hover{background:linear-gradient(135deg,var(--green-deep),var(--green));transform:translateY(-1px);box-shadow:0 6px 18px rgba(31,61,51,.22)}
.rfq-form .form-submit::after{content:"\2192";font-size:13px;transition:transform .2s var(--ease-out)}
.rfq-form .form-submit:hover::after{transform:translateX(3px)}
.form-note{margin:14px 0 0;font-size:11.5px;color:var(--muted);font-style:italic;line-height:1.5}

/* ============ Explore further — back-link grid ============ */
.explore-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px;
}
@media (max-width:980px){.explore-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.explore-grid{grid-template-columns:1fr}}
.explore-card{
  display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  padding:20px 22px;color:var(--ink);position:relative;overflow:hidden;
  transition:all .25s var(--ease-out);text-decoration:none;
  box-shadow:var(--shadow-xs);
}
.explore-card::before{
  content:"";position:absolute;top:0;left:0;width:3px;height:0;
  background:linear-gradient(180deg,var(--gold),var(--gold-light));
  transition:height .3s var(--ease-out);
}
.explore-card:hover{border-color:var(--gold-light);box-shadow:var(--shadow-md);transform:translateY(-2px);color:var(--ink)}
.explore-card:hover::before{height:100%}
.explore-card .explore-tag{
  display:inline-block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:8px;
  padding:3px 8px;background:var(--paper);border-radius:var(--r-sm);
}
.explore-card h4{
  font-family:var(--serif);font-size:16px;font-weight:600;color:var(--green-deep);
  margin:6px 0 8px;line-height:1.3;
}
.explore-card p{font-size:13px;color:var(--ink-3);line-height:1.5;margin:0 0 10px}
.explore-card .explore-arrow{
  display:inline-block;font-size:16px;color:var(--gold);font-weight:700;
  transition:transform .25s var(--ease-out);
}
.explore-card:hover .explore-arrow{transform:translateX(4px);color:var(--rust)}

/* ============ Trust band — sophisticated ============ */
.trust-band{
  background:linear-gradient(180deg,var(--green-deep),var(--bg-dark));
  color:var(--gold-soft);padding:18px 0;border-top:1px solid var(--green-2);border-bottom:1px solid var(--green-2);
  position:relative;overflow:hidden;
}
.trust-band::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-light) 30%,var(--gold-light) 70%,transparent);opacity:.4;
}
.trust-band-row{
  display:flex;flex-wrap:wrap;gap:30px;justify-content:center;align-items:center;
  font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  max-width:var(--container);margin:0 auto;padding:0 24px;
}
.trust-band-row a{display:inline-flex;align-items:center;gap:8px;color:var(--gold-soft);transition:color .15s}
.trust-band-row a:hover{color:var(--gold-2)}
.trust-band-row a::before{content:"\25c6";color:var(--gold);font-size:8px}

/* ============ Subtle on-scroll animation (reduced-motion aware) ============ */
@media (prefers-reduced-motion:no-preference){
  .pad,.cta-section{animation:fadeUp .6s var(--ease-out) backwards}
  @keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
}

/* ============ Print ============ */
@media print{
  header.site-header,footer.site-footer,.mobile-quickbar,.cta-section,.marquee{display:none}
  body{font-size:11pt;background:#fff}
  a{color:var(--ink);text-decoration:underline}
  .pad{padding:24px 0;animation:none}
  figure svg{box-shadow:none;border:1px solid #ccc}
}

/* ====== Buyback recovery tables ====== */
.recovery-table{width:100%;border-collapse:collapse;margin:16px 0 20px;font-size:14px;background:linear-gradient(180deg,#fff 0%,#fafaf7 100%);border:1px solid #e6e0d2;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px rgba(31,61,51,.04)}
.recovery-table thead{background:linear-gradient(180deg,#f5efe0 0%,#ede5d0 100%)}
.recovery-table th{padding:12px 14px;text-align:left;font-weight:700;color:#1f3d33;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;border-bottom:2px solid #d4c89e}
.recovery-table td{padding:11px 14px;border-bottom:1px solid #efe9d9;color:#2a2a2a;vertical-align:top}
.recovery-table tbody tr:last-child td{border-bottom:none}
.recovery-table tbody tr:hover{background:rgba(184,146,74,.05)}
.recovery-table td:last-child{font-weight:600;color:#1f3d33;white-space:nowrap}
@media (max-width:640px){
  .recovery-table{font-size:12.5px}
  .recovery-table th,.recovery-table td{padding:8px 10px}
}
.muted.small{color:#6a6a6a;font-size:12.5px;margin-top:4px;font-style:italic;line-height:1.5}

/* ============ Stat bar above footer — verifiable signals ============ */
.stat-bar{
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
  border-top:1px solid var(--gold-light);border-bottom:1px solid var(--line);
  padding:32px 0;position:relative;
}
.stat-bar::before{
  content:"";position:absolute;top:-1px;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold) 40%,var(--gold) 60%,transparent);opacity:.5;
}
.stat-bar-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:24px;
  align-items:start;
}
.stat-item{text-align:left;border-left:2px solid var(--gold-light);padding-left:16px}
.stat-item:first-child{border-left:0;padding-left:0}
.stat-label{
  font-family:var(--sans);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:6px;
}
.stat-value{
  font-family:var(--serif);font-size:18px;color:var(--green-deep);
  font-weight:600;letter-spacing:-.01em;line-height:1.25;
}
.stat-sub{
  font-size:11.5px;color:var(--muted);line-height:1.4;margin-top:4px;font-weight:500;
}
@media (max-width:980px){
  .stat-bar-grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .stat-item:nth-child(odd){border-left:0;padding-left:0}
  .stat-item:nth-child(even){border-left:2px solid var(--gold-light);padding-left:16px}
}
@media (max-width:560px){
  .stat-bar{padding:24px 0}
  .stat-bar-grid{grid-template-columns:1fr;gap:14px}
  .stat-item{border-left:0 !important;padding-left:0 !important;padding-bottom:14px;border-bottom:1px solid var(--line)}
  .stat-item:last-child{border-bottom:0;padding-bottom:0}
  .stat-value{font-size:16px}
}

/* ============ Case study "Engagement at a glance" spec table ============ */
.case-spec-table{
  width:100%;border-collapse:collapse;margin:18px 0 12px;
  background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;
  box-shadow:0 1px 6px rgba(31,61,51,.04);
}
.case-spec-table th,.case-spec-table td{
  padding:14px 18px;text-align:left;vertical-align:top;
  border-bottom:1px solid #f0ebd9;font-size:14.5px;line-height:1.55;
}
.case-spec-table tr:last-child th,
.case-spec-table tr:last-child td{border-bottom:none}
.case-spec-table th{
  width:160px;font-weight:700;color:var(--green-deep);font-size:11.5px;
  letter-spacing:.12em;text-transform:uppercase;
  background:linear-gradient(90deg,rgba(184,146,74,.08),transparent);
}
.case-spec-table td{color:var(--ink)}
@media (max-width:600px){
  .case-spec-table th,.case-spec-table td{display:block;padding:8px 14px;border-bottom:none}
  .case-spec-table th{padding-top:14px;padding-bottom:2px;font-size:10.5px;width:auto;background:transparent}
  .case-spec-table tr{display:block;border-bottom:1px solid #f0ebd9;padding-bottom:8px}
  .case-spec-table tr:last-child{border-bottom:none}
}

/* ============================================================
   MOBILE HARDENING — 2026-05-17
   Fixes: iPhone notch/home-indicator overlap, horizontal scroll,
   quickbar covering content, brand header wrapping, footer notice
   wall-of-text, modal-overflow issues on long disclaimer page.
   ============================================================ */

/* ── iOS scroll/text-size fixes (NOTE: overflow-x:hidden is intentionally
       NOT applied to <html> or <body> because it BREAKS position:fixed
       on iOS Safari — the mobile-quickbar would scroll with the page and
       appear to cover content. Horizontal overflow is contained via the
       per-element max-width rule below + the table-wrap rule.) ── */
html{-webkit-text-size-adjust:100%}
img,svg,video,iframe,canvas{max-width:100%;height:auto}
table{max-width:100%}

/* Prevent rubber-band scroll exposing the area behind the fixed bar on iOS */
@media (max-width:780px){body{overscroll-behavior-y:contain}}

/* ── Safe-area + bigger buffer for the mobile quickbar.
       Quickbar visual height = ~58px content + safe-area-inset-bottom.
       Body padding-bottom must clear that with comfortable margin so
       footer content is fully readable above the bar. ── */
.mobile-quickbar{padding-bottom:env(safe-area-inset-bottom,0)}
@media (max-width:780px){
  body{padding-bottom:calc(78px + env(safe-area-inset-bottom,0)) !important}
}

/* ── Compact header on small screens (was wrapping awkwardly) ── */
@media (max-width:600px){
  header.site-header{position:sticky;top:0}
  .nav{padding:11px 0;flex-wrap:nowrap;gap:8px}
  .brand-mark{width:34px;height:34px}
  .brand .name{font-size:17px;letter-spacing:.02em}
  .brand .sub{font-size:9.5px;letter-spacing:.10em;margin-top:2px}
  .container{padding:0 16px}
  .nav-cta{padding:8px 12px;font-size:12.5px}
  .nav-cta::after{display:none}
}
@media (max-width:380px){
  .brand .sub{display:none}
  .nav-cta{padding:7px 10px;font-size:12px}
}

/* ── Mobile quickbar: tighter, label-safe, single-line guarantee ── */
@media (max-width:780px){
  .mobile-quickbar{box-shadow:0 -6px 18px rgba(0,0,0,.08)}
  .qb-link{padding:11px 4px;font-size:10.5px;min-height:54px;display:flex;flex-direction:column;justify-content:center;align-items:center}
  .qb-icon{font-size:18px;margin-bottom:2px;line-height:1}
  .qb-label{font-size:10.5px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}
}
@media (max-width:380px){
  .qb-link{padding:10px 2px;font-size:10px}
  .qb-icon{font-size:17px}
  .qb-label{font-size:10px}
}

/* ── Footer legal notice: shown in full on desktop, height-constrained
       and scrollable on mobile so it doesn't dominate the viewport. ── */
.footer-legal-notice{
  margin-top:10px;font-size:11.5px;opacity:.78;line-height:1.55;
}
.footer-legal-notice-inner{display:block}

@media (max-width:780px){
  .footer-copyright{padding:0 0 18px}
  .footer-copyright .container{padding:0 16px}
  .footer-copyright .container.footer-legal-notice{
    flex-direction:column;align-items:stretch;
    font-size:11px !important;
  }
  .footer-legal-notice-inner{
    border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.6);
    padding:11px 13px;width:100%;box-sizing:border-box;
    max-height:200px;overflow-y:auto;-webkit-overflow-scrolling:touch;
    font-size:10.5px;line-height:1.55;
    position:relative;
  }
  .footer-legal-notice-inner::after{
    content:"↓ scroll to read full notice ↓";display:block;
    position:sticky;bottom:-11px;text-align:center;
    font-size:9px;margin-top:8px;padding:6px 0 0;color:var(--muted);
    font-weight:600;letter-spacing:.1em;text-transform:uppercase;
    background:linear-gradient(transparent,rgba(255,255,255,.95) 40%);
  }
}

/* ── Disclaimer page: long body text needs to be readable on mobile.
       Tighten paragraph max-width + reduce font for h3s, since the
       page has 33 numbered sections that otherwise feel oppressive. ── */
@media (max-width:600px){
  body[data-page="disclaimer"] h3,
  main h3{font-size:16.5px;line-height:1.35;margin-top:24px}
  .prose{font-size:14.5px;line-height:1.65}
  .prose p{margin-bottom:12px}
}

/* ── Page hero: avoid bottom edge clipping on iOS Safari, and keep
       CTAs accessible above the quickbar ── */
@media (max-width:780px){
  .page-hero{padding:36px 0 32px}
  .page-hero h1{font-size:clamp(26px,7vw,40px)}
  .cta-row{flex-direction:column;align-items:stretch}
  .cta-row .btn-primary,.cta-row .btn-ghost{justify-content:center;width:100%}
}

/* ── Section padding tightened so the page doesn't feel infinite ── */
@media (max-width:600px){
  .pad{padding:44px 0}
  .pad-lg{padding:56px 0}
  section .container > div + div{margin-top:18px}
}

/* ── Footer hreflang region picker + sitemap: stack cleanly ── */
@media (max-width:600px){
  .footer-sitemap-grid{gap:18px}
  .footer-sitemap-grid h3{font-size:13px;letter-spacing:.08em}
  .footer-sitemap-grid a{font-size:12.5px;line-height:1.6}
}

/* ── At-a-glance aside in hero: avoid horizontal overflow ── */
@media (max-width:600px){
  .hero-aside{padding:18px 16px;font-size:13px}
  .hero-aside dt{font-size:11px}
  .hero-aside dd{font-size:12.5px}
}

/* ── RFQ form on mobile: ensure form inputs fit the viewport ── */
@media (max-width:600px){
  input,select,textarea{font-size:16px !important;max-width:100%;box-sizing:border-box}
  .form-grid,form .grid-2,form .grid-3{grid-template-columns:1fr !important}
  label.check{padding:8px 0;font-size:13.5px}
}

/* ── Recovery table: enable horizontal scroll on narrow screens
       so the data is still readable without breaking the layout ── */
@media (max-width:560px){
  .recovery-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}
  .recovery-table td:last-child{white-space:nowrap}
}

/* ── Anything inline-style absolutely-positioned in case it leaks ── */
@media (max-width:600px){
  [style*="position:fixed"]:not(.mobile-quickbar):not(.site-header){position:relative !important}
}
