:root {
    --app-bg: #f6f7fb;
    --app-surface: #ffffff;
    --app-surface-2: #eef2f7;
    --app-text: #18212f;
    --app-muted: #64748b;
    --app-line: #dfe6ef;
    --app-brand: #f97316;
    --app-brand-2: #fb923c;
    --app-dark: #0f172a;
    --app-shadow: 0 18px 48px rgba(15, 23, 42, .08);
}
[data-bs-theme="dark"] {
    --app-bg: #07111f;
    --app-surface: #0f1b2e;
    --app-surface-2: #15243a;
    --app-text: #e8edf5;
    --app-muted: #9aabc0;
    --app-line: #26364e;
    --app-shadow: 0 18px 48px rgba(0, 0, 0, .28);
}
html { scroll-behavior: smooth; }
body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background:
        radial-gradient(circle at 5% -10%, rgba(249, 115, 22, .13), transparent 32rem),
        var(--app-bg);
    color: var(--app-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
main { flex: 1 0 auto; }
a { color: var(--app-brand); }
.navbar-app {
    background: rgba(15, 23, 42, .94);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    box-shadow: 0 10px 35px rgba(2, 6, 23, .2);
}
.app-brand { color: #fff !important; font-weight: 900; letter-spacing: -.04em; }
.app-brand-mark {
    display: inline-grid; place-items: center; width: 34px; height: 34px;
    border-radius: 11px; margin-right: 9px;
    background: linear-gradient(135deg, var(--app-brand), #ef4444);
    box-shadow: 0 8px 24px rgba(249, 115, 22, .35);
}
.navbar-app .nav-link { color: rgba(255,255,255,.76); font-weight: 700; border-radius: 10px; padding-inline: .82rem !important; }
.navbar-app .nav-link:hover, .navbar-app .nav-link.active { color: #fff; background: rgba(255,255,255,.08); }
.btn-theme { width: 38px; height: 38px; display: inline-grid; place-items: center; border-radius: 12px; border: 1px solid rgba(255,255,255,.14); color: #fff; background: rgba(255,255,255,.05); }
.site-alerts { position: relative; z-index: 1030; }
.site-alerts .alert { border: 0; border-radius: 0; margin: 0; }
.promoted-shell {
    background: linear-gradient(180deg, rgba(249,115,22,.12), transparent), var(--app-surface);
    border-bottom: 1px solid var(--app-line);
}
.promoted-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.promoted-eyebrow { color: var(--app-brand); font-size: .75rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.promoted-track { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(160px, 190px); gap: 14px; overflow-x: auto; padding: 4px 2px 14px; scrollbar-width: thin; }
.promoted-card { display: block; color: var(--app-text); text-decoration: none; background: var(--app-surface); border: 1px solid var(--app-line); border-radius: 18px; overflow: hidden; box-shadow: 0 10px 30px rgba(15,23,42,.07); transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.promoted-card:hover { color: var(--app-text); transform: translateY(-4px); border-color: rgba(249,115,22,.65); box-shadow: var(--app-shadow); }
.promoted-media { position: relative; aspect-ratio: 4/3; background: var(--app-surface-2); overflow: hidden; }
.promoted-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.promoted-card:hover img { transform: scale(1.04); }
.promoted-badge { position: absolute; left: 10px; top: 10px; color: #fff; background: linear-gradient(135deg,var(--app-brand),#ef4444); padding: 4px 8px; border-radius: 999px; font-size: .67rem; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; box-shadow: 0 4px 16px rgba(0,0,0,.22); }
.status-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; margin-right: 4px; background: #94a3b8; }
.status-dot.online { background: #22c55e; box-shadow: 0 0 0 4px rgba(34,197,94,.14); }
.app-panel { background: var(--app-surface); border: 1px solid var(--app-line); border-radius: 22px; box-shadow: var(--app-shadow); }
.app-input, .form-control, .form-select { background-color: var(--app-surface); color: var(--app-text); border-color: var(--app-line); }
.form-control:focus, .form-select:focus { background-color: var(--app-surface); color: var(--app-text); border-color: var(--app-brand); box-shadow: 0 0 0 .25rem rgba(249,115,22,.14); }
.text-muted { color: var(--app-muted) !important; }
.bg-white, .card { background-color: var(--app-surface) !important; color: var(--app-text); }
.border, .card { border-color: var(--app-line) !important; }
.btn-brand { --bs-btn-color:#fff; --bs-btn-bg:var(--app-brand); --bs-btn-border-color:var(--app-brand); --bs-btn-hover-color:#fff; --bs-btn-hover-bg:#ea580c; --bs-btn-hover-border-color:#ea580c; font-weight:800; }
.footer-app { margin-top: 64px; background: #07111f; color: #d7e0ec; border-top: 1px solid #1e3048; }
.footer-app a { color: #d7e0ec; text-decoration: none; }
.footer-app a:hover { color: #fb923c; }
.footer-kicker { color: #fb923c; font-size: .76rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.age-gate { position: fixed; inset: 0; z-index: 2000; display: none; place-items: center; padding: 24px; background: rgba(2, 6, 23, .88); backdrop-filter: blur(18px); }
.age-gate.is-visible { display: grid; }
.age-gate-card { width: min(520px,100%); padding: 36px; border-radius: 26px; color: #e8edf5; background: #0f1b2e; border: 1px solid #334155; box-shadow: 0 30px 100px rgba(0,0,0,.55); text-align: center; }
.age-icon { width: 72px; height: 72px; display: grid; place-items: center; margin: 0 auto 18px; border-radius: 24px; background: linear-gradient(135deg,var(--app-brand),#ef4444); font-size: 1.45rem; font-weight: 950; }
.cookie-notice { position: fixed; z-index: 1080; right: 18px; bottom: 18px; width: min(430px,calc(100% - 36px)); padding: 18px; background: #0f1b2e; color: #e8edf5; border: 1px solid #334155; border-radius: 18px; box-shadow: 0 24px 70px rgba(0,0,0,.35); display:none; }
.cookie-notice.is-visible { display:block; }
.empty-state { padding: 48px 24px; text-align: center; color: var(--app-muted); }
.reference-code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; letter-spacing: .04em; }
.hover-lift { transition: transform .2s ease, box-shadow .2s ease; }
.hover-lift:hover { transform: translateY(-3px); box-shadow: var(--app-shadow) !important; }
.btn-social { width: 38px; height: 38px; display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;color:#fff; }
@media (max-width: 767.98px) {
    .promoted-track { grid-auto-columns: minmax(142px, 160px); }
    .footer-app { text-align: center; }
}
@media (prefers-reduced-motion: reduce) { *,*::before,*::after{scroll-behavior:auto!important;transition:none!important;animation:none!important} }

/* Public interface v2 */
.py-lg-6 { padding-top: 5.5rem !important; padding-bottom: 5.5rem !important; }
.hero-shell { position: relative; overflow: hidden; border-bottom: 1px solid var(--app-line); background: linear-gradient(140deg, rgba(249,115,22,.15), transparent 42%), linear-gradient(320deg, rgba(59,130,246,.10), transparent 44%), var(--app-surface); }
.hero-shell::before { content:""; position:absolute; width:420px; height:420px; border:1px solid rgba(249,115,22,.18); border-radius:50%; right:-130px; top:-180px; box-shadow:0 0 0 55px rgba(249,115,22,.035),0 0 0 110px rgba(249,115,22,.025); pointer-events:none; }
.hero-chip { display:inline-flex; align-items:center; gap:9px; padding:8px 12px; border-radius:999px; border:1px solid rgba(249,115,22,.25); background:rgba(249,115,22,.09); color:var(--app-brand); font-size:.78rem; font-weight:850; letter-spacing:.03em; }
.pulse-dot { display:inline-block; width:8px; height:8px; border-radius:50%; background:#22c55e; box-shadow:0 0 0 5px rgba(34,197,94,.14); }
.hero-title { max-width:850px; font-size:clamp(2.7rem,7vw,5.6rem); line-height:.97; letter-spacing:-.065em; font-weight:950; }
.hero-title span { color:var(--app-brand); }
.hero-copy { max-width:690px; margin-top:1.4rem; font-size:clamp(1.05rem,2vw,1.3rem); line-height:1.7; color:var(--app-muted); }
.hero-metrics { display:flex; flex-wrap:wrap; gap:1.1rem 2.4rem; }
.hero-metrics div { display:grid; }
.hero-metrics strong { font-size:1.6rem; letter-spacing:-.04em; }
.hero-metrics span { color:var(--app-muted); font-size:.78rem; font-weight:750; text-transform:uppercase; letter-spacing:.07em; }
.hero-visual { position:relative; padding:18px; transform:rotate(1.25deg); }
.hero-visual-top,.hero-visual-foot { display:flex; align-items:center; justify-content:space-between; gap:12px; font-size:.78rem; font-weight:800; }
.hero-visual-foot { justify-content:flex-start; padding-top:16px; color:var(--app-muted); line-height:1.45; }
.hero-visual-foot i { color:#22c55e; font-size:1.25rem; }
.status-chip { display:inline-flex; align-items:center; padding:5px 9px; border-radius:999px; background:var(--app-surface-2); color:var(--app-muted); }
.hero-mini-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:15px; }
.hero-mini-grid a { position:relative; overflow:hidden; aspect-ratio:4/3; border-radius:15px; color:#fff; background:var(--app-surface-2); }
.hero-mini-grid img { width:100%; height:100%; object-fit:cover; }
.hero-mini-grid a::after { content:""; position:absolute; inset:40% 0 0; background:linear-gradient(transparent,rgba(2,6,23,.85)); }
.hero-mini-grid a span { position:absolute; z-index:1; left:12px; right:12px; bottom:9px; font-weight:850; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.section-block { margin-top:clamp(3.5rem,8vw,6.5rem); }
.section-heading { display:flex; justify-content:space-between; align-items:end; gap:24px; margin-bottom:22px; }
.section-heading h2,.page-hero h1,.profile-header h1,.location-hero h1 { margin:.28rem 0 .35rem; font-size:clamp(2rem,4.2vw,3.3rem); font-weight:950; letter-spacing:-.05em; }
.section-heading p,.page-hero p { margin:0; color:var(--app-muted); }
.section-kicker { display:block; color:var(--app-brand); font-size:.73rem; font-weight:950; text-transform:uppercase; letter-spacing:.13em; }
.section-link { flex:0 0 auto; font-weight:850; text-decoration:none; }
.live-card { position:relative; overflow:hidden; border:1px solid var(--app-line); border-radius:19px; background:var(--app-surface); box-shadow:0 10px 28px rgba(15,23,42,.07); transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease; }
.live-card:hover { transform:translateY(-5px); border-color:rgba(249,115,22,.55); box-shadow:var(--app-shadow); }
.live-card-link { display:block; color:#fff; text-decoration:none; }
.live-card-link:hover { color:#fff; }
.live-card-media { position:relative; overflow:hidden; background:var(--app-surface-2); }
.live-card-media.model-media { aspect-ratio:4/5; }
.live-card-media.webcam-media { aspect-ratio:16/11; }
.live-card-media img { width:100%; height:100%; object-fit:cover; transition:transform .38s ease; }
.live-card:hover img { transform:scale(1.045); }
.media-gradient { position:absolute; inset:35% 0 0; background:linear-gradient(transparent,rgba(2,6,23,.92)); }
.live-pill,.quality-pill { position:absolute; top:10px; z-index:2; display:inline-flex; align-items:center; gap:7px; padding:5px 9px; border-radius:999px; color:#fff; font-size:.67rem; font-weight:950; letter-spacing:.05em; text-transform:uppercase; backdrop-filter:blur(8px); }
.live-pill { left:10px; background:rgba(15,23,42,.72); }
.quality-pill { right:10px; background:rgba(249,115,22,.9); }
.live-pill.static,.quality-pill.static { position:static; }
.live-card-overlay { position:absolute; z-index:2; left:12px; right:12px; bottom:11px; min-width:0; }
.live-card-name { font-size:.96rem; font-weight:900; }
.live-card-meta { display:flex; align-items:center; gap:5px; margin-top:2px; color:rgba(255,255,255,.75); font-size:.72rem; }
.media-placeholder { width:100%; height:100%; min-height:180px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; color:var(--app-muted); background:var(--app-surface-2); font-size:2.4rem; }
.page-hero,.profile-header { border-bottom:1px solid var(--app-line); background:linear-gradient(135deg,rgba(249,115,22,.10),transparent 45%),var(--app-surface); }
.page-hero a,.profile-header a,.location-hero a { text-decoration:none; font-weight:800; }
.pagination-app { gap:7px; }
.pagination-app .page-link { min-width:42px; height:42px; display:grid; place-items:center; border-radius:12px !important; border:1px solid var(--app-line); color:var(--app-text); background:var(--app-surface); }
.pagination-app .page-item.active .page-link { border-color:var(--app-brand); background:var(--app-brand); color:#fff; }
.tag-cloud { display:flex; flex-wrap:wrap; gap:10px; }
.tag-tile { display:flex; align-items:center; justify-content:space-between; gap:13px; min-width:150px; flex:1 1 170px; padding:13px 15px; border:1px solid var(--app-line); border-radius:14px; color:var(--app-text); text-decoration:none; background:var(--app-surface-2); transition:transform .18s,border-color .18s; }
.tag-tile:hover { color:var(--app-text); transform:translateY(-2px); border-color:var(--app-brand); }
.tag-tile span { min-width:0; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; font-weight:850; }
.tag-tile strong { padding:3px 7px; border-radius:999px; color:var(--app-brand); background:rgba(249,115,22,.10); font-size:.72rem; }
.share-bar { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:18px 20px; }
.share-bar div { display:grid; }
.directory-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.directory-continent { overflow:hidden; }
.directory-continent-head { display:flex; align-items:center; gap:10px; padding:17px 19px; border-bottom:1px solid var(--app-line); font-size:1rem; font-weight:900; }
.directory-continent-head i { color:var(--app-brand); }
.directory-continent .accordion-item,.directory-continent .accordion-button { color:var(--app-text); background:var(--app-surface); border-color:var(--app-line); }
.directory-continent .accordion-button:not(.collapsed) { color:var(--app-brand); box-shadow:none; }
.directory-link-row { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 18px; border-top:1px solid var(--app-line); }
.directory-link-row>a:first-child { min-width:0; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; color:var(--app-text); font-weight:750; text-decoration:none; }
.country-flag { border-radius:8px; box-shadow:0 7px 20px rgba(15,23,42,.16); }
.location-hero { color:var(--app-text); background:var(--app-surface); border-bottom:1px solid var(--app-line); }
.location-hero.has-image { color:#fff; background-image:var(--location-image); background-position:center; background-size:cover; }
.location-hero-overlay { background:linear-gradient(90deg,rgba(2,6,23,.87),rgba(2,6,23,.48)); }
.location-hero:not(.has-image) .location-hero-overlay { background:linear-gradient(135deg,rgba(249,115,22,.12),transparent); }
.stream-frame { overflow:hidden; border:1px solid var(--app-line); border-radius:24px; background:#020617; box-shadow:0 25px 70px rgba(2,6,23,.28); }
.stream-frame iframe,.stream-frame img { width:100%; height:100%; border:0; object-fit:contain; }
.profile-facts { display:grid; gap:0; margin:18px 0; }
.profile-facts div,.info-stack div { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:11px 0; border-bottom:1px solid var(--app-line); }
.profile-facts dt,.info-stack span { color:var(--app-muted); font-size:.78rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em; }
.profile-facts dd { margin:0; font-weight:900; }
.profile-tags { display:flex; flex-wrap:wrap; gap:7px; }
.profile-tags a { padding:5px 9px; border-radius:999px; color:var(--app-text); background:var(--app-surface-2); text-decoration:none; font-size:.75rem; font-weight:800; }
.info-stack { display:grid; }
.info-stack strong { text-align:right; word-break:break-word; }
.legal-content { font-size:1.02rem; line-height:1.78; }
.legal-content h2 { margin-top:2rem; font-size:1.4rem; font-weight:900; }
@media (max-width: 991.98px) { .hero-visual { transform:none; } .directory-grid { grid-template-columns:1fr; } }
@media (max-width: 767.98px) { .py-lg-6 { padding-top:3.8rem!important; padding-bottom:3.8rem!important; } .hero-title { font-size:3.1rem; } .section-heading,.share-bar { align-items:flex-start; flex-direction:column; } .hero-metrics { justify-content:space-between; gap:1rem; } .live-card-media.model-media { aspect-ratio:4/5.25; } }
