/* ============================================================
   H3 AI FILMS — MAIN STYLESHEET v2.0
   Direction: Runway ML — Pure Black · Massive Type · Video-First
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Space+Grotesk:wght@300;400;500&family=Syne:wght@400;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap');

/* ============================================================
   TOKENS
   ============================================================ */
:root {
  --black:    #000000;
  --white:    #ffffff;
  --off:      #f0f0f0;
  --g1:       #111111;
  --g2:       #1a1a1a;
  --muted:    rgba(255,255,255,0.45);
  --faint:    rgba(255,255,255,0.18);
  --line:     rgba(255,255,255,0.1);
  --nav-h:    72px;
  --ease:     cubic-bezier(0.22,1,0.36,1);
  --t:        0.28s;
  --font-d:   'Bebas Neue','Syne',sans-serif;
  --font-s:   'Syne',sans-serif;
  --font-b:   'DM Sans',sans-serif;
  --font-l:   'Space Grotesk',sans-serif;
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--black);color:var(--white);font-family:var(--font-b);font-weight:400;line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}
::selection{background:var(--white);color:var(--black)}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{width:100%;max-width:1400px;margin:0 auto;padding:0 48px}
.container--wide{max-width:1600px}
.container--narrow{max-width:820px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-l);font-size:.73rem;font-weight:500;
  letter-spacing:.13em;text-transform:uppercase;
  padding:14px 34px;cursor:pointer;
  transition:all var(--t) var(--ease);border:none
}
.btn--white{background:var(--white);color:var(--black)}
.btn--white:hover{background:var(--off);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.28)}
.btn--ghost:hover{border-color:var(--white);background:rgba(255,255,255,.05)}

/* ============================================================
   NAVIGATION
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);display:flex;align-items:center;
  transition:background var(--t) ease,border-color var(--t) ease;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(0,0,0,.9);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-color:var(--line);
}
.nav{width:100%;display:flex;align-items:center;justify-content:space-between;padding:0 48px}
.nav__logo{font-family:var(--font-l);font-size:.78rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase}
.nav__links{display:flex;align-items:center;gap:40px}
.nav__links a{font-family:var(--font-l);font-size:.7rem;font-weight:400;letter-spacing:.08em;color:var(--muted);transition:color var(--t)}
.nav__links a:hover{color:var(--white)}
.nav__cta{font-family:var(--font-l);font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--white);border:1px solid rgba(255,255,255,.25);padding:9px 22px;transition:all var(--t) ease}
.nav__cta:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.nav__hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav__hamburger span{display:block;width:24px;height:1px;background:var(--white);transition:all var(--t) ease}

/* Mobile nav */
.mobile-nav{display:none;position:fixed;inset:0;background:var(--black);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:48px}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--font-d);font-size:clamp(2.5rem,8vw,5rem);color:var(--white);letter-spacing:.04em;transition:color var(--t) ease}
.mobile-nav a:hover{color:var(--muted)}
.mobile-nav__close{position:absolute;top:24px;right:48px;font-size:1.8rem;color:var(--muted);cursor:pointer;transition:color var(--t)}
.mobile-nav__close:hover{color:var(--white)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;height:100svh;min-height:700px;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;background:var(--black);
}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover;opacity:.42}
.hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(0,0,0,.98) 0%,rgba(0,0,0,.55) 50%,rgba(0,0,0,.15) 100%)
}
.hero__grain{
  position:absolute;inset:0;z-index:2;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;pointer-events:none
}
.hero__content{position:relative;z-index:3;padding:0 48px 80px}
.hero__eyebrow{
  font-family:var(--font-l);font-size:.68rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);margin-bottom:24px;
  display:flex;align-items:center;gap:16px
}
.hero__eyebrow::before{content:'';display:block;width:32px;height:1px;background:rgba(255,255,255,.3)}
.hero__headline{
  font-family:var(--font-d);
  font-size:clamp(5rem,13.5vw,17rem);
  line-height:.9;letter-spacing:-.01em;color:var(--white);
  max-width:1200px;margin-bottom:56px
}
.hero__sub{display:flex;align-items:flex-end;justify-content:space-between;gap:32px}
.hero__desc{font-family:var(--font-b);font-size:1rem;color:var(--muted);max-width:380px;line-height:1.8}
.hero__actions{display:flex;gap:12px;flex-shrink:0}

/* scroll indicator */
.hero__scroll{
  position:absolute;bottom:80px;right:48px;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--font-l);font-size:.58rem;letter-spacing:.22em;
  color:rgba(255,255,255,.3);writing-mode:vertical-lr
}
.scroll-line{width:1px;height:64px;background:rgba(255,255,255,.12);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--white);animation:scrolldown 2s var(--ease) infinite}
@keyframes scrolldown{0%{top:-100%}100%{top:100%}}

/* ============================================================
   TICKER
   ============================================================ */
.ticker{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 0;background:var(--black)}
.ticker__track{display:flex;width:max-content;animation:ticker 28s linear infinite}
.ticker__track:hover{animation-play-state:paused}
.ticker__item{display:flex;align-items:center;gap:28px;padding-right:56px;font-family:var(--font-l);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.ticker__dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.25);flex-shrink:0}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   SHOWREEL
   ============================================================ */
.showreel{padding:100px 0;background:var(--black)}
.showreel__inner{max-width:1400px;margin:0 auto;padding:0 48px}
.showreel__label{font-family:var(--font-l);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.showreel__title{font-family:var(--font-d);font-size:clamp(3rem,7vw,8.5rem);line-height:.93;margin-bottom:56px}
.showreel__player{position:relative;aspect-ratio:16/9;background:var(--g1);cursor:pointer;overflow:hidden}
.showreel__thumb{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),opacity .4s ease}
.showreel__player:hover .showreel__thumb{transform:scale(1.04);opacity:.7}
.showreel__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.showreel__btn{
  width:84px;height:84px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.25);backdrop-filter:blur(8px);
  transition:all .3s ease
}
.showreel__player:hover .showreel__btn{background:var(--white);border-color:var(--white)}
.showreel__btn svg{width:22px;height:22px;fill:var(--white);margin-left:3px;transition:fill .3s}
.showreel__player:hover .showreel__btn svg{fill:var(--black)}
.showreel__meta{position:absolute;bottom:28px;left:32px;font-family:var(--font-l);font-size:.65rem;letter-spacing:.15em;color:rgba(255,255,255,.4)}

/* ============================================================
   SERVICES
   ============================================================ */
.services{padding:80px 0 120px;border-top:1px solid var(--line)}
.services__header{max-width:1400px;margin:0 auto 72px;padding:0 48px;display:flex;align-items:flex-end;justify-content:space-between;gap:32px}
.section-title{font-family:var(--font-d);font-size:clamp(3rem,6.5vw,8rem);line-height:.93;color:var(--white)}
.section-link{font-family:var(--font-l);font-size:.7rem;letter-spacing:.12em;color:var(--muted);border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:2px;transition:all var(--t);white-space:nowrap;margin-bottom:6px}
.section-link:hover{color:var(--white);border-color:var(--white)}
.service-row{display:grid;grid-template-columns:72px 1fr 1.2fr auto;align-items:center;gap:32px;padding:26px 48px;border-top:1px solid var(--line);cursor:pointer;transition:background var(--t) ease;max-width:1400px;margin:0 auto}
.service-row:hover{background:var(--g1)}
.service-row:last-child{border-bottom:1px solid var(--line)}
.service-row__num{font-family:var(--font-l);font-size:.6rem;letter-spacing:.1em;color:var(--faint)}
.service-row__name{font-family:var(--font-s);font-size:clamp(1.1rem,2vw,1.5rem);font-weight:700;color:var(--white)}
.service-row__desc{font-family:var(--font-b);font-size:.88rem;color:var(--muted);line-height:1.6}
.service-row__arrow{font-size:1.1rem;color:var(--faint);transition:color var(--t),transform var(--t)}
.service-row:hover .service-row__arrow{color:var(--white);transform:translate(4px,-4px)}

/* ============================================================
   PORTFOLIO GRID
   ============================================================ */
.portfolio{padding:80px 0 120px;border-top:1px solid var(--line)}
.portfolio__header{max-width:1400px;margin:0 auto 56px;padding:0 48px;display:flex;align-items:flex-end;justify-content:space-between;gap:32px}
.portfolio__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;padding:0 48px;max-width:1400px;margin:0 auto}
.pcard{position:relative;overflow:hidden;background:var(--g1);cursor:pointer}
.pcard--wide{grid-column:span 8;aspect-ratio:16/9}
.pcard--tall{grid-column:span 4;aspect-ratio:9/16;grid-row:span 2}
.pcard--half{grid-column:span 6;aspect-ratio:4/3}
.pcard--third{grid-column:span 4;aspect-ratio:4/3}
.pcard img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),opacity .4s ease;opacity:.8}
.pcard:hover img{transform:scale(1.07);opacity:1}
.pcard__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:28px;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 55%);opacity:0;transition:opacity .35s ease}
.pcard:hover .pcard__overlay{opacity:1}
.pcard__cat{font-family:var(--font-l);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.pcard__name{font-family:var(--font-s);font-size:1.1rem;font-weight:700}
.pcard__arrow{margin-top:10px;font-family:var(--font-l);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px}
.pcard__arrow::after{content:'→';transition:transform var(--t)}
.pcard:hover .pcard__arrow::after{transform:translateX(4px)}
.portfolio__more{text-align:center;margin-top:56px}

/* ============================================================
   STATS
   ============================================================ */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:80px 0}
.stats__grid{max-width:1400px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:0 40px;border-right:1px solid var(--line)}
.stat:first-child{padding-left:0}
.stat:last-child{border-right:none}
.stat__num{font-family:var(--font-d);font-size:clamp(3.5rem,5.5vw,7rem);line-height:1;color:var(--white);margin-bottom:12px}
.stat__label{font-family:var(--font-l);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);line-height:1.55}

/* ============================================================
   PRICING
   ============================================================ */
.pricing{padding:120px 0;border-top:1px solid var(--line)}
.pricing__header{max-width:1400px;margin:0 auto 72px;padding:0 48px}
.pricing__subtitle{font-size:1rem;color:var(--muted);max-width:480px;margin-top:16px}
.pricing__grid{max-width:1400px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.price-card{background:var(--black);padding:52px 44px;transition:background var(--t)}
.price-card:hover{background:var(--g1)}
.price-card--feat{background:var(--white);color:var(--black)}
.price-card--feat:hover{background:var(--off)}
.price-card__tag{font-family:var(--font-l);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:44px}
.price-card--feat .price-card__tag{color:rgba(0,0,0,.4)}
.price-card__name{font-family:var(--font-s);font-size:1.1rem;font-weight:700;margin-bottom:4px}
.price-card__sub{font-size:.85rem;color:var(--muted);margin-bottom:36px}
.price-card--feat .price-card__sub{color:rgba(0,0,0,.5)}
.price-card__price{font-family:var(--font-d);font-size:clamp(3.5rem,5.5vw,6.5rem);line-height:1;margin-bottom:44px}
.price-card__price sup{font-family:var(--font-l);font-size:1.1rem;vertical-align:super;margin-right:2px}
.price-card__features{margin-bottom:44px}
.price-card__features li{font-size:.88rem;color:var(--muted);padding:12px 0;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.price-card--feat .price-card__features li{color:rgba(0,0,0,.6);border-color:rgba(0,0,0,.1)}
.price-card__features li::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--faint);flex-shrink:0}
.price-card--feat .price-card__features li::before{background:rgba(0,0,0,.2)}
.price-card__cta{display:block;width:100%;padding:16px;text-align:center;font-family:var(--font-l);font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line);color:var(--white);transition:all var(--t)}
.price-card__cta:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.price-card--feat .price-card__cta{background:var(--black);color:var(--white);border-color:var(--black)}
.price-card--feat .price-card__cta:hover{background:var(--g2)}
.pricing__note{max-width:1400px;margin:40px auto 0;padding:0 48px;font-family:var(--font-l);font-size:.68rem;color:var(--muted)}

/* ============================================================
   PROCESS
   ============================================================ */
.process{padding:120px 0;border-top:1px solid var(--line)}
.process__inner{max-width:1400px;margin:0 auto;padding:0 48px}
.process__title{font-family:var(--font-d);font-size:clamp(3rem,6vw,7.5rem);line-height:.93;margin-bottom:72px;max-width:700px}
.process__steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.step{padding:36px 32px 36px 0;border-right:1px solid var(--line)}
.step:last-child{border-right:none}
.step__num{font-family:var(--font-l);font-size:.6rem;letter-spacing:.18em;color:var(--faint);margin-bottom:28px}
.step__name{font-family:var(--font-s);font-size:1rem;font-weight:700;color:var(--white);margin-bottom:12px}
.step__desc{font-size:.85rem;color:var(--muted);line-height:1.65}

/* ============================================================
   CTA FULL
   ============================================================ */
.cta-full{position:relative;padding:160px 0;text-align:center;border-top:1px solid var(--line);overflow:hidden}
.cta-full__glow{position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(255,255,255,.06) 0%,transparent 65%);pointer-events:none}
.cta-full__label{font-family:var(--font-l);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.cta-full__title{font-family:var(--font-d);font-size:clamp(4rem,10.5vw,13rem);line-height:.9;margin:0 auto 52px;max-width:1100px}
.cta-full__actions{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{border-top:1px solid var(--line);padding:80px 0 48px;background:var(--black)}
.footer__inner{max-width:1400px;margin:0 auto;padding:0 48px}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:72px}
.footer__brand-name{font-family:var(--font-l);font-size:.78rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px}
.footer__brand-desc{font-size:.88rem;color:var(--muted);line-height:1.75}
.footer__col-title{font-family:var(--font-l);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:22px}
.footer__col-links li{margin-bottom:13px}
.footer__col-links a{font-size:.9rem;color:var(--muted);transition:color var(--t)}
.footer__col-links a:hover{color:var(--white)}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;padding-top:32px;border-top:1px solid var(--line)}
.footer__copy{font-family:var(--font-l);font-size:.65rem;letter-spacing:.08em;color:var(--faint)}
.footer__socials{display:flex;gap:24px}
.footer__socials a{font-family:var(--font-l);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);transition:color var(--t)}
.footer__socials a:hover{color:var(--white)}

/* ============================================================
   FLOATS
   ============================================================ */
.float-wa{position:fixed;bottom:32px;right:32px;z-index:90;width:52px;height:52px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;transition:transform .25s ease,box-shadow .25s ease;box-shadow:0 4px 20px rgba(37,211,102,.28)}
.float-wa:hover{transform:scale(1.08);box-shadow:0 8px 32px rgba(37,211,102,.48)}
.float-wa svg{width:26px;height:26px;fill:#fff}
#back-to-top{position:fixed;bottom:96px;right:32px;z-index:89;width:44px;height:44px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--muted);background:rgba(0,0,0,.8);backdrop-filter:blur(8px);cursor:pointer;opacity:0;transform:translateY(8px);transition:all var(--t)}
#back-to-top.visible{opacity:1;transform:none}
#back-to-top:hover{border-color:var(--white);color:var(--white)}

/* ============================================================
   VIDEO MODAL
   ============================================================ */
.video-modal{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.95);align-items:center;justify-content:center}
.video-modal.open{display:flex}
.video-modal__inner{position:relative;width:90vw;max-width:1100px}
.video-modal__close{position:absolute;top:-44px;right:0;font-family:var(--font-l);font-size:.68rem;letter-spacing:.18em;color:var(--muted);cursor:pointer;transition:color var(--t)}
.video-modal__close:hover{color:var(--white)}
.video-modal iframe,.video-modal video{width:100%;aspect-ratio:16/9;border:none;display:block}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal--d1{transition-delay:.08s}
.reveal--d2{transition-delay:.16s}
.reveal--d3{transition-delay:.24s}
.reveal--d4{transition-delay:.32s}

/* ============================================================
   PAGE / SINGLE / MISC
   ============================================================ */
.page-hero{position:relative;min-height:50vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--black)}
.page-hero__bg{position:absolute;inset:0}
.page-hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.page-hero__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.98) 0%,rgba(0,0,0,.4) 100%)}
.page-hero__content{position:relative;z-index:1;padding:120px 48px 72px}
.page-hero__title{font-family:var(--font-d);font-size:clamp(3rem,8vw,9rem);line-height:.92}
.section-pad{padding:120px 0}
.entry-content{font-size:1rem;line-height:1.9;color:var(--muted)}
.entry-content h2,.entry-content h3{font-family:var(--font-s);color:var(--white);margin:2.5rem 0 1rem;font-weight:700}
.entry-content a{color:var(--white);border-bottom:1px solid var(--line);transition:border-color var(--t)}
.entry-content a:hover{border-color:var(--white)}
.entry-content p{margin-bottom:1.4rem}

/* blog */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.post-card{background:var(--black);transition:background var(--t)}
.post-card:hover{background:var(--g1)}
.post-card__thumb{aspect-ratio:16/9;overflow:hidden}
.post-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.post-card:hover .post-card__thumb img{transform:scale(1.04)}
.post-card__body{padding:28px 32px}
.post-card__meta{font-family:var(--font-l);font-size:.6rem;letter-spacing:.15em;color:var(--faint);margin-bottom:10px}
.post-card__title{font-family:var(--font-s);font-size:1.1rem;font-weight:700;margin-bottom:12px}
.post-card__title a{transition:color var(--t)}
.post-card__title a:hover{color:var(--muted)}
.post-card__excerpt{font-size:.88rem;color:var(--muted);line-height:1.7;margin-bottom:16px}
.post-card__link{font-family:var(--font-l);font-size:.65rem;letter-spacing:.12em;color:var(--muted);transition:color var(--t)}
.post-card__link:hover{color:var(--white)}

/* 404 */
.error-404{min-height:90vh;display:flex;align-items:center;text-align:center}
.error-404__inner{position:relative;width:100%;padding:0 48px}
.error-404__bg{font-family:var(--font-d);font-size:clamp(12rem,35vw,28rem);line-height:1;color:rgba(255,255,255,.03);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;white-space:nowrap}
.error-404__content{position:relative;z-index:1;padding:100px 0}
.error-404__label{font-family:var(--font-l);font-size:.65rem;letter-spacing:.2em;color:var(--muted);margin-bottom:20px}
.error-404__title{font-family:var(--font-d);font-size:clamp(4rem,10vw,10rem);line-height:.93;margin-bottom:20px}
.error-404__text{color:var(--muted);max-width:400px;margin:0 auto 36px;font-size:1rem}
.error-404__actions{display:flex;gap:12px;justify-content:center}

/* pagination */
.pagination{margin-top:56px;display:flex;justify-content:center}
.pagination .nav-links{display:flex;gap:4px;align-items:center}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--line);color:var(--muted);font-size:.85rem;transition:all var(--t)}
.pagination .page-numbers.current,.pagination .page-numbers:hover{border-color:var(--white);color:var(--white)}

/* search */
.search-form-wrap{margin-bottom:48px}
.search-form-wrap input[type="search"]{width:100%;background:var(--g1);border:1px solid var(--line);color:var(--white);padding:18px 24px;font-size:1rem;outline:none}
.search-form-wrap input[type="search"]:focus{border-color:rgba(255,255,255,.3)}

/* post nav */
.post-navigation{display:flex;justify-content:space-between;gap:16px;margin-top:72px;padding-top:40px;border-top:1px solid var(--line)}
.post-nav-link{display:flex;flex-direction:column;gap:6px;max-width:45%}
.post-nav-link--next{align-items:flex-end;text-align:right}
.post-nav-link span{font-family:var(--font-l);font-size:.62rem;letter-spacing:.15em;color:var(--faint)}
.post-nav-link strong{font-size:.92rem;color:var(--muted);font-weight:500;transition:color var(--t)}
.post-nav-link:hover strong{color:var(--white)}

/* no content */
.no-content{text-align:center;padding:80px 0;color:var(--muted)}
.no-content p{margin-bottom:24px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1200px){
  .container,.nav,.service-row,.services__header,.portfolio__header,.pricing__header,.process__inner,.portfolio__grid,.showreel__inner,.footer__inner,.stats__grid,.pricing__grid,.pricing__note{padding-left:32px;padding-right:32px}
  .hero__content,.page-hero__content{padding-left:32px;padding-right:32px}
  .footer__top{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:1024px){
  .process__steps{grid-template-columns:repeat(3,1fr)}
  .step:nth-child(3){border-right:none}
  .step:nth-child(4),.step:nth-child(5){border-top:1px solid var(--line)}
  .pcard--wide{grid-column:span 12}
  .pcard--tall{grid-column:span 6;aspect-ratio:4/3;grid-row:span 1}
  .pcard--half{grid-column:span 6}
  .pcard--third{grid-column:span 6}
}
@media(max-width:768px){
  .nav__links,.nav__cta{display:none}
  .nav__hamburger{display:flex}
  .hero__headline{font-size:clamp(3.5rem,16vw,6rem)}
  .hero__sub{flex-direction:column;align-items:flex-start;gap:24px}
  .hero__scroll{display:none}
  .services__header,.portfolio__header{flex-direction:column;align-items:flex-start}
  .service-row{grid-template-columns:1fr auto;gap:8px}
  .service-row__num,.service-row__desc{display:none}
  .portfolio__grid{grid-template-columns:1fr}
  .pcard--wide,.pcard--tall,.pcard--half,.pcard--third{grid-column:span 1;aspect-ratio:4/3;grid-row:span 1}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat{padding:32px 20px;border-bottom:1px solid var(--line)}
  .stat:nth-child(2),.stat:last-child{border-right:none}
  .pricing__grid{grid-template-columns:1fr}
  .process__steps{grid-template-columns:1fr 1fr}
  .step{border-right:none;border-bottom:1px solid var(--line)}
  .cta-full__title{font-size:clamp(3rem,13vw,7rem)}
  .footer__top{grid-template-columns:1fr;gap:32px}
  .footer__bottom{flex-direction:column;gap:20px;text-align:center}
  .posts-grid{grid-template-columns:1fr}
  .error-404__actions{flex-direction:column;align-items:center}
}
@media(max-width:480px){
  .nav{padding:0 20px}
  .hero__content{padding:0 20px 48px}
  .showreel__inner,.services__header,.portfolio__header,.pricing__header,.process__inner,.stats__grid,.footer__inner,.pricing__grid,.portfolio__grid,.pricing__note{padding-left:20px;padding-right:20px}
  .service-row{padding:20px}
  .hero__actions{flex-direction:column}
  .btn{width:100%;justify-content:center}
  .cta-full__actions{flex-direction:column;align-items:center}
}
