/* ============================================================
   Pikku Santorini – Main Stylesheet
   Aegean Blue #1A4480 · White #FFFFFF · Sky #EDF3FB
   Fonts: Cinzel (headings) · Inter (body)
   ============================================================ */

/* Fonts loaded via <link> in HTML — no duplicate @import */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --blue:        #1A4480;
  --blue-hover:  #2356A0;
  --blue-dark:   #0E2B56;
  --sky:         #EDF3FB;
  --sky-mid:     #D3E3F5;
  --white:       #FFFFFF;
  --offwhite:    #F8F7F4;
  --text-dark:   #0D1B2A;
  --text-mid:    #2C4A6E;
  --text-light:  #5B7BA0;
  --border:      rgba(26,68,128,0.12);
  --shadow:      rgba(14,43,86,0.08);
  --shadow-md:   rgba(14,43,86,0.14);
  --shadow-lg:   rgba(14,43,86,0.22);
  --nav-height:  80px;
  --tr:          0.3s ease;
  --r:           4px;
  --r-lg:        12px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--text-dark);
  background:var(--white);
  line-height:1.7;
  overflow-x:hidden;
  animation:pageFadeIn 0.22s ease-out both;
}
@keyframes pageFadeIn { from { opacity:0; } to { opacity:1; } }
img { display:block; max-width:100%; height:auto; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* ── Typography ────────────────────────────────────────────── */
h1,h2,h3,h4 {
  font-family:'Cinzel',Georgia,serif;
  line-height:1.2;
  font-weight:700;
  letter-spacing:0.02em;
}
h1 { font-size:clamp(2.2rem,4.5vw,4rem); }
h2 { font-size:clamp(1.7rem,2.8vw,2.6rem); }
h3 { font-size:clamp(1.1rem,1.8vw,1.4rem); }

.section-title {
  font-family:'Cinzel',Georgia,serif;
  font-size:clamp(1.8rem,3vw,2.8rem);
  color:var(--text-dark);
  text-align:center;
  margin-bottom:0.4rem;
  letter-spacing:0.04em;
}
.section-eyebrow {
  font-family:'Inter',sans-serif;
  font-size:0.72rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--blue);
  text-align:center;
  display:block;
  margin-bottom:0.6rem;
}
.section-header { text-align:center; margin-bottom:48px; }
.section-divider {
  width:52px;
  height:2px;
  background:linear-gradient(to right, transparent, var(--blue), transparent);
  margin:0.8rem auto 2.5rem;
  border-radius:1px;
}

/* ── Layout ────────────────────────────────────────────────── */
.container { max-width:1160px; margin:0 auto; padding:0 24px; }
.section { padding:90px 0; }
.section--sky   { background:var(--sky); }
.section--dark  { background:var(--blue-dark); }
.section--white { background:var(--white); }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display:inline-block;
  padding:13px 34px;
  font-family:'Cinzel',serif;
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.22em;
  text-transform:uppercase;
  border-radius:var(--r);
  transition:background var(--tr),color var(--tr),border-color var(--tr),transform 0.15s;
  cursor:pointer;
  text-align:center;
  white-space:nowrap;
  border:2px solid transparent;
  line-height:1;
}
.btn:active { transform:translateY(1px); }
.btn-lg { padding:16px 44px; font-size:0.76rem; }

.btn-gold { background:var(--white); color:var(--blue); border-color:var(--white); }
.btn-gold:hover { background:var(--sky); border-color:var(--sky); color:var(--blue-dark); }

/* outline on dark backgrounds (white border) */
.btn-outline {
  background:transparent;
  color:var(--white);
  border-color:rgba(255,255,255,0.55);
}
.btn-outline:hover { background:rgba(255,255,255,0.1); border-color:var(--white); }
.btn-outline-white {
  background:transparent;
  color:var(--white);
  border-color:rgba(255,255,255,0.55);
}
.btn-outline-white:hover { background:rgba(255,255,255,0.1); border-color:var(--white); }

/* outline on light backgrounds (blue border) */
.btn-outline-blue {
  background:transparent;
  color:var(--blue);
  border-color:var(--blue);
}
.btn-outline-blue:hover { background:var(--blue); color:var(--white); }

/* ── Navbar ────────────────────────────────────────────────── */
.navbar {
  position:fixed;
  top:0; left:0; right:0;
  height:var(--nav-height);
  z-index:1000;
  transition:background var(--tr),box-shadow var(--tr);
  background:transparent;
}
.navbar.scrolled {
  background:rgba(10,28,58,0.96);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,0.08);
  box-shadow:0 4px 40px rgba(0,0,0,0.36);
}
.nav-container {
  max-width:1160px;
  margin:0 auto;
  padding:0 24px;
  height:100%;
  display:flex;
  align-items:center;
  gap:0;
}
.nav-brand { display:flex; align-items:center; margin-right:auto; flex-shrink:0; }
.nav-brand img,
img.nav-logo { height:52px; width:auto; object-fit:contain; transition:opacity var(--tr); }
.nav-brand:hover img { opacity:0.82; }

.nav-links {
  display:flex;
  align-items:center;
  gap:0;
  list-style:none;
}
.nav-link {
  display:block;
  padding:9px 15px;
  font-family:'Cinzel',serif;
  font-size:0.67rem;
  font-weight:600;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.72);
  transition:color var(--tr),text-shadow var(--tr);
  position:relative;
}
.nav-link:hover {
  color:var(--white);
  text-shadow:0 0 18px rgba(255,255,255,0.2);
}
.nav-link.active { color:var(--white); }

.nav-cta-item { margin-left:8px; }
.nav-cta {
  background:var(--white) !important;
  color:var(--blue) !important;
  border-color:var(--white) !important;
  padding:9px 18px !important;
  font-family:'Cinzel',serif;
  letter-spacing:0.14em;
  font-size:0.72rem;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:var(--sky) !important; border-color:var(--sky) !important; }

/* Language switcher */
.nav-lang {
  display:flex;
  align-items:center;
  gap:2px;
  margin-left:10px;
}
.lang-btn {
  background:none;
  border:none;
  color:rgba(255,255,255,0.5);
  font-family:'Inter',sans-serif;
  font-size:0.7rem;
  font-weight:600;
  letter-spacing:0.1em;
  cursor:pointer;
  padding:4px 7px;
  border-radius:2px;
  transition:color var(--tr),background var(--tr);
}
.lang-btn:hover { color:var(--white); background:rgba(255,255,255,0.1); }
.lang-btn.active { color:var(--white); }

/* Mobile right cluster (lang + hamburger) */
.nav-mobile-right { display:none; align-items:center; gap:4px; margin-left:auto; }
.nav-lang-mobile { display:flex; align-items:center; gap:2px; }

/* Hamburger */
.hamburger {
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:36px; height:36px;
  padding:4px;
  margin-left:6px;
}
.hamburger span {
  display:block;
  width:22px; height:2px;
  background:rgba(255,255,255,0.85);
  border-radius:1px;
  transition:transform 0.25s,opacity 0.25s;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile nav dropdown */
@media (max-width:900px) {
  .nav-mobile-right { display:flex; }
  .nav-lang { display:none; }
  .nav-cta-item { display:none; }

  .nav-links {
    display:none;
    position:fixed;
    top:var(--nav-height);
    left:0; right:0;
    background:var(--blue-dark);
    flex-direction:column;
    align-items:stretch;
    gap:0;
    box-shadow:0 8px 24px rgba(0,0,0,0.3);
    z-index:999;
    max-height:calc(100vh - var(--nav-height));
    overflow-y:auto;
  }
  .nav-links.open { display:flex; }
  .nav-links li { border-bottom:1px solid rgba(255,255,255,0.06); }
  .nav-link { padding:14px 24px; font-size:0.82rem; }
  .nav-link::after { display:none; }
  .nav-cta-item {
    display:block;
    padding:14px 24px;
  }
  .nav-cta {
    display:block !important;
    text-align:center !important;
    width:100% !important;
    padding:12px 24px !important;
  }
}

/* ── Scroll reveal ─────────────────────────────────────────── */
.reveal {
  opacity:0;
  transform:translateY(24px);
  transition:opacity 0.65s ease,transform 0.65s ease;
}
.reveal.visible { opacity:1; transform:none; }

/* ── HERO ──────────────────────────────────────────────────── */
.hero {
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background:var(--blue-dark);
}
.hero::after {
  content:'';
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:0.03;
  z-index:1;
  pointer-events:none;
}
.hero-bg {
  position:absolute;
  inset:0;
  background-size:cover;
  background-repeat:no-repeat;
  will-change:transform;
  filter:saturate(0.55) brightness(0.68) contrast(1.05);
  transform:scale(1.04);
}
.hero-overlay {
  position:absolute;
  inset:0;
  background:
    linear-gradient(to bottom, rgba(8,18,40,0.68) 0%, rgba(10,22,50,0.34) 48%, rgba(8,18,40,0.72) 100%),
    linear-gradient(to right, rgba(8,18,40,0.3) 0%, transparent 55%);
}
.hero-content {
  position:relative;
  z-index:2;
  text-align:center;
  padding:0 32px;
  max-width:1000px;
  padding-bottom:80px;
}
.hero-eyebrow {
  font-family:'Cinzel',serif;
  font-size:0.68rem;
  letter-spacing:0.38em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.72);
  display:block;
  margin-bottom:28px;
  opacity:0.9;
}
/* New split title */
.hero-name { margin-bottom:0; }
.hero-name-pikku {
  font-family:'Cinzel',serif;
  font-size:clamp(1.2rem,3vw,2.2rem);
  font-weight:400;
  letter-spacing:0.7em;
  color:rgba(255,255,255,0.7);
  display:block;
  text-transform:uppercase;
  margin-bottom:-6px;
}
.hero-name-santorini {
  font-family:'Cinzel',serif;
  font-size:clamp(2.2rem,11vw,11rem);
  font-weight:900;
  letter-spacing:0.06em;
  color:var(--white);
  line-height:0.88;
  margin:0;
  text-shadow:
    0 1px 0 rgba(255,255,255,0.08),
    0 4px 32px rgba(0,0,0,0.55),
    0 0 80px rgba(255,255,255,0.04);
  -webkit-text-stroke:0.5px rgba(255,255,255,0.15);
}
.hero-rule {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin:28px auto 24px;
  max-width:240px;
}
.hero-rule-line {
  flex:1;
  height:1px;
  background:linear-gradient(to right, transparent, rgba(255,255,255,0.45), transparent);
  opacity:0.7;
}
.hero-rule-ornament {
  color:rgba(255,255,255,0.55);
  font-size:0.55rem;
  line-height:1;
  flex-shrink:0;
}
.hero-tagline {
  font-family:'Inter',sans-serif;
  font-size:clamp(0.88rem,1.4vw,1.05rem);
  color:rgba(255,255,255,0.65);
  letter-spacing:0.1em;
  margin-bottom:40px;
  font-weight:300;
  font-style:italic;
}
.hero-cta-row {
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
}
.hero-scroll-hint {
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  z-index:2;
  animation:scroll-bounce 2.2s ease-in-out infinite;
}
@keyframes scroll-bounce {
  0%,100% { transform:translateX(-50%) translateY(0); opacity:0.5; }
  50% { transform:translateX(-50%) translateY(8px); opacity:1; }
}
/* Legacy classes kept for compat */
.hero-title { display:none; }
.hero-divider { display:none; }

/* ── Ornamental section break ───────────────────────────────── */
.section-ornament {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
  padding:28px 0 0;
}
.section-ornament-line {
  width:80px;
  height:1px;
  background:linear-gradient(to right, transparent, rgba(26,68,128,0.3));
  opacity:0.35;
}
.section-ornament-line:last-child {
  background:linear-gradient(to left, transparent, rgba(26,68,128,0.3));
}
.section-ornament-glyph {
  font-family:'Cinzel',serif;
  font-size:0.58rem;
  letter-spacing:0.5em;
  color:var(--blue);
  opacity:0.65;
  text-transform:uppercase;
  white-space:nowrap;
}

/* ── ABOUT ─────────────────────────────────────────────────── */
.about-section {
  background:var(--offwhite);
  position:relative;
  overflow:hidden;
}
.about-section::before {
  content:'';
  position:absolute;
  top:-120px; right:-80px;
  width:480px; height:480px;
  background:radial-gradient(circle, rgba(26,68,128,0.06) 0%, transparent 70%);
  pointer-events:none;
}
.about-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:88px;
  align-items:center;
}
.about-text h2 { color:var(--text-dark); margin-bottom:1.2rem; }
.about-body { color:var(--text-mid); line-height:2; margin-bottom:1.6rem; font-size:1.02rem; }
.about-quote {
  display:flex;
  gap:16px;
  align-items:flex-start;
  border-left:3px solid var(--blue);
  padding:4px 0 4px 20px;
  margin:1.5rem 0 2rem;
  color:var(--blue);
  font-family:'Cinzel',serif;
  font-size:1.05rem;
  letter-spacing:0.04em;
}
.quote-icon { flex-shrink:0; margin-top:2px; opacity:0.5; }
.about-image { position:relative; padding-bottom:22px; padding-left:22px; }
.about-photo {
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  border-radius:var(--r-lg);
  box-shadow:0 28px 64px var(--shadow-lg);
  transition:transform 0.7s ease;
  display:block;
}
.about-image:hover .about-photo { transform:scale(1.02); }
.about-image-badge {
  position:absolute;
  bottom:0; left:0;
  background:var(--blue-dark);
  padding:18px 24px;
  border-radius:var(--r);
  text-align:center;
  box-shadow:0 8px 28px var(--shadow-md);
  z-index:1;
}
.about-image-badge span {
  display:block;
  font-size:0.68rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.55);
  margin-bottom:2px;
}
.about-image-badge strong {
  display:block;
  font-family:'Cinzel',serif;
  font-size:1.2rem;
  color:var(--white);
  letter-spacing:0.06em;
}

/* ── FEATURES ──────────────────────────────────────────────── */
.features-section { background:var(--blue-dark); padding:80px 0; }
.features-section .section-title { color:var(--white); }
.features-section .section-eyebrow { color:rgba(255,255,255,0.65); }
.features-section .section-divider { background:linear-gradient(to right, transparent, rgba(255,255,255,0.25), transparent); }
.features-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  margin-top:56px;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.feature-card {
  background:transparent;
  border:none;
  border-right:1px solid rgba(255,255,255,0.08);
  border-radius:0;
  padding:44px 32px;
  text-align:center;
  transition:background var(--tr);
  position:relative;
}
.feature-card:last-child { border-right:none; }
.feature-card:hover { background:rgba(255,255,255,0.04); }
.feature-icon {
  width:52px; height:52px;
  background:transparent;
  border:none;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 20px;
  color:rgba(255,255,255,0.35);
  transition:color var(--tr);
}
.feature-card:hover .feature-icon { color:var(--white); }
.feature-icon svg { flex-shrink:0; }
.feature-title {
  font-family:'Cinzel',serif;
  font-size:0.78rem;
  letter-spacing:0.18em;
  color:rgba(255,255,255,0.9);
  margin-bottom:0.7rem;
  text-transform:uppercase;
}
.feature-card::before {
  content:'';
  display:block;
  width:28px;
  height:1px;
  background:rgba(255,255,255,0.2);
  margin:0 auto 20px;
  opacity:0.7;
}
.feature-text { font-size:0.87rem; color:rgba(255,255,255,0.45); line-height:1.8; }

/* ── GALLERY STRIP ─────────────────────────────────────────── */
.gallery-strip { overflow:hidden; position:relative; }
.gallery-strip::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(to right, transparent, rgba(26,68,128,0.45), transparent);
  opacity:0.45;
  z-index:1;
}
.gallery-strip-inner {
  display:grid;
  grid-template-columns:1.2fr 0.8fr 1fr;
  height:480px;
}
.gallery-strip-inner > * {
  overflow:hidden;
  position:relative;
}
.gallery-strip-inner > *::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom,transparent 50%,rgba(14,43,86,0.45));
  opacity:0;
  transition:opacity 0.4s ease;
}
.gallery-strip-inner > *:hover::after { opacity:1; }
.gallery-img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94);
  display:block;
}
.gallery-strip-inner > *:hover .gallery-img { transform:scale(1.07); }

/* ── REVIEWS ───────────────────────────────────────────────── */
.reviews-section { background:var(--white); }
.reviews-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.review-card {
  background:var(--white);
  border:none;
  border-radius:0;
  padding:44px 36px;
  transition:background var(--tr);
}
.review-card:hover { background:var(--sky); }
.review-stars { display:flex; gap:3px; margin-bottom:18px; }
.star { width:14px; height:14px; color:var(--blue); flex-shrink:0; }
.review-text {
  font-size:0.95rem;
  color:var(--text-mid);
  line-height:1.85;
  margin-bottom:24px;
  font-style:italic;
  font-family:'Inter',sans-serif;
}
.review-author {
  font-family:'Cinzel',serif;
  font-size:0.72rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--text-dark);
  font-weight:600;
  font-style:normal;
  display:block;
  margin-bottom:14px;
}
.review-google-badge {
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-size:0.72rem;
  color:var(--text-light);
  letter-spacing:0.08em;
  text-transform:uppercase;
}

/* ── HOURS BAND ────────────────────────────────────────────── */
.hours-band {
  background:var(--blue-dark);
  padding:72px 0;
}
.hours-band-inner {
  display:grid;
  grid-template-columns:1fr 1.4fr auto;
  gap:64px;
  align-items:center;
}
.hours-band-title-col {}
.hours-band-heading {
  font-family:'Cinzel',serif;
  color:var(--white);
  font-size:clamp(1.4rem,2.4vw,2rem);
  letter-spacing:0.06em;
  margin-bottom:10px;
}
.hours-special-link {
  font-family:'Inter',sans-serif;
  font-size:0.78rem;
  font-weight:500;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.72);
  border-bottom:1px solid rgba(255,255,255,0.3);
  padding-bottom:2px;
  display:inline-block;
  transition:color var(--tr),border-color var(--tr);
}
.hours-special-link:hover { color:var(--white); border-color:var(--white); }
.hours-band-rows { display:grid; gap:0; }
.hours-row {
  display:flex;
  align-items:center;
  padding:13px 0;
  border-bottom:1px solid rgba(255,255,255,0.08);
  gap:12px;
}
.hours-row:first-child { border-top:1px solid rgba(255,255,255,0.08); }
.hours-day {
  font-family:'Cinzel',serif;
  font-size:0.72rem;
  letter-spacing:0.15em;
  color:rgba(255,255,255,0.65);
  text-transform:uppercase;
  width:110px;
  flex-shrink:0;
}
.hours-dots {
  flex:1;
  border-bottom:1px dotted rgba(255,255,255,0.15);
  margin-bottom:2px;
}
.hours-time { font-size:0.95rem; color:var(--white); font-weight:500; flex-shrink:0; }
.hours-kitchen-note {
  font-size:0.73rem;
  color:rgba(255,255,255,0.38);
  letter-spacing:0.08em;
  font-style:italic;
  padding-top:10px;
}
.hours-band-cta {
  display:flex;
  flex-direction:column;
  gap:14px;
  align-self:center;
}

/* ── MAP / CONTACT ─────────────────────────────────────────── */
.map-contact-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:start;
}
.map-wrapper {}
.map-facade {
  width:100%;
  height:400px;
  background:var(--sky);
  border-radius:var(--r-lg);
  overflow:hidden;
  position:relative;
  cursor:pointer;
  border:1px solid var(--border);
}
.map-facade-overlay {
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  background:rgba(14,43,86,0.04);
  transition:background var(--tr);
  z-index:1;
}
.map-facade:hover .map-facade-overlay { background:rgba(14,43,86,0.08); }
.map-facade-overlay span {
  font-family:'Inter',sans-serif;
  font-size:0.8rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--blue);
  font-weight:500;
}
.map-facade-thumb {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0.45;
}
.map-facade iframe {
  width:100%;
  height:100%;
  border:0;
  border-radius:var(--r-lg);
}
.contact-details { padding-top:8px; }
.contact-item {
  display:flex;
  gap:18px;
  margin-bottom:28px;
  align-items:flex-start;
}
.contact-icon {
  width:46px; height:46px;
  background:var(--blue);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--white);
}
.contact-info {}
.contact-label {
  font-family:'Cinzel',serif;
  font-size:0.66rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:4px;
  display:block;
}
.contact-value {
  font-size:1rem;
  color:var(--text-dark);
  font-weight:500;
  display:block;
  transition:color var(--tr);
}
.contact-value:hover { color:var(--blue); }

/* ── FOOTER ────────────────────────────────────────────────── */
.footer {
  background:var(--blue-dark);
  padding:72px 0 0;
}
.footer-grid {
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:48px;
  padding-bottom:52px;
}
.footer-logo {
  height:50px;
  width:auto;
  margin-bottom:16px;
  opacity:0.88;
  object-fit:contain;
}
.footer-desc {
  font-size:0.87rem;
  color:rgba(255,255,255,0.5);
  line-height:1.75;
  max-width:260px;
  margin-bottom:20px;
}
.footer-social { display:flex; gap:10px; }
.social-link {
  width:36px; height:36px;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,0.6);
  transition:background var(--tr),color var(--tr);
}
.social-link:hover { background:rgba(255,255,255,0.15); color:var(--white); }
.footer-heading {
  font-family:'Cinzel',serif;
  font-size:0.7rem;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.65);
  margin-bottom:18px;
  display:block;
}
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-link {
  font-size:0.87rem;
  color:rgba(255,255,255,0.55);
  transition:color var(--tr);
}
.footer-link:hover { color:var(--white); }
.footer-address {
  font-style:normal;
  font-size:0.87rem;
  color:rgba(255,255,255,0.55);
  line-height:1.9;
}
.footer-address a { color:rgba(255,255,255,0.55); transition:color var(--tr); }
.footer-address a:hover { color:var(--white); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.07);
  padding:24px 0;
}
.footer-bottom-inner {
  max-width:1160px;
  margin:0 auto;
  padding:0 24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
}
.footer-bottom-inner span { font-size:0.76rem; color:rgba(255,255,255,0.3); letter-spacing:0.07em; }
.footer-bottom-links { display:flex; gap:20px; }
.footer-bottom-link { font-size:0.76rem; color:rgba(255,255,255,0.38); transition:color var(--tr); }
.footer-bottom-link:hover { color:rgba(255,255,255,0.75); }

/* ── PAGE HERO (sub-pages) ─────────────────────────────────── */
.page-hero {
  background:var(--blue-dark);
  background-size:cover;
  background-position:center;
  padding:calc(var(--nav-height) + 80px) 0 80px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.page-hero-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(160deg,rgba(14,43,86,0.7) 0%,rgba(14,43,86,0.85) 100%);
}
.page-hero-content {
  position:relative;
  z-index:1;
}
.page-hero-title,
.page-hero h1 {
  font-family:'Cinzel',serif;
  color:var(--white);
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:700;
  letter-spacing:0.1em;
  margin-bottom:0.5rem;
  text-shadow:0 2px 16px rgba(0,0,0,0.2);
}
.page-hero-sub {
  font-family:'Inter',sans-serif;
  font-size:0.78rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.5);
}

/* ── MENU PAGE ─────────────────────────────────────────────── */
.menu-tabs {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  margin-bottom:48px;
}
.menu-tab {
  font-family:'Cinzel',serif;
  font-size:0.72rem;
  font-weight:600;
  letter-spacing:0.16em;
  text-transform:uppercase;
  padding:10px 22px;
  border:2px solid var(--border);
  background:var(--white);
  color:var(--text-mid);
  border-radius:var(--r);
  cursor:pointer;
  transition:all var(--tr);
}
.menu-tab:hover,
.menu-tab.active { background:var(--blue); color:var(--white); border-color:var(--blue); }
.menu-category { display:none; }
.menu-category.active { display:block; }
.menu-panel { display:none; }
.menu-panel.active { display:block; }
.menu-intro { text-align:center; margin-bottom:32px; }
.menu-allergen { font-size:0.82rem; color:var(--text-light); margin-bottom:4px; }
.menu-price-note { font-size:0.78rem; color:var(--text-light); font-style:italic; }
.menu-cta { text-align:center; margin-top:52px; }
.menu-category-title {
  font-family:'Cinzel',serif;
  font-size:1.3rem;
  letter-spacing:0.08em;
  color:var(--text-dark);
  text-align:center;
  margin-bottom:32px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
}
.menu-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.menu-item {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  padding:20px 22px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition:box-shadow var(--tr),border-color var(--tr);
}
.menu-item:hover { box-shadow:0 6px 20px var(--shadow); border-color:rgba(26,68,128,0.22); }
.menu-item-body { flex:1; }
.menu-item-name {
  font-family:'Cinzel',serif;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.1em;
  color:var(--text-dark);
  margin-bottom:6px;
  text-transform:uppercase;
}
.menu-item-desc { font-size:0.87rem; color:var(--text-light); line-height:1.6; }
.menu-item-price {
  font-family:'Cinzel',serif;
  font-size:1rem;
  font-weight:700;
  color:var(--blue);
  white-space:nowrap;
  flex-shrink:0;
}

/* ── LOUNAS PAGE ───────────────────────────────────────────── */
.lounas-includes {
  background:var(--sky);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:28px 36px;
  text-align:center;
  margin-bottom:48px;
}
.lounas-includes h2 {
  font-family:'Cinzel',serif;
  font-size:1rem;
  letter-spacing:0.12em;
  color:var(--blue);
  text-transform:uppercase;
  margin-bottom:8px;
}
.lounas-includes p { font-size:0.9rem; color:var(--text-mid); }
.lounas-note { text-align:center; font-size:0.9rem; color:var(--text-mid); max-width:600px; margin:0 auto 36px; line-height:1.7; }
.lounas-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.lounas-item {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding:20px 24px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition:box-shadow var(--tr);
}
.lounas-item:hover { box-shadow:0 4px 16px var(--shadow); }
.lounas-item-name {
  font-family:'Cinzel',serif;
  font-size:0.82rem;
  font-weight:700;
  letter-spacing:0.1em;
  color:var(--text-dark);
  text-transform:uppercase;
  margin-bottom:4px;
}
.lounas-item-desc { font-size:0.85rem; color:var(--text-light); }
.lounas-item-price {
  font-family:'Cinzel',serif;
  font-size:1.1rem;
  font-weight:700;
  color:var(--blue);
  white-space:nowrap;
  flex-shrink:0;
}

/* ── GROUPS PAGE ───────────────────────────────────────────── */
.group-features-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:48px;
}
.group-feature-card {
  background:var(--sky);
  border-radius:var(--r-lg);
  padding:40px 32px;
  text-align:center;
  border:1px solid var(--border);
}
.group-feature-card h3 {
  font-family:'Cinzel',serif;
  font-size:0.9rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--blue-dark);
  margin-bottom:0.8rem;
}
.group-feature-card p { font-size:0.9rem; color:var(--text-mid); line-height:1.7; }
.group-contact-box {
  background:var(--blue-dark);
  border-radius:var(--r-lg);
  padding:48px;
  text-align:center;
  max-width:640px;
  margin:0 auto;
}
.group-contact-box h2 { font-family:'Cinzel',serif; color:var(--white); margin-bottom:0.8rem; }
.group-contact-box p { color:rgba(255,255,255,0.65); margin-bottom:1.5rem; }
.group-contact-box .btn { margin:6px; }

/* ── CONTACT PAGE ──────────────────────────────────────────── */
.contact-page-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:start;
}
.map-facade--tall { height:480px; }
.hours-rows-compact .hours-row { padding:10px 0; }
.hours-rows-compact .hours-day { font-size:0.78rem; color:var(--text-mid); font-family:'Inter',sans-serif; letter-spacing:0.05em; text-transform:none; width:120px; }
.hours-rows-compact .hours-time { color:var(--text-dark); }
.hours-rows-compact .hours-dots { border-color:rgba(26,68,128,0.15); }
.hours-rows-compact .hours-row { border-bottom-color:var(--border); }
.hours-rows-compact .hours-row:first-child { border-top-color:var(--border); }

/* ── SPECIAL HOURS PAGE ────────────────────────────────────── */
.special-hours-list { max-width:620px; margin:0 auto; }
.special-hour-item {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 0;
  border-bottom:1px solid var(--border);
  gap:20px;
}
.special-hour-item:first-child { border-top:1px solid var(--border); }
.special-hour-date { font-family:'Cinzel',serif; font-size:0.9rem; letter-spacing:0.1em; color:var(--text-dark); font-weight:600; }
.special-hour-note { font-size:0.82rem; color:var(--text-light); margin-top:3px; }
.special-hour-time { font-size:0.95rem; color:var(--blue); font-weight:600; white-space:nowrap; }
.special-closed { color:#C0392B; }
#no-special-msg { display:none; text-align:center; color:var(--text-light); font-size:0.95rem; padding:32px 0; }

/* ── PRIVACY PAGE ──────────────────────────────────────────── */
.privacy-section { background:var(--white); }
.privacy-content { max-width:760px; margin:0 auto; }
.privacy-content h2 { font-family:'Cinzel',serif; font-size:1.1rem; color:var(--text-dark); margin:2.5rem 0 0.8rem; letter-spacing:0.04em; }
.privacy-content h2:first-child { margin-top:0; }
.privacy-content p,.privacy-content li { font-size:0.95rem; color:var(--text-mid); line-height:1.85; margin-bottom:1rem; }
.privacy-content ul { list-style:disc; padding-left:24px; margin-bottom:1rem; }
.privacy-content a { color:var(--blue); }

/* ── BOOKING FORM (varaa.php) ──────────────────────────────── */
.booking-page { background:var(--offwhite); min-height:100vh; }
.booking-hero {
  background:var(--blue-dark);
  padding:calc(var(--nav-height) + 52px) 0 52px;
  position:relative;
  overflow:hidden;
}
.booking-hero::before {
  content:'';
  position:absolute;
  inset:0;
  background-image:url('../img/tables.jpg');
  background-size:cover;
  background-position:center;
  opacity:0.1;
}
.booking-hero > .container { position:relative; z-index:1; text-align:center; }
.booking-hero h1 { font-family:'Cinzel',serif; color:var(--white); font-size:clamp(1.8rem,3vw,2.6rem); letter-spacing:0.08em; margin-bottom:0.4rem; }
.booking-hero-sub { font-family:'Inter',sans-serif; font-size:0.78rem; letter-spacing:0.26em; text-transform:uppercase; color:rgba(255,255,255,0.5); }
.booking-main { padding:56px 0 80px; }
.booking-grid { display:grid; grid-template-columns:1fr 340px; gap:36px; align-items:start; }
.booking-form-card { background:var(--white); border:1px solid var(--border); border-radius:var(--r-lg); padding:44px 48px; box-shadow:0 4px 24px var(--shadow); }
.booking-sidebar { background:var(--blue-dark); border-radius:var(--r-lg); padding:32px 28px; color:var(--white); position:sticky; top:calc(var(--nav-height) + 20px); }
.booking-sidebar h3 { font-family:'Cinzel',serif; font-size:0.76rem; letter-spacing:0.22em; text-transform:uppercase; margin-bottom:20px; color:rgba(255,255,255,0.6); }
.booking-hours-row { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.07); font-size:0.86rem; }
.booking-hours-row:last-of-type { border-bottom:none; }
.bh-day { color:rgba(255,255,255,0.55); font-size:0.8rem; }
.bh-time { color:var(--white); font-weight:500; }
.booking-sidebar-note { margin-top:16px; padding-top:16px; border-top:1px solid rgba(255,255,255,0.07); font-size:0.78rem; color:rgba(255,255,255,0.45); line-height:1.65; font-style:italic; }

/* Form fields */
.form-group { margin-bottom:22px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-label { display:block; font-family:'Cinzel',serif; font-size:0.66rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--text-mid); margin-bottom:8px; }
.form-label .req { color:#C0392B; margin-left:2px; }
.form-input,.form-select,.form-textarea { width:100%; padding:12px 15px; border:1.5px solid rgba(26,68,128,0.18); border-radius:var(--r); font-family:'Inter',sans-serif; font-size:0.95rem; color:var(--text-dark); background:var(--white); transition:border-color var(--tr),box-shadow var(--tr); outline:none; -webkit-appearance:none; appearance:none; }
.form-input:focus,.form-select:focus,.form-textarea:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(26,68,128,0.08); }
.form-input::placeholder,.form-textarea::placeholder { color:var(--text-light); }
.form-select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232C4A6E' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; cursor:pointer; }
.form-textarea { min-height:96px; resize:vertical; line-height:1.6; }
.form-input.error,.form-select.error { border-color:#C0392B; }
.form-error-box { background:rgba(192,57,43,0.05); border:1.5px solid rgba(192,57,43,0.28); border-radius:var(--r); padding:18px 22px; margin-bottom:28px; }
.form-error-box h2 { font-family:'Cinzel',serif; font-size:0.78rem; letter-spacing:0.14em; text-transform:uppercase; color:#C0392B; margin-bottom:10px; }
.form-error-box ul { list-style:disc; padding-left:20px; }
.form-error-box li { font-size:0.88rem; color:#C0392B; margin-bottom:4px; }
.btn-book { width:100%; padding:15px; background:var(--blue); color:var(--white); font-family:'Cinzel',serif; font-size:0.76rem; font-weight:700; letter-spacing:0.26em; text-transform:uppercase; border:none; border-radius:var(--r); cursor:pointer; transition:background var(--tr),transform 0.15s; margin-top:8px; }
.btn-book:hover { background:var(--blue-hover); }
.btn-book:active { transform:translateY(1px); }
.form-privacy { font-size:0.8rem; color:var(--text-light); line-height:1.6; margin-top:14px; text-align:center; }
.form-privacy a { color:var(--blue); }
.slot-full { color:var(--text-light) !important; }
.honeypot { display:none !important; }

/* Booking success */
.booking-success-wrap { max-width:580px; margin:0 auto; }
.booking-success { background:var(--white); border:1px solid var(--border); border-radius:var(--r-lg); padding:50px 44px; text-align:center; box-shadow:0 4px 24px var(--shadow); }
.booking-success-icon { width:72px; height:72px; background:var(--blue); border-radius:50%; margin:0 auto 24px; display:flex; align-items:center; justify-content:center; color:var(--white); }
.booking-success h1 { font-family:'Cinzel',serif; font-size:1.5rem; letter-spacing:0.06em; color:var(--text-dark); margin-bottom:0.5rem; }
.booking-success p { color:var(--text-mid); margin-bottom:0.5rem; font-size:0.95rem; }
.resnum-box { background:var(--sky); border:1px dashed var(--border); border-radius:var(--r); padding:20px; margin:24px 0; }
.resnum-label { font-family:'Cinzel',serif; font-size:0.68rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--blue); margin-bottom:6px; }
.resnum-value { font-family:'Courier New',Courier,monospace; font-size:1.6rem; font-weight:700; letter-spacing:0.14em; color:var(--blue); }
.cal-links { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin:20px 0; }
.cal-link { font-size:0.82rem; color:var(--blue); padding:8px 18px; border:1px solid var(--border); border-radius:var(--r); transition:background var(--tr),color var(--tr); }
.cal-link:hover { background:var(--blue); color:var(--white); }
.cancel-link { font-size:0.82rem; color:var(--text-light); transition:color var(--tr); }
.cancel-link:hover { color:var(--blue); }

/* ── OIVA badge ─────────────────────────────────────────────── */
.oiva-badge { display:inline-flex; align-items:center; gap:10px; background:rgba(26,68,128,0.06); border:1px solid var(--border); border-radius:var(--r); padding:10px 20px; font-size:0.82rem; color:var(--text-mid); }
.oiva-smile { font-size:1.4rem; }

/* ── Page hero variants ─────────────────────────────────────── */
.page-hero--small { padding:calc(var(--nav-height) + 52px) 0 52px; }

/* ── Contact page ───────────────────────────────────────────── */
.contact-page-info {}
.contact-page-map {}
.contact-hours-block { margin-top:32px; padding-top:28px; border-top:1px solid var(--border); }
.contact-hours-title {
  font-family:'Cinzel',serif;
  font-size:0.82rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:16px;
}

/* ── Lounas page extras ─────────────────────────────────────── */
.lounas-note { text-align:center; font-size:0.9rem; color:var(--text-mid); max-width:600px; margin:0 auto 36px; line-height:1.7; }
.lounas-section-title {
  font-family:'Cinzel',serif;
  font-size:1rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--blue);
  margin:36px 0 16px;
  padding-bottom:10px;
  border-bottom:1px solid var(--border);
}

/* ── Groups page extras ─────────────────────────────────────── */
.group-intro { text-align:center; max-width:700px; margin:0 auto 56px; }
.group-intro-text { color:var(--text-mid); font-size:1rem; line-height:1.85; text-align:center; margin-top:0; }
.group-cta { text-align:center; margin-top:48px; }
.group-cards {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:48px;
}
.group-card {
  background:var(--sky);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:40px 28px;
  text-align:center;
  transition:box-shadow var(--tr),transform var(--tr);
}
.group-card:hover { box-shadow:0 14px 36px var(--shadow-md); transform:translateY(-3px); }
.group-card-icon {
  width:68px; height:68px;
  background:var(--white);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
  color:var(--blue);
  border:1px solid var(--border);
  transition:background var(--tr),color var(--tr);
}
.group-card:hover .group-card-icon { background:var(--blue); color:var(--white); }
.group-card-title {
  font-family:'Cinzel',serif;
  font-size:0.82rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--text-dark);
  margin-bottom:0.7rem;
}
.group-card-text { font-size:0.88rem; color:var(--text-mid); line-height:1.75; margin-bottom:0.5rem; }
.group-card-note { font-size:0.78rem; color:var(--blue); font-weight:500; font-style:italic; }
.group-contact-box {
  background:var(--blue-dark);
  border-radius:var(--r-lg);
  padding:52px 48px;
  text-align:center;
  max-width:640px;
  margin:0 auto;
}
.group-contact-title {
  font-family:'Cinzel',serif;
  color:var(--white);
  font-size:clamp(1.2rem,2vw,1.6rem);
  letter-spacing:0.06em;
  margin-bottom:0.8rem;
}
.group-contact-text { color:rgba(255,255,255,0.65); margin-bottom:1.5rem; font-size:0.95rem; }
.group-contact-methods {
  display:flex;
  gap:24px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:28px;
}
.group-contact-link {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:0.95rem;
  color:rgba(255,255,255,0.75);
  font-weight:500;
  transition:color var(--tr);
}
.group-contact-link:hover { color:var(--white); }
.page-hero-subtitle {
  font-family:'Inter',sans-serif;
  font-size:0.95rem;
  font-style:italic;
  color:rgba(255,255,255,0.65);
  margin-top:8px;
  letter-spacing:0.06em;
}

/* ── Special hours extras ───────────────────────────────────── */
.special-hours-intro { text-align:center; max-width:560px; margin:0 auto 40px; color:var(--text-mid); font-size:0.95rem; line-height:1.75; }

/* ── Lounas extras ──────────────────────────────────────────── */
.lounas-cta { text-align:center; margin-top:48px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ── Lounas includes box ────────────────────────────────────── */
.lounas-header { margin-bottom:36px; }
.lounas-includes-box {
  display:flex;
  align-items:center;
  gap:18px;
  background:var(--sky);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px 32px;
  max-width:680px;
  margin:0 auto;
}
.lounas-includes-box p {
  font-size:0.95rem;
  color:var(--text-mid);
  line-height:1.7;
  flex:1;
}
.lounas-includes-icon {
  flex-shrink:0;
  width:48px; height:48px;
  background:var(--blue);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--white);
}

/* ── Map facade tall variant ────────────────────────────────── */
.map-facade-thumb--tall {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0.45;
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width:1024px) {
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .booking-grid { grid-template-columns:1fr; }
  .booking-sidebar { position:static; }
}
@media (max-width:860px) {
  .about-grid { grid-template-columns:1fr; gap:48px; }
  .about-image { padding-bottom:16px; padding-left:16px; }
  .about-image-badge { bottom:-10px; left:-10px; }
  .reviews-grid { grid-template-columns:1fr 1fr; }
  .hours-band-inner { grid-template-columns:1fr; gap:32px; }
  .map-contact-grid { grid-template-columns:1fr; gap:40px; }
  .contact-page-grid { grid-template-columns:1fr; gap:40px; }
  .gallery-strip-inner { height:220px; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .group-features-grid { grid-template-columns:1fr; }
  .group-cards { grid-template-columns:1fr; }
}
@media (max-width:600px) {
  .section { padding:60px 0; }
  h1 { font-size:clamp(1.8rem,6vw,2.8rem); }
  .hero-title { font-size:clamp(2.2rem,10vw,4rem); }
  .hero::after { height:40px; }
  .features-grid { grid-template-columns:1fr; }
  .reviews-grid { grid-template-columns:1fr; }
  .menu-grid { grid-template-columns:1fr; }
  .lounas-grid { grid-template-columns:1fr; }
  .gallery-strip-inner { grid-template-columns:1fr; height:auto; }
  .gallery-img { height:220px; }
  .footer-grid { grid-template-columns:1fr; }
  .booking-form-card { padding:28px 20px; }
  .form-row { grid-template-columns:1fr; }
  .hours-day { width:80px; font-size:0.68rem; }
}

/* === COOKIE CONSENT BANNER === */
.cookie-banner {
  position: fixed;
  left: 1rem; right: 1rem; bottom: 1rem;
  z-index: 9999;
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
  justify-content: space-between;
  background: var(--white, #fff);
  color: var(--text-dark, #0D1B2A);
  border: 1px solid var(--border, rgba(26,68,128,0.12));
  border-radius: var(--r, 4px);
  padding: 0.85rem 1.1rem;
  box-shadow: 0 6px 24px var(--shadow-md, rgba(14,43,86,0.14));
  font-family: 'Inter', sans-serif;
  animation: cookieUp 0.35s ease;
}
@keyframes cookieUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.cookie-banner-text { flex: 1 1 300px; margin: 0; font-size: 0.8rem; line-height: 1.5; color: var(--text-mid, #2C4A6E); }
.cookie-banner-link { color: var(--blue, #1A4480); text-decoration: underline; }
.cookie-banner-link:hover { color: var(--blue-hover, #2356A0); }
.cookie-banner-actions { display: flex; gap: 0.5rem; flex-shrink: 0; }
.cookie-btn {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 9px 18px;
  border-radius: var(--r, 4px);
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.cookie-btn--accept { background: var(--blue, #1A4480); color: #fff; border-color: var(--blue, #1A4480); }
.cookie-btn--accept:hover { background: var(--blue-hover, #2356A0); border-color: var(--blue-hover, #2356A0); }
.cookie-btn--decline { background: transparent; color: var(--text-mid, #2C4A6E); border-color: rgba(26,68,128,0.28); }
.cookie-btn--decline:hover { border-color: var(--blue, #1A4480); color: var(--blue, #1A4480); }
@media (max-width: 560px) {
  .cookie-banner {
    left: 0; right: 0; bottom: 0;
    max-width: none;
    border-radius: 0;
    border-left: 0; border-right: 0; border-bottom: 0;
    padding: 0.7rem 0.9rem;
    gap: 0.55rem;
  }
  .cookie-banner-text { flex: 1 1 100%; font-size: 0.74rem; }
  .cookie-banner-actions { width: 100%; }
  .cookie-btn { flex: 1; padding: 9px 8px; font-size: 0.7rem; }
}
