/* =========================================================
   DentalFriends — sito statico
   Design system + componenti (tema "premium")
   ========================================================= */

*{box-sizing:border-box;}
[hidden]{display:none!important;}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  overflow-x:hidden;
}

:root{
  --bg:#f3f1ee;
  --surface:#ffffff;
  --ink:#1a2238;
  --muted:#5a6079;
  --primary:#3a4a7a;
  --primary-deep:#1d2540;
  --accent:#f0a583;
  --soft:#e9ebf3;
  --brand:#f7bd2e;
  --warm:#fbede4;
  --radius:24px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

::selection{background:var(--brand);color:var(--ink);}

img{max-width:100%;}

/* ---------- keyframes ---------- */
@keyframes floatY{0%,100%{transform:translateY(0);}50%{transform:translateY(-18px);}}
@keyframes blobMorph{0%,100%{border-radius:46% 54% 60% 40%/48% 44% 56% 52%;}50%{border-radius:58% 42% 38% 62%/56% 58% 42% 44%;}}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--brand) 60%, transparent);}70%{box-shadow:0 0 0 9px rgba(0,0,0,0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

/* =========================================================
   Layout di base
   ========================================================= */
.page{position:relative;color:var(--ink);background:transparent;overflow-x:hidden;line-height:1.55;}
.content{position:relative;z-index:1;}
.wrap{max-width:var(--maxw);margin:0 auto;}

/* =========================================================
   Aurora background
   ========================================================= */
.aurora{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.aurora__wash{position:absolute;inset:0;background:currentColor;color:#f7bd2e;opacity:.07;transition:color .9s ease,opacity .9s ease;}
.aurora__blob{
  position:absolute;left:76%;top:40%;width:68vw;height:68vw;transform:translate(-50%,-50%);
  border-radius:50%;filter:blur(80px);opacity:.5;color:#f7bd2e;
  background:radial-gradient(circle at 50% 50%, currentColor, transparent 70%);
  transition:color .9s ease,left 1s var(--ease),top 1s var(--ease),width 1s var(--ease),height 1s var(--ease),opacity .9s ease;
  will-change:left,top,width,height;
}
.aurora__blob2{
  position:absolute;left:28%;top:74%;width:46vw;height:46vw;transform:translate(-50%,-50%);
  border-radius:50%;filter:blur(96px);opacity:.26;color:#3a4a7a;
  background:radial-gradient(circle at 50% 50%, currentColor, transparent 70%);
  transition:color 1.1s ease;
}

/* =========================================================
   Reveal on scroll
   ========================================================= */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .85s var(--ease),transform .85s var(--ease);}
[data-reveal][data-shown]{opacity:1 !important;transform:none !important;}

/* =========================================================
   Header
   ========================================================= */
.header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  border-bottom:1px solid rgba(0,0,0,0);
  transition:transform .42s var(--ease),background .4s,box-shadow .4s,border-color .4s;
  will-change:transform;
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
}
.header.is-scrolled{
  background:color-mix(in srgb, var(--surface) 88%, transparent);
  box-shadow:0 10px 34px -16px rgba(26,34,56,.22);
  border-bottom-color:rgba(0,0,0,.06);
}
.header.is-hidden{transform:translateY(-115%);}
.progress{
  position:absolute;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--brand),var(--accent));
  border-radius:0 3px 3px 0;transition:width .12s linear;
}
.header__inner{
  max-width:var(--maxw);margin:0 auto;padding:16px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  transition:padding .35s ease;
}
.header.is-scrolled .header__inner{padding:9px 24px;}
.header__logo{display:flex;align-items:center;text-decoration:none;}
.header__logo img{height:48px;width:auto;display:block;transition:height .35s ease;}
.header.is-scrolled .header__logo img{height:38px;}

.nav{display:flex;align-items:center;gap:4px;}
.navlink{
  position:relative;font-family:'Hanken Grotesk';font-weight:600;font-size:15.5px;
  color:var(--ink);text-decoration:none;padding:10px 16px;border-radius:999px;transition:color .25s;
}
.navlink:hover{color:var(--primary);}
.navlink.is-active{font-weight:700;color:var(--primary);}
.navlink::after{
  content:'';position:absolute;left:14px;right:14px;bottom:5px;height:2.5px;border-radius:2px;
  background:var(--brand);transform:scaleX(0);transform-origin:left center;transition:transform .38s var(--ease);
}
.navlink:hover::after{transform:scaleX(1);}

.nav__cta{
  margin-left:10px;display:inline-flex;align-items:center;gap:9px;
  background:var(--ink);color:#fff;font-family:'Schibsted Grotesk';font-weight:700;font-size:15px;
  text-decoration:none;padding:12px 22px;border-radius:999px;
  box-shadow:0 12px 24px -12px rgba(26,34,56,.7);
  transition:transform .3s,box-shadow .3s,background .3s;
}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 18px 32px -12px rgba(26,34,56,.7);background:var(--primary);}
.dot{width:8px;height:8px;border-radius:50%;background:var(--brand);}
.dot--pulse{animation:pulseDot 2.4s ease-out infinite;}

/* burger + mobile nav */
.burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:46px;border:none;border-radius:13px;background:var(--soft);cursor:pointer;padding:0;
}
.burger span{display:block;width:20px;height:2.5px;border-radius:2px;background:var(--ink);margin:0 auto;transition:transform .3s,opacity .3s;}
.burger.is-open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.burger.is-open span:nth-child(2){opacity:0;}
.burger.is-open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

.mobilenav{
  max-height:0;opacity:0;overflow:hidden;transition:max-height .42s var(--ease),opacity .3s;
  background:color-mix(in srgb,var(--surface) 97%, transparent);
  border-bottom:1px solid rgba(0,0,0,.06);
  box-shadow:0 18px 30px -22px rgba(26,34,56,.35);
}
.mobilenav__inner{max-width:var(--maxw);margin:0 auto;padding:6px 24px 22px;display:flex;flex-direction:column;gap:4px;}
.mobilenav a{font-family:'Hanken Grotesk';font-weight:600;font-size:17px;color:var(--ink);text-decoration:none;padding:14px 16px;border-radius:13px;transition:background .2s;}
.mobilenav a:hover{background:var(--soft);}
.mobilenav__cta{margin-top:6px;display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--ink) !important;color:#fff !important;font-family:'Schibsted Grotesk';font-weight:800;font-size:16px;padding:15px !important;border-radius:13px !important;}

/* =========================================================
   Buttons
   ========================================================= */
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-family:'Schibsted Grotesk';font-weight:700;border-radius:999px;cursor:pointer;border:none;}
.btn--dark{background:var(--ink);color:#fff;font-size:17px;padding:17px 32px;box-shadow:0 18px 36px -14px rgba(26,34,56,.65);transition:transform .3s,box-shadow .3s,background .3s;}
.btn--dark:hover{transform:translateY(-3px);box-shadow:0 26px 46px -14px rgba(26,34,56,.65);background:var(--primary);}
.btn--outline{color:var(--ink);font-size:17px;padding:15px 26px;border:1.6px solid color-mix(in srgb,var(--ink) 18%, transparent);transition:border-color .3s,background .3s;}
.btn--outline:hover{border-color:var(--brand);background:var(--surface);}
.btn--brand{background:var(--brand);color:var(--ink);font-weight:800;font-size:17px;padding:16px 32px;transition:transform .3s,box-shadow .3s;}
.btn--brand:hover{transform:translateY(-3px);box-shadow:0 22px 42px -16px rgba(0,0,0,.5);}
.btn__phoneicon{width:34px;height:34px;border-radius:50%;background:var(--brand);display:inline-flex;align-items:center;justify-content:center;color:var(--ink);font-size:16px;}
.arrow{font-size:19px;}

/* =========================================================
   Section helpers
   ========================================================= */
.section{padding:clamp(74px,9vw,120px) 24px;position:relative;}
.eyebrow{font-family:'Hanken Grotesk';font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:14px;}
.h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(32px,4.4vw,54px);letter-spacing:-.025em;margin:0;color:var(--ink);line-height:1;}

/* =========================================================
   HERO (Home — variante team)
   ========================================================= */
.hero{
  position:relative;padding:140px 24px 0;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.6) 0%, color-mix(in srgb, var(--bg) 50%, transparent) 100%);
}
.hero__inner{max-width:900px;margin:0 auto;text-align:center;position:relative;}
.badge{
  display:inline-flex;align-items:center;gap:11px;background:var(--surface);border:1px solid rgba(0,0,0,.06);
  padding:9px 18px 9px 14px;border-radius:999px;box-shadow:0 10px 26px -16px rgba(26,34,56,.5);
}
.badge__label{font-family:'Hanken Grotesk';font-weight:700;font-size:13px;letter-spacing:.1em;color:var(--primary);text-transform:uppercase;}
.hero h1{
  font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(40px,5.6vw,68px);line-height:1;letter-spacing:-.03em;
  margin:24px 0 0;color:var(--ink);text-wrap:balance;
}
.hero h1 .pretitle{display:block;font-size:.36em;font-weight:700;letter-spacing:.01em;color:var(--primary);margin-bottom:.55em;}
.hero h1 .hl{background:linear-gradient(180deg,transparent 60%, color-mix(in srgb,var(--brand) 85%, transparent) 60%, color-mix(in srgb,var(--brand) 85%, transparent) 92%, transparent 92%);padding:0 .06em;}
.hero__sub{font-size:clamp(17px,1.9vw,21px);color:var(--muted);max-width:40ch;margin:22px auto 0;font-weight:500;}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;align-items:center;justify-content:center;}
.hero__img{position:relative;max-width:var(--maxw);margin:30px auto 0;overflow:hidden;}
.hero__img img{
  display:block;width:100%;height:auto;margin:-6% 0 -19%;
  -webkit-mask-image:linear-gradient(to bottom, #000 0%, #000 55%, rgba(0,0,0,0) 78%);
  mask-image:linear-gradient(to bottom, #000 0%, #000 55%, rgba(0,0,0,0) 78%);
}

/* =========================================================
   Marquee servizi
   ========================================================= */
.marq{position:relative;overflow:hidden;border-top:1px solid rgba(0,0,0,.07);border-bottom:1px solid rgba(0,0,0,.07);background:var(--surface);}
.marq__track{display:flex;width:max-content;white-space:nowrap;animation:marquee 42s linear infinite;will-change:transform;}
.marq:hover .marq__track{animation-play-state:paused;}
.marq__group{display:inline-flex;align-items:center;font-family:'Schibsted Grotesk';font-weight:700;font-size:clamp(17px,2vw,25px);color:var(--ink);}
.marq__group span.txt{padding:18px 30px;}
.marq__group span.bullet{width:8px;height:8px;border-radius:50%;background:var(--brand);}

/* =========================================================
   Caratteristiche / valori
   ========================================================= */
.vals__head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:50px;}
.vals__rule{height:6px;flex:1;min-width:120px;max-width:260px;border-radius:999px;background:linear-gradient(90deg,var(--brand),color-mix(in srgb,var(--brand) 0%, transparent));margin-bottom:10px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.valcard{
  position:relative;overflow:hidden;background:var(--surface);border:1px solid rgba(0,0,0,.06);
  border-radius:calc(var(--radius) + 6px);padding:40px 32px 36px;box-shadow:0 30px 60px -42px rgba(26,34,56,.45);
}
.valcard--dark{background:var(--ink);border-color:var(--ink);box-shadow:0 36px 70px -38px rgba(26,34,56,.6);}
.valcard__ico{width:60px;height:60px;border-radius:17px;background:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:22px;}
.valcard h3{font-family:'Schibsted Grotesk';font-weight:800;font-size:25px;letter-spacing:-.01em;margin:0 0 14px;color:var(--ink);}
.valcard p{font-size:16px;color:var(--muted);margin:0;}
.valcard--dark h3{color:#fff;}
.valcard--dark p{color:rgba(255,255,255,.78);}

/* =========================================================
   Blocchi trattamento
   ========================================================= */
.block{
  position:relative;overflow:hidden;border-radius:calc(var(--radius) + 18px);padding:clamp(38px,5vw,66px);
}
.block--adults{background:linear-gradient(155deg, #004ea1, #1d2540 100%);}
.block--kids{background:linear-gradient(160deg, #e8871e, #fdf202);max-width:var(--maxw);margin:0 auto;}
.block__deco1{position:absolute;border-radius:50%;z-index:0;}
.block__deco-blob{position:absolute;top:-70px;right:-50px;width:260px;height:260px;border-radius:50%;background:color-mix(in srgb,var(--brand) 22%, transparent);z-index:0;animation:blobMorph 15s ease-in-out infinite;}
.block__deco-ring{position:absolute;bottom:-60px;left:6%;width:150px;height:150px;border-radius:50%;border:16px solid color-mix(in srgb,var(--primary) 42%, transparent);z-index:0;animation:floatY 9s ease-in-out infinite;}
.block__deco-blob--kids{top:-60px;right:-40px;width:240px;height:240px;background:color-mix(in srgb,var(--accent) 55%, transparent);border-radius:0;}
.block__deco-ring--kids{bottom:-50px;left:30%;width:140px;height:140px;background:color-mix(in srgb,var(--brand) 45%, transparent);border:none;animation:floatY 8s ease-in-out infinite;}

.grid-2{display:grid;grid-template-columns:1fr 1.1fr;gap:44px;align-items:flex-start;}
.block__top{position:relative;z-index:1;margin-bottom:44px;}
.tag{display:inline-flex;align-items:center;gap:9px;font-family:'Hanken Grotesk';font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin-bottom:14px;}
.tag .dot{background:var(--brand);}
.tag--pill{background:var(--surface);padding:8px 16px;border-radius:999px;color:var(--primary);letter-spacing:.12em;margin-bottom:18px;box-shadow:0 8px 20px -14px rgba(26,34,56,.4);}
.tag--pill .dot{background:var(--accent);}
.h2--light{color:#fff;}
.block__lead-white{font-size:17px;color:#ffffff;margin:18px 0 0;max-width:34ch;}

.notecard{background:var(--surface);border-radius:var(--radius);padding:28px 30px;box-shadow:0 30px 56px -34px rgba(0,0,0,.6);border-left:5px solid var(--brand);}
.notecard--soft{border-radius:calc(var(--radius) + 4px);padding:32px 34px;box-shadow:0 30px 60px -38px rgba(26,34,56,.4);border-left:none;}
.notecard h3{font-family:'Schibsted Grotesk';font-weight:800;font-size:21px;margin:0 0 10px;color:var(--ink);}
.notecard p{font-size:16.5px;color:var(--muted);margin:0 0 10px;}
.notecard p:last-child{margin-bottom:0;}
.notecard strong{color:var(--ink);}
.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.checklist li{display:flex;align-items:flex-start;gap:12px;font-size:16px;color:var(--ink);font-weight:500;}
.checklist .check{flex:none;width:24px;height:24px;border-radius:50%;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;margin-top:1px;background:#f58549;}

.block__photo{position:relative;z-index:1;height:clamp(240px,28vw,360px);border-radius:calc(var(--radius) + 4px);overflow:hidden;margin-bottom:24px;box-shadow:0 30px 60px -34px rgba(0,0,0,.6);}
.block__photo--kids{box-shadow:0 30px 60px -38px rgba(26,34,56,.4);}
.block__photo img{width:100%;height:128%;object-fit:cover;display:block;position:relative;top:-14%;will-change:transform;}

.grid-4{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.svc{position:relative;background:var(--surface);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);padding:30px 26px;transition:transform .42s var(--ease),box-shadow .42s,border-color .35s,opacity .8s;}
.svc::before{content:'';position:absolute;top:0;left:26px;right:26px;height:4px;border-radius:0 0 4px 4px;background:var(--brand);transform:scaleX(0);transform-origin:center;transition:transform .42s var(--ease);}
.svc:hover::before{transform:scaleX(1);}
.svc:hover{transform:translateY(-10px);box-shadow:0 34px 58px -28px rgba(26,34,56,.4);border-color:color-mix(in srgb,var(--brand) 55%, transparent);}
.svc__ico{width:74px;height:74px;border-radius:20px;background:var(--soft);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:background .38s var(--ease),transform .38s var(--ease);}
.svc:hover .svc__ico{transform:rotate(-7deg) scale(1.07);background:color-mix(in srgb,var(--brand) 28%, transparent);}
.svc__ico img{width:44px;height:44px;object-fit:contain;}
.svc h3{font-family:'Schibsted Grotesk';font-weight:700;font-size:19px;margin:0 0 8px;color:var(--ink);}
.svc p{font-size:15px;color:var(--muted);margin:0;}
/* variante bambini: cerchio caldo */
.svc--kids{border:1px solid rgba(255,255,255,.6);border-radius:calc(var(--radius) + 4px);padding:28px 24px;}
.svc--kids .svc__ico{border-radius:50%;background:var(--warm);}
.svc--kids h3{font-size:18px;}

/* =========================================================
   Staff (home)
   ========================================================= */
.staff{
  max-width:var(--maxw);margin:0 auto;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-deep) 100%);
  border-radius:calc(var(--radius) + 14px);padding:clamp(40px,6vw,72px);position:relative;overflow:hidden;color:#fff;
}
.staff__deco{position:absolute;right:-50px;top:-50px;width:300px;height:300px;background:color-mix(in srgb,var(--brand) 22%, transparent);animation:blobMorph 16s ease-in-out infinite;}
.staff__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(34px,4vw,56px);align-items:center;}
.staff__eyebrow{font-family:'Hanken Grotesk';font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin-bottom:16px;}
.staff h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(28px,4vw,46px);letter-spacing:-.02em;margin:0 0 18px;}
.staff p{font-size:19px;opacity:.92;margin:0 0 30px;}
.staff__img{position:relative;align-self:stretch;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;}
.staff__img img{width:100%;height:auto;display:block;margin:-2% 0 -7%;filter:drop-shadow(0 20px 30px rgba(0,0,0,.3));}

/* =========================================================
   Banner senza paura
   ========================================================= */
.fear{
  max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center;
  background:var(--surface);border:1px solid rgba(0,0,0,.06);border-radius:calc(var(--radius) + 14px);
  padding:clamp(36px,5vw,64px);box-shadow:0 30px 70px -50px rgba(26,34,56,.5);
}
.fear h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(26px,3.4vw,42px);letter-spacing:-.02em;margin:0 0 16px;color:var(--ink);line-height:1.05;}
.fear p{font-size:18px;color:var(--muted);margin:0;max-width:54ch;}
.phonecard{
  display:inline-flex;flex-direction:column;text-decoration:none;background:var(--ink);border-radius:var(--radius);
  padding:28px 36px;box-shadow:0 26px 50px -26px rgba(26,34,56,.6);transition:transform .3s,box-shadow .3s;border-bottom:5px solid var(--brand);
}
.phonecard:hover{transform:translateY(-4px);box-shadow:0 36px 64px -26px rgba(26,34,56,.65);}
.phonecard__label{font-family:'Hanken Grotesk';font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);}
.phonecard__num{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(26px,3vw,34px);color:#fff;margin-top:6px;}

/* =========================================================
   Comunità
   ========================================================= */
.community{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.community h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(28px,3.6vw,46px);letter-spacing:-.025em;margin:0 0 10px;color:var(--ink);line-height:1.02;}
.community h3{font-family:'Schibsted Grotesk';font-weight:700;font-size:22px;margin:0 0 18px;color:var(--primary);}
.community p{font-size:18px;color:var(--muted);margin:0;max-width:52ch;}
.community__media{position:relative;}
.community__deco{position:absolute;inset:-20px auto auto -20px;width:130px;height:130px;background:var(--brand);opacity:.9;z-index:0;animation:blobMorph 13s ease-in-out infinite;}
.community__frame{position:relative;z-index:1;border-radius:calc(var(--radius) + 12px);overflow:hidden;box-shadow:0 34px 70px -34px rgba(26,34,56,.5);background:var(--soft);}
.community__frame img{width:100%;height:auto;display:block;}

/* =========================================================
   Galleria + lightbox
   ========================================================= */
.gallery__head{text-align:center;margin-bottom:50px;}
.gallery{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:150px;gap:18px;}
.gcell{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;box-shadow:0 20px 44px -28px rgba(26,34,56,.45);}
.gcell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease);}
.gcell:hover img{transform:scale(1.07);}
.gcell--main{grid-column:span 4;grid-row:span 2;}
.gcell--w2{grid-column:span 2;grid-row:span 1;}
.gcell--w3{grid-column:span 3;grid-row:span 2;}
.gcell--quote{grid-column:span 3;grid-row:span 2;background:linear-gradient(135deg,var(--ink),var(--primary));display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;cursor:default;box-shadow:none;}
.gcell--quote span{font-family:'Schibsted Grotesk';font-weight:800;font-size:20px;color:#fff;line-height:1.3;}
.gcell--quote .accent{color:var(--brand);}

.lightbox{position:fixed;inset:0;z-index:200;background:rgba(10,12,24,.88);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:32px;animation:fadeIn .3s ease both;cursor:zoom-out;}
.lightbox[hidden]{display:none;}
.lightbox img{max-width:92%;max-height:88%;border-radius:16px;box-shadow:0 40px 90px -20px rgba(0,0,0,.7);display:block;}
.lightbox__close{position:absolute;top:24px;right:28px;width:48px;height:48px;border-radius:50%;border:none;background:rgba(255,255,255,.16);color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;}

/* =========================================================
   Footer
   ========================================================= */
.footer{background:var(--ink);color:#fff;padding:64px 24px 36px;}
.footer__inner{max-width:var(--maxw);margin:0 auto;}
.footer__top{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.14);}
.footer__logo{height:54px;width:auto;opacity:.95;}
.footer__nav{display:flex;gap:8px;flex-wrap:wrap;}
.footer__nav a{font-family:'Hanken Grotesk';font-weight:600;font-size:15.5px;color:#fff;text-decoration:none;padding:9px 16px;border-radius:999px;transition:background .25s;}
.footer__nav a:hover{background:rgba(255,255,255,.12);}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;padding-top:26px;font-size:14.5px;color:rgba(255,255,255,.72);}
.footer__bottom a{color:#fff;text-decoration:none;opacity:.85;}
.footer__meta{display:flex;flex-wrap:wrap;gap:18px;}

/* =========================================================
   Barra azioni mobile
   ========================================================= */
.mobilebar{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:90;gap:10px;transform:translateY(170%);transition:transform .45s var(--ease);}
.mobilebar.is-visible{transform:translateY(0);}
.mobilebar a{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:'Schibsted Grotesk';font-weight:800;font-size:16px;text-decoration:none;padding:16px;border-radius:16px;}
.mobilebar__call{flex:1;background:var(--surface);color:var(--ink);border:1px solid rgba(0,0,0,.08);box-shadow:0 16px 34px -14px rgba(26,34,56,.5);}
.mobilebar__call .ic{width:30px;height:30px;border-radius:50%;background:var(--brand);display:inline-flex;align-items:center;justify-content:center;font-size:15px;}
.mobilebar__info{flex:1.25;background:var(--ink);color:#fff;box-shadow:0 16px 34px -14px rgba(26,34,56,.6);}

/* =========================================================
   Hero pagina interna (Chi siamo / Contatti / Specialista)
   ========================================================= */
.pagehero{
  position:relative;padding:152px 24px 0;overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.66) 0%, color-mix(in srgb, var(--bg) 55%, transparent) 100%);
}
.pagehero__intro{max-width:760px;}
.pagehero .badge{margin-bottom:22px;background:var(--surface);border:none;padding:8px 16px;box-shadow:0 10px 26px -16px rgba(26,34,56,.4);}
.pagehero h1{font-family:'Schibsted Grotesk';font-weight:900;font-size:clamp(38px,6vw,72px);letter-spacing:-.03em;line-height:1.02;margin:0 0 22px;color:var(--ink);}
.pagehero h1 .accent{color:var(--primary);}
.pagehero p{font-size:clamp(17px,2vw,20px);color:var(--muted);margin:0;max-width:60ch;}
.pagehero__img{max-width:var(--maxw);margin:30px auto 0;overflow:hidden;}
.pagehero__img img{display:block;width:100%;height:auto;margin:-2% 0 -13%;-webkit-mask-image:linear-gradient(to bottom, #000 0%, #000 55%, rgba(0,0,0,0) 78%);mask-image:linear-gradient(to bottom, #000 0%, #000 55%, rgba(0,0,0,0) 78%);}

/* =========================================================
   Chi siamo — team
   ========================================================= */
.team-section{padding:clamp(36px,5vw,60px) 24px;}
.team-section__head{margin-bottom:34px;text-align:center;}
.team-section__head .eyebrow{margin-bottom:12px;}
.team-section__head h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(28px,3.6vw,44px);letter-spacing:-.025em;margin:0;color:var(--ink);}

.team-grid{display:grid;gap:22px;}
.team-grid--2{grid-template-columns:repeat(2,1fr);gap:28px;}
.team-grid--3{grid-template-columns:repeat(4,1fr);}
.team-grid--4{grid-template-columns:repeat(4,1fr);}

.card{
  position:relative;text-decoration:none;color:inherit;background:var(--surface);
  border:1px solid color-mix(in srgb,var(--ink) 8%, transparent);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 16px 40px -30px rgba(26,34,56,.38);
  transition:transform .42s var(--ease),box-shadow .42s,border-color .35s,opacity .8s;
}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--brand);transform:scaleX(0);transform-origin:center;transition:transform .42s var(--ease);z-index:2;}
a.card:hover::before{transform:scaleX(1);}
a.card:hover{transform:translateY(-9px);box-shadow:0 34px 58px -28px rgba(26,34,56,.4);border-color:color-mix(in srgb,var(--brand) 55%, transparent);}
.card__photo{overflow:hidden;background:var(--soft);}
.card__photo img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .6s var(--ease);}
a.card:hover .card__photo img{transform:scale(1.05);}
.card__body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1;}
.card__body h3{font-family:'Schibsted Grotesk';font-weight:800;font-size:18.5px;margin:0 0 7px;color:var(--ink);letter-spacing:-.01em;}
.card__body p{font-size:13.5px;color:var(--muted);margin:0 0 16px;flex:1;line-height:1.5;}
.more{display:inline-flex;align-items:center;gap:8px;font-family:'Schibsted Grotesk';font-weight:800;font-size:14px;color:var(--ink);transition:gap .3s var(--ease),color .25s;}
a.card:hover .more{gap:12px;color:var(--primary);}

/* specialisti: card grandi orizzontali */
.card--wide{flex-direction:row;display:grid;grid-template-columns:170px 1fr;box-shadow:0 18px 44px -30px rgba(26,34,56,.4);}
.card--wide .card__photo img{min-height:230px;}
.card--wide .card__body{padding:26px 26px 24px;}
.card--wide .card__body h3{font-size:22px;margin-bottom:10px;}
.card--wide .card__body p{font-size:14.5px;margin-bottom:20px;}
.card--wide .more{font-size:15px;}

/* collaboratori / igienisti: foto 4/5 */
.card--vert .card__photo{aspect-ratio:4/5;}
/* segreteria / aso: foto quadrate, niente link */
.card--square .card__photo{aspect-ratio:1/1;}
.card--square .card__body{padding:18px 20px 20px;}
.card--square .card__body h3{font-size:17px;margin-bottom:5px;}
.card--square .card__body p{font-size:13px;margin-bottom:0;}

/* CTA finale chi siamo */
.cta-box{
  max-width:var(--maxw);margin:0 auto;background:linear-gradient(135deg,var(--ink),var(--primary));
  border-radius:calc(var(--radius) + 6px);padding:clamp(40px,5vw,64px);text-align:center;color:#fff;box-shadow:0 40px 80px -40px rgba(26,34,56,.6);
}
.cta-box h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(28px,3.6vw,44px);letter-spacing:-.02em;margin:0 0 14px;}
.cta-box p{font-size:18px;opacity:.9;margin:0 auto 30px;max-width:50ch;}

/* =========================================================
   Contatti
   ========================================================= */
.contact-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(28px,3.5vw,48px);align-items:stretch;}
.contact-info{display:flex;flex-direction:column;gap:18px;}
.infocard{
  text-decoration:none;color:inherit;display:flex;align-items:center;gap:18px;background:var(--surface);
  border:1px solid color-mix(in srgb,var(--ink) 8%, transparent);border-radius:var(--radius);padding:22px 24px;
  box-shadow:0 18px 44px -32px rgba(26,34,56,.45);transition:transform .42s var(--ease),box-shadow .42s,border-color .35s,opacity .8s;
}
.infocard:hover{transform:translateY(-6px);box-shadow:0 30px 54px -30px rgba(26,34,56,.4);border-color:color-mix(in srgb,var(--brand) 55%, transparent);}
.infocard__ico{flex:none;width:54px;height:54px;border-radius:16px;background:color-mix(in srgb,var(--brand) 20%, var(--surface));display:flex;align-items:center;justify-content:center;color:var(--primary);}
.infocard__txt{display:flex;flex-direction:column;gap:3px;}
.infocard__label{font-family:'Hanken Grotesk';font-weight:700;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
.infocard__value{font-family:'Schibsted Grotesk';font-weight:800;font-size:19px;color:var(--ink);letter-spacing:-.01em;}
.mapcard{position:relative;flex:1;min-height:230px;text-decoration:none;color:inherit;border-radius:var(--radius);overflow:hidden;border:1px solid color-mix(in srgb,var(--ink) 8%, transparent);box-shadow:0 18px 44px -30px rgba(26,34,56,.45);display:block;}
.mapcard iframe{width:100%;height:100%;min-height:230px;border:0;display:block;filter:grayscale(.18) contrast(1.02);}
.mappin{position:absolute;left:16px;bottom:16px;display:inline-flex;align-items:center;gap:9px;background:var(--surface);padding:11px 16px;border-radius:999px;box-shadow:0 10px 26px -12px rgba(26,34,56,.5);pointer-events:none;}
.mappin span{font-family:'Schibsted Grotesk';font-weight:800;font-size:14px;color:var(--ink);}

.formcard{background:var(--surface);border:1px solid color-mix(in srgb,var(--ink) 8%, transparent);border-radius:calc(var(--radius) + 4px);padding:clamp(26px,3vw,40px);box-shadow:0 34px 70px -38px rgba(26,34,56,.5);}
.formcard h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(24px,2.6vw,30px);letter-spacing:-.02em;margin:0 0 6px;color:var(--ink);}
.formcard__sub{font-size:15.5px;color:var(--muted);margin:0 0 26px;}
.form{display:flex;flex-direction:column;gap:16px;}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field span{font-family:'Hanken Grotesk';font-weight:600;font-size:14px;color:var(--ink);}
.field input,.field textarea{
  width:100%;font-family:'Hanken Grotesk',sans-serif;font-size:16px;color:var(--ink);background:var(--surface);
  border:1.5px solid color-mix(in srgb,var(--ink) 14%, transparent);border-radius:14px;padding:15px 16px;outline:none;
  transition:border-color .25s,box-shadow .25s;resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{color:color-mix(in srgb,var(--muted) 78%, transparent);}
.field input:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 16%, transparent);}
.form__err{font-family:'Hanken Grotesk';font-weight:600;font-size:14px;color:#c2410c;}
.form__submit{margin-top:4px;display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--ink);color:#fff;font-family:'Schibsted Grotesk';font-weight:800;font-size:17px;border:none;cursor:pointer;padding:17px 28px;border-radius:999px;box-shadow:0 18px 36px -16px rgba(26,34,56,.7);transition:transform .3s,box-shadow .3s,background .3s;}
.form__submit:hover{transform:translateY(-3px);box-shadow:0 24px 44px -16px rgba(26,34,56,.7);background:var(--primary);}
.form__privacy{font-size:12.5px;color:var(--muted);margin:2px 0 0;text-align:center;}
.form__sent{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:30px 10px;}
.form__sent .check{width:64px;height:64px;border-radius:50%;background:color-mix(in srgb,var(--brand) 24%, var(--surface));display:flex;align-items:center;justify-content:center;color:var(--primary);}
.form__sent h3{font-family:'Schibsted Grotesk';font-weight:800;font-size:22px;margin:0;color:var(--ink);}
.form__sent p{font-size:15.5px;color:var(--muted);margin:0;max-width:36ch;}

.closeband{
  max-width:var(--maxw);margin:0 auto;background:linear-gradient(135deg,var(--ink),var(--primary));border-radius:calc(var(--radius) + 6px);
  padding:clamp(30px,4vw,52px) clamp(24px,4vw,56px);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:22px;
  box-shadow:0 40px 80px -42px rgba(26,34,56,.6);
}
.closeband__left{display:flex;align-items:center;gap:18px;}
.closeband__ico{flex:none;width:54px;height:54px;border-radius:16px;background:color-mix(in srgb,var(--brand) 26%, transparent);display:flex;align-items:center;justify-content:center;color:var(--brand);}
.closeband p{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(22px,2.6vw,32px);letter-spacing:-.02em;color:#fff;margin:0;}
.closeband .btn--brand{flex:none;font-size:16px;padding:15px 28px;}

/* =========================================================
   Specialista
   ========================================================= */
.back{display:inline-flex;align-items:center;gap:9px;font-family:'Schibsted Grotesk';font-weight:800;font-size:14.5px;color:var(--muted);text-decoration:none;margin-bottom:26px;transition:gap .3s var(--ease),color .25s;}
.back:hover{gap:14px;color:var(--primary);}
.prof-hero{display:grid;grid-template-columns:0.86fr 1.14fr;gap:clamp(32px,4vw,60px);align-items:center;}
.prof-hero__media{position:relative;}
.prof-hero__deco{position:absolute;inset:-26px -22px auto auto;width:140px;height:140px;background:color-mix(in srgb,var(--brand) 80%, transparent);opacity:.9;z-index:0;animation:blobMorph 14s ease-in-out infinite;}
.prof-hero__frame{position:relative;z-index:1;border-radius:260px 260px 28px 28px;overflow:hidden;box-shadow:0 40px 80px -34px rgba(26,34,56,.5);aspect-ratio:4/4.7;background:var(--soft);}
.prof-hero__frame img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;}
.prof-hero .badge{margin-bottom:20px;background:var(--surface);border:none;padding:8px 16px;box-shadow:0 10px 26px -16px rgba(26,34,56,.4);}
.prof-hero h1{font-family:'Schibsted Grotesk';font-weight:900;font-size:clamp(34px,5vw,58px);letter-spacing:-.03em;line-height:1.02;margin:0 0 16px;color:var(--ink);}
.prof-hero__lead{font-size:clamp(16px,1.8vw,19px);color:var(--muted);margin:0 0 22px;max-width:56ch;}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:28px;}
.chip{display:inline-flex;align-items:center;font-family:'Hanken Grotesk';font-weight:600;font-size:13.5px;color:var(--primary);background:color-mix(in srgb,var(--primary) 10%, var(--surface));border:1px solid color-mix(in srgb,var(--primary) 20%, transparent);padding:7px 14px;border-radius:999px;}
.prof-hero__cta{display:flex;flex-wrap:wrap;gap:12px;}
.btn--dark.btn--sm{font-size:16px;padding:15px 28px;box-shadow:0 16px 32px -16px rgba(26,34,56,.7);}
.btn--dark.btn--sm:hover{box-shadow:0 22px 40px -16px rgba(26,34,56,.7);}
.btn--ghost{background:var(--surface);color:var(--ink);border:1.5px solid color-mix(in srgb,var(--ink) 14%, transparent);font-weight:800;font-size:16px;padding:15px 26px;transition:border-color .25s,transform .3s;}
.btn--ghost:hover{border-color:var(--primary);transform:translateY(-3px);}

.studioband{
  display:flex;flex-wrap:wrap;align-items:center;gap:20px 36px;background:var(--surface);
  border:1px solid color-mix(in srgb,var(--ink) 8%, transparent);border-radius:calc(var(--radius) + 4px);
  padding:22px 28px;box-shadow:0 22px 54px -38px rgba(26,34,56,.5);margin-bottom:clamp(32px,4vw,48px);
}
.studioband__items{display:flex;flex-wrap:wrap;align-items:center;gap:18px 30px;flex:1;min-width:240px;}
.studioband__item{display:flex;align-items:center;gap:12px;}
.studioband__ico{flex:none;width:40px;height:40px;border-radius:12px;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--primary);}
.studioband__k{display:block;font-family:'Hanken Grotesk';font-weight:700;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.studioband__v{font-family:'Schibsted Grotesk';font-weight:700;font-size:16px;color:var(--ink);}
.studioband .btn--brand{flex:none;font-size:15.5px;padding:14px 26px;}

.prof-body__eyebrow{font-family:'Hanken Grotesk';font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:16px;}
.prof-body p{font-size:clamp(16px,1.7vw,18.5px);color:var(--ink);opacity:.92;margin:0 0 20px;max-width:64ch;}
.prof-areas{margin-top:14px;}
.prof-areas h2,.prof-acc h2{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(23px,2.5vw,30px);letter-spacing:-.02em;margin:0 0 24px;color:var(--ink);}
.disc-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.disc{display:flex;flex-direction:column;background:var(--surface);border:1px solid color-mix(in srgb,var(--ink) 8%, transparent);border-radius:calc(var(--radius) + 4px);overflow:hidden;box-shadow:0 22px 50px -34px rgba(26,34,56,.42);}
.disc__img{position:relative;background:color-mix(in srgb,var(--brand) 14%, var(--surface));overflow:hidden;height:230px;}
.disc__img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.disc__body{padding:24px 26px;display:flex;flex-direction:column;flex:1;}
.disc__body h3{font-family:'Schibsted Grotesk';font-weight:800;font-size:20px;margin:0 0 10px;color:var(--ink);letter-spacing:-.015em;}
.disc__body p{font-size:15px;color:var(--muted);margin:0;line-height:1.6;opacity:1;max-width:none;}

.prof-acc{margin-top:38px;}
.prof-acc h2{margin-bottom:20px;}
.acc-list{display:flex;flex-direction:column;gap:12px;}
.acc{background:var(--surface);border:1px solid color-mix(in srgb,var(--ink) 10%, transparent);border-radius:18px;overflow:hidden;box-shadow:0 14px 34px -30px rgba(26,34,56,.4);transition:border-color .3s,box-shadow .3s;}
.acc:hover{border-color:color-mix(in srgb,var(--primary) 40%, transparent);}
.acc__head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;cursor:pointer;list-style:none;width:100%;background:none;border:none;text-align:left;}
.acc__head span:first-child{font-family:'Schibsted Grotesk';font-weight:800;font-size:17px;color:var(--ink);}
.acc__plus{flex:none;width:30px;height:30px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:18px;transition:transform .3s var(--ease);}
.acc.is-open .acc__plus{transform:rotate(45deg);}
.acc__panel{margin:0;padding:0 24px;list-style:none;display:flex;flex-direction:column;gap:12px;max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s var(--ease);}
.acc.is-open .acc__panel{padding:0 24px 22px 24px;}
.acc__panel li{display:flex;gap:11px;font-size:14.5px;color:var(--muted);line-height:1.55;}
.acc__panel li .bullet{flex:none;width:7px;height:7px;border-radius:50%;background:var(--brand);margin-top:7px;}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .grid-2{grid-template-columns:1fr !important;}
  .staff__grid{grid-template-columns:1fr;}
  .fear{grid-template-columns:1fr;}
  .community{grid-template-columns:1fr;gap:34px;}
  .contact-grid{grid-template-columns:1fr;}
  .team-grid--2{grid-template-columns:1fr;}
  .prof-hero{grid-template-columns:1fr;gap:30px;}
  .disc-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:860px){
  .grid-3{grid-template-columns:1fr;}
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .team-grid--3,.team-grid--4{grid-template-columns:repeat(2,1fr);}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px;}
  .gallery>*{grid-column:span 1 !important;grid-row:span 1 !important;}
  .gcell--main{grid-column:1 / -1 !important;grid-row:span 2 !important;}
}
@media (max-width:760px){
  .nav{display:none !important;}
  .burger{display:flex;}
  .hero{padding-top:116px !important;}
  .pagehero{padding-top:128px !important;}
  .mobilebar{display:flex;}
  .form__row{grid-template-columns:1fr;}
  .disc-grid{grid-template-columns:1fr;}
  .card--wide{grid-template-columns:130px 1fr;}
}
@media (max-width:520px){
  .grid-4{grid-template-columns:1fr;}
  .team-grid--3,.team-grid--4{grid-template-columns:1fr;}
  .gallery{grid-template-columns:1fr;grid-auto-rows:200px;}
  .gcell--main{grid-row:span 1 !important;}
}

/* reduced motion: nessuna animazione, contenuti subito visibili */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;}
  [data-reveal]{opacity:1 !important;transform:none !important;transition:none !important;}
  .aurora__blob,.aurora__blob2,.aurora__wash{transition:none !important;}
}
