/*
Theme Name: Nsfw Hot
Theme URI: https://nsfwhot.net/
Author: Nsfw Studio
Author URI: https://nsfwhot.net/
Description: A bold, modern WordPress theme for Nsfw — AI girlfriends and chatting. Features 12 AI model cards, an AI girlfriend generator, About, Terms, FAQ, reviews, JSON-LD SEO, and breadcrumbs on every inner page.
Version: 1.0.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: nsfwhot
Tags: landing, dark, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ==========  DESIGN TOKENS  ========== */
:root{
  --bg:#08060d;
  --bg-2:#0f0a18;
  --surface:#15101f;
  --surface-2:#1c1430;
  --line:rgba(255,255,255,.08);
  --text:#f4eefb;
  --muted:#a99fc1;
  --pink:#ff3d8b;
  --pink-2:#ff7ac6;
  --violet:#8a4dff;
  --cyan:#5be9ff;
  --grad-primary:linear-gradient(135deg,#ff3d8b 0%,#a04bff 55%,#5be9ff 110%);
  --grad-card:linear-gradient(160deg,rgba(255,61,139,.18),rgba(138,77,255,.05) 60%,rgba(91,233,255,.12));
  --grad-text:linear-gradient(90deg,#ff7ac6,#a48bff,#5be9ff);
  --shadow-soft:0 12px 40px -12px rgba(255,61,139,.45);
  --shadow-glow:0 0 0 1px rgba(255,122,198,.35),0 30px 80px -30px rgba(160,75,255,.65);
  --radius:18px;
  --radius-sm:12px;
  --max:1240px;
  --font-head:"Space Grotesk","Inter",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
}

/* ==========  RESET / BASE  ========== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  background-image:
    radial-gradient(800px 500px at 80% -10%,rgba(255,61,139,.18),transparent 60%),
    radial-gradient(700px 500px at -10% 30%,rgba(138,77,255,.18),transparent 60%),
    radial-gradient(600px 400px at 50% 110%,rgba(91,233,255,.10),transparent 60%);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--pink-2);text-decoration:none;transition:color .2s}
a:hover{color:var(--cyan)}
h1,h2{font-family:var(--font-head);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:0 0 .6em}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.5rem,3vw,2.4rem)}
p{margin:0 0 1em;color:#d8d0ec}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.text-grad{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ==========  HEADER  ========== */
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:rgba(8,6,13,.65);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:700;font-size:1.25rem}
.brand img{width:38px;height:38px;filter:drop-shadow(0 0 12px rgba(255,61,139,.55))}
.brand-mark{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.main-menu{display:flex;gap:28px;list-style:none;margin:0;padding:0}
.main-menu a{color:var(--text);font-weight:500;font-size:.95rem;position:relative}
.main-menu a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--grad-primary);transition:width .25s}
.main-menu a:hover::after{width:100%}
.nav-cta{padding:10px 20px;border-radius:999px;background:var(--grad-primary);color:#fff!important;font-weight:600;font-size:.9rem;box-shadow:var(--shadow-soft)}
.nav-cta::after{display:none!important}
.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:1.6rem;cursor:pointer}
@media(max-width:860px){
  .menu-toggle{display:block}
  .main-menu{position:fixed;inset:64px 0 auto 0;background:rgba(15,10,24,.98);flex-direction:column;padding:24px;gap:18px;transform:translateY(-200%);transition:.3s}
  .main-menu.open{transform:translateY(0)}
}

/* ==========  HERO  ========== */
.hero{padding:80px 0 60px;text-align:center;position:relative}
.hero-eyebrow{display:inline-block;padding:6px 14px;border:1px solid var(--line);
  border-radius:999px;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:22px;
  background:rgba(255,255,255,.03)}
.hero h1 span{display:block}
.hero p.lead{font-size:1.15rem;color:var(--muted);max-width:720px;margin:0 auto 32px}
.btn{display:inline-block;padding:14px 28px;border-radius:999px;font-weight:600;cursor:pointer;border:0;
  font-family:var(--font-head);letter-spacing:.01em;transition:transform .2s,box-shadow .2s}
.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow-soft)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 50px -10px rgba(255,61,139,.6);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--pink-2)}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ==========  MODEL GRID  ========== */
.section{padding:80px 0;position:relative}
.section-head{text-align:center;margin-bottom:50px}
.section-head p{color:var(--muted);max-width:680px;margin:0 auto}
.model-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:22px}
@media(max-width:1100px){.model-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:820px){.model-grid{grid-template-columns:repeat(3,1fr);gap:16px}}
@media(max-width:560px){.model-grid{grid-template-columns:repeat(2,1fr);gap:14px}}

.model-card{position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--grad-card);border:1px solid var(--line);
  transition:transform .3s,box-shadow .3s,border-color .3s;display:block;color:inherit}
.model-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-glow);border-color:rgba(255,122,198,.35)}
.model-card .thumb{aspect-ratio:3/4;overflow:hidden;position:relative}
.model-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.model-card:hover .thumb img{transform:scale(1.06)}
.model-card .thumb::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(8,6,13,.92) 100%)}
.model-card .meta{position:absolute;left:14px;right:14px;bottom:12px;z-index:2}
.model-card .name{font-family:var(--font-head);font-weight:700;font-size:1.05rem;margin:0}
.model-card .tag{font-size:.78rem;color:var(--pink-2);margin-top:2px}
.model-card .online{position:absolute;top:12px;left:12px;background:rgba(8,6,13,.7);
  backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.12);
  border-radius:999px;padding:4px 10px;font-size:.7rem;color:#9dffb6;z-index:2;display:flex;align-items:center;gap:6px}
.model-card .online::before{content:"";width:6px;height:6px;border-radius:50%;background:#26ff80;box-shadow:0 0 8px #26ff80}

/* ==========  REVIEWS  ========== */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}
.review{padding:26px;border-radius:var(--radius);
  background:linear-gradient(160deg,rgba(255,61,139,.08),rgba(138,77,255,.04));
  border:1px solid var(--line)}
.review .stars{color:#ffcf3b;letter-spacing:2px;margin-bottom:10px}
.review .who{display:flex;align-items:center;gap:12px;margin-top:16px}
.review .who .avatar{width:42px;height:42px;border-radius:50%;background:var(--grad-primary);
  display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-family:var(--font-head)}
.review .who .name{font-weight:600}
.review .who .role{font-size:.8rem;color:var(--muted)}

/* ==========  FAQ  ========== */
.faq{max-width:820px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);
  background:rgba(255,255,255,.02);margin-bottom:12px;overflow:hidden}
.faq-item summary{padding:18px 22px;cursor:pointer;font-weight:600;font-family:var(--font-head);
  display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.4rem;color:var(--pink-2);transition:transform .3s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .a{padding:0 22px 20px;color:var(--muted)}

/* ==========  FEATURES BAND  ========== */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:40px}
@media(max-width:900px){.features{grid-template-columns:repeat(2,1fr)}}
.feature{padding:24px;border-radius:var(--radius-sm);background:rgba(255,255,255,.03);border:1px solid var(--line)}
.feature .icon{width:42px;height:42px;border-radius:12px;background:var(--grad-primary);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;font-size:1.2rem;color:#fff}
.feature p{margin:0;color:var(--muted);font-size:.95rem}
.feature strong{display:block;margin-bottom:6px;font-family:var(--font-head);font-size:1.05rem}

/* ==========  BREADCRUMBS  ========== */
.breadcrumbs{padding:18px 0;font-size:.85rem;color:var(--muted);border-bottom:1px solid var(--line)}
.breadcrumbs a{color:var(--muted)}.breadcrumbs a:hover{color:var(--pink-2)}
.breadcrumbs .sep{margin:0 8px;opacity:.5}

/* ==========  PAGE / SINGLE  ========== */
.page-hero{padding:60px 0 30px;text-align:center}
.page-hero p.intro{max-width:760px;margin:0 auto;color:var(--muted);font-size:1.05rem}
.entry{max-width:860px;margin:0 auto;padding:30px 0 80px;font-size:1.02rem}
.entry h2{margin-top:2em}
.entry ul{padding-left:1.2em}
.entry li{margin-bottom:.4em}

/* ==========  MODEL SINGLE  ========== */
.model-hero{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center;padding:50px 0}
@media(max-width:820px){.model-hero{grid-template-columns:1fr}}
.model-hero .photo{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-glow);aspect-ratio:3/4}
.model-hero .photo img{width:100%;height:100%;object-fit:cover}
.profile{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px}
.profile div{padding:14px 16px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px}
.profile span{display:block;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:4px}
.profile b{font-family:var(--font-head);font-size:1rem}

/* ==========  GENERATOR  ========== */
.gen-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:start}
@media(max-width:900px){.gen-wrap{grid-template-columns:1fr}}
.gen-preview{position:sticky;top:90px;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:3/4;background:#0f0a18;border:1px solid var(--line);box-shadow:var(--shadow-glow)}
.gen-preview img{width:100%;height:100%;object-fit:cover;transition:opacity .35s}
.gen-controls .group{margin-bottom:26px;padding:20px;border:1px solid var(--line);border-radius:var(--radius-sm);background:rgba(255,255,255,.02)}
.gen-controls .group strong{display:block;font-family:var(--font-head);margin-bottom:12px;font-size:1.05rem}
.opts{display:flex;flex-wrap:wrap;gap:10px}
.opts button{padding:9px 16px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--text);cursor:pointer;font-size:.9rem;transition:.2s}
.opts button:hover{border-color:var(--pink-2)}
.opts button.active{background:var(--grad-primary);border-color:transparent;box-shadow:var(--shadow-soft);color:#fff}

/* ==========  FOOTER  ========== */
.site-footer{border-top:1px solid var(--line);padding:50px 0 30px;margin-top:60px;
  background:linear-gradient(180deg,transparent,rgba(255,61,139,.04))}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:30px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr}}
.foot-grid h2{font-size:1rem;font-family:var(--font-head);margin-bottom:14px;color:var(--pink-2)}
.foot-grid ul{list-style:none;padding:0;margin:0}
.foot-grid li{margin-bottom:8px}
.foot-grid a{color:var(--muted)}
.foot-grid a:hover{color:var(--text)}
.foot-bottom{border-top:1px solid var(--line);padding-top:20px;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.85rem}

/* ==========  SCROLL TOP  ========== */
.scroll-up{position:fixed;right:22px;bottom:22px;width:48px;height:48px;border-radius:50%;
  background:var(--grad-primary);border:0;color:#fff;font-size:1.4rem;cursor:pointer;
  box-shadow:var(--shadow-soft);opacity:0;pointer-events:none;transform:translateY(20px);transition:.3s;z-index:60}
.scroll-up.show{opacity:1;pointer-events:auto;transform:translateY(0)}

/* ==========  ANIMATIONS  ========== */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.fade-in{opacity:0;transform:translateY(20px);transition:.6s ease}
.fade-in.show{opacity:1;transform:none}
