/* ==========================================================
   MediCare Premium Theme - Custom Stylesheet
   ========================================================== */

:root {
  --primary: #0d6efd;
  --primary-dark: #0a58ca;
  --accent: #0f766e;
  --accent-dark: #115e59;
  --gradient: linear-gradient(135deg, #0d6efd 0%, #0f766e 100%);
  --gradient-soft: linear-gradient(135deg, rgba(13,110,253,.08) 0%, rgba(15,118,110,.09) 100%);
  --dark: #0f172a;
  --muted: #64748b;
  --bg: #f8fafc;
  --white: #ffffff;
  --surface: #ffffff;
  --surface-soft: #f8fafc;
  --surface-strong: #f1f5f9;
  --border: #e2e8f0;
  --shadow-sm: 0 4px 20px rgba(15,23,42,.06);
  --shadow-md: 0 10px 40px rgba(15,23,42,.08);
  --shadow-lg: 0 20px 60px rgba(15,23,42,.12);
  --radius: 16px;
  --radius-lg: 24px;
  color-scheme: light;
}

html[data-site-theme="dark"] {
  --primary: #60a5fa;
  --primary-dark: #3b82f6;
  --accent: #5eead4;
  --accent-dark: #2dd4bf;
  --gradient: linear-gradient(135deg, #2563eb 0%, #0f766e 100%);
  --gradient-soft: linear-gradient(135deg, rgba(96,165,250,.14) 0%, rgba(45,212,191,.12) 100%);
  --dark: #e5edf8;
  --muted: #94a3b8;
  --bg: #0b1120;
  --white: #0f172a;
  --surface: #111827;
  --surface-soft: #0b1220;
  --surface-strong: #1e293b;
  --border: #263244;
  --shadow-sm: 0 4px 20px rgba(0,0,0,.22);
  --shadow-md: 0 10px 40px rgba(0,0,0,.28);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.35);
  color-scheme: dark;
}

@media (prefers-color-scheme: dark) {
  html:not([data-site-theme="light"]) {
    --primary: #60a5fa;
    --primary-dark: #3b82f6;
    --accent: #5eead4;
    --accent-dark: #2dd4bf;
    --gradient: linear-gradient(135deg, #2563eb 0%, #0f766e 100%);
    --gradient-soft: linear-gradient(135deg, rgba(96,165,250,.14) 0%, rgba(45,212,191,.12) 100%);
    --dark: #e5edf8;
    --muted: #94a3b8;
    --bg: #0b1120;
    --white: #0f172a;
    --surface: #111827;
    --surface-soft: #0b1220;
    --surface-strong: #1e293b;
    --border: #263244;
    --shadow-sm: 0 4px 20px rgba(0,0,0,.22);
    --shadow-md: 0 10px 40px rgba(0,0,0,.28);
    --shadow-lg: 0 20px 60px rgba(0,0,0,.35);
    color-scheme: dark;
  }
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Poppins', system-ui, -apple-system, sans-serif;
  color: var(--dark);
  background: var(--white);
  line-height: 1.7;
  overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6 { font-weight: 700; letter-spacing: -.02em; color: var(--dark); }
a { text-decoration: none; transition: all .3s ease; }
img { max-width: 100%; height: auto; }

a:focus-visible, button:focus-visible, .btn:focus-visible, .form-control:focus-visible, .form-select:focus-visible, .accordion-button:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 3px;
}

.skip-link {
  background: var(--dark);
  border-radius: 0 0 12px 0;
  color: #fff;
  font-weight: 700;
  left: 0;
  padding: .75rem 1rem;
  position: fixed;
  top: 0;
  transform: translateY(-120%);
  z-index: 2000;
}

.skip-link:focus {
  color: #fff;
  outline: 3px solid var(--accent);
  outline-offset: 2px;
  transform: translateY(0);
}

main:focus {
  outline: 0;
}

.text-gradient {
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.btn { font-weight: 600; padding: .8rem 1.8rem; border-radius: 50px; transition: all .3s ease; }
.btn-primary { background: var(--gradient); border: none; color: #fff; box-shadow: 0 8px 24px rgba(13,110,253,.35); }
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(13,110,253,.45); color: #fff; }
.btn-outline-primary { border: 2px solid var(--primary); color: var(--primary); background: transparent; }
.btn-outline-primary:hover { background: var(--primary); color: #fff; transform: translateY(-3px); }
.btn-light-soft { background: rgba(255,255,255,.15); color: #fff; border: 2px solid rgba(255,255,255,.3); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); }
.btn-light-soft:hover { background: #fff; color: var(--primary); }

/* TOPBAR */
.topbar { background: var(--dark); color: rgba(255,255,255,.85); font-size: .875rem; padding: .55rem 0; }
.topbar a { color: rgba(255,255,255,.85); }
.topbar a:hover { color: var(--accent); }
.topbar i { color: var(--accent); margin-right: 6px; }

/* NAVBAR */
.navbar { background: var(--surface); padding: 1rem 0; box-shadow: var(--shadow-sm); transition: all .3s ease; }
.navbar.scrolled { padding: .6rem 0; box-shadow: var(--shadow-md); }
.navbar-brand { font-weight: 800; font-size: 1.6rem; color: var(--dark) !important; display: flex; align-items: center; gap: 0.5rem; }
.navbar-brand i { color: var(--primary); font-size: 1.8rem; }
.navbar-brand span { color: var(--dark); }
.navbar-logo { --logo-height: 50px; height: var(--logo-height); width: auto;  object-fit: contain; transition: all .3s ease; }
.navbar.scrolled .navbar-logo { height: calc(var(--logo-height) * 0.85); }

/* Modern Hover Menu */
.navbar-nav .nav-link {
  font-weight: 500;
  color: var(--dark) !important;
  margin: 0 .25rem;
  position: relative;
  padding: .5rem 1rem !important;
  display: flex;
  align-items: center;
  gap: 4px;
  transition: all .3s ease;
}

.navbar-nav .nav-link i.bi-chevron-down {
  font-size: 0.75rem;
  transition: transform .3s ease;
}

.navbar-nav .nav-item.dropdown:hover > .nav-link i.bi-chevron-down {
  transform: rotate(180deg);
}

.navbar-nav .nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 3px;
  background: var(--gradient);
  transition: all .3s ease;
  transform: translateX(-50%);
  border-radius: 3px;
}

.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after {
  width: 60%;
}

.navbar-nav .nav-link:hover {
  color: var(--primary) !important;
}

/* Hover-based Dropdown */
.navbar-nav .dropdown {
  position: relative;
}

.navbar-nav .dropdown-menu {
  display: block;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all .3s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
  min-width: 240px;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  border-radius: var(--radius);
  padding: .75rem;
  margin-top: .5rem !important;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
}

.navbar-nav .dropdown:hover > .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: all;
}

/* Mega Menu for top-level items */
.navbar-nav .mega-dropdown .mega-menu {
  min-width: 320px;
  max-width: 500px;
}

/* Nested Dropdown */
.navbar-nav .dropdown-menu .dropdown {
  position: relative;
}

.navbar-nav .dropdown-menu .dropdown-menu {
  left: 100%;
  top: 0;
  margin-left: .5rem !important;
  margin-top: 0 !important;
}

.navbar-nav .dropdown-menu .dropdown:hover > .dropdown-menu {
  transform: translateX(0);
}

/* Dropdown Items */
.dropdown-item {
  color: var(--dark);
  padding: .75rem 1rem;
  border-radius: 10px;
  font-weight: 500;
  transition: all .2s ease;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background: var(--gradient-soft);
  color: var(--primary);
  transform: translateX(4px);
}

.dropdown-divider {
  margin: .5rem 0;
  border-top: 1px solid var(--border);
  opacity: 0.5;
}
.theme-toggle { align-items: center; background: var(--gradient-soft); border: 1px solid rgba(13,110,253,.16); border-radius: 999px; color: var(--primary); display: inline-flex; height: 44px; justify-content: center; padding: 0; position: relative; transition: all .25s ease; width: 44px; }
.theme-toggle:hover { background: var(--primary); color: #fff; transform: translateY(-2px); }
.theme-toggle__icon { font-size: 1.05rem; line-height: 1; }
.theme-toggle__icon--sun { display: none; }
.theme-toggle[data-theme-current="dark"] .theme-toggle__icon--moon { display: none; }
.theme-toggle[data-theme-current="dark"] .theme-toggle__icon--sun { display: inline-flex; }

/* NAVBAR ACTIONS */
.navbar-actions { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
.nav-btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.625rem 1.25rem; border-radius: 12px; font-weight: 600; font-size: 0.9375rem; transition: all 0.25s ease; text-decoration: none; border: none; cursor: pointer; white-space: nowrap; }
.nav-btn i { font-size: 1.125rem; }
.nav-btn-ghost { background: transparent; color: var(--dark); border: 1px solid transparent; }
.nav-btn-ghost:hover { background: var(--surface-soft); color: var(--primary); }
.nav-btn-outline { background: transparent; color: var(--primary); border: 1px solid var(--primary); }
.nav-btn-outline:hover { background: var(--primary); color: #fff; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(13,110,253,0.25); }
.nav-btn-primary { background: var(--gradient); color: #fff; border: 1px solid transparent; box-shadow: 0 2px 8px rgba(13,110,253,0.2); }
.nav-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(13,110,253,0.35); }

@media (max-width: 991.98px) {
  .navbar-actions { width: 100%; margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--border); }
  .nav-btn { justify-content: center; flex: 1; min-width: 140px; }
  .navbar-actions form { flex: 1; }
  .navbar-actions form .nav-btn { width: 100%; }
}

/* HERO SLIDER */
.hero-slider { position: relative; overflow: hidden; }
.hero-slide { height: 92vh; min-height: 620px; position: relative; background-size: cover; background-position: center; display: flex; align-items: center; }
.hero-slide::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(15,23,42,var(--hero-overlay, .85)) 0%, rgba(13,110,253,var(--hero-overlay, .55)) 100%); }
.hero-content { position: relative; z-index: 2; color: #fff; max-width: 720px; }
.hero-content .badge-pill { display: inline-block; background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.3); padding: .5rem 1.2rem; border-radius: 50px; font-size: .85rem; margin-bottom: 1.5rem; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); }
.hero-content h1 { font-size: clamp(2.2rem, 5vw, 4rem); color: #fff; margin-bottom: 1.25rem; line-height: 1.1; }
.hero-content h1 span { color: #5eead4; }
.hero-content p { font-size: 1.15rem; opacity: .92; margin-bottom: 2rem; }

.swiper-button-next, .swiper-button-prev { width: 56px; height: 56px; background: rgba(255,255,255,.15); border: 2px solid rgba(255,255,255,.3); border-radius: 50%; color: #fff !important; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); transition: all .3s; }
.swiper-button-next:hover, .swiper-button-prev:hover { background: var(--primary); border-color: var(--primary); }
.swiper-button-next:focus-visible, .swiper-button-prev:focus-visible { background: var(--primary); border-color: var(--accent); outline-color: #fff; }
.swiper-button-next::after, .swiper-button-prev::after { font-size: 18px; font-weight: 800; }
.swiper-pagination-bullet { width: 12px; height: 12px; background: #fff; opacity: .5; }
.swiper-pagination-bullet-active { opacity: 1; background: var(--accent); width: 32px; border-radius: 6px; }

/* SECTION */
section { padding: 6rem 0; }
.section-title { margin-bottom: 3.5rem; }
.section-title .small-tag { display: inline-block; color: var(--primary); font-weight: 600; text-transform: uppercase; letter-spacing: 3px; font-size: .85rem; margin-bottom: .75rem; }
.small-tag { display: inline-block; color: var(--primary); font-weight: 600; text-transform: uppercase; letter-spacing: 3px; font-size: .85rem; margin-bottom: .75rem; }
.section-title h2 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); margin-bottom: 1rem; }
.section-title p { color: var(--muted); font-size: 1.05rem; }
.home-info-section { padding: 4.5rem 0; }

/* INFO STRIP */
.info-strip { margin-top: -80px; position: relative; z-index: 5; }
.info-card { background: var(--surface); padding: 2.2rem 1.8rem; border-radius: var(--radius); box-shadow: var(--shadow-md); border-top: 4px solid transparent; transition: all .35s ease; height: 100%; }
.info-card:hover { transform: translateY(-8px); border-top-color: var(--primary); }
.info-card .ic { width: 64px; height: 64px; border-radius: 16px; background: var(--gradient-soft); color: var(--primary); display: inline-flex; align-items: center; justify-content: center; font-size: 1.7rem; margin-bottom: 1.2rem; }
.info-card h5 { margin-bottom: .6rem; }
.info-card p { color: var(--muted); margin: 0; font-size: .95rem; }

/* SERVICES */
.service-card { background: var(--surface); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: all .35s ease; height: 100%; }
.service-card:hover { transform: translateY(-10px); box-shadow: var(--shadow-lg); }
.service-card .img-wrap { position: relative; height: 220px; overflow: hidden; }
.service-card .img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.service-card:hover .img-wrap img { transform: scale(1.08); }
.service-card .ic-circle { position: absolute; left: 1.5rem; bottom: -28px; width: 56px; height: 56px; background: var(--gradient); border-radius: 50%; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; box-shadow: 0 10px 24px rgba(13,110,253,.4); }
.service-card .body { padding: 2.4rem 1.8rem 1.8rem; }
.service-card h5 { margin-bottom: .75rem; }
.service-card p { color: var(--muted); font-size: .95rem; margin-bottom: 1.25rem; }
.service-card .more { font-weight: 600; color: var(--primary); display: inline-flex; align-items: center; gap: 6px; }
.service-card .more:hover { gap: 12px; color: var(--accent-dark); }

/* ABOUT */
.about-img-wrap { position: relative; }
.about-img-wrap .main-img { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.about-img-wrap .badge-float { position: absolute; bottom: -30px; left: -30px; background: var(--gradient); color: #fff; padding: 1.5rem 2rem; border-radius: var(--radius); box-shadow: var(--shadow-lg); }
.about-img-wrap .badge-float h3 { color: #fff; font-size: 2.2rem; margin: 0; }
.about-img-wrap .badge-float span { font-size: .9rem; opacity: .9; }
.about-list { list-style: none; padding: 0; }
.about-list li { display: flex; align-items: flex-start; gap: 12px; margin-bottom: .9rem; color: var(--muted); }
.about-list li i { color: var(--accent); font-size: 1.3rem; flex-shrink: 0; }

/* STATS */
.stats-section { background: var(--gradient); color: #fff; padding: 4.5rem 0; }
.stat-item { text-align: center; }
.stat-item .num { font-size: 3rem; font-weight: 800; margin-bottom: .25rem; }
.stat-item .lbl { font-size: 1rem; opacity: .9; text-transform: uppercase; letter-spacing: 1px; }

/* PROMO COUNTDOWN */
.promo-countdown-section { background: var(--bg); }
.promo-countdown { align-items: center; background: var(--gradient); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); color: #fff; display: grid; gap: 1.5rem; grid-template-columns: minmax(0, 1fr) auto auto; margin-top: -2.8rem; overflow: hidden; padding: 1.35rem; position: relative; z-index: 5; }
.promo-countdown::before { background: radial-gradient(circle at 20% 50%, rgba(255,255,255,.2), transparent 34%); content: ''; inset: 0; pointer-events: none; position: absolute; }
.promo-countdown__content, .promo-countdown__timer, .promo-countdown .btn { position: relative; z-index: 1; }
.promo-countdown .small-tag { background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.2); color: #fff; margin-bottom: .6rem; }
.promo-countdown h2 { color: #fff; font-size: clamp(1.35rem, 2.6vw, 2rem); margin-bottom: .4rem; }
.promo-countdown p { color: rgba(255,255,255,.88); margin: 0; max-width: 680px; }
.promo-countdown__timer { display: grid; gap: .55rem; grid-template-columns: repeat(4, minmax(66px, 1fr)); }
.promo-countdown__timer div { background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.18); border-radius: 14px; min-width: 66px; padding: .75rem .65rem; text-align: center; }
.promo-countdown__timer strong { color: #fff; display: block; font-size: 1.35rem; line-height: 1; }
.promo-countdown__timer span { color: rgba(255,255,255,.78); display: block; font-size: .72rem; font-weight: 700; margin-top: .3rem; text-transform: uppercase; }
.promo-countdown[data-expired="true"] .promo-countdown__timer { opacity: .72; }

/* TRUST BADGES */
.trust-badge-section { background: var(--bg); }
.trust-badge-strip { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); display: grid; gap: 0; grid-template-columns: repeat(4, minmax(0, 1fr)); overflow: hidden; }
.trust-badge { align-items: center; border-right: 1px solid var(--border); display: grid; gap: .25rem .85rem; grid-template-columns: auto minmax(0, 1fr); padding: 1.2rem; }
.trust-badge:last-child { border-right: 0; }
.trust-badge span { align-items: center; background: var(--gradient-soft); border-radius: 14px; color: var(--primary); display: inline-flex; font-size: 1.35rem; grid-row: span 2; height: 48px; justify-content: center; width: 48px; }
.trust-badge strong { color: var(--dark); font-size: .98rem; line-height: 1.3; }
.trust-badge small { color: var(--muted); line-height: 1.5; }

/* DOCTORS */
.doctor-card { background: var(--surface); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: all .35s; height: 100%; display: block; text-decoration: none; color: inherit; cursor: pointer; }
.doctor-card:hover { transform: translateY(-10px); box-shadow: var(--shadow-lg); }
.doctor-card .photo { position: relative; height: 320px; overflow: hidden; }
.doctor-card .photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.doctor-card:hover .photo img { transform: scale(1.05); }
.doctor-card .socials { position: absolute; right: 1rem; bottom: 1rem; display: flex; flex-direction: column; gap: .5rem; opacity: 0; transform: translateX(20px); transition: all .4s ease; }
.doctor-card:hover .socials { opacity: 1; transform: translateX(0); }
.doctor-card .socials a { width: 40px; height: 40px; border-radius: 50%; background: var(--surface); color: var(--primary); display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-sm); }
.doctor-card .socials a:hover { background: var(--primary); color: #fff; }
.doctor-card .body { padding: 1.5rem; text-align: center; }
.doctor-card .body h5 { margin-bottom: .25rem; color: var(--dark); transition: color .3s; }
.doctor-card:hover .body h5 { color: var(--primary); }
.doctor-card .body span { color: var(--primary); font-weight: 500; font-size: .9rem; }

/* TESTIMONIALS */
.testimonial-card { background: var(--surface); border-radius: var(--radius); padding: 2rem; box-shadow: var(--shadow-sm); position: relative; height: 100%; }
.testimonial-card::before { content: '\201C'; position: absolute; top: -10px; right: 20px; font-size: 6rem; background: var(--gradient); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; font-family: Georgia, serif; line-height: 1; }
.testimonial-card p { color: var(--muted); font-style: italic; margin-bottom: 1.5rem; }
.testimonial-card .person { display: flex; align-items: center; gap: 1rem; }
.testimonial-card .person img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; }
.testimonial-card .person .avatar-initial { width: 56px; height: 56px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: var(--gradient); color: #fff; font-weight: 700; flex: 0 0 56px; }
.testimonial-card .person h6 { margin: 0; }
.testimonial-card .person span { color: var(--muted); font-size: .85rem; }
.testimonial-card .stars { color: #ffc107; margin-bottom: .75rem; }
.review-form-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: clamp(1.25rem, 3vw, 2.5rem); }
.review-form-card h3 { margin-bottom: .75rem; }
.review-form-card p, .form-check-label { color: var(--muted); }

/* BLOG */
.blog-toolbar { align-items: center; display: flex; gap: 1rem; justify-content: space-between; }
.blog-search-form { flex: 1 1 420px; max-width: 620px; }
.blog-search-shell { align-items: center; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-sm); display: flex; gap: .7rem; min-height: 56px; padding: .35rem .45rem .35rem 1rem; }
.blog-search-shell i { color: var(--primary); font-size: 1.1rem; }
.blog-search-shell input { background: transparent; border: 0; color: var(--dark); flex: 1; font-weight: 600; min-width: 0; outline: 0; }
.blog-search-shell input::placeholder { color: var(--muted); font-weight: 500; }
.blog-search-shell button { background: var(--gradient); border: 0; border-radius: calc(var(--radius) - 4px); color: #fff; font-weight: 800; min-height: 44px; padding: 0 1.2rem; }
.blog-clear-filter { color: var(--primary); font-weight: 800; white-space: nowrap; }
.blog-filter-bar { align-items: center; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-sm); display: flex; flex-wrap: wrap; gap: .65rem; padding: 1rem; }
.blog-filter-chip { align-items: center; background: var(--surface-soft); border: 1px solid var(--border); border-radius: 999px; color: var(--dark); display: inline-flex; font-weight: 700; gap: .45rem; padding: .62rem 1rem; }
.blog-filter-chip span { align-items: center; background: var(--surface); border-radius: 999px; color: var(--muted); display: inline-flex; font-size: .78rem; justify-content: center; min-width: 1.5rem; padding: .1rem .45rem; }
.blog-filter-chip:hover, .blog-filter-chip.active { background: var(--gradient); border-color: transparent; color: #fff; transform: translateY(-2px); }
.blog-filter-chip:hover span, .blog-filter-chip.active span { background: rgba(255,255,255,.2); color: #fff; }
.blog-card { background: var(--surface); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: all .35s; height: 100%; }
.blog-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); }
.blog-card .img-wrap { height: 230px; overflow: hidden; position: relative; }
.blog-card .img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.blog-card:hover .img-wrap img { transform: scale(1.08); }
.blog-card .cat { position: absolute; top: 1rem; left: 1rem; background: var(--gradient); color: #fff; padding: .35rem 1rem; border-radius: 50px; font-size: .8rem; font-weight: 600; }
.blog-card .body { padding: 1.75rem; }
.blog-card .meta { color: var(--muted); font-size: .85rem; margin-bottom: .75rem; display: flex; gap: 1rem; }
.blog-card .meta i { color: var(--primary); margin-right: 4px; }
.blog-card h5 a { color: var(--dark); }
.blog-card h5 a:hover { color: var(--primary); }
.blog-card p { color: var(--muted); font-size: .95rem; margin: .75rem 0 1rem; }

/* PAGE HEADER */
.page-header { background: linear-gradient(135deg, rgba(15,23,42,.85), rgba(13,110,253,.7)), url('https://images.unsplash.com/photo-1576091160399-112ba8d25d1d?w=1600') center/cover; padding: 7rem 0 5rem; color: #fff; position: relative; }
.page-header h1 { color: #fff; font-size: clamp(2rem, 4vw, 3rem); margin-bottom: .75rem; }
.page-header .breadcrumb { background: transparent; padding: 0; justify-content: center; }
.page-header .breadcrumb-item, .page-header .breadcrumb-item a { color: rgba(255,255,255,.85); }
.page-header .breadcrumb-item.active { color: var(--accent); }
.page-header .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.6); }

/* FAQ */
.accordion-item { background: var(--surface); border: none; margin-bottom: 1rem; border-radius: var(--radius) !important; overflow: hidden; box-shadow: var(--shadow-sm); }
.accordion-button { background: var(--surface); font-weight: 600; padding: 1.25rem 1.5rem; color: var(--dark); border-radius: var(--radius) !important; }
.accordion-button:not(.collapsed) { background: var(--gradient-soft); color: var(--primary); box-shadow: none; }
.accordion-button:focus { box-shadow: none; border-color: transparent; }
.accordion-body { background: var(--surface); padding: 0 1.5rem 1.5rem; color: var(--muted); }

/* FORMS */
.form-control, .form-select { background: var(--surface); border: 2px solid var(--border); border-radius: 12px; color: var(--dark); padding: .85rem 1.1rem; font-size: .95rem; transition: all .3s; }
.form-control::placeholder { color: var(--muted); }
.form-control:focus, .form-select:focus { border-color: var(--primary); box-shadow: 0 0 0 4px rgba(13,110,253,.12); }
.form-control.is-invalid, .form-select.is-invalid, .was-validated .form-control:invalid, .was-validated .form-select:invalid { border-color: #dc3545; box-shadow: none; }
.form-control.is-valid, .form-select.is-valid, .was-validated .form-control:valid, .was-validated .form-select:valid { border-color: #198754; }
.invalid-feedback { font-size: .82rem; }
.form-label { font-weight: 600; margin-bottom: .5rem; color: var(--dark); font-size: .9rem; }

/* APPOINTMENT */
.appointment-card { background: var(--surface); border-radius: var(--radius-lg); padding: 3rem; box-shadow: var(--shadow-lg); }
.appointment-card .ic-circle { align-items: center; background: var(--gradient); border-radius: 50%; box-shadow: 0 10px 24px rgba(13,110,253,.4); color: #fff; display: inline-flex; flex: 0 0 56px; font-size: 1.4rem; height: 56px; justify-content: center; width: 56px; }
.appointment-bg { background: var(--gradient); color: #fff; border-radius: var(--radius-lg); padding: 3rem; height: 100%; }
.appointment-bg h3 { color: #fff; }
.appointment-bg ul { list-style: none; padding: 0; margin-top: 1.5rem; }
.appointment-bg ul li { display: flex; gap: 12px; margin-bottom: 1rem; align-items: flex-start; }
.appointment-bg ul li i { font-size: 1.4rem; }
.appointment-slot-status { align-items: center; color: var(--muted); display: flex; font-size: .86rem; gap: .5rem; min-height: 1.75rem; padding-top: .35rem; }
.appointment-slot-status .spinner-border { border-width: .15rem; color: var(--primary); flex: 0 0 auto; height: 1rem; width: 1rem; }
.appointment-slot-status.is-success { color: #198754; }
.appointment-slot-status.is-warning { color: #b45309; }
.appointment-slot-status.is-error { color: #dc3545; }
.appointment-slot-status.is-loading { color: var(--primary); }
.appointment-date-input { max-width: 240px; }
.appointment-calendar { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; margin-top: .75rem; padding: 1rem; }
.appointment-calendar-head { align-items: center; display: flex; justify-content: space-between; margin-bottom: .85rem; }
.appointment-calendar-head strong { color: var(--dark); font-size: 1rem; text-transform: capitalize; }
.calendar-nav { align-items: center; background: var(--gradient-soft); border: 1px solid rgba(13,110,253,.12); border-radius: 999px; color: var(--primary); display: inline-flex; height: 36px; justify-content: center; width: 36px; }
.calendar-nav:hover, .calendar-nav:focus { background: var(--primary); color: #fff; outline: 0; }
.appointment-calendar-weekdays, .appointment-calendar-grid { display: grid; gap: .45rem; grid-template-columns: repeat(7, minmax(0, 1fr)); }
.appointment-calendar-weekdays { color: var(--muted); font-size: .78rem; font-weight: 700; margin-bottom: .45rem; text-align: center; }
.appointment-day { align-items: center; aspect-ratio: 1 / 1; background: var(--surface-soft); border: 1px solid var(--border); border-radius: 12px; color: var(--dark); display: flex; flex-direction: column; font-size: .86rem; justify-content: center; min-width: 0; padding: .35rem; }
.appointment-day small { color: var(--muted); font-size: .66rem; font-weight: 700; line-height: 1.1; margin-top: .12rem; }
.appointment-day.is-empty { background: transparent; border: 0; }
.appointment-day.is-musait { background: rgba(15,118,110,.1); border-color: rgba(15,118,110,.3); }
.appointment-day.is-musait:hover, .appointment-day.is-musait:focus { background: var(--accent); border-color: var(--accent); color: #fff; outline: 0; }
.appointment-day.is-musait:hover small, .appointment-day.is-musait:focus small { color: rgba(255,255,255,.86); }
.appointment-day.is-selected { background: var(--gradient); border-color: transparent; color: #fff; box-shadow: 0 8px 22px rgba(13,110,253,.28); }
.appointment-day.is-selected small { color: rgba(255,255,255,.88); }
.appointment-day.is-dolu { background: #fff7ed; border-color: #fed7aa; color: #9a3412; }
.appointment-day.is-kapali, .appointment-day.is-disabled, .appointment-day:disabled { cursor: not-allowed; opacity: .58; }
.appointment-confirmation-card { overflow: hidden; }
.confirmation-heading { align-items: center; display: flex; gap: 1rem; margin-bottom: 2rem; }
.confirmation-summary { display: grid; gap: 1rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.summary-item { background: var(--gradient-soft); border: 1px solid var(--border); border-radius: 14px; padding: 1rem 1.1rem; }
.summary-item span { color: var(--muted); display: block; font-size: .82rem; font-weight: 600; margin-bottom: .25rem; }
.summary-item strong { color: var(--dark); display: block; font-size: 1rem; }

/* CONTACT INFO */
.contact-info-card { background: var(--surface); border-radius: var(--radius); padding: 2.2rem 1.8rem; text-align: center; box-shadow: var(--shadow-sm); height: 100%; transition: all .35s; }
.contact-info-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); }
.contact-info-card .ic { width: 72px; height: 72px; margin: 0 auto 1.2rem; border-radius: 50%; background: var(--gradient); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.7rem; }
.contact-info-card h5 { margin-bottom: .6rem; }
.contact-info-card p { color: var(--muted); margin: 0; }

/* DETAIL */
.detail-img { width: 100%; border-radius: var(--radius); margin-bottom: 2rem; box-shadow: var(--shadow-md); }
.detail-content h2, .detail-content h3 { margin-top: 2rem; margin-bottom: 1rem; }
.detail-content p { color: var(--muted); margin-bottom: 1.2rem; line-height: 1.85; }
.detail-content blockquote { border-left: 4px solid var(--primary); background: var(--gradient-soft); padding: 1.25rem 1.5rem; border-radius: 0 var(--radius) var(--radius) 0; margin: 1.5rem 0; font-style: italic; color: var(--dark); }
.detail-content img { max-width: 100%; height: auto; border-radius: var(--radius); }
.detail-content ul, .detail-content ol { color: var(--muted); line-height: 1.85; margin-bottom: 1.2rem; padding-left: 1.35rem; }
.page-content-box { background: var(--surface); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: clamp(1.25rem, 3vw, 2.5rem); }
.sidebar-widget { background: var(--surface); border-radius: var(--radius); padding: 1.75rem; box-shadow: var(--shadow-sm); margin-bottom: 1.75rem; }
.sidebar-widget h5 { margin-bottom: 1.2rem; padding-bottom: .75rem; border-bottom: 2px solid var(--surface-strong); }
.sidebar-widget ul { list-style: none; padding: 0; margin: 0; }
.sidebar-widget ul li { padding: .55rem 0; border-bottom: 1px dashed var(--border); }
.sidebar-widget ul li:last-child { border-bottom: none; }
.sidebar-widget ul li a { color: var(--muted); display: flex; justify-content: space-between; align-items: center; }
.sidebar-widget ul li a:hover { color: var(--primary); padding-left: 6px; }
.sidebar-widget ul li a i { color: var(--primary); }
.recent-post { display: flex; gap: 1rem; margin-bottom: 1.1rem; }
.recent-post img { width: 80px; height: 80px; border-radius: 12px; object-fit: cover; flex-shrink: 0; }
.recent-post h6 { font-size: .95rem; margin: 0 0 .25rem; }
.recent-post h6 a { color: var(--dark); }
.recent-post h6 a:hover { color: var(--primary); }
.recent-post span { color: var(--muted); font-size: .8rem; }
.tag { display: inline-block; padding: .35rem 1rem; background: var(--gradient-soft); color: var(--primary); border-radius: 50px; font-size: .82rem; margin: 0 .35rem .5rem 0; font-weight: 500; }
.tag:hover { background: var(--gradient); color: #fff; }
.share-strip { align-items: center; background: var(--surface-soft); border: 1px solid var(--border); border-radius: 16px; display: flex; flex-wrap: wrap; gap: 14px; justify-content: space-between; padding: 14px 16px; }
.share-strip__label { color: var(--dark); font-weight: 800; }
.share-strip__actions { display: flex; flex-wrap: wrap; gap: 8px; }
.share-strip__actions a { align-items: center; background: var(--surface); border: 1px solid var(--border); border-radius: 999px; color: var(--primary); display: inline-flex; height: 42px; justify-content: center; text-decoration: none; transition: all .25s; width: 42px; }
.share-strip__actions a:hover, .share-strip__actions a:focus-visible { background: var(--gradient); border-color: transparent; color: #fff; transform: translateY(-2px); }
.related-content { border-top: 1px solid var(--border); padding-top: 1.5rem; }
.related-grid { display: grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.related-card, .related-service { background: var(--surface-soft); border: 1px solid var(--border); border-radius: var(--radius); color: var(--dark); overflow: hidden; text-decoration: none; transition: all .25s; }
.related-card:hover, .related-card:focus-visible, .related-service:hover, .related-service:focus-visible { background: var(--surface); box-shadow: var(--shadow-md); color: var(--primary); transform: translateY(-4px); }
.related-card img { aspect-ratio: 16 / 10; border-radius: 0; display: block; object-fit: cover; width: 100%; }
.related-card span, .related-card strong, .related-card small { display: block; margin-inline: 1rem; }
.related-card span { color: var(--primary); font-size: .78rem; font-weight: 800; margin-top: 1rem; text-transform: uppercase; }
.related-card strong { font-size: .98rem; line-height: 1.45; margin-top: .35rem; }
.related-card small { color: var(--muted); margin-bottom: 1rem; margin-top: .45rem; }
.related-service { display: flex; flex-direction: column; gap: .65rem; min-height: 100%; padding: 1.1rem; }
.related-service__icon { align-items: center; background: var(--gradient-soft); border-radius: 14px; color: var(--primary); display: inline-flex; font-size: 1.35rem; height: 46px; justify-content: center; width: 46px; }
.related-service strong { font-size: 1rem; }
.related-service small { color: var(--muted); line-height: 1.6; }

/* VIRTUAL TOUR */
.virtual-tour-section { background: var(--bg); }
.virtual-tour-frame-wrap { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; position: relative; }
.virtual-tour-frame-wrap::before { background: linear-gradient(135deg, rgba(13,110,253,.24), rgba(15,118,110,.18)); content: ''; inset: 12px; pointer-events: none; position: absolute; z-index: 1; }
.virtual-tour-frame { aspect-ratio: 16 / 9; background: #0f172a; border: 0; display: block; min-height: 360px; width: 100%; }

/* FOOTER */
footer { background: var(--dark); color: rgba(255,255,255,.75); padding: 4.5rem 0 0; }
footer h5 { color: #fff; margin-bottom: 1.5rem; font-size: 1.1rem; position: relative; padding-bottom: .75rem; }
footer h5::after { content: ''; position: absolute; bottom: 0; left: 0; width: 40px; height: 3px; background: var(--gradient); border-radius: 3px; }
footer a { color: rgba(255,255,255,.75); }
footer a:hover { color: var(--accent); padding-left: 4px; }
footer ul { list-style: none; padding: 0; }
footer ul li { padding: .35rem 0; }
footer ul li a { display: inline-flex; align-items: center; gap: 6px; transition: padding .3s; }
.footer-brand { font-size: 1.6rem; font-weight: 800; color: #fff; margin-bottom: 1rem; }
.footer-brand i { color: var(--primary); margin-right: 6px; }
.footer-brand span { color: var(--accent); }
.footer-social a { width: 42px; height: 42px; background: rgba(255,255,255,.08); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; margin-right: .5rem; color: #fff !important; }
.footer-social a:hover { background: var(--gradient); transform: translateY(-3px); padding-left: 0; }
.footer-contact li { display: flex; gap: 12px; align-items: flex-start; }
.footer-contact li i { color: var(--accent); font-size: 1.1rem; flex-shrink: 0; margin-top: 4px; }
.footer-newsletter h5 { margin-bottom: 1rem; }
.footer-newsletter__status { background: rgba(22,163,74,.16); border: 1px solid rgba(74,222,128,.24); border-radius: 12px; color: #bbf7d0; font-size: .9rem; margin-bottom: .8rem; padding: .65rem .8rem; }
.footer-newsletter__form { display: grid; gap: .7rem; }
.footer-newsletter__input { align-items: center; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); border-radius: 14px; display: flex; overflow: hidden; }
.footer-newsletter__input input { background: transparent; border: 0; color: #fff; flex: 1; min-width: 0; outline: 0; padding: .85rem .95rem; }
.footer-newsletter__input input::placeholder { color: rgba(255,255,255,.58); }
.footer-newsletter__input button { align-items: center; align-self: stretch; background: var(--gradient); border: 0; color: #fff; display: inline-flex; justify-content: center; width: 48px; }
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: .55rem; }
.footer-links li a { color: rgba(255,255,255,.9); font-weight: 600; }
.footer-links li a:hover { color: var(--accent); padding-left: 6px; }
.footer-newsletter__check { align-items: flex-start; color: rgba(255,255,255,.68); display: flex; font-size: .82rem; gap: .55rem; line-height: 1.5; margin: 0; }
.footer-newsletter__check input { flex: 0 0 auto; margin-top: .2rem; }
.footer-newsletter__error { color: #fecaca; font-size: .82rem; }
.footer-newsletter__status--success { background: rgba(34,197,94,.16); border-color: rgba(74,222,128,.24); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 3rem; padding: 1.5rem 0; font-size: .9rem; }
.footer-bottom-links { display: inline-block; margin-left: 1rem; font-size: .85rem; }
.footer-bottom-links a { color: rgba(255,255,255,.7); transition: color .2s; text-decoration: none; }
.footer-bottom-links a:hover { color: #fff; }

/* BACK TO TOP */
.back-to-top { position: fixed; right: 25px; bottom: 25px; width: 50px; height: 50px; background: var(--gradient); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-md); z-index: 999; opacity: 0; visibility: hidden; transition: all .3s; cursor: pointer; border: none; }
.back-to-top.show { opacity: 1; visibility: visible; }
.back-to-top:hover { transform: translateY(-4px); color: #fff; }

/* COOKIE CONSENT */
.cookie-consent { position: fixed; left: 50%; bottom: 24px; z-index: 1200; display: grid; grid-template-columns: auto minmax(0, 1fr) auto; gap: 18px; align-items: center; width: min(920px, calc(100% - 32px)); padding: 18px; border: 1px solid rgba(255,255,255,.18); border-radius: 18px; background: linear-gradient(135deg, rgba(15,23,42,.98) 0%, rgba(15,118,110,.96) 100%); color: #fff; box-shadow: 0 24px 70px rgba(15,23,42,.28); transform: translateX(-50%); transition: opacity .25s ease, transform .25s ease, visibility .25s ease; }
.cookie-consent[hidden] { display: none; }
.cookie-consent.cookie-consent--closing { opacity: 0; visibility: hidden; transform: translate(-50%, 12px); }
.cookie-consent__icon { width: 46px; height: 46px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.16); color: #fff; font-size: 22px; }
.cookie-consent__content strong { display: block; margin-bottom: 4px; font-size: 1rem; }
.cookie-consent__content p { margin: 0; color: rgba(255,255,255,.88); font-size: .9rem; line-height: 1.6; }
.cookie-consent__content a { display: inline-flex; margin-top: 6px; color: #fff; font-weight: 700; text-decoration: underline; text-underline-offset: 4px; }
.cookie-consent__actions { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.cookie-consent__actions .btn { min-width: 88px; font-weight: 700; }
.cookie-consent__actions .btn-outline-light { border-color: rgba(255,255,255,.6); color: #fff; }
.cookie-consent__actions .btn-outline-light:hover { background: rgba(255,255,255,.14); color: #fff; }

/* ERROR PAGES */
.error-shell { background: var(--bg); color: var(--dark); font-family: 'Poppins', sans-serif; min-height: 100vh; }
.error-page { align-items: center; background: linear-gradient(135deg, rgba(13,110,253,.08), rgba(15,118,110,.1)); display: flex; min-height: 100vh; padding: clamp(3rem, 8vw, 6rem) 0; }
.error-panel { margin: 0 auto; max-width: 760px; text-align: center; }
.error-status { color: rgba(13,110,253,.14); font-size: clamp(5rem, 18vw, 12rem); font-weight: 800; letter-spacing: 0; line-height: .82; margin-bottom: -1.4rem; }
.error-icon { align-items: center; background: var(--gradient); border-radius: 24px; box-shadow: var(--shadow-md); color: #fff; display: inline-flex; font-size: 2.1rem; height: 78px; justify-content: center; margin-bottom: 1.4rem; width: 78px; }
.error-panel h1 { color: var(--dark); font-size: clamp(2rem, 4vw, 3.25rem); margin-bottom: 1rem; }
.error-panel p { color: var(--muted); font-size: 1.05rem; line-height: 1.8; margin: 0 auto 1.8rem; max-width: 620px; }
.error-actions { display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; }
.error-actions .btn { border-radius: 999px; font-weight: 700; min-width: 140px; padding: .8rem 1.35rem; }
.error-actions .btn-light { background: var(--surface); border-color: var(--border); color: var(--dark); }
.error-actions .btn-light:hover { background: var(--gradient-soft); color: var(--primary); }

/* WHATSAPP */
.whatsapp-float { position: fixed; left: 25px; bottom: 25px; width: 56px; height: 56px; background: #25d366; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 24px rgba(37,211,102,.4); font-size: 1.6rem; z-index: 999; animation: pulse 2s infinite; }
.whatsapp-float:hover { color: #fff; transform: scale(1.1); }
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(37,211,102,.6); }
  70% { box-shadow: 0 0 0 18px rgba(37,211,102,0); }
  100% { box-shadow: 0 0 0 0 rgba(37,211,102,0); }
}

/* PAGINATION */
.pagination { gap: .5rem; }
.page-link { background: var(--surface-strong); border: none; border-radius: 12px !important; color: var(--dark); font-weight: 600; padding: .65rem 1.05rem; }
.page-link:hover { background: var(--gradient-soft); color: var(--primary); }
.page-item.active .page-link { background: var(--gradient); color: #fff; }

/* CTA */
.cta-banner { background: linear-gradient(135deg, rgba(13,110,253,.92), rgba(15,118,110,.92)), url('https://images.unsplash.com/photo-1631815588090-d4bfec5b1ccb?w=1600') center/cover; padding: 5rem 0; color: #fff; text-align: center; border-radius: var(--radius-lg); }
.cta-banner h2 { color: #fff; margin-bottom: 1rem; }

/* RESPONSIVE */
@media (max-width: 992px) {
  section { padding: 4rem 0; }
  .hero-slide { height: auto; padding: 7rem 0 5rem; min-height: 0; }
  .info-strip { margin-top: 2rem; }
  .promo-countdown { grid-template-columns: 1fr; margin-top: 1.5rem; text-align: center; }
  .promo-countdown p { margin-inline: auto; }
  .trust-badge-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .trust-badge:nth-child(2n) { border-right: 0; }
  .trust-badge:nth-child(-n + 2) { border-bottom: 1px solid var(--border); }
  .about-img-wrap .badge-float { left: 15px; bottom: -20px; padding: 1rem 1.4rem; }
  .appointment-card, .appointment-bg { padding: 2rem; }
  .navbar-collapse { background: var(--surface); padding: 1rem; border-radius: var(--radius); margin-top: 1rem; box-shadow: var(--shadow-md); }
}
@media (max-width: 576px) {
  .stat-item .num { font-size: 2.2rem; }
  .promo-countdown { padding: 1rem; }
  .promo-countdown__timer { grid-template-columns: repeat(2, minmax(0, 1fr)); width: 100%; }
  .trust-badge-strip { grid-template-columns: 1fr; }
  .trust-badge, .trust-badge:nth-child(2n), .trust-badge:nth-child(-n + 2) { border-bottom: 1px solid var(--border); border-right: 0; }
  .trust-badge:last-child { border-bottom: 0; }
  .related-grid { grid-template-columns: 1fr; }
  .virtual-tour-frame { min-height: 300px; }
  .blog-toolbar { align-items: stretch; flex-direction: column; }
  .blog-search-form { max-width: none; width: 100%; }
  .blog-clear-filter { text-align: center; }
  .appointment-calendar { padding: .75rem; }
  .appointment-calendar-weekdays, .appointment-calendar-grid { gap: .3rem; }
  .appointment-day { border-radius: 10px; font-size: .8rem; padding: .25rem; }
  .appointment-day small { font-size: .6rem; }
  .confirmation-heading { align-items: flex-start; flex-direction: column; }
  .confirmation-summary { grid-template-columns: 1fr; }
  .swiper-button-next, .swiper-button-prev { display: none; }
  .cookie-consent { grid-template-columns: 1fr; gap: 12px; bottom: 16px; padding: 16px; }
  .cookie-consent__icon { display: none; }
  .cookie-consent__actions { justify-content: stretch; }
  .cookie-consent__actions .btn { flex: 1 1 130px; }
  .error-actions .btn { width: 100%; }
}
