/* FactoViso Phase 20 app.css */
*{box-sizing:border-box}:root{--primary-dark:#0A1E4D;--primary:#1565D8;--primary-light:#2FA8FF;--bg:#F7F9FC;--text:#0F172A;--muted:#64748B;--border:#E5EAF2;--shadow:0 16px 48px rgba(10,30,77,.10)}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}code{background:#F1F5F9;padding:3px 6px;border-radius:7px;color:var(--primary-dark)}.auth-page{min-height:100vh;display:grid;place-items:center;padding:32px;background:radial-gradient(circle at top left,rgba(47,168,255,.22),transparent 35%),linear-gradient(180deg,#fff,var(--bg))}.auth-card{width:min(520px,100%);background:#fff;border:1px solid var(--border);border-radius:28px;box-shadow:var(--shadow);padding:34px}.auth-logo{display:flex;align-items:center;gap:12px;color:var(--primary-dark);font-weight:800;font-size:22px;margin-bottom:28px}.auth-logo img{width:42px;height:42px;border-radius:12px}.auth-card h1{margin:0 0 10px;font-size:34px;color:var(--primary-dark)}.auth-card p{color:var(--muted);line-height:1.6}.app-layout{display:grid;grid-template-columns:270px 1fr;min-height:100vh}.sidebar{background:var(--primary-dark);color:#fff;padding:24px}.sidebar-brand{display:flex;align-items:center;gap:12px;font-size:22px;font-weight:900;margin-bottom:34px}.sidebar-brand img{width:42px;height:42px;border-radius:12px;background:#fff}.sidebar-nav{display:grid;gap:8px}.sidebar-nav a{color:rgba(255,255,255,.72);padding:13px 14px;border-radius:14px;font-weight:700}.sidebar-nav a:hover,.sidebar-nav a.active{color:#fff;background:rgba(255,255,255,.12)}.main{padding:34px}.topbar{display:flex;justify-content:space-between;align-items:start;margin-bottom:28px}.topbar h1{margin:0 0 6px;font-size:36px;color:var(--primary-dark);letter-spacing:-.04em}.topbar p{margin:0;color:var(--muted)}.top-actions{display:flex;gap:12px;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;cursor:pointer;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;padding:14px 20px;border-radius:14px;font-weight:800;font-size:15px;box-shadow:0 12px 30px rgba(21,101,216,.22)}.btn-secondary{background:#fff;color:var(--primary-dark);border:1px solid var(--border);box-shadow:none}.form{display:grid;gap:16px;margin-top:26px}.inline-form{display:inline}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}label{display:grid;gap:8px;font-size:14px;color:#334155;font-weight:700}input,textarea,select{width:100%;border:1px solid var(--border);border-radius:14px;padding:14px 15px;font-size:15px;outline:none;font-family:inherit;background:#fff}textarea{resize:vertical}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(21,101,216,.10)}.panel{background:#fff;border:1px solid var(--border);border-radius:24px;padding:24px;box-shadow:0 10px 34px rgba(10,30,77,.06)}.panel-head{margin-bottom:20px}.panel-head h2{margin:0;color:var(--primary-dark)}.dashboard-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:22px}.dashboard-pro-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:24px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}.stat-card,.hero-card{background:#fff;border:1px solid var(--border);border-radius:24px;padding:24px;box-shadow:0 10px 34px rgba(10,30,77,.06)}.stat-card span,.hero-card span{color:var(--muted);font-weight:700;font-size:14px}.stat-card strong,.hero-card strong{display:block;margin-top:12px;font-size:30px;color:var(--primary-dark)}.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}.hero-card{background:linear-gradient(135deg,#fff,#F8FBFF)}.hero-card small{color:var(--muted);font-weight:700}.table{width:100%;border-collapse:collapse}.table th{text-align:left;color:var(--muted);font-size:13px;padding:12px;border-bottom:1px solid var(--border)}.table td{padding:14px 12px;border-bottom:1px solid var(--border)}.status{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(21,101,216,.10);color:var(--primary);font-weight:800;font-size:12px}.status-paid{background:#DCFCE7;color:#166534}.status-open{background:#DBEAFE;color:#1D4ED8}.status-overdue{background:#FEE2E2;color:#991B1B}.status-cancelled{background:#E5E7EB;color:#374151}.actions{white-space:nowrap}.actions a,.text-link{color:var(--primary);font-weight:800;margin-right:12px}.alert{padding:14px 16px;border-radius:14px;margin-bottom:18px}.alert-error{color:#991B1B;background:#FEE2E2;border:1px solid #FECACA}.alert-success{color:#166534;background:#DCFCE7;border:1px solid #BBF7D0}.empty{color:var(--muted)}.mt{margin-top:24px}.quick-actions{display:grid;gap:12px}.quick-actions a{padding:15px 16px;border:1px solid var(--border);border-radius:16px;color:var(--primary-dark);font-weight:800;background:#F8FAFC}.row-between{display:flex;align-items:center;justify-content:space-between;gap:16px}.mini-badge{display:inline-flex;padding:7px 11px;border-radius:999px;background:rgba(21,101,216,.1);color:var(--primary);font-size:12px;font-weight:900}.info-list{display:grid;gap:12px}.info-list div{padding:14px;border:1px solid var(--border);border-radius:18px;background:#F8FAFC}.info-list p{color:var(--muted);margin:6px 0 0}.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.price-card{background:#fff;border:1px solid var(--border);border-radius:24px;padding:26px;box-shadow:0 10px 34px rgba(10,30,77,.06)}.price-card h3{margin:0;color:var(--primary-dark);font-size:24px}.price-card p{color:var(--muted)}.price-card strong{display:block;color:var(--primary-dark);font-size:38px;margin:16px 0}.price-card ul{color:var(--muted);line-height:2}.raw-text{white-space:pre-wrap;background:#0F172A;color:#E2E8F0;padding:18px;border-radius:18px;max-height:520px;overflow:auto;line-height:1.6}.items-box{border:1px solid var(--border);border-radius:22px;padding:18px;background:#F8FAFC}.items-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.item-row{display:grid;grid-template-columns:2fr .7fr .8fr .9fr .8fr 40px;gap:12px;align-items:end;margin-bottom:12px}.remove-btn{height:46px;border:0;border-radius:14px;cursor:pointer;font-size:24px;color:#991B1B;background:#FEE2E2}.document-preview{background:#fff;border:1px solid var(--border);border-radius:28px;padding:42px;box-shadow:var(--shadow)}.doc-head{display:flex;justify-content:space-between;gap:24px;margin-bottom:50px}.doc-head h2{margin:0 0 8px;color:var(--primary-dark);font-size:30px}.doc-meta{display:grid;gap:8px;text-align:right;color:var(--muted)}.doc-company,.doc-address{display:grid;gap:6px;margin-bottom:28px;color:#334155}.doc-note{margin-top:28px;padding:18px;border-radius:18px;background:#F8FAFC;border:1px solid var(--border)}.totals{width:min(360px,100%);margin-left:auto;margin-top:24px;display:grid;gap:10px}.totals div{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.totals .grand{font-size:20px;color:var(--primary-dark);border-bottom:0}.bar-chart{height:230px;display:grid;grid-template-columns:repeat(12,1fr);gap:10px;align-items:end}.bar-item{height:100%;display:grid;grid-template-rows:1fr auto;gap:8px;text-align:center;color:var(--muted);font-size:12px;font-weight:800}.bar-track{height:100%;background:#F1F5F9;border-radius:999px;display:flex;align-items:end;overflow:hidden}.bar-fill{width:100%;border-radius:999px;background:linear-gradient(180deg,var(--primary-light),var(--primary));min-height:6px}@media print{.sidebar,.topbar,.btn{display:none!important}.app-layout{display:block}.main{padding:0}body{background:#fff}.document-preview{border:0;box-shadow:none;border-radius:0}}@media(max-width:1200px){.hero-stats{grid-template-columns:repeat(2,1fr)}.dashboard-pro-grid,.pricing{grid-template-columns:1fr}}@media(max-width:1100px){.grid-3,.item-row{grid-template-columns:1fr}}@media(max-width:900px){.app-layout{grid-template-columns:1fr}.stat-grid,.dashboard-grid,.grid-2,.hero-stats{grid-template-columns:1fr}}
