/* ============================================================
   FONT FALLBACKS — metric-matched to the web fonts so the
   swap from system fonts causes no layout shift.
   Overrides computed from the actual font tables
   (frequency-weighted advance widths, hhea ascent/descent).
============================================================ */
@font-face{
  font-family:"Playfair Display Fallback";
  src:local("Georgia");
  size-adjust:104.6%;
  ascent-override:103.45%;
  descent-override:24%;
  line-gap-override:0%;
}

@font-face{
  font-family:"Lato Fallback";
  src:local("Arial");
  size-adjust:98.09%;
  ascent-override:100.63%;
  descent-override:21.72%;
  line-gap-override:0%;
}

/* ============================================================
   TOKENS
============================================================ */
:root{
  --color-primary:      #C0392B;
  --color-primary-dark: #96281B;
  --color-cream:        #FAF6F0;
  --color-sand:         #E8DDD0;
  --color-charcoal:     #1C1C1C;
  --color-text-muted:   #6B5E52;
  --color-accent:       #2471A3;
  --color-white:        #FFFFFF;

  --fs-display:  clamp(3.5rem, 8vw, 6rem);
  --fs-hero-sub: clamp(1.2rem, 2.5vw, 1.6rem);
  --fs-h2:       clamp(2rem, 4vw, 3rem);
  --fs-h3:       clamp(1.3rem, 2.5vw, 1.8rem);
  --fs-lead:     1.125rem;
  --fs-body:     1rem;
  --fs-small:    0.875rem;

  --font-display: "Playfair Display", "Playfair Display Fallback", Georgia, serif;
  --font-body:    "Lato", "Lato Fallback", "Helvetica Neue", Arial, sans-serif;

  --container: 1140px;
  --radius: 8px;
}

/* ============================================================
   BASE
============================================================ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:5rem; }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
}

body{
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:1.65;
  color:var(--color-charcoal);
  background:var(--color-cream);
  -webkit-font-smoothing:antialiased;
  font-kerning:normal;
}

img{ max-width:100%; display:block; }

h1,h2,h3{ text-wrap:balance; }
p{ text-wrap:pretty; }

a{ color:var(--color-primary); }

a:focus-visible,
button:focus-visible{
  outline:3px solid var(--color-accent);
  outline-offset:3px;
  border-radius:4px;
}

.container{
  width:min(var(--container), 100% - 2.5rem);
  margin-inline:auto;
}

.section{ padding:5.5rem 0; }

.section-head{ max-width:42rem; margin-bottom:3rem; }

.section-head h2{
  font-family:var(--font-display);
  font-weight:700;
  font-size:var(--fs-h2);
  line-height:1.1;
}

.section-head .sub{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:700;
  font-size:var(--fs-lead);
  color:var(--color-text-muted);
  margin-top:.75rem;
}

.lucide{ width:1.25em; height:1.25em; stroke-width:2; flex-shrink:0; }

/* ============================================================
   SCROLL REVEAL
============================================================ */
.reveal{ opacity:1; }

/* Hidden-at-rest only when JS is running (html.js), so content
   never ships invisible if the script fails to load. */
@media (prefers-reduced-motion: no-preference){
  .js .reveal{
    opacity:0;
    transform:translateY(20px);
    transition:opacity .7s ease, transform .7s ease;
  }
  .js .reveal.visible{
    opacity:1;
    transform:translateY(0);
  }
}

/* ============================================================
   NAVBAR
============================================================ */
.navbar{
  position:fixed;
  inset:0 0 auto 0;
  z-index:100;
  padding:1rem 0;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
}

.navbar.scrolled{
  background:rgba(28,28,28,.95);
  box-shadow:0 4px 24px rgba(0,0,0,.35);
  padding:.6rem 0;
}

.navbar .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}

.nav-brand{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:900;
  font-size:1.5rem;
  color:var(--color-cream);
  text-decoration:none;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:2rem;
  list-style:none;
}

.nav-links a{
  font-weight:700;
  font-size:var(--fs-small);
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--color-cream);
  text-decoration:none;
  padding:.35rem 0;
  border-bottom:2px solid transparent;
  transition:border-color .2s ease, color .2s ease;
}

.nav-links a:hover{ border-color:var(--color-primary); }

.nav-toggle{
  display:none;
  background:none;
  border:0;
  color:var(--color-cream);
  cursor:pointer;
  padding:.5rem;
}

.nav-toggle .lucide{ width:1.75rem; height:1.75rem; }
.nav-toggle .icon-close{ display:none; }
.nav-toggle[aria-expanded="true"] .icon-open{ display:none; }
.nav-toggle[aria-expanded="true"] .icon-close{ display:block; }

@media (max-width: 767px){
  .nav-toggle{ display:block; }
  .nav-links{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    flex-direction:column;
    gap:0;
    background:rgba(28,28,28,.97);
    padding:.75rem 0 1.25rem;
    display:none;
    box-shadow:0 16px 32px rgba(0,0,0,.4);
  }
  .nav-links.open{ display:flex; }
  .nav-links a{
    display:block;
    padding:.85rem 1.25rem;
    width:100%;
    text-align:center;
    border-bottom:0;
  }
}

/* ============================================================
   HERO
============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  padding:6rem 1.25rem 4rem;
  background:
    radial-gradient(ellipse 120% 70% at 50% 115%, rgba(192,57,43,.35), transparent 60%),
    radial-gradient(ellipse 80% 55% at 80% -10%, rgba(150,40,27,.45), transparent 65%),
    radial-gradient(ellipse 70% 60% at 12% 30%, rgba(74,18,8,.85), transparent 70%),
    linear-gradient(165deg, #1a0a08 0%, #2c0d08 45%, #4A1208 100%);
  color:var(--color-cream);
}

.hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
}

/* Slowly rotating colour drift, blurred into an aurora */
.hero-aurora{
  position:absolute;
  inset:-40%;
  background:conic-gradient(from 0deg at 50% 50%,
    transparent 0deg,
    rgba(192,57,43,.28) 60deg,
    transparent 130deg,
    rgba(36,113,163,.10) 190deg,
    transparent 240deg,
    rgba(150,40,27,.32) 300deg,
    transparent 360deg);
  filter:blur(70px);
  opacity:.8;
}

/* Pulsing glow behind the title */
.hero-glow{
  position:absolute;
  top:50%;
  left:50%;
  width:min(60vw, 40rem);
  aspect-ratio:1;
  transform:translate(-50%,-55%);
  background:radial-gradient(circle, rgba(192,57,43,.45), transparent 62%);
}

/* Rising embers (spans injected by JS) */
.hero-embers{ position:absolute; inset:0; overflow:hidden; }

.ember{
  position:absolute;
  bottom:-3vh;
  left:var(--x);
  width:var(--size);
  height:var(--size);
  border-radius:50%;
  background:radial-gradient(circle,
    rgba(255,196,128,.95) 0%,
    rgba(192,57,43,.55) 55%,
    transparent 75%);
  opacity:0;
  filter:blur(.4px);
}

/* Drifting ghost waves — the sea behind the red fire */
.hero-waves{
  position:absolute;
  inset:auto 0 0 0;
  height:62%;
  will-change:transform;
}

.hero-waves .wave{
  position:absolute;
  bottom:0;
  left:0;
  width:200%;
  height:100%;
}

/* CSS-only grain */
.hero-grain{
  position:absolute;
  inset:0;
  opacity:.5;
  background-image:
    radial-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,.18) 1px, transparent 1px);
  background-size:3px 3px, 5px 5px;
  background-position:0 0, 2px 3px;
  mix-blend-mode:overlay;
}

.hero-inner{
  position:relative;
  z-index:2;
  max-width:60rem;
}

.hero-eyebrow{
  font-weight:400; /* light weights drop out on the dark hero */
  font-size:var(--fs-small);
  letter-spacing:.45em;
  text-transform:uppercase;
  color:var(--color-sand);
}

.hero-rule{
  width:min(22rem, 70%);
  height:1px;
  margin:1.75rem auto;
  background:linear-gradient(90deg, transparent, rgba(232,221,208,.7), transparent);
}

.hero-title{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:900;
  font-size:var(--fs-display);
  line-height:1;
  color:var(--color-cream);
  letter-spacing:-.01em;
  text-shadow:0 4px 40px rgba(0,0,0,.45);
  perspective:600px;
}

/* Single letters (split by JS) */
.hero-title .ltr{
  display:inline-block;
  white-space:pre;
  transform-origin:50% 85%;
}

.hero-tagline{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:700;
  font-size:var(--fs-hero-sub);
  line-height:1.3;
  color:var(--color-sand);
}

.hero-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  justify-content:center;
  margin-top:2.75rem;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-family:var(--font-body);
  font-weight:700;
  font-size:var(--fs-small);
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  padding:1rem 2.25rem;
  border-radius:var(--radius);
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease;
}

.btn:hover{ transform:scale(1.03); }

.btn-primary{
  background:var(--color-primary);
  color:var(--color-white);
}
.btn-primary:hover{ background:var(--color-primary-dark); }

.btn-ghost{
  background:transparent;
  border-color:var(--color-cream);
  color:var(--color-cream);
}
.btn-ghost:hover{
  background:var(--color-cream);
  color:var(--color-charcoal);
}

.hero-scroll{
  position:absolute;
  bottom:1.75rem;
  left:50%;
  transform:translateX(-50%);
  z-index:2;
  color:var(--color-sand);
  display:inline-flex;
  padding:.5rem;
}

.hero-scroll .lucide{ width:2rem; height:2rem; }

/* --- Hero motion (all gated behind reduced-motion) --- */
@media (prefers-reduced-motion: no-preference){

  .hero-aurora{ animation:auroraSpin 48s linear infinite; }

  @keyframes auroraSpin{
    from{ transform:rotate(0deg); }
    to{ transform:rotate(360deg); }
  }

  .hero-glow{ animation:glowPulse 7s ease-in-out infinite; }

  @keyframes glowPulse{
    0%,100%{ opacity:.55; transform:translate(-50%,-55%) scale(1); }
    50%{ opacity:1; transform:translate(-50%,-55%) scale(1.18); }
  }

  .ember{
    animation:emberRise var(--dur) linear var(--delay) infinite;
  }

  @keyframes emberRise{
    0%{ transform:translate3d(0,0,0) scale(1); opacity:0; }
    8%{ opacity:var(--o); }
    70%{ opacity:calc(var(--o) * .6); }
    100%{ transform:translate3d(var(--drift), -108vh, 0) scale(.15); opacity:0; }
  }

  .hero-waves .wave-1{ animation:waveDrift 16s linear infinite, waveBob 7s ease-in-out infinite; }
  .hero-waves .wave-2{ animation:waveDrift 26s linear infinite reverse, waveBob 9s ease-in-out infinite .8s; }
  .hero-waves .wave-3{ animation:waveDrift 38s linear infinite, waveBob 12s ease-in-out infinite 1.6s; }

  @keyframes waveDrift{
    from{ translate:0 0; }
    to{ translate:-50% 0; }
  }

  @keyframes waveBob{
    0%,100%{ margin-bottom:0; }
    50%{ margin-bottom:14px; }
  }

  /* Title letters: cinematic flip-in, then a perpetual gentle wave */
  .hero-title .ltr{
    opacity:0;
    animation:
      ltrIn .9s cubic-bezier(.16,1,.3,1) forwards,
      ltrFloat 5.5s ease-in-out infinite;
    animation-delay:
      calc(.35s + var(--i) * 70ms),
      calc(1.8s + var(--i) * 200ms);
  }

  @keyframes ltrIn{
    from{ opacity:0; transform:translateY(75px) rotateX(75deg) scale(.7); }
    to{ opacity:1; transform:translateY(0) rotateX(0) scale(1); }
  }

  @keyframes ltrFloat{
    0%,100%{ transform:translateY(0) rotate(0deg); }
    50%{ transform:translateY(-8px) rotate(-1.4deg); }
  }

  .hero-stagger{
    opacity:0;
    animation:heroIn .9s ease forwards;
    animation-delay:var(--d, 0s);
  }

  @keyframes heroIn{
    from{ opacity:0; transform:translateY(24px); }
    to{ opacity:1; transform:translateY(0); }
  }

  .hero-scroll{ animation:bounce 2.2s ease-in-out infinite; }

  @keyframes bounce{
    0%,100%{ transform:translate(-50%, 0); }
    50%{ transform:translate(-50%, 9px); }
  }
}

/* ============================================================
   INFO BAR
============================================================ */
.infobar{
  background:var(--color-primary);
  color:var(--color-white);
  padding:1rem 0;
}

.infobar .container{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:.75rem 0;
}

.infobar-item{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-weight:700;
  font-size:var(--fs-small);
  letter-spacing:.04em;
  padding:0 1.75rem;
}

.infobar-item + .infobar-item{
  border-left:1px solid rgba(255,255,255,.35);
}

.infobar-item a{
  color:var(--color-white);
  text-decoration:none;
}
.infobar-item a:hover{ text-decoration:underline; }

@media (max-width: 767px){
  .infobar .container{ flex-direction:column; }
  .infobar-item + .infobar-item{ border-left:0; }
}

/* ============================================================
   ABOUT
============================================================ */
.about-grid{
  display:grid;
  gap:3.5rem;
  align-items:center;
}

@media (min-width: 768px){
  .about-grid{ grid-template-columns:1.15fr .85fr; }
}

.about-copy p.lead{
  font-size:var(--fs-lead);
  color:var(--color-charcoal);
  max-width:36rem;
}

.about-stats{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
  gap:1.5rem;
  margin-top:2.75rem;
}

.stat .stat-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:2.9rem;
  height:2.9rem;
  border-radius:50%;
  background:var(--color-sand);
  color:var(--color-primary);
  margin-bottom:.75rem;
}

.stat h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:var(--fs-lead);
  margin-bottom:.2rem;
}

.stat p{
  font-size:var(--fs-small);
  color:var(--color-text-muted);
}

/* Photo + monogram badge composition */
.about-art{
  position:relative;
  width:min(26rem, 100%);
  margin-inline:auto;
}

.about-art img{
  width:100%;
  height:auto;
  border-radius:12px;
  box-shadow:0 14px 34px rgba(28,28,28,.12);
}

.about-badge{
  position:absolute;
  right:-.75rem;
  bottom:-1.25rem;
  width:6.5rem;
  aspect-ratio:1;
  border-radius:50%;
  background:var(--color-primary);
  border:1px solid var(--color-accent); /* the one quiet nod to the sea */
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 18px 40px rgba(150,40,27,.35);
}

.about-badge span{
  font-family:var(--font-display);
  font-weight:900;
  font-style:italic;
  font-size:3rem;
  line-height:1;
  color:var(--color-cream);
  transform:translateY(-4%);
}

/* ============================================================
   MENU
============================================================ */
#menu{ background:var(--color-sand); }

/* Cured Wood fails AA on River Stone (~3.1:1) — use coal on the sand surface */
#menu .section-head .sub{ color:var(--color-charcoal); }

.menu-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-bottom:2.5rem;
}

.menu-tab{
  font-family:var(--font-body);
  font-weight:700;
  font-size:var(--fs-small);
  letter-spacing:.08em;
  text-transform:uppercase;
  min-height:2.75rem; /* 44px touch target */
  padding:.7rem 1.4rem;
  border:2px solid var(--color-primary);
  border-radius:999px;
  background:transparent;
  color:var(--color-primary);
  cursor:pointer;
  transition:background-color .2s ease, color .2s ease, transform .2s ease;
}

.menu-tab:hover{ transform:scale(1.03); }

.menu-tab[aria-selected="true"]{
  background:var(--color-primary);
  color:var(--color-white);
}

.menu-panel{ display:none; }

.menu-panel.active{ display:block; }

@media (prefers-reduced-motion: no-preference){
  .menu-panel.active{ animation:panelIn .35s ease; }
  @keyframes panelIn{
    from{ opacity:0; }
    to{ opacity:1; }
  }
}

.menu-grid{
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(auto-fit, minmax(min(250px, 100%), 1fr));
}

.dish{
  background:var(--color-white);
  border-radius:var(--radius);
  padding:1.75rem;
  box-shadow:0 6px 18px rgba(28,28,28,.07);
  display:flex;
  flex-direction:column;
  gap:.6rem;
}

.dish-tag{
  align-self:flex-start;
  background:var(--color-primary);
  color:var(--color-white);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:.25rem .7rem;
  border-radius:999px;
}

.dish h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:var(--fs-h3);
  line-height:1.15;
}

.dish p{
  color:var(--color-text-muted);
  font-size:var(--fs-small);
  flex-grow:1;
}

.dish .price{
  font-weight:700;
  font-size:var(--fs-lead);
  color:var(--color-primary);
}

.menu-note{
  margin-top:2.5rem;
  font-family:var(--font-display);
  font-style:italic;
  font-weight:700;
  color:var(--color-charcoal); /* Cured Wood fails AA on River Stone */
  text-align:center;
}

/* ============================================================
   SPECIALITÀ
============================================================ */
#specialita{
  background:var(--color-charcoal);
  color:var(--color-cream);
}

#specialita .section-head h2{ color:var(--color-cream); }
#specialita .section-head .sub{ color:var(--color-sand); }

.features{
  display:grid;
  gap:2.5rem;
  grid-template-columns:repeat(auto-fit, minmax(min(260px, 100%), 1fr));
}

.feature::before{
  content:"";
  display:block;
  width:2.75rem;
  height:3px;
  background:var(--color-primary);
  margin-bottom:1.5rem;
}

.feature h3{
  font-family:var(--font-display);
  font-weight:700;
  font-size:var(--fs-h3);
  color:var(--color-cream);
  margin-bottom:.6rem;
}

.feature p{
  /* light-on-dark compensation: regular weight, looser leading, a touch of tracking */
  font-weight:400;
  line-height:1.7;
  letter-spacing:.01em;
  color:var(--color-sand);
}

/* ============================================================
   RECENSIONI
============================================================ */
.reviews-grid{
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(auto-fit, minmax(min(270px, 100%), 1fr));
}

.review{
  background:var(--color-white);
  border-radius:12px;
  padding:2rem;
  box-shadow:0 8px 24px rgba(28,28,28,.07);
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.stars{
  color:#E8B931;
  font-size:var(--fs-lead);
  letter-spacing:.15em;
}

.review blockquote{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:700;
  font-size:var(--fs-lead);
  line-height:1.45;
  flex-grow:1;
}

.review cite{
  font-style:normal;
  font-weight:700;
  font-size:var(--fs-small);
  color:var(--color-text-muted);
}

.reviews-total{
  margin-top:2.75rem;
  text-align:center;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  flex-wrap:wrap;
}

.reviews-total .lucide{
  color:#E8B931;
  fill:#E8B931;
}

/* ============================================================
   CONTATTI
============================================================ */
#contatti{ background:var(--color-cream); }

.contact-grid{
  display:grid;
  gap:3rem;
}

@media (min-width: 768px){
  .contact-grid{ grid-template-columns:1fr 1fr; align-items:start; }
}

.contact-line{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  margin-bottom:1rem;
}

.contact-line .lucide{
  color:var(--color-primary);
  margin-top:.2rem;
}

.btn-call{ margin:.75rem 0 2.25rem; }

.hours{
  width:100%;
  border-collapse:collapse;
  font-size:var(--fs-small);
}

.hours caption{
  text-align:left;
  font-family:var(--font-display);
  font-weight:700;
  font-size:var(--fs-lead);
  margin-bottom:.75rem;
}

.hours th,
.hours td{
  text-align:left;
  padding:.55rem .25rem;
  border-bottom:1px solid var(--color-sand);
}

.hours th{ font-weight:700; }
.hours td{
  color:var(--color-text-muted);
  font-variant-numeric:tabular-nums; /* opening times align column-true across rows */
}

.hours tr.closed th,
.hours tr.closed td{
  color:var(--color-primary);
  font-weight:700;
}

.amenities{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  margin-top:2rem;
  list-style:none;
}

.amenities li{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  background:var(--color-sand);
  border-radius:999px;
  padding:.45rem 1rem;
  font-size:var(--fs-small);
  font-weight:700;
  color:var(--color-charcoal);
}

.amenities .lucide{ color:var(--color-primary); width:1.05rem; height:1.05rem; }

.map-wrap{
  border-radius:12px;
  overflow:hidden;
  border:3px solid var(--color-primary);
  box-shadow:0 14px 34px rgba(28,28,28,.12);
}

.map-link{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  margin-top:1rem;
  font-weight:700;
  font-size:var(--fs-small);
  letter-spacing:.04em;
}

.map-link .lucide{ width:1.05rem; height:1.05rem; }

.map-wrap iframe{
  display:block;
  width:100%;
  height:430px;
  border:0;
}

/* ============================================================
   FOOTER
============================================================ */
.footer{
  background:var(--color-charcoal);
  color:var(--color-sand);
  padding:4.5rem 0 0;
}

.footer-grid{
  display:grid;
  gap:2.5rem;
  grid-template-columns:repeat(auto-fit, minmax(min(220px, 100%), 1fr));
  padding-bottom:3rem;
}

.footer-brand .name{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:900;
  font-size:2rem;
  color:var(--color-cream);
}

.footer-brand .tagline{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:700;
  margin-top:.4rem;
}

.footer-social{
  display:flex;
  gap:.75rem;
  margin-top:1.5rem;
}

.footer-social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:2.75rem;  /* 44px touch target */
  height:2.75rem;
  border-radius:50%;
  border:1px solid rgba(232,221,208,.35);
  color:var(--color-sand);
  transition:background-color .2s ease, color .2s ease, transform .2s ease, border-color .2s ease;
}

.footer-social a:hover{
  background:var(--color-primary);
  border-color:var(--color-primary);
  color:var(--color-white);
  transform:scale(1.03);
}

.footer-social svg{
  width:1.15rem;
  height:1.15rem;
}

.footer h3{
  font-family:var(--font-body);
  font-weight:700;
  font-size:var(--fs-small);
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--color-cream);
  margin-bottom:1.1rem;
}

.footer ul{ list-style:none; }

.footer li{ margin-bottom:.6rem; }

.footer a{
  color:var(--color-sand);
  text-decoration:none;
}

.footer a:hover{ color:var(--color-white); text-decoration:underline; }

.footer-bottom{
  border-top:1px solid rgba(232,221,208,.18);
  padding:1.4rem 0;
  text-align:center;
  font-weight:400;
  font-size:var(--fs-small); /* .78rem was below the 14px mobile floor */
  letter-spacing:.04em;
}
