/* ============================================================
   Dr. Mahmoud Al-Balbisi — Cinematic LIGHT
   Clinical white · soft slate-teal ink · medical teal accent
   ============================================================ */

:root{
  --ink:#eef4f6;          /* loader / base surface */
  --ink-2:#e7eff1;
  --white:#10303a;        /* primary text (kept name for reuse) */
  --muted:rgba(16,48,58,.64);
  --faint:rgba(16,48,58,.42);
  --accent:#0fa3b1;       /* medical teal */
  --accent-soft:#0b8492;  /* deeper teal for text on light */
  --accent-glow:rgba(15,163,177,.30);
  --line:rgba(15,70,84,.14);
  --line-2:rgba(15,70,84,.08);
  --glass:rgba(255,255,255,.58);
  --glass-2:rgba(255,255,255,.80);
  --font-display:"El Messiri",serif;
  --font-body:"Readex Pro",system-ui,sans-serif;
  --font-num:"Space Grotesk","Readex Pro",sans-serif;
  --maxw:1280px;
  --bg:#eef4f6;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -webkit-tap-highlight-color:transparent;
  transition:background-color 1.1s ease;
}
::selection{background:var(--accent);color:#fff}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-.01em}

/* ---------- fixed atmosphere ---------- */
#fx{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.9}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.xray{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.6;
  background:
    repeating-linear-gradient(to right,transparent 0 119px,rgba(15,120,135,.05) 119px 120px),
    repeating-linear-gradient(to bottom,transparent 0 119px,rgba(15,120,135,.04) 119px 120px);
  mask-image:radial-gradient(ellipse 90% 80% at 50% 40%,#000 30%,transparent 78%);
}
.vignette{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse 120% 95% at 50% -5%,rgba(15,163,177,.07),transparent 55%);
}
.progress{position:fixed;top:0;inset-inline:0;height:2px;z-index:60;background:transparent}
.progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-soft));box-shadow:0 0 12px var(--accent-glow)}

/* ---------- preloader ---------- */
.loader{
  position:fixed;inset:0;z-index:200;background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;
}
.loader-tooth{width:96px;height:auto;filter:drop-shadow(0 0 22px var(--accent-glow))}
.loader-name{display:flex;gap:.04em;font-family:var(--font-display);font-size:clamp(26px,5vw,46px);font-weight:600;color:var(--white)}
.loader-name span{display:inline-block;opacity:0;filter:blur(14px);transform:translateY(8px)}
.loader-bar{width:140px;height:2px;background:rgba(15,70,84,.14);border-radius:2px;overflow:hidden}
.loader-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-soft))}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;inset-inline:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px clamp(20px,4vw,56px);
  transition:background-color .4s ease,backdrop-filter .4s ease,border-color .4s ease,padding .4s ease,box-shadow .4s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(140%);border-bottom-color:var(--line-2);box-shadow:0 6px 30px rgba(15,70,84,.06);padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--line);border-radius:9px;background:var(--glass-2)}
.brand-mark svg{width:15px;height:auto;stroke:var(--accent);stroke-width:1.4;fill:none}
.brand-txt{display:flex;flex-direction:column;line-height:1.15}
.brand-txt b{font-family:var(--font-display);font-size:15px;font-weight:600}
.brand-txt small{font-size:11px;color:var(--muted)}
.nav-links{display:flex;gap:30px}
.nav-links a{font-size:14.5px;color:var(--muted);position:relative;transition:color .25s}
.nav-links a::after{content:"";position:absolute;bottom:-5px;inset-inline-start:0;width:0;height:1px;background:var(--accent);transition:width .3s}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  font-size:14px;padding:9px 20px;border-radius:999px;color:#fff;
  border:1px solid transparent;background:linear-gradient(180deg,var(--accent),var(--accent-soft));
  box-shadow:0 6px 18px var(--accent-glow);
  transition:transform .3s,box-shadow .3s,filter .3s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 26px var(--accent-glow);filter:brightness(1.05)}
/* keep bar items above the mobile drop-down menu panel */
.brand,.nav-cta,.nav-burger{position:relative;z-index:3}
/* hamburger — hidden on desktop, shown ≤900px */
.nav-burger{
  display:none;width:44px;height:44px;flex:0 0 auto;padding:0;cursor:pointer;
  border:1px solid var(--line);border-radius:12px;background:var(--glass-2);backdrop-filter:blur(10px);
  box-shadow:0 4px 14px rgba(15,70,84,.06);transition:border-color .3s,box-shadow .3s;
}
.nav-burger:hover{border-color:rgba(15,163,177,.45)}
.nav-burger span{position:absolute;left:12px;right:12px;height:2px;border-radius:2px;background:var(--accent-soft);transition:transform .35s ease,opacity .2s ease,top .35s ease}
.nav-burger span:nth-child(1){top:15px}
.nav-burger span:nth-child(2){top:21px}
.nav-burger span:nth-child(3){top:27px}
.nav.menu-open .nav-burger span:nth-child(1){top:21px;transform:rotate(45deg)}
.nav.menu-open .nav-burger span:nth-child(2){opacity:0}
.nav.menu-open .nav-burger span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* ---------- shared ---------- */
section{position:relative;z-index:2}
/* anchor jumps (incl. mobile menu) land below the fixed nav */
:where(section[id],footer[id]){scroll-margin-top:84px}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-soft);
  font-family:var(--font-num);font-weight:500;
}
.eyebrow .ed{width:24px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}
.sec-head{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.sec-head h2{font-size:clamp(34px,5.4vw,68px);margin:18px 0 16px}
.sec-head p{color:var(--muted);max-width:46ch;font-size:clamp(16px,1.5vw,19px)}

/* glass buttons */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  padding:15px 30px;border-radius:999px;font-size:15.5px;font-weight:500;overflow:hidden;
  border:1px solid var(--line);background:var(--glass-2);backdrop-filter:blur(10px);color:var(--white);
  box-shadow:0 4px 18px rgba(15,70,84,.06);
  transition:transform .3s,box-shadow .3s,border-color .3s,background .3s;
}
.btn span{position:relative;z-index:2}
.btn::before{
  content:"";position:absolute;top:0;inset-inline-start:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-18deg);transition:none;
}
.btn:hover::before{animation:shimmer 1s ease}
@keyframes shimmer{from{inset-inline-start:-120%}to{inset-inline-start:140%}}
.btn:hover{transform:translateY(-2px);border-color:rgba(15,163,177,.45);box-shadow:0 12px 30px rgba(15,70,84,.10)}
.btn-primary{color:#fff;background:linear-gradient(180deg,var(--accent),var(--accent-soft));border-color:transparent;box-shadow:0 8px 24px var(--accent-glow)}
.btn-primary:hover{box-shadow:0 14px 40px var(--accent-glow);filter:brightness(1.04)}

/* ============ HERO ============ */
.hero{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:104px clamp(20px,4vw,56px) 88px;overflow-x:clip}
.hero-motif{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(60vh,86vw,640px);z-index:0;pointer-events:none;will-change:transform;opacity:0}
.hero-motif svg{width:100%;height:auto;filter:drop-shadow(0 0 60px rgba(15,163,177,.12))}
.hero-inner{position:relative;z-index:3;max-width:1000px;display:flex;flex-direction:column;align-items:center;gap:18px}
.hero-name{
  font-size:clamp(40px,8.5vw,116px);font-weight:700;line-height:.95;letter-spacing:-.02em;
  display:flex;flex-wrap:nowrap;white-space:nowrap;max-width:none;justify-content:center;gap:0 .06em;
  color:#0c2a34;text-shadow:0 6px 40px rgba(15,163,177,.18);
}
.hero-name .ch{display:inline-block;opacity:0;filter:blur(16px);transform:translateY(.18em);color:#0c2a34}
.hero-name .sp{width:.32em}
.hero-role{font-size:clamp(16px,2vw,22px);color:var(--accent-soft);font-weight:500;letter-spacing:.01em;opacity:0;transform:translateY(18px)}
.hero-lede{max-width:54ch;color:var(--muted);font-size:clamp(16px,1.6vw,20px);opacity:0;transform:translateY(18px)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:8px;opacity:0;transform:translateY(18px)}
.hero-stats{display:flex;gap:clamp(28px,5vw,76px);margin-top:30px;flex-wrap:wrap;justify-content:center;opacity:0;transform:translateY(18px)}
.stat{display:flex;flex-direction:column;align-items:center;gap:4px}
.stat .num{font-family:var(--font-num);font-size:clamp(40px,5vw,68px);font-weight:300;line-height:1;color:var(--accent-soft);font-variant-numeric:tabular-nums}
.stat span{font-size:13.5px;color:var(--faint);max-width:15ch;text-align:center}
.shimmer-in{opacity:0}
.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:9px;font-size:12px;letter-spacing:.18em;color:var(--faint);text-transform:uppercase;opacity:0}

/* ---- hero portrait (cinematic side bleed) ---- */
.hero-portrait{
  position:absolute;bottom:clamp(24px,5vh,80px);left:clamp(16px,4.5vw,80px);z-index:2;
  width:clamp(230px,20vw,310px);margin:0;
  opacity:0;transform:translateY(34px);will-change:transform,opacity;
}
.hp-frame{
  position:relative;width:100%;aspect-ratio:1/1;pointer-events:auto;
  /* image is now a transparent cutout — shadow hugs the silhouette */
  filter:drop-shadow(0 22px 26px rgba(15,70,84,.26)) drop-shadow(0 4px 10px rgba(15,70,84,.16));
}
.hp-frame image-slot{display:block;width:100%;height:100%}
.hero-portrait.is-float{animation:hpFloat 7s ease-in-out infinite}
@keyframes hpFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.scroll-cue span{width:1px;height:40px;background:linear-gradient(180deg,var(--accent),transparent);position:relative;overflow:hidden}
.scroll-cue span::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--accent-soft);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%{top:-50%}60%,100%{top:100%}}

/* ============ ABOUT — horizontal pin ============ */
.about{background:transparent}
.about-pin{height:100svh;overflow:hidden;display:flex;align-items:center;direction:ltr}
.about-track{display:flex;flex-direction:row;direction:ltr;width:max-content;gap:clamp(60px,9vw,170px);padding:0 clamp(40px,10vw,180px);will-change:transform;align-items:center}
.apanel{flex:0 0 auto;direction:rtl;display:flex;flex-direction:column;justify-content:center;min-height:60vh}
.apanel--intro{width:min(78vw,640px)}
.apanel--intro .eyebrow{margin-bottom:24px}
.apanel-head{font-size:clamp(36px,5.5vw,76px);line-height:1.05;margin-bottom:24px}
.apanel-lede{font-size:clamp(17px,1.8vw,22px);color:var(--muted);max-width:42ch}
.apanel-hint{margin-top:34px;font-size:12px;letter-spacing:.2em;color:var(--faint);font-family:var(--font-num)}
.apanel--avatar{width:min(80vw,460px);align-items:center;text-align:center}
.avatar-glow{position:relative;width:min(60vw,320px);aspect-ratio:3/3.6;display:grid;place-items:center}
.avatar-glow .ring{position:absolute;border-radius:50%;border:1px solid rgba(15,163,177,.30)}
.avatar-glow .r1{inset:-6%;animation:spin 22s linear infinite}
.avatar-glow .r2{inset:-14%;border-style:dashed;border-color:rgba(15,163,177,.18);animation:spin 40s linear infinite reverse}
.avatar-glow .r3{inset:2%;border-color:rgba(15,163,177,.45);box-shadow:0 0 50px var(--accent-glow) inset}
@keyframes spin{to{transform:rotate(360deg)}}
.avatar-frame{position:relative;width:86%;height:86%;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--glass-2);box-shadow:0 30px 70px rgba(15,70,84,.18)}
.avatar-frame image-slot{display:block;width:100%;height:100%}
.avatar-cap{margin-top:26px}
.avatar-cap b{display:block;font-family:var(--font-display);font-size:20px}
.avatar-cap span{font-size:14px;color:var(--muted)}
.apanel--creds{width:min(86vw,560px);display:grid;grid-template-columns:1fr 1fr;gap:18px;align-content:center}
.cred{display:flex;gap:14px;align-items:flex-start;padding:22px;border:1px solid var(--line);border-radius:16px;background:var(--glass-2);backdrop-filter:blur(8px);box-shadow:0 10px 30px rgba(15,70,84,.05)}
.cred-k{flex:0 0 auto;width:42px;height:42px;display:grid;place-items:center;border-radius:11px;background:rgba(15,163,177,.10);border:1px solid rgba(15,163,177,.28)}
.cred-k svg{width:21px;height:21px;stroke:var(--accent);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.cred b{display:block;font-family:var(--font-display);font-size:16px;margin-bottom:3px}
.cred span{font-size:13.5px;color:var(--muted);line-height:1.45}

/* ============ SERVICES ============ */
.services{padding:clamp(100px,12vh,170px) 0}
.cards{max-width:var(--maxw);margin:60px auto 0;padding:0 clamp(20px,4vw,56px);display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  position:relative;padding:38px 32px 34px;border-radius:22px;
  border:1px solid var(--line);background:linear-gradient(180deg,var(--glass-2),var(--glass));
  backdrop-filter:blur(12px);overflow:hidden;
  transform-style:preserve-3d;transition:box-shadow .4s,border-color .4s;
  box-shadow:0 14px 40px rgba(15,70,84,.06);
  min-height:330px;display:flex;flex-direction:column;
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:22px;opacity:0;transition:opacity .4s;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(15,163,177,.14),transparent 60%);
}
.card:hover::before{opacity:1}
.card:hover{border-color:rgba(15,163,177,.40);box-shadow:0 30px 60px rgba(15,70,84,.14)}
.card-no{font-family:var(--font-num);font-size:14px;color:var(--accent-soft);letter-spacing:.1em;transform:translateZ(40px)}
.card-ic{width:54px;height:54px;margin:18px 0 22px;display:grid;place-items:center;border-radius:14px;background:rgba(15,163,177,.10);border:1px solid rgba(15,163,177,.28);transform:translateZ(60px);transition:transform .4s}
.card:hover .card-ic{transform:translateZ(60px) translateY(-4px)}
.card-ic svg{width:27px;height:27px;stroke:var(--accent);stroke-width:1.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.card h3{font-size:23px;margin-bottom:12px;transform:translateZ(34px)}
.card p{color:var(--muted);font-size:15px;flex:1;transform:translateZ(20px)}
.card-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;transform:translateZ(24px)}
.card-tags span{font-size:12px;padding:5px 11px;border-radius:999px;border:1px solid var(--line);color:var(--muted);background:rgba(15,163,177,.05)}

/* ============ PROCEDURES — accordion ============ */
.procedures{padding:clamp(100px,12vh,170px) 0}
.acc{max-width:1100px;margin:54px auto 0;padding:0 clamp(20px,4vw,56px);display:flex;flex-direction:column;gap:14px}
.acc-item{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--glass-2);transition:background .5s,border-color .5s,flex-grow .5s,box-shadow .5s}
.acc-item.open{background:linear-gradient(120deg,rgba(15,163,177,.10),rgba(15,163,177,.02));border-color:rgba(15,163,177,.40);box-shadow:0 18px 44px rgba(15,70,84,.08)}
.acc-head{width:100%;display:flex;align-items:center;gap:22px;padding:26px 30px;background:none;border:0;cursor:pointer;color:var(--white);text-align:start;font-family:inherit}
.acc-no{font-family:var(--font-num);font-size:15px;color:var(--accent-soft);opacity:.8}
.acc-head h3{flex:1;font-size:clamp(20px,2.4vw,30px);transition:color .4s}
.acc-plus{position:relative;width:20px;height:20px;flex:0 0 auto}
.acc-plus::before,.acc-plus::after{content:"";position:absolute;background:var(--accent);border-radius:2px;transition:transform .4s,opacity .4s}
.acc-plus::before{top:9px;left:0;width:20px;height:2px}
.acc-plus::after{left:9px;top:0;width:2px;height:20px}
.acc-item.open .acc-plus::after{transform:rotate(90deg);opacity:0}
.acc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .55s cubic-bezier(.4,0,.2,1)}
.acc-item.open .acc-body{grid-template-rows:1fr}
.acc-inner{overflow:hidden;padding:0 30px}
.acc-item.open .acc-inner{padding-bottom:30px}
.acc-line{color:var(--muted);font-size:clamp(15px,1.5vw,18px);max-width:62ch;margin-bottom:12px;opacity:0;transform:translateY(12px)}
.acc-item.open .acc-line{animation:accLine .6s ease forwards}
.acc-item.open .acc-line:nth-child(2){animation-delay:.08s}
.acc-item.open .acc-line:nth-child(3){animation-delay:.16s}
@keyframes accLine{to{opacity:1;transform:none}}
.acc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.acc-tags span{font-size:12px;padding:5px 12px;border-radius:999px;border:1px solid rgba(15,163,177,.30);color:var(--accent-soft);background:rgba(15,163,177,.07)}

/* ============ BEFORE / AFTER SLIDER ============ */
.results{padding:clamp(100px,12vh,170px) 0}
.ba-wrap{max-width:1040px;margin:56px auto 0;padding:0 clamp(20px,4vw,56px)}
.ba{
  position:relative;width:100%;aspect-ratio:16/10;border-radius:24px;overflow:hidden;
  border:1px solid var(--line);box-shadow:0 30px 70px rgba(15,70,84,.12);
  --pos:50%;cursor:ew-resize;user-select:none;touch-action:pan-y;
  background:#dfeaec;
}
.ba-panel{position:absolute;inset:0;display:grid;place-items:center}
/* BEFORE / AFTER image layers */
.ba-before{position:absolute;inset:0;clip-path:inset(0 calc(100% - var(--pos)) 0 0)}
.ba-tag{
  position:absolute;top:20px;font-family:var(--font-num);font-size:13px;letter-spacing:.14em;
  padding:7px 16px;border-radius:999px;backdrop-filter:blur(6px);z-index:3;
}
.ba-tag--before{inset-inline-start:20px;background:rgba(70,84,88,.30);color:#fff;border:1px solid rgba(255,255,255,.30)}
.ba-tag--after{inset-inline-end:20px;background:rgba(255,255,255,.62);color:var(--accent-soft);border:1px solid rgba(15,163,177,.30)}
/* divider + grip */
.ba-divider{position:absolute;top:0;bottom:0;left:var(--pos);transform:translateX(-50%);width:2px;z-index:4;pointer-events:none}
.ba-line{position:absolute;inset:0;width:2px;background:linear-gradient(180deg,transparent,#fff 12%,#fff 88%,transparent);box-shadow:0 0 16px var(--accent-glow),0 0 4px rgba(255,255,255,.8)}
.ba-grip{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;gap:0;
  background:rgba(255,255,255,.9);border:1px solid rgba(15,163,177,.4);
  box-shadow:0 8px 26px rgba(15,70,84,.22),0 0 0 6px rgba(15,163,177,.10),0 0 30px var(--accent-glow);
  pointer-events:auto;cursor:ew-resize;
}
.ba-grip::before{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(15,163,177,.30);animation:ping 2.6s ease-out infinite}
.ba-grip svg{width:26px;height:26px;stroke:var(--accent-soft);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ba-hint{margin-top:18px;text-align:center;font-family:var(--font-num);font-size:12px;letter-spacing:.18em;color:var(--faint)}

/* ============ CLINIC GALLERY ============ */
.gallery{padding:clamp(90px,11vh,150px) 0;overflow:hidden}
.gallery .sec-head{margin-bottom:48px}
.gal-viewport{position:relative;width:100%;direction:ltr;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.gal-track{display:flex;gap:24px;width:max-content;direction:ltr;animation:galScroll 46s linear infinite;will-change:transform}
.gal-viewport:hover .gal-track{animation-play-state:paused}
@keyframes galScroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 12px))}}
.gcard{
  position:relative;flex:0 0 auto;width:clamp(260px,30vw,360px);aspect-ratio:4/5;
  border-radius:20px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 18px 44px rgba(15,70,84,.10);direction:rtl;
}
.gcard-bg{position:absolute;inset:0}
.gcard-bg::before,.gcard-bg::after{content:"";position:absolute;border-radius:50%}
/* per-card gradient + geometric accents */
.gcard:nth-child(6n+1) .gcard-bg{background:linear-gradient(150deg,#d6f1f4,#a6dfe6)}
.gcard:nth-child(6n+2) .gcard-bg{background:linear-gradient(150deg,#e3eef0,#bcd3d7)}
.gcard:nth-child(6n+3) .gcard-bg{background:linear-gradient(150deg,#cdeef0,#8fd2da)}
.gcard:nth-child(6n+4) .gcard-bg{background:linear-gradient(150deg,#eef4f5,#cfe2e4)}
.gcard:nth-child(6n+5) .gcard-bg{background:linear-gradient(150deg,#d2eef1,#9bd9e0)}
.gcard:nth-child(6n+6) .gcard-bg{background:linear-gradient(150deg,#e6f1f2,#b4d6da)}
.gcard-bg::before{width:54%;aspect-ratio:1;top:-12%;inset-inline-end:-10%;background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.7),rgba(15,163,177,.18));}
.gcard-bg::after{width:36%;aspect-ratio:1;bottom:14%;inset-inline-start:-8%;border:1.5px solid rgba(15,163,177,.30);background:transparent}
.gcard-shape{position:absolute;width:40%;aspect-ratio:1;top:40%;inset-inline-start:30%;transform:rotate(45deg);border:1.5px solid rgba(255,255,255,.55);border-radius:14px;background:rgba(255,255,255,.10)}
.gcard-ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(12,42,52,.42),transparent 52%)}
.gcard-no{position:absolute;top:16px;inset-inline-start:18px;font-family:var(--font-num);font-size:13px;color:var(--accent-soft);background:rgba(255,255,255,.7);padding:4px 10px;border-radius:999px;border:1px solid rgba(15,163,177,.25)}
.gcard-label{position:absolute;bottom:18px;inset-inline-start:18px;inset-inline-end:18px;display:flex;flex-direction:column;gap:3px;z-index:2}
.gcard-label b{font-family:var(--font-display);font-size:20px;color:#fff;font-weight:600}
.gcard-label span{font-size:12.5px;color:rgba(255,255,255,.82)}

/* ============ CONTACT ============ */
.contact{padding:clamp(100px,12vh,170px) clamp(20px,4vw,56px)}
.contact-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.contact-left h2{font-size:clamp(40px,6vw,82px);margin:16px 0 18px}
.contact-lede{color:var(--muted);font-size:18px;max-width:38ch}
.cinfo{list-style:none;margin:38px 0 34px;display:flex;flex-direction:column;gap:24px}
.cinfo li{display:flex;flex-direction:column;gap:4px;padding-bottom:22px;border-bottom:1px solid var(--line-2)}
.ci-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);font-family:var(--font-num)}
.ci-val{font-size:17px;color:var(--white);line-height:1.5}
.ci-phone{font-family:var(--font-num);font-size:clamp(28px,3.4vw,42px);font-weight:300;color:var(--accent-soft);width:max-content;animation:beat 2.4s ease-in-out infinite;transform-origin:center}
@keyframes beat{0%,100%{text-shadow:0 0 0 transparent;transform:scale(1)}8%{transform:scale(1.04);text-shadow:0 0 30px var(--accent-glow)}16%{transform:scale(1)}24%{transform:scale(1.03);text-shadow:0 0 22px var(--accent-glow)}32%{transform:scale(1)}}
.uline{position:relative}
.uline::after{content:"";position:absolute;bottom:-4px;inset-inline-start:0;width:0;height:1px;background:var(--accent);transition:width .4s}
.uline:hover::after{width:100%}

/* CSS map */
.contact-right{aspect-ratio:1/1;width:100%}
.map{position:relative;width:100%;height:100%;border-radius:24px;overflow:hidden;border:1px solid var(--line);background:radial-gradient(circle at 50% 45%,#ffffff,#e3eef0 78%);box-shadow:0 24px 60px rgba(15,70,84,.10)}
.map-grid{position:absolute;inset:0;background:
  repeating-linear-gradient(to right,transparent 0 31px,rgba(15,120,135,.07) 31px 32px),
  repeating-linear-gradient(to bottom,transparent 0 31px,rgba(15,120,135,.07) 31px 32px)}
.road{position:absolute;background:rgba(15,140,156,.22)}
.r-h1{top:38%;left:0;width:100%;height:3px}
.r-h2{top:66%;left:0;width:100%;height:2px;background:rgba(15,140,156,.14)}
.r-v1{left:44%;top:0;height:100%;width:3px}
.r-v2{left:74%;top:0;height:100%;width:2px;background:rgba(15,140,156,.14)}
.r-d1{top:0;left:10%;width:2px;height:140%;background:rgba(15,140,156,.16);transform-origin:top left;transform:rotate(34deg)}
.map-pin{position:absolute;top:38%;left:44%;transform:translate(-50%,-50%);width:18px;height:18px;display:grid;place-items:center}
.pin-dot{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 18px var(--accent-glow);border:2px solid #fff;z-index:2}
.pin-pulse{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--accent);animation:ping 2.4s ease-out infinite}
@keyframes ping{0%{transform:scale(1);opacity:.6}100%{transform:scale(5);opacity:0}}
.map-label{position:absolute;bottom:16px;inset-inline-start:16px;font-family:var(--font-num);font-size:12px;color:var(--accent-soft);background:rgba(255,255,255,.78);padding:6px 12px;border-radius:8px;border:1px solid var(--line)}

/* ============ FOOTER ============ */
.foot{position:relative;z-index:2;text-align:center;padding:clamp(80px,12vh,160px) 20px clamp(40px,6vh,70px);overflow:hidden}
.foot-name{font-family:var(--font-display);font-weight:700;font-size:clamp(80px,22vw,320px);line-height:.8;letter-spacing:-.03em;background:linear-gradient(180deg,rgba(15,163,177,.55),rgba(15,163,177,.06));-webkit-background-clip:text;background-clip:text;color:transparent;will-change:transform,opacity}
.foot-meta{display:flex;flex-direction:column;gap:8px;margin-top:40px;color:var(--muted);font-size:14px}
.foot-disc{color:var(--faint);font-size:12.5px;max-width:60ch;margin:6px auto 0;line-height:1.6}

/* ============ NEWS — media slideshow ============ */
.news{padding:clamp(100px,12vh,170px) 0}
.news-slider{position:relative;max-width:1040px;margin:54px auto 0;padding:0 clamp(20px,4vw,56px)}
.ns-viewport{
  position:relative;overflow:hidden;border-radius:24px;direction:ltr;
  border:1px solid var(--line);box-shadow:0 30px 70px rgba(15,70,84,.12);
  height:clamp(340px,46vw,520px);background:#dfeaec;
}
.ns-track{display:flex;height:100%;width:100%;transition:transform .6s cubic-bezier(.5,0,.2,1);will-change:transform}
.nslide{position:relative;flex:0 0 100%;width:100%;height:100%;direction:rtl;overflow:hidden;display:grid}
/* media (photo / video) */
.ns-media{width:100%;height:100%;object-fit:cover;display:block;background:#cddee1}
.nslide--photo::after,.nslide--video::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(0deg,rgba(8,30,38,.72),rgba(8,30,38,.12) 46%,transparent 70%);
}
/* caption over media */
.ns-cap{position:absolute;inset-inline:0;bottom:0;z-index:2;padding:clamp(20px,3vw,34px);color:#fff;max-width:64ch}
.ns-cap--top{bottom:auto;top:0;background:linear-gradient(180deg,rgba(8,30,38,.55),transparent)}
.ns-cap h3{font-size:clamp(20px,2.6vw,32px);color:#fff;margin:8px 0 6px;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.ns-cap p{font-size:clamp(14px,1.4vw,17px);color:rgba(255,255,255,.9);max-width:48ch}
/* text slide */
.nslide--text{place-items:center;text-align:center;padding:clamp(28px,5vw,60px)}
.nslide--text.nm-1{background:radial-gradient(120% 120% at 18% 18%,rgba(255,255,255,.6),transparent 55%),linear-gradient(140deg,#d6f1f4,#9fe0e7 60%,#7accd4)}
.nslide--text.nm-2{background:radial-gradient(120% 120% at 82% 14%,rgba(255,255,255,.55),transparent 55%),linear-gradient(140deg,#e7eff0,#cfe2e4 55%,#aacdd2)}
.ns-text{position:relative;z-index:2;max-width:60ch;display:flex;flex-direction:column;align-items:center;gap:6px}
.ns-text h3{font-size:clamp(23px,3.4vw,44px);color:#0c2a34;margin:6px 0 8px;line-height:1.12}
.ns-text p{color:var(--accent-soft);font-size:clamp(15px,1.6vw,19px);max-width:46ch}
.ns-cta{
  margin-top:16px;display:inline-flex;align-items:center;padding:12px 26px;border-radius:999px;
  font-size:15px;font-weight:600;color:#fff;background:linear-gradient(180deg,var(--accent),var(--accent-soft));
  box-shadow:0 8px 24px var(--accent-glow);transition:transform .3s,box-shadow .3s,filter .3s;
}
.ns-cta:hover{transform:translateY(-2px);box-shadow:0 14px 34px var(--accent-glow);filter:brightness(1.04)}
/* category chip + date (shared) */
.ncard-cat{display:inline-block;font-family:var(--font-num);font-size:12px;letter-spacing:.12em;padding:5px 13px;border-radius:999px;background:rgba(15,163,177,.14);color:var(--accent-soft);border:1px solid rgba(15,163,177,.30)}
.ns-cap .ncard-cat{background:rgba(255,255,255,.22);color:#fff;border-color:rgba(255,255,255,.4);backdrop-filter:blur(4px)}
.ncard-date{font-family:var(--font-num);font-size:13px;color:var(--faint)}
.ns-cap .ncard-date{color:rgba(255,255,255,.85)}
/* video play button */
.ns-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;
  width:74px;height:74px;border-radius:50%;cursor:pointer;display:grid;place-items:center;
  background:rgba(255,255,255,.92);border:1px solid rgba(15,163,177,.4);
  box-shadow:0 10px 30px rgba(15,70,84,.28),0 0 0 8px rgba(15,163,177,.12);
  transition:transform .3s,box-shadow .3s,opacity .3s;
}
.ns-play:hover{transform:translate(-50%,-50%) scale(1.06)}
.ns-play svg{width:30px;height:30px;fill:var(--accent-soft);margin-inline-start:3px}
.ns-play.is-hidden{opacity:0;pointer-events:none}
/* arrows */
.ns-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:46px;height:46px;border-radius:50%;cursor:pointer;display:grid;place-items:center;
  background:var(--glass-2);border:1px solid var(--line);backdrop-filter:blur(10px);
  box-shadow:0 8px 24px rgba(15,70,84,.12);transition:transform .3s,border-color .3s,background .3s;
}
.ns-nav:hover{border-color:rgba(15,163,177,.45);transform:translateY(-50%) scale(1.06)}
.ns-nav svg{width:22px;height:22px;stroke:var(--accent-soft);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ns-prev{inset-inline-start:max(8px,calc(clamp(20px,4vw,56px) - 23px))}
.ns-next{inset-inline-end:max(8px,calc(clamp(20px,4vw,56px) - 23px))}
/* dots */
.ns-dots{display:flex;justify-content:center;gap:9px;margin-top:20px}
.ns-dot{width:9px;height:9px;border-radius:999px;cursor:pointer;padding:0;border:0;background:rgba(15,70,84,.20);transition:width .3s,background .3s}
.ns-dot.is-active{width:26px;background:linear-gradient(90deg,var(--accent),var(--accent-soft))}

/* ---------- reveal defaults ---------- */
.reveal-up{opacity:0;transform:translateY(28px)}

/* ============ RESPONSIVE ============ */
@media (max-width:1180px){
  .hero-portrait{display:none}
}
@media (max-width:900px){
  .nav-burger{display:block}
  /* group CTA + burger together at the inline-end; brand stays at the start */
  .nav{gap:12px}
  .brand{margin-inline-end:auto}
  /* nav links become a glass drop-down panel */
  .nav-links{
    position:fixed;top:0;inset-inline:0;z-index:2;
    flex-direction:column;align-items:stretch;gap:0;
    padding:80px clamp(20px,6vw,44px) 26px;
    background:rgba(255,255,255,.95);backdrop-filter:blur(22px) saturate(150%);
    border-bottom:1px solid var(--line);box-shadow:0 24px 54px rgba(15,70,84,.14);
    transform:translateY(-100%);opacity:0;visibility:hidden;
    transition:transform .45s cubic-bezier(.4,0,.2,1),opacity .3s ease,visibility .45s;
  }
  .nav.menu-open .nav-links{transform:translateY(0);opacity:1;visibility:visible}
  .nav-links a{font-size:19px;color:var(--white);padding:16px 4px;border-bottom:1px solid var(--line-2)}
  .nav-links a:last-child{border-bottom:0}
  .nav-links a::after{display:none}

  .cards{grid-template-columns:1fr;gap:18px}
  .card{min-height:auto}
  .contact-grid{grid-template-columns:1fr}
  .contact-right{max-width:420px;margin-inline:auto}
  .apanel--creds{grid-template-columns:1fr}
  .hero-stats{gap:24px}
  .acc-head{padding:20px 22px;gap:14px}
  .acc-inner{padding:0 22px}
  .ba{aspect-ratio:4/5}
  .gcard{width:clamp(220px,72vw,300px)}

  /* tighten the tall section rhythm on phones */
  .hero{padding-top:92px;padding-bottom:64px}
  .services,.procedures,.results,.news{padding:clamp(64px,9vh,110px) 0}
  .news-slider{margin-top:38px}
  .ns-viewport{height:clamp(380px,82vw,460px)}
  .contact{padding:clamp(64px,9vh,110px) clamp(20px,4vw,56px)}
  .gallery{padding:clamp(56px,8vh,100px) 0}
  .cards{margin-top:40px}
  .ba-wrap,.acc{margin-top:38px}
}
@media (max-width:560px){
  .hero-name{font-size:clamp(32px,12vw,72px);white-space:normal;flex-wrap:wrap;line-height:1.04}
  .stat span{max-width:11ch;font-size:12px}
  /* compact, tidy top-bar CTA on phones so it sits neatly beside the burger */
  .nav-cta{padding:9px 16px;font-size:13px;font-weight:600;letter-spacing:.2px;white-space:nowrap}
  .sec-head h2{font-size:clamp(30px,8vw,46px)}
  .ba-grip{width:48px;height:48px}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.05ms!important}
  html{scroll-behavior:auto}
}

/* ============ ACCESSIBILITY ============ */
/* skip-to-content — visible only when focused */
.skip-link{
  position:fixed;top:12px;left:50%;z-index:300;transform:translate(-50%,-160%);
  padding:10px 20px;border-radius:999px;background:var(--accent-soft);color:#fff;
  font-family:var(--font-body);font-size:14px;font-weight:600;
  box-shadow:0 8px 24px var(--accent-glow);transition:transform .25s ease;
}
.skip-link:focus{transform:translate(-50%,0);outline:none}
main:focus{outline:none}
/* clear keyboard focus ring (outline survives overflow:hidden, unlike a shadow) */
a:focus-visible,button:focus-visible,.btn:focus-visible,.acc-head:focus-visible,
.ba-grip:focus-visible,.nav-burger:focus-visible,.nav-cta:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;
}

/* ============ FLOATING QUICK-CALL ============ */
.fab-call{
  position:fixed;z-index:70;bottom:18px;inset-inline-end:18px;
  display:none;align-items:center;gap:8px;
  padding:13px 18px;border-radius:999px;color:#fff;
  font-family:var(--font-body);font-size:14px;font-weight:600;
  background:linear-gradient(180deg,var(--accent),var(--accent-soft));
  box-shadow:0 10px 30px var(--accent-glow),0 4px 14px rgba(15,70,84,.18);
  transform:translateY(150%);opacity:0;pointer-events:none;
  transition:transform .45s cubic-bezier(.34,1.4,.5,1),opacity .35s ease;
}
.fab-call svg{width:20px;height:20px;fill:#fff}
.fab-call.is-shown{transform:translateY(0);opacity:1;pointer-events:auto}
@media (max-width:900px){.fab-call{display:inline-flex}}
