:root {
  --white: #fff;
  --silver: #d5d5d5;
  --orange: #ff5a1f;
  --charcoal: #2b2b2b;
  --black: #000;
  --display: "Archivo Black", sans-serif;
  --sans: "Manrope", sans-serif;
  --mono: "DM Mono", monospace;
}

* { box-sizing: border-box; }
html { background: var(--black); scroll-behavior: smooth; overflow-x:hidden; }
body { margin: 0; color: var(--white); background: var(--black); font-family: var(--sans); overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
.grain { position: fixed; inset: 0; z-index: 100; pointer-events: none; opacity: .05; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E"); }
.page-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 30; display: flex; align-items: center; justify-content: space-between; padding: 24px 4vw; mix-blend-mode: difference; }
.brand { font: 400 .95rem var(--display); text-transform: uppercase; letter-spacing: -.04em; }
.brand i { color: var(--orange); font-style: normal; }
.page-nav nav { display: flex; gap: 30px; align-items: center; font: .68rem var(--mono); text-transform: uppercase; }
.page-nav nav a:hover, .page-nav .active { color: var(--orange); }
.nav-contact { border: 1px solid currentColor; border-radius: 100px; padding: 9px 15px; }
.page-main { min-height: 100vh; }
.page-hero { min-height: 82vh; display: flex; flex-direction: column; justify-content: flex-end; padding: 130px 4vw 8vh; position: relative; overflow: hidden; }
.eyebrow { font: .7rem var(--mono); text-transform: uppercase; letter-spacing: .08em; }
.page-hero h1, .page-title, .cta-title { margin: 20px 0 24px; font: 400 clamp(3.5rem, 9vw, 9rem)/.92 var(--display); letter-spacing: -.055em; }
.page-hero h1 em, .page-title em { color: var(--orange); font-style: normal; }
.page-lead { width: min(580px, 80vw); margin-left: auto; font-size: clamp(1rem, 1.5vw, 1.3rem); line-height: 1.65; }
.shader-canvas { position: absolute; inset: 0; width: 100%; height: 100%; opacity: .7; }
.shader-overlay { position: absolute; inset: 0; background: radial-gradient(circle at center, transparent, #000 80%); }
.hero-content { position: relative; z-index: 2; }
.section { padding: 120px 4vw; }
.light { color: var(--black); background: var(--silver); }
.orange { color: var(--black); background: var(--orange); }
.split { display: grid; grid-template-columns: 1fr 2fr; gap: 8vw; }
.copy-large { font: 400 clamp(2rem, 4.5vw, 5rem)/1.02 var(--display); letter-spacing: -.05em; }
.body-copy { max-width: 620px; font-size: 1.05rem; line-height: 1.75; }
.mockup-section { display: grid; grid-template-columns: .85fr 1.4fr; gap: 8vw; align-items: center; min-height: 80vh; }
.mockup-stage { position: relative; min-height: 520px; perspective: 1200px; }
.mock-card { position: absolute; border: 1px solid rgba(255,255,255,.2); background: var(--charcoal); box-shadow: 0 30px 100px rgba(0,0,0,.45); overflow: hidden; transition: transform .2s linear; }
.mock-card.primary { inset: 10% 4% 5% 10%; transform: rotateY(-7deg) rotateX(3deg); }
.mock-card.secondary { width: 46%; height: 58%; right: -2%; top: 0; background: var(--orange); transform: translateY(var(--parallax, 0px)) rotate(5deg); }
.mock-ui { height: 100%; padding: 32px; display: flex; flex-direction: column; justify-content: space-between; }
.mock-ui .lines { display: grid; gap: 12px; }
.mock-ui .lines i { height: 10px; display: block; background: rgba(255,255,255,.22); }
.mock-ui .lines i:nth-child(2) { width: 70%; }
.mock-ui .screen-title { font: 400 clamp(2rem, 4vw, 4rem)/.95 var(--display); letter-spacing: -.05em; }
.skills-grid, .price-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(0,0,0,.25); border: 1px solid rgba(0,0,0,.25); }
.skill, .price-card { background: var(--silver); padding: 34px; min-height: 190px; }
.skill span, .price-card span { font: .65rem var(--mono); }
.skill h3, .price-card h2 { margin: 50px 0 0; font: 400 clamp(1.3rem, 2.5vw, 2.5rem)/1 var(--display); letter-spacing: -.04em; }
.price-grid { grid-template-columns: repeat(3, 1fr); background: rgba(255,255,255,.2); border-color: rgba(255,255,255,.2); }
.price-card { color: var(--white); background: var(--charcoal); min-height: 430px; display: flex; flex-direction: column; }
.price-card.featured { color: var(--black); background: var(--orange); }
.price-card p { line-height: 1.6; }
.price-card ul { margin: auto 0 24px; padding: 0; list-style: none; font: .78rem/2 var(--mono); }
.price-card a { border-top: 1px solid currentColor; padding-top: 18px; font: .7rem var(--mono); text-transform: uppercase; }
.portfolio-intro { min-height:56vh; display:grid; align-content:end; grid-template-columns:1fr 2.3fr; gap:20px 6vw; padding:140px 4vw 55px; border-bottom:1px solid rgba(255,255,255,.22); background:radial-gradient(circle at 80% 15%,rgba(255,90,31,.12),transparent 34%),#000; }
.portfolio-intro .eyebrow { align-self:start; }
.portfolio-intro h1 { grid-column:2; margin:0; font:400 clamp(3.5rem,9vw,9rem)/.9 var(--display); letter-spacing:-.06em; }
.portfolio-copy { grid-column:2; max-width:720px; margin:25px 0 0 auto; text-align:left; font-size:1.12rem; line-height:1.7; }
.portfolio-intro-cue { grid-column:2; margin-top:20px; font:.65rem var(--mono); color:var(--orange); text-transform:uppercase; }
.portfolio-films { padding-top:90px; }
.film-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 18px; }
.film-frame { min-height: 480px; position: relative; overflow: hidden; background: var(--charcoal); }
.film-frame:nth-child(3) { grid-column: 1 / -1; min-height: 600px; }
.film-frame span { position: absolute; left: 18px; bottom: 16px; font: .68rem var(--mono); text-transform: uppercase; }
.video-galleries { display: grid; gap: 150px; }
.video-group { display: grid; gap: 38px; }
.video-group-header { display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: end; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,.25); }
.video-group-header h2 { margin: 0; font: 400 clamp(2rem, 4vw, 4.5rem)/1 var(--display); letter-spacing: -.05em; text-transform: uppercase; }
.video-group-header span { font: .64rem var(--mono); text-transform: uppercase; }
.video-group-header span:last-child { text-align: right; }
.video-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 70px 22px; align-items: start; }
.video-grid-portrait { width: min(880px, 100%); margin-inline: auto; }
.video-card { min-width: 0; margin: 0; }
.video-grid .video-card:last-child:nth-child(odd) { grid-column: 1 / -1; width: calc(50% - 11px); justify-self: center; }
.video-card video { display: block; width: 100%; background: var(--charcoal); object-fit: cover; border: 1px solid rgba(255,255,255,.18); }
.video-landscape video { aspect-ratio: 16 / 9; }
.video-portrait video { aspect-ratio: 9 / 16; }
.video-card figcaption { display: flex; justify-content: space-between; padding: 14px 0; border-top: 1px solid rgba(255,255,255,.22); font: .64rem var(--mono); text-transform: uppercase; }
.video-card video::-webkit-media-controls-enclosure { border-radius: 0; }
.category-switcher { display:grid; grid-template-columns:1fr 1fr; border-block:1px solid rgba(255,255,255,.22); }
.category-switcher a { min-height:260px; display:flex; flex-direction:column; justify-content:space-between; padding:38px 4vw; transition:background .25s ease,color .25s ease; }
.category-switcher a + a { border-left:1px solid rgba(255,255,255,.22); text-align:right; align-items:flex-end; }
.category-switcher a:hover { color:var(--black); background:var(--orange); }
.category-switcher span { font:.65rem var(--mono); text-transform:uppercase; }
.category-switcher strong { max-width:90%; font:400 clamp(1.8rem,4vw,4.7rem)/.95 var(--display); letter-spacing:-.05em; }
.art-events { background: radial-gradient(circle at 28% 42%, var(--orange), transparent 12%), radial-gradient(circle at 70% 30%, var(--white), transparent 18%), linear-gradient(125deg,#000,#2b2b2b 60%,#777); }
.art-beauty { background: radial-gradient(ellipse at 60% 35%,#fff 0 10%,transparent 11%), radial-gradient(ellipse at 53% 57%,var(--orange) 0 17%,transparent 18%), linear-gradient(145deg,#000,#2b2b2b 60%,#d5d5d5); }
.art-food { background: radial-gradient(circle at 60% 52%,#fff 0 17%,transparent 18%), radial-gradient(circle at 60% 52%,var(--orange) 0 27%,transparent 28%), linear-gradient(130deg,#000,#2b2b2b 55%,#777); }
.art-sports { background: radial-gradient(ellipse at 45% 46%,var(--orange) 0 8%,transparent 9%), linear-gradient(150deg,#000,#2b2b2b 52%,#d5d5d5); }
.art-personal { background: radial-gradient(circle at 40% 38%,rgba(255,90,31,.75) 0 4%,transparent 25%), linear-gradient(155deg,#000,#2b2b2b 55%,#777); }
.art-corporate { background: linear-gradient(145deg,transparent 50%,rgba(255,255,255,.25) 51% 52%,transparent 53%),linear-gradient(125deg,#000,#2b2b2b 48%,#d5d5d5); }
.contact-panel { min-height: 100vh; display: grid; place-items: center; text-align: center; padding: 100px 4vw; position: relative; overflow: hidden; }
.contact-panel .hero-content { max-width: 1100px; }
.email-big { font: 400 clamp(1.2rem, 3vw, 3rem) var(--display); border-bottom: 3px solid; }
.page-footer { display: flex; justify-content: space-between; padding: 28px 4vw; border-top: 1px solid rgba(255,255,255,.2); font: .65rem var(--mono); text-transform: uppercase; }
.reveal { opacity: 0; transform: translateY(35px); transition: opacity .8s ease, transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.visible { opacity: 1; transform: none; }
.page-wipe { position: fixed; inset: 0; z-index: 200; pointer-events: none; background: var(--orange); transform: translateY(101%); transition: transform .42s cubic-bezier(.76,0,.24,1); }
body.is-leaving .page-wipe { transform: translateY(0); }
@media (max-width: 800px) {
  .page-nav { align-items:flex-start; padding:16px; mix-blend-mode:normal; background:rgba(0,0,0,.82); backdrop-filter:blur(12px); }
  .brand { max-width:100px; font-size:.7rem; line-height:1.1; }
  .page-nav nav { max-width:74%; justify-content:flex-end; flex-wrap:wrap; gap:6px 12px; font-size:.55rem; }
  .nav-contact { padding:6px 9px; }
  .page-hero, .section { padding-left: 20px; padding-right: 20px; }
  .split, .mockup-section, .price-grid, .skills-grid, .film-grid { grid-template-columns: 1fr; }
  .page-lead { margin-left: 0; width: 100%; }
  .mockup-stage { min-height: 400px; }
  .price-card { min-height: 380px; }
  .film-frame:nth-child(3) { grid-column: auto; }
  .video-galleries { gap: 100px; }
  .video-group-header { grid-template-columns: 1fr auto; }
  .video-group-header h2 { grid-column: 1 / -1; grid-row: 1; }
  .video-group-header span { grid-row: 2; }
  .video-grid { gap: 42px 12px; }
  .video-grid-landscape { grid-template-columns: 1fr; }
  .video-grid-portrait { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .video-grid-landscape .video-card:last-child:nth-child(odd) { grid-column: auto; width: 100%; }
  .video-grid-portrait .video-card:last-child:nth-child(odd) { width: calc(50% - 6px); }
  .video-card figcaption { gap: 8px; font-size: .52rem; }
  .portfolio-intro { min-height:auto; grid-template-columns:1fr; align-content:end; padding:125px 20px 45px; }
  .portfolio-intro h1,.portfolio-copy,.portfolio-intro-cue { grid-column:1; }
  .portfolio-intro h1 { font-size:clamp(3rem,15vw,5.4rem); }
  .portfolio-copy { margin:8px 0 0; font-size:.98rem; }
  .portfolio-films { padding-top:65px; }
  .category-switcher { grid-template-columns:1fr; }
  .category-switcher a { min-height:190px; padding:28px 20px; }
  .category-switcher a + a { border-left:0; border-top:1px solid rgba(255,255,255,.22); }
  .page-footer { gap: 20px; flex-wrap: wrap; }
}
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; scroll-behavior:auto!important; }
}
@media (max-width:360px) {
  .page-nav { flex-wrap:wrap; }
  .page-nav nav { order:2; width:100%; max-width:none; justify-content:space-between; margin-top:9px; }
  .portfolio-intro,.page-hero { padding-top:150px; }
}
