/* ============================================================
   GHASSEN HECHLEF — Colorist & Editor portfolio
   Cinematic dark-first system. Teal & orange grade palette.
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Hanken+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ---- Tokens ---- */
:root {
  --accent:   #ff5a36;   /* warm orange — highlights / lift */
  --accent-2: #38b6ac;   /* teal — shadows / cool side      */
  --accent-rgb: 255, 90, 54;

  --serif: 'Instrument Serif', Georgia, serif;
  --sans:  'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --mono:  'JetBrains Mono', ui-monospace, monospace;

  /* dark theme (default) */
  --bg:      #0b0a09;
  --bg-1:    #121110;
  --surface: #17150f00;
  --card:    #18161300;
  --panel:   #141210;
  --text:    #f3efe7;
  --text-dim: #b8b1a4;
  --text-faint: #7c756a;
  --line:    rgba(243, 239, 231, 0.10);
  --line-2:  rgba(243, 239, 231, 0.16);
  --grain-op: 0.045;
  --shadow: 0 30px 80px -30px rgba(0,0,0,0.8);

  --maxw: 1280px;
  --gut: clamp(20px, 5vw, 88px);
  --r: 14px;
}

:root[data-theme="light"] {
  --bg:      #f4f1ea;
  --bg-1:    #ece7dd;
  --surface: #ffffff;
  --card:    #ffffff;
  --panel:   #ffffff;
  --text:    #161310;
  --text-dim: #4f4a42;
  --text-faint: #8b8479;
  --line:    rgba(22, 19, 16, 0.10);
  --line-2:  rgba(22, 19, 16, 0.18);
  --grain-op: 0.02;
  --shadow: 0 30px 80px -40px rgba(60,50,30,0.35);
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  transition: background .5s ease, color .5s ease;
}
img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
::selection { background: var(--accent); color: #0b0a09; }

/* film grain overlay */
body::after {
  content: ""; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  opacity: var(--grain-op);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

/* ---- Layout helpers ---- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }
.eyebrow {
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent);
  display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before {
  content: ""; width: 22px; height: 1px; background: var(--accent); opacity: .7;
}
.eyebrow.dim { color: var(--text-faint); }
.eyebrow.dim::before { background: var(--text-faint); }

h1, h2, h3 { font-weight: 400; line-height: 1.02; letter-spacing: -0.01em; }
.display {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(2.8rem, 9vw, 8.4rem); line-height: 0.92;
  letter-spacing: -0.02em; text-wrap: balance;
}
.display .it { font-style: italic; color: var(--accent); }
.h2 { font-family: var(--serif); font-size: clamp(2rem, 5vw, 4rem); letter-spacing: -0.015em; }
.lead { font-size: clamp(1.05rem, 1.5vw, 1.35rem); color: var(--text-dim); max-width: 60ch; text-wrap: pretty; }

.section { padding-block: clamp(72px, 11vw, 160px); position: relative; }
.section-head { display: flex; flex-direction: column; gap: 22px; margin-bottom: clamp(40px, 6vw, 72px); }
.section-head .h2 { max-width: 18ch; }

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 15px 26px; border-radius: 100px;
  font-family: var(--mono); font-size: 12.5px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  transition: transform .35s cubic-bezier(.2,.8,.2,1), background .3s, color .3s, border-color .3s;
}
.btn-primary { background: var(--accent); color: #120a06; }
.btn-primary:hover { transform: translateY(-3px); }
.btn-ghost { border: 1px solid var(--line-2); color: var(--text); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-3px); }
.btn .arr { transition: transform .35s cubic-bezier(.2,.8,.2,1); }
.btn:hover .arr { transform: translate(4px, -4px); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px var(--gut);
  transition: background .4s, backdrop-filter .4s, border-color .4s, padding .4s;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: color-mix(in oklab, var(--bg) 82%, transparent);
  backdrop-filter: blur(18px) saturate(1.2);
  border-bottom-color: var(--line);
  padding-block: 13px;
}
.brand { display: flex; align-items: center; gap: 13px; }
.brand .mark {
  width: 34px; height: 34px; position: relative; flex: none;
  display: grid; place-items: center;
}
.brand .mark svg { width: 100%; height: 100%; }
.brand .name { display: flex; flex-direction: column; line-height: 1; }
.brand .name b { font-weight: 600; font-size: 15px; letter-spacing: 0.02em; }
.brand .name span { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--text-faint); margin-top: 3px; }

.nav-links { display: flex; align-items: center; gap: 6px; }
.nav-links a {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--text-dim); padding: 9px 14px; border-radius: 8px; transition: color .25s, background .25s;
}
.nav-links a:hover { color: var(--text); background: var(--line); }
.nav-right { display: flex; align-items: center; gap: 10px; }

.lang-toggle, .theme-toggle {
  display: flex; align-items: center; border: 1px solid var(--line-2); border-radius: 100px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; overflow: hidden;
}
.lang-toggle button { padding: 8px 12px; color: var(--text-faint); transition: color .25s, background .25s; }
.lang-toggle button.active { color: #120a06; background: var(--accent); }
.theme-toggle { padding: 9px 11px; color: var(--text-dim); }
.theme-toggle:hover { color: var(--accent); border-color: var(--accent); }
.nav .btn { padding: 11px 18px; }

.burger { display: none; width: 42px; height: 42px; border: 1px solid var(--line-2); border-radius: 10px; }
.burger span { display:block; width:18px; height:1.5px; background: var(--text); margin: 4px auto; transition: .3s; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; min-height: 100vh; display: flex; align-items: flex-end; padding-bottom: clamp(48px, 7vw, 90px); padding-top: 120px; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.35fr 0.9fr; gap: clamp(30px, 5vw, 70px); align-items: end; width: 100%; }
.hero-copy { position: relative; z-index: 3; }
.hero-copy .display { margin: 22px 0 0; }
.hero-sub { display: flex; flex-wrap: wrap; gap: 28px; margin-top: 34px; align-items: flex-end; }
.hero-sub .lead { flex: 1 1 320px; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }

.hero-media { position: relative; z-index: 2; }
.hero-portrait {
  position: relative; aspect-ratio: 0.72; border-radius: var(--r); overflow: hidden;
  box-shadow: var(--shadow);
}
.hero-portrait img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.05) contrast(1.04); }
.hero-portrait .scan { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.55)); }
.hero-portrait .tc {
  position: absolute; left: 14px; bottom: 13px; font-family: var(--mono); font-size: 11px;
  color: var(--text); letter-spacing: .08em; background: rgba(0,0,0,.4); padding: 5px 9px; border-radius: 6px;
  backdrop-filter: blur(4px);
}
.hero-portrait .rec { position: absolute; right: 13px; top: 13px; display:flex; align-items:center; gap:7px; font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:var(--text); background:rgba(0,0,0,.4); padding:5px 9px; border-radius:6px; }
.hero-portrait .rec i { width:8px; height:8px; border-radius:50%; background:var(--accent); display:block; animation: blink 1.6s steps(2) infinite; }
@keyframes blink { 50% { opacity: .15; } }

/* big background word + ambient glow */
.hero-bgword {
  position: absolute; left: var(--gut); right: 0; bottom: -2vw; z-index: 1; pointer-events: none;
  font-family: var(--serif); font-size: 28vw; line-height: .7; color: var(--text);
  opacity: .035; white-space: nowrap; letter-spacing: -0.03em;
}
.hero-glow {
  position: absolute; z-index: 0; width: 70vw; height: 70vw; right: -18vw; top: -12vw; pointer-events: none;
  background: radial-gradient(circle, rgba(var(--accent-rgb), .16), transparent 62%);
  filter: blur(20px);
}
.hero-glow.teal { left: -22vw; right:auto; top: auto; bottom: -22vw; background: radial-gradient(circle, color-mix(in oklab, var(--accent-2) 60%, transparent), transparent 62%); opacity:.5; }

.hero-meta { display: flex; gap: 34px; flex-wrap: wrap; margin-top: 22px; }
.hero-meta .m b { display:block; font-family: var(--serif); font-size: 2.1rem; line-height:1; }
.hero-meta .m span { font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-faint); }

/* hero variant B: full-bleed portrait background */
body[data-hero="full"] .hero-media { display: none; }
body[data-hero="full"] .hero-grid { grid-template-columns: 1fr; }
body[data-hero="full"] .hero { align-items: center; text-align: left; }
body[data-hero="full"] .hero-bg-full { display: block; }
.hero-bg-full { display: none; position: absolute; inset: 0; z-index: 0; }
.hero-bg-full img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.02) contrast(1.03) brightness(.62); }
.hero-bg-full::after { content:""; position:absolute; inset:0; background: linear-gradient(90deg, var(--bg) 8%, color-mix(in oklab, var(--bg) 40%, transparent) 52%, transparent); }
body[data-hero="full"] .hero-copy { max-width: 60ch; }

.marquee-strip { border-block: 1px solid var(--line); overflow: hidden; padding-block: 16px; background: var(--bg-1); }
.marquee { display: flex; gap: 56px; white-space: nowrap; animation: marq 38s linear infinite; width: max-content; }
.marquee span { font-family: var(--mono); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--text-faint); display:flex; align-items:center; gap:56px; }
.marquee span::after { content:"◆"; color: var(--accent); font-size: 8px; }
@keyframes marq { to { transform: translateX(-50%); } }

/* ============================================================
   PORTFOLIO GRID
   ============================================================ */
.filter-bar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 38px; }
.chip {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .08em; text-transform: uppercase;
  padding: 9px 16px; border-radius: 100px; border: 1px solid var(--line-2); color: var(--text-dim);
  transition: .25s;
}
.chip:hover { border-color: var(--text-dim); color: var(--text); }
.chip.active { background: var(--text); color: var(--bg); border-color: var(--text); }

.work-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(14px, 1.8vw, 26px); }
.work {
  position: relative; border-radius: var(--r); overflow: hidden; cursor: pointer;
  background: var(--bg-1); border: 1px solid var(--line);
  transition: transform .5s cubic-bezier(.2,.8,.2,1);
}
.work:hover { transform: translateY(-6px); }
.work .thumb { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.work.tall .thumb { aspect-ratio: 4/5; }
.work .ph {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 12px, transparent 12px 24px),
    linear-gradient(135deg, var(--g1, #211d18), var(--g2, #0d0c0a));
  display: grid; place-items: center;
}
.work .ph .tag { font-family: var(--mono); font-size: 10.5px; letter-spacing:.16em; text-transform:uppercase; color: rgba(255,255,255,.5); border:1px dashed rgba(255,255,255,.2); padding:6px 12px; border-radius:6px; }
.work .play {
  position:absolute; left:50%; top:50%; transform: translate(-50%,-50%) scale(.85); width:64px; height:64px; border-radius:50%;
  background: rgba(var(--accent-rgb), .92); display:grid; place-items:center; opacity:0; transition: .45s cubic-bezier(.2,.8,.2,1);
}
.work .play svg { width: 22px; height: 22px; margin-left: 3px; fill: #120a06; }
.work:hover .play { opacity:1; transform: translate(-50%,-50%) scale(1); }
.work .grade-wipe { position:absolute; inset:0; opacity:0; transition:.5s; background: linear-gradient(110deg, transparent 45%, rgba(var(--accent-rgb),.12) 50%, color-mix(in oklab, var(--accent-2) 30%, transparent) 75%); mix-blend-mode: screen; }
.work:hover .grade-wipe { opacity:1; }
.work .info { padding: 18px 20px 22px; display:flex; flex-direction:column; gap:8px; }
.work .info .cat { font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color: var(--accent); }
.work .info h3 { font-size: 1.18rem; font-family: var(--sans); font-weight: 600; letter-spacing: -0.01em; }
.work .info .role { font-size: .85rem; color: var(--text-faint); }
.work .yr { position:absolute; right:14px; top:13px; font-family:var(--mono); font-size:11px; color:var(--text); background:rgba(0,0,0,.45); padding:4px 9px; border-radius:6px; backdrop-filter:blur(4px); z-index:2; }

/* spans */
.s-6 { grid-column: span 6; } .s-4 { grid-column: span 4; } .s-5 { grid-column: span 5; }
.s-7 { grid-column: span 7; } .s-8 { grid-column: span 8; } .s-12 { grid-column: span 12; }
.s-3 { grid-column: span 3; }

/* ============================================================
   BEFORE / AFTER
   ============================================================ */
.ba {
  position: relative; aspect-ratio: 16/9; border-radius: var(--r); overflow: hidden; user-select: none;
  cursor: ew-resize; border: 1px solid var(--line-2); box-shadow: var(--shadow);
}
.ba .layer { position: absolute; inset: 0; }
.ba .layer img { width:100%; height:100%; object-fit: cover; }
.ba .before { filter: saturate(.55) contrast(.92) brightness(1.05) hue-rotate(8deg); }
.ba .after-clip { clip-path: inset(0 0 0 50%); }
.ba .after img { filter: saturate(1.18) contrast(1.12) brightness(.98); }
.ba .grad-after { position:absolute; inset:0; background: linear-gradient(120deg, rgba(var(--accent-rgb),.18), transparent 40%, color-mix(in oklab,var(--accent-2) 40%, transparent)); mix-blend-mode: soft-light; }
.ba .lbl { position:absolute; bottom:16px; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; padding:6px 12px; border-radius:6px; background:rgba(0,0,0,.5); backdrop-filter:blur(5px); }
.ba .lbl.l { left: 16px; } .ba .lbl.r { right: 16px; color: var(--accent); }
.ba .handle { position:absolute; top:0; bottom:0; left:50%; width:2px; background: var(--text); transform: translateX(-50%); }
.ba .handle .knob {
  position:absolute; top:50%; left:50%; transform: translate(-50%,-50%); width:46px; height:46px; border-radius:50%;
  background: var(--text); display:grid; place-items:center; box-shadow: 0 6px 24px rgba(0,0,0,.5);
}
.ba .handle .knob svg { width: 22px; height: 22px; stroke: var(--bg); }

/* ============================================================
   ABOUT / RESUME
   ============================================================ */
.about-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(36px, 6vw, 90px); align-items: start; }
.about-portrait { position: relative; border-radius: var(--r); overflow:hidden; box-shadow: var(--shadow); position: sticky; top: 110px; }
.about-portrait img { width:100%; aspect-ratio: 0.82; object-fit: cover; }
.about-portrait .cap { position:absolute; left:0; right:0; bottom:0; padding:26px 22px 20px; background:linear-gradient(transparent, rgba(0,0,0,.8)); font-family:var(--mono); font-size:11px; letter-spacing:.12em; color:var(--text-dim); }

.bio p { color: var(--text-dim); font-size: 1.12rem; line-height: 1.7; text-wrap: pretty; }
.bio p + p { margin-top: 1.1em; }
.bio .sig { font-family: var(--serif); font-style: italic; font-size: 1.9rem; color: var(--text); margin-top: 26px; }

.timeline { margin-top: 50px; border-top: 1px solid var(--line); }
.tl-item { display: grid; grid-template-columns: 92px 1fr auto; gap: 22px; padding: 22px 0; border-bottom: 1px solid var(--line); align-items: baseline; transition: padding-left .35s, background .35s; }
.tl-item:hover { padding-left: 14px; }
.tl-item .yr { font-family: var(--mono); font-size: 12px; color: var(--accent); letter-spacing: .06em; }
.tl-item .role { font-size: 1.08rem; font-weight: 600; }
.tl-item .role span { display:block; font-weight: 400; color: var(--text-faint); font-size: .9rem; margin-top: 3px; }
.tl-item .place { font-family: var(--mono); font-size: 11px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .08em; text-align: right; }
.tl-more { margin-top: 28px; }

.creds { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 40px; }
.cred { border: 1px solid var(--line); border-radius: var(--r); padding: 24px; background: var(--bg-1); }
.cred .eyebrow { margin-bottom: 14px; }
.cred h4 { font-size: 1.05rem; font-weight: 600; }
.cred p { font-size: .9rem; color: var(--text-faint); margin-top: 5px; font-family: var(--mono); letter-spacing:.03em; }

/* ============================================================
   SKILLS / TOOLS
   ============================================================ */
.skills-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: clamp(14px,1.6vw,22px); }
.skill { border: 1px solid var(--line); border-radius: var(--r); padding: 28px; background: var(--bg-1); position: relative; overflow: hidden; transition: border-color .35s, transform .35s; }
.skill:hover { border-color: var(--line-2); transform: translateY(-4px); }
.skill .tool-mark { width: 44px; height: 44px; border-radius: 11px; display:grid; place-items:center; font-family:var(--mono); font-weight:600; font-size:15px; margin-bottom: 18px; color:#fff; }
.skill h4 { font-size: 1.1rem; font-weight: 600; }
.skill .meta { font-family:var(--mono); font-size:11px; color: var(--text-faint); letter-spacing:.06em; text-transform:uppercase; margin-top: 6px; }
.skill .bar { height: 3px; background: var(--line); border-radius: 3px; margin-top: 18px; overflow:hidden; }
.skill .bar i { display:block; height:100%; background: linear-gradient(90deg, var(--accent-2), var(--accent)); width:0; border-radius:3px; transition: width 1.2s cubic-bezier(.2,.8,.2,1); }

.tools-row { display:flex; flex-wrap:wrap; gap: 12px; margin-top: 44px; }
.tool-pill { display:flex; align-items:center; gap:11px; padding: 11px 18px 11px 12px; border:1px solid var(--line); border-radius:100px; background: var(--bg-1); transition:.3s; }
.tool-pill:hover { border-color: var(--line-2); transform: translateY(-3px); }
.tool-pill .ic { width:30px; height:30px; border-radius:8px; display:grid; place-items:center; font-family:var(--mono); font-weight:600; font-size:12px; color:#fff; }
.tool-pill b { font-weight:500; font-size:.92rem; }
.tool-pill span { font-family:var(--mono); font-size:10px; color:var(--text-faint); }

/* ============================================================
   CLIENTS MARQUEE
   ============================================================ */
.clients { display:grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); border:1px solid var(--line); border-radius: var(--r); overflow:hidden; }
.client { padding: 34px 24px; display:grid; place-items:center; text-align:center; border-right:1px solid var(--line); border-bottom:1px solid var(--line); transition: background .35s; }
.client:hover { background: var(--bg-1); }
.client b { font-family: var(--serif); font-size: 1.25rem; color: var(--text-dim); transition: color .35s; }
.client:hover b { color: var(--text); }
.client span { display:block; font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color: var(--text-faint); margin-top:6px; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes { display:grid; grid-template-columns: repeat(3,1fr); gap: clamp(14px,1.8vw,22px); }
.quote { border:1px solid var(--line); border-radius: var(--r); padding: 32px; background: var(--bg-1); display:flex; flex-direction:column; gap: 22px; }
.quote .qm { font-family: var(--serif); font-size: 3.4rem; line-height: .4; color: var(--accent); height: 26px; }
.quote p { font-size: 1.05rem; color: var(--text); line-height: 1.6; flex: 1; text-wrap: pretty; }
.quote .who { display:flex; flex-direction:column; gap:3px; padding-top: 6px; border-top: 1px solid var(--line); }
.quote .who b { font-weight: 600; font-size: .95rem; }
.quote .who span { font-family: var(--mono); font-size: 10.5px; letter-spacing:.08em; text-transform:uppercase; color: var(--text-faint); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(36px,6vw,80px); align-items:start; }
.contact-left .display { font-size: clamp(2.4rem, 6vw, 5.2rem); }
.contact-links { margin-top: 40px; display:flex; flex-direction:column; gap: 2px; border-top:1px solid var(--line); }
.contact-link { display:flex; align-items:center; justify-content:space-between; padding: 20px 4px; border-bottom:1px solid var(--line); transition: padding-left .35s, color .3s; }
.contact-link:hover { padding-left: 12px; color: var(--accent); }
.contact-link .lab { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color: var(--text-faint); }
.contact-link .val { font-size: 1.15rem; font-weight: 500; }
.contact-link:hover .lab { color: var(--accent); }

.form { border:1px solid var(--line); border-radius: var(--r); padding: clamp(24px,3vw,40px); background: var(--bg-1); }
.field { margin-bottom: 22px; }
.field label { display:block; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color: var(--text-dim); margin-bottom: 10px; }
.field input, .field textarea, .field select {
  width:100%; background: transparent; border:none; border-bottom:1px solid var(--line-2); padding: 11px 2px;
  color: var(--text); font-family: var(--sans); font-size: 1rem; transition: border-color .3s;
}
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-bottom-color: var(--accent); }
.field textarea { resize: vertical; min-height: 96px; }
.field select option { background: var(--panel); color: var(--text); }
.ptype { display:flex; flex-wrap:wrap; gap:8px; }
.ptype label { display:none; }
.ptype .opt { font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:9px 15px; border:1px solid var(--line-2); border-radius:100px; color:var(--text-dim); cursor:pointer; transition:.25s; }
.ptype .opt.sel { background: var(--accent); color:#120a06; border-color: var(--accent); }
.form .btn-primary { width:100%; justify-content:center; margin-top: 8px; }
.form-note { font-family:var(--mono); font-size:11px; color: var(--text-faint); margin-top: 16px; text-align:center; letter-spacing:.04em; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { border-top:1px solid var(--line); padding-block: 56px 38px; }
.footer-top { display:flex; justify-content:space-between; align-items:flex-start; gap: 40px; flex-wrap:wrap; }
.footer .display { font-size: clamp(2rem,5vw,3.4rem); }
.footer-socials { display:flex; gap: 10px; flex-wrap:wrap; }
.footer-socials a { font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:10px 16px; border:1px solid var(--line-2); border-radius:100px; transition:.25s; }
.footer-socials a:hover { border-color: var(--accent); color: var(--accent); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; margin-top: 50px; padding-top: 24px; border-top:1px solid var(--line); flex-wrap:wrap; gap: 14px; }
.footer-bottom span { font-family:var(--mono); font-size:11px; color: var(--text-faint); letter-spacing:.04em; }
.footer-bottom a.admin-link { color: var(--text-faint); font-family: var(--mono); font-size: 11px; }
.footer-bottom a.admin-link:hover { color: var(--accent); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
[data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal][data-d="1"] { transition-delay: .08s; }
[data-reveal][data-d="2"] { transition-delay: .16s; }
[data-reveal][data-d="3"] { transition-delay: .24s; }
[data-reveal][data-d="4"] { transition-delay: .32s; }

/* lang visibility */
[data-lang-fr] { display: none; }
:root[data-lang="fr"] [data-lang-en] { display: none; }
:root[data-lang="fr"] [data-lang-fr] { display: revert; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-media { max-width: 380px; }
  .about-grid { grid-template-columns: 1fr; }
  .about-portrait { position: relative; top: 0; max-width: 440px; }
  .quotes { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .s-4, .s-5, .s-6, .s-7, .s-8 { grid-column: span 6; }
}
@media (max-width: 720px) {
  .nav-links, .nav .btn span.hidesm { display: none; }
  .burger { display: block; }
  .nav-mobile { position: fixed; inset: 0; z-index: 190; background: var(--bg); display:flex; flex-direction:column; justify-content:center; gap: 8px; padding: var(--gut); transform: translateX(100%); transition: transform .5s cubic-bezier(.2,.8,.2,1); }
  .nav-mobile.open { transform: none; }
  .nav-mobile a { font-family: var(--serif); font-size: 2.4rem; color: var(--text); }
  .nav-mobile a span { font-family: var(--mono); font-size: 12px; color: var(--text-faint); margin-right: 14px; }
  .work-grid { gap: 16px; }
  .s-3, .s-4, .s-5, .s-6, .s-7, .s-8 { grid-column: span 12; }
  .creds { grid-template-columns: 1fr; }
  .quotes { grid-template-columns: 1fr; }
  .hero-meta { gap: 24px; }
  .display { font-size: clamp(2.6rem, 13vw, 5rem); }
}
@media (min-width: 721px) { .nav-mobile { display: none; } }

/* ============================================================
   VIDEO LIGHTBOX
   ============================================================ */
.work.has-video { cursor: pointer; }
.lightbox {
  position: fixed; inset: 0; z-index: 500; display: none;
  align-items: center; justify-content: center; padding: clamp(16px, 5vw, 60px);
  background: rgba(5,4,3,.86); backdrop-filter: blur(10px);
  opacity: 0; transition: opacity .3s ease;
}
.lightbox.open { display: flex; opacity: 1; }
.lightbox-inner {
  position: relative; width: min(1100px, 100%); aspect-ratio: 16/9;
  border-radius: var(--r); overflow: hidden; box-shadow: var(--shadow);
  background: #000;
}
.lightbox-inner iframe, .lightbox-inner video { width: 100%; height: 100%; border: 0; display: block; }
.lightbox-close {
  position: absolute; top: 22px; right: 26px; z-index: 2;
  width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--line-2);
  background: rgba(0,0,0,.5); color: var(--text); font-size: 18px;
  display: grid; place-items: center; transition: .25s;
}
.lightbox-close:hover { border-color: var(--accent); color: var(--accent); transform: rotate(90deg); }

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.skip-link {
  position: absolute; left: 12px; top: -60px; z-index: 9999;
  background: var(--accent); color: #120a06; padding: 10px 18px; border-radius: 8px;
  font-family: var(--mono); font-size: 12px; letter-spacing: .06em; transition: top .2s;
}
.skip-link:focus { top: 12px; outline: none; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 3px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
}
