@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@100;200;300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

:root{
  --leo-black:#0a220a;--leo-green:#00b800;--leo-lime:#9bff00;
  --tan:#cac4ba;--off-white:#f5f3e9;--white:#ffffff;
  --starlight:#faf8d4;
  --pure-black:#0d0d0d;
  --apple:#ff4133;--sunset:#ff8e14;--mint:#9cfcd3;--sky:#b8f1ff;--sunlight:#ffe872;
  /* TEMA SCURO (default): sfondo NERO neutro, testo off-white */
  --bg:var(--pure-black);--ink:var(--off-white);--ink-dim:rgba(245,243,233,.55);
  --line:rgba(245,243,233,.14);--accent:var(--leo-lime);
  --accent-text:var(--leo-lime);   /* verde accento leggibile per sezione/eyebrow */
  --title-accent:var(--ink);       /* colore dei titoloni: normale su scuro */
  --header-bg:rgba(13,13,13,.85);--veil-rgb:13,13,13;
  /* superficie elevata (modali, thumbnail): nero appena schiarito, stessa tinta */
  --surface:color-mix(in srgb, var(--pure-black) 90%, #ffffff 10%);
  --display-weight:400;
  --display:"Montserrat",-apple-system,system-ui,sans-serif;
  --body:"Montserrat",-apple-system,system-ui,sans-serif;
  --util:"DM Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
/* TEMA CHIARO (Off-White): sfondo off-white, testo nero — scelto dal CMS.
   Rimappo off-white/white su nero così tutti i testi restano leggibili. */
body.theme-cream{
  --bg:#f5f3e9;--ink:#0d0d0d;--ink-dim:rgba(13,13,13,.6);
  --line:rgba(13,13,13,.16);--off-white:#0d0d0d;--white:#0d0d0d;
  --header-bg:rgba(245,243,233,.9);--veil-rgb:245,243,233;
  --accent-text:#006400;   /* verde scuro leggibile su off-white */
  --title-accent:#006400;  /* titoloni in verde scuro brand sul tema beige */
  --surface:color-mix(in srgb, #f5f3e9 90%, #0d0d0d 10%);
}
/* Font Thin: scelto dal CMS */
body.font-thin{--display-weight:200}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--leo-lime);color:var(--leo-black)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{display:block}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important}}

header{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:20px 34px;border-bottom:1px solid transparent;transition:background .35s var(--ease),border-color .35s}
.logo{height:34px;width:auto}
nav.main{display:flex;gap:30px;align-items:center}
nav.main a{font-family:var(--util);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--off-white);position:relative;padding:5px 0;text-shadow:0 1px 8px rgba(0,0,0,.45)}
nav.main a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--leo-lime);transition:width .4s var(--ease)}
nav.main a:hover::after,nav.main a.active::after{width:100%}
body.scrolled header,body.solid header{background:var(--header-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom-color:var(--line)}
body.scrolled nav.main a,body.solid nav.main a{text-shadow:none}
@media(max-width:760px){nav.main{gap:18px}nav.main a{font-size:11px}.logo{height:28px}header{padding:16px 20px}}

#app{position:relative;width:100%;height:100vh;height:100svh;overflow:hidden}
.slider{position:absolute;inset:0;z-index:1;overflow:hidden}
.slide{position:absolute;inset:0;clip-path:inset(0 100% 0 0);transition:clip-path 1s var(--ease)}
.slide.active{clip-path:inset(0 0 0 0);z-index:2}
.slide.prev{clip-path:inset(0 0 0 100%);z-index:1}
.slide .media{position:absolute;inset:0;transform:scale(1.08);transition:transform 1.4s var(--ease)}
.slide.active .media{transform:scale(1)}
.slide a.media-link{position:absolute;inset:0;z-index:3;display:block}
.slide video,.slide .media img,.slide .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.slide .ph{background:linear-gradient(135deg,var(--surface),#000)}
.slide .veil{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(to top,rgba(13,13,13,.8) 0%,rgba(13,13,13,.04) 44%,rgba(13,13,13,.42) 100%)}

.slide-meta{position:absolute;left:34px;right:34px;bottom:120px;z-index:4;max-width:980px;pointer-events:none}
.slide-meta>*{pointer-events:auto}
.slide-meta .eyebrow{font-family:var(--util);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--leo-lime);margin-bottom:16px;opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease) .15s,transform .7s var(--ease) .15s}
.titlelogo{max-width:min(46vw,540px);max-height:24vh;width:auto;height:auto;filter:drop-shadow(0 4px 24px rgba(0,0,0,.5));opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease) .25s,transform .8s var(--ease) .25s}
.slide-meta h2{font-family:var(--display);font-weight:var(--display-weight);letter-spacing:-.03em;font-size:clamp(38px,6.4vw,98px);line-height:.94;color:#fff;overflow-wrap:break-word;hyphens:none;text-wrap:balance;opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease) .25s,transform .8s var(--ease) .25s}
.slide-meta .client{margin-top:18px;font-family:var(--util);font-size:13px;letter-spacing:.04em;color:#f5f3e9;opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease) .4s,transform .7s var(--ease) .4s}
.slide-meta .client b{color:var(--leo-lime)}
.slide-meta .viewwork{pointer-events:auto;display:inline-flex;align-items:center;gap:11px;margin-top:26px;font-family:var(--util);font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:11px 20px;border:1.5px solid var(--leo-lime);border-radius:2px;color:var(--leo-lime);opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease) .5s,transform .7s var(--ease) .5s,background .3s,color .3s}
.slide-meta .viewwork:hover{background:var(--leo-lime);color:var(--leo-black)}
.slide-meta .viewwork svg{width:15px;transition:transform .35s var(--ease)}
.slide-meta .viewwork:hover svg{transform:translateX(5px)}
.slide.active .eyebrow,.slide.active .titlelogo,.slide.active h2,.slide.active .client,.slide.active .viewwork{opacity:1;transform:none}
@media(max-width:760px){.slide-meta{left:20px;right:20px;bottom:128px}.titlelogo{max-width:80vw}}

.dots{position:fixed;right:34px;top:50%;transform:translateY(-50%);z-index:30;display:flex;flex-direction:column;gap:13px;transition:opacity .4s var(--ease),visibility .4s}
.dots button{width:8px;height:8px;border-radius:50%;border:1.5px solid rgba(245,243,233,.45);transition:all .4s var(--ease)}
.dots button.on{background:var(--leo-lime);border-color:var(--leo-lime);transform:scale(1.4)}
@media(max-width:760px){.dots{right:14px;gap:10px}}

.ticker{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;align-items:center;justify-content:space-between;padding:18px 34px;font-family:var(--util);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);border-top:1px solid var(--line);background:rgba(var(--veil-rgb),.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:opacity .4s var(--ease),visibility .4s}
.ticker .count b{color:var(--off-white)}
.ticker .now{display:flex;gap:9px;align-items:center;max-width:50vw;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.ticker .now em{color:var(--leo-lime);font-style:normal;animation:blink 2s steps(2) infinite}
@keyframes blink{50%{opacity:.3}}
.scrollhint{display:flex;align-items:center;gap:11px}
.scrollhint .bar{width:42px;height:1.5px;background:rgba(245,243,233,.25);position:relative;overflow:hidden}
.scrollhint .bar::after{content:"";position:absolute;inset:0;background:var(--leo-lime);animation:sweep 2.4s var(--ease) infinite}
@keyframes sweep{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}
@media(max-width:760px){.ticker{padding:13px 18px;font-size:11px}.scrollhint{display:none}}

.to-portfolio{position:fixed;left:50%;bottom:72px;transform:translateX(-50%);z-index:25;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--off-white);font-family:var(--util);font-size:11px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:opacity .4s var(--ease),visibility .4s}
.to-portfolio svg{width:18px;animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
@media(max-width:760px){.to-portfolio{display:none}}
body.scrolled .dots,body.scrolled .ticker,body.scrolled .to-portfolio{opacity:0;visibility:hidden}

#intro{position:fixed;inset:0;z-index:90;background:#0d0d0d;display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease),visibility .6s;overflow:hidden}
#intro.intro-cream{background:#f5f3e9}
#introStars{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:0;transition:opacity 1s var(--ease)}
#intro.stars-on #introStars{opacity:1}
.intro-logo-wrap{z-index:2}
#intro.hide{opacity:0;visibility:hidden}
#intro.skip{display:none}
.intro-logo-wrap{position:relative;height:clamp(88px,17vw,190px);opacity:0;transform:scale(.94);animation:introIn .7s var(--ease) forwards}
@keyframes introIn{to{opacity:1;transform:none}}
.intro-logo-wrap .siglogo{height:100%;width:auto;display:block}
.intro-logo-wrap .fill{position:absolute;inset:0;height:100%;
  /* il logo verde si svela dal basso verso l'alto */
  clip-path:inset(100% 0 0 0);transition:clip-path 1.1s var(--ease) .25s}
#intro.go .intro-logo-wrap .fill{clip-path:inset(0 0 0 0)}
#intro .barwrap,#intro .barfill,#intro .pct{display:none}

.portfolio{position:relative;z-index:20;background:var(--bg);border-top:1px solid var(--line);padding:90px 34px 120px}
.portfolio-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;max-width:1320px;margin:0 auto 38px;flex-wrap:wrap}
.portfolio-head .ttl{font-family:var(--display);font-weight:var(--display-weight);letter-spacing:-.03em;font-size:clamp(32px,4.6vw,60px);color:var(--white);line-height:.96;text-wrap:balance}
.portfolio-head .sub{font-family:var(--util);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}
.filters{display:flex;gap:8px;flex-wrap:wrap;max-width:1320px;margin:0 auto 30px}
.filter{font-family:var(--util);font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:9px 15px;border:1px solid var(--line);border-radius:2px;color:var(--ink-dim);transition:all .25s var(--ease);background:transparent;cursor:pointer}
.filter:hover{border-color:var(--off-white);color:var(--off-white)}
.filter.active{background:var(--leo-lime);color:var(--leo-black);border-color:var(--leo-lime)}
.grid-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;max-width:1320px;margin:0 auto}
.grid-tile{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:4/3;background:var(--surface);display:block;cursor:pointer}
.grid-tile img,.grid-tile video{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .5s var(--ease);filter:saturate(.92)}
.grid-tile:hover img,.grid-tile:hover video{transform:scale(1.06);filter:saturate(1.08)}
.grid-tile .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,13,13,.92) 0%,rgba(13,13,13,.12) 56%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:22px}
.grid-tile .ov .cl{font-family:var(--util);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--leo-lime);margin-bottom:6px}
.grid-tile .ov .tt{font-family:var(--display);font-weight:var(--display-weight);font-size:20px;color:#f5f3e9;line-height:1.15;text-wrap:balance}
.grid-tile .ov .go{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;border:1.5px solid rgba(245,243,233,.3);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.7);transition:all .4s var(--ease);color:var(--leo-lime)}
.grid-tile:hover .ov .go{opacity:1;transform:none;border-color:var(--leo-lime)}
.grid-tile .ph2{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--surface);font-family:var(--util);font-size:12px;letter-spacing:.16em;color:rgba(245,243,233,.3);text-transform:uppercase}
@media(max-width:760px){.portfolio{padding:60px 20px 90px}.grid-tiles{grid-template-columns:1fr 1fr;gap:12px}}
@media(max-width:460px){.grid-tiles{grid-template-columns:1fr}}

.project-hero{position:relative;width:100%;height:84vh;height:84svh;overflow:hidden}
.project-hero .media,.project-hero .media video,.project-hero .media img,.project-hero .media picture,.project-hero .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.project-hero .media picture img{position:static;width:100%;height:100%;object-fit:cover}
.project-hero .ph{background:linear-gradient(135deg,var(--surface),#000)}
.project-hero .veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,13,13,.88) 0%,rgba(13,13,13,.1) 50%,rgba(13,13,13,.5) 100%)}
.project-hero .ph-logo{position:absolute;left:34px;bottom:38px;max-width:min(46vw,520px);max-height:22vh;width:auto;height:auto;z-index:2;filter:drop-shadow(0 4px 24px rgba(0,0,0,.5))}
img.ph-logo{display:block}
picture.ph-logo{display:inline-block;line-height:0}
picture.ph-logo img{position:static;display:block;width:auto;height:auto;max-width:min(46vw,520px);max-height:22vh}
@media(max-width:760px){.project-hero{height:64svh}.project-hero .ph-logo{left:20px;right:20px;max-width:78vw}.project-hero picture.ph-logo img{max-width:78vw}}

.project-body{max-width:1100px;margin:0 auto;padding:64px 34px 40px}
.project-back{font-family:var(--util);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);display:inline-flex;align-items:center;gap:8px;margin-bottom:34px;transition:color .25s}
.project-back:hover{color:var(--leo-lime)}
.project-back svg{width:16px}
.project-eyebrow{font-family:var(--util);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-text);margin-bottom:16px}
.project-title{font-family:var(--display);font-weight:var(--display-weight);letter-spacing:-.035em;line-height:.95;font-size:clamp(40px,7vw,104px);color:var(--white);text-wrap:balance;overflow-wrap:break-word}
.project-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:50px;margin-top:48px}
@media(max-width:820px){.project-grid{grid-template-columns:1fr;gap:30px}}
.project-grid .lead{font-size:clamp(17px,2.1vw,22px);line-height:1.6;color:var(--off-white)}
.project-meta{border-left:1px solid var(--line);padding-left:26px}
.project-meta .row{margin-bottom:22px}
.project-meta .k{font-family:var(--util);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:6px}
.project-meta .v{font-size:15px;color:var(--off-white);line-height:1.5}
.project-meta .v a{color:var(--leo-lime)}
.project-cta{display:inline-flex;align-items:center;gap:10px;margin-top:6px;font-family:var(--util);font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:12px 22px;border-radius:2px;background:var(--leo-lime);color:var(--leo-black);transition:filter .25s}
.project-cta:hover{filter:brightness(1.08)}
.project-gallery{max-width:1100px;margin:20px auto 0;padding:0 34px;display:flex;flex-wrap:wrap;gap:22px;align-items:flex-start;justify-content:center}
.project-gallery .g{border-radius:6px;overflow:hidden;background:var(--surface)}
.project-gallery .g img,.project-gallery .g video{width:100%;height:auto;display:block}
.project-gallery .g video{background:#000}
/* 4 dimensioni scelte nel CMS. small/medium possono affiancarsi (flex-wrap);
   large/full occupano la riga intera. Il gap è 22px → uso calc per le metà. */
.project-gallery .g.size-small{width:min(100%,300px)}
.project-gallery .g.size-medium{width:calc(50% - 11px);min-width:280px}
.project-gallery .g.size-large{width:min(100%,760px)}
.project-gallery .g.size-full{width:100%}
/* le verticali, a parità di size, limitano l'altezza e si centrano */
.project-gallery .g.portrait img,.project-gallery .g.portrait video{max-height:82vh;width:auto;max-width:100%;margin:0 auto}
@media(max-width:680px){
  .project-gallery{gap:16px}
  .project-gallery .g.size-small,.project-gallery .g.size-medium,.project-gallery .g.size-large{width:100%;min-width:0}
}
/* hero quando è un video player: niente cover che taglia i controlli */
.project-hero.is-player{height:auto;max-height:84svh;background:#000;display:flex;align-items:center;justify-content:center}
.project-hero.is-player .media{position:relative}
.project-hero.is-player .media video{position:relative;width:100%;height:auto;max-height:84svh;object-fit:contain}
.related{max-width:1320px;margin:90px auto 0;padding:0 34px 110px}
.related h2{font-family:var(--display);font-weight:var(--display-weight);font-size:clamp(24px,3vw,38px);letter-spacing:-.02em;color:var(--white);margin-bottom:30px;text-wrap:balance}
.related .related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}

body.page{overflow-y:auto}
.page-wrap{max-width:1180px;margin:0 auto;padding:140px 34px 120px;position:relative;z-index:2}
@media(max-width:760px){.page-wrap{padding:110px 20px 90px}}
.page-eyebrow{font-family:var(--util);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-text);margin-bottom:20px}
.page-title{font-family:var(--display);font-weight:var(--display-weight);letter-spacing:-.04em;line-height:.95;font-size:clamp(46px,8.5vw,120px);color:var(--title-accent);text-wrap:balance;overflow-wrap:break-word}
.page-lead{font-size:clamp(18px,2.3vw,26px);line-height:1.5;color:var(--off-white);max-width:760px;margin-top:28px}
.about-cols{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:64px}
@media(max-width:820px){.about-cols{grid-template-columns:1fr;gap:38px}}
.about-cols h2{font-family:var(--display);font-weight:var(--display-weight);font-size:30px;letter-spacing:-.02em;color:var(--white);margin-bottom:18px}
.about-cols p{font-size:16px;line-height:1.7;color:var(--off-white);margin-bottom:16px}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:72px}
@media(max-width:680px){.stat-row{grid-template-columns:1fr;gap:14px}}
.stat{border:1px solid var(--line);border-radius:6px;padding:30px 26px}
.stat .n{font-family:var(--display);font-weight:var(--display-weight);font-size:clamp(38px,5vw,60px);color:var(--accent-text);letter-spacing:-.03em;line-height:1}
.stat .l{font-family:var(--util);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);margin-top:12px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:60px}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.contact-block h3{font-family:var(--util);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-text);margin-bottom:16px}
.contact-block .big{font-family:var(--display);font-weight:var(--display-weight);font-size:clamp(24px,3vw,38px);letter-spacing:-.02em;color:var(--off-white);line-height:1.25}
.contact-block .big a:hover{color:var(--leo-lime)}
.contact-block address{font-style:normal;font-size:16px;line-height:1.7;color:var(--off-white)}
.social-row{display:flex;gap:14px;margin-top:24px;flex-wrap:wrap}
.social-row a{font-family:var(--util);font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:10px 16px;border:1px solid var(--line);border-radius:2px;transition:all .25s var(--ease)}
.social-row a:hover{border-color:var(--leo-lime);color:var(--leo-lime)}
.site-footer{border-top:1px solid var(--line);padding:26px 34px;position:relative;z-index:2}
.site-footer .footer-line{display:flex;align-items:center;gap:28px;flex-wrap:wrap;
  max-width:1600px;margin:0 auto}
.site-footer .footer-logo{height:24px;width:auto;flex-shrink:0}
.footer-legal{display:flex;gap:20px;flex-wrap:wrap;font-family:var(--util);font-size:12px;
  letter-spacing:.03em;color:var(--ink-dim)}
.footer-links{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--util);font-size:11px;
  letter-spacing:.06em;text-transform:uppercase;margin-left:auto}
.footer-links a{color:var(--ink-dim);transition:color .25s var(--ease)}
.footer-links a:hover{color:var(--leo-lime)}
.footer-socials{display:flex;gap:12px;align-items:center;flex-shrink:0}
.footer-socials a{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--off-white);
  transition:all .25s var(--ease)}
.footer-socials a:hover{border-color:var(--leo-lime);color:var(--leo-lime);transform:translateY(-2px)}
.footer-socials svg{width:17px;height:17px}
@media(max-width:980px){.footer-links{margin-left:0}.site-footer .footer-line{gap:18px}}
@media(max-width:680px){.site-footer{padding:24px 20px}}

[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.07s}
[data-reveal][data-delay="2"]{transition-delay:.14s}
[data-reveal][data-delay="3"]{transition-delay:.21s}

.leo-ripple{position:absolute;border-radius:50%;pointer-events:none;background:radial-gradient(circle,rgba(155,255,0,.45) 0%,rgba(155,255,0,0) 70%);transform:scale(0);animation:leoRip .6s var(--ease) forwards;z-index:5}
@keyframes leoRip{to{transform:scale(1);opacity:0}}
.btn:focus-visible,.viewwork:focus-visible,nav.main a:focus-visible,.social-row a:focus-visible,.grid-tile:focus-visible,.filter:focus-visible,.project-cta:focus-visible{outline:2px solid var(--leo-lime);outline-offset:3px;border-radius:2px}

.gate{position:fixed;inset:0;z-index:88;background:var(--bg);display:none;align-items:center;justify-content:center;flex-direction:column;gap:22px}
.gate.open{display:flex}
.gate .siglogo{height:78px;width:auto;margin-bottom:4px}
.gate .tag{font-family:var(--util);font-size:12px;color:var(--ink-dim);letter-spacing:.22em;text-transform:uppercase}
.gate .ip{display:flex;gap:10px}
.gate input{background:transparent;border:1.5px solid var(--line);border-radius:3px;padding:13px 16px;color:var(--ink);font-family:var(--util);letter-spacing:.1em;width:230px}
.gate input:focus{outline:none;border-color:var(--leo-lime)}
.gate .err{color:var(--apple);font-size:12px;height:14px;font-family:var(--util)}
.gate .demo{opacity:.4;font-size:11px;font-family:var(--util);letter-spacing:.08em}
.gate .demo b{color:var(--leo-lime)}
#admin{position:fixed;inset:0;z-index:80;background:var(--bg);overflow-y:auto;display:none}
#admin.open{display:block}
.adm-top{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid var(--line);background:rgba(var(--veil-rgb),.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
.adm-top .brand{display:flex;align-items:center;gap:12px}
.adm-top .brand img{height:26px;width:auto}
.adm-top .brand span{font-family:var(--util);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--leo-lime)}
.adm-actions{display:flex;gap:10px}
.btn{font-family:var(--util);font-size:12px;letter-spacing:.08em;padding:11px 18px;border-radius:2px;transition:all .25s var(--ease);text-transform:uppercase}
.btn-primary{background:var(--leo-lime);color:var(--leo-black)}
.btn-primary:hover{background:var(--leo-green);color:var(--white)}
.btn-ghost{border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--off-white)}
.btn-danger{color:var(--apple);border:1px solid rgba(255,65,51,.35)}
.btn-danger:hover{background:rgba(255,65,51,.12)}
.adm-wrap{max-width:1140px;margin:0 auto;padding:44px 28px 110px}
.adm-head h1{font-family:var(--display);font-weight:var(--display-weight);font-size:38px;letter-spacing:-.03em;color:var(--white)}
.adm-head p{color:var(--ink-dim);font-size:14px;margin-top:10px;max-width:580px;line-height:1.65}
.adm-section-label{font-family:var(--util);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--leo-lime);margin:34px 0 18px;display:flex;align-items:center;gap:14px}
.adm-section-label::after{content:"";flex:1;height:1px;background:var(--line)}
.adm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.work-card{border:1px solid var(--line);border-radius:5px;overflow:hidden;background:rgba(245,243,233,.03);transition:border-color .25s,transform .25s var(--ease)}
.work-card:hover{border-color:rgba(155,255,0,.5);transform:translateY(-3px)}
.work-card .thumb{aspect-ratio:16/10;background:var(--surface);position:relative;overflow:hidden}
.work-card .thumb video,.work-card .thumb img.cov{width:100%;height:100%;object-fit:cover}
.work-card .thumb .tl{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);max-width:70%;max-height:40%;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
.work-card .thumb .empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--util);font-size:12px;color:var(--ink-dim);letter-spacing:.1em}
.work-card .body{padding:15px 16px}
.work-card .body .c{font-family:var(--util);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--leo-lime)}
.work-card .body h3{font-size:16px;font-weight:700;margin-top:7px;color:var(--off-white)}
.work-card .body .row{display:flex;gap:7px;margin-top:15px;flex-wrap:wrap}
.work-card .body .row button{font-family:var(--util);font-size:11px;letter-spacing:.04em;padding:8px 12px;border-radius:2px;border:1px solid var(--line)}
.work-card .body .row button:hover{border-color:var(--off-white)}
.add-card{border:1px dashed var(--line);border-radius:5px;min-height:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--ink-dim);transition:all .25s var(--ease)}
.add-card:hover{border-color:var(--leo-lime);color:var(--leo-lime)}
.add-card .plus{font-size:38px;font-weight:300;line-height:1}
.add-card span{font-family:var(--util);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.modal{position:fixed;inset:0;z-index:85;display:none;align-items:flex-start;justify-content:center;background:rgba(5,16,6,.8);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);overflow-y:auto;padding:40px 20px}
.modal.open{display:flex}
.sheet{background:var(--surface);border:1px solid var(--line);border-radius:7px;width:100%;max-width:680px;padding:34px}
.sheet h2{font-family:var(--display);font-weight:var(--display-weight);font-size:25px;letter-spacing:-.02em;margin-bottom:26px;color:var(--white)}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--util);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:9px}
.field input[type=text],.field textarea{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:3px;padding:12px 14px;color:var(--ink);font-family:var(--body);font-size:14px}
.field textarea{resize:vertical;min-height:80px;line-height:1.55}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--leo-lime)}
.field .hint{font-family:var(--util);font-size:11px;color:var(--ink-dim);margin-top:7px}
.drop{border:1px dashed var(--line);border-radius:4px;padding:22px;text-align:center;color:var(--ink-dim);font-size:13px;transition:all .25s var(--ease);cursor:pointer}
.drop:hover,.drop.over{border-color:var(--leo-lime);color:var(--leo-lime);background:rgba(155,255,0,.04)}
.drop .pv{margin-top:14px}
.drop .pv video,.drop .pv img{max-height:150px;border-radius:3px;width:auto;max-width:100%;margin:0 auto}
.sheet-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:28px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.two{grid-template-columns:1fr}}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(60px);z-index:99;background:var(--leo-lime);color:var(--leo-black);font-family:var(--util);font-size:12px;letter-spacing:.04em;padding:13px 22px;border-radius:3px;opacity:0;transition:all .4s var(--ease)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.page-empty{font-family:var(--util);font-size:13px;color:var(--ink-dim);border:1px dashed var(--line);border-radius:6px;padding:50px 30px;text-align:center;margin-top:40px}

/* CMS — lista galleria + indicatore backend */
.gallery-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;margin-top:14px}
.gallery-list .gitem{position:relative;aspect-ratio:1;border-radius:4px;overflow:hidden;background:var(--surface);border:1px solid var(--line)}
.gallery-list .gitem img,.gallery-list .gitem video{width:100%;height:100%;object-fit:cover}
.gallery-list .gitem .rm{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;
  background:rgba(var(--veil-rgb),.85);color:var(--apple);font-size:14px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,65,51,.4)}
.gallery-list .gitem .rm:hover{background:var(--apple);color:#fff}
.gallery-list .gitem .badge-v{position:absolute;left:4px;bottom:4px;font-family:var(--util);font-size:9px;
  letter-spacing:.1em;background:var(--leo-lime);color:var(--leo-black);padding:2px 5px;border-radius:2px}
.backend-pill{font-family:var(--util);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  padding:6px 11px;border-radius:2px;border:1px solid var(--line);color:var(--ink-dim)}
.backend-pill.on{color:var(--leo-black);background:var(--leo-lime);border-color:var(--leo-lime)}
.backend-pill.off{color:var(--sunset);border-color:rgba(255,142,20,.4)}
.uploading{font-family:var(--util);font-size:11px;color:var(--leo-lime);margin-top:8px;letter-spacing:.06em}

/* CMS — tab e form About/Contact */
.adm-tabs{max-width:1140px;margin:0 auto;padding:24px 28px 0;display:flex;gap:6px;border-bottom:1px solid var(--line)}
.adm-tab{font-family:var(--util);font-size:13px;letter-spacing:.04em;padding:12px 20px;color:var(--ink-dim);
  border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s var(--ease)}
.adm-tab:hover{color:var(--off-white)}
.adm-tab.active{color:var(--leo-lime);border-bottom-color:var(--leo-lime)}
.adm-form{max-width:1140px}
.social-edit-list{display:flex;flex-direction:column;gap:10px}
.social-row-edit{display:grid;grid-template-columns:200px 1fr auto;gap:10px;align-items:center}
.social-row-edit input{background:var(--bg);border:1px solid var(--line);border-radius:3px;
  padding:11px 13px;color:var(--ink);font-family:var(--body);font-size:14px}
.social-row-edit input:focus{outline:none;border-color:var(--leo-lime)}
.social-row-edit .rm-social{width:38px;height:38px;border-radius:3px;border:1px solid rgba(255,65,51,.35);
  color:var(--apple);font-size:18px;display:flex;align-items:center;justify-content:center}
.social-row-edit .rm-social:hover{background:rgba(255,65,51,.12)}
@media(max-width:560px){.social-row-edit{grid-template-columns:1fr;gap:6px}.social-row-edit .rm-social{width:100%}}

/* CMS — pulsante rimuovi media */
.btn-remove-media{margin-top:10px;font-family:var(--util);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;padding:8px 14px;border-radius:2px;border:1px solid rgba(255,65,51,.35);
  color:var(--apple);transition:all .25s var(--ease)}
.btn-remove-media:hover{background:rgba(255,65,51,.12)}

/* ===== COOKIE BANNER + MODALE ===== */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:95;background:rgba(var(--veil-rgb),.97);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:20px 28px;
  animation:cookieUp .5s var(--ease)}
@keyframes cookieUp{from{transform:translateY(100%)}to{transform:none}}
.cookie-banner-inner{max-width:1320px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cookie-text{font-size:13.5px;line-height:1.6;color:var(--off-white);max-width:680px}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn{font-family:var(--util);font-size:12px;letter-spacing:.06em;padding:11px 18px;border-radius:2px;
  transition:all .25s var(--ease);white-space:nowrap}
.cookie-btn.primary{background:var(--leo-lime);color:var(--leo-black)}
.cookie-btn.primary:hover{background:var(--leo-green);color:var(--white)}
.cookie-btn.ghost{border:1px solid var(--line);color:var(--off-white)}
.cookie-btn.ghost:hover{border-color:var(--off-white)}
@media(max-width:680px){.cookie-banner-inner{flex-direction:column;align-items:stretch}.cookie-actions{justify-content:stretch}.cookie-btn{flex:1}}

.cookie-modal{position:fixed;inset:0;z-index:96;background:rgba(5,16,6,.82);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:24px;animation:cookieFade .3s var(--ease)}
@keyframes cookieFade{from{opacity:0}to{opacity:1}}
.cookie-sheet{background:var(--surface);border:1px solid var(--line);border-radius:8px;width:100%;max-width:560px;padding:32px}
.cookie-sheet h2{font-family:var(--display);font-weight:var(--display-weight);font-size:24px;letter-spacing:-.02em;color:var(--white);margin-bottom:12px}
.cookie-intro{font-size:14px;line-height:1.6;color:var(--ink-dim);margin-bottom:22px}
.cookie-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 0;border-top:1px solid var(--line)}
.cookie-row span{display:flex;flex-direction:column;gap:4px}
.cookie-row b{font-size:14px;color:var(--off-white)}
.cookie-row small{font-size:12.5px;color:var(--ink-dim);line-height:1.45}
.cookie-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--leo-lime);flex-shrink:0}
.cookie-row.disabled b{color:var(--ink-dim)}
.cookie-sheet-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}
@media(max-width:560px){.cookie-sheet-foot{flex-direction:column}.cookie-sheet-foot .cookie-btn{width:100%}}

/* ===== PAGINE LEGAL ===== */
.legal-page .legal-body{max-width:760px;margin-top:34px}
.legal-page .legal-body p{font-size:15.5px;line-height:1.75;color:var(--off-white);margin-bottom:16px}
.legal-page .legal-body p:first-child{font-size:18px;color:var(--off-white)}

/* CMS — footer/legal */
.cookie-toggle-field{display:flex;align-items:center;gap:10px;font-family:var(--util);font-size:13px;
  color:var(--off-white);margin:6px 0 10px;cursor:pointer}
.cookie-toggle-field input{width:18px;height:18px;accent-color:var(--leo-lime)}
.legal-warning{background:rgba(255,142,20,.1);border:1px solid rgba(255,142,20,.3);border-radius:6px;
  padding:14px 16px;font-size:13px;line-height:1.5;color:var(--sunset);margin:18px 0}

/* CMS — editor blocchi media unificato */
.media-blocks{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}
.media-block{display:grid;grid-template-columns:96px 1fr auto;gap:14px;align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:10px}
.media-block.is-hero{border-color:var(--leo-lime)}
.media-block .mb-thumb{width:96px;height:64px;border-radius:4px;overflow:hidden;background:var(--surface);position:relative;flex-shrink:0}
.media-block .mb-thumb img,.media-block .mb-thumb video{width:100%;height:100%;object-fit:cover;display:block}
.media-block .mb-badge{position:absolute;top:3px;left:3px;font-family:var(--util);font-size:9px;letter-spacing:.04em;
  padding:2px 6px;border-radius:2px;background:rgba(var(--veil-rgb),.85);color:var(--off-white)}
.media-block.is-hero .mb-badge{background:var(--leo-lime);color:var(--leo-black)}
.media-block .mb-info{min-width:0}
.media-block .mb-info .mb-type{font-family:var(--util);font-size:12px;color:var(--off-white)}
.media-block .mb-info .mb-orient{font-family:var(--util);font-size:11px;color:var(--ink-dim);margin-top:2px}
.media-block .mb-actions{display:flex;gap:4px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.media-block .mb-btn{width:32px;height:32px;border-radius:3px;border:1px solid var(--line);color:var(--off-white);
  display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s var(--ease)}
.media-block .mb-btn:hover{border-color:var(--leo-lime);color:var(--leo-lime)}
.media-block .mb-btn:disabled{opacity:.3;pointer-events:none}
.media-block .mb-btn.poster{width:auto;padding:0 10px;font-family:var(--util);font-size:11px;letter-spacing:.03em}
.media-block .mb-btn.del{border-color:rgba(255,65,51,.35);color:var(--apple)}
.media-block .mb-btn.del:hover{background:rgba(255,65,51,.12)}
.drop-add{cursor:pointer;text-align:center}
@media(max-width:560px){.media-block{grid-template-columns:72px 1fr;gap:10px}.media-block .mb-actions{grid-column:1/-1;justify-content:flex-start}.media-block .mb-thumb{width:72px;height:48px}}

/* CMS — selettore dimensione media */
.mb-size{display:flex;gap:4px;margin-top:8px}
.mb-size-btn{width:26px;height:24px;border-radius:3px;border:1px solid var(--line);background:transparent;
  color:var(--ink-dim);font-family:var(--util);font-size:11px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s var(--ease)}
.mb-size-btn:hover{border-color:var(--leo-lime);color:var(--off-white)}
.mb-size-btn.on{background:var(--leo-lime);border-color:var(--leo-lime);color:var(--leo-black);font-weight:600}

/* CMS — modale scelta frame video */
.sheet-frame{max-width:720px}
.frame-stage{background:#000;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;max-height:54vh}
.frame-stage video{width:100%;max-height:54vh;display:block;object-fit:contain}
.frame-seek{width:100%;margin:14px 0 6px;accent-color:var(--leo-lime);cursor:pointer}
.frame-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.frame-controls .btn{padding:8px 14px;font-size:12px}
.frame-time{font-family:var(--util);font-size:12px;color:var(--ink-dim);margin-left:auto}

/* CMS — scelte Aspetto (tema/font) */
.choice-grid{display:flex;gap:14px;flex-wrap:wrap}
.choice{display:flex;flex-direction:column;align-items:center;gap:10px;min-width:130px;padding:18px 22px;
  background:var(--surface);border:1.5px solid var(--line);border-radius:8px;color:var(--off-white);
  transition:all .2s var(--ease);cursor:pointer}
.choice:hover{border-color:var(--leo-lime)}
.choice.on{border-color:var(--leo-lime);box-shadow:0 0 0 3px rgba(155,255,0,.15)}
.choice-sw{width:42px;height:42px;border-radius:50%}
.choice-tx{font-family:var(--util);font-size:12px;text-align:center;line-height:1.4;color:var(--off-white)}
.choice-tx small{color:var(--ink-dim);font-size:10px}

/* CMS — scelta tema per sezione */
.section-theme-row{display:flex;align-items:center;gap:24px;padding:14px 0;border-bottom:1px solid var(--line)}
.section-theme-row:last-of-type{border-bottom:none}
.section-theme-name{flex:0 0 160px;font-family:var(--display);font-weight:500;font-size:17px;color:var(--off-white)}
.section-theme-name small{display:block;font-family:var(--util);font-size:11px;color:var(--ink-dim);margin-top:2px}
.section-theme-choice{flex:1}
.section-theme-choice .choice{min-width:auto;padding:12px 18px;flex-direction:row;gap:10px}
.section-theme-choice .choice-sw{width:24px;height:24px}

/* About — layout testo + illustrazione palle */
.about-layout{max-width:1500px;margin:0 auto;padding:120px 34px 80px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.about-text{max-width:620px}
.about-title{font-family:var(--display);font-weight:var(--display-weight);letter-spacing:-.03em;line-height:.98;font-size:clamp(40px,5vw,76px);color:var(--title-accent);margin:14px 0 26px;text-wrap:balance}
.about-lead{font-family:var(--display);font-weight:var(--display-weight);font-size:clamp(18px,1.5vw,23px);line-height:1.5;color:var(--ink);margin-bottom:44px;max-width:560px}
.about-section{margin-bottom:38px}
.about-section h2{font-family:var(--display);font-weight:600;font-size:22px;color:var(--ink);margin-bottom:14px;letter-spacing:-.01em}
.about-section p{font-size:15px;line-height:1.6;color:var(--ink-dim);margin-bottom:14px}
.about-art{position:sticky;top:90px;width:100%;will-change:transform}
.apples-stage{position:relative;width:100%}
.apples-stage .apple{position:absolute;will-change:transform;transform:translate(-50%,-50%)}
.apples-stage .apple img{display:block;width:100%;height:auto;pointer-events:none}
@media(max-width:900px){
  .about-layout{grid-template-columns:1fr;gap:30px;padding-top:96px}
  .about-art{position:relative;top:0;order:-1;max-width:460px;margin:0 auto}
}

/* Contact — layout con matita laterale */
.contact-layout{display:grid;grid-template-columns:1fr 0.8fr;gap:40px;align-items:start}
.contact-main{min-width:0}
.contact-art{position:relative;display:flex;align-items:flex-start;justify-content:center;min-height:72vh;overflow:visible}
.contact-art #pencilTrail{position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:2px}
.contact-art #pencilImg{position:relative;z-index:2;width:auto;height:min(50vh,425px);will-change:transform;transform-origin:94% 99%;filter:drop-shadow(0 8px 22px rgba(0,0,0,.18))}
@media(max-width:820px){
  .contact-layout{grid-template-columns:1fr}
  .contact-art{display:none}
}
