/* ===== MIROO v6 ===== */
:root{
  --bg:#000000;
  --fg:#ffffff;
  --muted:#666660;
  --line:rgba(255,255,255,.1);
  --lime:oklch(0.92 0.22 128);
  --ease:cubic-bezier(.7,0,.2,1);
  --pad:clamp(18px,3.4vw,40px);
  --font:"Kinetika","Plus Jakarta Sans",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  scrollbar-width:none;-ms-overflow-style:none}
html::-webkit-scrollbar,body::-webkit-scrollbar{width:0;height:0;display:none}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font);
  font-size:16px;line-height:1.4;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
::selection{background:#fff;color:#000}
img{display:block;max-width:100%}

.display{font-family:var(--font);font-weight:800;letter-spacing:-.02em;line-height:.84;text-transform:uppercase}
.serif{font-family:var(--font);font-style:italic;font-weight:400}

@media (hover:hover) and (pointer:fine){ *{cursor:none} }

/* ===== CURSOR ===== */
.cursor{position:fixed;top:0;left:0;width:11px;height:11px;border-radius:50%;
  background:#fff;mix-blend-mode:difference;z-index:9000;pointer-events:none;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease)}
.cursor.is-big{width:80px;height:80px}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ===== LOADER ===== */
.loader{position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;align-items:center;justify-content:center}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:28px}
.loader__logo{
  width:min(46vw,360px);height:calc(min(46vw,360px)/5);
  background:var(--lime);
  -webkit-mask:url("../assets/logo-miroo.png") center/contain no-repeat;
  mask:url("../assets/logo-miroo.png") center/contain no-repeat;
}
.loader__pct{font-size:clamp(36px,7vw,72px);font-weight:700;line-height:1}
.loader.is-done{transform:translateY(-101%);transition:transform 1s var(--ease)}

/* ===== NAV ===== */
.nav{position:fixed;top:0;left:0;width:100%;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);mix-blend-mode:difference;color:#fff}
.nav__logo{
  display:block;width:92px;height:20px;
  background:currentColor;
  -webkit-mask:url("../assets/logo-miroo.png") center/contain no-repeat;
  mask:url("../assets/logo-miroo.png") center/contain no-repeat;
}
.nav__menu{background:none;border:none;color:inherit;font-family:inherit;
  font-size:15px;font-weight:600;letter-spacing:.01em}

/* ===== OVERLAY MENU ===== */
.overlay{position:fixed;inset:0;z-index:480;background:var(--bg);color:var(--fg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:80px var(--pad);clip-path:inset(0 0 100% 0);
  transition:clip-path .85s var(--ease);pointer-events:none}
.overlay.is-open{clip-path:inset(0 0 0% 0);pointer-events:auto}
.overlay__nav{list-style:none;display:flex;flex-direction:column;align-items:center;
  width:100%;max-width:1200px}
.overlay__item{position:relative}
.overlay__item a{display:flex;align-items:center;justify-content:center;
  transition:opacity .35s var(--ease)}
.overlay__big{font-family:var(--font);font-weight:800;text-transform:uppercase;
  letter-spacing:-.02em;line-height:.92;font-size:clamp(46px,8.5vw,128px);
  display:block;
  transition:opacity .35s,transform .5s var(--ease)}
.overlay__item a:hover .overlay__big{opacity:.4}
.overlay__big{opacity:0;transform:translateY(40%)}
.overlay.is-open .overlay__big{opacity:1;transform:none;
  transition:opacity .6s var(--ease),transform .7s var(--ease)}
.overlay.is-open .overlay__item:nth-child(1) .overlay__big{transition-delay:.18s}
.overlay.is-open .overlay__item:nth-child(2) .overlay__big{transition-delay:.24s}
.overlay.is-open .overlay__item:nth-child(3) .overlay__big{transition-delay:.30s}
.overlay.is-open .overlay__item:nth-child(4) .overlay__big{transition-delay:.36s}
.overlay__foot{position:absolute;left:0;bottom:0;width:100%;
  display:flex;justify-content:space-between;padding:24px var(--pad);
  font-size:14px;font-weight:600}
.overlay__foot a{transition:opacity .3s}
@media(max-width:720px){.overlay__big{font-size:clamp(40px,13vw,80px)}}

/* ===== ROLL LINK (scroll-from-bottom hover) ===== */
.roll-link{
  position:relative;
  display:inline-block;
  overflow:hidden;
  vertical-align:bottom;
}
.roll-link > span{
  display:block;
  transition:transform .5s var(--ease);
  will-change:transform;
}
.roll-link::before{
  content:attr(data-text);
  position:absolute;
  top:100%;
  left:0;
  width:100%;
  transition:transform .5s var(--ease);
  will-change:transform;
}
/* triggered directly */
.roll-link:hover > span{ transform:translateY(-100%) }
.roll-link:hover::before{ transform:translateY(-100%) }
/* triggered by parent hover (overlay items, footer cols) */
a:hover .roll-link > span{ transform:translateY(-100%) }
a:hover .roll-link::before{ transform:translateY(-100%) }

/* ===== HERO ===== */
.hero{min-height:100svh;display:flex;align-items:center;justify-content:center;
  padding:90px var(--pad) 40px;position:relative;overflow:hidden}
/* full-bleed background photo that slides up & fades out on scroll */
.hero__bg{position:absolute;inset:0;z-index:0;
  background:#000 url("../assets/hero-bg.jpg") center/cover no-repeat;
  will-change:transform,opacity}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.5),rgba(0,0,0,.32) 42%,rgba(0,0,0,.78))}
.hero__grid{position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:flex-start;
  width:100%;max-width:1400px}
.hero__line{font-family:var(--font);font-weight:800;
  text-transform:uppercase;letter-spacing:-.02em;line-height:.9;
  font-size:clamp(44px,11vw,160px);display:block}
.hero__more{color:var(--lime)}

/* ===== HERO SCROLL CUE ===== */
.hero__cue{position:absolute;left:50%;bottom:clamp(18px,3.2vh,36px);transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--fg);opacity:.85}
.hero__cue-arrow{font-size:16px;line-height:1;display:block;
  animation:cueBob 1.7s var(--ease) infinite}
@keyframes cueBob{
  0%{transform:translateY(-4px);opacity:.35}
  50%{transform:translateY(5px);opacity:1}
  100%{transform:translateY(-4px);opacity:.35}
}
@media(max-width:720px){.hero__cue{font-size:10px;letter-spacing:.18em}}

/* ===== KINETIC + EXPANDING MEDIA ===== */
.kinetic{position:relative;height:420vh}
.kinetic__pin{position:sticky;top:0;height:100vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;padding:0 var(--pad)}
.kinetic__title{font-family:var(--font);font-weight:800;text-transform:uppercase;
  letter-spacing:-.02em;line-height:.82;text-align:center;
  font-size:clamp(60px,16vw,240px);display:flex;flex-direction:column;position:relative;z-index:1}
.kinetic__word{display:block;overflow:hidden}
.expand{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:clamp(90px,11vw,190px);height:clamp(70px,8.6vw,150px);
  overflow:hidden;z-index:2;will-change:width,height;background:#111}
.expand__img{display:block;width:100%;height:100%;
  background:url("../assets/expand.jpg") center/cover no-repeat;
  transform:scale(1.05);will-change:transform}
.no-js .expand,.kinetic.is-static .expand{position:relative;top:auto;left:auto;transform:none;margin:40px auto 0}

/* dark scrim over the fullscreen image so the caption is readable */
.kinetic__scrim{position:absolute;inset:0;z-index:4;background:#000;opacity:0;pointer-events:none}

/* caption that reveals word-by-word once the image fills the screen */
.kinetic__caption{position:absolute;top:0;left:0;width:100%;height:100%;z-index:5;
  display:flex;align-items:center;justify-content:center;padding:5vh var(--pad);pointer-events:none}
.kinetic__caption-text{font-family:var(--font);font-style:italic;font-weight:400;
  font-size:clamp(18px,2.4vw,30px);line-height:1.38;text-align:center;max-width:min(640px,92vw)}
.kinetic__caption-text .w{display:inline-block;opacity:0;margin-right:.26em}
.kinetic.is-static .kinetic__caption{position:static;width:auto;height:auto;padding:6vh 0}
.no-js .kinetic__caption-text .w,.kinetic.is-static .kinetic__caption-text .w{opacity:1}

/* ===== SERVICES (accordion: hover/tap apre la descrizione inline) ===== */
.services{padding:2vh var(--pad) 12vh;position:relative}
.services__list{display:flex;flex-direction:column;align-items:stretch;text-align:center;
  max-width:1100px;margin:0 auto}
.service{position:relative}
.sv-line{
  font-family:var(--font);font-weight:800;text-transform:uppercase;letter-spacing:-.02em;
  line-height:.9;font-size:clamp(30px,6vw,82px);
  display:inline-flex;align-items:center;justify-content:center;gap:.12em;
  width:100%;background:none;border:0;padding:.16em 0;margin:0;cursor:pointer;color:inherit;
  transition:color .3s var(--ease)}
.sv-line::after{content:"+";font-size:.42em;font-weight:700;opacity:.45;display:inline-block;
  transition:transform .4s var(--ease),opacity .3s var(--ease),color .3s var(--ease)}
.service:hover .sv-line,.service.is-open .sv-line{color:var(--lime)}
.service:hover .sv-line::after,.service.is-open .sv-line::after{opacity:1;color:var(--lime);transform:rotate(45deg)}
/* expanding panel (grid 0fr -> 1fr anima fino all'altezza reale del contenuto) */
.sv-panel{display:grid;grid-template-rows:0fr;opacity:0;
  transition:grid-template-rows .55s var(--ease),opacity .45s var(--ease)}
.service:hover .sv-panel,.service.is-open .sv-panel{grid-template-rows:1fr;opacity:1}
.sv-panel__clip{overflow:hidden;min-height:0}
.sv-panel__content{max-width:600px;margin:0 auto;padding:6px var(--pad) 30px;
  text-transform:none;letter-spacing:normal;font-weight:400}
.sv-panel__desc{font-size:clamp(15px,1.6vw,18px);line-height:1.5;color:rgba(255,255,255,.82)}
.sv-panel__list{list-style:none;margin-top:16px;display:flex;flex-direction:column;gap:9px;text-align:left}
.sv-panel__list li{position:relative;padding-left:22px;font-size:clamp(14px,1.4vw,16px);
  line-height:1.45;color:rgba(255,255,255,.78)}
.sv-panel__list li::before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;
  background:var(--lime);border-radius:2px}

/* ===== STATEMENT ===== */
.statement{padding:12vh var(--pad) 2vh;text-align:center;display:flex;flex-direction:column;
  align-items:center;gap:30px}
.statement__text{font-family:var(--font);font-style:italic;font-weight:400;
  font-size:clamp(28px,4.6vw,68px);line-height:1.08;max-width:22ch}
.statement__link{font-size:13px;letter-spacing:.02em;color:var(--muted);
  border-bottom:1px solid var(--muted);padding-bottom:3px}

/* ===== CTA ===== */
.cta{background:var(--bg);color:var(--fg);
  padding:18vh var(--pad);text-align:center;display:flex;flex-direction:column;
  align-items:center;gap:40px;border-top:1px solid var(--line)}
.cta__text{font-family:var(--font);font-style:italic;font-weight:400;
  font-size:clamp(28px,4.4vw,64px);line-height:1.1;max-width:20ch}
.cta__link{font-size:13px;letter-spacing:.02em;color:rgba(255,255,255,.5);
  border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:3px}
.cta__link::before{ color:var(--fg) }

/* ===== FOOTER ===== */
.footer{background:var(--bg);color:var(--fg);padding:40px var(--pad) 24px;
  min-height:100vh;display:flex;flex-direction:column;border-top:1px solid var(--line);
  overflow-x:clip}
.footer__top{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;
  max-width:760px;margin-right:auto}
.footer__label{display:block;font-size:13px;font-weight:600;opacity:.4;margin-bottom:14px;
  letter-spacing:.04em;text-transform:uppercase}
.footer__col a{display:block;font-size:14px;font-weight:600;line-height:1.7}
/* giant wordmark, pushed toward the bottom, overflowing ~5% past each viewport edge */
.footer__wordmark{display:flex;align-items:flex-end;
  width:110vw;margin-left:calc(50% - 55vw);margin-top:auto;padding-top:12vh;line-height:0}
.fw-letter{flex:1 1 0;height:30vw;overflow:hidden;position:relative}
/* each slice masks one fifth of the same wordmark and rises from below */
.fw-slice{position:absolute;inset:0;background:var(--lime);
  -webkit-mask-image:url("../assets/logo-miroo.png");mask-image:url("../assets/logo-miroo.png");
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  -webkit-mask-size:500% auto;mask-size:500% auto;
  -webkit-mask-position:calc(var(--i) * 25%) center;mask-position:calc(var(--i) * 25%) center;
  transform:translateY(115%);
  transition:transform 1s var(--ease)}
.footer__wordmark.is-in .fw-slice{transform:translateY(0)}
.footer__wordmark.is-in .fw-letter:nth-child(1) .fw-slice{transition-delay:.05s}
.footer__wordmark.is-in .fw-letter:nth-child(2) .fw-slice{transition-delay:.14s}
.footer__wordmark.is-in .fw-letter:nth-child(3) .fw-slice{transition-delay:.23s}
.footer__wordmark.is-in .fw-letter:nth-child(4) .fw-slice{transition-delay:.32s}
.footer__wordmark.is-in .fw-letter:nth-child(5) .fw-slice{transition-delay:.41s}
.footer__bottom{display:flex;justify-content:space-between;font-size:13px;font-weight:600;
  flex-wrap:wrap;gap:8px;padding-top:20px}
@media(max-width:720px){
  .footer__top{grid-template-columns:1fr;gap:24px}
  .footer__wordmark{width:116vw;margin-left:calc(50% - 58vw)}
  .fw-letter{height:40vw}
}

/* ===== reveals ===== */
.reveal{opacity:0;transform:translateY(42px);
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
.kinetic__word>span{display:inline-block}

.no-js .reveal{opacity:1;transform:none}
.no-js .fw-slice{transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .loader{display:none}
  .reveal{opacity:1;transform:none}
  .fw-slice{transform:none}
  .kinetic__caption-text .w{opacity:1}
}
