/* I. Gordon Apartments — themeable palette system.
   Default = "forest" (current). Swap via body[data-theme="..."] blocks below.
   All components should reference the semantic var names, not hardcoded hex. */

:root,
body[data-theme="forest"]{
  --forest:        #1F3A2E;
  --forest-deep:   #15281F;
  --ivory:         #F5F1E8;
  --ivory-warm:    #EAE3D2;
  --brass:         #B08D47;
  --brass-deep:    #8E6F32;
  --charcoal:      #201C18;
  --muted:         #6B6459;
  --hair:          rgba(32,28,24,0.12);
  --overlay-tint:  20 36 28;
}

body[data-theme="midnight"]{
  --forest:        #1E3354;
  --forest-deep:   #13223C;
  --ivory:         #F1EBDE;
  --ivory-warm:    #E3DBC7;
  --brass:         #C47940;
  --brass-deep:    #9B5A2A;
  --charcoal:      #1A1F2B;
  --muted:         #5C6170;
  --hair:          rgba(26,31,43,0.14);
  --overlay-tint:  19 34 60;
}

body[data-theme="slate"]{
  --forest:        #3A443F;
  --forest-deep:   #2A3230;
  --ivory:         #EDEAE0;
  --ivory-warm:    #DAD5C6;
  /* WHY brass retuned: original #8AA88B sage had ~2:1 contrast on the ivory
     paper — every brass text element (eyebrows, tagline, "Visit site") read
     as washed-out blur, giving the page a variegated grey-and-pale-green
     look. Deeper sage-forest passes AA on ivory and still reads on the dark
     surfaces, matching the legibility the other themes get by default. */
  --brass:         #4E7356;
  --brass-deep:    #3A5741;
  --charcoal:      #1F2321;
  --muted:         #606862;
  --hair:          rgba(31,35,33,0.14);
  --overlay-tint:  42 50 48;
}

body[data-theme="burgundy"]{
  --forest:        #5C2424;
  --forest-deep:   #3F1717;
  --ivory:         #F3E9D8;
  --ivory-warm:    #E5D7BE;
  --brass:         #B8944A;
  --brass-deep:    #957430;
  --charcoal:      #261613;
  --muted:         #6F5751;
  --hair:          rgba(38,22,19,0.14);
  --overlay-tint:  63 23 23;
}

/* Row 1 — themes 5–7 (terracotta removed; meadow promoted to slot 7) */
body[data-theme="noir"]{
  --forest:        #0D0D0D;
  --forest-deep:   #000000;
  --ivory:         #FFFFFF;
  --ivory-warm:    #F2F2F2;
  --brass:         #B08D47;
  --brass-deep:    #8E6F32;
  --charcoal:      #0D0D0D;
  --muted:         #6B6B6B;
  --hair:          rgba(0,0,0,0.10);
  --overlay-tint:  0 0 0;
}

body[data-theme="coastal"]{
  --forest:        #1F3E52;
  --forest-deep:   #132633;
  --ivory:         #F3F8FA;
  --ivory-warm:    #DCE7ED;
  --brass:         #5A9EA5;
  --brass-deep:    #3A7E85;
  --charcoal:      #1A2530;
  --muted:         #607680;
  --hair:          rgba(26,37,48,0.12);
  --overlay-tint:  18 32 47;
}

body[data-theme="meadow"]{
  --forest:        #2A4A3A;
  --forest-deep:   #1A3325;
  --ivory:         #EDEFE5;
  --ivory-warm:    #DDE2D2;
  --brass:         #C9A14E;
  --brass-deep:    #A17B35;
  --charcoal:      #1F2E24;
  --muted:         #687066;
  --hair:          rgba(31,46,36,0.14);
  --overlay-tint:  28 50 36;
}

/* Row 2 — themes 8–15, sourced from LANDING_RESEARCH.md reference sites */

/* 8 — Camden: navy + lime */
body[data-theme="camden"]{
  --forest:        #002664;
  --forest-deep:   #001745;
  --ivory:         #F4F5F8;
  --ivory-warm:    #E0E4EC;
  --brass:         #7AB800;
  --brass-deep:    #5F9100;
  --charcoal:      #001234;
  --muted:         #4A5B7C;
  --hair:          rgba(0,18,52,0.12);
  --overlay-tint:  0 22 72;
}

/* 9 — Windsor: navy on cream + coral */
body[data-theme="windsor"]{
  --forest:        #12294A;
  --forest-deep:   #091732;
  --ivory:         #E8E6D9;
  --ivory-warm:    #D6D2C0;
  --brass:         #E0786B;
  --brass-deep:    #B85A4E;
  --charcoal:      #0E1F3A;
  --muted:         #5E6A7E;
  --hair:          rgba(14,31,58,0.12);
  --overlay-tint:  9 23 50;
}

/* 10 — Hines: editorial near-black + crimson */
body[data-theme="editorial"]{
  --forest:        #17212B;
  --forest-deep:   #0A0F15;
  --ivory:         #F2F3F5;
  --ivory-warm:    #E4E7EA;
  --brass:         #B70021;
  --brass-deep:    #8B001A;
  --charcoal:      #17212B;
  --muted:         #5E6B79;
  --hair:          rgba(23,33,43,0.12);
  --overlay-tint:  10 15 21;
}

/* 11 — Greystar: stucco paper + navy + harvest gold
   WHY brass retuned: the reference sunshine #FFD972 is illegible as text on
   the stucco paper. Using a deeper harvest gold keeps the warm yellow family
   but passes AA on both the cream bg and the dark navy bg/footer. */
body[data-theme="stucco"]{
  --forest:        #0A2245;
  --forest-deep:   #061529;
  --ivory:         #F5EBDC;
  --ivory-warm:    #E5D7C0;
  --brass:         #9B7615;
  --brass-deep:    #6F5410;
  --charcoal:      #0A2245;
  --muted:         #5A5146;
  --hair:          rgba(10,34,69,0.14);
  --overlay-tint:  6 21 41;
}

/* 12 — Morgan: graphite paper + electric blue */
body[data-theme="graphite"]{
  --forest:        #2C3335;
  --forest-deep:   #1A1F20;
  --ivory:         #E8E6E2;
  --ivory-warm:    #D0CEC9;
  --brass:         #157CBC;
  --brass-deep:    #0F5A8A;
  --charcoal:      #1F2426;
  --muted:         #60666B;
  --hair:          rgba(31,36,38,0.14);
  --overlay-tint:  26 31 32;
}

:root{
  --serif: 'Libre Baskerville', Georgia, serif;
  --sans:  'Plus Jakarta Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --container:     1200px;
  --radius:        4px;

  /* WHY: CTA + kicker decoupled from --brass. Default matches the old brass
     behavior, but individual themes can override these when the accent is
     too loud for a big filled button (e.g., editorial's crimson). */
  --cta-bg:            var(--brass);
  --cta-border:        var(--brass);
  --cta-text:          var(--charcoal);
  --cta-hover-bg:      var(--ivory);
  --cta-hover-border:  var(--ivory);
  --cta-hover-text:    var(--charcoal);
  --hero-kicker-color: var(--brass);
}

/* Per-theme CTA/kicker overrides — themes where brass is an aggressive hue
   use a mellow cream CTA and a lighter kicker so the hero doesn't scream. */
body[data-theme="editorial"]{
  --cta-bg:            #E8E3D6;
  --cta-border:        #E8E3D6;
  --cta-text:          #17212B;
  --cta-hover-bg:      #FFFFFF;
  --cta-hover-border:  #FFFFFF;
  --cta-hover-text:    #17212B;
  --hero-kicker-color: #EDE6D2;
}


*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--charcoal);
  background:var(--ivory);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--forest); text-decoration:none; transition:color .2s ease; }
a:hover{ color:var(--brass); }

.skip{
  position:absolute; left:-9999px; top:0;
  background:var(--forest); color:var(--ivory); padding:.75rem 1rem;
}
.skip:focus{ left:1rem; top:1rem; z-index:1000; }

.container{
  width:100%; max-width:var(--container);
  margin-inline:auto;
  padding-inline:clamp(1rem, 3vw, 2.5rem);
}

/* ───────── Specials strip ───────── */
.specials-strip{
  background:var(--forest-deep);
  color:var(--ivory);
  text-align:center;
  font-size:.875rem;
  letter-spacing:.02em;
  padding:.6rem 1rem;
}
.specials-strip em{
  font-style:normal;
  color:var(--brass);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:0 .25rem;
}
.specials-strip .dot{ opacity:.55; margin:0 .55rem; }
.specials-strip a{ color:var(--brass); font-weight:600; border-bottom:1px solid transparent; }
.specials-strip a:hover{ color:var(--ivory); border-bottom-color:var(--brass); }

/* ───────── Header ───────── */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--ivory);
  border-bottom:1px solid var(--hair);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:1.5rem;
  padding-block:.75rem;
}
.brand{ display:flex; flex-direction:column; line-height:1; color:var(--forest); }
.brand:hover{ color:var(--forest); }
.brand-mark{
  font-family:var(--serif);
  font-size:2.35rem;
  font-weight:400;
  letter-spacing:.01em;
}
.brand-sub{
  font-family:var(--sans);
  font-size:.82rem;
  letter-spacing:.38em;
  text-transform:uppercase;
  color:var(--brass);
  margin-top:0;
  font-weight:600;
}

.site-nav{ display:flex; align-items:center; gap:2rem; }
.nav-link{
  color:var(--charcoal);
  font-weight:500;
  font-size:.9rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  position:relative;
  padding-block:.35rem;
}
.nav-link::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:var(--brass);
  transform:scaleX(0); transform-origin:left;
  transition:transform .25s ease;
}
.nav-link:hover{ color:var(--forest); }
.nav-link:hover::after{ transform:scaleX(1); }

.btn{
  font-family:var(--sans);
  font-weight:600;
  font-size:.9rem;
  letter-spacing:.04em;
  padding:.65rem 1.15rem;
  border-radius:var(--radius);
  border:1px solid transparent;
  cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .2s, color .2s, border-color .2s, transform .1s;
  white-space:nowrap;
}
.btn-fill{
  background:var(--forest); color:var(--ivory);
  border-color:var(--forest);
}
.btn-fill:hover{ background:var(--brass); border-color:var(--brass); color:var(--ivory); }
.btn-ghost{ background:transparent; color:var(--forest); border-color:var(--forest); }
.btn-ghost:hover{ background:var(--forest); color:var(--ivory); }
.btn-ghost--light{ color:var(--ivory); border-color:var(--ivory); }
.btn-ghost--light:hover{ background:var(--ivory); color:var(--forest); }
.btn-lg{ padding:.95rem 1.75rem; font-size:1rem; }

.nav-toggle{
  display:none;
  background:none; border:0; padding:.5rem;
  width:44px; height:44px;
  flex-direction:column; justify-content:center; gap:5px;
  cursor:pointer;
}
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--charcoal); transition:transform .2s, opacity .2s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{
  display:none;
  background:var(--ivory);
  border-bottom:1px solid var(--hair);
  padding:1rem clamp(1rem,3vw,2.5rem) 1.5rem;
  flex-direction:column; gap:1rem;
}
.mobile-menu a{ font-size:1.05rem; font-weight:500; color:var(--charcoal); }
.mobile-menu a.btn{ align-self:flex-start; }
.mobile-menu[data-open]{ display:flex; }

/* ───────── Hero ───────── */
.hero{
  position:relative;
  min-height:min(88vh, 820px);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  isolation:isolate;
}
/* WHY: Rochester skyline served as <picture> + srcset so browsers only
   fetch the width they need (42KB at 800w → 329KB at 2800w). Replaces a
   9MB PNG. The <img> fills the hero via object-fit cover. */
.hero-bg{
  position:absolute; inset:0;
  display:block;
  background:var(--forest-deep);
}
.hero-bg img{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  display:block;
}
.hero-overlay{
  position:absolute; inset:0;
  /* WHY: overlay tint pulled from --overlay-tint (rgb triplet) so each theme
     darkens the skyline in its own color family instead of always green. */
  background:
    linear-gradient(180deg,
      rgb(var(--overlay-tint) / .10) 0%,
      rgb(var(--overlay-tint) / .50) 65%,
      rgb(var(--overlay-tint) / .80) 100%),
    radial-gradient(ellipse at 50% 58%,
      rgb(var(--overlay-tint) / .15) 0%,
      rgb(var(--overlay-tint) / .40) 70%);
}
.hero-content{
  position:relative; z-index:2;
  text-align:center;
  color:var(--ivory);
  padding-block:4rem;
}
.hero-kicker{
  font-family:var(--sans);
  font-size:.8rem;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--hero-kicker-color);
  font-weight:700;
  margin:0 0 1.25rem;
  /* WHY: kicker is brass-on-sunset — lowest contrast zone on the page.
     Triple-layer shadow gives it a tight outline, a mid halo, and a wide
     bloom so it reads without adding a background badge. */
  text-shadow:
    0 0 1px rgba(0,0,0,.9),
    0 1px 3px rgba(0,0,0,.85),
    0 2px 14px rgba(0,0,0,.7);
}
.hero-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2.75rem, 7vw, 5.25rem);
  line-height:1.05;
  margin:0 0 1.25rem;
  letter-spacing:-0.01em;
  /* WHY: dual-layer shadow (tight + wide bloom) gives the text its own
     contrast halo without needing to darken the whole hero image. */
  text-shadow:
    0 1px 2px rgba(0,0,0,.5),
    0 2px 18px rgba(0,0,0,.65);
}
.hero-title em{
  font-style:italic;
  color:var(--brass);
}
.hero-sub{
  max-width:54ch;
  margin:0 auto 2rem;
  font-size:1.1rem;
  color:rgba(245,241,232,.95);
  text-shadow:
    0 1px 2px rgba(0,0,0,.55),
    0 1px 8px rgba(0,0,0,.55);
}
.hero-cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero .btn-fill{
  background:var(--cta-bg);
  border-color:var(--cta-border);
  color:var(--cta-text);
}
.hero .btn-fill:hover{
  background:var(--cta-hover-bg);
  border-color:var(--cta-hover-border);
  color:var(--cta-hover-text);
}

.scroll-indicator{
  position:absolute; bottom:1.75rem; left:50%;
  transform:translateX(-50%);
  background:transparent; border:0; cursor:pointer;
  color:var(--ivory); opacity:.8;
  padding:.5rem;
  animation:bounce 2.4s ease-in-out infinite;
}
.scroll-indicator:hover{ opacity:1; color:var(--brass); }
@keyframes bounce{
  0%,100%{ transform:translate(-50%,0); }
  50%   { transform:translate(-50%,10px); }
}

/* ───────── Section basics ───────── */
.eyebrow{
  font-size:.75rem;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:var(--brass);
  font-weight:600;
  margin:0 0 .85rem;
}
.eyebrow.light{ color:var(--brass); }

.section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(1.85rem, 3.6vw, 2.85rem);
  line-height:1.15;
  margin:0 0 1.25rem;
  color:var(--forest);
  letter-spacing:-0.005em;
}
.section-title.light{ color:var(--ivory); }
.section-lede{
  max-width:60ch;
  color:var(--muted);
  font-size:1.05rem;
}
.section-head{ text-align:center; max-width:720px; margin:0 auto 3.5rem; }
.section-head .section-lede{ margin-inline:auto; }

/* ───────── About ───────── */
.about{ padding:clamp(4rem,8vw,7rem) 0; background:var(--ivory); }
.about-inner{
  display:grid; gap:3rem;
  grid-template-columns:1.4fr 1fr;
  align-items:start;
}
.about-copy p{ font-size:1.05rem; color:var(--charcoal); margin-block:0 1.1rem; }
/* Value pillars — replaces the old pull-quote aside.
   WHY: headline and pull-quote repeated the same sentence; pillars answer
   "how we operate" instead of re-stating the tagline. */
.about-pillars{ padding-block:.25rem; }
.pillar{
  display:grid; grid-template-columns:36px 1fr; gap:1rem;
  padding:1.15rem 0;
  border-bottom:1px solid var(--hair);
}
.pillar:last-child{ border-bottom:0; }
.pillar-ico{
  width:36px; height:36px;
  border:1.5px solid var(--brass); border-radius:50%;
  color:var(--brass); font-family:var(--serif); font-size:.95rem;
  display:grid; place-items:center;
}
.pillar-body h3{
  font-family:var(--serif); color:var(--forest);
  font-size:1.05rem; margin:.15rem 0 .3rem;
}
.pillar-body p{
  margin:0; color:var(--muted);
  font-size:.95rem; line-height:1.5;
}

/* ───────── Properties ───────── */
.properties{
  padding:clamp(5rem,9vw,8rem) 0;
  background:
    linear-gradient(180deg, var(--ivory-warm) 0%, var(--ivory) 100%);
}

.property-grid{
  list-style:none; padding:0; margin:0;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(290px, 1fr));
  gap:1.5rem;
}
.property-card{
  background:#fff;
  border:1px solid var(--hair);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position:relative;
}
.property-card::after{
  content:""; position:absolute; inset:auto 0 0 0; height:3px;
  background:var(--brass); transform:scaleX(0); transform-origin:left;
  transition:transform .3s ease;
}
.property-card:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 40px -16px rgba(32,28,24,.25);
  border-color:var(--brass);
}
.property-card:hover::after{ transform:scaleX(1); }
.property-card > a{
  display:grid; grid-template-rows:170px auto;
  height:100%;
  color:var(--charcoal);
}
.property-card a:hover{ color:var(--charcoal); }

/* WHY: property logos are dark-on-transparent PNGs — tile bg must be light
   for them to read. Subtle ivory gradient + bottom brass hairline keeps
   the premium feel without washing out the logos. */
.property-logo{
  background:
    radial-gradient(ellipse at 50% 30%, #FFFFFF 0%, var(--ivory) 70%, var(--ivory-warm) 100%);
  display:grid; place-items:center;
  padding:.75rem 1rem;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--hair);
}
.property-logo::after{
  content:""; position:absolute; left:1.5rem; right:1.5rem; bottom:0;
  height:2px; background:var(--brass);
  transform:scaleX(0); transform-origin:center;
  transition:transform .35s ease;
}
.property-card:hover .property-logo::after{ transform:scaleX(1); }
.property-logo img{
  max-height:100%;
  max-width:100%;
  width:auto;
  height:auto;
  object-fit:contain;
  position:relative; z-index:1;
}
/* WHY: Webster Park's PNG is essentially wordmark edge-to-edge (no graphic
   element alongside), so it outweighs the other logos when scaled to fill
   the tile. Cap it so visual weight matches the others. */
.property-logo img[src*="WPA_"]{
  max-width:70%;
  max-height:78%;
}

.property-meta{
  padding:1rem 1.25rem 1.25rem;
  display:flex; flex-direction:column; gap:.35rem;
}
.property-meta h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.25rem;
  margin:0;
  color:var(--forest);
}
.property-area{
  margin:0;
  font-size:.82rem;
  color:var(--muted);
  letter-spacing:.02em;
}
.property-cta{
  margin-top:.5rem;
  font-weight:600;
  font-size:.85rem;
  color:var(--brass);
  letter-spacing:.04em;
}
.property-card:hover .property-cta{ color:var(--forest); }

/* ───────── Apply strip ───────── */
.apply{
  background:var(--forest);
  color:var(--ivory);
  padding:clamp(4rem,7vw,6rem) 0;
}
.apply-inner{
  display:flex; gap:2rem;
  align-items:center; justify-content:space-between;
  flex-wrap:wrap;
}
.apply .section-title{ margin-bottom:.75rem; }
.apply-sub{ max-width:50ch; color:rgba(245,241,232,.8); margin:0; }
.apply-actions{ display:flex; gap:1rem; flex-wrap:wrap; }
.apply .btn-fill{ background:var(--brass); border-color:var(--brass); color:var(--charcoal); }
.apply .btn-fill:hover{ background:var(--ivory); border-color:var(--ivory); }

/* ───────── Contact ───────── */
.contact{
  padding:clamp(4rem,8vw,7rem) 0;
  background:var(--ivory);
}
.contact-inner{
  display:grid; gap:3rem;
  grid-template-columns:1.2fr 1fr;
  align-items:start;
}
.contact-details{
  font-style:normal;
  background:var(--ivory-warm);
  border:1px solid var(--hair);
  border-radius:var(--radius);
  padding:2rem;
}
.contact-line{ margin:0 0 1rem; font-size:1rem; }
.contact-line:last-child{ margin-bottom:0; }
.contact-line strong{
  display:inline-block;
  min-width:80px;
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--brass);
  font-weight:600;
  margin-right:.5rem;
}

/* ───────── Footer ───────── */
.site-footer{
  background:var(--forest-deep);
  color:rgba(245,241,232,.8);
  margin-top:0;
}
.footer-inner{
  display:grid;
  grid-template-columns:1.2fr repeat(3, 1fr);
  gap:2.5rem;
  padding:4rem 0 3rem;
}
.footer-brand .brand-mark{ color:var(--ivory); font-size:1.6rem; }
.footer-brand .brand-sub{ color:var(--brass); }
.footer-tag{ margin-top:1rem; color:rgba(245,241,232,.55); font-size:.85rem; }
.footer-col h4{
  font-family:var(--sans);
  color:var(--ivory);
  font-size:.78rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  margin:0 0 1.25rem;
  font-weight:600;
}
.footer-col a{
  display:block;
  color:rgba(245,241,232,.75);
  padding:.25rem 0;
  font-size:.95rem;
}
.footer-col a:hover{ color:var(--brass); }
.footer-col p{ margin:0 0 .5rem; font-size:.92rem; line-height:1.6; }
.footer-col p a{ display:inline; }

.footer-fine{
  border-top:1px solid rgba(245,241,232,.08);
  padding-block:1.25rem;
  font-size:.82rem;
  color:rgba(245,241,232,.5);
}
.footer-fine .container{
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
}

/* ───────── Responsive ───────── */
@media (max-width: 960px){
  .about-inner, .contact-inner{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr 1fr; }
  .nav-link, .btn-ghost, .btn-fill.nav-apply{ display:none; }
  .site-nav .nav-link, .site-nav .btn-ghost, .site-nav .btn-fill{ display:none; }
  .site-nav .nav-phone{ display:none; }
  .nav-toggle{ display:flex; }
}
@media (max-width: 560px){
  .footer-inner{ grid-template-columns:1fr; gap:2rem; padding-top:3rem; }
  .property-card > a{ grid-template-rows:180px auto; }
  .specials-strip{ font-size:.82rem; }
  .specials-strip .dot{ display:block; height:0; margin:.25rem 0; opacity:0; }
  .hero-content{ padding-block:3rem; }
  .apply-inner{ flex-direction:column; align-items:flex-start; }
  .nav-phone{ display:none; }
}

/* ───────── Theme switcher (fixed upper-left, two rows) ─────────
   Numbered buttons 1–15, two rows (7 then 8). Click to apply; localStorage
   persists choice. No palette names in the UI. */
.theme-switcher{
  position:fixed;
  top:1rem; left:1rem;
  z-index:100;
  display:flex; flex-direction:column; gap:.35rem;
  padding:.5rem .65rem;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  box-shadow:0 4px 16px -6px rgba(0,0,0,.25);
}
.theme-switcher-row{ display:flex; gap:.35rem; }
.theme-dot{
  width:24px; height:24px;
  border-radius:50%;
  border:1.5px solid rgba(0,0,0,.12);
  padding:0;
  cursor:pointer;
  background:#FFFFFF;
  color:#2A2A2A;
  font-family:var(--serif);
  font-size:.72rem;
  font-weight:700;
  display:flex; align-items:center; justify-content:center;
  line-height:1;
  transition:transform .15s ease, border-color .15s, background .15s, color .15s;
}
.theme-dot:hover{ transform:scale(1.15); border-color:#2A2A2A; }
.theme-dot[data-active="true"]{
  background:#2A2A2A;
  color:#FFFFFF;
  border-color:#2A2A2A;
}
