/*
Theme Name: Haven - Spicychat AI App
Theme URI: https://spicychat-ai.app
Author: Spicychat AI
Author URI: https://spicychat-ai.app
Description: Premium WordPress theme for Spicychat AI App — an immersive AI companion and chatting experience. Built with cinematic visuals, glassmorphism, 3D depth, and lightning SEO performance.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: haven
Tags: ai, chat, dating, dark, modern, animated, one-column, custom-colors, custom-menu, featured-images, theme-options, threaded-comments
*/

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#07060d;
  --bg-soft:#0d0a1a;
  --surface:rgba(255,255,255,.04);
  --surface-2:rgba(255,255,255,.07);
  --border:rgba(255,255,255,.09);
  --text:#f4f1ff;
  --text-dim:#b9b4d1;
  --text-mute:#8b86a3;
  --pink:#ff2d8a;
  --pink-2:#ff6ec7;
  --violet:#8a2bff;
  --cyan:#27e1ff;
  --gold:#ffcf66;
  --grad:linear-gradient(135deg,#ff2d8a 0%,#8a2bff 50%,#27e1ff 100%);
  --grad-2:linear-gradient(135deg,#ff6ec7,#ff2d8a 40%,#8a2bff);
  --radius:18px;
  --radius-lg:28px;
  --shadow-glow:0 20px 60px -20px rgba(255,45,138,.55),0 8px 30px -10px rgba(138,43,255,.45);
  --shadow-soft:0 10px 40px -10px rgba(0,0,0,.55);
  --max:1240px;
  --ease:cubic-bezier(.22,1,.36,1);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1100px 600px at 10% -10%,rgba(255,45,138,.18),transparent 60%),
    radial-gradient(900px 500px at 90% 10%,rgba(138,43,255,.18),transparent 60%),
    radial-gradient(700px 700px at 50% 120%,rgba(39,225,255,.10),transparent 60%);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:.25s var(--ease)}
a:hover{color:var(--pink-2)}
h1,h2{font-family:'Space Grotesk','Inter',sans-serif;line-height:1.1;letter-spacing:-.02em;font-weight:700}
h1{font-size:clamp(2.6rem,6vw,5.2rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem);margin-bottom:1.2rem}
p{color:var(--text-dim);margin-bottom:1rem}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}
section{position:relative;padding:120px 0;overflow:hidden}
section:nth-of-type(even){background:linear-gradient(180deg,transparent,rgba(138,43,255,.05),transparent)}

/* === HEADER === */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  background:rgba(7,6,13,.55);
  border-bottom:1px solid var(--border);
  transition:.3s var(--ease);
}
.site-header.scrolled{padding:10px 0;background:rgba(7,6,13,.85)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.25rem;color:#fff}
.brand-logo{
  width:38px;height:38px;border-radius:12px;
  background:var(--grad);
  display:grid;place-items:center;font-size:18px;color:#fff;
  box-shadow:0 8px 24px -6px rgba(255,45,138,.55);
  position:relative;
}
.brand-logo::after{content:"";position:absolute;inset:-2px;border-radius:14px;background:var(--grad);filter:blur(14px);opacity:.55;z-index:-1}
.nav-menu{display:flex;gap:30px;list-style:none;align-items:center}
.nav-menu a{color:var(--text-dim);font-weight:500;font-size:.95rem;position:relative;padding:6px 0}
.nav-menu a:hover{color:#fff}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--grad);transition:.3s var(--ease)}
.nav-menu a:hover::after{width:100%}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:99px;font-weight:600;font-size:.92rem;
  background:var(--grad);color:#fff;
  box-shadow:0 8px 24px -8px rgba(255,45,138,.6);
  transform:translateZ(0);
}
.nav-cta:hover{color:#fff;transform:translateY(-2px) scale(1.03);box-shadow:0 14px 36px -10px rgba(255,45,138,.75)}
.menu-toggle{display:none;background:transparent;border:0;color:#fff;font-size:24px;cursor:pointer}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:99px;font-weight:600;font-size:1rem;cursor:pointer;border:0;transition:.3s var(--ease);position:relative}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow)}
.btn-primary:hover{color:#fff;transform:translateY(-3px) scale(1.02);box-shadow:0 30px 60px -20px rgba(255,45,138,.7)}
.btn-ghost{background:var(--surface-2);color:#fff;border:1px solid var(--border);backdrop-filter:blur(10px)}
.btn-ghost:hover{color:#fff;background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2)}
.btn-xl{padding:20px 40px;font-size:1.1rem}

/* === HERO === */
.hero{min-height:100vh;display:grid;place-items:center;padding:160px 0 100px;position:relative}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:url('assets/images/hero-bg.webp');
  background-size:cover;background-position:center;
  opacity:.35;filter:blur(2px);z-index:0;
}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,var(--bg) 80%);z-index:1}
.hero .container{position:relative;z-index:2;text-align:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 16px;border-radius:99px;
  background:var(--surface-2);border:1px solid var(--border);
  font-size:.83rem;color:var(--text-dim);font-weight:500;
  margin-bottom:28px;
}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:#19f5a3;box-shadow:0 0 12px #19f5a3;animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.hero h1{margin-bottom:24px}
.hero h1 .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.hero-sub{font-size:1.2rem;max-width:680px;margin:0 auto 38px;color:var(--text-dim)}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;justify-content:center;gap:60px;margin-top:70px;flex-wrap:wrap}
.hero-stat strong{display:block;font-size:2.2rem;font-family:'Space Grotesk',sans-serif;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-stat span{color:var(--text-mute);font-size:.9rem;text-transform:uppercase;letter-spacing:.12em}

/* 3D orb */
.hero-orb{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:520px;height:520px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ff6ec7,#8a2bff 50%,#1a0a3a 80%);filter:blur(60px);opacity:.5;z-index:0;animation:float 8s ease-in-out infinite}
@keyframes float{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-48%,-52%) scale(1.06)}}

/* === SECTION HEADER === */
.s-head{text-align:center;max-width:760px;margin:0 auto 70px}
.s-eyebrow{display:inline-block;padding:6px 14px;border-radius:99px;background:var(--surface-2);border:1px solid var(--border);font-size:.8rem;color:var(--pink-2);text-transform:uppercase;letter-spacing:.16em;margin-bottom:18px;font-weight:600}
.s-head p{font-size:1.1rem}

/* === COMPANION GRID === */
.companions{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.companion{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:3/4;cursor:pointer;
  transform-style:preserve-3d;perspective:1000px;
  transition:.5s var(--ease);
  box-shadow:var(--shadow-soft);
}
.companion img{width:100%;height:100%;object-fit:cover;transition:.7s var(--ease)}
.companion:hover{transform:translateY(-8px);box-shadow:var(--shadow-glow)}
.companion:hover img{transform:scale(1.08)}
.companion-meta{position:absolute;inset:auto 0 0 0;padding:24px;background:linear-gradient(transparent,rgba(7,6,13,.95));z-index:2}
.companion-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;background:rgba(25,245,163,.18);color:#19f5a3;font-size:.72rem;font-weight:600;margin-bottom:10px;text-transform:uppercase;letter-spacing:.08em}
.companion-name{font-family:'Space Grotesk',sans-serif;font-size:1.25rem;font-weight:700;color:#fff;margin-bottom:4px}
.companion-desc{font-size:.85rem;color:var(--text-dim);margin:0}
.companion-action{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;background:rgba(7,6,13,.7);backdrop-filter:blur(10px);display:grid;place-items:center;z-index:3;transition:.3s var(--ease)}
.companion:hover .companion-action{background:var(--grad);transform:scale(1.1) rotate(15deg)}

/* === FEATURE CARDS === */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{
  padding:36px 30px;border-radius:var(--radius-lg);
  background:var(--surface);border:1px solid var(--border);
  backdrop-filter:blur(20px);
  transition:.4s var(--ease);position:relative;overflow:hidden;
}
.feature::before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;height:3px;background:var(--grad);opacity:0;transition:.3s var(--ease)}
.feature:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.18);background:var(--surface-2)}
.feature:hover::before{opacity:1}
.feature-icon{width:60px;height:60px;border-radius:18px;background:var(--grad);display:grid;place-items:center;font-size:26px;margin-bottom:22px;box-shadow:0 12px 30px -10px rgba(255,45,138,.6)}
.feature h2,.feature h3{font-size:1.4rem;margin-bottom:12px;color:#fff;font-family:'Space Grotesk',sans-serif}
.feature p{font-size:.95rem;margin:0}

/* === HOW IT WORKS === */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;position:relative}
.step{text-align:center;position:relative;padding:30px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);backdrop-filter:blur(10px);transition:.3s var(--ease)}
.step:hover{transform:translateY(-5px);border-color:rgba(255,110,199,.4)}
.step-n{width:66px;height:66px;margin:0 auto 18px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-size:1.5rem;font-weight:700;color:#fff;box-shadow:var(--shadow-glow)}
.step h2,.step h3{font-size:1.2rem;color:#fff;margin-bottom:8px}
.step p{font-size:.9rem;margin:0}

/* === STORY / TEXT BLOCK === */
.story{display:grid;grid-template-columns:1.1fr .9fr;gap:70px;align-items:center}
.story-text p{font-size:1.05rem;line-height:1.8;margin-bottom:18px}
.story-visual{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-glow);transform:rotate(-2deg);transition:.4s var(--ease)}
.story-visual:hover{transform:rotate(0) scale(1.02)}
.story-visual img{width:100%;height:100%;object-fit:cover}
.story-badge{position:absolute;bottom:24px;left:24px;right:24px;padding:18px 22px;border-radius:18px;background:rgba(7,6,13,.7);backdrop-filter:blur(20px);border:1px solid var(--border)}
.story-badge strong{display:block;font-family:'Space Grotesk',sans-serif;font-size:1.3rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.story-badge span{font-size:.85rem;color:var(--text-dim)}
.story-reverse{grid-template-columns:.9fr 1.1fr}
.story-reverse .story-visual{transform:rotate(2deg);order:2}
.story-reverse .story-text{order:1}

/* === CHAT PREVIEW === */
.chat-preview{
  max-width:560px;margin:0 auto;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:28px;
  backdrop-filter:blur(20px);
  box-shadow:var(--shadow-glow);
}
.chat-head{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--border);margin-bottom:20px}
.chat-avatar{width:48px;height:48px;border-radius:50%;background:var(--grad);position:relative}
.chat-avatar::after{content:"";position:absolute;bottom:0;right:0;width:13px;height:13px;border-radius:50%;background:#19f5a3;border:3px solid var(--bg)}
.chat-name{font-weight:700;color:#fff}
.chat-status{font-size:.8rem;color:#19f5a3}
.chat-body{display:flex;flex-direction:column;gap:12px}
.bubble{padding:12px 18px;border-radius:18px;max-width:78%;font-size:.95rem;animation:slideUp .6s var(--ease) both}
.bubble.them{background:var(--surface-2);align-self:flex-start;border-bottom-left-radius:5px;color:var(--text)}
.bubble.me{background:var(--grad);color:#fff;align-self:flex-end;border-bottom-right-radius:5px}
.bubble:nth-child(2){animation-delay:.2s}.bubble:nth-child(3){animation-delay:.4s}.bubble:nth-child(4){animation-delay:.6s}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.typing{display:inline-flex;gap:4px;padding:14px 16px;background:var(--surface-2);border-radius:18px;align-self:flex-start}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--pink-2);animation:blink 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25}40%{opacity:1}}

/* === STATS === */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-card{padding:36px 26px;text-align:center;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(20px);transition:.3s var(--ease)}
.stat-card:hover{transform:translateY(-4px);border-color:rgba(255,110,199,.3)}
.stat-num{font-family:'Space Grotesk',sans-serif;font-size:3rem;font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat-card p{margin:8px 0 0;font-size:.95rem}

/* === TESTIMONIALS === */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.test-card{padding:32px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);position:relative;transition:.3s var(--ease)}
.test-card:hover{transform:translateY(-5px);border-color:rgba(255,110,199,.35)}
.test-stars{color:var(--gold);margin-bottom:14px;letter-spacing:3px}
.test-text{color:var(--text);font-size:1rem;line-height:1.7;margin-bottom:20px}
.test-author{display:flex;align-items:center;gap:12px}
.test-avatar{width:44px;height:44px;border-radius:50%;background:var(--grad)}
.test-author strong{display:block;color:#fff;font-size:.95rem}
.test-author span{font-size:.82rem;color:var(--text-mute)}

/* === PRICING === */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto}
.plan{padding:38px 30px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);position:relative;backdrop-filter:blur(20px);transition:.3s var(--ease)}
.plan:hover{transform:translateY(-6px)}
.plan.featured{border:2px solid transparent;background:linear-gradient(var(--bg-soft),var(--bg-soft)) padding-box,var(--grad) border-box;transform:scale(1.04);box-shadow:var(--shadow-glow)}
.plan.featured:hover{transform:scale(1.04) translateY(-6px)}
.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);padding:6px 16px;border-radius:99px;background:var(--grad);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff}
.plan-name{font-family:'Space Grotesk',sans-serif;font-size:1.4rem;color:#fff;margin-bottom:6px}
.plan-price{font-family:'Space Grotesk',sans-serif;font-size:3rem;font-weight:700;color:#fff;margin:18px 0}
.plan-price small{font-size:1rem;color:var(--text-mute);font-weight:400}
.plan ul{list-style:none;margin:24px 0 32px;padding:0}
.plan li{padding:9px 0;font-size:.95rem;color:var(--text-dim);display:flex;gap:10px;align-items:center}
.plan li::before{content:"✓";color:#19f5a3;font-weight:700}
.plan .btn{width:100%;justify-content:center}

/* === FAQ === */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:.3s var(--ease)}
.faq-item.open{border-color:rgba(255,110,199,.4);background:var(--surface-2)}
.faq-q{padding:22px 26px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#fff;font-size:1.02rem;gap:20px}
.faq-q .ico{width:30px;height:30px;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;transition:.3s var(--ease);flex-shrink:0;font-size:18px}
.faq-item.open .faq-q .ico{background:var(--grad);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;padding:0 26px;transition:.4s var(--ease)}
.faq-item.open .faq-a{max-height:400px;padding:0 26px 22px}
.faq-a p{color:var(--text-dim);margin:0;line-height:1.7}

/* === BIG TEXT BLOCK === */
.prose{max-width:840px;margin:0 auto;font-size:1.06rem;line-height:1.85}
.prose p{color:var(--text-dim);margin-bottom:20px}
.prose p:first-of-type::first-letter{font-family:'Space Grotesk',sans-serif;font-size:3.6rem;float:left;line-height:1;margin:6px 14px 0 0;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}

/* === CTA BIG === */
.cta-big{
  padding:80px 50px;border-radius:36px;text-align:center;
  background:linear-gradient(135deg,rgba(255,45,138,.15),rgba(138,43,255,.18),rgba(39,225,255,.12));
  border:1px solid var(--border);backdrop-filter:blur(20px);
  position:relative;overflow:hidden;
}
.cta-big::before{content:"";position:absolute;top:-100px;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;background:var(--grad);opacity:.15;filter:blur(80px)}
.cta-big > *{position:relative;z-index:2}
.cta-big h2{margin-bottom:16px}
.cta-big p{font-size:1.15rem;max-width:560px;margin:0 auto 32px}

/* === TRUST BADGES === */
.trust-row{display:flex;justify-content:center;gap:50px;flex-wrap:wrap;opacity:.7}
.trust-row .badge{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-dim);font-size:.95rem}

/* === TIMELINE === */
.timeline{position:relative;max-width:880px;margin:0 auto;padding-left:40px}
.timeline::before{content:"";position:absolute;left:14px;top:0;bottom:0;width:3px;background:var(--grad);border-radius:3px;opacity:.7}
.tl-item{position:relative;padding:0 0 50px 40px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-30px;top:6px;width:18px;height:18px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 5px var(--bg),0 0 0 7px rgba(255,45,138,.35)}
.tl-year{font-family:'Space Grotesk',sans-serif;font-size:1.4rem;color:var(--pink-2);font-weight:700;margin-bottom:6px}
.tl-item h2,.tl-item h3{font-size:1.2rem;color:#fff;margin-bottom:10px}

/* === ABOUT PAGE === */
.about-hero{padding-top:180px;padding-bottom:80px;text-align:center}
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px}
.about-card{padding:30px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:.3s var(--ease)}
.about-card:hover{transform:translateY(-5px);border-color:rgba(255,110,199,.4)}
.about-card .icon{font-size:32px;margin-bottom:14px}

/* === CONTACT === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-info{padding:36px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}
.contact-info .item{display:flex;gap:14px;margin-bottom:24px;align-items:flex-start}
.contact-info .item:last-child{margin-bottom:0}
.contact-info .item .ico{width:46px;height:46px;border-radius:14px;background:var(--grad);display:grid;place-items:center;font-size:20px;flex-shrink:0}
.contact-info .item strong{display:block;color:#fff;margin-bottom:3px}
.contact-info .item span{color:var(--text-dim);font-size:.94rem}
.contact-form{padding:36px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:18px}
.form-field label{display:block;font-size:.88rem;margin-bottom:6px;color:var(--text-dim);font-weight:500}
.form-field input,.form-field textarea{width:100%;padding:14px 16px;border-radius:12px;background:var(--bg);border:1px solid var(--border);color:#fff;font-family:inherit;font-size:.95rem;transition:.25s var(--ease)}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,45,138,.15)}
.form-field textarea{min-height:130px;resize:vertical}

/* === LEGAL PAGES === */
.legal-page{padding-top:160px;padding-bottom:80px}
.legal-page .container{max-width:880px}
.legal-page h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:14px;text-align:center}
.legal-meta{text-align:center;color:var(--text-mute);font-size:.92rem;margin-bottom:60px;padding-bottom:30px;border-bottom:1px solid var(--border)}
.legal-page h2{font-size:1.4rem;margin:40px 0 14px;color:#fff;display:flex;gap:14px;align-items:baseline}
.legal-page h2 .n{font-family:'Space Grotesk',sans-serif;color:var(--pink-2);font-weight:700;flex-shrink:0}
.legal-page p{font-size:1rem;line-height:1.8}

/* === FOOTER === */
.site-footer{padding:80px 0 30px;border-top:1px solid var(--border);background:linear-gradient(180deg,transparent,rgba(138,43,255,.07))}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;margin-bottom:50px}
.footer-brand p{margin-top:18px;font-size:.94rem;max-width:300px}
.footer-col h2,.footer-col h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;color:#fff;margin-bottom:18px;font-weight:600}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{color:var(--text-dim);font-size:.95rem}
.footer-col a:hover{color:var(--pink-2)}
.footer-bottom{padding-top:30px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;font-size:.88rem;color:var(--text-mute)}

/* === ANIMATIONS === */
.reveal{opacity:0;transform:translateY(30px);transition:.8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .companions,.features,.stats-grid,.testimonials,.pricing{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .story,.contact-grid{grid-template-columns:1fr;gap:50px}
  .story-reverse .story-visual{order:0}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .about-grid{grid-template-columns:1fr}
  section{padding:80px 0}
}
@media(max-width:680px){
  .nav-menu{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(7,6,13,.97);flex-direction:column;padding:24px;gap:18px;border-bottom:1px solid var(--border)}
  .nav-menu.open{display:flex}
  .menu-toggle{display:block}
  .nav-cta{display:none}
  .companions,.features,.stats-grid,.testimonials,.pricing,.steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-stats{gap:30px}
  .cta-big{padding:50px 24px}
  section{padding:60px 0}
}

/* ===== Bio table ===== */
.bio-table{max-width:880px;margin:0 auto;border-radius:24px;overflow:hidden;border:1px solid var(--border);background:rgba(13,11,22,.6);backdrop-filter:blur(14px)}
.bio-table table{width:100%;border-collapse:collapse;font-size:1rem}
.bio-table th,.bio-table td{padding:16px 22px;text-align:left;vertical-align:top;border-bottom:1px solid rgba(255,255,255,.06)}
.bio-table th{width:32%;color:#ff5da8;font-weight:600;letter-spacing:.02em;text-transform:uppercase;font-size:.78rem;background:rgba(255,45,138,.05)}
.bio-table td{color:#e9e6f1}
.bio-table tr:last-child th,.bio-table tr:last-child td{border-bottom:none}

/* ===== Non-animated slider ===== */
.slider-wrap{position:relative}
.slider-track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:auto;padding:8px 4px 22px;scrollbar-width:thin}
.slider-track::-webkit-scrollbar{height:8px}
.slider-track::-webkit-scrollbar-thumb{background:rgba(255,45,138,.4);border-radius:99px}
.slide{flex:0 0 260px;scroll-snap-align:start;border-radius:18px;overflow:hidden;border:1px solid var(--border);background:rgba(13,11,22,.55);text-decoration:none;color:#fff;display:flex;flex-direction:column}
.slide img{width:100%;height:320px;object-fit:cover;display:block}
.slide-meta{padding:14px 16px;display:flex;flex-direction:column;gap:4px}
.slide-meta strong{font-size:1rem}
.slide-meta span{font-size:.82rem;opacity:.65}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:rgba(7,6,13,.85);color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.slider-prev{left:-8px}
.slider-next{right:-8px}
.slider-btn:hover{background:rgba(255,45,138,.25)}
@media (max-width:720px){.slide{flex-basis:200px}.slide img{height:260px}.slider-btn{display:none}}
