/* ============================================================
   Igor Haleta — personal site
   Swiss Modernism 2.0 × Exaggerated Minimalism · strict monochrome
   ============================================================ */

:root{
  --bg:#0A0A0A;
  --surface:#141414;
  --paper:#FAFAFA;
  --ink:#09090B;
  --text:#FFFFFF;
  --muted:#A0A0A0;
  --muted-2:#6B6B6B;
  --line:rgba(255,255,255,.12);
  --line-ink:rgba(9,9,11,.12);
  --accent:#FFFFFF;            /* monochrome: interactive accent is pure white-on-dark / ink-on-light */

  --maxw:1240px;
  --pad:24px;
  --unit:8px;

  --font-display:"Archivo","Space Grotesk",system-ui,sans-serif;
  --font-grotesk:"Space Grotesk",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;

  --ease:cubic-bezier(.16,1,.3,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.nowrap{white-space:nowrap}

.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:10px 16px;z-index:200;border-radius:0 0 4px 0}
.skip-link:focus{left:0}

:focus-visible{outline:2px solid #fff;outline-offset:3px}

/* ---------- shared section bits ---------- */
section{position:relative}
section[id]{scroll-margin-top:84px}   /* land below the sticky nav */
.section__kicker{
  font-family:var(--font-grotesk);
  font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin-bottom:36px;
  display:flex;align-items:center;gap:14px;
}
.section__kicker::before{content:"";width:28px;height:1px;background:var(--muted-2)}

.eyebrow{
  font-family:var(--font-grotesk);
  font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-grotesk);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:15px 28px;border:1px solid transparent;cursor:pointer;
  transition:transform .2s var(--ease),background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
}
.btn--primary{background:#fff;color:#000;border-color:#fff}
.btn--primary:hover{transform:translateY(-2px);background:#e9e9e9}
.btn--ghost{background:transparent;color:#fff;border-color:var(--line)}
.btn--ghost:hover{border-color:#fff;transform:translateY(-2px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(10,10,10,.72);backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__mark{
  font-family:var(--font-display);font-weight:900;font-size:1rem;letter-spacing:-.02em;
  width:34px;height:34px;display:grid;place-items:center;border:1.5px solid #fff;
}
.nav__name{font-family:var(--font-grotesk);font-weight:600;font-size:.95rem}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-family:var(--font-grotesk);font-size:.9rem;color:var(--muted);transition:color .18s}
.nav__links a:hover{color:#fff}
.nav__cta{
  color:#fff!important;border:1px solid var(--line);padding:9px 18px;
  transition:border-color .18s,background .18s,color .18s!important;
}
.nav__cta:hover{background:#fff;color:#000!important;border-color:#fff}

.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:24px;height:2px;background:#fff;transition:.25s var(--ease)}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__mobile{display:none;flex-direction:column;border-top:1px solid var(--line);padding:8px var(--pad) 20px}
.nav__mobile a{font-family:var(--font-grotesk);font-size:1.1rem;padding:14px 0;border-bottom:1px solid var(--line);color:#eaeaea}
.nav__mobile a:last-child{border-bottom:0}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:clamp(48px,8vw,110px) 0 clamp(56px,8vw,120px);overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:center}
.hero__copy{max-width:42ch}
.hero__name{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(3.4rem,11vw,9.5rem);line-height:.9;letter-spacing:-.045em;
  margin:18px 0 22px;text-transform:uppercase;
}
.hero__lead{
  font-family:var(--font-grotesk);font-weight:600;
  font-size:clamp(1.3rem,3.2vw,2.1rem);line-height:1.15;letter-spacing:-.02em;margin-bottom:20px;
}
.hero__lead-rest{font-weight:500;color:#b8b8b8}
.hero__sub{color:#cfcfcf;font-size:1.05rem;line-height:1.65;max-width:48ch;margin-bottom:18px}
.hero__dual{
  font-family:var(--font-grotesk);font-size:.95rem;color:var(--muted);
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:34px;
}
.hero__dual .dot{color:var(--muted-2)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}

.hero__media{position:relative}
.hero__media img{
  width:100%;aspect-ratio:1/1.05;object-fit:cover;object-position:center top;
  filter:grayscale(1) contrast(1.05);
  border:1px solid var(--line);
}

/* ============================================================
   STATS
   ============================================================ */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface)}
.stats__grid{display:grid;grid-template-columns:repeat(6,1fr)}
.stat{padding:38px 22px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.stat:last-child{border-right:0}
.stat__num{font-family:var(--font-display);font-weight:800;font-size:clamp(1.6rem,2.6vw,2.4rem);letter-spacing:-.03em;line-height:1}
.stat__label{font-size:.82rem;color:var(--muted);line-height:1.35}

/* ============================================================
   ABOUT
   ============================================================ */
.about{padding:clamp(64px,9vw,120px) 0}
.about__grid{display:grid;grid-template-columns:1fr 2fr;gap:40px}
.about__lead{font-family:var(--font-grotesk);font-weight:500;font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.3;letter-spacing:-.02em;margin-bottom:26px}
.about__body p{color:#cfcfcf;font-size:1.05rem;line-height:1.7;margin-bottom:18px}
.about__markets{color:var(--muted)!important;font-family:var(--font-grotesk);font-size:.95rem!important}
.about__markets strong{color:#fff;letter-spacing:.04em}

/* ============================================================
   HOW I HELP — scenario router
   ============================================================ */
.help{padding:clamp(64px,9vw,120px) 0;background:var(--paper);color:var(--ink)}
.help .section__kicker{color:var(--muted-2)}
.help .section__kicker::before{background:#bdbdbd}
.help__head{margin-bottom:48px}
.help__intro{font-family:var(--font-grotesk);font-weight:500;font-size:clamp(1.3rem,2.4vw,1.9rem);letter-spacing:-.02em;max-width:24ch}
.help__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-ink);border:1px solid var(--line-ink)}
.card{background:var(--paper);padding:40px;display:flex;flex-direction:column;gap:16px;transition:background .25s var(--ease)}
.card:hover{background:#fff}
.card__index{font-family:var(--font-grotesk);font-weight:700;font-size:.85rem;color:#bdbdbd;letter-spacing:.1em}
.card__title{font-family:var(--font-display);font-weight:800;font-size:1.65rem;line-height:1.05;letter-spacing:-.02em}
.card__title span{display:block;font-size:1rem;font-weight:600;color:var(--muted-2);margin-top:6px;letter-spacing:0}
.card__for,.card__do{font-size:.98rem;line-height:1.6;color:#3a3a3a}
.card__for strong,.card__do strong{color:#000;font-weight:700}
.card__proof{display:flex;flex-direction:column;gap:8px;margin-top:4px;padding-top:18px;border-top:1px solid var(--line-ink)}
.card__proof li{font-size:.9rem;line-height:1.45;color:#3a3a3a;padding-left:18px;position:relative}
.card__proof li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;background:#000}
.card__proof b{color:#000}
.card__cta{margin-top:auto;font-family:var(--font-grotesk);font-weight:600;font-size:.95rem;color:#000;padding-top:12px;transition:gap .2s,opacity .2s}
.card__cta:hover{opacity:.6}

/* ============================================================
   EXPERIENCE timeline
   ============================================================ */
.exp{padding:clamp(64px,9vw,120px) 0}
.timeline{border-top:1px solid var(--line)}
.tl{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:34px 0;border-bottom:1px solid var(--line)}
.tl__date{font-family:var(--font-grotesk);font-weight:600;font-size:.9rem;color:var(--muted)}
.tl__body h3{font-family:var(--font-display);font-weight:700;font-size:1.45rem;letter-spacing:-.01em;line-height:1.15;margin-bottom:10px;display:flex;flex-wrap:wrap;gap:6px 14px;align-items:baseline}
.tl__co{font-family:var(--font-grotesk);font-size:.92rem;font-weight:500;color:var(--muted)}
.tl__body p{color:#cfcfcf;font-size:1rem;line-height:1.65;max-width:62ch}
.exp__edu{margin-top:28px;font-family:var(--font-grotesk);font-size:.95rem;color:var(--muted)}

/* ============================================================
   PROOF STRIP
   ============================================================ */
.proof{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg);padding:26px 0}
.proof__inner{display:flex;flex-wrap:wrap;align-items:center;gap:18px 28px;justify-content:space-between}
.proof__label{font-family:var(--font-grotesk);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);flex-shrink:0}
.proof__list{display:flex;flex-wrap:wrap;gap:18px 22px;flex:1;min-width:0;justify-content:center}
.proof__list li{font-family:var(--font-grotesk);font-weight:600;font-size:.9rem;color:#cfcfcf;letter-spacing:-.005em}
.proof__more{font-family:var(--font-grotesk);font-size:.85rem;color:var(--muted);flex-shrink:0}
.proof__more a{color:var(--muted);transition:color .18s;border-bottom:1px solid transparent}
.proof__more a:hover{color:#fff;border-bottom-color:var(--line)}

/* ============================================================
   PUBLIC PRESENCE — stage + camera
   ============================================================ */
.presence{padding:clamp(64px,9vw,120px) 0;background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.presence__intro{font-family:var(--font-grotesk);font-weight:500;font-size:clamp(1.1rem,1.8vw,1.4rem);color:#cfcfcf;max-width:62ch;margin-bottom:42px;letter-spacing:-.01em}
.presence__sub{font-family:var(--font-grotesk);font-weight:600;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin:8px 0 22px;display:flex;align-items:center;gap:14px}
.presence__sub::before{content:"";width:18px;height:1px;background:var(--muted-2)}
.presence__sub:not(:first-of-type){margin-top:52px}

.stage__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.shot{position:relative;background:#0c0c0c;border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;grid-column:span 2}
.shot--wide{grid-column:span 4}
.shot img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;filter:grayscale(.15) contrast(1.04);transition:filter .35s var(--ease),transform .55s var(--ease)}
.shot:hover img{filter:none;transform:scale(1.02)}
.shot figcaption{padding:14px 16px;font-family:var(--font-grotesk);font-size:.85rem;color:var(--muted);display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--line)}
.shot figcaption b{color:#fff;font-weight:600;letter-spacing:-.005em}

/* Reels — YouTube shorts (vertical, click-to-play) */
.reels__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.reel{background:#0c0c0c;border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s var(--ease),transform .25s var(--ease)}
.reel:hover{border-color:#fff;transform:translateY(-3px)}
.reel__play{position:relative;width:100%;aspect-ratio:9/16;padding:0;border:0;background:#000;cursor:pointer;overflow:hidden}
.reel__poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.05);transition:transform .35s var(--ease),filter .25s var(--ease)}
.reel__play:hover .reel__poster{transform:scale(1.03);filter:none}
.reel__triangle{position:absolute;inset:0;display:grid;place-items:center;font-size:3.5rem;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.6);transition:transform .25s var(--ease)}
.reel__play:hover .reel__triangle{transform:scale(1.1)}
.reel__meta{display:flex;flex-direction:column;gap:4px;padding:18px 20px;border-top:1px solid var(--line)}
.reel__year{font-family:var(--font-display);font-weight:800;font-size:1.15rem;letter-spacing:-.01em;color:#fff}
.reel__title{font-family:var(--font-grotesk);font-size:.85rem;color:var(--muted)}
.reel iframe{width:100%;aspect-ratio:9/16;display:block;border:0}

/* ============================================================
   SIDE PROJECT — Soulmate (softened)
   ============================================================ */
.side{padding:clamp(64px,9vw,120px) 0}
.side__grid{display:grid;grid-template-columns:1.4fr .6fr;gap:48px;align-items:start}
.side__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,2.6vw,2rem);line-height:1.1;letter-spacing:-.02em;margin-bottom:20px}
.side__copy p{color:#cfcfcf;font-size:1rem;line-height:1.7;max-width:58ch;margin-bottom:14px}
.side__note{color:var(--muted)!important;font-family:var(--font-grotesk);font-size:.95rem!important}
.side__facts{border:1px solid var(--line);display:flex;flex-direction:column}
.side__row{display:flex;flex-direction:column;gap:3px;padding:18px 22px;border-bottom:1px solid var(--line);font-family:var(--font-grotesk)}
.side__row:last-child{border-bottom:0}
.side__row span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.side__row b{font-weight:600;font-size:.95rem;color:#ededed;letter-spacing:-.005em}


/* ============================================================
   RECOMMENDATIONS
   ============================================================ */
.recs{padding:clamp(64px,9vw,120px) 0}
.recs__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.rec{background:var(--bg);padding:36px;display:flex;flex-direction:column;gap:22px}
.rec blockquote{font-family:var(--font-grotesk);font-weight:500;font-size:1.12rem;line-height:1.5;letter-spacing:-.01em;color:#ededed}
.rec figcaption{display:flex;flex-direction:column;gap:3px;margin-top:auto}
.rec figcaption strong{font-size:.98rem}
.rec figcaption span{font-size:.85rem;color:var(--muted)}
.recs__more{margin-top:26px;font-family:var(--font-grotesk);font-size:.95rem}
.recs__more a{color:var(--muted);transition:color .18s}
.recs__more a:hover{color:#fff}

/* ============================================================
   PRESS
   ============================================================ */
.press{padding:clamp(56px,8vw,100px) 0;border-top:1px solid var(--line);background:var(--surface)}
.press__grid{display:flex;flex-wrap:wrap;gap:14px}
.press__grid li a{
  font-family:var(--font-grotesk);font-weight:600;font-size:1rem;color:var(--muted);
  border:1px solid var(--line);padding:12px 20px;display:inline-block;transition:.2s var(--ease);
}
.press__grid li a::after{content:" ↗";opacity:.5;font-size:.85em}
.press__grid li a:hover{color:#000;background:#fff;border-color:#fff;transform:translateY(-2px)}
.press__grid li a:hover::after{opacity:.8}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{padding:clamp(80px,12vw,160px) 0;text-align:center}
.contact__title{font-family:var(--font-display);font-weight:900;font-size:clamp(3rem,11vw,8rem);line-height:.95;letter-spacing:-.045em;text-transform:uppercase}
.contact__lead{color:var(--muted);font-family:var(--font-grotesk);margin:18px 0 40px;font-size:1.05rem}
.contact__paths{display:grid;grid-template-columns:repeat(2,minmax(0,360px));gap:18px;justify-content:center;margin-bottom:40px}
.path{border:1px solid var(--line);padding:26px;text-align:left;display:flex;flex-direction:column;gap:8px;transition:.22s var(--ease)}
.path:hover{border-color:#fff;transform:translateY(-3px);background:var(--surface)}
.path__k{font-family:var(--font-grotesk);font-weight:600;font-size:1.05rem}
.path__v{font-size:.9rem;color:var(--muted)}
.contact__email{font-family:var(--font-grotesk)!important}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line);padding:30px 0}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer__name{font-family:var(--font-grotesk);font-size:.9rem;color:var(--muted)}
.footer__social{display:flex;gap:22px;flex-wrap:wrap}
.footer__social a{font-family:var(--font-grotesk);font-size:.9rem;color:var(--muted);transition:color .18s}
.footer__social a:hover{color:#fff}

/* ============================================================
   REVEAL animation
   ============================================================ */
/* Reveal is only hidden once JS has flagged the page (html.reveal-on).
   If JS fails for any reason, content stays fully visible — never a blank section. */
.reveal{transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.reveal-on .reveal{opacity:0;transform:translateY(22px)}
html.reveal-on .reveal.is-in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .stats__grid{grid-template-columns:repeat(3,1fr)}
  .stat:nth-child(3){border-right:0}
  .stat:nth-child(n+4){border-top:1px solid var(--line)}
}
@media (max-width:860px){
  .nav__links{display:none}
  .nav__toggle{display:flex}
  .nav__mobile[data-open="true"]{display:flex}
  .hero__grid{grid-template-columns:1fr;gap:36px}
  .hero__media{order:-1;max-width:300px}
  .about__grid{grid-template-columns:1fr;gap:18px}
  .help__grid{grid-template-columns:1fr}
  .side__grid{grid-template-columns:1fr;gap:32px}
  .stage__grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .shot,.shot--wide{grid-column:span 1}
  .reels__grid{grid-template-columns:1fr;gap:14px}
  .proof__inner{flex-direction:column;align-items:flex-start;gap:12px}
  .proof__list{justify-content:flex-start}
  .recs__grid{grid-template-columns:1fr}
  .tl{grid-template-columns:1fr;gap:8px}
}
@media (max-width:560px){
  :root{--pad:18px}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat{border-right:1px solid var(--line)}
  .stat:nth-child(2n){border-right:0}
  .stat:nth-child(n+3){border-top:1px solid var(--line)}
  .stat:nth-child(3){border-right:1px solid var(--line)}
  .card{padding:28px}
  .contact__paths{grid-template-columns:1fr}
  .hero__actions .btn{flex:1}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .btn,.path,.press__grid li a,.card{transition:none!important}
}
