/* =========================================================
   POLICLÍNICA DR. SALVADOR RIBOT RUIZ — Stylesheet
   Design tokens
   ========================================================= */

:root{
  /* Color */
  --cream:        #F7F3EC;
  --cream-deep:   #EFE8DA;
  --ink:          #1B2430;
  --ink-soft:     #3C4654;
  --red:          #B5232A;
  --red-deep:     #8C1A20;
  --red-tint:     #F4DCDC;
  --teal:         #2E7D6B;
  --gold:         #D6A24A;
  --line:         #E2D9C8;
  --white:        #FFFFFF;

  /* Type */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'IBM Plex Mono', 'Courier New', monospace;

  /* Scale */
  --step--1: clamp(0.83rem, 0.8rem + 0.1vw, 0.9rem);
  --step-0:  clamp(1rem, 0.95rem + 0.2vw, 1.05rem);
  --step-1:  clamp(1.2rem, 1.1rem + 0.4vw, 1.35rem);
  --step-2:  clamp(1.5rem, 1.3rem + 0.8vw, 1.85rem);
  --step-3:  clamp(1.9rem, 1.5rem + 1.6vw, 2.6rem);
  --step-4:  clamp(2.4rem, 1.8rem + 2.6vw, 3.6rem);
  --step-5:  clamp(3rem, 2rem + 4vw, 5rem);

  /* Layout */
  --maxw: 1180px;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 28px;

  --shadow-sm: 0 2px 10px rgba(27,36,48,0.06);
  --shadow-md: 0 10px 30px rgba(27,36,48,0.10);
  --shadow-red: 0 14px 34px rgba(181,35,42,0.22);

  --ease: cubic-bezier(.22,.61,.36,1);
  --topbar-h: 40px;
}

/* =========================================================
   Reset
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  font-size:var(--step-0);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img,video{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4,p{ margin:0; }

:focus-visible{
  outline:3px solid var(--gold);
  outline-offset:3px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
}

.container{
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
}

.eyebrow{
  font-family:var(--font-mono);
  font-size:var(--step--1);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--red);
  display:flex;
  align-items:center;
  gap:.6em;
}
.eyebrow::before{
  content:'';
  width:22px; height:2px;
  background:var(--red);
  display:inline-block;
}

.section{
  padding-block: clamp(3.5rem, 8vw, 7rem);
}
.section-head{
  max-width:640px;
  margin-bottom:clamp(2rem,5vw,3.2rem);
}
.section-head h2{
  font-family:var(--font-display);
  font-size:var(--step-3);
  font-weight:600;
  line-height:1.1;
  margin-top:.5rem;
  color:var(--ink);
}
.section-head p{
  margin-top:.9rem;
  color:var(--ink-soft);
  font-size:var(--step-1);
}

.bg-deep{ background:var(--cream-deep); }
.bg-ink{ background:var(--ink); color:var(--cream); }
.bg-ink .eyebrow{ color:var(--gold); }
.bg-ink .eyebrow::before{ background:var(--gold); }

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.85rem 1.6rem;
  border-radius:999px;
  font-weight:600;
  font-size:var(--step--1);
  letter-spacing:.01em;
  border:1.5px solid transparent;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  white-space:nowrap;
}
.btn-primary{
  background:var(--red);
  color:var(--white);
  box-shadow:var(--shadow-red);
}
.btn-primary:hover{ background:var(--red-deep); transform:translateY(-2px); }
.btn-ghost{
  background:transparent;
  border-color:currentColor;
  color:inherit;
}
.btn-ghost:hover{ background:rgba(0,0,0,.05); }
.bg-ink .btn-ghost:hover{ background:rgba(255,255,255,.08); }
.btn-sm{ padding:.55rem 1.1rem; font-size:var(--step--1); }

/* =========================================================
   Top bar — horario
   ========================================================= */
.top-bar{
  position:fixed; top:0; left:0; right:0; z-index:210;
  height:var(--topbar-h);
  background:var(--ink); color:var(--cream);
}
.top-bar-inner{
  height:100%;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.top-bar-hours{
  display:flex; align-items:center; gap:.5rem;
  font-size:.78rem; font-weight:500; white-space:nowrap;
  overflow-x:auto;
}
.top-bar-hours svg{ width:14px; height:14px; flex-shrink:0; color:var(--gold); }
.top-bar-sep{ opacity:.5; }
.top-bar-phone{
  display:flex; align-items:center; gap:.4rem;
  font-size:.78rem; font-weight:600; color:var(--cream); white-space:nowrap;
}
.top-bar-phone svg{ width:13px; height:13px; color:var(--gold); }
.top-bar-phone:hover{ color:var(--gold); }

@media (max-width: 620px){
  .top-bar-inner{ justify-content:center; }
  .top-bar-phone{ display:none; }
  .top-bar-hours{ font-size:.72rem; }
  .hero-title-row{ gap:.65rem; align-items:flex-start; }
  .hero-title-logo{ width:40px; height:40px; margin-top:.3rem; }
}

/* =========================================================
   Header / Nav
   ========================================================= */
.site-header{
  position:fixed; top:var(--topbar-h); left:0; right:0; z-index:200;
  border-bottom:1px solid transparent;
  transition:border-color .3s;
}
.site-header::before{
  content:'';
  position:absolute; inset:0;
  background:rgba(247,243,236,0.85);
  backdrop-filter:blur(10px);
  transition:background .3s;
  z-index:-1;
}
.site-header.scrolled{
  border-color:var(--line);
}
.site-header.scrolled::before{
  background:rgba(247,243,236,0.96);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding-block:.7rem;
  gap:1rem;
}
.brand{ display:flex; align-items:center; gap:.6rem; }
.brand img{ height:42px; width:auto; }
.brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-text strong{ font-family:var(--font-display); font-size:1.05rem; font-weight:700; }
.brand-text span{ font-size:.68rem; letter-spacing:.05em; color:var(--ink-soft); }

.main-nav{ display:flex; align-items:center; gap:1.7rem; }
.main-nav a{
  font-size:var(--step--1); font-weight:600; color:var(--ink-soft);
  position:relative; padding-block:.3rem;
}
.main-nav a.nav-cta, .main-nav a.nav-cta:hover{ color:var(--white); }
.main-nav a::after{
  content:''; position:absolute; left:0; right:0; bottom:-2px; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left;
  transition:transform .25s var(--ease);
}
.main-nav a:hover{ color:var(--ink); }
.main-nav a:hover::after{ transform:scaleX(1); }

.header-actions{ display:flex; align-items:center; gap:.7rem; }

.lang-switch{
  display:flex; border:1.5px solid var(--line); border-radius:999px; overflow:hidden;
  font-family:var(--font-mono); font-size:.74rem; font-weight:600;
}
.lang-switch button{
  background:transparent; border:none; padding:.4rem .65rem; color:var(--ink-soft);
  transition:background .2s, color .2s;
}
.lang-switch button.active{ background:var(--ink); color:var(--cream); }

.nav-toggle{
  display:none;
  width:42px; height:42px; border-radius:50%;
  border:1.5px solid var(--line); background:var(--white);
  align-items:center; justify-content:center;
  position:relative; z-index:10;
}
.nav-toggle svg{ width:18px; height:18px; transition:opacity .15s, transform .2s; }
.nav-toggle .icon-close{ position:absolute; opacity:0; transform:rotate(-90deg); }
.nav-toggle[aria-expanded="true"] .icon-open{ opacity:0; transform:rotate(90deg); }
.nav-toggle[aria-expanded="true"] .icon-close{ opacity:1; transform:rotate(0); }

@media (max-width: 880px){
  .main-nav{
    position:fixed; top:calc(64px + var(--topbar-h)); right:0; bottom:0; left:0; background:var(--cream);
    flex-direction:column; justify-content:flex-start; align-items:stretch;
    padding:1.5rem var(--gutter); gap:0;
    transform:translateX(100%); transition:transform .35s var(--ease);
    overflow-y:auto;
    z-index:150;
  }
  .main-nav.open{ transform:translateX(0); }
  .main-nav a{
    padding-block:.95rem; border-bottom:1px solid var(--line); font-size:1.05rem;
  }
  .main-nav .nav-cta{ margin-top:1.2rem; }
  .nav-toggle{ display:flex; }
  .brand-text span{ display:none; }
}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;
  padding-top: calc(clamp(7rem, 14vw, 9rem) + var(--topbar-h));
  padding-bottom: clamp(4rem, 9vw, 6rem);
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items:center;
}
.hero-ring{
  position:absolute;
  top:-160px; right:-160px;
  width:520px; height:520px;
  border:48px solid var(--red-tint);
  border-radius:50%;
  z-index:0;
}
.hero-kicker{
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--white); border:1px solid var(--line);
  padding:.4rem .8rem; border-radius:999px;
  font-family:var(--font-mono); font-size:.74rem; color:var(--red-deep); font-weight:600;
  box-shadow:var(--shadow-sm);
}
.hero-kicker svg{ width:14px; height:14px; }
.hero-title-row{
  display:flex;
  align-items:flex-start;
  gap:clamp(.8rem, 2vw, 1.4rem);
  margin-top:1.1rem;
}
.hero-title-logo{
  width:clamp(48px, 6vw, 72px);
  height:clamp(48px, 6vw, 72px);
  flex-shrink:0;
  margin-top:.3em;
}
.hero h1{
  font-family:var(--font-display);
  font-size:var(--step-5);
  line-height:1.02;
  font-weight:600;
  margin-top:0;
  color:var(--ink);
}
.hero h1 em{
  font-style:normal; color:var(--red);
}
.hero-lede{
  margin-top:1.3rem;
  font-size:var(--step-1);
  color:var(--ink-soft);
  max-width:46ch;
}
.hero-actions{
  margin-top:2rem;
  display:flex; flex-wrap:wrap; gap:.9rem;
}
.hero-meta{
  margin-top:2.4rem;
  display:flex; flex-wrap:wrap; gap:1.6rem .6rem;
}
.hero-meta-item{ display:flex; align-items:center; gap:.55rem; }
.hero-meta-item svg{ width:18px; height:18px; color:var(--red); flex-shrink:0; }
.hero-meta-item span{ font-size:var(--step--1); color:var(--ink-soft); font-weight:600; }

.hero-visual{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  aspect-ratio:4/5;
}
.hero-visual img{ width:100%; height:100%; object-fit:cover; }
.hero-badge{
  position:absolute; bottom:1.1rem; left:1.1rem; right:1.1rem;
  background:rgba(27,36,48,.78);
  backdrop-filter:blur(6px);
  color:var(--white);
  border-radius:var(--radius-md);
  padding:.9rem 1.1rem;
  display:flex; align-items:center; gap:.8rem;
}
.hero-badge strong{ display:block; font-size:var(--step--1); }
.hero-badge span{ display:block; font-size:.74rem; opacity:.8; margin-top:.1rem; }
.hero-badge-icon{
  width:38px; height:38px; border-radius:50%;
  background:var(--red); display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.hero-badge-icon svg{ width:18px; height:18px; color:#fff; }

@media (max-width: 880px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ aspect-ratio:16/10; order:-1; }
  .hero-ring{ width:320px; height:320px; border-width:30px; top:-100px; right:-120px; }
}

/* =========================================================
   Trust strip
   ========================================================= */
.trust-strip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--white);
}
.trust-strip .container{
  display:flex; flex-wrap:wrap; gap:2rem 2.5rem;
  padding-block:1.6rem;
  justify-content:space-between;
}
.trust-item{ display:flex; align-items:center; gap:.7rem; }
.trust-item svg{ width:22px; height:22px; color:var(--red); flex-shrink:0; }
.trust-item strong{ display:block; font-size:var(--step-1); font-family:var(--font-display); }
.trust-item span{ display:block; font-size:.78rem; color:var(--ink-soft); }

/* =========================================================
   Services
   ========================================================= */
.svc-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.4rem;
}
.svc-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:1.8rem 1.6rem;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
  position:relative;
  overflow:hidden;
}
.svc-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-md);
  border-color:var(--red-tint);
}
.svc-icon{
  width:52px; height:52px; border-radius:50%;
  background:var(--red-tint); color:var(--red-deep);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:1.1rem;
}
.svc-icon svg{ width:26px; height:26px; }
.svc-card h3{
  font-family:var(--font-display); font-size:var(--step-1); font-weight:600;
  margin-bottom:.5rem;
}
.svc-card p{ color:var(--ink-soft); font-size:var(--step--1); margin-bottom:1rem; }
.svc-list{ display:flex; flex-direction:column; gap:.4rem; }
.svc-list li{
  font-size:.82rem; color:var(--ink-soft);
  display:flex; align-items:flex-start; gap:.5rem;
}
.svc-list li::before{
  content:''; width:5px; height:5px; border-radius:50%;
  background:var(--red); margin-top:.55em; flex-shrink:0;
}
.svc-card .svc-phone{
  margin-top:1rem; padding-top:.9rem; border-top:1px dashed var(--line);
  font-family:var(--font-mono); font-size:.78rem; color:var(--red-deep); font-weight:600;
}

@media (max-width: 980px){ .svc-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width: 620px){ .svc-grid{ grid-template-columns:1fr; } }

/* Wellness strip (vitamins/weight) */
.wellness-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:.85rem;
  margin-top:1rem;
}
.wellness-pill{
  display:flex; align-items:center; gap:.7rem;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:.8rem .95rem;
  font-weight:600; font-size:var(--step--1);
}
.wellness-pill-icon{
  width:32px; height:32px; border-radius:50%; flex-shrink:0;
  background:var(--red-tint); color:var(--red-deep);
  display:flex; align-items:center; justify-content:center;
}
.wellness-pill-icon svg{ width:16px; height:16px; }
@media (max-width:420px){ .wellness-grid{ grid-template-columns:1fr; } }

/* Additional services — icon cards */
.addl-services{ margin-top:2.6rem; }
.addl-services-head{ margin-bottom:1.2rem; }
.addl-services-head h3{
  font-family:var(--font-display); font-size:var(--step-2); font-weight:600;
  margin-top:.4rem;
}
.addl-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1rem;
}
.addl-card{
  display:flex; flex-direction:column; align-items:flex-start; gap:.55rem;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-md);
  padding:1.3rem 1.2rem;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
}
a.addl-card:hover{
  transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--red-tint);
}
.addl-card-static{ cursor:default; }
.addl-icon{
  width:42px; height:42px; border-radius:50%;
  background:var(--red-tint); color:var(--red-deep);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.addl-icon svg{ width:21px; height:21px; }
.addl-card strong{ font-family:var(--font-display); font-size:.95rem; font-weight:600; color:var(--ink); }
.addl-phone{
  font-family:var(--font-mono); font-size:.76rem; color:var(--ink-soft);
}
a.addl-card .addl-phone{ color:var(--red-deep); }

@media (max-width:980px){ .addl-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .addl-grid{ grid-template-columns:repeat(2,1fr); } }

/* =========================================================
   Tour / video
   ========================================================= */
.tour-wrap{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-md);
}
.tour-wrap video{ width:100%; display:block; background:#000; aspect-ratio:848/480; }
.tour-caption{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  margin-top:1.1rem;
}
.tour-tags{ display:flex; gap:.5rem; flex-wrap:wrap; }
.tour-tag{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.04em;
  border:1px solid var(--line); border-radius:999px; padding:.3rem .7rem;
  color:var(--ink-soft);
}

.gallery-strip{
  display:grid; grid-template-columns:repeat(4,1fr); gap:.9rem;
  margin-top:1.4rem;
}
.gallery-strip figure{
  margin:0; border-radius:var(--radius-sm); overflow:hidden; aspect-ratio:4/3;
  position:relative; cursor:pointer;
}
.gallery-strip img{ width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.gallery-strip figure:hover img{ transform:scale(1.06); }
.gallery-strip figcaption{
  position:absolute; left:0; right:0; bottom:0;
  background:linear-gradient(to top, rgba(0,0,0,.65), transparent);
  color:#fff; font-size:.72rem; padding:1.2rem .6rem .5rem;
}
@media (max-width:880px){ .gallery-strip{ grid-template-columns:repeat(2,1fr); } }

/* Lightbox */
.lightbox{
  position:fixed; inset:0; background:rgba(15,18,24,.92); z-index:300;
  display:none; align-items:center; justify-content:center; padding:2rem;
}
.lightbox.open{ display:flex; }
.lightbox img{ max-width:90vw; max-height:85vh; border-radius:var(--radius-sm); }
.lightbox-close{
  position:absolute; top:1.4rem; right:1.4rem;
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.25);
  color:#fff; display:flex; align-items:center; justify-content:center;
}

/* =========================================================
   Doctors
   ========================================================= */
.doc-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.3rem;
}
.doc-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-md);
  overflow:hidden; transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.doc-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.doc-photo{
  aspect-ratio:1/1; background:var(--cream-deep);
  display:flex; align-items:center; justify-content:center; color:var(--red-deep);
  position:relative; overflow:hidden;
}
.doc-photo svg{ width:46%; height:46%; opacity:.5; }
.doc-photo img{ width:100%; height:100%; object-fit:cover; }
.doc-photo .ring-deco{
  position:absolute; inset:0; border:3px dashed var(--line); border-radius:50%;
  margin:14%;
}
.doc-info{ padding:1.1rem 1.2rem 1.3rem; }
.doc-info h3{ font-family:var(--font-display); font-size:1.05rem; font-weight:600; }
.doc-info .doc-role{
  font-family:var(--font-mono); font-size:.72rem; color:var(--red-deep);
  text-transform:uppercase; letter-spacing:.04em; margin-top:.3rem; display:block;
}
@media (max-width:980px){ .doc-grid{ grid-template-columns:repeat(2,1fr); } }

/* Leadership cards — larger, with bio text */
.leader-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1.6rem;
}
.leader-card{
  display:flex; gap:1.4rem;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-md);
  padding:1.4rem; transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.leader-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.leader-photo{
  flex-shrink:0; width:128px; height:148px; border-radius:var(--radius-sm);
  overflow:hidden; background:var(--cream-deep);
}
.leader-photo img{ width:100%; height:100%; object-fit:cover; }
.leader-info h3{ font-family:var(--font-display); font-size:1.15rem; font-weight:600; }
.leader-info .doc-role{
  font-family:var(--font-mono); font-size:.72rem; color:var(--red-deep);
  text-transform:uppercase; letter-spacing:.04em; margin-top:.3rem; display:block;
}
.leader-info p{ font-size:.84rem; color:var(--ink-soft); margin-top:.6rem; line-height:1.55; }
@media (max-width:780px){
  .leader-grid{ grid-template-columns:1fr; }
  .leader-card{ flex-direction:column; }
  .leader-photo{ width:100%; height:220px; }
}

/* =========================================================
   Tips (Consejos)
   ========================================================= */
.tips-rail{
  display:flex; gap:1rem; overflow-x:auto; padding-bottom:.5rem;
  scroll-snap-type:x mandatory;
  margin-top:1rem;
}
.tip-card{
  flex:0 0 230px; scroll-snap-align:start;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-md);
  padding:1.4rem 1.2rem;
}
.tip-card svg{ width:30px; height:30px; color:var(--teal); margin-bottom:.8rem; }
.tip-card h4{ font-family:var(--font-display); font-size:1.05rem; margin-bottom:.4rem; }
.tip-card p{ font-size:.85rem; color:var(--ink-soft); }

/* =========================================================
   Verse / quote band
   ========================================================= */
.verse-band{
  position:relative;
  text-align:center;
  padding-block:clamp(3rem,7vw,5rem);
}
.verse-band .quote-mark{
  font-family:var(--font-display); font-size:6rem; color:var(--red-tint);
  line-height:0; display:block; margin-bottom:-1rem;
}
.verse-band p.verse{
  font-family:var(--font-display); font-style:italic; font-weight:500;
  font-size:var(--step-2); max-width:720px; margin-inline:auto; color:var(--ink);
}
.verse-band .verse-ref{
  display:block; margin-top:1rem; font-family:var(--font-mono);
  font-size:.8rem; color:var(--red-deep); letter-spacing:.05em;
}
.verse-band .verse-sub{
  margin-top:2rem; font-size:var(--step--1); color:var(--ink-soft); max-width:560px; margin-inline:auto;
}

/* =========================================================
   About (Quienes somos / Vision)
   ========================================================= */
.about-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start;
}
.about-block{ display:flex; gap:1.1rem; }
.about-num{
  font-family:var(--font-display); font-size:2.4rem; color:var(--red-tint); font-weight:700;
  line-height:1;
}
.about-block h3{ font-family:var(--font-display); font-size:var(--step-2); margin-bottom:.6rem; }
.about-block p{ color:var(--ink-soft); }
@media (max-width:880px){ .about-grid{ grid-template-columns:1fr; gap:2.4rem; } }

.about-photo-grid{
  position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md);
}
.about-photo{ aspect-ratio:16/7; }
.about-photo img{ width:100%; height:100%; object-fit:cover; }
.about-photo-caption{
  position:absolute; left:0; bottom:0; right:0;
  background:linear-gradient(to top, rgba(15,18,24,.82), transparent);
  color:#fff; padding:1.6rem clamp(1.2rem,3vw,2rem) 1.2rem;
  display:flex; align-items:center; gap:1rem;
}
.about-year{
  font-family:var(--font-display); font-size:2rem; font-weight:700; color:var(--gold);
  flex-shrink:0; line-height:1;
}
.about-photo-caption span:last-child{ font-size:.86rem; max-width:48ch; }
@media (max-width:620px){
  .about-photo{ aspect-ratio:4/5; }
  .about-photo-caption{ flex-direction:column; align-items:flex-start; gap:.3rem; }
}

/* =========================================================
   Map / location
   ========================================================= */
.loc-grid{
  display:grid; grid-template-columns:0.85fr 1.15fr; gap:0;
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md);
}
.loc-info{
  background:var(--ink); color:var(--cream);
  padding:clamp(2rem,4vw,3rem);
  display:flex; flex-direction:column; gap:1.5rem; justify-content:center;
}
.loc-info h3{ font-family:var(--font-display); font-size:var(--step-2); color:#fff; }
.loc-row{ display:flex; gap:.9rem; align-items:flex-start; }
.loc-row svg{ width:20px; height:20px; color:var(--gold); flex-shrink:0; margin-top:.2rem; }
.loc-row strong{ display:block; font-size:var(--step--1); margin-bottom:.15rem; }
.loc-row span, .loc-row a{ font-size:.85rem; color:#C9CFD8; }
.loc-map{ min-height:380px; position:relative; }
.loc-map iframe{ width:100%; height:100%; border:0; position:absolute; inset:0; }
@media (max-width:880px){ .loc-grid{ grid-template-columns:1fr; } .loc-map{ min-height:300px; } }

.parking-block{
  margin-top:clamp(2.6rem, 6vw, 4rem);
  padding-top:clamp(2.6rem, 6vw, 4rem);
  border-top:1px solid var(--line);
}
.parking-title{
  font-family:var(--font-display);
  font-size:var(--step-2);
  font-weight:600;
  color:var(--ink);
}
.parking-lede{
  margin-top:.6rem;
  max-width:60ch;
  color:var(--ink-soft);
  font-size:var(--step-0);
}
.parking-strip{
  grid-template-columns:repeat(4,1fr);
  margin-top:1.6rem;
}
@media (max-width:880px){ .parking-strip{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .parking-strip{ grid-template-columns:1fr; } }

/* =========================================================
   Contact / form
   ========================================================= */
.contact-grid{
  display:grid; grid-template-columns:1fr 1.15fr; gap:clamp(2rem,5vw,4rem);
}
.contact-form{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.4rem); box-shadow:var(--shadow-sm);
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field{ margin-bottom:1.1rem; }
.field label{
  display:block; font-size:.78rem; font-weight:600; margin-bottom:.4rem; color:var(--ink-soft);
}
.field input, .field select, .field textarea{
  width:100%; padding:.75rem .9rem; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  font-family:inherit; font-size:.92rem; background:var(--cream); color:var(--ink);
  transition:border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:var(--red); outline:none;
}
.field textarea{ resize:vertical; min-height:100px; }
.form-note{ font-size:.78rem; color:var(--ink-soft); margin-top:.8rem; }
.form-success{
  display:none; background:#EAF4EE; border:1px solid #BEDFC9; color:#1E5C38;
  border-radius:var(--radius-sm); padding:1rem 1.1rem; font-size:.88rem; margin-top:1rem;
}
.form-success.show{ display:block; }

.contact-side{ display:flex; flex-direction:column; gap:1.3rem; }
.contact-card{
  background:var(--cream-deep); border-radius:var(--radius-md); padding:1.5rem 1.6rem;
  display:flex; gap:1rem; align-items:flex-start;
}
.contact-card svg{ width:24px; height:24px; color:var(--red); flex-shrink:0; margin-top:.15rem; }
.contact-card h4{ font-family:var(--font-display); font-size:1.05rem; margin-bottom:.25rem; }
.contact-card p, .contact-card a{ font-size:.86rem; color:var(--ink-soft); display:block; }
.contact-card a:hover{ color:var(--red-deep); }

@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; } .form-row{ grid-template-columns:1fr; } }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  background:var(--ink); color:#AFB7C2; padding-block:clamp(2.5rem,5vw,3.5rem) 1.6rem;
}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2.5rem;
}
.footer-brand{ display:flex; align-items:center; gap:.7rem; margin-bottom:1rem; }
.footer-brand img{ height:44px; width:auto; }
.footer-brand-text{ display:flex; flex-direction:column; gap:.15rem; }
.footer-brand-text strong{ color:#fff; font-family:var(--font-display); font-size:1rem; line-height:1.2; }
.footer-brand-text span{ color:#9CA6B3; font-size:.74rem; letter-spacing:.03em; }
.site-footer h5{
  color:#fff; font-size:.8rem; letter-spacing:.04em; text-transform:uppercase;
  margin-bottom:1rem; font-family:var(--font-mono);
}
.site-footer ul li{ margin-bottom:.6rem; font-size:.86rem; }
.site-footer a:hover{ color:#fff; }
.footer-bottom{
  margin-top:2.5rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.1);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; font-size:.78rem;
}
@media (max-width:880px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:2rem; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }

/* =========================================================
   Sticky CTA bar (mobile)
   ========================================================= */
.sticky-cta{
  position:fixed; bottom:0; left:0; right:0; z-index:90;
  background:var(--white); border-top:1px solid var(--line);
  padding:.7rem var(--gutter); display:none;
  box-shadow:0 -8px 24px rgba(0,0,0,.08);
  gap:.7rem;
}
.sticky-cta a{ flex:1; text-align:center; }
@media (max-width:640px){ .sticky-cta{ display:flex; } body{ padding-bottom:70px; } }

/* =========================================================
   Reveal-on-scroll
   ========================================================= */
[data-reveal]{
  opacity:0; transform:translateY(18px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
[data-reveal].in{ opacity:1; transform:translateY(0); }

/* Lang visibility */
[data-lang]{ display:none; }
[data-lang].lang-active{ display:revert; }
[data-lang].lang-active.flex-restore{ display:flex; }

/* Skip link */
.skip-link{
  position:absolute; left:-999px; top:0; background:var(--ink); color:#fff;
  padding:.6rem 1rem; z-index:1000;
}
.skip-link:focus{ left:1rem; top:1rem; }

/* Visually hidden (used for the Netlify Forms honeypot field) */
.visually-hidden{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
