/* EstimateWiz — global styles (v1) */
:root{
  --ink:#111827; --muted:#5b6472; --bg:#f4f5f7; --card:#ffffff;
  --brand:#047857; --brand-dark:#065f46; --brand-ink:#064e3b;
  --accent:#f59e0b; --line:#e5e7eb; --ok:#059669; --soft:#ecfdf5;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1140px;margin:0 auto;padding:0 20px}

/* header */
.site-head{background:#fff;border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.logo{font-weight:800;font-size:20px;color:var(--ink);letter-spacing:-.02em}
.logo b{color:var(--brand)}
.logo .zap{color:var(--accent)}
.nav{display:flex;gap:22px;font-size:14.5px;font-weight:600}
.nav a{color:#374151}
.nav a:hover{color:var(--brand);text-decoration:none}
@media(max-width:640px){.nav{display:none}}

/* hero */
.hero{padding:38px 0 10px;text-align:center}
.hero h1{font-size:clamp(26px,4vw,40px);line-height:1.2;margin:0 0 10px;letter-spacing:-.02em}
.hero p.sub{max-width:760px;margin:0 auto;color:var(--muted);font-size:17px}
.chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:16px 0 0}
.chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 14px;font-size:13.5px;font-weight:600;color:#374151}
.chip::before{content:"✓ ";color:var(--ok);font-weight:800}

/* tool */
.tool{padding:26px 0 8px}
.tool-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);gap:22px;align-items:start}
@media(max-width:980px){.tool-grid{grid-template-columns:1fr}}
.panel{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px}
.panel h3{margin:0 0 12px;font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.fgroup{margin-bottom:20px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.frow3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
@media(max-width:520px){.frow,.frow3{grid-template-columns:1fr}}
label{display:block;font-size:12.5px;font-weight:600;color:#374151;margin:8px 0 3px}
input[type=text],input[type=email],input[type=date],input[type=number],select,textarea{
  width:100%;padding:9px 11px;border:1px solid #d1d5db;border-radius:8px;font:inherit;font-size:14px;color:var(--ink);background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid #a7f3d0;border-color:var(--brand)}
textarea{resize:vertical;min-height:64px}

/* line items editor */
.items-head,.item-row{display:grid;grid-template-columns:minmax(0,1fr) 64px 88px 90px 30px;gap:8px;align-items:center}
.items-head{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:6px}
.item-row{margin-bottom:8px}
.item-amt{font-size:13.5px;font-weight:600;text-align:right;white-space:nowrap}
.item-del{background:none;border:none;color:#9ca3af;font-size:17px;cursor:pointer;padding:2px}
.item-del:hover{color:#dc2626}
.add-row{background:var(--soft);border:1px dashed #a7f3d0;color:var(--brand);border-radius:8px;padding:8px 12px;font:inherit;font-size:14px;font-weight:600;cursor:pointer;width:100%;margin-top:4px}
.add-row:hover{background:#d1fae5}

/* actions */
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.btn{display:inline-block;border:none;border-radius:10px;padding:12px 22px;font:inherit;font-size:15.5px;font-weight:700;cursor:pointer;text-align:center}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-dark)}
.btn-ghost{background:#fff;color:#374151;border:1px solid #d1d5db}
.btn-ghost:hover{border-color:#9ca3af}
.hint{font-size:12.5px;color:var(--muted);margin-top:8px}

/* badge unlock box */
.unlock{margin-top:16px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:12px 14px}
.unlock p{margin:0 0 8px;font-size:13.5px;color:#374151}
.unlock-row{display:flex;gap:8px}
.unlock-row input{flex:1}
.unlock-row .btn{padding:9px 14px;font-size:14px;white-space:nowrap}
.unlock .hint{margin:8px 0 0}

/* paper preview */
.paper-wrap{position:sticky;top:16px}
.paper{background:#fff;border:1px solid var(--line);border-radius:6px;box-shadow:0 10px 30px rgba(17,24,39,.08);padding:34px 36px;font-size:13px;min-height:540px;color:#1f2937}
.p-top{display:flex;justify-content:space-between;gap:16px;margin-bottom:22px}
.p-from{white-space:pre-line}
.p-from .p-name{font-size:16px;font-weight:800}
.p-doc{text-align:right}
.p-doc .p-title{font-size:22px;font-weight:800;letter-spacing:.06em;color:var(--brand-ink)}
.p-meta{font-size:12.5px;color:#4b5563;margin-top:6px}
.p-meta div{margin-top:2px}
.p-to{margin:0 0 18px}
.p-to .p-lab{font-size:10.5px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:#6b7280}
.p-to .p-name{font-weight:700}
.p-to{white-space:pre-line}
table.p-items{width:100%;border-collapse:collapse;margin:6px 0 14px}
.p-items th{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:#6b7280;text-align:left;padding:7px 8px;border-bottom:2px solid #e5e7eb}
.p-items th.r,.p-items td.r{text-align:right}
.p-items td{padding:8px;border-bottom:1px solid #f3f4f6;vertical-align:top}
.p-totals{width:260px;margin-left:auto;font-size:13px}
.p-totals div{display:flex;justify-content:space-between;padding:4px 8px}
.p-totals .grand{border-top:2px solid #111827;font-size:15.5px;font-weight:800;margin-top:4px;padding-top:8px}
.p-notes{margin-top:18px;font-size:12px;color:#4b5563;white-space:pre-line;border-top:1px solid #f3f4f6;padding-top:12px}
.p-badge{margin-top:26px;font-size:10.5px;color:#9ca3af;text-align:center}
.p-badge a{color:#9ca3af}

/* content sections */
.section{padding:34px 0 6px}
.section h2{font-size:clamp(21px,3vw,28px);letter-spacing:-.01em;margin:0 0 14px}
.section p{max-width:820px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
@media(max-width:880px){.cards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px}
.card h3{margin:0 0 6px;font-size:16.5px}
.card p{margin:0;font-size:14px;color:var(--muted)}
.card .num{display:inline-flex;width:28px;height:28px;border-radius:8px;background:var(--soft);color:var(--brand);font-weight:800;align-items:center;justify-content:center;margin-bottom:10px}
ul.check{list-style:none;padding:0;max-width:820px}
ul.check li{padding:7px 0 7px 28px;position:relative;border-bottom:1px solid #eceef1}
ul.check li::before{content:"✓";position:absolute;left:2px;color:var(--ok);font-weight:800}
table.price{width:100%;max-width:820px;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;font-size:14.5px}
table.price th{background:#f9fafb;text-align:left;padding:10px 14px;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
table.price td{padding:10px 14px;border-top:1px solid #f0f1f3}
table.price td:last-child{text-align:right;font-weight:600;white-space:nowrap}
.note{font-size:13px;color:var(--muted);max-width:820px}

/* FAQ */
.faq{max-width:820px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:10px;padding:2px 18px}
.faq summary{font-weight:700;font-size:15.5px;padding:12px 0;cursor:pointer;list-style:none;position:relative}
.faq summary::after{content:"+";position:absolute;right:0;color:var(--muted);font-weight:400;font-size:20px}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 0 14px;color:#374151;font-size:14.5px}

/* template directory */
.dir{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
@media(max-width:880px){.dir{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.dir{grid-template-columns:1fr}}
.dir a{display:block;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;color:var(--ink)}
.dir a:hover{border-color:var(--brand);text-decoration:none;box-shadow:0 4px 14px rgba(4,120,87,.08)}
.dir b{display:block;font-size:15.5px}
.dir span{font-size:13px;color:var(--muted)}

/* CTA band */
.band{background:linear-gradient(135deg,#047857,#064e3b);color:#fff;border-radius:16px;padding:30px 28px;margin:40px 0;text-align:center}
.band h2{margin:0 0 8px;font-size:24px}
.band p{margin:0 auto 18px;max-width:640px;color:#d1fae5}
.band .btn{background:#fff;color:var(--brand-ink)}

/* footer */
.site-foot{border-top:1px solid var(--line);background:#fff;margin-top:46px;padding:30px 0 36px;font-size:14px;color:var(--muted)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
@media(max-width:720px){.foot-grid{grid-template-columns:1fr}}
.site-foot h4{margin:0 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.07em;color:#374151}
.site-foot ul{list-style:none;margin:0;padding:0}
.site-foot li{margin:5px 0}
.site-foot a{color:var(--muted)}
.copyright{margin-top:22px;font-size:12.5px}

/* article pages (privacy/terms) */
.article{max-width:820px;margin:0 auto;padding:40px 20px}
.article h1{font-size:30px}
.article h2{font-size:20px;margin-top:28px}

/* print: tool.js moves #paper to <body> and adds .printing before printing.
   Zero @page margin leaves the browser no room to draw its URL/title header & footer;
   #paper carries the visual margin itself via padding. */
@media print{
  @page{margin:0;size:letter}
  html,body{background:#fff;margin:0;padding:0}
  body.printing > *:not(#paper){display:none !important}
  #paper{width:100%;min-height:0;margin:0;border:none;box-shadow:none;border-radius:0;padding:16mm 15mm;font-size:12.5px}
}

/* ===== paystubwiz additions ===== */
/* watermarked preview until paid */
.paper{position:relative;overflow:hidden}
.wm{position:absolute;inset:0;pointer-events:none;display:flex;flex-direction:column;justify-content:space-around;z-index:5}
.wm span{transform:rotate(-24deg);font-size:26px;font-weight:800;color:rgba(4,120,87,.13);letter-spacing:.2em;white-space:nowrap;text-align:center}

/* pay stub document */
.stub-h{display:flex;justify-content:space-between;gap:14px;border-bottom:2px solid #111827;padding-bottom:10px;margin-bottom:12px}
.stub-h .co{font-weight:800;font-size:15px}
.stub-h .doc{font-size:18px;font-weight:800;letter-spacing:.08em;color:var(--brand-ink)}
.stub-meta{display:grid;grid-template-columns:1fr 1fr;gap:4px 20px;font-size:12px;margin-bottom:12px}
.stub-meta b{color:#374151}
table.stub{width:100%;border-collapse:collapse;font-size:12px;margin:10px 0}
table.stub th{background:#f3f4f6;text-align:left;padding:5px 8px;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:#4b5563;border:1px solid #e5e7eb}
table.stub td{padding:5px 8px;border:1px solid #eceef1}
table.stub .r{text-align:right}
table.stub .tot td{font-weight:800;background:#f9fafb}
.netpay{display:flex;justify-content:space-between;align-items:center;background:#ecfdf5;border:2px solid var(--brand);border-radius:8px;padding:10px 14px;font-size:15px;font-weight:800;margin-top:12px}

/* W-2 / 1099 box grid */
.taxform{border:2px solid #111827;font-size:11px}
.tf-row{display:grid;border-bottom:1px solid #111827}
.tf-row:last-child{border-bottom:none}
.tf-cell{border-right:1px solid #111827;padding:4px 6px;min-height:34px}
.tf-cell:last-child{border-right:none}
.tf-lab{display:block;font-size:8.5px;text-transform:uppercase;color:#4b5563;letter-spacing:.03em}
.tf-val{font-weight:700;font-size:12px;word-break:break-word}
.tf-title{text-align:center;font-weight:800;padding:6px;border-bottom:2px solid #111827;font-size:13px;letter-spacing:.05em}

/* letter documents */
.letter{font-size:13px;line-height:1.75;white-space:pre-wrap}
.letter .lh{font-weight:800;font-size:15px;margin-bottom:2px}

/* payment modal */
.modal-mask{position:fixed;inset:0;background:rgba(17,24,39,.55);z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:#fff;border-radius:16px;max-width:420px;width:100%;padding:26px;position:relative}
.modal h3{margin:0 0 4px;font-size:20px}
.modal .price{font-size:32px;font-weight:800;color:var(--brand-ink);margin:8px 0}
.modal .price small{font-size:14px;color:var(--muted);font-weight:600}
.modal ul{margin:0 0 16px;padding-left:20px;font-size:14px;color:#374151}
.modal ul li{margin:4px 0}
.modal-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:22px;color:#9ca3af;cursor:pointer}
.modal .hint{text-align:center}
#paypal-slot{min-height:120px}
.paid-flag{background:#ecfdf5;border:1px solid #6ee7b7;color:#065f46;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;margin-top:10px}
