/* =========================================================
   Sätra Tandkliniken — Modern Static Redesign
   Design system: Gold × Pine/Petrol × Cream — warm, fresh, premium
   Pairs gold accents with editorial B/W clinical photography
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --ink:        #0d2b27;
  --ink-2:      #163f39;
  --ink-soft:   #4f6661;
  --muted:      #84968f;

  --gold:       #ffc222;
  --gold-deep:  #ef9d00;
  --gold-soft:  #fff3d2;
  --gold-glow:  rgba(255,194,34,.45);

  --mint:       #15b39c;
  --mint-soft:  #e3f6f1;

  --cream:      #fbf8f0;
  --paper:      #ffffff;
  --line:       rgba(13,43,39,.10);
  --line-2:     rgba(13,43,39,.06);

  --shadow-sm:  0 2px 10px rgba(13,43,39,.05);
  --shadow:     0 18px 50px -20px rgba(13,43,39,.22);
  --shadow-lg:  0 40px 90px -40px rgba(13,43,39,.48);
  --shadow-gold:0 22px 50px -18px rgba(239,157,0,.55);

  /* gradients */
  --grad-gold: linear-gradient(135deg,#ffda74 0%,#ffc222 45%,#ef9d00 100%);
  --grad-ink:  linear-gradient(160deg,#17443d 0%,#0d2b27 70%);
  --grad-text: linear-gradient(100deg,#ef9d00,#ffc222 50%,#15b39c);
  --grad-sheen:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);

  /* subtle dot pattern used on dark sections */
  --dots: radial-gradient(rgba(255,255,255,.5) 1px, transparent 1px);

  --r-sm: 14px;
  --r:    22px;
  --r-lg: 34px;
  --r-xl: 46px;

  --container: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --ff-head: "Sora", system-ui, sans-serif;
  --ff-body: "Inter", system-ui, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  background-image:
    radial-gradient(circle at 12% -5%, rgba(255,194,34,.12), transparent 40%),
    radial-gradient(circle at 92% 8%, rgba(21,179,156,.08), transparent 38%),
    radial-gradient(circle at 50% 120%, rgba(255,194,34,.07), transparent 45%);
  background-attachment:fixed;
  line-height:1.65;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ list-style:none; }
h1,h2,h3,h4{ font-family:var(--ff-head); font-weight:700; line-height:1.1; letter-spacing:-.02em; color:var(--ink); }
::selection{ background:var(--gold); color:var(--ink); }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }
.section{ padding:clamp(72px,9vw,130px) 0; position:relative; }
.section--tight{ padding:clamp(54px,6vw,90px) 0; }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--ff-head); font-weight:700; font-size:.78rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep);
  background:var(--gold-soft); padding:7px 15px; border-radius:100px; border:1px solid #ffe2a6;
}
.eyebrow::before{ content:""; width:7px; height:7px; background:var(--gold-deep); border-radius:50%;
  box-shadow:0 0 0 4px rgba(239,157,0,.18); }
.section-head{ max-width:640px; }
.section-head--center{ margin-inline:auto; text-align:center; }
.section-title{ font-size:clamp(2.1rem,4.4vw,3.3rem); margin:18px 0 16px; }
.section-title .hl{ position:relative; white-space:nowrap;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.section-title .hl::after{ content:""; position:absolute; left:0; right:0; bottom:-.12em; height:.14em; border-radius:4px;
  background:var(--grad-gold); opacity:.85; }
.lead{ color:var(--ink-soft); font-size:1.08rem; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--grad-gold); --fg:var(--ink);
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-head); font-weight:600; font-size:.97rem;
  padding:15px 26px; border-radius:100px; background:var(--bg); color:var(--fg);
  position:relative; isolation:isolate; overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s;
  box-shadow:var(--shadow-gold);
}
.btn::before{ content:""; position:absolute; inset:0; z-index:-1; background:var(--grad-sheen);
  transform:translateX(-120%); transition:transform .7s var(--ease); }
.btn:hover::before{ transform:translateX(120%); }
.btn svg{ width:18px; height:18px; transition:transform .35s var(--ease); }
.btn:hover{ transform:translateY(-3px); box-shadow:0 28px 60px -18px rgba(239,157,0,.7); }
.btn:hover svg{ transform:translateX(4px); }
.btn--ghost{ background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.6px var(--line); }
.btn--ghost:hover{ box-shadow:inset 0 0 0 1.6px var(--ink); background:var(--ink); color:#fff; }
.btn--light{ background:#fff; color:var(--ink); box-shadow:var(--shadow); }
.btn--dark{ background:var(--ink); color:#fff; box-shadow:0 20px 40px -20px rgba(13,43,39,.7); }
.btn--lg{ padding:18px 32px; font-size:1.02rem; }

/* ---------- Brand / logo ---------- */
.brand{ display:flex; align-items:center; gap:12px; }
.brand__chip{ display:inline-flex; align-items:center; padding:6px 4px; border-radius:10px;
  background:transparent;
  transition:transform .5s var(--ease), padding .4s var(--ease); }
.brand:hover .brand__chip{ transform:translateY(-2px); }
.brand__logo{ height:44px; width:auto; display:block; }
.footer__logo{ height:54px; width:auto; display:block; }

/* ---------- Header / Nav ---------- */
.header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:padding .4s var(--ease), background .4s, box-shadow .4s, border-color .4s;
  padding:18px 0; border-bottom:1px solid transparent;
}
.header.scrolled{
  padding:10px 0; background:rgba(251,248,240,.82);
  backdrop-filter:blur(16px) saturate(140%); border-bottom-color:var(--line);
  box-shadow:0 8px 30px -18px rgba(13,43,39,.25);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.header.scrolled .brand__chip{ padding:7px 14px; }
.header.scrolled .brand__logo{ height:26px; }

.nav__menu{ display:flex; align-items:center; gap:6px; }
.nav__link{
  font-family:var(--ff-head); font-weight:500; font-size:.95rem; color:var(--ink-2);
  padding:9px 15px; border-radius:100px; position:relative; transition:color .25s, background .25s;
}
.nav__link:hover, .nav__link.active{ color:var(--ink); background:rgba(13,43,39,.05); }
.nav__item{ position:relative; }
.nav__item--has > .nav__link::after{
  content:""; width:6px; height:6px; border-right:2px solid currentColor; border-bottom:2px solid currentColor;
  display:inline-block; transform:rotate(45deg) translateY(-2px); margin-left:7px; transition:transform .3s;
}
.nav__item--has:hover > .nav__link::after{ transform:rotate(225deg) translateY(2px); }
.dropdown{
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%) translateY(10px);
  background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:10px;
  min-width:282px; box-shadow:var(--shadow); opacity:0; visibility:hidden; transition:.3s var(--ease);
}
.nav__item--has:hover .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.dropdown::before{ content:""; position:absolute; top:-8px; left:0; right:0; height:18px; }
.dropdown a{
  display:flex; align-items:center; gap:13px; padding:11px 13px; border-radius:14px;
  font-size:.93rem; font-weight:500; color:var(--ink-2); transition:background .2s, color .2s, transform .2s;
}
.dropdown a:hover{ background:var(--gold-soft); color:var(--ink); transform:translateX(3px); }
.dropdown a .ico{ width:34px; height:34px; flex:none; border-radius:10px; background:var(--gold-soft); color:var(--gold-deep);
  display:grid; place-items:center; }
.dropdown a .ico svg{ width:18px; height:18px; }

.nav__cta{ display:flex; align-items:center; gap:12px; }
.nav__phone{ display:flex; align-items:center; gap:9px; font-family:var(--ff-head); font-weight:600; font-size:.95rem; }
.nav__phone .pico{ width:38px; height:38px; border-radius:50%; background:var(--gold-soft); color:var(--gold-deep); display:grid; place-items:center; }
.nav__phone .pico svg{ width:17px; height:17px; }
.nav__phone small{ display:block; font-size:.66rem; font-weight:500; color:var(--muted); letter-spacing:.05em; }

.burger{ display:none; width:46px; height:46px; border-radius:13px; background:rgba(13,43,39,.05); }
.burger span{ display:block; width:20px; height:2px; background:var(--ink); margin:4px auto; border-radius:2px; transition:.3s var(--ease); }
.burger.open span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:clamp(120px,16vw,180px) 0 clamp(70px,8vw,110px); overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:-2;
  background:
    radial-gradient(60% 80% at 78% 18%, rgba(255,205,90,.32), transparent 60%),
    radial-gradient(50% 70% at 12% 80%, rgba(21,179,156,.16), transparent 60%);
}
.hero__bg::after{ /* fine grid texture */
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(13,43,39,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(13,43,39,.04) 1px,transparent 1px);
  background-size:54px 54px; mask-image:radial-gradient(70% 60% at 50% 40%,#000,transparent 80%);
}
.blob{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.6; z-index:-1; }
.blob--1{ width:540px; height:540px; background:radial-gradient(circle,#ffe39a,#ffc22200); top:-170px; right:-120px; animation:float1 16s ease-in-out infinite; }
.blob--2{ width:460px; height:460px; background:radial-gradient(circle,#bdeee4,#15b39c00); bottom:-170px; left:-130px; animation:float2 20s ease-in-out infinite; }
.blob--3{ width:300px; height:300px; background:radial-gradient(circle,#ffd6a6,#ff9b3b00); top:40%; left:38%; opacity:.4; animation:float1 22s ease-in-out infinite 1s; }
@keyframes float1{ 50%{ transform:translate(-30px,40px) scale(1.1);} }
@keyframes float2{ 50%{ transform:translate(40px,-30px) scale(1.08);} }

.hero__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,70px); align-items:center; }
.hero__pill{
  display:inline-flex; align-items:center; gap:10px; padding:8px 8px 8px 16px; border-radius:100px;
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); font-size:.85rem; font-weight:500; color:var(--ink-2);
}
.hero__pill b{ background:var(--ink); color:#fff; font-family:var(--ff-head); font-size:.72rem; padding:5px 11px; border-radius:100px; font-weight:600; }
.hero__title{ font-size:clamp(2.6rem,6vw,4.5rem); margin:24px 0 0; }
.hero__title .hl{
  position:relative; display:inline-block;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.hero__title .hl::after{
  content:""; position:absolute; left:-2%; right:-2%; bottom:.02em; height:.22em; z-index:-1;
  background:var(--grad-gold); opacity:.35; border-radius:4px;
}
.hero__sub{ font-size:1.18rem; color:var(--ink-soft); max-width:480px; margin-top:22px; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero__trust{ display:flex; align-items:center; gap:18px; margin-top:34px; flex-wrap:wrap; }
.hero__avatars{ display:flex; }
.hero__avatars span{
  width:42px; height:42px; border-radius:50%; border:3px solid var(--cream); margin-left:-12px;
  background:var(--mint-soft); display:grid; place-items:center; font-family:var(--ff-head); font-weight:700; color:var(--mint); font-size:.85rem;
}
.hero__avatars :first-child{ margin-left:0; }
.hero__avatars span:nth-child(2){ background:var(--gold-soft); color:var(--gold-deep); }
.hero__avatars span:nth-child(3){ background:var(--ink); color:var(--gold); }
.hero__trust small{ display:block; color:var(--muted); }
.hero__trust .stars{ color:var(--gold-deep); font-weight:700; font-family:var(--ff-head); }

/* hero visual */
.hero__visual{ position:relative; }
.hero__photo{
  position:relative; border-radius:46% 46% 44% 44%/ 38% 38% 40% 40%; overflow:hidden;
  aspect-ratio:4/4.3; box-shadow:var(--shadow-lg); background:var(--ink);
  border:8px solid #fff;
}
.hero__photo img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.hero__visual:hover .hero__photo img{ transform:scale(1.06); }
.hero__ring{ position:absolute; inset:-22px; border:2px dashed var(--gold); border-radius:48%; opacity:.5; animation:spin 40s linear infinite; z-index:-1; }
@keyframes spin{ to{ transform:rotate(360deg);} }

.float-card{
  position:absolute; background:#fff; border-radius:18px; padding:14px 18px; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:12px; border:1px solid var(--line-2);
}
.float-card .fc-ico{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; flex:none; }
.float-card strong{ font-family:var(--ff-head); font-size:1rem; display:block; line-height:1.1; }
.float-card small{ color:var(--muted); font-size:.78rem; }
.float-card--a{ top:18%; left:-26px; animation:bob 5s ease-in-out infinite; }
.float-card--b{ bottom:14%; right:-22px; animation:bob 6s ease-in-out infinite .6s; }
.float-card--a .fc-ico{ background:var(--mint-soft); color:var(--mint); }
.float-card--b .fc-ico{ background:var(--gold-soft); color:var(--gold-deep); }
@keyframes bob{ 50%{ transform:translateY(-12px);} }

/* ---------- Marquee trust bar ---------- */
.trustbar{ border-block:1px solid var(--line); background:#fff; }
.marquee{ display:flex; overflow:hidden; gap:0; mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee__row{ display:flex; gap:60px; padding:22px 30px; white-space:nowrap; animation:scroll 28s linear infinite; }
.marquee__row span{ font-family:var(--ff-head); font-weight:600; color:var(--ink-2); display:flex; align-items:center; gap:14px; font-size:1.02rem; }
.marquee__row span::after{ content:"✦"; color:var(--gold); }
@keyframes scroll{ to{ transform:translateX(-50%);} }

/* ---------- Treatments (immersive photo band) ---------- */
.svc-section{ position:relative; overflow:hidden; color:#fff; }
.svc-section::before{ content:""; position:absolute; inset:0; z-index:-2;
  background:url("../images/tandimplantat-satra-tandkliniken-1024x684.webp") center/cover fixed; }
.svc-section::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(8,28,25,.93), rgba(8,28,25,.8) 45%, rgba(8,28,25,.95));
}
.svc-section .section-title, .svc-section .eyebrow{ color:#fff; }
.svc-section .eyebrow{ background:rgba(255,194,34,.16); border-color:rgba(255,194,34,.3); color:var(--gold); }
.svc-section .section-title .hl{ -webkit-text-fill-color:transparent; }
.svc-section .lead{ color:#c2d2cd; }
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:54px; }
.svc{
  position:relative; background:linear-gradient(180deg,#fff,#fffdf8); border:1px solid var(--line); border-radius:var(--r-lg); padding:36px 30px 30px;
  overflow:hidden; transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s;
}
.svc::before{ content:""; position:absolute; inset:0 0 auto 0; height:4px; background:var(--grad-gold);
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.svc:hover::before{ transform:scaleX(1); }
.svc::after{ content:""; position:absolute; inset:auto -40% -60% auto; width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle,var(--gold-soft),transparent 70%); opacity:0; transition:opacity .5s; }
.svc:hover{ transform:translateY(-10px); box-shadow:0 34px 70px -28px rgba(239,157,0,.45); border-color:transparent; }
.svc:hover::after{ opacity:1; }
.svc__ico{ width:64px; height:64px; border-radius:18px; background:var(--grad-ink); color:var(--gold); display:grid; place-items:center;
  transition:transform .45s var(--ease), background .45s; position:relative; z-index:1; box-shadow:var(--shadow-sm); }
.svc__ico svg{ width:30px; height:30px; }
.svc:hover .svc__ico{ background:var(--grad-gold); color:var(--ink); transform:rotate(-6deg) scale(1.08); }
.svc h3{ font-size:1.32rem; margin:22px 0 10px; position:relative; z-index:1; }
.svc p{ color:var(--ink-soft); font-size:.97rem; position:relative; z-index:1; }
.svc__link{ display:inline-flex; align-items:center; gap:8px; margin-top:18px; font-family:var(--ff-head); font-weight:600;
  font-size:.9rem; color:var(--gold-deep); position:relative; z-index:1; }
.svc__link svg{ width:16px; height:16px; transition:transform .35s var(--ease); }
.svc:hover .svc__link svg{ transform:translateX(5px); }

/* glass variant inside immersive photo band */
.svc-section .svc{ background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(14px) saturate(130%); -webkit-backdrop-filter:blur(14px) saturate(130%); }
.svc-section .svc h3{ color:#fff; }
.svc-section .svc p{ color:#c2d2cd; }
.svc-section .svc__ico{ background:var(--grad-gold); color:var(--ink); }
.svc-section .svc:hover{ background:rgba(255,255,255,.12); border-color:rgba(255,194,34,.4);
  box-shadow:0 34px 70px -28px rgba(0,0,0,.6); }
.svc-section .svc:hover .svc__ico{ transform:rotate(-6deg) scale(1.08); }
.svc-section .svc__link{ color:var(--gold); }

/* ---------- Split / About ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,72px); align-items:center; }
.split--rev .split__media{ order:2; }
.split__media{ position:relative; }
.media-stack{ position:relative; }
.media-stack__main{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:5/5.6; }
.media-stack__main img{ width:100%; height:100%; object-fit:cover; }
.media-stack__sub{ position:absolute; right:-26px; bottom:-26px; width:46%; border-radius:var(--r); overflow:hidden;
  border:7px solid #fff; box-shadow:var(--shadow); aspect-ratio:4/3; }
.media-stack__sub img{ width:100%; height:100%; object-fit:cover; }
.media-badge{ position:absolute; left:-22px; top:30px; background:var(--ink); color:#fff; border-radius:18px; padding:16px 20px;
  box-shadow:var(--shadow-lg); }
.media-badge b{ font-family:var(--ff-head); font-size:1.9rem; color:var(--gold); display:block; line-height:1; }
.media-badge small{ font-size:.78rem; color:#c4d4cf; }

.checklist{ display:grid; gap:14px; margin-top:26px; }
.checklist li{ display:flex; gap:14px; align-items:flex-start; }
.checklist .ck{ width:26px; height:26px; flex:none; border-radius:50%; background:var(--mint-soft); color:var(--mint);
  display:grid; place-items:center; margin-top:2px; }
.checklist .ck svg{ width:14px; height:14px; }
.checklist b{ font-family:var(--ff-head); }
.checklist p{ color:var(--ink-soft); font-size:.95rem; }

/* ---------- Stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:48px; }
.stat{ position:relative; text-align:center; padding:32px 16px; border-radius:var(--r); overflow:hidden;
  background:linear-gradient(180deg,#fff,#fffdf7); border:1px solid var(--line); box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.stat::before{ content:""; position:absolute; inset:auto 0 0 0; height:3px; background:var(--grad-gold); opacity:.7; }
.stat:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.stat b{ font-family:var(--ff-head); font-weight:800; font-size:clamp(2.4rem,4.4vw,3.2rem); display:block; line-height:1;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.stat b .suffix{ -webkit-text-fill-color:initial; color:var(--gold-deep); }
.stat small{ color:var(--ink-soft); font-weight:600; font-size:.92rem; margin-top:6px; display:block; }

/* ---------- Stats photo band ---------- */
.stat-band{ position:relative; overflow:hidden; padding:clamp(60px,8vw,100px) 0; color:#fff; }
.stat-band__bg{ position:absolute; inset:0; z-index:-2;
  background:url("../images/tandblekning-satra-tandklinik-1024x684.webp") center/cover fixed; }
.stat-band::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(135deg, rgba(239,157,0,.9), rgba(13,43,39,.92) 60%, rgba(8,28,25,.96)); }
.stat-band .section-title, .stat-band .eyebrow{ color:#fff; }
.stat-band .eyebrow{ background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.24); color:#fff; }
.stat-band .section-title .hl{ -webkit-text-fill-color:#fff; }
.stat-band .stats{ margin-top:46px; }
.stats--3{ grid-template-columns:repeat(3,minmax(0,260px)); justify-content:center; }
.stat-band .stat{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(10px) saturate(130%); -webkit-backdrop-filter:blur(10px) saturate(130%); box-shadow:none; }
.stat-band .stat::before{ opacity:1; }
.stat-band .stat b{ -webkit-text-fill-color:#fff; color:#fff; background:none; }
.stat-band .stat b .suffix{ color:var(--gold); -webkit-text-fill-color:var(--gold); }
.stat-band .stat small{ color:#e6efec; }
.stat-band .stat:hover{ background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.3); transform:translateY(-6px); }

/* ---------- Why (features on ink) ---------- */
.ink-sec{ background:radial-gradient(120% 120% at 80% 0%, #15433c, var(--ink)); color:#fff; border-radius:var(--r-xl); overflow:hidden; position:relative; }
.ink-sec::before{ content:""; position:absolute; inset:0; background-image:var(--dots); background-size:22px 22px; opacity:.06; }
.ink-sec h2,.ink-sec h3{ color:#fff; }
.ink-sec .lead{ color:#c2d2cd; }
.feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:50px; position:relative; }
.feat{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09); border-radius:var(--r); padding:28px 26px;
  transition:transform .4s var(--ease), background .4s; }
.feat:hover{ transform:translateY(-6px); background:rgba(255,255,255,.07); }
.feat__ico{ width:54px; height:54px; border-radius:15px; background:var(--gold); color:var(--ink); display:grid; place-items:center; }
.feat__ico svg{ width:26px; height:26px; }
.feat h3{ font-size:1.18rem; margin:20px 0 9px; }
.feat p{ color:#aebdb7; font-size:.95rem; }

/* ---------- Team ---------- */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:54px; }
.member{ position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/4.7; box-shadow:var(--shadow-sm);
  background:linear-gradient(160deg,#1c4a43,#0d2b27); }
.member img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.member.noimg{ display:grid; place-items:center; }
.member.noimg .initials{ font-family:var(--ff-head); font-weight:800; font-size:4.4rem; color:var(--gold); opacity:.95;
  letter-spacing:.04em; filter:drop-shadow(0 8px 22px rgba(0,0,0,.35)); }
.member:hover img{ transform:scale(1.07); }
.member__info{ position:absolute; inset:auto 0 0 0; padding:60px 24px 24px; color:#fff;
  background:linear-gradient(transparent, rgba(6,18,16,.92)); }
.member__info b{ font-family:var(--ff-head); font-size:1.22rem; display:block; }
.member__info small{ color:var(--gold); font-weight:600; letter-spacing:.02em; }
.member__tag{ position:absolute; top:16px; left:16px; background:rgba(255,255,255,.9); backdrop-filter:blur(6px);
  font-family:var(--ff-head); font-weight:600; font-size:.72rem; padding:6px 12px; border-radius:100px; color:var(--ink); }

/* ---------- Quote ---------- */
.quote-band{ position:relative; text-align:center; max-width:980px; margin-inline:auto; overflow:hidden;
  background:radial-gradient(120% 140% at 80% -10%,#184740,var(--ink)); color:#fff;
  border-radius:var(--r-xl); padding:clamp(40px,5vw,64px) clamp(28px,5vw,72px); box-shadow:var(--shadow-lg); }
.quote-band::before{ content:""; position:absolute; inset:0; background-image:var(--dots); background-size:22px 22px; opacity:.06; }
.quote-band::after{ content:""; position:absolute; width:280px; height:280px; border-radius:50%; top:-140px; right:-80px;
  background:radial-gradient(circle,var(--gold-glow),transparent 70%); filter:blur(20px); }
.quote-band > *{ position:relative; }
.quote-band .qmark{ font-family:var(--ff-head); font-size:5rem; line-height:.6;
  background:var(--grad-gold); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.quote-band blockquote{ font-family:var(--ff-head); font-weight:600; font-size:clamp(1.5rem,3.4vw,2.4rem); line-height:1.3;
  letter-spacing:-.02em; margin:14px 0 22px; color:#fff; }
.quote-band cite{ font-style:normal; color:#dbe6e2; font-weight:600; }
.quote-band cite small{ display:block; color:var(--gold); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; margin-top:4px; }

/* ---------- CTA band ---------- */
.cta{ position:relative; border-radius:var(--r-xl); overflow:hidden; padding:clamp(46px,6vw,80px);
  background:linear-gradient(120deg,var(--gold),var(--gold-deep)); color:var(--ink); text-align:center; }
.cta::before{ content:""; position:absolute; inset:0;
  background-image:radial-gradient(rgba(13,43,39,.18) 1px, transparent 1px); background-size:24px 24px; opacity:.5; }
.cta__inner{ position:relative; max-width:680px; margin-inline:auto; }
.cta h2{ font-size:clamp(2rem,4.6vw,3.2rem); }
.cta p{ font-size:1.1rem; margin:16px 0 30px; color:#43361a; }
.cta .btn--dark:hover{ transform:translateY(-3px); }
.cta__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ---------- Contact / Footer ---------- */
.contact-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:30px; }
.contact-cards{ display:grid; gap:16px; align-content:start; }
.ccard{ display:flex; gap:18px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:22px 24px;
  transition:transform .35s var(--ease), box-shadow .35s; }
.ccard:hover{ transform:translateY(-4px); box-shadow:var(--shadow-sm); }
.ccard__ico{ width:54px; height:54px; border-radius:15px; background:var(--gold-soft); color:var(--gold-deep); display:grid; place-items:center; flex:none; }
.ccard__ico svg{ width:24px; height:24px; }
.ccard small{ color:var(--muted); display:block; font-size:.8rem; letter-spacing:.04em; text-transform:uppercase; font-weight:600; }
.ccard b{ font-family:var(--ff-head); font-size:1.1rem; }
.map{ border-radius:var(--r-lg); overflow:hidden; min-height:340px; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.map iframe{ width:100%; height:100%; min-height:340px; border:0; filter:grayscale(.2) contrast(1.05); }

.footer{ background:var(--ink); color:#c2d2cd; padding:80px 0 30px; position:relative; overflow:hidden; }
.footer::before{ content:""; position:absolute; inset:0; background-image:var(--dots); background-size:24px 24px; opacity:.04; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; position:relative; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer .brand__name{ color:#fff; }
.footer__about{ margin:22px 0; max-width:340px; color:#9fb0aa; }
.footer h4{ color:#fff; font-size:1rem; margin-bottom:20px; letter-spacing:.02em; }
.footer__links{ display:grid; gap:12px; }
.footer__links a{ color:#9fb0aa; transition:color .25s, padding .25s; font-size:.96rem; }
.footer__links a:hover{ color:var(--gold); padding-left:6px; }
.socials{ display:flex; gap:12px; }
.socials a{ width:44px; height:44px; border-radius:13px; background:rgba(255,255,255,.06); display:grid; place-items:center; color:#fff;
  transition:background .3s, transform .3s, color .3s; }
.socials a:hover{ background:var(--gold); color:var(--ink); transform:translateY(-4px); }
.socials a svg{ width:20px; height:20px; }
.footer__hours{ display:grid; gap:8px; }
.footer__hours div{ display:flex; justify-content:space-between; gap:20px; font-size:.95rem; }
.footer__hours b{ color:#fff; font-family:var(--ff-head); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; padding-top:26px; position:relative; font-size:.86rem; color:#7e8f89; }
.footer__credit{ text-align:center; padding:18px 0 2px; margin-top:18px; border-top:1px solid rgba(255,255,255,.08); font-size:.82rem; color:#6f807a; }
.footer__credit a{ color:var(--gold); font-weight:600; transition:color .25s; }
.footer__credit a:hover{ color:#ffd874; text-decoration:underline; }

/* ---------- Page hero (inner pages) ---------- */
.phero{ position:relative; padding:clamp(140px,16vw,190px) 0 clamp(50px,6vw,80px); overflow:hidden; }
.phero .hero__bg{ background:
    radial-gradient(55% 75% at 85% 10%, rgba(255,205,90,.3), transparent 60%),
    radial-gradient(45% 60% at 8% 90%, rgba(21,179,156,.14), transparent 60%); }
.phero h1 .hl{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.breadcrumb{ display:flex; gap:9px; align-items:center; font-size:.86rem; color:var(--muted); font-weight:500; }
.breadcrumb a:hover{ color:var(--gold-deep); }
.breadcrumb span{ color:var(--line); }
.phero h1{ font-size:clamp(2.3rem,5vw,3.6rem); margin:18px 0 0; max-width:760px; }
.phero p{ color:var(--ink-soft); font-size:1.12rem; max-width:560px; margin-top:18px; }
.phero__img{ margin-top:46px; border-radius:var(--r-xl); overflow:hidden; aspect-ratio:16/6.4; box-shadow:var(--shadow); }
.phero__img img{ width:100%; height:100%; object-fit:cover; }

/* ---------- Article / rich content ---------- */
.prose{ max-width:780px; margin-inline:auto; }
.prose.wide{ max-width:980px; }
.prose h2{ font-size:clamp(1.6rem,3.2vw,2.3rem); margin:48px 0 16px; }
.prose h3{ font-size:1.4rem; margin:34px 0 12px; }
.prose p{ color:var(--ink-soft); margin-bottom:18px; }
.prose p strong, .prose b{ color:var(--ink); }
.prose > p:first-of-type{ font-size:1.18rem; color:var(--ink); }
.feature-list{ display:grid; gap:14px; margin:24px 0; }
.feature-list li{ position:relative; display:flex; gap:14px; background:linear-gradient(180deg,#fff,#fffdf8); border:1px solid var(--line); border-radius:16px; padding:18px 20px;
  overflow:hidden; transition:transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.feature-list li::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--grad-gold);
  transform:scaleY(0); transform-origin:top; transition:transform .35s var(--ease); }
.feature-list li:hover{ transform:translateX(5px); box-shadow:var(--shadow); border-color:transparent; }
.feature-list li:hover::before{ transform:scaleY(1); }
.feature-list .num{ width:36px; height:36px; flex:none; border-radius:11px; background:var(--grad-ink); color:var(--gold);
  font-family:var(--ff-head); font-weight:800; display:grid; place-items:center; font-size:.95rem; box-shadow:var(--shadow-sm); }
.feature-list b{ font-family:var(--ff-head); }
.feature-list p{ margin:4px 0 0; font-size:.95rem; }
.callout{ background:var(--gold-soft); border:1px solid #ffe2a6; border-radius:var(--r); padding:26px 28px; margin:30px 0;
  display:flex; gap:18px; align-items:center; }
.callout .ci{ width:50px; height:50px; flex:none; border-radius:14px; background:var(--gold); color:var(--ink); display:grid; place-items:center; }
.callout b{ font-family:var(--ff-head); font-size:1.1rem; }
.callout p{ margin:2px 0 0; color:#7a5e16; font-size:.95rem; }
.pill-tags{ display:flex; flex-wrap:wrap; gap:10px; margin:22px 0; }
.pill-tags span{ background:#fff; border:1px solid var(--line); border-radius:100px; padding:10px 18px; font-family:var(--ff-head);
  font-weight:600; font-size:.9rem; display:flex; align-items:center; gap:9px; }
.pill-tags span::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--gold); }

.quote-inline{ border-left:3px solid var(--gold); padding:6px 0 6px 26px; margin:36px 0; }
.quote-inline p{ font-family:var(--ff-head); font-weight:600; font-size:1.4rem; color:var(--ink); font-style:italic; }
.quote-inline cite{ font-style:normal; color:var(--muted); font-size:.85rem; text-transform:uppercase; letter-spacing:.14em; }

/* sticky aside CTA on article pages */
.article-layout{ display:grid; grid-template-columns:1fr 320px; gap:50px; align-items:start; }
.aside{ position:sticky; top:100px; display:grid; gap:18px; }
.aside-card{ background:var(--ink); color:#fff; border-radius:var(--r-lg); padding:30px 28px; box-shadow:var(--shadow); }
.aside-card h3{ color:#fff; font-size:1.3rem; }
.aside-card p{ color:#b6c4bf; font-size:.94rem; margin:10px 0 20px; }
.aside-card .btn{ width:100%; justify-content:center; }
.aside-phone{ display:flex; align-items:center; gap:14px; margin-top:18px; padding-top:18px; border-top:1px solid rgba(255,255,255,.12); }
.aside-phone .pico{ width:44px; height:44px; border-radius:12px; background:rgba(255,255,255,.08); color:var(--gold); display:grid; place-items:center; }
.aside-phone b{ font-family:var(--ff-head); font-size:1.15rem; }
.aside-phone small{ display:block; color:#9fb0aa; font-size:.78rem; }
.aside-img{ border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/4.4; box-shadow:var(--shadow-sm); }
.aside-img img{ width:100%; height:100%; object-fit:cover; }

/* related treatments */
.related{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; }
.rel{ display:flex; align-items:center; gap:14px; background:#fff; border:1px solid var(--line); border-radius:18px; padding:18px 20px;
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.rel:hover{ transform:translateY(-4px); box-shadow:var(--shadow-sm); border-color:transparent; }
.rel__ico{ width:46px; height:46px; flex:none; border-radius:12px; background:var(--gold-soft); color:var(--gold-deep); display:grid; place-items:center; }
.rel__ico svg{ width:22px; height:22px; }
.rel b{ font-family:var(--ff-head); font-size:1rem; }
.rel small{ color:var(--muted); }

/* price table */
.price-table{ display:grid; gap:12px; margin:30px 0; }
.price-row{ display:flex; justify-content:space-between; align-items:center; gap:20px; background:#fff; border:1px solid var(--line);
  border-radius:16px; padding:18px 22px; transition:transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.price-row:hover{ transform:translateX(4px); box-shadow:var(--shadow-sm); border-color:transparent; }
.price-row b{ font-family:var(--ff-head); font-size:1.05rem; }
.price-row .price{ font-family:var(--ff-head); font-weight:800; color:var(--gold-deep); white-space:nowrap; font-size:1.1rem; }
.price-note{ color:var(--muted); font-size:.9rem; }

/* campaign hero card */
.kampanj-card{ position:relative; overflow:hidden; border-radius:var(--r-xl); background:var(--grad-ink); color:#fff;
  display:grid; grid-template-columns:1.1fr 1fr; gap:0; box-shadow:var(--shadow-lg); }
.kampanj-card__body{ padding:clamp(34px,5vw,60px); position:relative; z-index:1; }
.kampanj-card__media{ position:relative; min-height:300px; }
.kampanj-card__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.kampanj-price{ display:flex; align-items:baseline; gap:14px; margin:20px 0 8px; }
.kampanj-price .now{ font-family:var(--ff-head); font-weight:800; font-size:3rem; color:var(--gold); line-height:1; }
.kampanj-price .was{ color:#9fb0aa; text-decoration:line-through; font-size:1.3rem; }
.kampanj-save{ display:inline-block; background:var(--gold); color:var(--ink); font-family:var(--ff-head); font-weight:700;
  padding:7px 16px; border-radius:100px; font-size:.9rem; margin-bottom:8px; }

/* ---------- Team split photo ---------- */
.team-split-photo{
  position:relative;
  border-radius:var(--r-xl);
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-lg);
  border:7px solid #fff;
}
.team-split-photo img{
  width:100%; height:auto;
  display:block;
  object-fit:contain;
}
.team-split-photo .media-badge{
  position:absolute; left:-22px; top:30px;
  background:var(--ink); color:#fff; border-radius:18px; padding:16px 20px;
  box-shadow:var(--shadow-lg);
}

/* ---------- Team photo ---------- */
.team-photo-wrap{
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  box-shadow:var(--shadow-lg); aspect-ratio:16/7;
}
.team-photo-img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.2s var(--ease);
}
.team-photo-wrap:hover .team-photo-img{ transform:scale(1.04); }
.team-photo-caption{
  position:absolute; inset:auto 0 0 0;
  padding:40px 36px 28px;
  background:linear-gradient(transparent, rgba(8,28,25,.75));
  display:flex; align-items:flex-end;
}
.team-photo-caption span{
  font-family:var(--ff-head); font-weight:600; font-size:1.08rem;
  color:#fff; letter-spacing:.01em;
  display:flex; align-items:center; gap:10px;
}
.team-photo-caption span::before{
  content:""; width:8px; height:8px; border-radius:50%;
  background:var(--gold); flex:none;
  box-shadow:0 0 0 4px rgba(255,194,34,.28);
}
@media (max-width:600px){
  .team-photo-wrap{ aspect-ratio:4/3; }
}

/* ---------- FAQ (accordion) ---------- */
.faq{ max-width:820px; margin:50px auto 0; display:grid; gap:14px; }
.faq__item{ background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden;
  transition:box-shadow .3s, border-color .3s; }
.faq__item[open]{ box-shadow:var(--shadow-sm); border-color:transparent; }
.faq__q{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:20px 24px; font-family:var(--ff-head); font-weight:600; font-size:1.05rem; color:var(--ink); }
.faq__q::-webkit-details-marker{ display:none; }
.faq__q .ic{ width:30px; height:30px; flex:none; border-radius:9px; background:var(--gold-soft); color:var(--gold-deep);
  display:grid; place-items:center; transition:transform .35s var(--ease), background .3s, color .3s; }
.faq__q .ic svg{ width:16px; height:16px; }
.faq__item[open] .faq__q .ic{ transform:rotate(45deg); background:var(--gold); color:var(--ink); }
.faq__a{ padding:0 24px 22px; color:var(--ink-soft); }
.faq__a p{ margin:0; }
.faq__a a{ color:var(--gold-deep); font-weight:600; }

/* ---------- Reveal animation ---------- */
[data-reveal]{ opacity:0; transform:translateY(32px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.08s; }
[data-reveal][data-delay="2"]{ transition-delay:.16s; }
[data-reveal][data-delay="3"]{ transition-delay:.24s; }
[data-reveal][data-delay="4"]{ transition-delay:.32s; }
[data-reveal][data-delay="5"]{ transition-delay:.40s; }

/* scroll progress */
.progress{ position:fixed; top:0; left:0; height:3px; width:0; background:linear-gradient(90deg,var(--gold),var(--gold-deep)); z-index:200; transition:width .1s linear; }

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__visual{ max-width:440px; margin:10px auto 0; }
  .svc-grid,.feat-grid,.team-grid,.related{ grid-template-columns:repeat(2,1fr); }
  .article-layout{ grid-template-columns:1fr; }
  .aside{ position:static; grid-template-columns:1fr 1fr; }
  .footer__top{ grid-template-columns:1fr 1fr; }
  .kampanj-card{ grid-template-columns:1fr; }
  .kampanj-card__media{ min-height:240px; order:-1; }
}
@media (max-width:860px){
  body{ background-attachment:scroll; }
  .svc-section::before,.stat-band__bg{ background-attachment:scroll; }
  .nav__menu,.nav__phone span{ display:none; }
  .burger{ display:block; }
  .nav__cta .btn{ display:none; }
  .contact-grid,.split,.split--rev .split__media{ grid-template-columns:1fr; }
  .split--rev .split__media{ order:0; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .media-stack{ max-width:460px; margin-inline:auto; }
  .nav__menu{
    position:fixed; inset:0 0 0 auto; width:min(340px,86vw); background:var(--cream);
    flex-direction:column; align-items:stretch; gap:4px; padding:96px 22px 30px; box-shadow:var(--shadow-lg);
    transform:translateX(100%); transition:transform .45s var(--ease); z-index:90; overflow-y:auto;
  }
  .nav__menu.open{ display:flex; transform:translateX(0); }
  .nav__link{ font-size:1.05rem; padding:13px 16px; }
  .dropdown{ position:static; transform:none; opacity:1; visibility:visible; box-shadow:none; border:none; background:transparent;
    min-width:0; padding:4px 0 4px 12px; }
  .nav__item--has:hover .dropdown{ transform:none; }
  .nav-backdrop{ position:fixed; inset:0; background:rgba(13,43,39,.4); backdrop-filter:blur(2px); opacity:0; visibility:hidden;
    transition:.3s; z-index:80; }
  .nav-backdrop.open{ opacity:1; visibility:visible; }
}
@media (max-width:600px){
  body{ font-size:16px; }
  .svc-grid,.feat-grid,.team-grid,.related,.aside{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:14px; }
  .footer__top{ grid-template-columns:1fr; }
  .float-card--a{ left:-8px; }
  .float-card--b{ right:-8px; }
  .media-stack__sub{ right:0; }
  .hero__photo{ border-width:6px; }
  .cta{ padding:40px 24px; }
  .price-row{ flex-direction:row; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
  [data-reveal]{ opacity:1; transform:none; }
}
