/* ============================================================
   Kayseri Kalibrasyon — Ana Site Stili
   ============================================================ */

/* ---------- CSS Custom Properties ---------- */
:root {
  --primary: #0D9488;
  --primary-dark: #0F766E;
  --primary-pale: rgba(13,148,136,.08);
  --navy: #0B1D2E;
  --ice: #F4FAFB;
  --blue: #00ACC1;
  --blue-pale: rgba(0,172,193,.1);
  --font: 'Inter', system-ui, -apple-system, sans-serif;
  --text: #1E293B;
  --text-muted: #4A6090;
  --text-light: #64748B;
  --gray-100: #F1F5F9;
  --gray-200: #E2E8F0;
  --gray-300: #CBD5E1;
  --gray-400: #94A3B8;
  --gray-500: #64748B;
  --gray-600: #475569;
  --gray-700: #334155;
  --gray-900: #0F172A;
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --shadow: 0 4px 24px rgba(0,0,0,.06);
  --shadow-sm: 0 2px 12px rgba(0,0,0,.04);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.1);
  --shadow-blue: 0 4px 20px rgba(0,172,193,.12);
  --transition: .25s ease;
  --container: 1200px;
}

/* ---------- Reset & Base ---------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body {
  font-family:var(--font);
  font-size:1rem;
  line-height:1.6;
  color:var(--text);
  background:#fff;
  overflow-x:hidden;
}
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { font-family:inherit; cursor:pointer; }
input,textarea,select { font-family:inherit; font-size:inherit; }

.container { width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }

/* ---------- Floating Crosses ---------- */
.floating-cross {
  position:fixed; top:0; left:0; width:100%; height:100%;
  pointer-events:none; z-index:-1; opacity:.015;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%230D9488' fill-opacity='1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

/* ---------- Buttons ---------- */
.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 24px;
  border-radius:var(--radius-sm);
  font-size:.9rem;
  font-weight:600;
  line-height:1;
  border:2px solid transparent;
  transition:all var(--transition);
  text-decoration:none;
  white-space:nowrap;
}
.btn--primary {
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}
.btn--primary:hover {
  background:var(--primary-dark);
  border-color:var(--primary-dark);
  box-shadow:0 8px 24px rgba(13,148,136,.3);
  transform:translateY(-1px);
}
.btn--lg { padding:16px 32px; font-size:1rem; border-radius:var(--radius); }
.btn--full { width:100%; justify-content:center; }
.btn--ghost {
  background:transparent;
  color:var(--primary);
  border-color:var(--gray-200);
}
.btn--ghost:hover {
  border-color:var(--primary);
  background:var(--primary-pale);
}
.btn--glass {
  background:rgba(255,255,255,.1);
  color:#fff;
  border-color:rgba(255,255,255,.25);
  backdrop-filter:blur(8px);
}
.btn--glass:hover {
  background:rgba(255,255,255,.2);
  border-color:rgba(255,255,255,.4);
}
.btn--black { background:#0F172A; color:#fff; border-color:#0F172A; }
.btn--black:hover { background:#1E293B; }
.btn--white { background:#fff; color:var(--primary); border-color:#fff; }
.btn--white:hover { background:var(--ice); }
.btn--outline-white { background:transparent; color:#fff; border-color:rgba(255,255,255,.4); }
.btn--outline-white:hover { border-color:#fff; background:rgba(255,255,255,.1); }
.btn--outline {
  background:transparent;
  color:var(--navy);
  border-color:var(--gray-200);
}
.btn--outline:hover {
  border-color:var(--primary);
  color:var(--primary);
}

/* ---------- Section Header ---------- */
.section-header { text-align:center; margin-bottom:48px; }
.section-header__eyebrow {
  display:inline-block;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--primary);
  background:var(--primary-pale);
  padding:6px 16px;
  border-radius:20px;
  margin-bottom:16px;
}
.section-header__title {
  font-size:clamp(1.6rem,3.5vw,2.4rem);
  font-weight:900;
  color:var(--navy);
  line-height:1.2;
  margin-bottom:16px;
}
.section-header__desc {
  font-size:1.05rem;
  color:var(--text-muted);
  max-width:560px;
  margin:0 auto;
  line-height:1.7;
}

/* ---------- Form Elements ---------- */
.form-group { margin-bottom:18px; }
.form-group label {
  display:block;
  font-size:.8rem;
  font-weight:600;
  color:var(--gray-600);
  text-transform:uppercase;
  letter-spacing:.05em;
  margin-bottom:6px;
}
.form-group input,
.form-group textarea,
.form-group select {
  width:100%;
  padding:12px 16px;
  border:1.5px solid var(--gray-200);
  border-radius:var(--radius-sm);
  font-family:var(--font);
  font-size:.9rem;
  color:var(--text);
  background:#fff;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(0,172,193,.12);
}
.form-group textarea { resize:vertical; min-height:100px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.success-msg { background:#D1FAE5; border:1px solid #6EE7B7; border-radius:var(--radius); padding:20px; color:#065F46; font-weight:600; margin-bottom:20px; }
.error-msg { background:#FEE2E2; border:1px solid #FCA5A5; border-radius:var(--radius); padding:20px; color:#991B1B; font-weight:600; margin-bottom:20px; }

/* ---------- NAVBAR ---------- */
/* ---------- TOP BAR ---------- */
.top-bar {
  background: var(--primary);
  color: #fff;
  font-size: .78rem;
  font-weight: 500;
  line-height: 1;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1001;
}
.top-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 38px;
  gap: 16px;
}
.top-bar__left {
  display: flex;
  align-items: center;
  gap: 20px;
}
.top-bar__right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.top-bar__item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #fff;
  text-decoration: none;
  transition: opacity .2s ease;
}
.top-bar__item svg {
  opacity: .8;
  flex-shrink: 0;
}
.top-bar__item:hover { opacity: .85; }
.top-bar__item--static { cursor: default; }
.top-bar__item--static:hover { opacity: 1; }
.top-bar__social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: rgba(255,255,255,.12);
  color: #fff;
  text-decoration: none;
  transition: all .2s ease;
}
.top-bar__social:hover {
  background: rgba(255,255,255,.25);
  transform: translateY(-1px);
}
.top-bar__social svg {
  width: 14px;
  height: 14px;
}

/* ---------- Navbar ---------- */
.navbar {
  position:fixed;
  top:38px; left:0; right:0;
  z-index:1000;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid rgba(226,232,240,.5);
  transition:all .3s ease;
}
.navbar.scrolled { box-shadow:0 4px 20px rgba(0,0,0,.05); }
body { padding-top:110px; }
.navbar__inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  height:72px;
}
.navbar__logo {
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  flex-shrink:0;
}
.logo-icon {
  width:40px; height:40px;
  position:relative;
  flex-shrink:0;
}
.logo-icon svg { width:100%; height:100%; }
.logo-pulse {
  position:absolute;
  inset:-3px;
  border-radius:13px;
  border:2px solid rgba(13,148,136,.2);
  animation:logoPulse 3s ease-in-out infinite;
}
@keyframes logoPulse {
  0%,100% { transform:scale(1); opacity:.3; }
  50% { transform:scale(1.15); opacity:0; }
}
.logo-text { display:flex; flex-direction:column; }
.logo-text__main { font-size:1rem; font-weight:800; color:var(--navy); line-height:1.2; }
.logo-text__sub { font-size:.7rem; font-weight:600; color:var(--text-muted); letter-spacing:.04em; }

/* Navbar Menu */
.navbar__menu ul {
  display:flex;
  align-items:center;
  gap:4px;
}
.navbar__menu a {
  display:flex;
  align-items:center;
  gap:6px;
  padding:8px 14px;
  font-size:.88rem;
  font-weight:600;
  color:var(--gray-600);
  border-radius:var(--radius-sm);
  transition:all var(--transition);
  white-space:nowrap;
}
.navbar__menu a:hover,
.navbar__menu a.active {
  background:var(--primary-pale);
  color:var(--primary);
}
.navbar__cta {
  flex-shrink:0;
  padding:10px 20px;
  font-size:.85rem;
}
.navbar__cta-mobile-li { display:none; }

/* ---------- Search ---------- */
.search-wrapper {
  position:relative;
  flex-shrink:0;
}
.search-icon {
  position:absolute;
  left:14px; top:50%;
  transform:translateY(-50%);
  color:var(--gray-400);
  pointer-events:none;
}
.search-input {
  width:200px;
  padding:9px 14px 9px 40px;
  border:1.5px solid var(--gray-200);
  border-radius:20px;
  font-size:.82rem;
  background:var(--gray-100);
  outline:none;
  transition:all .3s ease;
}
.search-input:focus {
  width:260px;
  border-color:var(--primary);
  background:#fff;
  box-shadow:0 0 0 3px rgba(13,148,136,.1);
}
.search-results {
  position:absolute;
  top:calc(100% + 6px);
  left:0; right:0;
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  max-height:360px;
  overflow-y:auto;
  display:none;
  z-index:100;
}
.search-results.show,
.search-results.visible { display:block; }
.search-results a {
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 16px;
  font-size:.85rem;
  color:var(--text);
  transition:background .15s;
}
.search-results a:hover { background:var(--primary-pale); }
.search-results a:not(:last-child) { border-bottom:1px solid var(--gray-100); }
.search-results__empty { padding:16px; text-align:center; color:var(--gray-400); font-size:.82rem; }

/* ---------- Hamburger ---------- */
.navbar__hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  padding:8px;
  cursor:pointer;
}
.navbar__hamburger span {
  display:block;
  width:24px; height:2px;
  background:var(--navy);
  border-radius:2px;
  transition:all .3s ease;
}
.navbar__hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.navbar__hamburger.active span:nth-child(2) { opacity:0; }
.navbar__hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ---------- MEGA MENU ---------- */
.has-mega { position:static; }
.mega-menu {
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%) translateY(8px);
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  box-shadow:0 20px 60px rgba(0,0,0,.12);
  opacity:0;
  visibility:hidden;
  transition:all .28s cubic-bezier(.16,1,.3,1);
  z-index:999;
  padding:24px;
  min-width:600px;
  width:auto;
}
.has-mega:hover .mega-menu { opacity:1; visibility:visible; transform:translateX(-50%) translateY(4px); }
.mega-menu--sm { min-width:320px; }
.mega-menu--lg { min-width:720px; }
.mega-menu__header { margin-bottom:20px; }
.mega-menu__title { display:block; font-size:1rem; font-weight:800; color:var(--navy); }
.mega-menu__sub { font-size:.78rem; color:var(--text-muted); margin-top:4px; }
.mega-menu__grid { display:grid; gap:10px; }
.mega-menu__grid--2 { grid-template-columns:1fr 1fr; }
.mega-menu__grid--3 { grid-template-columns:repeat(3, 1fr); }
.mega-menu__footer {
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid var(--gray-200);
}
.mega-menu .mega-menu__all {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-size:.82rem;
  font-weight:700;
  color:#0F172A;
  transition:all .28s ease;
  padding:10px 20px;
  border-radius:10px;
  background:#F8FAFC;
  border:1.5px solid #E2E8F0;
  text-decoration:none;
}
.mega-menu .mega-menu__all:hover {
  gap:12px;
  border-color:#0F172A;
  background:#fff;
  box-shadow:0 4px 16px rgba(0,0,0,.06);
}
/* Mega Cards — Horizontal layout, dark icon, stroke border */
.mega-menu .mega-card {
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  border-radius:12px;
  background:#fff;
  border:1px solid #E8EDF2;
  transition:border-color .2s ease, box-shadow .2s ease;
  text-decoration:none;
}
.mega-menu .mega-card:hover {
  border-color:var(--primary);
  box-shadow:0 2px 12px rgba(13,148,136,.08);
}
.mega-menu .mega-card__icon {
  width:48px; height:48px;
  min-width:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:var(--primary);
  padding:11px;
  flex-shrink:0;
}
.mega-menu .mega-card__icon svg { width:100%; height:100%; }
.mega-menu .mega-card__text {
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.mega-menu .mega-card__title {
  font-size:.82rem;
  font-weight:700;
  color:#0F172A;
  line-height:1.2;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.mega-menu .mega-card__sub {
  font-size:.7rem;
  color:#64748B;
  line-height:1.4;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* ---------- HERO SLIDER ---------- */
.hero-slider {
  position:relative;
  width:100%;
  height:56.25vw;
  min-height:480px;
  max-height:100vh;
  overflow:hidden;
  background:#0B1D2E;
  margin-top:0;
}
.hero-slider__bg-noise {
  position:absolute;
  inset:0;
  opacity:.03;
  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='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  z-index:1;
}
.hero-slider__slides { position:relative; width:100%; height:100%; }
.hero-slider__slide {
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity .8s ease,transform .8s ease;
  transform:scale(1.04);
  display:flex;
  align-items:center;
}
.hero-slider__slide.active { opacity:1; transform:scale(1); z-index:2; }
.hero-slider__video {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  transform:translateZ(0);
}
.hero-slider__overlay {
  position:absolute;
  inset:0;
  z-index:1;
}
.hero-slider__shapes { position:absolute; inset:0; z-index:1; overflow:hidden; pointer-events:none; }
.hero-slider__shape {
  position:absolute;
  border-radius:50%;
}
.hero-slider__shape--1 {
  top:-120px; right:-60px;
  width:500px; height:500px;
  background:radial-gradient(circle,rgba(38,198,218,.12),transparent 70%);
  animation:heroShapeFloat 12s ease-in-out infinite;
}
.hero-slider__shape--2 {
  bottom:-80px; left:-40px;
  width:350px; height:350px;
  background:radial-gradient(circle,rgba(13,148,136,.1),transparent 70%);
  animation:heroShapeFloat 16s ease-in-out infinite reverse;
}
@keyframes heroShapeFloat {
  0%,100% { transform:translate(0,0) scale(1); }
  50% { transform:translate(30px,-20px) scale(1.08); }
}
.hero-slider__content {
  position:relative;
  z-index:2;
  max-width:640px;
  padding:0 0 48px;
}
.hero-slider__badge {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12);
  padding:6px 16px;
  border-radius:20px;
  font-size:.78rem;
  font-weight:600;
  color:rgba(255,255,255,.8);
  margin-bottom:24px;
}
.badge__dot {
  width:6px; height:6px;
  border-radius:50%;
  background:#5EEAD4;
  animation:badgePulse 2s ease-in-out infinite;
}
@keyframes badgePulse {
  0%,100% { opacity:1; } 50% { opacity:.3; }
}
.hero-slider__title {
  font-size:clamp(2rem,5vw,3.6rem);
  font-weight:900;
  color:#fff;
  line-height:1.1;
  margin-bottom:20px;
  letter-spacing:-.02em;
  text-shadow:0 2px 16px rgba(0,0,0,.15);
}
.hero-slider__desc {
  font-size:1.1rem;
  color:rgba(224,247,250,.85);
  line-height:1.7;
  margin-bottom:32px;
  max-width:540px;
}
.hero-slider__actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px; }
.hero-slider__trust { display:flex; gap:20px; flex-wrap:wrap; }
.hero-slider__trust-item {
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.82rem;
  color:rgba(224,247,250,.7);
}

/* Slider Navigation */
.hero-slider__nav {
  position:absolute;
  bottom:24px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:12px;
  z-index:5;
}
.hero-slider__dot {
  width:36px; height:6px;
  border:none;
  border-radius:4px;
  background:rgba(255,255,255,.25);
  cursor:pointer;
  padding:0;
  position:relative;
  transition:all .4s ease;
  overflow:hidden;
}
.hero-slider__dot.active { background:rgba(255,255,255,.4); width:48px; }
.hero-slider__dot-inner {
  position:absolute;
  left:0; top:0;
  height:100%;
  border-radius:4px;
  background:#5EEAD4;
  width:0;
  transition:width 5s linear;
}
.hero-slider__dot.active .hero-slider__dot-inner { width:100%; }

/* Slider Arrows */
.hero-slider__arrows {
  position:absolute;
  top:50%;
  left:0; right:0;
  transform:translateY(-50%);
  display:flex;
  justify-content:space-between;
  padding:0 24px;
  z-index:5;
  pointer-events:none;
}
.hero-slider__arrow {
  width:48px; height:48px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(8px);
  color:rgba(255,255,255,.6);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .25s ease;
  pointer-events:auto;
}
.hero-slider__arrow:hover {
  background:rgba(255,255,255,.12);
  color:#fff;
  border-color:rgba(255,255,255,.3);
}

/* Scroll Indicator */
.hero-scroll-indicator {
  position:absolute;
  bottom:16px;
  right:24px;
  z-index:5;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  color:rgba(255,255,255,.3);
  font-size:.65rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  animation:scrollBounce 2.5s ease-in-out infinite;
}
.scroll-arrow-down {
  width:1px; height:24px;
  background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);
}
@keyframes scrollBounce {
  0%,100% { transform:translateY(0); } 50% { transform:translateY(6px); }
}

/* ---------- HERO SEARCH / WIZARD ---------- */
.hero-search-section { background:var(--ice); padding:0 0 80px; margin-top:-40px; position:relative; z-index:3; }
.hero-search-section::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(13,148,136,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,148,136,0.02) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* --- Wizard Card --- */
.device-wizard {
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  padding:32px 36px 28px;
  box-shadow:0 8px 32px rgba(0,0,0,.05), 0 1px 3px rgba(0,0,0,.03);
}

/* --- Header --- */
.device-wizard__header {
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:28px;
}
.device-wizard__icon-wrap {
  width:44px; height:44px;
  border-radius:12px;
  background:linear-gradient(135deg,var(--primary),var(--blue));
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(13,148,136,.25);
}
.device-wizard__title {
  font-size:1.05rem;
  font-weight:800;
  color:var(--navy);
  line-height:1.3;
}
.device-wizard__subtitle {
  font-size:.8rem;
  color:var(--text-muted);
  margin-top:2px;
}

/* --- Step Indicators --- */
.wizard-steps {
  display:flex;
  align-items:center;
  gap:0;
  margin-bottom:28px;
  padding:0 4px;
}
.wizard-step {
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
}
.wizard-step__circle {
  width:32px; height:32px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--gray-100);
  border:2px solid var(--gray-200);
  position:relative;
  transition:all .35s cubic-bezier(.4,0,.2,1);
}
.wizard-step__num {
  font-size:.78rem;
  font-weight:700;
  color:var(--gray-400);
  transition:all .3s ease;
}
.wizard-step__check {
  position:absolute;
  opacity:0;
  transform:scale(0);
  transition:all .3s cubic-bezier(.4,0,.2,1);
}
.wizard-step__label {
  font-size:.8rem;
  font-weight:600;
  color:var(--gray-400);
  transition:color .3s ease;
  white-space:nowrap;
}

/* Active step */
.wizard-step.active .wizard-step__circle {
  background:var(--primary);
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(13,148,136,.12);
}
.wizard-step.active .wizard-step__num { color:#fff; }
.wizard-step.active .wizard-step__label { color:var(--primary); font-weight:700; }

/* Done step — green check */
.wizard-step.done .wizard-step__circle {
  background:#10B981;
  border-color:#10B981;
  box-shadow:0 0 0 4px rgba(16,185,129,.12);
}
.wizard-step.done .wizard-step__num { opacity:0; transform:scale(0); }
.wizard-step.done .wizard-step__check { opacity:1; transform:scale(1); }
.wizard-step.done .wizard-step__label { color:#065F46; font-weight:600; }

/* Connecting lines */
.wizard-step__line {
  flex:1;
  height:2px;
  background:var(--gray-200);
  margin:0 8px;
  min-width:24px;
  border-radius:1px;
  transition:background .4s ease;
}
.wizard-step__line.filled {
  background:#10B981;
}

/* --- Select Row --- */
.wizard-row {
  display:grid;
  grid-template-columns:1fr 1fr 1fr auto;
  gap:14px;
  align-items:end;
}
.wizard-select-wrap {
  display:flex;
  flex-direction:column;
  gap:6px;
}
.wizard-select-wrap label {
  font-size:.7rem;
  font-weight:700;
  color:var(--gray-500);
  text-transform:uppercase;
  letter-spacing:.06em;
}
.wizard-select-container {
  position:relative;
}
.wizard-select {
  width:100%;
  height:46px;
  padding:0 40px 0 14px;
  border:1.5px solid var(--gray-200);
  border-radius:var(--radius-sm);
  font-size:.88rem;
  font-weight:500;
  color:var(--text);
  background:#fff;
  outline:none;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  transition:all .25s ease;
}
.wizard-select:focus {
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(13,148,136,.08);
}
.wizard-select:disabled {
  background:var(--gray-100);
  color:var(--gray-400);
  cursor:not-allowed;
  border-color:var(--gray-100);
}

/* Green check when selected */
.wizard-select-container.has-value .wizard-select {
  border-color:#10B981;
}
.wizard-select-check {
  position:absolute;
  right:34px; top:50%;
  transform:translateY(-50%) scale(0);
  width:20px; height:20px;
  border-radius:50%;
  background:#10B981;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.wizard-select-container.has-value .wizard-select-check {
  opacity:1;
  transform:translateY(-50%) scale(1);
}

/* Arrow icon */
.wizard-select-arrow {
  position:absolute;
  right:12px; top:50%;
  transform:translateY(-50%);
  color:var(--gray-400);
  pointer-events:none;
  transition:color .2s;
}
.wizard-select:focus + .wizard-select-check + .wizard-select-arrow,
.wizard-select-container.has-value .wizard-select-arrow {
  color:var(--primary);
}

/* --- Submit Button --- */
.wizard-submit {
  padding-bottom:0;
}
.wiz-btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  height:46px;
  padding:0 28px;
  background:linear-gradient(135deg,var(--primary),var(--blue));
  color:#fff;
  border:none;
  border-radius:var(--radius-sm);
  font-size:.9rem;
  font-weight:700;
  cursor:pointer;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  white-space:nowrap;
  box-shadow:0 4px 14px rgba(13,148,136,.3);
  position:relative;
  overflow:hidden;
}
.wiz-btn::before {
  content:'';
  position:absolute;
  top:0; left:-100%;
  width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transition:left .5s ease;
}
.wiz-btn:hover:not(:disabled)::before {
  left:100%;
}
.wiz-btn:hover:not(:disabled) {
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(13,148,136,.4);
}
.wiz-btn:active:not(:disabled) {
  transform:translateY(0);
}
.wiz-btn:disabled {
  opacity:.45;
  cursor:not-allowed;
  box-shadow:none;
}
.wiz-btn__arrow {
  transition:transform .2s ease;
}
.wiz-btn:hover:not(:disabled) .wiz-btn__arrow {
  transform:translateX(3px);
}

/* --- Bot Protection (Honeypot) --- */
.wizard-hp {
  position:absolute;
  left:-9999px;
  top:-9999px;
  opacity:0;
  height:0;
  width:0;
  overflow:hidden;
  pointer-events:none;
}

/* --- Trust Bar --- */
.device-wizard__trust {
  display:flex;
  gap:24px;
  margin-top:20px;
  padding-top:18px;
  border-top:1px solid var(--gray-100);
  flex-wrap:wrap;
}
.trust-pill {
  display:flex;
  align-items:center;
  gap:6px;
  font-size:.78rem;
  font-weight:500;
  color:var(--gray-500);
}

/* --- Glass Variant --- */
.device-wizard--glass {
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px) saturate(1.3);
  -webkit-backdrop-filter:blur(20px) saturate(1.3);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:
    0 8px 32px rgba(0,0,0,.06),
    0 1px 2px rgba(0,0,0,.03),
    inset 0 1px 0 rgba(255,255,255,.8);
}

/* ---------- CATEGORY CARDS ---------- */
.category-cards { padding:60px 0 0; }
.category-cards__grid {
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:0;
}
.category-card {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:28px 16px;
  background:#fff;
  border:1.5px solid var(--gray-200);
  transition:all .3s ease;
  text-decoration:none;
  text-align:center;
  aspect-ratio:1;
  position:relative;
  overflow:hidden;
}
.category-card::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(13,148,136,.04),transparent);
  opacity:0;
  transition:opacity .3s ease;
}
.category-card:hover {
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(13,148,136,.06),0 8px 32px rgba(13,148,136,.1);
  transform:translateY(-2px);
  z-index:2;
}
.category-card:hover::before {
  opacity:1;
}
.category-card__icon {
  width:48px; height:48px;
  flex-shrink:0;
  color:var(--primary);
  position:relative;
  z-index:1;
}
.category-card__icon svg { width:100%; height:100%; }
.category-card__title {
  font-size:.82rem;
  font-weight:700;
  color:var(--navy);
  flex:1;
  position:relative;
  z-index:1;
  line-height:1.3;
}
.category-card__arrow {
  color:var(--gray-300);
  transition:all .3s ease;
  flex-shrink:0;
  position:relative;
  z-index:1;
}
.category-card:hover .category-card__arrow {
  color:var(--primary);
  transform:translateY(3px);
}

/* ---------- SERVICES ---------- */
.services { padding:96px 0; background:var(--ice); position:relative; }
.services::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(13,148,136,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,148,136,0.02) 1px, transparent 1px);
  background-size: 40px 40px;
}
.services__grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.service-card {
  background:#fff;
  border:1.5px solid var(--gray-200);
  border-radius:var(--radius-lg);
  padding:36px 32px;
  transition:all .3s ease;
  text-decoration:none;
  display:flex;
  flex-direction:column;
  position:relative;
  overflow:hidden;
}
.service-card::before {
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:linear-gradient(90deg,var(--primary),var(--blue));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s ease;
}
.service-card:hover {
  border-color:var(--primary);
  box-shadow:0 12px 40px rgba(13,148,136,.1);
  transform:translateY(-4px);
}
.service-card:hover::before {
  transform:scaleX(1);
}
.service-card__icon {
  width:56px; height:56px;
  margin-bottom:20px;
}
.service-card__icon svg { width:100%; height:100%; }
.service-card__title {
  font-size:1.1rem;
  font-weight:800;
  color:var(--navy);
  margin-bottom:10px;
}
.service-card__desc {
  font-size:.88rem;
  color:var(--text-muted);
  line-height:1.7;
  flex:1;
  margin-bottom:16px;
}
.service-card__link {
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.82rem;
  font-weight:700;
  color:var(--primary);
  transition:gap .25s ease;
}
.service-card:hover .service-card__link { gap:12px; }

/* ---------- CONTACT TEASER ---------- */
.contact-teaser { padding:96px 0; background:#fff; position:relative; }
.contact-teaser::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(13,148,136,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,148,136,0.015) 1px, transparent 1px);
  background-size: 40px 40px;
}
.contact-teaser__grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:start;
}
.contact-teaser__desc {
  font-size:1rem;
  color:var(--text-muted);
  line-height:1.7;
  margin-bottom:36px;
}
.contact-items { display:flex; flex-direction:column; gap:20px; }
.contact-item {
  display:flex;
  gap:16px;
  align-items:center;
}
.contact-item__icon {
  width:44px; height:44px;
  background:var(--primary-pale);
  border-radius:var(--radius-sm);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.contact-item strong { display:block; font-size:.82rem; font-weight:700; color:var(--text-muted); margin-bottom:2px; }
.contact-item a, .contact-item span { font-size:.95rem; font-weight:600; color:var(--navy); }
.contact-item a:hover { color:var(--primary); }
.quick-form { padding:0; }
.quick-form h3 { font-size:1.2rem; font-weight:800; color:var(--navy); margin-bottom:20px; }

/* ---------- STATS ---------- */
.stats { padding:80px 0; background:linear-gradient(135deg,var(--navy),#0D3D42); position:relative; overflow:hidden; }
.stats::before {
  content:''; position:absolute; inset:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.stats__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:32px; position:relative; z-index:1; }
.stats__item { text-align:center; }
.stats__number {
  font-size:clamp(2rem,4vw,3rem);
  font-weight:900;
  color:#fff;
  line-height:1;
  margin-bottom:8px;
}
.stats__label { font-size:.85rem; color:rgba(255,255,255,.6); font-weight:500; }
.stats__item .stats__plus { color:#5EEAD4; font-size:1.8rem; }

/* ---------- ABOUT & PAGE HERO (Modern) ---------- */
.page-hero {
  background:linear-gradient(135deg,var(--navy) 0%,#0D3B3B 50%,#006064 100%);
  padding:120px 0 70px; text-align:center;
  position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 30% 40%, rgba(13,148,136,.1) 0%, transparent 70%),
    radial-gradient(ellipse 400px 300px at 70% 30%, rgba(6,182,212,.08) 0%, transparent 70%);
  pointer-events:none;
}
.page-hero::after {
  content:''; position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.025) 1px, transparent 1px),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 50px 50px;
  pointer-events:none;
}
.page-hero h1 { font-size:clamp(2rem,4vw,3rem); font-weight:900; color:#fff; margin-bottom:12px; position:relative; }
.page-hero p { color:rgba(255,255,255,.6); font-size:1.05rem; position:relative; }
.page-hero .hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.08); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.1);
  padding:6px 18px; border-radius:20px; font-size:.78rem; color:rgba(255,255,255,.7);
  margin-bottom:24px; position:relative;
}
.about-section { padding:80px 0; background:var(--ice); position:relative; }
.about-section::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(13,148,136,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,148,136,0.02) 1px, transparent 1px);
  background-size: 40px 40px;
}
.about-content { max-width:800px; margin:0 auto; }
.about-content h2 { font-size:1.6rem; font-weight:800; color:var(--navy); margin-bottom:20px; margin-top:48px; }
.about-content h2:first-child { margin-top:0; }
.about-content p { font-size:1rem; color:var(--text-muted); line-height:1.8; margin-bottom:16px; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:32px; }
.about-card { background:#fff; border:1px solid var(--gray-200); border-radius:var(--radius); padding:32px; text-align:center; }
.about-card__icon { width:48px; height:48px; background:var(--blue-pale); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.about-card h3 { font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:8px; }
.about-card p { font-size:.875rem; color:var(--text-muted); line-height:1.6; margin:0; }

/* ---------- PAGE (statik sayfalar) ---------- */
.page-section { padding:80px 0; background:var(--ice); position:relative; }
.page-section::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(13,148,136,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,148,136,0.02) 1px, transparent 1px);
  background-size: 40px 40px;
}
.page-content { max-width:800px; margin:0 auto; }
.page-content h2 { font-size:1.4rem; font-weight:700; color:var(--navy); margin-bottom:16px; margin-top:40px; }
.page-content h3 { font-size:1.15rem; font-weight:700; color:var(--navy); margin-bottom:12px; margin-top:32px; }
.page-content p { font-size:1rem; color:var(--text-muted); line-height:1.8; margin-bottom:16px; }
.page-content ul,.page-content ol { margin-bottom:16px; padding-left:24px; }
.page-content li { font-size:1rem; color:var(--text-muted); line-height:1.8; margin-bottom:6px; }
.page-content a { color:var(--primary); text-decoration:underline; }
.page-content blockquote { border-left:4px solid var(--primary); padding:16px 24px; margin:24px 0; background:#fff; border-radius:0 var(--radius) var(--radius) 0; }
.page-content img { max-width:100%; height:auto; border-radius:var(--radius); margin:24px 0; }

/* ---------- BLOG LIST (Modern) ---------- */
.blog-hero {
  background:linear-gradient(135deg,var(--navy) 0%,#0D3B3B 50%,#006064 100%);
  padding:120px 0 80px; text-align:center;
  position:relative; overflow:hidden;
}
.blog-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 20% 50%, rgba(13,148,136,.12) 0%, transparent 70%),
    radial-gradient(ellipse 500px 300px at 80% 20%, rgba(6,182,212,.08) 0%, transparent 70%);
  pointer-events:none;
}
.blog-hero::after {
  content:''; position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 25% 25%, rgba(255,255,255,.03) 1px, transparent 1px),
    radial-gradient(circle at 75% 75%, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events:none;
}
.blog-hero h1 { font-size:clamp(2rem,4vw,3rem); font-weight:900; color:#fff; margin-bottom:12px; position:relative; }
.blog-hero p { color:rgba(255,255,255,.6); font-size:1.05rem; max-width:600px; margin:0 auto; position:relative; }
.blog-hero .hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.08); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.1);
  padding:6px 18px; border-radius:20px; font-size:.78rem; color:rgba(255,255,255,.7);
  margin-bottom:24px; position:relative;
}
.blog-section { padding:80px 0; background:var(--ice); min-height:50vh; position:relative; }
.blog-section--nohero { padding-top:32px; }

.blog-stats {
  display:flex; justify-content:center; gap:48px;
  margin-bottom:48px; padding:24px 0;
  border-bottom:1px solid var(--gray-200);
}
.blog-stats-item { text-align:center; }
.blog-stats-item .num { font-size:1.5rem; font-weight:800; color:var(--navy); display:block; }
.blog-stats-item .label { font-size:.75rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.05em; }

.blog-preview__grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
  gap:28px;
}
.blog-card {
  background:#fff; border-radius:16px; overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.04); transition:all .4s cubic-bezier(.22,1,.36,1);
  text-decoration:none; display:flex; flex-direction:column;
  border:1px solid var(--gray-200);
  position:relative;
}
.blog-card:hover {
  transform:translateY(-8px);
  box-shadow:0 20px 60px rgba(13,148,136,.12),0 8px 24px rgba(0,0,0,.06);
  border-color:rgba(13,148,136,.15);
}
.blog-card__image {
  height:210px; overflow:hidden; position:relative;
  background:linear-gradient(135deg,var(--gray-100),var(--gray-200));
}
.blog-card__image img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .7s cubic-bezier(.22,1,.36,1);
}
.blog-card:hover .blog-card__image img { transform:scale(1.08); }
.blog-card__image::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.06) 100%);
  pointer-events:none;
}
.blog-card__image .placeholder-icon { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:var(--gray-300); }
.blog-card__date {
  position:absolute; top:16px; left:16px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  padding:6px 14px; border-radius:20px; font-size:.75rem; font-weight:700; color:var(--navy);
  box-shadow:0 2px 8px rgba(0,0,0,.06);
  z-index:1;
}
.blog-card__category {
  position:absolute; top:16px; right:16px;
  background:rgba(13,148,136,.9); backdrop-filter:blur(8px);
  padding:5px 14px; border-radius:20px;
  font-size:.68rem; font-weight:600; color:#fff; letter-spacing:.04em; text-transform:uppercase;
  z-index:1;
}
.blog-card__body { padding:24px; flex:1; display:flex; flex-direction:column; }
.blog-card__tag {
  display:inline-block; background:var(--primary-pale); color:var(--primary-dark);
  font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  padding:4px 12px; border-radius:20px; margin-bottom:12px; align-self:flex-start;
}
.blog-card__body h3 {
  font-size:1.05rem; font-weight:700; color:var(--text); line-height:1.45;
  margin-bottom:10px; transition:color .3s ease;
}
.blog-card:hover .blog-card__body h3 { color:var(--primary); }
.blog-card__body p { font-size:.85rem; color:var(--text-muted); line-height:1.65; flex:1; }
.blog-card__footer {
  display:flex; align-items:center; gap:8px;
  margin-top:16px; padding-top:14px;
  border-top:1px solid var(--gray-100);
  font-size:.78rem; color:var(--gray-500);
}
.blog-card__footer .dot { width:4px; height:4px; border-radius:50%; background:var(--gray-300); }

.empty-blog {
  text-align:center; padding:80px 20px;
  max-width:400px; margin:0 auto;
}
.empty-blog .empty-icon {
  width:80px; height:80px; margin:0 auto 24px;
  background:linear-gradient(135deg,var(--primary-pale),var(--blue-pale));
  border-radius:50%; display:flex; align-items:center; justify-content:center;
}
.empty-blog .empty-icon svg { width:36px; height:36px; color:var(--primary); }
.empty-blog h3 { font-size:1.2rem; font-weight:700; color:var(--gray-500); margin-bottom:8px; }
.empty-blog p { font-size:.9rem; color:var(--gray-400); }

/* ---------- NEWS MAGAZINE SLIDER ---------- */
.news-slider {
  position:relative;
  margin-bottom:48px;
  background:#fff;
  border-radius:var(--radius-lg);
  border:1px solid var(--gray-200);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.news-slider__stage {
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:0;
  min-height:400px;
}
.news-slider__featured {
  position:relative;
  overflow:hidden;
}
.news-slider__side {
  display:flex;
  flex-direction:column;
  border-left:1px solid var(--gray-200);
}

/* Featured Card (left) */
.news-featured-card {
  display:block;
  position:relative;
  width:100%;
  height:100%;
  min-height:400px;
  overflow:hidden;
  text-decoration:none;
}
.news-featured-card__img {
  width:100%;
  height:100%;
  object-fit:cover;
  position:absolute;
  inset:0;
  transition:transform .7s cubic-bezier(.22,1,.36,1);
}
.news-featured-card:hover .news-featured-card__img {
  transform:scale(1.05);
}
.news-featured-card__img--placeholder {
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--gray-100),var(--gray-200));
  color:var(--gray-300);
}
.news-featured-card__overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.75) 100%);
  padding:32px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.news-featured-card__badge {
  display:inline-block;
  background:var(--primary);
  color:#fff;
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
  padding:4px 14px;
  border-radius:20px;
  margin-bottom:12px;
  align-self:flex-start;
}
.news-featured-card__title {
  font-size:clamp(1.2rem,2.2vw,1.6rem);
  font-weight:800;
  color:#fff;
  line-height:1.35;
  margin-bottom:8px;
}
.news-featured-card:hover .news-featured-card__title {
  text-decoration:underline;
  text-underline-offset:3px;
}
.news-featured-card__excerpt {
  font-size:.85rem;
  color:rgba(255,255,255,.7);
  line-height:1.6;
  margin-bottom:12px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.news-featured-card__meta {
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.78rem;
  color:rgba(255,255,255,.55);
}

/* Side Cards (right, 3 stacked) */
.news-side-card {
  display:block;
  position:relative;
  flex:1;
  min-height:0;
  overflow:hidden;
  text-decoration:none;
  border-bottom:1px solid var(--gray-200);
}
.news-side-card:last-child { border-bottom:none; }
.news-side-card__img {
  width:100%;
  height:100%;
  object-fit:cover;
  position:absolute;
  inset:0;
  transition:transform .7s cubic-bezier(.22,1,.36,1);
}
.news-side-card:hover .news-side-card__img {
  transform:scale(1.05);
}
.news-side-card__img--placeholder {
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--gray-100),var(--gray-200));
  color:var(--gray-300);
}
.news-side-card__overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,.8) 100%);
  padding:20px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.news-side-card__badge {
  display:inline-block;
  background:rgba(13,148,136,.85);
  color:#fff;
  font-size:.62rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
  padding:2px 10px;
  border-radius:12px;
  margin-bottom:6px;
  align-self:flex-start;
}
.news-side-card__title {
  font-size:.88rem;
  font-weight:700;
  color:#fff;
  line-height:1.35;
  margin-bottom:4px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.news-side-card:hover .news-side-card__title {
  text-decoration:underline;
  text-underline-offset:2px;
}
.news-side-card__meta {
  font-size:.72rem;
  color:rgba(255,255,255,.5);
}

/* Slider Numbered Navigation */
.news-slider__nums {
  display:flex;
  justify-content:center;
  gap:6px;
  padding:14px 16px;
  background:#fff;
  border-top:1px solid var(--gray-100);
  flex-wrap:wrap;
}
.news-slider__num {
  width:36px;
  height:36px;
  border-radius:8px;
  border:1px solid var(--gray-200);
  background:transparent;
  cursor:pointer;
  transition:all .25s ease;
  padding:0;
  font-size:.82rem;
  font-weight:700;
  color:var(--text-muted);
  display:flex;
  align-items:center;
  justify-content:center;
}
.news-slider__num:hover {
  border-color:var(--primary);
  color:var(--primary);
  background:var(--primary-pale);
}
.news-slider__num.active {
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
  box-shadow:0 4px 12px rgba(13,148,136,.25);
}

/* ---------- MAGAZINE GRID ---------- */
.blog-magazine-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:24px;
  padding-top:8px;
}
.mag-card {
  display:flex;
  flex-direction:column;
  background:#fff;
  border-radius:var(--radius);
  border:1px solid var(--gray-200);
  overflow:hidden;
  text-decoration:none;
  transition:all .35s cubic-bezier(.22,1,.36,1);
  box-shadow:var(--shadow-sm);
}
.mag-card:hover {
  transform:translateY(-6px);
  box-shadow:0 16px 48px rgba(13,148,136,.1),0 4px 16px rgba(0,0,0,.05);
  border-color:rgba(13,148,136,.12);
}
.mag-card__img {
  height:180px;
  overflow:hidden;
  position:relative;
  background:linear-gradient(135deg,var(--gray-100),var(--gray-200));
}
.mag-card__img img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .6s cubic-bezier(.22,1,.36,1);
}
.mag-card:hover .mag-card__img img { transform:scale(1.06); }
.mag-card__img--placeholder {
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gray-300);
}
.mag-card__body {
  padding:20px;
  flex:1;
  display:flex;
  flex-direction:column;
}
.mag-card__badge {
  display:inline-block;
  background:var(--primary-pale);
  color:var(--primary-dark);
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
  padding:3px 12px;
  border-radius:16px;
  margin-bottom:10px;
  align-self:flex-start;
}
.mag-card__title {
  font-size:1rem;
  font-weight:700;
  color:var(--text);
  line-height:1.4;
  margin-bottom:8px;
  transition:color .25s ease;
}
.mag-card:hover .mag-card__title { color:var(--primary); }
.mag-card__excerpt {
  font-size:.82rem;
  color:var(--text-muted);
  line-height:1.6;
  flex:1;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.mag-card__footer {
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid var(--gray-100);
  font-size:.75rem;
  color:var(--gray-500);
}
.mag-card__dot {
  width:3px;
  height:3px;
  border-radius:50%;
  background:var(--gray-300);
}

/* ---------- NEWS SLIDER RESPONSIVE ---------- */
@media (max-width: 900px) {
  .news-slider__stage { grid-template-columns:1fr; }
  .news-slider__side { display:grid; grid-template-columns:1fr 1fr 1fr; border-left:none; border-top:1px solid var(--gray-200); }
  .news-side-card { min-height:180px; border-bottom:none; border-right:1px solid var(--gray-200); }
  .news-side-card:last-child { border-right:none; }
  .news-featured-card { min-height:320px; }
}
@media (max-width: 640px) {
  .news-slider__side { grid-template-columns:1fr; }
  .news-side-card { min-height:160px; border-right:none; border-bottom:1px solid var(--gray-200); }
  .news-side-card:last-child { border-bottom:none; }
  .news-featured-card { min-height:260px; }
  .news-featured-card__overlay { padding:20px; }
  .news-slider__num { width:32px; height:32px; font-size:.75rem; }
  .blog-magazine-grid { grid-template-columns:1fr; }
}

/* ---------- BLOG POST (Modern) ---------- */
.bp-hero {
  background:linear-gradient(135deg,var(--navy) 0%,#0D3B3B 50%,#006064 100%);
  padding:140px 0 80px; text-align:center;
  position:relative; overflow:hidden;
}
.bp-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 700px 400px at 30% 60%, rgba(13,148,136,.1) 0%, transparent 70%),
    radial-gradient(ellipse 500px 300px at 70% 30%, rgba(6,182,212,.08) 0%, transparent 70%);
}
.bp-hero::after {
  content:''; position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 30% 40%, rgba(255,255,255,.02) 1px, transparent 1px),
    radial-gradient(circle at 70% 60%, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 50px 50px;
}
.bp-hero .bp-meta {
  display:flex; align-items:center; justify-content:center; gap:12px;
  font-size:.85rem; color:rgba(255,255,255,.55); margin-bottom:16px; position:relative; z-index:1;
}
.bp-hero .bp-meta .sep { width:4px; height:4px; border-radius:50%; background:rgba(255,255,255,.25); }
.bp-hero h1 {
  font-size:clamp(1.6rem,3.5vw,2.6rem); font-weight:900; color:#fff;
  line-height:1.25; max-width:800px; margin:0 auto 16px; position:relative; z-index:1;
}
.bp-hero .bp-category {
  display:inline-block;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.8); font-size:.7rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.08em;
  padding:5px 18px; border-radius:20px; position:relative; z-index:1;
}
.bp-section { padding:60px 0 80px; background:var(--ice); }
.bp-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }
.bp-content {
  background:#fff; border-radius:16px; padding:48px 56px;
  box-shadow:0 1px 3px rgba(0,0,0,.04); border:1px solid var(--gray-200);
  font-size:1.05rem; line-height:1.9; color:var(--gray-700);
}
.bp-content h2 {
  font-size:1.5rem; font-weight:800; color:var(--text);
  margin:48px 0 16px; padding-bottom:8px;
  border-bottom:2px solid var(--gray-100);
}
.bp-content h2:first-child { margin-top:0; }
.bp-content h3 { font-size:1.2rem; font-weight:700; color:var(--text); margin:36px 0 12px; }
.bp-content p { margin-bottom:20px; }
.bp-content ul,.bp-content ol { margin-bottom:20px; padding-left:24px; }
.bp-content li { margin-bottom:8px; }
.bp-content a { color:var(--primary); text-decoration:underline; text-underline-offset:3px; }
.bp-content a:hover { color:var(--primary-dark); }
.bp-content blockquote {
  border-left:4px solid var(--primary);
  padding:20px 28px; margin:32px 0;
  background:linear-gradient(135deg,var(--primary-pale) 0%,#fff 100%);
  border-radius:0 12px 12px 0;
  font-style:italic; color:var(--gray-600); font-size:1.05rem;
}
.bp-content img { max-width:100%; height:auto; border-radius:12px; margin:32px 0; box-shadow:0 4px 20px rgba(0,0,0,.06); }
.bp-content pre {
  background:#0F172A; color:#E2E8F0;
  padding:24px 28px; border-radius:12px;
  overflow-x:auto; font-size:.85rem; line-height:1.7;
  margin:28px 0; border:1px solid rgba(255,255,255,.06);
}
.bp-content code { font-family:'JetBrains Mono','Fira Code',monospace; font-size:.85em; }
.bp-content p > code { background:var(--gray-100); padding:2px 8px; border-radius:4px; color:var(--primary-dark); }
.bp-image-wrap { margin-bottom:40px; margin-top:-20px; }
.bp-image-wrap img {
  width:100%; max-height:500px; object-fit:cover;
  border-radius:16px; box-shadow:0 8px 30px rgba(0,0,0,.08);
}
.bp-sidebar { position:sticky; top:120px; }
.bp-sidebar-card {
  background:#fff; border:1px solid var(--gray-200);
  border-radius:16px; padding:28px;
  box-shadow:0 1px 3px rgba(0,0,0,.04);
  margin-bottom:24px;
  transition:box-shadow .3s ease;
}
.bp-sidebar-card:hover { box-shadow:0 4px 16px rgba(0,0,0,.06); }
.bp-sidebar-card h4 {
  font-size:.73rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; color:var(--gray-400); margin-bottom:16px;
}
.bp-sidebar-card .cta-text { font-size:.9rem; color:var(--text-muted); margin-bottom:16px; line-height:1.6; }
.bp-sidebar-card .btn--full { width:100%; text-align:center; justify-content:center; }
.bp-sidebar-card--cta {
  background:linear-gradient(135deg,var(--navy) 0%,#0D3B3B 100%);
  border-color:transparent; color:#fff;
}
.bp-sidebar-card--cta h4 { color:rgba(255,255,255,.6); }
.bp-sidebar-card--cta .cta-text { color:rgba(255,255,255,.7); }
.bp-share { display:flex; gap:8px; }
.bp-share a {
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  border-radius:10px; background:var(--gray-100); color:var(--gray-500);
  transition:all .3s ease; text-decoration:none;
}
.bp-share a:hover { background:var(--primary); color:#fff; transform:translateY(-2px); }
.bp-share a.share-wa:hover { background:#25D366; }
.bp-share a.share-fb:hover { background:#1877F2; }
.bp-share a.share-tw:hover { background:#000; }
.bp-nav { display:flex; justify-content:space-between; align-items:center; margin-top:48px; padding-top:28px; border-top:1px solid var(--gray-200); flex-wrap:wrap; gap:16px; }

/* ---------- AUTHOR BIO ---------- */
.bp-author {
  display:flex; align-items:center; gap:16px;
  margin-top:48px; padding:24px 28px;
  background:var(--gray-50); border-radius:12px;
  border:1px solid var(--gray-200);
}
.bp-author__avatar {
  width:56px; height:56px; border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--blue));
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:800; font-size:1.2rem;
  flex-shrink:0;
}
.bp-author__info h4 { font-size:.9rem; font-weight:700; color:var(--navy); margin-bottom:2px; }
.bp-author__info p { font-size:.8rem; color:var(--text-muted); margin:0; }

/* ---------- QUOTE / TEKLİF ---------- */
.quote-section { padding:80px 0; background:var(--ice); position:relative; }
.quote-section::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(13,148,136,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,148,136,0.02) 1px, transparent 1px);
  background-size: 40px 40px;
}
.quote-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:60px; align-items:start; }
.quote-info h2 { font-size:1.6rem; font-weight:800; color:var(--navy); margin-bottom:16px; }
.quote-info p { color:var(--text-muted); line-height:1.8; margin-bottom:28px; }
.quote-info-list { display:flex; flex-direction:column; gap:16px; }
.quote-info-item { display:flex; gap:12px; align-items:flex-start; }
.qi-dot { width:8px; height:8px; border-radius:50%; background:var(--primary); flex-shrink:0; margin-top:6px; }
.quote-info-item p { margin:0; font-size:.9rem; color:var(--text-muted); }
.quote-info-item strong { display:block; font-size:.95rem; color:var(--navy); margin-bottom:4px; }
.quote-form-card { background:#fff; border:1px solid var(--gray-200); border-radius:var(--radius-lg); padding:48px 40px; }
.quote-form-card h3 { font-size:1.3rem; font-weight:800; color:var(--navy); margin-bottom:6px; }
.quote-form-card p.subtitle { font-size:.85rem; color:var(--text-muted); margin-bottom:28px; }
.ql-tabs { display:flex; gap:2px; background:var(--gray-100); border-radius:var(--radius-sm); padding:4px; margin-bottom:28px; }
.ql-tab { flex:1; padding:10px; text-align:center; font-size:.85rem; font-weight:600; color:var(--gray-500); border:none; background:none; border-radius:calc(var(--radius-sm) - 2px); cursor:pointer; transition:all .2s; }
.ql-tab.active { background:#fff; color:var(--primary); box-shadow:var(--shadow-sm); }
.ql-panel { display:none; }
.ql-panel.active { display:block; }

/* ---------- TRACKING ---------- */
.tracking-section { padding:80px 0; background:var(--ice); position:relative; }
.tracking-section::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(13,148,136,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,148,136,0.02) 1px, transparent 1px);
  background-size: 40px 40px;
}
.tracking-login-card {
  max-width:380px; margin:0 auto; text-align:center;
  background:#fff; border:1px solid var(--gray-200); border-radius:var(--radius-lg);
  padding:40px 36px; box-shadow:var(--shadow);
}
.tracking-login-card h2 { font-size:1.2rem; font-weight:800; color:var(--navy); margin-bottom:8px; }
.tracking-login-card p { font-size:.85rem; color:var(--text-muted); margin-bottom:20px; }
.tracking-dashboard { display:none; }
.tracking-table-wrap { overflow-x:auto; border:1px solid var(--gray-200); border-radius:var(--radius); }
.tracking-table { width:100%; border-collapse:collapse; font-size:.88rem; }
.tracking-table th { background:var(--gray-100); padding:14px 16px; text-align:left; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--gray-500); }
.tracking-table td { padding:14px 16px; border-top:1px solid var(--gray-100); color:var(--text); }
.cal-badge { display:inline-flex; align-items:center; gap:4px; padding:4px 12px; border-radius:20px; font-size:.75rem; font-weight:700; }
.cal-badge--ok { background:#D1FAE5; color:#065F46; }
.cal-badge--warn { background:#FEF3C7; color:#92400E; }
.cal-badge--due { background:#FEE2E2; color:#991B1B; }

/* Device List */
.device-list-add { background:var(--gray-100); border-radius:var(--radius); padding:16px; }
.device-list-add__title { font-size:.82rem; font-weight:700; color:var(--navy); margin-bottom:10px; }
.device-add-row { display:flex; gap:8px; }
.device-add-row input { flex:1; padding:10px 14px; border:1.5px solid var(--gray-200); border-radius:var(--radius-sm); font-size:.85rem; outline:none; }
.device-add-row input:focus { border-color:var(--primary); }
.add-device-btn { padding:10px 20px; background:var(--primary); color:#fff; border:none; border-radius:var(--radius-sm); font-size:.85rem; font-weight:600; cursor:pointer; white-space:nowrap; }
.add-device-btn:hover { background:var(--primary-dark); }
.device-list-table { margin-top:16px; }
.device-list-table__head { display:grid; grid-template-columns:2fr 1fr 1fr 40px; gap:8px; padding:10px 12px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--gray-400); border-bottom:1px solid var(--gray-200); }
.device-list-table__body { max-height:300px; overflow-y:auto; }
.device-list-row__empty { padding:20px; text-align:center; color:var(--gray-400); font-size:.85rem; }
.device-list-row { display:grid; grid-template-columns:2fr 1fr 1fr 40px; gap:8px; padding:10px 12px; align-items:center; border-bottom:1px solid var(--gray-100); font-size:.85rem; }
.device-list-row__remove { width:32px; height:32px; border:none; background:transparent; color:var(--gray-400); border-radius:6px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .2s; }
.device-list-row__remove:hover { background:#FEE2E2; color:#DC2626; }
.quote-list-count { display:flex; justify-content:space-between; padding:12px 12px 0; font-size:.82rem; color:var(--text-muted); }

/* ---------- CONTACT PAGE ---------- */
.contact-section {
  padding:80px 0; background:var(--ice); position:relative;
}
.contact-section::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(ellipse 800px 500px at 20% 30%, rgba(13,148,136,.03) 0%, transparent 70%),
    radial-gradient(ellipse 600px 400px at 80% 70%, rgba(6,182,212,.03) 0%, transparent 70%);
}
.contact-page-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:60px; align-items:start; }
.contact-cards { display:flex; flex-direction:column; gap:20px; margin-bottom:40px; }

/* Contact Card v2 */
.contact-card {
  background:#fff; border:1px solid var(--gray-200);
  border-radius:14px; padding:28px;
  display:flex; gap:20px; align-items:flex-start;
  transition:all .35s cubic-bezier(.22,1,.36,1);
  position:relative; overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.03);
}
.contact-card::before {
  content:''; position:absolute; top:0; left:0;
  width:100%; height:100%;
  background:linear-gradient(135deg, rgba(13,148,136,.02) 0%, transparent 50%);
  opacity:0; transition:opacity .35s ease;
}
.contact-card:hover {
  border-color:rgba(13,148,136,.15);
  box-shadow:0 12px 40px rgba(13,148,136,.08);
  transform:translateY(-3px);
}
.contact-card:hover::before { opacity:1; }
.contact-card__icon {
  width:52px; height:52px;
  background:linear-gradient(135deg,var(--primary-pale),var(--blue-pale));
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  transition:transform .3s ease;
}
.contact-card:hover .contact-card__icon { transform:scale(1.05) rotate(-3deg); }
.contact-card__icon svg { width:22px; height:22px; stroke:var(--primary); }
.contact-card h4 { font-size:.82rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); margin-bottom:4px; }
.contact-card a,.contact-card span { font-size:1rem; color:var(--navy); font-weight:600; }
.contact-card a:hover { color:var(--primary); }

/* Contact Form v2 */
.contact-form-card {
  background:#fff; border:1px solid var(--gray-200);
  border-radius:16px; padding:48px 44px;
  box-shadow:0 1px 3px rgba(0,0,0,.03);
}
.contact-form-card h3 {
  font-size:1.3rem; font-weight:800; color:var(--navy);
  margin-bottom:8px;
}
.contact-form-card .form-subtitle {
  font-size:.85rem; color:var(--text-muted);
  margin-bottom:28px;
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-group { margin-bottom:18px; }
.form-group label {
  display:block; font-size:.78rem; font-weight:600;
  color:var(--gray-600); text-transform:uppercase; letter-spacing:.05em;
  margin-bottom:6px; transition:color .2s ease;
}
.form-group input,
.form-group textarea,
.form-group select {
  width:100%; padding:12px 16px;
  border:1.5px solid var(--gray-200);
  border-radius:10px; font-size:.95rem;
  font-family:inherit;
  background:#fff;
  color:var(--text);
  transition:all .25s ease;
  outline:none;
}
.form-group input:focus,
.form-group textarea:focus {
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(13,148,136,.08);
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--gray-400); }
.form-group textarea { resize:vertical; min-height:120px; }

.success-msg {
  background:linear-gradient(135deg,#D1FAE5,#ECFDF5);
  border:1px solid #6EE7B7;
  border-radius:12px; padding:20px 24px;
  color:#065F46; font-weight:600; margin-bottom:24px;
  display:flex; align-items:center; gap:12px;
}
.success-msg svg { width:24px; height:24px; flex-shrink:0; }

.error-msg {
  background:linear-gradient(135deg,#FEE2E2,#FEF2F2);
  border:1px solid #FCA5A5;
  border-radius:12px; padding:20px 24px;
  color:#991B1B; font-weight:600; margin-bottom:24px;
  display:flex; align-items:center; gap:12px;
}

.map-embed {
  margin-top:32px; border-radius:14px; overflow:hidden;
  border:1px solid var(--gray-200);
  box-shadow:0 4px 16px rgba(0,0,0,.04);
}

/* ---------- FOOTER ---------- */
/* ---------- FOOTER (21st.dev SaaS Style) ---------- */
.footer {
  background:linear-gradient(180deg,#0B1D2E 0%,#071521 100%);
  color:rgba(255,255,255,.7);
  position:relative;
  overflow:hidden;
}
.footer__glow {
  position:absolute;
  top:-200px;
  left:50%;
  transform:translateX(-50%);
  width:600px;
  height:400px;
  background:radial-gradient(ellipse,rgba(13,148,136,.12) 0%,transparent 70%);
  pointer-events:none;
  z-index:0;
}
.footer__wrapper {
  position:relative;
  z-index:1;
  padding:60px 24px 0;
}

/* Footer Top: Brand + Newsletter */
.footer__top {
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer__brand { display:flex; flex-direction:column; }
.footer__logo {
  display:inline-flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  margin-bottom:20px;
}
.footer__logo-icon {
  width:44px;
  height:44px;
  flex-shrink:0;
}
.footer__logo-icon svg { width:100%; height:100%; }
.footer__logo-text {
  font-size:1.15rem;
  font-weight:700;
  color:#fff;
  letter-spacing:-.01em;
}
.footer__desc {
  font-size:.88rem;
  color:rgba(255,255,255,.5);
  line-height:1.7;
  max-width:380px;
  margin-bottom:24px;
}
.footer__socials { display:flex; gap:10px; }
.footer__social {
  width:38px;
  height:38px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.06);
  transition:all .25s ease;
}
.footer__social:hover {
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(13,148,136,.3);
}

/* Newsletter CTA */
.footer__newsletter {
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:linear-gradient(135deg,rgba(13,148,136,.08) 0%,rgba(13,148,136,.03) 100%);
  border:1px solid rgba(13,148,136,.12);
  border-radius:var(--radius-lg);
  padding:36px 32px;
  backdrop-filter:blur(8px);
}
.footer__newsletter h4 {
  font-size:1.1rem;
  font-weight:700;
  color:#fff;
  margin-bottom:8px;
}
.footer__newsletter p {
  font-size:.85rem;
  color:rgba(255,255,255,.5);
  margin-bottom:20px;
  line-height:1.5;
}
.footer__newsletter-btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 24px;
  background:var(--primary);
  color:#fff;
  border-radius:var(--radius);
  font-size:.88rem;
  font-weight:600;
  text-decoration:none;
  transition:all .25s ease;
  width:fit-content;
}
.footer__newsletter-btn:hover {
  background:#0a7a6e;
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(13,148,136,.35);
}

/* Footer Columns */
.footer__columns {
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr 1fr;
  gap:20px;
  padding:48px 0;
}
.footer__col h4 {
  font-size:.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.4);
  margin-bottom:20px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer__col ul {
  display:flex;
  flex-direction:column;
  gap:10px;
}
.footer__col a {
  font-size:.85rem;
  color:rgba(255,255,255,.6);
  transition:color .2s;
  text-decoration:none;
}
.footer__col a:hover { color:#26C6DA; }

/* Contact list */
.footer__contact-list li {
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:.82rem;
  color:rgba(255,255,255,.55);
  line-height:1.5;
}
.footer__contact-list li svg {
  flex-shrink:0;
  margin-top:3px;
  opacity:.5;
}
.footer__contact-list a { color:rgba(255,255,255,.7); transition:color .2s; }
.footer__contact-list a:hover { color:#26C6DA; }

/* Hours list */
.footer__hours-list li {
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:6px 0;
  font-size:.82rem;
}
.footer__hours-list li span:first-child { color:rgba(255,255,255,.5); }
.footer__hours-list li span:last-child { color:rgba(255,255,255,.75); font-weight:600; }
.footer__hours--closed { color:#EF4444 !important; }
.footer__emergency {
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:16px;
  padding:10px 16px;
  background:rgba(13,148,136,.08);
  border:1px solid rgba(13,148,136,.15);
  border-radius:var(--radius-sm);
  font-size:.78rem;
  color:#26C6DA;
  font-weight:600;
}
.footer__emergency svg { flex-shrink:0; }

/* Certificates Bar */
.footer__certs {
  display:flex;
  align-items:center;
  gap:20px;
  padding:20px 0;
  border-top:1px solid rgba(255,255,255,.06);
  flex-wrap:wrap;
}
.footer__certs-label {
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.3);
  flex-shrink:0;
}
.footer__cert {
  display:flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  transition:opacity .2s;
}
.footer__cert:hover { opacity:.8; }
.footer__cert svg { flex-shrink:0; }
.footer__cert span {
  font-size:.78rem;
  font-weight:600;
  color:rgba(255,255,255,.5);
}

/* Footer Bottom */
.footer__bottom {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding:24px 0;
  border-top:1px solid rgba(255,255,255,.06);
  font-size:.8rem;
  color:rgba(255,255,255,.3);
  flex-wrap:wrap;
}
.footer__bottom-links {
  display:flex;
  align-items:center;
  gap:16px;
}
.footer__bottom-links a {
  color:rgba(255,255,255,.4);
  text-decoration:none;
  transition:color .2s;
}
.footer__bottom-links a:hover { color:#26C6DA; }

/* ---------- FABs ---------- */
.fab-whatsapp {
  position:fixed;
  right:24px; bottom:24px;
  width:44px; height:44px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:999;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  transition:all .25s ease;
}
.fab-whatsapp:hover { transform:scale(1.06); box-shadow:0 8px 32px rgba(37,211,102,.5); }

/* ---------- COOKIE CONSENT ---------- */
.cookie-consent {
  position:fixed;
  bottom:0; left:0; right:0;
  background:rgba(11,29,46,.97);
  backdrop-filter:blur(12px);
  z-index:1500;
  padding:16px 0;
  display:none;
  border-top:1px solid rgba(255,255,255,.05);
}
.cookie-consent.show { display:block; }
.cookie-consent__inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.cookie-consent__text {
  font-size:.85rem;
  color:rgba(255,255,255,.6);
  line-height:1.6;
}
.cookie-consent__text a {
  color:#26C6DA;
  text-decoration:underline;
}
.cookie-consent__actions { flex-shrink:0; }
.cookie-consent__accept { white-space:nowrap; }

/* ---------- PAGE LOADING ---------- */
.page-loading {
  position:fixed;
  inset:0;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  transition:opacity .5s ease;
}
.page-loading.hide { opacity:0; pointer-events:none; }
.page-loading__spinner {
  width:40px; height:40px;
  border:3px solid var(--gray-200);
  border-top-color:var(--primary);
  border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ============================================================
   21st.dev Magic UI Inspired Enhancements
   ============================================================ */

/* ---------- ANIMATED GRADIENT TEXT ---------- */
.gradient-text {
  background: linear-gradient(
    135deg,
    #fff 0%,
    #5EEAD4 25%,
    #26C6DA 50%,
    #00ACC1 75%,
    #fff 100%
  );
  background-size: 300% 300%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradientShift 6s ease-in-out infinite;
}
@keyframes gradientShift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* ---------- BORDER BEAM / GLOW HOVER ---------- */
.border-beam {
  position: relative;
  overflow: hidden;
}
.border-beam::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 2px;
  background: linear-gradient(
    var(--beam-angle, 0deg),
    transparent 40%,
    var(--primary) 50%,
    transparent 60%
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.4s ease;
  animation: beamRotate 4s linear infinite;
  pointer-events: none;
}
.border-beam:hover::before {
  opacity: 1;
}
@keyframes beamRotate {
  to { --beam-angle: 360deg; }
}
@property --beam-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

/* ---------- SHIMMER SHINE BUTTON ---------- */
.btn--shimmer {
  position: relative;
  overflow: hidden;
}
.btn--shimmer::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.3) 50%,
    transparent 100%
  );
  transition: left 0.5s ease;
}
.btn--shimmer:hover::after {
  left: 100%;
}

/* ---------- GRID PATTERN BACKGROUND ---------- */
.grid-pattern {
  background-image:
    linear-gradient(rgba(13, 148, 136, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13, 148, 136, 0.03) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* ---------- BLUR FADE ENTRANCE ---------- */
.blur-fade {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
  transition: opacity 0.6s ease, filter 0.6s ease, transform 0.6s ease;
}
.blur-fade.in-view {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

/* Stagger delays for children */
.stagger-children > *:nth-child(1) { transition-delay: 0ms; }
.stagger-children > *:nth-child(2) { transition-delay: 80ms; }
.stagger-children > *:nth-child(3) { transition-delay: 160ms; }
.stagger-children > *:nth-child(4) { transition-delay: 240ms; }
.stagger-children > *:nth-child(5) { transition-delay: 320ms; }
.stagger-children > *:nth-child(6) { transition-delay: 400ms; }

/* ---------- CATEGORY CARD STROKE HOVER ---------- */
.category-card--stroke {
  position: relative;
  background: #fff;
  border: 2px solid var(--gray-200);
  transition: all 0.3s ease;
}
.category-card--stroke:hover {
  border-color: var(--primary);
  box-shadow:
    0 0 0 4px rgba(13, 148, 136, 0.08),
    0 8px 32px rgba(13, 148, 136, 0.12);
  transform: translateY(-3px);
}

/* ---------- DEVICE WIZARD GLASS MORPHISM (legacy — now in wizard section) ---------- */

/* ---------- MEGA MENU ENHANCED ---------- */
.mega-menu--enhanced {
  border: 1px solid rgba(13, 148, 136, 0.08);
  box-shadow:
    0 24px 80px rgba(0, 0, 0, 0.12),
    0 0 0 1px rgba(13, 148, 136, 0.05);
}
.mega-menu--enhanced .mega-card {
  position: relative;
  overflow: hidden;
}

/* ---------- BLOG CARD ENHANCED ---------- */
.blog-card--enhanced {
  position: relative;
  overflow: hidden;
}
.blog-card--enhanced::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--blue));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
.blog-card--enhanced:hover::after {
  transform: scaleX(1);
}

/* ---------- HERO SLIDER FLOATING SHAPES ---------- */
.hero-slider__shape--3 {
  top: 20%;
  left: 60%;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(94, 234, 212, 0.08), transparent 70%);
  animation: heroShapeFloat 20s ease-in-out infinite;
}
.hero-slider__shape--4 {
  bottom: 10%;
  right: 20%;
  width: 150px;
  height: 150px;
  background: radial-gradient(circle, rgba(38, 198, 218, 0.06), transparent 70%);
  animation: heroShapeFloat 14s ease-in-out infinite reverse;
}

/* ---------- SCROLL REVEAL UTILITIES ---------- */
.reveal-up {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-up.in-view {
  opacity: 1;
  transform: translateY(0);
}
.reveal-left {
  opacity: 1;
  transform: translateX(0);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-left.in-view {
  opacity: 1;
  transform: translateX(0);
}
.reveal-right {
  opacity: 1;
  transform: translateX(0);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-right.in-view {
  opacity: 1;
  transform: translateX(0);
}
.reveal-scale {
  opacity: 1;
  transform: scale(1);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-scale.in-view {
  opacity: 1;
  transform: scale(1);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1200px) {
  .mega-menu--lg { min-width:600px; }
  .mega-menu__grid--3 { grid-template-columns:1fr 1fr; }
}
@media (max-width: 1024px) {
  .services__grid { grid-template-columns:1fr 1fr; }
  .contact-teaser__grid { grid-template-columns:1fr; gap:40px; }
  .contact-page-grid { grid-template-columns:1fr; }
  .quote-grid { grid-template-columns:1fr; }
  .stats__grid { grid-template-columns:repeat(2,1fr); gap:24px; }
  .category-cards__grid { grid-template-columns:repeat(2,1fr); }
  .wizard-row { grid-template-columns:1fr 1fr; }
  .bp-layout { grid-template-columns:1fr; }
  .bp-sidebar { position:static; }
  .bp-sidebar-card .cta-text { display:none; }
}
@media (max-width: 900px) {
  .footer__top { grid-template-columns:1fr; gap:32px; }
  .footer__columns { grid-template-columns:1fr 1fr; }
}
@media (max-width: 768px) {
  .top-bar__item--static { display:none; }
  .navbar__hamburger { display:flex; }
  .navbar__menu {
    position:fixed;
    top:38px; left:0; right:0;
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    padding:24px 24px 40px;
    box-shadow:0 24px 80px rgba(0,0,0,.12);
    transform:translateY(-110%);
    opacity:0;
    transition:all .4s cubic-bezier(.16,1,.3,1);
    overflow-y:auto;
    max-height:calc(100vh - 38px);
    border:none;
  }
  .navbar__menu.open { transform:translateY(0); opacity:1; }
  .navbar__menu ul { flex-direction:column; gap:4px; }
  .navbar__menu a { padding:14px 16px; font-size:.95rem; border-radius:10px; }
  .navbar__menu a:hover,
  .navbar__menu a.active { background:var(--primary-pale); }
  .navbar__cta { display:none; }
  .navbar__cta-mobile-li { display:block; margin-top:12px; }
  .navbar__cta-mobile { width:100%; justify-content:center; }
  .search-wrapper { display:none; }

  .hero-slider { height:75vw; min-height:360px; max-height:560px; }
  .hero-slider__content { padding:60px 0 40px; }
  .hero-slider__title { font-size:clamp(1.4rem,5vw,2.2rem); }
  .hero-slider__desc { font-size:.95rem; margin-bottom:24px; }
  .hero-slider__actions { gap:10px; }
  .hero-slider__arrows { display:none; }
  .hero-scroll-indicator { display:none; }
  .hero-slider__trust { gap:14px; }
  .hero-slider__badge { font-size:.7rem; padding:4px 12px; margin-bottom:18px; }
  .hero-slider__nav { bottom:16px; gap:8px; }
  .hero-slider__dot { width:28px; height:5px; }
  .hero-slider__dot.active { width:36px; }

  .device-wizard { padding:24px 20px; }
  .wizard-row { grid-template-columns:1fr; }
  .wizard-submit .btn { width:100%; justify-content:center; }

  .services { padding:60px 0; }
  .services__grid { grid-template-columns:1fr; gap:16px; }
  .category-cards__grid { grid-template-columns:repeat(2,1fr); }
  .category-card { aspect-ratio:auto; padding:20px 16px; }

  .stats { padding:48px 0; }
  .stats__grid { grid-template-columns:repeat(2,1fr); gap:20px; }

  .contact-teaser { padding:60px 0; }
  .contact-form-card { padding:28px 20px; }
  .quote-form-card { padding:28px 20px; }

  .blog-hero { padding:100px 0 60px; }
  .blog-section { padding:48px 0; }
  .blog-preview__grid { grid-template-columns:1fr; gap:20px; }
  .bp-hero { padding:110px 0 48px; }
  .bp-content { padding:28px 20px; border-radius:var(--radius); }
  .bp-section { padding:32px 0 48px; }
  .bp-image-wrap { margin-bottom:28px; margin-top:0; }

  .footer__columns { grid-template-columns:1fr; }
  .footer__certs { flex-direction:column; align-items:flex-start; }
  .footer__bottom { flex-direction:column; text-align:center; }
  .footer__bottom-links { justify-content:center; flex-wrap:wrap; }

  .form-row { grid-template-columns:1fr; }

  .about-grid { grid-template-columns:1fr; }
  .contact-page-grid { grid-template-columns:1fr; }

  .device-add-row { flex-direction:column; }
  .device-list-table__head { display:none; }
  .device-list-row { grid-template-columns:1fr 1fr; }

  .hero-search-section { padding:0 0 48px; }

  .mega-menu { display:none; }
  .has-mega { position:relative; }
  .mega-menu {
    position:static;
    transform:none;
    box-shadow:none;
    border:none;
    border-radius:0;
    padding:0 0 0 16px;
    min-width:auto !important;
    opacity:1;
    visibility:visible;
    display:none;
    background:transparent;
  }
  .has-mega:hover .mega-menu { transform:none; }
  .navbar__menu.open .has-mega .mega-menu { display:none; }
  .navbar__menu.open .has-mega.open .mega-menu { display:block; }
  .mega-menu__header { display:none; }
  .mega-menu__grid { grid-template-columns:1fr 1fr !important; gap:8px; }
  .mega-menu__footer { display:none; }
  .mega-menu .mega-card { padding:10px 12px; gap:10px; }
  .mega-menu .mega-card__icon { width:36px; height:36px; min-width:36px; padding:7px; border-radius:10px; }
  .mega-menu .mega-card__title { font-size:.75rem; }
}
@media (max-width: 480px) {
  .container { padding:0 16px; }
  .top-bar__left { gap:12px; }
  .top-bar__item svg { display:none; }
  .top-bar__social { width:26px; height:26px; }
  .hero-slider { height:85vw; min-height:300px; max-height:480px; }
  .hero-slider__content { padding:40px 0 30px; }
  .hero-slider__title { font-size:clamp(1.2rem,6.5vw,1.7rem); margin-bottom:12px; }
  .hero-slider__desc { font-size:.85rem; margin-bottom:20px; }
  .hero-slider__actions { flex-direction:column; width:100%; }
  .hero-slider__actions .btn { width:100%; justify-content:center; font-size:.85rem; padding:12px 20px; }
  .hero-slider__trust { flex-direction:column; gap:8px; }
  .hero-slider__trust-item { font-size:.75rem; }
  .hero-slider__nav { bottom:12px; gap:6px; }
  .hero-slider__dot { width:24px; height:4px; }
  .hero-slider__dot.active { width:32px; }
  .hero-slider__badge { font-size:.65rem; margin-bottom:14px; }
  .device-wizard__trust { flex-direction:column; gap:10px; }
  .stats__grid { grid-template-columns:1fr 1fr; gap:16px; }
  .mega-menu__grid { grid-template-columns:1fr !important; }
  .category-cards__grid { grid-template-columns:repeat(2,1fr); }
  .category-card { aspect-ratio:auto; padding:16px 12px; }
}
/* ---------- Extra small screens (≤420px) ---------- */
@media (max-width: 420px) {
  .top-bar__left .top-bar__item:nth-child(2) { display:none; }
  .top-bar__right .top-bar__social:nth-child(n+4) { display:none; }
  .hero-slider { height:90vw; min-height:260px; max-height:420px; }
  .hero-slider__content { padding:32px 0 24px; }
  .hero-slider__title { font-size:clamp(1rem,7vw,1.4rem); margin-bottom:10px; }
  .hero-slider__desc { font-size:.8rem; margin-bottom:16px; }
  .hero-slider__actions { gap:8px; }
  .hero-slider__actions .btn { font-size:.8rem; padding:10px 16px; }
  .hero-slider__trust-item { font-size:.7rem; }
  .hero-slider__badge { margin-bottom:10px; }
  .section-header__title { font-size:1.5rem !important; }
  .services__grid { gap:12px; }
  .page-content h2 { font-size:1.15rem; }
  .page-content p { font-size:.9rem; }
  .footer__columns { gap:24px; }
}
/* ---------- Mobile content pages responsive ---------- */
@media (max-width: 600px) {
  .page-content { padding:0 4px; }
  .page-content table { font-size:.78rem; display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .page-content table tbody tr td,
  .page-content table thead tr th { padding:6px 8px; white-space:nowrap; }
  .pb-hero h1 { font-size:1.35rem; }
}
/* Legal pages: reduce inline padding-top on mobile */
@media (max-width: 768px) {
  section .section-header + div[style*="font-size"] { padding:0 4px; }
}
@media (max-width: 480px) {
  section[style*="padding-top"] { padding-top:100px !important; }
}
.mega-menu--lg {
  min-width: 680px;
}
.mega-menu--lg .mega-menu__grid--3 {
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

/* ============================================================
   HEALTH MODERN — Header & Footer Redesign v2
   ============================================================ */

/* ---------- Animated Background Blobs ---------- */
.blob {
  position: fixed;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  z-index: -1;
  opacity: 0.15;
  animation: blobFloat 20s ease-in-out infinite;
}
.blob--1 {
  width: 400px; height: 400px;
  top: -100px; left: -100px;
  background: radial-gradient(circle, #10b981, #059669);
}
.blob--2 {
  width: 350px; height: 350px;
  top: 30%; right: -80px;
  background: radial-gradient(circle, #14b8a6, #0d9488);
  animation-delay: -7s;
  animation-duration: 25s;
}
.blob--3 {
  width: 300px; height: 300px;
  bottom: 10%; left: 30%;
  background: radial-gradient(circle, #34d399, #10b981);
  animation-delay: -14s;
  animation-duration: 22s;
}
@keyframes blobFloat {
  0%, 100% { transform: translate(0, 0) scale(1); }
  25% { transform: translate(30px, -40px) scale(1.05); }
  50% { transform: translate(-20px, 20px) scale(0.95); }
  75% { transform: translate(40px, 30px) scale(1.02); }
}

/* ---------- Glass Morphism Utilities ---------- */
.glass {
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(20px) saturate(1.3);
  -webkit-backdrop-filter: blur(20px) saturate(1.3);
  border: 1px solid rgba(255, 255, 255, 0.3);
}
.glass-strong {
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(24px) saturate(1.4);
  -webkit-backdrop-filter: blur(24px) saturate(1.4);
  border: 1px solid rgba(226, 232, 240, 0.4);
}
.glass-card {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(16px) saturate(1.2);
  -webkit-backdrop-filter: blur(16px) saturate(1.2);
  border: 1px solid rgba(255, 255, 255, 0.25);
  box-shadow: 0 8px 32px rgba(13, 148, 136, 0.08);
}
.glass-dark {
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(20px) saturate(1.2);
  -webkit-backdrop-filter: blur(20px) saturate(1.2);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

/* ---------- Premium Navbar v2 ---------- */
.navbar--modern {
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  border-bottom: 1px solid rgba(13, 148, 136, 0.08);
}
.navbar--modern.scrolled {
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 4px 30px rgba(13, 148, 136, 0.08), 0 1px 0 rgba(13, 148, 136, 0.05);
}
.navbar--modern .navbar__menu a {
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.01em;
  padding: 8px 16px;
  border-radius: 10px;
  color: #334155;
  transition: all 0.25s ease;
  position: relative;
}
.navbar--modern .navbar__menu a:hover,
.navbar--modern .navbar__menu a.active {
  background: rgba(13, 148, 136, 0.08);
  color: #059669;
}
.navbar--modern .navbar__menu a::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 60%;
  height: 2px;
  background: linear-gradient(90deg, #10b981, #059669);
  border-radius: 2px;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.navbar--modern .navbar__menu a:hover::after,
.navbar--modern .navbar__menu a.active::after {
  transform: translateX(-50%) scaleX(1);
}

/* ---------- Premium Top Bar v2 ---------- */
.top-bar--modern {
  background: linear-gradient(135deg, #059669 0%, #0d9488 50%, #0f766e 100%);
  overflow: hidden;
}
.top-bar--modern::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(52, 211, 153, 0.2), transparent 60%),
              radial-gradient(ellipse at 80% 50%, rgba(20, 184, 166, 0.15), transparent 60%);
  pointer-events: none;
}
.top-bar--modern .top-bar__inner {
  position: relative;
  z-index: 1;
}
.top-bar--modern .top-bar__social {
  background: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: all 0.25s ease;
}
.top-bar--modern .top-bar__social:hover {
  background: rgba(255, 255, 255, 0.25);
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
}

/* ---------- Premium Mega Menu v2 ---------- */
.mega-menu--v2 {
  border: 1px solid rgba(13, 148, 136, 0.1);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(24px) saturate(1.3);
  -webkit-backdrop-filter: blur(24px) saturate(1.3);
  box-shadow:
    0 24px 80px rgba(0, 0, 0, 0.1),
    0 0 0 1px rgba(13, 148, 136, 0.04),
    0 4px 20px rgba(13, 148, 136, 0.06);
  padding: 24px;
  min-width: 680px;
}
.mega-menu--v2 .mega-menu__header {
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(13, 148, 136, 0.06);
}
.mega-menu--v2 .mega-menu__title {
  font-size: 0.95rem;
  font-weight: 800;
  color: #0f172a;
  letter-spacing: -0.01em;
}
.mega-menu--v2 .mega-menu__sub {
  font-size: 0.75rem;
  color: #64748b;
  margin-top: 2px;
}
.mega-menu--v2 .mega-card {
  border: 1px solid #e8edf2;
  border-radius: 14px;
  padding: 14px 16px;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  background: #fff;
  position: relative;
  overflow: hidden;
}
.mega-menu--v2 .mega-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(13, 148, 136, 0.03), transparent 60%);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.mega-menu--v2 .mega-card:hover {
  border-color: rgba(13, 148, 136, 0.25);
  box-shadow:
    0 4px 20px rgba(13, 148, 136, 0.08),
    0 1px 3px rgba(13, 148, 136, 0.04);
  transform: translateY(-2px);
}
.mega-menu--v2 .mega-card:hover::before {
  opacity: 1;
}
.mega-menu--v2 .mega-card__icon {
  width: 46px;
  height: 46px;
  min-width: 46px;
  border-radius: 12px;
  background: linear-gradient(135deg, #059669, #0d9488);
  padding: 10px;
  box-shadow: 0 4px 12px rgba(5, 150, 105, 0.2);
  position: relative;
  z-index: 1;
}
.mega-menu--v2 .mega-card__title {
  font-size: 0.82rem;
  font-weight: 700;
  color: #0f172a;
  position: relative;
  z-index: 1;
}
.mega-menu--v2 .mega-card__sub {
  font-size: 0.7rem;
  color: #64748b;
  position: relative;
  z-index: 1;
}
.mega-menu--v2 .mega-menu__footer {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(13, 148, 136, 0.06);
}
.mega-menu--v2 .mega-menu__all {
  background: linear-gradient(135deg, rgba(13, 148, 136, 0.06), rgba(5, 150, 105, 0.04));
  border: 1px solid rgba(13, 148, 136, 0.12);
  border-radius: 12px;
  padding: 10px 20px;
  font-size: 0.8rem;
  font-weight: 700;
  color: #0f172a;
  transition: all 0.3s ease;
}
.mega-menu--v2 .mega-menu__all:hover {
  background: linear-gradient(135deg, rgba(13, 148, 136, 0.12), rgba(5, 150, 105, 0.08));
  border-color: rgba(13, 148, 136, 0.25);
  box-shadow: 0 4px 16px rgba(13, 148, 136, 0.1);
  transform: translateY(-1px);
  gap: 12px;
}

/* ---------- Footer Light / White Theme ---------- */
.footer--modern {
  position: relative;
  background: #ffffff;
  border-top: 1px solid #e8edf2;
}
.footer--modern .footer-title {
  font-size: 0.85rem;
  font-weight: 700;
  color: #0f172a;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding-bottom: 10px;
  margin-bottom: 20px;
  border-bottom: 2px solid #10b981;
  display: inline-block;
}
.footer--modern .footer-link {
  display: block;
  font-size: 0.82rem;
  color: #475569;
  padding: 4px 0;
  transition: all 0.2s ease;
  text-decoration: none;
}
.footer--modern .footer-link:hover {
  color: #059669;
  transform: translateX(4px);
}
.footer--modern .footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.82rem;
  color: #475569;
  padding: 6px 10px;
  border-radius: 10px;
  transition: all 0.2s ease;
}
.footer--modern .footer-contact-item:hover {
  background: #f0fdf4;
  color: #059669;
}
.footer--modern .footer-contact-item svg {
  color: #10b981;
  flex-shrink: 0;
  margin-top: 2px;
}
.footer--modern .footer-social-btn {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: #f1f5f9;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #64748b;
  text-decoration: none;
  transition: all 0.25s ease;
}
.footer--modern .footer-social-btn:hover {
  background: #059669;
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(5, 150, 105, 0.25);
}
.footer--modern .footer-accredit-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: #f8fafc;
  border: 1px solid #e8edf2;
  transition: all 0.25s ease;
}
.footer--modern .footer-accredit-card:hover {
  border-color: #10b981;
  background: #f0fdf4;
  box-shadow: 0 2px 12px rgba(16, 185, 129, 0.1);
}
.footer--modern .footer-accredit-card svg {
  color: #10b981;
  flex-shrink: 0;
}
.footer--modern .footer-accredit-title {
  font-size: 0.8rem;
  font-weight: 600;
  color: #0f172a;
}
.footer--modern .footer-accredit-sub {
  font-size: 0.68rem;
  color: #64748b;
}
.footer--modern .footer-hours-card {
  border-radius: 12px;
  padding: 14px;
}
.footer--modern .footer-hours-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 5px 0;
}
.footer--modern .footer-hours-item svg {
  color: #10b981;
  flex-shrink: 0;
}
.footer--modern .footer-hours-day {
  font-size: 0.8rem;
  font-weight: 600;
  color: #0f172a;
}
.footer--modern .footer-hours-time {
  font-size: 0.78rem;
  color: #64748b;
}
.footer--modern .footer-emergency {
  margin-top: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  font-weight: 600;
  color: #dc2626;
}
.footer--modern .footer-emergency svg {
  color: #ef4444;
  flex-shrink: 0;
}

/* ---------- Footer Services Cloud (Horizontal Links) ---------- */
.footer-services-cloud {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 16px;
    padding: 28px 0;
    border-top: 1px solid #e8edf2;
    margin-top: 8px;
}
.footer-services-cloud__label {
    font-size: 0.8rem;
    font-weight: 700;
    color: #0f172a;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.footer-services-cloud__tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 4px 20px;
}
.footer-service-tag {
    font-size: 0.85rem;
    font-weight: 600;
    color: #475569;
    text-decoration: none;
    padding: 4px 0;
    position: relative;
    transition: color 0.2s ease;
    white-space: nowrap;
}
.footer-service-tag::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: #059669;
    transform: scaleX(0);
    transition: transform 0.2s ease;
}
.footer-service-tag:hover {
    color: #059669;
}
.footer-service-tag:hover::after {
    transform: scaleX(1);
}
.footer-service-tag:not(:last-child)::before {
    content: '·';
    position: absolute;
    right: -12px;
    color: #cbd5e1;
    font-weight: 700;
}
@media (max-width: 768px) {
    .footer-services-cloud__tags { gap: 4px 14px; }
    .footer-service-tag { font-size: 0.8rem; }
}

/* ---------- Footer Bottom Light ---------- */
.footer-bottom-slim {
  border-top: 1px solid #e8edf2;
  padding: 20px 0 0;
  margin-top: 32px;
}
.footer-legal-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px 20px;
  font-size: 0.78rem;
  color: #64748b;
}
.footer-legal-links .label {
  font-weight: 600;
  color: #0f172a;
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}
.footer-legal-links a {
  color: #475569;
  text-decoration: none;
  transition: color 0.2s;
}
.footer-legal-links a:hover {
  color: #059669;
}
.footer-mid-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  padding: 24px 0;
}
.footer-mid-row .copyright {
  font-size: 0.78rem;
  color: #64748b;
}
.footer-mid-row .credit {
  font-size: 0.75rem;
  color: #64748b;
}
.footer-mid-row .credit a {
  color: #059669;
  text-decoration: none;
  font-weight: 600;
}
.footer-mid-row .credit a:hover {
  color: #10b981;
}

/* ---------- Footer Partner Logo ---------- */
.footer-logo-light--2 img {
  max-width: 200px;
  height: auto;
  opacity: 0.75;
  transition: opacity 0.25s ease;
}
.footer-logo-light--2 img:hover {
  opacity: 1;
}

/* ---------- Accreditation Badges Bottom ---------- */
.footer-badges {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;
  padding: 20px 0 0;
  border-top: 1px solid #e8edf2;
  margin-top: 0;
}
.footer-badge-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 8px;
  background: #f8fafc;
  border: 1px solid #e8edf2;
  font-size: 0.72rem;
  font-weight: 600;
  color: #0f172a;
}
.footer-badge-item svg {
  width: 20px;
  height: 20px;
  color: #10b981;
  flex-shrink: 0;
}
.footer-badge-pay {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 6px;
  background: #f1f5f9;
  font-size: 0.68rem;
  font-weight: 600;
  color: #334155;
}

/* ---------- Responsive adjustments ---------- */
@media (max-width: 768px) {
  .mega-menu--v2 {
    min-width: auto;
    padding: 16px;
    border-radius: 12px;
  }
  .mega-menu--v2 .mega-card {
    padding: 10px 12px;
  }
  .mega-menu--v2 .mega-card__icon {
    width: 36px;
    height: 36px;
    min-width: 36px;
    padding: 7px;
  }
  .footer--modern .footer-contact-item {
    padding: 6px 10px;
  }
}
