/* FilePile | Modern SaaS UI */
:root {
    --bg: #f8fafc;
    --surface: #ffffff;
    --surface2: #f1f5f9;
    --border: #e2e8f0;
    --text: #0f172a;
    --muted: #64748b;
    --primary: #4f46e5;
    --primary-dark: #4338ca;
    --primary-light: #eef2ff;
    --success: #059669;
    --error: #dc2626;
    --warning: #d97706;
    --radius: 12px;
    --shadow: 0 1px 3px rgba(15,23,42,.08), 0 4px 12px rgba(15,23,42,.04);
    --shadow-lg: 0 8px 30px rgba(15,23,42,.1);
    --font: 'Inter', system-ui, sans-serif;
    --control-height: 2.375rem;
    --select-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: var(--font); color: var(--text); line-height: 1.6; background: var(--bg); }
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }
.container { max-width: 1140px; margin: 0 auto; padding: 0 1.5rem; }
.text-muted { color: var(--muted); }
.text-center { text-align: center; }

/* Nav */
.nav { background: var(--surface); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 50; }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.logo { font-size: 1.35rem; font-weight: 800; color: var(--text); text-decoration: none !important; }
.logo span { color: var(--primary); }
.nav-links { display: flex; align-items: center; gap: 1.25rem; }
.nav-links a { color: var(--muted); font-weight: 500; font-size: 0.9rem; text-decoration: none; }
.nav-links a.btn-primary { color: #fff !important; }
.nav-links a.btn-primary:hover { color: #fff !important; opacity: 0.92; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .4rem; padding: .55rem 1.1rem; border-radius: 8px; font-weight: 600; font-size: 0.875rem; border: none; cursor: pointer; text-decoration: none !important; transition: all .15s; }
.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-dark); color: #fff; }
.btn-outline { background: var(--surface); color: var(--text); border: 1px solid var(--border); }
.btn-outline:hover { border-color: var(--primary); color: var(--primary); }
.btn-danger { color: #b91c1c; border-color: #fecaca; }
.btn-danger:hover { color: #fff; background: #b91c1c; border-color: #b91c1c; }
.ledger-actions { white-space: nowrap; display: flex; gap: 0.35rem; flex-wrap: wrap; }
.btn-sm { padding: .35rem .75rem; font-size: .8rem; }
.btn-lg { padding: .75rem 1.5rem; font-size: 1rem; }
.btn-block { width: 100%; }

select {
    appearance: none;
    -webkit-appearance: none;
    min-height: var(--control-height);
    padding: 0.5rem 2.25rem 0.5rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    font: inherit;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text);
    background-color: var(--surface);
    background-image: var(--select-chevron);
    background-repeat: no-repeat;
    background-position: right 0.6rem center;
    background-size: 1.1rem;
    cursor: pointer;
    line-height: 1.25;
}
select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-light);
}
select:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Hero */
.hero { padding: 5rem 0 4rem; background: linear-gradient(180deg, #fff 0%, var(--bg) 100%); }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.hero-copy h1 { font-size: 3.2rem; line-height: 1.1; font-weight: 800; letter-spacing: -.02em; margin: 1rem 0; }
.hero-copy h1 em { font-style: normal; color: var(--primary); }
.lead { font-size: 1.15rem; color: var(--muted); max-width: 520px; }
.pill { display: inline-block; background: var(--primary-light); color: var(--primary); padding: .3rem .85rem; border-radius: 999px; font-size: .8rem; font-weight: 600; }
.hero-cta { display: flex; gap: 1rem; margin-top: 2rem; flex-wrap: wrap; }
.mock-card { background: var(--surface); border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 1.5rem; border: 1px solid var(--border); }
.mock-header { font-weight: 700; margin-bottom: 1rem; }
.mock-chart { height: 120px; background: linear-gradient(180deg, var(--primary-light), transparent); border-radius: 8px; margin-bottom: 1rem; }
.mock-rows div { display: flex; justify-content: space-between; padding: .5rem 0; border-bottom: 1px solid var(--border); font-size: .9rem; }

/* Sections */
.section { padding: 4rem 0; }
.section-alt { background: var(--surface); }
.section-title { text-align: center; font-size: 2rem; font-weight: 800; margin-bottom: 2.5rem; }
.compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.compare-card { padding: 2rem; border-radius: var(--radius); border: 1px solid var(--border); }
.compare-card.bad { background: #fef2f2; }
.compare-card.good { background: #ecfdf5; border-color: #a7f3d0; }
.compare-card h3 { margin-bottom: 1rem; }
.compare-card ul { list-style: none; }
.compare-card li { padding: .4rem 0; padding-left: 1.5rem; position: relative; font-size: .95rem; }
.compare-card li::before { content: '•'; position: absolute; left: 0; }
.content-panel { width: 100%; }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.step-card { text-align: center; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 2rem 1.5rem; box-shadow: var(--shadow); }
.section-alt .step-card { background: var(--bg); }
.step-num { display: inline-flex; width: 44px; height: 44px; align-items: center; justify-content: center; background: var(--primary); color: #fff; border-radius: 50%; font-weight: 700; margin-bottom: 1rem; font-size: 1.1rem; }
.step-card h3 { margin-bottom: 0.5rem; font-size: 1.1rem; }
.step-card p { color: var(--muted); font-size: 0.95rem; line-height: 1.55; }
.cta-section { padding-bottom: 5rem; }
.cta-box { text-align: center; background: linear-gradient(135deg, #4f46e5, #6366f1); color: #fff; padding: 3rem 2rem; border-radius: var(--radius); box-shadow: var(--shadow-lg); }
.cta-box h2 { font-size: 2rem; margin-bottom: .5rem; }
.cta-box p { opacity: .9; margin-bottom: 1.5rem; }
.cta-box .btn-primary { background: #fff; color: var(--primary); }
.cta-box .btn-primary:hover { background: #f8fafc; color: var(--primary-dark); }

.hero-links { display: flex; gap: 1.25rem; margin-top: 1.25rem; flex-wrap: wrap; }
.link-btn { background: none; border: none; color: var(--primary); font-weight: 600; cursor: pointer; font-size: 0.9rem; padding: 0; }
.mock-line-chart { margin-bottom: 1rem; }
.mock-line-chart svg { width: 100%; height: 110px; display: block; }
.mock-chart-labels, .demo-chart-labels { display: flex; justify-content: space-between; font-size: 0.7rem; color: var(--muted); margin-top: 0.35rem; padding: 0 2px; }
.demo-chart-labels em { display: block; font-style: normal; font-weight: 600; color: var(--text); margin-top: 0.15rem; }
.feature-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.feature-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; box-shadow: var(--shadow); }
.feature-card-head { display: flex; align-items: center; gap: 0.65rem; margin-bottom: 0.65rem; }
.feature-card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: var(--primary-light);
    border-radius: 10px;
    flex-shrink: 0;
    line-height: 0;
}
.feature-card-icon svg { display: block; color: var(--primary); }
.feature-card h3 { margin: 0; font-size: 1.1rem; }
.feature-card p { color: var(--muted); font-size: 0.95rem; }
.feature-card code { font-size: 0.8rem; background: var(--surface2); padding: 0.15rem 0.4rem; border-radius: 4px; }

.demo-modal { border: none; border-radius: var(--radius); padding: 1.75rem; max-width: 520px; width: 92%; box-shadow: var(--shadow-lg); }
.demo-modal::backdrop { background: rgba(15,23,42,.5); }
.demo-stat { font-size: 1.25rem; margin: 1rem 0; }
.demo-line-chart { margin: 1.5rem 0; }
.demo-line-chart svg { width: 100%; height: 140px; display: block; border-radius: 8px; background: var(--surface2); }
.folder-tree { background: #0f172a; color: #e2e8f0; padding: 1rem; border-radius: 8px; font-size: 0.8rem; overflow-x: auto; margin: 1rem 0; }
.chat-demo { display: flex; flex-direction: column; gap: 0.75rem; margin: 1rem 0; }
.chat-bubble { padding: 0.75rem 1rem; border-radius: 12px; font-size: 0.9rem; max-width: 90%; }
.chat-bubble.user { background: var(--primary-light); align-self: flex-end; }
.chat-bubble.ai { background: var(--surface2); align-self: flex-start; }

.expense-controls { display: flex; align-items: center; gap: 1rem; }
.expense-controls select { font-size: 0.8rem; min-height: 2.125rem; padding: 0.4rem 2rem 0.4rem 0.65rem; }
.ai-messages { max-height: 200px; overflow-y: auto; margin-bottom: 0.75rem; display: flex; flex-direction: column; gap: 0.5rem; }
.ai-form { display: flex; gap: 0.5rem; }
.ai-form input { flex: 1; padding: 0.55rem 0.85rem; border: 1px solid var(--border); border-radius: 8px; font: inherit; }

.account-page { width: 100%; display: flex; flex-direction: column; gap: 1.5rem; }
.account-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.25rem; width: 100%; }
.account-grid .card-wide { grid-column: 1 / -1; }

/* Billing overview hero */
.billing-hero {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 0;
    background: linear-gradient(135deg, #312e81 0%, #4f46e5 55%, #6366f1 100%);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    color: #fff;
}
.billing-hero-main { padding: 1.75rem 2rem; border-right: 1px solid rgba(255,255,255,.12); }
.billing-hero-stat { padding: 1.75rem 1.5rem; border-right: 1px solid rgba(255,255,255,.12); display: flex; flex-direction: column; justify-content: center; }
.billing-hero-stat:last-child { border-right: none; }
.billing-plan-badge {
    display: inline-block;
    background: rgba(255,255,255,.18);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.3rem 0.65rem;
    border-radius: 999px;
    margin-bottom: 0.75rem;
}
.billing-hero-title { font-size: 2.25rem; font-weight: 800; line-height: 1; margin: 0 0 0.5rem; color: #fff; }
.billing-hero-title span { font-size: 1rem; font-weight: 500; opacity: 0.75; margin-left: 0.15rem; }
.billing-hero-meta { font-size: 0.9rem; opacity: 0.85; margin: 0 0 1.25rem; color: #fff; }
.billing-hero-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.btn-on-dark { background: rgba(255,255,255,.15); color: #fff; border: 1px solid rgba(255,255,255,.35); }
.btn-on-dark:hover { background: rgba(255,255,255,.25); color: #fff; }
.billing-hero-actions .btn-primary { background: #fff; color: var(--primary); border: none; }
.billing-hero-actions .btn-primary:hover { background: #f8fafc; color: var(--primary-dark); }
.billing-stat-label { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; opacity: 0.75; margin-bottom: 0.35rem; }
.billing-stat-value { font-size: 1.65rem; font-weight: 800; margin: 0 0 0.65rem; color: #fff; line-height: 1.2; }
.billing-stat-value span { font-size: 0.95rem; font-weight: 500; opacity: 0.7; }
.billing-stat-value.billing-credit { color: #c7d2fe; }
.billing-stat-hint { font-size: 0.8rem; opacity: 0.7; margin-top: 0.35rem; }
.billing-hero .usage-bar { background: rgba(255,255,255,.2); margin: 0 0 0.5rem; height: 6px; }
.billing-hero .usage-fill { background: linear-gradient(90deg, #c7d2fe, #fff); }
.billing-hero .usage-bar.usage-mid .usage-fill { background: linear-gradient(90deg, #fcd34d, #fef3c7); }
.billing-hero .usage-bar.usage-high .usage-fill { background: linear-gradient(90deg, #fca5a5, #fee2e2); }
.topup-inline { display: flex; gap: 0.5rem; margin-top: 0.85rem; align-items: center; }
.topup-inline select {
    flex: 1;
    padding: 0.5rem 2rem 0.5rem 0.65rem;
    border: 1px solid rgba(255,255,255,.35);
    border-radius: 8px;
    background-color: rgba(255,255,255,.12);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23e2e8f0' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");
    color: #fff;
    font: inherit;
    font-size: 0.85rem;
}
.topup-inline select:focus {
    border-color: rgba(255,255,255,.55);
    box-shadow: 0 0 0 3px rgba(255,255,255,.15);
}
.topup-inline select option { color: var(--text); background: var(--surface); }
.billing-alert { margin: 0; }

/* Account shortcut tiles */
.account-tiles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.85rem;
}
.account-tile {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem 1.15rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s, transform .15s;
    box-shadow: var(--shadow);
}
.account-tile:hover {
    border-color: #c7d2fe;
    box-shadow: var(--shadow-lg);
    transform: translateY(-1px);
    text-decoration: none;
}
.account-tile-icon {
    width: 42px;
    height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primary-light);
    border-radius: 10px;
    flex-shrink: 0;
    line-height: 0;
    margin: 0;
    max-width: none;
    overflow: visible;
}
.account-tile-icon svg {
    display: block;
    width: 22px;
    height: 22px;
    margin: 0;
}
.account-tile strong { display: block; font-size: 0.9rem; color: var(--text); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 180px; }
.account-tile > div span { display: block; font-size: 0.8rem; color: var(--muted); margin-top: 0.1rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 180px; }

/* Bottom panels */
.account-panels { display: grid; grid-template-columns: 1.6fr 1fr; gap: 1.25rem; align-items: start; }
.account-panel .card-header h2 { font-size: 1rem; font-weight: 600; }
.panel-empty { color: var(--muted); padding: 2rem 1rem; text-align: center; font-size: 0.9rem; }
.table-flush { border: none; box-shadow: none; border-radius: 0; }
.table-flush .data-table th:first-child, .table-flush .data-table td:first-child { padding-left: 0; }
.table-flush .data-table th:last-child, .table-flush .data-table td:last-child { padding-right: 0; }
.txn-type { text-transform: capitalize; font-size: 0.85rem; }
.txn-amount { font-weight: 600; color: var(--primary); }
.text-success { color: var(--success); }

.shortcut-list { display: flex; flex-direction: column; }
.shortcut-list a {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.75rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--border);
    text-decoration: none;
    transition: color .15s;
}
.shortcut-list a > svg.icon {
    display: block;
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    padding: 9px;
    box-sizing: content-box;
    background: var(--primary-light);
    border-radius: 8px;
}
.shortcut-list a:last-child { border-bottom: none; }
.shortcut-list a:hover { text-decoration: none; }
.shortcut-list a:hover .shortcut-copy > span { color: var(--primary); }
.shortcut-list .shortcut-copy { display: flex; flex-direction: column; gap: 0.1rem; min-width: 0; }
.shortcut-list .shortcut-copy > span { font-weight: 600; font-size: 0.9rem; color: var(--text); }
.shortcut-list em { font-style: normal; font-size: 0.8rem; color: var(--muted); }

/* Security page */
.security-page { gap: 1.25rem; }
.security-overview {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.85rem;
}
.security-overview-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem 1.35rem;
    box-shadow: var(--shadow);
}
.security-overview-label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    margin-bottom: 0.5rem;
}
.security-overview-email { font-size: 1.05rem; font-weight: 700; color: var(--text); margin: 0 0 0.25rem; word-break: break-all; }
.security-overview-value { font-size: 1.05rem; font-weight: 700; color: var(--text); margin: 0 0 0.25rem; }
.security-overview-meta { font-size: 0.85rem; color: var(--muted); margin: 0; line-height: 1.45; }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size: 0.9em; }
.security-panels { margin-top: 0; }
.security-password-hint { color: var(--muted); font-size: 0.875rem; margin: 0 0 1rem; line-height: 1.5; }
.security-form { margin-top: 0; }
.security-form .btn-primary { margin-top: 0.25rem; }
.security-table .row-current { background: #f8fafc; }
.session-tag {
    display: inline-block;
    margin-left: 0.35rem;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    background: var(--primary-light);
    color: var(--primary);
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
    vertical-align: middle;
}
.admin-users-table { font-size: 0.82rem; }
.admin-login-cell { white-space: nowrap; font-size: 0.8rem; }
.admin-ip-cell { font-size: 0.8rem; color: var(--muted); }

/* Checkout */
.checkout-card { border-color: #c7d2fe; box-shadow: var(--shadow-lg); }
.checkout-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 0.5rem; }
.checkout-header h2 { font-size: 1.15rem; margin-bottom: 0.25rem; }
.checkout-lines { margin: 1rem 0; background: var(--surface2); border-radius: 10px; padding: 0.5rem 1rem; }
.checkout-lines div { display: flex; justify-content: space-between; padding: 0.55rem 0; border-bottom: 1px solid var(--border); font-size: 0.9rem; }
.checkout-lines div:last-child { border-bottom: none; }
.checkout-total { font-size: 1.05rem; font-weight: 700; margin-top: 0.25rem; padding-top: 0.65rem !important; border-top: 2px solid var(--border) !important; }
.checkout-total strong { color: var(--primary); font-size: 1.15rem; }

.stat-card { display: flex; flex-direction: column; gap: 0.35rem; }
.stat-label { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted); }
.stat-value { font-size: 1.75rem; font-weight: 800; color: var(--text); line-height: 1.2; }
.usage-bar { height: 8px; background: var(--surface2); border-radius: 999px; overflow: hidden; margin: 0.5rem 0; }
.usage-fill { height: 100%; background: linear-gradient(90deg, var(--primary), #818cf8); border-radius: 999px; }
.usage-bar.usage-mid .usage-fill { background: linear-gradient(90deg, #d97706, #fbbf24); }
.usage-bar.usage-high .usage-fill { background: linear-gradient(90deg, #dc2626, #f87171); }
.card-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.75rem; }
.inline-form { display: inline; }
.empty-state-card { text-align: center; padding: 3rem 2rem; }
.empty-state-card .btn { margin-top: 1rem; }
.invoice-list { display: flex; flex-direction: column; gap: 1.5rem; }
.platform-invoice { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-lg); overflow: hidden; }
.platform-invoice-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1.5rem; padding: 1.5rem 1.75rem; background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%); color: #fff; }
.platform-invoice-logo { font-size: 1.35rem; font-weight: 800; color: #fff; }
.platform-invoice-logo span { opacity: 0.9; }
.platform-invoice-vendor { display: block; font-size: 0.8rem; opacity: 0.85; margin-top: 0.15rem; }
.platform-invoice-meta h2 { font-size: 1.5rem; font-weight: 700; margin-bottom: 0.5rem; text-align: right; }
.platform-invoice-meta dl { margin: 0; }
.platform-invoice-meta dl div { display: flex; justify-content: flex-end; gap: 0.75rem; font-size: 0.85rem; margin-bottom: 0.25rem; }
.platform-invoice-meta dt { opacity: 0.8; }
.platform-invoice-meta dd { margin: 0; font-weight: 600; }
.platform-invoice-header .status { background: rgba(255,255,255,.2); color: #fff; }
.platform-invoice-header .status-completed { background: rgba(255,255,255,.25); color: #fff; }
.platform-invoice-parties { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; padding: 1.5rem 1.75rem; border-bottom: 1px solid var(--border); }
.platform-invoice-parties h3 { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); margin-bottom: 0.5rem; }
.platform-invoice-parties p { margin: 0 0 0.2rem; font-size: 0.9rem; color: var(--text); }
.platform-invoice-dates { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1rem; padding: 1.25rem 1.75rem; background: var(--surface2); border-bottom: 1px solid var(--border); }
.platform-invoice-dates > div { display: flex; flex-direction: column; gap: 0.2rem; }
.platform-invoice-dates span { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted); font-weight: 600; }
.platform-invoice-dates strong { font-size: 0.9rem; color: var(--text); }
.platform-invoice-dates .mono { font-family: ui-monospace, monospace; font-size: 0.8rem; }
.platform-invoice-table { margin: 0; border: none; border-radius: 0; }
.platform-invoice-table .data-table th { background: var(--surface); }
.invoice-line-desc { margin: 0.35rem 0 0; font-size: 0.85rem; color: var(--muted); font-weight: 400; }
.invoice-total { font-size: 1.1rem; font-weight: 800; color: var(--primary); }
.platform-invoice-footer { padding: 1rem 1.75rem; background: var(--surface2); font-size: 0.85rem; color: var(--muted); }
.platform-invoice-footer a { color: var(--primary); }
.text-right { text-align: right; }
.notify-form { display: flex; flex-direction: column; gap: 0.75rem; margin-top: 1.25rem; }
.notify-option { display: flex; align-items: flex-start; gap: 1rem; padding: 1rem 1.15rem; border: 1px solid var(--border); border-radius: 10px; background: var(--surface); cursor: pointer; transition: border-color .15s, background .15s; }
.notify-option:hover { border-color: #c7d2fe; background: #fafbff; }
.notify-option input[type="checkbox"] { width: 18px; height: 18px; margin-top: 0.15rem; accent-color: var(--primary); flex-shrink: 0; }
.notify-option-body { display: flex; flex-direction: column; gap: 0.2rem; }
.notify-option-body strong { color: var(--text); font-size: 0.95rem; font-weight: 600; }
.notify-option-body span { color: var(--muted); font-size: 0.875rem; line-height: 1.45; }
.form-grid label { display: block; margin-bottom: 1rem; font-size: 0.875rem; font-weight: 500; }
.form-grid input, .form-grid textarea { width: 100%; margin-top: 0.35rem; padding: 0.65rem 0.85rem; border: 1px solid var(--border); border-radius: 8px; font: inherit; }
.form-grid select { width: 100%; margin-top: 0.35rem; }
.form-grid input:focus, .form-grid select:focus, .form-grid textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-light); }
.form-grid .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.profile-list { display: flex; flex-direction: column; gap: 0.75rem; }
.profile-item { display: flex; justify-content: space-between; align-items: center; padding: 1rem; border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface2); }
.profile-item strong { display: block; }
.profile-item span { font-size: 0.85rem; color: var(--muted); }
.plan-name { font-size: 1.5rem; font-weight: 700; }
.credit-balance { font-size: 2rem; font-weight: 800; color: var(--primary); }
.topup-form { display: flex; gap: 0.5rem; align-items: flex-end; margin-top: 0.75rem; }
.card h2 { font-size: 1rem; font-weight: 600; color: var(--text); }
.alert-warning { background: #fef3c7; color: #92400e; }
.alert-info { background: #e0e7ff; color: #3730a3; }
/* Team page */
.team-page { gap: 1.25rem; }
.team-overview {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
.team-overview-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem 1.35rem;
    box-shadow: var(--shadow);
}
.team-overview-label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    margin-bottom: 0.35rem;
}
.team-overview-value {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 0.25rem;
    line-height: 1.2;
}
.team-overview-meta { font-size: 0.85rem; color: var(--muted); margin: 0; line-height: 1.45; }

.team-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(280px, 1fr);
    gap: 1.25rem;
    align-items: start;
}
.team-layout-single { grid-template-columns: 1fr; }
.team-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
}
.team-card-head h2 { margin-bottom: 0.35rem; }
.team-card-head p { margin: 0; max-width: 36rem; }
.team-card-head-compact { align-items: center; margin-bottom: 1rem; }
.team-invite-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: var(--primary-light);
    color: var(--primary);
    flex-shrink: 0;
}
.team-invite-icon svg { display: block; }

.team-roster { display: flex; flex-direction: column; gap: 0.75rem; }
.team-member-card {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 1rem;
    align-items: center;
    padding: 1.1rem 1.2rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow);
    transition: border-color .15s, box-shadow .15s;
}
.team-member-card:hover { border-color: #c7d2fe; }
.team-member-owner {
    background: linear-gradient(135deg, #fafaff 0%, #fff 100%);
    border-color: #c7d2fe;
}
.team-member-pending { background: #fafafa; }
.team-member-avatar {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--primary) 0%, #6366f1 100%);
    color: #fff;
    font-size: 0.95rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    letter-spacing: 0.02em;
}
.team-member-owner .team-member-avatar {
    background: linear-gradient(135deg, #312e81 0%, #4f46e5 100%);
}
.team-member-main { min-width: 0; }
.team-member-title-row {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
    margin-bottom: 0.2rem;
}
.team-member-title-row strong { font-size: 1rem; color: var(--text); }
.team-member-email { margin: 0; font-size: 0.85rem; color: var(--muted); word-break: break-word; }
.team-member-note { margin: 0.35rem 0 0; font-size: 0.82rem; color: var(--muted); line-height: 1.45; }

.team-role-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.72rem;
    font-weight: 600;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    background: var(--surface2);
    color: var(--text);
    white-space: nowrap;
}
.team-role-badge svg { display: block; width: 14px; height: 14px; }
.team-role-owner { background: #eef2ff; color: #4338ca; }
.team-role-manager { background: #ecfdf5; color: #047857; }
.team-role-uploader { background: #eff6ff; color: #1d4ed8; }
.team-role-viewer { background: #f1f5f9; color: #475569; }
.team-role-accountant { background: #fef3c7; color: #b45309; }

.team-member-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.5rem;
    flex-shrink: 0;
}
.team-role-form { margin: 0; }
.team-role-select-label {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.team-role-select-label select {
    font-size: 0.85rem;
    min-height: 2.125rem;
    min-width: 9rem;
    margin: 0;
}
.team-remove-btn { color: var(--muted); border-color: var(--border); }
.team-remove-btn:hover { color: var(--error); border-color: #fecaca; background: #fef2f2; }

.team-sidebar { display: flex; flex-direction: column; gap: 1.25rem; }
.team-invite-form { display: flex; flex-direction: column; gap: 1rem; }
.team-email-label {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    font-size: 0.875rem;
    font-weight: 500;
}
.team-email-label input {
    padding: 0.65rem 0.85rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    font: inherit;
}
.team-email-label input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-light);
}

.team-role-picker {
    border: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.team-role-picker legend {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 0.5rem;
    padding: 0;
}
.team-role-option {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.85rem 1rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--surface);
    cursor: pointer;
    transition: border-color .15s, background .15s, box-shadow .15s;
}
.team-role-option:hover { border-color: #c7d2fe; background: #fafbff; }
.team-role-option:has(input:checked) {
    border-color: var(--primary);
    background: var(--primary-light);
    box-shadow: 0 0 0 1px var(--primary);
}
.team-role-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.team-role-option-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: #fff;
    color: var(--primary);
    flex-shrink: 0;
}
.team-role-option-icon svg { display: block; }
.team-role-option-body { display: flex; flex-direction: column; gap: 0.15rem; min-width: 0; }
.team-role-option-body strong { font-size: 0.9rem; color: var(--text); }
.team-role-option-body span { font-size: 0.8rem; color: var(--muted); line-height: 1.4; }

.team-roles-card h2 { margin-bottom: 1rem; }
.team-role-grid { display: flex; flex-direction: column; gap: 0.65rem; }
.team-role-card {
    padding: 0.85rem 1rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--surface2);
}
.team-role-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: #fff;
    color: var(--primary);
    margin-bottom: 0.45rem;
}
.team-role-card-icon svg { display: block; }
.team-role-card strong { display: block; font-size: 0.9rem; margin-bottom: 0.2rem; }
.team-role-card p { margin: 0; font-size: 0.8rem; color: var(--muted); line-height: 1.45; }
.due-card { margin-bottom: 0; }
.due-list, .due-list-compact { display: flex; flex-direction: column; gap: 0.5rem; min-height: 80px; }
.due-item, .due-item-compact { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 0.85rem 1rem; border: 1px solid var(--border); border-radius: 10px; background: var(--surface2); flex-wrap: wrap; }
.due-item.due-soon, .due-item-compact.due-soon { border-color: #fcd34d; background: #fffbeb; }
.due-item-compact > div { display: flex; flex-direction: column; gap: 0.15rem; min-width: 0; }
.due-item-compact > div span { font-size: 0.8rem; color: var(--muted); }
.due-item strong, .due-item-compact strong { color: var(--text); font-size: 0.9rem; }
.due-badge { font-style: normal; font-size: 0.7rem; font-weight: 700; padding: 0.15rem 0.45rem; border-radius: 999px; margin-left: 0.35rem; }
.due-badge.today { background: #fee2e2; color: #b91c1c; }
.due-badge.overdue { background: #fecaca; color: #991b1b; }
.due-badge.soon { background: #fef3c7; color: #92400e; }
.empty-inline { color: var(--muted); padding: 1rem 0; }
.field-hint { display: block; font-size: 0.8rem; color: var(--muted); margin-top: 0.35rem; font-weight: 400; }
.notify-form label:not(.notify-option) { display: block; margin-top: 0.75rem; font-size: 0.875rem; font-weight: 500; color: var(--text); }
.notify-form label:not(.notify-option) input { width: 100%; margin-top: 0.35rem; padding: 0.65rem 0.85rem; border: 1px solid var(--border); border-radius: 8px; font: inherit; }

.reminder-days-section {
    margin-top: 0.5rem;
    padding: 1.15rem 1.25rem;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 12px;
}
.reminder-days-header { margin-bottom: 1rem; }
.reminder-days-header strong { display: block; font-size: 0.95rem; color: var(--text); margin-bottom: 0.25rem; }
.reminder-days-header p { margin: 0; font-size: 0.85rem; }
.reminder-day-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.reminder-day-chip {
    appearance: none;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    font: inherit;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0.55rem 1rem;
    border-radius: 999px;
    cursor: pointer;
    transition: border-color .15s, background .15s, color .15s, box-shadow .15s;
}
.reminder-day-chip:hover {
    border-color: #c7d2fe;
    background: #fafbff;
}
.reminder-day-chip.active {
    border-color: var(--primary);
    background: var(--primary-light);
    color: var(--primary-dark);
    box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.12);
}
.reminder-day-chip:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
}
.reminder-days-preview {
    margin: 0.85rem 0 0;
    font-size: 0.85rem;
    color: var(--muted);
    line-height: 1.45;
}
.reminder-days-preview-warn { color: #b45309; }
.notify-reminder-link {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--border);
}
.notify-reminder-link p { margin: 0 0 0.35rem; }
.notify-reminder-link .btn { margin-top: 0.75rem; }
.notif-wrap { position: relative; }
.notif-btn {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    min-height: var(--control-height);
    min-width: var(--control-height);
    padding: 0;
    cursor: pointer;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
    transition: border-color .15s, color .15s;
}
.notif-btn:hover { border-color: var(--primary); }
.notif-btn svg { display: block; color: var(--text); }
.notif-badge { position: absolute; top: -4px; right: -4px; background: #dc2626; color: #fff; font-size: 0.65rem; font-weight: 700; padding: 0.1rem 0.35rem; border-radius: 999px; }
.notif-dropdown { position: absolute; right: 0; top: calc(100% + 8px); width: 320px; max-height: 360px; overflow-y: auto; background: var(--surface); border: 1px solid var(--border); border-radius: 12px; box-shadow: var(--shadow-lg); z-index: 60; padding: 0.5rem; }
.notif-item { display: block; padding: 0.75rem; border-radius: 8px; text-decoration: none; border-bottom: 1px solid var(--border); }
.notif-item:hover { background: var(--surface2); text-decoration: none; }
.notif-item.unread { background: #eef2ff; }
.notif-item strong { display: block; color: var(--text); font-size: 0.85rem; }
.notif-item span { display: block; color: var(--muted); font-size: 0.8rem; margin-top: 0.15rem; }
.notif-empty { padding: 1rem; color: var(--muted); font-size: 0.85rem; text-align: center; }

/* Auth */
.auth-page { min-height: calc(100vh - 200px); display: flex; align-items: center; justify-content: center; padding: 2rem; }
.auth-card { background: var(--surface); padding: 2.5rem; border-radius: var(--radius); box-shadow: var(--shadow-lg); width: 100%; max-width: 420px; border: 1px solid var(--border); }
.auth-card h1 { font-size: 1.5rem; margin-bottom: .25rem; }
.auth-card label { display: block; margin-bottom: 1rem; font-size: .875rem; font-weight: 500; }
.auth-card input { width: 100%; margin-top: .35rem; padding: .65rem .85rem; border: 1px solid var(--border); border-radius: 8px; font: inherit; }
.auth-card input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-light); }
.auth-footer { text-align: center; margin-top: 1.5rem; font-size: .9rem; color: var(--muted); }

/* Pricing */
.pricing-hero {
    padding: 4.5rem 0 3.5rem;
    background: linear-gradient(165deg, #fff 0%, var(--primary-light) 45%, var(--bg) 100%);
    border-bottom: 1px solid var(--border);
}
.pricing-hero-inner { text-align: center; max-width: 720px; }
.pricing-hero h1 {
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 800;
    line-height: 1.12;
    letter-spacing: -.02em;
    margin: 1rem 0;
}
.pricing-hero h1 em { font-style: normal; color: var(--primary); }
.pricing-hero .lead { margin: 0 auto; max-width: 560px; }
.pricing-alert { margin-top: 1.5rem; text-align: left; }

.pricing-plans-section { padding: 4rem 0; }
.pricing-packs-section {
    padding: 4rem 0;
    background: var(--surface);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.pricing-trust-section { padding: 3.5rem 0 4rem; }

.pricing-section-head { text-align: center; max-width: 640px; margin: 0 auto 2.5rem; }
.pricing-section-head h2 { font-size: 1.75rem; font-weight: 800; margin: 0 0 0.65rem; letter-spacing: -.02em; }
.pricing-section-head p { color: var(--muted); margin: 0; font-size: 1.02rem; line-height: 1.6; }

.pricing-grid { display: grid; gap: 1.5rem; }
.pricing-plans-grid { grid-template-columns: repeat(3, 1fr); align-items: stretch; }

.pricing-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 4px);
    padding: 1.75rem;
    box-shadow: var(--shadow);
    transition: border-color .2s, box-shadow .2s, transform .2s;
}
.pricing-card:hover { box-shadow: var(--shadow-lg); }
.pricing-card.featured {
    border-color: var(--primary);
    box-shadow: 0 12px 40px rgba(79, 70, 229, .15);
    transform: translateY(-4px);
    z-index: 1;
}
.pricing-card-badge {
    position: absolute;
    top: -0.65rem;
    left: 50%;
    transform: translateX(-50%);
    background: var(--primary);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    padding: 0.3rem 0.85rem;
    border-radius: 999px;
    white-space: nowrap;
}
.pricing-card-top { margin-bottom: 1rem; }
.pricing-card h3 { font-size: 1.2rem; font-weight: 800; margin: 0 0 0.35rem; }
.pricing-card-desc { color: var(--muted); font-size: 0.9rem; margin: 0; line-height: 1.5; min-height: 2.7rem; }
.pricing-card-price { margin-bottom: 1.25rem; }
.price-amount { font-size: 2.35rem; font-weight: 800; line-height: 1; letter-spacing: -.02em; }
.price-period { display: block; font-size: 0.85rem; font-weight: 500; color: var(--muted); margin-top: 0.2rem; }
.pricing-card-metrics {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem;
    margin-bottom: 1.25rem;
}
.pricing-metric {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0.75rem 0.85rem;
    text-align: center;
}
.pricing-metric strong { display: block; font-size: 1.05rem; font-weight: 800; color: var(--text); }
.pricing-metric span { display: block; font-size: 0.72rem; color: var(--muted); margin-top: 0.15rem; text-transform: uppercase; letter-spacing: .03em; font-weight: 600; }
.pricing-card.plan-pro .pricing-metric { background: var(--primary-light); border-color: rgba(79, 70, 229, .15); }
.pricing-card.plan-business .pricing-metric { background: #ecfdf5; border-color: rgba(5, 150, 105, .15); }
.pricing-feature-list { flex: 1; margin: 0 0 1.5rem; }
.pricing-card-cta { margin-top: auto; }

.pricing-packs-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: start;
}
.pricing-pack-column-head { margin-bottom: 1rem; }
.pricing-pack-column-head p { color: var(--muted); font-size: 0.9rem; margin: 0.5rem 0 0; }
.pack-tier-label {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .35rem .75rem;
    border-radius: 999px;
}
.pack-column-pro .pack-tier-label { background: var(--primary-light); color: var(--primary); }
.pack-column-business .pack-tier-label { background: #d1fae5; color: #047857; }
.pricing-pack-stack { display: flex; flex-direction: column; gap: 1rem; }
.pricing-pack-card {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem 1.35rem;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    transition: border-color .2s, box-shadow .2s;
}
.pricing-pack-card:hover { border-color: rgba(79, 70, 229, .35); box-shadow: var(--shadow); }
.pack-column-business .pricing-pack-card:hover { border-color: rgba(5, 150, 105, .35); }
.pricing-pack-main {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}
.pricing-pack-card h3 { font-size: 1rem; font-weight: 700; margin: 0 0 0.25rem; }
.pricing-pack-desc { font-size: 0.82rem; color: var(--muted); margin: 0; line-height: 1.45; }
.pricing-pack-price-block { text-align: right; flex-shrink: 0; }
.pricing-pack-price { display: block; font-size: 1.35rem; font-weight: 800; line-height: 1.1; }
.pricing-pack-rate { display: block; font-size: 0.78rem; font-weight: 600; color: var(--primary); margin-top: 0.2rem; }
.pack-column-business .pricing-pack-rate { color: #059669; }
.pricing-pack-tags {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin: 0;
    padding: 0;
}
.pricing-pack-tags li {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--muted);
    background: var(--surface);
    border: 1px solid var(--border);
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
}
.pricing-pack-cta { margin-top: auto; }

.pricing-trust-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}
.pricing-trust-item {
    text-align: center;
    padding: 1.5rem 1rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}
.pricing-trust-item .icon-trust { color: var(--primary); margin-bottom: 0.75rem; }
.pricing-trust-item strong { display: block; font-size: 0.95rem; margin-bottom: 0.35rem; }
.pricing-trust-item p { font-size: 0.85rem; color: var(--muted); margin: 0; line-height: 1.5; }
.pricing-footnote { text-align: center; font-size: 0.9rem; margin: 0; }

.price { font-size: 2.5rem; font-weight: 800; margin: .75rem 0; }
.price span { font-size: 1rem; font-weight: 500; color: var(--muted); }
.feature-list { list-style: none; margin: 1.5rem 0; }
.feature-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: .4rem 0;
    font-size: .9rem;
    color: var(--muted);
}
.feature-list li::before { content: none; }

/* Help center / docs */
.docs-hero {
    padding: 3.5rem 0 2.5rem;
    background: linear-gradient(165deg, #fff 0%, var(--primary-light) 50%, var(--bg) 100%);
    border-bottom: 1px solid var(--border);
}
.docs-hero-inner { text-align: center; max-width: 680px; }
.docs-hero h1 { font-size: clamp(1.85rem, 4vw, 2.6rem); font-weight: 800; margin: 0.75rem 0; letter-spacing: -.02em; }
.docs-search {
    display: flex;
    gap: 0.5rem;
    max-width: 420px;
    margin: 1.75rem auto 0;
}
.docs-search input {
    flex: 1;
    padding: 0.65rem 0.9rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    font: inherit;
}
.docs-layout-section { padding: 2.5rem 0 4rem; }
.docs-layout, .docs-article-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 2rem;
    align-items: start;
}
.docs-nav { display: flex; flex-direction: column; gap: 0.2rem; position: sticky; top: 5rem; }
.docs-nav-label { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); padding: 0 0.75rem 0.5rem; }
.docs-nav a {
    display: block;
    padding: 0.45rem 0.75rem;
    border-radius: 8px;
    color: var(--muted);
    font-size: 0.9rem;
    font-weight: 500;
    text-decoration: none;
}
.docs-nav a:hover { background: var(--surface2); color: var(--text); text-decoration: none; }
.docs-nav a.active { background: var(--primary-light); color: var(--primary); font-weight: 600; }
.docs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.25rem;
}
.docs-card {
    display: flex;
    flex-direction: column;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    text-decoration: none !important;
    color: inherit;
    box-shadow: var(--shadow);
    transition: border-color .2s, box-shadow .2s, transform .2s;
}
.docs-card:hover { border-color: rgba(79, 70, 229, .35); box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.docs-card-cover {
    height: 140px;
    background: var(--surface2) center/cover no-repeat;
}
.docs-card-cover-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary);
    background: linear-gradient(135deg, var(--primary-light), var(--surface2));
}
.docs-card-body { padding: 1.15rem 1.25rem 1.35rem; flex: 1; display: flex; flex-direction: column; }
.docs-card-category {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--primary);
    margin-bottom: 0.4rem;
}
.docs-card h2 { font-size: 1.05rem; font-weight: 700; margin: 0 0 0.4rem; line-height: 1.35; color: var(--text); }
.docs-card p { font-size: 0.88rem; color: var(--muted); margin: 0; line-height: 1.5; flex: 1; }
.docs-empty { padding: 2.5rem; text-align: center; }
.docs-article-hero {
    padding: 2.5rem 0 1.5rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
}
.docs-article-hero-inner { max-width: 760px; }
.docs-back { font-size: 0.88rem; font-weight: 600; display: inline-block; margin-bottom: 1rem; }
.docs-article-hero h1 { font-size: clamp(1.75rem, 4vw, 2.35rem); font-weight: 800; margin: 0.5rem 0; letter-spacing: -.02em; }
.docs-article-summary { font-size: 1.1rem; color: var(--muted); margin: 0; line-height: 1.6; max-width: 620px; }
.docs-article-section { padding: 2rem 0 4rem; }
.docs-article { padding: 0; overflow: hidden; }
.docs-article-cover img { width: 100%; max-height: 360px; object-fit: cover; display: block; }
.doc-content { padding: 2rem 2.25rem 2.5rem; font-size: 1.02rem; line-height: 1.75; color: var(--text); }
.doc-content h2, .doc-content h3, .doc-content h4 { margin: 2rem 0 0.75rem; line-height: 1.3; font-weight: 800; }
.doc-content h2.doc-heading { font-size: 1.45rem; }
.doc-content h3.doc-heading { font-size: 1.2rem; }
.doc-content h4.doc-heading { font-size: 1.05rem; }
.doc-content p { margin: 0 0 1rem; color: var(--text); }
.doc-content a { color: var(--primary); font-weight: 500; }
.doc-content ul.doc-list, .doc-content ol.doc-list { margin: 0 0 1.25rem 1.25rem; }
.doc-content li { margin-bottom: 0.4rem; }
.doc-content .doc-code, .doc-content code { background: var(--surface2); padding: 0.15rem 0.4rem; border-radius: 4px; font-size: 0.88em; }
.doc-content .doc-pre {
    background: #0f172a;
    color: #e2e8f0;
    padding: 1rem 1.15rem;
    border-radius: 8px;
    overflow-x: auto;
    margin: 0 0 1.25rem;
    font-size: 0.88rem;
}
.doc-content p { line-height: 1.7; margin-bottom: 1rem; }
.doc-content strong { font-weight: 600; }
.doc-content p strong, .doc-content li strong { font-weight: 600; }
.doc-content h2, .doc-content h3, .doc-content h4 { font-weight: 700; }
.doc-content .doc-figure { margin: 1.5rem 0; }
.doc-content .doc-inline-img { display: none; }
.doc-content .doc-figure img, .doc-content .doc-inline-img {
    max-width: 100%;
    border-radius: var(--radius);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
}
.doc-content figcaption { font-size: 0.85rem; color: var(--muted); margin-top: 0.5rem; text-align: center; }
.doc-edit-form label { display: block; margin-bottom: 1rem; font-size: 0.875rem; font-weight: 500; }
.doc-edit-form input, .doc-edit-form textarea {
    width: 100%;
    margin-top: 0.35rem;
    padding: 0.6rem 0.8rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    font: inherit;
}
.doc-edit-form select { width: 100%; margin-top: 0.35rem; }
.doc-markdown-input { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.88rem; line-height: 1.55; }
.doc-editor-toolbar { display: flex; align-items: center; gap: 1rem; margin-bottom: 0.5rem; flex-wrap: wrap; }
.doc-upload-label { margin: 0; cursor: pointer; }
.doc-preview-wrap { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.doc-preview { background: var(--surface2); border-radius: var(--radius); padding: 1.5rem; }
.docs-gen-actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.docs-auto-label { display: flex; align-items: center; gap: 0.4rem; font-size: 0.9rem; margin: 0; cursor: pointer; }
.admin-header-actions { display: flex; gap: 0.5rem; }

/* App layout */
.app-body { display: flex; min-height: 100vh; }
.sidebar { width: 240px; background: #0f172a; color: #fff; display: flex; flex-direction: column; padding: 1.5rem; flex-shrink: 0; }
.sidebar .logo { color: #fff; margin-bottom: 2rem; }
.sidebar-nav { display: flex; flex-direction: column; gap: .25rem; flex: 1; }
.sidebar-section-label { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.08em; color: #64748b; padding: 1rem 0.85rem 0.35rem; font-weight: 600; }
.sidebar-nav a {
    color: #94a3b8;
    padding: .6rem .85rem;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 500;
    font-size: .9rem;
    display: flex;
    align-items: center;
    gap: 0.65rem;
}
.sidebar-nav a:hover, .sidebar-nav a.active { background: rgba(255,255,255,.08); color: #fff; }
.sidebar-nav a:hover .icon-nav, .sidebar-nav a.active .icon-nav { opacity: 1; color: #fff; }
.sidebar-footer { border-top: 1px solid rgba(255,255,255,.1); padding-top: 1rem; font-size: .85rem; }
.sidebar-logout { display: inline-flex; align-items: center; gap: 0.35rem; margin-top: 0.5rem; }
.sidebar-logout .icon-nav { opacity: 0.7; }
.sidebar-logout:hover { color: #fff; }
.sidebar-logout:hover .icon-nav { opacity: 1; color: #fff; }
.user-chip strong { display: block; }
.user-chip span { color: #94a3b8; }
.app-main { flex: 1; padding: 1.5rem 2rem; overflow-x: hidden; min-width: 0; }
.app-content { width: 100%; max-width: none; }
.sidebar-brand-note { font-size: 0.7rem; color: #64748b; margin: -1rem 0 1.25rem; line-height: 1.3; }
.app-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1.5rem; flex-wrap: wrap; gap: 1rem; }
.app-header h1 { font-size: 1.5rem; font-weight: 700; }
.header-actions { display: flex; gap: .75rem; align-items: center; }
.header-actions .btn-sm {
    min-height: var(--control-height);
    padding: 0 0.85rem;
}
.profile-select { display: flex; }
.profile-select select { min-width: 10rem; font-size: 0.8rem; }
.impersonate-bar { background: #fef3c7; color: #92400e; padding: .5rem 1rem; text-align: center; font-size: .875rem; }

/* Dashboard */
.dashboard-page { display: flex; flex-direction: column; gap: 1.5rem; }
.dash-hero {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 0;
    background: linear-gradient(135deg, #312e81 0%, #4f46e5 55%, #6366f1 100%);
    border-radius: var(--radius);
    color: #fff;
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}
.dash-hero-main { padding: 1.75rem 2rem; border-right: 1px solid rgba(255,255,255,.12); }
.dash-hero-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.dash-hero-label { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.07em; opacity: 0.75; display: block; margin-bottom: 0.35rem; }
.dash-hero-title { font-size: 1.85rem; font-weight: 800; line-height: 1.15; margin: 0 0 0.5rem; color: #fff; }
.dash-hero-meta { font-size: 0.9rem; opacity: 0.9; margin: 0; color: #fff; }
.dash-plan-pill { display: inline-block; background: rgba(255,255,255,.18); padding: 0.15rem 0.55rem; border-radius: 999px; font-weight: 600; font-size: 0.8rem; }
.dash-hero-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.dash-hero-actions .btn-primary { background: #fff; color: var(--primary); border: none; }
.dash-hero-actions .btn-primary:hover { background: #f8fafc; }
.dash-hero-actions .btn-on-dark { border-color: rgba(255,255,255,.35); color: #fff; background: rgba(255,255,255,.08); }
.dash-hero-actions .btn-on-dark:hover { background: rgba(255,255,255,.15); color: #fff; border-color: rgba(255,255,255,.5); }
.dash-hero .usage-bar { background: rgba(255,255,255,.2); height: 6px; margin: 0; }
.dash-hero .usage-fill { background: linear-gradient(90deg, #c7d2fe, #fff); }
.dash-hero .usage-bar.usage-mid .usage-fill { background: linear-gradient(90deg, #fcd34d, #fef3c7); }
.dash-hero .usage-bar.usage-high .usage-fill { background: linear-gradient(90deg, #fca5a5, #fee2e2); }
.dash-usage-hint { font-size: 0.8rem; opacity: 0.8; margin: 0.5rem 0 0; }
.dash-stat-tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.dash-stat-tile { padding: 1.25rem 1.5rem; border-bottom: 1px solid rgba(255,255,255,.1); border-right: 1px solid rgba(255,255,255,.1); display: flex; flex-direction: column; justify-content: center; min-height: 100px; }
.dash-stat-tile:nth-child(2n) { border-right: none; }
.dash-stat-tile:nth-last-child(-n+2) { border-bottom: none; }
.dash-stat-tile.dash-stat-warn { background: rgba(254,226,226,.12); }
.dash-stat-label { font-size: 0.68rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; opacity: 0.75; margin-bottom: 0.3rem; }
.dash-stat-value { font-size: 1.45rem; font-weight: 800; line-height: 1.2; color: #fff; }
.dash-stat-value.dash-stat-credit { color: #c7d2fe; }
.dash-stat-hint { font-size: 0.78rem; opacity: 0.75; margin-top: 0.25rem; }
.dash-stat-link { font-size: 0.78rem; color: #c7d2fe; margin-top: 0.35rem; text-decoration: none; font-weight: 500; }
.dash-stat-link:hover { color: #fff; text-decoration: underline; }

.dash-ai-section {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 280px);
    gap: 1.25rem;
    margin-bottom: 1.25rem;
    align-items: stretch;
}
.dash-ai-card-wide { padding-bottom: 1.25rem; min-width: 0; }
.dash-ai-card-wide .ai-messages { max-height: 300px; min-height: 140px; }
.dash-ai-card-wide .ai-form input { min-width: 0; }
.dash-ai-tools { align-self: start; }
.dash-ai-tools-hint { font-size: 0.85rem; margin-bottom: 0.75rem; }
.dash-ai-upgrade { font-size: 0.9rem; margin: 0; }
.dash-ai-section:has(.dash-ai-card-wide:only-child) { grid-template-columns: 1fr; }

.dash-layout { display: grid; grid-template-columns: 1fr 260px; gap: 1.25rem; align-items: start; }
.dash-layout-full { grid-template-columns: 1fr; }
.dash-main { display: flex; flex-direction: column; gap: 1.25rem; min-width: 0; }
.dash-aside { display: flex; flex-direction: column; gap: 1.25rem; position: sticky; top: 1rem; }
.dash-insights { display: grid; grid-template-columns: 1.65fr 1fr; gap: 1.25rem; }
.dash-chart-card { min-height: 280px; }
.dash-chart-wrap { position: relative; min-height: 200px; }
.dash-chart-wrap canvas { max-height: 220px; }
.card-subtitle { font-size: 0.8rem; color: var(--muted); margin: 0.15rem 0 0; font-weight: 400; }
.expense-total-badge { font-size: 0.8rem; font-weight: 600; color: var(--primary); background: var(--primary-light); padding: 0.25rem 0.65rem; border-radius: 999px; white-space: nowrap; }
.dash-vendor-list { min-height: 180px; }
.dash-vendor-list li:last-child { border-bottom: none; }
.dash-vendor-list .empty { padding: 2rem 0; text-align: center; color: var(--muted); border: none; }
.dash-category-wrap { min-height: 140px; max-height: 160px; margin-bottom: 0.75rem; }
.dash-category-list { margin-top: 0.25rem; }
.dash-category-list .cat-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 0.4rem; vertical-align: middle; }
.dash-vendors-card { margin-bottom: 0; }
.dash-vendors-full { grid-column: 1 / -1; }
.dash-vendor-list-full { display: flex; flex-direction: column; gap: 0.65rem; width: 100%; }
.dash-vendor-list-full li { border-bottom: none; padding: 0; flex-direction: column; align-items: stretch; gap: 0.35rem; }
.dash-vendor-list-full li.empty { padding: 2rem 0; text-align: center; color: var(--muted); }
.dash-vendor-row-head { display: flex; justify-content: space-between; align-items: center; gap: 1rem; font-size: 0.875rem; }
.dash-vendor-row-head span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash-vendor-bar { width: 100%; height: 8px; border-radius: 999px; background: var(--surface2); overflow: hidden; }
.dash-vendor-bar-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, #6366f1, #4f46e5); min-width: 2px; }
.due-recurring-section { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--border); }
.due-recurring-section h3 { font-size: 0.82rem; font-weight: 600; margin: 0 0 0.65rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.ledger-desc { color: var(--muted); font-size: 0.78rem; line-height: 1.35; }
.cat-badge { display: inline-block; font-size: 0.68rem; font-weight: 600; padding: 0.2rem 0.5rem; border-radius: 999px; background: var(--primary-light); color: var(--primary); white-space: nowrap; }
.cat-badge.cat-software-saas { background: #dbeafe; color: #1d4ed8; }
.cat-badge.cat-hosting-infrastructure { background: #cffafe; color: #0e7490; }
.cat-badge.cat-marketing-advertising { background: #fce7f3; color: #be185d; }
.cat-badge.cat-office-supplies { background: #fef3c7; color: #b45309; }
.cat-badge.cat-professional-services { background: #ede9fe; color: #6d28d9; }
.cat-badge.cat-travel-meals { background: #ffedd5; color: #c2410c; }
.cat-badge.cat-utilities-telecom { background: #e0e7ff; color: #4338ca; }
.cat-badge.cat-insurance { background: #d1fae5; color: #047857; }
.cat-badge.cat-payroll-contractors { background: #f3e8ff; color: #7e22ce; }
.cat-badge.cat-hardware-equipment { background: #f1f5f9; color: #475569; }
.cat-badge.cat-taxes-fees { background: #fee2e2; color: #b91c1c; }
.cat-badge.cat-other { background: #f1f5f9; color: #64748b; }

.dash-payments-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.25rem; }
.dash-pay-list { display: flex; flex-direction: column; gap: 0.5rem; }
.dash-pay-item {
    display: flex; justify-content: space-between; align-items: center; gap: 1rem;
    padding: 0.9rem 1rem; border: 1px solid var(--border); border-radius: 10px;
    background: var(--surface2); text-decoration: none; color: inherit; transition: border-color .15s, box-shadow .15s;
}
.dash-pay-item:hover { border-color: #c7d2fe; box-shadow: var(--shadow); text-decoration: none; }
.dash-pay-item strong { display: block; color: var(--text); font-size: 0.9rem; }
.dash-pay-item span { font-size: 0.8rem; color: var(--muted); }
.dash-pay-amount { display: flex; align-items: center; gap: 0.65rem; text-align: right; }
.dash-pay-amount strong { color: var(--primary); font-size: 1rem; }
.dash-loading { padding: 1.5rem 0; text-align: center; }

.dash-workspace { padding: 0; overflow: hidden; background: var(--surface); }
.dash-workspace-head {
    display: flex; justify-content: space-between; align-items: flex-end; gap: 1rem; flex-wrap: wrap;
    padding: 1.25rem 1.25rem 0.75rem; border-bottom: 1px solid var(--border); background: transparent;
}
.dash-workspace-head h2 { font-size: 1rem; font-weight: 600; margin: 0; }
.dash-workspace .dash-tabs { margin-bottom: 0; background: var(--surface2); }
.dash-workspace .tab-panel { padding: 1.25rem; background: var(--surface); }
.dash-workspace .upload-zone { border-color: #c7d2fe; background: var(--surface); }
.dash-workspace .progress-card { border: none; padding: 0; margin-bottom: 1rem; box-shadow: none; }
.dash-empty-role { padding: 2.5rem; text-align: center; color: var(--muted); background: var(--surface2); border-radius: 10px; }

.dash-ai-card { padding-bottom: 1rem; }
.dash-links-card h2 { font-size: 0.95rem; font-weight: 600; margin-bottom: 0.75rem; }
.dash-quick-links { list-style: none; display: flex; flex-direction: column; gap: 0.15rem; }
.dash-quick-links a {
    display: block; padding: 0.55rem 0.65rem; border-radius: 8px; font-size: 0.875rem; font-weight: 500;
    color: var(--text); text-decoration: none; transition: background .15s;
}
.dash-quick-links a:hover { background: var(--surface2); text-decoration: none; color: var(--primary); }

.dashboard-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 1.25rem; margin-bottom: 1.5rem; }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; box-shadow: var(--shadow); }
.card-wide { grid-column: span 1; }
.dashboard-grid .card-wide, .dash-insights .card-wide { grid-column: 1 / -1; }
.card-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 1rem; flex-wrap: wrap; }
.card-header h2 { font-size: 1rem; font-weight: 600; margin: 0; }
.vendor-list { list-style: none; }
.vendor-list li { display: flex; justify-content: space-between; align-items: center; padding: .65rem 0; border-bottom: 1px solid var(--border); font-size: .875rem; gap: 0.5rem; }
.vendor-list li strong { color: var(--primary); font-weight: 700; white-space: nowrap; }
.upload-zone .upload-icon { color: var(--primary); margin-bottom: 0.75rem; line-height: 0; }
.upload-zone .upload-icon svg { display: block; margin: 0 auto; color: var(--primary); }

/* Tabs */
.tabs { display: flex; gap: .35rem; margin-bottom: 0; background: var(--surface); padding: .35rem; border-radius: 10px; border: 1px solid var(--border); flex-wrap: wrap; }
.dash-tabs { margin-bottom: -1px; border-bottom-left-radius: 0; border-bottom-right-radius: 0; border-bottom: none; background: var(--surface); }
.tab { background: transparent; border: none; padding: .5rem 1rem; border-radius: 8px; cursor: pointer; font: inherit; font-weight: 500; font-size: .875rem; color: var(--muted); }
.tab.active { background: var(--surface); color: var(--text); box-shadow: var(--shadow); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }
.badge { background: var(--primary-light); color: var(--primary); padding: .1rem .45rem; border-radius: 999px; font-size: .7rem; margin-left: .25rem; }

/* Upload */
.upload-zone { border: 2px dashed var(--border); border-radius: var(--radius); padding: 3rem; text-align: center; cursor: pointer; background: var(--surface); transition: .15s; }
.upload-zone:hover, .upload-zone.dragover { border-color: var(--primary); background: var(--primary-light); }
.upload-icon { margin-bottom: .75rem; }

/* Heroicons */
.icon { flex-shrink: 0; }
.icon-tile { width: 22px; height: 22px; color: var(--primary); }
.icon-nav { width: 18px; height: 18px; opacity: 0.8; color: currentColor; }
.icon-shortcut { width: 18px; height: 18px; color: var(--primary); flex-shrink: 0; }
.icon-check { width: 18px; height: 18px; color: var(--success); margin-top: 1px; }
.icon-nav-marketing { width: 18px; height: 18px; color: var(--muted); flex-shrink: 0; }
.icon-link-inline { width: 1em; height: 1em; vertical-align: -0.15em; }
.icon-inline-text { display: inline-block; vertical-align: -0.2em; margin: 0 0.15rem; color: var(--primary); }
.icon-back, .icon-link-arrow { flex-shrink: 0; }
.icon-notify { color: var(--primary); flex-shrink: 0; }
.icon-stat { color: var(--primary); margin-bottom: 0.35rem; }
.icon-upload { color: var(--primary); opacity: 0.85; }
.icon-feature { color: var(--primary); }
.icon-notif { color: currentColor; }

.nav-link-item { display: inline-flex; align-items: center; gap: 0.35rem; }
.nav-links a.btn { display: inline-flex; align-items: center; gap: 0.35rem; }
.btn-icon-text { display: inline-flex; align-items: center; gap: 0.35rem; }

.icon-back-link, .icon-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--muted);
    text-decoration: none !important;
}
.icon-back-link:hover, .icon-link:hover { color: var(--primary); }

.link-btn { display: inline-flex; align-items: center; gap: 0.35rem; }

.notify-option-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 8px;
    background: var(--primary-light);
    flex-shrink: 0;
    margin-top: 0.1rem;
}

.docs-search { position: relative; align-items: center; }
.docs-search-icon {
    position: absolute;
    left: 0.85rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--muted);
    pointer-events: none;
    display: flex;
}
.docs-search input { padding-left: 2.5rem; }

.admin-stat-card { position: relative; }
.admin-stat-icon { display: block; margin-bottom: 0.25rem; }
.btn-icon { display: inline-flex; align-items: center; gap: 0.35rem; }
.btn-icon svg { display: block; }
.hint { color: var(--muted); font-size: .85rem; }

/* Progress & tables */
.progress-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; margin-bottom: 1rem; }
.progress-header { display: flex; justify-content: space-between; font-size: .875rem; margin-bottom: .5rem; }
.progress-bar { height: 8px; background: var(--surface2); border-radius: 999px; overflow: hidden; }
.progress-fill { height: 100%; background: linear-gradient(90deg, var(--primary), #818cf8); border-radius: 999px; transition: width .4s; width: 0; }
.stats-row { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: .75rem; font-size: .8rem; color: var(--muted); }
.stat-pill { background: var(--surface2); padding: .2rem .55rem; border-radius: 999px; }
.table-wrap { overflow-x: auto; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); }
.data-table { width: 100%; border-collapse: collapse; font-size: .875rem; }
.data-table th { text-align: left; padding: .75rem 1rem; background: var(--surface2); color: var(--muted); font-weight: 600; font-size: .75rem; text-transform: uppercase; letter-spacing: .03em; }
.data-table td { padding: .65rem 1rem; border-top: 1px solid var(--border); }
.empty { color: var(--muted); text-align: center; padding: 2rem !important; }

.status { display: inline-block; padding: .15rem .5rem; border-radius: 999px; font-size: .7rem; font-weight: 600; text-transform: capitalize; }
.status-pending { background: #f1f5f9; color: #475569; }
.status-processing { background: #dbeafe; color: #1d4ed8; }
.status-completed { background: #d1fae5; color: #047857; }
.status-error { background: #fee2e2; color: #b91c1c; }
.status-duplicate { background: #ede9fe; color: #6d28d9; }

/* Browse */
.browse-toolbar { margin-bottom: 1rem; }
.browse-tree { display: flex; flex-direction: column; gap: .75rem; }
.company-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.company-header { padding: .85rem 1rem; background: var(--surface2); font-weight: 600; display: flex; justify-content: space-between; align-items: center; gap: .75rem; }
.month-block { border-top: 1px solid var(--border); }
.month-header { padding: .6rem 1rem .6rem 1.5rem; color: var(--muted); font-size: .85rem; font-weight: 600; display: flex; justify-content: space-between; align-items: center; gap: .75rem; }
.file-list { list-style: none; padding: 0 1rem .75rem 2rem; margin: 0; }
.file-list li { padding: .35rem 0; display: flex; align-items: center; gap: .75rem; font-size: .85rem; }
.browse-company > summary,
.browse-month > summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.browse-company > summary::-webkit-details-marker,
.browse-month > summary::-webkit-details-marker { display: none; }
.browse-company > summary::before,
.browse-month > summary::before {
    content: '';
    display: inline-block;
    width: .45rem;
    height: .45rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(-45deg);
    transition: transform .15s ease;
    margin-right: .55rem;
    flex-shrink: 0;
    opacity: .55;
}
.browse-company[open] > summary::before,
.browse-month[open] > summary::before { transform: rotate(45deg); }
.browse-summary-label { display: inline-flex; align-items: center; gap: .4rem; flex: 1; min-width: 0; }
.browse-count {
    font-style: normal;
    font-size: .75rem;
    font-weight: 600;
    color: var(--muted);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: .1rem .45rem;
}
.browse-company-body { border-top: 1px solid var(--border); }
.browse-month { border-top: 1px solid var(--border); }
.browse-month > summary.month-header { color: var(--text); }
.due-badge.paid { background: #d1fae5; color: #047857; display: inline-flex; align-items: center; gap: .25rem; }
.due-item-compact.due-received { opacity: .85; }

/* Admin */
.admin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.admin-grid .card-wide { grid-column: 1 / -1; }
.admin-form label { display: block; margin-bottom: .75rem; font-size: .875rem; font-weight: 500; }
.admin-form input, .admin-form textarea { width: 100%; margin-top: .25rem; padding: .5rem .75rem; border: 1px solid var(--border); border-radius: 8px; font: inherit; }
.admin-form select { width: 100%; margin-top: .25rem; }
.form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: .75rem; }
.actions-cell { display: flex; flex-direction: column; gap: .35rem; }
.credit-form { display: flex; gap: .35rem; flex-wrap: wrap; align-items: center; }
.admin-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; margin-bottom: 1.25rem; }
.admin-stat-card { display: flex; flex-direction: column; gap: 0.35rem; }
.admin-stat-label { font-size: 0.8rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.admin-stat-value { font-size: 1.75rem; font-weight: 700; }
.admin-page-header { margin-bottom: 1.25rem; }
.admin-page-header h2 { margin: 0.25rem 0; }
.admin-back { font-size: 0.875rem; text-decoration: none; }
.admin-dl { display: grid; gap: 0.5rem; margin: 0; }
.admin-dl > div { display: grid; grid-template-columns: 120px 1fr; gap: 0.5rem; font-size: 0.875rem; }
.admin-dl dt { color: var(--muted); margin: 0; }
.admin-dl dd { margin: 0; }
.admin-list { list-style: none; padding: 0; margin: 0; font-size: 0.875rem; }
.admin-list li { padding: 0.35rem 0; border-bottom: 1px solid var(--border); }
.invoice-line-items { display: flex; flex-direction: column; gap: 0.5rem; margin: 1rem 0; }
.invoice-line-row { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.invoice-line-row input[type="text"] { flex: 1; min-width: 180px; }
.invoice-line-row input[type="number"] { width: 110px; }
.invoice-pay-card { margin-bottom: 1.25rem; }
.invoice-pay-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-top: 0.75rem; }
.data-table-compact { font-size: 0.82rem; }

/* Alerts & misc */
.alert { padding: .75rem 1rem; border-radius: 8px; margin-bottom: 1rem; font-size: .875rem; }
.alert-error { background: #fee2e2; color: #b91c1c; }
.alert-success { background: #d1fae5; color: #047857; }
.hidden { display: none !important; }
.site-footer { padding: 2rem 0; border-top: 1px solid var(--border); color: var(--muted); font-size: .875rem; text-align: center; }
dialog { border: none; border-radius: var(--radius); padding: 1.5rem; box-shadow: var(--shadow-lg); max-width: 420px; width: 92%; margin: auto; inset: 0; position: fixed; }
dialog.profile-modal { max-width: 440px; }
dialog::backdrop { background: rgba(15,23,42,.45); }
.profile-modal form { display: flex; flex-direction: column; gap: 0.25rem; }
.footer-links { margin-top: 0.35rem; font-size: 0.85rem; }
.footer-links a { color: var(--muted); }
.legal-page { padding: 0; }
.legal-page h1 { margin-bottom: 0.5rem; }
.legal-page h2 { margin: 1.75rem 0 0.75rem; font-size: 1.1rem; }
.legal-page p, .legal-page li { color: var(--muted); margin-bottom: 0.75rem; }
.chart-empty { text-align: center; color: var(--muted); padding: 2rem; font-size: 0.9rem; }

/* Business HQ */
.business-suite-marketing,
.pricing-suite-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}
.business-suite-item, .business-suite-pricing-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.35rem;
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    min-height: 220px;
}
.business-suite-item h3, .business-suite-pricing-card h3 { font-size: 1rem; margin-bottom: 0.5rem; line-height: 1.35; }
.business-suite-item .business-suite-lead,
.business-suite-pricing-card .pricing-pack-desc { color: var(--text); font-size: 0.88rem; margin-bottom: 0.5rem; font-weight: 500; }
.business-suite-item .business-suite-detail,
.business-suite-pricing-card .business-suite-detail { color: var(--muted); font-size: 0.85rem; margin-bottom: 0.75rem; line-height: 1.55; flex: 1; }
.business-suite-item .pill, .business-suite-pricing-card .pack-tier-label { margin-top: auto; align-self: flex-start; }
.pricing-suite-grid { margin-top: 1rem; }
.business-hq-title { font-size: 1.65rem !important; }
.business-hq-page .business-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}
.business-feature-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.75rem;
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    min-height: 260px;
}
.business-feature-card.locked { opacity: 0.92; border-style: dashed; }
.business-feature-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.75rem; margin-bottom: 0.75rem; }
.business-feature-head h3 { font-size: 1.05rem; margin: 0; line-height: 1.35; }
.business-feature-lead { font-size: 0.92rem; font-weight: 500; color: var(--text); margin: 0 0 0.65rem; line-height: 1.5; }
.business-feature-detail { font-size: 0.88rem; color: var(--muted); margin: 0 0 1rem; line-height: 1.6; flex: 1; }
.business-feature-foot { margin-top: auto; }
.business-plan-pill { font-size: 0.7rem; font-weight: 600; background: var(--surface2); padding: 0.25rem 0.55rem; border-radius: 999px; color: var(--muted); white-space: nowrap; }
.business-panels { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-top: 1.5rem; }
.business-panels .card-wide { grid-column: 1 / -1; }
.business-panel-body { margin-top: 0.75rem; }
.business-stat-row { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.business-stat-row div span { display: block; font-size: 0.75rem; color: var(--muted); }
.business-stat-row strong { font-size: 1.25rem; }
.business-inbox-addr { background: var(--surface2); padding: 0.75rem 1rem; border-radius: 8px; font-size: 0.9rem; word-break: break-all; }
.business-export-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; padding: 0.5rem 0; }
.business-budget-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1rem; align-items: end; margin-bottom: 1rem; }
.budget-row { padding: 0.75rem 0; border-bottom: 1px solid var(--border); }
.budget-row.budget-alert { background: #fff7ed; margin: 0 -1rem; padding: 0.75rem 1rem; border-radius: 8px; }
.business-bank-form { display: flex; gap: 1rem; align-items: flex-end; flex-wrap: wrap; margin-bottom: 1rem; }
@media (max-width: 1200px) {
    .business-suite-marketing, .pricing-suite-grid { grid-template-columns: repeat(2, 1fr); }
    .business-hq-page .business-feature-grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
    .business-panels { grid-template-columns: 1fr; }
    .business-suite-marketing, .pricing-suite-grid { grid-template-columns: 1fr; }
}
dialog h3 { margin-bottom: 1rem; }
dialog label { display: block; margin-bottom: .75rem; font-size: .875rem; }
dialog input { width: 100%; margin-top: .25rem; padding: .5rem; border: 1px solid var(--border); border-radius: 8px; }
.dialog-actions { display: flex; gap: .5rem; justify-content: flex-end; margin-top: 1rem; }

@media (max-width: 900px) {
    .hero-grid, .compare-grid, .steps, .dashboard-grid, .admin-grid, .account-grid, .account-tiles, .account-panels, .billing-hero, .dash-hero, .dash-insights, .dash-ai-section, .dash-layout, .dash-stat-tiles, .feature-cards, .form-grid .form-row, .platform-invoice-parties, .platform-invoice-header { grid-template-columns: 1fr; flex-direction: column; }
    .dash-hero-main, .dash-stat-tile { border-right: none; border-bottom: 1px solid rgba(255,255,255,.12); }
    .dash-stat-tile:nth-child(2n) { border-right: none; }
    .dash-aside { position: static; }
    .dash-workspace-head { flex-direction: column; align-items: stretch; }
    .dash-tabs { width: 100%; }
    .billing-hero-main, .billing-hero-stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,.12); }
    .billing-hero-stat:last-child { border-bottom: none; }
    .account-tile strong, .account-tile > div span { max-width: none; }
    .security-overview, .team-overview { grid-template-columns: 1fr; }
    .team-layout { grid-template-columns: 1fr; }
    .team-member-card {
        grid-template-columns: auto 1fr;
        grid-template-rows: auto auto;
    }
    .team-member-actions {
        grid-column: 1 / -1;
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
        flex-wrap: wrap;
    }
    .platform-invoice-meta h2, .platform-invoice-meta dl div { text-align: left; justify-content: flex-start; }
    .hero-copy h1 { font-size: 2.4rem; }
    .pricing-plans-grid, .pricing-packs-layout, .pricing-trust-grid, .docs-layout, .docs-article-layout { grid-template-columns: 1fr; }
    .docs-nav { position: static; flex-direction: row; flex-wrap: wrap; margin-bottom: 1rem; }
    .pricing-card.featured { transform: none; }
    .pricing-pack-main { flex-direction: column; }
    .pricing-pack-price-block { text-align: left; }
    .app-body { flex-direction: column; }
    .sidebar { width: 100%; flex-direction: row; flex-wrap: wrap; align-items: center; }
    .sidebar-nav { flex-direction: row; flex-wrap: wrap; }
}
