/* ================================================
   SNEL ID v2.5 — Complete Styles
   ================================================ */
:root {
    --primary: #0f4c81;
    --primary-light: #1a6bb5;
    --primary-dark: #0a3560;
    --accent: #ef4444;
    --accent-light: #f87171;
    --success: #10b981;
    --success-light: #34d399;
    --warning: #f59e0b;
    --danger: #ef4444;
    --info: #3b82f6;
    --purple: #8b5cf6;
    --bg: #f0f4f8;
    --bg-card: #ffffff;
    --bg-sidebar: #0c2d4a;
    --bg-sidebar-hover: #11395e;
    --text: #1e293b;
    --text-secondary: #64748b;
    --text-light: #94a3b8;
    --text-sidebar: #cbd5e1;
    --border: #e2e8f0;
    --border-light: #f1f5f9;
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 6px rgba(0,0,0,0.07), 0 2px 4px rgba(0,0,0,0.06);
    --shadow-lg: 0 10px 15px rgba(0,0,0,0.1), 0 4px 6px rgba(0,0,0,0.05);
    --radius: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --sidebar-width: 260px;
    --sidebar-collapsed: 70px;
    --topbar-height: 64px;
    --transition: 0.25s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:15px;scroll-behavior:smooth;}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--text-light);border-radius:3px;}

/* ================================================
   LOGIN
   ================================================ */
.login-overlay{display:none;position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#0c2d4a 0%,#0f4c81 50%,#1a6bb5 100%);align-items:center;justify-content:center;}
.login-overlay.active{display:flex;}
.login-box{background:var(--bg-card);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);animation:fadeUp .4s ease-out;}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}
.login-header{text-align:center;margin-bottom:32px;}
.login-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.8rem;color:var(--warning);}
.login-header h1{font-size:1.8rem;color:var(--text);margin-bottom:4px;}
.login-header p{font-size:0.82rem;color:var(--text-secondary);}
.login-form{display:flex;flex-direction:column;gap:16px;}
.login-field{display:flex;flex-direction:column;gap:6px;}
.login-field label{font-size:0.82rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px;}
.login-field label i{color:var(--primary);}
.login-field select{padding:12px 14px;padding-right:36px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;background:var(--bg-card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='2' fill='none'/%3E%3C/svg%3E") no-repeat right 12px center;color:var(--text);transition:border-color var(--transition);min-height:48px;-webkit-appearance:none;appearance:none;}
.login-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,76,129,.1);}
.login-btn{width:100%;justify-content:center;margin-top:8px;}
.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;}
.login-btn:not(:disabled){cursor:pointer;}
.login-field input[type="email"],.login-field input[type="password"]{padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;color:var(--text);background:var(--bg-card);transition:border-color var(--transition);min-height:48px;width:100%;box-sizing:border-box;}
.login-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,76,129,.1);}
.login-error{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:var(--radius);font-size:.85rem;border:1px solid #fca5a5;}
.login-footer{text-align:center;margin-top:20px;font-size:.75rem;color:var(--text-light);}

/* ================================================
   APP SHELL & SIDEBAR
   ================================================ */
.app-shell{display:flex;min-height:100vh;min-height:100dvh;}
.sidebar{width:var(--sidebar-width);min-height:100vh;min-height:100dvh;background:var(--bg-sidebar);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:1000;transition:width var(--transition),transform var(--transition);overflow:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.sidebar.collapsed{width:var(--sidebar-collapsed);}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;opacity:0;transition:opacity .3s ease;-webkit-tap-highlight-color:transparent;touch-action:none;}
.sidebar-backdrop.active{display:block;opacity:1;}
.sidebar.collapsed{width:var(--sidebar-collapsed);}
.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:18px 16px;border-bottom:1px solid rgba(255,255,255,.08);}
.logo{display:flex;align-items:center;gap:10px;color:#fff;font-size:1.3rem;font-weight:700;white-space:nowrap;}
.logo i{font-size:1.5rem;color:var(--warning);min-width:24px;text-align:center;}
.sidebar.collapsed .logo span,.sidebar.collapsed .nav-item span,.sidebar.collapsed .agent-info span,.sidebar.collapsed .nav-section-label,.sidebar.collapsed .logout-btn span,.sidebar.collapsed .nav-badge{display:none;}
.sidebar-toggle{background:none;border:none;color:var(--text-sidebar);cursor:pointer;font-size:1rem;padding:4px;transition:transform var(--transition);}
.sidebar.collapsed .sidebar-toggle i{transform:rotate(180deg);}
.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;}
.nav-section-label{font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-light);padding:12px 16px 4px;font-weight:700;}
.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-sidebar);text-decoration:none;border-radius:var(--radius);transition:all var(--transition);white-space:nowrap;font-size:.9rem;position:relative;min-height:44px;-webkit-tap-highlight-color:transparent;}
.nav-item:hover{background:var(--bg-sidebar-hover);color:#fff;}
.nav-item.active{background:var(--primary);color:#fff;font-weight:600;}
.nav-item i{min-width:20px;text-align:center;font-size:1rem;}
.nav-badge{background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:10px;margin-left:auto;}
.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.08);}
.agent-info{display:flex;align-items:center;gap:8px;color:var(--text-sidebar);font-size:.82rem;margin-bottom:8px;}
.logout-btn{width:100%;justify-content:center;border-color:rgba(255,255,255,.15);color:var(--text-sidebar);min-height:44px;}
.logout-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(239,68,68,.08);}

/* ================================================
   MAIN CONTENT & TOPBAR
   ================================================ */
.main-content{flex:1;margin-left:var(--sidebar-width);transition:margin-left var(--transition);min-height:100vh;}
.sidebar.collapsed~.main-content{margin-left:var(--sidebar-collapsed);}
.topbar{height:var(--topbar-height);background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:500;box-shadow:var(--shadow-sm);}
.mobile-menu-btn{display:none;background:none;border:none;font-size:1.3rem;color:var(--text);cursor:pointer;padding:8px;min-width:44px;min-height:44px;-webkit-tap-highlight-color:transparent;}
.topbar-title{flex:1;}
.topbar-title h1{font-size:1.12rem;font-weight:700;}
.topbar-subtitle{font-size:.76rem;color:var(--text-secondary);}
.user-pill{display:flex;align-items:center;gap:6px;background:var(--border-light);padding:6px 14px;border-radius:20px;font-size:.82rem;font-weight:600;color:var(--text-secondary);}
.user-pill i{color:var(--primary);}
.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0;border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.1);transition:background .3s ease;}
.status-dot.online{background:#22c55e;}
.status-dot.offline{background:#ef4444;animation:pulse-offline 1.5s infinite;}@keyframes pulse-offline{0%,100%{box-shadow:0 0 0 1px rgba(0,0,0,.1);}50%{box-shadow:0 0 0 4px rgba(239,68,68,.3);}}

/* ================================================
   VIEWS
   ================================================ */
.view{display:none;padding:24px;}
.view.active{display:block;}

/* ================================================
   FICHE STATUS BAR
   ================================================ */
.fiche-status-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 20px;margin-bottom:20px;box-shadow:var(--shadow);}
.status-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.fiche-id-display{font-family:'Courier New',monospace;font-weight:800;font-size:1.05rem;color:var(--primary);background:rgba(15,76,129,.06);padding:4px 12px;border-radius:6px;}
.fiche-assigned-info{font-size:.82rem;color:var(--text-secondary);}
.status-actions{display:flex;gap:8px;flex-wrap:wrap;}

/* Status Badges */
.status-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;}
.status-created{background:#e0e7ff;color:#3730a3;}
.status-assigned{background:#fef3c7;color:#92400e;}
.status-in-progress{background:#dbeafe;color:#1e40af;}
.status-completed{background:#d1fae5;color:#065f46;}
.status-validated{background:#d1fae5;color:#065f46;border:1px solid #10b981;}
.status-rejected{background:#fee2e2;color:#991b1b;}

/* ================================================
   SUMMARY PANEL
   ================================================ */
.summary-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:14px;margin-bottom:20px;position:sticky;top:var(--topbar-height);z-index:400;background:var(--bg);padding:14px 0;}
.summary-card{display:flex;align-items:center;gap:12px;background:var(--bg-card);padding:14px;border-radius:var(--radius-lg);box-shadow:var(--shadow);border-left:4px solid var(--primary);transition:transform var(--transition);}
.summary-card:hover{transform:translateY(-2px);}
.summary-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;color:#fff;flex-shrink:0;}
.summary-icon.power{background:linear-gradient(135deg,var(--primary),var(--primary-light));}
.summary-icon.kw{background:linear-gradient(135deg,#2563eb,#60a5fa);}
.summary-icon.branch{background:linear-gradient(135deg,var(--success),#34d399);}
.summary-icon.tariff{background:linear-gradient(135deg,#8b5cf6,#a78bfa);}
.summary-icon.alerts{background:linear-gradient(135deg,var(--danger),#f87171);}
.alerts-card{border-left-color:var(--danger);}
.summary-data{display:flex;flex-direction:column;}
.summary-value{font-size:1.1rem;font-weight:800;color:var(--text);}
.summary-label{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;}

/* ================================================
   ALERTS ZONE
   ================================================ */
.alerts-zone{margin-bottom:20px;}
.alert-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius);margin-bottom:6px;font-size:.85rem;animation:slideIn .3s ease-out;}
@keyframes slideIn{from{opacity:0;transform:translateX(-20px);}to{opacity:1;transform:translateX(0);}}
.alert-item.warning{background:#fef3c7;border:1px solid #fcd34d;color:#92400e;}
.alert-item.danger{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;}
.alert-item.info{background:#dbeafe;border:1px solid #93c5fd;color:#1e40af;}
.alert-item i{font-size:1rem;}

/* ================================================
   FORM SECTIONS
   ================================================ */
.form-section{background:var(--bg-card);border-radius:var(--radius-xl);padding:24px;margin-bottom:20px;box-shadow:var(--shadow);border:1px solid var(--border);}
.section-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:14px;border-bottom:2px solid var(--border-light);}
.section-number{width:38px;height:38px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;flex-shrink:0;}
.section-header h2{font-size:1.05rem;font-weight:700;}
.section-header p{font-size:.78rem;color:var(--text-secondary);margin-top:1px;}
.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-group.full-width{grid-column:1/-1;}
.form-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:5px;}
.form-group label i{color:var(--primary);font-size:.82rem;}
.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.9rem;font-family:inherit;color:var(--text);background:var(--bg-card);transition:border-color var(--transition),box-shadow var(--transition);min-height:44px;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,76,129,.1);}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-light);}
.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:var(--border-light);cursor:not-allowed;opacity:.7;}
.field-hint{font-size:.75rem;padding:3px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px;margin-top:2px;}
.field-hint.suggestion{background:#dbeafe;color:#1e40af;}
.field-hint.warning{background:#fef3c7;color:#92400e;}

/* ================================================
   APPLIANCE
   ================================================ */
.quick-add-panel{background:var(--border-light);border-radius:var(--radius-lg);padding:16px;margin-bottom:18px;}
.quick-add-panel h4{font-size:.85rem;color:var(--text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.appliance-chips{display:flex;flex-wrap:wrap;gap:7px;}
.appliance-chip{display:inline-flex;align-items:center;gap:5px;padding:8px 13px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:18px;font-size:.8rem;cursor:pointer;transition:all var(--transition);user-select:none;white-space:nowrap;min-height:40px;-webkit-tap-highlight-color:transparent;}
.appliance-chip:hover{border-color:var(--primary);background:rgba(15,76,129,.04);transform:translateY(-1px);}
.appliance-chip.added{background:var(--primary);color:#fff;border-color:var(--primary);}
.appliance-chip i{font-size:.85rem;}
.appliance-table-wrapper{overflow-x:auto;margin-bottom:16px;}
.appliance-table{width:100%;border-collapse:collapse;}
.appliance-table th{background:var(--border-light);padding:10px 12px;font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;text-align:left;border-bottom:2px solid var(--border);}
.appliance-table td{padding:8px 12px;border-bottom:1px solid var(--border-light);font-size:.88rem;vertical-align:middle;}
.appliance-table tbody tr:hover{background:rgba(15,76,129,.02);}
.appliance-table .col-name{min-width:180px;}
.appliance-table .col-qty{width:80px;}
.appliance-table .col-pw{width:140px;}
.appliance-table .col-total{width:130px;font-weight:700;}
.appliance-table .col-action{width:40px;}
.appliance-table input[type="number"]{width:100%;padding:5px 8px;border:1.5px solid var(--border);border-radius:6px;font-size:.88rem;text-align:center;font-family:inherit;}
.appliance-table input[type="number"]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(15,76,129,.1);}
.total-row td{background:linear-gradient(135deg,rgba(15,76,129,.05),rgba(15,76,129,.02));font-size:.95rem;border-top:2px solid var(--primary);padding:12px;}
.total-row strong{color:var(--primary);}
.btn-remove-row{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:.95rem;padding:3px;border-radius:4px;transition:all var(--transition);}
.btn-remove-row:hover{color:var(--danger);background:#fee2e2;}
.manual-add{background:var(--border-light);border-radius:var(--radius);padding:14px;}
.manual-add h4{font-size:.82rem;color:var(--text-secondary);margin-bottom:8px;display:flex;align-items:center;gap:6px;}
.manual-add-row{display:flex;gap:8px;flex-wrap:wrap;}
.manual-add-row input{padding:7px 10px;border:1.5px solid var(--border);border-radius:6px;font-size:.85rem;font-family:inherit;}
.manual-add-row input:first-child{flex:2;min-width:140px;}
.manual-add-row input:nth-child(2){width:70px;}
.manual-add-row input:nth-child(3){width:110px;}

/* ================================================
   PHOTOS & SIGNATURE
   ================================================ */
.photo-upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:18px;transition:border-color var(--transition),background var(--transition);cursor:pointer;}
.photo-upload-zone.dragover{border-color:var(--primary);background:rgba(15,76,129,.03);}
.photo-placeholder{text-align:center;padding:24px;color:var(--text-light);}
.photo-placeholder i{font-size:2.2rem;margin-bottom:8px;}
.photo-placeholder p{font-size:.9rem;margin-bottom:3px;}
.photo-placeholder span{font-size:.75rem;}
.photo-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;}
.photo-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden;border:2px solid var(--border);}
.photo-thumb img{width:100%;height:100%;object-fit:cover;}
.photo-thumb .remove-photo{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.signature-box{border:2px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:#fff;}
.signature-box canvas{width:100%;height:200px;display:block;cursor:crosshair;touch-action:none;-ms-touch-action:none;}
.signature-actions{padding:6px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;}

/* ================================================
   BUTTONS
   ================================================ */
.btn{display:inline-flex;align-items:center;gap:7px;padding:7px 16px;border:none;border-radius:var(--radius);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap;min-height:44px;-webkit-tap-highlight-color:transparent;}
.btn-primary{background:var(--primary);color:#fff;}
.btn-primary:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn-success{background:var(--success);color:#fff;}
.btn-success:hover{background:#059669;transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn-accent{background:linear-gradient(135deg,var(--danger),#dc2626);color:#fff;}
.btn-accent:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text-secondary);}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:rgba(15,76,129,.03);}
.btn-add{background:var(--success);color:#fff;}
.btn-add:hover{background:#059669;}
.btn-sm{padding:5px 10px;font-size:.78rem;}
.btn-lg{padding:11px 22px;font-size:.92rem;}
.btn-danger{border-color:var(--danger);color:var(--danger);}
.btn-danger:hover{background:var(--danger);color:#fff;}
.btn-warning{background:var(--warning);color:#fff;}
.btn-warning:hover{background:#d97706;}
.form-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;padding:16px 0 36px;}

/* ================================================
   TOOLBAR & DATA TABLES
   ================================================ */
.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px;}
.search-box{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:7px 12px;flex:1;min-width:180px;max-width:360px;}
.search-box i{color:var(--text-light);}
.search-box input{border:none;outline:none;font-family:inherit;font-size:.88rem;flex:1;background:transparent;}
.filter-group{display:flex;gap:8px;flex-wrap:wrap;}
.toolbar-select{padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.82rem;font-family:inherit;background:var(--bg-card);}
.toolbar-stats{color:var(--text-secondary);font-size:.82rem;font-weight:600;}
.data-table-wrapper{overflow-x:auto;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);}
.data-table{width:100%;border-collapse:collapse;}
.data-table th{background:var(--border-light);padding:10px 12px;font-size:.73rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;text-align:left;border-bottom:2px solid var(--border);white-space:nowrap;}
.data-table td{padding:9px 12px;font-size:.85rem;border-bottom:1px solid var(--border-light);}
.data-table tbody tr:hover{background:rgba(15,76,129,.02);}
.data-table .badge{padding:3px 9px;border-radius:10px;font-size:.72rem;font-weight:600;white-space:nowrap;}
.badge-mono{background:#dbeafe;color:#1e40af;}
.badge-tri{background:#dcfce7;color:#166534;}
.badge-dom{background:#f3e8ff;color:#6b21a8;}
.badge-com{background:#fef3c7;color:#92400e;}
.db-action-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:6px 8px;border-radius:4px;transition:all var(--transition);font-size:.88rem;min-width:36px;min-height:36px;display:inline-flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;}
.db-action-btn:hover{color:var(--primary);background:rgba(15,76,129,.06);}
.db-action-btn.delete:hover{color:var(--danger);background:#fee2e2;}
.empty-state{text-align:center;padding:50px 20px;color:var(--text-light);}
.empty-state i{font-size:2.8rem;margin-bottom:10px;}
.empty-state p{font-size:1rem;margin-bottom:3px;color:var(--text-secondary);}
.empty-state span{font-size:.82rem;}

/* ================================================
   MISSIONS CARDS (Agent View)
   ================================================ */
.missions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;}
.mission-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition);}
.mission-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.mission-card-header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-light);}
.mission-card-header .mission-id{font-family:'Courier New',monospace;font-weight:800;font-size:.9rem;color:var(--primary);}
.mission-card-body{padding:14px 16px;}
.mission-card-body .mission-field{display:flex;justify-content:space-between;font-size:.82rem;padding:3px 0;}
.mission-field .lbl{color:var(--text-secondary);}
.mission-field .val{font-weight:600;}
.mission-card-footer{padding:10px 16px;border-top:1px solid var(--border-light);display:flex;gap:8px;justify-content:flex-end;}

/* ================================================
   DASHBOARD
   ================================================ */
.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;}
.dash-card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow);border:1px solid var(--border);padding:18px;}
.dash-card.wide{grid-column:span 2;}
.stat-card{display:flex;align-items:center;gap:14px;}
.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;flex-shrink:0;background:linear-gradient(135deg,var(--primary),var(--primary-light));}
.stat-icon.total-icon{background:linear-gradient(135deg,var(--primary),var(--primary-light));}
.stat-icon.pending-icon{background:linear-gradient(135deg,var(--warning),#fbbf24);}
.stat-icon.progress-icon{background:linear-gradient(135deg,var(--info),#60a5fa);}
.stat-icon.success-icon{background:linear-gradient(135deg,var(--success),#34d399);}
.stat-icon.validated-icon{background:linear-gradient(135deg,#8b5cf6,#a78bfa);}
.stat-icon.alert-icon{background:linear-gradient(135deg,var(--danger),#f87171);}
.stat-value{font-size:1.4rem;font-weight:800;color:var(--text);}
.stat-label{font-size:.73rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;}
.stat-info{display:flex;flex-direction:column;}
.chart-card h3{font-size:.85rem;font-weight:700;color:var(--text-secondary);margin-bottom:14px;display:flex;align-items:center;gap:7px;}
.chart-card canvas{width:100%!important;max-height:260px;}

/* ================================================
   ID FORMAT PREVIEW
   ================================================ */
.id-preview-box{background:var(--border-light);border-radius:var(--radius);padding:16px;margin-top:16px;text-align:center;}
.id-preview-box label{font-size:.8rem;color:var(--text-secondary);font-weight:600;display:block;margin-bottom:6px;}
.id-preview{font-family:'Courier New',monospace;font-size:1.5rem;font-weight:800;color:var(--primary);letter-spacing:1px;padding:10px;background:var(--bg-card);border-radius:var(--radius);border:2px dashed var(--primary);display:inline-block;}

/* ================================================
   MODAL
   ================================================ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px);}
.modal-overlay.active{display:flex;}
.modal{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:700px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modalIn .25s ease-out;}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(20px);}to{opacity:1;transform:scale(1) translateY(0);}}
.modal-header{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-header h3{font-size:1rem;display:flex;align-items:center;gap:7px;}
.modal-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-secondary);padding:4px;}
.modal-body{padding:22px;overflow-y:auto;flex:1;}
.modal-footer{padding:12px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;}
.modal-section{margin-bottom:16px;}
.modal-section h4{font-size:.82rem;color:var(--primary);font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--border-light);}
.modal-field{display:flex;justify-content:space-between;padding:4px 0;font-size:.85rem;}
.modal-field .label{color:var(--text-secondary);}
.modal-field .value{font-weight:600;color:var(--text);text-align:right;max-width:55%;}
/* Modal inline form */
.modal-form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;}
.modal-form-group label{font-size:.82rem;font-weight:600;color:var(--text-secondary);}
.modal-form-group input,.modal-form-group select,.modal-form-group textarea{padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.9rem;font-family:inherit;min-height:44px;}
.modal-form-group input:focus,.modal-form-group select:focus{outline:none;border-color:var(--primary);}

/* ================================================
   TOASTS
   ================================================ */
/* Offline banner */
.offline-banner{position:fixed;top:0;left:0;right:0;z-index:4000;background:linear-gradient(135deg,#f59e0b,#d97706);color:#78350f;padding:8px 16px;text-align:center;font-size:.85rem;font-weight:600;box-shadow:0 2px 8px rgba(0,0,0,.15);animation:slideDown .3s ease-out;}
.offline-banner-content{display:flex;align-items:center;justify-content:center;gap:10px;}
.offline-banner i{font-size:1rem;}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0;}to{transform:translateY(0);opacity:1;}}
@keyframes slideUp{from{transform:translateY(0);opacity:1;}to{transform:translateY(-100%);opacity:0;}}
.offline-banner.hiding{animation:slideUp .3s ease-in forwards;}
body.is-offline .topbar{top:36px;}
body.is-offline .sidebar{top:36px;height:calc(100vh - 36px);}

.toast-container{position:fixed;bottom:24px;right:24px;z-index:3000;display:flex;flex-direction:column;gap:8px;max-width:calc(100vw - 32px);}
.toast{display:flex;align-items:center;gap:10px;padding:11px 18px;border-radius:var(--radius);font-size:.85rem;font-weight:500;color:#fff;box-shadow:var(--shadow-lg);animation:toastIn .3s ease-out,toastOut .3s ease-in 2.7s forwards;max-width:400px;word-break:break-word;}
.toast.success{background:var(--success);}
.toast.error{background:var(--danger);}
.toast.warning{background:var(--warning);color:#78350f;}
.toast.info{background:var(--info);}
@keyframes toastIn{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}
@keyframes toastOut{from{opacity:1;}to{opacity:0;transform:translateY(10px);}}

/* ================================================
   RESPONSIVE
   ================================================ */

/* Safe area insets for notched devices (iPhone X+, Dynamic Island, etc.) */
@supports(padding: env(safe-area-inset-top)) {
    .topbar{padding-left:max(12px, env(safe-area-inset-left));padding-right:max(12px, env(safe-area-inset-right));}
    .sidebar{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);}
    .form-actions{padding-bottom:max(36px, env(safe-area-inset-bottom));}
    .toast-container{bottom:max(24px, env(safe-area-inset-bottom));right:max(12px, env(safe-area-inset-right));}
    .login-box{padding-bottom:max(40px, env(safe-area-inset-bottom));}
    .login-overlay{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);}
    .modal-overlay{padding-top:max(8px, env(safe-area-inset-top));padding-bottom:max(8px, env(safe-area-inset-bottom));}
    .offline-banner{padding-top:max(8px, env(safe-area-inset-top));}
}

/* Tablets & small laptops */
@media(max-width:1024px){
    .dashboard-grid{grid-template-columns:repeat(2,1fr);}
    .dash-card.wide{grid-column:span 2;}
    .missions-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));}
}

/* Tablets portrait & large phones */
@media(max-width:768px){
    .sidebar{transform:translateX(-100%);width:min(var(--sidebar-width), 85vw);}
    .sidebar.mobile-open{transform:translateX(0);box-shadow:4px 0 24px rgba(0,0,0,.25);}
    .main-content{margin-left:0!important;}
    .mobile-menu-btn{display:flex;align-items:center;justify-content:center;}
    .topbar{padding:0 12px;gap:8px;}
    .topbar-title h1{font-size:.95rem;}
    .topbar-subtitle{display:none;}
    .user-pill{padding:5px 10px;font-size:.76rem;}
    .user-pill .fa-circle-user{display:none;}
    .view{padding:12px;}
    .form-grid{grid-template-columns:1fr;}
    .summary-panel{grid-template-columns:repeat(2,1fr);gap:8px;position:relative;top:auto;}
    .form-section{padding:16px;}
    .section-header{flex-direction:row;gap:10px;}
    .section-header h2{font-size:.95rem;}
    .section-header p{font-size:.72rem;}
    .dashboard-grid{grid-template-columns:1fr;}
    .dash-card.wide{grid-column:span 1;}
    .manual-add-row{flex-direction:column;}
    .manual-add-row input:first-child,.manual-add-row input:nth-child(2),.manual-add-row input:nth-child(3){width:100%;}
    .toolbar{flex-direction:column;align-items:stretch;gap:8px;}
    .search-box{max-width:100%;}
    .missions-grid{grid-template-columns:1fr;}
    .filter-group{flex-direction:column;}
    /* Data tables: horizontal scroll with better swipe */
    .data-table-wrapper{border-radius:var(--radius);-webkit-overflow-scrolling:touch;overflow-x:auto;scroll-snap-type:x proximity;}
    .data-table th,.data-table td{padding:8px 8px;font-size:.78rem;}
    /* Scroll hint on data tables */
    .data-table-wrapper::after{content:'';position:sticky;right:0;top:0;bottom:0;width:24px;background:linear-gradient(to left,rgba(0,0,0,.06),transparent);pointer-events:none;display:block;float:right;margin-top:-100%;height:100%;}
    /* Modal: near-fullscreen on mobile */
    .modal-overlay{padding:8px;}
    .modal{max-width:100%;max-height:92vh;max-height:92dvh;border-radius:var(--radius-lg);}
    .modal-header{padding:12px 16px;}
    .modal-body{padding:14px 16px;-webkit-overflow-scrolling:touch;}
    .modal-footer{padding:10px 16px;flex-wrap:wrap;}
    .modal-footer .btn{flex:1;min-width:0;justify-content:center;}
    .modal-field{flex-direction:column;gap:2px;}
    .modal-field .value{text-align:left;max-width:100%;}
    /* Login */
    .login-overlay{padding:16px;}
    .login-box{padding:28px 20px;margin:0 auto;max-width:100%;width:100%;}
    .login-header h1{font-size:1.4rem;}
    .login-logo{width:52px;height:52px;font-size:1.5rem;}
    .login-btn{padding:14px 20px;font-size:1rem;}
    /* Signature */
    .signature-box canvas{height:160px;}
    /* Photo grid */
    .photo-preview-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));}
    /* Appliance chips */
    .appliance-chips{gap:6px;}
    .appliance-chip{padding:6px 10px;font-size:.75rem;min-height:36px;}
    /* Offline banner */
    .offline-banner{font-size:.78rem;padding:6px 10px;}
    .offline-banner-content{gap:6px;}
    /* Chart cards */
    .chart-card canvas{max-height:200px;}
    /* Status bar */
    .fiche-status-bar{flex-direction:column;align-items:stretch;padding:10px 14px;gap:8px;}
    .status-actions{display:flex;flex-wrap:wrap;gap:6px;}
    .status-actions .btn{flex:1;justify-content:center;min-width:0;}
    /* Improve touch scrolling */
    .sidebar-nav{-webkit-overflow-scrolling:touch;}
    .view{-webkit-overflow-scrolling:touch;}
}

/* Small phones (iPhone SE, Galaxy S, etc.) */
@media(max-width:480px){
    html{font-size:14px;}
    .summary-panel{grid-template-columns:1fr;}
    .summary-card{padding:10px 12px;}
    .summary-icon{width:36px;height:36px;font-size:1rem;}
    .summary-value{font-size:.95rem;}
    .form-actions{flex-direction:column;gap:8px;padding:16px 0 42px;}
    .form-actions .btn{width:100%;justify-content:center;}
    .stat-card{gap:10px;}
    .stat-icon{width:40px;height:40px;font-size:1.1rem;}
    .stat-value{font-size:1.15rem;}
    .stat-label{font-size:.68rem;}
    /* Appliance table compact */
    .appliance-table .col-name{min-width:100px;}
    .appliance-table th,.appliance-table td{padding:6px 6px;font-size:.78rem;}
    .appliance-table input[type="number"]{padding:6px 4px;font-size:.8rem;min-height:36px;}
    /* Hide unit power col on very small screens */
    .appliance-table .col-pw{min-width:80px;}
    /* Mission cards */
    .mission-card-header{padding:10px 12px;}
    .mission-card-body{padding:10px 12px;}
    .mission-card-footer{padding:8px 12px;flex-wrap:wrap;}
    .mission-card-footer .btn{flex:1;min-width:0;justify-content:center;}
    .mission-field{font-size:.78rem;}
    /* ID preview */
    .id-preview{font-size:1.1rem;padding:8px;}
    /* Buttons */
    .btn-lg{padding:12px 16px;font-size:.88rem;}
    /* Login compact */
    .login-box{padding:24px 18px;}
    .login-header{margin-bottom:20px;}
    /* Modal */
    .modal{max-height:95vh;max-height:95dvh;border-radius:var(--radius) var(--radius) 0 0;margin-top:auto;}
    .modal-overlay{align-items:flex-end;padding:0;}
    /* Topbar */
    .topbar{padding:0 8px;gap:6px;}
    .user-pill span{max-width:80px;overflow:hidden;text-overflow:ellipsis;}
}

/* Very small phones & Z Fold outer screen */
@media(max-width:320px){
    html{font-size:13px;}
    .view{padding:8px;}
    .form-section{padding:10px;margin-bottom:10px;}
    .section-number{width:28px;height:28px;font-size:.8rem;border-radius:7px;}
    .section-header h2{font-size:.85rem;}
    .section-header p{font-size:.68rem;}
    .topbar{height:48px;padding:0 6px;}
    .topbar-title h1{font-size:.82rem;}
    .user-pill{padding:3px 6px;font-size:.68rem;}
    .user-pill span{max-width:60px;}
    .login-overlay{padding:8px;}
    .login-header h1{font-size:1.15rem;}
    .login-header p{font-size:.72rem;}
    .login-logo{width:44px;height:44px;font-size:1.3rem;}
    .login-box{padding:18px 14px;}
    .login-field select{font-size:.88rem;padding:10px 12px;}
    .summary-card{padding:8px 10px;gap:8px;}
    .summary-icon{width:32px;height:32px;font-size:.9rem;}
    .summary-value{font-size:.88rem;}
    .summary-label{font-size:.62rem;}
    .signature-box canvas{height:130px;}
    .appliance-chip{padding:5px 8px;font-size:.68rem;min-height:32px;}
    .appliance-chips{gap:4px;}
    .photo-preview-grid{grid-template-columns:repeat(3,1fr);}
    .offline-banner{font-size:.72rem;padding:4px 8px;}
    /* Sidebar narrower */
    .sidebar{width:min(240px, 80vw);}
    /* Dashboard compact */
    .dash-card{padding:12px;}
    .stat-icon{width:36px;height:36px;font-size:1rem;}
    .stat-value{font-size:1rem;}
    /* Mission cards */
    .mission-card-footer{flex-direction:column;}
    .mission-card-footer .btn{width:100%;}
    /* Table actions inline */
    .data-table td:last-child{white-space:nowrap;}
}

/* Landscape phones */
@media(max-height:500px) and (orientation:landscape){
    .login-overlay{overflow-y:auto;align-items:flex-start;}
    .login-box{margin:12px auto;padding:20px;}
    .login-header{margin-bottom:12px;}
    .login-logo{width:36px;height:36px;font-size:1.1rem;margin-bottom:6px;}
    .login-header h1{font-size:1.1rem;}
    .login-header p{display:none;}
    .signature-box canvas{height:100px;}
    .modal{max-height:95vh;}
    .summary-panel{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));}
    .form-section{padding:12px;}
    .section-header{margin-bottom:12px;padding-bottom:8px;}
}

/* Foldable open (Z Fold inner screen ~885px when unfolded) */
@media(min-width:750px) and (max-width:920px){
    .dashboard-grid{grid-template-columns:repeat(2,1fr);}
    .form-grid{grid-template-columns:repeat(2,1fr);}
    .missions-grid{grid-template-columns:repeat(2,1fr);}
    .summary-panel{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));}
}

/* Z Fold unfolded in landscape (~1812px wide but short height) */
@media(min-width:900px) and (max-height:700px){
    .sidebar{width:220px;}
    .main-content{margin-left:220px;}
    .form-grid{grid-template-columns:repeat(3,1fr);}
    .summary-panel{grid-template-columns:repeat(5,1fr);}
    .dashboard-grid{grid-template-columns:repeat(3,1fr);}
}

/* iPad Pro & larger tablets */
@media(min-width:1024px) and (max-width:1400px) and (min-height:700px){
    .form-grid{grid-template-columns:repeat(2,1fr);}
    .missions-grid{grid-template-columns:repeat(2,1fr);}
}

/* High DPI/retina screens */
@media(-webkit-min-device-pixel-ratio:3),(min-resolution:3dppx){
    .form-group input,.form-group select,.form-group textarea{font-size:16px;}
    .login-field select{font-size:16px;}
    .search-box input{font-size:16px;}
}

/* Prevent iOS zoom on input focus (font-size < 16px triggers zoom) */
@supports(-webkit-touch-callout:none){
    .form-group input,.form-group select,.form-group textarea{font-size:max(.9rem, 16px);}
    .login-field select,.login-field input{font-size:max(.95rem, 16px);}
    .search-box input{font-size:max(.88rem, 16px);}
    .toolbar-select{font-size:max(.82rem, 16px);}
    .modal-form-group input,.modal-form-group select,.modal-form-group textarea{font-size:max(.9rem, 16px);}
}

@media print{
    .sidebar,.sidebar-backdrop,.topbar,.form-actions,.quick-add-panel,.manual-add,.btn-remove-row,.summary-panel,.fiche-status-bar,.toolbar,.offline-banner{display:none!important;}
    .main-content{margin-left:0!important;}
    .form-section{box-shadow:none;border:1px solid #ccc;break-inside:avoid;}
}
