:root{--bg: #f4f6f9;--surface: #ffffff;--surface-soft: #f9fafb;--text: #111827;--text-muted: #6b7280;--border: #e5e7eb;--primary: #0f4c81;--primary-strong: #0b3b63;--danger: #b42318;--danger-soft: #fef3f2;--warning-soft: #fff7e6;--warning-text: #8a5b00;--error-soft: #fef3f2;--error-text: #b42318;--success-soft: #ecfdf3;--success-text: #027a48;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .05);--shadow-md: 0 8px 20px rgba(16, 24, 40, .08);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--sidebar-w: 220px}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;font-family:Segoe UI,Helvetica Neue,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:20;box-shadow:var(--shadow-sm)}.sidebar-brand{padding:16px 14px;border-bottom:1px solid var(--border)}.sidebar-brand-text{font-size:.95rem;font-weight:700;color:#243b53}.sidebar-nav{flex:1;padding:8px 0;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:block;width:100%;text-align:left;padding:10px 14px;border:none;background:none;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-muted);transition:all .12s ease}.sidebar-link:hover{background:var(--surface-soft);color:var(--text)}.sidebar-link.active{background:#eff8ff;color:var(--primary);border-right:3px solid var(--primary)}.sidebar-footer{padding:12px 14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sidebar-user{display:flex;flex-direction:column}.sidebar-user-name{font-size:.86rem;font-weight:700;color:#101828}.sidebar-user-role{font-size:.76rem;color:#667085;text-transform:uppercase}.sidebar-logout{font-size:.82rem}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh}a{color:inherit;text-decoration:none}.page{max-width:min(1760px,calc(1120px + 20vw));margin:0 auto;padding:24px 16px 32px}.auth-topbar{margin-bottom:14px;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.auth-topbar-title{margin:0;font-size:.95rem;font-weight:700;color:#243b53}.auth-topbar-right{display:flex;align-items:center;gap:10px}.profile-pill{border:1px solid var(--border);border-radius:999px;padding:7px 12px;display:inline-flex;align-items:center;gap:8px;background:#fff}.profile-name{font-size:.86rem;font-weight:700;color:#101828}.profile-role{font-size:.78rem;color:#667085;border-left:1px solid #d0d5dd;padding-left:8px;text-transform:uppercase}.page-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px}.page-title{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:.2px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.section{padding:18px}.btn{border:none;border-radius:var(--radius-sm);padding:10px 14px;font-weight:600;font-size:.94rem;cursor:pointer;transition:all .12s ease}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-strong)}.btn-outline{background:#fff;color:var(--text);border:1px solid var(--border)}.btn-outline:hover{background:var(--surface-soft)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-danger{color:var(--danger);border-color:#fecdca;background:#fff}.field-label{display:block;margin-bottom:8px;font-size:.86rem;font-weight:600;color:#344054}.input,.select,.textarea{width:100%;border:1px solid #d0d5dd;border-radius:var(--radius-sm);background:#fff;color:var(--text);padding:10px 12px;font-size:.94rem;line-height:1.4;transition:border-color .12s ease,box-shadow .12s ease}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:#84add1;box-shadow:0 0 0 3px #0f4c8121}.input.error{border-color:#fda29b}.helper-error{margin:6px 0 0;color:var(--danger);font-size:.82rem}.form-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px}.col-12{grid-column:span 12}.col-6{grid-column:span 6}.col-4{grid-column:span 4}.col-8{grid-column:span 8}.notice{margin-bottom:14px;padding:10px 12px;border-radius:var(--radius-sm);font-size:.9rem;border:1px solid}.notice-error{color:var(--danger);background:var(--danger-soft);border-color:#fecdca}.notice-success{color:var(--success-text);background:var(--success-soft);border-color:#abefc6}.filters{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.report-grid .btn{width:100%;justify-content:center}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.9rem}.table th,.table td{border-bottom:1px solid var(--border);padding:12px;text-align:left;vertical-align:middle}.table th{color:var(--text-muted);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700}.table tr:hover td{background:#fbfcfe}.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:.76rem;font-weight:700}.badge-warning{background:var(--warning-soft);color:var(--warning-text)}.badge-success{background:var(--success-soft);color:var(--success-text)}.badge-info{background:#eff8ff;color:#175cd3}.badge-error{background:var(--error-soft);color:var(--error-text)}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--border)}.timeline-item{position:relative;padding-bottom:20px}.timeline-item:before{content:"";position:absolute;left:-20px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--primary);border:2px solid var(--surface);box-shadow:0 0 0 2px var(--primary)}.timeline-item.end:before{background:var(--danger);box-shadow:0 0 0 2px var(--danger)}.timeline-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.timeline-date{font-size:.82rem;font-weight:700;color:var(--text)}.timeline-sequence{font-size:.72rem;color:var(--text-muted);background:var(--surface-soft);border:1px solid var(--border);padding:1px 6px;border-radius:999px}.timeline-body{margin-top:4px}.timeline-meta{margin:0 0 4px;font-size:.84rem;color:var(--text-muted)}.timeline-discussion{margin:6px 0 0;font-size:.88rem;color:var(--text)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.3);z-index:30}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:100vw;background:var(--surface);box-shadow:var(--shadow-md);z-index:31;overflow-y:auto;padding:20px}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.drawer-title{margin:0;font-size:1.15rem;font-weight:700}.sales-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.sales-legend-item{display:flex;align-items:center;gap:4px;font-size:.82rem}.sales-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.customer-search-dropdown{position:relative}.customer-search-input{padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23667085' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.customer-search-options{position:absolute;z-index:20;left:0;right:0;margin-top:4px;max-height:260px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.customer-search-option{padding:10px 12px;cursor:pointer;transition:background .1s ease}.customer-search-option.active,.customer-search-option.selected{background:#eff8ff}.customer-search-name{font-weight:600;font-size:.9rem}.customer-search-address{font-size:.78rem;color:var(--text-muted)}.customer-search-new-btn{display:flex;align-items:center;gap:4px;width:100%;padding:10px 12px;border:none;background:var(--surface-soft);cursor:pointer;font-weight:600;font-size:.9rem;color:var(--primary);text-align:left}.customer-search-new-btn:hover{background:#eff8ff}.customer-search-loading,.customer-search-empty{padding:10px 12px;font-size:.82rem;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);z-index:40;display:grid;place-items:center}.modal{background:var(--surface);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:440px;box-shadow:var(--shadow-md)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-muted)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.confirm-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);z-index:40;display:grid;place-items:center}.confirm-dialog{background:var(--surface);border-radius:var(--radius-lg);padding:24px;max-width:400px;width:90%;box-shadow:var(--shadow-md)}.confirm-dialog h3{margin:0 0 8px}.confirm-dialog p{margin:0 0 16px;color:var(--text-muted);font-size:.9rem}.confirm-dialog-actions{display:flex;gap:8px;justify-content:flex-end}.row-actions{display:flex;gap:8px}.mobile-cards{display:none;gap:10px;flex-direction:column}.mobile-card{padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);background:#fff}.mobile-card h4{margin:0 0 8px;font-size:1rem}.mobile-meta{margin:0 0 8px;color:var(--text-muted);font-size:.86rem}.login-page{min-height:100vh;display:grid;place-items:center;padding:16px}.login-card{width:100%;max-width:420px;padding:28px}.login-title{margin:0;font-size:1.55rem}.login-subtitle{margin:6px 0 18px;color:var(--text-muted);font-size:.92rem}.stack{display:grid;gap:12px}.placeholder{border:1px dashed #bfd1e5;border-radius:var(--radius-sm);background:#f8fbff;padding:12px;color:#37526e;font-size:.88rem}.upload-box{border:1px dashed #bfd1e5;border-radius:var(--radius-md);background:#f8fbff;padding:14px}.upload-help{margin-top:8px;color:var(--text-muted);font-size:.82rem}.dashboard-sheet-wrap{display:grid;gap:22px}.dashboard-sheet{width:100%;border-collapse:collapse;border:1px solid #2f2f2f}.dashboard-sheet th,.dashboard-sheet td{border:1px solid #2f2f2f;padding:10px 12px;text-align:center;font-size:1.05rem;font-weight:700}.dashboard-sheet thead th{background:#355e21;color:#fff}.dashboard-sheet tbody td:first-child,.dashboard-sheet .status-label{background:#a7c995}.dashboard-sheet .total-row td{background:#efd075}.dashboard-sheet-followup td.followup-on-track{background:#d7efcf}.dashboard-sheet-followup td.followup-deadline{background:#ff0000;color:#fff}.dashboard-sheet-followup td.followup-alert{background:#ffff33}.dashboard-top-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.dashboard-top-stat{border:1px solid #d0d5dd;border-radius:var(--radius-sm);padding:12px;background:#f8fbff;display:flex;flex-direction:column;gap:6px}.dashboard-top-label{font-size:.78rem;color:#344054;font-weight:700;letter-spacing:.04em}.dashboard-top-stat strong{font-size:1.4rem;color:#0f4c81}.account-sheet{width:100%;border-collapse:collapse;border:1px solid #2f2f2f}.account-sheet th,.account-sheet td{border:1px solid #2f2f2f;padding:8px 10px;text-align:center;font-size:.95rem}.account-sheet th{background:#355e21;color:#fff;font-weight:700}.account-sheet td:first-child{text-align:left;font-weight:600}@media (max-width: 700px){.dashboard-sheet th,.dashboard-sheet td{padding:8px;font-size:.88rem}.dashboard-top-stats{grid-template-columns:1fr}}@media (max-width: 900px){.filters{grid-template-columns:repeat(2,minmax(0,1fr))}.col-6,.col-4,.col-8{grid-column:span 12}}@media (max-width: 700px){:root{--sidebar-w: 0px}.sidebar{display:none}.page{padding:16px 12px 24px}.section{padding:14px}.table-wrap{display:none}.mobile-cards{display:flex}.page-header{align-items:flex-start;flex-direction:column}.filters{grid-template-columns:1fr}.row-actions{flex-wrap:wrap}.drawer{width:100vw}}
