/*
Theme Name: Golove AI App
Theme URI: https://golove-ai.app/
Author: Golove AI App
Description: Premium AI Girlfriend chatting platform theme. Modern, immersive, animated, SEO-optimized.
Version: 1.0.0
License: GPL v2 or later
Text Domain: golove-ai
*/

:root{
  --bg:#070617;
  --bg-2:#0e0a26;
  --panel:rgba(255,255,255,.04);
  --panel-2:rgba(255,255,255,.07);
  --border:rgba(255,255,255,.09);
  --text:#f4f1ff;
  --muted:#a8a3c6;
  --pink:#ff3ea5;
  --violet:#7a5cff;
  --cyan:#36e2ff;
  --gold:#ffd166;
  --grad:linear-gradient(135deg,#ff3ea5 0%,#7a5cff 50%,#36e2ff 100%);
  --grad-soft:linear-gradient(135deg,rgba(255,62,165,.18),rgba(122,92,255,.18));
  --radius:22px;
  --shadow:0 30px 80px -20px rgba(122,92,255,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:'Inter','Segoe UI',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}

html{scroll-behavior:auto !important}
body{overflow-y:auto !important;overscroll-behavior:auto !important}
*,*::before,*::after{animation:none !important;transition:none !important}
.btn:hover,.model-card:hover,.model-card:hover .ph img,.stat:hover,.step:hover,.blog:hover,.faq-item.open .faq-q::after,.model-hero-img,.model-hero-img:hover{transform:none !important;box-shadow:inherit}
.plan.featured{transform:none !important}

a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ---- background aurora removed for stable scrolling ---- */
body::before,body::after{content:none}

.container{max-width:1240px;margin:0 auto;padding:0 22px;position:relative;z-index:1}

/* ---- header ---- */
.site-header{position:relative;top:auto;z-index:50;backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(7,6,23,.96);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;letter-spacing:.3px}
.logo-mark{width:34px;height:34px;border-radius:11px;background:var(--grad);box-shadow:0 0 25px rgba(255,62,165,.55);display:grid;place-items:center;color:#fff;font-weight:900}
.nav-links{display:flex;gap:28px;font-size:15px}
.nav-links a{color:var(--muted);transition:.25s}
.nav-links a:hover{color:#fff}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:999px;font-weight:700;font-size:15px;background:var(--grad);color:#fff;box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease;position:relative;overflow:hidden}
.btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 30px 70px -10px rgba(255,62,165,.55)}
.btn-ghost{background:transparent;border:1px solid var(--border);color:#fff;box-shadow:none}
.btn-lg{padding:18px 38px;font-size:17px}

/* ---- hero (Section 1) ---- */
.hero{padding:80px 0 60px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero h1{font-size:clamp(40px,5.5vw,72px);line-height:1.04;letter-spacing:-1.5px;font-weight:900;background:linear-gradient(180deg,#fff,#c9c0ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero h1 span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{margin-top:24px;font-size:19px;color:var(--muted);max-width:560px;line-height:1.6}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-trust{display:flex;gap:30px;margin-top:36px;color:var(--muted);font-size:14px}
.hero-trust b{display:block;color:#fff;font-size:22px;font-weight:800}

/* ---- 3D rotating hero card stack ---- */
.hero-stage{height:560px;position:relative;display:flex;align-items:center;justify-content:center;pointer-events:none}
.hero-slider{position:relative;width:380px;max-width:90%;height:520px;border-radius:30px;overflow:hidden;box-shadow:0 40px 80px -20px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.08);background:#1a1336;pointer-events:none;user-select:none}
.hero-slide{position:absolute;inset:0;opacity:0;pointer-events:none}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;display:block}
.hero-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7) 100%)}
.hero-slide .card-name{position:absolute;left:22px;bottom:22px;z-index:2;font-weight:800;font-size:22px;color:#fff}
.hero-slide .card-name small{display:block;font-weight:500;font-size:13px;color:#d6cfff;margin-top:4px}
.hero-orb{display:none}

/* ---- section base ---- */
.section{padding:100px 0;position:relative}
.section-head{text-align:center;max-width:780px;margin:0 auto 60px}
.section-head .eyebrow{display:inline-block;padding:8px 16px;border:1px solid var(--border);border-radius:999px;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:18px;background:var(--panel)}
.section h2{font-size:clamp(32px,4vw,52px);line-height:1.1;font-weight:900;letter-spacing:-1px}
.section h2 i{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-head p{margin-top:18px;font-size:17px;color:var(--muted);line-height:1.65}

/* ---- gallery (Section 3) ---- */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.chip{padding:11px 22px;border-radius:999px;background:var(--panel);border:1px solid var(--border);color:var(--muted);font-size:14px;font-weight:600;transition:.25s}
.chip:hover{color:#fff;border-color:var(--pink)}
.chip.active{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 10px 30px -10px rgba(255,62,165,.6)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.model-card{position:relative;border-radius:22px;overflow:hidden;background:var(--panel);border:1px solid var(--border);transition:.4s cubic-bezier(.2,.8,.2,1)}
.model-card a{display:block}
.model-card:hover{transform:translateY(-8px) rotateX(2deg);box-shadow:var(--shadow)}
.model-card .ph{aspect-ratio:3/4;overflow:hidden;position:relative}
.model-card .ph img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.model-card:hover .ph img{transform:scale(1.08)}
.model-card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(7,6,23,.95) 100%)}
.model-card .info{position:absolute;left:16px;right:16px;bottom:14px;z-index:2;color:#fff}
.model-card .row1{display:flex;justify-content:space-between;align-items:center;gap:8px}
.model-card .name{font-weight:800;font-size:18px}
.model-card .name small{display:block;color:#d4cdf6;font-weight:500;font-size:12px;margin-top:2px}
.model-card .rating{display:inline-flex;align-items:center;gap:4px;font-size:13px;background:rgba(0,0,0,.45);padding:5px 10px;border-radius:999px;backdrop-filter:blur(6px)}
.model-card .rating::before{content:"★";color:var(--gold)}
.flag{position:absolute;top:14px;left:14px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);display:grid;place-items:center;font-size:18px;border:1px solid rgba(255,255,255,.2)}
.tag-online{position:absolute;top:14px;right:14px;z-index:2;background:rgba(0,200,120,.85);color:#fff;font-size:11px;font-weight:700;padding:5px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:1px}
.tag-online::before{content:"";display:inline-block;width:6px;height:6px;background:#fff;border-radius:50%;margin-right:6px}

/* ---- feature blocks (Section 4-7) ---- */
.feature-block{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-bottom:80px}
.feature-block.rev{direction:rtl}.feature-block.rev>*{direction:ltr}
.feature-card{padding:50px;border-radius:30px;background:var(--grad-soft);border:1px solid var(--border);position:relative;overflow:hidden}
.feature-card h2{margin-bottom:18px;font-size:clamp(28px,3vw,40px)}
.feature-card p{color:var(--muted);line-height:1.7;font-size:16px;margin-bottom:14px}
.feature-visual{aspect-ratio:1;border-radius:30px;background:var(--grad);position:relative;overflow:hidden;box-shadow:var(--shadow)}
.feature-visual img{width:100%;height:100%;object-fit:cover;mix-blend-mode:luminosity;opacity:.85}
.feature-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,62,165,.4),rgba(54,226,255,.3))}
.float-emoji{position:absolute;font-size:80px;filter:drop-shadow(0 10px 30px rgba(255,62,165,.5))}

/* ---- stats (Section 8) ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.stat{padding:36px;border-radius:24px;background:var(--panel);border:1px solid var(--border);text-align:center;transition:.3s}
.stat:hover{transform:translateY(-4px);border-color:var(--pink)}
.stat b{display:block;font-size:48px;font-weight:900;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat span{display:block;margin-top:10px;color:var(--muted);font-size:14px;text-transform:uppercase;letter-spacing:1.5px}

/* ---- how it works (Section 9) ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{padding:40px;border-radius:24px;background:var(--panel);border:1px solid var(--border);position:relative;transition:.3s}
.step:hover{transform:translateY(-6px);background:var(--panel-2)}
.step .num{position:absolute;top:30px;right:30px;font-size:70px;font-weight:900;color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.15);line-height:1}
.step h2{font-size:22px;margin-bottom:12px;margin-top:30px}
.step p{color:var(--muted);font-size:15px;line-height:1.65}

/* ---- testimonials (Section 10) ---- */
.testis{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{padding:32px;border-radius:22px;background:var(--panel);border:1px solid var(--border);position:relative}
.testi p{color:#e3deff;line-height:1.7;font-size:15px;margin-bottom:20px}
.testi p::before{content:"\201C";position:absolute;top:10px;right:24px;font-size:90px;color:var(--pink);opacity:.25;line-height:1}
.testi-foot{display:flex;align-items:center;gap:12px}
.testi-foot .av{width:42px;height:42px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-weight:800}
.testi-foot b{display:block;font-size:14px}
.testi-foot small{color:var(--muted);font-size:12px}

/* ---- pricing (Section 11) ---- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.plan{padding:40px;border-radius:24px;background:var(--panel);border:1px solid var(--border);position:relative;transition:.3s}
.plan.featured{background:var(--grad-soft);border-color:rgba(255,62,165,.5);transform:scale(1.04);box-shadow:var(--shadow)}
.plan .pl-name{font-size:14px;text-transform:uppercase;letter-spacing:2px;color:var(--muted)}
.plan .pl-price{font-size:54px;font-weight:900;margin:14px 0}.plan .pl-price small{font-size:16px;color:var(--muted);font-weight:500}
.plan ul{list-style:none;margin:24px 0}
.plan li{padding:10px 0;color:#e3deff;font-size:14px;display:flex;align-items:center;gap:10px}
.plan li::before{content:"✓";color:var(--cyan);font-weight:900}
.plan .btn{width:100%;justify-content:center}
.pl-badge{position:absolute;top:-12px;right:30px;background:var(--grad);color:#fff;font-size:11px;font-weight:700;padding:6px 12px;border-radius:999px;letter-spacing:1px;text-transform:uppercase}

/* ---- compare table (Section 12) ---- */
.compare{border-radius:24px;overflow:hidden;border:1px solid var(--border)}
.compare table{width:100%;border-collapse:collapse;background:var(--panel)}
.compare th,.compare td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--border);font-size:15px}
.compare th{background:rgba(255,255,255,.03);color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-size:12px;font-weight:700}
.compare td.yes{color:#36e2ff;font-weight:700}
.compare td.no{color:#ff5577;font-weight:700}

/* ---- safety (Section 13) ---- */
.safety{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.safety .step .ico{font-size:36px;display:inline-block;padding:14px;border-radius:14px;background:var(--grad);box-shadow:var(--shadow)}

/* ---- blog teaser (Section 14) ---- */
.blogs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog{padding:30px;border-radius:22px;background:var(--panel);border:1px solid var(--border);transition:.3s}
.blog:hover{transform:translateY(-4px);background:var(--panel-2)}
.blog .tag{font-size:11px;letter-spacing:2px;color:var(--pink);text-transform:uppercase;font-weight:700}
.blog h2{font-size:20px;margin:12px 0;line-height:1.35}
.blog p{color:var(--muted);font-size:14px;line-height:1.6}

/* ---- FAQ (Section 15) ---- */
.faq{max-width:880px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:18px;background:var(--panel);margin-bottom:14px;overflow:hidden;transition:.3s}
.faq-item.open{background:var(--panel-2);border-color:var(--pink)}
.faq-q{width:100%;padding:24px 30px;display:flex;justify-content:space-between;align-items:center;text-align:left;font-size:17px;font-weight:700}
.faq-q::after{content:"+";font-size:26px;color:var(--pink);transition:.3s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;padding:0 30px;color:var(--muted);line-height:1.7;font-size:15px}
.faq-item.open .faq-a{max-height:400px;padding:0 30px 24px}

/* ---- final CTA (Section 16) ---- */
.final-cta{text-align:center;padding:90px 50px;border-radius:36px;background:var(--grad);position:relative;overflow:hidden;box-shadow:var(--shadow)}
.final-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.2),transparent 50%)}
.final-cta h2{color:#fff;font-size:clamp(32px,4.5vw,56px);font-weight:900;letter-spacing:-1px;position:relative}
.final-cta p{margin:20px auto 36px;max-width:560px;color:rgba(255,255,255,.9);font-size:17px;position:relative;line-height:1.6}
.final-cta .btn{background:#fff;color:#1a0b3e;position:relative}

/* ---- footer ---- */
.site-footer{padding:70px 0 30px;border-top:1px solid var(--border);margin-top:80px;background:rgba(0,0,0,.3)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.foot-grid h2{font-size:14px;text-transform:uppercase;letter-spacing:2px;margin-bottom:18px;color:#fff}
.foot-grid a{display:block;color:var(--muted);font-size:14px;padding:6px 0;transition:.2s}
.foot-grid a:hover{color:#fff}
.foot-grid p{color:var(--muted);font-size:14px;line-height:1.6;margin-top:16px}
.foot-bottom{text-align:center;color:var(--muted);font-size:13px;padding-top:30px;border-top:1px solid var(--border)}

/* ---- single model page ---- */
.model-hero{padding:60px 0}
.model-hero-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.model-hero-img{aspect-ratio:3/4;border-radius:30px;overflow:hidden;box-shadow:var(--shadow);position:relative;transform:perspective(1200px) rotateY(-6deg);transition:.6s}
.model-hero-img:hover{transform:perspective(1200px) rotateY(0)}
.model-hero-img img{width:100%;height:100%;object-fit:cover}
.model-meta{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 26px}
.meta-pill{padding:8px 16px;border-radius:999px;background:var(--panel);border:1px solid var(--border);font-size:13px;color:#e3deff}
.model-bio{margin-top:50px;background:var(--panel);border:1px solid var(--border);border-radius:30px;padding:50px}
.model-bio h2{font-size:28px;margin-bottom:20px}
.model-bio p{color:var(--muted);line-height:1.75;font-size:16px;margin-bottom:18px}
.likes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:30px}
.like{padding:18px;border-radius:16px;background:var(--panel-2);text-align:center;font-size:14px}
.like span{font-size:28px;display:block;margin-bottom:6px}

/* ---- page content (Privacy, Terms, About, Contact) ---- */
.page-hero{padding:80px 0 40px;text-align:center}
.page-hero h1{font-size:clamp(36px,5vw,64px);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:900;letter-spacing:-1px}
.page-hero p{margin-top:18px;color:var(--muted);font-size:18px}
.legal{max-width:880px;margin:40px auto;padding:50px;background:var(--panel);border:1px solid var(--border);border-radius:24px}
.legal h2{font-size:22px;margin:30px 0 12px;color:#fff}
.legal p{color:var(--muted);line-height:1.7;font-size:15px;margin-bottom:10px}
.legal ol{counter-reset:l;list-style:none}
.legal ol>li{counter-increment:l;padding:14px 0 14px 50px;position:relative;border-bottom:1px solid var(--border)}
.legal ol>li::before{content:counter(l,decimal-leading-zero);position:absolute;left:0;top:14px;font-weight:900;color:var(--pink);font-size:18px}

/* ---- about extras ---- */
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:50px 0}
.about-card{padding:36px;border-radius:24px;background:var(--panel);border:1px solid var(--border);text-align:center}
.about-card .ico{font-size:46px;margin-bottom:14px;display:inline-block}
.timeline{max-width:900px;margin:60px auto;position:relative;padding-left:40px;border-left:2px solid var(--border)}
.tl-item{position:relative;padding:0 0 36px 30px}
.tl-item::before{content:"";position:absolute;left:-49px;top:6px;width:18px;height:18px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 6px rgba(122,92,255,.15)}
.tl-item time{display:block;color:var(--pink);font-weight:800;font-size:18px;margin-bottom:6px}
.tl-item p{color:var(--muted);font-size:15px;line-height:1.6}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;max-width:1000px;margin:0 auto}
.contact-form{background:var(--panel);border:1px solid var(--border);padding:40px;border-radius:24px}
.contact-form label{display:block;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:8px}
.contact-form input,.contact-form textarea{width:100%;padding:14px 18px;background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:12px;color:#fff;font:inherit;margin-bottom:18px;transition:.2s}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--pink);background:rgba(0,0,0,.4)}
.contact-info{padding:40px;border-radius:24px;background:var(--grad-soft);border:1px solid var(--border)}
.contact-info h2{font-size:22px;margin-bottom:14px}
.contact-info p{color:var(--muted);line-height:1.7;margin-bottom:20px}
.contact-info a{display:block;padding:10px 0;color:#fff;font-weight:600}

/* ---- responsive ---- */
@media(max-width:980px){
 .hero-grid,.feature-block,.model-hero-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
 .gallery{grid-template-columns:repeat(2,1fr)}
 .stats,.steps,.testis,.pricing,.safety,.blogs,.about-grid,.likes{grid-template-columns:repeat(2,1fr)}
 .foot-grid{grid-template-columns:1fr 1fr}
 .nav-links{display:none}
 .hero-stage{height:480px}
 .plan.featured{transform:none}
 .legal,.model-bio{padding:30px}
}
@media(max-width:560px){
 .gallery{grid-template-columns:1fr 1fr}
 .stats,.steps,.testis,.pricing,.safety,.blogs,.about-grid{grid-template-columns:1fr}
 .foot-grid{grid-template-columns:1fr}
}

/* reveal blocks are shown immediately to avoid any scroll-linked interference */
.reveal{opacity:1;transform:none;transition:none}
.reveal.in{opacity:1;transform:none}

/* Scroll-to-top button */
.to-top{position:fixed;right:24px;bottom:24px;width:48px;height:48px;border-radius:50%;border:none;background:var(--pink,#ff4d8d);color:#fff;font-size:22px;line-height:1;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;z-index:9998}
.to-top.show{display:flex}
@media(max-width:768px){.to-top{display:none !important}}

/* Cookie consent banner */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;max-width:1100px;margin:0 auto;background:rgba(20,20,28,.96);border:1px solid var(--border,#2a2a3a);color:#fff;border-radius:16px;padding:18px 22px;display:none;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;z-index:9999;box-shadow:0 10px 40px rgba(0,0,0,.5)}
.cookie-banner.show{display:flex}
.cookie-banner p{margin:0;flex:1;min-width:240px;font-size:14px;line-height:1.55;color:#d8d8e0}
.cookie-banner button{background:var(--pink,#ff4d8d);color:#fff;border:none;padding:12px 22px;border-radius:10px;font-weight:600;cursor:pointer;font-size:14px}
