/* EstimateWiz — global styles (v1) */
:root{
  --ink:#111827; --muted:#5b6472; --bg:#f4f5f7; --card:#ffffff;
  --brand:#6d28d9; --brand-dark:#5b21b6; --brand-ink:#4c1d95;
  --accent:#f59e0b; --line:#e5e7eb; --ok:#059669; --soft:#f5f3ff;
}
*{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 #ddd6fe;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 #ddd6fe;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:#ede9fe}

/* 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(109,40,217,.08)}
.dir b{display:block;font-size:15.5px}
.dir span{font-size:13px;color:var(--muted)}

/* CTA band */
.band{background:linear-gradient(135deg,#6d28d9,#4c1d95);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:#ede9fe}
.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}
}

/* ===== timecardwiz additions ===== */
.calc-wrap{max-width:920px;margin:0 auto}
.tc-grid{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.tc-grid th{background:#f9fafb;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:9px 8px;text-align:left}
.tc-grid td{padding:6px 8px;border-top:1px solid #f0f1f3;vertical-align:middle}
.tc-grid input[type=time]{width:100%;min-width:96px}
.tc-grid input[type=number]{width:76px}
.tc-grid .day{font-weight:700;font-size:13.5px;white-space:nowrap}
.tc-grid .hrs{font-weight:700;text-align:right;white-space:nowrap;font-size:14px}
.tc-week{background:#f5f3ff !important;font-weight:700}
.result{background:#fff;border:2px solid var(--brand);border-radius:14px;padding:18px 22px;margin-top:18px}
.result .big{font-size:34px;font-weight:800;color:var(--brand-ink);line-height:1.1}
.result .big small{font-size:15px;color:var(--muted);font-weight:600}
.result-row{display:flex;justify-content:space-between;gap:10px;padding:5px 0;font-size:14.5px;border-top:1px solid #f0f1f3;margin-top:4px}
.result-row:first-of-type{border-top:none}
.result-row b{font-size:15px}
.opts{display:flex;gap:18px;flex-wrap:wrap;align-items:end;margin-top:14px}
.opts>div{min-width:130px}
.opts label.cb{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;margin:0 0 10px}
.opts input[type=checkbox]{width:17px;height:17px}
table.chart{width:100%;max-width:560px;border-collapse:collapse;background:#fff;border:1px solid var(--line);font-size:14px}
table.chart th{background:#f9fafb;padding:8px 12px;text-align:left;font-size:12px;text-transform:uppercase;color:var(--muted)}
table.chart td{padding:7px 12px;border-top:1px solid #f0f1f3}
.funnel{background:#ecfdf5;border:1px solid #6ee7b7;border-radius:12px;padding:14px 18px;margin-top:18px;font-size:14.5px}
.funnel a{font-weight:700;color:#047857}
@media print{
  body.printing > *:not(#printable){display:none !important}
  @page{margin:0;size:letter}
  #printable{padding:16mm 15mm;font-size:13px}
}
#printable{display:none}
body.printing #printable{display:block}
