/* ============================================
   DESIGN SYSTEM — Orçamentos Pro
   Modern SaaS Admin Dashboard 2026
   ============================================ */

/* ---------- Google Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ============================================
   CSS CUSTOM PROPERTIES (Light Theme)
   ============================================ */
:root {
  /* — Typography — */
  --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-mono: 'SF Mono', 'Fira Code', 'Fira Mono', monospace;

  /* — Primary Palette (Indigo) — */
  --primary-50: #eef2ff;
  --primary-100: #e0e7ff;
  --primary-200: #c7d2fe;
  --primary-300: #a5b4fc;
  --primary-400: #818cf8;
  --primary-500: #6366f1;
  --primary-600: #4f46e5;
  --primary-700: #4338ca;
  --primary-800: #3730a3;
  --primary-900: #312e81;

  /* — Neutral Palette — */
  --gray-25: #fcfcfd;
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;
  --gray-950: #030712;

  /* — Status Colors — */
  --success-50: #ecfdf5; --success-100: #d1fae5; --success-500: #10b981; --success-600: #059669; --success-700: #047857;
  --warning-50: #fffbeb; --warning-100: #fef3c7; --warning-500: #f59e0b; --warning-600: #d97706; --warning-700: #b45309;
  --danger-50: #fef2f2;  --danger-100: #fee2e2;  --danger-500: #ef4444;  --danger-600: #dc2626;  --danger-700: #b91c1c;
  --info-50: #eff6ff;    --info-100: #dbeafe;    --info-500: #3b82f6;    --info-600: #2563eb;    --info-700: #1d4ed8;

  /* — Semantic Tokens (Light) — */
  --bg-body: var(--gray-50);
  --bg-surface: #ffffff;
  --bg-surface-secondary: var(--gray-50);
  --bg-surface-tertiary: var(--gray-100);
  --bg-surface-hover: var(--gray-50);
  --bg-sidebar: #0f172a;
  --bg-sidebar-hover: rgba(255,255,255,0.06);
  --bg-sidebar-active: rgba(99,102,241,0.15);
  --bg-topbar: rgba(255,255,255,0.82);
  --bg-input: #ffffff;
  --bg-overlay: rgba(0,0,0,0.45);

  --text-primary: var(--gray-900);
  --text-secondary: var(--gray-600);
  --text-tertiary: var(--gray-400);
  --text-inverse: #ffffff;
  --text-sidebar: rgba(255,255,255,0.6);
  --text-sidebar-active: #ffffff;
  --text-link: var(--primary-600);

  --border-default: var(--gray-200);
  --border-light: var(--gray-100);
  --border-input: var(--gray-300);
  --border-focus: var(--primary-500);

  --shadow-xs: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.03);
  --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.07), 0 2px 4px -2px rgba(0,0,0,0.04);
  --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.07), 0 4px 6px -4px rgba(0,0,0,0.03);
  --shadow-xl: 0 20px 25px -5px rgba(0,0,0,0.08), 0 8px 10px -6px rgba(0,0,0,0.03);
  --shadow-card: 0 1px 3px rgba(0,0,0,0.05), 0 1px 2px rgba(0,0,0,0.02);
  --shadow-card-hover: 0 10px 30px rgba(0,0,0,0.08);

  /* — Layout — */
  --sidebar-width: 260px;
  --sidebar-collapsed-width: 72px;
  --topbar-height: 64px;
  --content-max: 1440px;

  /* — Radius — */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 20px;
  --radius-full: 9999px;

  /* — Transitions — */
  --transition-fast: 150ms cubic-bezier(0.4,0,0.2,1);
  --transition-base: 200ms cubic-bezier(0.4,0,0.2,1);
  --transition-slow: 300ms cubic-bezier(0.4,0,0.2,1);
  --transition-spring: 400ms cubic-bezier(0.34,1.56,0.64,1);
}

/* ============================================
   DARK THEME
   ============================================ */
[data-theme="dark"] {
  --bg-body: #0c0f1a;
  --bg-surface: #151929;
  --bg-surface-secondary: #1a1f33;
  --bg-surface-tertiary: #1f2541;
  --bg-surface-hover: #1a1f33;
  --bg-sidebar: #0a0d19;
  --bg-sidebar-hover: rgba(255,255,255,0.05);
  --bg-sidebar-active: rgba(99,102,241,0.2);
  --bg-topbar: rgba(21,25,41,0.88);
  --bg-input: #1a1f33;
  --bg-overlay: rgba(0,0,0,0.7);
  --text-primary: #f1f5f9;
  --text-secondary: #94a3b8;
  --text-tertiary: #64748b;
  --text-link: var(--primary-400);
  --border-default: #1e293b;
  --border-light: rgba(255,255,255,0.06);
  --border-input: #2d3654;
  --border-focus: var(--primary-400);
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.2);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.3);
  --shadow-lg: 0 10px 15px rgba(0,0,0,0.3);
  --shadow-xl: 0 20px 25px rgba(0,0,0,0.4);
  --shadow-card: 0 1px 3px rgba(0,0,0,0.2);
  --shadow-card-hover: 0 10px 30px rgba(0,0,0,0.35);
  --gray-50: #1a1f33;
  --gray-100: #1f2541;
  --gray-200: #2d3654;
}

/* ============================================
   BASE
   ============================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-family);font-size:14px;line-height:1.6;color:var(--text-primary);background:var(--bg-body);margin:0;padding:0;min-height:100vh;transition:background var(--transition-slow),color var(--transition-slow)}
::selection{background:var(--primary-200);color:var(--primary-900)}
[data-theme="dark"] ::selection{background:var(--primary-800);color:#fff}

h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;color:var(--text-primary);margin-top:0}
h1{font-size:1.75rem;letter-spacing:-0.025em}
h2{font-size:1.5rem;letter-spacing:-0.02em}
h3{font-size:1.25rem;letter-spacing:-0.015em}
h4{font-size:1.1rem}
h5{font-size:1rem}
h6{font-size:0.8125rem;text-transform:uppercase;letter-spacing:0.05em;font-weight:600}

a{color:var(--text-link);text-decoration:none;transition:color var(--transition-fast)}
a:hover{color:var(--primary-700)}
[data-theme="dark"] a:hover{color:var(--primary-300)}
p{color:var(--text-secondary);margin-bottom:1rem}
small{font-size:0.8125rem}
code{font-family:var(--font-mono);font-size:0.85em;padding:2px 6px;background:var(--bg-surface-tertiary);border-radius:var(--radius-sm);color:var(--danger-600)}
[data-theme="dark"] code{color:#f87171}
hr{border:0;border-top:1px solid var(--border-light);margin:1.5rem 0}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}
[data-theme="dark"]::-webkit-scrollbar-thumb{background:#334155}

/* ============================================
   LAYOUT — App Shell
   ============================================ */
.app-wrapper{display:flex;min-height:100vh}
.main-area{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--transition-slow)}
.sidebar-collapsed .main-area{margin-left:var(--sidebar-collapsed-width)}
.main-content{flex:1;padding:2rem;padding-top:calc(var(--topbar-height) + 2rem);max-width:var(--content-max);width:100%;margin:0 auto}

/* ============================================
   SIDEBAR
   ============================================ */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-sidebar);z-index:1040;display:flex;flex-direction:column;transition:width var(--transition-slow),transform var(--transition-slow);overflow:hidden;border-right:1px solid rgba(255,255,255,0.05)}
.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width)}

.sidebar-brand{display:flex;align-items:center;padding:0 1.25rem;height:var(--topbar-height);border-bottom:1px solid rgba(255,255,255,0.06);flex-shrink:0}
.sidebar-brand .brand-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(99,102,241,0.35)}
.sidebar-brand .brand-text{margin-left:12px;white-space:nowrap;overflow:hidden;transition:opacity var(--transition-base)}
.sidebar-brand .brand-name{font-size:1rem;font-weight:700;color:#fff;letter-spacing:-0.01em;line-height:1.2}
.sidebar-brand .brand-subtitle{font-size:0.6rem;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:0.1em;font-weight:500}
.sidebar-collapsed .sidebar .brand-text{opacity:0;pointer-events:none}

.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:1rem 0.75rem;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.08) transparent}
.sidebar-nav::-webkit-scrollbar{width:3px}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:3px}

.sidebar-section{margin-bottom:1.5rem}
.sidebar-section-label{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;color:rgba(255,255,255,0.25);padding:0 0.75rem;margin-bottom:0.5rem;font-weight:600;white-space:nowrap;overflow:hidden}
.sidebar-collapsed .sidebar-section-label{text-align:center;font-size:0}
.sidebar-collapsed .sidebar-section-label::before{content:'···';font-size:0.6rem;color:rgba(255,255,255,0.15)}

.sidebar-link{display:flex;align-items:center;padding:0.5rem 0.75rem;border-radius:var(--radius-md);color:var(--text-sidebar);font-size:0.8125rem;font-weight:500;transition:all var(--transition-fast);margin-bottom:1px;position:relative;text-decoration:none;white-space:nowrap}
.sidebar-link:hover{color:rgba(255,255,255,0.9);background:var(--bg-sidebar-hover)}
.sidebar-link.active{color:var(--text-sidebar-active);background:var(--bg-sidebar-active)}
.sidebar-link.active::before{content:'';position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--primary-400);border-radius:0 3px 3px 0}
.sidebar-link i{font-size:1.1rem;width:22px;text-align:center;flex-shrink:0;opacity:0.65;transition:opacity var(--transition-fast)}
.sidebar-link:hover i,.sidebar-link.active i{opacity:1}
.sidebar-link span{margin-left:12px;transition:opacity var(--transition-base)}
.sidebar-collapsed .sidebar-link span{opacity:0;pointer-events:none;width:0}
.sidebar-collapsed .sidebar-link{justify-content:center;padding:0.5rem}
.sidebar-collapsed .sidebar-link.active::before{left:0}

.sidebar-footer{padding:1rem 0.75rem;border-top:1px solid rgba(255,255,255,0.06);flex-shrink:0}

.sidebar-overlay{display:none;position:fixed;inset:0;background:var(--bg-overlay);z-index:1035;opacity:0;transition:opacity var(--transition-slow)}
.sidebar-overlay.show{display:block;opacity:1}

/* ============================================
   TOPBAR
   ============================================ */
.topbar{position:fixed;top:0;right:0;left:var(--sidebar-width);height:var(--topbar-height);background:var(--bg-topbar);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-light);z-index:1030;display:flex;align-items:center;padding:0 2rem;transition:left var(--transition-slow),background var(--transition-slow)}
.sidebar-collapsed .topbar{left:var(--sidebar-collapsed-width)}

.topbar-left{display:flex;align-items:center;gap:1rem;flex:1}
.topbar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:1.15rem}
.topbar-toggle:hover{background:var(--bg-surface-tertiary);color:var(--text-primary)}

.topbar-breadcrumb{display:flex;align-items:center;gap:0.5rem;font-size:0.8125rem}
.topbar-breadcrumb a{color:var(--text-tertiary)}
.topbar-breadcrumb a:hover{color:var(--text-primary)}
.topbar-breadcrumb .separator{color:var(--text-tertiary);font-size:0.7rem}
.topbar-breadcrumb .current{color:var(--text-primary);font-weight:600}

.topbar-search{position:relative;max-width:300px;flex:1;margin-left:1rem}
.topbar-search input{width:100%;height:38px;padding:0 1rem 0 36px;border:1px solid var(--border-default);border-radius:var(--radius-full);background:var(--bg-surface-secondary);color:var(--text-primary);font-size:0.8125rem;font-family:var(--font-family);transition:all var(--transition-fast)}
.topbar-search input::placeholder{color:var(--text-tertiary)}
.topbar-search input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px rgba(99,102,241,0.12);background:var(--bg-surface)}
.topbar-search i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);font-size:0.85rem;pointer-events:none}

.topbar-right{display:flex;align-items:center;gap:0.25rem}
.topbar-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:1.1rem;position:relative}
.topbar-btn:hover{background:var(--bg-surface-tertiary);color:var(--text-primary)}
.topbar-btn .badge-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;background:var(--danger-500);border-radius:50%;border:2px solid var(--bg-topbar)}
.topbar-divider{width:1px;height:28px;background:var(--border-default);margin:0 0.5rem}

.topbar-user{display:flex;align-items:center;gap:0.75rem;padding:4px 8px 4px 4px;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast);border:none;background:transparent;text-decoration:none}
.topbar-user:hover{background:var(--bg-surface-tertiary)}
.topbar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;flex-shrink:0}
.topbar-user-info{text-align:left;line-height:1.3}
.topbar-user-name{font-size:0.8125rem;font-weight:600;color:var(--text-primary)}
.topbar-user-role{font-size:0.675rem;color:var(--text-tertiary)}

/* ============================================
   PAGE HEADER
   ============================================ */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}
.page-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 4px;letter-spacing:-0.025em;display:flex;align-items:center;gap:0.75rem}
.page-title i{font-size:1.2rem;color:var(--primary-500)}
.page-subtitle{font-size:0.8125rem;color:var(--text-secondary);margin:0}
.page-header-actions{display:flex;gap:0.75rem;align-items:center;flex-wrap:wrap}

/* ============================================
   CARDS
   ============================================ */
.card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-base),transform var(--transition-base),background var(--transition-slow);overflow:hidden}
.card-hover:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-light);background:transparent;display:flex;align-items:center;justify-content:space-between}
.card-header h5,.card-header h6{margin:0;font-size:0.9375rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:0.5rem}
.card-header h5 i,.card-header h6 i{color:var(--text-tertiary);font-size:1rem}
.card-body{padding:1.5rem}
.card-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-light);background:var(--bg-surface-secondary)}

/* ============================================
   STAT CARDS
   ============================================ */
.stat-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card);transition:all var(--transition-base);position:relative;overflow:hidden}
.stat-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
.stat-card-inner{display:flex;justify-content:space-between;align-items:flex-start}
.stat-card-label{font-size:0.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:0.5rem;text-transform:uppercase;letter-spacing:0.04em}
.stat-card-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1.1;letter-spacing:-0.03em}
.stat-card-change{font-size:0.7rem;font-weight:600;margin-top:0.5rem;display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-full)}
.stat-card-change.up{color:var(--success-700);background:var(--success-50)}
.stat-card-change.down{color:var(--danger-700);background:var(--danger-50)}
.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.stat-card-icon.primary{background:var(--primary-50);color:var(--primary-600)}
.stat-card-icon.success{background:var(--success-50);color:var(--success-600)}
.stat-card-icon.warning{background:var(--warning-50);color:var(--warning-600)}
.stat-card-icon.danger{background:var(--danger-50);color:var(--danger-600)}
.stat-card-icon.info{background:var(--info-50);color:var(--info-600)}

[data-theme="dark"] .stat-card-icon.primary{background:rgba(99,102,241,0.12)}
[data-theme="dark"] .stat-card-icon.success{background:rgba(16,185,129,0.12)}
[data-theme="dark"] .stat-card-icon.warning{background:rgba(245,158,11,0.12)}
[data-theme="dark"] .stat-card-icon.danger{background:rgba(239,68,68,0.12)}
[data-theme="dark"] .stat-card-icon.info{background:rgba(59,130,246,0.12)}
[data-theme="dark"] .stat-card-change.up{background:rgba(16,185,129,0.12);color:#34d399}
[data-theme="dark"] .stat-card-change.down{background:rgba(239,68,68,0.12);color:#f87171}

/* ============================================
   BUTTONS
   ============================================ */
.btn{font-family:var(--font-family);font-weight:600;font-size:0.8125rem;border-radius:var(--radius-md);padding:8px 16px;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:0.5rem;border:1px solid transparent;cursor:pointer;line-height:1.5}
.btn:active{transform:scale(0.97)}
.btn-sm{font-size:0.75rem;padding:5px 12px;border-radius:var(--radius-sm)}
.btn-lg{font-size:0.9375rem;padding:12px 24px}
.btn-primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600);box-shadow:0 1px 2px rgba(79,70,229,0.15)}
.btn-primary:hover{background:var(--primary-700);border-color:var(--primary-700);color:#fff;box-shadow:0 4px 12px rgba(79,70,229,0.25);transform:translateY(-1px)}
.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-default)}
.btn-secondary:hover{background:var(--bg-surface-secondary);color:var(--text-primary);border-color:var(--border-input)}
.btn-success{background:var(--success-600);color:#fff;border-color:var(--success-600)}
.btn-success:hover{background:var(--success-700);border-color:var(--success-700);color:#fff}
.btn-warning{background:var(--warning-500);color:#fff;border-color:var(--warning-500)}
.btn-warning:hover{background:var(--warning-600);border-color:var(--warning-600);color:#fff}
.btn-danger{background:var(--danger-600);color:#fff;border-color:var(--danger-600)}
.btn-danger:hover{background:var(--danger-700);border-color:var(--danger-700);color:#fff}
.btn-info{background:var(--info-600);color:#fff;border-color:var(--info-600)}
.btn-info:hover{background:var(--info-700);border-color:var(--info-700);color:#fff}
.btn-outline-primary{background:transparent;color:var(--primary-600);border-color:var(--primary-200)}
.btn-outline-primary:hover{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-300)}
.btn-outline-secondary{background:transparent;color:var(--text-secondary);border-color:var(--border-default)}
.btn-outline-secondary:hover{background:var(--bg-surface-secondary);color:var(--text-primary)}
.btn-outline-danger{background:transparent;color:var(--danger-600);border-color:var(--danger-200)}
.btn-outline-danger:hover{background:var(--danger-50);color:var(--danger-700)}
.btn-outline-success{background:transparent;color:var(--success-600);border-color:var(--success-200)}
.btn-outline-success:hover{background:var(--success-50);color:var(--success-700)}
.btn-outline-warning{background:transparent;color:var(--warning-600);border-color:var(--warning-200)}
.btn-outline-warning:hover{background:var(--warning-50);color:var(--warning-700)}
.btn-outline-info{background:transparent;color:var(--info-600);border-color:var(--info-200)}
.btn-outline-info:hover{background:var(--info-50);color:var(--info-700)}
.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:6px 10px}
.btn-ghost:hover{background:var(--bg-surface-tertiary);color:var(--text-primary)}

[data-theme="dark"] .btn-outline-primary{border-color:rgba(99,102,241,0.3)}
[data-theme="dark"] .btn-outline-primary:hover{background:rgba(99,102,241,0.1)}
[data-theme="dark"] .btn-outline-danger{border-color:rgba(239,68,68,0.3)}
[data-theme="dark"] .btn-outline-danger:hover{background:rgba(239,68,68,0.1)}
[data-theme="dark"] .btn-outline-success{border-color:rgba(16,185,129,0.3)}
[data-theme="dark"] .btn-outline-success:hover{background:rgba(16,185,129,0.1)}
[data-theme="dark"] .btn-outline-warning{border-color:rgba(245,158,11,0.3)}
[data-theme="dark"] .btn-outline-warning:hover{background:rgba(245,158,11,0.1)}
[data-theme="dark"] .btn-outline-info{border-color:rgba(59,130,246,0.3)}
[data-theme="dark"] .btn-outline-info:hover{background:rgba(59,130,246,0.1)}
[data-theme="dark"] .btn-secondary{background:var(--bg-surface-secondary);border-color:var(--border-default)}

/* ============================================
   FORMS
   ============================================ */
.form-label{font-size:0.8125rem;font-weight:600;color:var(--text-primary);margin-bottom:0.375rem}
.form-control,.form-select{font-family:var(--font-family);font-size:0.875rem;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--radius-md);padding:9px 14px;transition:all var(--transition-fast);line-height:1.5}
.form-control:focus,.form-select:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px rgba(99,102,241,0.1);outline:none;background:var(--bg-surface)}
.form-control::placeholder{color:var(--text-tertiary)}
.form-control-sm{font-size:0.8125rem;padding:6px 10px}
.form-control-lg{font-size:1rem;padding:12px 18px}
textarea.form-control{resize:vertical;min-height:80px}
.form-text{font-size:0.75rem;color:var(--text-tertiary);margin-top:4px}
.form-check-input{border-color:var(--border-input);transition:all var(--transition-fast)}
.form-check-input:checked{background-color:var(--primary-600);border-color:var(--primary-600)}
.form-check-input:focus{box-shadow:0 0 0 3px rgba(99,102,241,0.1);border-color:var(--primary-400)}
.form-switch .form-check-input{height:1.25em;width:2.25em}
.form-control-color{padding:4px;height:38px;width:48px}
.input-group .form-control{border-radius:0}
.input-group .form-control:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}
.input-group .form-control:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}
.input-group-text{background:var(--bg-surface-secondary);border-color:var(--border-input);color:var(--text-secondary);font-size:0.8125rem}

/* ============================================
   TABLES
   ============================================ */
.table-container{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}
.table{color:var(--text-primary);margin:0;font-size:0.875rem}
.table>:not(caption)>*>*{background:transparent;color:var(--text-primary);padding:0.875rem 1.25rem;border-bottom:1px solid var(--border-light);vertical-align:middle}
.table>thead>tr>th{font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--text-secondary);background:var(--bg-surface-secondary);border-bottom:1px solid var(--border-default);white-space:nowrap;padding:0.75rem 1.25rem}
.table>tbody>tr{transition:background var(--transition-fast)}
.table>tbody>tr:hover>td{background:var(--bg-surface-hover)}
.table>tbody>tr:last-child>td{border-bottom:none}
.table-light>th{background:var(--bg-surface-secondary)!important;color:var(--text-secondary)!important}
.table-striped>tbody>tr:nth-of-type(odd)>td{background:var(--bg-surface-secondary)}

/* ============================================
   BADGES
   ============================================ */
.badge{font-family:var(--font-family);font-size:0.675rem;font-weight:600;padding:3px 8px;border-radius:var(--radius-full);letter-spacing:0.02em;display:inline-flex;align-items:center;gap:4px;line-height:1.4}
.badge i{font-size:0.6rem}

.badge-status{font-size:0.7rem;font-weight:600;padding:4px 12px;border-radius:var(--radius-full);display:inline-flex;align-items:center;gap:5px}
.badge-status::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0}
.badge-status.status-aprovado,.badge-status.status-concluida,.badge-status.status-completed{background:var(--success-50);color:var(--success-700)}
.badge-status.status-aprovado::before,.badge-status.status-concluida::before,.badge-status.status-completed::before{background:var(--success-500)}
.badge-status.status-pendente,.badge-status.status-em-aberto,.badge-status.status-enviado{background:var(--warning-50);color:var(--warning-700)}
.badge-status.status-pendente::before,.badge-status.status-em-aberto::before,.badge-status.status-enviado::before{background:var(--warning-500)}
.badge-status.status-rejeitado,.badge-status.status-cancelada{background:var(--danger-50);color:var(--danger-700)}
.badge-status.status-rejeitado::before,.badge-status.status-cancelada::before{background:var(--danger-500)}
.badge-status.status-rascunho{background:var(--gray-100);color:var(--gray-600)}
.badge-status.status-rascunho::before{background:var(--gray-400)}
.badge-status.status-em-andamento,.badge-status.status-em-execucao{background:var(--info-50);color:var(--info-700)}
.badge-status.status-em-andamento::before,.badge-status.status-em-execucao::before{background:var(--info-500)}
.badge-status.status-agendada{background:var(--primary-50);color:var(--primary-700)}
.badge-status.status-agendada::before{background:var(--primary-500)}

[data-theme="dark"] .badge-status.status-aprovado,[data-theme="dark"] .badge-status.status-concluida,[data-theme="dark"] .badge-status.status-completed{background:rgba(16,185,129,0.12);color:#34d399}
[data-theme="dark"] .badge-status.status-pendente,[data-theme="dark"] .badge-status.status-em-aberto,[data-theme="dark"] .badge-status.status-enviado{background:rgba(245,158,11,0.12);color:#fbbf24}
[data-theme="dark"] .badge-status.status-rejeitado,[data-theme="dark"] .badge-status.status-cancelada{background:rgba(239,68,68,0.12);color:#f87171}
[data-theme="dark"] .badge-status.status-rascunho{background:rgba(100,116,139,0.15);color:#94a3b8}
[data-theme="dark"] .badge-status.status-em-andamento,[data-theme="dark"] .badge-status.status-em-execucao{background:rgba(59,130,246,0.12);color:#60a5fa}
[data-theme="dark"] .badge-status.status-agendada{background:rgba(99,102,241,0.12);color:#a5b4fc}

[data-theme="dark"] .bg-primary{background-color:var(--primary-600)!important}
[data-theme="dark"] .bg-success{background-color:var(--success-600)!important}
[data-theme="dark"] .bg-warning{background-color:var(--warning-600)!important;color:#fff!important}
[data-theme="dark"] .bg-danger{background-color:var(--danger-600)!important}
[data-theme="dark"] .bg-info{background-color:var(--info-600)!important}
[data-theme="dark"] .bg-secondary{background-color:#475569!important}
[data-theme="dark"] .bg-light{background-color:var(--bg-surface-secondary)!important}

/* ============================================
   NAV TABS
   ============================================ */
.nav-tabs{border-bottom:2px solid var(--border-light);gap:4px}
.nav-tabs .nav-link{font-family:var(--font-family);font-size:0.8125rem;font-weight:600;color:var(--text-secondary);padding:0.75rem 1.25rem;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:0;transition:all var(--transition-fast);display:flex;align-items:center;gap:0.5rem}
.nav-tabs .nav-link:hover{color:var(--text-primary);border-bottom-color:var(--gray-300)}
.nav-tabs .nav-link.active{color:var(--primary-600);border-bottom-color:var(--primary-600);background:transparent}
[data-theme="dark"] .nav-tabs .nav-link.active{color:var(--primary-400);border-bottom-color:var(--primary-400)}
.nav-tabs .nav-link .badge{font-size:0.6rem;padding:2px 6px}

.nav-pills .nav-link{font-family:var(--font-family);font-size:0.8125rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-md);padding:0.5rem 1rem;transition:all var(--transition-fast)}
.nav-pills .nav-link.active{background:var(--primary-600);color:#fff}

/* ============================================
   MODALS
   ============================================ */
.modal-content{border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);background:var(--bg-surface);overflow:hidden}
.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-light)}
.modal-title{font-size:1.0625rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:0.5rem}
.modal-body{padding:1.5rem}
.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-light)}
.btn-close{opacity:0.4;transition:opacity var(--transition-fast)}
.btn-close:hover{opacity:1}
[data-theme="dark"] .btn-close{filter:invert(1)}
[data-theme="dark"] .modal-backdrop.show{opacity:0.7}

/* ============================================
   ALERTS
   ============================================ */
.alert{border-radius:var(--radius-lg);border:1px solid;font-size:0.875rem;padding:1rem 1.25rem}
.alert-info{background:var(--info-50);border-color:var(--info-100);color:var(--info-700)}
.alert-success{background:var(--success-50);border-color:var(--success-100);color:var(--success-700)}
.alert-warning{background:var(--warning-50);border-color:var(--warning-100);color:var(--warning-700)}
.alert-danger{background:var(--danger-50);border-color:var(--danger-100);color:var(--danger-700)}
[data-theme="dark"] .alert-info{background:rgba(59,130,246,0.08);border-color:rgba(59,130,246,0.15);color:#93c5fd}
[data-theme="dark"] .alert-success{background:rgba(16,185,129,0.08);border-color:rgba(16,185,129,0.15);color:#6ee7b7}
[data-theme="dark"] .alert-warning{background:rgba(245,158,11,0.08);border-color:rgba(245,158,11,0.15);color:#fcd34d}
[data-theme="dark"] .alert-danger{background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.15);color:#fca5a5}

/* ============================================
   DROPDOWN
   ============================================ */
.dropdown-menu{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:0.5rem;font-size:0.8125rem;min-width:180px;animation:dropdownIn var(--transition-fast)}
@keyframes dropdownIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.dropdown-item{padding:0.5rem 0.75rem;border-radius:var(--radius-sm);color:var(--text-primary);font-weight:500;transition:background var(--transition-fast);display:flex;align-items:center;gap:0.5rem}
.dropdown-item:hover{background:var(--bg-surface-tertiary);color:var(--text-primary)}
.dropdown-item i{color:var(--text-tertiary);width:18px;text-align:center}
.dropdown-divider{border-color:var(--border-light);margin:0.25rem 0}

/* ============================================
   ACCORDION
   ============================================ */
.accordion-item{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg)!important;margin-bottom:0.5rem;overflow:hidden}
.accordion-button{font-family:var(--font-family);font-weight:600;font-size:0.875rem;color:var(--text-primary);background:var(--bg-surface);padding:1rem 1.25rem}
.accordion-button:not(.collapsed){background:var(--bg-surface-secondary);color:var(--primary-600);box-shadow:none}
.accordion-button:focus{box-shadow:0 0 0 3px rgba(99,102,241,0.1)}
[data-theme="dark"] .accordion-button{background:var(--bg-surface);color:var(--text-primary)}
[data-theme="dark"] .accordion-button:not(.collapsed){background:var(--bg-surface-secondary);color:var(--primary-400)}
[data-theme="dark"] .accordion-button::after{filter:invert(1)}
.accordion-body{padding:1.25rem}

/* ============================================
   LIST GROUP
   ============================================ */
.list-group-item{background:var(--bg-surface);border-color:var(--border-light);color:var(--text-primary);padding:1rem 1.25rem;transition:background var(--transition-fast)}
.list-group-item-action:hover{background:var(--bg-surface-hover);color:var(--text-primary)}
.list-group-item.active{background:var(--primary-600);border-color:var(--primary-600)}

/* ============================================
   TOAST
   ============================================ */
.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:0.75rem}
.custom-toast{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:1rem 1.25rem;display:flex;align-items:center;gap:0.75rem;min-width:300px;max-width:420px;animation:toastIn 0.35s var(--transition-spring);font-size:0.875rem;font-weight:500;color:var(--text-primary)}
.custom-toast.toast-exit{animation:toastOut 0.2s ease-in forwards}
.custom-toast .toast-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:0.85rem;background:var(--success-50);color:var(--success-600)}
[data-theme="dark"] .custom-toast .toast-icon{background:rgba(16,185,129,0.12);color:#34d399}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes toastOut{from{transform:translateX(0);opacity:1}to{transform:translateX(120%);opacity:0}}

/* ============================================
   TIMELINE
   ============================================ */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:'';position:absolute;left:9px;top:4px;bottom:4px;width:2px;background:var(--border-default);border-radius:2px}
.timeline-item{position:relative;padding-bottom:1.5rem}
.timeline-item:last-child{padding-bottom:0}
.timeline-dot{position:absolute;left:-28px;top:2px;width:20px;height:20px;border-radius:50%;background:var(--bg-surface);border:2px solid var(--border-default);display:flex;align-items:center;justify-content:center;z-index:1}
.timeline-dot i{font-size:0.5rem}
.timeline-dot.primary{border-color:var(--primary-500);color:var(--primary-500)}
.timeline-dot.success{border-color:var(--success-500);color:var(--success-500)}
.timeline-dot.warning{border-color:var(--warning-500);color:var(--warning-500)}
.timeline-dot.danger{border-color:var(--danger-500);color:var(--danger-500)}
.timeline-dot.info{border-color:var(--info-500);color:var(--info-500)}
.timeline-title{font-size:0.8125rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}
.timeline-desc{font-size:0.75rem;color:var(--text-tertiary)}

/* ============================================
   WIZARD
   ============================================ */
.wizard-steps{display:flex;justify-content:center;margin-bottom:2rem;position:relative}
.wizard-step{display:flex;flex-direction:column;align-items:center;position:relative;flex:1;max-width:200px}
.wizard-step:not(:last-child)::after{content:'';position:absolute;top:18px;left:calc(50% + 22px);width:calc(100% - 44px);height:2px;background:var(--border-default);transition:background var(--transition-base)}
.wizard-step.completed:not(:last-child)::after{background:var(--primary-500)}
.wizard-step-number{width:36px;height:36px;border-radius:50%;background:var(--bg-surface-tertiary);border:2px solid var(--border-default);color:var(--text-tertiary);font-size:0.8125rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);position:relative;z-index:1}
.wizard-step.active .wizard-step-number{background:var(--primary-600);border-color:var(--primary-600);color:#fff;box-shadow:0 0 0 4px rgba(99,102,241,0.12)}
.wizard-step.completed .wizard-step-number{background:var(--primary-600);border-color:var(--primary-600);color:#fff}
.wizard-step-label{font-size:0.7rem;font-weight:600;color:var(--text-tertiary);margin-top:0.5rem;text-align:center;transition:color var(--transition-base)}
.wizard-step.active .wizard-step-label{color:var(--primary-600)}
.wizard-step.completed .wizard-step-label{color:var(--text-secondary)}

/* ============================================
   CALENDAR
   ============================================ */
.calendar-grid{border:1px solid var(--border-light);border-radius:var(--radius-lg);overflow:hidden}
.calendar-grid table{width:100%;border-collapse:collapse}
.calendar-grid th{text-align:center;padding:0.75rem;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--text-secondary);background:var(--bg-surface-secondary);border-bottom:1px solid var(--border-light)}
.calendar-grid td{padding:0.5rem;border:1px solid var(--border-light);vertical-align:top;height:110px;width:14.28%;transition:background var(--transition-fast)}
.calendar-grid td:hover{background:var(--bg-surface-hover)}
.calendar-grid td.today{background:var(--primary-50)}
[data-theme="dark"] .calendar-grid td.today{background:rgba(99,102,241,0.06)}
.calendar-grid .day-number{font-size:0.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:4px}
.calendar-grid td.today .day-number{background:var(--primary-600);color:#fff;width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}
.calendar-event{font-size:0.625rem;font-weight:500;padding:2px 6px;border-radius:var(--radius-sm);margin-bottom:2px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;transition:opacity var(--transition-fast)}
.calendar-event:hover{opacity:0.75}
.calendar-event.type-visita{background:var(--info-50);color:var(--info-700);border-left:2px solid var(--info-500)}
.calendar-event.type-instalacao{background:var(--success-50);color:var(--success-700);border-left:2px solid var(--success-500)}
.calendar-event.type-vencimento{background:var(--danger-50);color:var(--danger-700);border-left:2px solid var(--danger-500)}
.calendar-event.type-reuniao{background:var(--warning-50);color:var(--warning-700);border-left:2px solid var(--warning-500)}
.calendar-event.type-manutencao{background:var(--primary-50);color:var(--primary-700);border-left:2px solid var(--primary-500)}
[data-theme="dark"] .calendar-event.type-visita{background:rgba(59,130,246,0.1);color:#93c5fd}
[data-theme="dark"] .calendar-event.type-instalacao{background:rgba(16,185,129,0.1);color:#6ee7b7}
[data-theme="dark"] .calendar-event.type-vencimento{background:rgba(239,68,68,0.1);color:#fca5a5}
[data-theme="dark"] .calendar-event.type-reuniao{background:rgba(245,158,11,0.1);color:#fcd34d}
[data-theme="dark"] .calendar-event.type-manutencao{background:rgba(99,102,241,0.1);color:#c7d2fe}
.calendar-grid td.other-month{background:var(--bg-surface-secondary);opacity:0.4}

/* ============================================
   CHARTS
   ============================================ */
.chart-bar-group{display:flex;align-items:flex-end;gap:0.75rem;height:200px;padding:0 1rem}
.chart-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:0.5rem;height:100%;justify-content:flex-end}
.chart-bar{width:100%;max-width:48px;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:height 0.6s cubic-bezier(0.34,1.56,0.64,1);position:relative;cursor:pointer;min-height:4px}
.chart-bar:hover{filter:brightness(1.1)}
.chart-bar.bar-primary{background:linear-gradient(180deg,var(--primary-400),var(--primary-600))}
.chart-bar.bar-success{background:linear-gradient(180deg,#34d399,var(--success-600))}
.chart-bar.bar-warning{background:linear-gradient(180deg,#fbbf24,var(--warning-600))}
.chart-bar.bar-danger{background:linear-gradient(180deg,#f87171,var(--danger-600))}
.chart-bar.bar-info{background:linear-gradient(180deg,#60a5fa,var(--info-600))}
.chart-bar-value{font-size:0.7rem;font-weight:700;color:var(--text-primary)}
.chart-bar-label{font-size:0.625rem;font-weight:500;color:var(--text-tertiary);text-align:center;white-space:nowrap}
.progress{height:8px;border-radius:var(--radius-full);background:var(--bg-surface-tertiary);overflow:hidden}
.progress-bar{border-radius:var(--radius-full);transition:width 0.6s cubic-bezier(0.34,1.56,0.64,1)}

/* ============================================
   FILTER BAR
   ============================================ */
.filter-bar{display:flex;gap:0.75rem;align-items:center;flex-wrap:wrap;padding:1rem 1.25rem;background:var(--bg-surface-secondary);border-bottom:1px solid var(--border-light);border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.filter-bar .form-control,.filter-bar .form-select{font-size:0.8125rem;height:36px;padding:4px 12px;border-radius:var(--radius-md);max-width:200px}
.filter-bar .form-control:first-child{max-width:260px}

/* ============================================
   EMPTY STATE
   ============================================ */
.empty-state{text-align:center;padding:3rem 1.5rem}
.empty-state-icon{font-size:3rem;color:var(--text-tertiary);margin-bottom:1rem;opacity:0.4}
.empty-state-title{font-size:1.125rem;font-weight:600;color:var(--text-secondary);margin-bottom:0.5rem}
.empty-state-text{font-size:0.875rem;color:var(--text-tertiary);max-width:400px;margin:0 auto 1.25rem}

/* ============================================
   DETAIL INFO
   ============================================ */
.detail-grid{display:grid;gap:1rem}
.detail-grid.cols-2{grid-template-columns:1fr 1fr}
.detail-grid.cols-3{grid-template-columns:1fr 1fr 1fr}
.detail-grid.cols-4{grid-template-columns:1fr 1fr 1fr 1fr}
.detail-label{font-size:0.675rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-tertiary);margin-bottom:4px}
.detail-value{font-size:0.9375rem;font-weight:600;color:var(--text-primary)}

/* ============================================
   PROPOSAL (public)
   ============================================ */
.proposal-page{background:var(--bg-body);min-height:100vh}
.proposal-container{max-width:800px;margin:0 auto;padding:2rem 1rem}
.proposal-card{background:var(--bg-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.proposal-header{background:linear-gradient(135deg,var(--primary-700),var(--primary-900));padding:2.5rem 2rem;color:#fff;text-align:center}
.proposal-header h1{color:#fff;font-size:1.5rem;margin-bottom:0.5rem}
.proposal-header p{color:rgba(255,255,255,0.7);margin:0}
.proposal-body{padding:2rem}
.proposal-section{margin-bottom:2rem}
.proposal-section-title{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-tertiary);margin-bottom:1rem;padding-bottom:0.5rem;border-bottom:2px solid var(--border-light)}
.proposal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.proposal-info-item label{font-size:0.7rem;color:var(--text-tertiary);display:block;margin-bottom:2px}
.proposal-info-item span{font-size:0.9375rem;font-weight:600;color:var(--text-primary)}
.proposal-total{background:var(--bg-surface-secondary);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;margin-top:1.5rem}
.proposal-total-label{font-size:0.8125rem;color:var(--text-secondary);margin-bottom:4px}
.proposal-total-value{font-size:2rem;font-weight:800;color:var(--primary-600);letter-spacing:-0.03em}
.proposal-actions{display:flex;gap:0.75rem;justify-content:center;padding:1.5rem 2rem;border-top:1px solid var(--border-light)}

/* ============================================
   CONTRACT (print)
   ============================================ */
.contract-page{max-width:800px;margin:0 auto;background:var(--bg-surface);padding:2.5rem}
.contract-page h1{text-align:center;font-size:1.5rem;margin-bottom:2rem;text-transform:uppercase;letter-spacing:0.03em}
.contract-page h3{font-size:1rem;margin-top:1.5rem;margin-bottom:0.75rem}
.contract-page p{text-align:justify;line-height:1.8}
.contract-signatures{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-top:3rem;text-align:center}
.contract-signature-line{border-top:1px solid var(--text-primary);padding-top:0.5rem;font-size:0.875rem}

/* ============================================
   QUICK LINKS
   ============================================ */
.quick-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border-light);background:var(--bg-surface);transition:all var(--transition-fast);text-decoration:none;color:var(--text-primary)}
.quick-link:hover{border-color:var(--primary-200);box-shadow:var(--shadow-md);transform:translateY(-2px);color:var(--text-primary)}
[data-theme="dark"] .quick-link:hover{border-color:rgba(99,102,241,0.3)}
.quick-link-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.quick-link-text{font-size:0.875rem;font-weight:600;line-height:1.3}
.quick-link-desc{font-size:0.7rem;color:var(--text-tertiary);font-weight:400}

/* ============================================
   UTILITIES
   ============================================ */
.text-primary{color:var(--primary-600)!important}
.text-success{color:var(--success-600)!important}
.text-warning{color:var(--warning-600)!important}
.text-danger{color:var(--danger-600)!important}
.text-info{color:var(--info-600)!important}
.text-muted{color:var(--text-secondary)!important}
[data-theme="dark"] .text-primary{color:var(--primary-400)!important}
[data-theme="dark"] .text-success{color:#34d399!important}
[data-theme="dark"] .text-warning{color:#fbbf24!important}
[data-theme="dark"] .text-danger{color:#f87171!important}
[data-theme="dark"] .text-info{color:#60a5fa!important}
.bg-surface{background:var(--bg-surface)!important}
.bg-surface-secondary{background:var(--bg-surface-secondary)!important}
[data-theme="dark"] .bg-light{background:var(--bg-surface-secondary)!important}
[data-theme="dark"] .bg-opacity-10{opacity:1!important}
.border-light{border-color:var(--border-light)!important}
[data-theme="dark"] .border{border-color:var(--border-default)!important}
.rounded-lg{border-radius:var(--radius-lg)}
.rounded-xl{border-radius:var(--radius-xl)}
.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.fw-800{font-weight:800}
.fs-xs{font-size:0.675rem}.fs-sm{font-size:0.8125rem}.fs-md{font-size:0.875rem}
.separator{height:1px;background:var(--border-light);margin:1.5rem 0}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
.animate-in{animation:fadeInUp 0.4s ease-out both}
.animate-delay-1{animation-delay:.05s}.animate-delay-2{animation-delay:.1s}.animate-delay-3{animation-delay:.15s}.animate-delay-4{animation-delay:.2s}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1199.98px){.main-content{padding:1.5rem;padding-top:calc(var(--topbar-height) + 1.5rem)}}
@media(max-width:991.98px){
  .sidebar{transform:translateX(-100%);width:var(--sidebar-width);box-shadow:var(--shadow-xl)}
  .sidebar.show{transform:translateX(0)}
  .sidebar-collapsed .sidebar{width:var(--sidebar-width)}
  .main-area{margin-left:0!important}
  .topbar{left:0!important}
  .detail-grid.cols-3,.detail-grid.cols-4{grid-template-columns:1fr 1fr}
  .proposal-info-grid{grid-template-columns:1fr}
  .calendar-grid td{height:80px}
  .contract-signatures{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:767.98px){
  .main-content{padding:1rem;padding-top:calc(var(--topbar-height) + 1rem)}
  .topbar{padding:0 1rem}
  .topbar-search,.topbar-user-info{display:none}
  .page-header{flex-direction:column;gap:0.75rem}
  .filter-bar{flex-direction:column}
  .filter-bar .form-control,.filter-bar .form-select{max-width:100%}
  .detail-grid.cols-2,.detail-grid.cols-3,.detail-grid.cols-4{grid-template-columns:1fr}
  .wizard-step-label{font-size:0.6rem}
  .stat-card-value{font-size:1.5rem}
  .proposal-body,.proposal-actions{padding:1.25rem}
  .proposal-actions{flex-direction:column}
  .calendar-grid td{height:60px;font-size:0.7rem}
  .calendar-event{font-size:0.55rem;padding:1px 4px}
}
@media(max-width:575.98px){
  .page-title{font-size:1.25rem}
  .card-body{padding:1rem}
  .card-header{padding:1rem}
  .topbar-breadcrumb{display:none}
}

/* ============================================
   PRINT
   ============================================ */
@media print{
  .sidebar,.topbar,.sidebar-overlay,.topbar-toggle,.toast-container,.filter-bar{display:none!important}
  .main-area{margin-left:0!important}
  .main-content{padding:0!important;max-width:100%}
  body{background:#fff;color:#000}
  .card{box-shadow:none;border:1px solid #ddd}
  .stat-card{break-inside:avoid}
  @page{margin:2cm}
}
