/* ============================================================
   EYETIME V2 — Shared stylesheet
   Marble + rose gold · Photo-enhanced editorial
   ============================================================ */

/* ============ BASE ============ */
:root{
  --ivory:#FAF7F2;
  --marble:#F4EFE8;
  --marble-deep:#EDE5DA;
  --rose:#B4896D;
  --rose-dark:#8F6A52;
  --rose-light:#D4B59E;
  --rose-pale:#F0E1D4;
  --ink:#2B2320;
  --ink-soft:#4A3F39;
  --mute:#8A7A70;
  --line:#E3D7C9;
  --serif:'Cormorant Garamond', serif;
  --sans:'Jost', sans-serif;
  --deco:'Italiana', serif;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--ivory);
  font-size:16px;
  line-height:1.65;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(180,137,109,.04), transparent 50%),
    radial-gradient(ellipse at 80% 60%, rgba(180,137,109,.03), transparent 50%),
    radial-gradient(ellipse at 50% 90%, rgba(212,181,158,.04), transparent 50%);
  pointer-events:none;
  z-index:-1;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

.container{max-width:1280px;margin:0 auto;padding:0 32px}
@media (max-width:640px){.container{padding:0 20px}}

/* ============ TYPOGRAPHY ============ */
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:1.15}
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--rose);
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--rose);display:inline-block}

.section-title{
  font-size:clamp(2.2rem,4.5vw,3.8rem);
  font-weight:400;
  letter-spacing:-.015em;
  margin-top:18px;
}
.section-title em{font-style:italic;color:var(--rose-dark);font-family:var(--serif)}
.section-intro{
  font-size:1.05rem;
  color:var(--ink-soft);
  max-width:620px;
  margin-top:22px;
  line-height:1.75;
  font-weight:300;
}

/* ============ TOP BAR ============ */
.topbar{
  background:var(--ink);
  color:var(--ivory);
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:10px 0;
  font-weight:300;
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
  position:relative;
}
.topbar-text{flex:1;text-align:center}
.topbar-text span{color:var(--rose-light);margin:0 12px}
.topbar-social{
  display:flex;
  gap:10px;
  align-items:center;
}
.topbar-social a{
  width:26px;height:26px;
  display:grid;place-items:center;
  color:var(--rose-light);
  transition:color .3s var(--ease), transform .3s var(--ease);
}
.topbar-social a:hover{color:var(--ivory);transform:translateY(-1px)}
.topbar-social svg{width:14px;height:14px}
@media (max-width:700px){
  .topbar-inner{flex-direction:column;gap:8px}
  .topbar-text{font-size:10.5px}
}

/* Footer social icons under about text */
.footer-social{
  display:flex;
  gap:10px;
  margin-top:22px;
}
.footer-social a{
  width:40px;height:40px;
  display:grid;place-items:center;
  border:1px solid rgba(250,247,242,.15);
  color:rgba(250,247,242,.7);
  transition:all .4s var(--ease);
}
.footer-social a:hover{
  background:var(--rose);
  border-color:var(--rose);
  color:var(--ivory);
  transform:translateY(-3px);
}
.footer-social svg{width:16px;height:16px}

/* ============ NAV ============ */
.nav{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(250,247,242,.9);
  backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease), background .4s var(--ease);
}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(250,247,242,.97)}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 0;
}
.logo{
  display:flex;
  align-items:center;
  gap:14px;
  font-family:var(--deco);
  font-size:1.6rem;
  letter-spacing:.28em;
  color:var(--ink);
}
.logo-mark{width:44px;height:44px;display:grid;place-items:center}
.logo-mark svg{width:100%;height:100%}
.logo-text{line-height:1}
.logo-sub{
  display:block;
  font-family:var(--sans);
  font-size:9px;
  letter-spacing:.28em;
  color:var(--mute);
  margin-top:4px;
  font-weight:400;
  text-transform:uppercase;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:10px;
  list-style:none;
}
.nav-links a{
  font-size:12.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:400;
  padding:8px 12px;
  border-radius:8px;
  transition:background-color .3s var(--ease), color .3s var(--ease);
}
.nav-links a:hover{
  background:var(--rose-pale);
  color:var(--rose-dark);
}
.nav-links a.active{
  background:var(--rose-pale);
  color:var(--rose-dark);
  font-weight:500;
}

.nav-cta{
  padding:12px 22px;
  border:1px solid var(--rose);
  border-radius:12px;
  color:var(--rose-dark);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  white-space:nowrap;
  transition:all .4s var(--ease);
}
.nav-cta:hover{background:var(--rose);color:var(--ivory)}

.nav-toggle{
  display:none;
  width:32px;height:24px;
  flex-direction:column;justify-content:space-between;
}
.nav-toggle span{display:block;height:1px;background:var(--ink);transition:all .3s}

@media (max-width:1020px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav.open .nav-links{
    display:flex;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;gap:6px;
    background:var(--ivory);
    padding:22px 18px 28px;
    border-bottom:1px solid var(--line);
    box-shadow:0 20px 40px -20px rgba(80,60,45,.18);
  }
  .nav.open .nav-links a{
    padding:16px 22px;
    font-size:17px;
    font-weight:500;
    letter-spacing:.08em;
    text-align:center;
    border-radius:12px;
    border:none;
  }
  .nav.open .nav-links a:hover,
  .nav.open .nav-links a.active{
    background:var(--rose-pale);
  }
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:18px 34px;
  border-radius:12px;
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:500;
  transition:all .4s var(--ease);
  cursor:pointer;
}
.btn-primary{
  background:linear-gradient(120deg, var(--rose-dark), var(--rose));
  color:var(--ivory);
  box-shadow:0 10px 30px -10px rgba(143,106,82,.4);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 40px -10px rgba(143,106,82,.55);
}
.btn-ghost{border:1px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--ivory)}
.btn-light{border:1px solid var(--ivory);color:var(--ivory)}
.btn-light:hover{background:var(--ivory);color:var(--ink)}
.btn-arrow{display:inline-block;transition:transform .4s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(6px)}

/* ============ HERO (home) ============ */
.hero{
  position:relative;
  min-height:88vh;
  display:flex;
  align-items:center;
  padding:80px 0 60px;
  overflow:hidden;
  background:linear-gradient(180deg, transparent 0%, rgba(244,239,232,.6) 100%), var(--marble);
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 800px 600px at 80% 30%, rgba(240,225,212,.6), transparent 70%),
    radial-gradient(ellipse 600px 400px at 10% 80%, rgba(212,181,158,.25), transparent 70%);
  pointer-events:none;
}
.hero::after{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(115deg, transparent 48%, rgba(180,137,109,.08) 48.5%, transparent 49.3%),
    linear-gradient(75deg, transparent 62%, rgba(143,106,82,.06) 62.4%, transparent 63%);
  pointer-events:none;
}
.hero-inner{
  position:relative;
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:80px;
  align-items:center;
  z-index:2;
}
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:60px}
  .hero{min-height:auto;padding:60px 0}
}

.hero-text h1{
  font-size:clamp(2.8rem,6.2vw,5.6rem);
  font-weight:300;
  line-height:1.02;
  letter-spacing:-.025em;
  color:var(--ink);
}
.hero-text h1 em{
  font-style:italic;
  font-weight:400;
  background:linear-gradient(120deg, var(--rose) 0%, var(--rose-dark) 50%, var(--rose) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero-text .eyebrow{margin-bottom:28px}
.hero-lead{
  margin-top:32px;
  font-size:1.15rem;
  color:var(--ink-soft);
  max-width:520px;
  line-height:1.75;
  font-weight:300;
}
.hero-actions{margin-top:44px;display:flex;gap:18px;flex-wrap:wrap}

.hero-visual{
  position:relative;
  aspect-ratio:4/5;
  max-width:500px;
  justify-self:end;
  width:100%;
}
.hero-photo{
  position:absolute;inset:0;
  overflow:hidden;
  box-shadow:0 40px 80px -20px rgba(80,60,45,.3), 0 20px 40px -10px rgba(80,60,45,.15);
}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.9) sepia(.08);
}
.hero-photo::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(150deg, rgba(180,137,109,.1) 0%, transparent 40%, rgba(43,35,32,.1) 100%);
  pointer-events:none;
}
.hero-badge{
  position:absolute;
  bottom:-28px;left:-28px;
  background:var(--ivory);
  padding:22px 28px;
  border:1px solid var(--line);
  box-shadow:0 20px 40px -12px rgba(80,60,45,.15);
  z-index:3;
}
.hero-badge-label{
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--rose);margin-bottom:6px;
}
.hero-badge-value{font-family:var(--serif);font-size:1.3rem;color:var(--ink);line-height:1.2}
.hero-floating{
  position:absolute;
  top:40px;right:-20px;
  background:rgba(43,35,32,.95);
  color:var(--ivory);
  padding:18px 24px;
  backdrop-filter:blur(10px);
  z-index:3;
  max-width:220px;
}
.hero-floating-label{
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--rose-light);margin-bottom:6px;
}
.hero-floating-text{font-size:.95rem;line-height:1.4;font-weight:300}

/* ============ PAGE HERO (internal pages) ============ */
.page-hero{
  position:relative;
  padding:80px 0 90px;
  background:linear-gradient(180deg, var(--marble) 0%, var(--ivory) 100%);
  overflow:hidden;
}
.page-hero::before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(115deg, transparent 48%, rgba(180,137,109,.08) 48.5%, transparent 49.3%),
    linear-gradient(75deg, transparent 62%, rgba(143,106,82,.06) 62.4%, transparent 63%);
  pointer-events:none;
}
.page-hero-inner{
  position:relative;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:80px;
  align-items:end;
  z-index:2;
}
@media (max-width:900px){.page-hero-inner{grid-template-columns:1fr;gap:50px;align-items:start}}

.page-hero h1{
  font-size:clamp(2.5rem,5.5vw,4.8rem);
  font-weight:300;
  line-height:1.05;
  letter-spacing:-.025em;
  color:var(--ink);
  margin-top:24px;
}
.page-hero h1 em{font-style:italic;color:var(--rose-dark);font-weight:400}
.page-hero p{
  margin-top:28px;
  font-size:1.1rem;
  color:var(--ink-soft);
  max-width:540px;
  line-height:1.75;
}

.breadcrumb{
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--mute);
  margin-bottom:20px;
}
.breadcrumb a{color:var(--mute);transition:color .3s}
.breadcrumb a:hover{color:var(--rose-dark)}
.breadcrumb span{color:var(--rose);margin:0 12px}

.page-hero-image{
  aspect-ratio:4/5;
  max-width:400px;
  width:100%;
  justify-self:end;
  overflow:hidden;
  box-shadow:0 30px 60px -20px rgba(80,60,45,.25);
  position:relative;
}
.page-hero-image img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.9) sepia(.08);
}
.page-hero-image::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(150deg, rgba(180,137,109,.1) 0%, transparent 40%, rgba(43,35,32,.12) 100%);
}

/* ============ SECTION LAYOUT ============ */
section{padding:100px 0;position:relative}
@media (max-width:768px){section{padding:70px 0}}
.section-head{max-width:780px;margin-bottom:64px}
.section-head.center{margin:0 auto 64px;text-align:center}
.section-head.center .eyebrow{justify-content:center;display:inline-flex}

.divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:40px 0;
}
.divider-line{flex:1;max-width:80px;height:1px;background:var(--line)}
.divider-mark{width:8px;height:8px;border:1px solid var(--rose);transform:rotate(45deg)}

/* ============ FOCUS GRID ============ */
.focus-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
@media (max-width:900px){.focus-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.focus-grid{grid-template-columns:1fr}}

.focus-card{
  padding:50px 44px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  transition:background .5s var(--ease);
  position:relative;
  overflow:hidden;
  display:block;
  color:inherit;
}
.focus-card:hover{background:var(--marble)}
.focus-icon{
  width:56px;height:56px;
  display:grid;place-items:center;
  margin-bottom:28px;
  color:var(--rose);
  transition:transform .5s var(--ease);
}
.focus-card:hover .focus-icon{transform:translateY(-4px)}
.focus-icon svg{width:100%;height:100%}
.focus-num{
  position:absolute;
  top:28px;right:32px;
  font-family:var(--serif);
  font-style:italic;
  font-size:1rem;
  color:var(--rose);
  opacity:.6;
}
.focus-card h3{font-size:1.5rem;margin-bottom:14px;color:var(--ink)}
.focus-card p{font-size:.95rem;color:var(--ink-soft);line-height:1.7}
.focus-card-link{
  margin-top:22px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--rose-dark);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
  transition:gap .3s var(--ease);
}
.focus-card:hover .focus-card-link{gap:16px}

/* ============ SPLIT / IMAGE SECTIONS ============ */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:50px}}
.split-reverse{direction:rtl}
.split-reverse > *{direction:ltr}

.split-image{
  aspect-ratio:4/5;
  box-shadow:0 40px 80px -20px rgba(80,60,45,.2);
  overflow:hidden;
  position:relative;
}
.split-image img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.9) sepia(.08);
}
.split-image::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(150deg, rgba(180,137,109,.06) 0%, transparent 40%, rgba(43,35,32,.08) 100%);
}

/* ============ SERVICE LIST ============ */
.service-list{list-style:none;margin-top:36px}
.service-list li{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  padding:22px 0;
  border-bottom:1px solid var(--line);
  gap:24px;
}
.service-list li:first-child{border-top:1px solid var(--line)}
.service-name{
  font-family:var(--serif);
  font-size:1.2rem;
  color:var(--ink);
  font-weight:400;
}
.service-name em{color:var(--rose-dark);font-style:italic;margin-left:8px;font-size:.9em}
.service-dot{flex:1;border-bottom:1px dotted var(--line);margin:0 16px;height:1px;align-self:center}
.service-meta{
  font-size:.85rem;
  color:var(--mute);
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
}

/* ============ PROCEDURE CARDS ============ */
.proc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:20px;
}
@media (max-width:900px){.proc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.proc-grid{grid-template-columns:1fr}}

.proc-card{
  background:var(--ivory);
  padding:44px 36px;
  position:relative;
  overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  border:1px solid transparent;
}
.proc-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 60px -20px rgba(80,60,45,.2);
  border-color:var(--rose-pale);
}
.proc-card::after{
  content:"";
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, var(--rose) 0%, var(--rose-light) 100%);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .6s var(--ease);
}
.proc-card:hover::after{transform:scaleX(1)}
.proc-tag{
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--rose);margin-bottom:18px;
}
.proc-card h3{font-size:1.6rem;margin-bottom:14px}
.proc-card p{font-size:.93rem;color:var(--ink-soft);line-height:1.7;margin-bottom:24px}
.proc-more{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--rose-dark);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
  transition:gap .3s var(--ease);
}
.proc-card:hover .proc-more{gap:16px}

/* ============ DARK SECTION ============ */
.section-dark{
  background:var(--ink);
  color:var(--ivory);
  position:relative;
  overflow:hidden;
}
.section-dark::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 20% 30%, rgba(180,137,109,.18), transparent 70%),
    radial-gradient(ellipse 500px 350px at 85% 70%, rgba(143,106,82,.15), transparent 70%);
}
.section-dark .container{position:relative}
.section-dark .eyebrow{color:var(--rose-light)}
.section-dark .eyebrow::before{background:var(--rose-light)}
.section-dark .section-title,.section-dark h3{color:var(--ivory)}
.section-dark .section-title em{color:var(--rose-light)}
.section-dark .section-intro{color:rgba(250,247,242,.7)}

.aes-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:rgba(250,247,242,.12);
  margin-top:20px;
}
@media (max-width:900px){.aes-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.aes-grid{grid-template-columns:1fr}}
.aes-card{
  background:var(--ink);
  padding:44px 32px;
  transition:background .4s var(--ease);
  cursor:pointer;
}
.aes-card:hover{background:rgba(180,137,109,.12)}
.aes-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  color:var(--rose-light);
  margin-bottom:20px;
  display:block;
}
.aes-card h3{font-size:1.35rem;margin-bottom:12px;color:var(--ivory);font-weight:400}
.aes-card p{font-size:.88rem;color:rgba(250,247,242,.6);line-height:1.65}

/* ============ ABOUT DOCTOR ============ */
.about-grid{
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:100px;
  align-items:center;
}
@media (max-width:900px){.about-grid{grid-template-columns:1fr;gap:60px}}

.doctor-visual{position:relative;aspect-ratio:3/4}
.doctor-frame{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#E8DCCE,#C8B299);
  box-shadow:0 50px 100px -30px rgba(80,60,45,.3);
  overflow:hidden;
}
.doctor-frame::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(110deg, transparent 40%, rgba(255,255,255,.3) 42%, transparent 45%),
    radial-gradient(ellipse at 35% 25%, rgba(255,255,255,.35), transparent 60%);
}
.doctor-placeholder{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:12px;
  color:var(--ink-soft);
  text-align:center;padding:40px;
}
.doctor-placeholder svg{width:64px;height:64px;opacity:.4}
.doctor-placeholder small{
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--mute);max-width:220px;line-height:1.6;
}
.doctor-signature{
  position:absolute;
  bottom:-32px;right:-32px;
  background:var(--ivory);
  padding:28px 32px;
  border:1px solid var(--line);
  box-shadow:0 20px 40px -12px rgba(80,60,45,.15);
  max-width:280px;
}
.doctor-signature-name{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.6rem;
  color:var(--rose-dark);
  line-height:1.2;
}
.doctor-signature-title{
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--mute);margin-top:8px;
}
.about-text p{margin-top:22px;color:var(--ink-soft);line-height:1.8;font-size:1rem}
.credentials{
  margin-top:40px;padding-top:32px;
  border-top:1px solid var(--line);
  display:grid;grid-template-columns:repeat(2,1fr);gap:28px;
}
.cred-label{
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--rose);margin-bottom:6px;
}
.cred-value{font-family:var(--serif);font-size:1.1rem;color:var(--ink)}

/* ============ PRICE CARD ============ */
.price-card{
  background:var(--ivory);
  padding:60px;
  max-width:820px;
  margin:0 auto;
  border:1px solid var(--line);
  position:relative;
}
.price-card::before{
  content:"";
  position:absolute;top:-1px;left:-1px;right:-1px;height:3px;
  background:linear-gradient(90deg, transparent, var(--rose), transparent);
}
@media (max-width:640px){.price-card{padding:40px 28px}}
.price-group{margin-bottom:44px}
.price-group:last-child{margin-bottom:0}
.price-group h4{
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--rose);font-weight:500;font-family:var(--sans);
  padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:18px;
}
.price-note{
  background:var(--rose-pale);
  padding:18px 24px;
  margin-top:32px;
  border-left:2px solid var(--rose);
}
.price-note small{
  font-size:.85rem;color:var(--ink-soft);line-height:1.6;
  font-style:italic;font-family:var(--serif);
}

/* ============ TESTIMONIALS ============ */
.test-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  margin-top:20px;
}
@media (max-width:900px){.test-grid{grid-template-columns:1fr}}
.test-card{padding:44px 36px;background:var(--marble);position:relative}
.test-quote{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.1rem;
  line-height:1.6;
  color:var(--ink);
  margin-bottom:28px;
  padding-left:28px;
  border-left:2px solid var(--rose);
}
.test-stars{letter-spacing:.3em;color:var(--rose);font-size:.9rem;margin-bottom:14px}
.test-author{font-family:var(--sans);font-size:.88rem;color:var(--ink);font-weight:500}
.test-author-sub{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--mute);margin-top:4px;
}

/* ============ CONTACT ============ */
.contact-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  margin-top:20px;
}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.contact-info{
  background:var(--ivory);
  padding:56px 48px;
  border:1px solid var(--line);
}
@media (max-width:640px){.contact-info{padding:40px 28px}}
.contact-block{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--line)}
.contact-block:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.contact-label{
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--rose);margin-bottom:10px;font-weight:500;
  display:flex;align-items:center;gap:10px;
}
.contact-label svg{width:14px;height:14px}
.contact-value{font-family:var(--serif);font-size:1.3rem;color:var(--ink);font-weight:400}
.contact-value a:hover{color:var(--rose-dark)}
.contact-sub{font-size:.9rem;color:var(--ink-soft);margin-top:6px}
.social-links{display:flex;gap:12px;margin-top:8px}
.social-links a{
  width:44px;height:44px;display:grid;place-items:center;
  border:1px solid var(--line);color:var(--ink);
  transition:all .4s var(--ease);
}
.social-links a:hover{
  background:var(--rose);color:var(--ivory);
  border-color:var(--rose);transform:translateY(-3px);
}
.social-links svg{width:18px;height:18px}

.map-placeholder{
  aspect-ratio:4/5;
  background:linear-gradient(140deg,#E8E0D4,#CDBBA7);
  position:relative;
  overflow:hidden;
  box-shadow:0 30px 60px -20px rgba(80,60,45,.2);
}
.map-placeholder::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(45deg, transparent 0 40px, rgba(180,137,109,.06) 40px 41px),
    repeating-linear-gradient(-45deg, transparent 0 60px, rgba(143,106,82,.04) 60px 61px);
}
.map-pin{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-100%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
}
.map-pin-dot{
  width:18px;height:18px;
  background:var(--rose);border-radius:50%;
  border:3px solid var(--ivory);
  box-shadow:0 6px 20px -4px rgba(143,106,82,.5);
  position:relative;
}
.map-pin-dot::after{
  content:"";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:40px;height:40px;
  border:1px solid var(--rose);border-radius:50%;
  animation:pulse 2.5s ease-out infinite;
}
@keyframes pulse{
  0%{transform:translate(-50%,-50%) scale(1);opacity:1}
  100%{transform:translate(-50%,-50%) scale(2.5);opacity:0}
}
.map-pin-label{
  background:var(--ivory);padding:10px 18px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);box-shadow:0 6px 16px -4px rgba(80,60,45,.2);
}

/* ============ CTA STRIP ============ */
.cta-strip{
  background:var(--ink);
  color:var(--ivory);
  padding:80px 0;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-strip::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 800px 400px at 50% 100%, rgba(180,137,109,.25), transparent 70%);
}
.cta-strip .container{position:relative}
.cta-strip h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:300;margin-bottom:18px}
.cta-strip h2 em{font-style:italic;color:var(--rose-light)}
.cta-strip p{color:rgba(250,247,242,.7);margin-bottom:36px;font-size:1.05rem}

/* ============ FOOTER ============ */
footer{background:#1E1815;color:rgba(250,247,242,.7);padding:70px 0 30px}
.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:50px;
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-logo{
  font-family:var(--deco);
  font-size:1.6rem;
  letter-spacing:.28em;
  color:var(--ivory);
  margin-bottom:18px;
}
.footer-about{font-size:.9rem;line-height:1.7;max-width:320px}
.footer-col h5{
  font-family:var(--sans);
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--rose-light);margin-bottom:20px;font-weight:500;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:12px}
.footer-col a{font-size:.9rem;transition:color .3s}
.footer-col a:hover{color:var(--rose-light)}
.footer-bottom{
  padding-top:30px;
  border-top:1px solid rgba(250,247,242,.1);
  display:flex;justify-content:space-between;align-items:center;
  font-size:.8rem;color:rgba(250,247,242,.5);
  letter-spacing:.08em;flex-wrap:wrap;gap:16px;
}
.footer-bottom em{color:var(--rose-light);font-style:italic;font-family:var(--serif)}

/* ============ SECTION BACKGROUNDS ============ */
.bg-ivory{background:var(--ivory)}
.bg-marble{background:var(--marble);position:relative}
.bg-marble::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(130deg, transparent 40%, rgba(180,137,109,.04) 42%, transparent 44%);
  pointer-events:none;
}
.bg-gradient{background:linear-gradient(180deg, var(--ivory) 0%, var(--marble) 100%)}

/* ============ REVEAL ANIM ============ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* ============ UTILS ============ */
.text-center{text-align:center}
.mt-small{margin-top:20px}
.mt-big{margin-top:48px}

/* ============ FULL-WIDTH IMAGE FEATURE ============ */
.feature-image{
  height:60vh;
  min-height:400px;
  overflow:hidden;
  position:relative;
  margin:80px 0;
}
.feature-image img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.9) sepia(.08);
}
.feature-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(43,35,32,.1) 0%, transparent 30%, transparent 70%, rgba(43,35,32,.3) 100%);
}
.feature-caption{
  position:absolute;
  bottom:32px;left:32px;
  color:var(--ivory);
  font-family:var(--serif);
  font-style:italic;
  font-size:1.3rem;
  max-width:500px;
  z-index:2;
}
@media (max-width:780px){
  .feature-image{
    height:auto;
    aspect-ratio:4/3;
    min-height:0;
    margin:50px 0;
  }
  .feature-caption{
    font-size:1rem;
    bottom:18px;
    left:18px;
    right:18px;
    max-width:none;
    line-height:1.45;
  }
}

/* ============ IMAGE GALLERY ============ */
.image-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-top:60px;
}
@media (max-width:700px){.image-gallery{grid-template-columns:1fr 1fr}}
.gallery-item{
  aspect-ratio:4/5;
  overflow:hidden;
  position:relative;
  transition:transform .5s var(--ease);
}
.gallery-item:hover{transform:translateY(-4px)}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.9) sepia(.08);
  transition:transform .8s var(--ease);
}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(43,35,32,.3) 100%);
  pointer-events:none;
}

/* ============ BLOG ============ */
.blog-filter{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:16px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  justify-content:center;
}
.blog-filter-link{
  padding:10px 20px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:500;
  border:1px solid transparent;
  transition:all .3s var(--ease);
}
.blog-filter-link:hover{color:var(--rose-dark);border-color:var(--rose-pale)}
.blog-filter-link.active{
  color:var(--rose-dark);
  border-color:var(--rose);
  background:var(--rose-pale);
}

.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  margin-top:20px;
}
@media (max-width:960px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.blog-grid{grid-template-columns:1fr}}

.blog-card{
  background:var(--ivory);
  border:1px solid var(--line);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
  color:inherit;
}
.blog-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 60px -20px rgba(80,60,45,.2);
  border-color:var(--rose-pale);
}
.blog-card-image{
  aspect-ratio:16/10;
  overflow:hidden;
  position:relative;
}
.blog-card-image img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.9) sepia(.08);
  transition:transform .8s var(--ease);
}
.blog-card:hover .blog-card-image img{transform:scale(1.05)}
.blog-card-body{
  padding:28px 28px 24px;
  display:flex;flex-direction:column;
  flex:1;
}
.blog-card-cat{
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--rose);margin-bottom:14px;font-weight:500;
}
.blog-card h3{
  font-size:1.4rem;
  color:var(--ink);
  margin-bottom:12px;
  line-height:1.2;
}
.blog-card-excerpt{
  font-size:.92rem;
  color:var(--ink-soft);
  line-height:1.6;
  margin-bottom:auto;
}
.blog-card-meta{
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:11px;
  letter-spacing:.1em;
  color:var(--mute);
}
.blog-card-more{
  color:var(--rose-dark);
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  transition:gap .3s var(--ease);
}

/* TAGS */
.tag-cloud{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin-top:12px;
}
.tag-chip{
  padding:8px 16px;
  background:var(--ivory);
  border:1px solid var(--line);
  font-size:.82rem;
  color:var(--ink-soft);
  transition:all .3s var(--ease);
}
.tag-chip:hover,.tag-chip.active{
  background:var(--rose);
  color:var(--ivory);
  border-color:var(--rose);
}

/* SINGLE POST */
.post-hero{
  width:100%;
  max-height:60vh;
  overflow:hidden;
  position:relative;
}
.post-hero img{
  width:100%;
  max-height:60vh;
  object-fit:cover;
  filter:contrast(1.05) saturate(.9) sepia(.05);
}
.post-hero::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(43,35,32,.05) 0%, transparent 30%, transparent 70%, rgba(43,35,32,.15) 100%);
}

.post-body{
  max-width:780px;
  margin:0 auto;
}
.post-body .breadcrumb{margin-bottom:24px}
.post-category{
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--rose);
  font-weight:500;
  margin-bottom:18px;
}
.post-title{
  font-size:clamp(2rem,4.5vw,3.6rem);
  font-weight:400;
  line-height:1.15;
  letter-spacing:-.015em;
  color:var(--ink);
}
.post-meta{
  margin-top:22px;
  padding-bottom:28px;
  border-bottom:1px solid var(--line);
  font-size:.85rem;
  color:var(--mute);
  letter-spacing:.1em;
}
.post-meta-sep{margin:0 10px;color:var(--rose)}
.post-excerpt{
  margin-top:28px;
  font-family:var(--serif);
  font-style:italic;
  font-size:1.35rem;
  color:var(--ink-soft);
  line-height:1.55;
}
.post-content{
  margin-top:40px;
  font-size:1.05rem;
  line-height:1.85;
  color:var(--ink-soft);
}
.post-content h2{
  font-size:1.9rem;
  color:var(--ink);
  margin:48px 0 16px;
  font-weight:500;
}
.post-content h3{
  font-size:1.4rem;
  color:var(--ink);
  margin:36px 0 14px;
}
.post-content p{margin-bottom:20px}
.post-content ul,.post-content ol{
  margin:20px 0 24px;
  padding-left:28px;
}
.post-content li{margin-bottom:8px}
.post-content a{
  color:var(--rose-dark);
  border-bottom:1px solid var(--rose-pale);
  transition:all .3s;
}
.post-content a:hover{color:var(--rose);border-color:var(--rose)}
.post-content blockquote{
  margin:32px 0;
  padding:20px 28px;
  background:var(--rose-pale);
  border-left:3px solid var(--rose);
  font-family:var(--serif);
  font-style:italic;
  font-size:1.15rem;
  color:var(--ink);
}
.post-content img{
  margin:32px 0;
  border-radius:2px;
}
.post-content strong{color:var(--ink)}

.post-tags{
  margin-top:48px;
  padding-top:32px;
  border-top:1px solid var(--line);
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.post-nav{
  margin-top:48px;
  padding-top:32px;
  border-top:1px solid var(--line);
}

/* ============ LIGHTBOX ============ */
.lb-overlay{
  position:fixed;
  inset:0;
  background:rgba(30,22,18,.94);
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transition:opacity .35s cubic-bezier(.2,.7,.2,1), visibility .35s;
}
.lb-overlay.open{opacity:1;visibility:visible}
.lb-image-wrap{
  position:relative;
  max-width:90vw;
  max-height:85vh;
  display:flex;
  align-items:center;
  justify-content:center;
}
.lb-image-wrap img{
  max-width:100%;
  max-height:85vh;
  object-fit:contain;
  box-shadow:0 40px 100px -20px rgba(0,0,0,.6);
  transition:opacity .25s;
}
.lb-image-wrap.loading img{opacity:.3}
.lb-caption{
  position:absolute;
  bottom:-44px;
  left:0;right:0;
  text-align:center;
  color:rgba(250,247,242,.82);
  font-family:var(--serif);
  font-style:italic;
  font-size:1rem;
  padding:0 20px;
}
.lb-btn{
  position:fixed;
  background:transparent;
  border:1px solid rgba(250,247,242,.3);
  color:rgba(250,247,242,.8);
  width:52px;height:52px;
  display:grid;place-items:center;
  cursor:pointer;
  transition:all .25s;
  font-size:24px;
  line-height:1;
  font-family:var(--sans);
  z-index:10001;
}
.lb-btn:hover{
  background:rgba(180,137,109,.25);
  border-color:var(--rose-light);
  color:var(--ivory);
}
.lb-close{top:24px;right:24px}
.lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-next{right:24px;top:50%;transform:translateY(-50%)}
.lb-counter{
  position:fixed;
  top:30px;left:50%;transform:translateX(-50%);
  color:rgba(250,247,242,.6);
  font-size:11px;
  letter-spacing:.25em;
  text-transform:uppercase;
  z-index:10001;
}
@media (max-width:640px){
  .lb-btn{width:44px;height:44px;font-size:20px}
  .lb-close{top:14px;right:14px}
  .lb-prev{left:10px}
  .lb-next{right:10px}
}

/* Gallery tweak — show as clickable */
.image-gallery a.gallery-item{
  cursor:zoom-in;
  display:block;
  position:relative;
}
.image-gallery a.gallery-item::after{
  content:"⤢";
  position:absolute;
  bottom:14px;right:14px;
  width:36px;height:36px;
  background:rgba(43,35,32,.7);
  backdrop-filter:blur(6px);
  color:var(--ivory);
  display:grid;place-items:center;
  font-size:15px;
  opacity:0;
  transition:opacity .3s var(--ease);
}
.image-gallery a.gallery-item:hover::after{opacity:1}
.gallery-caption{
  position:absolute;
  left:0;right:0;bottom:0;
  padding:12px 16px;
  background:linear-gradient(to top, rgba(43,35,32,.85), transparent);
  color:var(--ivory);
  font-size:12.5px;
  letter-spacing:.03em;
  opacity:0;
  transform:translateY(8px);
  transition:all .35s var(--ease);
}
.image-gallery a.gallery-item:hover .gallery-caption{opacity:1;transform:translateY(0)}

/* ============ MISSING RULES — hero columns, price list, timeline ============ */

/* Hero two-column layout */
.hero-content{
  position:relative;
  z-index:2;
}
.hero-content h1{
  font-family:var(--serif);
  font-size:clamp(2.4rem, 5vw, 4rem);
  font-weight:400;
  line-height:1.08;
  letter-spacing:-.015em;
  color:var(--ink);
  margin:14px 0 28px;
}
.hero-content h1 em{
  color:var(--rose-dark);
  font-family:var(--serif);
  font-weight:500;
}
.hero-content p{
  font-size:1.08rem;
  line-height:1.72;
  color:var(--ink-soft);
  max-width:520px;
  margin-bottom:36px;
}
.hero-buttons{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}

/* Hero right column (contains .hero-photo absolute + .hero-floating) */
.hero-image{
  position:relative;
  aspect-ratio:4/5;
  min-height:520px;
}
@media (max-width:980px){
  .hero-image{aspect-ratio:16/11;min-height:340px;margin-top:40px}
  .hero-inner{grid-template-columns:1fr !important;gap:40px !important}
}

/* ============ PRICE LIST ============ */
.price-list{
  list-style:none;
  padding:0;
  margin:0;
}
.price-list li{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  padding:20px 0;
  border-bottom:1px solid var(--line);
  gap:24px;
}
.price-list li:first-child{
  border-top:1px solid var(--line);
}
.price-name{
  font-family:var(--serif);
  font-size:1.18rem;
  color:var(--ink);
  font-weight:400;
}
.price-name em{
  color:var(--rose-dark);
  font-style:italic;
  font-size:.85em;
  margin-left:8px;
}
.price-dot{
  flex:1;
  border-bottom:1px dotted var(--line);
  height:1px;
  align-self:center;
  margin:0 14px;
}
.price-value{
  font-family:var(--serif);
  font-size:1.15rem;
  color:var(--rose-dark);
  font-weight:500;
  white-space:nowrap;
  letter-spacing:.01em;
}

/* Title for each price group */
.price-group-title{
  font-family:var(--serif);
  font-size:1.7rem;
  font-weight:500;
  color:var(--ink);
  margin-bottom:10px;
  letter-spacing:-.005em;
}
.price-group{
  margin-bottom:60px;
}
.price-group:last-of-type{
  margin-bottom:0;
}

/* ============ TIMELINE (Priebeh zákroku) ============ */
.timeline{
  max-width:760px;
  margin:0 auto;
  position:relative;
  padding-left:48px;
}
.timeline::before{
  content:"";
  position:absolute;
  left:18px;
  top:10px;
  bottom:10px;
  width:1px;
  background:linear-gradient(180deg, var(--rose-light) 0%, var(--line) 50%, transparent 100%);
}
.timeline-step{
  position:relative;
  padding:22px 0 22px 40px;
}
.timeline-step::before{
  content:"";
  position:absolute;
  left:-38px;
  top:30px;
  width:12px;
  height:12px;
  background:var(--ivory);
  border:2px solid var(--rose);
  border-radius:50%;
}
.timeline-num{
  font-family:var(--serif);
  font-size:.9rem;
  font-weight:500;
  color:var(--rose);
  letter-spacing:.2em;
  font-style:italic;
  display:block;
  margin-bottom:4px;
}
.timeline-step h4{
  font-family:var(--serif);
  font-size:1.35rem;
  font-weight:500;
  color:var(--ink);
  margin-bottom:6px;
  letter-spacing:-.005em;
}
.timeline-step p{
  color:var(--ink-soft);
  line-height:1.68;
  font-size:.98rem;
  max-width:560px;
}

@media (max-width:640px){
  .timeline{padding-left:32px}
  .timeline-step{padding-left:24px}
  .timeline-step::before{left:-28px;width:10px;height:10px}
}

/* Gallery items — align with lightbox styling */
.image-gallery{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
  margin-top:50px;
}
@media (max-width:860px){.image-gallery{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:500px){.image-gallery{grid-template-columns:1fr}}
.image-gallery .gallery-item{
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--marble);
  display:block;
}
.image-gallery .gallery-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .7s var(--ease);
}
.image-gallery .gallery-item:hover img{transform:scale(1.04)}

/* ============ MAP EMBED (Google Maps iframe) ============ */
.map-embed{
  width:100%;
  position:relative;
  line-height:0;
  background:var(--marble);
  box-shadow:inset 0 20px 30px -20px rgba(80,60,45,.2),
             inset 0 -20px 30px -20px rgba(80,60,45,.2);
}
.map-embed iframe{
  width:100%;
  min-height:480px;
  filter:saturate(.82) contrast(.96);
  transition:filter .5s var(--ease);
}
.map-embed:hover iframe{filter:saturate(1) contrast(1)}
@media (max-width:640px){.map-embed iframe{min-height:360px}}

/* ============ THEME VARIANTS ============
   Default (no [data-theme] attr) uses :root rose-gold palette.
   Each variant overrides only accent colors — backgrounds,
   typography and layout stay consistent across themes.
   ========================================= */

body[data-theme="oliva"]{
  --rose:       #8A9A5B;
  --rose-dark:  #6B7C42;
  --rose-light: #B8C48F;
  --rose-pale:  #EDEFDE;
}
body[data-theme="blue"]{
  --rose:       #6B8CAE;
  --rose-dark:  #3E5A7E;
  --rose-light: #A6C0D5;
  --rose-pale:  #E3EBF3;
}
body[data-theme="purple"]{
  --rose:       #8C6AA6;
  --rose-dark:  #624778;
  --rose-light: #C0A8D2;
  --rose-pale:  #EFE5F1;
}

/* ============ CUSTOM LOGO IMAGE ============ */
.logo-img{
  max-height:var(--logo-h, 56px);
  width:auto;
  display:block;
  object-fit:contain;
  transition:transform .3s var(--ease);
}
.logo:hover .logo-img{transform:scale(1.03)}
@media (max-width:640px){
  .logo-img{max-height:var(--logo-hm, 44px)}
}

/* ============ TESTIMONIALS ============ */
.testimonial-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
  margin-top:60px;
}
@media (max-width:900px){.testimonial-grid{grid-template-columns:1fr 1fr;gap:20px}}
@media (max-width:640px){.testimonial-grid{grid-template-columns:1fr}}

.testimonial{
  background:var(--ivory);
  border:1px solid var(--line);
  padding:34px 30px;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:18px;
  transition:all .35s var(--ease);
}
.testimonial::before{
  content:"\201E";
  position:absolute;
  top:-6px;left:20px;
  font-family:var(--serif);
  font-size:80px;
  color:var(--rose-pale);
  font-style:italic;
  line-height:1;
  z-index:0;
}
.testimonial:hover{
  border-color:var(--rose-light);
  transform:translateY(-3px);
  box-shadow:0 20px 40px -18px rgba(80,60,45,.18);
}
.testimonial-stars{
  font-size:13px;
  color:var(--rose);
  letter-spacing:.15em;
  position:relative;
  z-index:1;
}
.testimonial blockquote{
  font-family:var(--serif);
  font-size:1.12rem;
  line-height:1.65;
  font-style:italic;
  color:var(--ink);
  margin:0;
  padding:0;
  position:relative;
  z-index:1;
  flex:1;
}
.testimonial figcaption{
  padding-top:16px;
  border-top:1px solid var(--line);
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.testimonial figcaption strong{
  font-family:var(--sans);
  font-weight:500;
  color:var(--ink);
  font-size:.98rem;
}
.testimonial figcaption span{
  color:var(--mute);
  font-size:.82rem;
  letter-spacing:.04em;
}

.footnote{
  text-align:center;
  margin-top:40px;
  color:var(--mute);
  font-size:.85rem;
  letter-spacing:.03em;
  font-style:italic;
}

/* ============ OPENING HOURS ============ */
.hours-table{
  max-width:560px;
  margin:50px auto 0;
  display:flex;
  flex-direction:column;
  gap:0;
}
.hours-row{
  display:flex;
  align-items:baseline;
  padding:18px 6px;
  border-bottom:1px solid var(--line);
  gap:20px;
}
.hours-row:first-child{border-top:1px solid var(--line)}
.hours-day{
  font-family:var(--serif);
  font-size:1.1rem;
  font-weight:400;
  color:var(--ink);
  min-width:120px;
}
.hours-dot{
  flex:1;
  border-bottom:1px dotted var(--line);
  height:1px;
  align-self:center;
}
.hours-time{
  font-family:var(--sans);
  font-size:.95rem;
  color:var(--rose-dark);
  letter-spacing:.03em;
  font-weight:500;
  white-space:nowrap;
  text-align:right;
  min-width:140px;
}
.hours-note{
  max-width:560px;
  margin:32px auto 0;
  padding:20px 24px;
  background:var(--rose-pale);
  border-left:2px solid var(--rose);
  color:var(--ink-soft);
  font-size:.95rem;
  line-height:1.6;
}

/* ============ MAP SECTION ============ */
.map-section{
  width:100%;
  position:relative;
  overflow:hidden;
}
.map-caption{
  position:absolute;
  bottom:20px;left:50%;
  transform:translateX(-50%);
  padding:10px 22px;
  background:rgba(250,247,242,.92);
  backdrop-filter:blur(10px);
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--rose-dark);
  font-weight:500;
  pointer-events:none;
  z-index:2;
}
