:root{
  --navy:#050824;--navy2:#080d33;--navy3:#11195a;--ink:#070b25;--muted:#606a80;--soft:#f7f4ff;--soft2:#eef8ff;--white:#fff;
  --pink:#ff178d;--hot:#eb3b8b;--orange:#ff8200;--blue:#00a7ff;--cyan:#00d4ff;--purple:#6a22ff;--violet:#8f39ff;
  --green:#16a66a;--amber:#f59e0b;--red:#d93d55;--border:rgba(5,8,36,.11);--shadow:0 28px 76px rgba(5,8,36,.17);--soft-shadow:0 16px 42px rgba(5,8,36,.10);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:#fff;color:var(--ink);font-family:"Fredoka",Arial,Helvetica,sans-serif;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
.page{min-height:100vh;background:linear-gradient(180deg,#fff 0%,#f8f6ff 42%,#eef8ff 100%)}
.wrap{width:min(1160px,calc(100% - 44px));margin:0 auto}

.hero{position:relative;color:#fff;overflow:hidden;background:radial-gradient(circle at 82% 12%,rgba(255,23,141,.28),transparent 28%),radial-gradient(circle at 96% 72%,rgba(0,212,255,.18),transparent 34%),radial-gradient(circle at 12% 92%,rgba(106,34,255,.35),transparent 30%),linear-gradient(135deg,#050824,#090e36 58%,#10175a);padding:30px 0 48px}
.hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:38px 38px;mask-image:linear-gradient(180deg,#000,transparent 88%)}
.hero .wrap{position:relative;z-index:1}
.tcw-brand-lockup{display:flex;align-items:center;justify-content:space-between;gap:18px;margin:0 0 28px}
.tcw-real-logo{display:inline-flex;align-items:center;justify-content:flex-start;width:min(300px,56vw);min-height:74px}
.tcw-real-logo img{display:block;width:100%;height:auto;max-height:96px;object-fit:contain;filter:drop-shadow(0 18px 34px rgba(0,0,0,.28))}
.tcw-brand-note{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.78);font-size:13px;backdrop-filter:blur(10px)}
.tcw-brand-note:before{content:"";width:8px;height:8px;border-radius:999px;background:var(--blue);box-shadow:0 0 20px rgba(0,167,255,.7)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:30px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:#fff;font-size:13px;font-weight:400;text-transform:uppercase;letter-spacing:.05em;margin-bottom:15px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:8px 13px;backdrop-filter:blur(10px)}
.dot{width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--cyan));box-shadow:0 0 20px rgba(255,23,141,.75)}
h1{font-size:clamp(39px,5.8vw,76px);line-height:.94;letter-spacing:-.045em;margin:0 0 18px;font-weight:400}
h1 span{color:var(--blue);text-shadow:0 0 26px rgba(0,167,255,.32)}
.hero p{font-size:18px;line-height:1.55;color:rgba(255,255,255,.82);max-width:760px;margin:0 0 20px}
.hero-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.hero-card{background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.17);border-radius:30px;padding:24px;box-shadow:0 24px 62px rgba(0,0,0,.24);backdrop-filter:blur(14px)}
.hero-card strong{display:block;font-size:25px;line-height:1.08;margin-bottom:8px;font-weight:400}
.hero-card p{font-size:14px;margin:0 0 15px;line-height:1.45}
.signal-stack{display:grid;gap:10px}
.signal{display:flex;gap:10px;align-items:flex-start;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:11px}
.signal b{display:block;font-weight:400;font-size:14px}
.signal small{display:block;color:rgba(255,255,255,.72);font-size:12px;line-height:1.3}
.sig-icon{width:28px;height:28px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,var(--pink),var(--purple));flex:0 0 auto;padding:5px;overflow:hidden}
.sig-icon img,.module-icon img,.tcw-proof-icon img{display:block;width:100%;height:100%;object-fit:contain}

.tcw-proof-reset{position:relative;z-index:5;margin:-28px 0 0;padding:0 0 12px}
.tcw-proof-grid{display:grid;grid-template-columns:1.15fr repeat(3,minmax(0,1fr));gap:16px;align-items:stretch;background:radial-gradient(circle at 96% 0%,rgba(0,167,255,.16),transparent 28%),radial-gradient(circle at 3% 100%,rgba(255,23,141,.12),transparent 26%),linear-gradient(135deg,rgba(255,255,255,.98),rgba(248,250,255,.98));border:1px solid rgba(5,8,36,.10);border-radius:32px;box-shadow:0 26px 76px rgba(5,8,36,.16);padding:18px}
.tcw-proof-intro{display:flex;flex-direction:column;justify-content:center;min-height:190px;padding:16px 14px;background:radial-gradient(circle at 0% 0%,rgba(255,23,141,.12),transparent 34%),linear-gradient(135deg,#050824,#0d1550);border-radius:24px;color:#fff;overflow:hidden}
.tcw-proof-kicker{display:inline-flex;width:max-content;max-width:100%;margin:0 0 10px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);font-size:12px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.88)}
.tcw-proof-intro h2{margin:0 0 10px;color:#fff;font-size:clamp(25px,2.7vw,36px);line-height:1.02;letter-spacing:-.04em;font-weight:400}
.tcw-proof-intro p{margin:0;color:rgba(255,255,255,.76);font-size:14px;line-height:1.45}
.tcw-proof-card{display:flex;flex-direction:column;min-height:190px;background:radial-gradient(circle at 85% 15%,rgba(0,167,255,.13),transparent 32%),linear-gradient(180deg,#fff,#fbfbff);border:1px solid rgba(5,8,36,.09);border-radius:24px;padding:18px;box-shadow:0 14px 34px rgba(5,8,36,.07)}
.tcw-proof-icon{width:62px;height:62px;border-radius:22px;display:grid;place-items:center;margin:0 0 13px;padding:9px;background:linear-gradient(135deg,var(--pink),var(--purple));box-shadow:0 14px 28px rgba(106,34,255,.20)}
.tcw-proof-card h3{margin:0 0 8px;color:var(--navy);font-size:19px;line-height:1.08;font-weight:400}
.tcw-proof-card p{margin:0;color:var(--muted);font-size:13.5px;line-height:1.45}

.main{padding:30px 0 52px}
.app-shell{display:grid;grid-template-columns:300px minmax(0,1fr);gap:22px;align-items:start}
.side{position:sticky;top:18px;background:rgba(255,255,255,.88);border:1px solid var(--border);border-radius:28px;box-shadow:var(--soft-shadow);padding:20px;backdrop-filter:blur(14px)}
.side h2{font-size:22px;line-height:1.08;margin:0 0 8px;color:var(--navy);font-weight:400;letter-spacing:-.025em}
.side p{font-size:14px;line-height:1.45;color:var(--muted);margin:0 0 15px}
.steps-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}
.steps-list li{display:flex;gap:9px;align-items:center;padding:9px;border-radius:16px;font-size:13px;color:var(--muted);border:1px solid transparent}
.steps-list li span{width:25px;height:25px;border-radius:10px;display:grid;place-items:center;background:#f3f5fb;color:var(--navy);font-weight:400;flex:0 0 auto}
.steps-list li.active{background:linear-gradient(135deg,rgba(255,23,141,.10),rgba(0,167,255,.10));color:var(--navy);border-color:rgba(255,23,141,.15);font-weight:400}
.steps-list li.active span{color:#fff;background:linear-gradient(135deg,var(--pink),var(--purple))}
.mini-note{margin-top:14px;padding:12px;border-radius:18px;background:linear-gradient(135deg,rgba(0,167,255,.10),rgba(106,34,255,.08));color:var(--navy);font-size:13px;line-height:1.35}
.card{background:rgba(255,255,255,.94);border:1px solid var(--border);border-radius:32px;box-shadow:var(--shadow);overflow:hidden}
.progress{height:8px;background:#edf0f8}
.progress-bar{height:8px;width:0;background:linear-gradient(90deg,var(--pink),var(--purple),var(--cyan),var(--orange));transition:width .25s ease}
.step-panel{display:none;padding:32px 32px 12px}
.step-panel.active{display:block}
.step-panel h2{font-size:clamp(29px,4vw,44px);line-height:1.02;letter-spacing:-.035em;margin:0 0 10px;color:var(--navy);font-weight:400}
.intro{font-size:16px;line-height:1.52;color:var(--muted);max-width:790px;margin:0 0 24px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:grid;gap:7px}
.field.full{grid-column:1/-1}
label,.label{font-weight:400;color:var(--navy);font-size:15px}
input,select,textarea{width:100%;border:1px solid rgba(5,8,36,.16);border-radius:17px;min-height:50px;padding:12px 14px;background:#fff;color:var(--ink);outline:none;font-weight:300}
textarea{min-height:98px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(255,23,141,.48);box-shadow:0 0 0 4px rgba(255,23,141,.08)}
.module-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}
.module-card{position:relative;display:flex;gap:13px;align-items:flex-start;padding:16px;border:1px solid rgba(5,8,36,.12);border-radius:22px;background:linear-gradient(180deg,#fff,#fbfbff);cursor:pointer;transition:.16s ease;min-height:112px}
.module-card:hover{transform:translateY(-2px);border-color:rgba(255,23,141,.34);box-shadow:0 14px 30px rgba(5,8,36,.08)}
.module-card input{width:auto;min-height:auto;margin:4px 0 0;accent-color:var(--pink)}
.module-card strong{display:block;font-size:18px;line-height:1.08;color:var(--navy);font-weight:400;margin-bottom:5px}
.module-card small{display:block;color:var(--muted);font-size:13px;line-height:1.35}
.module-card:has(input:checked){border-color:rgba(255,23,141,.45);background:linear-gradient(135deg,rgba(255,23,141,.10),rgba(0,167,255,.10));box-shadow:0 16px 34px rgba(255,23,141,.10)}
.module-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--pink),var(--purple));box-shadow:0 12px 22px rgba(106,34,255,.18);flex:0 0 auto;padding:7px;overflow:hidden}
.full-star{padding:0;font-size:22px}
.choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.choice-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.choice{position:relative;display:flex;align-items:flex-start;gap:10px;padding:13px;border:1px solid rgba(5,8,36,.12);border-radius:18px;background:#fff;cursor:pointer;min-height:54px;transition:.15s ease}
.choice:hover{border-color:rgba(255,23,141,.32);box-shadow:0 8px 20px rgba(5,8,36,.06)}
.choice input{width:auto;min-height:auto;margin:2px 0 0;accent-color:var(--pink)}
.choice strong{display:block;color:var(--navy);font-size:14px;font-weight:400;line-height:1.2}
.choice small{display:block;color:var(--muted);font-size:12px;line-height:1.25;margin-top:2px}
.choice:has(input:checked){background:linear-gradient(135deg,rgba(255,23,141,.07),rgba(0,167,255,.07));border-color:rgba(255,23,141,.35)}
.api-box{margin:20px 0 0;border:1px solid rgba(0,167,255,.16);background:linear-gradient(135deg,rgba(0,167,255,.09),rgba(106,34,255,.07));border-radius:22px;padding:16px}
.api-box h3{margin:0 0 8px;font-size:19px;font-weight:400;color:var(--navy)}
.api-box p{margin:0;color:var(--muted);line-height:1.45;font-size:14px}
.indicator-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}
.indicator{border-radius:999px;padding:8px 10px;background:#fff;border:1px solid rgba(5,8,36,.09);font-size:12px;color:var(--navy);font-weight:400}
.nav-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:26px;padding-top:20px;border-top:1px solid rgba(5,8,36,.08)}
#navRow{margin-top:0;padding:22px 32px 32px;background:#fff}
.btn{appearance:none;border:0;border-radius:18px;min-height:51px;padding:0 23px;display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:400;cursor:pointer;text-align:center;transition:.16s ease;white-space:normal;line-height:1.1}
.btn:hover{transform:translateY(-1px)}
.btn-primary{color:#fff;background:linear-gradient(135deg,var(--pink),var(--purple));box-shadow:0 18px 34px rgba(255,23,141,.23)}
.btn-secondary{color:var(--navy);background:#fff;border:1px solid rgba(5,8,36,.14)}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}
.error{display:none;margin:0 32px 16px;padding:12px 14px;border-radius:16px;background:#fff0f3;color:#9e263a;border:1px solid rgba(217,61,85,.20);font-weight:400}
.result-wrap{display:none;padding:32px}
.result-wrap.active{display:block}
.result-hero{display:grid;grid-template-columns:250px minmax(0,1fr);gap:26px;align-items:start}
.score-card{border-radius:28px;color:#fff;background:radial-gradient(circle at 20% 20%,rgba(255,23,141,.25),transparent 35%),radial-gradient(circle at 82% 82%,rgba(0,212,255,.18),transparent 35%),linear-gradient(135deg,#050824,#10175a);padding:22px;text-align:center;box-shadow:var(--soft-shadow)}
.score-circle{width:178px;height:178px;border-radius:50%;margin:0 auto 15px;display:grid;place-items:center;background:conic-gradient(var(--pink) var(--score-deg), rgba(255,255,255,.13) 0);position:relative;box-shadow:0 18px 34px rgba(0,0,0,.22)}
.score-circle:before{content:"";position:absolute;inset:17px;border-radius:50%;background:radial-gradient(circle at 40% 25%,rgba(255,255,255,.13),transparent 32%),#071033}
.score-number{position:relative;z-index:1;font-size:47px;font-weight:500;line-height:.9;letter-spacing:-.04em}
.score-number small{display:block;font-size:14px;font-weight:400;color:rgba(255,255,255,.82);letter-spacing:0;margin-top:5px}
.score-card h3{font-size:22px;line-height:1.1;margin:0 0 8px;font-weight:400}
.score-card p{font-size:13px;line-height:1.4;color:rgba(255,255,255,.74);margin:0}
.result-copy h2{font-size:clamp(30px,4.4vw,48px);line-height:1.02;letter-spacing:-.04em;margin:0 0 10px;color:var(--navy);font-weight:400}
.result-copy p{font-size:16px;line-height:1.53;color:var(--muted);margin:0 0 16px}
.result-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px}
.result-stat{border-radius:18px;padding:13px;border:1px solid rgba(5,8,36,.08);background:#fff}
.result-stat b{display:block;font-size:28px;line-height:1;font-weight:500}
.result-stat span{font-size:12px;color:var(--muted)}
.result-stat.red b{color:var(--red)}.result-stat.amber b{color:var(--amber)}.result-stat.green b{color:var(--green)}
.finding-grid{display:grid;gap:13px;margin-top:20px}
.finding{border-radius:23px;background:#fff;border:1px solid rgba(5,8,36,.10);box-shadow:0 10px 24px rgba(5,8,36,.05);padding:16px;display:grid;gap:7px}
.finding-top{display:flex;align-items:center;gap:10px}
.finding-badge{border-radius:999px;padding:6px 9px;font-size:12px;font-weight:400}
.finding-badge.green{background:#ecfbf4;color:#126f47}
.finding-badge.amber{background:#fff7e6;color:#925d00}
.finding-badge.red{background:#fff0f3;color:#a8283f}
.finding h3{font-size:19px;font-weight:400;color:var(--navy);margin:0}
.finding p{font-size:14px;line-height:1.45;color:var(--muted);margin:0}
.result-section{margin-top:18px;padding:18px;border-radius:23px;background:#fff;border:1px solid rgba(5,8,36,.09);box-shadow:0 10px 24px rgba(5,8,36,.05)}
.result-section h3{margin:0 0 10px;color:var(--navy);font-size:20px;font-weight:400}
.pill-list{display:flex;flex-wrap:wrap;gap:8px}
.pill{border-radius:999px;padding:8px 10px;background:#f4f6fb;color:var(--navy);font-weight:400;font-size:13px;border:1px solid rgba(5,8,36,.08)}
.pill.risk{background:#fff0f3;color:#a8283f;border-color:rgba(217,61,85,.18)}
.pill.good{background:#effbf5;color:#116d45;border-color:rgba(23,167,107,.18)}
.next-steps{margin:0;padding-left:20px;color:var(--ink);line-height:1.5}
.next-steps li{margin:0 0 8px}
.disclaimer{font-size:13px!important;line-height:1.45!important;color:var(--muted)!important;background:#f8f6ff;border:1px solid rgba(5,8,36,.08);padding:12px 14px;border-radius:16px;margin-top:18px!important}
.submit-status{display:none;margin-top:16px;padding:12px 14px;border-radius:16px;background:#f0f7ff;color:#104c7a;border:1px solid rgba(0,156,255,.18);font-weight:400;line-height:1.4}
.debug-payload{display:none;width:100%;min-height:160px;margin-top:12px;font-size:12px;font-family:Consolas,monospace;white-space:pre-wrap}
.mini-footer{padding:22px 0;text-align:center;color:var(--muted);font-size:13px}
.mini-footer a{color:var(--navy);font-weight:400}

@media(max-width:940px){
  .wrap{width:min(100% - 28px,1160px)}
  .hero{padding:24px 0 32px}
  .tcw-brand-lockup{align-items:flex-start;flex-direction:column;margin-bottom:22px}
  .tcw-real-logo{width:min(255px,74vw);min-height:62px}
  .tcw-real-logo img{max-height:82px}
  .hero-grid,.app-shell,.form-grid,.result-hero{grid-template-columns:1fr}
  .side{position:static;display:none}
  .hero-card{padding:20px;border-radius:24px}
  .step-panel,.result-wrap{padding:23px 22px 10px}
  .module-grid,.choice-grid,.choice-grid.three,.tcw-proof-grid,.result-stats{grid-template-columns:1fr}
  .tcw-proof-reset{margin:0;padding:14px 0 0}
  .tcw-proof-grid{border-radius:24px}
  .tcw-proof-intro,.tcw-proof-card{min-height:auto}
  .nav-row{display:grid;grid-template-columns:1fr;gap:10px}
  #navRow{padding:18px 22px 22px}
  .btn{width:100%}
  h1{font-size:clamp(38px,10vw,54px)}
  .hero p{font-size:16px}
  .score-card{max-width:330px;margin:0 auto}
  .error{margin:0 22px 14px}
}



.help-tip{
  display:inline-grid;
  place-items:center;
  width:18px;
  height:18px;
  margin:0 2px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(0,167,255,.14),rgba(255,23,141,.12));
  border:1px solid rgba(5,8,36,.12);
  color:var(--navy);
  font-size:12px;
  font-weight:500;
  cursor:help;
  vertical-align:middle;
}
.help-tip:hover,
.help-tip:focus{
  outline:none;
  border-color:rgba(255,23,141,.38);
  box-shadow:0 0 0 4px rgba(255,23,141,.08);
}



/* Local dev shortcut panel */
.dev-tools{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:9999;
  display:grid;
  gap:8px;
  width:190px;
  padding:12px;
  border-radius:18px;
  background:rgba(5,8,36,.92);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 18px 48px rgba(5,8,36,.28);
  backdrop-filter:blur(16px);
  color:#fff;
}
.dev-tools-title{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:rgba(255,255,255,.68);
}
.dev-tools button{
  min-height:36px;
  border:0;
  border-radius:12px;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  color:#fff;
  cursor:pointer;
  font-size:13px;
  font-weight:400;
}
.dev-tools button:hover{
  transform:translateY(-1px);
}
@media(max-width:700px){
  .dev-tools{
    left:12px;
    right:12px;
    bottom:12px;
    width:auto;
    grid-template-columns:1fr 1fr 1fr;
  }
  .dev-tools-title{
    grid-column:1/-1;
  }
}



/* Result page upgrade */
.result-brief{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin:22px 0 2px;
}
.result-brief-card{
  min-height:130px;
  border-radius:22px;
  padding:16px;
  border:1px solid rgba(5,8,36,.09);
  background:
    radial-gradient(circle at 90% 10%,rgba(0,167,255,.10),transparent 34%),
    linear-gradient(180deg,#fff,#fbfbff);
  box-shadow:0 12px 28px rgba(5,8,36,.06);
}
.result-brief-card.priority{
  color:#fff;
  background:
    radial-gradient(circle at 20% 0%,rgba(255,23,141,.22),transparent 36%),
    linear-gradient(135deg,#050824,#10175a);
  border-color:rgba(255,255,255,.10);
}
.result-brief-card b{
  display:block;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.055em;
  color:var(--muted);
  font-weight:400;
  margin-bottom:8px;
}
.result-brief-card.priority b{
  color:rgba(255,255,255,.66);
}
.result-brief-card strong{
  display:block;
  font-size:20px;
  line-height:1.08;
  color:var(--navy);
  font-weight:400;
  margin-bottom:7px;
}
.result-brief-card.priority strong{
  color:#fff;
}
.result-brief-card p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  line-height:1.42;
}
.result-brief-card.priority p{
  color:rgba(255,255,255,.74);
}
.result-brief-card .tag{
  display:inline-flex;
  margin-top:9px;
  padding:6px 8px;
  border-radius:999px;
  background:rgba(255,23,141,.10);
  color:var(--navy);
  font-size:12px;
  font-weight:400;
}
.result-brief-card.priority .tag{
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.88);
}
@media(max-width:940px){
  .result-brief{
    grid-template-columns:1fr;
  }
}



/* Narrative intelligence layer */
.narrative-summary{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(250px,.65fr);
  gap:14px;
  margin:22px 0 0;
}
.narrative-main,
.narrative-side{
  border-radius:24px;
  padding:18px;
  border:1px solid rgba(5,8,36,.09);
  box-shadow:0 14px 34px rgba(5,8,36,.06);
}
.narrative-main{
  background:
    radial-gradient(circle at 100% 0%,rgba(0,167,255,.12),transparent 34%),
    linear-gradient(180deg,#fff,#fbfbff);
}
.narrative-side{
  color:#fff;
  background:
    radial-gradient(circle at 0% 0%,rgba(255,23,141,.24),transparent 38%),
    linear-gradient(135deg,#050824,#10175a);
}
.section-kicker{
  display:inline-flex;
  margin:0 0 9px;
  padding:6px 9px;
  border-radius:999px;
  background:rgba(0,167,255,.10);
  color:var(--navy);
  font-size:11px;
  line-height:1;
  font-weight:400;
  letter-spacing:.055em;
  text-transform:uppercase;
}
.narrative-side .section-kicker{
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.78);
}
.narrative-main h3{
  margin:0 0 8px;
  color:var(--navy);
  font-size:25px;
  line-height:1.06;
  font-weight:400;
  letter-spacing:-.03em;
}
.narrative-main p,
.narrative-side p{
  margin:0;
  font-size:14px;
  line-height:1.5;
}
.narrative-main p{
  color:var(--muted);
}
.narrative-side strong{
  display:block;
  color:#fff;
  font-size:21px;
  line-height:1.08;
  font-weight:400;
  margin-bottom:8px;
}
.narrative-side p{
  color:rgba(255,255,255,.74);
}
.priority-groups{
  margin-top:20px;
}
.priority-groups-head{
  margin-bottom:12px;
}
.priority-groups-head h3{
  margin:0 0 6px;
  color:var(--navy);
  font-size:24px;
  line-height:1.08;
  font-weight:400;
}
.priority-groups-head p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.45;
}
.priority-group-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.priority-group-card{
  display:grid;
  grid-template-columns:40px minmax(0,1fr);
  gap:13px;
  padding:15px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(5,8,36,.09);
  box-shadow:0 12px 28px rgba(5,8,36,.05);
}
.priority-group-number{
  width:40px;
  height:40px;
  border-radius:15px;
  display:grid;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  font-weight:500;
}
.priority-group-card h4{
  margin:0 0 5px;
  color:var(--navy);
  font-size:18px;
  line-height:1.08;
  font-weight:400;
}
.priority-group-card p{
  margin:0 0 9px;
  color:var(--muted);
  font-size:13px;
  line-height:1.4;
}
.priority-group-card strong{
  display:block;
  margin:8px 0 4px;
  color:var(--navy);
  font-size:14px;
  font-weight:400;
}
.priority-group-card small{
  display:block;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}
.priority-mini{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.priority-mini span{
  display:inline-flex;
  padding:5px 7px;
  border-radius:999px;
  background:#fff7e6;
  color:#925d00;
  font-size:11px;
}
.priority-mini span.risk{
  background:#fff0f3;
  color:#a8283f;
}
.priority-mini span.good{
  background:#effbf5;
  color:#116d45;
}
@media(max-width:940px){
  .narrative-summary,
  .priority-group-grid{
    grid-template-columns:1fr;
  }
}



/* Result usability patch */
.result-cta-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) 230px;
  gap:16px;
  align-items:center;
  margin:18px 0 22px;
  padding:18px;
  border-radius:26px;
  color:#fff;
  background:
    radial-gradient(circle at 8% 0%,rgba(255,23,141,.22),transparent 32%),
    radial-gradient(circle at 92% 80%,rgba(0,167,255,.20),transparent 34%),
    linear-gradient(135deg,#050824,#11195a);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 20px 50px rgba(5,8,36,.16);
}
.result-cta-card .section-kicker{
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.78);
}
.result-cta-copy h3{
  margin:0 0 8px;
  color:#fff;
  font-size:28px;
  line-height:1.02;
  letter-spacing:-.035em;
  font-weight:400;
}
.result-cta-copy p{
  margin:0 0 12px;
  color:rgba(255,255,255,.76);
  font-size:14px;
  line-height:1.46;
}
.result-cta-copy strong{
  display:block;
  margin:0 0 4px;
  color:#fff;
  font-size:16px;
  font-weight:400;
}
.result-cta-copy small{
  display:block;
  color:rgba(255,255,255,.68);
  font-size:12.5px;
  line-height:1.4;
}
.result-cta-actions{
  display:grid;
  gap:10px;
}
.result-cta-actions .btn-secondary{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.18);
}
.detailed-findings{
  margin-top:20px;
}
.detailed-findings summary{
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-radius:22px;
  cursor:pointer;
  background:#fff;
  border:1px solid rgba(5,8,36,.09);
  box-shadow:0 12px 28px rgba(5,8,36,.05);
}
.detailed-findings summary::-webkit-details-marker{
  display:none;
}
.detailed-findings summary span{
  color:var(--navy);
  font-size:19px;
  font-weight:400;
}
.detailed-findings summary span:before{
  content:"+";
  display:inline-grid;
  place-items:center;
  width:26px;
  height:26px;
  margin-right:9px;
  border-radius:10px;
  color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  box-shadow:0 8px 18px rgba(255,23,141,.18);
}
.detailed-findings[open] summary span:before{
  content:"–";
}
.detailed-findings summary small{
  display:inline-flex;
  padding:6px 9px;
  border-radius:999px;
  color:var(--navy);
  background:#f4f6fb;
  border:1px solid rgba(5,8,36,.08);
}
.detailed-findings .finding-grid{
  margin-top:13px;
}
@media(max-width:940px){
  .result-cta-card{
    grid-template-columns:1fr;
  }
}



/* Inline field explanations */
.field-help{
  margin-top:-3px;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}
.help-tip{
  display:inline-grid;
  place-items:center;
  width:18px;
  height:18px;
  margin:0 2px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(0,167,255,.14),rgba(255,23,141,.12));
  border:1px solid rgba(5,8,36,.12);
  color:var(--navy);
  font-size:12px;
  font-weight:500;
  cursor:help;
  vertical-align:middle;
}
.help-tip:hover,
.help-tip:focus{
  outline:none;
  border-color:rgba(255,23,141,.38);
  box-shadow:0 0 0 4px rgba(255,23,141,.08);
}



/* Form density refinement */
select{
  min-height:44px;
  padding:9px 40px 9px 13px;
  font-size:14px;
  line-height:1.2;
}
input{
  min-height:46px;
  padding:10px 13px;
  font-size:14px;
}
textarea{
  padding:11px 13px;
  font-size:14px;
}
.form-grid{
  gap:13px 16px;
}
.field{
  gap:5px;
}
.field-help{
  margin-top:-2px;
  font-size:11.5px;
  line-height:1.3;
}
.choice{
  min-height:48px;
  padding:11px 13px;
}
.choice strong{
  font-size:13.5px;
}
.module-card{
  min-height:104px;
}
@media(max-width:940px){
  select{
    min-height:46px;
  }
}



/* Hard select height fix - prevents oversized dropdowns on wrapped-label fields */
.step-panel .field select,
.step-panel select[data-required-when-active]{
  height:40px !important;
  min-height:40px !important;
  max-height:40px !important;
  padding:0 38px 0 12px !important;
  font-size:14px !important;
  line-height:40px !important;
  display:block !important;
}
.step-panel .field input{
  height:42px !important;
  min-height:42px !important;
  padding:0 12px !important;
  font-size:14px !important;
}
.step-panel .field label{
  line-height:1.22;
}
.step-panel .field-help{
  margin-top:-2px !important;
  margin-bottom:2px !important;
  font-size:11px !important;
  line-height:1.24 !important;
}
.step-panel .form-grid{
  align-items:start !important;
}



/* Form spacing refinement - stops uneven rows when labels/helper text wrap */
.step-panel .form-grid{
  gap:20px 18px !important;
  align-items:start !important;
}
.step-panel .field{
  display:flex !important;
  flex-direction:column !important;
  gap:7px !important;
  min-height:92px;
}
.step-panel .field label{
  display:block !important;
  min-height:34px;
  line-height:1.25 !important;
  margin:0 !important;
}
.step-panel .field .field-help{
  min-height:28px;
  margin:0 !important;
  font-size:11px !important;
  line-height:1.25 !important;
  color:var(--muted);
}
.step-panel .field label + select,
.step-panel .field label + input{
  margin-top:28px;
}
.step-panel .field label + .field-help + select,
.step-panel .field label + .field-help + input{
  margin-top:0;
}
.step-panel .field select,
.step-panel select[data-required-when-active]{
  height:42px !important;
  min-height:42px !important;
  max-height:42px !important;
  line-height:42px !important;
}
.step-panel .field.full{
  min-height:auto;
}
.step-panel .field.full label,
.step-panel .field.full .label{
  min-height:auto;
}
.step-panel .choice-grid{
  margin-top:6px;
}

/* Keep compact sections readable on smaller screens */
@media(max-width:940px){
  .step-panel .field{
    min-height:auto;
  }
  .step-panel .field label{
    min-height:auto;
  }
  .step-panel .field .field-help{
    min-height:auto;
  }
  .step-panel .field label + select,
  .step-panel .field label + input{
    margin-top:0;
  }
}



/* Recommended full check card */
.module-card--full{
  grid-column:1/-1;
  background:
    radial-gradient(circle at 92% 10%,rgba(0,167,255,.14),transparent 34%),
    linear-gradient(135deg,rgba(255,23,141,.10),rgba(106,34,255,.08),rgba(0,167,255,.08));
  border-color:rgba(255,23,141,.28);
}
.module-card--full strong{
  font-size:20px;
}
.module-card--full small:after{
  content:" Recommended for the most complete result.";
  color:var(--navy);
  font-weight:400;
}
@media(max-width:940px){
  .module-card--full{
    grid-column:auto;
  }
}



/* Action-led result CTAs */
.finding-cta{
  margin-top:8px;
  padding:12px;
  border-radius:17px;
  background:linear-gradient(135deg,rgba(0,167,255,.08),rgba(255,23,141,.06));
  border:1px solid rgba(5,8,36,.08);
}
.finding-cta p{
  margin:0 0 9px !important;
  color:var(--navy) !important;
  font-size:13px !important;
  line-height:1.4 !important;
}
.mini-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 12px;
  border-radius:12px;
  color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  box-shadow:0 10px 20px rgba(255,23,141,.14);
  font-size:13px;
  font-weight:400;
}
.final-contact-actions p{
  margin:0 0 14px;
  color:var(--muted);
  font-size:14px;
  line-height:1.45;
}
.final-action-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.result-cta-actions a.btn{
  text-decoration:none;
}
@media(max-width:940px){
  .final-action-grid{
    grid-template-columns:1fr;
  }
}



/* Multi-select checkbox controls */
.choice-grid--compact{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px;
}
.choice--control{
  border-color:rgba(255,23,141,.24);
  background:linear-gradient(135deg,rgba(255,23,141,.08),rgba(0,167,255,.06));
}
.hint{
  color:var(--muted);
  font-size:12px;
  font-weight:400;
}
@media(max-width:940px){
  .choice-grid--compact{
    grid-template-columns:1fr;
  }
}



/* Finish section text checkbox lists */
.text-check-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px 18px;
  margin-top:2px;
}
.text-check-list .choice{
  min-height:0 !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  border-radius:0 !important;
  display:flex !important;
  align-items:flex-start !important;
  gap:8px !important;
  color:var(--navy);
  font-size:13.5px;
  line-height:1.3;
}
.text-check-list .choice:hover{
  transform:none !important;
  box-shadow:none !important;
}
.text-check-list .choice input{
  margin-top:2px;
  width:16px;
  height:16px;
  flex:0 0 auto;
}
.text-check-list .choice span{
  display:block;
}
.text-check-list .choice strong{
  font-size:13.5px !important;
  line-height:1.28 !important;
  font-weight:400 !important;
}
.text-check-list .choice--control{
  color:var(--purple);
}
.text-check-list .choice--control strong{
  font-weight:500 !important;
}
@media(max-width:940px){
  .text-check-list{
    grid-template-columns:1fr;
    gap:9px;
  }
}



/* Calmer finish checklist layout */
.text-check-list--calm{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:4px 18px !important;
  padding:12px 14px;
  border:1px solid rgba(5,8,36,.08);
  border-radius:18px;
  background:rgba(255,255,255,.58);
}
.text-check-list--calm .choice{
  min-height:28px !important;
  padding:2px 0 !important;
  display:grid !important;
  grid-template-columns:18px minmax(0,1fr) !important;
  align-items:start !important;
  column-gap:8px !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  transform:none !important;
  cursor:pointer;
}
.text-check-list--calm .choice:hover{
  background:rgba(255,255,255,.45) !important;
  border-radius:10px !important;
}
.text-check-list--calm .choice input{
  width:14px !important;
  height:14px !important;
  min-height:14px !important;
  margin:3px 0 0 !important;
  padding:0 !important;
  grid-column:1;
}
.text-check-list--calm .choice span{
  grid-column:2;
  display:block;
  min-width:0;
}
.text-check-list--calm .choice strong{
  display:block;
  font-size:12.8px !important;
  line-height:1.25 !important;
  font-weight:400 !important;
  color:var(--navy);
}
.text-check-list--calm .choice--control{
  min-height:26px !important;
  margin-bottom:3px;
}
.text-check-list--calm .choice--control strong{
  font-size:12.5px !important;
  font-weight:500 !important;
  color:var(--purple) !important;
}
.text-check-list--calm .choice--control input{
  accent-color:var(--purple);
}
.step-panel .field.full:has(.text-check-list--calm){
  gap:8px !important;
  margin-bottom:4px;
}
.step-panel .field.full:has(.text-check-list--calm) > label{
  min-height:0 !important;
  margin-bottom:0 !important;
}
@media(max-width:940px){
  .text-check-list--calm{
    grid-template-columns:1fr;
    gap:3px !important;
    padding:11px 12px;
  }
  .text-check-list--calm .choice{
    min-height:30px !important;
  }
}



/* Force final checklists into true inline checkbox rows */
.inline-check-list{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:7px 22px !important;
  padding:13px 15px !important;
}
.inline-check-list label.choice,
.inline-check-list .choice{
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:8px !important;
  min-height:22px !important;
  height:auto !important;
  padding:0 !important;
  margin:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  border-radius:0 !important;
  line-height:1.2 !important;
}
.inline-check-list label.choice:hover{
  background:transparent !important;
  transform:none !important;
  box-shadow:none !important;
}
.inline-check-list label.choice input[type="checkbox"]{
  position:static !important;
  display:inline-block !important;
  width:14px !important;
  height:14px !important;
  min-width:14px !important;
  min-height:14px !important;
  max-width:14px !important;
  max-height:14px !important;
  flex:0 0 14px !important;
  margin:0 !important;
  padding:0 !important;
  vertical-align:middle !important;
}
.inline-check-list label.choice span{
  display:inline !important;
  min-width:0 !important;
  margin:0 !important;
  padding:0 !important;
}
.inline-check-list label.choice strong{
  display:inline !important;
  margin:0 !important;
  padding:0 !important;
  font-size:12.8px !important;
  line-height:1.2 !important;
  font-weight:400 !important;
}
.inline-check-list label.choice.choice--control strong{
  font-weight:500 !important;
  color:var(--purple) !important;
}
@media(max-width:940px){
  .inline-check-list{
    grid-template-columns:1fr !important;
    gap:8px !important;
  }
}



/* V17 form density correction */
.step-panel .form-grid{
  gap:14px 18px !important;
}
.step-panel .field{
  min-height:auto !important;
  gap:5px !important;
}
.step-panel .field label{
  min-height:auto !important;
  line-height:1.22 !important;
  margin:0 0 2px !important;
}
.step-panel .field label + select,
.step-panel .field label + input{
  margin-top:0 !important;
}
.step-panel .field label + .field-help + select,
.step-panel .field label + .field-help + input{
  margin-top:0 !important;
}
.step-panel .field .field-help,
.step-panel .field-help{
  min-height:auto !important;
  margin:0 0 2px !important;
  font-size:10.8px !important;
  line-height:1.22 !important;
}
.step-panel .field select,
.step-panel select[data-required-when-active]{
  height:39px !important;
  min-height:39px !important;
  max-height:39px !important;
  line-height:39px !important;
}
.step-panel .field input{
  height:40px !important;
  min-height:40px !important;
}
.step-panel .field.full{
  margin-top:6px !important;
}

/* Hide duplicate ? icons when visible helper copy is already shown */
.help-tip{
  display:none !important;
}

/* Slimmer consent box at the bottom */
#consent{
  width:16px !important;
  height:16px !important;
  min-height:16px !important;
  margin-top:2px !important;
}
label.choice:has(#consent){
  min-height:0 !important;
  padding:14px 15px !important;
  display:grid !important;
  grid-template-columns:18px minmax(0,1fr) !important;
  align-items:start !important;
  gap:9px !important;
  border-radius:18px !important;
}
label.choice:has(#consent) span{
  display:block !important;
}
label.choice:has(#consent) strong{
  font-size:13px !important;
  line-height:1.25 !important;
}
label.choice:has(#consent) small{
  font-size:11.2px !important;
  line-height:1.3 !important;
  margin-top:2px !important;
}
textarea#extraNotes{
  min-height:82px !important;
}

/* Keep the final answer checklists compact and readable */
.inline-check-list{
  gap:5px 22px !important;
  padding:11px 14px !important;
}
.inline-check-list label.choice{
  min-height:21px !important;
}



/* Earlier softer conversion points */
.early-help-panel{
  margin-top:18px;
  padding:18px;
  border-radius:24px;
  background:
    radial-gradient(circle at 95% 0%,rgba(0,167,255,.14),transparent 34%),
    linear-gradient(135deg,rgba(255,23,141,.07),rgba(106,34,255,.06));
  border:1px solid rgba(255,23,141,.18);
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
}
.early-help-panel h3{
  margin:4px 0 6px;
  font-size:21px;
}
.early-help-panel p{
  margin:0;
  color:var(--muted);
  font-size:13.5px;
  line-height:1.45;
}
.early-help-actions{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-width:190px;
}
.btn-ghost{
  background:rgba(255,255,255,.7);
  color:var(--navy);
  border:1px solid rgba(5,8,36,.10);
  box-shadow:none;
}
.guidance-signup{
  margin-top:8px !important;
}
.guidance-choice{
  min-height:0 !important;
  padding:13px 15px !important;
  border-radius:18px !important;
  background:linear-gradient(135deg,rgba(0,167,255,.08),rgba(255,23,141,.05)) !important;
  border:1px solid rgba(0,167,255,.18) !important;
  display:grid !important;
  grid-template-columns:18px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
}
.guidance-choice input{
  width:15px !important;
  height:15px !important;
  min-height:15px !important;
  margin-top:2px !important;
}
.guidance-choice strong{
  font-size:13px !important;
}
.guidance-choice small{
  font-size:11.4px !important;
  line-height:1.3 !important;
}
.final-action-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.final-action-grid button.btn{
  border:0;
  cursor:pointer;
}
@media(max-width:940px){
  .early-help-panel{
    grid-template-columns:1fr;
  }
  .early-help-actions{
    min-width:0;
  }
  .final-action-grid{
    grid-template-columns:1fr;
  }
}



/* V19 result CTA polish */
.focus-contact{
  margin-top:12px;
}
.result-cta-actions--four{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:9px !important;
}
.result-cta-actions--four .btn{
  width:100%;
  min-height:44px;
  text-align:center;
  text-decoration:none;
}
.result-cta-actions--four #topSubmitLeadBtn{
  order:1;
}
.result-cta-actions--four #topContactBtn{
  order:2;
}
.result-cta-actions--four #topCopySummaryBtn{
  order:3;
}
.result-cta-actions--four #topDownloadResultBtn{
  order:4;
}
#topSubmitLeadBtn:disabled{
  opacity:1;
  background:linear-gradient(135deg,rgba(255,23,141,.86),rgba(106,34,255,.86));
  color:#fff;
}
.final-action-grid{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:10px !important;
  align-items:stretch !important;
}
.final-action-grid .btn,
.final-action-grid button.btn{
  width:100%;
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  text-decoration:none;
  border-radius:16px;
  font-family:inherit;
  line-height:1.1;
}
.final-action-grid button.btn{
  border:1px solid rgba(5,8,36,.10);
  cursor:pointer;
}
@media(max-width:940px){
  .final-action-grid{
    grid-template-columns:1fr !important;
  }
}



/* Suggested review focus CTA */
.suggested-focus-contact{
  margin-top:12px;
  width:max-content;
  max-width:100%;
}



/* V20 CTA spacing and wording polish */
.early-help-panel{
  padding:22px !important;
  gap:22px !important;
  grid-template-columns:minmax(0,1.35fr) minmax(210px,.65fr) !important;
  align-items:center !important;
  background:
    radial-gradient(circle at 96% 6%,rgba(0,167,255,.18),transparent 36%),
    linear-gradient(135deg,rgba(255,23,141,.10),rgba(106,34,255,.07),rgba(0,167,255,.08)) !important;
}
.early-help-panel .eyebrow{
  display:inline-flex !important;
  width:max-content;
  max-width:100%;
  padding:6px 10px !important;
  border-radius:999px;
  background:rgba(255,255,255,.78) !important;
  color:var(--purple) !important;
  font-size:11px !important;
  letter-spacing:.08em !important;
  font-weight:500 !important;
  text-transform:uppercase;
}
.early-help-panel h3{
  margin:10px 0 8px !important;
  font-size:22px !important;
  line-height:1.12 !important;
}
.early-help-panel p{
  max-width:620px;
  font-size:13.2px !important;
}
.early-help-actions{
  gap:10px !important;
}
.early-help-actions .btn{
  min-height:44px;
  width:100%;
  text-align:center;
  justify-content:center;
}

/* Suggested review focus CTA spacing */
.suggested-focus-contact,
.focus-contact{
  display:flex !important;
  width:100% !important;
  min-height:38px !important;
  margin-top:14px !important;
  border-radius:14px !important;
  font-size:12.5px !important;
}

/* Next step box button spacing */
.result-cta-actions--four{
  gap:10px !important;
  min-width:250px;
}
.result-cta-actions--four .btn{
  min-height:42px !important;
  padding-left:14px !important;
  padding-right:14px !important;
  line-height:1.12 !important;
}
.result-cta-actions--four #topSubmitLeadBtn{
  cursor:default;
}
.result-cta-actions--four #topContactBtn{
  font-weight:400;
}

/* Bottom action row: make each box feel intentional */
.final-action-grid{
  gap:12px !important;
}
.final-action-grid .btn,
.final-action-grid button.btn{
  min-height:46px !important;
  padding:10px 12px !important;
  white-space:normal;
}
@media(max-width:940px){
  .early-help-panel{
    grid-template-columns:1fr !important;
    padding:18px !important;
  }
  .result-cta-actions--four{
    min-width:0;
  }
}



/* V21 plain-English priority labels */
.priority-mini{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.priority-mini span{
  white-space:normal;
  line-height:1.2;
  font-size:11px;
}
.priority-mini .risk{
  background:rgba(255,74,97,.10);
  color:#a3142a;
}
.priority-mini .good{
  background:rgba(0,148,98,.10);
  color:#08724e;
}



/* V22 spacing clean-up */
.step-panel .form-grid{
  gap:12px 18px !important;
}
.step-panel .field{
  gap:4px !important;
}
.step-panel .field label{
  margin-bottom:0 !important;
}
.step-panel .field .field-help,
.step-panel .field-help{
  font-size:10.5px !important;
  line-height:1.18 !important;
  margin:0 !important;
  max-width:96%;
}
.step-panel .field select,
.step-panel select[data-required-when-active]{
  height:38px !important;
  min-height:38px !important;
  max-height:38px !important;
  line-height:38px !important;
}
.step-panel .field input{
  height:39px !important;
  min-height:39px !important;
}
.step-panel .field.full{
  margin-top:4px !important;
}
textarea#extraNotes{
  min-height:72px !important;
}

/* Make bottom finish controls read as one neat sequence */
.guidance-signup{
  margin-top:10px !important;
  margin-bottom:8px !important;
}
.guidance-choice{
  padding:11px 13px !important;
  border-radius:16px !important;
}
.guidance-choice strong{
  font-size:12.8px !important;
}
.guidance-choice small{
  font-size:10.8px !important;
  line-height:1.25 !important;
}

/* Tidy consent below guidance */
label.choice:has(#consent){
  margin-top:8px !important;
  padding:11px 13px !important;
  border-radius:16px !important;
}
label.choice:has(#consent) strong{
  font-size:12.6px !important;
}
label.choice:has(#consent) small{
  font-size:10.8px !important;
}

/* Reduce excess vertical breathing room at the foot of each step */
.step-panel{
  padding-bottom:26px !important;
}
.nav-row{
  margin-top:12px !important;
}



/* V23 real results page and loading screen */
.result-loading{
  display:none;
  max-width:980px;
  margin:0 auto;
  padding:44px 22px 70px;
}
.result-loading.active{
  display:block;
}
.result-loading-card{
  position:relative;
  overflow:hidden;
  border-radius:34px;
  padding:34px;
  background:
    radial-gradient(circle at 88% 12%,rgba(0,184,255,.28),transparent 34%),
    radial-gradient(circle at 8% 90%,rgba(235,59,139,.20),transparent 38%),
    linear-gradient(135deg,#060a32,#11145f 58%,#073a7d);
  color:#fff;
  box-shadow:0 30px 90px rgba(5,8,36,.24);
}
.result-loading-logo{
  width:168px;
  max-width:54%;
  height:auto;
  display:block;
  margin-bottom:18px;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.22));
}
.result-loading-card .eyebrow{
  background:rgba(255,255,255,.14);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
}
.result-loading-card h2{
  max-width:760px;
  margin:12px 0 12px;
  font-size:34px;
  line-height:1.05;
}
.result-loading-card p{
  max-width:760px;
  margin:0;
  color:rgba(255,255,255,.78);
  font-size:15px;
  line-height:1.55;
}
.loading-steps{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}
.loading-steps span{
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.13);
  font-size:12px;
}
.loading-bar{
  height:8px;
  margin-top:24px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  overflow:hidden;
}
.loading-bar span{
  display:block;
  height:100%;
  width:44%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--pink),var(--cyan));
  animation:loadingSweep 1.35s ease-in-out infinite;
}
@keyframes loadingSweep{
  0%{transform:translateX(-100%);}
  100%{transform:translateX(240%);}
}

/* Hide the homepage/marketing top once loading/results start */
body.is-results-ready .hero,
body.is-results-ready .hero-shell,
body.is-results-ready .hero-section,
body.is-results-ready .intro-section,
body.is-results-ready .why-section,
body.is-results-ready .trust-section,
body.is-results-ready .site-hero,
body.is-results-ready .top-section,
body.is-results-ready .marketing-section,
body.is-results-ready [data-home-section],
body.is-result-loading .hero,
body.is-result-loading .hero-shell,
body.is-result-loading .hero-section,
body.is-result-loading .intro-section,
body.is-result-loading .why-section,
body.is-result-loading .trust-section,
body.is-result-loading .site-hero,
body.is-result-loading .top-section,
body.is-result-loading .marketing-section,
body.is-result-loading [data-home-section]{
  display:none !important;
}
body.is-results-ready .result-page{
  margin-top:0 !important;
  padding-top:22px !important;
}
body.is-results-ready main,
body.is-result-loading main{
  padding-top:0 !important;
}
@media(max-width:940px){
  .result-loading{
    padding:26px 14px 46px;
  }
  .result-loading-card{
    padding:24px;
    border-radius:26px;
  }
  .result-loading-card h2{
    font-size:27px;
  }
  .result-loading-logo{
    width:140px;
  }
}



/* V24 compact grid row spacing fix */
.step-panel .form-grid{
  row-gap:9px !important;
  column-gap:18px !important;
  align-items:start !important;
}
.step-panel .field{
  min-height:0 !important;
  gap:3px !important;
}
.step-panel .field label{
  min-height:0 !important;
  margin:0 !important;
  line-height:1.18 !important;
}
.step-panel .field .field-help,
.step-panel .field-help{
  min-height:0 !important;
  margin:0 !important;
  font-size:10px !important;
  line-height:1.14 !important;
}
.step-panel .field select,
.step-panel select[data-required-when-active]{
  height:36px !important;
  min-height:36px !important;
  max-height:36px !important;
  line-height:36px !important;
  padding-top:0 !important;
  padding-bottom:0 !important;
}

/* The Cyber page has the most helper text, so it needs a tighter row rhythm */
.step-panel[data-title="Cyber"] .form-grid{
  row-gap:7px !important;
}
.step-panel[data-title="Cyber"] .field{
  gap:2px !important;
}
.step-panel[data-title="Cyber"] .field-help{
  font-size:9.8px !important;
  line-height:1.1 !important;
}
.step-panel[data-title="Cyber"] select{
  height:35px !important;
  min-height:35px !important;
  max-height:35px !important;
  line-height:35px !important;
}



/* V25 tighten guidance opt-in to match consent */
.guidance-signup{
  margin-top:8px !important;
  margin-bottom:6px !important;
}
.guidance-choice{
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  display:grid !important;
  grid-template-columns:18px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
}
.guidance-choice input,
#guidanceOptIn{
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  max-width:15px !important;
  max-height:15px !important;
  margin:1px 0 0 !important;
  padding:0 !important;
}
.guidance-choice span{
  display:block !important;
  margin:0 !important;
}
.guidance-choice strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
}
.guidance-choice small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.6px !important;
  line-height:1.22 !important;
}



/* V26 readable loading screen and softer Fredoka weights */
body{
  font-weight:300;
}
h1,h2,h3,h4,
.hero h1,
.step-panel h2,
.result-loading-card h2,
.result-section h3,
.narrative-main h3,
.result-brief-card strong,
.priority-group-card h4{
  font-weight:400 !important;
}
strong,b,label,
.btn,
button,
select,
input,
textarea,
.section-kicker,
.eyebrow{
  font-weight:400 !important;
}
.step-panel label,
.choice strong,
.module-card strong{
  font-weight:400 !important;
}
.result-loading-card{
  padding:38px !important;
}
.result-loading-card h2{
  font-size:31px !important;
  line-height:1.12 !important;
  max-width:820px !important;
  margin-bottom:14px !important;
}
.result-loading-card p{
  font-size:15.5px !important;
  line-height:1.58 !important;
  max-width:820px !important;
}
.loading-steps span{
  font-weight:300 !important;
  font-size:12.5px !important;
}
.loading-bar span{
  animation:loadingSweep 2.6s ease-in-out infinite !important;
}

/* Keep CTAs readable without going chunky */
.btn,
button.btn,
.mini-action{
  font-weight:400 !important;
}
@media(max-width:940px){
  .result-loading-card{
    padding:26px !important;
  }
  .result-loading-card h2{
    font-size:25px !important;
  }
  .result-loading-card p{
    font-size:14px !important;
  }
}



/* V27 fix Cyber grid dead-space caused by wrapped helper text */
.step-panel[data-title="Cyber"] .form-grid{
  display:block !important;
  column-count:2;
  column-gap:18px;
}
.step-panel[data-title="Cyber"] .form-grid .field{
  display:flex !important;
  break-inside:avoid;
  page-break-inside:avoid;
  margin:0 0 10px !important;
  width:100%;
  min-height:0 !important;
}
.step-panel[data-title="Cyber"] .form-grid .field.full{
  column-span:all;
  margin-top:12px !important;
}
.step-panel[data-title="Cyber"] .field label{
  margin:0 0 2px !important;
  min-height:0 !important;
}
.step-panel[data-title="Cyber"] .field-help{
  margin:0 0 3px !important;
  min-height:0 !important;
  font-size:10px !important;
  line-height:1.14 !important;
}
.step-panel[data-title="Cyber"] select{
  height:36px !important;
  min-height:36px !important;
  max-height:36px !important;
}
@media(max-width:940px){
  .step-panel[data-title="Cyber"] .form-grid{
    column-count:1;
  }
}



/* V28b hard Cyber layout fix and longer loading */
.step-panel[data-title="Cyber"] .form-grid{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:12px 18px !important;
  align-items:start !important;
  column-count:initial !important;
}
.step-panel[data-title="Cyber"] .cyber-column{
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  min-width:0 !important;
}
.step-panel[data-title="Cyber"] .cyber-column .field{
  margin:0 !important;
  min-height:0 !important;
}
.step-panel[data-title="Cyber"] .field.full{
  grid-column:1/-1 !important;
}
.step-panel[data-title="Cyber"] .field label{
  min-height:0 !important;
  margin:0 0 2px !important;
  line-height:1.16 !important;
}
.step-panel[data-title="Cyber"] .field-help{
  min-height:0 !important;
  margin:0 0 3px !important;
  font-size:9.8px !important;
  line-height:1.1 !important;
}
.step-panel[data-title="Cyber"] select{
  height:35px !important;
  min-height:35px !important;
  max-height:35px !important;
  line-height:35px !important;
}
.loading-bar span{
  animation-duration:4.8s !important;
}
@media(max-width:940px){
  .step-panel[data-title="Cyber"] .form-grid{
    grid-template-columns:1fr !important;
  }
}



/* V29 side-by-side guidance opt-in and rolling loading screen */
.guidance-signup{
  margin-top:8px !important;
  margin-bottom:6px !important;
}
.guidance-choice{
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:9px !important;
}
.guidance-choice input,
#guidanceOptIn{
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  max-width:15px !important;
  max-height:15px !important;
  flex:0 0 15px !important;
  margin:0 !important;
  padding:0 !important;
}
.guidance-choice span{
  display:block !important;
  margin:0 !important;
  min-width:0 !important;
}
.guidance-choice strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.18 !important;
}
.guidance-choice small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.6px !important;
  line-height:1.2 !important;
}

/* Rolling loader */
.loading-spinner-wrap{
  margin-top:24px;
  display:grid;
  grid-template-columns:46px minmax(0,1fr);
  gap:14px;
  align-items:center;
}
.loading-spinner{
  width:42px;
  height:42px;
  border-radius:50%;
  border:4px solid rgba(255,255,255,.20);
  border-top-color:var(--cyan);
  border-right-color:var(--pink);
  animation:tcwSpin 1.1s linear infinite;
  box-shadow:0 0 24px rgba(0,184,255,.20);
}
@keyframes tcwSpin{
  to{transform:rotate(360deg);}
}
.loading-message-window{
  height:48px;
  overflow:hidden;
  border-radius:18px;
  background:rgba(255,255,255,.11);
  border:1px solid rgba(255,255,255,.14);
}
.loading-message-track{
  display:flex;
  flex-direction:column;
  animation:tcwLoadingMessages 4.8s ease-in-out infinite;
}
.loading-message-track span{
  min-height:48px;
  display:flex;
  align-items:center;
  padding:0 14px;
  color:rgba(255,255,255,.88);
  font-size:13.5px;
  line-height:1.25;
  font-weight:300 !important;
}
@keyframes tcwLoadingMessages{
  0%,25%{transform:translateY(0);}
  36%,60%{transform:translateY(-48px);}
  72%,100%{transform:translateY(-96px);}
}
.loading-bar,
.loading-steps{
  display:none !important;
}
@media(max-width:940px){
  .loading-spinner-wrap{
    grid-template-columns:38px minmax(0,1fr);
    gap:11px;
  }
  .loading-spinner{
    width:34px;
    height:34px;
    border-width:3px;
  }
  .loading-message-track span{
    font-size:12.5px;
  }
}



/* V30 loader, inline required stars, guidance alignment and next-step cleanup */

/* Simple loading state: round logo, no big advert card */
.result-loading--simple{
  display:none;
  max-width:720px;
  margin:0 auto;
  padding:56px 22px 80px;
  text-align:center;
}
.result-loading--simple.active{
  display:block;
}
.round-logo-loader{
  width:118px;
  height:118px;
  margin:0 auto 18px;
  border-radius:50%;
  display:grid;
  place-items:center;
  position:relative;
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(239,249,255,.92));
  box-shadow:0 22px 60px rgba(5,8,36,.16);
}
.round-logo-loader:before{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:50%;
  border:4px solid rgba(0,184,255,.14);
  border-top-color:var(--pink);
  border-right-color:var(--cyan);
  animation:tcwSpin 1.1s linear infinite;
}
.round-logo-loader img{
  width:78px;
  max-width:72%;
  height:auto;
  display:block;
}
.loading-main{
  margin:0 0 14px;
  font-size:22px;
  line-height:1.2;
  color:var(--navy);
  font-weight:400;
}
.plain-loading-lines{
  height:26px;
  max-width:690px;
  margin:0 auto;
  overflow:hidden;
  color:var(--muted);
  font-size:14px;
  line-height:26px;
}
.plain-loading-lines span{
  display:block;
  height:26px;
  animation:plainLoadingScroll 4.8s ease-in-out infinite;
}
@keyframes plainLoadingScroll{
  0%,25%{transform:translateY(0);}
  36%,60%{transform:translateY(-26px);}
  72%,100%{transform:translateY(-52px);}
}

/* Keep required asterisk attached to the question */
.required-star{
  display:inline-block;
  white-space:nowrap;
  margin-left:2px;
}

/* Guidance opt-in should line up like the consent row */
.consent-style-choice,
.guidance-choice.consent-style-choice,
label.choice:has(#consent){
  display:grid !important;
  grid-template-columns:18px minmax(0,1fr) !important;
  align-items:start !important;
  gap:9px !important;
  min-height:0 !important;
  padding:11px 13px !important;
  border-radius:16px !important;
}
.consent-style-choice input,
.guidance-choice.consent-style-choice input,
#guidanceOptIn,
#consent{
  grid-column:1 !important;
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  max-width:15px !important;
  max-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}
.consent-style-choice span,
.guidance-choice.consent-style-choice span,
label.choice:has(#consent) span{
  grid-column:2 !important;
  display:block !important;
  margin:0 !important;
}
.consent-style-choice strong,
.guidance-choice.consent-style-choice strong,
label.choice:has(#consent) strong{
  display:block !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
  margin:0 !important;
}
.consent-style-choice small,
.guidance-choice.consent-style-choice small,
label.choice:has(#consent) small{
  display:block !important;
  font-size:10.7px !important;
  line-height:1.24 !important;
  margin-top:1px !important;
}

/* Clean the top result next-step box */
.result-cta{
  padding:22px !important;
  border-radius:25px !important;
}
.result-cta h3{
  font-size:24px !important;
  line-height:1.12 !important;
  margin-bottom:8px !important;
}
.result-cta p{
  font-size:13.2px !important;
  line-height:1.42 !important;
  margin-bottom:12px !important;
}
.result-cta strong{
  display:block;
  margin-top:8px;
  font-size:14px !important;
}
.result-cta small{
  display:block;
  margin-top:4px;
  font-size:11.8px !important;
  line-height:1.32 !important;
}
.result-cta-actions--four{
  gap:8px !important;
}
.result-cta-actions--four .btn{
  min-height:39px !important;
  border-radius:15px !important;
  font-size:13px !important;
  line-height:1.1 !important;
}
@media(max-width:940px){
  .round-logo-loader{
    width:96px;
    height:96px;
  }
  .round-logo-loader img{
    width:64px;
  }
  .loading-main{
    font-size:19px;
  }
  .plain-loading-lines{
    font-size:12.8px;
  }
}



/* V31 hard alignment fixes */

/* Guidance and consent: true side-by-side rows */
.guidance-inline-row,
.consent-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,23,141,.24);
  background:linear-gradient(135deg,rgba(239,249,255,.78),rgba(255,241,250,.78));
}
.guidance-inline-row input,
.consent-inline-row input{
  grid-column:1 !important;
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  max-width:15px !important;
  max-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}
.guidance-inline-copy,
.consent-inline-copy{
  grid-column:2 !important;
  display:block !important;
  min-width:0 !important;
  margin:0 !important;
}
.guidance-inline-copy strong,
.consent-inline-copy strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
  font-weight:400 !important;
}
.guidance-inline-copy small,
.consent-inline-copy small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.7px !important;
  line-height:1.22 !important;
  color:var(--muted);
}

/* Required star stays attached visually */
.required-star{
  display:inline !important;
  white-space:nowrap !important;
  margin-left:0 !important;
}

/* Compact all labels slightly so required stars do not fall away */
.step-panel .field label{
  font-size:13px !important;
  line-height:1.16 !important;
  letter-spacing:-.01em;
}
.step-panel .field-help{
  font-size:9.6px !important;
  line-height:1.08 !important;
  margin-top:0 !important;
}

/* Cyber section hard layout */
.step-panel[data-title="Cyber"] .form-grid{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:9px 18px !important;
  align-items:start !important;
  column-count:initial !important;
}
.step-panel[data-title="Cyber"] .cyber-column{
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
}
.step-panel[data-title="Cyber"] .field{
  min-height:0 !important;
  margin:0 !important;
  gap:2px !important;
}
.step-panel[data-title="Cyber"] .field label{
  font-size:12.8px !important;
  line-height:1.12 !important;
}
.step-panel[data-title="Cyber"] .field-help{
  font-size:9.2px !important;
  line-height:1.04 !important;
  max-width:100% !important;
}
.step-panel[data-title="Cyber"] select{
  height:34px !important;
  min-height:34px !important;
  max-height:34px !important;
  line-height:34px !important;
}
@media(max-width:940px){
  .step-panel[data-title="Cyber"] .form-grid{
    grid-template-columns:1fr !important;
  }
}



/* V32 restore consent and widen working area */
:root{
  --health-check-max-width:1260px;
}

/* Widen the main app shell/card area */
.health-check-shell,
.check-shell,
.app-shell,
.page-shell,
.health-check-app,
.check-layout,
.form-shell,
.form-wrap,
.main-card,
.wizard-shell,
.wizard-layout,
main > .container{
  max-width:1260px !important;
}

/* The two-column wizard needs more horizontal room */
.wizard,
.health-check-grid,
.check-grid,
.form-layout{
  max-width:1260px !important;
  grid-template-columns:minmax(230px,280px) minmax(0,1fr) !important;
  gap:22px !important;
}

/* Main question panel should breathe */
.step-panel{
  max-width:none !important;
  padding-left:34px !important;
  padding-right:34px !important;
}
.step-panel .form-grid{
  grid-template-columns:repeat(2,minmax(300px,1fr)) !important;
  column-gap:22px !important;
  row-gap:12px !important;
}

/* Widen result area too */
.result-wrap,
.result-page{
  max-width:1120px !important;
}

/* Restore and tidy consent */
.consent-field{
  margin-top:10px !important;
  margin-bottom:8px !important;
}
.consent-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  min-height:0 !important;
  padding:11px 13px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,23,141,.28) !important;
  background:linear-gradient(135deg,rgba(239,249,255,.82),rgba(255,241,250,.82)) !important;
}
.consent-inline-row input,
#consent{
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}
.consent-inline-copy{
  display:block !important;
  min-width:0 !important;
}
.consent-inline-copy strong{
  display:block !important;
  margin:0 !important;
  font-size:12.7px !important;
  line-height:1.22 !important;
  font-weight:400 !important;
}
.consent-inline-copy small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.7px !important;
  line-height:1.24 !important;
  color:var(--muted);
}

/* Guidance should be aligned but not squeezed */
.guidance-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  padding:11px 13px !important;
}
.guidance-inline-row input,
#guidanceOptIn{
  margin:2px 0 0 !important;
}
.guidance-inline-copy strong{
  font-size:12.7px !important;
  line-height:1.22 !important;
}
.guidance-inline-copy small{
  font-size:10.7px !important;
  line-height:1.24 !important;
}

/* Cyber section: use the wider card rather than crushing text */
.step-panel[data-title="Cyber"] .form-grid{
  grid-template-columns:1fr 1fr !important;
  column-gap:24px !important;
  row-gap:12px !important;
}
.step-panel[data-title="Cyber"] .cyber-column{
  gap:10px !important;
}
.step-panel[data-title="Cyber"] .field label{
  font-size:13px !important;
  line-height:1.18 !important;
}
.step-panel[data-title="Cyber"] .field-help{
  font-size:9.8px !important;
  line-height:1.12 !important;
}
.step-panel[data-title="Cyber"] select{
  height:36px !important;
  min-height:36px !important;
  max-height:36px !important;
}

@media(max-width:940px){
  .wizard,
  .health-check-grid,
  .check-grid,
  .form-layout{
    grid-template-columns:1fr !important;
  }
  .step-panel{
    padding-left:20px !important;
    padding-right:20px !important;
  }
  .step-panel .form-grid,
  .step-panel[data-title="Cyber"] .form-grid{
    grid-template-columns:1fr !important;
  }
}



/* V33 consent placement and result CTA cleanup */

/* Pull the working area back from 'too wide' */
.health-check-shell,
.check-shell,
.app-shell,
.page-shell,
.health-check-app,
.check-layout,
.form-shell,
.form-wrap,
.main-card,
.wizard-shell,
.wizard-layout,
main > .container{
  max-width:1160px !important;
}
.wizard,
.health-check-grid,
.check-grid,
.form-layout{
  max-width:1160px !important;
  grid-template-columns:minmax(230px,270px) minmax(0,1fr) !important;
  gap:20px !important;
}
.step-panel{
  padding-left:30px !important;
  padding-right:30px !important;
}
.step-panel .form-grid{
  grid-template-columns:repeat(2,minmax(275px,1fr)) !important;
  column-gap:20px !important;
  row-gap:12px !important;
}

/* Consent only belongs on Finish, styled slimly */
.consent-field{
  margin-top:10px !important;
  margin-bottom:8px !important;
}
.consent-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,23,141,.28) !important;
  background:linear-gradient(135deg,rgba(239,249,255,.82),rgba(255,241,250,.82)) !important;
}
.consent-inline-row input,
#consent{
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  max-width:15px !important;
  max-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}
.consent-inline-copy{
  display:block !important;
  min-width:0 !important;
}
.consent-inline-copy strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
  font-weight:400 !important;
}
.consent-inline-copy small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.7px !important;
  line-height:1.24 !important;
  color:var(--muted);
}

/* Clean and contain the Next Step card */
.result-cta{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(230px,300px) !important;
  gap:22px !important;
  align-items:start !important;
  overflow:hidden !important;
  padding:22px !important;
}
.result-cta > div:first-child{
  min-width:0 !important;
}
.result-cta-actions,
.result-cta-actions--four{
  width:100% !important;
  max-width:300px !important;
  min-width:0 !important;
  justify-self:end !important;
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:8px !important;
}
.result-cta-actions .btn,
.result-cta-actions--four .btn,
.result-cta-actions button,
.result-cta-actions--four button{
  width:100% !important;
  max-width:100% !important;
  min-height:38px !important;
  padding:9px 12px !important;
  border-radius:14px !important;
  line-height:1.12 !important;
  white-space:normal !important;
  text-align:center !important;
  box-sizing:border-box !important;
  font-size:12.7px !important;
}
#topContactBtn{
  font-size:12.4px !important;
}
@media(max-width:940px){
  .wizard,
  .health-check-grid,
  .check-grid,
  .form-layout{
    grid-template-columns:1fr !important;
  }
  .step-panel{
    padding-left:20px !important;
    padding-right:20px !important;
  }
  .step-panel .form-grid{
    grid-template-columns:1fr !important;
  }
  .result-cta{
    grid-template-columns:1fr !important;
  }
  .result-cta-actions,
  .result-cta-actions--four{
    max-width:none !important;
    justify-self:stretch !important;
  }
}



/* V34 consent only on Finish + result CTA wording support */
.step-panel:not([data-title="Finish"]) .consent-field,
.step-panel:not([data-title="Finish"]) #consent{
  display:none !important;
}
.step-panel[data-title="Finish"] .consent-field{
  margin-top:10px !important;
  margin-bottom:10px !important;
}
.step-panel[data-title="Finish"] .consent-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,23,141,.28) !important;
  background:linear-gradient(135deg,rgba(239,249,255,.82),rgba(255,241,250,.82)) !important;
}
.step-panel[data-title="Finish"] #consent{
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}
.step-panel[data-title="Finish"] .consent-inline-copy strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
  font-weight:400 !important;
}
.step-panel[data-title="Finish"] .consent-inline-copy small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.7px !important;
  line-height:1.24 !important;
  color:var(--muted);
}



/* V35 result page should not show the homepage/hero top */
body.result-only-view [data-result-hide],
body.is-results-ready [data-result-hide],
body.is-result-loading [data-result-hide]{
  display:none !important;
}

/* Also catch the real top blocks by structure if the data attribute misses */
body.result-only-view main > section:first-of-type,
body.is-results-ready main > section:first-of-type,
body.is-result-loading main > section:first-of-type{
  display:none !important;
}

/* Keep the actual result/loading sections visible even if they are first sections */
body.result-only-view #resultWrap,
body.is-results-ready #resultWrap,
body.is-result-loading #resultLoading{
  display:block !important;
}

/* Pull report up so it feels like a report page, not a page continuation */
body.result-only-view #resultWrap,
body.is-results-ready #resultWrap{
  margin-top:0 !important;
  padding-top:24px !important;
}
body.result-only-view .result-wrap,
body.is-results-ready .result-wrap{
  max-width:1120px !important;
}

/* Hide big marketing cards above the wizard/results when in result state */
body.result-only-view .hero,
body.result-only-view .hero-shell,
body.result-only-view .hero-section,
body.result-only-view .intro-grid,
body.result-only-view .intro-cards,
body.result-only-view .feature-grid,
body.result-only-view .marketing-grid,
body.result-only-view .worth-grid,
body.result-only-view .proof-grid,
body.is-results-ready .hero,
body.is-results-ready .hero-shell,
body.is-results-ready .hero-section,
body.is-results-ready .intro-grid,
body.is-results-ready .intro-cards,
body.is-results-ready .feature-grid,
body.is-results-ready .marketing-grid,
body.is-results-ready .worth-grid,
body.is-results-ready .proof-grid{
  display:none !important;
}



/* V36 true report page mode */
.hide-before-result{
  display:none !important;
}
body.result-only-view [data-result-hide],
body.is-results-ready [data-result-hide],
body.is-result-loading [data-result-hide]{
  display:none !important;
}
body.result-only-view #resultWrap,
body.is-results-ready #resultWrap{
  display:block !important;
  margin-top:0 !important;
  padding-top:24px !important;
}
body.result-only-view .wizard-shell,
body.is-results-ready .wizard-shell,
body.result-only-view .wizard-layout,
body.is-results-ready .wizard-layout{
  display:block !important;
}

/* Report header to make the result feel generated/special */
.result-report-header{
  margin:0 0 20px;
  padding:22px;
  border-radius:26px;
  background:
    radial-gradient(circle at 92% 10%,rgba(0,184,255,.16),transparent 34%),
    linear-gradient(135deg,rgba(6,10,50,.98),rgba(16,20,95,.96));
  color:#fff;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  align-items:center;
  box-shadow:0 24px 70px rgba(5,8,36,.18);
}
.result-report-header .eyebrow{
  color:#fff !important;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
}
.result-report-header h2{
  margin:8px 0 6px;
  font-size:30px;
  line-height:1.08;
  font-weight:400;
}
.result-report-header p{
  margin:0;
  color:rgba(255,255,255,.78);
  font-size:13.5px;
  line-height:1.45;
}
.report-header-actions{
  min-width:250px;
}
.report-header-actions .btn{
  width:100%;
  min-height:42px;
  text-align:center;
  text-decoration:none;
}

/* Consent belongs only on Finish */
.step-panel:not([data-title="Finish"]) .consent-field,
.step-panel:not([data-title="Finish"]) #consent{
  display:none !important;
}
.step-panel[data-title="Finish"] .consent-field{
  margin-top:10px !important;
  margin-bottom:10px !important;
}
.step-panel[data-title="Finish"] .consent-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,23,141,.28) !important;
  background:linear-gradient(135deg,rgba(239,249,255,.82),rgba(255,241,250,.82)) !important;
}
.step-panel[data-title="Finish"] #consent{
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}
.step-panel[data-title="Finish"] .consent-inline-copy strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
  font-weight:400 !important;
}
.step-panel[data-title="Finish"] .consent-inline-copy small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.7px !important;
  line-height:1.24 !important;
  color:var(--muted);
}
@media(max-width:940px){
  .result-report-header{
    grid-template-columns:1fr;
  }
  .report-header-actions{
    min-width:0;
  }
}



/* V37 clean report result page and Finish-only consent */

/* Result mode: make it an actual report page, not the wizard layout */
body.result-only-view .sidebar,
body.result-only-view .side-card,
body.result-only-view .steps,
body.result-only-view .wizard-sidebar,
body.result-only-view aside,
body.is-results-ready .sidebar,
body.is-results-ready .side-card,
body.is-results-ready .steps,
body.is-results-ready .wizard-sidebar,
body.is-results-ready aside{
  display:none !important;
}

body.result-only-view .wizard,
body.result-only-view .wizard-layout,
body.result-only-view .health-check-grid,
body.result-only-view .check-grid,
body.result-only-view .form-layout,
body.is-results-ready .wizard,
body.is-results-ready .wizard-layout,
body.is-results-ready .health-check-grid,
body.is-results-ready .check-grid,
body.is-results-ready .form-layout{
  display:block !important;
  max-width:1120px !important;
  margin:0 auto !important;
}

body.result-only-view #healthCheckForm,
body.result-only-view form,
body.is-results-ready #healthCheckForm,
body.is-results-ready form{
  display:none !important;
}

body.result-only-view #resultWrap,
body.is-results-ready #resultWrap{
  display:block !important;
  width:100% !important;
  max-width:1120px !important;
  margin:0 auto !important;
  padding:28px 18px 60px !important;
}

body.result-only-view .result-wrap,
body.is-results-ready .result-wrap{
  width:100% !important;
  max-width:1120px !important;
}

/* Hide all marketing/top sections once result has been generated */
body.result-only-view [data-result-hide],
body.is-results-ready [data-result-hide],
body.result-only-view .hero,
body.result-only-view .hero-shell,
body.result-only-view .hero-section,
body.result-only-view .intro-grid,
body.result-only-view .intro-cards,
body.result-only-view .feature-grid,
body.result-only-view .marketing-grid,
body.result-only-view .worth-grid,
body.result-only-view .proof-grid,
body.is-results-ready .hero,
body.is-results-ready .hero-shell,
body.is-results-ready .hero-section,
body.is-results-ready .intro-grid,
body.is-results-ready .intro-cards,
body.is-results-ready .feature-grid,
body.is-results-ready .marketing-grid,
body.is-results-ready .worth-grid,
body.is-results-ready .proof-grid{
  display:none !important;
}

/* Remove broken report header if an older cached DOM version still has it */
.result-report-header{
  display:none !important;
}

/* Consent only on Finish */
.step-panel:not([data-title="Finish"]) .consent-field,
.step-panel:not([data-title="Finish"]) #consent{
  display:none !important;
}
.step-panel[data-title="Finish"] .consent-field{
  margin-top:10px !important;
  margin-bottom:10px !important;
}
.step-panel[data-title="Finish"] .consent-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,23,141,.28) !important;
  background:linear-gradient(135deg,rgba(239,249,255,.82),rgba(255,241,250,.82)) !important;
}
.step-panel[data-title="Finish"] #consent{
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}
.step-panel[data-title="Finish"] .consent-inline-copy strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
  font-weight:400 !important;
}
.step-panel[data-title="Finish"] .consent-inline-copy small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.7px !important;
  line-height:1.24 !important;
  color:var(--muted);
}

/* Next-step box: contain the right-hand buttons */
.result-cta{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(230px,300px) !important;
  gap:22px !important;
  align-items:start !important;
  overflow:hidden !important;
}
.result-cta-actions,
.result-cta-actions--four{
  width:100% !important;
  max-width:300px !important;
  justify-self:end !important;
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:8px !important;
}
.result-cta-actions .btn,
.result-cta-actions--four .btn,
.result-cta-actions button,
.result-cta-actions--four button{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
  white-space:normal !important;
}
@media(max-width:940px){
  body.result-only-view #resultWrap,
  body.is-results-ready #resultWrap{
    padding:20px 12px 44px !important;
  }
  .result-cta{
    grid-template-columns:1fr !important;
  }
  .result-cta-actions,
  .result-cta-actions--four{
    max-width:none !important;
    justify-self:stretch !important;
  }
}



/* V38 force result into full-width report layout */
body.result-report-mode,
body.result-only-view,
body.is-results-ready{
  overflow-x:hidden;
}

/* Collapse the old wizard/grid layout completely when showing results */
body.result-report-mode .wizard,
body.result-report-mode .wizard-layout,
body.result-report-mode .health-check-grid,
body.result-report-mode .check-grid,
body.result-report-mode .form-layout,
body.result-report-mode .health-check-shell,
body.result-report-mode .check-shell,
body.result-report-mode .app-shell,
body.result-report-mode .page-shell,
body.result-report-mode .health-check-app,
body.result-report-mode .form-shell,
body.result-report-mode .form-wrap,
body.result-report-mode .main-card{
  display:block !important;
  width:100% !important;
  max-width:1180px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  grid-template-columns:none !important;
}

/* Hide wizard navigation/sidebar during the result */
body.result-report-mode .sidebar,
body.result-report-mode .side-card,
body.result-report-mode .steps,
body.result-report-mode .wizard-sidebar,
body.result-report-mode aside,
body.result-report-mode #healthCheckForm,
body.result-report-mode form,
body.result-report-mode .nav-row{
  display:none !important;
}

/* The result wrapper itself becomes the report container */
body.result-report-mode #resultWrap,
body.result-report-mode .result-wrap,
body.result-report-mode .result-report-clean,
body.is-results-ready #resultWrap,
body.is-results-ready .result-wrap{
  display:block !important;
  width:100% !important;
  max-width:1180px !important;
  min-width:0 !important;
  margin:0 auto !important;
  padding:30px 22px 70px !important;
  box-sizing:border-box !important;
  grid-column:1 / -1 !important;
}

/* If any result internals inherited narrow/column sizing, release them */
body.result-report-mode #resultWrap > *,
body.result-report-mode .result-wrap > *,
body.result-report-mode .result-report-clean > *{
  max-width:100% !important;
  box-sizing:border-box !important;
}

/* Keep result header/summary in a proper two-column report where intended */
body.result-report-mode .result-hero,
body.result-report-mode .result-top,
body.result-report-mode .result-summary,
body.result-report-mode .result-overview,
body.result-report-mode .result-narrative{
  width:100% !important;
}

/* Priority cards/results should use available space */
body.result-report-mode .priority-grid,
body.result-report-mode .priority-groups,
body.result-report-mode .grouped-priorities,
body.result-report-mode .result-card-grid,
body.result-report-mode .score-grid{
  width:100% !important;
}

/* Do not let suggested review card turn into a skinny vertical strip */
body.result-report-mode .suggested-focus,
body.result-report-mode .focus-card,
body.result-report-mode .review-focus{
  width:100% !important;
  min-width:0 !important;
}

/* Hide marketing/homepage sections above result */
body.result-report-mode [data-result-hide],
body.result-report-mode .hero,
body.result-report-mode .hero-shell,
body.result-report-mode .hero-section,
body.result-report-mode .intro-grid,
body.result-report-mode .intro-cards,
body.result-report-mode .feature-grid,
body.result-report-mode .marketing-grid,
body.result-report-mode .worth-grid,
body.result-report-mode .proof-grid{
  display:none !important;
}

@media(max-width:940px){
  body.result-report-mode #resultWrap,
  body.result-report-mode .result-wrap,
  body.result-report-mode .result-report-clean{
    padding:22px 12px 48px !important;
  }
}


/* V39 LIVE FILE REPAIR - clean result layout, Finish-only consent, no inherited wizard trap */
body.result-report-mode [data-result-hide],
body.result-report-mode .hero,
body.result-report-mode .tcw-proof-reset,
body.is-results-ready [data-result-hide],
body.is-results-ready .hero,
body.is-results-ready .tcw-proof-reset,
body.is-result-loading [data-result-hide],
body.is-result-loading .hero,
body.is-result-loading .tcw-proof-reset{
  display:none !important;
}

body.result-report-mode .main,
body.is-results-ready .main,
body.is-result-loading .main{
  padding-top:28px !important;
}

body.result-report-mode .app-shell,
body.is-results-ready .app-shell{
  display:block !important;
  width:min(1180px, calc(100% - 44px)) !important;
  max-width:1180px !important;
  margin:0 auto !important;
}

body.result-report-mode .side,
body.is-results-ready .side{
  display:none !important;
}

body.result-report-mode .card,
body.is-results-ready .card{
  display:block !important;
  width:100% !important;
  max-width:1180px !important;
  margin:0 auto !important;
  padding:0 !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  overflow:visible !important;
}

body.result-report-mode .progress,
body.is-results-ready .progress,
body.result-report-mode #healthCheckForm,
body.is-results-ready #healthCheckForm,
body.result-report-mode #navRow,
body.is-results-ready #navRow{
  display:none !important;
}

body.result-report-mode #resultWrap,
body.is-results-ready #resultWrap{
  display:block !important;
  width:100% !important;
  max-width:1180px !important;
  margin:0 auto !important;
  padding:0 0 64px !important;
  box-sizing:border-box !important;
}

.result-inner-report{
  width:100% !important;
  max-width:1180px !important;
  margin:0 auto !important;
}

body.result-report-mode .result-hero,
body.is-results-ready .result-hero{
  display:grid !important;
  grid-template-columns:270px minmax(0,1fr) !important;
  gap:26px !important;
  align-items:stretch !important;
  padding:24px !important;
  border-radius:34px !important;
  background:
    radial-gradient(circle at 95% 8%, rgba(0,167,255,.14), transparent 34%),
    radial-gradient(circle at 8% 94%, rgba(255,23,141,.10), transparent 36%),
    linear-gradient(180deg, #fff, #fbfcff) !important;
  border:1px solid rgba(5,8,36,.09) !important;
  box-shadow:0 28px 76px rgba(5,8,36,.12) !important;
}

body.result-report-mode .score-card,
body.is-results-ready .score-card{
  min-height:100% !important;
}

body.result-report-mode .result-copy,
body.is-results-ready .result-copy{
  min-width:0 !important;
  align-self:center !important;
}

body.result-report-mode .narrative-summary,
body.is-results-ready .narrative-summary{
  display:grid !important;
  grid-template-columns:minmax(0,1.35fr) minmax(270px,.65fr) !important;
  gap:16px !important;
  width:100% !important;
}

body.result-report-mode .result-brief,
body.is-results-ready .result-brief{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:12px !important;
}

body.result-report-mode .priority-group-grid,
body.is-results-ready .priority-group-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:14px !important;
}

body.result-report-mode .result-cta-card,
body.is-results-ready .result-cta-card{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(240px,310px) !important;
  gap:22px !important;
  align-items:start !important;
  width:100% !important;
  overflow:hidden !important;
}

body.result-report-mode .result-cta-actions,
body.result-report-mode .result-cta-actions--four,
body.is-results-ready .result-cta-actions,
body.is-results-ready .result-cta-actions--four{
  width:100% !important;
  max-width:310px !important;
  justify-self:end !important;
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:8px !important;
}

body.result-report-mode .result-cta-actions .btn,
body.result-report-mode .result-cta-actions--four .btn,
body.is-results-ready .result-cta-actions .btn,
body.is-results-ready .result-cta-actions--four .btn{
  width:100% !important;
  max-width:100% !important;
  min-height:40px !important;
  padding:9px 12px !important;
  white-space:normal !important;
  box-sizing:border-box !important;
}

.step-panel:not([data-title="Finish"]) .consent-field,
.step-panel:not([data-title="Finish"]) #consent{
  display:none !important;
}

.step-panel[data-title="Finish"] .consent-field{
  display:block !important;
  grid-column:1 / -1 !important;
  margin:10px 0 6px !important;
}

.step-panel[data-title="Finish"] .consent-inline-row{
  display:grid !important;
  grid-template-columns:16px minmax(0,1fr) !important;
  gap:9px !important;
  align-items:start !important;
  min-height:0 !important;
  padding:10px 13px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,23,141,.28) !important;
  background:linear-gradient(135deg,rgba(239,249,255,.82),rgba(255,241,250,.82)) !important;
}

.step-panel[data-title="Finish"] #consent{
  display:block !important;
  width:15px !important;
  height:15px !important;
  min-width:15px !important;
  min-height:15px !important;
  max-width:15px !important;
  max-height:15px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
}

.step-panel[data-title="Finish"] .consent-inline-copy strong{
  display:block !important;
  margin:0 !important;
  font-size:12.6px !important;
  line-height:1.22 !important;
  font-weight:400 !important;
}

.step-panel[data-title="Finish"] .consent-inline-copy small{
  display:block !important;
  margin-top:1px !important;
  font-size:10.7px !important;
  line-height:1.24 !important;
  color:var(--muted) !important;
}

body:not(.result-report-mode) .app-shell{
  display:grid !important;
  grid-template-columns:300px minmax(0,1fr) !important;
  gap:22px !important;
  align-items:start !important;
}

body:not(.result-report-mode) .card{
  border-radius:32px !important;
  overflow:hidden !important;
}

@media(max-width:940px){
  body.result-report-mode .app-shell,
  body.is-results-ready .app-shell,
  body.result-report-mode #resultWrap,
  body.is-results-ready #resultWrap{
    width:min(100% - 28px, 1180px) !important;
  }

  body.result-report-mode .result-hero,
  body.is-results-ready .result-hero,
  body.result-report-mode .narrative-summary,
  body.is-results-ready .narrative-summary,
  body.result-report-mode .result-brief,
  body.is-results-ready .result-brief,
  body.result-report-mode .priority-group-grid,
  body.is-results-ready .priority-group-grid,
  body.result-report-mode .result-cta-card,
  body.is-results-ready .result-cta-card{
    grid-template-columns:1fr !important;
  }

  body.result-report-mode .result-cta-actions,
  body.result-report-mode .result-cta-actions--four,
  body.is-results-ready .result-cta-actions,
  body.is-results-ready .result-cta-actions--four{
    max-width:none !important;
    justify-self:stretch !important;
  }
}


/* V40 result-mode failsafe - if resultWrap is active, force true report mode */
.card:has(#resultWrap.active){
  display:block !important;
  width:100% !important;
  max-width:1180px !important;
  margin:0 auto !important;
  padding:0 !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  overflow:visible !important;
}
.app-shell:has(#resultWrap.active){
  display:block !important;
  width:min(1180px, calc(100% - 44px)) !important;
  max-width:1180px !important;
  margin:0 auto !important;
}
.app-shell:has(#resultWrap.active) .side,
.card:has(#resultWrap.active) .progress,
.card:has(#resultWrap.active) #healthCheckForm,
.card:has(#resultWrap.active) #navRow{
  display:none !important;
}
.card:has(#resultWrap.active) #resultWrap{
  display:block !important;
  width:100% !important;
  max-width:1180px !important;
  margin:0 auto !important;
  padding:0 0 64px !important;
}
.card:has(#resultWrap.active) .result-inner-report{
  width:100% !important;
  max-width:1180px !important;
  margin:0 auto !important;
}
.card:has(#resultWrap.active) .result-hero{
  display:grid !important;
  grid-template-columns:270px minmax(0,1fr) !important;
  gap:26px !important;
  padding:24px !important;
  border-radius:34px !important;
  background:
    radial-gradient(circle at 95% 8%, rgba(0,167,255,.14), transparent 34%),
    radial-gradient(circle at 8% 94%, rgba(255,23,141,.10), transparent 36%),
    linear-gradient(180deg, #fff, #fbfcff) !important;
  border:1px solid rgba(5,8,36,.09) !important;
  box-shadow:0 28px 76px rgba(5,8,36,.12) !important;
}
@media(max-width:940px){
  .card:has(#resultWrap.active) .result-hero{
    grid-template-columns:1fr !important;
  }
}


/* V41 result hero repair - remove giant empty panel and balance report header */
body.result-report-mode .result-hero,
body.is-results-ready .result-hero,
.card:has(#resultWrap.active) .result-hero{
  display:grid !important;
  grid-template-columns:minmax(210px,250px) minmax(0,1fr) !important;
  gap:24px !important;
  align-items:center !important;
  width:100% !important;
  min-height:0 !important;
  padding:24px !important;
  margin:0 0 20px !important;
  border-radius:30px !important;
  background:
    radial-gradient(circle at 94% 12%, rgba(0,167,255,.12), transparent 32%),
    radial-gradient(circle at 8% 92%, rgba(255,23,141,.08), transparent 34%),
    linear-gradient(180deg,#fff,#fbfdff) !important;
  border:1px solid rgba(5,8,36,.09) !important;
  box-shadow:0 22px 64px rgba(5,8,36,.10) !important;
  box-sizing:border-box !important;
  overflow:hidden !important;
}

/* Make sure the score is the left report tile, not lost/hidden */
body.result-report-mode .result-hero .score-card,
body.is-results-ready .result-hero .score-card,
.card:has(#resultWrap.active) .result-hero .score-card{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  width:100% !important;
  max-width:250px !important;
  min-height:250px !important;
  margin:0 !important;
  box-sizing:border-box !important;
}

/* Result copy should use the available right-hand area */
body.result-report-mode .result-hero .result-copy,
body.is-results-ready .result-hero .result-copy,
.card:has(#resultWrap.active) .result-hero .result-copy{
  width:100% !important;
  max-width:none !important;
  min-width:0 !important;
  align-self:center !important;
}

body.result-report-mode .result-hero .result-copy h2,
body.is-results-ready .result-hero .result-copy h2,
.card:has(#resultWrap.active) .result-hero .result-copy h2{
  max-width:760px !important;
  margin:0 0 12px !important;
  font-size:42px !important;
  line-height:1.04 !important;
}

body.result-report-mode .result-hero .result-copy p,
body.is-results-ready .result-hero .result-copy p,
.card:has(#resultWrap.active) .result-hero .result-copy p{
  max-width:760px !important;
  font-size:15px !important;
  line-height:1.5 !important;
}

/* The reviewed module pills should become rows across the report area, not one skinny stack */
body.result-report-mode .module-pills,
body.is-results-ready .module-pills,
.card:has(#resultWrap.active) .module-pills{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:9px !important;
  max-width:820px !important;
  width:100% !important;
}

body.result-report-mode .module-pills .pill,
body.is-results-ready .module-pills .pill,
.card:has(#resultWrap.active) .module-pills .pill{
  width:auto !important;
  max-width:none !important;
  white-space:nowrap !important;
}

/* The three summary counters should sit neatly under the result hero */
body.result-report-mode .result-counters,
body.is-results-ready .result-counters,
.card:has(#resultWrap.active) .result-counters{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
  margin-top:16px !important;
}

/* Pull the next report blocks up and keep them balanced */
body.result-report-mode .narrative-summary,
body.is-results-ready .narrative-summary,
.card:has(#resultWrap.active) .narrative-summary{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(280px,340px) !important;
  gap:18px !important;
  align-items:stretch !important;
  margin-top:18px !important;
}

body.result-report-mode .suggested-focus,
body.result-report-mode .focus-card,
body.result-report-mode .review-focus,
body.is-results-ready .suggested-focus,
body.is-results-ready .focus-card,
body.is-results-ready .review-focus,
.card:has(#resultWrap.active) .suggested-focus,
.card:has(#resultWrap.active) .focus-card,
.card:has(#resultWrap.active) .review-focus{
  min-width:0 !important;
  width:100% !important;
  max-width:none !important;
}

/* Avoid the huge pale result hero if the score card is not rendered for any reason */
body.result-report-mode .result-hero:not(:has(.score-card)){
  display:block !important;
  padding:24px 28px !important;
}

@media(max-width:940px){
  body.result-report-mode .result-hero,
  body.is-results-ready .result-hero,
  .card:has(#resultWrap.active) .result-hero{
    grid-template-columns:1fr !important;
    padding:20px !important;
  }

  body.result-report-mode .result-hero .score-card,
  body.is-results-ready .result-hero .score-card,
  .card:has(#resultWrap.active) .result-hero .score-card{
    max-width:none !important;
    min-height:210px !important;
  }

  body.result-report-mode .result-hero .result-copy h2,
  body.is-results-ready .result-hero .result-copy h2,
  .card:has(#resultWrap.active) .result-hero .result-copy h2{
    font-size:32px !important;
  }

  body.result-report-mode .narrative-summary,
  body.is-results-ready .narrative-summary,
  .card:has(#resultWrap.active) .narrative-summary{
    grid-template-columns:1fr !important;
  }
}


/* V46 indicator check display */
.indicator-check-section {
  margin-top: 24px;
}

.indicator-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.indicator-check-card {
  border: 1px solid rgba(15, 23, 42, .10);
  border-radius: 18px;
  background: #ffffff;
  padding: 16px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .06);
}

.indicator-check-top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 8px;
  font-size: 12px;
  color: #64748b;
}

.indicator-check-top strong {
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 11px;
  background: #f1f5f9;
  color: #0f172a;
  white-space: nowrap;
}

.indicator-check-card h3 {
  margin: 0 0 8px;
  font-size: 16px;
  line-height: 1.2;
  color: #071033;
}

.indicator-check-card p {
  margin: 0;
  color: #475569;
  line-height: 1.45;
  font-size: 14px;
}

.indicator-good {
  border-color: rgba(22, 163, 74, .24);
  background: linear-gradient(180deg, #ffffff, #f0fdf4);
}

.indicator-good .indicator-check-top strong {
  background: #dcfce7;
  color: #166534;
}

.indicator-warn {
  border-color: rgba(245, 158, 11, .28);
  background: linear-gradient(180deg, #ffffff, #fffbeb);
}

.indicator-warn .indicator-check-top strong {
  background: #fef3c7;
  color: #92400e;
}

.indicator-risk {
  border-color: rgba(239, 68, 68, .24);
  background: linear-gradient(180deg, #ffffff, #fef2f2);
}

.indicator-risk .indicator-check-top strong {
  background: #fee2e2;
  color: #991b1b;
}

.indicator-neutral {
  border-color: rgba(100, 116, 139, .20);
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}

@media (max-width: 760px) {
  .indicator-check-grid {
    grid-template-columns: 1fr;
  }
}


/* V47 plain-English indicator explanations */
.indicator-check-card h3 {
  font-size: 17px;
  line-height: 1.25;
  margin-bottom: 10px;
}

.indicator-technical-detail {
  margin: 10px 0 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(15,23,42,.08);
  padding: 9px 10px;
}

.indicator-technical-detail summary {
  cursor: pointer;
  font-weight: 600;
  color: #334155;
  font-size: 13px;
}

.indicator-technical-detail p {
  margin-top: 8px;
  font-size: 13px;
}

.indicator-explain,
.indicator-next {
  margin-top: 10px;
}

.indicator-explain b,
.indicator-next b {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: #334155;
  margin-bottom: 4px;
}

.indicator-explain p,
.indicator-next p {
  font-size: 14px;
  line-height: 1.45;
}

.indicator-check-card.indicator-warn h3,
.indicator-check-card.indicator-risk h3 {
  color: #071033;
}


/* V48 collapsible indicator explanations */
.indicator-heading-compact p {
  max-width: 760px;
}

.indicator-meaning-detail {
  margin-top: 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(15,23,42,.08);
  padding: 10px 12px;
}

.indicator-meaning-detail summary {
  cursor: pointer;
  font-weight: 700;
  color: #334155;
  font-size: 14px;
  list-style-position: outside;
}

.indicator-meaning-detail[open] {
  background: #ffffff;
  box-shadow: inset 0 0 0 1px rgba(15,23,42,.03);
}

.indicator-tech-note {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed rgba(15,23,42,.14);
}

.indicator-tech-note b {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: #64748b;
  margin-bottom: 4px;
}

.indicator-tech-note p {
  font-size: 13px;
  color: #64748b;
}

/* Hide the older separate technical detail block if cached markup appears */
.indicator-technical-detail {
  display: none;
}


/* V49 indicator section contrast fix */
.indicator-check-section .eyebrow,
.indicator-heading-compact .eyebrow {
  color: #071033 !important;
  background: rgba(255, 255, 255, .82);
  border: 1px solid rgba(123, 44, 255, .20);
  box-shadow: 0 8px 20px rgba(15, 23, 42, .08);
  padding: 6px 11px;
  border-radius: 999px;
  display: inline-flex;
  width: fit-content;
}

.indicator-check-section .report-section-heading h2,
.indicator-heading-compact h2 {
  color: #071033;
}

.indicator-check-section .report-section-heading p,
.indicator-heading-compact p {
  color: #334155;
}


/* V50 whole indicator section collapsible */
.indicator-section-collapsible {
  border: 1px solid rgba(123, 44, 255, .16);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(248,246,255,.72));
  box-shadow: 0 12px 30px rgba(15, 23, 42, .07);
  padding: 0;
  overflow: hidden;
}

.indicator-section-collapsible > summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  color: #071033;
  font-weight: 800;
}

.indicator-section-collapsible > summary::-webkit-details-marker {
  display: none;
}

.indicator-section-collapsible > summary::after {
  content: "Show";
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 6px 11px;
  background: #ffffff;
  color: #7b2cff;
  border: 1px solid rgba(123,44,255,.22);
  font-size: 12px;
  font-weight: 800;
}

.indicator-section-collapsible[open] > summary::after {
  content: "Hide";
}

.indicator-section-collapsible > summary small {
  color: #64748b;
  font-weight: 700;
  margin-left: auto;
}

.indicator-section-collapsible #indicatorCheckList {
  padding: 0 20px 20px;
}

.indicator-section-collapsible .report-section-heading {
  padding-top: 4px;
}

@media (max-width: 760px) {
  .indicator-section-collapsible > summary {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .indicator-section-collapsible > summary small {
    margin-left: 0;
  }
}


/* V51 full address capture */
.field-wide {
  grid-column: 1 / -1;
}

.address-picker-field {
  position: relative;
}

.address-lookup-status {
  margin-top: 7px;
  font-size: 12px;
  color: #64748b;
}

.address-suggestions {
  position: absolute;
  z-index: 20;
  left: 0;
  right: 0;
  top: calc(100% - 2px);
  background: #ffffff;
  border: 1px solid rgba(123, 44, 255, .18);
  border-radius: 16px;
  box-shadow: 0 18px 38px rgba(15, 23, 42, .16);
  overflow: hidden;
  max-height: 280px;
  overflow-y: auto;
}

.address-suggestion {
  display: block;
  width: 100%;
  border: 0;
  background: #ffffff;
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
  border-bottom: 1px solid rgba(15, 23, 42, .07);
  font-family: inherit;
}

.address-suggestion:hover,
.address-suggestion:focus {
  background: #f8f6ff;
  outline: none;
}

.address-suggestion strong {
  display: block;
  color: #071033;
  font-size: 14px;
}

.address-suggestion span {
  display: block;
  color: #64748b;
  font-size: 12px;
  margin-top: 3px;
}


/* V53 actual postcode address options */
.address-suggestion strong {
  line-height: 1.25;
}

.address-suggestion span {
  line-height: 1.35;
}


/* V54 Giacom address option display */
.address-lookup-status {
  min-height: 16px;
}


/* V61 single address field */
.address-suggestions[hidden] {
  display: none !important;
}

.address-suggestions.is-open {
  display: block;
}

.address-picker-field input[data-address-selected="true"] {
  border-color: rgba(34, 197, 94, .45);
  box-shadow: 0 0 0 3px rgba(34, 197, 94, .10);
}


/* V63 result availability action options */
.result-action-options {
  margin-top: 18px;
  border-radius: 22px;
  border: 1px solid rgba(123, 44, 255, .16);
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(248,246,255,.88));
  box-shadow: 0 14px 30px rgba(15, 23, 42, .08);
  padding: 18px;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, .9fr);
  gap: 18px;
  align-items: center;
}

.result-action-options h3 {
  margin: 6px 0 6px;
  color: #071033;
}

.result-action-options p {
  margin: 0;
  color: #475569;
  line-height: 1.5;
}

.result-action-option-buttons {
  display: grid;
  gap: 10px;
}

.result-action-option-buttons .secondary-btn {
  width: 100%;
  justify-content: center;
  min-height: 42px;
  font-weight: 700;
}

@media (max-width: 760px) {
  .result-action-options {
    grid-template-columns: 1fr;
  }
}


/* V65 FTTP opportunity card */
.result-brief-card.opportunity {
  border-color: rgba(34, 197, 94, .30);
  background: linear-gradient(145deg, rgba(240, 253, 244, .96), rgba(255,255,255,.92));
}

.result-brief-card.opportunity b {
  color: #15803d;
}

.button-like {
  border: 0;
  cursor: pointer;
  font: inherit;
  margin-top: 10px;
}


/* V69 simplified dependency questions */
.dependency-question select {
  margin-top: 6px;
}

.dependency-examples {
  margin: 8px 0 0;
  color: #64748b;
  font-size: 13px;
  line-height: 1.45;
}


/* V71 polished result action options */
.result-action-options {
  position: relative;
  overflow: hidden;
  margin-top: 22px;
  border-radius: 28px;
  border: 1px solid rgba(123, 44, 255, .18);
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 59, 139, .14), transparent 34%),
    radial-gradient(circle at 92% 18%, rgba(0, 184, 255, .14), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,246,255,.94));
  box-shadow: 0 22px 50px rgba(15, 23, 42, .10);
  padding: 22px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .9fr);
  gap: 22px;
  align-items: stretch;
}

.result-action-options::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 7px;
  background: linear-gradient(180deg, #eb3b8b, #7b2cff, #00b8ff);
}

.result-action-copy {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: 4px;
}

.result-action-options h3 {
  margin: 8px 0 8px;
  color: #071033;
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.05;
}

.result-action-options p {
  margin: 0;
  color: #475569;
  line-height: 1.55;
  max-width: 62ch;
}

.result-action-option-buttons {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
}

.result-next-btn {
  appearance: none;
  border: 1px solid rgba(123, 44, 255, .16);
  border-radius: 18px;
  background: rgba(255,255,255,.88);
  box-shadow: 0 10px 26px rgba(15, 23, 42, .08);
  min-height: 68px;
  padding: 13px 15px;
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: #071033;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.result-next-btn span {
  display: block;
  font-weight: 800;
  line-height: 1.15;
}

.result-next-btn small {
  display: block;
  margin-top: 5px;
  color: #64748b;
  line-height: 1.25;
  font-size: 12px;
}

.result-next-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(235, 59, 139, .36);
  box-shadow: 0 16px 34px rgba(15, 23, 42, .12);
}

.result-next-btn.primary {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, #eb3b8b, #7b2cff, #00b8ff);
}

.result-next-btn.primary small {
  color: rgba(255,255,255,.82);
}

@media (max-width: 760px) {
  .result-action-options {
    grid-template-columns: 1fr;
    padding: 20px;
  }
}


/* V76 lighter recommended/area pills */
.area-score,
.area-chip,
.result-pill,
.reviewed-pill,
.module-pill,
.result-brief-card .mini-action,
.priority-card .pill,
.priority-pill,
.score-pill {
  font-weight: 500 !important;
  letter-spacing: 0 !important;
}

.area-scores span,
.area-scores .area-score,
.result-meta span,
.result-meta .reviewed-pill {
  font-weight: 500 !important;
}

.result-brief-card b,
.priority-card b,
.result-stat span {
  font-weight: 500;
}


/* V84 safe loader hide: result must stay visible */
body.is-results-ready #resultLoading,
body.result-only-view #resultLoading,
body.result-report-mode #resultLoading{
  display:none !important;
  visibility:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}

body.is-results-ready #resultWrap,
body.result-only-view #resultWrap,
body.result-report-mode #resultWrap,
#resultWrap.active{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
}

body.is-results-ready .result-wrap.active,
body.result-only-view .result-wrap.active,
body.result-report-mode .result-wrap.active{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
}


/* V86 quick-view visibility and lighter typography */
.result-brief-grid,
#resultBrief {
  display:grid !important;
}

.result-brief-card,
.result-brief-card p,
.result-brief-card .tag,
.result-brief-card b,
.result-brief-card strong,
.priority-group-card,
.priority-group-card p,
.priority-group-card h4,
.area-scores .pill,
#areaScoreList .pill,
#reviewedList .pill,
.result-stat,
.result-stat span,
.result-stat b {
  font-weight:300 !important;
  letter-spacing:0 !important;
}

.result-brief-card b,
.priority-group-card .priority-count,
.section-kicker,
.eyebrow {
  font-weight:400 !important;
}

.result-brief-card strong {
  font-weight:400 !important;
  line-height:1.16;
}

.result-brief-card p {
  line-height:1.48;
  color:#5f6f88;
}

#areaScoreList .pill,
#reviewedList .pill {
  font-size:12px;
  line-height:1.2;
  padding:8px 10px;
}


/* V87 force quick-view/result brief visible */
body.is-results-ready #resultBrief,
body.result-only-view #resultBrief,
body.result-report-mode #resultBrief,
body.is-results-ready .result-brief-grid,
body.result-only-view .result-brief-grid,
body.result-report-mode .result-brief-grid,
body.is-results-ready .result-brief,
body.result-only-view .result-brief,
body.result-report-mode .result-brief,
body.is-results-ready .result-brief-card,
body.result-only-view .result-brief-card,
body.result-report-mode .result-brief-card {
  display: grid !important;
  visibility: visible !important;
  opacity: 1 !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

#resultBrief,
.result-brief-grid {
  min-height: 1px;
}

#resultBrief .result-brief-card {
  display: flex !important;
  flex-direction: column;
}

/* softer, less chunky quick-view typography */
#resultBrief,
#resultBrief *,
.result-brief-grid,
.result-brief-grid *,
.result-brief-card,
.result-brief-card * {
  font-weight: 300 !important;
}

#resultBrief b,
#resultBrief strong,
.result-brief-card b,
.result-brief-card strong {
  font-weight: 400 !important;
}


/* V88 final quick-view + quick-check visibility and lighter result typography */
body.is-results-ready #resultBrief,
body.result-only-view #resultBrief,
body.result-report-mode #resultBrief{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:12px !important;
  visibility:visible !important;
  opacity:1 !important;
  margin:20px 0 12px !important;
}

.result-brief-head{
  grid-column:1 / -1;
  padding:0 2px 2px;
}

.result-brief-head h3{
  margin:3px 0 0 !important;
  font-size:20px !important;
  line-height:1.15 !important;
  font-weight:300 !important;
  color:#071033 !important;
}

#resultBrief .result-brief-card{
  display:flex !important;
  flex-direction:column !important;
  min-height:118px !important;
  padding:14px !important;
  border-radius:20px !important;
  font-weight:300 !important;
}

#resultBrief .result-brief-card b{
  font-size:11px !important;
  letter-spacing:.035em !important;
  font-weight:300 !important;
  color:#6b7890 !important;
}

#resultBrief .result-brief-card strong{
  font-size:17px !important;
  line-height:1.12 !important;
  font-weight:300 !important;
}

#resultBrief .result-brief-card p,
#resultBrief .result-brief-card .tag,
#reviewedList .pill,
#areaScoreList .pill,
#nextSteps,
#nextSteps li,
.result-stat span,
.result-copy p,
.narrative-summary p,
.priority-group-card p,
.indicator-check-card p{
  font-weight:300 !important;
}

.result-stat b{
  font-weight:300 !important;
  font-size:24px !important;
}

.result-section h3,
.indicator-check-section summary span,
.detailed-findings summary span{
  font-weight:300 !important;
}

/* Quick checks must be visible in result mode */
body.is-results-ready #indicatorCheckSection,
body.result-only-view #indicatorCheckSection,
body.result-report-mode #indicatorCheckSection{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  margin-top:18px !important;
}

body.is-results-ready #indicatorCheckList,
body.result-only-view #indicatorCheckList,
body.result-report-mode #indicatorCheckList{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
}

#indicatorCheckSection[open] #indicatorCheckList{
  display:block !important;
}

.indicator-check-card h3{
  font-weight:300 !important;
  font-size:15.5px !important;
}

.indicator-check-top strong{
  font-weight:300 !important;
}

@media(max-width:940px){
  body.is-results-ready #resultBrief,
  body.result-only-view #resultBrief,
  body.result-report-mode #resultBrief{
    grid-template-columns:1fr !important;
  }
}


/* V89 quick-check card visibility and calmer backup weighting */
body.is-results-ready #indicatorCheckSection[open] #indicatorCheckList,
body.result-only-view #indicatorCheckSection[open] #indicatorCheckList,
body.result-report-mode #indicatorCheckSection[open] #indicatorCheckList,
#indicatorCheckList{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  height:auto !important;
  max-height:none !important;
  overflow:visible !important;
  padding-top:14px !important;
}

.quick-check-grid-visible,
#indicatorCheckList .indicator-check-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:12px !important;
  visibility:visible !important;
  opacity:1 !important;
}

.quick-check-card-visible,
#indicatorCheckList .indicator-check-card{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  min-height:0 !important;
  padding:14px !important;
  border-radius:16px !important;
  font-weight:300 !important;
}

#indicatorCheckList .report-section-heading h2{
  font-size:20px !important;
  font-weight:300 !important;
  margin-bottom:5px !important;
}

#indicatorCheckList .report-section-heading p,
#indicatorCheckList .indicator-check-card p,
#indicatorCheckList .indicator-next p,
#indicatorCheckList .indicator-meaning-detail summary,
#indicatorCheckList .indicator-check-top span,
#indicatorCheckList .indicator-check-top strong{
  font-weight:300 !important;
}

#indicatorCheckList .indicator-check-card h3{
  font-size:15.5px !important;
  line-height:1.22 !important;
  font-weight:300 !important;
  margin-bottom:7px !important;
}

#indicatorCheckList .indicator-meaning-detail{
  margin-top:8px !important;
}

#indicatorCheckList .indicator-tech-note{
  display:none !important;
}

/* Do not let backup cards visually dominate the report */
.finding:has(.mini-action[href*="backup"]),
.finding:has(button[data-hc-action="backup_options"]){
  order:8;
}

@media(max-width:940px){
  .quick-check-grid-visible,
  #indicatorCheckList .indicator-check-grid{
    grid-template-columns:1fr !important;
  }
}
