/* =========================================================
   Järva Tandkliniken — Modern Static Redesign
   Design system: Amber × Ink Navy × Cream — clean, fresh, premium
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --ink:        #0e1a2b;
  --ink-2:      #1c2b40;
  --ink-soft:   #56657d;
  --muted:      #8593a7;

  --amber:      #ffb01f;
  --amber-deep: #f59300;
  --amber-soft: #fff3d6;
  --amber-glow: rgba(255,176,31,.45);

  --teal:       #129b8c;
  --teal-soft:  #e7f5f2;

  --cream:      #fffbf4;
  --paper:      #ffffff;
  --line:       rgba(14,26,43,.09);
  --line-2:     rgba(14,26,43,.06);

  --shadow-sm:  0 2px 10px rgba(14,26,43,.05);
  --shadow:     0 18px 50px -20px rgba(14,26,43,.20);
  --shadow-lg:  0 40px 90px -40px rgba(14,26,43,.45);
  --shadow-amber: 0 22px 50px -18px rgba(245,147,0,.55);

  /* gradients */
  --grad-amber: linear-gradient(135deg,#ffce5c 0%,#ffb01f 45%,#f08200 100%);
  --grad-ink:   linear-gradient(160deg,#1a2c45 0%,#0e1a2b 70%);
  --grad-text:  linear-gradient(100deg,#f59300,#ffb01f 50%,#129b8c);
  --grad-sheen: linear-gradient(120deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);

  --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,176,31,.10), transparent 40%),
    radial-gradient(circle at 92% 8%, rgba(18,155,140,.08), transparent 38%),
    radial-gradient(circle at 50% 120%, rgba(255,176,31,.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(--amber); 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(--amber-deep);
  background:var(--amber-soft); padding:7px 15px; border-radius:100px; border:1px solid #ffe2a6;
}
.eyebrow--center{ background:var(--amber-soft); }
.eyebrow::before{ content:""; width:7px; height:7px; background:var(--amber-deep); border-radius:50%;
  box-shadow:0 0 0 4px rgba(245,147,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-amber); opacity:.85; }
.lead{ color:var(--ink-soft); font-size:1.08rem; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--grad-amber); --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-amber);
}
.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(245,147,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(14,26,43,.7); }
.btn--lg{ padding:18px 32px; font-size:1.02rem; }

/* ---------- 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:20px 0; border-bottom:1px solid transparent;
}
.header.scrolled{
  padding:11px 0; background:rgba(255,251,244,.82);
  backdrop-filter:blur(16px) saturate(140%); border-bottom-color:var(--line);
  box-shadow:0 8px 30px -18px rgba(14,26,43,.25);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand__logo{ height:46px; width:auto; display:block; transition:transform .5s var(--ease); }
.brand:hover .brand__logo{ transform:scale(1.04); }
.header.scrolled .brand__logo{ height:40px; }
.brand__mark{ width:46px; height:46px; flex:none; transition:transform .5s var(--ease); }
.brand:hover .brand__mark{ transform:rotate(-8deg) scale(1.05); }
.brand__txt{ display:flex; flex-direction:column; line-height:1; }
.brand__name{ font-family:var(--ff-head); font-weight:800; font-size:1.18rem; letter-spacing:.02em; color:var(--ink); }
.brand__sub{ font-size:.62rem; letter-spacing:.34em; text-transform:uppercase; color:var(--amber-deep); font-weight:600; margin-top:4px; }

.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(14,26,43,.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:280px; 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(--amber-soft); color:var(--ink); transform:translateX(3px); }
.dropdown a .ico{ width:34px; height:34px; flex:none; border-radius:10px; background:var(--amber-soft); color:var(--amber-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(--amber-soft); color:var(--amber-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(14,26,43,.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,200,90,.30), transparent 60%),
    radial-gradient(50% 70% at 12% 80%, rgba(18,155,140,.16), transparent 60%);
}
.hero__bg::before{ /* pattern */
  content:""; position:absolute; inset:0; background:url("../images/jarva-logo-pattern-optimerad.png");
  background-size:340px; opacity:.05; mix-blend-mode:multiply;
}
.hero__bg::after{ /* fine grid texture */
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(14,26,43,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(14,26,43,.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,#ffd989,#ffb01f00); top:-170px; right:-120px; animation:float1 16s ease-in-out infinite; }
.blob--2{ width:460px; height:460px; background:radial-gradient(circle,#bdeee7,#129b8c00); bottom:-170px; left:-130px; animation:float2 20s ease-in-out infinite; }
.blob--3{ width:300px; height:300px; background:radial-gradient(circle,#ffc6c6,#ff6b6b00); 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 .word{ display:inline-block; }
.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-amber); 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 img, .hero__avatars span{
  width:42px; height:42px; border-radius:50%; border:3px solid var(--cream); object-fit:cover; margin-left:-12px;
  background:var(--teal-soft); display:grid; place-items:center; font-family:var(--ff-head); font-weight:700; color:var(--teal); font-size:.85rem;
}
.hero__avatars :first-child{ margin-left:0; }
.hero__trust small{ display:block; color:var(--muted); }
.hero__trust .stars{ color:var(--amber-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(--amber); 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(--teal-soft); color:var(--teal); }
.float-card--b .fc-ico{ background:var(--amber-soft); color:var(--amber-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(--amber); }
@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/DSC06242-scaled.webp") center/cover fixed; }
.svc-section::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(10,18,30,.92), rgba(10,18,30,.78) 45%, rgba(10,18,30,.94));
}
.svc-section .section-title, .svc-section .eyebrow{ color:#fff; }
.svc-section .eyebrow{ background:rgba(255,176,31,.16); border-color:rgba(255,176,31,.3); color:var(--amber); }
.svc-section .section-title .hl{ -webkit-text-fill-color:transparent; }
.svc-section .lead{ color:#c4cdda; }
.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-amber);
  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(--amber-soft),transparent 70%); opacity:0; transition:opacity .5s; }
.svc:hover{ transform:translateY(-10px); box-shadow:0 34px 70px -28px rgba(245,147,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(--amber); 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-amber); 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(--amber-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:#c4cdda; }
.svc-section .svc__ico{ background:var(--grad-amber); color:var(--ink); }
.svc-section .svc:hover{ background:rgba(255,255,255,.12); border-color:rgba(255,176,31,.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(--amber); }

/* ---------- 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(--amber); display:block; line-height:1; }
.media-badge small{ font-size:.78rem; color:#c9d2df; }

.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(--teal-soft); color:var(--teal);
  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-amber); 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(--amber-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/DSC06268-scaled.webp") center/cover fixed; }
.stat-band::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(135deg, rgba(245,147,0,.92), rgba(14,26,43,.9) 60%, rgba(10,18,30,.95)); }
.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--2{ grid-template-columns:repeat(2,minmax(0,280px)); 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(--amber); -webkit-text-fill-color:var(--amber); }
.stat-band .stat small{ color:#e6ebf2; }
.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%, #16263c, var(--ink)); color:#fff; border-radius:var(--r-xl); overflow:hidden; position:relative; }
.ink-sec::before{ content:""; position:absolute; inset:0; background:url("../images/jarva-logo-pattern-optimerad.png"); background-size:300px; opacity:.04; }
.ink-sec h2,.ink-sec h3{ color:#fff; }
.ink-sec .lead{ color:#c4cdda; }
.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(--amber); 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:#aeb9c8; 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,#243349,#0e1a2b); }
.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:4rem; color:var(--amber); opacity:.9; }
.member.noimg .member__logo{ width:62%; max-width:180px; height:auto; object-fit:contain; opacity:.95;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.35)); transition:transform .8s var(--ease); }
.member.noimg:hover .member__logo{ transform:scale(1.06); }
.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(8,15,26,.9)); }
.member__info b{ font-family:var(--ff-head); font-size:1.22rem; display:block; }
.member__info small{ color:var(--amber); 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%,#1b2c44,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:url("../images/jarva-logo-pattern-optimerad.png"); background-size:280px; opacity:.04; }
.quote-band::after{ content:""; position:absolute; width:280px; height:280px; border-radius:50%; top:-140px; right:-80px;
  background:radial-gradient(circle,var(--amber-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-amber); -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:#dbe2ec; font-weight:600; }
.quote-band cite small{ display:block; color:var(--amber); 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(--amber),var(--amber-deep)); color:var(--ink); text-align:center; }
.cta::before{ content:""; position:absolute; inset:0; background:url("../images/jarva-logo-pattern-optimerad.png"); background-size:240px; opacity:.08; }
.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:#3a2c06; }
.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(--amber-soft); color:var(--amber-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:#c4cdda; padding:80px 0 30px; position:relative; overflow:hidden; }
.footer::before{ content:""; position:absolute; inset:0; background:url("../images/jarva-logo-pattern-optimerad.png"); background-size:320px; opacity:.03; }
.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:#9fabbc; }
.footer h4{ color:#fff; font-size:1rem; margin-bottom:20px; letter-spacing:.02em; }
.footer__links{ display:grid; gap:12px; }
.footer__links a{ color:#9fabbc; transition:color .25s, padding .25s; font-size:.96rem; }
.footer__links a:hover{ color:var(--amber); 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(--amber); 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:#7e8b9d; }
.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:#6f7c8e; }
.footer__credit a{ color:var(--amber); font-weight:600; transition:color .25s; }
.footer__credit a:hover{ color:#ffd27a; 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,200,90,.28), transparent 60%),
    radial-gradient(45% 60% at 8% 90%, rgba(18,155,140,.14), transparent 60%); }
.phero h1 .hl{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.phero__bg{ position:absolute; inset:0; z-index:-1; }
.phero__bg::before{ content:""; position:absolute; inset:0; background:url("../images/jarva-logo-pattern-optimerad.png"); background-size:300px; opacity:.04; }
.breadcrumb{ display:flex; gap:9px; align-items:center; font-size:.86rem; color:var(--muted); font-weight:500; }
.breadcrumb a:hover{ color:var(--amber-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-amber);
  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(--amber);
  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(--amber-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(--amber); 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(--amber); }

.quote-inline{ border-left:3px solid var(--amber); 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:#b6c0cf; 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(--amber); display:grid; place-items:center; }
.aside-phone b{ font-family:var(--ff-head); font-size:1.15rem; }
.aside-phone small{ display:block; color:#9fabbc; 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(--amber-soft); color:var(--amber-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); }

/* ---------- 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(--amber),var(--amber-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; }
}
@media (max-width:860px){
  /* iOS/mobile ignores background-attachment:fixed → use scroll to avoid broken render */
  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; }
  /* mobile menu panel */
  .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(14,26,43,.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; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
  [data-reveal]{ opacity:1; transform:none; }
}
