/* =========================================================
   Rising Suns Agency — white-label system  (v2, design-matched)
   Built from extracted RSA design language — see DESIGN-LANGUAGE.md
   Fonts: the EXACT Adobe Typekit faces from risingsunsagency.com,
   self-hosted (aileron + ivypresto-display).
   ========================================================= */

/* ---- Aileron (brand sans) ---- */
@font-face{font-family:"aileron";font-style:normal;font-weight:300;font-display:swap;src:url("/assets/fonts/aileron-300.woff2") format("woff2")}
@font-face{font-family:"aileron";font-style:normal;font-weight:400;font-display:swap;src:url("/assets/fonts/aileron-400.woff2") format("woff2")}
@font-face{font-family:"aileron";font-style:normal;font-weight:600;font-display:swap;src:url("/assets/fonts/aileron-600.woff2") format("woff2")}
@font-face{font-family:"aileron";font-style:normal;font-weight:700;font-display:swap;src:url("/assets/fonts/aileron-700.woff2") format("woff2")}
@font-face{font-family:"aileron";font-style:normal;font-weight:800;font-display:swap;src:url("/assets/fonts/aileron-800.woff2") format("woff2")}
@font-face{font-family:"aileron";font-style:normal;font-weight:900;font-display:swap;src:url("/assets/fonts/aileron-900.woff2") format("woff2")}
/* ---- ivypresto-display (serif accent) — only the thin italic is used on their site ---- */
@font-face{font-family:"ivypresto-display";font-style:italic;font-weight:100 600;font-display:swap;src:url("/assets/fonts/ivypresto-display-100i.woff2") format("woff2")}

:root{
  --dark:#141414;
  --dark-2:#1a1a1a;
  --dark-3:#0f0f0f;
  --cream:#f5f5f5;
  --cream-2:#fafafa;
  --ink:#f5f5f5;          /* text on dark */
  --ink-soft:rgba(245,245,245,.66);
  --ink-faint:rgba(245,245,245,.40);
  --night:#141414;        /* text on cream */
  --night-soft:#5d6c7b;   /* slate muted (their colour) */
  --slate:#758696;
  --yellow:#eba900;
  --yellow-bright:#ffc01f;
  /* playful category-pill colours (their palette) */
  --c-orange:#e57b20;
  --c-verm:#f05124;
  --c-pink:#e9018a;
  --c-blue:#0082f3;
  --c-red:#ea384c;
  --line:rgba(245,245,245,.13);
  --line-strong:rgba(245,245,245,.26);
  --line-night:rgba(20,20,20,.12);
  --radius:12px;
  --radius-sm:10px;
  --maxw:1220px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --pad:clamp(20px,5vw,44px);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--dark);color:var(--ink);
  font-family:"aileron","Helvetica Neue",Helvetica,Arial,sans-serif;
  font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--yellow);color:#141414}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
section{position:relative}
.section{padding-block:clamp(70px,12vw,150px)}
.section--tight{padding-block:clamp(52px,8vw,104px)}

/* dark / cream section system — alternating tone is core to RSA */
.section--light{background:var(--cream);color:var(--night)}
.section--light .lead,.section--light .muted{color:var(--night-soft)}
.section--light .card{background:#fff;border-color:var(--line-night);color:var(--night)}
.section--light .card p{color:var(--night-soft)}
.section--light .steps{background:var(--line-night);border-color:var(--line-night)}
.section--light .step{background:var(--cream)}
.section--light .step p{color:var(--night-soft)}
.section--light .stat__l{color:var(--night-soft)}
.section--light .eyebrow{color:var(--night)}

/* ---------- type (matched to RSA: aileron 400 headings, ivypresto 300 italic accent) ---------- */
h1,h2,h3{margin:0;font-weight:400;line-height:1.28;letter-spacing:0}
.serif{font-family:"ivypresto-display",Georgia,serif;font-weight:300;font-style:italic;letter-spacing:0}
.display{font-size:clamp(2.7rem,5.9vw,5.1rem);font-weight:400;line-height:1.3;letter-spacing:-.005em;color:#fff}
.display .serif{font-weight:300}
.h2{font-size:clamp(2rem,4.6vw,3.6rem);font-weight:600;line-height:1.16}
.h3{font-size:clamp(1.18rem,1.8vw,1.5rem);font-weight:600;letter-spacing:0}
.lead{font-size:clamp(1.06rem,1.4vw,1.3rem);color:var(--ink-soft);font-weight:400;max-width:60ch}
.muted{color:var(--ink-soft)}

/* eyebrow: sentence case w/ a small coloured dot — NOT tracked caps */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:.95rem;font-weight:600;letter-spacing:0;color:var(--ink);
}
.eyebrow::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--yellow);flex:none}
.eyebrow--center{justify-content:center}

/* ---------- buttons : RSA .button-2 style — underlined text link ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  height:auto;padding:0 0 3px;border:0;border-bottom:1.5px solid currentColor;border-radius:0;
  background:none;color:var(--ink);
  font-family:inherit;font-size:18px;font-weight:400;letter-spacing:.5px;cursor:pointer;
  transition:opacity .2s var(--ease);
}
.btn:hover{opacity:.65}
.btn-outline{color:var(--ink)}
.btn-primary{color:var(--yellow);border-bottom-color:var(--yellow)}
.section--light .btn,.section--light .btn-outline{color:var(--night);border-bottom-color:var(--night)}
.section--light .btn-primary{color:#bd8807;border-bottom-color:#bd8807}
.btn-arrow svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.btn:hover .btn-arrow svg{transform:translateX(3px)}
/* nav CTA = yellow-outline pill (their "Contact Us") */
.nav .btn{border:1px solid var(--yellow);border-radius:50px;padding:9px 20px;color:var(--ink);font-size:15px;letter-spacing:.3px}
.nav .btn:hover{background:var(--yellow);color:#161616;opacity:1}

/* ---------- nav ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;display:flex;align-items:center;gap:24px;
  padding:18px var(--pad);transition:background .3s var(--ease),backdrop-filter .3s var(--ease),padding .3s var(--ease),border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-stuck{background:rgba(15,15,15,.8);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom-color:var(--line);padding-block:13px}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__brand img{height:30px;width:auto}
.nav__center{flex:1;display:flex;align-items:center;justify-content:center;gap:30px}
.nav__right{display:flex;align-items:center;gap:20px}
@media(max-width:720px){.nav__center{display:none}}
.nav__link{font-size:17px;font-weight:400;color:var(--ink-soft);transition:color .2s}
.nav__link:hover{color:var(--ink)}
@media(max-width:720px){.nav__link{display:none}}

/* ---------- sunrise glow ---------- */
.glow-sun{position:absolute;z-index:0;pointer-events:none;
  width:min(1100px,120vw);aspect-ratio:1;left:50%;top:42%;transform:translate(-50%,-50%);
  background:radial-gradient(circle, #eba9001f, #eba90000 59%);}

/* ---------- hero (centered, glow, RSA-style) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;isolation:isolate;padding-top:90px}
.hero__inner{position:relative;z-index:2;width:100%;max-width:1000px;margin:0 auto;padding:0 var(--pad)}
.hero .display{margin-inline:auto;max-width:16ch}
.hero .lead{margin:26px auto 0;text-align:center}
.hero__cta{margin-top:38px;display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
/* framed showreel under the hero headline (echoes their video card) */
.hero__reel{position:relative;z-index:2;max-width:1000px;margin:clamp(40px,6vw,68px) auto 0;padding:0 var(--pad)}
.hero__reel-inner{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:#000;aspect-ratio:16/9}
.hero__reel-inner video,.hero__reel-inner img{width:100%;height:100%;object-fit:cover}
.hero__scroll{position:absolute;left:50%;transform:translateX(-50%);bottom:22px;z-index:2;font-size:.8rem;color:var(--ink-faint);display:flex;align-items:center;gap:10px}
.hero__scroll::after{content:"";width:1px;height:26px;background:var(--ink-faint);animation:scrolltick 2.2s var(--ease) infinite}
@keyframes scrolltick{0%,100%{transform:scaleY(.3);transform-origin:top;opacity:.4}50%{transform:scaleY(1);transform-origin:top;opacity:1}}

/* floating talent-style pills in hero */
.float-pills{position:absolute;inset:0;z-index:1;pointer-events:none}
.fpill{position:absolute;display:flex;align-items:center;gap:9px;background:#1c1c1c;border:1px solid var(--line);border-radius:50px;padding:6px 14px 6px 6px;font-size:.82rem;font-weight:600;white-space:nowrap;box-shadow:0 12px 30px rgba(0,0,0,.4);animation:bob 6s var(--ease) infinite}
.fpill img{width:30px;height:30px;border-radius:50%;object-fit:cover}
.fpill i{width:9px;height:9px;border-radius:50%;display:inline-block}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media(max-width:760px){.float-pills{display:none}}

/* ---------- kinetic wordmark marquee ---------- */
.wordmark{overflow:hidden;border-block:1px solid var(--line);padding-block:clamp(14px,2.4vw,26px);background:var(--dark-3)}
.wordmark--light{background:var(--cream-2);border-color:var(--line-night)}
.wordmark__track{display:flex;width:max-content;white-space:nowrap;align-items:center;gap:0;animation:marq 30s linear infinite}
.wordmark:hover .wordmark__track{animation-play-state:paused}
.wordmark__unit{display:inline-flex;align-items:center;gap:.5em;padding-inline:.4em;font-size:clamp(2rem,7vw,5.2rem);font-weight:400;line-height:1;letter-spacing:-.01em}
.wordmark__unit .serif{font-weight:500;color:var(--yellow)}
.wordmark--light .wordmark__unit{color:var(--night)}
.wordmark__dot{color:var(--yellow);font-size:.6em;padding-inline:.3em}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- section head ---------- */
.shead{max-width:780px;margin-bottom:clamp(40px,5vw,64px)}
.shead .h2{margin-top:18px}
.shead .lead{margin-top:20px}
.shead--center{margin-inline:auto;text-align:center}
.shead--center .eyebrow{justify-content:center}

/* ---------- cards ---------- */
.grid{display:grid;gap:18px}
.cap-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.card{background:var(--dark-2);border:1px solid var(--line);border-radius:var(--radius);padding:30px;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.card:hover{transform:translateY(-4px)}
.card__ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:20px;background:rgba(235,169,0,.12);color:var(--yellow)}
.card__ic svg{width:22px;height:22px}
.card h3{margin-bottom:10px}
.card p{margin:0;color:var(--ink-soft);font-size:.98rem}

/* ---------- work gallery (justified mosaic — real shapes, big, edge-to-edge) ---------- */
.gallery-wrap{max-width:1640px;margin:0 auto;padding-inline:clamp(20px,5vw,44px)}
.gallery{display:flex;flex-wrap:wrap;gap:12px}
.tile{flex:0 0 auto;height:320px;position:relative;overflow:hidden;border-radius:var(--radius);background:#0a0a0a;border:1px solid var(--line);cursor:pointer;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.tile:hover{transform:translateY(-4px);border-color:var(--line-strong);z-index:2}
.tile__media{position:absolute;inset:0}
.tile__media img,.tile__media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile__media video{opacity:0;transition:opacity .45s var(--ease)}
.tile.is-playing video{opacity:1}
.tile.is-playing .tile__poster{opacity:0}
.tile__poster{transition:opacity .45s var(--ease)}
/* silent UGC = ambient texture: autoplay muted, no play button, not clickable */
.tile--ugc{cursor:default}
.tile--ugc>video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1}
.tile--ugc:hover{transform:none}

/* ---------- scrolling video band ---------- */
.video-band{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.video-band__track{display:flex;gap:12px;width:max-content;animation:bandscroll 70s linear infinite}
.video-band:hover .video-band__track{animation-play-state:paused}
.video-band .tile{height:clamp(190px,24vw,290px)}
@keyframes bandscroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 6px))}}
@media(prefers-reduced-motion:reduce){.video-band__track{animation:none}}

/* ---------- fullscreen lightbox (click = big video + sound) ---------- */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,8,8,.93);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:clamp(14px,3vw,48px);opacity:0;transition:opacity .3s var(--ease)}
.lightbox.in{opacity:1}
.lightbox video{max-width:100%;max-height:100%;width:auto;height:auto;border-radius:10px;box-shadow:0 30px 90px rgba(0,0,0,.7);background:#000}
.lightbox__close{position:fixed;top:18px;right:22px;z-index:201;width:50px;height:50px;border-radius:50%;border:1px solid rgba(245,245,245,.3);background:rgba(20,20,20,.55);color:#fff;font-size:22px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:all .2s var(--ease)}
.lightbox__close:hover{background:var(--yellow);color:#161616;border-color:var(--yellow);transform:scale(1.05)}
.tile__play{position:absolute;inset:0;display:grid;place-items:center;z-index:2;pointer-events:none;transition:opacity .3s var(--ease)}
.tile.is-playing .tile__play{opacity:0}
.tile__play span{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:rgba(20,20,20,.5);border:1px solid rgba(245,245,245,.5);backdrop-filter:blur(6px);transition:transform .3s var(--ease),background .3s var(--ease)}
.tile:hover .tile__play span{transform:scale(1.08);background:var(--yellow)}
.tile:hover .tile__play span svg{color:#161616}
.tile__play span svg{width:22px;height:22px;color:#fff;margin-left:3px}
.tile__meta{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:18px 18px 16px;pointer-events:none;background:linear-gradient(180deg,transparent,rgba(8,8,8,.86));display:flex;align-items:flex-end;justify-content:space-between;gap:12px;transition:opacity .3s var(--ease)}
.tile.is-playing .tile__meta{opacity:0}
.tile__label{font-weight:700;font-size:1rem;letter-spacing:-.01em}
/* multi-colour pill tags */
.pill{font-size:.72rem;font-weight:700;letter-spacing:.01em;border-radius:50px;padding:6px 13px;white-space:nowrap;color:#fff;background:var(--c-blue)}
.pill--orange{background:var(--c-orange)}.pill--verm{background:var(--c-verm)}
.pill--pink{background:var(--c-pink)}.pill--blue{background:var(--c-blue)}
.pill--red{background:var(--c-red)}.pill--yellow{background:var(--yellow);color:#161616}

/* ---------- process steps ---------- */
.steps{counter-reset:step;display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.steps--4{grid-template-columns:repeat(4,1fr)}
.steps--col{grid-template-columns:1fr}
@media(max-width:860px){.steps--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps--4{grid-template-columns:1fr}}
.step{background:var(--dark);padding:34px 28px}
.step__n{font-family:"ivypresto-display",Georgia,serif;font-style:italic;font-size:2.5rem;color:var(--yellow);line-height:1;margin-bottom:16px}
.step h3{font-size:1.14rem;margin-bottom:8px}
.step p{margin:0;color:var(--ink-soft);font-size:.95rem}

/* ---------- split feature ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.split--rev .split__media{order:2}
@media(max-width:880px){.split{grid-template-columns:1fr}.split--rev .split__media{order:0}}
.split__media{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:#000;position:relative}
.split__media video,.split__media img{width:100%;height:100%;object-fit:cover}

/* ---------- checklist ---------- */
.checks{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:14px}
.checks li{display:flex;gap:14px;align-items:flex-start;color:var(--ink-soft)}
.checks li strong{color:var(--ink);font-weight:700}
.section--light .checks li{color:var(--night-soft)}
.section--light .checks li strong{color:var(--night)}
.checks svg{flex:none;width:22px;height:22px;color:var(--yellow);margin-top:1px}

/* ---------- big thin stats ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media(max-width:680px){.stats{grid-template-columns:1fr}}
.stat__n{font-size:clamp(2.6rem,5.6vw,4.4rem);font-weight:300;letter-spacing:-.01em;line-height:1.05}
.stat__n .serif{font-weight:300;color:var(--yellow);font-size:1.12em}

/* ---------- RSA stat-line (title -> thin rule -> big italic value) ---------- */
.statline-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(36px,6vw,90px)}
@media(max-width:760px){.statline-grid{grid-template-columns:1fr;gap:48px}}
.statline__title{font-size:16px;font-weight:400;letter-spacing:.01em;color:var(--slate);margin-bottom:22px}
.statline__rule{height:1px;background:#999;opacity:.5;margin-bottom:30px}
.statline__value{font-family:"ivypresto-display",Georgia,serif;font-style:italic;font-weight:300;font-size:clamp(4rem,8vw,108px);line-height:.92;letter-spacing:-.01em;color:var(--ink)}
.section--light .statline__title{color:var(--night-soft)}
.section--light .statline__rule{background:#bbb}
.section--light .statline__value{color:var(--night)}
.stat__l{margin-top:12px;color:var(--ink-soft);font-size:.98rem;max-width:30ch}

/* ---------- CTA band ---------- */
.cta-band{position:relative;border-radius:clamp(20px,3vw,26px);overflow:hidden;border:1px solid var(--line);background:var(--dark-2)}
.cta-band__inner{padding:clamp(48px,7vw,88px) var(--pad);text-align:center;position:relative;z-index:2}
.cta-band .lead{margin:18px auto 0}
.cta-band .hero__cta{margin-top:34px}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);background:var(--dark-3);padding-block:58px 40px}
.footer__top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:34px;align-items:flex-start}
.footer__brand img{height:36px;width:auto;margin-bottom:16px}
.footer__brand p{margin:0;color:var(--ink-soft);max-width:34ch;font-size:.96rem}
.footer__col h4{font-size:.95rem;color:var(--ink);margin:0 0 14px;font-weight:600}
.footer__col a,.footer__col span{display:block;color:var(--ink-soft);font-size:.96rem;margin-bottom:9px;transition:color .2s}
.footer__col a:hover{color:var(--yellow)}
.footer__social{display:flex;gap:12px;margin-top:4px}
.footer__social a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--ink-soft);transition:all .25s var(--ease)}
.footer__social a:hover{color:#161616;background:var(--yellow);border-color:var(--yellow);transform:translateY(-2px)}
.footer__social svg{width:17px;height:17px}
.footer__bot{margin-top:46px;padding-top:24px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;color:var(--ink-faint);font-size:.85rem}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .wordmark__track,.hero__scroll::after,.fpill{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- avatar showcase ---------- */
.looks{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.looks{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.looks{grid-template-columns:repeat(2,1fr);gap:12px}}
.look{position:relative;border-radius:var(--radius-sm);overflow:hidden;background:#000;border:1px solid var(--line);cursor:pointer;aspect-ratio:9/16}
.look video,.look img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.look video{opacity:0;transition:opacity .4s var(--ease)}
.look img{transition:opacity .4s var(--ease)}
.look.is-playing video{opacity:1}
.look.is-playing img{opacity:0}
.look::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(transparent 55%,rgba(8,8,8,.5));pointer-events:none}
.look__cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px;background:linear-gradient(transparent,rgba(8,8,8,.9));font-size:.82rem;font-weight:700;pointer-events:none}
.look__cap small{display:block;font-weight:500;color:var(--yellow);font-size:.74rem;margin-bottom:3px;font-style:italic;font-family:"ivypresto-display",Georgia,serif}

.states{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
@media(max-width:760px){.states{grid-template-columns:repeat(3,1fr)}}
@media(max-width:420px){.states{grid-template-columns:repeat(2,1fr)}}
.state{position:relative;border-radius:10px;overflow:hidden;background:#000;border:1px solid var(--line);cursor:pointer;aspect-ratio:1/1}
.state video,.state img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.state video{opacity:0;transition:opacity .35s var(--ease)}
.state img{transition:opacity .35s var(--ease)}
.state.is-playing video{opacity:1}
.state.is-playing img{opacity:0}
.state__tag{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:9px 10px;background:linear-gradient(transparent,rgba(8,8,8,.92));font-size:.74rem;font-weight:600;color:var(--ink);pointer-events:none}
