/* === ChatEroticaGratis.com — base styles === */
:root{
  --c-bg:#0e0e10;
  --c-surface:#17171b;
  --c-surface-2:#1f1f25;
  --c-text:#f4f4f5;
  --c-muted:#a1a1aa;
  --c-primary:#d6336c;
  --c-primary-2:#ff5c8a;
  --c-accent:#7c3aed;
  --c-border:#2a2a31;
  --radius:14px;
  --maxw:1120px;
  --maxw-narrow:760px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --font: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
@media (prefers-color-scheme: light){
  :root{ --c-bg:#fff; --c-surface:#fafafa; --c-surface-2:#f1f1f5; --c-text:#0e0e10; --c-muted:#52525b; --c-border:#e5e5ea; }
}
*{ box-sizing:border-box }
html{ scroll-behavior:smooth }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto } *{ animation:none!important; transition:none!important } }
body{
  margin:0; font-family:var(--font); color:var(--c-text); background:var(--c-bg);
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block }
a{ color:var(--c-primary-2); text-decoration:underline; text-underline-offset:3px }
a:hover{ color:var(--c-primary) }
:focus-visible{ outline:3px solid var(--c-primary-2); outline-offset:2px; border-radius:6px }

.skip-link{
  position:absolute; left:-9999px; top:0; background:var(--c-primary); color:#fff; padding:.75rem 1rem; z-index:9999;
}
.skip-link:focus{ left:1rem; top:1rem }

.container{ max-width:var(--maxw); margin:0 auto; padding:0 1.25rem }
.container--narrow{ max-width:var(--maxw-narrow) }

/* Header */
.site-header{ position:sticky; top:0; z-index:50; background:rgba(14,14,16,.85); backdrop-filter:saturate(160%) blur(10px); border-bottom:1px solid var(--c-border) }
.header__inner{ display:flex; align-items:center; justify-content:space-between; padding:.85rem 1.25rem }
.logo{ display:inline-flex; gap:.5rem; align-items:center; text-decoration:none; color:var(--c-text); font-weight:700 }
.logo__mark{ color:var(--c-primary) }
.logo__tld{ color:var(--c-muted); font-weight:500 }
.nav ul{ list-style:none; display:flex; gap:1.25rem; margin:0; padding:0 }
.nav a{ color:var(--c-text); text-decoration:none }
.nav a:hover{ color:var(--c-primary-2) }
@media (max-width:640px){ .nav ul{ gap:.75rem; font-size:.9rem } }

/* Buttons */
.btn{ display:inline-block; padding:.85rem 1.4rem; border-radius:var(--radius); font-weight:600; text-decoration:none; border:1px solid transparent; cursor:pointer; transition:transform .12s ease, background .2s ease }
.btn--primary{ background:linear-gradient(135deg,var(--c-primary),var(--c-accent)); color:#fff }
.btn--primary:hover{ color:#fff; transform:translateY(-1px) }
.btn--ghost{ background:transparent; color:var(--c-text); border-color:var(--c-border) }
.btn--lg{ padding:1rem 1.6rem; font-size:1.05rem }
.btn--sm{ padding:.5rem .9rem; font-size:.9rem }

/* Hero */
.hero{ padding:4rem 0 3rem; background:radial-gradient(1200px 500px at 50% -10%, rgba(214,51,108,.25), transparent 60%) }
.eyebrow{ color:var(--c-primary-2); font-weight:600; letter-spacing:.04em; text-transform:uppercase; font-size:.85rem; margin:0 0 .75rem }
.hero h1{ font-size:clamp(1.9rem, 4vw, 3rem); line-height:1.15; margin:0 0 1rem }
.hero__lead{ color:var(--c-muted); font-size:1.15rem; max-width:62ch }
.hero__cta{ display:flex; gap:.75rem; flex-wrap:wrap; margin:1.75rem 0 1.5rem }
.hero__trust{ display:flex; flex-wrap:wrap; gap:1rem 1.5rem; list-style:none; padding:0; margin:0; color:var(--c-muted); font-size:.95rem }

/* Sections */
.section{ padding:3.5rem 0 }
.section--alt{ background:var(--c-surface) }
.section--cta{ background:linear-gradient(135deg, rgba(214,51,108,.12), rgba(124,58,237,.12)); text-align:center }
.section h2{ font-size:clamp(1.5rem,2.5vw,2rem); margin:0 0 .75rem }
.section__lead{ color:var(--c-muted); margin:0 0 2rem }

/* Steps */
.steps{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.25rem }
.steps li{ background:var(--c-surface-2); border:1px solid var(--c-border); border-radius:var(--radius); padding:1.5rem }
.steps__num{ display:inline-grid; place-items:center; width:2.25rem; height:2.25rem; border-radius:999px; background:linear-gradient(135deg,var(--c-primary),var(--c-accent)); color:#fff; font-weight:700; margin-bottom:.5rem }
.steps h3{ margin:.25rem 0 .5rem }

/* Features */
.features{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.25rem }
.feature{ background:var(--c-surface-2); border:1px solid var(--c-border); border-radius:var(--radius); padding:1.5rem }
.feature h3{ margin:0 0 .5rem }

/* Form */
.enter-form{ max-width:520px; margin:1.5rem auto 0; display:grid; gap:1rem; text-align:left; background:var(--c-surface-2); border:1px solid var(--c-border); border-radius:var(--radius); padding:1.5rem }
.enter-form input[type=text]{ width:100%; padding:.85rem 1rem; border-radius:10px; border:1px solid var(--c-border); background:var(--c-bg); color:var(--c-text); font:inherit }
.enter-form fieldset{ border:0; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:1rem }
.enter-form legend{ margin-bottom:.5rem; color:var(--c-muted) }
.checkbox{ font-size:.95rem; color:var(--c-muted); display:flex; gap:.5rem; align-items:flex-start }
.checkbox a{ color:var(--c-primary-2) }

/* FAQ */
details{ background:var(--c-surface-2); border:1px solid var(--c-border); border-radius:var(--radius); padding:1rem 1.25rem; margin-bottom:.75rem }
details summary{ cursor:pointer; font-weight:600; list-style:none }
details summary::-webkit-details-marker{ display:none }
details[open] summary{ color:var(--c-primary-2) }

/* Legal pages */
.legal{ padding:2.5rem 0 4rem }
.legal h1{ font-size:clamp(1.8rem,3vw,2.4rem); margin-top:.5rem }
.legal h2{ margin-top:2rem }
.legal h3{ margin-top:1.25rem }
.legal p, .legal li{ color:var(--c-text) }
.breadcrumb{ color:var(--c-muted); font-size:.9rem; margin-bottom:1rem }
.table{ width:100%; border-collapse:collapse; margin:1rem 0 1.5rem; font-size:.95rem }
.table th, .table td{ border:1px solid var(--c-border); padding:.6rem .8rem; text-align:left }
.table thead th{ background:var(--c-surface-2) }

/* Footer */
.site-footer{ background:var(--c-surface); border-top:1px solid var(--c-border); margin-top:3rem; padding:2.5rem 0 1.5rem; color:var(--c-muted) }
.footer__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.5rem }
.site-footer h2{ font-size:1rem; color:var(--c-text); margin:0 0 .5rem }
.site-footer ul{ list-style:none; padding:0; margin:0; display:grid; gap:.4rem }
.site-footer a{ color:var(--c-muted) }
.site-footer a:hover{ color:var(--c-primary-2) }
.footer__logo{ font-weight:700; color:var(--c-text); margin:0 0 .5rem }
.footer__bottom{ border-top:1px solid var(--c-border); margin-top:1.5rem; padding-top:1rem; font-size:.85rem }
.rta{ font-size:.85rem; margin-top:.5rem }

/* Age gate */
.age-gate{ position:fixed; inset:0; background:rgba(0,0,0,.85); display:grid; place-items:center; z-index:9999; padding:1rem }
.age-gate[hidden]{ display:none }
.age-gate__inner{ background:var(--c-surface-2); border:1px solid var(--c-border); border-radius:var(--radius); max-width:520px; padding:2rem; text-align:center; box-shadow:var(--shadow) }
.age-gate__buttons{ display:flex; flex-direction:column; gap:.75rem; margin:1.25rem 0 .5rem }
.age-gate__legal{ font-size:.85rem; color:var(--c-muted); margin:.5rem 0 0 }
