/* Material Design 3 red palette + mobile-first */
:root{
  --red-50:#FFEBEE;
  --red-100:#FFCDD2;
  --red-300:#E57373;
  --red-500:#F44336;
  --red-700:#D32F2F;
  --red-900:#B71C1C;
  --on-primary:#FFFFFF;
  --surface:#FFFFFF;
  --surface-variant:#FDF7F7;
  --on-surface:#1D1B20;
  --on-surface-variant:#4A4448;
  --outline:#E7DFE0;
  --shadow:0 1px 2px rgba(0,0,0,0.06),0 1px 3px rgba(0,0,0,0.08);
  --shadow-lg:0 6px 16px rgba(211,47,47,0.14),0 2px 6px rgba(0,0,0,0.08);
  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:20px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Arial,Helvetica,"Helvetica Neue",sans-serif;color:var(--on-surface);background:var(--red-50);min-height:100vh;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--red-700);text-decoration:none}
a:hover{text-decoration:underline}

/* Top app bar */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--red-700);color:var(--on-primary);box-shadow:var(--shadow)}
.brand{flex:1;text-align:center;line-height:1.1}
.brand-name{font-weight:700;font-size:20px;letter-spacing:.2px}
.brand-tag{font-size:12px;opacity:.92}
.icon-btn{background:transparent;border:0;color:inherit;padding:8px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
.icon-btn:hover{background:rgba(255,255,255,.14)}
.icon-btn:active{background:rgba(255,255,255,.24)}

/* Drawer */
.drawer{position:fixed;top:0;left:-300px;bottom:0;width:280px;background:var(--surface);box-shadow:var(--shadow-lg);z-index:30;transition:left .25s ease;display:flex;flex-direction:column}
.drawer.open{left:0}
.drawer-header{padding:16px;display:flex;gap:12px;align-items:center;background:var(--red-50)}
.drawer-logo{width:44px;height:44px}
.drawer-nav{display:flex;flex-direction:column;padding:8px 0;flex:1}
.drawer-nav a{padding:12px 20px;color:var(--on-surface);border-left:3px solid transparent}
.drawer-nav a:hover{background:var(--red-50);border-left-color:var(--red-300);text-decoration:none}
.nav-section{padding:14px 20px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--on-surface-variant)}

/* Search popover */
.search-pop{position:fixed;top:56px;right:8px;width:min(420px,calc(100vw - 16px));max-height:70vh;background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:25;transform:translateY(-8px);opacity:0;pointer-events:none;transition:.2s;display:flex;flex-direction:column;overflow:hidden}
.search-pop.open{opacity:1;transform:none;pointer-events:auto}
.search-pop input{border:0;padding:14px 16px;font-size:16px;outline:none;border-bottom:1px solid var(--outline);font-family:inherit}
.search-results{overflow:auto;max-height:60vh}
.search-hint{padding:14px 16px;color:var(--on-surface-variant);font-size:14px}
.search-result{display:block;padding:12px 16px;border-bottom:1px solid var(--outline);color:var(--on-surface)}
.search-result:hover{background:var(--red-50);text-decoration:none}
.sr-name{font-weight:600}
.sr-desc{font-size:13px;color:var(--on-surface-variant)}

/* Container */
.container{max-width:960px;margin:0 auto;padding:20px 16px 100px}

/* Hero */
.hero{text-align:center;padding:28px 16px 12px}
.hero-logo{width:82px;height:82px}
.hero h1{margin:12px 0 6px;font-size:28px;color:var(--red-700)}
.hero .lead{color:var(--on-surface-variant);margin:0}
.cta-row{margin-top:18px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:999px;border:0;cursor:pointer;font-family:inherit;font-size:15px;font-weight:600;transition:.15s;text-decoration:none}
.btn.full{width:100%}
.btn-primary{background:var(--red-700);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--red-900);text-decoration:none}
.btn-outline{background:transparent;color:var(--red-700);border:1.5px solid var(--red-700)}
.btn-outline:hover{background:var(--red-50);text-decoration:none}
.btn-ghost{background:transparent;color:var(--red-700);padding:8px 12px}

/* Sections + cards */
.section{margin:22px 0}
.section-title{margin:0 0 10px;font-size:18px;color:var(--red-700)}
.card{background:var(--surface);border-radius:var(--radius-md);padding:18px;box-shadow:var(--shadow);border:1px solid var(--outline)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.svc-card{display:block;color:var(--on-surface);transition:transform .12s,box-shadow .12s}
.svc-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);text-decoration:none}
.svc-header{display:flex;justify-content:space-between;align-items:center}
.svc-name{font-weight:700;font-size:17px;color:var(--red-700)}
.svc-desc{color:var(--on-surface-variant);margin:8px 0 12px;min-height:42px}
.svc-footer{display:flex;justify-content:space-between;align-items:center}
.price{font-weight:700}
.arrow{color:var(--red-700)}

.chip{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;text-transform:uppercase;letter-spacing:.4px;background:var(--red-50);color:var(--red-700);border:1px solid var(--red-100)}
.chip-provider{background:var(--red-700);color:#fff;border-color:var(--red-700)}
.chip-client{background:#517C96;color:#FFFFFF;border-color:#517C96}
.chip-status{font-weight:700}
.chip-active{background:#E8F5E9;color:#2E7D32;border-color:#C8E6C9}
.chip-pending{background:#FFF3E0;color:#EF6C00;border-color:#FFE0B2}
.chip-canceled{background:#EEE;color:#555;border-color:#DDD}
.chip-failed{background:#FFEBEE;color:#C62828;border-color:#FFCDD2}
.chip-paid{background:#E8F5E9;color:#2E7D32;border-color:#C8E6C9}
.chip-unpaid{background:#FFF3E0;color:#EF6C00;border-color:#FFE0B2}

.list{display:flex;flex-direction:column;gap:8px}
.list-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--outline)}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:16px}

.card-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.mini-card{background:var(--surface);padding:12px;border-radius:var(--radius-md);border:1px solid var(--outline);box-shadow:var(--shadow)}
.mini-card img{width:100%;border-radius:var(--radius-sm);display:block}
.mini-title{font-weight:700;margin-top:8px}
.muted{color:var(--on-surface-variant)}
.small{font-size:12.5px}

/* Forms */
.form{display:flex;flex-direction:column;gap:12px}
.form label{display:flex;flex-direction:column;font-size:13px;color:var(--on-surface-variant);gap:4px}
.form input,.form textarea{font:15px/1.4 Arial,sans-serif;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--outline);background:var(--surface);color:var(--on-surface);outline:none;transition:border-color .15s,box-shadow .15s}
.form input:focus{border-color:var(--red-700);box-shadow:0 0 0 3px rgba(211,47,47,.14)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.form-grid .full{grid-column:1/-1}
@media (max-width:520px){.form-grid{grid-template-columns:1fr}}

.auth-card{max-width:420px;margin:24px auto}
.auth-card h2{margin:0 0 6px;color:var(--red-700)}
.alert{padding:10px 12px;border-radius:var(--radius-sm);margin:8px 0;font-size:14px}
.alert-error{background:#FFEBEE;color:#C62828;border:1px solid #FFCDD2}
.alert-info{background:#E3F2FD;color:#1565C0;border:1px solid #BBDEFB}

/* Footer with logo bottom-left */
.footer{position:fixed;left:12px;bottom:12px;display:flex;align-items:center;gap:8px;background:var(--surface);padding:6px 10px 6px 6px;border-radius:999px;box-shadow:var(--shadow);border:1px solid var(--outline);z-index:10}
.footer-logo{width:36px;height:36px}
.footer-text{font-size:11px;line-height:1.15}
.footer-text .muted{font-size:10px}

/* ---- Floating chatbot ---- */
.chat-panel{width:min(370px,calc(100vw - 28px));height:min(520px,70vh);background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 12px 32px rgba(0,0,0,.18),0 4px 12px rgba(0,0,0,.08);border:1px solid var(--outline);display:flex;flex-direction:column;opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;visibility:hidden;transition:.2s ease;overflow:hidden;order:-1;position:absolute;bottom:66px;right:0}
.chat-panel.open{opacity:1;transform:none;pointer-events:auto;visibility:visible}
#chat-fab-wrap{position:fixed;right:14px;bottom:14px;z-index:40;pointer-events:none}
#chat-fab-wrap>*{pointer-events:auto}
.chat-fab{width:56px;height:56px;border-radius:50%;background:var(--red-700);color:#fff;border:0;box-shadow:0 6px 16px rgba(211,47,47,.35),0 2px 6px rgba(0,0,0,.15);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s;position:relative}
.chat-fab:hover{background:var(--red-900);transform:scale(1.04)}
.chat-fab .chat-icon-close{position:absolute;opacity:0;transform:rotate(-90deg);transition:.2s}
.chat-fab .chat-icon-open{transition:.2s}
.chat-fab.open .chat-icon-open{opacity:0;transform:rotate(90deg)}
.chat-fab.open .chat-icon-close{opacity:1;transform:none}
.chat-panel{width:min(370px,calc(100vw - 28px));height:min(520px,70vh);background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 12px 32px rgba(0,0,0,.18),0 4px 12px rgba(0,0,0,.08);border:1px solid var(--outline);display:flex;flex-direction:column;opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;visibility:hidden;transition:.2s ease;overflow:hidden;order:-1;position:absolute;bottom:66px;right:0}
.chat-panel.open{opacity:1;transform:none;pointer-events:auto;visibility:visible}
.chat-header{background:var(--red-700);color:#fff;padding:12px 16px}
.chat-title{font-weight:700;font-size:15px}
.chat-sub{font-size:12px;opacity:.9}
.chat-log{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;background:var(--red-50)}
.chat-msg{max-width:82%;padding:10px 12px;border-radius:14px;font-size:14px;line-height:1.4;word-wrap:break-word;white-space:pre-wrap}
.chat-msg-user{align-self:flex-end;background:var(--red-700);color:#fff;border-bottom-right-radius:4px}
.chat-msg-assistant{align-self:flex-start;background:var(--surface);color:var(--on-surface);border-bottom-left-radius:4px;border:1px solid var(--outline)}
.chat-msg-assistant code{background:var(--red-50);color:var(--red-700);padding:1px 6px;border-radius:6px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px}
.chat-form{display:flex;gap:6px;padding:8px;border-top:1px solid var(--outline);background:var(--surface)}
.chat-input{flex:1;font:14px/1.4 Arial,sans-serif;padding:9px 12px;border-radius:999px;border:1px solid var(--outline);outline:none;background:var(--surface-variant)}
.chat-input:focus{border-color:var(--red-700);box-shadow:0 0 0 3px rgba(211,47,47,.14)}
.chat-send{width:38px;height:38px;border-radius:50%;background:var(--red-700);color:#fff;border:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
.chat-send:hover{background:var(--red-900)}
.chat-send:disabled{opacity:.5;cursor:not-allowed}
.chat-typing{padding:6px 14px;font-size:12px;color:var(--on-surface-variant);background:var(--surface);border-top:1px solid var(--outline);display:none}
.chat-typing.htmx-request,.htmx-request .chat-typing{display:block}
@media (max-width:520px){.chat-panel{width:calc(100vw - 20px);height:70vh}}

/* ---- vCard wizard ---- */
.wizard{min-height:200px}
.wizard-skeleton{color:var(--on-surface-variant);text-align:center;padding:24px}
.wiz-header{margin:-4px -4px 14px;padding:0 4px}
.wiz-crumb{font-size:12px;color:var(--on-surface-variant);margin-bottom:6px}
.wiz-bar{height:6px;background:var(--red-50);border-radius:999px;overflow:hidden}
.wiz-fill{height:100%;background:var(--red-700);border-radius:999px;transition:width .25s ease}
.wiz-form{display:flex;flex-direction:column;gap:14px}
.wiz-label{display:flex;flex-direction:column;gap:6px}
.wiz-title{font-size:18px;font-weight:700;color:var(--red-700)}
.wiz-help{margin:-2px 0 4px}
.wiz-input{font:16px/1.4 Arial,sans-serif;padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--outline);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}
.wiz-input:focus{border-color:var(--red-700);box-shadow:0 0 0 3px rgba(211,47,47,.14)}
.wiz-hint{margin-top:2px}
.wiz-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center;margin-top:8px;flex-wrap:wrap}
.wiz-actions .btn-outline{margin-right:auto}
.wiz-stem{font-size:15px;color:var(--on-surface);margin-bottom:6px;line-height:1.45}

/* Checkbox picker (naics / legal / gics) */
.cb-grid{display:flex;flex-direction:column;gap:6px;max-height:52vh;overflow-y:auto;padding:2px;margin:6px 0}
.cb-row{position:relative;display:grid;grid-template-columns:auto 1fr auto;column-gap:10px;row-gap:0;align-items:center;padding:10px 12px;background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s,border-color .12s}
.cb-row:hover{background:var(--red-50);border-color:var(--red-300)}
.cb-input{position:absolute;left:-9999px}
.cb-check{width:20px;height:20px;border-radius:5px;border:2px solid var(--red-300);background:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.cb-check::after{content:"";width:10px;height:6px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translate(1px,-1px);opacity:0;transition:opacity .12s}
.cb-input:checked ~ .cb-check{background:var(--red-700);border-color:var(--red-700)}
.cb-input:checked ~ .cb-check::after{opacity:1}
.cb-text{font-size:15px;color:var(--on-surface);line-height:1.3}
.cb-info{width:22px;height:22px;border-radius:50%;background:var(--red-50);color:var(--red-700);border:1px solid var(--red-100);font-weight:700;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1}
.cb-info:hover{background:var(--red-100)}
.cb-popup{grid-column:2/-1;font-size:12.5px;color:var(--on-surface-variant);background:var(--red-50);border-left:3px solid var(--red-300);padding:8px 10px;border-radius:6px;margin-top:8px;display:none}
.cb-row.show-popup .cb-popup{display:block}

/* Review step */
.review-list{display:flex;flex-direction:column;gap:6px;margin:12px 0}
.review-row{display:grid;grid-template-columns:180px 1fr auto;column-gap:12px;align-items:center;padding:8px 12px;background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius-sm)}
.review-row dt{font-size:12px;color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.4px;font-weight:600;margin:0}
.review-row dd{margin:0;font-size:14px;color:var(--on-surface);word-break:break-word}
.review-empty dd{color:var(--on-surface-variant);font-style:italic}
.review-edit{background:transparent;border:0;color:var(--red-700);font:600 13px Arial,sans-serif;cursor:pointer;padding:6px 8px;border-radius:6px}
.review-edit:hover{background:var(--red-50)}
@media (max-width:520px){.review-row{grid-template-columns:1fr auto;column-gap:8px}.review-row dt{grid-column:1/-1}}
