
/* ================================================================
   RESET & TOKENS
================================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#E8151B;
  --red-dark:#b50f14;
  --red-glow:rgba(232,21,27,.18);
  --black:#0A0A0A;
  --surface:#111111;
  --surface2:#181818;
  --border:#252525;
  --text:#F0EDE8;
  --muted:#888;
  --white:#FFFFFF;
  --font-display:'Bebas Neue',sans-serif;
  --font-head:'Barlow Condensed',sans-serif;
  --font-body:'Barlow',sans-serif;
  --radius:4px;
  --transition:0.28s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--black);
  color:var(--text);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.65;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
::selection{background:var(--red);color:#fff}

/* ================================================================
   SCROLLBAR
================================================================ */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:var(--red)}

/* ================================================================
   LOGO
================================================================ */
.nav-logo img {
  height: 45px;
  max-height: 60px;
  width: auto;
}

/* ================================================================
   NAV
================================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:0 clamp(1.5rem,5vw,4rem);
  height:68px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background var(--transition),border-color var(--transition);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,10,10,.95);
  backdrop-filter:blur(12px);
  border-color:var(--border);
}
.nav-logo{
  font-family:var(--font-display);
  font-size:1.7rem;
  letter-spacing:0.05em;
  color:var(--white);
  line-height:1;
}
.nav-logo span{color:var(--red)}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{
  font-family:var(--font-head);
  font-size:.9rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--white);
  transition:color var(--transition);
}
.nav-links a:hover{color:var(--white)}
.nav-cta{
  font-family:var(--font-head);
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:.55rem 1.4rem;
  background:var(--red);
  color:#fff;
  border:none;
  border-radius:var(--radius);
  cursor:pointer;
  transition:background var(--transition),transform var(--transition);
}
.nav-cta:hover{background:var(--red-dark);transform:translateY(-1px)}

/* Mobile burger */
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.burger span{display:block;width:24px;height:2px;background:var(--white);transition:var(--transition)}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-menu{
  display:none;
  position:fixed;top:68px;left:0;right:0;
  background:rgba(10,10,10,.98);
  border-top:1px solid var(--border);
  padding:2rem clamp(1.5rem,5vw,4rem);
  z-index:899;
  flex-direction:column;gap:1.5rem;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-family:var(--font-head);
  font-size:1rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--text);
  border-bottom:1px solid var(--border);
  padding-bottom:1.2rem;
}
.mobile-menu .nav-cta{width:100%;text-align:center;padding:.8rem}

/* ================================================================
   HERO
================================================================ */

.hero{
  background-image: url("image/bg.jpg") !important;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height:100vh;
  display:flex;align-items:flex-end;
  padding:0 clamp(1.5rem,5vw,4rem);
  padding-bottom:clamp(4rem,10vw,8rem);
  position:relative;
  overflow:hidden;
}

.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 60% at 75% 40%, rgba(232,21,27,.12) 0%, transparent 70%),
    linear-gradient(180deg, transparent 40%, rgba(10,10,10,.9) 100%);
  z-index:1;
  background-color: rgba(0,0,0,.5);
}

/* Geometric accent lines */
.hero-lines{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  overflow:hidden;
}
.hero-lines::before{
  content:'';
  position:absolute;
  top:-10%;right:10%;
  width:2px;height:140%;
  background:linear-gradient(180deg,transparent,var(--red),transparent);
  transform:rotate(-15deg);
  opacity:.25;
}
.hero-lines::after{
  content:'';
  position:absolute;
  top:-10%;right:22%;
  width:1px;height:140%;
  background:linear-gradient(180deg,transparent,var(--border),transparent);
  transform:rotate(-15deg);
  opacity:.5;
}

.hero-content{
  position:relative;z-index:3;
  max-width:820px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-head);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--red);
  margin-bottom:1.2rem;
}
.hero-h1{
  font-family:var(--font-display);
  font-size:clamp(5rem,13vw,11rem);
  line-height:.50;
  letter-spacing:-.01em;
  color:var(--white);
  text-transform:uppercase;
  margin-bottom:.3rem;
}
.hero-h1 em{
  font-style:italic;
  color:var(--red);
  font-family:var(--font-head);
  font-style:italic;
  font-size:clamp(3rem,7vw,6rem);
  font-weight:900;
  display:block;
  line-height:1;
  letter-spacing:0;
}
.hero-actions{
  display:flex;align-items:center;gap:1.5rem;
  margin-top:2.5rem;
  flex-wrap:wrap;
}
.btn-primary{
  font-family:var(--font-head);
  font-size:.9rem;
  font-weight:800;
  letter-spacing:.15em;
  text-transform:uppercase;
  padding:.85rem 2.2rem;
  background:var(--red);
  color:#fff;
  border:none;
  border-radius:var(--radius);
  cursor:pointer;
  display:inline-flex;align-items:center;gap:.6rem;
  transition:background var(--transition),transform var(--transition),box-shadow var(--transition);
}
.btn-primary:hover{
  background:var(--red-dark);
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(232,21,27,.35);
}
.btn-ghost{
  font-family:var(--font-head);
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:.5rem;
  transition:color var(--transition);
}
.btn-ghost:hover{color:var(--white)}
.btn-ghost svg{transition:transform var(--transition)}
.btn-ghost:hover svg{transform:translateX(3px)}
.hero-scroll{
  position:absolute;
  bottom:2rem;left:50%;transform:translateX(-50%);
  z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  font-family:var(--font-head);
  font-size:.65rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
}
.hero-scroll-line{
  width:1px;height:3rem;
  background:linear-gradient(180deg,var(--red),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ================================================================
   SECTION COMMONS
================================================================ */
.section {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(4rem, 8vw, 8rem) clamp(1.25rem, 4vw, 3rem);
}
.section-label{
  font-family:var(--font-head);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--red);
  display:flex;align-items:center;gap:.6rem;
  margin-bottom:1rem;
}
.section-label::before{content:'';display:block;width:1.5rem;height:2px;background:var(--red)}
.section-h2{
  font-family:var(--font-display);
  font-size:clamp(3rem,7vw,6rem);
  line-height:.95;
  letter-spacing:.0.1em;
  word-spacing: -0.1em;
  text-transform:uppercase;
  color:var(--white);
}
.section-h2 span{color:var(--red)}
.section-h2-sm{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,5vw,4rem);
  line-height:1;
  text-transform:uppercase;
  color:var(--white);
}
.section-h2-sm span{color:var(--red)}

/* ================================================================
   TICKER STRIP
================================================================ */
.ticker-vertical {
  position: fixed;
  left: 0;
  top: 0;
  height: 100vh;
  width: 36px;
  background: var(--red);
  overflow: hidden;
  z-index: 800;
}

.ticker-vertical-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .6rem;
  padding: .6rem 0;
  animation: tickerUp 18s linear infinite;
}

.ticker-vertical-inner img {
  width: 60px;
  height: 60px;
  object-fit: contain;
  filter: brightness(0) invert(1);
  flex-shrink: 0;
  transform: rotate(270deg);
}

@keyframes tickerUp {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

@media(max-width:768px) {
  .ticker-vertical { display: none; }
}

/* ================================================================
   PAIN POINTS (WHY)
================================================================ */
.why-section{background:var(--surface)}
.why-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  margin-top:1rem;
  border:1px solid var(--border);
}
.why-item{
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:0;
  cursor:pointer;
  transition:background var(--transition);
}
.why-item:nth-child(2n){border-right:none}
.why-item:nth-last-child(-n+2){border-bottom:none}
.why-item:hover{background:var(--surface2)}
.why-item-header{
  display:flex;align-items:flex-start;gap:1rem;
  padding:2rem;
}
.why-num{
  font-family:var(--font-display);
  font-size:3.5rem;
  line-height:1;
  color:var(--border);
  flex-shrink:0;
  transition:color var(--transition);
}
.why-item.open .why-num,.why-item:hover .why-num{color:var(--red)}
.why-body-wrap{flex:1}
.why-title{
  font-family:var(--font-head);
  font-size:1.1rem;
  font-weight:700;
  color:var(--text);
  line-height:1.3;
  margin-bottom:.3rem;
}
.why-arrow{
  font-size:1.3rem;
  color:var(--muted);
  flex-shrink:0;
  margin-top:.15rem;
  transition:transform var(--transition),color var(--transition);
  line-height:1;
}
.why-item.open .why-arrow{transform:rotate(45deg);color:var(--red)}
.why-dropdown{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1);
  padding:0 2rem 0 calc(2rem + 3rem + 1rem);
}
.why-item.open .why-dropdown{max-height:200px}
.why-dropdown p{
  font-size:.9rem;
  color:rgba(240,237,232,.6);
  line-height:1.7;
  padding-bottom:2rem;
}

/* ================================================================
   WHAT YOU GET (CARDS)
================================================================ */
.what-section{background:var(--black)}
.cards-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1px;
  background:var(--border);
  margin-top:1rem;
  border:1px solid var(--border);
}
.card{
  background:var(--surface);
  padding:2.5rem;
  position:relative;
  overflow:hidden;
  transition:background var(--transition);
}
.card:hover{background:var(--surface2)}
.card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--red),transparent);
  opacity:0;
  transition:opacity var(--transition);
}
.card:hover::before{opacity:1}
.card-number{
  font-family:var(--font-display);
  font-size:5rem;
  line-height:1;
  color:var(--border);
  position:absolute;top:1.5rem;right:2rem;
  transition:color var(--transition);
}
.card:hover .card-number{color:rgba(232,21,27,.12)}
.card-title{
  font-family:var(--font-head);
  font-size:1.4rem;
  font-weight:700;
  color:var(--white);
  text-transform:uppercase;
  letter-spacing:.05em;
  margin-bottom:1rem;
  position:relative;z-index:1;
}
.card-divider{
  width:2.5rem;height:2px;
  background:var(--red);
  margin-bottom:1.2rem;
}
.card-body{
  font-size:.92rem;
  color:rgba(240,237,232,.6);
  line-height:1.75;
  position:relative;z-index:1;
}
.tag-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.tag{
  font-family:var(--font-head);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:.3rem .8rem;
  border:1px solid var(--border);
  color:var(--muted);
  border-radius:2px;
  transition:border-color var(--transition),color var(--transition);
}
.card:hover .tag{border-color:var(--red);color:var(--text)}
.what-cta-strip{
  background:var(--red);
  padding:3rem clamp(1.5rem,5vw,4rem);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1.5rem;
}
.what-cta-strip p{
  font-family:var(--font-head);
  font-size:clamp(1rem,2.5vw,1.3rem);
  font-weight:600;
  color:#fff;
  max-width:560px;
}
.btn-white{
  font-family:var(--font-head);
  font-size:.85rem;
  font-weight:800;
  letter-spacing:.15em;
  text-transform:uppercase;
  padding:.85rem 2rem;
  background:#fff;
  color:var(--red);
  border:none;
  border-radius:var(--radius);
  cursor:pointer;
  white-space:nowrap;
  transition:background var(--transition),transform var(--transition);
  display:inline-block;
}
.btn-white:hover{background:var(--black);color:#fff;transform:translateY(-2px)}

/* ================================================================
   PRICING
================================================================ */
.pricing-section{background:var(--surface)}
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--border);
  margin-top:1rem;
  border:1px solid var(--border);
}
.pricing-card{
  background:var(--surface);
  padding:2.5rem 2rem;
  position:relative;
  transition:background var(--transition);
}

.pricing-tier{
  font-family:var(--font-head);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(240,237,232,.5);
  margin-bottom:.5rem;
}
.pricing-name {
  font-family:var(--font-display);
  font-size:1.8rem;
  text-transform:uppercase;
  color:var(--white);
  line-height:1;
  margin-bottom:.8rem;
}
.pricing-amount{
  display:flex;align-items:baseline;gap:.3rem;
  margin-bottom:2rem;
  padding-bottom:2rem;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.pricing-currency{
  font-family:var(--font-head);
  font-size:1.1rem;
  font-weight:700;
  color:var(--white);
}
.pricing-price{
  font-family:var(--font-display);
  font-size:4rem;
  color:var(--white);
  line-height:1;
}
.pricing-card.featured .pricing-per{color:rgba(255,255,255,.7)}
.pricing-features{display:flex;flex-direction:column;gap:.8rem;margin-bottom:2.5rem}
.pricing-features li{
  font-size:.9rem;
  color:rgba(240,237,232,.7);
  display:flex;align-items:flex-start;gap:.7rem;
  line-height:1.4;
}
.pricing-card.featured .pricing-features li{color:rgba(255,255,255,.9)}
.pricing-features li::before{
  content:'✓';
  color:var(--red);
  font-weight:700;
  flex-shrink:0;
  margin-top:.05rem;
}
.pricing-card.featured .pricing-features li::before{color:#fff}
.pricing-btn{
  width:100%;
  font-family:var(--font-head);
  font-size:.85rem;
  font-weight:800;
  letter-spacing:.15em;
  text-transform:uppercase;
  padding:.85rem;
  border:2px solid var(--border);
  background:transparent;
  color:var(--text);
  border-radius:var(--radius);
  cursor:pointer;
  transition:all var(--transition);
  display:block;
  text-align:center;
}
.pricing-btn:hover{border-color:var(--red);color:var(--white);background:rgba(232,21,27,.1)}
.pricing-card.featured .pricing-btn{
  border-color:#fff;
  background:#fff;
  color:var(--red);
}
.pricing-card.featured .pricing-btn:hover{background:var(--black);color:#fff;border-color:var(--black)}

/* ================================================================
   ABOUT PAGE OVERRIDES
================================================================ */

.about-img-stack { display: none; }

.about-section {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 68px 2rem 2rem 5rem;
  position: relative;
  overflow: hidden;
}

.about-section::before {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 100%;
  height: 100%;
  background: url('image/hero.png') center right / cover no-repeat;
  z-index: 0;
}

.about-section::after {
  display: none;
}

.about-inner {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
}

.about-text-col {
  position: relative;
  z-index: 2;
  max-width: 500px;
  width: 100%;
  background: linear-gradient(135deg, rgba(10,10,10,.85) 0%, rgba(10,10,10,.6) 100%);
  padding: 2.5rem;
  backdrop-filter: blur(4px);
  border-left: 2px solid var(--red);
}

/* Stats boxes */
.about-stats {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin: 2rem 0;
}
.about-stat {
  background: var(--surface);
  padding: 1.2rem;
  text-align: center;
}
.about-stat .num {
  font-family: var(--font-display);
  font-size: 2.2rem;
  color: var(--red);
  display: block;
  line-height: 1;
}
.about-stat .lbl {
  font-family: var(--font-head);
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Specialty tags */
.about-spec-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1.5rem;
}
.about-spec-tag {
  font-family: var(--font-head);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .35rem .85rem;
  border: 1px solid var(--red);
  color: var(--red);
  border-radius: 2px;
}

/* ── RESPONSIVE ── */
@media(max-width:768px) {
  .about-section {
    padding: 68px 1.5rem 3rem 1.5rem;
    align-items: flex-start;
  }

  .about-section::before {
    width: 100%;
    height: 100%;
    background: url('image/hero.png') top center / cover no-repeat;
    opacity: .25;
  }

  .about-section::after {
    content: '';
    display: block;
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(10,10,10,.6) 0%, rgba(10,10,10,.95) 50%);
    z-index: 1;
  }

  .about-text-col {
    max-width: 100%;
    background: transparent;
    backdrop-filter: none;
    border-left: none;
    padding: 0;
  }
}

/* ================================================================
   CONTACT / FORM
================================================================ */
.contact-section{background:var(--black)}
.social-strip{display:flex;gap:.8rem;margin-top:2rem}
.social-btn{
  width:2.4rem;height:2.4rem;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--transition);
}
.social-btn:hover{background:var(--red);border-color:var(--red)}
.social-btn svg{width:14px;height:14px;color:var(--muted);transition:color var(--transition)}
.social-btn:hover svg{color:#fff}

/* Multi-step form */
.mf-box{
  background:var(--surface2);
  border:1px solid var(--border);
  padding:2.5rem;
  margin-top:1rem;
}
.mf-steps{
  display:flex;align-items:center;
  margin-bottom:2.5rem;
  gap:0;
}
.mf-step{
  display:flex;align-items:center;gap:.6rem;
}
.mf-step-circle{
  width:2rem;height:2rem;
  border-radius:50%;
  border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);
  font-size:.75rem;
  font-weight:700;
  color:var(--muted);
  transition:all var(--transition);
}
.mf-step.active .mf-step-circle{border-color:var(--red);background:var(--red);color:#fff}
.mf-step.done .mf-step-circle{border-color:var(--red);background:transparent;color:var(--red)}
.mf-step-label{
  font-family:var(--font-head);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
  transition:color var(--transition);
}
.mf-step.active .mf-step-label{color:var(--text)}
.mf-step-line{flex:1;height:1px;background:var(--border);margin:0 .6rem;transition:background var(--transition)}
.mf-step-line.active{background:var(--red)}
.mf-page{display:none}
.mf-page.active{display:block}
.mf-page-title{
  font-family:var(--font-head);
  font-size:1.2rem;
  font-weight:700;
  color:var(--white);
  text-transform:uppercase;
  letter-spacing:.05em;
  margin-bottom:1.5rem;
}
.mf-label{
  font-family:var(--font-head);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
  display:block;
  margin-bottom:.5rem;
}
.mf-req{color:var(--red)}
.mf-field{margin-bottom:1.2rem}
.mf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.mf-hint{
  font-size:.8rem;
  color:var(--muted);
  margin-bottom:.5rem;
}
input,select,textarea{
  width:100%;
  padding:.75rem 1rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text);
  font-family:var(--font-body);
  font-size:.9rem;
  outline:none;
  transition:border-color var(--transition);
  appearance:none;
}
input:focus,select:focus,textarea:focus{border-color:var(--red)}
select option{background:var(--surface);color:var(--text)}
textarea{resize:vertical;min-height:90px}
.mf-err{display:block;font-size:.75rem;color:var(--red);margin-top:.3rem}
.mf-gender-row{display:flex;gap:.6rem}
.mf-radio-card{
  flex:1;
  padding:.7rem;
  border:1px solid var(--border);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  font-family:var(--font-head);
  font-size:.85rem;
  font-weight:700;
  color:var(--muted);
  transition:all var(--transition);
  gap:.4rem;
}
.mf-radio-card input{display:none}
.mf-radio-card:has(input:checked){
  border-color:var(--red);
  background:rgba(232,21,27,.1);
  color:var(--text);
}
.mf-goals-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.5rem;
  margin-bottom:1rem;
}
.mf-goal-tile{
  border:1px solid var(--border);
  border-radius:var(--radius);
  cursor:pointer;
  transition:all var(--transition);
  overflow:hidden;
}
.mf-goal-tile input{display:none}
.mf-goal-inner{
  display:flex;align-items:center;gap:.7rem;
  padding:.8rem 1rem;
}
.mf-goal-tile:has(input:checked){
  border-color:var(--red);
  background:rgba(232,21,27,.08);
}
.mf-goal-icon{font-size:1.1rem}
.mf-goal-text{
  font-family:var(--font-head);
  font-size:.82rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--muted);
  transition:color var(--transition);
}
.mf-goal-tile:has(input:checked) .mf-goal-text{color:var(--text)}
.mf-nav{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;gap:.8rem}
.mf-btn-back,.mf-btn-next,.mf-btn-submit{
  font-family:var(--font-head);
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:.75rem 1.8rem;
  border-radius:var(--radius);
  cursor:pointer;
  transition:all var(--transition);
  border:none;
}
.mf-btn-back{background:var(--surface);color:var(--muted);border:1px solid var(--border)}
.mf-btn-back:hover{color:var(--text);border-color:var(--text)}
.mf-btn-next,.mf-btn-submit{background:var(--red);color:#fff}
.mf-btn-next:hover,.mf-btn-submit:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(232,21,27,.3)}
.mf-success-wrap{
  text-align:center;
  padding:3rem 2rem;
}
.mf-success-icon{
  width:4rem;height:4rem;
  border-radius:50%;
  background:var(--red);
  display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;color:#fff;
  margin:0 auto 1.5rem;
}
.mf-success-title{
  font-family:var(--font-display);
  font-size:2.5rem;
  color:var(--white);
  margin-bottom:.8rem;
}
.mf-success-msg{font-size:.95rem;color:var(--muted);line-height:1.7}

/* ================================================================
   FOOTER
================================================================ */
.footer{
  background:var(--black);
  border-top:1px solid var(--border);
  padding:4rem clamp(1.5rem,5vw,4rem) 2rem;
}
.footer-inner{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:5rem;
  padding-bottom:3rem;
  border-bottom:1px solid var(--border);
  margin-bottom:2rem;
}
.footer-logo{
  font-family:var(--font-display);
  font-size:2.5rem;
  color:var(--white);
  letter-spacing:.05em;
  margin-bottom:.5rem;
}
.footer-logo span{color:var(--red)}
.footer-tagline{
  font-family:var(--font-head);
  font-size:1rem;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.1em;
  line-height:1.6;
  margin-bottom:1.5rem;
}
.footer-right-heading{
  font-family:var(--font-head);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--red);
  margin-bottom:1.2rem;
}
.footer-contact-list{display:flex;flex-direction:column;gap:.8rem}
.footer-contact-row{
  display:flex;align-items:center;gap:.8rem;
  font-size:.88rem;
  color:var(--muted);
}
.footer-contact-row a{color:var(--muted);transition:color var(--transition)}
.footer-contact-row a:hover{color:var(--red)}
.footer-contact-row .fc-icon{
  width:1.6rem;height:1.6rem;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  border-radius:2px;
}
.footer-contact-row .fc-icon svg{width:10px;height:10px;color:var(--red)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;
}
.footer-copy{
  font-size:.8rem;
  color:rgba(136,136,136,.6);
}

/* ================================================================
   BACK TO TOP
================================================================ */
#back-top{
  position:fixed;
  bottom:2rem;right:2rem;
  z-index:500;
  opacity:0;pointer-events:none;
  transition:opacity var(--transition),transform var(--transition);
}
#back-top.visible{opacity:1;pointer-events:auto}
#back-top a{
  width:2.8rem;height:2.8rem;
  background:var(--red);
  border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  transition:background var(--transition),transform var(--transition);
}
#back-top a:hover{background:var(--red-dark);transform:translateY(-3px)}
#back-top svg{width:16px;height:16px}

/* ================================================================
   REVEAL ANIMATIONS
================================================================ */
.reveal{
  opacity:0;
  transform:translateY(32px);
  transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1);
}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ================================================================
   RESPONSIVE
================================================================ */
@media(max-width:1024px){
  .hero-counter-strip{display:none}
  .about-inner{grid-template-columns:1fr;gap:3rem}
  .about-exp-float{right:1rem;top:1rem}
  .contact-inner{grid-template-columns:1fr;gap:3rem}
  .pricing-grid{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links,.nav-cta.desktop{display:none}
  .burger{display:flex}
  .why-grid{grid-template-columns:1fr}
  .why-item:nth-child(2n){border-right:1px solid var(--border)}
  .why-item:nth-last-child(-n+2){border-bottom:1px solid var(--border)}
  .why-item:last-child{border-bottom:none}
  .mf-row{grid-template-columns:1fr}
  .mf-goals-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:3rem}
  .about-exp-float{display:none}
}
@media(max-width:480px){
  .hero-h1{font-size:4rem}
  .section-h2{font-size:2.5rem}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .what-cta-strip{flex-direction:column;align-items:flex-start}
}
