/* ============================================================
   Relojería Garsán — Design System
   Navy #09307c (sampled from logo) · Champagne gold · Cream · Ink
   ============================================================ */

:root{
  --ink:#0c1626;        /* deep navy-black, dark sections        */
  --ink-2:#11203a;      /* raised dark surface                    */
  --navy:#0f3a82;       /* brand royal navy (from logo)           */
  --navy-deep:#09254f;  /* deeper navy                            */
  --gold:#c2a268;       /* champagne accent                       */
  --gold-soft:#d8c39a;
  --gold-deep:#a8884d;
  --cream:#f5f1e8;      /* warm off-white, light sections         */
  --paper:#faf7f0;      /* lightest paper                         */
  --stone:#6f6a5f;      /* warm grey body text on cream           */
  --stone-2:#928c7e;
  --line-dark:rgba(216,195,154,.18);
  --line-cream:rgba(36,30,20,.14);

  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Manrope", system-ui, -apple-system, sans-serif;
  --label:"Marcellus", Georgia, serif;

  --maxw:1280px;
  --pad: clamp(20px, 5vw, 80px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--ink)}

/* ---------- Typography primitives ---------- */
.eyebrow{
  font-family:var(--label);
  font-size:.78rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:.85em;
}
.eyebrow::before{
  content:"";
  width:30px;height:1px;
  background:currentColor;
  opacity:.7;
}
.eyebrow.center::after{
  content:"";
  width:30px;height:1px;
  background:currentColor;
  opacity:.7;
}
.eyebrow.center{justify-content:center}
.eyebrow.on-dark{color:var(--gold-soft)}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:.005em}
.display{
  font-size:clamp(2.7rem,6.6vw,5.6rem);
  font-weight:500;
  line-height:1.0;
  letter-spacing:-.01em;
}
.h2{
  font-size:clamp(2.1rem,4.3vw,3.6rem);
  line-height:1.05;
}
.lead{
  font-size:clamp(1.05rem,1.5vw,1.28rem);
  line-height:1.65;
  color:var(--stone);
  font-weight:350;
  max-width:46ch;
  text-wrap:pretty;
}
.lead.on-dark{color:rgba(245,241,232,.72)}
.italic{font-style:italic}
.gold-text{color:var(--gold-deep)}

/* ---------- Layout ---------- */
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.section-pad{padding-block:clamp(72px,11vw,150px)}
.dark{background:var(--ink);color:var(--cream)}
.dark .lead{color:rgba(245,241,232,.7)}
.cream{background:var(--cream)}
.paper{background:var(--paper)}

.rule{height:1px;background:var(--line-cream);border:0;width:100%}
.dark .rule{background:var(--line-dark)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);
  font-size:.82rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  padding:1.05em 1.9em;
  border:1px solid transparent;
  cursor:pointer;
  transition:all .45s var(--ease);
  white-space:nowrap;
}
.btn .arr{transition:transform .45s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn-gold{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-soft);border-color:var(--gold-soft)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-deep);border-color:var(--navy-deep)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--line-cream)}
.btn-outline:hover{border-color:var(--ink);background:var(--ink);color:var(--cream)}
.btn-outline.on-dark{color:var(--cream);border-color:rgba(245,241,232,.28)}
.btn-outline.on-dark:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}

/* ---------- Stars ---------- */
.stars{display:inline-flex;gap:3px;color:var(--gold);font-size:.95em;letter-spacing:1px;line-height:1}
.stars.sm{font-size:.8em}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(14px,2vw,22px) var(--pad);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.site-header.scrolled{
  background:rgba(10,18,34,.86);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line-dark);
  padding-block:12px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:clamp(30px,3.4vw,42px);width:auto;transition:height .5s var(--ease)}
.scrolled .brand img{height:30px}
.brand .est{
  font-family:var(--label);font-size:.6rem;letter-spacing:.28em;
  color:var(--gold-soft);text-transform:uppercase;
  border-left:1px solid var(--line-dark);padding-left:14px;
  line-height:1.4;
}
@media(max-width:600px){.brand .est{display:none}}

.nav{display:flex;align-items:center;gap:clamp(20px,2.6vw,40px)}
.nav-links{display:flex;gap:clamp(18px,2.2vw,34px)}
.nav-links a{
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  color:rgba(245,241,232,.82);position:relative;padding:4px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--gold);transition:width .4s var(--ease);
}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-phone{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:.78rem;letter-spacing:.1em;font-weight:600;color:var(--gold-soft);
  border:1px solid rgba(216,195,154,.32);padding:.7em 1.2em;border-radius:999px;
  transition:all .4s var(--ease);
}
.nav-phone:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:1.5px;background:var(--cream);transition:.4s var(--ease)}

@media(max-width:920px){
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:flex}
}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:200;
  background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  opacity:0;pointer-events:none;transition:opacity .5s var(--ease);
}
.drawer.open{opacity:1;pointer-events:auto}
.drawer a{
  font-family:var(--serif);font-size:2rem;color:var(--cream);padding:.25em;
  opacity:0;transform:translateY(14px);transition:.5s var(--ease);
}
.drawer.open a{opacity:1;transform:none}
.drawer.open a:nth-child(1){transition-delay:.08s}
.drawer.open a:nth-child(2){transition-delay:.14s}
.drawer.open a:nth-child(3){transition-delay:.20s}
.drawer.open a:nth-child(4){transition-delay:.26s}
.drawer.open a:nth-child(5){transition-delay:.32s}
.drawer.open a:nth-child(6){transition-delay:.38s}
.drawer .close{position:absolute;top:24px;right:24px;font-size:2rem;color:var(--gold-soft);background:none;border:0;cursor:pointer;font-family:var(--sans)}
.drawer .dphone{margin-top:24px;color:var(--gold-soft);letter-spacing:.1em;font-size:1rem;font-family:var(--sans)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  background:var(--ink);
  overflow:hidden;
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:72% 42%;filter:brightness(.72) contrast(1.05) saturate(.9)}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(8,14,26,.6) 0%, rgba(8,14,26,.2) 28%, rgba(8,14,26,.42) 56%, rgba(8,14,26,.96) 100%),
    linear-gradient(95deg, rgba(8,14,26,.95) 0%, rgba(8,14,26,.78) 34%, rgba(8,14,26,.3) 60%, rgba(8,14,26,0) 82%);
}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(56px,8vw,110px);padding-top:140px}
.hero-rating{
  display:inline-flex;align-items:center;gap:.7em;margin-bottom:30px;
  font-size:.8rem;letter-spacing:.08em;color:rgba(245,241,232,.85);
}
.hero-rating b{color:#fff;font-weight:600}
.hero-rating .g{font-family:var(--label);letter-spacing:.18em;color:var(--gold-soft);font-size:.72rem;text-transform:uppercase}
.hero h1{color:var(--cream);max-width:16ch;text-shadow:0 2px 30px rgba(8,14,26,.45)}
.hero h1 em{font-style:italic;color:var(--gold-soft);font-weight:500}
.hero-sub{margin-top:28px;max-width:42ch;color:rgba(245,241,232,.86);text-shadow:0 1px 16px rgba(8,14,26,.55)}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;margin-top:40px}
.hero-est{
  position:absolute;right:var(--pad);top:46%;z-index:2;
  writing-mode:vertical-rl;text-orientation:mixed;
  font-family:var(--label);letter-spacing:.4em;text-transform:uppercase;
  font-size:.72rem;color:rgba(216,195,154,.7);
  display:flex;align-items:center;gap:18px;
}
.hero-est::after{content:"";height:60px;width:1px;background:rgba(216,195,154,.4)}
@media(max-width:920px){.hero-est{display:none}}

.scroll-hint{
  position:absolute;left:var(--pad);bottom:30px;z-index:2;
  display:flex;align-items:center;gap:12px;
  font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(245,241,232,.55);
}
.scroll-hint .l{width:46px;height:1px;background:rgba(245,241,232,.4);position:relative;overflow:hidden}
.scroll-hint .l::after{content:"";position:absolute;inset:0;background:var(--gold);animation:scroll-line 2.4s var(--ease) infinite}
@keyframes scroll-line{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}
@media(max-width:920px){.scroll-hint{display:none}}

/* ============================================================
   IDENTITY / PRESENTATION
   ============================================================ */
.identity{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,7vw,110px);align-items:center}
.identity-seal{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  aspect-ratio:1/1;border:1px solid var(--line-cream);border-radius:50%;
  width:min(78%,420px);margin:0 auto;text-align:center;position:relative;
}
.identity-seal::before{content:"";position:absolute;inset:14px;border:1px solid var(--line-cream);border-radius:50%}
.identity-seal .yr{font-family:var(--serif);font-size:clamp(3.4rem,7vw,5.2rem);color:var(--navy);line-height:1}
.identity-seal .yr-label{font-family:var(--label);letter-spacing:.3em;text-transform:uppercase;font-size:.72rem;color:var(--gold-deep);margin-bottom:10px}
.identity-seal .yr-sub{font-size:.74rem;color:var(--stone-2);letter-spacing:.05em;margin-top:6px}
.identity h2{color:var(--ink);margin-top:18px}
.identity .lead{margin-top:24px}
.identity-sign{margin-top:30px}
.identity-sign img{height:54px;width:auto;opacity:.95}
@media(max-width:860px){
  .identity{grid-template-columns:1fr;gap:48px}
  .identity-seal{order:-1;width:min(64%,300px)}
}

/* ============================================================
   CATEGORIES
   ============================================================ */
.cat-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:54px}
.cat-head h2{color:var(--cream);max-width:14ch}
.cat-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:18px;
}
.cat{
  position:relative;overflow:hidden;cursor:pointer;
  background:var(--ink-2);min-height:340px;display:flex;
  grid-column:span 2;
}
.cat.tall{grid-row:span 2;min-height:auto}
.cat:nth-child(1){grid-column:span 3}
.cat:nth-child(2){grid-column:span 3}
.cat-img{position:absolute;inset:0}
.cat-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease),filter 1.1s var(--ease);filter:saturate(.92) brightness(.82)}
.cat:hover .cat-img img{transform:scale(1.06);filter:saturate(1) brightness(.7)}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,14,26,0) 35%,rgba(8,14,26,.86) 100%);z-index:1}
.cat-body{position:relative;z-index:2;margin-top:auto;padding:26px 26px 28px;width:100%;display:flex;align-items:flex-end;justify-content:space-between;gap:14px}
.cat-num{font-family:var(--label);font-size:.68rem;letter-spacing:.2em;color:var(--gold-soft);opacity:.8}
.cat-title{font-family:var(--serif);font-size:clamp(1.5rem,2.4vw,2.05rem);color:var(--cream);line-height:1.05}
.cat-arrow{
  width:42px;height:42px;border:1px solid rgba(245,241,232,.4);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--cream);flex-shrink:0;
  transition:all .45s var(--ease);transform:translateY(6px);opacity:0;
}
.cat:hover .cat-arrow{transform:none;opacity:1;background:var(--gold);border-color:var(--gold);color:var(--ink)}
@media(max-width:860px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .cat,.cat:nth-child(1),.cat:nth-child(2){grid-column:span 1}
  .cat.tall{grid-row:auto}
  .cat{min-height:280px}
}
@media(max-width:520px){
  .cat-grid{grid-template-columns:1fr}
  .cat,.cat:nth-child(1),.cat:nth-child(2){grid-column:span 1}
}

/* ============================================================
   EDITORIAL BAND
   ============================================================ */
.editorial{background:var(--ink);overflow:hidden}
.ed-grid{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.ed-media{position:relative;min-height:560px}
.ed-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ed-media.b{border-left:1px solid var(--line-dark)}
.ed-text{
  padding:clamp(48px,7vw,110px) clamp(28px,6vw,90px);
  display:flex;flex-direction:column;justify-content:center;gap:26px;
}
.ed-claim{font-family:var(--serif);font-size:clamp(2rem,3.6vw,3.2rem);color:var(--cream);line-height:1.1;font-style:italic}
.ed-claim .accent{color:var(--gold-soft)}
.ed-list{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.ed-list .item{display:flex;align-items:baseline;gap:18px;padding:18px 0;border-top:1px solid var(--line-dark)}
.ed-list .item:last-child{border-bottom:1px solid var(--line-dark)}
.ed-list .n{font-family:var(--label);font-size:.72rem;letter-spacing:.18em;color:var(--gold);min-width:34px}
.ed-list .t{font-family:var(--serif);font-size:1.5rem;color:var(--cream)}
@media(max-width:860px){
  .ed-grid{grid-template-columns:1fr}
  .ed-media{min-height:360px}
  .ed-media.b{order:3;border-left:0;border-top:1px solid var(--line-dark)}
}

/* split editorial (image + claims pairing) */
.ed-split{display:grid;grid-template-columns:1.1fr .9fr;gap:0;min-height:600px}
@media(max-width:860px){.ed-split{grid-template-columns:1fr}}

/* ============================================================
   SERVICES
   ============================================================ */
.serv-head{max-width:680px;margin-bottom:60px}
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-cream)}
.serv{
  background:var(--cream);padding:clamp(30px,3.4vw,46px) clamp(26px,2.6vw,38px);
  display:flex;flex-direction:column;gap:16px;min-height:230px;
  transition:background .5s var(--ease);position:relative;
}
.serv:hover{background:var(--paper)}
.serv .s-num{font-family:var(--label);font-size:.72rem;letter-spacing:.2em;color:var(--gold-deep)}
.serv .s-title{font-family:var(--serif);font-size:1.7rem;color:var(--ink);line-height:1.1}
.serv .s-desc{font-size:.95rem;line-height:1.6;color:var(--stone);font-weight:350}
.serv .s-line{margin-top:auto;width:28px;height:1px;background:var(--gold);transition:width .5s var(--ease)}
.serv:hover .s-line{width:54px}
@media(max-width:860px){.serv-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.serv-grid{grid-template-columns:1fr}}

/* ============================================================
   WHY US
   ============================================================ */
.why{background:var(--ink);color:var(--cream)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.why-intro h2{color:var(--cream)}
.why-intro .lead{margin-top:24px}
.why-rating{margin-top:38px;display:flex;align-items:center;gap:20px;padding-top:30px;border-top:1px solid var(--line-dark)}
.why-rating .score{font-family:var(--serif);font-size:3.4rem;color:var(--gold-soft);line-height:1}
.why-rating .meta{font-size:.85rem;color:rgba(245,241,232,.65);line-height:1.5}
.why-rating .meta b{color:var(--cream);font-weight:600}
.why-list{display:flex;flex-direction:column}
.why-item{display:flex;gap:22px;padding:24px 0;border-top:1px solid var(--line-dark);align-items:flex-start}
.why-item:last-child{border-bottom:1px solid var(--line-dark)}
.why-item .ic{
  width:40px;height:40px;flex-shrink:0;border:1px solid var(--line-dark);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--gold);
}
.why-item .ic svg{width:18px;height:18px}
.why-item h3{font-family:var(--serif);font-size:1.4rem;color:var(--cream);margin-bottom:6px}
.why-item p{font-size:.9rem;color:rgba(245,241,232,.62);line-height:1.55;font-weight:350}
@media(max-width:860px){.why-grid{grid-template-columns:1fr;gap:40px}}

/* ============================================================
   REVIEWS
   ============================================================ */
.rev-head{text-align:center;max-width:640px;margin:0 auto 60px}
.rev-head .lead{margin:28px auto 0}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev-card{
  background:var(--paper);border:1px solid var(--line-cream);
  padding:34px 32px 30px;display:flex;flex-direction:column;gap:18px;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease);
}
.rev-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -30px rgba(12,22,38,.4);border-color:rgba(194,162,104,.5)}
.rev-card .quote{font-family:var(--serif);font-size:1.28rem;line-height:1.45;color:var(--ink);font-style:italic;text-wrap:pretty}
.rev-card .quote::before{content:"“";color:var(--gold);font-size:1.4em;line-height:0;vertical-align:-.3em;margin-right:.05em}
.rev-foot{margin-top:auto;display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line-cream)}
.rev-avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:var(--navy);color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.2rem;
}
.rev-name{font-weight:600;font-size:.92rem;color:var(--ink);letter-spacing:.01em}
.rev-src{font-size:.72rem;color:var(--stone-2);letter-spacing:.06em;margin-top:2px}

/* carousel row */
.rev-carousel{margin-top:26px;overflow:hidden;position:relative}
.rev-track{display:flex;gap:20px;width:max-content;animation:marquee 46s linear infinite}
.rev-carousel:hover .rev-track{animation-play-state:paused}
.rev-mini{
  width:340px;flex-shrink:0;background:var(--cream);border:1px solid var(--line-cream);
  padding:24px 26px;display:flex;flex-direction:column;gap:12px;
}
.rev-mini .quote{font-size:1rem;line-height:1.5;color:var(--stone);font-weight:350}
.rev-mini .nm{font-weight:600;font-size:.85rem;color:var(--ink)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rev-fade{position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.rev-fade.l{left:0;background:linear-gradient(90deg,var(--cream),transparent)}
.rev-fade.r{right:0;background:linear-gradient(270deg,var(--cream),transparent)}
@media(max-width:860px){.rev-grid{grid-template-columns:1fr}}

/* ============================================================
   STORE (facade)
   ============================================================ */
.store{background:var(--ink);overflow:hidden}
.store-grid{display:grid;grid-template-columns:1.15fr .85fr;align-items:stretch}
.store-media{position:relative;min-height:520px}
.store-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.store-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,14,26,0) 60%,rgba(8,14,26,.5) 100%)}
.store-badge{
  position:absolute;left:24px;top:24px;z-index:3;
  background:rgba(10,18,34,.7);backdrop-filter:blur(8px);
  border:1px solid var(--line-dark);padding:12px 18px;
  font-family:var(--label);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);
}
.store-text{padding:clamp(48px,6vw,90px) clamp(30px,5vw,80px);display:flex;flex-direction:column;justify-content:center;gap:24px}
.store-text h2{color:var(--cream)}
.store-info{display:flex;flex-direction:column;gap:18px;margin-top:6px}
.store-info .row{display:flex;gap:16px;align-items:flex-start}
.store-info .ic{color:var(--gold);width:20px;flex-shrink:0;margin-top:3px}
.store-info .ic svg{width:18px;height:18px}
.store-info .row b{color:var(--cream);font-weight:600;font-size:1rem;display:block;letter-spacing:.01em}
.store-info .row span{color:rgba(245,241,232,.62);font-size:.9rem;line-height:1.55;font-weight:350}
.store-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
@media(max-width:860px){
  .store-grid{grid-template-columns:1fr}
  .store-media{min-height:340px}
}

/* ============================================================
   CONTACT + MAP + FORM
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,72px);align-items:stretch}
.contact-info h2{color:var(--ink)}
.contact-info .lead{margin-top:20px;margin-bottom:36px}
.info-block{display:flex;flex-direction:column;gap:0}
.info-row{display:flex;gap:18px;align-items:flex-start;padding:20px 0;border-top:1px solid var(--line-cream)}
.info-row:last-child{border-bottom:1px solid var(--line-cream)}
.info-row .ic{width:22px;flex-shrink:0;color:var(--gold-deep);margin-top:2px}
.info-row .ic svg{width:20px;height:20px}
.info-row .lab{font-family:var(--label);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:5px}
.info-row .val{font-size:1rem;color:var(--ink);line-height:1.55}
.info-row .val a:hover{color:var(--navy)}
.hours-line{display:flex;justify-content:space-between;gap:20px;font-size:.92rem;padding:3px 0;color:var(--stone)}
.hours-line .d{color:var(--ink);font-weight:500}
.hours-line.closed .t{color:var(--gold-deep);font-style:italic}

/* map / location card */
.map-card{
  margin-top:30px;border:1px solid var(--line-cream);overflow:hidden;position:relative;
  aspect-ratio:16/10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  background:radial-gradient(120% 120% at 50% 0%, var(--ink-2), var(--ink) 70%);
  text-align:center;transition:transform .5s var(--ease);
}
.map-card:hover{transform:translateY(-3px)}
.map-grid{position:absolute;inset:0;opacity:.5;
  background:
    repeating-linear-gradient(0deg,transparent 0 38px,rgba(216,195,154,.07) 38px 39px),
    repeating-linear-gradient(90deg,transparent 0 38px,rgba(216,195,154,.07) 38px 39px),
    radial-gradient(circle at 50% 46%, rgba(194,162,104,.16), transparent 40%);
}
.map-card::after{content:"";position:absolute;left:50%;top:46%;width:54px;height:54px;transform:translate(-50%,-50%);
  border:1px solid rgba(194,162,104,.35);border-radius:50%;animation:ping 3s ease-out infinite}
@keyframes ping{0%{transform:translate(-50%,-50%) scale(.5);opacity:.9}70%,100%{transform:translate(-50%,-50%) scale(2.4);opacity:0}}
.map-pin{position:relative;z-index:2;width:46px;height:46px;border-radius:50%;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px -8px rgba(0,0,0,.6)}
.map-pin svg{width:22px;height:22px}
.map-place{position:relative;z-index:2;font-family:var(--serif);font-size:1.5rem;color:var(--cream);margin-top:12px}
.map-addr{position:relative;z-index:2;font-size:.85rem;color:rgba(245,241,232,.6);letter-spacing:.04em}
.map-cta{position:relative;z-index:2;margin-top:14px;font-family:var(--label);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);border-bottom:1px solid rgba(216,195,154,.35);padding-bottom:4px;transition:border-color .4s var(--ease)}
.map-card:hover .map-cta{border-color:var(--gold-soft)}

/* form */
.form-card{background:var(--ink);color:var(--cream);padding:clamp(34px,4vw,54px)}
.form-card .eyebrow{color:var(--gold-soft)}
.form-card h3{font-family:var(--serif);font-size:clamp(1.7rem,2.6vw,2.3rem);color:var(--cream);margin:14px 0 8px}
.form-card p.fc-sub{color:rgba(245,241,232,.6);font-size:.95rem;line-height:1.6;margin-bottom:30px;font-weight:350}
.field{margin-bottom:22px;position:relative}
.field label{display:block;font-family:var(--label);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:9px}
.field input,.field textarea{
  width:100%;background:transparent;border:0;border-bottom:1px solid rgba(245,241,232,.22);
  color:var(--cream);font-family:var(--sans);font-size:1rem;padding:10px 2px;
  transition:border-color .4s var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:rgba(245,241,232,.32)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field textarea{resize:vertical;min-height:90px}
.field.error input,.field.error textarea{border-color:#d98a7a}
.field .err{color:#e0a99c;font-size:.74rem;margin-top:6px;display:none}
.field.error .err{display:block}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.form-submit{width:100%;justify-content:center;margin-top:8px}
.form-ok{
  display:none;text-align:center;padding:40px 10px;
}
.form-ok.show{display:block}
.form-ok .check{width:54px;height:54px;border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--gold)}
.form-ok h3{margin-bottom:8px}
/* google maps embed */
.map-embed{overflow:hidden;border:1px solid var(--line-cream);min-height:480px}
.map-embed iframe{width:100%;height:100%;border:0;display:block;min-height:480px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
@media(max-width:860px){.map-embed{min-height:360px}.map-embed iframe{min-height:360px}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#070d18;color:var(--cream);padding-top:clamp(60px,8vw,100px)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:60px}
.foot-brand img{height:46px;width:auto;margin-bottom:22px}
.foot-brand p{font-size:.9rem;color:rgba(245,241,232,.55);line-height:1.7;max-width:34ch;font-weight:350}
.foot-brand .stars{margin-top:18px}
.foot-col h4{font-family:var(--label);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:20px}
.foot-col a,.foot-col p{display:block;font-size:.88rem;color:rgba(245,241,232,.6);line-height:2.05;font-weight:350;transition:color .3s var(--ease)}
.foot-col a:hover{color:var(--gold-soft)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:26px 0;border-top:1px solid rgba(216,195,154,.12)}
.foot-bottom .legal{display:flex;gap:24px;flex-wrap:wrap}
.foot-bottom a,.foot-bottom span{font-size:.76rem;color:rgba(245,241,232,.45);letter-spacing:.04em}
.foot-bottom a:hover{color:var(--gold-soft)}
@media(max-width:860px){
  .foot-top{grid-template-columns:1fr 1fr;gap:36px}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:520px){.foot-top{grid-template-columns:1fr}}

/* ============================================================
   IMAGE FALLBACK (graceful degradation if a photo fails)
   ============================================================ */
.ph{background:
   repeating-linear-gradient(135deg,rgba(216,195,154,.05) 0 2px,transparent 2px 11px),
   linear-gradient(150deg,var(--ink-2),var(--navy-deep) 120%);
}
.ph.cr{background:
   repeating-linear-gradient(135deg,rgba(36,30,20,.04) 0 2px,transparent 2px 11px),
   linear-gradient(150deg,#ece5d6,#ded3bd 120%);
}
.ph.failed::after{
  content:attr(data-ph);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--label);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(216,195,154,.55);text-align:center;padding:20px;
}
.ph.cr.failed::after{color:rgba(120,100,60,.5)}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .rev-track{animation:none}
  *{scroll-behavior:auto}
}
