/* ============================================================
   FYF — Luxury Design System
   ============================================================ */
:root{
	--bg:#0b0710;
	--bg-2:#120b1c;
	--surface:rgba(255,255,255,.045);
	--surface-2:rgba(255,255,255,.07);
	--border:rgba(255,255,255,.10);
	--text:#f3eef8;
	--muted:#a99fb6;
	--gold:#e9b873;
	--violet:#c084fc;
	--pink:#f472b6;
	--grad:linear-gradient(120deg,var(--gold),var(--violet) 55%,var(--pink));
	--grad-soft:linear-gradient(135deg,rgba(233,184,115,.18),rgba(192,132,252,.18));
	--radius:20px;
	--radius-sm:12px;
	--shadow:0 24px 60px -20px rgba(0,0,0,.7);
	--shadow-glow:0 0 40px -8px rgba(192,132,252,.5);
	--container:1200px;
	--font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
	--display:'Playfair Display',Georgia,serif;
}

body{
	font-family:var(--font);
	background:radial-gradient(1200px 800px at 80% -10%,rgba(192,132,252,.12),transparent 60%),
		radial-gradient(900px 700px at -10% 20%,rgba(233,184,115,.10),transparent 55%),
		var(--bg);
	color:var(--text);
	line-height:1.7;
	overflow-x:hidden;
}
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }
.narrow{ max-width:820px; }
.center{ text-align:center; }
h1,h2,h3,h4{ font-family:var(--display); line-height:1.15; font-weight:600; 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:1.3rem; }
p{ margin:0 0 1rem; color:var(--muted); }
.gradient-text{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.eyebrow{ display:inline-block; font-family:var(--font); font-weight:600; letter-spacing:.16em; text-transform:uppercase; font-size:.72rem; color:var(--gold); margin-bottom:1rem; }

/* Buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-family:var(--font); font-weight:600; font-size:.95rem; padding:.85rem 1.6rem; border-radius:999px; border:1px solid transparent; cursor:pointer; text-decoration:none; transition:transform .25s,box-shadow .25s,background .25s; white-space:nowrap; }
.btn-primary{ background:var(--grad); color:#1a0f24; box-shadow:var(--shadow-glow); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 0 50px -6px rgba(244,114,182,.6); }
.btn-ghost{ background:var(--surface); border-color:var(--border); color:var(--text); backdrop-filter:blur(8px); }
.btn-ghost:hover{ background:var(--surface-2); transform:translateY(-3px); }
.btn-outline{ background:transparent; border-color:var(--border); color:var(--text); }
.btn-outline:hover{ border-color:var(--violet); color:#fff; }
.btn-sm{ padding:.55rem 1.1rem; font-size:.85rem; }
.btn-lg{ padding:1.05rem 2.2rem; font-size:1.05rem; }
.btn-block{ display:flex; width:100%; }

/* Header */
.site-header{ position:sticky; top:0; z-index:200; transition:background .3s,box-shadow .3s; }
.site-header.scrolled{ background:rgba(11,7,16,.82); backdrop-filter:blur(14px); border-bottom:1px solid var(--border); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-block:16px; }
.brand{ text-decoration:none; }
.fyf-logo{ display:inline-flex; align-items:center; gap:.6rem; }
.fyf-logo svg{ border-radius:12px; }
.fyf-logo-text{ font-family:var(--display); font-weight:700; font-size:1.4rem; letter-spacing:.04em; color:var(--text); }
.primary-nav .nav-list{ display:flex; gap:1.8rem; list-style:none; margin:0; padding:0; }
.primary-nav a{ text-decoration:none; color:var(--muted); font-weight:500; font-size:.95rem; transition:color .2s; }
.primary-nav a:hover{ color:var(--text); }
.header-actions{ display:flex; align-items:center; gap:.8rem; }
.menu-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.menu-toggle span{ width:24px; height:2px; background:var(--text); border-radius:2px; transition:.3s; }
.menu-toggle.active span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle.active span:nth-child(2){ opacity:0; }
.menu-toggle.active span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
.mobile-menu{ display:none; flex-direction:column; gap:1rem; padding:0 24px 24px; }
.mobile-menu.open{ display:flex; }
.mobile-nav-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.4rem; }
.mobile-nav-list a{ display:block; padding:.8rem 1rem; border-radius:var(--radius-sm); background:var(--surface); text-decoration:none; color:var(--text); }

/* Scroll progress */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; background:var(--grad); z-index:300; transition:width .1s; }

/* Hero */
.hero{ position:relative; padding:clamp(3rem,8vw,7rem) 0 clamp(3rem,7vw,6rem); overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg .orb{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.5; animation:float 14s ease-in-out infinite; }
.orb-1{ width:380px; height:380px; background:rgba(192,132,252,.5); top:-80px; right:5%; }
.orb-2{ width:300px; height:300px; background:rgba(233,184,115,.4); bottom:-60px; left:-40px; animation-delay:-4s; }
.orb-3{ width:240px; height:240px; background:rgba(244,114,182,.35); top:40%; left:45%; animation-delay:-8s; }
#particles{ position:absolute; inset:0; width:100%; height:100%; }
.hero-inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.1fr .9fr; gap:3rem; align-items:center; }
.hero-sub{ font-size:1.15rem; max-width:38ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; margin:1.8rem 0; }
.hero-stats{ display:flex; gap:2.4rem; margin-top:2rem; }
.hero-stats strong{ display:block; font-family:var(--display); font-size:1.9rem; color:#fff; }
.hero-stats span{ font-size:.8rem; color:var(--muted); }
.hero-visual{ position:relative; min-height:380px; }
.chat-float{ position:absolute; display:flex; gap:.7rem; align-items:center; background:var(--surface-2); border:1px solid var(--border); backdrop-filter:blur(14px); padding:.8rem 1rem; border-radius:18px; box-shadow:var(--shadow); max-width:280px; animation:float 8s ease-in-out infinite; }
.chat-float img{ width:48px; height:48px; border-radius:50%; object-fit:cover; }
.chat-float strong{ font-size:.9rem; }
.chat-float p{ margin:0; font-size:.82rem; }
.chat-float-1{ top:10%; left:0; }
.chat-float-2{ top:42%; right:0; animation-delay:-3s; }
.chat-float-3{ bottom:5%; left:12%; animation-delay:-6s; }

@keyframes float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-18px); } }

.online-dot{ display:inline-block; width:9px; height:9px; border-radius:50%; background:#34d399; box-shadow:0 0 0 0 rgba(52,211,153,.6); animation:pulse 2s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(52,211,153,.6);} 70%{ box-shadow:0 0 0 8px rgba(52,211,153,0);} 100%{ box-shadow:0 0 0 0 rgba(52,211,153,0);} }

/* Sections */
.section{ padding:clamp(3rem,7vw,6rem) 0; }
.section-alt{ background:linear-gradient(180deg,transparent,rgba(192,132,252,.04),transparent); }
.section-head{ text-align:center; max-width:680px; margin:0 auto 3rem; }
.section-head p{ font-size:1.05rem; }

/* Companion grid */
.companion-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.6rem; }
.companion-grid.related{ grid-template-columns:repeat(3,1fr); }
.companion-card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:transform .3s,box-shadow .3s,border-color .3s; }
.companion-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-color:rgba(192,132,252,.4); }
.card-img{ position:relative; display:block; aspect-ratio:3/4; overflow:hidden; }
.card-img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.companion-card:hover .card-img img{ transform:scale(1.06); }
.status-badge{ position:absolute; top:12px; left:12px; display:inline-flex; align-items:center; gap:.4rem; background:rgba(11,7,16,.6); backdrop-filter:blur(6px); border:1px solid var(--border); padding:.3rem .7rem; border-radius:999px; font-size:.72rem; color:#fff; }
.status-badge.large{ position:static; display:inline-flex; margin-top:1rem; }
.card-body{ padding:1.2rem; }
.card-body h3{ margin:0 0 .2rem; font-size:1.2rem; }
.card-body h3 a{ text-decoration:none; }
.card-tag{ display:block; font-size:.78rem; color:var(--gold); margin-bottom:.6rem; }
.card-body p{ font-size:.88rem; margin-bottom:1rem; }
.card-actions{ display:flex; gap:.5rem; }

/* Feature grid */
.feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.feature-card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.8rem; transition:transform .3s,border-color .3s; }
.feature-card:hover{ transform:translateY(-6px); border-color:rgba(233,184,115,.4); }
.feature-ico{ width:54px; height:54px; display:grid; place-items:center; font-size:1.5rem; border-radius:14px; background:var(--grad-soft); margin-bottom:1rem; }

/* Steps */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin-bottom:2.5rem; }
.step{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:2rem 1.6rem; text-align:center; }
.step-num{ display:grid; place-items:center; width:54px; height:54px; margin:0 auto 1rem; border-radius:50%; background:var(--grad); color:#1a0f24; font-family:var(--display); font-size:1.5rem; font-weight:700; }

/* Personalities */
.personality-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.personality-card{ position:relative; aspect-ratio:3/4; border-radius:var(--radius); overflow:hidden; text-decoration:none; display:block; }
.personality-card img{ width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.personality-card:hover img{ transform:scale(1.08); }
.personality-overlay{ position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:1.4rem; background:linear-gradient(to top,rgba(11,7,16,.9),transparent 65%); }
.personality-overlay h3{ margin:0; }
.personality-overlay p{ margin:.3rem 0 0; font-size:.84rem; }

/* Stats */
.stats-section{ background:var(--grad-soft); }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; text-align:center; }
.stats-grid strong{ display:block; font-family:var(--display); font-size:clamp(2.2rem,5vw,3.4rem); background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stats-grid span{ color:var(--muted); font-size:.9rem; }

/* Testimonials */
.testimonial-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.testimonial{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.8rem; margin:0; }
.stars{ color:var(--gold); letter-spacing:2px; margin-bottom:.8rem; }
.testimonial blockquote{ margin:0 0 1.2rem; font-size:1rem; color:var(--text); }
.testimonial figcaption strong{ display:block; }
.testimonial figcaption span{ font-size:.82rem; color:var(--muted); }

/* FAQ */
.faq-list{ display:flex; flex-direction:column; gap:.8rem; }
.faq-item{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:0 1.4rem; }
.faq-item summary{ cursor:pointer; list-style:none; padding:1.2rem 0; font-weight:600; font-size:1.02rem; color:var(--text); display:flex; justify-content:space-between; gap:1rem; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; color:var(--gold); font-size:1.4rem; line-height:1; transition:transform .3s; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-answer{ padding-bottom:1.2rem; }
.faq-answer p{ margin:0; }

/* Final CTA */
.final-cta{ padding:clamp(3.5rem,8vw,6rem) 0; background:radial-gradient(600px 300px at 50% 0,rgba(192,132,252,.2),transparent); }
.final-cta h2{ font-size:clamp(2rem,5vw,3.2rem); }
.fineprint{ font-size:.8rem; margin-top:1rem; }

/* Breadcrumbs */
.breadcrumbs{ padding:1.2rem 0 0; }
.breadcrumbs ol{ list-style:none; display:flex; flex-wrap:wrap; gap:.5rem; margin:0; padding:0; font-size:.82rem; color:var(--muted); }
.breadcrumbs li:not(:last-child)::after{ content:'/'; margin-left:.5rem; color:var(--border); }
.breadcrumbs a{ text-decoration:none; color:var(--gold); }

/* Companion page */
.companion-hero{ padding:2rem 0 3rem; }
.companion-hero-inner{ display:grid; grid-template-columns:.9fr 1.1fr; gap:3rem; align-items:center; }
.companion-photo{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.companion-photo img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.companion-photo .status-badge.large{ position:absolute; top:16px; left:16px; margin:0; }
.companion-tagline{ font-family:var(--display); font-size:1.3rem; font-style:italic; color:var(--gold); }
.quick-facts{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:.8rem; padding:0; margin:1.6rem 0; }
.quick-facts li{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:.8rem 1rem; }
.quick-facts span{ display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); }
.quick-facts strong{ color:#fff; }

.companion-body{ display:grid; grid-template-columns:1fr 320px; gap:3rem; padding:2rem 24px 4rem; }
.block{ margin-bottom:2.6rem; }
.block h2{ font-size:1.7rem; margin-bottom:1rem; position:relative; padding-bottom:.6rem; }
.block h2::after{ content:''; position:absolute; left:0; bottom:0; width:54px; height:3px; background:var(--grad); border-radius:3px; }
.chip-list{ display:flex; flex-wrap:wrap; gap:.6rem; }
.chip{ background:var(--surface); border:1px solid var(--border); border-radius:999px; padding:.45rem 1rem; font-size:.85rem; text-decoration:none; color:var(--text); transition:border-color .2s; }
.chip:hover{ border-color:var(--violet); }
.topic-list{ list-style:none; padding:0; display:grid; gap:.6rem; }
.topic-list li{ background:var(--surface); border:1px solid var(--border); border-left:3px solid var(--gold); border-radius:var(--radius-sm); padding:.8rem 1rem; }

/* Conversation */
.convo{ display:flex; flex-direction:column; gap:.8rem; margin-bottom:1.6rem; }
.bubble{ display:flex; gap:.6rem; align-items:flex-end; max-width:80%; }
.bubble img{ width:34px; height:34px; border-radius:50%; object-fit:cover; }
.bubble p{ margin:0; padding:.8rem 1.1rem; border-radius:16px; font-size:.92rem; }
.bubble-her p{ background:var(--surface-2); border:1px solid var(--border); border-bottom-left-radius:4px; color:var(--text); }
.bubble-you{ align-self:flex-end; }
.bubble-you p{ background:var(--grad); color:#1a0f24; border-bottom-right-radius:4px; }

/* Masonry gallery */
.masonry{ columns:3; column-gap:1rem; }
.masonry-item{ break-inside:avoid; margin:0 0 1rem; border-radius:var(--radius-sm); overflow:hidden; position:relative; cursor:pointer; }
.masonry-item img{ width:100%; transition:transform .5s,filter .3s; }
.masonry-item:hover img{ transform:scale(1.05); }
.masonry-item figcaption{ position:absolute; left:0; right:0; bottom:0; padding:1.4rem .9rem .7rem; font-size:.78rem; color:#fff; background:linear-gradient(to top,rgba(11,7,16,.85),transparent); }

.profile-meta{ margin-top:1.4rem; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:1.2rem 1.4rem; }
.profile-meta p{ margin:.3rem 0; }
.companion-cta{ background:var(--grad-soft); border:1px solid var(--border); border-radius:var(--radius); padding:2.4rem; text-align:center; }

/* Sidebar */
.companion-aside{ position:sticky; top:90px; align-self:start; }
.sidebar-widgets{ display:flex; flex-direction:column; gap:1.4rem; }
.widget{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.4rem; }
.widget-title{ font-size:1.05rem; margin-bottom:1rem; }
.mini-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.7rem; }
.mini-list a{ display:flex; gap:.7rem; align-items:center; text-decoration:none; color:var(--text); }
.mini-list img{ width:44px; height:44px; border-radius:12px; object-fit:cover; }
.mini-list strong{ display:block; font-size:.9rem; }
.mini-list em{ font-style:normal; font-size:.76rem; color:var(--muted); }
.widget-cta p{ font-size:.88rem; }

/* Legal */
.legal-page h1{ margin-bottom:1.5rem; }
.legal-content h2{ font-size:1.6rem; margin-top:0; }
.legal-content h3{ margin-top:1.8rem; color:var(--gold); }
.legal-content ul{ color:var(--muted); padding-left:1.2rem; }
.legal-content li{ margin-bottom:.5rem; }
.legal-cta{ margin-top:3rem; padding-top:2rem; border-top:1px solid var(--border); text-align:center; }

/* Footer */
.site-footer{ border-top:1px solid var(--border); padding-top:3.5rem; margin-top:2rem; background:linear-gradient(180deg,transparent,rgba(18,11,28,.6)); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2rem; padding-bottom:2.5rem; }
.footer-brand p{ margin-top:1rem; font-size:.9rem; max-width:32ch; }
.footer-col h4{ font-family:var(--font); font-size:.95rem; letter-spacing:.05em; margin-bottom:1rem; }
.footer-col ul,.footer-menu{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.6rem; }
.footer-col a{ text-decoration:none; color:var(--muted); font-size:.9rem; transition:color .2s; }
.footer-col a:hover{ color:var(--text); }
.footer-cta p{ font-size:.88rem; margin-bottom:1rem; }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem; padding:1.4rem 24px; border-top:1px solid var(--border); }
.footer-bottom p{ margin:0; font-size:.8rem; }

/* Floating widgets */
.floating-cta{ position:fixed; right:20px; bottom:20px; z-index:180; display:inline-flex; align-items:center; gap:.5rem; background:var(--grad); color:#1a0f24; padding:.85rem 1.3rem; border-radius:999px; text-decoration:none; font-weight:600; box-shadow:var(--shadow-glow); transition:transform .25s; }
.floating-cta:hover{ transform:scale(1.06); }
.sticky-cta{ position:fixed; left:0; right:0; bottom:0; z-index:170; display:flex; align-items:center; justify-content:center; gap:1.2rem; flex-wrap:wrap; padding:.9rem 1.2rem; background:rgba(11,7,16,.92); backdrop-filter:blur(14px); border-top:1px solid var(--border); transform:translateY(120%); transition:transform .4s; }
.sticky-cta.show{ transform:translateY(0); }
.sticky-cta span{ font-size:.9rem; }
.back-to-top{ position:fixed; right:20px; bottom:84px; z-index:175; width:46px; height:46px; border-radius:50%; border:1px solid var(--border); background:var(--surface-2); backdrop-filter:blur(10px); color:var(--text); cursor:pointer; display:grid; place-items:center; opacity:0; pointer-events:none; transition:opacity .3s,transform .3s; }
.back-to-top.show{ opacity:1; pointer-events:auto; }
.back-to-top:hover{ transform:translateY(-3px); }

/* Live activity */
.live-activity{ position:fixed; left:20px; bottom:20px; z-index:160; display:flex; align-items:center; gap:.6rem; background:var(--surface-2); border:1px solid var(--border); backdrop-filter:blur(14px); padding:.7rem 1.1rem; border-radius:14px; font-size:.85rem; box-shadow:var(--shadow); opacity:0; transform:translateY(20px); transition:opacity .4s,transform .4s; max-width:300px; }
.live-activity.show{ opacity:1; transform:translateY(0); }
.live-activity .online-dot{ flex-shrink:0; }

/* Cookie banner */
.cookie-banner{ position:fixed; left:20px; right:20px; bottom:20px; z-index:190; max-width:540px; margin:0 auto; display:none; align-items:center; gap:1rem; flex-wrap:wrap; justify-content:space-between; background:rgba(18,11,28,.96); border:1px solid var(--border); backdrop-filter:blur(14px); padding:1rem 1.3rem; border-radius:var(--radius); box-shadow:var(--shadow); }
.cookie-banner.show{ display:flex; }
.cookie-banner p{ margin:0; font-size:.85rem; flex:1; min-width:220px; }
.cookie-banner a{ color:var(--gold); }

/* Exit popup */
.exit-popup{ position:fixed; inset:0; z-index:300; display:none; align-items:center; justify-content:center; background:rgba(5,3,8,.75); backdrop-filter:blur(6px); padding:1.5rem; }
.exit-popup.show{ display:flex; }
.exit-popup-inner{ position:relative; max-width:460px; width:100%; text-align:center; background:linear-gradient(160deg,var(--bg-2),var(--bg)); border:1px solid var(--border); border-radius:var(--radius); padding:2.6rem 2rem; box-shadow:var(--shadow); animation:popIn .4s ease; }
@keyframes popIn{ from{ transform:scale(.9); opacity:0; } to{ transform:scale(1); opacity:1; } }
.exit-close{ position:absolute; top:12px; right:16px; background:none; border:0; color:var(--muted); font-size:1.8rem; cursor:pointer; line-height:1; }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:320; display:none; align-items:center; justify-content:center; background:rgba(5,3,8,.92); padding:2rem; }
.lightbox.show{ display:flex; }
.lightbox img{ max-width:90vw; max-height:88vh; border-radius:var(--radius-sm); box-shadow:var(--shadow); }
.lightbox-close{ position:absolute; top:18px; right:24px; background:none; border:0; color:#fff; font-size:2.4rem; cursor:pointer; line-height:1; }

/* Reveal animation */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease,transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* Responsive */
@media (max-width:980px){
	.hero-inner,.companion-hero-inner{ grid-template-columns:1fr; }
	.hero-visual{ display:none; }
	.companion-body{ grid-template-columns:1fr; }
	.companion-aside{ position:static; }
	.companion-grid,.personality-grid{ grid-template-columns:repeat(2,1fr); }
	.feature-grid,.steps,.testimonial-grid,.companion-grid.related{ grid-template-columns:1fr 1fr; }
	.stats-grid{ grid-template-columns:1fr 1fr; }
	.footer-grid{ grid-template-columns:1fr 1fr; }
	.primary-nav{ display:none; }
	.menu-toggle{ display:flex; }
	.header-cta{ display:none; }
	.masonry{ columns:2; }
}
@media (max-width:560px){
	.companion-grid,.personality-grid,.feature-grid,.steps,.testimonial-grid,.stats-grid,.companion-grid.related,.footer-grid{ grid-template-columns:1fr; }
	.hero-stats{ gap:1.4rem; }
	.masonry{ columns:1; }
	.quick-facts{ grid-template-columns:1fr; }
	.floating-cta span{ display:none; }
}

@media (prefers-reduced-motion:reduce){
	*{ animation:none !important; transition:none !important; }
	.reveal{ opacity:1; transform:none; }
}
