/* Google Fonts — Plus Jakarta Sans */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* =====================================================================
   RESET & BASE
===================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);line-height:1.55;min-height:100vh;transition:background .2s,color .2s}
img{display:block;max-width:100%}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
button{cursor:pointer}

/* =====================================================================
   THEME TOKENS  — clean neutral base, indigo primary, green/amber accents
===================================================================== */
:root{
  --bg:#f0f0f5; --surface:#ffffff; --surface2:#f5f5fa; --surface3:#ebebf2;
  --border:#e2e2ec; --border-strong:#c8c8d8;
  --text:#1a1a2e; --text-muted:#606070; --text-subtle:#9898b0;
  --accent:#5d5fef; --accent-bg:#ededfd; --accent-hover:#4648d4;
  --success:#219653; --success-bg:#e8f5ee;
  --warning:#f2994a; --warning-bg:#fef3e8;
  --danger:#eb5757; --danger-bg:#feeaea;
  --focus-ring:rgba(93,95,239,.18);
  --shadow-sm:0 1px 2px rgba(26,26,46,.06);
  --shadow:0 1px 3px rgba(26,26,46,.08),0 0 0 1px rgba(26,26,46,.04);
  --shadow-md:0 4px 12px rgba(26,26,46,.1),0 0 0 1px rgba(26,26,46,.04);
  --shadow-lg:0 8px 24px rgba(26,26,46,.12),0 0 0 1px rgba(26,26,46,.06);
  --radius:10px; --radius-sm:6px; --radius-lg:14px;
}
[data-theme="dark"]{
  --bg:#12121e; --surface:#1c1c2e; --surface2:#24243a; --surface3:#2e2e46;
  --border:#2e2e46; --border-strong:#3e3e5c;
  --text:#f0f0fa; --text-muted:#9898b8; --text-subtle:#5c5c7a;
  --accent:#7b7dff; --accent-bg:#1c1c3e; --accent-hover:#9496ff;
  --success:#6fcf97; --success-bg:#0d2218;
  --warning:#f2994a; --warning-bg:#271806;
  --danger:#f87171; --danger-bg:#2a0e0e;
  --focus-ring:rgba(123,125,255,.22);
  --shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --shadow:0 1px 3px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04);
  --shadow-lg:0 8px 24px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.05);
}

/* =====================================================================
   TYPOGRAPHY
===================================================================== */
h1{font-size:2.1rem;font-weight:800;letter-spacing:-.035em;line-height:1.15}
h2{font-size:1.4rem;font-weight:700;letter-spacing:-.025em;line-height:1.25}
h3{font-size:1.05rem;font-weight:700;letter-spacing:-.015em}
h4{font-size:.9rem;font-weight:600}
p{color:var(--text-muted);line-height:1.65}
small{font-size:.78rem;color:var(--text-muted)}

/* =====================================================================
   LAYOUT UTILITIES
===================================================================== */
.container{max-width:1160px;margin:0 auto;padding:0 24px}
.container-sm{max-width:640px;margin:0 auto;padding:0 24px}
.container-md{max-width:860px;margin:0 auto;padding:0 24px}
.flex{display:flex}.flex-col{flex-direction:column}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}
.text-center{text-align:center}.text-muted{color:var(--text-muted)}
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
@keyframes spin{to{transform:rotate(360deg)}}
.icon-spin{animation:spin 1s linear infinite;display:inline-flex}

/* =====================================================================
   SITE HEADER / NAV
===================================================================== */
.site-header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;box-shadow:var(--shadow)}
.site-nav{height:56px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-brand{font-size:.95rem;font-weight:800;letter-spacing:-.02em;color:var(--text);text-decoration:none}
.nav-brand:hover{text-decoration:none;color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{padding:6px 10px;font-size:.8rem;font-weight:500;color:var(--text-muted);border-radius:var(--radius-sm);transition:background .12s,color .12s}
.nav-link:hover{background:var(--surface2);color:var(--text);text-decoration:none}
.nav-right{display:flex;align-items:center;gap:8px}
.dark-toggle{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text-muted);font-size:.72rem;font-family:inherit}

/* =====================================================================
   BUTTONS
===================================================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:.83rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .12s,border-color .12s,color .12s,box-shadow .12s;font-family:inherit;line-height:1;text-decoration:none;white-space:nowrap}
.btn:hover{text-decoration:none}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--focus-ring)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.btn-outline{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-outline:hover{background:var(--accent-bg)}
.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}
.btn-ghost:hover{background:var(--surface2);color:var(--text)}
.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:#fff}
.btn-lg{padding:12px 28px;font-size:.95rem;border-radius:var(--radius)}
.btn-sm{padding:5px 11px;font-size:.75rem}
.btn-full{width:100%}
.btn-loading{opacity:.7;pointer-events:none}
.btn[disabled]{opacity:.5;pointer-events:none}

/* =====================================================================
   FORM ELEMENTS
===================================================================== */
.form-group{display:flex;flex-direction:column;gap:5px}
.form-label{font-size:.78rem;font-weight:500;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.form-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text);font-size:.88rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;-moz-appearance:textfield}
.form-input::-webkit-outer-spin-button,.form-input::-webkit-inner-spin-button{-webkit-appearance:none}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring)}
.form-input::placeholder{color:var(--text-subtle)}
.form-input.error{border-color:var(--danger)}
.form-error{font-size:.75rem;color:var(--danger);margin-top:3px}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239898b0'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.radio-group{display:flex;gap:14px;flex-wrap:wrap}
.radio-group label{display:flex;align-items:center;gap:5px;font-size:.83rem;cursor:pointer;color:var(--text);font-weight:400}
.checkbox-row label{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted);cursor:pointer}

/* =====================================================================
   CARDS
===================================================================== */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card-sm{padding:14px}
.card-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}

/* =====================================================================
   QUOTA BADGE
===================================================================== */
.quota-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:600}
.quota-badge.free{background:var(--warning-bg);color:var(--warning);border:1px solid #fcd34d}
.quota-badge.pro{background:var(--success-bg);color:var(--success);border:1px solid #bef264}
.quota-badge.exhausted{background:var(--danger-bg);color:var(--danger);border:1px solid #fca5a5}

/* =====================================================================
   APP LAYOUT  (calculator page)
===================================================================== */
.app-header-bar{background:var(--surface);border-bottom:1px solid var(--border);padding:10px 0;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.app-header-inner{display:flex;align-items:center;gap:12px}
.app-header-left{display:flex;align-items:center;gap:10px;flex:1}
.app-header-right{display:flex;align-items:center;gap:8px}
.app-brand{font-size:.9rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.app-subtitle{font-size:.72rem;color:var(--text-muted)}

.app-main{padding:18px 0}
.app-layout{display:grid;grid-template-columns:1fr 370px;gap:18px;align-items:start}
@media(max-width:920px){.app-layout{grid-template-columns:1fr}.results-sticky{position:static!important;max-height:none!important}}
.inputs-col{display:flex;flex-direction:column;gap:14px}
.results-sticky{position:sticky;top:66px;max-height:calc(100vh - 86px);overflow-y:auto}

/* =====================================================================
   APP FORM GRID
===================================================================== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.subsection-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);margin:14px 0 8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.section-head .card-title{margin-bottom:0}
.help{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--border);color:var(--text-muted);font-size:.6rem;cursor:help;font-style:normal;font-weight:700;flex-shrink:0}

/* =====================================================================
   LABOR MODE TOGGLE
===================================================================== */
.mode-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.mode-btn{padding:4px 12px;font-size:.73rem;font-weight:500;background:var(--surface2);color:var(--text-muted);border:none;cursor:pointer;font-family:inherit;transition:background .12s,color .12s}
.mode-btn.active{background:var(--accent);color:#fff}

/* =====================================================================
   LABOR PREVIEW
===================================================================== */
.labor-preview{margin-top:12px;padding:10px 12px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.preview-stat{text-align:center}
.preview-stat .val{font-size:.92rem;font-weight:700;color:var(--text);display:block}
.preview-stat .lbl{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}

/* =====================================================================
   PRESET GRID
===================================================================== */
.preset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:10px}
.preset-btn{padding:8px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text-muted);font-size:.76rem;font-weight:500;cursor:pointer;text-align:center;transition:all .12s;font-family:inherit}
.preset-btn:hover{border-color:var(--accent);color:var(--text)}
.preset-btn.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);font-weight:600}
.preset-desc{font-size:.76rem;color:var(--text-muted);line-height:1.45;margin-bottom:10px}

/* =====================================================================
   ADD-ONS
===================================================================== */
.addon-list{display:flex;flex-direction:column;gap:5px}
.addon-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);cursor:pointer;transition:border-color .12s,background .12s}
.addon-item:hover{border-color:var(--accent)}
.addon-item.checked{border-color:var(--accent);background:var(--accent-bg)}
.addon-item input[type=checkbox]{cursor:pointer;flex-shrink:0;accent-color:var(--accent)}
.addon-label{flex:1;font-size:.8rem;color:var(--text)}
.addon-meta{font-size:.68rem;color:var(--text-muted);white-space:nowrap}

/* =====================================================================
   RESULTS PANEL
===================================================================== */
.results-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.results-header{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface2)}
.results-header h2{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}
.quote-hero{padding:16px 16px 10px;text-align:center}
.quote-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:3px}
.quote-amount{font-size:2.6rem;font-weight:800;color:var(--text);letter-spacing:-.04em;line-height:1}
.quote-service{font-size:.72rem;color:var(--text-muted);margin-top:4px}
.min-fee-note{font-size:.68rem;color:var(--warning);margin-top:3px;font-weight:500}
.tier-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;padding:0 16px 12px}
.tier-box{text-align:center;padding:8px 4px;border-radius:var(--radius-sm);border:1px solid var(--border)}
.tier-box.low{border-color:var(--warning);background:var(--warning-bg)}
.tier-box.standard{border-color:var(--accent);background:var(--accent-bg)}
.tier-box.premium{border-color:var(--success);background:var(--success-bg)}
.tier-name{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.tier-box.low .tier-name{color:var(--warning)}
.tier-box.standard .tier-name{color:var(--accent)}
.tier-box.premium .tier-name{color:var(--success)}
.tier-price{font-size:.95rem;font-weight:700;color:var(--text)}
.tier-margin{font-size:.65rem;color:var(--text-muted)}
.metrics-row{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:0 16px 12px}
.metric{padding:8px 10px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border)}
.metric .m-val{font-size:1rem;font-weight:700;color:var(--text);display:block}
.metric .m-lbl{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}
.breakdown-wrap{padding:0 16px 12px}
.breakdown-bar{height:7px;border-radius:4px;overflow:hidden;display:flex;margin-bottom:7px}
.bar-seg{height:100%;transition:width .2s}
.bar-legend{display:flex;flex-wrap:wrap;gap:7px}
.legend-item{display:flex;align-items:center;gap:4px;font-size:.65rem;color:var(--text-muted)}
.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.line-items{padding:12px 16px;border-top:1px solid var(--border)}
.line-item{display:flex;justify-content:space-between;align-items:baseline;padding:3px 0;font-size:.78rem;color:var(--text-muted)}
.line-item.indent{padding-left:10px;font-size:.73rem}
.line-item.subtotal{border-top:1px dashed var(--border);margin-top:4px;padding-top:6px;color:var(--text);font-weight:600}
.line-item.total{border-top:1px solid var(--border);margin-top:4px;padding-top:7px;font-weight:700;color:var(--text);font-size:.88rem}
.line-item .val{font-variant-numeric:tabular-nums;font-family:'SF Mono',Consolas,monospace;font-size:.78rem}
.line-item.total .val{font-size:.88rem}
.results-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:7px}
.results-footer .btn{flex:1}

/* =====================================================================
   QUOTA GATE OVERLAY  (on results panel)
===================================================================== */
.quota-gate{padding:20px 16px;text-align:center;border-top:1px solid var(--border)}
.quota-gate h3{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:6px}
.quota-gate p{font-size:.78rem;color:var(--text-muted);margin-bottom:14px}
.quota-pips{display:flex;justify-content:center;gap:6px;margin-bottom:14px}
.pip{width:10px;height:10px;border-radius:50%;background:var(--border)}
.pip.used{background:var(--accent)}
.pip.exhausted{background:var(--danger)}

/* =====================================================================
   MODAL
===================================================================== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:620px;max-height:85vh;display:flex;flex-direction:column}
.modal-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-head h2{font-size:.95rem;font-weight:700;color:var(--text)}
.modal-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted);padding:2px 6px;border-radius:3px;font-family:inherit}
.modal-close:hover{background:var(--surface2)}
.modal-body{flex:1;overflow-y:auto;padding:20px}
.modal-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:center}
.copy-confirm{font-size:.72rem;color:var(--success);margin-left:auto;display:none}
.copy-confirm.show{display:block}
.proposal-text{font-family:'SF Mono',Consolas,'Courier New',monospace;font-size:.74rem;line-height:1.75;white-space:pre-wrap;color:var(--text)}

/* =====================================================================
   TOAST
===================================================================== */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--text);color:var(--bg);padding:10px 20px;border-radius:var(--radius);font-size:.8rem;font-weight:500;transition:transform .25s;z-index:2000;pointer-events:none;white-space:nowrap}
#toast.show{transform:translateX(-50%) translateY(0)}

/* =====================================================================
   LANDING PAGE
===================================================================== */
.hero{padding:80px 0 72px;text-align:center}
.hero h1{font-size:3.8rem;letter-spacing:-.05em;max-width:760px;margin:0 auto .5rem}
.hero p{font-size:1.1rem;max-width:520px;margin:.75rem auto 0;color:var(--text-muted);line-height:1.6}
.hero-actions{display:flex;justify-content:center;gap:12px;margin-top:28px;flex-wrap:wrap}
.hero-note{margin-top:12px;font-size:.75rem;color:var(--text-subtle)}

.features{padding:56px 0;border-top:1px solid var(--border)}
.features > .container > h2{font-size:2rem;font-weight:500;letter-spacing:-.03em}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.feature-card{padding:22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.feature-icon{margin-bottom:12px;color:var(--accent)}
.feature-icon svg{width:26px;height:26px;stroke-width:1.75}
.feature-card h3{font-size:.9rem;margin-bottom:5px}
.feature-card p{font-size:.8rem;line-height:1.55}

.how-it-works{padding:56px 0;border-top:1px solid var(--border)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.step{text-align:center;padding:20px}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--accent-bg);border:1px solid var(--accent);color:var(--accent);font-size:.8rem;font-weight:700;margin-bottom:12px}
.step h3{font-size:.9rem;margin-bottom:5px}
.step p{font-size:.8rem}

.landing-pricing{padding:56px 0;border-top:1px solid var(--border)}
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:680px;margin:36px auto 0}
.pricing-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);position:relative}
.pricing-card.featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow)}
.pricing-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
.pricing-name{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:8px}
.pricing-amount{display:flex;align-items:baseline;gap:3px;margin-bottom:4px}
.pricing-amount .price{font-size:2.2rem;font-weight:800;color:var(--text);letter-spacing:-.04em}
.pricing-amount .per{font-size:.8rem;color:var(--text-muted)}
.pricing-sub{font-size:.73rem;color:var(--text-muted);margin-bottom:20px}
.pricing-features{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:22px}
.pricing-features li{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:7px}
.pricing-features li::before{content:'✓';color:var(--success);font-weight:700;flex-shrink:0}
.pricing-free{font-size:.75rem;color:var(--text-muted);text-align:center;margin-top:10px}

.site-footer{border-top:1px solid var(--border);padding:28px 0;margin-top:40px}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-brand{font-size:.82rem;font-weight:700;color:var(--text-muted)}
.footer-links{display:flex;gap:16px}
.footer-link{font-size:.75rem;color:var(--text-subtle)}
.footer-link:hover{color:var(--text-muted)}

/* =====================================================================
   AUTH PAGE
===================================================================== */
.auth-wrap{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:32px 20px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 32px;width:100%;max-width:400px;box-shadow:var(--shadow-md);text-align:center}
.auth-card h1{font-size:1.5rem;margin-bottom:6px}
.auth-card .tagline{font-size:.83rem;color:var(--text-muted);margin-bottom:28px}
.auth-divider{border:none;border-top:1px solid var(--border);margin:20px 0}
.auth-footer{margin-top:20px;font-size:.75rem;color:var(--text-subtle);line-height:1.6}
.auth-footer a{color:var(--accent)}
.check-email-icon{margin-bottom:16px;color:var(--accent)}
.check-email-icon svg{width:44px;height:44px;stroke-width:1.5}
.status-icon{margin-bottom:16px;display:flex;justify-content:center}
.status-icon svg{width:44px;height:44px;stroke-width:1.5}
.status-icon.loading{color:var(--text-muted)}
.status-icon.loading svg{animation:spin 1s linear infinite}
.status-icon.success{color:var(--success)}
.status-icon.error{color:var(--danger)}
.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:.8rem;margin-bottom:14px;text-align:left}
.alert.error{background:var(--danger-bg);color:var(--danger);border:1px solid #fca5a5}
.alert.success{background:var(--success-bg);color:var(--success);border:1px solid #bef264}
.alert.info{background:var(--accent-bg);color:var(--accent);border:1px solid #fed7aa}

/* =====================================================================
   PRICING PAGE
===================================================================== */
.pricing-hero{padding:52px 0 36px;text-align:center}
.pricing-hero p{max-width:460px;margin:.5rem auto 0}
.pricing-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:700px;margin:0 auto}
.faq{padding:52px 0;border-top:1px solid var(--border)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.faq-item h3{font-size:.88rem;margin-bottom:5px}
.faq-item p{font-size:.8rem}

/* =====================================================================
   RESPONSIVE
===================================================================== */
@media(max-width:720px){
  h1{font-size:1.7rem}.hero h1{font-size:2.4rem}.hero{padding:52px 0 44px}
  .features-grid,.steps,.faq-grid{grid-template-columns:1fr}
  .pricing-grid,.pricing-page-grid{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;text-align:center}
}
@media(max-width:600px){
  .grid-2{grid-template-columns:1fr}
  .preset-grid{grid-template-columns:repeat(2,1fr)}
  .container{padding:0 14px}
  .app-main{padding:12px 0}
  .quote-amount{font-size:2rem}
  .tier-row{grid-template-columns:1fr}
  .labor-preview{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
}

/* =====================================================================
   PRINT
===================================================================== */
@media print{
  .app-header-bar,.inputs-col,.results-footer,.site-header,.dark-toggle{display:none!important}
  .app-layout{display:block}
  .results-sticky{position:static;max-height:none;overflow:visible}
  .results-panel{box-shadow:none;border:none}
  body{background:#fff;color:#000}
}
.print-proposal-area{display:none}
@media print{
  body.print-mode *{display:none!important}
  body.print-mode .print-proposal-area{display:block!important;white-space:pre-wrap;font-family:'Courier New',monospace;font-size:11px;line-height:1.75;padding:20px;color:#000}
}
