/*
Theme Name: SafelyOS
Theme URI: https://ubezpieczenieb2b.pl
Author: KG Serwis Ubezpieczeń (Konrad Gawron)
Author URI: https://gawron-broker.pl
Description: Aplikacja-lejek Safely Score — interaktywny audyt ochrony dla B2B / freelancerów, oparty na ofercie ubezpieczenieb2b.pl. Motyw jednostronicowy w stylu Stripe.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: safelyos
*/

:root{
  --blurple:#635bff;
  --blurple-d:#5249e0;
  --blurple-dd:#4a41cc;
  --ink:#0a2540;
  --slate:#425466;
  --muted:#697386;
  --soft:#8792a2;
  --line:#e3e8ee;
  --line-2:#ebeef1;
  --bg:#ffffff;
  --bg-2:#f6f9fc;
  --green:#15be53;
  --amber:#f5a623;
  --red:#df1b41;
  --track:#e3e8ee;
  --shadow-card:0 50px 100px -20px rgba(50,50,93,.16),0 30px 60px -30px rgba(0,0,0,.16);
  --shadow-md:0 13px 27px -5px rgba(50,50,93,.18),0 8px 16px -8px rgba(0,0,0,.18);
  --shadow-sm:0 2px 5px -1px rgba(50,50,93,.16),0 1px 3px -1px rgba(0,0,0,.1);
  --r:16px;--r-sm:10px;--r-xs:8px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--slate);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.01em;
}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font-family:inherit}
h1,h2,h3{color:var(--ink);font-weight:700;letter-spacing:-.02em;line-height:1.1}

.app{min-height:100vh;display:grid;grid-template-columns:264px 1fr}

/* ---------- Sidebar (Stripe dashboard style: light, hairline) ---------- */
.sidebar{
  background:var(--bg);
  border-right:1px solid var(--line);
  padding:22px 16px;
  position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;justify-content:space-between;
}
.logoDark{height:54px;border-radius:var(--r-sm);background:var(--ink);border:1px solid var(--ink);display:grid;place-items:center;overflow:hidden;margin-bottom:22px}
.logoDark img{max-height:34px;width:auto;display:block}
.menu{display:flex;flex-direction:column;gap:2px}
.menu a{color:var(--muted);font-weight:500;font-size:14px;padding:9px 12px;border-radius:var(--r-xs);display:flex;align-items:center;gap:8px;transition:background .15s ease,color .15s ease}
.menu a:hover{background:var(--bg-2);color:var(--ink)}
.menu a.active{background:#f0f1ff;color:var(--blurple);font-weight:600}
.sideScore{margin-top:18px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:18px;text-align:center}
.sideScore img{max-width:120px;width:60%;display:block;margin:0 auto 12px;border-radius:8px}
.sideScore strong{display:block;font-size:30px;letter-spacing:-.04em;color:var(--ink);font-variant-numeric:tabular-nums}
.sideScore span{color:var(--muted);font-size:12px;font-weight:600}

/* ---------- Main / topbar ---------- */
.main{min-width:0;background:var(--bg)}
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 40px;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.topLogo img{height:30px;display:block}
.topActions{display:flex;align-items:center;gap:10px}
.btn{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:14px;padding:9px 16px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:background .15s ease,box-shadow .15s ease,transform .15s ease}
.btn.light{color:var(--ink);background:#fff;border-color:var(--line)}
.btn.light:hover{background:var(--bg-2)}
.btn.primary{background:var(--blurple);color:#fff;box-shadow:var(--shadow-sm)}
.btn.primary:hover{background:var(--blurple-d);transform:translateY(-1px)}

/* ---------- Hero with signature Stripe diagonal gradient ---------- */
.hero{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:72px 40px 96px;overflow:hidden;color:#fff}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(60% 80% at 0% 0%,#7c5cff 0%,transparent 55%),
    radial-gradient(50% 70% at 100% 0%,#19b6f6 0%,transparent 55%),
    radial-gradient(60% 90% at 85% 100%,#13e0c8 0%,transparent 50%),
    radial-gradient(60% 90% at 0% 100%,#8e4dff 0%,transparent 55%),
    linear-gradient(120deg,#6a5bff 0%,#3f8efc 48%,#1ec8d3 100%);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 72px),0 100%);
}
.hero>*{position:relative;z-index:2}
.kicker{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#fff;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);padding:6px 12px;border-radius:999px;letter-spacing:0}
.kicker i{width:7px;height:7px;border-radius:50%;background:#fff;display:inline-block;box-shadow:0 0 0 4px rgba(255,255,255,.25)}
.heroCopy h1{color:#fff;font-size:54px;line-height:1.05;letter-spacing:-.03em;margin:18px 0 16px;font-weight:800}
.heroCopy p{color:rgba(255,255,255,.92);font-size:18px;max-width:460px;margin:0}
.heroTiles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:26px;max-width:460px;position:relative;z-index:3}
.heroTile{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-radius:var(--r-sm);padding:14px}
.heroTile span{display:block;color:rgba(255,255,255,.8);font-size:12px;font-weight:600;margin-bottom:4px}
.heroTile strong{display:block;color:#fff;font-size:20px;letter-spacing:-.02em}

/* Floating product card on the right */
.scoreHero{background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px;box-shadow:var(--shadow-card)}
.scoreHeroLogo{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 16px;margin-bottom:22px;display:flex;align-items:center;justify-content:flex-start;box-shadow:var(--shadow-sm)}
.scoreHeroLogo img{max-height:34px;width:auto;display:block}
.bigScore span{display:block;color:var(--muted);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.bigScore strong{display:block;font-size:64px;line-height:1;letter-spacing:-.04em;color:var(--ink);margin:6px 0 12px;font-variant-numeric:tabular-nums}
.bigScore p{color:var(--slate);font-size:15px;max-width:360px;margin:0}

/* ---------- Workspace / audit panel ---------- */
.workspace{display:grid;grid-template-columns:1fr 360px;gap:28px;padding:40px 40px;align-items:start}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden}
.panelHead{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:26px 28px;border-bottom:1px solid var(--line-2)}
.panelHead h2{font-size:22px;margin:0 0 4px}
.panelHead p{margin:0;color:var(--muted);font-size:14px;max-width:420px}
.scoreRing{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;flex:none;background:conic-gradient(var(--blurple) 0deg,var(--blurple) 175deg,#e8eef5 175deg)}
.scoreRing div{width:66px;height:66px;border-radius:50%;background:#fff;display:grid;place-items:center;font-size:22px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.formGrid{padding:24px 28px;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field input,.field select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-xs);font-size:15px;color:var(--ink);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}
.field input:focus,.field select:focus{outline:none;border-color:var(--blurple);box-shadow:0 0 0 3px rgba(99,91,255,.18)}
.resultBar{display:grid;grid-template-columns:repeat(3,1fr);background:var(--bg-2);border-top:1px solid var(--line-2)}
.resultItem{padding:18px 28px;border-right:1px solid var(--line-2)}
.resultItem:last-child{border-right:0}
.resultItem span{display:block;color:var(--muted);font-size:12px;font-weight:600;margin-bottom:4px}
.resultItem strong{font-size:20px;color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.explain{border-top:1px solid var(--line-2);padding:24px 28px 8px}
.explain h3{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 16px}
.explainRow{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line-2)}
.explainRow:last-child{border-bottom:0}
.explainIco{flex:0 0 38px;width:38px;height:38px;border-radius:10px;background:var(--bg-2);border:1px solid var(--line);display:grid;place-items:center;font-size:18px}
.explainRow strong{display:block;font-size:15px;color:var(--ink);letter-spacing:-.01em;margin-bottom:4px}
.explainRow strong span{color:var(--blurple)}
.explainRow p{margin:0;color:var(--slate);font-size:13.5px;line-height:1.55}

.rightRail{position:sticky;top:88px;display:flex;flex-direction:column;gap:18px}
.reco{background:var(--ink);color:#fff;border-radius:var(--r);padding:24px}
.recoTop{display:flex;align-items:center;justify-content:space-between;gap:12px}
.recoScore{background:var(--blurple);color:#fff;font-weight:700;font-size:14px;border-radius:999px;padding:4px 12px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.recoPremium{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.14)}
.recoPremium span{color:rgba(255,255,255,.65);font-size:13px;font-weight:600}
.recoPremium strong{color:#fff;font-size:22px;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.reco small{color:rgba(255,255,255,.65);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.reco h3{color:#fff;font-size:20px;margin:8px 0 8px}
.reco p{color:rgba(255,255,255,.85);font-size:14px;margin:0}
.areas{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow-sm)}
.areas h3{font-size:15px;margin:0 0 14px;color:var(--ink)}
.barRow{display:grid;grid-template-columns:74px 1fr 42px;gap:10px;align-items:center;font-size:13px;font-weight:600;margin:12px 0;color:var(--slate)}
.track{height:7px;background:var(--track);border-radius:999px;overflow:hidden}
.fill{height:100%;width:0;border-radius:999px;transition:width .9s cubic-bezier(.22,1,.36,1),background-color .4s ease}
.fill.bad{background:var(--red)}
.fill.warn{background:var(--amber)}
.fill.good{background:var(--green)}
.barRow b{text-align:right;color:var(--ink);font-variant-numeric:tabular-nums}

/* ---------- Generic sections ---------- */
.section{padding:64px 40px;border-top:1px solid var(--line-2)}
.section:nth-of-type(even){background:var(--bg-2)}
.sectionHead{max-width:640px;margin-bottom:34px}
.sectionHead h2{font-size:34px;letter-spacing:-.025em;margin:0 0 10px}
.sectionHead p{margin:0;color:var(--muted);font-size:16px}

.protectGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.protectCard{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;display:flex;gap:14px;align-items:center;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease}
.protectCard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blurple)}
.protectCard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.protectCard .ico{width:46px;height:46px;border-radius:12px;background:#f0f1ff;display:grid;place-items:center;font-size:22px;flex:none}
.pcBody{min-width:0}
.protectCard span{display:block;color:var(--muted);font-size:12px;font-weight:600;margin-bottom:3px;text-transform:uppercase;letter-spacing:.03em}
.protectCard strong{font-size:19px;color:var(--ink);letter-spacing:-.02em;line-height:1.2;font-variant-numeric:tabular-nums}
.pc-income::before{background:#15be53}.pc-income .ico{background:#e6f9ee}
.pc-debt::before{background:#f5a623}.pc-debt .ico{background:#fdf1de}
.pc-family::before{background:var(--blurple)}.pc-family .ico{background:#f0f1ff}
.pc-health::before{background:#df1b41}.pc-health .ico{background:#fde8ec}

.recommended{display:grid;grid-template-columns:1fr 420px;gap:40px;align-items:center;padding:64px 40px;border-top:1px solid var(--line-2)}
.recommended h2{font-size:34px;margin:0 0 10px}
.recommended p{color:var(--muted);font-size:16px;margin:0}
.miniPkg{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-md)}
.miniPkg small{color:var(--blurple);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.miniPkg h3{font-size:24px;margin:6px 0 4px}
.miniDesc{color:var(--slate);font-size:14px;line-height:1.5;margin:6px 0 14px}
.price{font-size:30px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.price span,.price small{font-size:14px;font-weight:500;color:var(--muted)}
.miniPkg ul{list-style:none;margin:18px 0 0;padding:18px 0 0;border-top:1px solid var(--line-2)}
.miniPkg li{display:flex;justify-content:space-between;padding:7px 0;font-size:14px;color:var(--slate)}
.miniPkg li b{color:var(--ink)}

.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pkg,.product{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;display:flex;flex-direction:column}
.pkg:hover,.product:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pkg.rec{border-color:var(--blurple);box-shadow:0 0 0 1px var(--blurple),var(--shadow-md)}
.pkg h3,.product h3{font-size:20px;margin:10px 0 6px}
.pkg p,.product p{color:var(--muted);font-size:14px;margin:0 0 16px;flex:1}
.tag{align-self:flex-start;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--blurple);background:#f0f1ff;padding:4px 10px;border-radius:999px}
.pkg ul,.product ul{list-style:none;margin:14px 0 18px;padding:14px 0 0;border-top:1px solid var(--line-2)}
.pkg li,.product li{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;color:var(--slate)}
.pkg li b,.product li b{color:var(--ink)}
.pkg a,.product button{display:inline-flex;align-items:center;justify-content:center;margin-top:auto;background:var(--blurple);color:#fff;font-weight:600;font-size:14px;padding:11px 18px;border-radius:var(--r-xs);border:0;cursor:pointer;transition:background .15s ease,transform .15s ease}
.pkg a:hover,.product button:hover{background:var(--blurple-d);transform:translateY(-1px)}
.pkg.rec a{box-shadow:var(--shadow-sm)}

.modules{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.module{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:20px;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.module:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.module i{font-size:24px;font-style:normal;display:block;margin-bottom:10px}
.module h3{font-size:16px;margin:0 0 6px}
.module p{color:var(--muted);font-size:13px;margin:0 0 12px}
.module strong{color:var(--blurple);font-size:15px}

.docs{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.doc{font-size:13px;font-weight:600;color:var(--blurple);border:1px solid var(--line);background:#fff;padding:8px 14px;border-radius:999px}
.doc:hover{background:var(--bg-2)}
.infoLine{margin-top:18px;color:var(--muted);font-size:14px}
.infoLine a{color:var(--blurple);font-weight:600}

.tableWrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:#fff;box-shadow:var(--shadow-sm)}
.tableWrap table{width:100%;border-collapse:collapse;min-width:640px}
.tableWrap th,.tableWrap td{text-align:left;padding:12px 16px;font-size:13px;border-bottom:1px solid var(--line-2);color:var(--slate)}
.tableWrap th{background:var(--bg-2);color:var(--ink);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
.priceCell{font-weight:600;color:var(--ink);cursor:pointer;white-space:nowrap}
.priceCell:hover{color:var(--blurple);background:#f0f1ff}

.complex{background:var(--ink);color:#fff;border-radius:var(--r);padding:34px;display:grid;grid-template-columns:1fr 360px;gap:30px;box-shadow:var(--shadow-md)}
.complex h3{color:#fff;font-size:30px;margin:0 0 14px;letter-spacing:-.02em}
.complex p{color:rgba(255,255,255,.82);font-size:15px;margin:0}
.complexGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:20px}
.complexGrid li,.complexGrid div{list-style:none;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 14px;font-size:14px;color:#fff}
.complexPrice{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-sm);padding:24px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.complexPrice span{color:rgba(255,255,255,.7);font-size:13px;font-weight:600}
.complexPrice strong{color:#fff;font-size:40px;letter-spacing:-.03em}
.complexPrice a{margin-top:8px;background:#fff;color:var(--ink);font-weight:600;font-size:14px;padding:11px 18px;border-radius:var(--r-xs);transition:transform .15s ease}
.complexPrice a:hover{transform:translateY(-1px)}

.notice{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:var(--r-sm);padding:14px 18px;font-size:14px}

/* ---------- CTA / form ---------- */
.cta{display:grid;grid-template-columns:1fr 460px;gap:40px;align-items:start;padding:72px 40px;border-top:1px solid var(--line-2);background:var(--bg-2)}
.cta h2{font-size:38px;letter-spacing:-.03em;margin:0 0 14px}
.cta p{color:var(--muted);font-size:16px;margin:0}
.formBox{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:12px}
.formBox input,.formBox select,.formBox textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--r-xs);font-size:15px;color:var(--ink);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}
.formBox input:focus,.formBox select:focus,.formBox textarea:focus{outline:none;border-color:var(--blurple);box-shadow:0 0 0 3px rgba(99,91,255,.18)}
.formBox textarea{min-height:88px;resize:vertical}
.checkbox{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted);line-height:1.5}
.checkbox input{width:auto;margin-top:3px;accent-color:var(--blurple)}
.formBox button{background:var(--blurple);color:#fff;font-weight:600;font-size:15px;padding:13px;border-radius:var(--r-xs);border:0;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s ease,transform .15s ease}
.formBox button:hover{background:var(--blurple-d);transform:translateY(-1px)}

.footer{padding:30px 40px;border-top:1px solid var(--line);color:var(--soft);font-size:13px}
.dark{color:var(--ink)}

/* ---------- Score visuals ---------- */
.scoreRing{transition:transform .3s ease}
.scoreRing div{transition:color .3s ease}
.bigScore strong,#scoreRingText,#sideScore{font-variant-numeric:tabular-nums}

/* ---------- Accessibility ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.menuToggle:focus-visible,.priceCell:focus-visible{outline:3px solid var(--blurple);outline-offset:2px;border-radius:6px}

/* ---------- Hamburger + mobile drawer + score pill ---------- */
.menuToggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--line);background:#fff;border-radius:12px;cursor:pointer;padding:0}
.menuToggle span{display:block;width:20px;height:2px;background:var(--ink);position:relative;border-radius:2px}
.menuToggle span::before,.menuToggle span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);border-radius:2px}
.menuToggle span::before{top:-6px}.menuToggle span::after{top:6px}

.mobileNav{position:fixed;inset:0 30% 0 0;max-width:300px;background:#fff;border-right:1px solid var(--line);z-index:60;transform:translateX(-105%);transition:transform .3s cubic-bezier(.22,1,.36,1);padding:20px 14px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;box-shadow:var(--shadow-card)}
.mobileNav.open{transform:translateX(0)}
.mobileNav a{color:var(--muted);font-weight:500;font-size:15px;padding:11px 12px;border-radius:var(--r-xs)}
.mobileNav a.active{background:#f0f1ff;color:var(--blurple);font-weight:600}
.mobileNav .navScore{margin-top:auto;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:18px;text-align:center}
.mobileNav .navScore strong{display:block;font-size:34px;letter-spacing:-.03em;color:var(--ink);font-variant-numeric:tabular-nums}
.mobileNav .navScore span{color:var(--muted);font-size:12px;font-weight:600}
.navOverlay{position:fixed;inset:0;background:rgba(10,37,64,.4);backdrop-filter:blur(2px);z-index:55;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}
.navOverlay.open{opacity:1;visibility:visible}

.scorePill{display:none;position:fixed;right:16px;bottom:16px;z-index:50;background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 16px 10px 10px;box-shadow:var(--shadow-md);align-items:center;gap:10px;cursor:pointer}
.scorePill .dot{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:14px;background:var(--blurple);color:#fff;font-variant-numeric:tabular-nums}
.scorePill em{font-style:normal;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.03em}
.scorePill b{display:block;font-size:14px;font-weight:700;color:var(--ink)}

/* ---------- Responsive ---------- */
@media(max-width:1100px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .menuToggle{display:flex}
  .scorePill{display:flex}
  .topbar{padding:12px 20px}
  .topActions .btn.light{display:none}
  .hero{grid-template-columns:1fr;padding:52px 20px 76px;gap:32px}
  .heroCopy h1{font-size:40px}
  .workspace,.recommended,.cta{grid-template-columns:1fr;padding:40px 20px}
  .section{padding:44px 20px}
  .rightRail{position:relative;top:0}
  .formGrid,.resultBar,.protectGrid,.cards3,.modules,.complex,.complexGrid{grid-template-columns:1fr}
  .resultItem{border-right:0;border-bottom:1px solid var(--line-2)}
  .resultItem:last-child{border-bottom:0}
  .sectionHead h2{font-size:28px}
  .cta h2{font-size:30px}
  body.navOpen{overflow:hidden}
}
@media(max-width:560px){
  .heroTiles{grid-template-columns:1fr 1fr}
  .tableWrap table{min-width:520px}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition-duration:.01ms !important;animation-duration:.01ms !important}
}

