/* ==========================================================================
   Estate Haul — visual system
   Palette:  deep teal · warm amber · off-white paper · charcoal ink
   Type:     Fraunces (display serif, variable)  +  Source Serif 4 (body)
            +  Inter (UI / nav / meta)
   ========================================================================== */
:root{
  --paper:        #f7f1e6;   /* off-white paper background */
  --paper-2:      #efe6d2;   /* slightly darker for tinted bands */
  --surface:      #fffdf7;   /* card surface */
  --ink:          #1b1815;   /* near-black charcoal */
  --ink-2:        #4a4239;   /* secondary text */
  --ink-3:        #7a6f60;   /* tertiary muted */
  --line:         #e3d8be;   /* warm hairline */
  --line-2:       #d6c9a8;

  --teal:         #0e4f5c;   /* deep teal — primary brand */
  --teal-dark:    #093540;
  --teal-soft:    #d6e6e9;

  --amber:        #d89a3a;   /* warm amber — accent */
  --amber-dark:   #a86f1c;
  --amber-soft:   #f6e4be;

  --rust:         #b35234;   /* warm rust for category badges */
  --rust-soft:    #f3d6c6;

  --moss:         #4a6a3d;   /* secondary support */
  --moss-soft:    #dde3c7;

  --shadow-sm:    0 2px 8px rgba(20,15,5,.06);
  --shadow:       0 12px 36px rgba(20,15,5,.12);
  --shadow-lg:    0 22px 60px rgba(14,79,92,.18);

  --r-sm: 6px;
  --r:    10px;
  --r-lg: 16px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Source Serif 4","Source Serif Pro",Georgia,serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s,color .15s}
a:hover{color:var(--teal-dark);border-bottom-color:var(--amber)}

h1,h2,h3,h4,h5{
  font-family:"Fraunces","Source Serif 4",Georgia,serif;
  font-variation-settings:"opsz" 144;
  line-height:1.12;color:var(--ink);margin:0 0 .55em;
  letter-spacing:-.012em;
}
h1{font-size:2.6rem;font-weight:700}
h2{font-size:1.85rem;font-weight:600}
h3{font-size:1.18rem;font-weight:600}
h4{font-size:1rem;font-weight:600}

.container{max-width:1200px;margin:0 auto;padding:0 28px}
.container.narrow{max-width:820px}

/* --------------------------------------------------------------------------
   Header
   -------------------------------------------------------------------------- */
.site-header{
  background:var(--surface);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(6px);
}
.site-header .bar{display:flex;align-items:center;gap:28px;padding:18px 0}
.brand{
  display:flex;align-items:center;gap:12px;border:0;
  font-family:"Fraunces",serif;font-variation-settings:"opsz" 144;
  font-weight:700;font-size:1.55rem;color:var(--ink);letter-spacing:-.02em;
  white-space:nowrap;
}
.brand:hover{color:var(--teal-dark);border:0}
.brand .mark{
  width:42px;height:42px;border-radius:10px;
  background:var(--teal);
  display:grid;place-items:center;color:var(--amber);
  font-family:"Fraunces",serif;font-weight:700;font-size:1.25rem;
  box-shadow:inset 0 0 0 2px rgba(216,154,58,.35),0 6px 18px rgba(14,79,92,.25);
  position:relative;
}
.brand .mark::after{
  content:"";position:absolute;inset:5px;border-radius:6px;
  border:1px dashed rgba(216,154,58,.45);
}
.brand small{
  display:block;font-family:"Inter",system-ui,sans-serif;
  font-weight:500;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);margin-top:2px;
}
.nav{display:flex;gap:24px;margin-left:auto;flex-wrap:wrap;align-items:center}
.nav a{
  color:var(--ink-2);font-size:.93rem;font-family:"Inter",system-ui,sans-serif;
  font-weight:500;border:0;padding:6px 0;position:relative;
}
.nav a:hover{color:var(--teal)}
.cta-btn{
  background:var(--amber);color:var(--ink);padding:11px 20px;border-radius:var(--r);
  font-family:"Inter",system-ui,sans-serif;font-weight:600;font-size:.9rem;
  border:0;cursor:pointer;display:inline-block;letter-spacing:.01em;
  box-shadow:0 4px 14px rgba(216,154,58,.35);transition:transform .12s,box-shadow .12s,background .12s;
}
.cta-btn:hover{background:var(--amber-dark);color:#fff;border:0;transform:translateY(-1px);box-shadow:0 6px 18px rgba(168,111,28,.4)}
.cta-btn.teal{background:var(--teal);color:#fff;box-shadow:0 4px 14px rgba(14,79,92,.3)}
.cta-btn.teal:hover{background:var(--teal-dark);color:#fff}
.cta-btn.ghost{background:transparent;color:var(--teal);box-shadow:none;border:1.5px solid var(--teal);padding:9.5px 18px}
.cta-btn.ghost:hover{background:var(--teal);color:#fff}

/* --------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */
.hero{
  position:relative;color:#fdf6e7;
  background:
    linear-gradient(180deg,rgba(9,53,64,.78) 0%,rgba(9,53,64,.92) 100%),
    radial-gradient(circle at 20% 0%,rgba(216,154,58,.45),transparent 55%),
    var(--teal-dark);
  overflow:hidden;
  padding:84px 0 110px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg,rgba(255,255,255,.025) 0 1px,transparent 1px 14px);
  pointer-events:none;
}
.hero img.bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.18;mix-blend-mode:luminosity;
}
.hero .inner{position:relative;text-align:center;max-width:880px;margin:0 auto}
.hero .eyebrow{
  display:inline-block;font-family:"Inter",sans-serif;font-weight:600;
  font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--amber);margin:0 0 18px;
  padding:6px 14px;border:1px solid rgba(216,154,58,.45);border-radius:999px;
}
.hero h1{
  color:#fdf6e7;font-size:clamp(2.4rem,5.5vw,4rem);
  font-variation-settings:"opsz" 144;font-weight:700;
  margin:0 0 18px;line-height:1.04;
}
.hero h1 em{font-style:italic;color:var(--amber);font-weight:600}
.hero p.lede{
  font-family:"Source Serif 4",serif;font-size:1.18rem;
  max-width:640px;margin:0 auto 36px;opacity:.92;line-height:1.55;
}

/* Centered hero search */
.hero-search{
  background:var(--surface);border-radius:var(--r-lg);
  padding:14px;display:flex;gap:10px;flex-wrap:wrap;align-items:stretch;
  box-shadow:var(--shadow-lg);max-width:720px;margin:0 auto;
  border:1px solid rgba(216,154,58,.5);
}
.hero-search > *{font-family:"Inter",sans-serif;font-size:.96rem}
.hero-search select,.hero-search input{
  flex:1;min-width:140px;padding:14px 16px;border:1px solid var(--line);
  border-radius:var(--r);background:#fff;color:var(--ink);font-family:inherit;
}
.hero-search select:focus,.hero-search input:focus{
  outline:0;border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,79,92,.15);
}
.hero-search button{
  background:var(--amber);color:var(--ink);border:0;font-family:inherit;font-weight:700;
  padding:14px 26px;border-radius:var(--r);cursor:pointer;letter-spacing:.01em;
  box-shadow:0 4px 14px rgba(216,154,58,.4);
}
.hero-search button:hover{background:var(--amber-dark);color:#fff}
.hero .stats{
  display:flex;gap:48px;justify-content:center;margin-top:32px;
  font-family:"Inter",sans-serif;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;color:rgba(253,246,231,.7);
}
.hero .stats b{display:block;font-family:"Fraunces",serif;font-weight:600;font-size:1.8rem;color:var(--amber);letter-spacing:-.01em;text-transform:none;margin-bottom:2px}

/* --------------------------------------------------------------------------
   Sections / blocks
   -------------------------------------------------------------------------- */
section.block{padding:64px 0}
section.block.tinted{background:var(--paper-2)}
section.block.cream{background:#fffaf0}
section.block.dark{background:var(--teal-dark);color:#fdf6e7}
section.block.dark h2,section.block.dark h3{color:#fdf6e7}
section.block.dark a{color:var(--amber)}
.section-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:32px;gap:16px;flex-wrap:wrap}
.section-head h2{margin:0}
.section-head .eyebrow{
  display:block;font-family:"Inter",sans-serif;font-weight:600;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--amber-dark);margin-bottom:6px;
}
.section-head .more{
  font-family:"Inter",sans-serif;font-size:.92rem;font-weight:500;color:var(--teal);
  border-bottom:1px solid var(--amber);
}

/* --------------------------------------------------------------------------
   Cards — vintage market vibe with date chips and category badges
   -------------------------------------------------------------------------- */
.grid{display:grid;gap:22px}
.grid.cols-3{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}
.grid.cols-4{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.grid.cols-2{grid-template-columns:repeat(auto-fill,minmax(420px,1fr))}

.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px 22px 20px;display:flex;flex-direction:column;gap:10px;
  position:relative;border-bottom-width:3px;border-bottom-color:var(--line-2);
  transition:transform .15s,box-shadow .15s,border-color .15s;
}
.card:hover{
  transform:translateY(-3px);
  border-color:var(--amber);
  box-shadow:var(--shadow);
  border-bottom-color:var(--amber);
}
.card .row-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:2px}
.card h3{margin:0;font-size:1.12rem;line-height:1.25}
.card .meta{
  color:var(--ink-3);font-size:.88rem;font-family:"Inter",sans-serif;
  display:flex;gap:8px;align-items:center;flex-wrap:wrap;
}
.card .meta .sep{color:var(--line);margin:0 2px}
.card p{margin:6px 0 0;color:var(--ink-2);font-size:.95rem;line-height:1.5}

/* Category / sale-type badge */
.badge-cat{
  display:inline-flex;align-items:center;gap:6px;
  font:600 .68rem/1 "Inter",sans-serif;letter-spacing:.1em;text-transform:uppercase;
  background:var(--amber-soft);color:var(--amber-dark);
  padding:6px 10px;border-radius:999px;border:1px solid rgba(168,111,28,.25);
  white-space:nowrap;
}
.badge-cat.teal{background:var(--teal-soft);color:var(--teal-dark);border-color:rgba(14,79,92,.25)}
.badge-cat.rust{background:var(--rust-soft);color:var(--rust);border-color:rgba(179,82,52,.25)}
.badge-cat.moss{background:var(--moss-soft);color:var(--moss);border-color:rgba(74,106,61,.3)}

/* Date chip — vintage ticket vibe */
.date-chip{
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--paper-2);color:var(--ink);
  border:1px solid var(--line-2);border-radius:8px;
  padding:6px 10px;min-width:54px;
  font-family:"Inter",sans-serif;line-height:1;
  box-shadow:inset 0 -2px 0 var(--amber);
  flex:0 0 auto;
}
.date-chip .m{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--amber-dark)}
.date-chip .d{font-size:1.25rem;font-weight:700;font-family:"Fraunces",serif;color:var(--ink);margin-top:2px}
.date-chip .dow{font-size:.6rem;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}

/* Old .pill alias for backwards compatibility */
.pill{
  display:inline-block;font:600 .72rem/1 "Inter",sans-serif;
  letter-spacing:.1em;text-transform:uppercase;
  background:var(--amber-soft);color:var(--amber-dark);
  padding:6px 11px;border-radius:999px;align-self:flex-start;border:1px solid rgba(168,111,28,.25);
}
.pill.green{background:var(--teal-soft);color:var(--teal-dark);border-color:rgba(14,79,92,.25)}

/* --------------------------------------------------------------------------
   Trust badges
   -------------------------------------------------------------------------- */
.badges{display:flex;gap:14px;flex-wrap:wrap;margin:18px 0 6px}
.badge{
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:var(--r);padding:10px 14px;
  font-family:"Inter",sans-serif;font-size:.86rem;color:var(--ink-2);font-weight:500;
}
.badge .icon{
  width:30px;height:30px;border-radius:50%;background:var(--teal-soft);color:var(--teal);
  display:grid;place-items:center;font-weight:700;font-size:.95rem;
}
.badge.gold .icon{background:var(--amber-soft);color:var(--amber-dark)}
.badge.rust .icon{background:var(--rust-soft);color:var(--rust)}

/* --------------------------------------------------------------------------
   Lead form
   -------------------------------------------------------------------------- */
.lead-form{
  background:linear-gradient(135deg,var(--teal) 0%,var(--teal-dark) 100%);
  color:#fdf6e7;border-radius:var(--r-lg);padding:38px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.lead-form::before{
  content:"";position:absolute;top:-40px;right:-40px;width:220px;height:220px;
  background:radial-gradient(circle,rgba(216,154,58,.22),transparent 70%);
  pointer-events:none;
}
.lead-form h2{color:#fdf6e7;margin:0 0 6px}
.lead-form p.lede{opacity:.9;margin:0 0 16px;font-size:1.02rem}
.lead-form .badges{margin:14px 0 18px}
.lead-form .badges .badge{background:rgba(255,255,255,.92)}
.lead-form form{display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:14px;position:relative}
.lead-form input,.lead-form select,.lead-form textarea{
  padding:13px 15px;border:0;border-radius:var(--r);font:inherit;
  background:#fff;color:var(--ink);font-family:"Inter",sans-serif;font-size:.95rem;
}
.lead-form input.full,.lead-form textarea,.lead-form .btn-row{grid-column:1/-1}
.lead-form .btn-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.lead-form .secure{display:flex;align-items:center;gap:8px;font-family:"Inter",sans-serif;font-size:.85rem;opacity:.9}
.lead-form button{
  background:var(--amber);color:var(--ink);border:0;padding:14px 24px;border-radius:var(--r);
  font:700 1rem "Inter",sans-serif;cursor:pointer;letter-spacing:.01em;
  box-shadow:0 4px 14px rgba(216,154,58,.4);
}
.lead-form button:hover{background:#fff;color:var(--teal-dark)}

/* --------------------------------------------------------------------------
   Sale detail
   -------------------------------------------------------------------------- */
.sale-detail{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:flex-start;padding:44px 0}
.sale-detail .main h1{margin-top:0;font-size:2.2rem}
.sale-detail .crumb{
  font-family:"Inter",sans-serif;color:var(--ink-3);margin:0 0 8px;font-size:.88rem;
}
.sale-detail .meta-row{
  display:flex;gap:18px;flex-wrap:wrap;font-family:"Inter",sans-serif;color:var(--ink-2);
  margin:0 0 22px;font-size:.94rem;
}
.sale-detail .meta-row span{display:inline-flex;align-items:center;gap:6px}
.sale-detail aside{position:sticky;top:90px}
.sale-detail .info-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;
  border-top:4px solid var(--amber);
}
.sale-detail .info-card h3{margin:0 0 12px}
.sale-detail .info-card dl{margin:0;display:grid;grid-template-columns:1fr 1.4fr;gap:8px 14px}
.sale-detail .info-card dt{color:var(--ink-3);font-family:"Inter",sans-serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;align-self:center}
.sale-detail .info-card dd{margin:0;font-weight:600;font-size:.95rem;color:var(--ink)}
.sale-detail h2{margin-top:30px;font-size:1.5rem}
.cat-pills{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 24px}
.cat-pills span{
  background:var(--rust-soft);color:var(--rust);font-family:"Inter",sans-serif;
  font-size:.8rem;padding:6px 12px;border-radius:999px;font-weight:500;
  border:1px solid rgba(179,82,52,.2);
}

/* --------------------------------------------------------------------------
   Lists
   -------------------------------------------------------------------------- */
.list{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.list .row{
  display:grid;grid-template-columns:auto 1fr 180px 100px;gap:18px;align-items:center;
  padding:16px 22px;border-top:1px solid var(--line);
}
.list .row:first-child{border-top:0}
.list .row:hover{background:var(--paper)}
.list .row .name{font-weight:600;font-family:"Fraunces",serif;font-size:1.05rem}
.list .row .name a{color:var(--ink)}
.list .row .name a:hover{color:var(--teal)}
.list .row .name small{
  display:block;color:var(--ink-3);font-weight:400;font-family:"Inter",sans-serif;
  font-size:.82rem;margin-top:3px;
}
.list .row .when{color:var(--ink-2);font-family:"Inter",sans-serif;font-size:.9rem}
.list .row .more{justify-self:end;font-family:"Inter",sans-serif;font-size:.88rem;font-weight:500;color:var(--teal)}

/* --------------------------------------------------------------------------
   Pager
   -------------------------------------------------------------------------- */
.pager{display:flex;gap:6px;justify-content:center;margin:36px 0;font-family:"Inter",sans-serif;flex-wrap:wrap}
.pager a, .pager span{
  padding:9px 13px;border:1px solid var(--line);border-radius:var(--r-sm);
  background:#fff;color:var(--ink-2);font-size:.88rem;
}
.pager a:hover{border-color:var(--teal);color:var(--teal)}
.pager .current{background:var(--teal);color:#fff;border-color:var(--teal);font-weight:600}

/* --------------------------------------------------------------------------
   AdSense placeholder
   -------------------------------------------------------------------------- */
.ad-slot{
  background:repeating-linear-gradient(45deg,#f4ecd8,#f4ecd8 10px,#efe3c5 10px,#efe3c5 20px);
  border:1px dashed #c9b78a;border-radius:var(--r);color:#7a6a3e;
  padding:14px;text-align:center;font-family:"Inter",sans-serif;font-size:.82rem;
  margin:18px 0;
}
.ad-slot.compact{padding:10px;font-size:.78rem}

/* --------------------------------------------------------------------------
   Recommended-reading block (PBN slots) — editorial style
   -------------------------------------------------------------------------- */
.recommended{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px;border-top:3px solid var(--moss);
}
.recommended .eyebrow{
  display:block;font:600 .68rem/1 "Inter",sans-serif;
  letter-spacing:.22em;text-transform:uppercase;color:var(--moss);margin-bottom:4px;
}
.recommended h4{margin:0 0 14px;font-size:1.15rem;font-family:"Fraunces",serif}
.recommended ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.recommended li{display:flex;flex-direction:column;gap:3px;padding-bottom:14px;border-bottom:1px dashed var(--line)}
.recommended li:last-child{padding-bottom:0;border-bottom:0}
.recommended li a{
  font-family:"Fraunces",serif;font-weight:600;font-size:1.02rem;color:var(--ink);
  border:0;line-height:1.3;
}
.recommended li a:hover{color:var(--teal)}
.recommended li small{
  font-family:"Inter",sans-serif;font-size:.82rem;color:var(--ink-3);line-height:1.45;
}

/* Footer-wide recommended strip */
.footer-recommended{
  background:var(--paper-2);border-top:1px solid var(--line);padding:36px 0 28px;
}
.footer-recommended .grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.footer-recommended .item{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;
}
.footer-recommended .item a{
  font-family:"Fraunces",serif;font-weight:600;color:var(--ink);font-size:.98rem;border:0;display:block;line-height:1.3;
}
.footer-recommended .item a:hover{color:var(--teal)}
.footer-recommended .item small{font-family:"Inter",sans-serif;color:var(--ink-3);font-size:.8rem;display:block;margin-top:4px;line-height:1.4}
.footer-recommended .head{display:flex;justify-content:space-between;align-items:end;margin-bottom:18px;flex-wrap:wrap;gap:8px}
.footer-recommended h3{margin:0;font-size:1.25rem}
.footer-recommended .head small{
  font-family:"Inter",sans-serif;font-size:.78rem;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.site-footer{background:var(--ink);color:#cbc6bc;padding:56px 0 30px;font-family:"Inter",sans-serif}
.site-footer .cols{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:36px}
.site-footer h4{color:#fdf6e7;font-family:"Fraunces",serif;margin:0 0 14px;font-size:1.05rem}
.site-footer a{color:#cbc6bc;font-size:.92rem;display:block;padding:4px 0;border:0}
.site-footer a:hover{color:var(--amber)}
.site-footer .brand-block{display:flex;flex-direction:column;gap:10px;margin-bottom:6px}
.site-footer .brand-block .brand{color:#fdf6e7}
.site-footer .brand-block .brand small{color:var(--amber)}
.site-footer .colophon{
  margin-top:40px;border-top:1px solid #2f2a23;padding-top:18px;
  color:#857d70;font-size:.82rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
}

/* --------------------------------------------------------------------------
   Testimonials
   -------------------------------------------------------------------------- */
.testimonials{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px}
.tcard{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;
  display:flex;flex-direction:column;gap:12px;position:relative;
  border-bottom:3px solid var(--amber);
}
.tcard::before{
  content:"\201C";position:absolute;top:-22px;left:18px;font-family:"Fraunces",serif;
  font-size:5rem;color:var(--amber);line-height:1;opacity:.6;
}
.tcard .stars{color:var(--amber);font-family:"Inter",sans-serif;font-size:1.05rem;letter-spacing:.06em}
.tcard blockquote{margin:0;font-style:italic;color:var(--ink);line-height:1.55;font-size:1.02rem}
.tcard cite{font-style:normal;color:var(--ink-3);font-family:"Inter",sans-serif;font-size:.88rem;font-weight:500}

/* --------------------------------------------------------------------------
   Long-form articles (about, guides, etc.)
   -------------------------------------------------------------------------- */
.article{max-width:760px;margin:0 auto;padding:48px 0}
.article-layout{
  display:grid;grid-template-columns:1fr 290px;gap:48px;align-items:flex-start;
  max-width:1200px;margin:0 auto;padding:48px 28px;
}
.article-layout .article{padding:0;max-width:none}
.article-layout aside{position:sticky;top:90px;display:flex;flex-direction:column;gap:22px}
.article p{margin:0 0 1.05em;font-size:1.06rem;line-height:1.7}
.article h2{margin-top:1.8em;font-size:1.65rem}
.article h3{margin-top:1.45em;font-size:1.18rem}
.article ul,.article ol{padding-left:1.5em}
.article ul li,.article ol li{margin:.4em 0;line-height:1.6}
.article blockquote{
  border-left:3px solid var(--amber);
  padding:8px 18px;margin:1.5em 0;
  background:var(--paper-2);border-radius:0 var(--r) var(--r) 0;
  font-style:italic;color:var(--ink-2);
}
.article .lede{font-size:1.18rem;color:var(--ink-2);font-style:italic;margin-bottom:1.6em}
.article .crumb{font-family:"Inter",sans-serif;font-size:.88rem;color:var(--ink-3);margin:0 0 12px}
.article .tags{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0}
.article .tags span{
  background:var(--teal-soft);color:var(--teal-dark);font-family:"Inter",sans-serif;
  font-size:.78rem;padding:5px 11px;border-radius:999px;font-weight:500;
}

/* Hero band for inner pages */
.page-hero{
  background:linear-gradient(135deg,var(--teal-dark) 0%,var(--teal) 100%);
  color:#fdf6e7;padding:56px 0 50px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 80% 0%,rgba(216,154,58,.18),transparent 50%);
  pointer-events:none;
}
.page-hero h1{color:#fdf6e7;margin:0 0 10px}
.page-hero p{color:rgba(253,246,231,.92);font-size:1.08rem;max-width:680px;margin:0}
.page-hero .crumb{font-family:"Inter",sans-serif;color:var(--amber);font-size:.86rem;margin:0 0 12px;letter-spacing:.04em}
.page-hero .crumb a{color:var(--amber);border:0}

/* --------------------------------------------------------------------------
   Mobile nav (hamburger)
   -------------------------------------------------------------------------- */
/* Visually hidden but still focusable so keyboard + AT can toggle the menu */
.navtoggle{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;margin:0;border:0;padding:0;overflow:hidden;clip:rect(0 0 0 0)}
.navtoggle:focus-visible + .navbtn{outline:2px solid var(--amber);outline-offset:2px}
.navbtn{display:none;cursor:pointer;width:42px;height:42px;border-radius:8px;
  background:transparent;border:1px solid var(--line);align-items:center;justify-content:center;
  flex-direction:column;gap:5px;padding:0;margin-left:auto;flex-shrink:0;}
.navbtn span{display:block;width:20px;height:2px;background:var(--ink);border-radius:1px;transition:transform .2s,opacity .2s}
.nav-cta{display:none}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 980px){
  .navbtn{display:flex}
  .header-cta{display:none}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--surface);
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    flex-direction:column;padding:14px 20px;gap:0;box-shadow:var(--shadow);z-index:50}
  .nav a{display:block;padding:14px 6px;border-bottom:1px solid var(--line);font-size:1rem}
  .nav a:last-child{border-bottom:0}
  .nav .nav-cta{display:inline-block;margin-top:10px;text-align:center;padding:14px 20px;border:0}
  .navtoggle:checked ~ .nav{display:flex}
  .navtoggle:checked ~ .navbtn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .navtoggle:checked ~ .navbtn span:nth-child(2){opacity:0}
  .navtoggle:checked ~ .navbtn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .site-header .bar{position:relative;justify-content:space-between;flex-wrap:nowrap}
  .article-layout{grid-template-columns:1fr;gap:32px}
  .article-layout aside{position:static}
  .grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .page-hero{padding:38px 0 36px}
  .page-hero h1{font-size:1.85rem}
}
@media (max-width: 720px){
  body{font-size:16.5px}
  h1{font-size:1.85rem}
  .hero{padding:48px 0 64px}
  .hero h1{font-size:2.1rem;line-height:1.1}
  .hero p.lede{font-size:1.02rem}
  .hero .stats{gap:24px;flex-wrap:wrap;justify-content:center}
  .hero-search{flex-direction:column;padding:14px;gap:10px}
  .hero-search select,.hero-search input,.hero-search button{width:100%}
  .sale-detail{grid-template-columns:1fr;gap:24px;padding:24px 20px}
  .sale-detail aside{position:static}
  .list .row{grid-template-columns:1fr;gap:6px;padding:14px 16px}
  .list .row .more,.list .row .when{justify-self:start}
  .site-footer .cols{grid-template-columns:repeat(2,1fr)}
  .lead-form{padding:24px 18px}
  .lead-form form{grid-template-columns:1fr}
  .container{padding:0 18px}
  .grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr;gap:16px}
  .brand{font-size:1.2rem}
  .brand .mark{width:38px;height:38px;font-size:1.15rem}
  .brand small{font-size:.66rem}
  .page-hero{padding:32px 0 30px}
  .page-hero h1{font-size:1.65rem}
  .page-hero p{font-size:.98rem}
  .section-head{flex-direction:column;align-items:flex-start;gap:6px}
  .pager{flex-wrap:wrap}
  .meta-row{flex-direction:column;gap:8px;align-items:flex-start}
  .cat-pills{gap:6px}
  .cat-pills span,.cat-pills a span{font-size:.78rem;padding:5px 10px}
}
