*{box-sizing:border-box;margin:0;padding:0}:root{--teal:#0F766E;--teal-d:#0a5750;--teal-l:#14b8a6;--ink:#1E293B;--ink-2:#334155;--slate:#64748b;--slate-l:#94a3b8;--amber:#D97706;--amber-l:#f59e0b;--bg:#F8FAFC;--card:#FFFFFF;--line:#e2e8f0;--line-2:#cbd5e1;--ring:rgba(15,118,110,0.12);--accent:#0F766E;--accent2:#14b8a6;--dark:#0a5750;--grad:linear-gradient(135deg,#0F766E,#14b8a6);--serif:'Fraunces',Georgia,'Times New Roman',serif;--sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--mono:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace}body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}.tool-head{max-width:760px;margin:0 auto;padding:48px 20px 8px;text-align:center}.tool-eyebrow{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);display:inline-block;margin-bottom:14px}.tool-head h1{font-family:var(--serif);font-weight:600;font-size:clamp(30px,4.4vw,44px);line-height:1.07;letter-spacing:-.02em;color:var(--ink)}.tool-head h1 span{color:var(--teal);font-style:italic}.tool-head .sub{font-size:16px;color:var(--ink-2);max-width:600px;margin:16px auto 0;line-height:1.7}.tool-head .tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:22px}.tool-head .tags span{font-family:var(--mono);font-size:11.5px;font-weight:500;color:var(--ink-2);background:var(--card);border:1px solid var(--line);padding:6px 13px;border-radius:999px;box-shadow:0 1px 2px rgba(15,23,42,.04)}.cnt{max-width:1080px;margin:0 auto;padding:28px 20px 40px}.tool-card{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:0 1px 2px rgba(15,23,42,.04),0 10px 30px rgba(15,23,42,.06);overflow:hidden;margin-bottom:26px}.tch{display:flex;align-items:center;gap:16px;padding:24px 36px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#f0fdfa 0%,#fbfdfd 100%)}.ti{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;background:var(--grad);color:#fff}.tch-text h2{font-family:var(--serif);font-size:20px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}.tch-text p{font-size:13px;color:var(--slate);margin-top:3px}.tb{padding:36px}.sl{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--slate);text-transform:uppercase;letter-spacing:.1em;margin:28px 0 16px;padding-bottom:9px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}.sl:first-child{margin-top:0}.sl::before{content:'';width:3px;height:13px;border-radius:2px;background:var(--teal);flex-shrink:0}.g2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.fd{display:flex;flex-direction:column;gap:7px}.fl{font-size:11px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em}.iw{display:flex;border-radius:11px;overflow:hidden;border:1.5px solid var(--line-2);transition:border-color .18s,box-shadow .18s;background:#fff}.iw:focus-within{border-color:var(--teal);box-shadow:0 0 0 4px var(--ring)}.iw input,.iw select{border:none;outline:none;background:transparent;font-family:inherit;font-size:14px;color:var(--ink);padding:13px 16px;width:100%}.iu{background:var(--bg);padding:13px 15px;font-size:12px;font-weight:600;color:var(--slate);white-space:nowrap;border-left:1.5px solid var(--line);flex-shrink:0;display:flex;align-items:center}.hint{font-size:11px;color:var(--slate-l);line-height:1.5}.btn-row{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap;align-items:center}.bcalc{background:var(--teal);color:#fff;border:none;border-radius:12px;padding:15px 36px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .18s;display:inline-flex;align-items:center;gap:9px;box-shadow:0 4px 14px rgba(15,118,110,.28)}.bcalc:hover{background:var(--teal-d);transform:translateY(-2px);box-shadow:0 10px 26px rgba(15,118,110,.34)}.breset{background:#fff;color:var(--ink-2);border:1.5px solid var(--line-2);border-radius:12px;padding:15px 26px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .18s}.breset:hover{border-color:var(--teal);color:var(--teal)}.bpdf{background:var(--ink);color:#fff;border:none;border-radius:12px;padding:15px 26px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .18s;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 14px rgba(30,41,59,.2)}.bpdf:hover{background:#0b1220;transform:translateY(-2px);box-shadow:0 8px 22px rgba(30,41,59,.3)}.rw{margin-top:30px;display:none}.rhdr{font-family:var(--mono);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.09em;margin-bottom:18px;display:flex;align-items:center;gap:10px;color:var(--teal)}.rhdr-dot{width:24px;height:24px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;font-weight:700;flex-shrink:0}.kg{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.kc{border-radius:16px;padding:20px 16px;text-align:center;border:1px solid var(--line);transition:transform .15s;cursor:default;background:#fff}.kc:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(15,23,42,.06)}.kv{font-family:var(--serif);font-size:28px;font-weight:600;line-height:1;margin-bottom:5px;letter-spacing:-.01em;color:var(--ink)}.ku{font-family:var(--mono);font-size:11px;font-weight:600;margin-bottom:4px;color:var(--teal);text-transform:uppercase;letter-spacing:.04em}.kl{font-size:11.5px;color:var(--slate)}.alert-ok{background:#ecfdf5;border:1px solid #a7f3d0;border-radius:12px;padding:14px 18px;font-size:13.5px;color:#065f46;margin-top:14px}.alert-warn{background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:14px 18px;font-size:13.5px;color:#92400e;margin-top:14px}.alert-fail{background:#fef2f2;border:1px solid #fca5a5;border-radius:12px;padding:14px 18px;font-size:13.5px;color:#991b1b;margin-top:14px}.cbox{background:var(--ink);border-radius:14px;padding:24px;margin-top:20px}.cbox-title{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--slate-l);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.cbox pre{font-family:var(--mono);font-size:12.5px;color:#cbd5e1;line-height:1.9;white-space:pre-wrap;margin:0}.dt{width:100%;border-collapse:collapse;font-size:13px;margin-top:18px;border-radius:12px;overflow:hidden;border:1px solid var(--line)}.dt th{padding:13px 16px;text-align:left;font-weight:600;font-size:12px;background:var(--ink);color:#fff;letter-spacing:.02em}.dt td{padding:12px 16px;border-bottom:1px solid var(--line);color:var(--ink-2)}.dt tr:last-child td{border-bottom:none}.dt tr:nth-child(even) td{background:#fafbfc}.dt td.num{font-family:var(--mono);font-weight:600}.dt td.hl{font-weight:700;font-size:14px;color:var(--ink)}.dt td.hi{font-weight:700;color:var(--ink)}.info-block{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:0 1px 2px rgba(15,23,42,.04),0 8px 24px rgba(15,23,42,.05);padding:40px;margin-bottom:24px}.info-block h2{font-family:var(--serif);font-size:26px;font-weight:600;color:var(--ink);margin-bottom:12px;letter-spacing:-.015em}.info-block h3{font-family:var(--serif);font-size:18px;font-weight:600;margin:28px 0 11px;display:flex;align-items:center;gap:10px;color:var(--ink)}.info-block h3::before{content:'';width:4px;height:18px;background:var(--teal);border-radius:2px;flex-shrink:0}.info-block p{color:var(--ink-2);line-height:1.8;margin-bottom:10px;font-size:14px}.info-block ul,.info-block ol{color:var(--ink-2);padding-left:22px;line-height:1.9;font-size:14px}.info-block li{margin-bottom:6px}.info-block strong{color:var(--ink);font-weight:650}.ut{display:flex;flex-wrap:wrap;gap:9px;margin:14px 0}.utag{border-radius:9px;padding:6px 15px;font-size:12px;font-weight:600;background:var(--ring);color:var(--teal-d);border:1px solid rgba(15,118,110,.22)}.fp{display:block;background:var(--ink);font-family:var(--mono);font-size:13px;padding:13px 18px;border-radius:10px;margin:6px 0;line-height:1.7;color:#7dd3c8}.hdiv{height:1px;background:linear-gradient(90deg,var(--teal),transparent);margin:32px 0;opacity:.3}.faq-wrap{display:flex;flex-direction:column;gap:10px}.fqi{border:1px solid var(--line);border-radius:14px;overflow:hidden}.fqq{padding:18px 22px;font-weight:650;font-size:14px;color:var(--ink);background:var(--bg)}.fqa{padding:15px 22px;font-size:13.5px;color:var(--ink-2);line-height:1.8;background:#fff;border-top:1px solid var(--line)}@media(max-width:760px){.g2,.g3,.g4,.kg{grid-template-columns:1fr 1fr}.tool-head h1{font-size:28px}.tb{padding:22px 20px}.tch{padding:18px 20px}.info-block{padding:24px 20px}}@media(max-width:480px){.g2,.g3,.g4,.kg{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*{transition:none!important}}:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.vk-topbar{background:rgba(248,250,252,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}.vk-topbar-in{max-width:1060px;margin:0 auto;padding:0 20px;height:60px;display:flex;align-items:center;justify-content:space-between}.vk-brand{display:flex;align-items:center;gap:11px;font-weight:700;text-decoration:none}.vk-brand svg{width:34px;height:34px;flex:none}.vk-brand b{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.vk-brand span{font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);display:block;line-height:1}.vk-nav{display:flex;gap:22px;align-items:center}.vk-nav a{font-size:14px;font-weight:500;color:var(--ink-2);text-decoration:none;transition:color .15s}.vk-nav a:hover{color:var(--teal)}.vk-crumb{max-width:1060px;margin:0 auto;padding:16px 20px 0;font-family:var(--mono);font-size:12px;color:var(--slate)}.vk-crumb a{color:var(--teal);text-decoration:none}.vk-crumb a:hover{text-decoration:underline}.vk-related{max-width:1060px;margin:0 auto;padding:10px 20px 60px}.vk-related h3{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--ink);margin-bottom:6px;letter-spacing:-.01em}.vk-related .vk-rsub{font-size:14px;color:var(--slate);margin-bottom:20px}.vk-rgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.vk-rcard{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:16px 17px;text-decoration:none;transition:all .16s;display:flex;flex-direction:column;gap:5px}.vk-rcard:hover{border-color:var(--teal);box-shadow:0 6px 18px rgba(15,23,42,.06);transform:translateY(-2px)}.vk-rcard b{font-size:14px;font-weight:600;color:var(--ink);line-height:1.25}.vk-rcard span{font-size:12px;color:var(--slate);line-height:1.4}.vk-foot{background:#0b1220;color:#cbd5e1;padding:40px 20px;text-align:center}.vk-foot-in{max-width:1060px;margin:0 auto}.vk-foot a{color:#94a3b8;text-decoration:none;margin:0 12px;font-size:13.5px}.vk-foot a:hover{color:#fff}.vk-foot .vk-copy{font-size:12.5px;color:#64748b;margin-top:16px;font-family:var(--mono)}@media(max-width:760px){.vk-rgrid{grid-template-columns:1fr 1fr}.vk-nav{display:none}}@media(max-width:480px){.vk-rgrid{grid-template-columns:1fr}}:root{--teal:#0F766E;--teal-d:#0a5750;--teal-l:#14b8a6;--ink:#1E293B;--ink-2:#334155;--slate:#64748b;--slate-l:#94a3b8;--amber:#D97706;--amber-l:#f59e0b;--bg:#F8FAFC;--card:#FFFFFF;--line:#e2e8f0;--line-2:#cbd5e1;--ring:rgba(15,118,110,0.12);--serif:'Fraunces',Georgia,'Times New Roman',serif;--sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--mono:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace}.tool-head{max-width:760px;margin:0 auto;padding:48px 20px 8px;text-align:center}.tool-head h1 .sub{display:block;font-style:italic;color:var(--teal);font-size:.55em;font-weight:500;margin-top:10px;letter-spacing:0}.tool-head .tagline{font-size:16px;color:var(--ink-2);max-width:600px;margin:16px auto 0;line-height:1.7}.tool-head .htags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:22px}.tool-head .htags span{font-family:var(--mono);font-size:11.5px;font-weight:500;color:var(--ink-2);background:var(--card);border:1px solid var(--line);padding:6px 13px;border-radius:999px;box-shadow:0 1px 2px rgba(15,23,42,.04)}.cnt{max-width:1060px;margin:0 auto;padding:28px 20px 50px}.card{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:0 1px 2px rgba(15,23,42,.04),0 10px 30px rgba(15,23,42,.06);overflow:hidden;margin-bottom:26px}.card-head{display:flex;align-items:center;gap:16px;padding:22px 32px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#f0fdfa 0%,#fbfdfd 100%)}.card-icon{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:15px;font-weight:600;flex-shrink:0;background:linear-gradient(135deg,#0F766E,#14b8a6);color:#fff;letter-spacing:.02em}.card-title{flex:1;text-align:center}.card-title h2{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.card-title p{font-size:13px;color:var(--slate);margin-top:2px}.card-body{padding:32px}.sl{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--slate);text-transform:uppercase;letter-spacing:.1em;margin:28px 0 14px;padding-bottom:9px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}.sl-bar{width:3px;height:13px;border-radius:2px;background:var(--teal);flex-shrink:0;display:inline-block}.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.fd{display:flex;flex-direction:column;gap:6px}.fl{font-size:10.5px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.07em}.iw{display:flex;border-radius:11px;overflow:hidden;border:1.5px solid var(--line-2);background:#fff;transition:border-color .18s,box-shadow .18s}.iw input,.iw select{border:none;outline:none;background:transparent;font-family:inherit;font-size:14px;color:var(--ink);padding:12px 15px;width:100%;min-width:0}.iu{background:var(--bg);padding:12px 13px;font-size:11.5px;font-weight:600;color:var(--slate);white-space:nowrap;border-left:1.5px solid var(--line);flex-shrink:0;display:flex;align-items:center}.btn-row{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;align-items:center}.bcalc{background:var(--teal);color:#fff;border:none;border-radius:12px;padding:14px 36px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .18s,box-shadow .18s,background .18s;box-shadow:0 4px 16px rgba(15,118,110,.28)}.bcalc:hover{background:var(--teal-d);transform:translateY(-2px);box-shadow:0 10px 28px rgba(15,118,110,.34)}.breset{background:#fff;color:var(--ink-2);border:1.5px solid var(--line-2);border-radius:12px;padding:14px 24px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .18s}.bpdf{background:var(--ink);color:#fff;border:none;border-radius:12px;padding:14px 26px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;display:none;align-items:center;gap:8px;box-shadow:0 4px 12px rgba(30,41,59,.25);transition:all .18s}.bpdf:hover{background:#0b1220;transform:translateY(-2px);box-shadow:0 10px 24px rgba(30,41,59,.32)}.bpdf.show{display:inline-flex}.res{margin-top:28px;display:none}.res.show{display:block}.res-hdr{font-family:var(--mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);display:flex;align-items:center;gap:10px;margin-bottom:18px}.res-dot{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#0F766E,#14b8a6);display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;font-weight:700;flex-shrink:0}.kg{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.kc{border-radius:14px;padding:18px 14px;text-align:center;border:1px solid #cdeae6;background:linear-gradient(135deg,#eafaf7,#d6f2ec);transition:transform .15s;cursor:default}.kv{font-family:var(--serif);font-size:24px;font-weight:600;line-height:1;margin-bottom:4px;letter-spacing:-.01em;color:#0a5750}.ku{font-family:var(--mono);font-size:11px;font-weight:600;color:#0F766E;margin-bottom:3px;text-transform:uppercase;letter-spacing:.04em}.kl{font-size:11px;font-weight:500;color:var(--slate)}.a-ok{background:#ecfdf5;border:1px solid #a7f3d0;border-radius:12px;padding:12px 18px;font-size:13px;color:#065f46;margin-top:14px}.a-warn{background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:12px 18px;font-size:13px;color:#92400e;margin-top:14px}.a-info{background:#ecfeff;border:1px solid #99e6e0;border-radius:12px;padding:12px 18px;font-size:13px;color:#0a5750;margin-top:14px}.cbox{background:var(--ink);border-radius:13px;padding:22px;margin-top:18px}.cbox-lbl{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--slate-l);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}.cbox pre{font-family:var(--mono);font-size:12px;color:#cbd5e1;line-height:1.85;white-space:pre-wrap;margin:0}.dt{width:100%;border-collapse:collapse;font-size:13px;margin-top:16px;border-radius:10px;overflow:hidden;border:1px solid var(--line)}.dt th{padding:11px 14px;text-align:left;font-weight:600;font-size:11.5px;background:var(--ink);color:#fff}.dt td{padding:10px 14px;border-bottom:1px solid var(--line);color:var(--ink-2)}.dt td.hi{font-weight:700;color:#0a5750}.dbox{border-radius:13px;padding:18px 20px;margin-top:14px;border:1px solid #cdeae6;background:linear-gradient(135deg,#eafaf7,#d6f2ec)}.drow{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid rgba(10,87,80,.1);font-size:13px}.drow:last-child{border-bottom:none}.drow span{color:var(--ink-2)}.drow strong{color:#0a5750;font-family:var(--mono);font-size:12.5px}.iblock{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:0 1px 2px rgba(15,23,42,.04),0 8px 24px rgba(15,23,42,.05);padding:38px 40px;margin-bottom:26px}.iblock h2{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);margin-bottom:12px;letter-spacing:-.015em}.iblock h3{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin:26px 0 10px;display:flex;align-items:center;gap:9px}.iblock h3::before{content:'';width:4px;height:18px;background:var(--teal);border-radius:2px;flex-shrink:0}.iblock p{color:var(--ink-2);line-height:1.8;font-size:14px;margin-bottom:10px}.iblock ul{color:var(--ink-2);padding-left:20px;line-height:1.9;font-size:14px}.iblock li{margin-bottom:5px}.iblock strong{color:var(--ink);font-weight:650}.tags{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.tag{border-radius:8px;padding:5px 14px;font-size:12px;font-weight:600;background:var(--ring);color:var(--teal-d);border:1px solid rgba(15,118,110,.22)}.fp{display:block;background:var(--ink);font-family:var(--mono);font-size:12px;padding:11px 18px;border-radius:9px;margin:5px 0;line-height:1.7;color:#7dd3c8}.hdiv{height:1px;background:linear-gradient(90deg,var(--teal),transparent);margin:28px 0;opacity:.35}.faq{display:flex;flex-direction:column;gap:9px}.fq{border:1px solid var(--line);border-radius:12px;overflow:hidden}.fq-q{padding:14px 20px;font-weight:650;font-size:13.5px;color:var(--ink);background:var(--bg)}.fq-a{padding:12px 20px;font-size:13px;color:var(--ink-2);line-height:1.78;background:#fff;border-top:1px solid var(--line)}.card-body{padding:20px 18px}.iblock{padding:26px 20px}.btn-row{flex-direction:column;align-items:stretch}.bcalc,.breset,.bpdf{text-align:center;justify-content:center}
/* ============================================================
   AUTHORITATIVE MOBILE RESPONSIVE LAYER (appended last = wins)
   Fixes: cramped multi-column inputs, clipped dropdown text,
   squeezed result cards, overflowing tables/code on phones.
   ============================================================ */

/* Tablet: 3- and 4-col input grids drop to 2 cols, result KPIs to 2 */
@media (max-width:820px){
  .g3,.g4{grid-template-columns:1fr 1fr !important}
  .kg{grid-template-columns:1fr 1fr !important}
}

/* Phone: EVERYTHING goes single-column so labels + inputs are full width */
@media (max-width:560px){
  .g2,.g3,.g4{grid-template-columns:1fr !important;gap:14px !important}
  .kg{grid-template-columns:1fr 1fr !important;gap:10px !important}

  /* inputs + selects: full width, readable, text never clipped */
  .iw{width:100% !important}
  .iw input,.iw select{font-size:16px !important;padding:13px 14px !important;min-width:0 !important;text-overflow:ellipsis}
  /* 16px font stops iOS auto-zoom on focus */
  select{max-width:100% !important;text-overflow:ellipsis}
  .iu{font-size:12px !important;padding:13px 11px !important}
  .fl{font-size:12px !important}            /* field labels a touch bigger */
  .hint{font-size:12px !important}

  /* card padding tighter so content has room */
  .card-body{padding:18px 15px !important}
  .card-head{padding:16px 16px !important}
  .card-title h2{font-size:17px !important}
  .cnt{padding:20px 14px 40px !important}
  .tool-head{padding:34px 16px 6px !important}

  /* buttons stack full-width and are easy to tap */
  .btn-row{flex-direction:column !important;align-items:stretch !important;gap:10px !important}
  .bcalc,.breset,.bpdf{width:100% !important;justify-content:center !important;text-align:center !important;padding:15px !important;font-size:15px !important}

  /* RESULT cards: full readable size, numbers not squeezed */
  .kc{padding:16px 12px !important}
  .kv{font-size:22px !important}
  .ku{font-size:10.5px !important}
  .kl{font-size:11px !important}

  /* calc trace + formula blocks: scroll instead of overflow/clip */
  .cbox,.fp,.fexpr{overflow-x:auto !important;-webkit-overflow-scrolling:touch}
  .cbox pre{font-size:11.5px !important}

  /* data tables: horizontal scroll wrapper so columns don't crush */
  .dt{display:block !important;overflow-x:auto !important;white-space:nowrap !important;-webkit-overflow-scrolling:touch}

  /* detail rows (label:value) wrap nicely */
  .drow{flex-wrap:wrap !important;gap:2px}

  /* info/FAQ readable */
  .iblock{padding:22px 16px !important}
  .iblock h2{font-size:21px !important}
  .fq-q,.fq-a{padding-left:16px !important;padding-right:16px !important}

  /* related-tools + resource links wrap */
  .vk-rgrid{grid-template-columns:1fr !important}
  .tool-res-in{flex-direction:column !important;align-items:stretch !important}
  .tool-res-in a{text-align:center}
}

/* Very small phones */
@media (max-width:380px){
  .kg{grid-template-columns:1fr !important}
  .tool-head h1{font-size:25px !important}
}

/* Global safety: never let anything force horizontal page scroll */
@media (max-width:560px){
  html,body{overflow-x:hidden !important;max-width:100% !important}
  .card,.iblock,.cnt,.tool-head{max-width:100% !important}
  img,svg,table,pre,code{max-width:100% !important}
}

/* Mobile: subtle scroll affordance for wide data tables */
@media (max-width:560px){
  .dt-wrap{position:relative}
  .dt{margin-top:8px !important}
  /* faint right-edge fade hinting horizontal scroll */
  .card-body .dt::after,.dt::after{content:""}
}

/* ============================================================
   MOBILE POLISH v2 — professional table & result presentation
   ============================================================ */
@media (max-width:560px){
  /* Tables: contained, scrollable, with rounded border preserved */
  .dt{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    overflow-x:auto !important;
    white-space:nowrap !important;
    -webkit-overflow-scrolling:touch;
    border:1px solid var(--line) !important;
    border-radius:12px !important;
  }
  /* tighten table cell padding so more fits before scroll is needed */
  .dt th,.dt td{padding:11px 13px !important;font-size:12.5px !important}

  /* KPI result cards: clean 2-col, comfortable height, centered */
  .kg{grid-template-columns:1fr 1fr !important;gap:11px !important}
  .kc{padding:18px 10px !important;border-radius:14px !important;min-height:104px;display:flex;flex-direction:column;justify-content:center}
  .kv{font-size:23px !important;word-break:break-word}
  .ku{font-size:10px !important;margin-top:2px}
  .kl{font-size:10.5px !important;line-height:1.3}

  /* result summary alert: comfortable reading */
  .a-ok,.a-warn,.a-info{font-size:13.5px !important;line-height:1.6 !important;padding:15px 16px !important}

  /* footer: add breathing room + center the brand block nicely */
  .site-foot{padding:44px 0 26px !important}
  .site-foot .foot-grid{gap:30px !important;text-align:left}
  .site-foot .foot-brand p{max-width:100% !important;font-size:14px !important}
  .site-foot .foot-col h5{margin-bottom:12px !important}
  .site-foot .foot-col a{padding:7px 0 !important;font-size:14.5px !important}
}
