/*
Theme Name: Sinfull Studios
Theme URI: https://sinfullstudios.com
Author: Robert Slinn
Author URI: https://sinfullstudios.com
Description: Custom theme for Sinfull Studios — Seven Sins brand architecture
Version: 1.0.5
License: Proprietary
Text Domain: sinfull-studios
*/

/* ===== Sinfull Studios — Homepage Wireframe ===== */
:root {
  --red: #C8102E;
  --red-deep: #8A0B20;
  --red-glow: #E8243F;
  --ink: #0E0E10;
  --ink-2: #1A1A1A;
  --ink-3: #232326;
  --bone: #F4F1EC;
  --bone-2: #E8E3DA;
  --grey: #777777;
  --grey-2: #4A4A4A;
  --grey-3: #2A2A2D;
  --line: rgba(255,255,255,0.08);
  --line-strong: rgba(255,255,255,0.18);

  --f-display: "Bodoni Moda", "Didot", "Playfair Display", Georgia, serif;
  --f-sans: "Inter Tight", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--ink);
  color: var(--bone);
  font-family: var(--f-sans);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

.utility-bar {
  background: #050505;
  color: rgba(244,241,236,0.78);
  font-size: 12px;
  font-family: var(--f-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 8px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--line);
}
.utility-bar .ub-left, .utility-bar .ub-right { display: flex; gap: 24px; align-items: center; }
.utility-bar .ub-right { flex-wrap: wrap; justify-content: flex-end; }
.utility-bar .ub-right a { opacity: 0.82; transition: opacity 0.15s ease, color 0.15s ease; }
.utility-bar .ub-right a:hover { opacity: 1; color: var(--bone); }
.utility-bar .ub-pulse { display: inline-flex; align-items: center; gap: 8px; }
.utility-bar .ub-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--red); box-shadow: 0 0 8px var(--red);
  animation: pulse 1.6s infinite;
}
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.35; } }

.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(14,14,16,0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 16px 28px;
  max-width: 1440px; margin: 0 auto;
}
.brand { display: flex; align-items: center; gap: 14px; }
.brand-mark {
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--bone); display: grid; place-items: center;
  overflow: hidden; flex-shrink: 0;
}
.brand-mark img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.05); }
.brand-name { font-family: var(--f-display); font-weight: 600; font-size: 22px; letter-spacing: 0.02em; white-space: nowrap; }
.brand-name em { font-style: italic; color: var(--red); }

.nav-links { display: flex; gap: 2px; align-items: center; font-size: 13px; letter-spacing: 0.01em; white-space: nowrap; flex-wrap: nowrap; }
.nav-link { padding: 7px 11px; border-radius: 999px; display: inline-flex; align-items: center; gap: 5px; transition: background 0.15s ease; position: relative; white-space: nowrap; }
.nav-link:hover { background: var(--ink-3); }
.nav-link .caret { font-size: 9px; opacity: 0.5; }
.nav-link.desires { color: var(--red); border: 1px solid rgba(200,16,46,0.4); }
.nav-link.desires:hover { background: rgba(200,16,46,0.12); }
.nav-cta { background: var(--red); color: var(--bone); padding: 10px 18px; border-radius: 999px; font-weight: 500; border: none; font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; transition: background 0.15s ease; }
.nav-cta:hover { background: var(--red-glow); }

.nav-link .dropdown { position: absolute; top: calc(100% + 8px); left: 0; background: var(--ink-2); border: 1px solid var(--line); border-radius: 12px; padding: 10px; min-width: 240px; opacity: 0; pointer-events: none; transform: translateY(-4px); transition: all 0.15s ease; display: flex; flex-direction: column; z-index: 100; }
.nav-link:hover .dropdown { opacity: 1; pointer-events: auto; transform: translateY(0); }
.dropdown a { padding: 10px 12px; border-radius: 8px; font-size: 13px; display: flex; justify-content: space-between; align-items: center; }
.dropdown a:hover { background: var(--ink-3); color: var(--red-glow); }
.dropdown a span { font-family: var(--f-mono); font-size: 11px; opacity: 0.6; }

.hero { position: relative; padding: 72px 32px 48px; max-width: 1440px; margin: 0 auto; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; align-items: end; }
.hero-eyebrow { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--grey); display: flex; align-items: center; gap: 12px; margin-bottom: 28px; }
.hero-eyebrow::before { content: ""; width: 32px; height: 1px; background: var(--red); }
.hero h1 { font-family: var(--f-display); font-weight: 500; font-size: clamp(52px, 7vw, 104px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 28px; }
.hero h1 .it { font-style: italic; color: var(--red); }
.hero h1 .strike { position: relative; display: inline-block; }
.hero h1 .strike::after { content: ""; position: absolute; left: -4px; right: -4px; top: 52%; height: 4px; background: var(--red); transform: rotate(-2deg); }
.hero-sub { max-width: 540px; font-size: 18px; color: rgba(244,241,236,0.82); line-height: 1.55; margin-bottom: 36px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.btn { padding: 14px 22px; border-radius: 4px; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; font-weight: 500; border: 1px solid transparent; transition: all 0.15s ease; display: inline-flex; align-items: center; gap: 10px; }
.btn-primary { background: var(--red); color: var(--bone); }
.btn-primary:hover { background: var(--red-glow); transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--bone); border-color: var(--line-strong); }
.btn-ghost:hover { border-color: var(--bone); background: rgba(255,255,255,0.04); }
.btn .arrow { transition: transform 0.15s ease; }
.btn:hover .arrow { transform: translate(2px, -2px); }

.hero-side { font-family: var(--f-mono); font-size: 12px; color: var(--grey); border-left: 1px solid var(--line-strong); padding-left: 24px; }
.hero-side dl { margin: 0; display: grid; gap: 18px; }
.hero-side dt { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(244,241,236,0.4); margin-bottom: 4px; }
.hero-side dd { margin: 0; font-size: 13px; color: var(--bone); }
.hero-side .live-tag { display: inline-flex; align-items: center; gap: 8px; padding: 4px 10px; background: var(--red); color: var(--bone); border-radius: 3px; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; }
.hero-side .live-tag .ldot { width: 6px; height: 6px; border-radius: 50%; background: var(--bone); animation: pulse 1.4s infinite; }

.ticker { margin-top: 64px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); overflow: hidden; white-space: nowrap; padding: 18px 0; font-family: var(--f-display); font-style: italic; font-size: 36px; font-weight: 400; color: rgba(244,241,236,0.55); }
.ticker-track { display: inline-block; animation: marquee 38s linear infinite; }
.ticker-track span { margin-right: 48px; }
.ticker-track .pip { color: var(--red); margin-right: 48px; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

.section { padding: 96px 32px; max-width: 1440px; margin: 0 auto; }
.section-head { display: flex; justify-content: space-between; align-items: end; gap: 32px; margin-bottom: 48px; border-bottom: 1px solid var(--line); padding-bottom: 24px; }
.section-head h2 { font-family: var(--f-display); font-weight: 500; font-size: clamp(36px, 5vw, 64px); letter-spacing: -0.02em; line-height: 1; margin: 0; }
.section-head h2 em { color: var(--red); font-style: italic; }
.section-head .num { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--grey); text-transform: uppercase; margin-bottom: 18px; display: block; }
.section-head .lede { max-width: 440px; color: rgba(244,241,236,0.8); font-size: 16px; line-height: 1.55; }

.sins { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: repeat(2, 1fr); gap: 2px; background: var(--line); border: 1px solid var(--line); }
.sin { background: var(--ink-2); padding: 32px 28px 28px; min-height: 280px; position: relative; cursor: pointer; overflow: hidden; display: flex; flex-direction: column; justify-content: space-between; transition: background 0.25s ease; text-align: left; border: none; color: inherit; font: inherit; }
.sin:hover { background: var(--ink-3); }
.sin:hover .sin-name { color: var(--red); }
.sin-bg { position: absolute; inset: 0; font-family: var(--f-display); font-style: italic; font-weight: 400; font-size: 240px; line-height: 0.85; color: var(--red); opacity: 0.06; pointer-events: none; transition: all 0.45s cubic-bezier(.2,.8,.2,1); display: flex; align-items: center; justify-content: center; letter-spacing: -0.04em; }
.sin-num { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--grey); text-transform: uppercase; }
.sin-body { position: relative; z-index: 1; }
.sin-name { font-family: var(--f-display); font-style: italic; font-weight: 500; font-size: 38px; line-height: 1; letter-spacing: -0.01em; margin: 8px 0 6px; transition: color 0.15s ease; }
.sin-promise { font-size: 15px; color: rgba(244,241,236,0.85); line-height: 1.45; margin-bottom: 20px; max-width: 26ch; }
.sin-sectors { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--grey); display: flex; flex-wrap: wrap; gap: 4px 10px; }
.sin-sectors span::after { content: "·"; margin-left: 10px; color: var(--red); }
.sin-sectors span:last-child::after { content: ""; }
.sin-arrow { position: absolute; top: 24px; right: 24px; width: 28px; height: 28px; display: grid; place-items: center; border: 1px solid var(--line-strong); border-radius: 50%; font-size: 11px; opacity: 0.4; transition: all 0.2s ease; z-index: 2; }
.sin:hover .sin-arrow { transform: translate(4px, -4px); opacity: 1; }
.sin:hover .sin-bg { opacity: 0.18; transform: scale(1.04); }

.sin.eighth { background: var(--ink); border: 1px dashed var(--line-strong); display: flex; align-items: center; justify-content: center; text-align: center; cursor: default; }
.sin.eighth:hover { background: var(--ink); }
.sin.eighth .eighth-inner { font-family: var(--f-display); font-style: italic; font-size: 22px; line-height: 1.2; color: rgba(244,241,236,0.5); max-width: 22ch; }
.sin.eighth small { display: block; font-family: var(--f-mono); font-style: normal; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--grey); margin-top: 10px; }

.stream { background: linear-gradient(180deg, #050505 0%, var(--ink-2) 100%); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding-top: 96px; padding-bottom: 96px; }
.stream-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 24px; margin-top: 24px; }
.stream-main { background: #000; border: 1px solid var(--line-strong); aspect-ratio: 16/9; position: relative; overflow: hidden; width: 100%; }
.stream-main::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 40%, rgba(200,16,46,0.4) 0%, transparent 50%), radial-gradient(ellipse at 70% 60%, rgba(120,20,180,0.3) 0%, transparent 60%), linear-gradient(135deg, #1a0608, #2a0a14); }
.stream-overlay { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 24px; z-index: 2; }
.stream-top { display: flex; justify-content: space-between; align-items: start; }
.stream-live { background: var(--red); color: var(--bone); padding: 6px 12px; border-radius: 3px; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; display: inline-flex; align-items: center; gap: 8px; }
.stream-live .ldot { width: 6px; height: 6px; background: var(--bone); border-radius: 50%; animation: pulse 1.4s infinite; }
.stream-meta { font-family: var(--f-mono); font-size: 11px; color: rgba(244,241,236,0.7); text-align: right; }
.stream-bottom { display: flex; justify-content: space-between; align-items: end; }
.stream-title { font-family: var(--f-display); font-style: italic; font-size: 36px; font-weight: 500; line-height: 1; margin: 0 0 8px; max-width: 80%; }
.stream-game { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(244,241,236,0.6); }
.stream-watch { background: var(--bone); color: var(--ink); padding: 12px 18px; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600; display: inline-flex; gap: 10px; align-items: center; border: none; }
.stream-side { display: grid; gap: 16px; }
.stream-card { background: var(--ink-2); border: 1px solid var(--line); padding: 18px; display: flex; flex-direction: column; gap: 12px; cursor: pointer; transition: border-color 0.15s ease; width: 100%; text-align: left; }
.stream-card:hover { border-color: var(--red); }
.stream-card-head { display: flex; justify-content: space-between; align-items: center; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--grey); }
.stream-card-head .platform { color: var(--bone); display: inline-flex; align-items: center; gap: 8px; }
.stream-card-head .pdot { width: 6px; height: 6px; border-radius: 50%; }
.pdot.yt { background: #FF0033; }
.pdot.tt { background: #00F2EA; }
.stream-thumb { aspect-ratio: 16/9; background: linear-gradient(135deg, #1f1f24, #0a0a0d); border: 1px solid var(--line); position: relative; overflow: hidden; }
.stream-thumb.yt::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 30%, rgba(255,0,51,0.25) 0%, transparent 60%), linear-gradient(135deg, #1a0a0a, #0a0a0d); }
.stream-thumb.tt::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 70%, rgba(0,242,234,0.2) 0%, transparent 60%), linear-gradient(135deg, #0a1a1a, #100020); }
.stream-thumb .duration { position: absolute; bottom: 8px; right: 8px; background: rgba(0,0,0,0.7); font-family: var(--f-mono); font-size: 10px; padding: 2px 6px; letter-spacing: 0.06em; }
.stream-card-title { font-size: 14px; font-weight: 500; line-height: 1.3; }
.stream-card-meta { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--grey); text-transform: uppercase; }

.services { padding-top: 96px; padding-bottom: 96px; }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.service-card { background: var(--ink); padding: 28px; cursor: pointer; display: flex; flex-direction: column; gap: 16px; min-height: 240px; border: none; text-align: left; color: inherit; font: inherit; transition: background 0.2s ease; position: relative; overflow: hidden; width: 100%; }
.service-card:hover { background: var(--ink-2); }
.service-card:hover .svc-arrow { transform: translate(4px, -4px); color: var(--red); }
.svc-tag { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--grey); display: flex; justify-content: space-between; align-items: center; }
.svc-tag .sin-pill { padding: 3px 8px; border: 1px solid rgba(200,16,46,0.4); color: var(--red); border-radius: 999px; font-size: 9px; }
.svc-name { font-family: var(--f-display); font-weight: 500; font-size: 30px; line-height: 1.05; letter-spacing: -0.01em; margin: 0; }
.svc-desc { font-size: 15px; color: rgba(244,241,236,0.82); line-height: 1.5; flex: 1; }
.svc-keywords { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--grey); border-top: 1px solid var(--line); padding-top: 12px; }
.svc-arrow { position: absolute; top: 28px; right: 28px; font-size: 14px; transition: all 0.2s ease; }

.trust { background: var(--bone); color: var(--ink); padding: 48px 32px; }
.trust-inner { max-width: 1440px; margin: 0 auto; display: grid; grid-template-columns: 1fr 2fr; gap: 48px; align-items: center; }
.trust h3 { font-family: var(--f-display); font-style: italic; font-weight: 500; font-size: 28px; margin: 0; line-height: 1.1; }
.trust-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.trust-stat .num { font-family: var(--f-display); font-size: 48px; font-weight: 500; line-height: 1; letter-spacing: -0.02em; color: var(--red); }
.trust-stat .label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--grey-2); margin-top: 8px; }

.vanlife { padding: 96px 32px; max-width: 1440px; margin: 0 auto; }
.vanlife-card { display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; border: 1px solid var(--line); background: var(--ink-2); overflow: hidden; }
.vanlife-img { background: #0a0a0d; min-height: 420px; position: relative; overflow: hidden; display: flex; align-items: end; padding: 32px; }
.vanlife-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(0.85) contrast(1.05); }
.vanlife-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.85) 100%); }
.vanlife-img-meta { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(244,241,236,0.5); position: relative; z-index: 1; }
.vanlife-body { padding: 48px 40px; display: flex; flex-direction: column; justify-content: center; gap: 20px; }
.vanlife-body .eyebrow { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red); }
.vanlife-body h3 { font-family: var(--f-display); font-weight: 500; font-size: 48px; line-height: 1; letter-spacing: -0.02em; margin: 0; }
.vanlife-body h3 em { color: var(--red); font-style: italic; }
.vanlife-body p { color: rgba(244,241,236,0.82); font-size: 16px; line-height: 1.55; margin: 0; }
.vanlife-links { display: flex; gap: 16px; flex-wrap: wrap; }
.vanlife-link { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; border-bottom: 1px solid var(--line-strong); padding-bottom: 4px; }
.vanlife-link:hover { color: var(--red); border-color: var(--red); }

.portfolio { background: #050505; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding-top: 96px; padding-bottom: 96px; }
.portfolio-filters { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 32px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; }
.portfolio-filter { padding: 8px 14px; border: 1px solid var(--line); background: transparent; color: rgba(244,241,236,0.6); border-radius: 999px; cursor: pointer; transition: all 0.15s ease; }
.portfolio-filter:hover { border-color: var(--line-strong); color: var(--bone); }
.portfolio-filter.active { background: var(--red); border-color: var(--red); color: var(--bone); }
.portfolio-grid { display: grid; grid-template-columns: repeat(12, 1fr); grid-auto-rows: 180px; gap: 8px; }
.pf-tile { position: relative; overflow: hidden; cursor: pointer; background: #09090b; border: none; padding: 0; }
.pf-tile img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform 0.6s cubic-bezier(.2,.8,.2,1), filter 0.3s; filter: grayscale(0.15) contrast(1.02); }
.pf-tile:hover img { transform: scale(1.05); filter: grayscale(0) contrast(1.05); }
.pf-tile-meta { position: absolute; left: 0; right: 0; bottom: 0; padding: 16px; background: linear-gradient(0deg, rgba(0,0,0,0.85) 0%, transparent 100%); display: flex; flex-direction: column; gap: 4px; z-index: 2; }
.pf-tile-cat { font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red-glow); }
.pf-tile-name { font-family: var(--f-display); font-style: italic; font-size: 18px; font-weight: 500; color: var(--bone); line-height: 1.1; }
.pf-a { grid-column: span 6; grid-row: span 2; }
.pf-b { grid-column: span 3; grid-row: span 1; }
.pf-c { grid-column: span 3; grid-row: span 1; }
.pf-d { grid-column: span 3; grid-row: span 2; }
.pf-e { grid-column: span 3; grid-row: span 2; }
.pf-f { grid-column: span 4; grid-row: span 1; }
.pf-g { grid-column: span 4; grid-row: span 1; }
.pf-h { grid-column: span 4; grid-row: span 1; }
.pf-i { grid-column: span 6; grid-row: span 2; }
.pf-j { grid-column: span 3; grid-row: span 2; }
.pf-k { grid-column: span 3; grid-row: span 2; }

.animals { padding: 96px 32px; max-width: 1440px; margin: 0 auto; }
.animals-card { display: grid; grid-template-columns: 1fr 1.2fr; gap: 32px; border: 1px solid var(--line); background: var(--ink-2); overflow: hidden; }
.animals-img { background: #0a0a0d; min-height: 440px; position: relative; overflow: hidden; display: flex; align-items: end; padding: 28px; }
.animals-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(0.78) contrast(1.05); }
.animals-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.85) 100%); }
.animals-img-meta { position: relative; z-index: 1; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(244,241,236,0.65); }
.animals-body { padding: 48px 40px; display: flex; flex-direction: column; justify-content: center; gap: 18px; }
.animals-body .eyebrow { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red); }
.animals-body h3 { font-family: var(--f-display); font-weight: 500; font-size: clamp(36px, 4vw, 52px); line-height: 1; letter-spacing: -0.02em; margin: 0; }
.animals-body h3 em { color: var(--red); font-style: italic; }
.animals-body p { color: rgba(244,241,236,0.7); font-size: 15px; line-height: 1.55; margin: 0; max-width: 56ch; }
.animals-pills { display: flex; flex-wrap: wrap; gap: 8px; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; margin-top: 4px; }
.animals-pill { padding: 6px 12px; border: 1px solid var(--line-strong); border-radius: 999px; color: rgba(244,241,236,0.75); }
.animals-pill.accent { border-color: var(--red); color: var(--red); }
.animals-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 12px; }

.founder { padding: 96px 32px; max-width: 1440px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px; align-items: center; }
.founder-img { aspect-ratio: 1/1; background: var(--ink-2); overflow: hidden; position: relative; border: 1px solid var(--line); }
.founder-img img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.08); }
.founder-img::after { content: "Robert Slinn — founder"; position: absolute; left: 16px; bottom: 16px; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(244,241,236,0.7); background: rgba(0,0,0,0.6); padding: 6px 10px; }
.founder-body .eyebrow { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red); margin-bottom: 16px; }
.founder-body h2 { font-family: var(--f-display); font-weight: 500; font-size: clamp(36px, 4.5vw, 56px); line-height: 1; letter-spacing: -0.02em; margin: 0 0 24px; }
.founder-body h2 em { color: var(--red); font-style: italic; }
.founder-body p { font-size: 15px; color: rgba(244,241,236,0.7); line-height: 1.6; max-width: 56ch; margin: 0 0 16px; }
.founder-quote { font-family: var(--f-display); font-style: italic; font-size: 20px; color: var(--bone); border-left: 2px solid var(--red); padding-left: 20px; margin: 28px 0 0; max-width: 50ch; }

.footer { background: #050505; border-top: 1px solid var(--line); padding: 64px 32px 32px; }
.footer-inner { max-width: 1440px; margin: 0 auto; display: grid; grid-template-columns: 1.5fr repeat(4, 1fr); gap: 48px; }
.footer h4 { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--grey); margin: 0 0 16px; font-weight: 500; }
.footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; font-size: 13px; }
.footer li a { color: rgba(244,241,236,0.7); }
.footer li a:hover { color: var(--red); }
.footer-brand { max-width: 280px; }
.footer-brand p { font-family: var(--f-display); font-style: italic; font-size: 18px; color: rgba(244,241,236,0.7); line-height: 1.3; margin-top: 16px; }
.footer-bottom { max-width: 1440px; margin: 64px auto 0; border-top: 1px solid var(--line); padding-top: 24px; display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--grey); }

.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.75); backdrop-filter: blur(8px); z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 24px; animation: fadeIn 0.2s ease; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.nav-burger { display: none; background: transparent; border: 1px solid var(--line-strong); color: var(--bone); width: 38px; height: 38px; border-radius: 999px; align-items: center; justify-content: center; font-size: 14px; margin-right: 8px; }
.mobile-menu { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: var(--ink); z-index: 200; padding: 80px 28px 32px; overflow-y: auto; overscroll-behavior: contain; display: flex; flex-direction: column; gap: 8px; }
.mobile-menu a { padding: 14px 16px; border-bottom: 1px solid var(--line); font-family: var(--f-display); font-size: 22px; font-weight: 500; line-height: 1.1; }
.mobile-menu a.desires { color: var(--red); }

@media (max-width: 1180px) { .nav-links { display: none; } .nav-cta { padding: 9px 14px; font-size: 12px; } .nav-burger { display: inline-flex; } }
@media (max-width: 1100px) { .sins { grid-template-columns: repeat(2, 1fr); grid-template-rows: auto; } .services-grid { grid-template-columns: repeat(2, 1fr); } .stream-grid { grid-template-columns: 1fr; } .vanlife-card { grid-template-columns: 1fr; } .hero-grid { grid-template-columns: 1fr; gap: 32px; } .footer-inner { grid-template-columns: 1fr 1fr; } .trust-inner { grid-template-columns: 1fr; } .trust-stats { grid-template-columns: repeat(2, 1fr); } .animals-card { grid-template-columns: 1fr; } .founder { grid-template-columns: 1fr; gap: 32px; } }
@media (max-width: 640px) { .sins { grid-template-columns: 1fr; } .services-grid { grid-template-columns: 1fr; } .section { padding: 64px 20px; } .hero { padding: 48px 20px 32px; } .utility-bar { padding: 8px 20px; gap: 12px; } .utility-bar .ub-right { display: none; } .portfolio-grid { grid-template-columns: repeat(6, 1fr); } .portfolio-grid > * { grid-column: span 6 !important; grid-row: span 1 !important; } }


@media (max-width: 1100px) {
  .portfolio-grid { grid-template-columns: repeat(6, 1fr); }
  .pf-a { grid-column: span 6; }
  .pf-b, .pf-c, .pf-f, .pf-g, .pf-h, .pf-d, .pf-e, .pf-i, .pf-j, .pf-k { grid-column: span 3; }
}

@media (max-width: 640px) {
  .portfolio-grid { grid-template-columns: 1fr; grid-auto-rows: minmax(220px, auto); }
  .portfolio-grid > * { grid-column: span 1 !important; grid-row: span 1 !important; }
}

/* =============================================
   INNER PAGE STYLES
   ============================================= */
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--bone);transition:.3s}
@media(max-width:768px){
  .nav-hamburger{display:flex}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--black);flex-direction:column;padding:1.5rem 2rem;gap:1rem}
  .nav-links.open{display:flex}
}
.page-main{padding-top:72px;min-height:100vh}
.page-hero{background:var(--black);border-bottom:1px solid rgba(200,16,46,.25);padding:5rem 2rem 4rem;position:relative;overflow:hidden}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.page-hero-title{font-family:"Bodoni Moda",Georgia,serif;font-size:clamp(2.2rem,5vw,4rem);color:var(--bone);line-height:1.1;margin:0 0 1rem}
.page-hero-sub{font-size:1.15rem;color:var(--grey);max-width:640px;line-height:1.6;margin:0}
.sin-label{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--red);border:1px solid var(--red);padding:.25rem .7rem;margin-bottom:1.2rem}
.page-body{background:var(--black);padding:4rem 2rem 6rem}
.page-body-inner{max-width:900px;margin:0 auto}
.sector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-top:3rem}
.sector-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:2rem;transition:border-color .25s,transform .25s;text-decoration:none;display:block}
.sector-card:hover{border-color:var(--red);transform:translateY(-3px)}
.sector-card h3{font-family:"Bodoni Moda",serif;font-size:1.3rem;color:var(--bone);margin:0 0 .6rem}
.sector-card p{color:var(--grey);font-size:.9rem;line-height:1.55;margin:0 0 1.2rem}
.sector-card .card-link{color:var(--red);font-size:.85rem;font-family:"JetBrains Mono",monospace;letter-spacing:.05em}
.service-intro{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;margin-bottom:3rem}
@media(max-width:640px){.service-intro{grid-template-columns:1fr}}
.service-features{list-style:none;padding:0;margin:1.5rem 0 0}
.service-features li{padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.06);color:var(--grey);font-size:.95rem}
.service-features li::before{content:"-- ";color:var(--red)}
.quote-panel{background:rgba(200,16,46,.06);border:1px solid rgba(200,16,46,.2);padding:3rem 2.5rem;margin-top:4rem}
.quote-panel h2{font-family:"Bodoni Moda",serif;font-size:1.8rem;color:var(--bone);margin:0 0 .5rem}
.quote-panel p{color:var(--grey);margin:0 0 2rem}
.quote-form{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.quote-form{grid-template-columns:1fr}}
.quote-form input,.quote-form textarea,.quote-form select{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);color:var(--bone);padding:.8rem 1rem;font-family:inherit;font-size:.9rem;width:100%;box-sizing:border-box;transition:border-color .2s}
.quote-form input:focus,.quote-form textarea:focus,.quote-form select:focus{outline:none;border-color:var(--red)}
.quote-form textarea{grid-column:1/-1;resize:vertical;min-height:120px}
.quote-form .form-submit{grid-column:1/-1}
.cta-btn,.btn-primary{display:inline-block;background:var(--red);color:#fff;padding:.85rem 2.2rem;font-family:"JetBrains Mono",monospace;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;border:none;cursor:pointer;transition:background .2s,transform .2s}
.cta-btn:hover,.btn-primary:hover{background:#a00d24;transform:translateY(-2px)}
.pf-grid-inner{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:2.5rem;grid-auto-rows:240px}
.pf-card-inner{position:relative;overflow:hidden;aspect-ratio:4/3}
.pf-card-inner img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pf-card-inner:hover img{transform:scale(1.05)}
.pf-card-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.85));padding:2rem 1rem .8rem}
.pf-card-caption p{color:var(--bone);font-size:.85rem;margin:0;font-family:"JetBrains Mono",monospace}
.credits-table{width:100%;border-collapse:collapse;margin-top:2rem}
.credits-table th{font-family:"JetBrains Mono",monospace;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--red);padding:.6rem 1rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}
.credits-table td{color:var(--grey);font-size:.9rem;padding:.7rem 1rem;border-bottom:1px solid rgba(255,255,255,.05)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:3rem}
@media(max-width:640px){.contact-grid{grid-template-columns:1fr}}
.contact-info h3{font-family:"Bodoni Moda",serif;color:var(--bone);font-size:1.3rem;margin:0 0 1.2rem}
.contact-info p{color:var(--grey);line-height:1.7;margin:0 0 .7rem}
.contact-info a{color:var(--red);text-decoration:none}
.site-footer{background:#0a0a0c;border-top:1px solid rgba(255,255,255,.06);padding:4rem 2rem 2rem}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.06)}
@media(max-width:768px){.footer-inner{grid-template-columns:1fr;gap:2rem}}
.footer-brand p{color:var(--grey);font-size:.9rem;margin:1rem 0 0}
.footer-links{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;align-content:start}
.footer-links a{color:var(--grey);text-decoration:none;font-size:.9rem;transition:color .2s}
.footer-links a:hover{color:var(--bone)}
.footer-contact p{color:var(--grey);font-size:.9rem;margin:0 0 .5rem}
.footer-contact a{color:var(--red);text-decoration:none}
.footer-bottom{max-width:1200px;margin:1.5rem auto 0;text-align:center}
.footer-bottom p{color:rgba(255,255,255,.25);font-size:.8rem;margin:0}

.footer-social{display:flex;gap:1.2rem;margin-top:1rem;flex-wrap:wrap}
.footer-social a{color:var(--grey);text-decoration:none;font-family:"JetBrains Mono",monospace;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;border:1px solid rgba(255,255,255,.1);padding:.3rem .7rem;transition:color .2s,border-color .2s}
.footer-social a:hover{color:var(--bone);border-color:var(--red)}

.pf-filter{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.pf-btn{background:transparent;border:1px solid rgba(255,255,255,.15);color:var(--grey);font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.4rem 1rem;cursor:pointer;transition:all .2s}
.pf-btn:hover,.pf-btn.active{background:var(--red);border-color:var(--red);color:#fff}
.pf-grid-inner{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;margin-top:1rem;grid-auto-rows:240px}
.lb-card{position:relative;overflow:hidden;aspect-ratio:4/3;display:block;cursor:zoom-in;height:240px}
.lb-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.lb-card:hover img{transform:scale(1.06)}
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:9999;align-items:center;justify-content:center;flex-direction:column}
.lightbox.open{display:flex}
.lb-img{max-width:90vw;max-height:80vh;object-fit:contain;border:1px solid rgba(255,255,255,.08)}
.lb-caption{color:var(--grey);font-family:"JetBrains Mono",monospace;font-size:.78rem;letter-spacing:.08em;margin-top:.8rem;text-align:center}
.lb-close{position:absolute;top:1.2rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;line-height:1;opacity:.7;transition:opacity .2s}
.lb-close:hover{opacity:1}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:3.5rem;cursor:pointer;line-height:1;padding:0 1rem;opacity:.6;transition:opacity .2s;user-select:none}
.lb-prev{left:0}.lb-next{right:0}
.lb-prev:hover,.lb-next:hover{opacity:1}

/* â”€â”€ Desires nav 18+ badge â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.nav-desires {
    position: relative;
}

.nav-desires > a {
    padding-right: 2em;
}

.nav-desires > a::after {
    content: "18+";
    position: absolute;
    top: -0.55em;
    right: -0.1em;
    font-family: 'Inter Tight', sans-serif;
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: #F4F1EC;
    background: #C8102E;
    border-radius: 3px;
    padding: 1px 4px;
    line-height: 1.4;
    pointer-events: none;
}

/* Slightly reduce opacity at rest so it's subtle, full on hover */
.nav-desires > a::after {
    opacity: 0.82;
    transition: opacity 0.2s ease;
}

.nav-desires:hover > a::after {
    opacity: 1;
}
/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

