/* =====================================================================
   comaison.com — site styles
   Extracted from index.html during Phase 2A.
   Block 1: main styles (was inline lines 84-470).
   Block 2: blog page styles (was inline lines 1805-1819 inside #page-blog).
   No rules were added, removed, reordered, or modified during extraction.
   ===================================================================== */

/* ======================== BLOCK 1 — MAIN STYLES ===================== */

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ivory:#F8F3EB;--ivory-deep:#EEE7D8;--paper:#FAF7F2;
  --ink:#24211B;--ink-soft:#3E3A32;
  --green:#2B4333;--green-mid:#3C5E4A;--green-pale:#EDF1EC;
  --bronze:#9B7940;--bronze-lt:#C5A164;
  --rule:rgba(42,66,50,0.13);--rule-b:rgba(155,121,64,0.28);
  --pos:#5a9e5a;
}
html{scroll-behavior:smooth}
body{overflow-x:hidden;background:var(--paper);color:var(--ink);font-family:'Libre Baskerville',Georgia,serif;font-size:16px;line-height:1.8;-webkit-font-smoothing:antialiased}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:200;background:var(--green);border-bottom:1px solid rgba(197,161,100,0.18);display:flex;align-items:center;justify-content:space-between;padding:0 4rem}
.nav-brand{display:flex;flex-direction:column;padding:1.1rem 0;cursor:pointer}
.nav-brand-name{font-family:'Playfair Display',serif;font-size:1.75rem;color:#fff;letter-spacing:0.14em;line-height:1}
.nav-rule{width:30px;height:1px;background:rgba(197,161,100,0.65);margin:5px 0}
.nav-sub{font-family:'Jost',sans-serif;font-size:0.58rem;font-weight:300;letter-spacing:0.38em;text-transform:uppercase;color:rgba(197,161,100,0.75)}
.nav-links{display:flex}
.nav-link{padding:1.35rem 1.1rem;font-family:'Jost',sans-serif;font-size:0.64rem;font-weight:400;letter-spacing:0.28em;text-transform:uppercase;color:rgba(248,243,235,0.58);cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s;white-space:nowrap}
.nav-link:hover,.nav-link.active{color:#fff;border-bottom-color:var(--bronze-lt)}
.nav-cta{margin-left:1.5rem;padding:0.65rem 1.5rem;background:var(--bronze);color:#fff;font-family:'Jost',sans-serif;font-size:0.62rem;font-weight:400;letter-spacing:0.28em;text-transform:uppercase;border:none;cursor:pointer;transition:background 0.2s;white-space:nowrap}
.nav-cta:hover{background:var(--bronze-lt)}

/* ── LAYOUT ── */
.section{padding:8rem 4rem}
.section-green{background:var(--green);padding:8rem 4rem}
.section-tinted{background:var(--ivory-deep);padding:8rem 4rem}
.wrap{max-width:1220px;margin:0 auto}
.eyebrow{display:flex;align-items:center;gap:0.9rem;margin-bottom:2rem}
.eyebrow::before{content:'';width:22px;height:1px;background:var(--bronze);flex-shrink:0}
.ey{font-family:'Jost',sans-serif;font-weight:400;font-size:0.6rem;letter-spacing:0.42em;text-transform:uppercase;color:var(--bronze)}
.eyebrow.lt::before{background:var(--bronze-lt)}
.eyebrow.lt .ey{color:var(--bronze-lt)}
h2{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(2.4rem,3.8vw,3.6rem);line-height:1.06;color:var(--ink);letter-spacing:-0.01em}
h2 em{font-style:italic;color:var(--green-mid)}
h2.lt{color:var(--ivory)}
h2.lt em{color:var(--bronze-lt)}
p.body{color:var(--ink-soft);line-height:1.88;margin-bottom:1.2rem;max-width:600px;font-size:0.96rem}
p.body.lt{color:rgba(248,243,235,0.7)}
p.body.wide{max-width:820px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.four-col{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
hr.rule{border:none;border-top:1px solid var(--rule);margin:0 4rem}
.pf{font-family:'Playfair Display',serif}
.jost{font-family:'Jost',sans-serif}

/* ── BUTTONS ── */
.btn-primary{padding:0.9rem 2.2rem;background:var(--bronze);color:#fff;font-family:'Jost',sans-serif;font-size:0.65rem;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;border:none;cursor:pointer;transition:background 0.2s}
.btn-primary:hover{background:var(--bronze-lt)}
.btn-outline{padding:0.9rem 2.2rem;background:transparent;color:rgba(248,243,235,0.75);font-family:'Jost',sans-serif;font-size:0.65rem;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;border:1px solid rgba(248,243,235,0.28);cursor:pointer;transition:all 0.2s}
.btn-outline:hover{border-color:rgba(248,243,235,0.65);color:#fff}
.btn-green{padding:0.7rem 1.5rem;background:var(--green);color:var(--ivory);font-family:'Jost',sans-serif;font-size:0.6rem;font-weight:400;letter-spacing:0.25em;text-transform:uppercase;border:none;cursor:pointer;transition:background 0.2s}
.btn-green:hover{background:var(--green-mid)}

/* ── HERO ── */
.hero{min-height:100vh;background:linear-gradient(155deg,#162419 0%,#2B4333 38%,#3C5E4A 68%,#1a2e22 100%);display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}
.hero-texture{position:absolute;inset:0;background-image:linear-gradient(rgba(197,161,100,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(197,161,100,0.035) 1px,transparent 1px);background-size:88px 88px}
.hero-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(197,161,100,0.07) 0%,transparent 55%)}
.hero-body{position:relative;z-index:2;padding:0 4rem;max-width:980px}
.hero-eyebrow{font-family:'Jost',sans-serif;font-weight:300;letter-spacing:0.45em;font-size:0.63rem;text-transform:uppercase;color:var(--bronze-lt);display:flex;align-items:center;gap:1rem;margin-bottom:1.8rem}
.hero-eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--bronze-lt)}
.hero-title{font-family:'Playfair Display',serif;font-weight:400;font-size:clamp(4rem,8.5vw,7.8rem);line-height:0.9;color:var(--ivory);letter-spacing:-0.02em;margin-bottom:2rem}
.hero-title em{color:var(--bronze-lt);font-style:italic}
.hero-intro{font-family:'Libre Baskerville',serif;font-size:1.05rem;font-style:italic;color:rgba(248,243,235,0.58);max-width:540px;line-height:1.75;margin-bottom:2.8rem}
.hero-btns{display:flex;gap:1rem;margin-bottom:0}
.hero-bar{position:relative;z-index:2;display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid rgba(197,161,100,0.18);margin-top:3.5rem}
.hb-cell{padding:1.6rem 2rem;border-right:1px solid rgba(197,161,100,0.12);background:rgba(20,16,11,0.5);backdrop-filter:blur(8px)}
.hb-cell:last-child{border-right:none}
.hb-lbl{font-family:'Jost',sans-serif;font-size:0.55rem;font-weight:400;letter-spacing:0.28em;text-transform:uppercase;color:rgba(197,161,100,0.5);margin-bottom:0.4rem}
.hb-val{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--ivory);line-height:1.1;display:block}
.hb-sub{font-size:0.72rem;font-style:italic;color:rgba(248,243,235,0.28);margin-top:0.2rem}

/* ── NOT TIMESHARE ── */
.compare-wrap{display:grid;grid-template-columns:1fr 1fr;margin-top:3rem;border:1px solid var(--rule)}
.compare-header{padding:1.4rem 2rem;font-family:'Playfair Display',serif;font-size:1.05rem}
.compare-header.good{background:var(--green);color:#F8F3EB}
.compare-header.bad{background:rgba(36,33,27,0.06);color:rgba(36,33,27,0.45);font-style:italic}
.compare-row{display:contents}
.compare-cell{padding:1.1rem 2rem;font-size:0.9rem;border-top:1px solid var(--rule)}
.compare-cell.good{background:var(--green-pale);color:var(--ink-soft)}
.compare-cell.bad{background:var(--ivory-deep);color:rgba(36,33,27,0.42);text-decoration:line-through;text-decoration-color:rgba(155,121,64,0.3)}

/* ── DIFF CARDS ── */
.diff-card{padding:2.8rem 2.2rem;background:var(--paper);border:1px solid var(--rule);border-top:3px solid var(--green);transition:transform 0.2s,box-shadow 0.2s}
.diff-card:hover{transform:translateY(-4px);box-shadow:0 16px 50px rgba(42,66,50,0.1)}
.diff-num{font-family:'Playfair Display',serif;font-size:2.8rem;color:rgba(42,66,50,0.09);line-height:1;margin-bottom:1rem}
.diff-title{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--green);margin-bottom:0.7rem}
.diff-desc{font-size:0.9rem;color:var(--ink-soft);line-height:1.78}

/* ── STEPS ── */
.step-grid{display:grid;grid-template-columns:repeat(3,1fr);margin-top:3rem;border:1px solid var(--rule)}
.step{padding:2.8rem 2.2rem}
.step+.step{border-left:1px solid var(--rule)}
.step-row2{border-top:1px solid var(--rule)}
.step-num{font-family:'Playfair Display',serif;font-size:3.5rem;color:rgba(42,66,50,0.08);line-height:1;margin-bottom:1rem}
.step-title{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--ink);margin-bottom:0.8rem}
.step-desc{font-size:0.9rem;color:var(--ink-soft);line-height:1.78}

/* ── POINTS PANEL ── */
.points-panel{background:rgba(255,255,255,0.045);border:1px solid rgba(248,243,235,0.14);position:relative;overflow:hidden}
.points-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--bronze-lt),transparent)}
.points-head{padding:1.4rem 2rem;border-bottom:1px solid rgba(248,243,235,0.08);font-family:'Jost',sans-serif;font-size:0.58rem;font-weight:400;letter-spacing:0.38em;text-transform:uppercase;color:var(--bronze-lt)}
.point-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid rgba(248,243,235,0.06);font-size:0.9rem}
.point-row:last-child{border-bottom:none}
.pr-label{color:rgba(248,243,235,0.55);font-family:'Libre Baskerville',serif}
.pr-val{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--bronze-lt)}

/* ── PROPERTIES ── */
.prop-card{background:var(--paper);border:1px solid var(--rule);overflow:hidden;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s}
.prop-card:hover{transform:translateY(-5px);box-shadow:0 18px 55px rgba(42,66,50,0.13)}
.prop-hero{height:280px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.prop-hero-bg{position:absolute;inset:0;background:linear-gradient(145deg,#162419 0%,#2B4333 40%,#3C5E4A 75%)}
.prop-hero-bg2{background:linear-gradient(155deg,#1a2420 0%,#2B4333 45%,#4a6a3a 75%)}
.prop-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(36,33,27,0.82) 0%,rgba(36,33,27,0.1) 55%,transparent)}
.prop-badge{position:absolute;top:1.2rem;left:1.2rem;padding:0.3rem 0.9rem;background:var(--bronze);font-family:'Jost',sans-serif;font-size:0.55rem;font-weight:400;letter-spacing:0.25em;text-transform:uppercase;color:#fff}
.prop-loc{font-family:'Jost',sans-serif;font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;color:rgba(197,161,100,0.8);margin-bottom:0.4rem;position:relative;z-index:1}
.prop-name-hero{font-family:'Playfair Display',serif;font-size:1.6rem;font-style:italic;color:#F8F3EB;position:relative;z-index:1}
.prop-hero-text{padding:1.5rem 1.8rem;position:relative;z-index:1}
.prop-body{padding:2rem 1.8rem}
.prop-desc{font-size:0.9rem;color:var(--ink-soft);line-height:1.75;margin-bottom:1.5rem}
.prop-stat-row{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--rule);margin-bottom:1.5rem}
.ps{padding:1rem 0.8rem;text-align:center}
.ps+.ps{border-left:1px solid var(--rule)}
.ps-val{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--green);display:block}
.ps-lbl{font-family:'Jost',sans-serif;font-size:0.54rem;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:rgba(36,33,27,0.38);margin-top:0.3rem}
.prop-price-row{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;border-top:1px solid var(--rule)}
.pp-label{font-family:'Jost',sans-serif;font-size:0.58rem;font-weight:400;letter-spacing:0.25em;text-transform:uppercase;color:rgba(36,33,27,0.45);margin-bottom:0.3rem}
.pp-val{font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--green)}
.coming-soon{border:1px dashed rgba(42,66,50,0.18);background:var(--ivory-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;min-height:420px}
.cs-country{font-family:'Playfair Display',serif;font-size:1.5rem;font-style:italic;color:rgba(42,66,50,0.35)}
.cs-sub{font-family:'Jost',sans-serif;font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;color:rgba(42,66,50,0.25)}

/* ── PULLQUOTE ── */
.pq{border-left:2px solid var(--bronze);padding:2rem 3.5rem;background:var(--ivory-deep);margin:4rem 0}
.pq p{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:400;font-style:italic;color:var(--green);line-height:1.5}
.pq.lt{background:rgba(255,255,255,0.05);border-left-color:var(--bronze-lt)}
.pq.lt p{color:#F8F3EB}

/* ── STAT STRIP ── */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(248,243,235,0.1);border-bottom:1px solid rgba(248,243,235,0.1);margin-top:4rem}
.ss-cell{padding:2.5rem 2rem;text-align:center}
.ss-cell+.ss-cell{border-left:1px solid rgba(248,243,235,0.1)}
.ss-val{font-family:'Playfair Display',serif;font-size:2.8rem;color:var(--bronze-lt);display:block;line-height:1}
.ss-lbl{font-family:'Jost',sans-serif;font-size:0.58rem;font-weight:300;letter-spacing:0.28em;text-transform:uppercase;color:rgba(248,243,235,0.38);margin-top:0.5rem}

/* ── DASHBOARD ── */
.dash-wrap{display:grid;grid-template-columns:250px 1fr;border:1px solid var(--rule);min-height:640px;background:var(--paper)}
.dash-sidebar{background:var(--green)}
.dash-sidebar-top{padding:1.8rem 1.5rem;border-bottom:1px solid rgba(248,243,235,0.1)}
.dash-avatar{width:44px;height:44px;border-radius:50%;background:rgba(197,161,100,0.18);display:flex;align-items:center;justify-content:center;margin-bottom:0.8rem}
.dash-avatar span{font-family:'Playfair Display',serif;color:var(--bronze-lt);font-size:1rem}
.dash-user{font-family:'Playfair Display',serif;font-size:1.1rem;color:#F8F3EB}
.dash-role{font-family:'Jost',sans-serif;font-size:0.57rem;letter-spacing:0.25em;text-transform:uppercase;color:rgba(197,161,100,0.55);margin-top:0.3rem}
.dash-nav{padding:1rem 0}
.dash-item{display:flex;align-items:center;gap:0.75rem;padding:0.7rem 1.5rem;cursor:pointer;transition:background 0.15s;font-family:'Jost',sans-serif;font-size:0.65rem;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:rgba(248,243,235,0.5);border-left:2px solid transparent}
.dash-item:hover{background:rgba(255,255,255,0.05);color:rgba(248,243,235,0.8)}
.dash-item.active{background:rgba(197,161,100,0.1);color:#F8F3EB;border-left-color:var(--bronze-lt)}
.dash-main{padding:2.5rem;overflow:auto}
.dash-title{font-family:'Playfair Display',serif;font-size:1.7rem;color:var(--ink);margin-bottom:0.3rem}
.dash-subtitle{font-family:'Libre Baskerville',serif;font-size:0.88rem;font-style:italic;color:var(--ink-soft);margin-bottom:2rem}
.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}
.metric{background:var(--ivory-deep);border:1px solid var(--rule);padding:1.5rem}
.metric-lbl{font-family:'Jost',sans-serif;font-size:0.57rem;font-weight:400;letter-spacing:0.25em;text-transform:uppercase;color:rgba(36,33,27,0.45);margin-bottom:0.5rem}
.metric-val{font-family:'Playfair Display',serif;font-size:2.1rem;color:var(--green);line-height:1}
.metric-sub{font-size:0.8rem;font-style:italic;color:var(--pos);margin-top:0.4rem}
.activity{background:var(--ivory-deep);border:1px solid var(--rule);padding:1.5rem}
.act-head{font-family:'Jost',sans-serif;font-size:0.57rem;font-weight:400;letter-spacing:0.25em;text-transform:uppercase;color:rgba(36,33,27,0.45);margin-bottom:1rem}
.act-item{display:flex;justify-content:space-between;align-items:center;padding:0.85rem 0;border-bottom:1px solid var(--rule);font-size:0.88rem}
.act-item:last-child{border-bottom:none}
.ai-title{color:var(--ink)}
.ai-sub{font-size:0.78rem;color:var(--ink-soft);margin-top:0.2rem}
.ai-val{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--bronze)}
.cal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0.5rem;margin:1.2rem 0}
.cal-week{padding:0.85rem;border:1px solid var(--rule);text-align:center;cursor:pointer;transition:all 0.15s;background:var(--paper)}
.cal-week:hover{border-color:rgba(42,66,50,0.3);background:var(--green-pale)}
.cal-week.taken{background:var(--ivory-deep);cursor:not-allowed;opacity:0.5}
.cal-week.mine{border-color:var(--bronze);background:rgba(155,121,64,0.06)}
.cw-date{font-size:0.82rem;color:var(--ink-soft)}
.cw-pts{font-family:'Jost',sans-serif;font-size:0.56rem;letter-spacing:0.2em;text-transform:uppercase;margin-top:0.3rem}
.cw-pts.avail{color:var(--pos)}
.cw-pts.shoulder{color:var(--bronze)}
.cw-pts.taken{color:rgba(36,33,27,0.35)}
.cw-pts.mine{color:var(--bronze)}
.swap-card{background:var(--ivory-deep);border:1px solid var(--rule);padding:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:0.8rem}
.sc-prop{font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--ink)}
.sc-detail{font-size:0.83rem;color:var(--ink-soft);margin-top:0.25rem}
.sc-pts{font-family:'Jost',sans-serif;font-size:0.57rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--bronze);margin-top:0.5rem}
.vc-wrap{background:var(--ivory-deep);border:1px solid var(--rule);padding:1.5rem;margin-bottom:1rem}
.vc-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}
.vc-prop{font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--ink)}
.vc-pct{font-family:'Jost',sans-serif;font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--pos)}
.vc-nums{display:flex;justify-content:space-between;margin-bottom:0.6rem}
.vc-purchase{font-size:0.82rem;color:var(--ink-soft)}
.vc-current{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--green)}
.bars{display:flex;align-items:flex-end;gap:3px;height:55px;margin-bottom:0.5rem}
.bar{flex:1;background:var(--green);border-radius:1px 1px 0 0}
.bar-labels{display:flex;justify-content:space-between;font-family:'Jost',sans-serif;font-size:0.54rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(36,33,27,0.35)}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.proj{padding:2rem 1.5rem;border:1px solid var(--rule);text-align:center}
.proj.featured{border-color:var(--bronze);background:rgba(155,121,64,0.04)}
.proj-badge{display:inline-block;padding:0.25rem 0.8rem;background:var(--bronze);color:#fff;font-family:'Jost',sans-serif;font-size:0.55rem;letter-spacing:0.25em;text-transform:uppercase;margin-bottom:1rem}
.proj-scenario{font-family:'Jost',sans-serif;font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;color:rgba(36,33,27,0.45);margin-bottom:0.5rem}
.proj-val{font-family:'Playfair Display',serif;font-size:2.5rem;color:var(--green);line-height:1;margin-bottom:0.4rem}
.proj-gain{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--bronze)}

/* ── FORM ── */
.form-field{display:flex;flex-direction:column;gap:0.5rem;margin-bottom:1.4rem}
.form-label{font-family:'Jost',sans-serif;font-size:0.6rem;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;color:rgba(248,243,235,0.55)}
.form-input{padding:0.85rem 1rem;background:rgba(255,255,255,0.06);border:1px solid rgba(248,243,235,0.14);color:#F8F3EB;font-family:'Libre Baskerville',serif;font-size:0.9rem;outline:none;transition:border-color 0.2s;width:100%}
.form-input:focus{border-color:rgba(197,161,100,0.45)}
.form-input::placeholder{color:rgba(248,243,235,0.22)}
select.form-input option{background:var(--green)}
textarea.form-input{resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}

/* ── FEATURE LIST ── */
.feat-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;margin-top:2.5rem}
.feat-list li{display:flex;align-items:flex-start;gap:0.8rem;padding:0.95rem 0;border-bottom:1px solid var(--rule);font-size:0.9rem;color:var(--ink-soft)}
.feat-list li::before{content:'—';color:var(--bronze);flex-shrink:0}

/* ── FOOTER ── */
.footer-main{background:var(--green);padding:5rem 4rem;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:4rem}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:2rem;color:#F8F3EB;letter-spacing:0.12em}
.footer-rule{width:28px;height:1px;background:rgba(197,161,100,0.55);margin:0.5rem 0}
.footer-brand-sub{font-family:'Jost',sans-serif;font-size:0.58rem;font-weight:300;letter-spacing:0.38em;text-transform:uppercase;color:rgba(197,161,100,0.65);margin-bottom:1.2rem}
.footer-desc{font-size:0.85rem;color:rgba(248,243,235,0.38);line-height:1.75;max-width:260px}
.footer-col-title{font-family:'Jost',sans-serif;font-size:0.6rem;font-weight:400;letter-spacing:0.38em;text-transform:uppercase;color:rgba(197,161,100,0.55);margin-bottom:1.5rem}
.footer-link{display:block;font-size:0.88rem;color:rgba(248,243,235,0.42);margin-bottom:0.6rem;cursor:pointer;transition:color 0.15s}
.footer-link:hover{color:rgba(248,243,235,0.85)}
.footer-bottom{background:rgba(0,0,0,0.25);padding:1.2rem 4rem;display:flex;justify-content:space-between;font-family:'Jost',sans-serif;font-size:0.58rem;font-weight:300;letter-spacing:0.2em;text-transform:uppercase;color:rgba(248,243,235,0.22)}

/* ── TABLET ── */

/* ══════════════════════════════════════════════
   TABLET  ≤ 1024px
══════════════════════════════════════════════ */
@media(max-width:1024px){
  .four-col{grid-template-columns:1fr 1fr}
  .three-col{grid-template-columns:1fr 1fr}
  nav{padding:0 2rem}
  .section,.section-green,.section-tinted{padding:6rem 2.5rem}
  .hero-body{padding:0 2.5rem}
}

/* ══════════════════════════════════════════════
   MOBILE  ≤ 768px
══════════════════════════════════════════════ */
@media(max-width:768px){

  /* ── Nav ── */
  nav{padding:0 1.2rem}
  .nav-links{display:none}
  .nav-cta{padding:0.5rem 1rem;font-size:0.58rem;margin-left:0.5rem}
  .nav-brand-name{font-size:1.4rem}

  /* ── Sections ── */
  .section,.section-green,.section-tinted{padding:4rem 1.2rem}
  hr.rule{margin:0 1.2rem}

  /* ── Hero ── */
  .hero{min-height:100svh}
  .hero-body{padding:0 1.2rem;max-width:100%}
  .hero-title{font-size:2.6rem;line-height:0.95}
  .hero-intro{font-size:0.95rem}
  .hero-btns{flex-direction:column;gap:0.75rem}
  .btn-primary,.btn-outline{width:100%;text-align:center;padding:1rem;box-sizing:border-box}
  .hero-bar{grid-template-columns:1fr 1fr!important;margin-top:2rem}
  .hb-cell{padding:1.2rem 1rem}
  .hb-val{font-size:1.05rem}

  /* ── Typography ── */
  h2{font-size:2rem}
  .pq{padding:1.5rem}
  .pq p{font-size:1.2rem}

  /* ── Gallery strip ── */
  .gallery-strip-grid{display:flex!important;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:3px}
  .gallery-strip-grid > div{flex:0 0 80vw;scroll-snap-align:start}

  /* ── Property cards ── */
  .two-col,.three-col,.four-col{grid-template-columns:1fr}
  .prop-hero{height:220px}
  .prop-stat-row{grid-template-columns:repeat(3,1fr)!important}
  .prop-price-row{flex-direction:column;gap:1rem;align-items:flex-start}

  /* ── Home preview & properties page ── */
  #page-home .three-col,
  #page-properties .three-col{grid-template-columns:1fr}

  /* ── Brochure page ── */
  #brochure-cards{grid-template-columns:1fr!important;gap:2rem!important}
  #brochure-gate .form-row{grid-template-columns:1fr!important}

  /* ── Blog index cards ── */
  #blog-index .three-col,
  #page-blog .three-col{grid-template-columns:1fr}
  .article-body{padding:0}
  .article-body h3{font-size:1.2rem}

  /* ── How It Works ── */
  .step-grid{border:none}
  .step{padding:1.8rem 0;border-bottom:1px solid var(--rule)}
  .step+.step{border-left:none}
  .compare-wrap{grid-template-columns:1fr!important}
  .compare-header.bad{display:none}
  .compare-cell.bad{display:none}
  .diff-card{padding:2rem 1.5rem}
  .points-panel{margin-top:2rem}

  /* ── Dashboard ── */
  .dash-wrap{grid-template-columns:1fr!important}
  .dash-sidebar{display:flex;overflow-x:auto;gap:0}
  .dash-sidebar-top{display:none}
  .dash-nav{display:flex;padding:0;min-width:max-content}
  .dash-item{padding:0.75rem 1rem;border-left:none;border-bottom:2px solid transparent;white-space:nowrap;font-size:0.7rem}
  .dash-item.active{border-left:none;border-bottom-color:var(--bronze-lt)}
  .dash-main{padding:1.5rem 1.2rem}
  .metric-row{gap:0.75rem;grid-template-columns:1fr 1fr!important}

  /* ── Stat strips ── */
  .stat-strip{grid-template-columns:1fr 1fr!important}
  .ss-val{font-size:2rem}

  /* ── All inline multi-col grids → single column ── */
  [style*="grid-template-columns:1fr 1fr 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr 1fr"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns:repeat(5"]{
    grid-template-columns:1fr!important
  }
  /* Keep 2-col stat boxes readable */
  [style*="grid-template-columns:repeat(3,1fr)"].prop-stat-row,
  [style*="grid-template-columns:repeat(5,1fr)"].prop-stat-row{
    grid-template-columns:repeat(3,1fr)!important
  }
  /* Keep 2-col inline grids where intentional */
  [style*="grid-template-columns:1fr 1fr"]:not(.hero-bar):not(.metric-row){
    grid-template-columns:1fr!important
  }

  /* ── Financial / projection blocks ── */
  .proj-grid{grid-template-columns:1fr!important}
  .flight-grid{grid-template-columns:1fr!important}

  /* ── Before/after strip ── */
  [style*="grid-template-columns:1fr 1fr 1fr;gap:3px"],
  [style*="grid-template-columns:1fr 1fr 1fr 1fr;gap:3px"]{
    grid-template-columns:1fr 1fr!important
  }

  /* ── Contact form ── */
  .form-row{grid-template-columns:1fr!important}
  #page-contact [style*="grid-template-columns"]{grid-template-columns:1fr!important}

  /* ── Footer ── */
  .footer-main{grid-template-columns:1fr;padding:3rem 1.2rem;gap:2rem}
  .footer-bottom{flex-direction:column;gap:0.5rem;padding:1rem 1.2rem;font-size:0.7rem;text-align:center}
  .footer-link{display:block;padding:0.3rem 0}

  /* ── Misc ── */
  .pq{padding:1.5rem 1.2rem}
  [style*="display:flex"][style*="gap"]{flex-wrap:wrap}
  .eyebrow-text{font-size:0.55rem}
}

/* ══════════════════════════════════════════════
   SMALL PHONE  ≤ 480px
══════════════════════════════════════════════ */
@media(max-width:480px){
  .hero-title{font-size:2.1rem}
  .hero-bar{grid-template-columns:1fr 1fr!important}
  .hb-cell:nth-child(n+5){display:none}
  .nav-brand-name{font-size:1.2rem}
  h2{font-size:1.75rem}
  .prop-stat-row{grid-template-columns:repeat(2,1fr)!important}
  .prop-hero{height:190px}
  .gallery-strip-grid > div{flex:0 0 90vw}
  [style*="font-size:3rem"],[style*="font-size:2.5rem"]{font-size:1.8rem!important}
  .hb-val{font-size:0.95rem}
  .dash-item{padding:0.6rem 0.8rem;font-size:0.62rem}
  .btn-primary,.btn-outline{font-size:0.6rem;padding:0.9rem}
  #brochure-cards [style*="height:280px"]{height:200px!important}
  .section,.section-green,.section-tinted{padding:3rem 1rem}
}

/* ======================== BLOCK 2 — BLOG STYLES ===================== */

.article-body h3{font-family:'Playfair Display',serif;font-weight:400;font-size:1.35rem;color:var(--green);margin:2.2rem 0 0.9rem}
.article-body p{color:var(--ink-soft);line-height:1.9;margin-bottom:1.2rem;font-size:0.97rem;max-width:680px}
.article-body strong{color:var(--ink);font-weight:normal;font-family:'Jost',sans-serif;font-size:0.9rem;font-weight:500;letter-spacing:0.01em}
.article-pullquote{border-left:2px solid var(--bronze);padding:1.5rem 2.5rem;background:var(--ivory-deep);margin:2.5rem 0}
.article-pullquote p{font-family:'Playfair Display',serif;font-size:1.35rem;font-style:italic;color:var(--green);line-height:1.5;margin:0;max-width:100%}
.blog-card{border:1px solid var(--rule);overflow:hidden;cursor:pointer;background:var(--paper);transition:transform 0.2s,box-shadow 0.2s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 14px 45px rgba(42,66,50,0.1)}
.blog-card-img{height:220px;overflow:hidden;position:relative}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.blog-card:hover .blog-card-img img{transform:scale(1.04)}
.blog-card-body{padding:1.8rem}
.blog-cat{font-family:'Jost',sans-serif;font-size:0.57rem;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;color:var(--bronze);margin-bottom:0.5rem}
.blog-title{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--ink);margin-bottom:0.7rem;line-height:1.25}
.blog-excerpt{font-size:0.88rem;color:var(--ink-soft);line-height:1.7;margin-bottom:1.2rem}
.blog-meta{display:flex;justify-content:space-between;align-items:center;font-family:'Jost',sans-serif;font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(36,33,27,0.4)}
