/* The Porno Tour Guide — premium nocturne editorial theme.
   Palette: midnight aubergine + warm gold + muted rose. Distinct from network. */
:root{
  --bg:#0d0a12; --bg2:#141019; --surface:#1b1422; --surface2:#231a2d;
  --line:#33263f; --text:#efe9f2; --muted:#a99fb5; --faint:#7d7388;
  --gold:#e3b25a; --gold-2:#f0cd86; --rose:#d6486b; --rose-2:#e76a89;
  --ok:#5ad1a0; --radius:16px; --maxw:1140px;
  --shadow:0 12px 40px rgba(0,0,0,.45);
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:
    radial-gradient(1100px 520px at 78% -8%,rgba(214,72,107,.16),transparent 60%),
    radial-gradient(900px 480px at 8% 4%,rgba(227,178,90,.10),transparent 55%),
    var(--bg);
  color:var(--text);font-family:var(--sans);line-height:1.65;font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold-2);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.5vw,3.1rem);margin:.2em 0 .35em}
h2{font-size:clamp(1.45rem,3vw,2.05rem);margin:1.8em 0 .5em}
h3{font-size:1.22rem;margin:1.4em 0 .4em}
p{margin:0 0 1.05em}
small{color:var(--faint)}

/* ---- top bar / masthead ---- */
.topbar{background:rgba(13,10,18,.85);border-bottom:1px solid var(--line);backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:40}
.topbar-in{display:flex;align-items:center;gap:18px;height:62px}
.brand{font-family:var(--serif);font-size:1.32rem;font-weight:600;white-space:nowrap;color:var(--text)}
.brand b{color:var(--gold)}
.brand:hover{text-decoration:none}
.spacer{flex:1}
.geo-form{display:flex;align-items:center;gap:7px;font-size:.84rem;color:var(--muted)}
.geo-form select{background:var(--surface2);color:var(--text);border:1px solid var(--line);
  border-radius:10px;padding:6px 9px;font:inherit;font-size:.84rem}
.nav-toggle{display:none}

/* ---- nav ---- */
.mainnav{border-bottom:1px solid var(--line);background:var(--bg2)}
.mainnav ul{display:flex;flex-wrap:wrap;gap:2px;list-style:none;margin:0;padding:0}
.mainnav a{display:block;padding:13px 15px;color:var(--muted);font-size:.92rem;font-weight:500;
  border-bottom:2px solid transparent}
.mainnav a:hover{color:var(--text);text-decoration:none}
.mainnav a.active{color:var(--gold-2);border-bottom-color:var(--gold)}

/* ---- hero ---- */
.hero{padding:54px 0 34px}
.hero.has-atmos{position:relative;border-radius:var(--radius);overflow:hidden;margin-top:20px;
  padding:52px 30px 40px;
  background:linear-gradient(180deg,rgba(13,10,18,.74),rgba(13,10,18,.93)),
             url(/assets/img/atmos-hero.webp) center/cover no-repeat;}
.hero .eyebrow{color:var(--gold);text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;font-weight:700;margin-bottom:14px}
.hero p.lead{font-size:1.18rem;color:var(--muted);max-width:60ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:999px;
  font-weight:700;font-size:.98rem;border:1px solid transparent;cursor:pointer;transition:transform .12s ease}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-cam{background:linear-gradient(135deg,var(--rose),var(--rose-2));color:#fff}
.btn-dating{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#2a1d07}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn-sm{padding:9px 16px;font-size:.86rem}

/* ---- cards / grid ---- */
.grid{display:grid;gap:18px;margin:26px 0}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column}
.card .pad{padding:18px 20px 20px}
.card h3{margin-top:0}
.card .thumb{aspect-ratio:16/10;background:var(--surface2);object-fit:cover;width:100%}
.tag{display:inline-block;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;
  color:var(--gold);background:rgba(227,178,90,.12);border:1px solid rgba(227,178,90,.3);
  padding:3px 9px;border-radius:999px}

/* ---- editorial body ---- */
.prose{max-width:74ch}
.prose ul,.prose ol{margin:0 0 1.1em;padding-left:1.3em}
.prose li{margin:.3em 0}
.prose blockquote{border-left:3px solid var(--gold);margin:1.3em 0;padding:.4em 1.1em;color:var(--muted);font-style:italic}
.section{padding:14px 0 8px}

/* ---- comparison table (honest, no fabricated ratings) ---- */
.cmp{width:100%;border-collapse:collapse;margin:22px 0;font-size:.95rem}
.cmp th,.cmp td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.cmp th{color:var(--gold);font-size:.78rem;text-transform:uppercase;letter-spacing:.07em}
.cmp tr:hover td{background:var(--surface)}

/* ---- callouts ---- */
.note{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--gold);
  border-radius:12px;padding:16px 18px;margin:22px 0}
.note.warn{border-left-color:var(--rose)}
.note h4{margin:0 0 .4em;font-family:var(--sans);font-size:1rem}

/* ---- offer band ---- */
.offer{background:linear-gradient(135deg,var(--surface2),var(--surface));border:1px solid var(--line);
  border-radius:var(--radius);padding:26px;margin:34px 0;text-align:center}
.offer h3{margin-top:0}

/* ---- breadcrumb ---- */
.crumbs{font-size:.82rem;color:var(--faint);padding:16px 0 0}
.crumbs a{color:var(--muted)}

/* ---- FAQ ---- */
.faq details{border:1px solid var(--line);border-radius:12px;background:var(--surface);margin:10px 0;padding:2px 16px}
.faq summary{cursor:pointer;font-weight:600;padding:13px 0}
.faq details[open] summary{color:var(--gold-2)}

/* ---- footer ---- */
.site-footer{border-top:1px solid var(--line);background:var(--bg2);margin-top:60px;padding:44px 0 30px}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.footer-col h4{font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--gold);margin:0 0 12px}
.footer-col a{display:block;color:var(--muted);font-size:.9rem;padding:3px 0}
.footer-bottom{border-top:1px solid var(--line);margin-top:30px;padding-top:20px;color:var(--faint);font-size:.82rem}
.disclaimer{margin-top:12px;font-size:.8rem;color:var(--faint);max-width:90ch}

/* ---- sticky cam CTA ---- */
.sticky-cta{position:fixed;right:18px;bottom:18px;z-index:45;background:linear-gradient(135deg,var(--rose),var(--rose-2));
  color:#fff;padding:13px 20px;border-radius:999px;font-weight:700;box-shadow:var(--shadow);display:flex;align-items:center;gap:9px}
.sticky-cta:hover{text-decoration:none;transform:translateY(-2px)}
.live-dot{width:9px;height:9px;border-radius:50%;background:#ff5470;box-shadow:0 0 0 0 rgba(255,84,112,.7);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,84,112,.6)}70%{box-shadow:0 0 0 12px rgba(255,84,112,0)}100%{box-shadow:0 0 0 0 rgba(255,84,112,0)}}

/* ---- 18+ gate ---- */
.agegate{position:fixed;inset:0;z-index:100;background:rgba(8,6,12,.96);display:flex;align-items:center;justify-content:center;padding:24px}
.agegate[hidden]{display:none}   /* the hidden attribute must actually hide it (overrides display:flex) */
.agegate-box{max-width:440px;text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow)}
.agegate h2{margin-top:0}
.agegate .btn{margin:6px}
.agehide{display:none}

@media(max-width:860px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .grid-3,.grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  body{font-size:16px}
  .mainnav ul{flex-wrap:nowrap;overflow-x:auto}
  .brand{font-size:1.1rem}
}
