/* ===== FansaFurn — warm stone/taupe + amber-gold ===== */
:root{
  --amber:#D97706; --amber-dark:#B45309; --amber-soft:#FBE7D2;
  --stone-900:#2B2622; --stone-800:#3D362F; --stone-700:#5A5047;
  --stone-600:#7A6E62; --stone-500:#9A8C7C; --stone-300:#CDBFAF;
  --stone-200:#E5DACE; --stone-100:#F0E8DF;
  --bg:#FAF5F2; --surface:#FFFFFF; --surface-2:#F5EDE4;
  --line:#E3D8CB; --ok:#3F7D58; --err:#B4452F;
  --radius:14px; --radius-sm:9px; --radius-lg:22px;
  --shadow-sm:0 1px 3px rgba(43,38,34,.08);
  --shadow:0 6px 22px rgba(43,38,34,.10);
  --shadow-lg:0 18px 50px rgba(43,38,34,.16);
  --maxw:1180px; --space:clamp(3.5rem,7vw,6rem);
  --font-head:"Lora",Georgia,serif; --font-body:"Raleway",system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:84px}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--stone-800);
  background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--amber-dark);text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--stone-900);line-height:1.2;font-weight:600}
ul{list-style:none}
.icon{width:24px;height:24px;display:block}

/* ===== buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-body);font-weight:600;font-size:1rem;line-height:1.25;
  padding:.85rem 1.5rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;text-align:center;transition:transform .18s ease,background .18s ease,box-shadow .18s ease;
  min-height:48px;-webkit-tap-highlight-color:transparent}
.btn-primary{background:var(--amber);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--amber-dark);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-secondary{background:transparent;color:var(--stone-900);border-color:var(--stone-300)}
.btn-secondary:hover{background:var(--surface-2);border-color:var(--amber);transform:translateY(-2px)}
.btn:focus-visible{outline:3px solid var(--amber);outline-offset:3px}

/* ===== header / nav ===== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(250,245,242,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .25s ease}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.nav-container{max-width:var(--maxw);margin:0 auto;padding:.75rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand-logo{font-family:var(--font-head);font-weight:700;font-size:1.5rem;color:var(--stone-900);letter-spacing:.3px}
.brand-logo:hover{color:var(--amber-dark)}
.main-nav{display:flex;align-items:center;gap:1.5rem}
.nav-list{display:flex;align-items:center;gap:1.4rem}
.nav-link{color:var(--stone-700);font-weight:500;font-size:.97rem;padding:.4rem 0;position:relative}
.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--amber);transition:width .22s ease}
.nav-link:hover{color:var(--stone-900)}
.nav-link:hover::after{width:100%}
.nav-cta{padding:.6rem 1.2rem;min-height:42px;font-size:.92rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;width:44px;height:44px;justify-content:center}
.nav-toggle-bar{width:24px;height:2px;background:var(--stone-900);border-radius:2px;transition:transform .25s ease,opacity .25s ease}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== generic section ===== */
.section-inner{max-width:var(--maxw);margin:0 auto;padding:var(--space) 1.25rem}
.section-header{max-width:760px;margin:0 auto 2.75rem;text-align:center}
.section-title{font-size:clamp(1.7rem,3.6vw,2.6rem);margin-bottom:.9rem}
.section-subtitle{font-size:1.08rem;color:var(--stone-600);line-height:1.6}

/* ===== hero ===== */
.hero{background:linear-gradient(160deg,var(--surface-2),var(--bg))}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(2.5rem,5vw,4.5rem) 1.25rem;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,3.5rem);align-items:center}
.hero-title{font-size:clamp(2rem,4.6vw,3.3rem);font-weight:700;margin-bottom:1.1rem}
.hero-subtitle{font-size:1.1rem;color:var(--stone-700);margin-bottom:1.5rem;line-height:1.65}
.hero-bullets{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.9rem}
.hero-bullet{position:relative;padding-left:1.9rem;color:var(--stone-700);line-height:1.5}
.hero-bullet::before{content:"";position:absolute;left:0;top:.15rem;width:1.2rem;height:1.2rem;border-radius:50%;
  background:var(--amber-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23B45309' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/13px no-repeat}
.hero-cta-group{display:flex;flex-wrap:wrap;gap:.85rem}
.hero-media{position:relative}
.hero-img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);object-fit:cover;aspect-ratio:4/3}

/* ===== benefits ===== */
.benefits{background:var(--bg)}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.benefit-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.9rem 1.6rem;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}
.benefit-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.benefit-icon{width:54px;height:54px;border-radius:14px;background:var(--amber-soft);color:var(--amber-dark);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.benefit-icon .icon{width:28px;height:28px}
.benefit-title{font-size:1.16rem;margin-bottom:.6rem;line-height:1.3}
.benefit-desc{color:var(--stone-600);font-size:.97rem;line-height:1.6}

/* ===== how it works ===== */
.how-it-works{background:var(--surface-2)}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.step-card{background:var(--surface);border-radius:var(--radius);padding:1.8rem 1.4rem;
  border:1px solid var(--line);text-align:center;box-shadow:var(--shadow-sm)}
.step-number{width:48px;height:48px;border-radius:50%;background:var(--amber);color:#fff;
  font-family:var(--font-head);font-weight:700;font-size:1.3rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.step-title{font-size:1.1rem;margin-bottom:.55rem}
.step-desc{color:var(--stone-600);font-size:.95rem}

/* ===== features ===== */
.features{background:var(--bg)}
.features-list{display:flex;flex-direction:column;gap:clamp(2.5rem,5vw,4.5rem)}
.feature-block{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3.5vw,3.5rem);align-items:center}
.feature-block-reverse .feature-media{order:2}
.feature-img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);object-fit:cover;aspect-ratio:4/3}
.feature-title{font-size:clamp(1.35rem,2.6vw,1.85rem);margin-bottom:1rem;line-height:1.25}
.feature-text{color:var(--stone-700);margin-bottom:1.2rem;line-height:1.65}
.feature-bullets{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.5rem}
.feature-bullet{position:relative;padding-left:1.7rem;color:var(--stone-700);font-size:.97rem;line-height:1.5}
.feature-bullet::before{content:"";position:absolute;left:0;top:.45rem;width:.55rem;height:.55rem;border-radius:50%;background:var(--amber)}

/* ===== products ===== */
.products{background:var(--surface-2)}
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.product-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product-media{aspect-ratio:1/1;background:var(--surface-2);overflow:hidden}
.product-img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.product-card:hover .product-img{transform:scale(1.04)}
.product-body{padding:1.4rem;display:flex;flex-direction:column;flex:1}
.product-name{font-size:1.12rem;line-height:1.3;margin-bottom:.6rem}
.product-rating{display:flex;align-items:center;gap:.45rem;margin-bottom:.8rem;flex-wrap:wrap}
.stars{display:inline-flex;color:var(--amber);font-size:1rem;letter-spacing:1px}
.star-empty{color:var(--stone-300)}
.rating-value{font-weight:600;color:var(--stone-800);font-size:.92rem}
.rating-count{color:var(--stone-500);font-size:.85rem}
.rating-new{display:inline-block;background:var(--amber-soft);color:var(--amber-dark);font-weight:600;
  font-size:.78rem;padding:.2rem .6rem;border-radius:999px}
.product-desc{color:var(--stone-600);font-size:.93rem;line-height:1.6;margin-bottom:1rem}
.product-highlights{display:flex;flex-direction:column;gap:.55rem;margin-bottom:1.3rem}
.highlight{position:relative;padding-left:1.6rem;font-size:.88rem;color:var(--stone-700);line-height:1.45}
.highlight::before{content:"";position:absolute;left:0;top:.1rem;width:1.1rem;height:1.1rem;border-radius:4px;
  background:var(--amber-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B45309' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat}
.product-cta{margin-top:auto;width:100%}

/* ===== about ===== */
.about-brief{background:var(--bg)}
.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.about-img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);object-fit:cover;aspect-ratio:4/3}
.about-title{text-align:left;font-size:clamp(1.6rem,3.2vw,2.3rem);margin-bottom:1.2rem}
.about-text{display:flex;flex-direction:column;gap:1rem}
.about-para{color:var(--stone-700);line-height:1.7}

/* ===== comparison table ===== */
.comparison{background:var(--surface-2)}
.comparison-table-wrap{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.comparison-table{width:100%;border-collapse:collapse;min-width:680px;background:var(--surface);font-size:.93rem}
.comparison-table th,.comparison-table td{padding:.95rem 1rem;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.comparison-table thead th{background:var(--stone-900);color:var(--stone-100);font-family:var(--font-body);font-weight:600;font-size:.9rem}
.comparison-table thead th.brand-col{background:var(--amber-dark);color:#fff}
.comparison-table .criterion-name{font-weight:600;color:var(--stone-900)}
.comparison-table td.brand-col{background:var(--amber-soft);color:var(--stone-900);font-weight:600}
.comparison-table tbody tr:last-child td{border-bottom:0}

/* ===== timeline ===== */
.timeline{background:var(--bg)}
.timeline-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:1.4rem;position:relative}
.timeline-item{display:grid;grid-template-columns:120px 1fr;gap:1.3rem;align-items:start;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm)}
.timeline-marker{display:flex}
.timeframe{display:inline-block;background:var(--amber);color:#fff;font-weight:600;font-size:.9rem;
  padding:.4rem .8rem;border-radius:999px;white-space:nowrap}
.timeline-outcome{color:var(--stone-700);line-height:1.6}

/* ===== fears ===== */
.fears{background:var(--surface-2)}
.fears-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.fear-card{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--amber);
  border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm)}
.fear-title{font-size:1.08rem;margin-bottom:.7rem;color:var(--stone-900);line-height:1.35}
.fear-desc{color:var(--stone-600);font-size:.95rem;line-height:1.65}

/* ===== who-for / personas ===== */
.who-for{background:var(--bg)}
.persona-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-bottom:2.5rem}
.persona-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;box-shadow:var(--shadow-sm)}
.persona-emoji{font-size:2rem;display:block;margin-bottom:.8rem}
.persona-title{font-size:1.14rem;margin-bottom:.7rem;line-height:1.3}
.persona-desc{color:var(--stone-600);font-size:.95rem;line-height:1.65}
.not-for-block{max-width:820px;margin:0 auto;background:var(--surface-2);border:1px dashed var(--stone-300);
  border-radius:var(--radius);padding:1.8rem}
.not-for-heading{font-size:1.2rem;margin-bottom:1rem;text-align:center}
.not-for-list{display:flex;flex-direction:column;gap:.85rem}
.not-for-item{position:relative;padding-left:1.9rem;color:var(--stone-700);line-height:1.55}
.not-for-item::before{content:"\00d7";position:absolute;left:.4rem;top:-.1rem;color:var(--err);font-weight:700;font-size:1.2rem}

/* ===== expert ===== */
.expert{background:var(--stone-900)}
.expert .section-title{color:var(--stone-100)}
.expert .section-subtitle{color:var(--stone-300)}
.expert-card{display:grid;grid-template-columns:280px 1fr;gap:2.2rem;background:var(--surface);
  border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.6rem);box-shadow:var(--shadow-lg);align-items:start}
.expert-media{text-align:center}
.expert-img{width:170px;height:170px;border-radius:50%;object-fit:cover;margin:0 auto 1rem;box-shadow:var(--shadow);border:4px solid var(--amber-soft)}
.expert-id{display:flex;flex-direction:column;gap:.2rem}
.expert-name{font-family:var(--font-head);font-weight:700;font-size:1.15rem;color:var(--stone-900)}
.expert-role{color:var(--stone-600);font-size:.88rem}
.expert-quote{font-family:var(--font-head);font-size:1.18rem;line-height:1.5;color:var(--stone-800);
  font-style:italic;border-left:3px solid var(--amber);padding-left:1.2rem;margin-bottom:1.5rem}
.expert-tips{display:flex;flex-direction:column;gap:.9rem;margin-bottom:1.5rem}
.expert-tip{position:relative;padding-left:2rem;color:var(--stone-700);font-size:.95rem;line-height:1.6;counter-increment:tip}
.expert-tips{counter-reset:tip}
.expert-tip::before{content:counter(tip);position:absolute;left:0;top:0;width:1.4rem;height:1.4rem;border-radius:50%;
  background:var(--amber);color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.expert-picks{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.2rem}
.expert-pick{display:flex;flex-direction:column;gap:.3rem;background:var(--surface-2);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:.8rem 1rem;font-size:.9rem;color:var(--stone-800);font-weight:500;flex:1;min-width:200px;transition:border-color .2s ease}
.expert-pick:hover{border-color:var(--amber)}
.expert-pick-cta{color:var(--amber-dark);font-weight:600;font-size:.85rem}
.expert-disclosure{font-size:.8rem;color:var(--stone-500);font-style:italic}

/* ===== newsletter ===== */
.newsletter{background:linear-gradient(150deg,var(--amber),var(--amber-dark));color:#fff}
.newsletter-inner{max-width:720px;margin:0 auto;padding:var(--space) 1.25rem;text-align:center}
.newsletter-title{color:#fff;font-size:clamp(1.6rem,3.4vw,2.4rem);margin-bottom:.8rem}
.newsletter-subtitle{color:rgba(255,255,255,.92);font-size:1.05rem;margin-bottom:2rem;line-height:1.6}
.newsletter-form{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;align-items:flex-start}
.newsletter-field{flex:1;min-width:260px;text-align:left}
.newsletter-label{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
.newsletter-input{width:100%;padding:.9rem 1.1rem;border:2px solid transparent;border-radius:999px;font-size:1rem;font-family:var(--font-body);min-height:48px}
.newsletter-input:focus-visible{outline:3px solid var(--stone-900);outline-offset:2px}
.newsletter-error{display:block;min-height:1.1rem;color:#3b1a10;font-size:.82rem;font-weight:600;padding:.2rem .9rem 0}
.newsletter-btn{background:var(--stone-900);border-color:var(--stone-900)}
.newsletter-btn:hover{background:#1d1916}
.newsletter-success{width:100%;margin-top:.8rem;font-weight:600;color:#fff}

/* ===== FAQ ===== */
.faq{background:var(--bg)}
.faq-list,.faq-more{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:.8rem}
.faq-more{margin-top:.8rem}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:none;border:0;cursor:pointer;padding:1.15rem 1.3rem;text-align:left;font-family:var(--font-body);
  font-weight:600;font-size:1.02rem;color:var(--stone-900);min-height:48px}
.faq-question:hover{color:var(--amber-dark)}
.faq-icon{flex-shrink:0;width:22px;height:22px;position:relative}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--amber-dark);border-radius:2px;transition:transform .25s ease}
.faq-icon::before{top:10px;left:2px;width:18px;height:2px}
.faq-icon::after{top:2px;left:10px;width:2px;height:18px}
.faq-question[aria-expanded="true"] .faq-icon::after{transform:rotate(90deg);opacity:0}
.faq-answer{padding:0 1.3rem 1.2rem;color:var(--stone-600);line-height:1.65;font-size:.96rem}
.faq-more-btn{display:flex;margin:1.6rem auto 0}

/* ===== sticky CTA ===== */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--stone-900);
  transform:translateY(110%);transition:transform .3s ease}
.sticky-cta.visible{transform:translateY(0)}
.sticky-cta-inner{max-width:var(--maxw);margin:0 auto;padding:.7rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.sticky-cta-text{color:var(--stone-100);font-size:.95rem;font-weight:500}
.sticky-cta-btn{padding:.6rem 1.3rem;min-height:42px}

/* ===== footer ===== */
.site-footer{background:var(--stone-900);color:var(--stone-300)}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(2.8rem,5vw,4rem) 1.25rem 2rem;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.brand-logo-footer{color:#fff;display:inline-block;margin-bottom:.9rem}
.footer-tagline{font-size:.92rem;line-height:1.6;margin-bottom:1.1rem;max-width:340px}
.footer-store-link{color:var(--amber);font-weight:600;font-size:.92rem}
.footer-heading{color:#fff;font-family:var(--font-body);font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem}
.footer-list,.footer-social{display:flex;flex-direction:column;gap:.6rem}
.footer-link{color:var(--stone-300);font-size:.92rem}
.footer-link:hover{color:var(--amber)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:1.5rem 1.25rem;max-width:var(--maxw);margin:0 auto;
  display:flex;flex-direction:column;gap:.6rem;text-align:center}
.footer-copy{font-size:.88rem;color:var(--stone-500)}
.footer-bottom p{font-size:.82rem;color:var(--stone-500);line-height:1.5}
.footer-bottom a{color:var(--amber)}

/* ===== legal / simple pages ===== */
.legal-main{background:var(--bg);min-height:60vh}
.legal-inner{max-width:820px;margin:0 auto;padding:clamp(2.5rem,5vw,4rem) 1.25rem}
.page-title{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:1.2rem}
.page-lead{font-size:1.1rem;color:var(--stone-600);line-height:1.6;margin-bottom:2rem}
.legal-body{display:flex;flex-direction:column;gap:1rem}
.legal-body h2{font-size:1.3rem;margin-top:1.2rem}
.legal-body p{color:var(--stone-700);line-height:1.7}
.legal-updated{color:var(--stone-500);font-size:.9rem;font-style:italic}
.about-page-media{margin:1.5rem 0}
.about-page-img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.about-page-cta{margin-top:2rem;text-align:center}

/* ===== contact form ===== */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:2.5rem;margin-top:1.5rem}
.contact-form{display:flex;flex-direction:column;gap:1.1rem}
.form-field{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-weight:600;font-size:.92rem;color:var(--stone-800)}
.req{color:var(--err)}
.form-input{width:100%;padding:.8rem 1rem;border:2px solid var(--line);border-radius:var(--radius-sm);
  font-size:1rem;font-family:var(--font-body);background:var(--surface);min-height:48px;color:var(--stone-900)}
.form-input:focus-visible{outline:none;border-color:var(--amber)}
.form-textarea{resize:vertical;min-height:140px}
.form-input.invalid{border-color:var(--err)}
.form-error{color:var(--err);font-size:.82rem;font-weight:600;min-height:1rem}
.form-submit{align-self:flex-start;margin-top:.4rem}
.form-success{color:var(--ok);font-weight:600;margin-top:.6rem}
.contact-aside{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;align-self:start}
.contact-aside-title{font-size:1.2rem;margin-bottom:1rem}
.contact-aside p{color:var(--stone-600);font-size:.95rem;line-height:1.6;margin-bottom:1rem}

/* ===== layout containers (explicit coverage) ===== */
.hero-content{min-width:0}
.hero-cta,.hero-cta-secondary{flex:0 1 auto;max-width:100%}
.about-media,.about-content{min-width:0}
.feature-content{min-width:0}
.feature-link{align-self:flex-start}
.expert-body{min-width:0}
.faq-q-text{flex:1;padding-right:.5rem}
.footer-col{min-width:0}
.footer-brand{max-width:380px}

/* ===== stars ===== */
.star{display:inline-block;line-height:1}
.star-full{color:var(--amber)}
.star-half{position:relative;color:var(--stone-300)}
.star-half::before{content:"\2605";position:absolute;left:0;top:0;width:50%;overflow:hidden;color:var(--amber)}
.product-rating-new{margin-bottom:.8rem}

/* ===== highlight type accents ===== */
.highlight-spec_scenario::before{background-color:var(--amber-soft)}
.highlight-mechanism::before{background-color:#E3ECE4}
.highlight-social_proof::before{background-color:#E6E0F0}
.highlight-risk_reversal::before{background-color:#F3E4DC}
.highlight-comparison::before{background-color:#E0EAF0}

/* ===== responsive ===== */
@media(max-width:960px){
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .expert-card{grid-template-columns:1fr;gap:1.5rem}
  .expert-media{display:flex;align-items:center;gap:1rem;text-align:left}
  .expert-img{margin:0}
  .footer-inner{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  html{scroll-padding-top:70px}
  .nav-toggle{display:flex}
  .main-nav{position:fixed;inset:64px 0 auto 0;background:var(--bg);flex-direction:column;align-items:stretch;
    gap:0;padding:1rem 1.25rem 1.5rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .3s ease;max-height:calc(100dvh - 64px);overflow-y:auto}
  .main-nav.open{transform:translateY(0)}
  .nav-list{flex-direction:column;align-items:stretch;gap:0}
  .nav-link{padding:.9rem 0;border-bottom:1px solid var(--line)}
  .nav-cta{margin-top:1rem;width:100%}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-media{order:-1}
  .hero-bullet{text-align:left}
  .hero-cta-group{justify-content:center}
  .feature-block,.feature-block-reverse{grid-template-columns:1fr}
  .feature-block-reverse .feature-media{order:0}
  .about-grid{grid-template-columns:1fr}
  .fears-grid,.persona-grid{grid-template-columns:1fr}
  .timeline-item{grid-template-columns:1fr;gap:.7rem}
  .newsletter-form{flex-direction:column}
  .newsletter-btn{width:100%}
  .sticky-cta-text{display:none}
  .sticky-cta-inner{justify-content:center}
  .sticky-cta-btn{width:100%}
}
@media(max-width:520px){
  .benefits-grid,.steps-grid,.products-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}
