@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:optional;src:url('/assets/fonts/poppins-400.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:optional;src:url('/assets/fonts/poppins-500.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:optional;src:url('/assets/fonts/poppins-600.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:optional;src:url('/assets/fonts/poppins-700.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:800;font-display:optional;src:url('/assets/fonts/poppins-800.woff2') format('woff2')}:root{  --km-bg:#0a0a0a; --km-surface:#121212; --km-surface-2:#1a1a1a; --km-surface-3:#232323; --km-line:#1a1a1a; --km-line-strong:#2a2a2a;  --km-text:#ffffff; --km-text-soft:#c8c8c8; --km-text-mute:#999; --km-text-faint:#555;  --km-accent:#E0115F; --km-accent-deep:#c70f54; --km-accent-soft:rgba(224,17,95,0.1); --km-accent-border:rgba(224,17,95,0.3); --km-accent-glow:rgba(224,17,95,0.35);  --km-sans:'Poppins',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;  --km-space-1:4px; --km-space-2:8px; --km-space-3:16px; --km-space-4:24px; --km-space-5:40px; --km-space-6:64px; --km-space-7:96px; --km-space-8:144px;  --km-container:1440px; --km-container-narrow:880px;  --km-radius:14px; --km-radius-lg:18px; --km-radius-pill:50px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{padding:0;margin:0;}
body{ background:var(--km-bg); color:var(--km-text); font-family:var(--km-sans); font-size:16px; line-height:1.7; font-weight:400; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; text-rendering:optimizeLegibility; min-height:100vh; overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
.km-container{ width:100%; max-width:var(--km-container); margin:0 auto; padding:0 var(--km-space-4);}
.km-header{ position:sticky; top:0; z-index:100; background:rgba(10,10,10,0.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid var(--km-line);}
.km-header-inner{ display:flex; align-items:center; justify-content:space-between; gap:var(--km-space-4); height:72px; max-width:var(--km-container); margin:0 auto; padding:0 var(--km-space-4);}
.km-brand-mark{ display:inline-flex; align-items:center; gap:12px; font-family:var(--km-sans); font-size:18px; font-weight:800; letter-spacing:2px; color:var(--km-text); text-transform:uppercase;}
.km-brand-mark-icon{ display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; color:var(--km-accent); flex-shrink:0;}
.km-brand-mark-icon svg{ width:100%; height:100%;}
.km-brand-mark-text{ display:inline-block; line-height:1;}
.km-brand-mark-text .accent{ color:var(--km-accent);}
.km-nav{ display:flex; align-items:center; gap:var(--km-space-5);}
.km-nav a{ font-size:13px; color:var(--km-text-soft); font-weight:500; letter-spacing:0.04em; transition:color 0.2s ease;}
.km-nav a:hover{ color:var(--km-accent);}
.km-creator-cta{ background:var(--km-accent); color:#fff !important; padding:7px 14px; border-radius:4px; text-decoration:none; font-weight:600; font-size:13px; letter-spacing:0.02em; transition:filter 0.18s ease; white-space:nowrap;}
.km-creator-cta:hover{filter:brightness(1.1);color:#fff !important;}
.km-buyer-avatar{ display:inline-block; border-radius:50%; object-fit:cover; background:var(--km-surface); border:1px solid var(--km-line); flex-shrink:0; vertical-align:middle;}
.km-buyer-avatar-md{width:80px;height:80px;}
@media (max-width:900px){ .km-header-inner{height:64px;padding:0 var(--km-space-3);}
 .km-brand-mark{font-size:16px;letter-spacing:1.5px;}
 .km-brand-mark-icon{width:28px;height:28px;}
 .km-nav{gap:var(--km-space-3);}
 .km-nav a{font-size:12px;}
}
@media (max-width:600px){ .km-nav a:not(.km-nav-keep){ display:none;}
}
.km-hero-tight .km-container{ position:relative; z-index:1;}
.km-section{ padding:var(--km-space-6) 0; position:relative;}
.km-section-first{ padding-top:var(--km-space-3);}
.km-section-tight{ padding:var(--km-space-5) 0 var(--km-space-6);}
.km-section-header-clean{ display:flex; align-items:flex-end; justify-content:space-between; gap:var(--km-space-3); flex-wrap:wrap; text-align:left; margin-bottom:var(--km-space-5); padding-bottom:var(--km-space-3); border-bottom:1px solid var(--km-line);} .km-section-header-clean.km-section-header-stack{ flex-direction:column; align-items:flex-start;} .km-section-eyebrow{ display:block; margin:0 0 12px; font-size:12px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--km-accent); line-height:1;}
.km-section-title-clean{ font-family:var(--km-sans); font-size:clamp(28px,4vw,40px); line-height:1.1; color:var(--km-text); margin:0; letter-spacing:-0.01em; font-weight:700;} .km-section-sub{ margin:14px 0 0; max-width:60ch; font-size:15px; line-height:1.65; color:var(--km-text-soft);} .km-section-sub a{ color:var(--km-accent); text-decoration:underline; text-underline-offset:3px;}
.km-section-link{ align-self:flex-end; flex-shrink:0; font-size:13px; font-weight:600; color:var(--km-text-soft); letter-spacing:0.04em; transition:color 0.2s ease; white-space:nowrap;}
.km-section-link:hover{ color:var(--km-accent);}
.km-section-link span{ transition:transform 0.2s ease; display:inline-block;}
.km-section-link:hover span{ transform:translateX(3px);}
.km-why{ padding:var(--km-space-5) 0 var(--km-space-6); position:relative;}
.km-why-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:var(--km-space-4);}
.km-why-item{ background:linear-gradient(180deg,var(--km-surface) 0%,#0d0d0d 100%); border:1px solid var(--km-line); border-radius:var(--km-radius); padding:var(--km-space-4) var(--km-space-4) var(--km-space-5); position:relative; transition:border-color 0.3s ease,transform 0.3s ease;}
.km-why-item:hover{ border-color:var(--km-accent-border); transform:translateY(-2px);}
.km-why-num{ display:inline-block; font-family:var(--km-sans); font-size:11px; font-weight:700; letter-spacing:2px; color:var(--km-accent); margin-bottom:var(--km-space-3);}
.km-why-title{ font-family:var(--km-sans); font-size:22px; line-height:1.2; color:var(--km-text); margin:0 0 var(--km-space-2); font-weight:700; letter-spacing:-0.01em;}
.km-why-text{ color:var(--km-text-soft); font-size:14px; line-height:1.6; margin:0;}
@media (max-width:600px){ .km-why-grid{grid-template-columns:1fr;}
}
.km-creator-grid{ display:grid;  grid-template-columns:repeat(auto-fill,minmax(min(100%,360px),420px)); justify-content:start; gap:var(--km-space-4);}
.km-creator-card{ display:flex; flex-direction:column; background:linear-gradient(180deg,var(--km-surface) 0%,#0d0d0d 100%); border:1px solid var(--km-line); border-radius:var(--km-radius); overflow:hidden; text-decoration:none; color:inherit; transition:transform 0.3s ease,border-color 0.3s ease,box-shadow 0.3s ease; position:relative;}
.km-creator-card:hover{ transform:translateY(-4px); border-color:var(--km-accent-border); box-shadow:0 20px 40px rgba(0,0,0,0.5), 0 0 30px var(--km-accent-soft);}
.km-creator-card-image{ position:relative; aspect-ratio:4 / 5; background-size:cover; background-position:center top; background-color:var(--km-surface-2); overflow:hidden;}
.km-creator-card-image-overlay{ position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, rgba(10,10,10,0.4) 80%, rgba(10,10,10,0.85) 100%); pointer-events:none;}
.km-creator-card-body{ padding:var(--km-space-3) var(--km-space-4) var(--km-space-4); display:flex; flex-direction:column; gap:6px;}
.km-creator-card-name{ font-family:var(--km-sans); font-size:22px; line-height:1.15; color:var(--km-text); margin:0; letter-spacing:-0.01em; font-weight:700;}
.km-creator-card-tagline{ font-size:16px; color:var(--km-accent); line-height:1.35; font-weight:700; letter-spacing:0.04em; text-transform:uppercase;}
@media (max-width:480px){ .km-creator-grid{ grid-template-columns:1fr; gap:var(--km-space-3);}
 .km-creator-card-name{ font-size:20px;}
}
.km-footer{ padding:var(--km-space-6) 0 var(--km-space-4); border-top:1px solid var(--km-line); background:var(--km-bg); margin-top:var(--km-space-7);}
.km-footer-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:var(--km-space-5); margin-bottom:var(--km-space-5);}
.km-footer-brand{ display:flex; flex-direction:column; gap:var(--km-space-3);}
.km-footer-brand-mark{ font-family:var(--km-sans); font-size:22px; font-weight:800; color:var(--km-text); letter-spacing:2px;}
.km-footer-brand-mark span{ color:var(--km-accent);}
.km-footer-brand-text{ color:var(--km-text-mute); font-size:13px; line-height:1.6; max-width:320px;}
.km-footer-col-title{ font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--km-text-faint); margin:0 0 var(--km-space-3) 0; font-weight:700;}
.km-footer-links{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px;}
.km-footer-links a{ color:var(--km-text-soft); font-size:13px; font-weight:500; transition:color 0.2s ease;}
.km-footer-links a:hover{ color:var(--km-accent);}
.km-footer-bottom{ padding-top:var(--km-space-4); border-top:1px solid var(--km-line); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:var(--km-space-3); font-size:12px; color:var(--km-text-faint); font-weight:500;}
@media (max-width:768px){ .km-footer-grid{ grid-template-columns:1fr 1fr;}
 .km-footer-brand{ grid-column:1 / -1;}
}
.km-age-gate{ position:fixed; inset:0; z-index:9999; background:rgba(10,10,10,0.97); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); display:flex; align-items:center; justify-content:center; padding:var(--km-space-4);}
.km-age-gate::before{ content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:700px; height:700px; background:radial-gradient(circle at center,var(--km-accent-soft) 0%,transparent 60%); filter:blur(60px); pointer-events:none;}
.km-age-gate-card{ position:relative; max-width:520px; width:100%; text-align:center; padding:var(--km-space-6) var(--km-space-5);}
.km-age-gate-buttons{ display:flex; gap:var(--km-space-3); justify-content:center; flex-wrap:wrap;}
@keyframes km-fade-up{ from{opacity:0;transform:translateY(16px);}
 to{opacity:1;transform:translateY(0);}
}
.km-fade-up{animation:km-fade-up 0.6s cubic-bezier(0.4,0,0.2,1) both;}
.km-fade-up-1{animation-delay:0.05s;}
.km-fade-up-2{animation-delay:0.15s;}
.km-fade-up-3{animation-delay:0.25s;}
.km-fade-up-4{animation-delay:0.35s;}
.km-hero-backdrop{ position:relative; width:100%; height:clamp(560px,90vh,820px); background:var(--km-bg); overflow:hidden; display:flex; align-items:center;}
.km-hero-backdrop-image{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center right; }
.km-hero-backdrop-overlay{ position:absolute; inset:0; background: linear-gradient(90deg,rgba(10,10,10,0.92) 0%,rgba(10,10,10,0.6) 55%,rgba(10,10,10,0.25) 100%), linear-gradient(180deg,rgba(10,10,10,0.4) 0%,rgba(10,10,10,0.0) 30%,rgba(10,10,10,0.6) 100%);}
.km-hero-backdrop-content{ position:relative; width:100%; max-width:var(--km-container); margin:0 auto; padding:0 var(--km-space-5);}
.km-hero-backdrop-eyebrow{ display:inline-block; font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--km-accent); margin-bottom:var(--km-space-3);}
.km-hero-backdrop-headline{ font-family:var(--km-sans); font-size:clamp(38px,5.5vw,76px); font-weight:800; line-height:1.0; letter-spacing:-0.02em; color:var(--km-text); margin:0 0 var(--km-space-4) 0; max-width:1100px;}
.km-hero-backdrop-headline em{ color:var(--km-accent); font-style:italic; font-weight:800; display:block;}
.km-hero-backdrop-sub{ font-size:clamp(16px,1.6vw,19px); font-weight:400; line-height:1.6; color:var(--km-text-soft); max-width:540px; margin:0;}
.km-icon-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:var(--km-space-3);}
@media (max-width:1100px){ .km-icon-grid{ grid-template-columns:repeat(4,1fr);}
}
@media (max-width:700px){ .km-icon-grid{ grid-template-columns:repeat(2,1fr);}
}
.km-icon-tile{ position:relative; background:linear-gradient(180deg,var(--km-surface),#0d0d0d); border:1px solid var(--km-line); border-radius:var(--km-radius); padding:var(--km-space-5) var(--km-space-4); text-align:center; text-decoration:none; color:var(--km-text); transition:all 0.25s ease; overflow:hidden; cursor:pointer; display:flex; flex-direction:column; align-items:center; gap:var(--km-space-3);}
.km-icon-tile::before{ content:""; position:absolute; inset:-1px; border-radius:var(--km-radius); background:radial-gradient(circle at 50% 30%,var(--km-accent-soft),transparent 60%); opacity:0; transition:opacity 0.3s ease; pointer-events:none;}
.km-icon-tile:hover{ border-color:var(--km-accent-border); transform:translateY(-3px); box-shadow:0 12px 30px rgba(0,0,0,0.45);}
.km-icon-tile:hover::before{ opacity:1;}
.km-icon-tile-icon{ position:relative; width:88px; height:88px; display:flex; align-items:center; justify-content:center; color:var(--km-text); filter: drop-shadow(0 0 8px var(--km-accent-glow)) drop-shadow(0 0 24px rgba(224,17,95,0.45)); transition:filter 0.3s ease,transform 0.3s ease;}
.km-icon-tile:hover .km-icon-tile-icon{ transform:scale(1.06); filter: drop-shadow(0 0 12px var(--km-accent)) drop-shadow(0 0 32px var(--km-accent));}
.km-icon-tile-icon svg,.km-icon-tile-icon img{ width:100%; height:100%; object-fit:contain; display:block;}
.km-icon-tile-name{ font-size:17px; font-weight:700; color:var(--km-text); line-height:1.3; margin:0;}
@media (max-width:600px){ .km-hero-backdrop{ height:clamp(480px,80vh,640px);}
 .km-icon-tile{ padding:var(--km-space-4);}
 .km-icon-tile-icon{ width:72px; height:72px;}
}
.km-burger{ display:none; -webkit-appearance:none; appearance:none; background:transparent; border:1px solid var(--km-line); border-radius:8px; width:40px; height:40px; padding:0; align-items:center; justify-content:center; flex-direction:column; gap:5px; cursor:pointer; color:var(--km-text); flex-shrink:0; transition:background 0.15s,border-color 0.15s,color 0.15s;}
.km-burger-bar{ display:block; width:18px; height:2px; background:currentColor; border-radius:2px;}
.km-burger[aria-expanded="true"]{ background:rgba(224,17,95,0.12); border-color:var(--km-accent,#E0115F); color:var(--km-accent,#E0115F);}
.km-why-rail{display:none;}
.km-drawer{ position:fixed; inset:0; z-index:9500; display:flex;}
.km-drawer[hidden]{display:none;}
.km-drawer-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,0.6); opacity:0; transition:opacity 0.24s ease;}
.km-drawer.is-open .km-drawer-backdrop{opacity:1;}
.km-drawer-panel{ position:relative; width:86%; max-width:380px; height:100%; background:#0e0e0e; border-right:1px solid var(--km-line); overflow-y:auto; -webkit-overflow-scrolling:touch; transform:translateX(-100%); transition:transform 0.24s ease; display:flex; flex-direction:column;}
.km-drawer.is-open .km-drawer-panel{transform:translateX(0);}
.km-drawer-signin{ padding:20px 18px; border-bottom:1px solid var(--km-line); display:flex; flex-direction:column; gap:10px;}
.km-drawer-cta{ display:block; padding:13px; background:var(--km-accent,#E0115F); color:#fff; text-align:center; border-radius:8px; text-decoration:none; font-weight:600; font-size:14px; letter-spacing:0.02em;}
.km-drawer-cta:active{filter:brightness(0.92);}
.km-drawer-signin-link{ text-align:center; font-size:13px; color:var(--km-text-soft); text-decoration:none;}
.km-drawer-section{padding:14px 12px 8px;}
.km-drawer-section+.km-drawer-section{border-top:1px solid var(--km-line);}
.km-drawer-section-title{ padding:0 6px 6px; font-size:11px; font-weight:600; color:var(--km-text-mute,#888); letter-spacing:0.16em; text-transform:uppercase;}
.km-drawer-link,.km-drawer-link-button{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:11px 8px; color:var(--km-text); text-decoration:none; font-size:14px; font-weight:500; border-radius:6px; border:none; background:transparent; text-align:left; cursor:pointer; font-family:inherit; width:100%; line-height:1.3;}
.km-drawer-link:active,.km-drawer-link-button:active{background:rgba(255,255,255,0.04);}
.km-drawer-cat{ display:flex; align-items:center; gap:12px; padding:9px 8px; color:var(--km-text); text-decoration:none; font-size:14px; font-weight:500; border-radius:6px;}
.km-drawer-cat:active{background:rgba(224,17,95,0.08);color:var(--km-accent,#E0115F);}
.km-drawer-cat-icon{ width:32px; height:32px; background:rgba(224,17,95,0.08); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0;}
.km-drawer-cat-icon img{ width:18px; height:18px; object-fit:contain; filter:brightness(1.1);}
.km-mobile-cats-cta{display:none;}
@media (max-width:760px){ .km-hero-backdrop{ height:auto; min-height:0; padding:44px 0 52px;}
 .km-hero-backdrop-eyebrow{margin-bottom:14px;}
 .km-hero-backdrop-headline{margin-bottom:16px;}
 .km-header-inner{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:8px; padding:0 12px; height:60px;}
 .km-burger{display:inline-flex;justify-self:start;}
 .km-brand-mark{justify-self:center;margin:0;}
 .km-nav, .kmnv, .km-creator-group{display:none !important;}
 .km-why{padding:16px 0 !important;}
 .km-why-grid{display:none;}
 .km-why-rail{ display:flex; align-items:center; justify-content:center; gap:7px; flex-wrap:nowrap; white-space:nowrap; padding:0 12px; font-family:var(--km-sans); font-size:10px; color:var(--km-text-soft,#b0b0b0); letter-spacing:0.1em; text-transform:uppercase;}
 .km-why-pill{font-weight:600;white-space:nowrap;}
 .km-why-sep{ width:4px; height:4px; background:var(--km-accent,#E0115F); border-radius:50%; flex-shrink:0;}
 .km-hide-mobile{display:none !important;}
 .km-section-first{padding-bottom:20px;}
 .km-mobile-cats-cta{ display:block; padding:0 0 28px;}
 .km-cats-cta{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:18px 20px; background:linear-gradient(135deg,rgba(224,17,95,0.14),rgba(224,17,95,0.04)); border:1px solid rgba(224,17,95,0.4); border-radius:12px; color:var(--km-text); font-weight:500; font-size:15px; letter-spacing:0.02em; text-decoration:none;}
 .km-cats-cta-arrow{ color:var(--km-accent,#E0115F); font-size:18px; font-weight:600;}
 .km-cats-cta:active{ background:linear-gradient(135deg,rgba(224,17,95,0.2),rgba(224,17,95,0.08));}
}
.km-buyers-featured{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:var(--km-space-3);}
@media (max-width:900px){ .km-buyers-featured{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:600px){ .km-buyers-featured{grid-template-columns:1fr;}
}
.km-buyers-fcard{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:8px; padding:20px 18px; background:var(--km-surface); border:1px solid var(--km-line); border-radius:var(--km-radius); text-decoration:none; color:inherit; transition:border-color 0.18s,transform 0.18s;}
.km-buyers-fcard:hover{ border-color:var(--km-accent); transform:translateY(-2px);}
.km-buyers-fcard-avatar{width:64px;height:64px;}
.km-buyers-fcard-name{font-size:15px;font-weight:700;line-height:1.2;}
.km-buyer-chip.is-active{ background:var(--km-accent); border-color:var(--km-accent); color:#fff;}
.km-buyers-tags{ display:flex; flex-wrap:wrap; gap:4px; justify-content:center; margin-top:2px;}
.km-buyer-tag{ display:inline-block; padding:2px 8px; background:rgba(224,17,95,0.10); border:1px solid rgba(224,17,95,0.25); color:var(--km-text); border-radius:999px; font-size:10px; font-weight:500; letter-spacing:0.02em; line-height:1.5; white-space:nowrap;}
.km-buyer-tag-more{ background:transparent; border-color:var(--km-line); color:var(--km-text-soft);}
.km-buyers-kinkcount{ font-size:10px; color:var(--km-text-soft); letter-spacing:0.04em; margin-top:2px;}
.km-why,.km-section,.km-section-first,.km-section-tight,.km-mobile-cats-cta,.km-footer,footer{ content-visibility:auto; contain-intrinsic-size:0 720px;}
/* =====================================================================
   DIRECTION B (FINAL) home redesign, 2026-06-02. Namespaced under .kmbf
   so it never collides with the shared header/footer styling above.
   Uses the existing --km-* vars + self-hosted Poppins (max weight 800,
   used for all mastheads - no cursive / no Allura).
   ===================================================================== */
.kmbf{line-height:1.5}
.kmbf a{color:inherit;text-decoration:none}
.kmbf .wrap{max-width:1240px;margin:0 auto;padding:0 30px}
.kmbf .btn{display:inline-block;background:var(--km-accent);color:#fff;font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;padding:16px 38px;border-radius:4px;transition:filter .18s,transform .18s}
.kmbf .btn:hover{filter:brightness(1.12);transform:translateY(-2px)}
.kmbf .btn.ghost{background:transparent;border:2px solid var(--km-accent);color:var(--km-text)}
.kmbf .btn.ghost:hover{background:var(--km-accent);color:#fff;filter:none}

/* hero split - FULL-BLEED. The photo column is ABSOLUTELY positioned to
   right:0 of the full-width hero, so it ALWAYS touches the viewport's
   right edge - no dead black space - regardless of the headline's width
   or font (an fr grid let the column fall ~2vw short; diagnosed
   2026-06-02 via headless measurement). The left column flows normally,
   padded so its text lines up with the 1240px site container, with a
   right gap so it never runs under the photo. (Earlier the image filled
   its box fine via object-fit:cover, but the box was a narrow 354px
   centred column - this makes the box itself reach the edge.) */
.kmbf .hero-sec{position:relative;width:100%}
.kmbf .hero{position:relative;min-height:78vh;display:flex;align-items:center;padding-left:max(30px, calc((100vw - 1240px) / 2 + 30px))}
.kmbf .hero-left{position:relative;z-index:2;width:min(620px, 52%);padding:70px 0}
.kmbf .hero-left .eyebrow{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--km-accent);font-weight:700;margin-bottom:22px}
.kmbf .hero h1{font-family:var(--km-sans);font-weight:800;font-size:clamp(44px,6vw,92px);line-height:.94;letter-spacing:-.035em;text-transform:uppercase;margin:0}
.kmbf .hero h1 .pink{color:var(--km-accent)}
.kmbf .hero .find{font-family:var(--km-sans);font-style:italic;font-weight:800;text-transform:none;font-size:clamp(34px,4.6vw,64px);color:var(--km-text);display:block;margin:6px 0 22px;letter-spacing:-.02em;line-height:1}
.kmbf .hero p.sub{max-width:46ch;color:var(--km-text-soft);font-size:17px;font-weight:400;line-height:1.55;margin:0 0 32px}
.kmbf .hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.kmbf .hero-right{position:absolute;top:0;right:0;bottom:0;width:46vw;overflow:hidden}
/* picture:contents removes it from the box tree so the <img> positions
   directly against .hero-right; max-width:none defeats the global
   img{max-width:100%} reset. */
.kmbf .hero-right picture{display:contents}
.kmbf .hero-right img{position:absolute;inset:0;width:100%;height:100%;max-width:none;object-fit:cover;object-position:center;display:block}
.kmbf .hero-right::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(224,17,95,.45),rgba(10,8,9,.55));mix-blend-mode:multiply;pointer-events:none;z-index:1}

/* light free strip */
.kmbf .freestrip{border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.kmbf .freestrip .wrap{display:flex;align-items:center;justify-content:center;gap:10px 26px;flex-wrap:wrap;padding:20px 30px;text-align:center}
.kmbf .freestrip .line{font-size:14px;font-weight:600;letter-spacing:.04em;color:var(--km-text)}
.kmbf .freestrip .line b{color:var(--km-accent);font-weight:700}
.kmbf .freestrip .sep{color:rgba(255,255,255,.25)}
.kmbf .freestrip a{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--km-accent)}
.kmbf .freestrip a:hover{filter:brightness(1.15)}

/* section heads */
.kmbf .sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap;margin-bottom:38px;border-bottom:1px solid var(--km-line);padding-bottom:16px}
.kmbf .sec-head h2{font-family:var(--km-sans);font-weight:800;text-transform:uppercase;font-size:clamp(28px,4.6vw,58px);letter-spacing:-.03em;line-height:1}
.kmbf .sec-head a{color:var(--km-accent);font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.06em;white-space:nowrap}

/* featured creators */
.kmbf .creators{padding:90px 0 100px}
.kmbf .empty-note{text-align:center;padding:64px 0;color:var(--km-text-soft)}
.kmbf .crow{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.kmbf .cc{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:8px;display:block}
.kmbf .cc-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s ease}
.kmbf .cc:hover .cc-img{transform:scale(1.04)}
.kmbf .cc-letter{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--km-sans);font-weight:800;font-size:64px;color:rgba(255,255,255,.18)}
.kmbf .cc .cov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,8,9,.94) 6%,rgba(10,8,9,.15) 55%);transition:.25s}
.kmbf .cc:hover .cov{background:linear-gradient(0deg,rgba(224,17,95,.72) 0%,rgba(10,8,9,.2) 60%)}
.kmbf .cc .cb{position:absolute;left:0;right:0;bottom:0;padding:24px}
.kmbf .cc .cn{font-family:var(--km-sans);font-weight:800;text-transform:uppercase;font-size:24px;letter-spacing:-.01em;line-height:1.05;color:#fff}
.kmbf .cc .ct{font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.14em;color:var(--km-accent);margin-top:8px}
.kmbf .cc .cr{margin-top:10px;font-size:13px;color:#f5a623;letter-spacing:2px}
.kmbf .cc .cr .empty{opacity:.28}
.kmbf .cc .cr small{color:rgba(255,255,255,.6);letter-spacing:0;font-size:12px;margin-left:6px}

/* categories chip flow */
.kmbf .cats{padding:0 0 100px}
.kmbf .catflow{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.kmbf .chip{padding:13px 22px;border:2px solid rgba(255,255,255,.14);font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.02em;border-radius:3px;transition:.18s;color:var(--km-text)}
.kmbf .chip:hover{border-color:var(--km-accent);color:var(--km-accent)}

/* how it works */
.kmbf .how{padding:70px 0;border-top:1px solid var(--km-line)}
.kmbf .how-head{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;margin-bottom:32px}
.kmbf .how-head .eyebrow{color:var(--km-accent);font-weight:700;letter-spacing:.3em;text-transform:uppercase;font-size:12px}
.kmbf .how-head h2{font-family:var(--km-sans);font-weight:800;text-transform:uppercase;font-size:clamp(24px,3.4vw,40px);letter-spacing:-.02em}
.kmbf .how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.kmbf .hstep{display:flex;gap:16px;align-items:flex-start}
.kmbf .hstep .hn{font-family:var(--km-sans);font-weight:800;font-size:34px;color:transparent;-webkit-text-stroke:1.5px var(--km-accent);line-height:.9}
.kmbf .hstep h3{font-weight:700;text-transform:uppercase;font-size:15px;letter-spacing:.01em;margin-bottom:6px;color:var(--km-text)}
.kmbf .hstep p{color:var(--km-text-soft);font-size:13.5px;line-height:1.6}

/* apply band */
.kmbf .apply{padding:100px 0;text-align:center;border-top:1px solid var(--km-line)}
.kmbf .apply h2{font-family:var(--km-sans);font-weight:800;text-transform:uppercase;font-size:clamp(28px,4.6vw,60px);line-height:.98;letter-spacing:-.03em}
.kmbf .apply h2 .accentline{display:block;color:var(--km-accent)}
.kmbf .apply p{max-width:60ch;margin:22px auto 0;color:var(--km-text-soft);font-size:16px;line-height:1.7}
.kmbf .apply a.inline{color:var(--km-accent);text-decoration:underline;text-underline-offset:3px}

@media(max-width:880px){
  .kmbf .hero{display:block;min-height:0;padding-left:0}
  .kmbf .hero-left{width:auto;padding:34px 30px 14px}
  .kmbf .hero-right{position:relative;top:auto;right:auto;bottom:auto;width:auto;height:340px}
  .kmbf .crow{grid-template-columns:1fr}
  .kmbf .how-steps{grid-template-columns:1fr}
}

/* #1098 mobile: trim hero image height + padding on small phones (was 340px scroll-past) */
@media(max-width:480px){
  .kmbf .hero-right{height:248px}
  .kmbf .hero-left{padding:30px 22px 12px}
}

/* #1145 (Dan 2026-06-14): hero photo on DESKTOP only, hidden on mobile */
@media(max-width:880px){
  .kmbf .hero-right{display:none}
  .kmbf .hero{min-height:0}
  .kmbf .hero-left{width:auto;padding:56px 30px 40px}
}
@media(max-width:480px){
  .kmbf .hero-left{padding:44px 22px 32px}
}
