:root{
  --bg:#fbfcff;
  --surface:#ffffff;
  --muted:#334155;
  --text:#052733;
  --border: rgba(2,6,23,0.06);
  --border-light: rgba(255,255,255,0.06);
  --space:1.25rem;
  --gutter:1rem;
  --yellow:#ffd166;
  --green:#06d6a0;
  --blue:#118ab2;
  --brand:#0f4c81;
  --accent-gradient:linear-gradient(135deg,var(--yellow),var(--green) 55%,var(--blue));
  --accent: #ff8a00; /* warm accent — subtle */
  --cta-gradient: linear-gradient(90deg,var(--blue),var(--green),var(--accent));
  --radius:12px;
  --container:1100px;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;
}
/* Skip link for keyboard users */
.skip-link{position:absolute;left:12px;top:12px;background:var(--brand);color:#fff;padding:.45rem .6rem;border-radius:6px;z-index:999;transform:translateY(-200%);transition:transform .18s ease}
.skip-link:focus{transform:none;outline:3px solid rgba(17,58,107,0.18)}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);background-image:linear-gradient(180deg, rgba(6,76,120,0.16), rgba(255,255,255,0.04)), url('../assets/location.jpg');background-repeat:no-repeat;background-attachment:fixed;background-size:cover;background-position:center center}

/* soft overlay to keep foreground readable */
body::before{content:"";position:fixed;inset:0;background:linear-gradient(180deg, rgba(6,76,120,0.12), rgba(255,255,255,0.18) 36%, rgba(0,10,20,0.04) 100%);pointer-events:none;mix-blend-mode:normal}
.container{max-width:var(--container);margin:0 auto;padding:var(--space)}
.header-row{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;gap:.6rem;align-items:center;font-weight:600;color:var(--brand);text-decoration:none}
.nav{display:flex;gap:var(--gutter);align-items:center}
.nav a{color:var(--brand);text-decoration:none;padding:.5rem .8rem;border-radius:8px;transition:color .18s ease,background .18s ease}
.nav a:hover,.nav a:focus{color:var(--accent)}
.nav a.cta{background:var(--brand);color:#fff}
.menu-toggle{display:none;background:none;border:0;font-size:1.3rem}
.site-header{position:sticky;top:0;z-index:40;background:transparent;padding:.75rem 0;backdrop-filter:blur(6px)}
.site-header .logo{color:#fff}
.site-header .nav a{color:rgba(255,255,255,0.95)}
.site-header .nav a.cta{background:#fff;color:var(--brand)}

/* small header brand shown on the left in the transparent header (mobile) */
.mobile-header-brand{display:none}
@media (max-width:900px){
  .mobile-header-brand{display:block;color:rgba(255,255,255,0.95);font-weight:700;margin-left:.4rem;font-size:1rem}
  /* keep the header layout tidy when brand is present */
  .header-row{gap:.4rem}
}

/* logo styling: header and hero */
.site-header .logo img{height:48px;width:auto;display:block;image-rendering:optimizeQuality;-webkit-font-smoothing:antialiased;object-fit:contain}
.logo-emblem, .logo-full{display:inline-block;vertical-align:middle}
.logo-emblem{width:44px;height:auto}
.logo-full{height:48px;width:auto}
.site-header .brand{color:rgba(255,255,255,0.95);font-weight:700}

.hero-image{display:flex;align-items:center;justify-content:center}
.hero-image img{width:100%;max-width:500px;height:auto;object-fit:contain;border-radius:18px;background:rgba(255,255,255,0.94);padding:20px;box-shadow:0 36px 90px rgba(2,6,23,0.20);border:1px solid rgba(0,0,0,0.06)}

@media (max-width:900px){
  .hero-image img{max-width:360px;padding:14px}
  .site-header .logo img{height:40px;max-height:40px}
}

/* show emblem on small screens, full logo on larger */
.logo-emblem{display:none;border-radius:8px;object-fit:contain}
.logo-full{display:inline-block;object-fit:contain}
@media (max-width:900px){
  .logo-emblem{display:inline-block;margin-right:.6rem}
  .logo-full{display:none}
  .site-header .brand{display:none}
}
/* ensure PNG emblem shows proportionally on small screens */
@media (max-width:460px){
  .logo-emblem{height:34px;width:auto}
  .site-header .logo img{height:34px}
}
.hero{position:relative;padding:3rem 0;}
.hero::before{
  content:"";position:absolute;right:-120px;top:-40px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle at 20% 20%,var(--yellow) 0%, transparent 30%),radial-gradient(circle at 80% 80%,var(--green) 0%, transparent 30%),radial-gradient(circle at 50% 50%,var(--blue) 0%, transparent 40%);opacity:0.14;filter:blur(36px);transform:rotate(12deg);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 360px;gap:2rem;align-items:center}
.hero h1{font-size:2.2rem;margin:.2rem 0}
.lead{font-size:1.1rem;color:var(--muted);margin:0}
.meta{margin-top:.5rem;color:var(--muted)}
.hero-ctas{margin-top:1.1rem;display:flex;gap:.6rem}
.btn{display:inline-block;padding:.7rem 1rem;border-radius:10px;text-decoration:none;border:1px solid transparent;transition:transform .18s ease,box-shadow .18s ease}
.btn:hover{transform:translateY(-3px)}
.btn-primary{background:var(--cta-gradient);background-size:200% 200%;color:#fff;font-weight:700;box-shadow:0 12px 36px rgba(2,6,23,0.12);transition:transform .18s ease,box-shadow .18s ease;animation:btnShift 6s ease-in-out infinite}
.btn-primary:hover{transform:translateY(-3px) scale(1.02)}
.btn-primary:active{transform:translateY(-1px)}
.btn-ghost{background:transparent;border:1px solid rgba(15,76,129,0.08);color:var(--brand)}
.hero-card{background:rgba(255,255,255,0.08);padding:1rem;border-radius:var(--radius);box-shadow:0 18px 48px rgba(2,6,23,0.12);border:1px solid rgba(255,255,255,0.06);backdrop-filter:blur(8px)}
.quick-info{list-style:none;margin:0;padding:0;color:var(--muted)}
.section{padding:2rem 0}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.patient-cards .card{display:flex;flex-direction:column;justify-content:space-between;min-height:180px}
.patient-cards .card-icon{font-size:1.6rem;margin-bottom:.6rem}
.patient-cards .card-actions{margin-top:1rem}

/* features cards styling */
.features-cards .card{display:flex;flex-direction:column;justify-content:flex-start;min-height:170px;padding:1rem}
.features-cards .feature-icon{font-size:1.8rem;margin-bottom:.6rem}
.features-cards h3{margin:.2rem 0 .4rem}
.nav{display:flex;gap:var(--gutter);align-items:center;align-self:stretch}
.nav a{color:var(--brand);text-decoration:none;padding:.55rem .95rem;border-radius:10px;font-weight:600;border:1px solid transparent}
.nav a:hover,.nav a:focus{background:rgba(15,76,129,0.06);outline:none}
.nav a.cta{background:var(--brand);color:#fff;padding:.55rem 1rem;border-radius:999px}
.nav a.cta:hover,.nav a.cta:focus{filter:brightness(.96)}

/* Active / current link */
.nav a[aria-current="page"], .nav a.active{background:linear-gradient(90deg,rgba(255,138,0,0.08),rgba(17,138,178,0.06));border-color:rgba(15,76,129,0.08)}
.patient-list{columns:2;gap:1rem}
.contact-grid{display:grid;grid-template-columns:1fr minmax(420px,820px);gap:1.5rem}
.contact-form label{display:block;margin-bottom:.8rem}
.contact-form input,.contact-form textarea{width:100%;padding:.6rem;border-radius:8px;border:1px solid #e6e9ef}
.form-actions{display:flex;gap:.6rem;margin-top:.8rem}
.form-status{margin-top:.6rem;color:var(--brand)}
.hero{position:relative;padding:3rem 0;}
.map-placeholder{height:140px;border-radius:10px;background:linear-gradient(90deg,#f0f4f8,#ffffff);display:flex;align-items:center;justify-content:center;color:var(--muted)}
.section{padding:2rem 0}
.site-footer{padding:1.6rem 0;text-align:center;color:var(--muted)}
.card{background:rgba(255,255,255,0.95);padding:1rem;border-radius:12px;box-shadow:0 6px 18px rgba(12,23,36,0.06), 0 0 30px var(--card-glow, rgba(17,138,178,0.08));transition:transform .22s cubic-bezier(.2,.9,.3,1),box-shadow .22s ease;border:2px solid transparent;color:var(--text);backdrop-filter:blur(6px);position:relative;overflow:visible}

/* Full-border glow accents: use subtle colored outer glows per card */
.cards-grid .card:nth-child(4n+1), .features-cards .card:nth-child(4n+1), .team-grid .card:nth-child(4n+1), .faq-cards .card:nth-child(4n+1){
  --card-glow: rgba(255,209,102,0.12);
  --card-glow-strong: rgba(255,209,102,0.20);
  border-color: rgba(255,209,102,0.22);
}
.cards-grid .card:nth-child(4n+2), .features-cards .card:nth-child(4n+2), .team-grid .card:nth-child(4n+2), .faq-cards .card:nth-child(4n+2){
  --card-glow: rgba(6,214,160,0.12);
  --card-glow-strong: rgba(6,214,160,0.20);
  border-color: rgba(6,214,160,0.22);
}
.cards-grid .card:nth-child(4n+3), .features-cards .card:nth-child(4n+3), .team-grid .card:nth-child(4n+3), .faq-cards .card:nth-child(4n+3){
  --card-glow: rgba(17,138,178,0.12);
  --card-glow-strong: rgba(17,138,178,0.20);
  border-color: rgba(17,138,178,0.22);
}
.cards-grid .card:nth-child(4n+4), .features-cards .card:nth-child(4n+4), .team-grid .card:nth-child(4n+4), .faq-cards .card:nth-child(4n+4){
  --card-glow: rgba(255,138,0,0.12);
  --card-glow-strong: rgba(255,138,0,0.20);
  border-color: rgba(255,138,0,0.22);
}

/* Make glow more prominent on hover and add a soft pulse */
.card:hover{
  box-shadow:0 16px 44px rgba(12,23,36,0.12), 0 0 64px var(--card-glow, rgba(17,138,178,0.12));
  animation: glowPulse 1.6s ease-in-out infinite;
}

@keyframes glowPulse{
  0%{box-shadow:0 12px 34px rgba(12,23,36,0.10), 0 0 40px var(--card-glow, rgba(17,138,178,0.08))}
  50%{box-shadow:0 20px 60px rgba(12,23,36,0.12), 0 0 86px var(--card-glow-strong, rgba(17,138,178,0.14))}
  100%{box-shadow:0 12px 34px rgba(12,23,36,0.10), 0 0 40px var(--card-glow, rgba(17,138,178,0.08))}
}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 46px rgba(12,23,36,0.10)}
.contact-grid{display:grid;grid-template-columns:1fr minmax(420px,820px);gap:1.5rem}
.map-container{width:100%;border-radius:10px;overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9;max-height:560px}
  .menu-toggle{display:block;padding:.35rem .55rem;background:var(--surface);border:1px solid rgba(2,6,23,0.04);border-radius:8px;color:var(--brand);font-size:1.3rem;cursor:pointer;position:relative;z-index:220}
  .nav{position:fixed;right:12px;top:64px;background:rgba(255,255,255,0.98);backdrop-filter:blur(8px);flex-direction:column;padding:.6rem;border-radius:12px;box-shadow:0 12px 40px rgba(2,6,23,0.10);display:none;z-index:9999;min-width:220px;max-width:92%;transform:translateY(-8px);opacity:0;transition:transform .22s ease,opacity .18s ease}
  .nav-mobile-brand{display:none}
  .nav.show{display:flex;transform:translateY(0);opacity:1}
  /* override header link colors when nav is a white panel on mobile */
  .site-header .nav a{color:var(--brand)}
  .site-header .nav a.cta{background:var(--brand);color:#fff}

  /* show a small brand/title inside the mobile nav panel */
  /* only show the brand when the nav panel is open */
  .nav-mobile-brand{color:var(--brand);font-weight:700;padding:.4rem .6rem;margin-bottom:.4rem;border-bottom:1px solid rgba(2,6,23,0.04);align-self:flex-start;display:none}
  .nav.show .nav-mobile-brand{display:block}
  .nav .nav-mobile-brand{font-size:1rem}
  /* simplify heavy background on small screens for performance */
  body{background-attachment:scroll;background-size:cover;background-position:top center}
/* hero image and content tweaks */
.hero-content h1{font-size:2.6rem;margin:0;color:#fff;text-shadow:0 6px 24px rgba(2,6,23,0.28)}
.hero-content .trusted{margin-top:1rem;display:flex;gap:.6rem;flex-wrap:wrap}
.pill{background:linear-gradient(90deg,var(--yellow),var(--accent) 40%,var(--green));padding:.35rem .6rem;border-radius:999px;color:#073042;font-weight:600;font-size:.9rem}
.hero-image{display:flex;align-items:center;justify-content:center}
.hero-image img{max-width:100%;height:auto;border-radius:14px;box-shadow:0 18px 40px rgba(12,23,36,0.08);border:1px solid rgba(12,23,36,0.03)}

/* features */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1rem}
.feature{background:transparent;padding:1rem;border-radius:12px}
.feature .icon{font-size:1.6rem;margin-bottom:.4rem}
.feature h4{margin:.2rem 0}

/* testimonials */
.testimonial p{font-style:italic;color:var(--muted)}

/* CTA strip above footer */
.cta-strip{background:linear-gradient(90deg,var(--blue),var(--green));color:#fff;padding:1.4rem;border-radius:12px;margin:2rem 0;display:flex;align-items:center;justify-content:space-between;box-shadow:0 18px 46px rgba(2,6,23,0.12)}
.cta-strip .btn{border-radius:8px}

@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-image{order:-1;margin-bottom:1rem}
}

/* ensure contact form and map sit side-by-side on tablet/desktop */
@media (min-width:700px){
  .contact-grid{grid-template-columns:1fr 460px;align-items:start}
  .map-container{max-height:520px}
}

/* subtle animations */
@keyframes floaty{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}
.feature .icon{animation:floaty 6s ease-in-out infinite}

@keyframes btnShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.9,.3,1);will-change:opacity,transform}
.reveal.visible{opacity:1;transform:none}
/* small stagger helpers */
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}

/* micro animation for CTA when visible */
.cta-strip.reveal.visible{transform:translateY(0) scale(1);box-shadow:0 20px 50px rgba(12,23,36,0.08)}

/* hover micro motion for cards already has transform; add subtle entrance */
.card.reveal{transform:translateY(20px)}
.card.reveal.visible{transform:none}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1rem}
.team-member{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1rem;color:var(--text)}
.team-member img{border-radius:999px;background:linear-gradient(90deg,var(--yellow),var(--green));padding:6px}

/* FAQ */
.faq.alt{background:linear-gradient(180deg,rgba(6,214,160,0.02),transparent);padding:2rem;border-radius:12px}
.faq-list{display:grid;gap:.6rem}
.faq-q{width:100%;text-align:left;padding:.8rem 1rem;background:#fff;border-radius:10px;border:1px solid rgba(2,6,23,0.08);font-weight:700;color:var(--text)}
.faq-a{padding:.8rem 1rem;display:none;background:transparent;color:var(--muted)}
.faq-item.active .faq-a{display:block}

/* FAQ cards styling */
.faq-cards .card{padding:0;border-radius:12px}
.faq-cards .card{padding:0;border-radius:12px;min-height:160px}
.faq-cards .card-body{padding:1.25rem;display:flex;flex-direction:column;justify-content:flex-start}
.faq-cards .faq-q{display:block;width:100%;text-align:left;background:transparent;border:0;padding:0;font-size:1.06rem;font-weight:700;cursor:pointer}
/* use max-height transition so answers expand smoothly */
.faq-cards .faq-a{display:block;max-height:0;overflow:hidden;padding-top:0;color:var(--muted);line-height:1.6;transition:max-height .32s ease,padding-top .28s ease}
.faq-cards .faq-item{overflow:hidden}
.faq-cards .faq-item.active{box-shadow:0 18px 46px rgba(12,23,36,0.06)}
.faq-cards .faq-item.active .faq-a{max-height:400px;padding-top:.6rem}

/* location image beside map */
.contact-info{display:flex;flex-direction:column;gap:.6rem;padding:1rem;border-radius:10px}
.contact-info h3{margin:0 0 .4rem;font-size:1.05rem}
.contact-info p{margin:.25rem 0;color:var(--muted);line-height:1.4}
.contact-info a{color:var(--brand);text-decoration:none}
.map-and-photo{display:grid;grid-template-columns:1fr;gap:.75rem;align-items:start}
.map-and-photo img{width:100%;height:auto;object-fit:cover;border-radius:10px;max-width:220px}

@media (min-width:900px){
  .map-and-photo{grid-template-columns:1fr 160px}
  .map-and-photo img{width:160px;height:auto}
}

/* responsive embedded map */
.map-container{width:100%;border-radius:10px;overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9;max-height:560px}
.map-container iframe{width:100%;height:100%;border:0;display:block}
@media (min-width:900px){.map-container{max-height:360px}}
@media (min-width:1200px){.map-container{max-height:420px}}

@media (max-width:900px){
  .map-and-photo{grid-template-columns:1fr}
}

/* Floating action buttons (FABs) */
.fab-group{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:.6rem;z-index:320}
.fab{display:inline-flex;align-items:center;gap:.6rem;padding:.6rem .9rem;border-radius:999px;color:#fff;text-decoration:none;font-weight:700;box-shadow:0 12px 30px rgba(2,6,23,0.18);transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease;backdrop-filter:blur(6px)}
.fab svg{height:18px;width:18px;flex-shrink:0}
.fab:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(2,6,23,0.22)}
.fab-whatsapp{background:#25D366}
.fab-booking{background:linear-gradient(90deg,var(--blue),var(--green))}

/* small floating motion */
@keyframes fabFloat{0%{transform:translateY(0)}50%{transform:translateY(-4px)}100%{transform:translateY(0)}}
.fab{animation:fabFloat 6s ease-in-out infinite}

@media (max-width:520px){
  .fab-group{right:12px;bottom:12px}
  .fab{padding:.5rem .6rem;font-size:.92rem}
  /* keep FABs expanded on mobile (show labels) */
  .fab{padding:.5rem .8rem;font-size:.96rem}
  .fab svg{height:20px;width:20px}
}

/* subtle entrance for FABs */
.fab-group{opacity:0;transform:translateY(8px);transition:opacity .36s ease,transform .36s ease}
.fab-group.visible{opacity:1;transform:none}

/* small decorative accent for headings */
h2::after{
  content: "";
  display: block;
  /* longer, responsive underline */
  width: min(240px, 50%);
  height: 6px;
  border-radius: 6px;
  margin-top: .6rem;
  background: linear-gradient(90deg, var(--yellow), var(--green), var(--accent), var(--blue));
  transform-origin: left;
  transform: scaleX(0);
  /* animate growth on load */
  animation: growLine 700ms cubic-bezier(.2,.9,.2,1) forwards;
}

@keyframes growLine{
  from{ transform: scaleX(0); }
  to{ transform: scaleX(1); }
}

/* subtle hover/enlarge effect */
h2:hover::after{
  transform: scaleX(1.05);
  transition: transform 220ms ease;
}

/* Button responsiveness: avoid horizontal overflow and ensure good tap targets */
.btn{white-space:normal;max-width:100%;word-break:break-word}

/* Make card/action buttons stack and fill width on small screens */
@media (max-width:520px){
  .card .card-actions{display:flex;flex-direction:column;gap:.5rem}
  .card .card-actions .btn, .cards-grid .btn{width:100%;text-align:center}
  .contact-form .form-actions{flex-direction:column;align-items:stretch}
  .contact-form .form-actions .btn{width:100%}
}

/* Prevent FAB labels from creating overflow on very narrow screens */
@media (max-width:360px){
  .fab span{display:none}
  .fab{padding:.45rem;gap:.45rem}
}

/* Mobile-specific improvements: tighten spacing, responsive type and CTA stacking */
@media (max-width:520px){
  :root{ --space:0.75rem; --gutter:0.6rem; }
  html{font-size:16px}
  .container{padding:0.8rem}
  .hero{padding:1.6rem 0}
  /* avoid horizontal scroll caused by decorative elements */
  .hero{overflow:hidden}
  html,body{overflow-x:hidden}
  /* responsive heading scale */
  .hero-content h1{font-size:clamp(1.6rem,6.8vw,2.2rem);line-height:1.05;margin-bottom:.4rem}
  .lead{font-size:clamp(.98rem,3.6vw,1.05rem)}
  .meta{font-size:.95rem}
  /* stack CTA buttons and make them full width for easier tapping */
  .hero-ctas{flex-direction:column;align-items:stretch}
  /* place CTAs side-by-side on most phones, but stack on very narrow screens */
  .hero-ctas{flex-direction:row;align-items:center;gap:.5rem}
  .hero-ctas .btn{flex:1 1 0;min-width:0;width:auto;max-width:none;padding:.6rem;border-radius:10px;text-align:center}
  .hero-ctas .btn + .btn{margin-top:0}
  /* reduce hero image padding and shadow on very small screens */
  .hero-image img{padding:10px;box-shadow:0 12px 30px rgba(12,23,36,0.06)}
  /* streamline header: smaller logo and tighter header spacing */
  .site-header{padding:.45rem 0}
  .site-header .logo img{height:34px}
  .menu-toggle{top:8px}
  /* make nav panel full-width-ish on tiny screens */
  .nav{right:8px;left:auto;min-width:160px;max-width:92%}
  /* contact and map stack vertically */
  .contact-grid{grid-template-columns:1fr}
  .map-container{aspect-ratio:4/3;max-height:360px}
  /* scale down card padding to avoid long scrolls */
  .card{padding:.8rem}
  /* FAB sizing and position adjustments */
  .fab-group{right:10px;bottom:10px}
  .fab{padding:.5rem .7rem;font-size:.95rem}
}

/* further constrain hero image on small phones to avoid overpowering the viewport */
@media (max-width:520px){
  .hero-image img{max-width:260px;width:100%;height:auto;padding:8px;border-radius:12px}
}

@media (max-width:380px){
  .hero-image img{max-width:220px;padding:6px}
}

/* Hide hero image entirely on small screens for a cleaner, text-first layout */
@media (max-width:520px){
  .hero-image{display:none !important}
  .hero{padding-top:1rem;padding-bottom:1rem}
}

@media (max-width:380px){
  .hero-content h1{font-size:clamp(1.4rem,7.2vw,1.9rem)}
  .lead{font-size:.95rem}
  /* on very narrow phones, stack CTAs to avoid cramped buttons */
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{padding:.6rem;width:100%;display:block}
}

/* Top banner (inserted above header) */
.top-banner{background:#ffffff;padding:.35rem 0;border-bottom:1px solid rgba(2,6,23,0.04)}
.top-banner .banner-inner{max-width:var(--container);margin:0 auto;padding:0 var(--space);display:flex;align-items:center;justify-content:center}
/* Full-width header image */
.top-banner{background:transparent;padding:0;margin-bottom:0}
.top-banner .banner-inner{width:100%;max-width:100%;margin:0}
.top-banner img{width:100%;height:auto;display:block;object-fit:cover;max-height:360px}

@media (max-width:900px){
  .top-banner img{max-height:220px}
}

@media (max-width:520px){
  .top-banner img{max-height:140px}
}

/* Banner layout: logo left + text right */
.banner-inner{display:flex;align-items:center;gap:1.25rem}
.banner-left img{max-height:160px;width:auto;display:block}
.banner-right{display:flex;flex-direction:column;gap:0.15rem}
.banner-right h1{margin:0;font-size:1.6rem;color:var(--brand);font-weight:800;letter-spacing:0.6px}
.banner-role{font-weight:700;color:var(--brand);opacity:0.9}
.banner-meta{color:var(--muted);font-size:0.95rem}

@media (max-width:900px){
  .banner-inner{gap:.8rem}
  .banner-left img{max-height:120px}
  .banner-right h1{font-size:1.3rem}
}

@media (max-width:520px){
  .banner-inner{flex-direction:column;align-items:center;text-align:center;padding:0}
  .banner-right{gap:0.1rem}
  .banner-left img{max-height:90px}
  .banner-right h1{font-size:1.15rem}
  .banner-meta{font-size:0.9rem}
}

/* Cookie consent banner */
.cookie-consent{position:fixed;left:0;right:0;bottom:16px;background:rgba(255,255,255,0.98);box-shadow:0 12px 36px rgba(2,6,23,0.08);padding:.6rem 0;border-radius:10px;z-index:1000}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.cookie-text{color:var(--muted);font-size:.95rem}
.cookie-actions{display:flex;gap:.5rem}

/* Sticky mobile booking CTA */
.sticky-cta{position:fixed;left:12px;right:12px;bottom:78px;display:flex;justify-content:center;z-index:980}
.sticky-cta .btn{padding:.9rem 1.1rem;border-radius:999px;font-weight:800}

@media (min-width:700px){.sticky-cta{display:none}}
