/* ControlHF — shared stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root{
  --teal:#0A4D5C;
  --teal-deep:#083D49;
  --teal-soft:#E6F4F7;
  --coral:#CC1515;
  --coral-deep:#A81010;
  --cream:#FAF7F2;
  --cream-2:#F2EDE4;
  --ink:#1C3A42;
  --ink-soft:#4A6B73;
  --line:rgba(10,77,92,.12);
  --serif:'Inter', system-ui, sans-serif;
  --sans:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(250,247,242,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1320px;margin:0 auto;
  padding:16px 36px;
  display:flex;align-items:center;justify-content:space-between;
  gap:32px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  flex-shrink:0;
}
.brand-logo{
  height:42px !important;
  max-height:42px !important;
  width:auto !important;
  max-width:200px !important;
  display:block;
  object-fit:contain;
}
.brand-mark{
  width:32px;height:32px;
  background:var(--teal);
  border-radius:50%;
  display:grid;place-items:center;
  position:relative;
}
.brand-mark::after{
  content:'';
  position:absolute;inset:0;
  border-radius:50%;
  border:2px solid var(--coral);
  animation:pulse 2.2s ease-out infinite;
}
@keyframes pulse{
  0%{transform:scale(1);opacity:.8}
  70%{transform:scale(1.55);opacity:0}
  100%{opacity:0}
}
.brand-mark svg{width:16px;height:16px;color:var(--cream)}
.brand b{color:var(--coral)}

.tabs{
  display:flex;gap:4px;
  background:var(--teal-soft);
  padding:5px;border-radius:999px;
  flex-shrink:1;
  min-width:0;
}
.tabs a{
  padding:9px 18px;
  font-size:13.5px;font-weight:600;
  border-radius:999px;
  color:var(--teal-deep);
  letter-spacing:.01em;
  transition:all .25s;
  white-space:nowrap; /* prevent text wrapping inside pill */
  flex-shrink:0;
}
.tabs a:hover{color:var(--coral-deep)}
.tabs a.active{
  background:var(--teal);
  color:var(--cream);
  box-shadow:0 4px 14px -4px rgba(10,77,92,.5);
}

.cta-btn{
  background:var(--coral);
  color:#fff;
  padding:12px 22px;
  border-radius:999px;
  font-weight:700;font-size:14px;
  border:none;cursor:pointer;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 8px 22px -8px rgba(255,90,95,.6);
  display:inline-block;
}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px -10px rgba(255,90,95,.7)}
.cta-btn.ghost{background:transparent;color:var(--teal);border:1.5px solid var(--teal);box-shadow:none}
.cta-btn.ghost:hover{background:var(--teal);color:#fff}
.cta-btn.ghost-light{background:transparent;color:var(--cream);border:1.5px solid rgba(250,247,242,.4);box-shadow:none}
.cta-btn.ghost-light:hover{background:rgba(250,247,242,.1);border-color:var(--cream)}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding:90px 36px 110px;
  max-width:1320px;margin:0 auto;
  overflow:hidden;
  min-height:580px;
  display:flex;
  align-items:center;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:60px;
  align-items:center;
  width:100%;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--coral-deep);
  margin-bottom:28px;
}
.eyebrow::before{
  content:'';width:32px;height:1.5px;background:var(--coral);
}
h1.display{
  font-family:var(--serif);
  font-weight:700;
  font-size:clamp(36px,4.5vw,64px);
  line-height:1.1;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-bottom:30px;
}
h1.display em{
  font-style:italic;
  color:var(--teal);
  font-weight:300;
}
h1.display b{
  font-weight:600;
  color:var(--coral);
  font-style:normal;
}
.hero-sub{
  font-size:20px;line-height:1.5;
  color:var(--ink-soft);
  max-width:540px;
  margin-bottom:38px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

.hero-visual{
  position:relative;
  aspect-ratio:.85;
  background:linear-gradient(165deg, var(--teal) 0%, var(--teal-deep) 100%);
  border-radius:32px;
  padding:40px;
  color:var(--cream);
  overflow:hidden;
  box-shadow:0 40px 80px -30px rgba(10,77,92,.45);
}
.hero-visual::before{
  content:'';position:absolute;
  width:280px;height:280px;
  background:radial-gradient(circle, rgba(255,90,95,.35) 0%, transparent 70%);
  top:-80px;right:-80px;
  border-radius:50%;
}
.ekg{
  position:absolute;
  bottom:40px;left:40px;right:40px;
  height:80px;
}
.ekg svg{width:100%;height:100%}
.ekg path{
  stroke:var(--coral);
  stroke-width:2.5;fill:none;
  stroke-dasharray:1000;
  stroke-dashoffset:1000;
  animation:draw 3s ease-out forwards infinite;
}
@keyframes draw{
  0%{stroke-dashoffset:1000}
  60%{stroke-dashoffset:0}
  100%{stroke-dashoffset:0;opacity:.4}
}
.metric{
  position:relative;z-index:2;
}
.metric .num{
  font-family:var(--serif);
  font-size:72px;font-weight:700;
  line-height:1;letter-spacing:-.03em;
}
.metric .num sup{font-size:32px;vertical-align:top;color:var(--coral)}
.metric .lbl{
  font-size:13px;letter-spacing:.15em;
  text-transform:uppercase;
  margin-top:14px;opacity:.75;
}
.metric .desc{
  margin-top:18px;font-size:15px;line-height:1.5;
  max-width:280px;opacity:.8;
}

/* ---------- SECTIONS ---------- */
.section{
  padding:110px 36px;
  max-width:1320px;margin:0 auto;
}
.section.dark{
  background:var(--teal-deep);
  color:var(--cream);
  max-width:none;margin:0;
  border-radius:0;
  padding:110px 36px;
}
.section.ink{
  background:var(--ink);
  color:var(--cream);
  max-width:none;margin:0;
  padding:110px 36px;
}
.section.cream2{background:var(--cream-2);max-width:none;margin:0;padding:110px 36px}
.section-inner{max-width:1320px;margin:0 auto}

.section-head{
  max-width:780px;
  margin-bottom:70px;
}
.section-head .eyebrow{margin-bottom:20px}
.section-head h2{
  font-family:var(--serif);
  font-weight:700;
  font-size:clamp(28px,3.2vw,46px);
  line-height:1.15;
  letter-spacing:-.02em;
}
.section-head h2 em{font-style:italic;color:var(--coral)}
.section-head h2 .teal{font-style:italic;color:var(--teal)}
.section-head p{
  margin-top:22px;
  font-size:18px;color:var(--ink-soft);max-width:620px;line-height:1.6;
}
.section.dark .section-head h2 em{color:var(--coral)}
.section.dark .section-head p,.section.ink .section-head p{color:rgba(250,247,242,.75)}
.section.ink .section-head h2{color:var(--cream)}
.section.ink .section-head h2 em{color:var(--coral)}

/* PULL QUOTE */
.pull{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:clamp(22px,2.4vw,34px);
  line-height:1.4;
  letter-spacing:-.01em;
  padding:20px 0 20px 36px;
  border-left:3px solid var(--coral);
  max-width:880px;
  margin:50px 0;
  color:var(--ink);
}
.section.dark .pull{color:var(--cream);border-left-color:var(--coral)}
.section.ink .pull{color:var(--cream)}
.pull cite{
  display:block;
  font-family:var(--sans);font-style:normal;
  font-size:13px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  margin-top:18px;
  color:var(--ink-soft);
}
.section.dark .pull cite,.section.ink .pull cite{color:rgba(250,247,242,.6)}

/* CARD GRID */
.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.cards.two{grid-template-columns:repeat(2,1fr)}
.cards.four{grid-template-columns:repeat(4,1fr)}
.card{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:20px;
  padding:36px 32px;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 40px -20px rgba(10,77,92,.2);
  border-color:var(--teal);
}
.section.dark .card,.section.ink .card{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.1);
  color:var(--cream);
}
.section.dark .card:hover,.section.ink .card:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,90,95,.4);
}
.card .icon{
  width:48px;height:48px;
  border-radius:14px;
  background:var(--teal-soft);
  display:grid;place-items:center;
  margin-bottom:22px;
  color:var(--teal);
  font-family:var(--serif);
  font-size:22px;font-weight:600;
}
.section.dark .card .icon,.section.ink .card .icon{background:rgba(255,90,95,.15);color:var(--coral)}
.card h3{
  font-family:var(--serif);
  font-size:24px;font-weight:500;
  letter-spacing:-.01em;
  margin-bottom:12px;line-height:1.2;
}
.card p{font-size:15px;color:var(--ink-soft);line-height:1.55}
.section.dark .card p,.section.ink .card p{color:rgba(250,247,242,.7)}

/* White card variant (on cream/cream2 backgrounds) */
.card.white{background:#fff;border-color:var(--line)}

/* STAT STRIP */
.stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:40px;
  padding:60px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.stat .num{
  font-family:var(--serif);
  font-size:52px;font-weight:700;
  line-height:1;color:var(--teal);
  letter-spacing:-.02em;
}
.stat .num sup{color:var(--coral);font-size:26px;vertical-align:top}
.stat .lbl{
  margin-top:14px;font-size:14px;
  color:var(--ink-soft);line-height:1.4;
}
.section.dark .stat .num,.section.ink .stat .num{color:var(--cream)}
.section.dark .stat .lbl,.section.ink .stat .lbl{color:rgba(250,247,242,.65)}
.section.dark .stats,.section.ink .stats{border-color:rgba(255,255,255,.12)}

/* SPLIT */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.split-visual{
  aspect-ratio:1;
  background:linear-gradient(140deg,var(--coral) 0%, #FF8A5F 100%);
  border-radius:28px;
  position:relative;
  overflow:hidden;
  box-shadow:0 30px 60px -25px rgba(255,90,95,.5);
}
.split-visual.teal{
  background:linear-gradient(140deg,var(--teal) 0%, var(--teal-deep) 100%);
  box-shadow:0 30px 60px -25px rgba(10,77,92,.5);
  aspect-ratio:auto;
  min-height:460px;
}
.split-visual::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 70% 30%, rgba(255,255,255,.2) 0%, transparent 50%);
}
.split-visual.teal::after{
  background:radial-gradient(circle at 70% 30%, rgba(255,255,255,.12) 0%, transparent 50%);
  pointer-events:none;
}
.split-content h3{
  font-family:var(--serif);
  font-weight:700;
  font-size:clamp(26px,2.8vw,40px);
  line-height:1.2;
  letter-spacing:-.015em;
  margin-bottom:24px;
}
.split-content h3 em{font-style:italic;color:var(--coral)}
.split-content > p{font-size:17px;color:var(--ink-soft);line-height:1.6;margin-bottom:8px}
.section.dark .split-content h3,.section.ink .split-content h3{color:var(--cream)}
.section.dark .split-content > p,.section.ink .split-content > p{color:rgba(250,247,242,.72)}
.split-content ul{list-style:none;margin-top:30px}
.split-content ul li{
  padding:18px 0;
  border-top:1px solid var(--line);
  display:flex;gap:18px;align-items:flex-start;
  font-size:16px;
}
.split-content ul li:last-child{border-bottom:1px solid var(--line)}
.split-content ul li::before{
  content:'';
  flex-shrink:0;
  width:8px;height:8px;
  background:var(--coral);
  border-radius:50%;
  margin-top:9px;
}
.split-content ul li b{color:var(--teal);font-weight:700}
.section.dark .split-content ul li,.section.ink .split-content ul li{border-color:rgba(255,255,255,.1);color:rgba(250,247,242,.85)}
.section.dark .split-content ul li b,.section.ink .split-content ul li b{color:var(--coral)}

/* HOW-STEPS */
.steps{display:flex;flex-direction:column;gap:0}
.step{
  display:flex;gap:24px;align-items:flex-start;
  padding:28px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.step:last-child{border-bottom:none}
.step-num{
  flex-shrink:0;
  width:40px;height:40px;border-radius:50%;
  border:1.5px solid var(--coral);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:18px;font-weight:500;
  color:var(--coral);margin-top:2px;
}
.step h4{
  font-family:var(--serif);font-size:20px;font-weight:500;
  color:var(--cream);margin-bottom:6px;letter-spacing:-.01em;
}
.step p{font-size:15px;color:rgba(250,247,242,.65);line-height:1.6}

/* RPM TABLE */
.rpm-table{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  overflow:hidden;
}
.rpm-row{
  display:flex;align-items:center;
  padding:20px 28px;gap:20px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.rpm-row:last-child{border-bottom:none}
.rpm-row.total{
  background:rgba(255,90,95,.12);
  border-top:1px solid rgba(255,90,95,.25);
}
.rpm-code{
  font-family:monospace;font-size:13px;font-weight:700;
  color:var(--coral);
  background:rgba(255,90,95,.1);
  padding:4px 10px;border-radius:6px;
  flex-shrink:0;width:80px;text-align:center;
}
.rpm-desc{flex:1;font-size:15px;color:rgba(250,247,242,.75)}
.rpm-amt{
  font-family:var(--serif);font-size:20px;font-weight:500;
  color:var(--cream);white-space:nowrap;
}
.rpm-row.total .rpm-desc{font-weight:700;color:var(--cream)}
.rpm-row.total .rpm-amt{color:var(--coral);font-size:24px}

/* DEPLOY TIMELINE */
.timeline{display:flex;flex-direction:column;gap:0}
.timeline-item{
  display:flex;gap:24px;
  padding:24px 0;
  border-bottom:1px solid var(--line);
}
.timeline-item:last-child{border-bottom:none}
.timeline-day{
  flex-shrink:0;
  width:56px;height:56px;border-radius:50%;
  background:var(--coral);color:#fff;
  display:grid;place-items:center;
  font-family:var(--serif);font-size:16px;font-weight:600;
  margin-top:2px;
}
.timeline-day.green{background:var(--teal)}
.timeline-title{font-family:var(--serif);font-size:19px;font-weight:500;color:var(--ink);margin-bottom:5px}
.timeline-text{font-size:15px;color:var(--ink-soft);line-height:1.6}

/* COMPLIANCE GRID */
.comp-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:50px;
}
.comp-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  padding:32px 28px;
}
.comp-card h4{
  font-family:var(--serif);font-size:20px;font-weight:500;
  color:var(--cream);margin-bottom:10px;
}
.comp-card p{font-size:14px;color:rgba(250,247,242,.65);line-height:1.6}
.comp-icon{
  font-size:28px;margin-bottom:16px;
}

/* CTA BAND */
.cta-band{
  background:var(--ink);
  color:var(--cream);
  padding:100px 36px;
  text-align:center;
}
.cta-band h2{
  font-family:var(--serif);
  font-weight:700;
  font-size:clamp(28px,3.5vw,52px);
  line-height:1.2;letter-spacing:-.015em;
  max-width:880px;margin:0 auto 30px;
}
.cta-band h2 em{color:var(--coral);font-style:italic}
.cta-band p{
  font-size:18px;
  color:rgba(250,247,242,.7);
  max-width:720px;margin:0 auto 40px;
  line-height:1.6;
  white-space:balance;
}
.cta-band .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-band .cta-btn.ghost{border-color:var(--cream);color:var(--cream)}
.cta-band .cta-btn.ghost:hover{background:var(--cream);color:var(--ink)}

/* STORE BADGES */
.store-badges{
  display:flex;
  flex-direction:row;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:36px;
}
.store-badge{
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  gap:12px;
  background:#111 !important;
  border:1.5px solid rgba(255,255,255,.3) !important;
  border-radius:12px;
  padding:12px 20px 12px 16px;
  color:#fff !important;
  text-decoration:none !important;
  min-width:160px;
  width:auto;
  transition:transform .2s, box-shadow .2s, border-color .2s;
  cursor:pointer;
  box-sizing:border-box;
}
.store-badge:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 28px -8px rgba(0,0,0,.8);
  border-color:rgba(255,255,255,.6) !important;
}
.store-badge svg{
  flex-shrink:0;
  width:24px;
  height:auto;
}
.badge-text{
  display:flex;
  flex-direction:column;
  gap:1px;
}
.badge-text .badge-sub{
  font-size:10px;
  font-weight:400;
  color:rgba(255,255,255,.7);
  line-height:1;
  display:block;
  letter-spacing:.02em;
  white-space:nowrap;
}
.badge-text .badge-main{
  font-size:17px;
  font-weight:700;
  color:#fff;
  line-height:1.2;
  display:block;
  letter-spacing:-.01em;
  white-space:nowrap;
}

/* DOWNLOAD STRIP */
.dl-strip{
  background:var(--teal-deep);
  padding:32px 36px;
  display:flex;align-items:center;justify-content:center;gap:14px;
  flex-wrap:wrap;
}

/* FOOTER */
footer{
  background:var(--cream-2);
  padding:60px 36px 30px;
  border-top:1px solid var(--line);
}
.foot-inner{
  max-width:1320px;margin:0 auto;
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:50px;
}
.foot-inner h4{
  font-size:12px;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--teal);margin-bottom:18px;
}
.foot-inner ul{list-style:none}
.foot-inner ul li{
  margin-bottom:10px;font-size:14px;
  color:var(--ink-soft);
}
.foot-inner ul li a:hover{color:var(--coral)}
.foot-tag{
  font-family:var(--serif);font-style:italic;
  font-size:18px;color:var(--ink-soft);
  max-width:280px;margin-top:14px;line-height:1.5;
}
.foot-bottom{
  max-width:1320px;margin:50px auto 0;
  padding-top:24px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;
  font-size:12px;color:var(--ink-soft);
  letter-spacing:.05em;
}

/* FEATURE LIST */
.feature-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:40px 60px;
  margin-top:30px;
}
.feature-item{display:flex;gap:18px}
.feature-item .ico{
  flex-shrink:0;
  width:42px;height:42px;
  border-radius:50%;
  background:var(--coral);color:#fff;
  display:grid;place-items:center;
  font-weight:700;font-family:var(--serif);
  font-size:18px;
}
.feature-item h4{
  font-family:var(--serif);font-size:20px;
  font-weight:500;margin-bottom:6px;letter-spacing:-.01em;
}
.feature-item p{font-size:15px;color:var(--ink-soft)}
.section.dark .feature-item p,.section.ink .feature-item p{color:rgba(250,247,242,.7)}
.section.dark .feature-item h4,.section.ink .feature-item h4{color:var(--cream)}

/* SETTINGS */
.settings-wrap{
  display:grid;
  grid-template-columns:280px 1fr;
  min-height:calc(100vh - 73px);
}
.settings-nav{
  background:var(--cream-2);
  border-right:1px solid var(--line);
  padding:36px 0;
  position:sticky;top:73px;
  height:calc(100vh - 73px);
  overflow-y:auto;
}
.settings-nav-group{
  margin-bottom:8px;
}
.settings-nav-label{
  font-size:11px;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--ink-soft);
  padding:16px 24px 8px;display:block;
}
.settings-nav a{
  display:flex;align-items:center;gap:12px;
  padding:11px 24px;
  font-size:14px;font-weight:500;
  color:var(--ink-soft);
  transition:all .2s;
  border-left:3px solid transparent;
}
.settings-nav a:hover{background:var(--cream);color:var(--ink)}
.settings-nav a.active{
  background:#fff;
  color:var(--coral);
  border-left-color:var(--coral);
  font-weight:700;
}
.settings-nav a svg{width:16px;height:16px;flex-shrink:0}
.settings-body{
  padding:48px;
  background:#fff;
  max-width:860px;
}
.settings-page-title{
  font-family:var(--serif);
  font-size:36px;font-weight:400;
  letter-spacing:-.02em;margin-bottom:8px;
}
.settings-page-sub{
  font-size:16px;color:var(--ink-soft);
  margin-bottom:48px;max-width:560px;line-height:1.6;
}
.settings-block{
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
  margin-bottom:32px;
}
.settings-block-head{
  padding:24px 28px 20px;
  border-bottom:1px solid var(--line);
  background:var(--cream);
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
}
.settings-block-head-info h3{
  font-family:var(--serif);font-size:20px;font-weight:500;
  margin-bottom:5px;
}
.settings-block-head-info p{font-size:14px;color:var(--ink-soft);line-height:1.5;max-width:480px}
.badge{
  display:inline-flex;align-items:center;
  font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;flex-shrink:0;
}
.badge.green{background:#DCFCE7;color:#166534}
.badge.red{background:#FEE2E2;color:#991B1B}
.badge.teal{background:var(--teal-soft);color:var(--teal)}
.badge.amber{background:#FEF3C7;color:#92400E}
.settings-block-body{padding:28px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.form-grid.full{grid-template-columns:1fr}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-label{
  font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);
}
.form-input,.form-select{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:10px;
  padding:12px 16px;
  font-family:var(--sans);
  font-size:15px;color:var(--ink);
  width:100%;transition:border-color .2s,box-shadow .2s;
  appearance:none;
}
.form-input:focus,.form-select:focus{
  outline:none;
  border-color:var(--coral);
  box-shadow:0 0 0 3px rgba(255,90,95,.12);
}
.form-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%233A4A53' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer;
}
.form-hint{font-size:12px;color:var(--ink-soft);line-height:1.5;margin-top:2px}
.form-actions{
  display:flex;justify-content:flex-end;gap:12px;
  margin-top:24px;padding-top:20px;
  border-top:1px solid var(--line);
}
.btn-cancel{
  background:none;border:none;
  font-family:var(--sans);font-size:14px;font-weight:600;
  color:var(--ink-soft);padding:10px 18px;border-radius:999px;cursor:pointer;
  transition:background .2s;
}
.btn-cancel:hover{background:var(--cream)}
.btn-save{
  background:var(--coral);color:#fff;
  font-family:var(--sans);font-size:14px;font-weight:700;
  padding:10px 24px;border-radius:999px;border:none;cursor:pointer;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 6px 18px -6px rgba(255,90,95,.6);
}
.btn-save:hover{transform:translateY(-1px)}
/* device / med / team rows */
.device-row,.med-row,.team-row{
  display:flex;align-items:center;gap:14px;
  padding:16px;
  background:var(--cream);
  border:1px solid var(--line);border-radius:14px;
  margin-bottom:10px;
}
.device-row:last-child,.med-row:last-child,.team-row:last-child{margin-bottom:0}
.row-icon{
  font-size:26px;flex-shrink:0;
  width:48px;height:48px;border-radius:12px;
  background:var(--teal-soft);display:grid;place-items:center;
}
.row-info{flex:1}
.row-name{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:2px}
.row-sub{font-size:13px;color:var(--ink-soft)}
.row-badge{
  font-size:11px;font-weight:700;
  padding:4px 12px;border-radius:999px;
  letter-spacing:.08em;text-transform:uppercase;flex-shrink:0;
}
.row-badge.on{background:#DCFCE7;color:#166534}
.row-badge.off{background:var(--cream-2);color:var(--ink-soft)}
/* threshold rows */
.thresh-row{
  display:flex;align-items:center;gap:16px;
  padding:18px 0;border-bottom:1px solid var(--line);
}
.thresh-row:last-child{border-bottom:none}
.thresh-label{flex:1;font-size:15px;font-weight:500;color:var(--ink)}
.thresh-val{
  font-family:var(--serif);font-size:18px;font-weight:500;
  background:var(--cream);border:1px solid var(--line);
  padding:7px 16px;border-radius:10px;color:var(--ink);
}
.thresh-controls{display:flex;gap:6px}
.thresh-btn{
  width:32px;height:32px;border-radius:8px;
  background:var(--cream-2);border:1px solid var(--line);
  font-size:18px;font-weight:700;color:var(--ink-soft);cursor:pointer;
  display:grid;place-items:center;transition:background .2s;
}
.thresh-btn:hover{background:var(--teal-soft);color:var(--teal)}
/* toggles */
.toggle-row{
  display:flex;align-items:flex-start;gap:16px;
  padding:20px 0;border-bottom:1px solid var(--line);
}
.toggle-row:last-child{border-bottom:none}
.toggle-info{flex:1}
.toggle-title{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:3px}
.toggle-sub{font-size:13px;color:var(--ink-soft);line-height:1.5}
.toggle{position:relative;width:46px;height:26px;flex-shrink:0;margin-top:2px}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{
  position:absolute;cursor:pointer;inset:0;
  background:var(--cream-2);border:1px solid var(--line);
  border-radius:999px;transition:background .25s;
}
.toggle-slider::before{
  content:'';position:absolute;
  width:20px;height:20px;left:2px;top:2px;
  background:#fff;border-radius:50%;
  transition:transform .25s;
  box-shadow:0 1px 4px rgba(0,0,0,.15);
}
.toggle input:checked+.toggle-slider{background:var(--coral);border-color:var(--coral)}
.toggle input:checked+.toggle-slider::before{transform:translateX(20px)}
/* conditions */
.cond-list{display:flex;flex-wrap:wrap;gap:8px}
.cond-tag{
  font-size:13px;font-weight:600;
  padding:6px 16px;border-radius:999px;
  background:rgba(255,90,95,.1);color:var(--coral-deep);
  border:1px solid rgba(255,90,95,.2);cursor:pointer;
  transition:all .2s;
}
.cond-tag:hover,.cond-tag.on{background:var(--coral);color:#fff;border-color:var(--coral)}
/* danger */
.danger-row{
  display:flex;align-items:flex-start;gap:16px;
  padding:22px 0;border-bottom:1px solid var(--line);
}
.danger-row:last-child{border-bottom:none}
.danger-info{flex:1}
.danger-title{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:4px}
.danger-sub{font-size:14px;color:var(--ink-soft)}
.btn-danger{
  background:none;color:#EF4444;
  border:1.5px solid #EF4444;
  font-family:var(--sans);font-size:14px;font-weight:700;
  padding:9px 18px;border-radius:999px;cursor:pointer;
  transition:all .2s;white-space:nowrap;flex-shrink:0;
}
.btn-danger:hover{background:#EF4444;color:#fff}
.btn-danger.solid{background:#EF4444;color:#fff}
.btn-danger.solid:hover{background:#DC2626}

/* avatar */
.avatar-row{
  display:flex;align-items:center;gap:20px;
  padding-bottom:28px;margin-bottom:28px;
  border-bottom:1px solid var(--line);
}
.avatar{
  width:76px;height:76px;border-radius:50%;
  background:var(--coral);color:#fff;
  display:grid;place-items:center;
  font-family:var(--serif);font-size:28px;font-weight:600;flex-shrink:0;
}
.avatar-info .name{font-family:var(--serif);font-size:20px;font-weight:500;margin-bottom:3px}
.avatar-info .sub{font-size:13px;color:var(--ink-soft);margin-bottom:12px}
.avatar-actions{display:flex;gap:10px}
.btn-sm{
  font-family:var(--sans);font-size:13px;font-weight:600;
  padding:7px 16px;border-radius:999px;cursor:pointer;transition:all .2s;
}
.btn-sm.outline{background:none;border:1.5px solid var(--teal);color:var(--teal)}
.btn-sm.outline:hover{background:var(--teal);color:#fff}
.btn-sm.ghost{background:none;border:1.5px solid var(--line);color:var(--ink-soft)}
.btn-sm.ghost:hover{background:var(--cream)}

/* ============================================================
   RESPONSIVE — Desktop · Tablet · Mobile
   Breakpoints: 1200 · 980 · 768 · 600 · 480
   ============================================================ */

/* ---- 1200px : large-tablet / small-laptop tweaks ---- */
@media(max-width:1200px){
  .nav-inner{padding:14px 28px}
  .hero{padding:80px 28px 100px}
  .hero-grid{gap:44px}
  .split{gap:60px}
  .section,.section.dark,.section.ink,.section.cream2{padding:90px 28px}
  .foot-inner{gap:36px}
}

/* ---- 980px : tablet — stack major grids ---- */
@media(max-width:980px){
  /* Nav */
  .nav-inner{
    flex-wrap:wrap;
    padding:14px 20px;
    gap:10px;
  }
  /* Tabs become a full-width scrollable horizontal strip */
  .tabs{
    order:3;
    width:100%;
    justify-content:flex-start;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    flex-wrap:nowrap;
    padding:4px 6px;
    border-radius:12px; /* less pill-like, better for strip */
  }
  .tabs::-webkit-scrollbar{display:none}
  .tabs a{
    white-space:nowrap;
    flex-shrink:0;
  }

  /* Hero */
  .hero{padding:60px 24px 80px;min-height:auto;align-items:flex-start}
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero-visual{
    aspect-ratio:auto;
    min-height:300px;
    max-height:380px;
  }
  .hero-sub{font-size:18px;max-width:100%}

  /* Sections */
  .section,.section.dark,.section.ink,.section.cream2{padding:72px 24px}
  .section-head{margin-bottom:50px}
  .section-head p{font-size:17px}

  /* Cards */
  .cards{grid-template-columns:1fr 1fr}
  .cards.four{grid-template-columns:1fr 1fr}
  .cards.two{grid-template-columns:1fr 1fr}

  /* Stats */
  .stats{grid-template-columns:1fr 1fr;gap:28px}

  /* Split */
  .split{grid-template-columns:1fr;gap:44px}
  .split-visual{aspect-ratio:auto;min-height:320px}
  .split-visual.teal{min-height:400px}

  /* Feature list */
  .feature-list{grid-template-columns:1fr;gap:32px}

  /* Compliance grid */
  .comp-grid{grid-template-columns:1fr 1fr}

  /* Pull quote */
  .pull{padding:18px 0 18px 28px;margin:40px 0}

  /* CTA band */
  .cta-band{padding:80px 24px}

  /* RPM table — allow horizontal scroll */
  .rpm-table{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .rpm-row{min-width:520px}

  /* Timeline */
  .timeline-item{gap:18px}

  /* Footer */
  .foot-inner{grid-template-columns:1fr 1fr;gap:36px}
  .foot-bottom{flex-direction:column;gap:8px;text-align:center}

  /* Contact page */
  .contact-layout{
    grid-template-columns:1fr !important;
    gap:40px;
    padding:0 24px 80px !important;
  }
  .contact-hero{padding:70px 24px 50px !important}
  .contact-sidebar{position:static !important;top:auto !important}
  .form-row{grid-template-columns:1fr 1fr}

  /* Settings */
  .settings-wrap{grid-template-columns:1fr}
  .settings-nav{
    position:relative;top:0;height:auto;
    display:flex;flex-wrap:wrap;
    padding:12px;
    border-right:none;
    border-bottom:1px solid var(--line);
  }
  .settings-nav-label{width:100%;padding:8px 8px 4px}
  .settings-nav a{
    border-left:none;
    border-bottom:2px solid transparent;
    border-radius:8px;
    padding:8px 12px;
  }
  .settings-nav a.active{border-bottom-color:var(--coral);border-left:none}
  .settings-body{padding:28px;max-width:none}
  .form-grid{grid-template-columns:1fr}
}

/* ---- 768px : mid-tablet ---- */
@media(max-width:768px){
  /* Nav */
  .nav-inner{padding:12px 18px;gap:10px}
  .tabs a{padding:8px 15px;font-size:13px}
  .cta-btn{padding:10px 18px;font-size:13px}

  /* Hero */
  .hero{padding:48px 18px 68px}
  .hero-visual{min-height:260px;max-height:320px}
  .metric .num{font-size:60px}
  .hero-actions{flex-wrap:wrap;gap:12px}

  /* Section head */
  .section-head{margin-bottom:40px}
  .section-head p{font-size:16px}

  /* Stats */
  .stat .num{font-size:44px}
  .stat .num sup{font-size:22px}

  /* Cards */
  .cards.two{grid-template-columns:1fr}
  .card{padding:28px 24px}
  .card h3{font-size:21px}

  /* Split */
  .split-visual.teal{min-height:360px}

  /* Timeline */
  .timeline-day{width:48px;height:48px;font-size:14px}
  .timeline-title{font-size:17px}
  .timeline-text{font-size:14px}

  /* RPM */
  .rpm-amt{font-size:17px}
  .rpm-desc{font-size:14px}

  /* Contact form */
  .contact-form-wrap{padding:32px 26px !important}
  .form-row{grid-template-columns:1fr}

  /* CTA band */
  .cta-band{padding:70px 20px}
  .cta-band h2{font-size:clamp(26px,5vw,44px)}
  .cta-band p{font-size:16px}
  .cta-band .actions{flex-wrap:wrap;justify-content:center;gap:12px}

  /* Footer */
  .foot-inner{grid-template-columns:1fr 1fr}
  footer{padding:50px 18px 24px}
}

/* ---- 600px : mobile ---- */
@media(max-width:600px){
  body{font-size:16px}

  /* Nav */
  .nav-inner{padding:10px 14px;gap:8px}
  .brand-logo{height:36px !important;max-height:36px !important}
  .tabs{padding:3px 4px;gap:2px;border-radius:10px}
  .tabs a{padding:7px 12px;font-size:12.5px}
  .cta-btn{padding:9px 16px;font-size:13px}

  /* Hero */
  .hero{padding:40px 14px 56px}
  .hero-sub{font-size:16px}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:10px}
  .hero-actions .cta-btn{width:100%;text-align:center;max-width:320px}
  /* Show hero visual but smaller */
  .hero-visual{
    min-height:220px;
    max-height:260px;
    padding:24px !important;
    border-radius:20px;
  }
  .metric .num{font-size:52px}
  .metric .lbl{font-size:12px;margin-top:10px}
  .metric .desc{font-size:13px;margin-top:12px}

  /* Sections */
  .section,.section.dark,.section.ink,.section.cream2{padding:56px 14px}
  .section-head{margin-bottom:32px}
  .section-head h2{letter-spacing:-.015em}

  /* Cards */
  .cards,.cards.four,.cards.two{grid-template-columns:1fr}
  .card{padding:26px 20px;border-radius:16px}
  .card h3{font-size:20px}
  .card p{font-size:14.5px}

  /* Stats */
  .stats{grid-template-columns:1fr 1fr;gap:20px;padding:36px 0}
  .stat .num{font-size:38px}
  .stat .num sup{font-size:18px}
  .stat .lbl{font-size:13px;margin-top:10px}

  /* Split */
  .split{gap:28px}
  .split-visual{min-height:200px;border-radius:20px}
  .split-visual.teal{min-height:300px}
  .split-content h3{font-size:clamp(22px,5.5vw,34px)}
  .split-content ul li{font-size:15px;padding:15px 0}

  /* Pull quote */
  .pull{
    font-size:clamp(18px,4.5vw,26px);
    padding:14px 0 14px 20px;
    margin:28px 0;
    border-left-width:2.5px;
  }

  /* Steps */
  .step{gap:14px;padding:20px 0}
  .step-num{width:36px;height:36px;font-size:16px}
  .step h4{font-size:18px}
  .step p{font-size:14px}

  /* Timeline */
  .timeline-item{gap:12px;padding:18px 0}
  .timeline-day{width:42px;height:42px;font-size:13px}
  .timeline-title{font-size:16px}
  .timeline-text{font-size:13.5px}

  /* RPM table */
  .rpm-code{font-size:12px;width:68px}
  .rpm-desc{font-size:13px}
  .rpm-amt{font-size:16px}
  .rpm-row.total .rpm-amt{font-size:20px}

  /* Compliance grid */
  .comp-grid{grid-template-columns:1fr}

  /* CTA band */
  .cta-band{padding:56px 14px}
  .cta-band h2{font-size:clamp(24px,6vw,38px)}
  .cta-band p{font-size:15px;margin-bottom:28px}
  .cta-band .actions{flex-direction:column;align-items:center;gap:10px}
  .cta-band .actions .cta-btn{width:100%;max-width:300px;text-align:center}

  /* DL strip */
  .dl-strip{padding:22px 14px;gap:10px}

  /* Footer */
  .foot-inner{grid-template-columns:1fr;gap:26px}
  footer{padding:44px 14px 22px}
  .foot-tag{font-size:16px}
  .foot-bottom{
    flex-direction:column;
    gap:6px;
    text-align:center;
    margin-top:32px;
    padding-top:18px;
  }

  /* Feature list */
  .feature-list{gap:24px}
  .feature-item{gap:14px}
  .feature-item .ico{width:36px;height:36px;font-size:15px}
  .feature-item h4{font-size:17px}
  .feature-item p{font-size:14px}

  /* Contact page */
  .contact-layout{padding:0 14px 52px !important;gap:28px}
  .contact-hero{padding:44px 14px 32px !important}
  .contact-hero h1{font-size:clamp(32px,8vw,52px) !important}
  .contact-hero p{font-size:16px !important}
  .contact-form-wrap{
    padding:22px 16px !important;
    border-radius:14px !important;
  }
  .contact-form-wrap h2{font-size:22px !important}
  .info-card{padding:20px 18px !important;border-radius:14px !important}

  /* Settings */
  .settings-body{padding:16px 14px}
  .settings-page-title{font-size:28px}
  .settings-block-body{padding:18px 16px}
  .thresh-row{flex-wrap:wrap;gap:10px}
  .thresh-label{width:100%}
  .danger-row{flex-wrap:wrap;gap:12px}
  .btn-danger{width:100%;text-align:center}
  .avatar-row{flex-direction:column;align-items:flex-start;gap:14px}
}

/* ---- 480px : small mobile ---- */
@media(max-width:480px){
  /* Nav */
  .nav-inner{padding:9px 12px;gap:6px}
  .brand-logo{height:32px !important;max-height:32px !important}
  .tabs a{padding:6px 11px;font-size:11.5px}
  .cta-btn{padding:8px 14px;font-size:12.5px}

  /* Hero */
  .hero{padding:32px 12px 48px}
  .hero-visual{display:none} /* Too small to be useful — metrics shown in stats strip */
  .hero-actions .cta-btn{max-width:100%}

  /* Stats — bump up a bit */
  .stats{grid-template-columns:1fr 1fr;gap:16px;padding:28px 0}
  .stat .num{font-size:34px}
  .stat .num sup{font-size:16px}
  .stat .lbl{font-size:12px}

  /* Cards */
  .card{padding:22px 16px}
  .card h3{font-size:19px}

  /* Split visual */
  .split-visual{min-height:180px}
  .split-visual.teal{min-height:260px}

  /* Section padding */
  .section,.section.dark,.section.ink,.section.cream2{padding:48px 12px}

  /* Section-head */
  .section-head h2{font-size:clamp(22px,6.5vw,32px)}

  /* CTA band */
  .cta-band{padding:48px 12px}
  .cta-band .actions .cta-btn{max-width:100%}

  /* Footer */
  .foot-inner{gap:22px}
  footer{padding:38px 12px 20px}

  /* Pull quote */
  .pull{padding:12px 0 12px 16px;margin:22px 0}

  /* Contact form wrap */
  .contact-form-wrap{padding:18px 14px !important}

  /* RPM row */
  .rpm-row{padding:12px 14px;min-width:420px}
}
