/* ─── tokens ─── */
:root{
  --paper: #F4EFE6;
  --paper-2: #EEE7D8;
  --paper-3: #E6DFCE;
  --ink: #161412;
  --ink-2: #2A2622;
  --ink-mute: #6B6258;
  --rule: rgba(22,20,18,0.12);
  --rule-strong: rgba(22,20,18,0.22);
  --accent: #E5562A;          /* amber-orange default */
  --accent-ink: #1a0d05;
  --accent-soft: #FBE5D6;
  --ok: #2F6A4A;
  --warn: #C8851A;
  --bad: #B4391E;

  --serif: "Instrument Serif", "Times New Roman", serif;
  --sans: "Geist", system-ui, -apple-system, sans-serif;
  --mono: "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 18px;
  --r-xl: 28px;

  --shadow-soft: 0 1px 0 rgba(22,20,18,0.04), 0 10px 30px -12px rgba(22,20,18,0.18);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-size:16px;line-height:1.55}

a{color:inherit;text-decoration:none}
button{font-family:inherit;color:inherit}
img{display:block;max-width:100%}

.serif{font-family:var(--serif);font-weight:400;letter-spacing:-0.01em}
.mono{font-family:var(--mono);font-weight:400}
.italic{font-style:italic}

.container{max-width:1240px;margin:0 auto;padding:0 28px}
.container-wide{max-width:1440px;margin:0 auto;padding:0 28px}

/* ─── nav ─── */
.nav{
  position:sticky;top:0;z-index:30;background:color-mix(in oklab, var(--paper) 88%, transparent);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--rule);
}
.nav-inner{display:flex;align-items:center;gap:32px;padding:14px 28px;max-width:1440px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:26px;letter-spacing:-0.02em}
.brand-dot{
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #fff 0 18%, var(--accent) 22% 70%, color-mix(in oklab, var(--accent) 60%, #000) 75% 100%);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.12), 0 1px 0 rgba(0,0,0,.1);
}
.nav-links{display:flex;gap:22px;font-size:14px;color:var(--ink-2)}
.nav-links a{padding:6px 0;border-bottom:1px solid transparent}
.nav-links a:hover{border-bottom-color:var(--ink)}
.nav-spacer{flex:1}
.nav-cta{display:flex;align-items:center;gap:10px}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  height:42px;padding:0 18px;border-radius:999px;
  font-size:14px;font-weight:500;letter-spacing:-0.01em;
  border:1px solid transparent;cursor:pointer;transition:transform .15s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--ink-2)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{filter:brightness(0.95)}
.btn-ghost{background:transparent;border-color:var(--rule-strong)}
.btn-ghost:hover{background:rgba(22,20,18,0.04)}
.btn-lg{height:52px;padding:0 24px;font-size:15px}
.btn-xl{height:60px;padding:0 30px;font-size:16px;border-radius:999px}

/* ─── hero ─── */
.hero{padding:36px 0 96px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns: 1.05fr 0.95fr;gap:60px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:0.14em;color:var(--ink-mute);margin-bottom:18px}
.eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 color-mix(in oklab, var(--accent) 60%, transparent);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab, var(--accent) 50%, transparent)}70%{box-shadow:0 0 0 10px transparent}100%{box-shadow:0 0 0 0 transparent}}
.h-display{font-family:var(--serif);font-size:clamp(56px, 7.2vw, 108px);line-height:0.95;letter-spacing:-0.025em;margin:0 0 22px;color:var(--ink)}
.h-display em{font-style:italic;color:var(--accent)}
.h-sub{font-size:19px;line-height:1.45;color:var(--ink-2);max-width:520px;margin:0 0 32px}
.h-meta{display:flex;flex-wrap:wrap;gap:24px;margin-top:36px;font-family:var(--mono);font-size:12px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:0.12em}
.h-meta span{display:inline-flex;align-items:center;gap:8px}
.h-meta b{color:var(--ink);font-weight:500}

/* checker card */
.check-card{
  background:var(--paper);
  border:1px solid var(--rule-strong);
  border-radius:var(--r-lg);
  padding:8px;
  box-shadow:var(--shadow-soft);
}

/* hero "Bring this with you" card */
.hero-check{
  background:var(--paper);
  border:1px solid var(--rule-strong);
  border-radius:var(--r-lg);
  padding:28px 28px 22px;
  box-shadow:var(--shadow-soft);
}
.hero-check-head{padding-bottom:18px;border-bottom:1px solid var(--rule);margin-bottom:18px}
.hero-check-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:18px}
.hero-check-list > li{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:flex-start}
.hero-check-list .hc-num{
  font-family:var(--mono);font-size:11px;letter-spacing:0.1em;color:var(--accent);
  background:var(--accent-soft);padding:5px 9px;border-radius:6px;font-weight:600;flex-shrink:0;
  align-self:flex-start;margin-top:2px;
}
.hero-check-list b{display:block;font-weight:500;font-size:15px;margin-bottom:2px;letter-spacing:-0.005em}
.hero-check-list p{margin:0;font-size:13.5px;color:var(--ink-mute);line-height:1.45}
.hero-check-foot{
  display:flex;gap:10px;align-items:flex-start;
  margin-top:20px;padding:14px 16px;background:var(--paper-2);border-radius:10px;
  font-size:13px;color:var(--ink-2);line-height:1.45;
}
.hero-check-foot svg{flex-shrink:0;margin-top:2px;color:var(--accent)}
.hero-check-foot b{font-weight:500;color:var(--ink)}
.check-top{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 6px;font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--ink-mute);text-transform:uppercase}
.check-top .dots{display:flex;gap:6px}
.check-top .dots i{width:7px;height:7px;border-radius:50%;background:var(--rule-strong);display:block}
.check-body{background:var(--paper-2);border-radius:14px;padding:20px}
.check-tabs{display:flex;gap:4px;background:var(--paper-3);border-radius:999px;padding:4px;margin-bottom:18px;width:fit-content}
.check-tabs button{
  background:transparent;border:0;padding:8px 14px;border-radius:999px;font-size:13px;cursor:pointer;color:var(--ink-2);font-weight:500;
}
.check-tabs button.on{background:var(--ink);color:var(--paper)}
.check-input{
  display:flex;gap:10px;align-items:stretch;
}
.check-input label{
  flex:1;display:flex;flex-direction:column;gap:6px;
  background:#fff;border:1px solid var(--rule);border-radius:12px;padding:10px 14px;
}
.check-input label:focus-within{border-color:var(--ink)}
.check-input span{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-mute)}
.check-input input{
  border:0;outline:0;font-family:var(--mono);font-size:18px;letter-spacing:0.06em;background:transparent;color:var(--ink);
  text-transform:uppercase;
}
.check-go{
  display:flex;align-items:center;justify-content:center;
  height:auto;width:54px;border-radius:12px;border:0;background:var(--ink);color:var(--paper);cursor:pointer;
}
.check-go:hover{background:var(--accent);color:#fff}
.check-result{
  display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border:1px solid var(--rule);border-radius:12px;margin-top:14px;
}
.status-pill{
  display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
}
.status-pill.ok{background:color-mix(in oklab, var(--ok) 12%, var(--paper));color:var(--ok)}
.status-pill.warn{background:color-mix(in oklab, var(--warn) 14%, var(--paper));color:var(--warn)}
.status-pill.bad{background:color-mix(in oklab, var(--bad) 14%, var(--paper));color:var(--bad)}
.status-pill i{width:7px;height:7px;border-radius:50%;background:currentColor}
.check-foot{
  display:flex;align-items:center;justify-content:space-between;padding:14px 4px 6px;font-size:13px;color:var(--ink-mute);
}
.check-foot a{text-decoration:underline;text-underline-offset:3px}

/* license disc visual */
.disc-wrap{position:relative;display:flex;justify-content:center;align-items:center;margin-top:18px}
.disc{
  --d-size: 280px;
  width:var(--d-size);height:var(--d-size);
  border-radius:50%;
  background:
    radial-gradient(circle at 30% 28%, rgba(255,255,255,.65) 0 8%, transparent 12%),
    repeating-conic-gradient(from 0deg, #fff8e6 0deg 6deg, #fdf1cf 6deg 12deg),
    #f6e7b5;
  border:2px dashed rgba(22,20,18,0.25);
  box-shadow:0 30px 60px -30px rgba(22,20,18,.4), inset 0 0 0 2px rgba(255,255,255,.5);
  position:relative;display:grid;place-items:center;
  font-family:var(--mono);
}
.disc::before{
  content:"";position:absolute;inset:14px;border:1px solid rgba(22,20,18,0.15);border-radius:50%;
}
.disc-inner{
  width:78%;aspect-ratio:1;border-radius:50%;background:rgba(255,255,255,.6);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  padding:14px;text-align:center;color:var(--ink);
  border:1px solid rgba(22,20,18,0.08);
}
.disc-inner .lbl{font-size:8.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-mute)}
.disc-inner .reg{font-size:22px;letter-spacing:0.18em;font-weight:500}
.disc-inner .exp{font-size:11px;letter-spacing:0.1em;color:var(--ink-mute)}
.disc-inner .exp b{color:var(--ink);font-weight:600}
.disc-inner .stamp{
  margin-top:4px;font-size:9px;letter-spacing:0.2em;border:1px solid var(--accent);color:var(--accent);
  padding:3px 8px;border-radius:999px;text-transform:uppercase;transform:rotate(-4deg);
}
.disc-stick{
  position:absolute;left:50%;top:0;transform:translate(-50%,-30%) rotate(-2deg);
  width:60%;height:90px;background:linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,.0));
  border-radius:6px;pointer-events:none;
}

/* section header */
.section{padding:100px 0;border-top:1px solid var(--rule)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:48px}
.section-head .left{max-width:680px}
.section-num{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;color:var(--ink-mute);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.section-num .rule{display:inline-block;width:24px;height:1px;background:var(--ink);flex-shrink:0}
.section-title{font-family:var(--serif);font-size:clamp(38px,4.2vw,58px);line-height:1.02;letter-spacing:-0.02em;margin:0 0 14px}
.section-title em{font-style:italic;color:var(--accent)}
.section-lede{font-size:17px;color:var(--ink-2);max-width:560px}

/* paths */
.paths{display:grid;grid-template-columns:repeat(3, 1fr);gap:20px}
.path{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-lg);
  padding:28px;display:flex;flex-direction:column;min-height:420px;transition:border-color .2s ease, transform .2s ease;
  position:relative;overflow:hidden;
}
.path:hover{border-color:var(--ink);transform:translateY(-2px)}
.path.featured{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.path.featured .path-meta,.path.featured .path-list li{color:color-mix(in oklab, var(--paper) 70%, transparent)}
.path.featured .path-name{color:var(--paper)}
.path.featured .path-price b{color:var(--accent)}
.path-tag{
  position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:10px;letter-spacing:0.16em;
  text-transform:uppercase;padding:5px 10px;border-radius:999px;background:var(--accent);color:#fff;
}
.path-icon{
  width:54px;height:54px;border-radius:14px;background:var(--paper-3);display:grid;place-items:center;margin-bottom:22px;
}
.path.featured .path-icon{background:rgba(255,255,255,0.08)}
.path-name{font-family:var(--serif);font-size:34px;line-height:1;margin:0 0 8px;letter-spacing:-0.02em}
.path-meta{font-size:13px;color:var(--ink-mute);margin-bottom:18px;font-family:var(--mono);letter-spacing:0.04em;text-transform:uppercase}
.path-price{font-family:var(--serif);font-size:42px;line-height:1;margin:0 0 6px;letter-spacing:-0.02em}
.path-price b{color:var(--accent);font-weight:400}
.path-price small{font-family:var(--sans);font-size:13px;color:var(--ink-mute);font-weight:400;margin-left:6px;letter-spacing:0}
.path-list{list-style:none;padding:0;margin:22px 0 0;display:flex;flex-direction:column;gap:10px;font-size:14.5px;color:var(--ink-2)}
.path-list li{display:flex;gap:10px;align-items:flex-start}
.path-list li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);margin-top:8px;flex-shrink:0}
.path-cta{margin-top:auto;padding-top:24px}

/* fees */
.fees-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:stretch}
.fees-panel{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-lg);padding:32px;
}
.fees-row{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.fees-row > span{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-mute)}
.chip-row{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  border:1px solid var(--rule-strong);background:transparent;color:var(--ink-2);
  padding:9px 14px;border-radius:999px;font-size:13px;font-weight:500;cursor:pointer;transition:.15s;
}
.chip:hover{border-color:var(--ink)}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.slider-wrap{display:flex;align-items:center;gap:14px;background:var(--paper-2);border-radius:12px;padding:16px}
.slider-wrap input[type=range]{flex:1;accent-color:var(--accent)}
.slider-val{font-family:var(--mono);font-size:14px;min-width:88px;text-align:right;color:var(--ink)}
.fees-out{
  background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:36px;display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
}
.fees-out::before{
  content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--accent) 0 30%, transparent 50%);
  opacity:0.5;filter:blur(2px);
}
.fees-amount{font-family:var(--serif);font-size:clamp(72px, 9vw, 132px);line-height:1;letter-spacing:-0.03em;margin:24px 0 8px;position:relative}
.fees-amount sup{font-size:0.32em;font-family:var(--mono);font-weight:400;vertical-align:top;margin-right:6px;color:color-mix(in oklab, var(--paper) 70%, transparent)}
.fees-line{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed rgba(255,255,255,0.18);font-size:14px}
.fees-line:last-of-type{border-bottom:0}
.fees-line span:last-child{font-family:var(--mono)}
.fees-foot{font-size:12px;color:color-mix(in oklab, var(--paper) 60%, transparent);margin-top:18px;line-height:1.5}

/* post-office directory */
.po-helpline{text-align:right;padding:14px 18px;border:1px solid var(--rule-strong);border-radius:var(--r-md);background:var(--paper)}
.po-helpline a:hover{color:var(--accent)}

.po-tabs{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:6px;background:var(--paper-2);border-radius:999px;width:fit-content;margin-bottom:24px;
  max-width:100%;overflow-x:auto;
}
.po-tab{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;border:0;padding:9px 16px;border-radius:999px;
  font-size:13px;font-weight:500;color:var(--ink-2);cursor:pointer;white-space:nowrap;transition:.15s;
}
.po-tab:hover{color:var(--ink)}
.po-tab.on{background:var(--ink);color:var(--paper)}
.po-tab .po-count{
  font-family:var(--mono);font-size:10px;letter-spacing:0;padding:2px 7px;border-radius:999px;
  background:var(--paper-3);color:var(--ink-mute);
}
.po-tab.on .po-count{background:rgba(255,255,255,0.12);color:color-mix(in oklab, var(--paper) 80%, transparent)}

.po-layout{display:grid;grid-template-columns:1.5fr 0.7fr;gap:28px;align-items:start}
.po-list-wrap{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column}
.po-search{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--rule)}
.po-search input{flex:1;border:0;outline:0;background:transparent;font-family:var(--sans);font-size:14.5px;color:var(--ink)}
.po-list{max-height:640px;overflow-y:auto}
.po-group-head{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px 8px;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-mute);
}
.po-group-head .po-rule{flex:1;height:1px;background:var(--rule)}
.po-item{
  display:flex;align-items:center;gap:16px;
  padding:14px 22px;border-top:1px solid var(--rule);
}
.po-item:hover{background:var(--paper-2)}
.po-item-main{flex:1;min-width:0}
.po-item-name{font-weight:500;font-size:15px;letter-spacing:-0.005em}
.po-item-addr{font-size:13px;color:var(--ink-mute);margin-top:2px;line-height:1.35}
.po-item-phone{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:13px;color:var(--ink);
  padding:8px 12px;border:1px solid var(--rule);border-radius:8px;background:var(--paper);
  white-space:nowrap;flex-shrink:0;
}
.po-item-phone:hover{border-color:var(--ink);color:var(--accent)}
.po-empty{padding:32px 22px;text-align:center;color:var(--ink-mute);font-size:14px}
.po-empty a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.po-foot{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 22px;border-top:1px solid var(--rule);background:var(--paper-2);
  font-size:12.5px;color:var(--ink-mute);
}
.po-foot-link{display:inline-flex;align-items:center;gap:6px;color:var(--ink);text-decoration:underline;text-underline-offset:3px}

.po-map{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-lg);
  padding:20px;position:sticky;top:88px;
}
.po-map-foot{margin-top:14px;padding-top:14px;border-top:1px solid var(--rule)}

/* forms */
.forms-list{display:grid;grid-template-columns:repeat(4, 1fr);gap:14px}
.form-card{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);padding:22px;display:flex;flex-direction:column;gap:14px;transition:.15s;
  position:relative;
}
.form-card:hover{border-color:var(--ink);transform:translateY(-2px)}
.form-sheet{
  height:140px;border-radius:8px;background:
    repeating-linear-gradient(0deg, transparent 0 16px, rgba(22,20,18,0.06) 16px 17px),
    #fff;
  border:1px solid var(--rule);position:relative;
}
.form-sheet::before{
  content:"";position:absolute;top:14px;left:14px;width:40%;height:8px;background:var(--ink);border-radius:2px;
}
.form-sheet::after{
  content:"";position:absolute;top:30px;left:14px;width:55%;height:5px;background:var(--rule-strong);border-radius:2px;
}
.form-code{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;color:var(--accent);text-transform:uppercase}
.form-title{font-family:var(--serif);font-size:22px;line-height:1.1;margin:0}
.form-desc{font-size:13px;color:var(--ink-mute);line-height:1.45;flex:1}
.form-link{font-size:13px;font-family:var(--mono);text-transform:uppercase;letter-spacing:0.12em;display:inline-flex;align-items:center;gap:6px;color:var(--ink)}
.form-link::after{content:"↓";font-size:14px}

/* social proof */
.social{display:grid;grid-template-columns: 1fr 1.4fr;gap:60px;align-items:start}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.stat{padding:28px 24px;border:1px solid var(--rule);border-radius:var(--r-md);background:var(--paper)}
.stat-num{font-family:var(--serif);font-size:58px;line-height:1;letter-spacing:-0.02em;color:var(--ink)}
.stat-num em{font-style:italic;color:var(--accent)}
.stat-lbl{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--ink-mute);text-transform:uppercase;margin-top:8px}
.testis{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.testi{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);padding:24px;display:flex;flex-direction:column;gap:14px;
}
.testi .stars{display:flex;gap:2px;color:var(--accent);font-size:14px;letter-spacing:2px}
.testi q{font-family:var(--serif);font-size:21px;line-height:1.25;letter-spacing:-0.01em;quotes:"“" "”";color:var(--ink)}
.testi .who{display:flex;align-items:center;gap:10px;margin-top:auto}
.testi .who .av{width:32px;height:32px;border-radius:50%;background:var(--paper-3);display:grid;place-items:center;font-family:var(--mono);font-size:12px;color:var(--ink-2);font-weight:500}
.testi .who .nm{font-size:13px;font-weight:500}
.testi .who .dt{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:0.06em}

/* faq */
.faq-grid{display:grid;grid-template-columns: 0.4fr 1fr;gap:40px}
.faq-list{border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--rule);padding:22px 0;cursor:pointer}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--serif);font-size:24px;line-height:1.2;letter-spacing:-0.01em}
.faq-q .pm{font-family:var(--sans);font-size:22px;color:var(--accent);transition:transform .2s}
.faq-item.open .faq-q .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;font-size:15.5px;color:var(--ink-2);line-height:1.5;}
.faq-item.open .faq-a{max-height:300px;padding-top:14px}

/* footer */
.foot{padding:80px 0 40px;border-top:1px solid var(--rule)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
.foot-brand{font-family:var(--serif);font-size:80px;line-height:0.9;letter-spacing:-0.03em;margin:0}
.foot-brand em{font-style:italic;color:var(--accent)}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;color:var(--ink-mute);text-transform:uppercase;margin:0 0 16px}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--rule);margin-top:60px;padding-top:24px;font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:0.06em;text-transform:uppercase}

/* CTA strip */
.cta-strip{
  background:var(--ink);color:var(--paper);border-radius:var(--r-xl);padding:60px;display:flex;align-items:center;justify-content:space-between;gap:40px;
  position:relative;overflow:hidden;margin-bottom:40px;
}
.cta-strip::before{
  content:"";position:absolute;left:-60px;bottom:-60px;width:240px;height:240px;border-radius:50%;
  border:2px dashed rgba(255,255,255,0.18);
}
.cta-strip h2{font-family:var(--serif);font-size:clamp(38px, 4.5vw, 64px);line-height:1;letter-spacing:-0.02em;margin:0;max-width:660px}
.cta-strip h2 em{font-style:italic;color:var(--accent)}

/* tweaks-panel theme assist */
[data-tweaks-root]{font-family:var(--sans)}

/* responsive */
@media (max-width: 980px){
  .hero-grid, .fees-grid, .social, .faq-grid, .foot-grid, .chatback-grid, .po-layout{grid-template-columns:1fr !important}
  .paths{grid-template-columns:1fr}
  .forms-list{grid-template-columns:repeat(2, 1fr)}
  .nav-links{display:none}
  .cta-strip{flex-direction:column;align-items:flex-start;padding:36px}
  .po-map{position:static}
}


/* ─── static-site additions ─── */
.container{max-width:1200px}

.nav-burger{display:none;background:transparent;border:0;font-size:24px;cursor:pointer;padding:6px 10px}
.nav-drawer{display:none;flex-direction:column;border-top:1px solid var(--rule);background:var(--paper)}
.nav-drawer a{padding:16px 28px;border-bottom:1px solid var(--rule);font-size:15px}
.nav-drawer .drawer-cta{background:var(--accent);color:#fff;font-weight:500}
@media (max-width: 980px){
  .nav-burger{display:block}
  .nav-links, .nav-cta{display:none}
  .nav-drawer.open{display:flex}
}

.crumbs{padding:14px 28px 0;margin:0 auto}
.crumbs ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.crumbs li:not(:last-child)::after{content:"/";margin-left:8px;opacity:.5}
.crumbs a:hover{color:var(--accent)}

.page-hero{padding:48px 0 56px}
.page-hero h1{font-family:var(--serif);font-size:clamp(48px,6vw,84px);line-height:0.98;letter-spacing:-0.025em;margin:14px 0 18px;max-width:14ch}
.page-hero h1 em{font-style:italic;color:var(--accent)}
.page-hero .lede{font-size:18px;color:var(--ink-2);max-width:62ch;line-height:1.5}

/* WSB banner reused */
.wsb-banner{max-width:860px;margin:14px auto 0;padding:0 28px;position:relative}
.wsb-banner .wsb-frame{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-lg);overflow:hidden;position:relative}
.wsb-banner .wsb-tag{position:absolute;top:12px;left:14px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;background:rgba(22,20,18,.78);color:var(--paper);padding:5px 9px;border-radius:999px}
.wsb-banner img{width:100%;height:auto;display:block}
.wsb-banner .wsb-foot{margin-top:6px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--ink-mute);text-align:right;text-transform:uppercase;padding:0 4px}

/* full-bleed fee tables — SEO-critical content as plain HTML */
.fee-table-wrap{border:1px solid var(--rule);border-radius:var(--r-md);overflow:hidden;background:var(--paper);margin:28px 0}
.fee-table-wrap details{padding:0}
.fee-table-wrap summary{
  list-style:none;cursor:pointer;padding:18px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:var(--serif);font-size:24px;letter-spacing:-0.01em;
}
.fee-table-wrap summary::-webkit-details-marker{display:none}
.fee-table-wrap summary::after{content:"+";font-family:var(--sans);color:var(--accent);font-size:20px}
.fee-table-wrap[open] summary::after{content:"–"}
.fee-table-wrap summary .meta{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);font-weight:400}
.fee-table{
  width:100%;border-collapse:collapse;font-size:14px;
  border-top:1px solid var(--rule);
}
.fee-table th{
  text-align:left;padding:10px 22px;font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);
  background:var(--paper-2);border-bottom:1px solid var(--rule);font-weight:500;
}
.fee-table td{padding:10px 22px;border-bottom:1px solid var(--rule)}
.fee-table tr:last-child td{border-bottom:0}
.fee-table td.fee{font-family:var(--mono);text-align:right;color:var(--ink);font-weight:500}
.fee-table tr:nth-child(even) td{background:rgba(22,20,18,0.02)}

.flat-fees{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0}
.flat-card{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);padding:18px 20px}
.flat-card .prov{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.flat-card .amt{font-family:var(--serif);font-size:36px;line-height:1;letter-spacing:-0.02em;margin-top:4px}

/* province grid */
.prov-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:32px 0}
.prov-card{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);
  padding:22px 24px;transition:.15s;
}
.prov-card:hover{border-color:var(--ink);transform:translateY(-2px)}
.prov-card .prov-name{font-family:var(--serif);font-size:26px;line-height:1;letter-spacing:-0.01em}
.prov-card .prov-meta{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin-top:4px}
.prov-card .prov-arrow{color:var(--accent);font-size:20px;flex-shrink:0}

/* article-style prose for content pages */
.prose{max-width:62ch;margin:0 auto;padding:0 28px}
.prose h2{font-family:var(--serif);font-size:36px;line-height:1.05;letter-spacing:-0.02em;margin:48px 0 16px}
.prose h3{font-family:var(--serif);font-size:24px;line-height:1.1;margin:32px 0 12px}
.prose p{margin:0 0 14px;font-size:17px;line-height:1.6;color:var(--ink-2)}
.prose ul, .prose ol{margin:0 0 18px;padding-left:22px;font-size:16px;line-height:1.6;color:var(--ink-2)}
.prose li{margin:4px 0}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* requirements checklist */
.req-list{list-style:none;padding:0;margin:24px 0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.req-list li{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);padding:18px 22px}
.req-list li b{display:block;font-size:15px;margin-bottom:4px;font-weight:500}
.req-list li p{margin:0;font-size:13.5px;color:var(--ink-mute);line-height:1.45}

/* branch listing for province pages */
.branch-search{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-md);margin-bottom:12px}
.branch-search input{flex:1;border:0;outline:0;background:transparent;font-size:14.5px}

.branch-list{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-lg);overflow:hidden}
.branch-group{}
.branch-group-head{padding:18px 22px 8px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);background:var(--paper-2);border-bottom:1px solid var(--rule)}
.branch-row{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;padding:14px 22px;border-top:1px solid var(--rule)}
.branch-row:hover{background:var(--paper-2)}
.branch-row .b-name{font-weight:500;font-size:15px}
.branch-row .b-addr{font-size:13px;color:var(--ink-mute);margin-top:2px}
.branch-row .b-phone{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:13px;padding:7px 12px;border:1px solid var(--rule);border-radius:8px;white-space:nowrap}
.branch-row .b-phone:hover{border-color:var(--ink);color:var(--accent)}

/* FAQ */
.faq-block details{border-bottom:1px solid var(--rule);padding:18px 0}
.faq-block details:first-of-type{border-top:1px solid var(--ink)}
.faq-block summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--serif);font-size:22px;line-height:1.2;letter-spacing:-0.01em}
.faq-block summary::-webkit-details-marker{display:none}
.faq-block summary::after{content:"+";color:var(--accent);font-family:var(--sans);font-size:22px;transition:transform .2s}
.faq-block details[open] summary::after{content:"–"}
.faq-block details > div{padding-top:12px;font-size:15.5px;line-height:1.55;color:var(--ink-2);max-width:62ch}

/* small fee calculator */
.calc{background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-lg);padding:28px}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.calc label.fld{display:block;margin-bottom:16px}
.calc label.fld > span{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:6px}
.calc select, .calc input[type=number]{width:100%;border:1px solid var(--rule);background:#fff;border-radius:8px;padding:10px 12px;font-family:var(--sans);font-size:15px;color:var(--ink)}
.calc input[type=range]{width:100%;accent-color:var(--accent)}
.calc-out{background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:24px;display:flex;flex-direction:column;justify-content:space-between}
.calc-out .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:color-mix(in oklab, var(--paper) 60%, transparent)}
.calc-out .big{font-family:var(--serif);font-size:64px;line-height:1;letter-spacing:-0.02em;margin:6px 0}
.calc-out .ln{display:flex;justify-content:space-between;font-size:13.5px;padding:8px 0;border-bottom:1px dashed rgba(255,255,255,0.18)}
.calc-out .ln:last-of-type{border-bottom:0}
.calc-out .ln span:last-child{font-family:var(--mono)}

@media (max-width: 780px){
  .prov-grid, .flat-fees, .req-list, .calc-grid{grid-template-columns:1fr !important}
  .nav-links{display:none}
}

/* misc utilities */
.section.tight{padding:60px 0}
.muted{color:var(--ink-mute);font-size:13.5px}
.kbd-list{list-style:none;padding:0;margin:0}
.kbd-list li{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--rule);align-items:flex-start}
.kbd-list li:last-child{border-bottom:0}
.kbd-list .step{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--accent);background:var(--accent-soft);padding:4px 8px;border-radius:6px;font-weight:600;flex-shrink:0;margin-top:2px}
.kbd-list .step-body b{font-weight:500;font-size:15.5px;display:block}
.kbd-list .step-body p{margin:2px 0 0;font-size:13.5px;color:var(--ink-mute);line-height:1.45}
