/* ====== aysa.css ====== */
:root{--bg:#000;--fg:#fff;--accent:#22c55e;--logo:72px;--vh:100vh;--navH:76px}
*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--fg);font:500 15px/1.45 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;overflow-x:hidden}

/* links */
a{color:inherit;text-decoration:none}
a:focus{outline:none}

/* stage */
.stage{position:relative;height:var(--vh);min-height:100svh;overflow:hidden}
.frame{position:absolute;inset:0}
.reel{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000}

/* logo */
.logoBadge{position:fixed;top:10px;left:12px;z-index:10000;pointer-events:none}
.logoImg{height:var(--logo);width:auto;display:block;filter:drop-shadow(0 2px 10px rgba(0,0,0,.55))}
@media (max-width:480px){.logoImg{height:52px}}

/* sound */
.soundToggle{position:absolute;top:12px;right:12px;z-index:9990;display:inline-flex;gap:8px;padding:10px 14px;border:2px solid rgba(255,255,255,.9);border-radius:999px;background:rgba(0,0,0,.45)}
.soundToggle[aria-pressed=true]{border-color:#22c55e}

/* hero overlay */
.heroOverlay{position:absolute;inset:0;z-index:9960;display:grid;place-items:center;padding:12px;text-align:center;text-shadow:0 10px 30px rgba(0,0,0,.7)}
.heroOverlay .t1{display:block;font-weight:900;line-height:.9;font-size:clamp(64px,18vw,150px);text-transform:uppercase}
.heroOverlay .t2{display:block;font-weight:900;font-size:clamp(18px,5.6vw,44px);text-transform:uppercase}
.heroOverlay .t3{display:block;font-family:'Pacifico',cursive;font-size:clamp(72px,22vw,210px)}

/* bottom nav */
.bottomNav{position:fixed;left:0;right:0;bottom:0;z-index:9980;padding:8px 0 calc(10px + env(safe-area-inset-bottom,0));background:linear-gradient(180deg,rgba(0,0,0,0) 0,rgba(0,0,0,.55) 28%,rgba(0,0,0,.92) 100%);min-height:var(--navH)}
.tabs{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding:0 12px;-webkit-overflow-scrolling:touch;overscroll-behavior-inline:contain;scrollbar-width:none;mask-image:linear-gradient(to right,transparent 0,black 24px,black calc(100% - 24px),transparent 100%)}
.tabs::-webkit-scrollbar{display:none}
.tab{flex:0 0 auto;white-space:nowrap;border:1px solid rgba(255,255,255,.55);border-radius:999px;padding:10px 12px;background:rgba(0,0,0,.35);color:#fff;font-size:clamp(12px,3.2vw,14px);line-height:1}
.tab[aria-current=page],.tab.is-active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(34,197,94,.35) inset}

/* snap container */
#snap{height:var(--vh);overflow-y:auto;scroll-snap-type:y mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;background:#0a0a0a;padding-bottom:calc(var(--navH) + env(safe-area-inset-bottom,0));scroll-padding-bottom:calc(var(--navH) + 8px)}
.screen{position:relative;scroll-snap-align:start;scroll-snap-stop:always;padding:32px 16px}
.screen .content{max-width:980px;margin:0 auto;display:flex;flex-direction:column;gap:16px;min-height:calc(var(--vh) - (64px + var(--navH)));padding-bottom:calc(24px + var(--navH) + env(safe-area-inset-bottom,0))}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border:2px solid #fff;border-radius:12px;padding:10px 12px;background:rgba(0,0,0,.38);color:#fff}
.btn.primary{border-color:var(--accent)}

/* caption */
.caption{position:absolute;left:12px;right:12px;z-index:10010;bottom:calc(24px + var(--navH) + env(safe-area-inset-bottom,0))}
.actions{display:flex;gap:8px;justify-content:flex-start}

/* text + cards */
.lede{font-size:18px;line-height:1.5;color:#eee}
.sub{color:#d4d4d4}
.cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px}
.card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px}
.card.span2{grid-column:1/-1}

/* auto hide overlays */
.heroOverlay,.seoOverlay{opacity:1;pointer-events:none;animation:aysaOverlayOut .6s ease-out 5s forwards}
@keyframes aysaOverlayOut{to{opacity:0;transform:translateY(10px)}}

/* hints */
.hintsOverlay{position:absolute;inset:auto 0 calc(var(--navH) + 12px) 0;z-index:9985;display:flex;justify-content:center;gap:14px;pointer-events:none;padding:0 12px}
.hint{display:inline-flex;align-items:center;gap:8px;border:2px solid rgba(255,255,255,.9);border-radius:999px;padding:8px 12px;background:rgba(0,0,0,.45);backdrop-filter:saturate(120%) blur(6px);font-size:13px;color:#fff;animation:hintPop .25s ease-out both}
.hintsOverlay .hint-right::before{content:"→"}.hintsOverlay .hint-left::before{content:"←"}.hintsOverlay .hint-down::before{content:"↓"}
.hintsOverlay.out{animation:hintFade .35s ease-out forwards}
@keyframes hintPop{from{transform:translateY(6px);opacity:0}to{transform:none;opacity:1}}
@keyframes hintFade{to{transform:translateY(6px);opacity:0}}
@media (pointer:fine){.hintsOverlay{display:none}}

/* hero section */
.screen--hero .content{padding-top:calc(env(safe-area-inset-top) + var(--logo) + 24px);padding-bottom:24px}
.h1xxl{font-weight:900;letter-spacing:-0.015em;line-height:1.05;margin:0 0 8px;font-size:clamp(28px,7vw,56px);text-wrap:balance}
.h2lead{font-weight:800;margin:12px 0 12px;font-size:clamp(18px,4.4vw,24px);text-wrap:balance}
.screen--hero .lede{font-size:clamp(16px,4vw,20px);line-height:1.5;max-width:38ch;margin:0 0 16px;opacity:.92}
.cta-group,.screen--hero .actions{display:flex;gap:8px;justify-content:flex-start}
.accent{color:var(--accent)}
.screen--hero .video-overlay h2{display:none}
@media (min-width:768px){.screen--hero .content{padding-top:120px}.h1xxl{font-size:clamp(40px,5vw,72px)}.h2lead{font-size:clamp(20px,2.4vw,28px);margin:14px 0}.screen--hero .lede{font-size:clamp(18px,2vw,20px);max-width:60ch}}
@media (min-width:1200px){.screen--hero .content{padding-top:140px}.h1xxl{font-size:84px}}

/* secondary titles */
.h2xl{font-weight:800;font-size:clamp(24px,6vw,42px);line-height:1.15;margin:0 0 12px;text-wrap:balance}
.screen--plan .content{padding-top:24px}
@media (max-width:480px){.screen--plan .content{padding-top:24px}.h2xl{font-size:clamp(22px,5.6vw,36px);line-height:1.2}}
@media (min-width:992px){.screen--plan .content{padding-top:24px}.h2xl{font-size:48px}}

/* CTA dock */
.dock{position:-webkit-sticky;position:sticky;bottom:calc(var(--navH) + env(safe-area-inset-bottom,0) + 12px);z-index:9991;display:flex;flex-wrap:wrap;gap:12px;margin-top:auto;padding-top:8px;background:none;border-radius:16px;will-change:transform}
@media (max-width:768px){
  .dock--fixed{position:fixed;left:16px;right:16px;bottom:calc(var(--navH) + env(safe-area-inset-bottom,0) + 12px);z-index:9992}
  #snap{padding-bottom:calc(var(--navH) + 120px + env(safe-area-inset-bottom,0));scroll-padding-bottom:calc(var(--navH) + 120px)}
  .screen .content{padding-bottom:calc(48px + var(--navH) + 120px + env(safe-area-inset-bottom,0))}
  .caption{position:absolute;left:12px;right:12px;z-index:10010;bottom:calc(24px + var(--navH) + env(safe-area-inset-bottom,0))}
  .cta-stick{display:none!important}
}

/* desktop tweak */
@media (min-width:992px){
  :root{--navH:76px}
}

/* fade after 5s */
.heroOverlay{opacity:1;animation:aysaOverlayOut .6s ease-out 5s forwards}
@keyframes aysaOverlayOut{to{opacity:0;transform:translateY(10px)}}

/* layering */
.logoBadge{z-index:10000}
.soundToggle{position:absolute;top:calc(12px + env(safe-area-inset-top,0));right:12px;z-index:9990}

/* ensure caption above video */
.caption{position:absolute;left:12px;right:12px;z-index:10010;bottom:calc(24px + var(--navH) + env(safe-area-inset-bottom,0))}
.actions{display:flex;gap:8px;justify-content:flex-start}

/* bottom nav never overlaps content */
@media (max-width:768px){
  .bottomNav{padding-bottom:env(safe-area-inset-bottom,0)}
  #snap{padding-bottom:calc(var(--navH) + 120px + env(safe-area-inset-bottom,0));scroll-padding-bottom:calc(var(--navH) + 120px)}
  .screen .content{padding-bottom:calc(48px + var(--navH) + 120px + env(safe-area-inset-bottom,0))}
}

/* smaller logo on phones */
@media (max-width:480px){:root{--logo:56px}}

/* overlay v3 left/bottom */
.heroOverlay{position:absolute;inset:0;z-index:9960;display:flex;align-items:flex-end;justify-content:flex-start;padding:calc(12px + env(safe-area-inset-top,0)) 16px calc(50px + 24px + var(--navH) + env(safe-area-inset-bottom,0));pointer-events:none}
.heroOverlay .wrap{max-width:min(1000px,92vw);margin:0;text-align:left}
.heroOverlay .t1,.heroOverlay .t2,.heroOverlay .t3{display:block;color:#fff;text-shadow:0 10px 30px rgba(0,0,0,.7)}
.heroOverlay .t1{font-weight:900;line-height:.95;font-size:clamp(58px,16vw,156px);text-transform:uppercase;letter-spacing:-.01em}
.heroOverlay .t2{font-weight:900;line-height:1.08;font-size:clamp(24px,7.3vw,57px);text-transform:uppercase}
.heroOverlay .t3{font-family:'Pacifico',cursive;line-height:1.02;font-size:clamp(48px,13vw,117px)}
.heroOverlay{opacity:1;animation:aysaOverlayOut .6s ease-out 5s forwards}
@keyframes aysaOverlayOut{to{opacity:0;transform:translateY(10px)}}

/* plan screen tweaks */
.screen--plan .h2xl{margin-bottom:8px}
.screen--plan .lede{margin-bottom:12px}
.screen--plan .actions{margin-top:8px;justify-content:flex-start;margin-bottom:8px}

/* screen-3 tidy */
.screen--plan .content{padding-top:24px}
.screen--plan .h2xl{margin:6px 0 6px}
.screen--plan .lede{margin:6px 0 10px}
.screen--plan .cards{gap:12px;margin:0 0 10px}
.screen--plan .card{padding:12px}
.screen--plan .actions.dock{margin-top:8px;justify-content:flex-start}

/* sound toggle icon and color */
.soundToggle{color:#fff}
.soundToggle .lbl{color:#fff}
.soundToggle .ico{display:inline-block;width:22px;height:22px;margin-right:8px;background-repeat:no-repeat;background-size:contain}
.soundToggle[aria-pressed="true"] .ico{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='white'><path d='M3 9v6h4l5 5V4L7 9H3z'/><path d='M14.5 12c0-1.77 1.02-3.29 2.5-4.03v8.06A4.49 4.49 0 0 1 14.5 12z'/><path d='M14.5 3.5v2.03c3.06 1.19 5.19 4.17 5.19 7.47s-2.13 6.28-5.19 7.47V22c4.28-1.3 7.4-5.2 7.4-10s-3.12-8.7-7.4-10z'/></svg>");}
.soundToggle[aria-pressed="false"] .ico{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='white'><path d='M3 9v6h4l5 5V4L7 9H3z'/><path d='M16.5 8l-1.5 1.5L17.5 12l-2.5 2.5L16.5 16l3.5-3.5L16.5 8z'/></svg>");}

/* captions */
video::cue{background:rgba(0,0,0,.55);color:#fff;font-size:1rem;line-height:1.4;border-radius:4px;text-align:left}

/* custom CC box */
.ccBox{position:absolute;z-index:9975;left:12px;right:12px;bottom:calc(var(--navH) + 120px);padding:8px 12px;color:#fff;border-radius:8px;font-size:1rem;line-height:1.4;max-width:80%;text-align:left;background:transparent}

/* avoid overlay/CC overlap on mobile */
@media (max-width:768px){
  #hero .heroOverlay{align-items:flex-start;justify-content:flex-start;padding-top:calc(10vh + env(safe-area-inset-top,0));padding-bottom:0}
  #hero .heroOverlay .wrap{margin-bottom:180px;max-width:86vw}
}

/* sound toggle label */
.soundToggle{display:inline-flex;align-items:center;gap:8px}
.soundToggle .lbl{color:#fff;text-transform:uppercase;font-size:110%;line-height:1}

/* hints full overlay */
.hintWrap{position:absolute;inset:0;z-index:9988;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.8)}
.hintWrap.is-on{display:flex}
.hintWrap .hint{display:flex;gap:16px}
.hintWrap .hint .btn{pointer-events:auto}
@media (min-width:769px){.hintWrap{background:rgba(0,0,0,.6)}}

/* hero overlay anchored to bottom on mobile */
@media (max-width:768px){
  #hero .heroOverlay{display:flex;align-items:flex-end;justify-content:flex-start;padding-top:0;padding-bottom:calc(var(--navH) + 140px)}
  #hero .heroOverlay .wrap{max-width:86vw;margin:0 0 8px 12px;text-align:left;word-wrap:break-word}
}

/* hero end overlay */
#hero .endOverlay{position:absolute;inset:0;z-index:9986;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;backdrop-filter:saturate(120%) blur(1px)}
#hero .endOverlay[hidden]{display:none}
#hero .endOverlay__inner{max-width:92vw;text-align:center;color:#fff}
#hero .endOverlay__title{font-weight:800;font-size:clamp(20px,6vw,40px);margin:0 0 12px}
#hero .endOverlay__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
#hero .endOverlay .btn{pointer-events:auto}

.ccBox.is-on{background:rgba(0,0,0,.55)}

/* LOGO HIGHLIGHT add-on */
.logoBadge{position:fixed}
.logoBadge::after{
  content:"";position:absolute;top:calc(100% - 6px);left:-12px;width:calc(100% + 64px);height:170px;pointer-events:none;z-index:0;
  background:linear-gradient(180deg,rgba(0,0,0,.66) 0%,rgba(0,0,0,.34) 38%,rgba(0,0,0,.14) 62%,rgba(0,0,0,0) 100%);filter:blur(1.2px)}
.logoBadge::before{
  content:"";position:absolute;top:6px;left:calc(100% - 10px);width:240px;height:80%;pointer-events:none;z-index:0;
  background:linear-gradient(90deg,rgba(0,0,0,.32) 0%,rgba(0,0,0,.16) 35%,rgba(0,0,0,.06) 65%,rgba(0,0,0,0) 100%);filter:blur(2px)}
@media (min-width:768px){
  .logoBadge::after{height:190px;left:-16px;width:calc(100% + 80px)}
  .logoBadge::before{width:300px;top:8px}
}

/* FIX LOGO clickable + halo */
.logoBadge{pointer-events:auto}
.logoBadge .logoLink,.logoBadge .logoImg{position:relative;z-index:1;pointer-events:auto}
.logoBadge::after,.logoBadge::before{z-index:0}
@media (max-width:540px){
  .logoBadge{top:calc(8px + env(safe-area-inset-top,0))}
  .logoBadge::after{top:calc(100% - 4px);left:-8px;width:calc(100% + 36px);height:100px;background:linear-gradient(180deg,rgba(0,0,0,.50) 0%,rgba(0,0,0,.22) 42%,rgba(0,0,0,.08) 70%,rgba(0,0,0,0) 100%);filter:blur(.8px)}
  .logoBadge::before{left:calc(100% - 6px);width:130px;height:60%;filter:blur(.9px)}
}

/* Portfolio header */
.screen--portfolio .content{padding-top:calc(env(safe-area-inset-top,0) + var(--logo) + 16px)}
.screen--portfolio .portfolioHeader{margin:8px 0 14px;padding:0 12px}
.screen--portfolio .portfolioHeader .h1xxl{margin:0 0 8px;font-size:clamp(32px,8vw,44px);line-height:1.05}
.screen--portfolio .portfolioHeader .lede{margin:0;font-size:clamp(16px,5vw,22px);line-height:1.35;max-width:36ch}
.screen--portfolio .storiesStrip{margin-top:6px}
@media (min-width:768px){
  .screen--portfolio .content{padding-top:calc(env(safe-area-inset-top,0) + var(--logo) + 24px)}
  .screen--portfolio .portfolioHeader{padding:0}
  .screen--portfolio .portfolioHeader .h1xxl{font-size:clamp(40px,5.2vw,64px)}
  .screen--portfolio .portfolioHeader .lede{font-size:clamp(18px,2.2vw,22px);max-width:60ch}
}

/* ===== FIX: primul screen text după .stage are offset sub logo ===== */
.stage + #snap > .screen:first-child .content{
  padding-top:calc(env(safe-area-inset-top,0) + var(--logo) + 16px);
}
@media (min-width:768px){
  .stage + #snap > .screen:first-child .content{
    padding-top:calc(env(safe-area-inset-top,0) + var(--logo) + 24px);
  }
}

/* Titlu generic .h1xl pentru ecrane text (ex: pillars/cases) */
.h1xl{
  font-weight:900;letter-spacing:-0.015em;line-height:1.05;
  margin:0 0 8px;font-size:clamp(32px,8vw,44px);text-wrap:balance;
}
@media(min-width:768px){
  .h1xl{font-size:clamp(40px,5.2vw,64px)}
}

/* Lede – păstrăm deja .lede global; ne asigurăm de max-width pe text screens */
.screen .content .lede{max-width:60ch}
/* === HARD FIX: offset sub logo pentru primul ecran de text după .stage === */
.stage + #snap > .screen:first-child .content{
  /* logo + spațiu de respirație + safe-area */
  padding-top: calc(var(--logo) + 64px + env(safe-area-inset-top, 0));
}

@media (max-width:540px){
  .stage + #snap > .screen:first-child .content{
    /* pe telefon, un pic mai mult ca logo-ul e mai aproape de margine */
    padding-top: calc(var(--logo) + 84px + env(safe-area-inset-top, 0));
  }
}

/* asigură-te că textul nu intră sub logo nici dacă apare alt screen întâi */
.stage + #snap .screen .content:first-child{
  padding-top: calc(var(--logo) + 64px + env(safe-area-inset-top, 0));
}
