html,
body{
  overflow-x:hidden;
}

/* ── NAV / HEADER ─────────────────────────── */

nav{
  position:fixed;
  width:100%;
  top:48px;
  z-index:40;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
  box-shadow:0 2px 8px rgba(0,0,0,.04);
}

.nav-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  padding:14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:800;
  color:var(--primary);
  min-width:0;
}

.brand-logo{
  width:84px;
  height:84px;
  display:grid;
  place-items:center;
  padding:8px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(38,38,38,.08);
  box-shadow:var(--shadow);
}

.brand-badge{
  width:54px;
  height:54px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--soft),#fff);
  border:1px solid var(--line);
  display:grid;
  place-items:center;
  font-weight:900;
  box-shadow:var(--shadow);
}

.brand small{
  display:block;
  color:var(--muted);
  font-size:.78rem;
  font-weight:700;
}

.nav-links{
  list-style:none;
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  padding:0;
  margin:0;
  font-weight:700;
}

.nav-links a:hover{
  color:var(--primary);
}

/* ── SOCIAL ICONS (NAV) ───────────────────── */

.nav-socials{
  display:flex;
  align-items:center;
  gap:6px;
  margin-left:12px;
}

.nav-socials a{
  width:34px;
  height:34px;
  border-radius:50%;
  display:grid;
  place-items:center;
  border:1.5px solid var(--line);
  color:var(--muted);
  transition:.2s;
  flex-shrink:0;
}

.nav-socials a:hover{
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
}

.nav-socials svg{
  width:16px;
  height:16px;
  fill:currentColor;
  display:block;
}

/* ── SOCIAL ICONS (FOOTER) ────────────────── */

.footer-socials{
  display:flex;
  justify-content:center;
  gap:14px;
  margin-top:28px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.18);
}

.footer-socials a{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:7px;
  color:rgba(255,255,255,.7);
  transition:.2s;
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.footer-socials a:hover{
  color:#fff;
}

.footer-socials .soc-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  display:grid;
  place-items:center;
  transition:.2s;
}

.footer-socials a:hover .soc-icon{
  background:rgba(255,255,255,.22);
  border-color:rgba(255,255,255,.3);
}

.footer-socials svg{
  width:20px;
  height:20px;
  fill:#fff;
  display:block;
}

/* ── MISSION CAROUSEL ─────────────────────── */

.mission{
  position:relative;
  overflow: visible;
  border-bottom:1px solid var(--line);
}

.mc-track{
  display:flex;
  transition:transform .55s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}

.mc-slide{
  min-width:100%;
  width:100%;
  flex-shrink:0;
  position:relative;
  overflow:hidden;
}

.mc-slide--bg{
  position:relative;
  min-height:500px;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  background:url('/assets/images/monroe.jpeg') center 50% / cover no-repeat;
  background-color:#1a2612;
}

.mc-slide--bg::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(
    to bottom,
    rgba(20,35,12,.10) 0%,
    rgba(20,35,12,.20) 50%,
    rgba(20,35,12,.80) 100%
  );
  z-index:1;
}

.mc-slide--bg .mc-content{
  position:relative;
  z-index:2;
  color:#fff;
  padding:40px 48px;
  text-align:left;
  max-width:760px;
}

.mc-slide--bg h2{
  font-size:clamp(1.8rem,4vw,3rem);
  font-weight:800;
  line-height:1.1;
  margin:0 0 12px;
}

.mc-slide--bg p{
  font-size:1.05rem;
  opacity:.88;
  max-width:580px;
  margin:0 auto;
}

.mc-slide--text{
  padding:72px 0 80px;
  background:#fff;
}

.mc-slide--text.tint{
  background:var(--soft);
}

.mc-slide--text .mc-content{
  width:min(calc(100% - 48px),820px);
  margin:0 auto;
}

.mc-tag{
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#ebc60e;
  margin:0 0 14px;
}

.mc-h{
  font-size:clamp(1.7rem,3.5vw,2.5rem);
  font-weight:800;
  line-height:1.12;
  color:#fff;
  margin:0 0 6px;
}

.mc-sub{
  font-size:1rem;
  font-weight:600;
  color:#ebc60e;
  margin:0 0 20px;
}

.mc-bar{
  width:48px;
  height:3px;
  background:var(--accent);
  border-radius:2px;
  margin:0 0 24px;
}

.mc-body{
  font-size:1.05rem;
  color:#fff;
  line-height:1.8;
  margin:0;
  max-width:720px;
}

.mc-body em{
  font-style:normal;
  font-weight:700;
  color:#06f726;
}

.mc-body-mobile,
.mc-h-mobile,
.mc-sub-mobile{
  display:none;
}

.mc-body-desktop,
.mc-h-desktop,
.mc-sub-desktop{
  display:block;
}

/* arrows */
.mc-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:20;
  width:42px;
  height:42px;
  border-radius:50%;
  background:rgba(255,255,255,.93);
  border:1px solid var(--line);
  box-shadow:0 2px 10px rgba(0,0,0,.13);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:1rem;
  color:var(--primary);
  font-weight:900;
  transition:.2s;
}

.mc-arrow:hover{
  box-shadow:0 4px 18px rgba(0,0,0,.2);
}

.mc-arrow--prev{
  left:16px;
}

.mc-arrow--next{
  right:16px;
}

/* dots */
.mc-dots{
  position:absolute;
  bottom:16px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:20;
}

.mc-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  padding:0;
  background:rgba(83,103,58,.22);
  border:none;
  cursor:pointer;
  transition:.25s;
}

.mc-dot.on{
  background:var(--primary);
  transform:scale(1.3);
}

/* ── OPTIONAL HERO (UNUSED) ───────────────── */

.hero{
  background:
    linear-gradient(rgba(83,103,58,.78),rgba(83,103,58,.78)),
    url('/assets/images/monroe.jpeg') center/cover no-repeat;
  color:#fff;
  text-align:center;
  padding:88px 0 96px;
}

.hero h1{
  font-size:clamp(2.4rem,6vw,4.2rem);
  line-height:1.02;
  margin:0 0 12px;
}

.hero p{
  margin:0 auto;
  max-width:820px;
  font-size:1.06rem;
  opacity:.96;
}

.hero-actions{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:24px;
}

/* ── QUICK ACTIONS ────────────────────────── */

.chrome-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:18px;
}

.chrome-card{
  position:relative;
  overflow:hidden;
  min-height:180px;
  border-radius:28px;
  padding:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(247,248,242,.78));
  border:1px solid rgba(255,255,255,.7);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 18px 40px rgba(35,35,35,.10);
  backdrop-filter:blur(10px);
}

.chrome-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at top right, rgba(223,43,34,.14), transparent 28%),
    radial-gradient(circle at bottom left, rgba(83,103,58,.12), transparent 32%);
  pointer-events:none;
}

.chrome-card > *{
  position:relative;
  z-index:1;
}

.span-4{
  grid-column:span 4;
}

.span-8{
  grid-column:span 8;
}

.chrome-card h3{
  margin:0 0 8px;
  color:var(--primary);
}

.chrome-card p{
  margin:0;
  color:var(--muted);
}

.metric{
  display:flex;
  align-items:flex-end;
  gap:10px;
  margin-top:14px;
}

.metric strong{
  font-size:2rem;
  line-height:1;
  color:var(--text);
}

.mini-pill{
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  font-size:.85rem;
  font-weight:700;
  margin-top:14px;
}

/* ── TEAM ─────────────────────────────────── */

.team-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
}

.team-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  overflow:hidden;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
}

.team-body{
  padding:24px 26px 26px;
  display:flex;
  flex-direction:column;
  flex:1;
}

.team-header{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:18px;
}

.team-photo{
  width:72px;
  height:72px;
  flex-shrink:0;
  border-radius:14px;
  overflow:hidden;
  background:linear-gradient(135deg,var(--soft-2),var(--soft));
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
}

.team-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
}

.team-photo-placeholder{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
  width:100%;
  height:100%;
}

.team-photo-placeholder .initials{
  width:42px;
  height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;
  font-size:1rem;
  font-weight:900;
  display:grid;
  place-items:center;
}

.team-photo-placeholder .ph-label{
  font-size:.5rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--muted);
  opacity:.6;
  text-align:center;
  line-height:1.2;
}

.team-meta{
  flex:1;
  min-width:0;
}

.team-card h3{
  margin:0 0 3px;
  color:var(--primary);
  font-size:1.05rem;
  line-height:1.25;
}

.team-card .role{
  color:var(--muted);
  font-weight:700;
  font-size:.83rem;
}

.team-desc{
  font-size:.91rem;
  color:var(--text);
  line-height:1.7;
  margin:0 0 16px;
}

.team-quote{
  border-left:3px solid var(--accent);
  padding:10px 14px;
  background:var(--soft);
  border-radius:0 10px 10px 0;
  margin:0 0 16px;
}

.team-quote-label{
  font-size:.62rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:5px;
}

.team-quote p{
  font-size:.87rem;
  font-style:italic;
  color:var(--text);
  margin:0;
  line-height:1.55;
}

.bits{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:auto;
  padding-top:4px;
}

.bit{
  padding:5px 11px;
  border-radius:999px;
  background:var(--soft);
  border:1px solid var(--line);
  font-size:.76rem;
  font-weight:800;
  color:var(--primary);
}

/* ── SERVICES WHEEL ───────────────────────── */

.circle-wrap{
  display:grid;
  place-items:center;
  padding:20px 0 10px;
}

.service-wheel{
  position:relative;
  width:min(760px,88vw);
  aspect-ratio:1 / 1;
}

.wheel-center{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:220px;
  height:220px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--primary),#738958);
  color:#fff;
  display:grid;
  place-items:center;
  text-align:center;
  padding:24px;
  box-shadow:0 20px 40px rgba(83,103,58,.24);
  z-index:3;
}

.wheel-center strong{
  display:block;
  font-size:1.4rem;
  line-height:1.1;
  margin-bottom:8px;
}

.service-node{
  position:absolute;
  width:170px;
  min-height:108px;
  transform:translate(-50%,-50%);
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:16px;
  box-shadow:var(--shadow);
  text-align:center;
}

.service-node .icon{
  font-size:1.5rem;
  margin-bottom:6px;
}

.service-node h4{
  margin:0 0 6px;
  color:var(--primary);
  font-size:1rem;
}

.service-node p{
  margin:0;
  color:var(--muted);
  font-size:.88rem;
  line-height:1.4;
}

.service-ring{
  position:absolute;
  inset:12%;
  border:2px dashed rgba(83,103,58,.18);
  border-radius:50%;
}

/* ── SUPPLEMENTS DOME ─────────────────────── */

.dome-shell{
  margin-top:8px;
  position:relative;
  padding-top:40px;
}

.dome{
  position:relative;
  height:420px;
  overflow:hidden;
  background:linear-gradient(180deg,#fff,var(--soft));
  border:1px solid var(--line);
  border-radius:32px;
  box-shadow:var(--shadow);
}

.dome-arc{
  position:absolute;
  left:50%;
  bottom:-290px;
  transform:translateX(-50%);
  width:980px;
  height:980px;
  border-radius:50%;
  border:2px dashed rgba(83,103,58,.14);
}

.supplement{
  position:absolute;
  width:170px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:16px;
  box-shadow:var(--shadow);
  text-align:center;
}

.supplement .thumb{
  width:66px;
  height:66px;
  border-radius:18px;
  margin:0 auto 10px;
  display:grid;
  place-items:center;
  font-size:1.6rem;
  background:linear-gradient(135deg,var(--soft-2),#fff);
  border:1px solid var(--line);
}

.supplement h4{
  margin:0 0 6px;
  color:var(--primary);
  font-size:1rem;
}

.supplement p{
  margin:0;
  color:var(--muted);
  font-size:.86rem;
  line-height:1.35;
}

/* ── CAREERS ──────────────────────────────── */

#careers{
  padding:72px 0;
}

.careers-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:start;
}

.careers-left h2{
  font-size:clamp(1.8rem,3.5vw,2.6rem);
  font-weight:800;
  color:var(--primary);
  line-height:1.15;
  margin:0 0 14px;
}

.careers-left p{
  color:var(--muted);
  font-size:.97rem;
  line-height:1.75;
  margin:0 0 20px;
}

.careers-perks{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:4px;
}

.careers-perk{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:.9rem;
  font-weight:600;
  color:var(--text);
}

.careers-perk-dot{
  width:32px;
  height:32px;
  border-radius:50%;
  flex-shrink:0;
  background:var(--soft-2);
  display:grid;
  place-items:center;
  font-size:1rem;
}

.careers-card{
  background:var(--soft);
  border:1px solid var(--line);
  border-radius:24px;
  padding:36px 32px;
  box-shadow:var(--shadow);
}

.careers-card h3{
  font-size:1.2rem;
  font-weight:800;
  color:var(--primary);
  margin:0 0 8px;
}

.careers-card p{
  font-size:.9rem;
  color:var(--muted);
  line-height:1.7;
  margin:0 0 24px;
}

.careers-email-block{
  background:#fff;
  border:1.5px dashed var(--line);
  border-radius:14px;
  padding:18px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.careers-email-label{
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:4px;
}

.careers-email-addr{
  font-size:.97rem;
  font-weight:700;
  color:var(--primary);
  word-break:break-all;
}

.careers-email-block a.btn{
  flex-shrink:0;
  font-size:.82rem;
  padding:10px 18px;
}

.careers-note{
  margin-top:16px;
  font-size:.8rem;
  color:var(--muted);
  line-height:1.6;
}

.mc-frame{
  position:relative;
  overflow:hidden;
}
/* ── MISSION COUNTDOWN ─────────────────────── */

.mission-countdown{
  position:relative;
  z-index:5;
  width:min(calc(100% - 32px), 960px);
  margin:28px auto 0;
}

.mission-countdown-card{
  background:rgba(16, 28, 12, 0.82);
  border:1px solid rgba(255,255,255,.12);
  border-radius:24px;
  padding:28px 24px;
  text-align:center;
  color:#fff;
  box-shadow:0 24px 60px rgba(0,0,0,.28);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.mission-countdown-badge{
  display:inline-block;
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.16);
  padding:5px 14px;
  border-radius:999px;
  margin-bottom:16px;
}

.mission-countdown-title{
  font-size:clamp(1.25rem, 2.5vw, 1.9rem);
  font-weight:800;
  line-height:1.3;
  margin-bottom:10px;
}

.mission-countdown-title span{
  color:#ebc60e;
}

.mission-countdown-sub{
  margin:0 auto 22px;
  max-width:700px;
  color:rgba(255,255,255,.8);
  font-size:.95rem;
}

.mission-countdown-tiles{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:18px;
}

.mission-countdown-tile{
  width:92px;
  padding:16px 8px 12px;
  border-radius:16px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}

.mission-countdown-tile .n{
  display:block;
  font-size:2.1rem;
  line-height:1;
  font-weight:900;
  color:#fff;
  font-variant-numeric:tabular-nums;
}

.mission-countdown-tile .l{
  display:block;
  margin-top:6px;
  font-size:.64rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
}

.mission-countdown-progress{
  height:4px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  overflow:hidden;
}

.mission-countdown-bar{
  height:100%;
  width:0%;
  border-radius:999px;
  background:linear-gradient(90deg,#53673a,#8bbd66);
  transition:width 1s linear;
}

.mission-countdown-go{
  display:none;
  margin-top:16px;
  font-size:1.1rem;
  font-weight:800;
  color:#fff;
}

.mission-countdown-go.show{
  display:block;
}
/* ── FOOTER ───────────────────────────────── */

footer{
  background:var(--primary);
  color:#fff;
  text-align:center;
  padding:42px 5%;
  margin-top:18px;
}

.contact-grid{
  display:flex;
  justify-content:center;
  gap:44px;
  flex-wrap:wrap;
  text-align:left;
  margin-bottom:16px;
}

.contact-grid h4{
  margin:0 0 8px;
}

.contact-grid p{
  margin:6px 0;
  opacity:.95;
}

.tm-option.featured {
  border: 2px solid #53673a;
  background: #f6f9f2;
}
.transfer-all-box {
  margin: 25px 0 10px;
}

.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
  margin-top: 5px; /* aligns with text nicely */
  width: 18px;
  height: 18px;
}

.checkbox-label span {
  display: flex;
  flex-direction: column;
}

.checkbox-label strong {
  color: #9b2c2c; /* your red tone */
  font-size: 1.05rem;
}

.checkbox-label small {
  margin-top: 4px;
  color: #5f6b5c;
  font-size: 0.85rem;
}
