/* ─────────────────────────────────────────────
   Shared styles for Ashley Rudder case-detail pages
   (dark portfolio aesthetic — matches index.html)
   ───────────────────────────────────────────── */
:root {
  --bg: #0A0908; --bg-deep: #050504; --surface: #131110; --surface-2: #1B1815;
  --ink: #F4F1EA; --ink-soft: #CFC9BD; --ink-muted: #8C857A; --ink-faint: #5E574D;
  --hair: rgba(244,241,234,0.12); --hair-soft: rgba(244,241,234,0.07);
  --accent: #C6A24C; --accent-deep: #A07F2E; --accent-soft: rgba(198,162,76,0.14); --gold: #C9A268;
  --ease: cubic-bezier(0.2,0.7,0.2,1);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; background: var(--bg); }
body {
  background: var(--bg); color: var(--ink);
  font-family: 'Playfair Display', Didot, 'Cormorant Garamond', Georgia, serif;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow-x: hidden;
}
body::before { content:''; position:fixed; inset:0; pointer-events:none; z-index:1; opacity:0.5;
  background-image: radial-gradient(circle at 17% 28%, rgba(255,250,240,0.035) 1px, transparent 1.6px), radial-gradient(circle at 71% 62%, rgba(255,250,240,0.030) 1px, transparent 1.6px), radial-gradient(circle at 41% 81%, rgba(255,250,240,0.024) 1px, transparent 1.6px);
  background-size: 47px 47px, 63px 63px, 89px 89px; }
body::after { content:''; position:fixed; inset:0; pointer-events:none; z-index:1;
  background: radial-gradient(ellipse 120% 80% at 50% -10%, rgba(198,162,76,0.08), transparent 55%), radial-gradient(ellipse at center, transparent 38%, rgba(0,0,0,0.55) 100%); }
.mono { font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace; }
.accent { color: var(--accent); }
a { color: inherit; text-decoration: none; }

.corner { position: fixed; width: 40px; height: 40px; z-index: 60; pointer-events: none; }
.corner::before, .corner::after { content:''; position:absolute; background: var(--ink); opacity:0.7; }
.corner::before { width:100%; height:1px; } .corner::after { height:100%; width:1px; }
.corner-tl{top:16px;left:16px}.corner-tl::before{top:0;left:0}.corner-tl::after{top:0;left:0}
.corner-tr{top:16px;right:16px}.corner-tr::before{top:0;right:0}.corner-tr::after{top:0;right:0}
.corner-bl{bottom:16px;left:16px}.corner-bl::before{bottom:0;left:0}.corner-bl::after{bottom:0;left:0}
.corner-br{bottom:16px;right:16px}.corner-br::before{bottom:0;right:0}.corner-br::after{bottom:0;right:0}
.hud { position: fixed; bottom: 22px; right: 26px; z-index: 60; font-size: 9px; letter-spacing: 2px; color: var(--ink-faint); pointer-events: none; }
.hud .sep { margin: 0 7px; opacity: 0.5; }

nav { position: sticky; top: 0; z-index: 50; display: flex; align-items: center; justify-content: space-between; padding: 22px 70px; transition: padding 0.4s var(--ease), background 0.4s, border-color 0.4s; }
nav.scrolled { padding: 14px 70px; background: rgba(10,9,8,0.72); backdrop-filter: blur(14px) saturate(120%); -webkit-backdrop-filter: blur(14px) saturate(120%); border-bottom: 1px solid var(--hair); }
.brand { font-family:'Playfair Display',Didot,serif; font-style:italic; font-size:17px; letter-spacing:0.3px; color:var(--ink); white-space:nowrap; }
.brand .dot { color: var(--accent); font-style: normal; }
.nav-links { display: flex; align-items: center; gap: 26px; }
.nav-links a { font-family:'JetBrains Mono',monospace; font-size:10.5px; letter-spacing:2.4px; text-transform:uppercase; color:var(--ink-muted); transition:color 0.25s; }
.nav-links a:hover { color: var(--ink); }
.nav-cta { border:1px solid var(--hair); padding:9px 18px; border-radius:2px; color:var(--ink); transition:border-color 0.25s, background 0.25s; }
.nav-cta:hover { border-color: var(--accent); background: var(--accent-soft); }

.wrap { max-width: 1180px; margin: 0 auto; padding: 0 70px; position: relative; z-index: 2; }
section { position: relative; z-index: 2; }

.btn { font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:2.4px; text-transform:uppercase; padding:15px 26px; border-radius:2px; display:inline-flex; align-items:center; gap:10px; transition:all 0.3s var(--ease); }
.btn-primary { background: var(--accent); color: #120a06; border: 1px solid var(--accent); }
.btn-primary:hover { background:#DEC074; border-color:#DEC074; box-shadow:0 0 0 1px rgba(198,162,76,0.4), 0 14px 40px -12px rgba(198,162,76,0.7); transform: translateY(-2px); }
.btn-ghost { color: var(--ink); border: 1px solid var(--hair); }
.btn-ghost:hover { border-color: var(--ink-muted); transform: translateY(-2px); }
.btn .arr { transition: transform 0.3s var(--ease); }
.btn:hover .arr { transform: translate(3px,-3px); }

.rv { opacity:0; transform: translateY(20px); transition: opacity 0.9s var(--ease), transform 0.9s var(--ease); }
.rv.in { opacity:1; transform:none; }

.sec-head { display:flex; align-items:baseline; gap:22px; margin-bottom:42px; padding-bottom:22px; border-bottom:1px solid var(--hair); }
.kick { font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--accent); white-space:nowrap; }
.sec-title { font-family:'Playfair Display',Didot,serif; font-style:italic; font-weight:400; font-size:clamp(26px,3.6vw,44px); letter-spacing:-1px; line-height:1; }
.sec-title em { color: var(--accent); font-weight:500; }
.sec-title .period { color: var(--ink); font-style: normal; }
.sec-note { margin-left:auto; font-family:'JetBrains Mono',monospace; font-size:9.5px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint); align-self:flex-end; padding-bottom:4px; }

.hero { padding: 140px 0 70px; }
.eyebrow { font-family:'JetBrains Mono',monospace; font-size:10.5px; letter-spacing:3.5px; text-transform:uppercase; color:var(--accent); margin-bottom:34px; display:flex; align-items:center; gap:14px; }
.eyebrow .ln { width:46px; height:1px; background:var(--accent); opacity:0.6; }
.hero h1 { font-family:'Playfair Display',Didot,serif; font-style:italic; font-weight:400; font-size:clamp(34px,5.4vw,76px); line-height:1.0; letter-spacing:-1.5px; max-width:15ch; margin-bottom:30px; }
.hero h1 em { color: var(--accent); font-weight:500; }
.hero h1 .period { color: var(--ink); font-style: normal; }
.hero-sub { font-family:'Playfair Display',Georgia,serif; font-size:clamp(16px,1.9vw,22px); line-height:1.5; color:var(--ink-soft); max-width:54ch; margin-bottom:46px; }
.hero-sub b { color: var(--ink); font-weight:600; font-style:italic; }
.hero-meta { display:flex; flex-wrap:wrap; gap:34px; padding-top:30px; border-top:1px solid var(--hair); }
.hero-meta .k { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint); display:block; margin-bottom:7px; }
.hero-meta .v { font-family:'Playfair Display',serif; font-style:italic; font-size:17px; color:var(--ink); }

.roi-banner { display:flex; align-items:center; gap:clamp(20px,4vw,60px); flex-wrap:wrap; margin:44px 0 0; padding:34px 0; }
.roi-banner .from { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(34px,5vw,60px); color:var(--ink-muted); letter-spacing:-2px; }
.roi-banner .arrow { font-family:'JetBrains Mono',monospace; color:var(--accent); font-size:24px; }
.roi-banner .to { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(48px,8vw,110px); color:var(--accent); letter-spacing:-3px; line-height:0.85; }
.roi-banner .lab { font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-muted); max-width:18ch; line-height:1.6; }

.film { position: relative; width: 100%; aspect-ratio: 16/9; overflow:hidden; cursor:pointer; background:#000; border-top:1px solid var(--hair); border-bottom:1px solid var(--hair); }
.film .poster { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition: transform 0.6s var(--ease), opacity 0.4s; }
.film:hover .poster { transform: scale(1.03); }
.film .scrim { position:absolute; inset:0; background: linear-gradient(180deg, rgba(10,9,8,0.4) 0%, rgba(10,9,8,0.1) 40%, rgba(10,9,8,0.7) 100%); pointer-events:none; }
.film .play { position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:90px; height:90px; border-radius:999px; background:rgba(244,241,234,0.1); border:1px solid rgba(244,241,234,0.55); backdrop-filter:blur(5px); -webkit-backdrop-filter:blur(5px); display:grid; place-items:center; transition: transform 0.3s var(--ease), background 0.3s, border-color 0.3s; }
.film:hover .play { background:var(--accent); border-color:var(--accent); transform:translate(-50%,-50%) scale(1.07); }
.film .play svg { width:28px; height:28px; margin-left:5px; fill:var(--ink); transition:fill 0.3s; }
.film:hover .play svg { fill:#120a06; }
.film .play .ring { position:absolute; inset:-1px; border-radius:999px; border:1px solid rgba(244,241,234,0.4); animation: pulse 2.6s ease-out infinite; }
@keyframes pulse { 0%{transform:scale(1);opacity:0.7} 100%{transform:scale(1.4);opacity:0} }
.film .cap { position:absolute; left:30px; bottom:24px; z-index:2; font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-soft); pointer-events:none; }

.block { padding: 96px 0; }
.block.tight { padding: 64px 0; }
.prose { max-width: 720px; }
.prose p { font-family:'Playfair Display',Georgia,serif; font-size:clamp(17px,1.9vw,21px); line-height:1.62; color:var(--ink-soft); margin-bottom:24px; }
.prose p b { color: var(--ink); font-weight:600; }
.prose .lede { color: var(--ink); }
.cols { display:grid; grid-template-columns: 1fr 1fr; gap:56px; }

.results { display:grid; grid-template-columns: repeat(4,1fr); gap:0; border:1px solid var(--hair); }
.rcell { padding:40px 30px; border-right:1px solid var(--hair); }
.rcell:last-child { border-right:none; }
.rcell .n { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(34px,4.4vw,52px); color:var(--ink); letter-spacing:-2px; line-height:0.9; display:block; margin-bottom:14px; }
.rcell .n .u { color: var(--accent); font-style:normal; font-size:0.5em; }
.rcell .l { font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--ink-muted); line-height:1.5; }

.strip { display:grid; grid-template-columns: repeat(3,1fr); gap:14px; }
.strip img { width:100%; aspect-ratio: 9/12; object-fit:cover; border:1px solid var(--hair); filter: saturate(1.02); }

.pull { max-width:900px; margin:0 auto; text-align:center; }
.pull q { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(24px,3.4vw,40px); line-height:1.25; color:var(--ink); quotes:none; letter-spacing:-0.5px; }
.pull q .accent { color: var(--accent); }
.pull .by { margin-top:24px; font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint); }

.recog { display:flex; gap:10px; flex-wrap:wrap; margin-top:38px; }
.recog .badge { font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--ink-soft); border:1px solid var(--hair); border-radius:2px; padding:10px 16px; }
.recog .badge .star { color: var(--accent); margin-right:6px; }

.close { padding: 110px 0; text-align:center; }
.close h2 { font-family:'Playfair Display',serif; font-style:italic; font-weight:400; font-size:clamp(28px,4.6vw,60px); line-height:1.04; letter-spacing:-1.4px; max-width:18ch; margin:0 auto 30px; }
.close h2 em { color: var(--accent); font-weight:500; }
.close h2 .period { color: var(--ink); font-style: normal; }
.close .recog { justify-content:center; }
.close .cbtns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:40px; }

.nextcase { border-top:1px solid var(--hair); padding:40px 70px; display:flex; align-items:center; justify-content:space-between; gap:24px; transition: background 0.3s; }
.nextcase:hover { background: var(--surface); }
.nextcase .nl { font-family:'JetBrains Mono',monospace; font-size:9.5px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint); }
.nextcase .nt { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(22px,3vw,38px); color:var(--ink); }
.nextcase .na { font-family:'JetBrains Mono',monospace; color:var(--ink-faint); font-size:22px; transition: transform 0.3s var(--ease), color 0.3s; }
.nextcase:hover .na { transform: translateX(6px); color: var(--accent); }

footer { border-top:1px solid var(--hair); padding:40px 70px; }
.foot-grid { max-width:1180px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.foot-social { display:flex; gap:22px; }
.foot-social a { font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-muted); transition:color 0.25s; }
.foot-social a:hover { color: var(--accent); }
.foot-meta { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:1.5px; color:var(--ink-faint); }

/* full-frame film lightbox */
.filmbox { position:fixed; inset:0; z-index:200; background:rgba(5,5,4,0.95); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); display:none; align-items:center; justify-content:center; padding:3vw; }
.filmbox.open { display:flex; }
.filmbox-frame { width:min(1500px,95vw); aspect-ratio:16/9; max-height:90vh; background:#000; border:1px solid var(--hair); box-shadow:0 50px 130px -28px rgba(0,0,0,0.9); }
.filmbox-frame video { width:100%; height:100%; display:block; object-fit:contain; background:#000; }
.filmbox-cap { position:absolute; left:0; right:0; bottom:24px; text-align:center; font-family:'JetBrains Mono',monospace; font-size:9.5px; letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint); }
.filmbox-close { position:absolute; top:22px; right:26px; width:44px; height:44px; border-radius:999px; background:none; border:1px solid var(--hair); color:var(--ink); font-size:15px; cursor:pointer; font-family:'JetBrains Mono',monospace; transition:border-color 0.2s, background 0.2s; }
.filmbox-close:hover { border-color:var(--accent); background:var(--accent-soft); }

@media (max-width: 880px) {
  nav, nav.scrolled { padding: 16px 22px; }
  .nav-links { gap: 14px; }
  .wrap { padding: 0 22px; }
  .cols { grid-template-columns: 1fr; gap: 22px; }
  .results { grid-template-columns: 1fr 1fr; }
  .rcell:nth-child(2) { border-right:none; }
  .rcell { border-bottom:1px solid var(--hair); }
  .strip { grid-template-columns: 1fr 1fr !important; }
  .nextcase, footer { padding: 30px 22px; }
  .roi-banner .to { font-size: 64px; }
}
@media (prefers-reduced-motion: reduce){ .rv{opacity:1!important;transform:none!important} .film .play .ring{animation:none} }
