:root{
  --bg:#0b0814; --bg2:#140a22;
  --ink:#f7f3ff; --muted:#bca8d9;
  --pink:#ff5fb4; --pink2:#ff9ad1;
  --violet:#8a4cff; --violet2:#c08bff;
  --grad: linear-gradient(135deg,#ff5fb4 0%,#8a4cff 60%,#5cd6ff 100%);
  --card:#1a1130; --border:#2c1d4a;
  --radius:18px;
  --shadow:0 18px 60px rgba(138,76,255,.25);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
.container{max-width:1200px;margin:0 auto;padding:0 22px}

/* Aurora background */
.bg-aurora{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 50% at 20% 10%, rgba(255,95,180,.25), transparent 60%),
    radial-gradient(60% 50% at 80% 20%, rgba(138,76,255,.28), transparent 60%),
    radial-gradient(50% 50% at 50% 100%, rgba(92,214,255,.18), transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  filter:saturate(1.05);
}
.bg-aurora::after{
  content:"";position:absolute;inset:-20%;
  background:radial-gradient(2px 2px at 20% 30%, #fff8 50%, transparent 51%),
             radial-gradient(2px 2px at 70% 60%, #fff8 50%, transparent 51%),
             radial-gradient(1.5px 1.5px at 40% 80%, #fff5 50%, transparent 51%);
  opacity:.25; animation: drift 30s linear infinite;
}
@keyframes drift{from{transform:translate3d(0,0,0)}to{transform:translate3d(-40px,-40px,0)}}

/* Header */
.site-header{position:sticky;top:0;z-index:30;backdrop-filter:blur(14px);
  background:rgba(11,8,20,.55);border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;gap:20px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{width:40px;height:40px;filter:drop-shadow(0 6px 14px rgba(255,95,180,.4))}
.brand-name{font-weight:800;letter-spacing:.3px;font-size:20px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.primary-nav{display:flex;align-items:center;gap:22px}
.primary-nav a{color:#e9deff;font-weight:500;font-size:15px;opacity:.9;transition:opacity .2s}
.primary-nav a:hover{opacity:1}

/* Buttons */
.btn-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--grad);color:#fff;padding:12px 22px;border-radius:999px;
  font-weight:700;border:0;cursor:pointer;
  box-shadow:0 10px 30px rgba(255,95,180,.45), inset 0 1px 0 rgba(255,255,255,.4);
  transition:transform .2s ease, box-shadow .2s ease}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(138,76,255,.55), inset 0 1px 0 rgba(255,255,255,.4)}
.btn-cta.big{padding:16px 32px;font-size:17px}
.btn-cta.small{padding:9px 16px;font-size:14px}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;padding:13px 22px;border-radius:999px;
  border:1px solid rgba(255,255,255,.2);color:#fff;background:rgba(255,255,255,.04);font-weight:600}
.btn-ghost:hover{background:rgba(255,255,255,.1)}

/* Hero */
.hero{padding:80px 0 60px;position:relative}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.eyebrow{display:inline-block;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  padding:6px 14px;border-radius:999px;font-size:13px;color:#f0d9ff;letter-spacing:.3px}
.hero h1{font-size:clamp(36px,5.5vw,62px);line-height:1.05;margin:18px 0 14px;font-weight:900;letter-spacing:-.02em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 4px 30px rgba(138,76,255,.15)}
.hero .lead{font-size:18px;color:#e7d8ff;max-width:560px;margin:0 0 26px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.hero-bullets{list-style:none;padding:0;margin:0;display:flex;gap:18px;flex-wrap:wrap;color:#cdb8ee;font-size:14px}
.hero-bullets li::before{content:"✦ ";color:var(--pink)}

/* Chat card */
.chat-card{background:linear-gradient(160deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:18px;backdrop-filter:blur(20px);
  box-shadow:var(--shadow);min-height:420px;display:flex;flex-direction:column}
.chat-head{display:flex;align-items:center;gap:10px;color:#f0e1ff;font-size:14px;padding:6px 8px 14px;border-bottom:1px solid rgba(255,255,255,.08)}
.dot{width:9px;height:9px;border-radius:50%;background:#3df58c;box-shadow:0 0 12px #3df58c}
.chat-title{font-weight:600}
.chat-stream{padding:14px 6px;overflow:auto;max-height:480px;display:flex;flex-direction:column;gap:14px;scrollbar-width:thin}
.chat-empty{color:#aa97cf;font-style:italic;font-size:14px;text-align:center;padding:30px 10px}
.chat-row{display:flex;gap:10px;align-items:flex-end;animation:slideIn .35s ease}
@keyframes slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.chat-avatar{width:34px;height:34px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:0 0 34px}
.chat-bubble{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);padding:10px 12px;border-radius:14px 14px 14px 4px;max-width:78%}
.chat-from{font-size:12px;color:var(--pink2);font-weight:700;margin-bottom:4px}
.chat-text{font-size:14.5px;color:#fff;margin-bottom:6px}
.chat-image{display:block;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.1);transition:transform .2s}
.chat-image:hover{transform:scale(1.02)}
.chat-image img{width:200px;height:auto;display:block}
.typing .chat-bubble{padding:14px 18px}
.dots{display:inline-flex;gap:4px}
.dots i{width:7px;height:7px;background:#f0d2ff;border-radius:50%;animation:bounce 1.2s infinite}
.dots i:nth-child(2){animation-delay:.15s}.dots i:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,80%,100%{transform:scale(.5);opacity:.4}40%{transform:scale(1);opacity:1}}

/* Sections */
section h2{font-size:clamp(28px,3.2vw,40px);font-weight:900;letter-spacing:-.01em;margin:0 0 14px;
  background:linear-gradient(135deg,#fff,#e7c6ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-lead{color:#c9b6e8;margin:0 0 30px;max-width:680px}

/* Models grid: 5 per row, ensures equal rows with 30 cards */
.models{padding:60px 0}
.model-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.model-card{position:relative;border-radius:18px;overflow:hidden;background:var(--card);
  border:1px solid var(--border);transition:transform .25s ease, box-shadow .25s ease;display:block}
.model-card:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(138,76,255,.4)}
.model-card img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .5s ease}
.model-card:hover img{transform:scale(1.05)}
.model-info{position:absolute;inset:auto 0 0 0;padding:14px;background:linear-gradient(0deg,rgba(11,8,20,.92),transparent);
  display:flex;flex-direction:column;gap:2px}
.model-name{font-weight:800;font-size:17px}
.model-style{font-size:12.5px;color:#f0c9ff;opacity:.9}

@media (max-width:1024px){
  .model-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:780px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .model-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:520px){
  .model-grid{grid-template-columns:repeat(2,1fr)}
}

/* Features */
.features{padding:60px 0}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.feat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:22px;transition:transform .25s}
.feat:hover{transform:translateY(-4px)}
.feat .emoji{font-size:30px}
.feat-title{font-weight:800;margin:10px 0 4px}
@media (max-width:780px){.feat-grid{grid-template-columns:repeat(2,1fr)}}

/* FAQ */
.faq{padding:60px 0}
.faq-list{display:grid;gap:12px;max-width:880px}
.faq details{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 18px;transition:background .2s}
.faq details[open]{background:rgba(255,255,255,.08)}
.faq summary{cursor:pointer;font-weight:700;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"+";font-size:22px;color:var(--pink2)}
.faq details[open] summary::after{content:"−"}
.faq p{margin:10px 0 0;color:#d4c1ef}

/* CTA band */
.cta-band{padding:80px 0;text-align:center;background:radial-gradient(60% 80% at 50% 50%, rgba(255,95,180,.18), transparent 70%)}
.cta-inner h2{margin-bottom:10px}
.cta-inner p{color:#d9c8f5;margin:0 0 22px}

/* Footer */
.site-footer{margin-top:40px;border-top:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.25);padding:50px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.footer-grid a{display:block;color:#cdb8ee;padding:4px 0;font-size:14px}
.footer-grid a:hover{color:#fff}
.footer-h{font-weight:800;color:#fff;margin:0 0 8px;font-size:14px;letter-spacing:.4px;text-transform:uppercase}
.muted{color:#9d87c2;font-size:14px}
.copy{margin-top:30px;color:#8c78b0;font-size:13px;border-top:1px solid rgba(255,255,255,.06);padding-top:18px;text-align:center}
@media (max-width:780px){.footer-grid{grid-template-columns:1fr 1fr;gap:20px}}

/* Cookie banner */
.cookie-banner{position:fixed;left:50%;bottom:20px;transform:translateX(-50%) translateY(140%);
  width:min(680px,calc(100% - 32px));background:rgba(20,10,34,.95);border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:16px 18px;display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap;
  box-shadow:0 24px 60px rgba(0,0,0,.5);z-index:60;transition:transform .4s ease}
.cookie-banner.show{transform:translateX(-50%) translateY(0)}
.cookie-banner p{margin:0;font-size:14px;color:#d8c4f5;flex:1 1 280px}
.cookie-actions{display:flex;gap:10px;align-items:center}
.link-muted{color:#9d87c2;font-size:13px}
.link-muted:hover{color:#fff}

/* Legal pages */
.legal{padding:60px 0 80px;max-width:880px}
.legal h1{font-size:clamp(28px,4vw,44px);font-weight:900;margin:0 0 6px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.legal h2{font-size:24px;margin:32px 0 12px;color:#fff}
.legal .legal-list{padding-left:22px;display:grid;gap:10px;color:#d8c4f5}
.legal .legal-list li strong{color:#fff}
.contact-form{display:grid;gap:14px;margin-top:24px;max-width:520px}
.contact-form label{display:grid;gap:6px;font-size:14px;color:#cdb8ee}
.contact-form input,.contact-form textarea{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:12px 14px;color:#fff;font:inherit}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--pink2);box-shadow:0 0 0 3px rgba(255,154,209,.2)}

/* Model page */
.model-hero{padding:50px 0 30px}
.model-hero-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.model-photo img{border-radius:24px;box-shadow:0 30px 80px rgba(138,76,255,.4);border:1px solid rgba(255,255,255,.08)}
.model-body h1{font-size:clamp(30px,4vw,50px);font-weight:900;margin:14px 0 12px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.model-meta{padding:30px 0 80px}
.bullets{padding-left:22px;color:#d8c4f5;display:grid;gap:8px}
@media (max-width:780px){.model-hero-inner{grid-template-columns:1fr}}
