/* =====================================================================
   ORDINE ETERNO G∴M∴M∴ — Armando Ventura
   Aesthetic: "GRIMORIO LUMINOSO" — illuminated esoteric editorial.
   Obsidian vellum · gold leaf · inscriptional capitals · sacred geometry.
   ===================================================================== */

:root{
  /* --- indigo/viola vellum (notte profonda, viola percepibile) --- */
  --void:#0a0819;
  --ink0:#0e0b24;
  --ink1:#15113a;
  --ink2:#1f1850;
  /* scrim viola scuro: aree scure leggibili ma con tinta viola, non nere */
  --scrim:14,10,42;
  /* --- gold leaf --- */
  --gold:#c9a24a;
  --gold-hi:#f0dfa6;
  --gold-lo:#7c5f22;
  --foil:linear-gradient(104deg,#f4e7bd 0%,#d8b45c 34%,#9a7526 66%,#e6cf86 100%);
  /* --- moonlit ink (freddo, notturno) --- */
  --bone:#ece7f5;
  --bone-dim:#b6b0d0;
  --bone-faint:#807aa0;
  --amethyst:#7d66cf;
  --line:rgba(201,162,74,.24);
  --line-2:rgba(201,162,74,.12);
  --hair:rgba(236,231,245,.10);

  --f-display:"Fraunces",Georgia,serif;      /* statements, characterful */
  --f-serif:"Cormorant Garamond",Georgia,serif; /* flowing accents, quotes */
  --f-label:"Cinzel",Georgia,serif;          /* ritual capitals */
  --f-body:"Jost","Segoe UI",system-ui,sans-serif;

  --wrap:1220px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-slow:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;font-family:var(--f-body);color:var(--bone);background:var(--void);
  font-weight:300;line-height:1.72;letter-spacing:.15px;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
html,body{max-width:100%;overflow-x:clip}

/* layered warm cosmos + vignette */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1150px 700px at 82% -8%, rgba(126,102,214,.48), transparent 62%),
    radial-gradient(900px 680px at 2% 16%, rgba(104,84,196,.30), transparent 60%),
    radial-gradient(720px 600px at 24% 6%, rgba(201,162,74,.08), transparent 58%),
    radial-gradient(1250px 950px at 50% 116%, rgba(96,74,182,.34), transparent 64%),
    radial-gradient(150% 130% at 50% 42%, transparent 44%, rgba(5,4,16,.6) 100%),
    linear-gradient(180deg,var(--void),var(--ink0) 46%,var(--void));
}
/* parchment grain */
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.055;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:rgba(201,162,74,.28);color:#fff}
/* scrollbar tematizzata (coerenza col tema, no stile nativo) */
*{scrollbar-width:thin;scrollbar-color:var(--gold-lo) transparent}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:var(--ink0)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--gold-lo),var(--amethyst));border-radius:8px;border:2px solid var(--ink0)}
::-webkit-scrollbar-thumb:hover{background:var(--gold)}

/* ---------- form contatti (tematizzato) ---------- */
.form{display:grid;gap:1.2rem}
.form label{font-family:var(--f-label);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-faint);display:block;margin-bottom:.5rem}
.form input,.form textarea{
  width:100%;font-family:var(--f-body);font-size:1rem;color:var(--bone);
  background:rgba(20,15,42,.55);border:1px solid var(--line-2);border-radius:6px;
  padding:.9rem 1.05rem;transition:border-color .3s,background .3s,box-shadow .3s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--gold);background:rgba(30,22,62,.65);box-shadow:0 0 0 3px rgba(201,162,74,.16)}
.form input::placeholder,.form textarea::placeholder{color:var(--bone-faint)}
.form input:user-invalid,.form textarea:user-invalid{border-color:rgba(214,120,120,.6)}
.form textarea{resize:vertical;min-height:8.5rem;line-height:1.6}
.form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.form__status{font-family:var(--f-body);font-size:.94rem;min-height:1.3rem;margin:0}
.form__status.ok{color:var(--gold-hi)}
.form__status.err{color:#e7a6a6}
.form button[type=submit]{width:100%;justify-content:center}
.form button[disabled]{opacity:.6;cursor:progress}
:focus-visible{outline:2px solid var(--gold-hi);outline-offset:3px;border-radius:2px}

/* ---------- layout ---------- */
.wrap{width:min(var(--wrap),90vw);margin-inline:auto}
.section{padding:clamp(4.5rem,10vw,8.5rem) 0;position:relative}
.section--tight{padding:clamp(3rem,7vw,5rem) 0}
.stack>*+*{margin-top:1.1em}
.rule{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);border:0;margin:0}

/* editorial section header: hanging numeral + label rail */
.head{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.2rem,3vw,2.6rem);align-items:start;margin-bottom:clamp(2rem,5vw,3.6rem)}
.head__idx{font-family:var(--f-label);font-size:clamp(1.4rem,3vw,2.1rem);color:var(--gold);opacity:.5;line-height:1;padding-top:.5rem;letter-spacing:.05em}
.head__idx::after{content:"";display:block;width:1px;height:clamp(30px,6vw,64px);background:linear-gradient(var(--gold),transparent);margin:.9rem auto 0}
.label{font-family:var(--f-label);font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);font-weight:500;display:block;margin-bottom:1.1rem}
.label--line{display:inline-flex;align-items:center;gap:1rem}
.label--line::after{content:"";height:1px;width:clamp(24px,6vw,60px);background:linear-gradient(90deg,var(--gold),transparent)}

h1,h2,h3,h4{font-family:var(--f-display);font-weight:400;line-height:1.04;margin:0;font-optical-sizing:auto}
.d-xl{font-size:clamp(2.9rem,7.4vw,6rem);letter-spacing:-.015em;font-weight:340}
.d-lg{font-size:clamp(2.2rem,4.8vw,3.7rem);letter-spacing:-.01em}
.d-md{font-size:clamp(1.5rem,2.6vw,2.1rem)}
.serif-lead{font-family:var(--f-serif);font-size:clamp(1.3rem,2.4vw,1.75rem);line-height:1.5;color:var(--bone);font-weight:400}
.foil{background:var(--foil);-webkit-background-clip:text;background-clip:text;color:transparent}
.ital{font-family:var(--f-serif);font-style:italic;font-weight:400}
p{margin:0 0 1rem;color:var(--bone-dim)}
.muted{color:var(--bone-faint)}
.big-p{font-size:1.06rem}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;cursor:pointer;position:relative;overflow:hidden;
  font-family:var(--f-label);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
  padding:1.05em 2.1em;border-radius:2px;border:1px solid var(--gold);color:var(--gold-hi);background:transparent;
  transition:color .45s var(--ease),background .45s var(--ease),box-shadow .45s var(--ease),transform .45s var(--ease);
}
.btn::before{content:"";position:absolute;inset:0;background:var(--foil);transform:translateY(101%);transition:transform .5s var(--ease-slow);z-index:-1}
.btn:hover{color:var(--void);border-color:transparent;box-shadow:0 16px 40px -16px rgba(201,162,74,.6);transform:translateY(-2px)}
.btn:hover::before{transform:translateY(0)}
.btn--solid{color:var(--void);border-color:transparent}
.btn--solid::before{transform:translateY(0)}
.btn--solid:hover::before{transform:translateY(0);filter:brightness(1.08)}
.btn--ghost{border-color:var(--hair);color:var(--bone)}
.btn--ghost::before{background:rgba(239,231,213,.08)}
.btn--ghost:hover{color:#fff;box-shadow:none}
.btn--lg{padding:1.2em 2.7em}

/* ---------- corner-tick plate (manuscript frame) ---------- */
.plate{position:relative;border:1px solid var(--line-2)}
.plate::before,.plate::after{content:"";position:absolute;width:15px;height:15px;border:1px solid var(--gold);opacity:.7;transition:opacity .4s}
.plate::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.plate::after{bottom:-1px;right:-1px;border-left:0;border-top:0}

/* ---------- navigation ---------- */
/* header unico fisso: ticker-rail SEMPRE sopra la navbar, mai sovrapposti */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .45s var(--ease),box-shadow .45s var(--ease);
  background:linear-gradient(180deg,rgba(7,6,18,.9),rgba(7,6,18,.35) 70%,transparent)}
.site-header.scrolled{background:rgba(9,8,22,.92);backdrop-filter:blur(16px) saturate(1.2);box-shadow:0 12px 34px -22px #000}
.ticker-rail{
  border-bottom:1px solid var(--line-2);font-family:var(--f-label);font-size:.58rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--bone-faint);
}
.ticker-rail .wrap{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0}
.ticker-rail span{color:var(--gold);opacity:.75}
.nav{
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  padding:1rem clamp(1.1rem,5vw,3rem);transition:padding .45s var(--ease);
}
.site-header.scrolled .nav{padding-block:.65rem}
.brand{display:flex;align-items:center;gap:.75rem}
.brand img{width:36px;height:36px;filter:drop-shadow(0 2px 12px rgba(201,162,74,.5))}
.brand__txt{font-family:var(--f-label);letter-spacing:.15em;font-size:.86rem;color:var(--gold-hi);line-height:1.2}
.brand__txt small{display:block;font-family:var(--f-body);letter-spacing:.34em;font-size:.52rem;color:var(--bone-faint);text-transform:uppercase;margin-top:2px}
@keyframes spin{to{transform:rotate(360deg)}}
.nav-links{display:flex;align-items:center;gap:clamp(1rem,2.1vw,2rem);list-style:none;margin:0;padding:0}
.nav-links a{font-size:.8rem;letter-spacing:.05em;color:var(--bone-dim);position:relative;padding:.3rem 0;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--foil);transition:width .4s var(--ease)}
.nav-links a:hover{color:var(--bone)}.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.9rem}
.nav-toggle{display:none;background:none;border:0;color:var(--gold-hi);cursor:pointer;width:44px;height:44px}
.nav-toggle span{display:block;width:24px;height:1.5px;background:currentColor;margin:5px auto;transition:.35s}
.btn--sm{padding:.72em 1.35em;font-size:.68rem}

/* ---- dropdown / sottovoci (tematizzati, mai stile nativo) ---- */
.nav-top{display:inline-flex;align-items:center;gap:.5rem;background:none;border:0;cursor:pointer;
  font-family:var(--f-body);font-size:.8rem;letter-spacing:.05em;color:var(--bone-dim);padding:.3rem 0;transition:color .3s}
.nav-top:hover,.has-sub.open>.nav-top,.has-sub:hover>.nav-top,.has-sub.is-active>.nav-top{color:var(--bone)}
.caret{width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .35s var(--ease);opacity:.8}
.has-sub.open>.nav-top .caret,.has-sub:hover>.nav-top .caret{transform:rotate(-135deg) translateY(-1px)}
.has-sub>.nav-top::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--foil);transition:width .4s var(--ease)}
.has-sub{position:relative}
.has-sub.is-active>.nav-top{color:var(--gold-hi)}
.subnav{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,10px);min-width:16.5rem;white-space:nowrap;
  list-style:none;margin:0;padding:.6rem;display:grid;gap:.1rem;z-index:120;
  background:rgba(11,10,28,.96);backdrop-filter:blur(18px) saturate(1.2);
  border:1px solid var(--line);border-radius:6px;box-shadow:0 30px 60px -28px rgba(0,0,0,.9);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s}
.subnav::before{content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);width:11px;height:11px;background:inherit;border-left:1px solid var(--line);border-top:1px solid var(--line)}
.has-sub:hover>.subnav,.has-sub:focus-within>.subnav,.has-sub.open>.subnav{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0)}
.subnav a{display:block;padding:.7rem .9rem;border-radius:4px;font-size:.86rem;letter-spacing:.02em;color:var(--bone-dim);transition:background .25s,color .25s}
.subnav a::after{display:none}
.subnav a:hover,.subnav a.is-active{background:linear-gradient(120deg,rgba(90,74,150,.35),rgba(201,162,74,.08));color:var(--bone)}
body.nav-lock{overflow:hidden}

/* ---------- hero ---------- */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;isolation:isolate;padding:8rem 0 4rem}
.hero__media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero__media img,.hero__media video{width:100%;height:100%;object-fit:cover;object-position:70% center;opacity:.30;filter:saturate(.6) contrast(1.05) brightness(.82)}
/* scrim: lato testo (sinistra) molto scuro per garantire la leggibilita */
.hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg, rgba(var(--scrim),.9) 0%, rgba(var(--scrim),.62) 44%, rgba(var(--scrim),.24) 72%, rgba(var(--scrim),.5) 100%),
  radial-gradient(72% 62% at 64% 42%, transparent, rgba(var(--scrim),.45) 74%, var(--void) 100%),
  linear-gradient(180deg,rgba(var(--scrim),.5),transparent 24%,rgba(var(--scrim),.88))}
.hero__seal{position:absolute;z-index:-1;right:clamp(-170px,-5vw,-30px);top:50%;transform:translateY(-50%);
  width:min(44vw,580px);opacity:.42;animation:spin 140s linear infinite;pointer-events:none;
  filter:drop-shadow(0 0 40px rgba(201,162,74,.12))}
.hero__inner{max-width:820px;min-width:0}
.hero .d-xl{margin:.4rem 0 1.5rem}
.hero .serif-lead{max-width:600px;margin-bottom:2.5rem;color:var(--bone-dim)}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero__rail{position:absolute;left:clamp(.6rem,3vw,2rem);top:50%;transform:translateY(-50%) rotate(180deg);writing-mode:vertical-rl;
  font-family:var(--f-label);font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--bone-faint)}
.hero__rail b{color:var(--gold)}
.hero__scroll{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);font-family:var(--f-label);font-size:.58rem;letter-spacing:.34em;text-transform:uppercase;color:var(--bone-faint);display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero__scroll span{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);animation:drop 2.6s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- marquee band ---------- */
.marquee{border-block:1px solid var(--line-2);padding:1.15rem 0;overflow:hidden;white-space:nowrap;-webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee__track{display:inline-flex;gap:2.6rem;animation:slide 46s linear infinite;will-change:transform}
.marquee span{font-family:var(--f-display);font-size:clamp(1.3rem,2.4vw,1.9rem);font-style:italic;color:transparent;-webkit-text-stroke:.6px var(--gold);opacity:.7}
.marquee span::after{content:"✦";-webkit-text-stroke:0;color:var(--gold);margin-left:2.6rem;font-size:.7em;vertical-align:middle;opacity:.6}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- splits ---------- */
.split{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(2rem,6vw,5.5rem);align-items:center}
.split--text-r .split__media{order:-1}
.figure{position:relative}
.figure img{width:100%;object-fit:cover;aspect-ratio:4/5;filter:saturate(.8) contrast(1.03);transition:filter 1s var(--ease),transform 1.4s var(--ease-slow)}
.figure:hover img{filter:saturate(1.05) contrast(1.05);transform:scale(1.04)}
.figure--wide img{aspect-ratio:16/12}
.figure .plate{position:absolute;inset:0;pointer-events:none}
.figure__cap{position:absolute;left:1rem;bottom:1rem;font-family:var(--f-label);font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-hi);background:rgba(8,6,16,.6);backdrop-filter:blur(6px);padding:.5rem .85rem;border:1px solid var(--line)}
.dropcap::first-letter{font-family:var(--f-display);font-size:4.4em;line-height:.72;float:left;padding:.05em .12em 0 0;color:transparent;background:var(--foil);-webkit-background-clip:text;background-clip:text}
.pull{font-family:var(--f-serif);font-style:italic;font-size:1.35rem;line-height:1.5;color:var(--bone);border-left:2px solid var(--gold);padding-left:1.3rem}

/* ---------- mirror motif ---------- */
.mirror{position:relative;border-radius:220px 220px 6px 6px;overflow:hidden;aspect-ratio:3/4.3;
  border:1px solid var(--line);box-shadow:0 40px 100px -44px #000, inset 0 0 70px rgba(90,74,134,.3)}
.mirror img{width:100%;height:100%;object-fit:cover;opacity:.9;filter:saturate(.8) contrast(1.05)}
.mirror::before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(115deg,transparent 32%,rgba(240,223,166,.3) 48%,transparent 56%);transform:translateX(-40%);animation:sheen 7s var(--ease) infinite}
.mirror::after{content:"";position:absolute;inset:0;background:radial-gradient(62% 52% at 50% 44%,transparent,rgba(8,6,16,.42) 76%,rgba(8,6,16,.88))}
.mirror__frame{position:absolute;inset:9px;border:1px solid var(--line);border-radius:210px 210px 3px 3px;z-index:3;pointer-events:none}
@keyframes sheen{0%,100%{transform:translateX(-70%) skewX(-8deg);opacity:0}42%{opacity:1}60%{transform:translateX(70%) skewX(-8deg);opacity:0}}

/* ---------- video (footage reale del Maestro) ---------- */
.videobox{position:relative;border-radius:6px;overflow:hidden;border:1px solid var(--line);box-shadow:0 34px 90px -44px #000;background:#05040e}
.videobox video{width:100%;height:100%;object-fit:cover;display:block}
.videobox::after{content:"";position:absolute;inset:0;pointer-events:none;transition:opacity .5s var(--ease);z-index:2;
  background:linear-gradient(180deg,rgba(11,8,30,.15),transparent 40%,rgba(11,8,30,.55)),radial-gradient(60% 60% at 50% 45%,transparent,rgba(11,8,30,.3))}
.videobox.playing::after{opacity:0}
.videobox__play{position:absolute;inset:0;margin:auto;width:5rem;height:5rem;border-radius:50%;z-index:3;cursor:pointer;
  border:1px solid var(--gold);background:rgba(11,8,30,.5);backdrop-filter:blur(6px);color:var(--gold-hi);
  display:grid;place-items:center;transition:.45s var(--ease);box-shadow:0 0 0 0 rgba(201,162,74,.5)}
.videobox__play svg{width:1.7rem;height:1.7rem;fill:currentColor;margin-left:.2rem}
.videobox__play::before{content:"";position:absolute;inset:-1px;border-radius:50%;border:1px solid var(--line);animation:pulse 2.8s var(--ease) infinite}
.videobox__play:hover{background:var(--foil);color:var(--void);border-color:transparent;transform:scale(1.06)}
.videobox.playing .videobox__play{opacity:0;pointer-events:none;transform:scale(.7)}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.35);opacity:0}100%{opacity:0}}
.videobox .figure__cap{z-index:3}
.videobox--wide{aspect-ratio:16/9}
@media (prefers-reduced-motion:reduce){.videobox__play::before{animation:none}}

/* ---------- numbered index (darsana / pillars) ---------- */
.index{border-top:1px solid var(--line-2)}
.index__row{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.4rem,4vw,3.4rem);padding:clamp(1.6rem,3.6vw,2.6rem) 0;border-bottom:1px solid var(--line-2);align-items:baseline;transition:.5s var(--ease)}
.index__row:hover{background:linear-gradient(90deg,rgba(90,74,134,.14),transparent 70%)}
.index__num{font-family:var(--f-display);font-size:clamp(2rem,4vw,3.1rem);color:transparent;background:var(--foil);-webkit-background-clip:text;background-clip:text;opacity:.85;line-height:1;min-width:2.4ch}
.index__row h3{font-size:clamp(1.4rem,2.4vw,1.9rem);margin-bottom:.5rem}
.index__row p{margin:0;max-width:64ch}

/* ---------- plates grid (cards) ---------- */
.grid{display:grid;gap:clamp(1.2rem,2.6vw,2rem)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{position:relative;padding:2.3rem 2rem;border:1px solid var(--line-2);background:linear-gradient(158deg,rgba(42,32,84,.5),rgba(16,12,36,.42));overflow:hidden;transition:.55s var(--ease)}
.card::before,.card::after{content:"";position:absolute;width:15px;height:15px;border:1px solid var(--gold);opacity:.6;transition:opacity .5s}
.card::before{top:8px;left:8px;border-right:0;border-bottom:0}
.card::after{bottom:8px;right:8px;border-left:0;border-top:0}
.card:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:0 30px 70px -34px rgba(0,0,0,.9),0 0 0 1px var(--line);background:linear-gradient(158deg,rgba(58,44,112,.6),rgba(20,15,42,.5))}
.card:hover::before,.card:hover::after{opacity:1}
.card__mk{font-family:var(--f-label);color:var(--gold);letter-spacing:.16em;font-size:.82rem;opacity:.8}
.card h3{margin:.75rem 0 .7rem;font-size:1.42rem}
.card p{margin:0;font-size:.98rem}
.card__icon{width:44px;height:44px;margin-bottom:1.1rem;color:var(--gold-hi)}
.card__icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1}
.card--link{display:flex;flex-direction:column}
.card--link .card__go{margin-top:auto;padding-top:1.3rem;font-family:var(--f-label);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-hi);transition:letter-spacing .4s var(--ease)}
.card--link:hover .card__go{letter-spacing:.28em}
.center{text-align:center}
.vision .card{text-align:center;padding-block:2.7rem}
.vision .card__icon{margin-inline:auto}

/* pull quote block */
.creed{text-align:center;max-width:940px;margin-inline:auto}
.creed q{font-family:var(--f-display);font-size:clamp(1.7rem,3.6vw,2.7rem);line-height:1.28;font-weight:340;quotes:none}
.creed cite{display:block;margin-top:1.4rem;font-family:var(--f-label);font-style:normal;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}

/* ---------- method list (percorso) ---------- */
.mlist{list-style:none;padding:0;margin:.9rem 0 0;font-size:.98rem;color:var(--bone-dim)}
.mlist li{padding:.55rem 0;border-bottom:1px dashed var(--line-2);display:flex;gap:.7rem;align-items:baseline}
.mlist li::before{content:"✦";color:var(--gold);font-size:.6em;opacity:.65;flex:none}
.mlist li:last-child{border:0}
.mlist b{color:var(--bone);font-weight:400;font-family:var(--f-label);letter-spacing:.02em}

/* ---------- roles ---------- */
.roles{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.4vw,1.6rem)}
.role{border:1px solid var(--line-2);padding:2rem 1.9rem;background:rgba(12,10,21,.4);transition:.45s var(--ease)}
.role:hover{border-color:var(--line);transform:translateY(-4px)}
.role h3{font-size:1.28rem;margin:0 0 .9rem;color:var(--gold-hi);font-family:var(--f-display)}
.role ul{list-style:none;padding:0;margin:0;font-size:.95rem;color:var(--bone-dim)}
.role li{padding:.4rem 0;border-bottom:1px dashed var(--line-2);display:flex;gap:.6rem}
.role li::before{content:"✦";color:var(--gold);font-size:.6em;opacity:.6;margin-top:.35em}
.role li:last-child{border:0}

/* ---------- posts ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.6vw,2rem)}
.post{position:relative;border:1px solid var(--line-2);background:var(--ink0);display:flex;flex-direction:column;transition:.55s var(--ease);overflow:hidden}
.post:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:0 30px 66px -34px #000}
.post__img{aspect-ratio:16/10;overflow:hidden;position:relative}
.post__img img{width:100%;height:100%;object-fit:cover;filter:saturate(.7) contrast(1.02) brightness(.9);transition:.9s var(--ease-slow)}
.post:hover .post__img img{transform:scale(1.06);filter:saturate(1) contrast(1.04) brightness(1)}
.post__img--empty{display:grid;place-items:center;background:radial-gradient(circle at 50% 42%,rgba(90,74,134,.4),var(--ink0));color:var(--gold);font-size:2rem;opacity:.55}
.post__n{position:absolute;top:.8rem;left:.9rem;font-family:var(--f-label);font-size:.62rem;letter-spacing:.2em;color:var(--gold-hi);background:rgba(8,6,16,.6);padding:.3rem .55rem;border:1px solid var(--line)}
.post__body{padding:1.5rem 1.6rem 1.8rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.post__meta{font-family:var(--f-label);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.post h3{font-size:1.3rem;line-height:1.16}
.post p{font-size:.92rem;margin:0;color:var(--bone-faint);flex:1}
.post__more{font-family:var(--f-label);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-hi);margin-top:.4rem}

/* ---------- contact ---------- */
.contact{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,6vw,4.5rem);align-items:center}
.contact__list{list-style:none;padding:0;margin:1.7rem 0 0;display:grid;gap:1.2rem}
.contact__list li{display:flex;gap:1rem;align-items:flex-start}
.contact__list svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.2;flex:none;margin-top:3px}
.contact__list b{display:block;font-family:var(--f-label);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-faint);font-weight:500;margin-bottom:2px}
.contact__panel{position:relative;padding:2.8rem 2.4rem;border:1px solid var(--line);background:linear-gradient(158deg,rgba(25,20,40,.55),rgba(12,10,21,.6));text-align:center;box-shadow:0 40px 90px -44px #000}
.contact__panel .seal-sm{width:64px;margin:0 auto 1rem;opacity:.7;animation:spin 90s linear infinite}

/* ---------- article ---------- */
.article-hero{padding:9.5rem 0 2.5rem;text-align:center;position:relative}
.article-hero .d-lg{max-width:940px;margin:1rem auto 1.1rem}
.article__meta{font-family:var(--f-label);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold)}
.article-body{width:min(760px,92vw);margin:2.4rem auto 0;font-size:1.1rem;font-family:var(--f-serif);line-height:1.62}
.article-body p{color:var(--bone-dim);margin:0 0 1.3rem;font-size:1.18rem}
.article-body h2,.article-body h3{font-family:var(--f-display);color:var(--gold-hi);margin:2.4rem 0 .8rem;font-size:1.6rem;font-weight:400}
.article-body>p:first-of-type::first-letter{font-family:var(--f-display);font-size:3.6em;line-height:.72;float:left;padding:.06em .1em 0 0;color:transparent;background:var(--foil);-webkit-background-clip:text;background-clip:text}
.article-body img{margin:2.2rem auto;border:1px solid var(--line)}
.article-body .subtitle{font-family:var(--f-serif);font-style:italic;font-size:1.35rem;color:var(--bone);border-left:2px solid var(--gold);padding-left:1.3rem;margin-bottom:2.2rem}
.back-link{display:inline-flex;gap:.5rem;align-items:center;font-family:var(--f-label);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.6rem}

/* ---------- footer / colophon ---------- */
.footer{border-top:1px solid var(--line-2);padding:clamp(3.4rem,7vw,5rem) 0 2rem;margin-top:2rem;position:relative}
.footer__seal{width:74px;margin:0 auto 2.4rem;opacity:.6;animation:spin 100s linear infinite;display:block}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2.6rem}
.footer h4{font-family:var(--f-label);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem;font-weight:500}
.footer a{color:var(--bone-dim);font-size:.9rem;display:block;padding:.28rem 0;transition:color .3s}
.footer a:hover{color:var(--gold-hi)}
.footer__brand p{font-size:.94rem;max-width:38ch;font-family:var(--f-serif);font-size:1.05rem}
.footer__bottom{margin-top:3rem;padding-top:1.6rem;border-top:1px solid var(--line-2);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.76rem;color:var(--bone-faint);font-family:var(--f-label);letter-spacing:.1em}
.social{display:flex;gap:.8rem;margin-top:1.3rem}
.social a{width:40px;height:40px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;color:var(--gold);transition:.45s var(--ease)}
.social a:hover{background:var(--foil);color:var(--void);border-color:transparent;transform:translateY(-3px)}
.social svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.4}

/* ---------- ancore sotto la nav fissa (evita sovrapposizioni in lettura) ---------- */
:root{--nav-h:6.4rem}
[id]{scroll-margin-top:var(--nav-h)}

/* ---------- page header (pagine interne) ---------- */
.page-hero{position:relative;padding:calc(var(--nav-h) + clamp(2rem,5vw,4rem)) 0 clamp(2.5rem,6vw,4.5rem);isolation:isolate;overflow:hidden}
.page-hero__media{position:absolute;inset:0;z-index:-1;overflow:hidden}
.page-hero__media img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.18;filter:saturate(.55) contrast(1.04) brightness(.8)}
.page-hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(var(--scrim),.8),rgba(var(--scrim),.48) 40%,var(--void) 88%),
  linear-gradient(90deg,rgba(var(--scrim),.78),transparent 62%)}
.page-hero__inner{max-width:820px;position:relative}
.page-crumbs{font-family:var(--f-label);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bone-faint);margin-bottom:1.5rem;display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.page-crumbs a{color:var(--gold)}.page-crumbs a:hover{color:var(--gold-hi)}
.page-crumbs span{opacity:.5}
.page-hero .d-xl,.page-hero .d-lg{margin:.4rem 0 0}
.page-lead{font-family:var(--f-serif);font-size:clamp(1.25rem,2.3vw,1.65rem);line-height:1.5;color:var(--bone-dim);max-width:62ch;margin-top:1.3rem}
.page-hero__idx{position:absolute;right:0;top:calc(var(--nav-h) + 1rem);font-family:var(--f-display);font-size:clamp(4rem,14vw,11rem);line-height:.8;color:transparent;background:var(--foil);-webkit-background-clip:text;background-clip:text;opacity:.12;z-index:-1;pointer-events:none}

/* ---------- CTA band (fondo pagina) ---------- */
.cta-band{text-align:center;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);position:relative}
.cta-band .seal-sm{width:60px;margin:0 auto 1.2rem;opacity:.6;animation:spin 100s linear infinite}
.cta-band h2{margin-bottom:1.4rem}
.cta-band .btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}

/* prossimi passi / link correlati */
.next-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,15rem),1fr));gap:1rem;margin-top:2.5rem}
.next-links a{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.3rem 1.5rem;border:1px solid var(--line-2);border-radius:6px;transition:.4s var(--ease);font-family:var(--f-label);letter-spacing:.04em;font-size:.9rem;color:var(--bone-dim)}
.next-links a:hover{border-color:var(--line);color:var(--bone);transform:translateY(-3px);background:linear-gradient(120deg,rgba(90,74,150,.16),transparent)}
.next-links a::after{content:"→";color:var(--gold)}

/* ---------- reveal ---------- */
.gsap [data-reveal]{transition:none !important}
html.js [data-reveal]{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease-slow),transform 1s var(--ease-slow)}
html.js [data-reveal].in{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}[data-delay="3"]{transition-delay:.3s}[data-delay="4"]{transition-delay:.4s}
html.shot .hero{min-height:820px}
html.shot .hero__scroll{display:none}
@media (prefers-reduced-motion:reduce){html.js [data-reveal]{opacity:1;transform:none}.mirror::before,.hero__scroll span,.marquee__track,.brand img,.footer__seal,.hero__seal,.contact__panel .seal-sm{animation:none}}

/* ---------- responsive ---------- */
@media (max-width:1240px){ .hero__rail{display:none} }
@media (max-width:1024px){
  .g3,.posts,.roles{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:960px){
  .split,.contact{grid-template-columns:1fr}
  /* su mobile: sempre testo/titolo prima, media dopo (ordine di lettura corretto) */
  .split>.stack{order:0}
  .split>.split__media{order:1}
  .page-hero__idx{display:none}
  .hero__seal{opacity:.22;right:-40%;width:min(72vw,480px)}
  .nav-cta .btn--sm{display:none}
  .nav-toggle{display:block}
  .nav-main{position:static}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(360px,86vw);flex-direction:column;align-items:stretch;
    justify-content:flex-start;gap:.2rem;overflow-y:auto;overscroll-behavior:contain;
    background:rgba(9,8,22,.98);backdrop-filter:blur(20px);padding:calc(var(--nav-h) + 1rem) 1.6rem 2rem;
    transform:translateX(100%);transition:transform .5s var(--ease);border-left:1px solid var(--line);
    box-shadow:-30px 0 80px -30px #000}
  .nav-links.open{transform:none}
  .nav-links>li{border-bottom:1px solid var(--line-2)}
  .nav-links>li>a{display:block;padding:1.1rem .2rem;font-size:1.12rem;font-family:var(--f-label);letter-spacing:.06em;color:var(--bone)}
  .has-sub{position:static;width:100%}
  .nav-top{width:100%;justify-content:space-between;padding:1.1rem .2rem;font-size:1.12rem;font-family:var(--f-label);letter-spacing:.06em;color:var(--bone)}
  .nav-top::after{display:none}
  .subnav{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;display:none;
    min-width:0;white-space:normal;background:none;border:0;box-shadow:none;backdrop-filter:none;padding:0 0 .8rem 1.1rem;
    border-left:1px solid var(--line-2);margin:0 0 .4rem}
  .subnav::before{display:none}
  /* override del dropdown desktop (piu specifico): niente translate su mobile */
  .has-sub.open>.subnav,.has-sub:hover>.subnav,.has-sub:focus-within>.subnav{transform:none;left:auto}
  .has-sub.open>.subnav{display:grid}
  .subnav a{font-size:1rem;padding:.6rem .7rem}
  .nav.open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav.open .nav-toggle span:nth-child(2){opacity:0}
  .nav.open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}
@media (max-width:600px){
  .g3,.posts,.roles,.footer__grid,.vision.g3{grid-template-columns:1fr}
  .head{grid-template-columns:1fr;gap:.6rem}
  .head__idx{display:flex;align-items:center;gap:1rem;padding-top:0}
  .head__idx::after{height:1px;width:40px;margin:0}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{justify-content:center}
  .d-xl{font-size:clamp(2.3rem,10vw,3.2rem)}
  .ticker-rail .wrap span:nth-child(2){display:none}
  .index__row{grid-template-columns:auto 1fr;gap:1rem}
  .stack,.split>*,.contact>*{min-width:0}
}
