/* We Sell Your House — Warm Luxury palette
   charcoal + warm ivory + brass/gold. Serif display (Cormorant Garamond),
   sans body (Inter). */

:root{
  --ink:#1c1a17;          /* near-black charcoal */
  --ink-soft:#3b3833;
  --paper:#f6f1e9;        /* warm ivory */
  --paper-2:#efe7da;      /* deeper ivory for alt sections */
  --card:#fffdf9;
  --line:#e2d8c7;
  --brass:#a9803f;        /* brass/gold accent */
  --brass-deep:#8a6630;
  --brass-soft:#c9a567;
  --muted:#6f685d;
  --white:#ffffff;
  --shadow:0 18px 50px -22px rgba(28,26,23,.45);
  --shadow-sm:0 6px 20px -12px rgba(28,26,23,.4);
  --radius:16px;
  --radius-sm:10px;
  --maxw:1140px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand-name,.card-title{
  font-family:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  font-weight:600;
  line-height:1.12;
  letter-spacing:.2px;
}
a{color:var(--brass-deep);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.hi{color:var(--brass)}

.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:16px;top:12px;background:var(--ink);color:#fff;padding:8px 14px;border-radius:8px;z-index:99}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(246,241,233,.86);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-row{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-mark{
  font-family:'Inter',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:1px;
  background:var(--ink);color:var(--brass-soft);
  padding:8px 9px;border-radius:8px;
}
.brand-name{font-size:1.35rem;color:var(--ink)}
.primary-nav{display:flex;align-items:center;gap:26px}
.primary-nav a{color:var(--ink-soft);font-weight:500;font-size:.95rem}
.primary-nav a:hover{color:var(--brass-deep);text-decoration:none}
.nav-cta,.nav-dashboard{
  background:var(--ink);color:var(--paper)!important;
  padding:9px 16px;border-radius:999px;font-weight:600;
}
.nav-cta:hover{background:var(--brass-deep);text-decoration:none}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);display:block}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;border-radius:999px;padding:13px 26px;font-weight:600;
  font-size:.98rem;cursor:pointer;border:1px solid transparent;transition:.18s ease;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--brass);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--brass-deep);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass-deep)}
.full{width:100%;text-align:center}

/* ---------- Flash ---------- */
.flash-stack{margin-top:16px;display:grid;gap:10px}
.flash{padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--card)}
.flash-success{border-color:#b9d8b9;background:#eef7ee;color:#27632a}
.flash-error{border-color:#e6bcbc;background:#fbeeee;color:#9a2b2b}

/* ---------- Eyebrows / headings ---------- */
.eyebrow{
  text-transform:uppercase;letter-spacing:2.5px;font-size:.72rem;font-weight:700;
  color:var(--brass-deep);margin:0 0 14px;
}
.eyebrow-accent{color:var(--brass-deep)}
.section-head{max-width:680px;margin:0 auto;text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:.2em 0 .35em}

/* ---------- Hero ---------- */
.hero{padding:72px 0 30px}
.hero-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:54px;align-items:center}
.hero-copy h1{font-size:clamp(2.6rem,5.2vw,4.1rem);margin:.1em 0 .3em}
.lede{font-size:1.15rem;color:var(--ink-soft);max-width:34em}
.trust-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.trust-pill{
  font-size:.82rem;font-weight:600;color:var(--ink-soft);
  background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 14px;
}
.hero-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow);
}
.card-h{text-transform:uppercase;letter-spacing:2px;font-size:.7rem;font-weight:700;color:var(--brass-deep)}
.card-title{font-size:1.9rem;margin:.25em 0 .15em}

/* ---------- Forms ---------- */
.form-stack{display:grid;gap:16px;margin-top:18px}
.row{display:grid;gap:6px}
.row label{font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.row input,.row select{
  width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);
  font:inherit;background:var(--white);color:var(--ink);
}
.row input:focus,.row select:focus{outline:2px solid var(--brass-soft);border-color:var(--brass)}
.err{color:#9a2b2b;font-size:.82rem;margin:2px 0 0}

/* ---------- Stat strip ---------- */
.strip{background:var(--ink);color:var(--paper);margin-top:30px}
.strip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:40px 24px}
.strip-num{font-family:'Cormorant Garamond',serif;font-size:2.6rem;color:var(--brass-soft);line-height:1}
.strip-num span{display:block;font-family:'Inter',sans-serif;font-size:.72rem;letter-spacing:2px;
  text-transform:uppercase;color:#cbbfa6;margin-top:6px}
.strip .muted{color:#cbbfa6;margin-top:10px;font-size:.95rem}

/* ---------- Sections ---------- */
.section{padding:80px 0}
.section-alt{background:var(--paper-2)}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:46px}
.cat-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow-sm);
}
.cat-card h3{display:flex;align-items:center;gap:12px;font-size:1.5rem;margin:0 0 .4em}
.cat-mark{
  font-family:'Inter',sans-serif;font-weight:700;font-size:.8rem;
  width:34px;height:34px;display:grid;place-items:center;flex:0 0 34px;
  background:var(--paper-2);color:var(--brass-deep);border-radius:9px;border:1px solid var(--line);
}
.cat-card p{color:var(--ink-soft);margin:0}

/* ---------- Two column / about ---------- */
.two-col{display:grid;grid-template-columns:1.3fr .85fr;gap:50px;align-items:start}
.prose h2{font-size:clamp(1.8rem,3.2vw,2.5rem);margin:.15em 0 .5em}
.prose p{color:var(--ink-soft);margin:0 0 1.1em}
.side-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.facts{list-style:none;padding:0;margin:14px 0 22px;display:grid;gap:12px}
.facts li{border-bottom:1px dashed var(--line);padding-bottom:10px;color:var(--ink-soft)}
.facts strong{color:var(--ink)}

/* ---------- CTA ---------- */
.cta{padding:70px 0}
.cta-row{
  display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:40px;box-shadow:var(--shadow);
}
.cta-row h2{font-size:2rem;margin:.1em 0 .3em}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--paper);padding:54px 0 26px;margin-top:10px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px}
.footer-brand{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--brass-soft);margin-bottom:10px}
.site-footer .muted{color:#bdb29c}
.site-footer a{color:var(--paper)}
.site-footer a:hover{color:var(--brass-soft)}
.footer-h{text-transform:uppercase;letter-spacing:2px;font-size:.72rem;color:var(--brass-soft);margin-bottom:12px;font-weight:700}
.footer-nav{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.footer-bottom{margin-top:34px;padding-top:18px;border-top:1px solid #34302a;font-size:.85rem}
.footer-bottom .muted{color:#9a907d}

/* ---------- SOLD badge (45° corner ribbon, used on listing cards) ---------- */
.listing-card{position:relative;overflow:hidden}
.sold-ribbon{
  position:absolute;top:18px;right:-46px;transform:rotate(45deg);
  background:#9a2b2b;color:#fff;font-weight:700;letter-spacing:2px;font-size:.74rem;
  text-transform:uppercase;padding:7px 60px;box-shadow:var(--shadow-sm);z-index:3;
}

/* ---------- Page head (interior pages) ---------- */
.page-head{padding:54px 0 6px;background:var(--paper)}
.page-head h1{font-size:clamp(2.2rem,4.4vw,3.2rem);margin:.1em 0 .2em}
.page-head .lede{max-width:40em}
.section-top{padding-top:40px}
.section-head-left{max-width:none;margin:0 0 26px;text-align:left}
.back-link{margin:0 0 22px}
.back-link a{font-weight:600;font-size:.9rem}
.empty-state{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:48px;text-align:center}
.empty-state h3{font-size:1.6rem;margin:0 0 .3em}

/* ---------- Realtor grid + cards ---------- */
.realtor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px}
.realtor-card{position:relative;display:block;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);color:var(--ink);
  transition:.18s ease}
.realtor-card:hover{text-decoration:none;transform:translateY(-3px);box-shadow:var(--shadow)}
.feat-tag{position:absolute;top:12px;left:12px;z-index:2;background:var(--brass);color:#fff;
  font-size:.66rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.realtor-photo{aspect-ratio:4/3;background:var(--paper-2);display:grid;place-items:center;overflow:hidden}
.realtor-photo img{width:100%;height:100%;object-fit:cover}
.photo-initials{font-family:'Cormorant Garamond',serif;font-size:3.4rem;color:var(--brass);font-weight:600}
.realtor-body{padding:18px 20px 22px}
.realtor-body h3{font-size:1.4rem;margin:0 0 .15em}
.r-title{color:var(--ink-soft);font-weight:600;font-size:.9rem;margin:0 0 .3em}
.r-link{display:inline-block;margin-top:10px;color:var(--brass-deep);font-weight:600;font-size:.9rem}

/* ---------- Listing grid + cards ---------- */
.listing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.listing-card{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);color:var(--ink);transition:.18s ease}
.listing-card:hover{text-decoration:none;transform:translateY(-3px);box-shadow:var(--shadow)}
.listing-photo{position:relative;aspect-ratio:4/3;background:var(--paper-2);display:grid;place-items:center;
  overflow:hidden;border-radius:var(--radius) var(--radius) 0 0}
.listing-photo img{width:100%;height:100%;object-fit:cover}
.photo-placeholder{font-family:'Inter',sans-serif;font-size:.8rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.status-chip{position:absolute;bottom:10px;left:10px;background:rgba(28,26,23,.85);color:#fff;
  font-size:.7rem;font-weight:600;padding:5px 10px;border-radius:6px}
.listing-body{padding:16px 18px 20px}
.listing-price{font-family:'Cormorant Garamond',serif;font-size:1.7rem;color:var(--brass-deep);font-weight:700;line-height:1}
.listing-addr{font-weight:600;margin-top:6px}
.listing-specs{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px;color:var(--ink-soft);font-size:.85rem}
.listing-specs span{white-space:nowrap}

/* ---------- Realtor profile ---------- */
.profile-head{display:flex;gap:30px;align-items:flex-start;flex-wrap:wrap}
.profile-photo{width:170px;height:170px;flex:0 0 170px;border-radius:var(--radius);overflow:hidden;
  background:var(--paper-2);display:grid;place-items:center;border:1px solid var(--line)}
.profile-photo img{width:100%;height:100%;object-fit:cover}
.profile-meta{flex:1;min-width:260px}
.profile-meta h1{font-size:clamp(2rem,3.6vw,2.8rem);margin:0 0 .1em}
.profile-actions{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0}
.profile-bio{margin-top:30px;max-width:60ch}
.profile-bio h2{font-size:1.5rem;margin:0 0 .4em}
.reco-line{margin-top:18px;border-top:1px solid var(--line);padding-top:12px}

/* ---------- Social icons ---------- */
.social-icons{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.social-icons a{width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--line);
  border-radius:999px;background:var(--card);transition:.16s ease}
.social-icons a:hover{border-color:var(--brass);background:var(--brass);transform:translateY(-2px)}
.social-icons svg{width:18px;height:18px;fill:var(--ink-soft)}
.social-icons a:hover svg{fill:#fff}

/* ---------- Listing detail ---------- */
.gallery{position:relative;margin-bottom:28px}
.gallery-main{aspect-ratio:16/10;background:var(--paper-2);border-radius:var(--radius);overflow:hidden;display:grid;place-items:center}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.thumb{width:84px;height:62px;padding:0;border:2px solid transparent;border-radius:8px;overflow:hidden;cursor:pointer;background:none}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.active{border-color:var(--brass)}
.sold-ribbon-lg{top:26px;right:-40px;font-size:.95rem;padding:9px 64px}
.listing-detail-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:36px;align-items:start}
.ld-head{display:flex;align-items:center;gap:16px;margin-bottom:6px}
.ld-price{font-family:'Cormorant Garamond',serif;font-size:2.4rem;color:var(--brass-deep);font-weight:700;line-height:1}
.status-badge{font-size:.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.status-active{background:#eef7ee;color:#27632a}
.status-pending{background:#fff4e2;color:#9a6a16}
.status-sold{background:#fbeeee;color:#9a2b2b}
.listing-main h1{font-size:clamp(1.6rem,3vw,2.2rem);margin:.1em 0}
.spec-row{display:flex;flex-wrap:wrap;gap:26px;margin:22px 0;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.spec{display:flex;flex-direction:column}
.spec strong{font-size:1.3rem;font-family:'Cormorant Garamond',serif}
.spec span{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
.ld-desc{max-width:64ch}
.ld-facts{list-style:none;padding:0;margin:20px 0;display:grid;gap:8px;color:var(--ink-soft)}
.agent-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;
  box-shadow:var(--shadow-sm);position:sticky;top:90px;text-align:center}
.agent-photo{width:110px;height:110px;margin:0 auto 14px;border-radius:999px;overflow:hidden;background:var(--paper-2);display:grid;place-items:center;border:1px solid var(--line)}
.agent-photo img{width:100%;height:100%;object-fit:cover}
.agent-card h3{font-size:1.4rem;margin:0 0 .1em}
.agent-actions{display:grid;gap:8px;margin:16px 0}
.agent-card .social-icons{justify-content:center}

/* ---------- Tools / calculators ---------- */
.tool-wrap{display:grid;gap:36px;max-width:880px;margin:0 auto}
.tool-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-sm)}
.tool-card h2{font-size:1.8rem;margin:0 0 .2em}
.calc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin:22px 0}
.field{display:grid;gap:6px}
.field label{font-size:.82rem;font-weight:600;color:var(--ink-soft)}
.field input,.field select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);
  font:inherit;background:var(--white);color:var(--ink)}
.field input:focus,.field select:focus{outline:2px solid var(--brass-soft);border-color:var(--brass)}
.field-hint{font-size:.78rem;color:var(--muted)}
.calc-warn{background:#fbeeee;border:1px solid #e6bcbc;color:#9a2b2b;border-radius:var(--radius-sm);
  padding:12px 14px;font-size:.88rem;margin-bottom:16px}
.calc-result{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:22px}
.result-headline{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:14px}
.result-label{text-transform:uppercase;letter-spacing:1.5px;font-size:.72rem;font-weight:700;color:var(--brass-deep)}
.result-big{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:700;color:var(--ink);line-height:1}
.result-lines{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.result-lines li{display:flex;justify-content:space-between;gap:16px;color:var(--ink-soft);font-size:.92rem}
.result-lines li strong{color:var(--ink)}
.result-total{border-top:1px solid var(--line);padding-top:10px;font-weight:600}
.result-total strong{color:var(--brass-deep)}
.result-note{display:block;color:var(--muted);font-size:.86rem}

/* ---------- Home extras ---------- */
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0 6px}
.center-cta{text-align:center;margin-top:32px}

/* textarea matches inputs */
.row textarea,.field textarea{width:100%;padding:12px 13px;border:1px solid var(--line);
  border-radius:var(--radius-sm);font:inherit;background:var(--white);color:var(--ink);resize:vertical}
.row textarea:focus{outline:2px solid var(--brass-soft);border-color:var(--brass)}

/* ---------- Newsletter / blog ---------- */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.post-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm)}
.post-card h2{font-size:1.45rem;margin:0 0 .2em}
.post-card h2 a{color:var(--ink)}
.post-card h2 a:hover{color:var(--brass-deep);text-decoration:none}
.subscribe-card{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-top:44px;padding:30px;background:var(--card);border:1px solid var(--line);
  border-left:3px solid var(--brass);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.subscribe-form{display:flex;gap:10px;flex-wrap:wrap}
.subscribe-form input{padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);
  font:inherit;min-width:240px;background:var(--white)}

/* ---------- Auth ---------- */
.auth-wrap{display:grid;place-items:center}
.auth-card{width:100%;max-width:440px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.auth-card h1{font-size:2rem;margin:.1em 0 .5em}

/* ---------- Dashboard ---------- */
.dash-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:26px}
.dash-head h1{font-size:clamp(1.8rem,3.4vw,2.6rem);margin:.1em 0 0}
.dash-head-actions{display:flex;gap:10px;flex-wrap:wrap}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px}
.dash-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow-sm)}
.dash-card h2{font-size:1.4rem;margin:0 0 .3em}
.dash-card .btn{margin-top:14px}
.dash-listings{margin-top:4px}
.dash-table{width:100%;border-collapse:collapse;margin-top:14px}
.dash-table th,.dash-table td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.dash-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
.dash-actions{display:flex;gap:14px;white-space:nowrap}
.dash-actions a{font-weight:600;font-size:.88rem}
.dash-actions .danger{color:#9a2b2b}

/* dashboard forms */
.dash-form{margin-top:10px}
.form-fields{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-fields .row-wide{grid-column:1 / -1}
.form-actions{display:flex;gap:12px;align-items:center;margin-top:24px}
.form-sub{font-size:1.3rem;margin:30px 0 .2em;border-top:1px solid var(--line);padding-top:24px}
.photo-formset{display:grid;gap:14px;margin-top:14px}
.photo-row{display:grid;grid-template-columns:2fr 2fr 1fr 1fr;gap:12px;align-items:start;
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px}
.row-narrow{max-width:120px}

/* ---------- Pricing ---------- */
.pricing-wrap{max-width:560px;margin:0 auto;display:grid;gap:22px}
.price-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:34px;box-shadow:var(--shadow-sm);text-align:center}
.price-card-feat{border-color:var(--brass);box-shadow:var(--shadow)}
.price-card h2{font-size:1.8rem;margin:0 0 .2em}
.price-amount{font-family:'Cormorant Garamond',serif;font-size:3.4rem;color:var(--brass-deep);
  font-weight:700;line-height:1;margin:.2em 0}
.price-amount span{font-family:'Inter',sans-serif;font-size:1rem;color:var(--muted)}
.price-features{list-style:none;padding:0;margin:20px 0;display:grid;gap:10px;text-align:left}
.price-features li{padding-left:26px;position:relative;color:var(--ink-soft)}
.price-features li::before{content:"✓";position:absolute;left:0;color:var(--brass);font-weight:700}
.price-actions{display:grid;gap:10px;margin-top:8px}
.dash-billing{margin-bottom:22px}
.inline-form{display:inline}
.linklike{background:none;border:0;color:var(--brass-deep);font:inherit;cursor:pointer;padding:0;text-decoration:underline}

/* ---------- Legal / document pages ---------- */
.legal{padding:60px 0 80px}
.legal .doc{max-width:780px;margin:0 auto}
.legal h1{font-size:clamp(2.1rem,4vw,3rem);margin:.1em 0 .15em}
.legal .updated{color:var(--muted);font-size:.9rem;margin-bottom:6px}
.legal .intro{font-size:1.08rem;color:var(--ink-soft);margin:18px 0 8px}
.legal h2{font-size:1.5rem;margin:1.9em 0 .5em;padding-top:.3em;border-top:1px solid var(--line)}
.legal h3{font-size:1.12rem;margin:1.3em 0 .35em}
.legal p,.legal li{color:var(--ink-soft)}
.legal ul{padding-left:1.2em;display:grid;gap:6px}
.legal .callout{
  background:var(--card);border:1px solid var(--line);border-left:3px solid var(--brass);
  border-radius:var(--radius-sm);padding:16px 18px;margin:18px 0;
}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .nav-toggle{display:flex}
  .primary-nav{
    position:absolute;top:70px;left:0;right:0;background:var(--paper);
    border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;
    gap:0;padding:8px 24px 16px;display:none;
  }
  .primary-nav.open{display:flex}
  .primary-nav a{padding:12px 0;border-bottom:1px solid var(--line)}
  .hero-grid,.two-col{grid-template-columns:1fr;gap:34px}
  .strip-grid,.cat-grid,.footer-grid{grid-template-columns:1fr;gap:22px}
  .cta-row{flex-direction:column;align-items:flex-start}
  .listing-detail-grid{grid-template-columns:1fr}
  .agent-card{position:static}
  .profile-photo{width:130px;height:130px;flex-basis:130px}
  .dash-grid,.form-fields{grid-template-columns:1fr}
  .photo-row{grid-template-columns:1fr}
  .row-narrow{max-width:none}
}
