@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Manrope:wght@300;400;500;600&family=Space+Mono:ital,wght@0,400;0,700;1,400&display=swap');

:root {
  --color-surface: #FAF8F3;
  --color-surface-alt: #F0EDE5;
  --color-surface-dark: #F0EDE5;
  --color-surface-laws: #F0EDE5;
  --color-primary: #7a5c5a;
  --color-primary-dark: #5c4240;
  --color-primary-light: #d4c4c3;
  --color-secondary: #B58A3D;
  --color-secondary-light: #E8D9B8;
  --color-accent: #7a5c5a;
  --color-on-surface: #2e221f;
  --color-on-surface-muted: #6E5A5A;
  --color-on-dark: #FAF8F3;
  --color-border: #D8D2C2;
  --color-border-dark: #C4BCA8;
  --font-serif: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --font-family: 'Manrope', 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'Space Mono', 'Courier New', monospace;
  --font-xs: clamp(0.7rem, 0.8vw, 0.8rem);
  --font-sm: clamp(0.8rem, 0.9vw, 0.9rem);
  --font-base: clamp(0.95rem, 1vw, 1.05rem);
  --font-md: clamp(1.05rem, 1.2vw, 1.15rem);
  --font-lg: clamp(1.2rem, 1.5vw, 1.4rem);
  --font-xl: clamp(1.5rem, 2vw, 2rem);
  --font-2xl: clamp(2rem, 3vw, 3rem);
  --font-3xl: clamp(2.5rem, 4vw, 4rem);
  --font-4xl: clamp(3.5rem, 5.5vw, 5.5rem);
  --font-5xl: clamp(4.5rem, 7vw, 7rem);
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem; --space-5: 1.25rem; --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem; --space-16: 4rem; --space-20: 5rem; --space-24: 6rem;
  --ease-luxury: cubic-bezier(0.25, 0.1, 0.25, 1.0);
  --ease-editorial: cubic-bezier(0.22, 1, 0.36, 1);
  --transition-base: all 0.6s var(--ease-luxury);
  --transition-slow: all 1.2s var(--ease-editorial);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body {
  font-family: var(--font-family);
  background: var(--color-surface);
  color: var(--color-on-surface);
  font-size: var(--font-base);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
::selection { background: var(--color-primary-light); color: var(--color-on-surface); }
img { max-width: 100%; height: auto; display: block; }

/* Typography */
h1, h2, h3, h4, .display { font-family: var(--font-serif); font-weight: 300; line-height: 1.1; letter-spacing: -0.02em; }
h1 { font-size: var(--font-4xl); }
h2 { font-size: var(--font-3xl); }
h3 { font-size: var(--font-xl); }
.display { font-size: var(--font-4xl); }
.display em { font-style: italic; color: var(--color-primary); }
.display em.text-lavender { color: #A294D9; }
.display em.text-rose { color: #c98fa6; }
.lede { font-size: var(--font-lg); color: var(--color-on-surface-muted); line-height: 1.6; }
.mono { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.18em; font-size: var(--font-xs); }
.eyebrow { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.2em; font-size: var(--font-xs); color: var(--color-accent); margin-bottom: var(--space-4); }
.editorial-prose p { margin-bottom: var(--space-6); color: var(--color-on-surface-muted); }
.split-text .display { margin-bottom: var(--space-10); }
.split-text.scroll-reveal {
  transition-duration: 1.2s;
  transition-timing-function: var(--ease-editorial);
}

/* Layout */
.container { width: 92%; max-width: 1200px; margin-left: auto; margin-right: auto; }
.container--narrow { max-width: 760px; }
.container--wide { max-width: 1320px; }
.text-center { text-align: center; }
.text-lavender { color: #A294D9; }
.eyebrow.text-lavender { color: #A294D9; }
.text-rose { color: #c98fa6; }

/* Scroll reveal */
.scroll-reveal { opacity: 0; transform: translateY(30px); transition: opacity 1s var(--ease-editorial), transform 1s var(--ease-editorial); }
.scroll-reveal.animated { opacity: 1; transform: translateY(0); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-3); justify-content: center;
  font-family: var(--font-family); font-size: var(--font-xs); text-transform: uppercase; letter-spacing: 0.15em; font-weight: 500;
  padding: var(--space-4) var(--space-8); border: 1px solid var(--color-on-surface); background: transparent; color: var(--color-on-surface);
  cursor: pointer; text-decoration: none; transition: var(--transition-base);
}
.btn:hover { background: var(--color-on-surface); color: var(--color-on-dark); }
.btn-primary { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.btn-primary:hover { background: var(--color-primary-dark); border-color: var(--color-primary-dark); color: #fff; }
.btn-lavender { background: #A294D9; border-color: #A294D9; color: #fff; }
.btn-lavender:hover { background: #8B7BC6; border-color: #8B7BC6; color: #fff; }
.btn-rose { background: #c98fa6; border-color: #c98fa6; color: #fff; }
.btn-rose:hover { background: #8B7BC6; border-color: #8B7BC6; color: #fff; }
[data-vb-id="hero-viso"] .btn-rose:hover { background: #CFC8D9; border-color: #CFC8D9; color: var(--color-on-surface); }
.btn-outline-rose { background: transparent; border-color: #c98fa6; color: #c98fa6; }
.btn-outline-rose:hover { background: #c98fa6; color: #fff; }
[data-vb-id="cta-viso"] .btn-outline-rose:hover { background: #c98fa6; border-color: #c98fa6; color: #fff; }
.btn-outline-dark { background: transparent; border-color: var(--color-primary-dark); color: var(--color-primary-dark); }
.btn-outline-dark:hover { background: #c98fa6; border-color: #c98fa6; color: #fff; }
.btn-outline-lavender { background: transparent; border-color: #A294D9; color: #A294D9; }
.btn-outline-lavender:hover { background: #A294D9; color: #fff; }
.btn-outline-primary { background: transparent; border-color: var(--color-primary); color: var(--color-primary); }
.btn-outline-primary:hover { background: var(--color-primary); color: #fff; }
.btn-hero-dark { background: transparent; border-color: #3e3a39; color: #3e3a39; }
.btn-hero-dark:hover { background: #3e3a39; color: #fff; }
.btn-white { border-color: var(--color-on-dark); color: var(--color-on-dark); }
.btn-white:hover { background: var(--color-on-dark); color: var(--color-on-surface); }
.btn-sm { padding: var(--space-3) var(--space-6); font-size: calc(var(--font-xs) * 0.9); }

/* Navigation */
.nav { position: fixed; inset: 0 0 auto 0; z-index: 100; background: rgba(248,246,244,0); border-bottom: 1px solid transparent; transition: var(--transition-base); color: var(--color-on-surface); }
.nav.scrolled { background: rgba(248,246,244,0.92); backdrop-filter: blur(12px); border-bottom-color: var(--color-border); color: var(--color-on-surface); }
.nav--transparent { color: var(--color-on-dark); }
.nav--transparent.scrolled { color: var(--color-on-surface); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 80px; }
.nav-logo { display: inline-flex; align-items: center; gap: 0; text-decoration: none; color: currentColor; }
.nav-logo-img { height: 48px; width: auto; display: block; object-fit: contain; background: transparent; opacity: 1; max-width: 200px; transform: translateY(0); margin-right: var(--space-3); transition: all 0.5s var(--ease-luxury); }
.nav-logo-text { font-family: var(--font-serif); font-size: var(--font-lg); font-weight: 400; letter-spacing: 0.02em; color: currentColor; line-height: 1; }
.nav-toggle { display: none; flex-direction: column; gap: 6px; background: none; border: none; cursor: pointer; padding: var(--space-2); }
.nav-toggle span { display: block; width: 24px; height: 1px; background: currentColor; transition: var(--transition-base); }
.nav-links { display: flex; gap: var(--space-10); list-style: none; padding: 0; }
.nav-links a { font-family: var(--font-family); font-size: var(--font-xs); text-transform: uppercase; letter-spacing: 0.15em; color: currentColor; text-decoration: none; position: relative; padding: var(--space-2) 0; }
.nav-links a::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 1px; background: var(--color-primary-dark); transition: width 0.5s var(--ease-luxury); }
.nav-links a:hover::after { width: 100%; }

@media (max-width: 767px) {
  .nav-toggle { display: flex; }
  .nav-links-wrapper { display: none; position: absolute; top: 80px; left: 0; right: 0; background: var(--color-surface); border-bottom: 1px solid var(--color-border); padding: var(--space-8); }
  .nav-links-wrapper.is-open { display: block; }
  .nav-links-wrapper.is-open .nav-links a { color: var(--color-on-surface); }
  .nav-links { flex-direction: column; gap: var(--space-6); }
}

/* Hero */
.hero { position: relative; display: flex; align-items: center; justify-content: center; text-align: center; min-height: 100vh; padding-top: 80px; overflow: hidden; }
.hero--sm { min-height: 60vh; }
.hero--about { min-height: 80vh; padding-top: var(--space-24); padding-bottom: var(--space-16); }
.hero--about .display { margin-bottom: var(--space-10); }
.hero--about .hero-lede { color: var(--color-on-surface-muted); }
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-bg { position: absolute; inset: -10% 0 -10% 0; overflow: hidden; }
.hero-bg img { width: 100%; height: 120%; object-fit: cover; opacity: 0.85; filter: saturate(0.8); }
.hero-overlay { position: absolute; inset: 0; background: rgba(62,58,57,0.30); }
.hero-content { position: relative; z-index: 2; max-width: 900px; padding: var(--space-8); }
.hero-content .display { color: var(--color-on-dark); margin-bottom: var(--space-6); }
.hero-lede { color: rgba(248,246,244,0.85); font-size: var(--font-md); max-width: 600px; margin: 0 auto var(--space-8); }
.hero--sm .hero-content .display { color: var(--color-on-surface); }
.hero--sm .hero-lede { color: var(--color-on-surface-muted); }

/* Sections */
.section { padding: var(--space-20) 0; position: relative; overflow: hidden; }
.section--sm { padding: var(--space-16) 0; }
.section--lg { padding: var(--space-24) 0; }
.section--alt { background: var(--color-surface-alt); }
.section--dark { background: var(--color-on-surface); color: var(--color-on-dark); }
.section--primary { background: var(--color-primary-light); }
.section-header { margin-bottom: var(--space-16); }

/* Split layout */
.split-layout { display: grid; grid-template-columns: 5fr 4fr; gap: var(--space-16); align-items: center; }
.split-visual img { width: 100%; height: 70vh; object-fit: cover; }

/* Layered visual composition */
.split-visual--layered { position: relative; overflow: hidden; }
.split-visual--layered .layer-base {
    width: 100%;
    height: 70vh;
    object-fit: cover;
    display: block;
    position: relative;
    z-index: 1;
}
.split-visual--layered .layer-overlay {
    position: absolute;
    width: 38%;
    height: auto;
    aspect-ratio: 1/1;
    object-fit: contain;
    bottom: var(--space-10);
    right: var(--space-6);
    z-index: 2;
    border: 3px solid var(--color-surface);
    box-shadow: 0 24px 60px rgba(0,0,0,0.10);
}
@media (min-width: 992px) {
    .split-visual--layered { overflow: visible; }
    .split-visual--layered .layer-overlay {
        bottom: var(--space-10);
        right: var(--space-6);
        width: 42%;
    }
}
@media (max-width: 991px) { .split-layout { grid-template-columns: 1fr; } .split-visual img { height: 50vh; } .split-visual--layered .layer-base { height: 50vh; } .split-visual--layered .layer-overlay { width: 35%; bottom: var(--space-8); right: var(--space-4); } }

/* Editorial quote */
.editorial-quote { font-family: var(--font-serif); font-size: var(--font-3xl); font-style: italic; font-weight: 300; line-height: 1.3; color: var(--color-on-surface-muted); }
.editorial-quote .text-lavender { color: #A294D9; }
.editorial-quote cite { display: block; margin-top: var(--space-8); font-family: var(--font-mono); font-size: var(--font-xs); text-transform: uppercase; letter-spacing: 0.15em; font-style: normal; color: var(--color-on-surface); }

/* Service grid */
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 767px) { .service-grid { grid-template-columns: 1fr; } }
.service-card { position: relative; overflow: hidden; cursor: pointer; }
a.service-card { display: block; text-decoration: none; color: inherit; }
.service-card-img { width: 100%; aspect-ratio: 3/4; object-fit: cover; transition: transform 1.2s var(--ease-editorial); }
.service-card:hover .service-card-img { transform: scale(1.05); }
.service-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(62,58,57,0.5), transparent 60%); display: flex; flex-direction: column; justify-content: flex-end; padding: var(--space-8); }
.service-card-title { font-family: var(--font-serif); font-size: var(--font-2xl); font-weight: 300; color: var(--color-on-dark); margin-bottom: var(--space-2); }
.service-card-meta { font-family: var(--font-mono); font-size: var(--font-xs); text-transform: uppercase; letter-spacing: 0.12em; color: rgba(250,248,246,0.8); }

/* Treatments list */
.treatment-list { display: flex; flex-direction: column; gap: var(--space-20); }
.treatment-item { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-16); align-items: center; }
.treatment-item--reverse { direction: rtl; }
.treatment-item--reverse > * { direction: ltr; }
.treatment-visual img { width: 100%; height: 60vh; object-fit: cover; }
.treatment-visual--square img { aspect-ratio: 1 / 1; height: auto; }
.treatment-visual--full {
  height: 80vh;
  min-height: 600px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.treatment-visual--full img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.treatment-text h2 { margin-bottom: var(--space-4); }
.treatment-text .lede { margin-bottom: var(--space-8); }
.treatment-specs { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: var(--space-4); }
.treatment-specs li { border-bottom: 1px solid var(--color-border); padding-bottom: var(--space-2); color: var(--color-on-surface-muted); }
@media (max-width: 991px) { .treatment-item { grid-template-columns: 1fr; } .treatment-visual img { height: 40vh; } .treatment-visual--square img { height: auto; } .treatment-visual--full { height: auto; min-height: auto; } .treatment-visual--full img { height: auto; max-height: 70vh; } }

/* Values */
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-12); }
.values-grid--2 { grid-template-columns: repeat(2, 1fr); }
.value-item { text-align: center; transition: transform 0.6s var(--ease-luxury), box-shadow 0.6s var(--ease-luxury); }
.value-item:hover { transform: translateY(-6px); box-shadow: 0 20px 48px rgba(46,34,31,0.08); transition-delay: .1s; }
.value-num { display: block; margin-bottom: var(--space-4); color: var(--color-primary-dark); }
.value-item h3 { margin-bottom: var(--space-3); font-size: var(--font-xl); }
.value-item p { color: var(--color-on-surface-muted); font-size: var(--font-sm); }
@media (max-width: 767px) { .values-grid { grid-template-columns: 1fr; } .values-grid--2 { grid-template-columns: 1fr; } }

/* Protocol cards */
.protocols-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.protocol-card { background: var(--color-surface); border: 1px solid var(--color-border); padding: var(--space-8); text-align: left; transition: transform 0.6s var(--ease-luxury), box-shadow 0.6s var(--ease-luxury), border-color 0.4s ease; }
.protocol-card:hover { transform: translateY(-4px); box-shadow: 0 20px 48px rgba(46,34,31,0.07); border-color: var(--color-border-dark); }
.protocol-card h3 { margin-bottom: var(--space-4); }
.protocol-card p { color: var(--color-on-surface-muted); font-size: var(--font-sm); }
.protocol-table { width: 100%; border-collapse: collapse; margin-top: var(--space-6); font-size: var(--font-sm); }
.protocol-table td { padding: var(--space-2) 0; border-bottom: 1px solid var(--color-border); vertical-align: top; line-height: 1.5; }
.protocol-table td:first-child { width: 38%; color: var(--color-on-surface-muted); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.1em; font-size: calc(var(--font-xs) * 0.9); padding-right: var(--space-4); }
.protocol-table tr:last-child td { border-bottom: none; }
@media (max-width: 767px) { .protocols-grid { grid-template-columns: 1fr; } }

/* Protocol cards — distinct surface/border from section background */
.protocols-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.protocol-card { background: var(--color-surface); border: 1px solid var(--color-border); padding: var(--space-8); text-align: left; transition: transform 0.6s var(--ease-luxury), box-shadow 0.6s var(--ease-luxury), border-color 0.4s ease; }
.protocol-card:hover { transform: translateY(-4px); box-shadow: 0 20px 48px rgba(46,34,31,0.07); border-color: var(--color-border-dark); }
.protocol-card h3 { margin-bottom: var(--space-4); }
.protocol-card p { color: var(--color-on-surface-muted); font-size: var(--font-sm); }
.protocol-table { width: 100%; border-collapse: collapse; margin-top: var(--space-6); font-size: var(--font-sm); }
.protocol-table td { padding: var(--space-2) 0; border-bottom: 1px solid var(--color-border); vertical-align: top; line-height: 1.5; }
.protocol-table td:first-child { width: 38%; color: var(--color-on-surface-muted); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.1em; font-size: calc(var(--font-xs) * 0.9); padding-right: var(--space-4); }
.protocol-table tr:last-child td { border-bottom: none; }
@media (max-width: 767px) { .protocols-grid { grid-template-columns: 1fr; } }

/* Contact */
.contact-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-16); }
.contact-info .eyebrow { margin-bottom: var(--space-8); }
.contact-block { margin-bottom: var(--space-8); }
.contact-block .mono { margin-bottom: var(--space-2); color: var(--color-on-surface-muted); }
.contact-block a { color: var(--color-on-surface); text-underline-offset: 4px; }
.contact-form .form-group { margin-bottom: var(--space-8); }
.contact-form label { display: block; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.12em; font-size: var(--font-xs); color: var(--color-on-surface-muted); margin-bottom: var(--space-3); }
.contact-form input, .contact-form textarea {
  width: 100%; padding: var(--space-3) 0; border: none; border-bottom: 1px solid var(--color-border-dark);
  background: transparent; color: var(--color-on-surface); font-family: var(--font-family); font-size: var(--font-base); transition: border-color 0.4s ease; border-radius: 0;
}
.contact-form input:focus, .contact-form textarea:focus { outline: none; border-bottom-color: var(--color-primary-dark); }
.contact-form textarea { resize: vertical; min-height: 120px; }
.form-hp { display: none; }
.form-message { margin-top: var(--space-4); font-size: var(--font-sm); min-height: 1.5em; }
@media (max-width: 991px) { .contact-layout { grid-template-columns: 1fr; } }

/* Pill list */
.pill-list { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; }
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--font-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: var(--space-3) var(--space-5);
  border: 1px solid var(--color-border-dark);
  border-radius: 999px;
  color: var(--color-on-surface-muted);
  background: var(--color-surface);
}
.pill::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary);
  display: inline-block;
}

/* Footer */
.footer { background: var(--color-surface-alt); padding: var(--space-20) 0 var(--space-8); border-top: 1px solid var(--color-border); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-12); }
.footer-brand { font-family: var(--font-serif); font-size: var(--font-xl); margin-bottom: var(--space-3); }
.footer-tagline { font-family: var(--font-serif); font-size: var(--font-lg); font-style: italic; color: var(--color-on-surface-muted); }
.footer-col-title { margin-bottom: var(--space-6); color: var(--color-on-surface-muted); }
.footer-links { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.footer-links a { text-decoration: none; color: var(--color-on-surface); font-size: var(--font-sm); transition: color 0.3s; }
.footer-links a:hover { color: var(--color-primary-dark); }
.footer-contact-link { color: #A294D9; text-decoration: none; }
.footer-bottom { margin-top: var(--space-16); padding-top: var(--space-6); border-top: 1px solid var(--color-border); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-4); font-family: var(--font-mono); font-size: var(--font-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-on-surface-muted); }
@media (max-width: 991px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 767px) { .footer-grid { grid-template-columns: 1fr; } }

/* Cookie banner */
.cookie-banner { position: fixed; bottom: 0; left: 0; right: 0; background: var(--color-on-surface); color: var(--color-on-dark); padding: var(--space-6); display: flex; justify-content: space-between; align-items: center; gap: var(--space-6); z-index: 200; flex-wrap: wrap; }
.cookie-text { font-size: var(--font-sm); margin: 0; }

/* Legal */
.legal-page { padding: var(--space-24) 0 var(--space-16); }
.legal-page h1 { margin-bottom: var(--space-12); }
.prose h2 { font-family: var(--font-serif); font-size: var(--font-xl); margin-top: var(--space-10); margin-bottom: var(--space-4); }
.prose p { margin-bottom: var(--space-4); color: var(--color-on-surface-muted); }

/* Testimonials */
.testimonials-section { background: var(--color-surface); }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); }
.testimonial-card { background: var(--color-surface); padding: var(--space-10); display: flex; flex-direction: column; justify-content: space-between; border: 1px solid #A294D9; transition: transform 0.6s var(--ease-luxury), box-shadow 0.6s var(--ease-luxury); }
.testimonial-card:hover { transform: translateY(-4px); box-shadow: 0 24px 48px rgba(46,34,31,0.06); }
.testimonial-quote { font-family: var(--font-serif); font-size: var(--font-lg); font-style: italic; line-height: 1.55; color: var(--color-on-surface-muted); margin-bottom: var(--space-8); }
.testimonial-footer { border-top: 1px solid var(--color-border); padding-top: var(--space-4); margin-top: auto; }
.testimonial-author { display: block; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.12em; font-size: var(--font-xs); color: var(--color-on-surface); margin-bottom: var(--space-1); }
.testimonial-role { font-size: var(--font-sm); color: var(--color-on-surface-muted); }
@media (max-width: 991px) { .testimonials-grid { grid-template-columns: 1fr; } }

/* Skip link */
.skip-link { position: absolute; top: -40px; left: 0; background: var(--color-on-surface); color: var(--color-on-dark); padding: var(--space-2) var(--space-4); z-index: 300; text-decoration: none; font-size: var(--font-xs); }
.skip-link:focus { top: 0; }

/* Gallery */
.gallery-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.gallery-item { position: relative; overflow: hidden; background: var(--color-surface-alt); }
.gallery-item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.gallery-caption { padding: var(--space-4) var(--space-5); font-size: var(--font-sm); color: var(--color-on-surface-muted); border-top: 1px solid var(--color-border); }
.gallery-caption .mono { display: block; margin-bottom: var(--space-1); color: var(--color-on-surface); }
@media (max-width: 767px) { .gallery-grid { grid-template-columns: 1fr; } }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .scroll-reveal { transition: none; opacity: 1 !important; transform: none !important; }
  .service-card-img { transition: none; }
}
