/* ============================================================
   HOMEPAGE DESIGN SYSTEM — canonical patterns extracted from
   index.html so every page can match. Include AFTER physio.css /
   pages.css so these rules win for shared components.
   ============================================================ */

/* --- SECTION HEADINGS (.sh-*) ---------------------------- */
.sh-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:2.4px;color:var(--orange);margin-bottom:14px}
.sh-eyebrow::before{content:'';width:22px;height:1px;background:var(--orange)}
.sh-row{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-bottom:48px}
.sh-row-left{max-width:640px}
.sh-row-left h2{font-family:var(--font-h);font-size:42px;font-weight:400;color:var(--gray-900);line-height:1.08;letter-spacing:-1.2px;margin:0}
.sh-row-left h2 em{font-style:normal;color:var(--orange);font-weight:500}
.sh-row-right{font-size:15px;color:var(--gray-500);max-width:360px;line-height:1.65;padding-bottom:4px}
.sh-center{text-align:center;margin-bottom:52px;max-width:740px;margin-left:auto;margin-right:auto}
.sh-center .sh-eyebrow{justify-content:center}
.sh-center .sh-eyebrow::after{content:'';width:22px;height:1px;background:var(--orange)}
.sh-center h2{font-family:var(--font-h);font-size:42px;font-weight:400;color:var(--gray-900);line-height:1.08;letter-spacing:-1.2px;margin:0 0 14px}
.sh-center h2 em{font-style:normal;color:var(--orange);font-weight:500}
.sh-center p{font-size:15.5px;color:var(--gray-500);line-height:1.65;margin:0}

/* --- UNIVERSAL CTA (parallax) ----------------------------- */
section.uni-cta{position:relative;padding:0;background:var(--navy);overflow:hidden}
section.uni-cta .uni-cta-block{display:contents} /* neutralize legacy wrapper */
section.uni-cta .uni-cta-bg{position:absolute;inset:0;background-image:url('https://images.unsplash.com/photo-1576091160550-2173dba999ef?w=2400&q=80&auto=format&fit=crop');background-size:cover;background-position:center;background-attachment:fixed;opacity:0.55;z-index:0;transform:none !important}
section.uni-cta .uni-cta-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(17,14,69,0.78) 0%,rgba(26,21,96,0.62) 50%,rgba(17,14,69,0.75) 100%);z-index:1}
section.uni-cta .uni-cta-glow,section.uni-cta .uni-cta-glow1{position:absolute;top:-180px;right:-150px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(232,123,30,0.16) 0%,transparent 65%);z-index:1;pointer-events:none;transform:none !important}
section.uni-cta .uni-cta-glow2{position:absolute;bottom:-140px;left:-100px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,0.05) 0%,transparent 70%);z-index:1;pointer-events:none;transform:none !important}
section.uni-cta .uni-cta-inner{position:relative;z-index:2;max-width:780px;margin:0 auto;padding:96px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;color:var(--white);width:100%}
section.uni-cta .uni-cta-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:600;color:var(--orange);text-transform:uppercase;letter-spacing:2.4px;margin-bottom:20px}
section.uni-cta .uni-cta-eyebrow::before,section.uni-cta .uni-cta-eyebrow::after{content:'';width:24px;height:1px;background:var(--orange)}
section.uni-cta .uni-cta-logo{width:88px;height:88px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;margin-bottom:28px;box-shadow:0 18px 48px rgba(0,0,0,0.25),0 0 0 8px rgba(255,255,255,0.06);overflow:hidden;transform:none !important}
section.uni-cta .uni-cta-logo img{width:88%;height:88%;max-height:none;object-fit:contain;border-radius:50%;filter:none !important;opacity:1 !important;display:block}
section.uni-cta .uni-cta-inner h2{font-family:var(--font-h);font-size:48px;font-weight:400;color:var(--white);line-height:1.06;letter-spacing:-1.4px;margin:0 0 20px;max-width:680px}
section.uni-cta .uni-cta-inner h2 em{font-style:normal;color:var(--orange);font-weight:500}
section.uni-cta .uni-cta-inner p{font-size:16px;color:rgba(255,255,255,0.78);line-height:1.65;margin:0 0 32px;max-width:540px}
section.uni-cta .uni-cta-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
section.uni-cta .uni-cta-actions .btn-primary{padding:16px 32px;font-size:14.5px;border:none;box-shadow:0 12px 32px rgba(232,123,30,0.32)}
section.uni-cta .uni-cta-actions .btn-primary:hover{background:var(--white) !important;color:var(--navy) !important}
section.uni-cta .uni-cta-actions .btn-secondary{padding:16px 32px;font-size:14.5px;background:transparent !important;color:var(--white) !important;border:1.5px solid rgba(255,255,255,0.40)}
section.uni-cta .uni-cta-actions .btn-secondary:hover{background:rgba(255,255,255,0.10) !important;border-color:var(--white) !important;color:var(--white) !important}
section.uni-cta .uni-cta-trust{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;margin-top:28px;font-size:13px;color:rgba(255,255,255,0.7)}
section.uni-cta .uni-cta-trust-item{display:inline-flex;align-items:center;gap:6px}
section.uni-cta .uni-cta-trust-item svg{width:16px;height:16px;stroke-width:2}

/* --- FAQ ------------------------------------------------- */
section.faq{padding:88px 0;background:var(--white)}
section.faq .faq-head{margin-bottom:48px;text-align:center;max-width:720px;margin-left:auto;margin-right:auto}
section.faq .faq-head .lbl{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:600;color:var(--orange);letter-spacing:2.4px;text-transform:uppercase;margin-bottom:14px}
section.faq .faq-head .lbl::before,section.faq .faq-head .lbl::after{content:'';width:22px;height:1px;background:var(--orange)}
section.faq .faq-head h2{font-family:var(--font-h);font-size:42px;font-weight:400;color:var(--gray-900);line-height:1.08;letter-spacing:-1.2px;margin:0 0 12px}
section.faq .faq-head h2 em{font-style:normal;color:var(--orange);font-weight:500}
section.faq .faq-head p{font-size:15px;color:var(--gray-600);line-height:1.65;margin:0}
section.faq .faq-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px 22px;max-width:1180px;margin:0 auto}
section.faq .faq-list{display:flex;flex-direction:column;gap:14px}
section.faq .faq-item{background:var(--white);border:1px solid var(--border-soft);border-radius:var(--r-8);transition:all 0.25s ease;overflow:hidden}
section.faq .faq-item:hover{border-color:var(--border);background:var(--gray-50)}
section.faq .faq-item.open{border-color:var(--navy);background:var(--gray-50)}
section.faq .faq-q{display:flex !important;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;cursor:pointer;font-family:var(--font-h);font-size:15px;font-weight:500;color:var(--navy);background:none;border:none;width:100%;text-align:left;transition:color 0.2s;line-height:1.4;letter-spacing:-0.15px}
section.faq .faq-q:hover{color:var(--orange)}
section.faq .faq-q-text{flex:1}
section.faq .faq-mini-icon{width:28px;height:28px;border-radius:50%;background:var(--gray-100);color:var(--gray-500);flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;transition:all 0.3s ease}
section.faq .faq-mini-icon::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:1.5px;background:currentColor;border-radius:1px}
section.faq .faq-mini-icon::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:1.5px;height:10px;background:currentColor;border-radius:1px;transition:height 0.3s ease}
section.faq .faq-item:hover .faq-mini-icon{background:var(--white);color:var(--navy)}
section.faq .faq-item.open .faq-mini-icon{background:var(--navy);color:var(--white)}
section.faq .faq-item.open .faq-mini-icon::after{height:0}
section.faq .faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
section.faq .faq-item.open .faq-a{max-height:600px}
section.faq .faq-a-inner{padding:0 22px 20px 22px;font-size:14px;color:var(--gray-600);line-height:1.7}

/* --- GENERIC IN-PAGE H2 / H3 NORMALIZER ---------------- */
/* Force any section H2 on inner pages to match homepage size unless explicitly themed */
main h2:not([class]):not(.uni-cta-inner h2):not(.faq-head h2),
section > .container > h2:not([class]){font-family:var(--font-h);font-size:42px;font-weight:400;color:var(--gray-900);line-height:1.08;letter-spacing:-1.2px;text-align:center}

/* --- RESPONSIVE ---------------------------------------- */
@media(max-width:1024px){
  .sh-row-left h2,.sh-center h2,section.faq .faq-head h2{font-size:32px;letter-spacing:-0.8px}
  section.uni-cta .uni-cta-inner h2{font-size:36px;letter-spacing:-1px}
}
@media(max-width:768px){
  section.uni-cta .uni-cta-inner{padding:72px 24px}
  section.uni-cta .uni-cta-inner h2{font-size:34px;letter-spacing:-0.9px}
  section.faq .faq-grid-2col{grid-template-columns:1fr;gap:14px;max-width:680px}
  .sh-row-left h2,.sh-center h2,section.faq .faq-head h2{font-size:28px;letter-spacing:-0.6px}
}
@media(max-width:640px){
  section.uni-cta .uni-cta-inner{padding:64px 20px}
  section.uni-cta .uni-cta-bg{background-attachment:scroll}
  section.uni-cta .uni-cta-actions{flex-direction:column;width:100%}
  section.uni-cta .uni-cta-actions .btn-primary,section.uni-cta .uni-cta-actions .btn-secondary{width:100%;justify-content:center}
  .sh-row-left h2,.sh-center h2,section.faq .faq-head h2,section.uni-cta .uni-cta-inner h2{font-size:26px;letter-spacing:-0.5px}
}

/* ============================================================
   GLOBAL FULL-WIDTH CONTAINER OVERRIDE
   Every section is container-fluid; 36px L/R padding everywhere.
   Loaded last — uses !important to beat tokens.css, physio.css,
   responsive.css and any media-query overrides.
   ============================================================ */
.container{max-width:none !important;width:100% !important;margin:0 !important;padding-left:36px !important;padding-right:36px !important;box-sizing:border-box !important}
@media(max-width:1180px){.container{padding-left:36px !important;padding-right:36px !important}}
@media(max-width:1024px){.container{padding-left:36px !important;padding-right:36px !important}}
@media(max-width:768px){.container{padding-left:36px !important;padding-right:36px !important}}
@media(max-width:640px){.container{padding-left:36px !important;padding-right:36px !important}}

/* ============================================================
   "WHY CHOOSE VRX" — simplified, decluttered
   ============================================================ */
section.why{padding:96px 0 !important;background:var(--white) !important;overflow:hidden}
section.why::before,section.why::after{display:none !important;content:none !important}
section.why .container{position:relative;z-index:1}
section.why .why-grid{grid-template-columns:1fr 1fr;column-gap:64px;row-gap:56px;margin-top:56px}
section.why .why-block{border-top:1px solid var(--border-soft);padding-top:28px}
section.why .why-block:hover{transform:none}
section.why .why-block .num-big{font-size:64px;font-weight:300;color:rgba(17,14,69,0.18);letter-spacing:-2px;min-width:88px}
section.why .why-block:hover .num-big{color:var(--orange)}
section.why .why-block-text{padding-top:6px}
section.why .why-block-text h3{font-size:20px;letter-spacing:-0.4px;margin:0 0 10px}
section.why .why-block-text p{font-size:15px;line-height:1.65}
@media(max-width:1024px){section.why .why-grid{grid-template-columns:1fr;column-gap:0;row-gap:40px}}
