/* ===================================================================
   GIRLFRIENDGPT REVIEW — "Aurora Companion" Design System
   Premium, emotionally-intelligent multimodal-companion aesthetic.
   Deliberately distinct from purple-AI-SaaS. 18+ adults only.
   =================================================================== */

:root {
  /* --- Aurora palette: deep midnight base + aurora gradient accents --- */
  --aurora-bg: #0b0e1a;          /* deep midnight */
  --aurora-bg-2: #11152a;        /* raised surface */
  --aurora-surface: #161b33;     /* cards */
  --aurora-surface-2: #1d2440;   /* elevated cards */
  --aurora-line: rgba(255,255,255,0.08);
  --aurora-line-strong: rgba(255,255,255,0.16);

  /* Aurora gradient stops — teal → violet → rose (the "aurora") */
  --aurora-teal: #4fe0c4;
  --aurora-cyan: #5bc8ff;
  --aurora-violet: #9b7bff;
  --aurora-rose: #ff8fb1;
  --aurora-amber: #ffd29a;

  --grad-aurora: linear-gradient(120deg, #4fe0c4 0%, #5bc8ff 28%, #9b7bff 62%, #ff8fb1 100%);
  --grad-aurora-soft: linear-gradient(120deg, rgba(79,224,196,.18), rgba(155,123,255,.18) 55%, rgba(255,143,177,.18));
  --grad-dusk: radial-gradient(1200px 700px at 70% -10%, rgba(155,123,255,.28), transparent 60%),
               radial-gradient(900px 600px at 10% 0%, rgba(91,200,255,.20), transparent 55%);

  --text: #eef1fb;
  --text-soft: #b6bdd6;
  --text-mute: #818aab;

  --radius: 18px;
  --radius-sm: 12px;
  --radius-lg: 28px;
  --shadow-soft: 0 10px 40px rgba(0,0,0,.45);
  --shadow-glow: 0 0 0 1px rgba(155,123,255,.25), 0 18px 60px rgba(91,200,255,.10);

  --font-display: 'Sora', 'Inter', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;

  --max: 1200px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--text);
  background: var(--aurora-bg);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Ambient aurora field behind everything */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: var(--grad-dusk);
  z-index: -2;
  pointer-events: none;
}
body::after {
  content: "";
  position: fixed;
  inset: -20%;
  background:
    radial-gradient(420px 420px at 18% 22%, rgba(79,224,196,.10), transparent 70%),
    radial-gradient(520px 520px at 82% 70%, rgba(255,143,177,.10), transparent 70%);
  z-index: -2;
  filter: blur(8px);
  animation: drift 22s ease-in-out infinite alternate;
  pointer-events: none;
}
@keyframes drift {
  from { transform: translate3d(-2%, -1%, 0) scale(1); }
  to   { transform: translate3d(2%, 2%, 0) scale(1.05); }
}

h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 700; line-height: 1.12; letter-spacing: -0.02em; margin: 0 0 .5em; }
h1 { font-size: clamp(2.4rem, 6vw, 4.2rem); }
h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
h3 { font-size: clamp(1.2rem, 2.4vw, 1.6rem); }
p { margin: 0 0 1.1em; color: var(--text-soft); }
a { color: var(--aurora-cyan); text-decoration: none; transition: color .2s; }
a:hover { color: var(--aurora-rose); }

.wrap { max-width: var(--max); margin: 0 auto; padding: 0 24px; }
.section { padding: 88px 0; position: relative; }
.section--tight { padding: 56px 0; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-size: .8rem; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase; color: var(--aurora-teal);
  margin-bottom: 14px;
}
.eyebrow::before { content:""; width: 26px; height: 2px; background: var(--grad-aurora); border-radius: 2px; }

.grad-text {
  background: var(--grad-aurora);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

.lead { font-size: 1.18rem; color: var(--text-soft); max-width: 62ch; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display); font-weight: 600; font-size: 1rem;
  padding: 14px 26px; border-radius: 999px; cursor: pointer;
  border: 1px solid transparent; transition: transform .18s, box-shadow .25s, background .25s;
}
.btn--primary {
  background: var(--grad-aurora); color: #0b0e1a;
  box-shadow: 0 12px 34px rgba(155,123,255,.35);
}
.btn--primary:hover { transform: translateY(-2px); color: #0b0e1a; box-shadow: 0 18px 44px rgba(255,143,177,.4); }
.btn--ghost {
  background: rgba(255,255,255,.04); color: var(--text);
  border-color: var(--aurora-line-strong);
}
.btn--ghost:hover { background: rgba(255,255,255,.08); color: var(--text); transform: translateY(-2px); }
.btn--block { width: 100%; justify-content: center; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 60;
  backdrop-filter: blur(14px);
  background: rgba(11,14,26,.72);
  border-bottom: 1px solid var(--aurora-line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.brand { display: flex; align-items: center; gap: 12px; font-family: var(--font-display); font-weight: 700; font-size: 1.18rem; color: var(--text); }
.brand:hover { color: var(--text); }
.brand-mark {
  width: 34px; height: 34px; border-radius: 11px; background: var(--grad-aurora);
  display: grid; place-items: center; color: #0b0e1a; font-weight: 800; font-size: 1rem;
  box-shadow: 0 6px 20px rgba(155,123,255,.4);
}
.nav-links { display: flex; align-items: center; gap: 28px; }
.nav-links a { color: var(--text-soft); font-size: .95rem; font-weight: 500; }
.nav-links a:hover { color: var(--text); }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-toggle { display: none; background: none; border: 0; color: var(--text); font-size: 1.5rem; cursor: pointer; }

.age-pill {
  font-size: .72rem; font-weight: 700; letter-spacing: .06em;
  padding: 4px 10px; border-radius: 999px; color: var(--aurora-rose);
  border: 1px solid rgba(255,143,177,.4); background: rgba(255,143,177,.08);
}

/* ---------- Hero ---------- */
.hero { padding: 96px 0 72px; position: relative; }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
.hero h1 { margin-bottom: 18px; }
.hero .lead { margin-bottom: 28px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 22px; }
.hero-meta { display: flex; gap: 22px; flex-wrap: wrap; color: var(--text-mute); font-size: .9rem; }
.hero-meta strong { color: var(--text); font-family: var(--font-display); }

/* Companion preview card (SFW, abstract) */
.companion-card {
  position: relative; border-radius: var(--radius-lg);
  background: var(--aurora-surface); border: 1px solid var(--aurora-line);
  box-shadow: var(--shadow-soft); overflow: hidden; padding: 22px;
}
.companion-card::before {
  content:""; position:absolute; inset:0; background: var(--grad-aurora-soft); opacity:.6; pointer-events:none;
}
.cc-top { display:flex; align-items:center; gap:12px; position:relative; margin-bottom:16px; }
.cc-avatar { width:46px; height:46px; border-radius:50%; background: var(--grad-aurora); box-shadow: 0 0 0 3px rgba(255,255,255,.08); }
.cc-name { font-family: var(--font-display); font-weight:600; }
.cc-status { font-size:.78rem; color: var(--aurora-teal); display:flex; align-items:center; gap:6px; }
.cc-status::before { content:""; width:8px; height:8px; border-radius:50%; background: var(--aurora-teal); box-shadow:0 0 10px var(--aurora-teal); }
.chat { display:flex; flex-direction:column; gap:10px; position:relative; }
.bubble { padding:11px 15px; border-radius:16px; font-size:.92rem; max-width:84%; line-height:1.5; }
.bubble--in { background: rgba(255,255,255,.06); border:1px solid var(--aurora-line); border-bottom-left-radius:5px; align-self:flex-start; color: var(--text); }
.bubble--out { background: var(--grad-aurora); color:#0b0e1a; border-bottom-right-radius:5px; align-self:flex-end; font-weight:500; }
.cc-tools { display:flex; gap:10px; margin-top:16px; position:relative; }
.cc-tool { flex:1; text-align:center; padding:8px; border-radius:12px; background: rgba(255,255,255,.04); border:1px solid var(--aurora-line); font-size:.78rem; color: var(--text-soft); }
.cc-tool i { display:block; color: var(--aurora-cyan); margin-bottom:4px; }

/* ---------- Trust strip ---------- */
.trust { border-top:1px solid var(--aurora-line); border-bottom:1px solid var(--aurora-line); background: rgba(255,255,255,.02); }
.trust-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:28px; padding:34px 0; text-align:center; }
.trust-num { font-family: var(--font-display); font-size: clamp(1.6rem,3vw,2.2rem); font-weight:700; }
.trust-label { color: var(--text-mute); font-size:.86rem; }

/* ---------- Cards / grids ---------- */
.grid { display:grid; gap:24px; }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }

.card {
  background: var(--aurora-surface); border:1px solid var(--aurora-line);
  border-radius: var(--radius); padding:26px; transition: transform .25s, border-color .25s, box-shadow .25s;
  position:relative; overflow:hidden;
}
.card:hover { transform: translateY(-4px); border-color: var(--aurora-line-strong); box-shadow: var(--shadow-glow); }
.card-icon {
  width:48px; height:48px; border-radius:14px; display:grid; place-items:center;
  background: var(--grad-aurora-soft); color: var(--aurora-cyan); font-size:1.3rem; margin-bottom:16px;
  border:1px solid var(--aurora-line);
}
.card h3 { margin-bottom:8px; }
.card p { margin:0; font-size:.95rem; }

/* ---------- Section heading block ---------- */
.sec-head { max-width: 64ch; margin-bottom: 44px; }
.sec-head--center { margin-left:auto; margin-right:auto; text-align:center; }

/* ---------- Rating / verdict ---------- */
.verdict {
  background: var(--aurora-surface-2); border:1px solid var(--aurora-line-strong);
  border-radius: var(--radius-lg); padding: 40px; box-shadow: var(--shadow-soft);
  display:grid; grid-template-columns: 220px 1fr; gap:40px; align-items:center;
}
.score-ring { text-align:center; }
.score-num { font-family: var(--font-display); font-size:3.6rem; font-weight:800; line-height:1; }
.score-num span { font-size:1.4rem; color: var(--text-mute); }
.stars { color: var(--aurora-amber); font-size:1.1rem; letter-spacing:2px; margin-top:8px; }
.score-label { color: var(--text-mute); font-size:.85rem; margin-top:6px; text-transform:uppercase; letter-spacing:.12em; }

.bars { display:flex; flex-direction:column; gap:14px; }
.bar-row { display:grid; grid-template-columns: 150px 1fr 44px; align-items:center; gap:14px; font-size:.9rem; }
.bar-track { height:8px; border-radius:99px; background: rgba(255,255,255,.07); overflow:hidden; }
.bar-fill { height:100%; border-radius:99px; background: var(--grad-aurora); }

/* ---------- Pros / cons ---------- */
.pc { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.pc-box { border-radius: var(--radius); padding:26px; border:1px solid var(--aurora-line); }
.pc-box--pro { background: rgba(79,224,196,.06); border-color: rgba(79,224,196,.25); }
.pc-box--con { background: rgba(255,143,177,.05); border-color: rgba(255,143,177,.22); }
.pc-box h3 { display:flex; align-items:center; gap:10px; }
.pc-list { list-style:none; padding:0; margin:0; }
.pc-list li { padding:8px 0 8px 30px; position:relative; color: var(--text-soft); border-bottom:1px solid var(--aurora-line); }
.pc-list li:last-child { border-bottom:0; }
.pc-list li::before { position:absolute; left:0; top:8px; font-family:"Font Awesome 6 Free"; font-weight:900; }
.pc-box--pro .pc-list li::before { content:"\f00c"; color: var(--aurora-teal); }
.pc-box--con .pc-list li::before { content:"\f068"; color: var(--aurora-rose); }

/* ---------- Pricing ---------- */
.price-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.price-card { background: var(--aurora-surface); border:1px solid var(--aurora-line); border-radius: var(--radius-lg); padding:32px; position:relative; }
.price-card--feat { border-color: rgba(155,123,255,.5); box-shadow: var(--shadow-glow); }
.price-tag { display:inline-block; position:absolute; top:-13px; left:32px; background:var(--grad-aurora); color:#0b0e1a; font-size:.72rem; font-weight:700; padding:5px 12px; border-radius:99px; letter-spacing:.05em; }
.price-name { font-family:var(--font-display); font-weight:600; color: var(--text-soft); }
.price-amt { font-family:var(--font-display); font-size:2.6rem; font-weight:800; margin:6px 0; }
.price-amt span { font-size:1rem; color: var(--text-mute); font-weight:400; }
.price-list { list-style:none; padding:0; margin:18px 0 24px; }
.price-list li { padding:7px 0 7px 26px; position:relative; font-size:.92rem; color: var(--text-soft); }
.price-list li::before { content:"\f00c"; font-family:"Font Awesome 6 Free"; font-weight:900; position:absolute; left:0; color: var(--aurora-teal); }

/* ---------- Table ---------- */
.table-wrap { overflow-x:auto; border:1px solid var(--aurora-line); border-radius: var(--radius); }
table.compare { width:100%; border-collapse:collapse; min-width:640px; }
table.compare th, table.compare td { padding:14px 18px; text-align:left; border-bottom:1px solid var(--aurora-line); font-size:.94rem; }
table.compare thead th { background: rgba(255,255,255,.03); font-family:var(--font-display); color:var(--text); }
table.compare td:first-child { color: var(--text); font-weight:500; }
table.compare .yes { color: var(--aurora-teal); }
table.compare .no { color: var(--text-mute); }
table.compare tr:hover td { background: rgba(255,255,255,.02); }

/* ---------- FAQ ---------- */
.faq-item { border:1px solid var(--aurora-line); border-radius:var(--radius-sm); margin-bottom:14px; overflow:hidden; background: var(--aurora-surface); }
.faq-q { width:100%; text-align:left; background:none; border:0; color:var(--text); font-family:var(--font-display); font-weight:600; font-size:1.05rem; padding:20px 22px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-q i { transition: transform .25s; color: var(--aurora-cyan); }
.faq-item.open .faq-q i { transform: rotate(180deg); }
.faq-a { max-height:0; overflow:hidden; transition: max-height .3s ease, padding .3s; padding:0 22px; }
.faq-item.open .faq-a { max-height:400px; padding:0 22px 20px; }
.faq-a p { margin:0; font-size:.96rem; }

/* ---------- CTA band ---------- */
.cta-band {
  border-radius: var(--radius-lg); padding: 56px 48px; text-align:center; position:relative; overflow:hidden;
  background: var(--aurora-surface-2); border:1px solid var(--aurora-line-strong);
}
.cta-band::before { content:""; position:absolute; inset:0; background: var(--grad-aurora-soft); opacity:.8; }
.cta-band > * { position:relative; }

/* ---------- Blog cards ---------- */
.post-card { display:flex; flex-direction:column; }
.post-thumb { height:170px; border-radius: var(--radius-sm); margin-bottom:16px; background: var(--grad-aurora-soft); border:1px solid var(--aurora-line); display:grid; place-items:center; color: var(--aurora-cyan); font-size:2rem; }
.post-cat { font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color: var(--aurora-teal); font-weight:600; }
.post-card h3 { font-size:1.18rem; margin:6px 0 8px; }
.post-card p { font-size:.92rem; }
.post-meta { margin-top:auto; padding-top:12px; color: var(--text-mute); font-size:.82rem; }

/* ---------- Safety note ---------- */
.safety-note {
  border:1px dashed rgba(255,143,177,.4); background: rgba(255,143,177,.05);
  border-radius:var(--radius-sm); padding:14px 18px; font-size:.85rem; color: var(--text-soft);
  display:flex; gap:12px; align-items:flex-start;
}
.safety-note i { color: var(--aurora-rose); margin-top:3px; }

/* ---------- Footer ---------- */
.site-footer { border-top:1px solid var(--aurora-line); background: rgba(11,14,26,.6); padding:56px 0 28px; margin-top: 40px; }
.footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:40px; }
.footer-grid h4 { font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); margin-bottom:14px; }
.footer-links { list-style:none; padding:0; margin:0; }
.footer-links li { margin-bottom:9px; }
.footer-links a { color: var(--text-soft); font-size:.92rem; }
.footer-bottom { margin-top:40px; padding-top:24px; border-top:1px solid var(--aurora-line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px; color: var(--text-mute); font-size:.82rem; }
.disclaimer { max-width:70ch; }

/* ---------- Page hero (interior) ---------- */
.page-hero { padding: 64px 0 44px; }
.breadcrumb { font-size:.85rem; color:var(--text-mute); margin-bottom:14px; }
.breadcrumb a { color: var(--text-soft); }

/* article body */
.article { max-width: 760px; margin:0 auto; }
.article h2 { margin-top:1.6em; }
.article h3 { margin-top:1.3em; }
.article ul, .article ol { color: var(--text-soft); padding-left:1.3em; }
.article li { margin-bottom:.5em; }
.article blockquote { border-left:3px solid var(--aurora-violet); margin:1.4em 0; padding:.6em 1.2em; background: rgba(155,123,255,.06); border-radius:0 12px 12px 0; color: var(--text); }
.toc { background: var(--aurora-surface); border:1px solid var(--aurora-line); border-radius: var(--radius); padding:22px 26px; margin-bottom:32px; }
.toc h4 { margin-top:0; font-family:var(--font-display); }
.toc ol { margin:0; padding-left:1.2em; }
.toc a { color: var(--text-soft); }

/* ---------- Images & media ---------- */
.hero-visual {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--aurora-line); box-shadow: var(--shadow-soft);
}
.hero-visual img { display:block; width:100%; height:100%; object-fit:cover; }
.hero-visual::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(11,14,26,0) 45%, rgba(11,14,26,.55) 100%);
  pointer-events:none;
}
.media-badge {
  position:absolute; left:16px; bottom:16px; z-index:2;
  display:inline-flex; align-items:center; gap:8px;
  background: rgba(11,14,26,.7); backdrop-filter: blur(8px);
  border:1px solid var(--aurora-line-strong); border-radius:999px;
  padding:7px 14px; font-size:.8rem; font-family:var(--font-display); font-weight:600;
}
.media-badge i { color: var(--aurora-cyan); }

/* full-width banner */
.banner-img {
  width:100%; border-radius: var(--radius-lg); border:1px solid var(--aurora-line);
  box-shadow: var(--shadow-soft); display:block; object-fit:cover; max-height:420px;
}

/* character gallery */
.gallery { display:grid; grid-template-columns: repeat(4,1fr); gap:18px; }
.char-card {
  position:relative; border-radius: var(--radius); overflow:hidden;
  border:1px solid var(--aurora-line); background: var(--aurora-surface);
  aspect-ratio: 3/4; transition: transform .25s, box-shadow .25s, border-color .25s;
}
.char-card img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .5s; }
.char-card:hover { transform: translateY(-4px); border-color: var(--aurora-line-strong); box-shadow: var(--shadow-glow); }
.char-card:hover img { transform: scale(1.06); }
.char-card .char-meta {
  position:absolute; inset:auto 0 0 0; padding:14px 16px;
  background: linear-gradient(180deg, transparent, rgba(11,14,26,.92));
}
.char-name { font-family:var(--font-display); font-weight:600; font-size:1rem; }
.char-tag { font-size:.75rem; color: var(--aurora-teal); }

/* feature image inside cards / split rows */
.feature-img { width:100%; border-radius:var(--radius-sm); border:1px solid var(--aurora-line); display:block; object-fit:cover; }
.split { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.split--reverse { direction:rtl; }
.split--reverse > * { direction:ltr; }

/* style chips strip */
.style-strip { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.style-tile { position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--aurora-line); aspect-ratio:1/1; }
.style-tile img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s; }
.style-tile:hover img { transform:scale(1.05); }
.style-tile span { position:absolute; left:12px; bottom:12px; background:rgba(11,14,26,.72); padding:5px 12px; border-radius:999px; font-size:.78rem; font-family:var(--font-display); font-weight:600; border:1px solid var(--aurora-line-strong); }

/* article inline image */
.article img.inline { width:100%; border-radius:var(--radius); border:1px solid var(--aurora-line); margin:1.4em 0; }

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  .hero-grid { grid-template-columns:1fr; gap:36px; }
  .grid-3, .grid-4, .price-grid, .gallery { grid-template-columns: repeat(2,1fr); }
  .split, .split--reverse { grid-template-columns:1fr; direction:ltr; }
  .style-strip { grid-template-columns: repeat(3,1fr); }
  .verdict { grid-template-columns:1fr; gap:28px; text-align:center; }
  .bar-row { grid-template-columns: 110px 1fr 40px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .trust-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px) {
  .nav-links, .nav-cta .btn--ghost { display:none; }
  .nav-toggle { display:block; }
  .nav-links.open { display:flex; position:absolute; top:72px; left:0; right:0; flex-direction:column; background: var(--aurora-bg-2); padding:20px 24px; border-bottom:1px solid var(--aurora-line); gap:16px; }
  .grid-2, .grid-3, .grid-4, .price-grid, .pc { grid-template-columns:1fr; }
  .gallery { grid-template-columns: repeat(2,1fr); }
  .section { padding:60px 0; }
  .cta-band { padding:40px 24px; }
}
