body{
  background: #0b0a12;
  color: #ffffff;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  line-height: 1.5;
}

h1, h2, h3{
  font-weight: 800;
  margin: 0 0 12px;
}

a{
  color: #ff3fa4;
  text-decoration: none;
}

button{
  background: linear-gradient(135deg, #ff3fa4, #7b00ff);
  color: #000;
  border: none;
  border-radius: 999px;
  padding: 10px 16px;
  font-weight: 800;
  cursor: pointer;
}
/* =========================
   ErotikCheck.de – style.css
   Komplett neu (Homepage)
   ========================= */

/* ---------- Reset / Base ---------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
:root{
  --bg0: #0b0a12;
  --bg1: #130b1f;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.08);
  --border: rgba(255,255,255,.10);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);

  --pink: #ff3fa4;
  --violet: #7b00ff;
  --amber: #ffd166;
  --shadow: 0 14px 34px rgba(0,0,0,.45);
  --shadow2: 0 10px 22px rgba(0,0,0,.35);
  --r: 18px;
}

body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--text);
  background:
    radial-gradient(1200px 700px at 20% 20%, rgba(255,63,164,.35) 0%, rgba(123,0,255,.15) 40%, rgba(0,0,0,0) 70%),
    radial-gradient(900px 600px at 70% 30%, rgba(123,0,255,.25) 0%, rgba(255,63,164,.10) 45%, rgba(0,0,0,0) 75%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
  min-height: 100vh;
}

/* ---------- Container ---------- */
.container{
  width: min(1100px, calc(100% - 40px));
  margin: 0 auto;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  line-height: 1;
  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease, background .12s ease;
  user-select: none;
}

.btn:hover{ transform: translateY(-1px); filter: brightness(1.03); }
.btn:active{ transform: translateY(0); }

.btn-primary{
  background: linear-gradient(135deg, var(--pink), var(--violet));
  color: #111;
  box-shadow: 0 10px 22px rgba(0,0,0,.35);
}

.btn-ghost{
  background: transparent;
  color: var(--text);
  border-color: rgba(255,255,255,.18);
}

.btn-outline{
  background: rgba(0,0,0,.15);
  color: var(--amber);
  border-color: rgba(255,209,102,.55);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.15);
}

.btn-small{ padding: 9px 12px; font-weight: 800; }

/* ---------- Header ---------- */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(10,8,16,.55);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.site-header-inner{
  width: min(1100px, calc(100% - 40px));
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 18px;
  padding: 12px 0;
}

.site-logo{ flex: 0 0 auto; }

.site-nav{
  flex: 1 1 auto;
  display:flex;
  align-items:center;
  gap: 14px;
  justify-content:flex-start;
}

.nav-link{
  text-decoration: none;
  font-weight: 800;
  color: rgba(255,255,255,.85);
  padding: 8px 10px;
  border-radius: 10px;
  transition: background .12s ease, color .12s ease;
}
.nav-link:hover{
  background: rgba(255,255,255,.06);
  color: #fff;
}

.site-auth{
  flex: 0 0 auto;
  display:flex;
  align-items:center;
  gap: 10px;
}

/* ---------- Logo (wie dein Screenshot) ---------- */
.ec-logo{
  display:flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
  white-space: nowrap;
}

.ec-badge{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  color: #fff;
  font-size: 22px;
  font-weight: 900;
  background: radial-gradient(circle at 30% 30%, #ff59b7 0%, #c300ff 55%, #7b00ff 100%);
  box-shadow: 0 10px 22px rgba(0,0,0,.45), inset 0 2px 6px rgba(255,255,255,.18);
}

.ec-text{
  display:flex;
  flex-direction:column;
  line-height: 1.05;
}

.ec-title{
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  text-shadow: 0 2px 0 rgba(0,0,0,.65), 0 0 10px rgba(0,0,0,.30);
}

.ec-sub{
  margin-top: 4px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 2.4px;
  color: rgba(255,255,255,.70);
  text-shadow: 0 1px 0 rgba(0,0,0,.55);
}

/* ---------- Main ---------- */
.main{
  width: min(1100px, calc(100% - 40px));
  margin: 0 auto;
  padding: 26px 0 70px;
}

/* ---------- Hero ---------- */
.hero{
  padding: 28px 0 10px;
}

.hero-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 24px;
}

.hero-text-block{
  flex: 1 1 640px;
}

.hero h1{
  margin: 0 0 10px;
  font-size: clamp(34px, 4.3vw, 54px);
  line-height: 1.05;
  font-weight: 950;
}

.hero-highlight{
  color: rgba(255,255,255,.90);
  background: linear-gradient(135deg, rgba(255,63,164,.95), rgba(123,0,255,.95));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-text{
  margin: 10px 0 16px;
  color: var(--muted);
  font-weight: 700;
  max-width: 56ch;
}

.hero-search{
  display:flex;
  gap: 12px;
  align-items:center;
  flex-wrap: wrap;
  margin-top: 10px;
}

.hero-search input[type="text"]{
  flex: 1 1 360px;
  min-width: 240px;
  padding: 13px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  color: var(--text);
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.15);
}

.hero-search input[type="text"]::placeholder{
  color: rgba(255,255,255,.55);
}

.hero-search .btn{
  min-width: 140px;
}

.hero .small-note,
.hero small{
  display:block;
  margin-top: 10px;
  color: rgba(255,255,255,.65);
  font-weight: 700;
}

/* ---------- Sections / Panels ---------- */
.section{
  margin-top: 22px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow2);
  padding: 18px;
}

.section-title{
  margin: 0 0 14px;
  font-size: 20px;
  font-weight: 900;
  color: rgba(255,255,255,.90);
}

/* ---------- Top 10 Ladies Block ---------- */
.top10-header{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 16px;
  margin: 4px 0 14px;
  text-align:center;
}

.top10-header .crown{
  font-size: 34px;
  filter: drop-shadow(0 8px 10px rgba(0,0,0,.35));
}

.top10-header .top10-title{
  font-size: clamp(22px, 3.0vw, 34px);
  font-weight: 950;
  color: var(--amber);
  text-shadow: 0 2px 0 rgba(0,0,0,.55);
  letter-spacing: .5px;
}

/* Buttons row unter Top10 */
.home-actions{
  display:flex;
  justify-content:center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 10px 0 8px;
}

.home-actions .btn{
  min-width: 170px;
}

.empty-hint{
  margin: 10px 0 0;
  color: rgba(255,255,255,.75);
  font-weight: 800;
}

/* ---------- Reviews Block ---------- */
.reviews-header{
  display:flex;
  align-items:center;
  justify-content:center;
  margin: 6px 0 12px;
  text-align:center;
}

.reviews-header h2,
.reviews-header .section-title{
  margin: 0;
  font-size: 22px;
  font-weight: 950;
}

.review-list{
  display:grid;
  gap: 12px;
}

.review-card{
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  padding: 14px;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.12);
}

.review-card .meta{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items:center;
  color: rgba(255,255,255,.70);
  font-weight: 800;
  font-size: 12px;
  margin-bottom: 8px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
}

.badge-amber{
  border-color: rgba(255,209,102,.55);
  color: var(--amber);
}

.review-card .title{
  font-weight: 950;
  margin: 0 0 6px;
}

.review-card .text{
  margin: 0;
  color: rgba(255,255,255,.82);
  font-weight: 650;
}

/* ---------- Age Modal / Gate (falls vorhanden) ---------- */
.age-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.age-note{
  margin: 10px 0 0;
  color: rgba(255,255,255,.70);
  font-weight: 700;
}

/* ---------- Utilities ---------- */
.center{ text-align:center; }
.mt-0{ margin-top:0; }
.mt-10{ margin-top:10px; }
.mt-16{ margin-top:16px; }
.mt-22{ margin-top:22px; }

/* ---------- Responsive ---------- */
@media (max-width: 920px){
  .site-header-inner{ gap: 12px; }
  .site-nav{ gap: 10px; }
}

@media (max-width: 760px){
  .site-header-inner{
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .site-nav{
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .site-auth{
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .hero-inner{ flex-direction: column; }
  .hero-search .btn{ width: 100%; }
  .hero-search input[type="text"]{ width: 100%; }
}

@media (max-width: 480px){
  .ec-badge{ width: 36px; height: 36px; font-size: 20px; }
  .ec-title{ font-size: 20px; }
  .ec-sub{ font-size: 10px; letter-spacing: 2.0px; }

  .home-actions .btn{ width: 100%; }
}
/* ===== FORCE NEW LAYOUT (FINAL) ===== */

/* Header */
.site-header{
  background: rgba(10,8,16,.55);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.site-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

/* Logo */
.site-logo{ flex:0 0 auto; }

.ec-logo{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  white-space:nowrap;
}

.ec-badge{
  width:42px;
  height:42px;
  border-radius:50%;
  background: radial-gradient(circle at 30% 30%, #ff59b7 0%, #c300ff 55%, #7b00ff 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:22px;
  font-weight:900;
  box-shadow: 0 10px 22px rgba(0,0,0,.45), inset 0 2px 6px rgba(255,255,255,.18);
}

.ec-text{
  display:flex;
  flex-direction:column;
  line-height:1.05;
}

.ec-title{
  font-size:22px;
  font-weight:900;
  color:#fff;
  text-shadow: 0 2px 0 rgba(0,0,0,.65);
}

.ec-sub{
  font-size:11px;
  letter-spacing:2.4px;
  color:rgba(255,255,255,.7);
}

/* Navigation */
.site-nav{
  display:flex;
  gap:14px;
  align-items:center;
}

.site-auth{
  display:flex;
  gap:10px;
  align-items:center;
}

/* ===== END FORCE ===== */
/* ===== AGE GATE CENTER FIX ===== */
.age-gate{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  z-index: 9999;
}

.age-card{
  margin: 0 auto;
  width: min(520px, 100%);
  text-align: center;
}
/* ===== Buttons unter Top-10 Karten ===== */
.home-actions-below{
  margin-top: 32px;   /* Abstand zu den Top-10 Bildern */
  padding-top: 24px;  /* zusätzlicher Luftabstand */
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Buttons gleich groß */
.home-actions-below .btn{
  min-width: 200px;
  justify-content: center;
}

/* Mobile: untereinander */
@media (max-width: 600px){
  .home-actions-below{
    flex-direction: column;
    align-items: stretch;
  }
  .home-actions-below .btn{
    width: 100%;
  }
}
/* ===== Top 10 Grid (Vorbereitung) ===== */
.top10-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
  margin-top: 20px;
}
/* ===== Top 10 Karten ===== */
.top10-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:18px;
  margin-top: 18px;
}

.lady-card{
  display:block;
  text-decoration:none;
  color: inherit;
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(0,0,0,.30);
  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease;
}

.lady-card:hover{
  transform: translateY(-2px);
  filter: brightness(1.02);
  box-shadow: 0 16px 34px rgba(0,0,0,.38);
}

.lady-img{
  position: relative;
  aspect-ratio: 16 / 10;
  background: rgba(255,255,255,.06);
}

.lady-img img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.lady-rank{
  position:absolute;
  top:10px;
  left:10px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 12px;
  color: #111;
  background: linear-gradient(135deg, var(--amber), #ff9f1c);
  box-shadow: 0 10px 18px rgba(0,0,0,.35);
}

.lady-body{
  padding: 14px 14px 16px;
}

.lady-title{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.lady-name{
  font-weight: 950;
  font-size: 16px;
  color: rgba(255,255,255,.95);
}

.lady-city{
  font-weight: 850;
  font-size: 12px;
  color: rgba(255,255,255,.70);
  letter-spacing: .3px;
}

.lady-rating{
  display:flex;
  align-items:center;
  gap: 8px;
  margin-bottom: 12px;
}

.rating-text{
  font-weight: 950;
  color: rgba(255,255,255,.92);
}

.rating-count{
  font-weight: 800;
  color: rgba(255,255,255,.60);
  font-size: 12px;
}

/* Sterne: 5 graue + goldener Overlay nach --rating (0..5) */
.stars{
  --star-size: 16px;
  --percent: calc(var(--rating) / 5 * 100%);
  position: relative;
  display: inline-block;
  font-size: var(--star-size);
  line-height: 1;
  letter-spacing: 2px;
}

.stars::before{
  content: "★★★★★";
  color: rgba(255,255,255,.25);
}

.stars::after{
  content: "★★★★★";
  position: absolute;
  left: 0;
  top: 0;
  width: var(--percent);
  overflow: hidden;
  color: var(--amber);
  text-shadow: 0 2px 8px rgba(0,0,0,.35);
}

.lady-cta{
  display:flex;
  justify-content:flex-end;
}

.lady-link{
  font-weight: 900;
  color: rgba(255,255,255,.88);
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}