/**
 * PaycheckPeek â€” Global Design System
 * Shared styles for all tool pages on paycheckpeek.com
 *
 * IMPORTANT: The existing index.html retains its inline <style> block.
 * This stylesheet is for NEW tool pages that use the shared component system.
 */

/* ==============================
   RESET & BASE
   ============================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;max-width:100%;overflow-x:hidden}
body{font-family:'Mulish',system-ui,-apple-system,sans-serif;background:var(--bg);color:#F1F5F9;line-height:1.6;overflow-x:hidden;min-height:100vh;display:flex;flex-direction:column}
h1,h2,h3,.display{font-family:'Unbounded',system-ui,-apple-system,cursive}
img,video,canvas,svg{max-width:100%;height:auto}
*{word-wrap:break-word;overflow-wrap:break-word}
main{flex:1}


/* ==============================
   DESIGN TOKENS
   ============================== */
:root{
  --bg:#1A1A2E;
  --bg2:#16213E;
  --bg3:#0F3460;
  --neon:#39FF14;
  --neon2:#32CD32;
  --neon-rgb:57,255,20;
  --white:#E8F5E9;
  --gray:#A8B8CC;
  --card:rgba(255,255,255,.05);
  --glass:rgba(255,255,255,.07);
  --red:#FF6B6B;
  --green:#22C55E;
  --amber:#F59E0B;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 8px 32px rgba(0,0,0,.5);
}


/* ==============================
   LAYOUT
   ============================== */
.container{max-width:1100px;margin:0 auto;padding:0 20px;width:100%}


/* ==============================
   STICKY HEADER
   ============================== */
.sticky-header{position:sticky;top:0;z-index:100;background:rgba(26,26,46,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);padding:14px 0;transition:box-shadow .3s}
.sticky-header.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto;padding:0 20px;gap:12px}
.logo{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.1rem;color:var(--neon);text-decoration:none;font-weight:700;white-space:nowrap}
.header-right{display:flex;align-items:center;gap:12px}
.header-cta{background:var(--neon);color:var(--bg);padding:10px 24px;border-radius:50px;font-weight:700;font-size:.85rem;text-decoration:none;border:none;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0}
.header-cta:hover{background:var(--neon2);transform:translateY(-1px)}
.header-guides-link{color:var(--gray);text-decoration:none;font-weight:600;font-size:.88rem;padding:8px 16px;border-radius:50px;transition:all .2s;border:1px solid transparent;white-space:nowrap}
.header-guides-link:hover{color:var(--accent);border-color:rgba(var(--accent-rgb,99,102,241),.3);background:rgba(var(--accent-rgb,99,102,241),.06)}


/* ==============================
   HAMBURGER / NAV TOGGLE
   ============================== */
.nav-toggle{background:none;border:1.5px solid rgba(255,255,255,.15);border-radius:8px;width:40px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;flex-shrink:0}
.nav-toggle:hover{border-color:var(--neon)}
.hamburger{display:block;width:18px;height:2px;background:#F1F5F9;border-radius:1px;position:relative;transition:all .3s}
.hamburger::before,.hamburger::after{content:'';position:absolute;left:0;width:18px;height:2px;background:#F1F5F9;border-radius:1px;transition:all .3s}
.hamburger::before{top:-6px}
.hamburger::after{top:6px}
.nav-toggle.open .hamburger{background:transparent}
.nav-toggle.open .hamburger::before{top:0;transform:rotate(45deg);background:var(--neon)}
.nav-toggle.open .hamburger::after{top:0;transform:rotate(-45deg);background:var(--neon)}


/* ==============================
   TOOL NAVIGATION PANEL
   ============================== */
.tool-nav{position:fixed;top:0;right:-360px;width:340px;max-width:85vw;height:100vh;background:rgba(22,33,62,.98);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-left:1px solid rgba(255,255,255,.08);z-index:200;transition:right .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-8px 0 40px rgba(0,0,0,.5)}
.tool-nav.open{right:0}
.tool-nav-inner{padding:20px}
.nav-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:16px}
.nav-title{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1rem;color:var(--neon)}
.nav-close{background:none;border:none;color:var(--gray);font-size:1.8rem;cursor:pointer;padding:0 4px;transition:color .2s;line-height:1}
.nav-close:hover{color:var(--neon)}
.nav-group{margin-bottom:20px}
.nav-group-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--gray);margin-bottom:8px;padding-left:4px;font-weight:700}
.nav-tool-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;text-decoration:none;color:#F1F5F9;transition:all .2s;margin-bottom:2px}
.nav-tool-item:hover{background:rgba(57,255,20,.06)}
.nav-tool-item.active{background:rgba(57,255,20,.1);border:1px solid rgba(57,255,20,.2)}
.nav-tool-icon{font-size:1.2rem;flex-shrink:0;width:28px;text-align:center}
.nav-tool-info{display:flex;flex-direction:column;min-width:0}
.nav-tool-name{font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-tool-desc{font-size:.72rem;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}


/* ==============================
   BREADCRUMB
   ============================== */
.breadcrumb{padding:16px 0 8px;font-size:.82rem;color:var(--gray)}
.breadcrumb a{color:var(--gray);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--neon)}


/* ==============================
   PAGE HERO (for sub-pages)
   ============================== */
.page-hero{padding:48px 0 24px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(var(--neon-rgb),.06) 0%,transparent 70%);pointer-events:none}
.page-hero h1{font-size:clamp(1.5rem,4vw,2.4rem);line-height:1.2;max-width:800px;margin:0 auto 12px}
.page-hero h1 span{color:var(--neon)}
.page-hero .sub{color:var(--gray);font-size:1rem;max-width:600px;margin:0 auto}


/* ==============================
   CALCULATOR / TOOL PANELS
   ============================== */
.tool-section{padding:24px 0 40px}
.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.tool-panel{background:linear-gradient(145deg,rgba(22,33,62,.9),rgba(26,26,46,.95));border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:28px;box-shadow:var(--shadow)}
.panel-title{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.1rem;margin-bottom:20px;color:var(--neon);display:flex;align-items:center;gap:8px}


/* ==============================
   FORM FIELDS
   ============================== */
.field{margin-bottom:16px;width:100%}
.field label{display:block;font-weight:700;font-size:.8rem;margin-bottom:5px;color:var(--gray);text-transform:uppercase;letter-spacing:.5px}
.field input,.field select{width:100%;background:var(--bg);border:1.5px solid rgba(255,255,255,.1);color:#F1F5F9;padding:11px 14px;border-radius:var(--radius-sm);font-family:'Mulish',system-ui,-apple-system,sans-serif;font-size:.95rem;outline:none;transition:border-color .3s}
.field input:focus,.field select:focus{border-color:var(--neon)}
.field input.field-invalid{border-color:var(--red)}
.field-error{display:block;color:var(--red);font-size:.75rem;margin-top:4px}
.field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394A3B8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.field textarea{width:100%;background:var(--bg);border:1.5px solid rgba(255,255,255,.1);color:#F1F5F9;padding:11px 14px;border-radius:var(--radius-sm);font-family:'Mulish',system-ui,-apple-system,sans-serif;font-size:.95rem;outline:none;transition:border-color .3s;resize:vertical;min-height:80px}
.field textarea:focus{border-color:var(--neon)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}


/* ==============================
   BUTTONS
   ============================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:50px;font-weight:700;font-size:.9rem;cursor:pointer;font-family:'Mulish',system-ui,-apple-system,sans-serif;border:none;transition:all .3s;text-decoration:none}
.btn-primary{background:var(--neon);color:var(--bg)}
.btn-primary:hover{background:var(--neon2);transform:translateY(-1px)}
.btn-outline{background:transparent;color:#F1F5F9;border:1.5px solid rgba(255,255,255,.15)}
.btn-outline:hover{border-color:var(--neon);color:var(--neon)}
.btn-sm{padding:8px 18px;font-size:.82rem}
.action-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--bg);border:1.5px solid rgba(255,255,255,.1);color:#F1F5F9;padding:12px 20px;border-radius:50px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'Mulish',system-ui,-apple-system,sans-serif;text-decoration:none;flex:1 1 auto;min-width:120px;white-space:nowrap}
.action-btn:hover{border-color:var(--neon);color:var(--neon)}
.action-btn.primary{background:var(--neon);color:var(--bg);border-color:var(--neon)}
.action-btn.primary:hover{background:var(--neon2)}


/* ==============================
   RESULTS CARD
   ============================== */
.result-card{background:linear-gradient(135deg,rgba(57,255,20,.08),rgba(15,52,96,.3));border:2px solid rgba(57,255,20,.2);border-radius:20px;padding:28px;margin-bottom:24px}
.result-card h3{font-size:1.05rem;margin-bottom:12px;color:var(--neon);display:flex;align-items:center;gap:8px}
.result-row{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;font-size:.9rem;gap:8px;border-bottom:1px solid rgba(255,255,255,.04)}
.result-row:last-child{border-bottom:none}
.result-row .label{color:var(--gray);min-width:0}
.result-row .value{font-weight:700;white-space:nowrap;flex-shrink:0}
.result-row.highlight{font-weight:800;font-size:1.2rem;color:var(--neon);border-top:2px solid rgba(57,255,20,.2);padding-top:12px;margin-top:8px;border-bottom:none}
.result-row.highlight .value{color:var(--neon)}
.result-row .deduct{color:var(--red)}

/* Rate Badges */
.rates-row{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}
.rate-badge{background:var(--glass);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 16px;text-align:center;flex:1;min-width:0}
.rate-badge .rb-label{color:var(--gray);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rate-badge .rb-val{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.3rem;color:var(--neon);margin-top:4px}


/* ==============================
   TABLES
   ============================== */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:24px;width:100%}
.data-table{width:100%;border-collapse:collapse;font-size:.85rem}
.data-table th{text-align:left;color:var(--gray);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap}
.data-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04);white-space:nowrap}
.data-table tr:hover{background:rgba(255,255,255,.02)}
.data-table .amt{text-align:right;font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:.85rem}
.data-table .highlight-row{background:rgba(57,255,20,.06);border-left:3px solid var(--neon)}


/* ==============================
   INSIGHT / INFO CARDS
   ============================== */
.insight-card{background:var(--card);border:1px solid rgba(57,255,20,.15);border-radius:var(--radius);padding:24px;margin-bottom:24px}
.insight-card h3{font-size:1.05rem;margin-bottom:10px;display:flex;align-items:center;gap:8px;color:var(--neon)}
.insight-card p{color:var(--gray);font-size:.92rem;line-height:1.7}
.insight-card strong{color:#F1F5F9}


/* ==============================
   CHART
   ============================== */
.chart-wrap{margin-top:24px;max-width:350px;margin-left:auto;margin-right:auto}


/* ==============================
   TOGGLE / COLLAPSIBLE
   ============================== */
.toggle-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;cursor:pointer;padding:8px 0}
.toggle-row span{font-weight:600;font-size:.85rem;color:var(--gray)}
.toggle-arrow{color:var(--neon);transition:transform .3s}
.toggle-row.open .toggle-arrow{transform:rotate(180deg)}
.collapsible{max-height:0;overflow:hidden;transition:max-height .4s ease}
.collapsible.open{max-height:1000px}


/* ==============================
   RELATED TOOLS
   ============================== */
.related-tools-section{margin-top:40px;padding:32px 0}
.related-tools-title{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.2rem;color:var(--neon);margin-bottom:20px;text-align:center}
.related-tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;max-width:900px;margin:0 auto}
.related-tool-card{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:14px;text-decoration:none;color:#F1F5F9;transition:all .25s}
.related-tool-card:hover{border-color:var(--neon);background:rgba(57,255,20,.04);transform:translateY(-2px)}
.related-tool-icon{font-size:1.6rem;flex-shrink:0}
.related-tool-text{display:flex;flex-direction:column;min-width:0;flex:1}
.related-tool-text strong{font-size:.9rem;margin-bottom:2px}
.related-tool-text span{font-size:.78rem;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.related-tool-arrow{color:var(--neon);font-size:1.1rem;flex-shrink:0;transition:transform .2s}
.related-tool-card:hover .related-tool-arrow{transform:translateX(4px)}


/* ==============================
   FOOTER (injected by footer.js)
   ============================== */
.site-footer{background:rgba(0,0,0,.3);border-top:1px solid rgba(255,255,255,.06);padding:48px 20px 32px;margin-top:40px}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:20px}
.footer-heading{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:.85rem;color:var(--neon);margin-bottom:12px;text-align:center}
.footer-tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px;width:100%;max-width:900px}
.footer-tool-grid a{color:var(--gray);text-decoration:none;font-size:.82rem;padding:8px 12px;border-radius:8px;transition:all .2s;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.footer-tool-grid a:hover{color:var(--neon);background:rgba(57,255,20,.06)}
.footer-divider{width:100%;max-width:900px;height:1px;background:rgba(255,255,255,.06);margin:8px 0}
.footer-links{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.footer-links a{color:var(--gray);text-decoration:none;font-size:.88rem;padding:8px 16px;border-radius:8px;transition:all .2s}
.footer-links a:hover{color:var(--neon);background:rgba(57,255,20,.06)}
.footer-links a:focus-visible{outline:2px solid var(--neon);outline-offset:2px}
.divider{width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--neon),transparent);border-radius:1px;margin:0 auto}
.copy{color:var(--gray);font-size:.82rem;text-align:center}


/* ==============================
   DISCLAIMER
   ============================== */
.disclaimer{color:var(--gray);font-size:.8rem;padding:16px;background:var(--card);border-radius:10px;line-height:1.6;margin-top:24px}


/* ==============================
   COOKIE BANNER
   ============================== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:rgba(26,26,46,.97);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);padding:16px 20px;display:flex;align-items:center;justify-content:center;gap:16px;z-index:1000;transform:translateY(100%);transition:transform .5s;flex-wrap:wrap}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner p{color:var(--gray);font-size:.85rem;max-width:600px}
.cookie-banner a{color:var(--neon)}
.cookie-accept{background:var(--neon);color:var(--bg);border:none;padding:10px 24px;border-radius:50px;font-weight:700;cursor:pointer;font-size:.85rem}


/* ==============================
   TOAST
   ============================== */
.toast{background:var(--bg2);border:1px solid rgba(57,255,20,.3);color:#F1F5F9;padding:14px 28px;border-radius:12px;font-weight:600;font-size:.9rem;transition:all .4s;box-shadow:0 8px 32px rgba(0,0,0,.5);max-width:90vw;text-align:center;opacity:0;transform:translateY(20px)}
.toast.show{opacity:1;transform:translateY(0)}
.toast.hide{opacity:0;transform:translateY(20px)}


/* ==============================
   SCROLL ANIMATIONS
   ============================== */
[data-animate]{opacity:0;transform:translateY(30px);transition:opacity .5s ease,transform .5s ease;will-change:opacity,transform}
[data-animate].visible{opacity:1;transform:translateY(0)}


/* ==============================
   ARTICLE / GUIDE STYLES
   ============================== */
.article-container{max-width:780px;margin:0 auto;padding:0 20px}
.article-hero{padding:48px 0 20px;text-align:center;position:relative;overflow:hidden}
.article-hero::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(var(--neon-rgb),.06) 0%,transparent 70%);pointer-events:none}
.article-hero h1{font-size:clamp(1.6rem,4vw,2.4rem);line-height:1.25;max-width:800px;margin:0 auto 12px}
.article-hero h1 span{color:var(--neon)}
.article-meta{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--gray);font-size:.85rem;flex-wrap:wrap;margin-bottom:8px}
.article-meta .tag{background:rgba(var(--neon-rgb),.12);color:var(--neon);padding:4px 12px;border-radius:50px;font-size:.78rem;font-weight:600}

.quick-answer{background:linear-gradient(135deg,rgba(var(--neon-rgb),.1),rgba(var(--neon-rgb),.03));border:1px solid rgba(var(--neon-rgb),.25);border-radius:var(--radius);padding:24px 28px;margin:24px 0 32px;font-size:1.02rem;line-height:1.8;color:var(--white)}
.quick-answer strong{color:var(--neon)}

.article-body{color:var(--gray);font-size:1rem;line-height:1.85}
.article-body h2{font-family:'Unbounded',system-ui,-apple-system,cursive;color:#F1F5F9;font-size:1.45rem;margin:40px 0 16px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06)}
.article-body h3{font-family:'Unbounded',system-ui,-apple-system,cursive;color:#F1F5F9;font-size:1.15rem;margin:28px 0 10px}
.article-body p{margin-bottom:16px}
.article-body ul,.article-body ol{margin:0 0 16px 20px;padding-left:0}
.article-body li{margin-bottom:8px;line-height:1.7}
.article-body strong{color:#F1F5F9}
.article-body a{color:var(--neon);text-decoration:none;border-bottom:1px solid rgba(var(--neon-rgb),.3);transition:border-color .2s}
.article-body a:hover{border-color:var(--neon)}
.article-body blockquote{border-left:3px solid var(--neon);padding:12px 20px;margin:20px 0;background:rgba(var(--neon-rgb),.04);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;color:#c4d0e0}

.example-box{background:linear-gradient(145deg,rgba(22,33,62,.7),rgba(26,26,46,.9));border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:24px 28px;margin:24px 0}
.example-box h4{color:var(--neon);font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.05rem;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.example-box .example-inputs,.example-box .example-outputs{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:12px}
.example-box .ex-item{background:rgba(0,0,0,.15);padding:10px 14px;border-radius:var(--radius-sm);display:flex;flex-direction:column}
.example-box .ex-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--gray);margin-bottom:2px}
.example-box .ex-value{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.1rem;color:var(--neon);font-weight:700}
.example-box .ex-result{background:rgba(var(--neon-rgb),.08);border:1px solid rgba(var(--neon-rgb),.2);padding:10px 14px;border-radius:var(--radius-sm);display:flex;flex-direction:column}
.example-box .ex-result .ex-value{color:var(--green)}
.example-box p{color:var(--gray);font-size:.92rem;line-height:1.7;margin-top:8px}

.cta-card{background:linear-gradient(135deg,rgba(var(--neon-rgb),.15),rgba(var(--neon-rgb),.05));border:1px solid rgba(var(--neon-rgb),.3);border-radius:var(--radius);padding:28px;text-align:center;margin:30px 0}
.cta-card h3{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.3rem;color:#F1F5F9;margin-bottom:8px}
.cta-card p{color:var(--gray);margin-bottom:16px;font-size:.95rem}
.cta-card a{display:inline-block;background:var(--neon);color:var(--bg);padding:14px 36px;border-radius:50px;font-weight:700;text-decoration:none;transition:all .3s;font-size:.95rem}
.cta-card a:hover{background:var(--neon2);transform:translateY(-2px)}

.faq-section{padding:40px 0}
.faq-title{font-family:'Unbounded',system-ui,-apple-system,cursive;font-size:1.5rem;text-align:center;margin-bottom:24px;color:#F1F5F9}
.faq-item{border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;background:var(--card);transition:all .3s}
.faq-item:hover{border-color:rgba(var(--neon-rgb),.3)}
.faq-q{padding:18px 24px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:1rem;color:#F1F5F9;user-select:none}
.faq-q:hover{color:var(--neon)}
.faq-q .icon{color:var(--neon);font-size:1.4rem;transition:transform .3s;flex-shrink:0;margin-left:12px}
.faq-item.open .faq-q .icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:500px;padding:0 24px 18px}
.faq-a p{color:var(--gray);font-size:.95rem;line-height:1.7;margin-bottom:8px}
.faq-a p:last-child{margin-bottom:0}

.author-section{background:var(--card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:24px 28px;margin:32px 0;display:flex;align-items:flex-start;gap:16px}
.author-section .author-avatar{width:48px;height:48px;border-radius:50%;background:rgba(var(--neon-rgb),.15);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.author-section .author-info{flex:1}
.author-section .author-name{font-weight:700;color:#F1F5F9;font-size:.95rem;margin-bottom:4px}
.author-section .author-bio{color:var(--gray);font-size:.85rem;line-height:1.6}

@media(max-width:768px){.quick-answer{padding:18px 20px}.article-hero h1{font-size:1.45rem}.example-box .example-inputs,.example-box .example-outputs{grid-template-columns:1fr}.example-box{padding:18px 20px}.author-section{flex-direction:column;align-items:center;text-align:center}}


/* ==============================
   PRINT STYLES
   ============================== */
@media print{
  .sticky-header,.cookie-banner,.action-bar,.tool-nav,.nav-toggle,.related-tools-section,.site-footer,footer,.cookie-banner,.toast,.breadcrumb,.page-hero,.disclaimer,.btn,.btn-primary,.btn-outline,.action-btn,.header-cta,.header-guides-link,.nav-toggle,.field label,.field input,.field select,.field textarea,.row2,.row3,.chart-wrap,canvas,.toggle-row,.collapsible:not(.open),[data-animate]:not(.visible){display:none!important}
  body{background:#fff;color:#111;font-size:11pt}
  .tool-grid{grid-template-columns:1fr!important}
  .tool-panel{border:1px solid #ddd;box-shadow:none;background:#fff;break-inside:avoid;padding:16px}
  .result-card{border:2px solid #1a6b00;box-shadow:none;background:#f0fff0;break-inside:avoid;padding:20px;border-radius:8px}
  h1,h2,h3{color:#111}
  .panel-title,.rate-badge .rb-val{color:#1a6b00!important}
  *{color:#333!important}
  .result-row.highlight,.result-row.highlight .value{color:#1a6b00!important;font-weight:700}
  .result-row .deduct{color:#c00!important}
  .result-row{border-bottom:1px solid #eee;padding:6px 0}
  .insight-card{background:#f9fafb!important;border:1px solid #e5e7eb!important;page-break-inside:avoid}
  .data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{border:1px solid #ddd;padding:6px 8px}.data-table th{background:#f5f5f5!important}
  .rates-row{display:flex;gap:8px;flex-wrap:wrap}.rate-badge{border:1px solid #ddd!important;padding:8px!important;text-align:center}
}


/* ==============================
   RESPONSIVE â€” TABLET
   ============================== */
@media(max-width:768px){
  .tool-grid{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .row3{grid-template-columns:1fr}
  .container{padding:0 12px}
  .page-hero h1{font-size:1.5rem}
  .page-hero{padding:40px 0 16px}
  .tool-panel{padding:18px 14px}
  .panel-title{font-size:.95rem}
  .rates-row{gap:8px;margin-top:14px}
  .rate-badge{padding:10px 8px}
  .rate-badge .rb-label{font-size:.65rem}
  .rate-badge .rb-val{font-size:1rem}
  .action-bar{flex-direction:column;gap:8px}
  .action-btn{width:100%;min-width:0}
  .chart-wrap{max-width:280px}
  .footer-tool-grid{grid-template-columns:1fr 1fr}
  .site-footer{padding:32px 16px 24px}
  .footer-links{flex-wrap:wrap;gap:4px}
  .footer-links a{font-size:.82rem;padding:8px 12px}
  .related-tools-grid{grid-template-columns:1fr}
}


/* ==============================
   RESPONSIVE â€” SMALL PHONES
   ============================== */
@media(max-width:420px){
  .container{padding:0 10px}
  .header-inner{padding:0 10px}
  .logo{font-size:.95rem}
  .header-cta{padding:8px 16px;font-size:.8rem}
  .page-hero h1{font-size:1.3rem}
  .tool-panel{padding:14px 10px}
  .rate-badge .rb-label{font-size:.6rem}
  .rate-badge .rb-val{font-size:.9rem}
  .footer-tool-grid{grid-template-columns:1fr}
}

/* -- Skip Navigation Link (WCAG 2.4.1) ----------------------------------- */
.skip-link{position:absolute;top:-100%;left:16px;z-index:9999;padding:12px 24px;background:var(--accent,#00D4FF);color:#0A0F1E;font-weight:700;font-size:.95rem;border-radius:0 0 8px 8px;text-decoration:none;transition:top .2s;white-space:nowrap}
.skip-link:focus{top:0}

/* -- Focus Visible - WCAG 2.4.7 ------------------------------------------ */
:focus-visible{outline:3px solid var(--accent,#00D4FF);outline-offset:3px;border-radius:4px}
button:focus-visible,.action-btn:focus-visible,.nav-tool-item:focus-visible,.related-tool-card:focus-visible,.footer-tool-grid a:focus-visible,.footer-links a:focus-visible,.header-cta:focus-visible,.header-guides-link:focus-visible,.cta-card a:focus-visible{outline:3px solid var(--accent,#00D4FF);outline-offset:3px}

/* -- Reduced Motion - WCAG 2.3.3 ----------------------------------------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  [data-animate]{opacity:1!important;transform:none!important;transition:none!important}
  .tool-nav{transition:none!important}
  .cookie-banner{transition:none!important}
}

#site-header{min-height:92px}
#site-nav{min-height:48px}