/* ============================================================
   HORMÉ — Thème V2
   Mairie d'Ancy — Bâtiments
   Pour changer le thème : modifier ce fichier uniquement
   ============================================================ */


/* ============================================================
   VARIABLES & RESET
   ============================================================ */
:root {
  /* Fond général teinté */
  --bg:        #e8eef5;
  --surface:   #ffffff;
  --sidebar:   #1a2636;
  --sidebar-hover: #243448;
  --sidebar-active: #2e7d52;
  --accent:    #2e7d52;
  --accent2:   #4caf7d;
  --text:      #1c2b3a;
  --muted:     #5a7080;
  --border:    #ccd6e0;
  --danger:    #c62828;
  --warn:      #e65100;
  --info:      #0d47a1;
  --radius:    10px;
  --sidebar-w: 220px;
  --topbar-h:  54px;
  --shadow:    0 2px 10px rgba(0,0,0,.10);
  --transition: .18s ease;
  /* Couleurs thématiques par module */
  --c-alerte:      #c62828; --c-alerte-bg:  #fce4e4; --c-alerte-dark: #b71c1c;
  --c-interv:      #e67e00; --c-interv-bg:  #fff3e0; --c-interv-dark: #e65100;
  --c-bat:         #1b5e20; --c-bat-bg:     #dcedc8; --c-bat-dark:    #145214;
  --c-agent:       #0d47a1; --c-agent-bg:   #e3f2fd; --c-agent-dark:  #0a3880;
  --c-entrep:      #4a148c; --c-entrep-bg:  #f3e5f5; --c-entrep-dark: #38006b;
  --c-cmd:         #006064; --c-cmd-bg:     #e0f7fa; --c-cmd-dark:    #004d40;
  --c-contrat:     #1a237e; --c-contrat-bg: #e8eaf6; --c-contrat-dark:#0d1657;
  --c-planning:    #f57f17; --c-planning-bg:#fff8e1; --c-planning-dark:#e65100;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column;}
button{cursor:pointer;font:inherit;}
input,select,textarea{font:inherit;}
a{color:inherit;text-decoration:none;}

/* ============================================================
   LOGIN PAGE
   ============================================================ */
#login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1a2636 0%,#2e4a30 100%);}
#reset-page{display:none;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1a2636 0%,#2e4a30 100%);}
.login-card{background:#fff;border-radius:16px;padding:40px 48px;width:100%;max-width:400px;box-shadow:0 8px 32px rgba(0,0,0,.25);}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px;}
.login-logo .icon{width:44px;height:44px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;}
.login-logo h1{font-size:20px;font-weight:700;color:var(--sidebar);}
.login-logo p{font-size:12px;color:var(--muted);}
.login-card label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:5px;margin-top:16px;}
.login-card input{width:100%;border:1.5px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-size:15px;transition:border-color var(--transition);}
.login-card input:focus{outline:none;border-color:var(--accent);}
.btn-login{width:100%;margin-top:24px;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:600;transition:background var(--transition);}
.btn-login:hover{background:var(--accent2);}
#login-error{color:var(--danger);font-size:13px;margin-top:12px;display:none;}

/* ============================================================
   APP SHELL
   ============================================================ */
#app{display:none;flex:1;}
/* SIDEBAR */
#sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--sidebar);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition);}
.sidebar-logo{padding:18px 16px 14px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;}
.sidebar-logo .icon{width:36px;height:36px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;flex-shrink:0;}
.sidebar-logo span{color:#fff;font-weight:700;font-size:15px;line-height:1.2;}
.sidebar-logo small{color:rgba(255,255,255,.45);font-size:11px;}
nav{flex:1;overflow-y:auto;padding:10px 0;}
nav a{display:flex;align-items:center;gap:10px;padding:10px 16px;color:rgba(255,255,255,.75);font-size:14px;transition:background var(--transition),color var(--transition);border-radius:6px;margin:1px 8px;}
nav a:hover{background:var(--sidebar-hover);color:#fff;}
nav a.active{background:var(--accent);color:#fff;}
nav a .nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
nav .nav-section{padding:14px 16px 4px;font-size:10px;font-weight:700;color:rgba(255,255,255,.3);letter-spacing:1px;text-transform:uppercase;}
.sidebar-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.6);font-size:12px;}
.sidebar-footer strong{display:block;color:#fff;font-size:13px;}
.sidebar-footer .role-badge{display:inline-block;font-size:10px;padding:2px 7px;border-radius:20px;margin-top:3px;font-weight:700;}
.role-S{background:var(--accent);color:#fff;}
.role-P{background:var(--info);color:#fff;}
.role-C{background:var(--muted);color:#fff;}
/* TOPBAR */
#topbar{position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--topbar-h);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:12px;z-index:90;box-shadow:0 2px 8px rgba(0,0,0,.08);}
#topbar h2{flex:1;font-size:17px;font-weight:700;color:var(--text);}
.topbar-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;background:var(--bg);font-size:13px;color:var(--muted);}
.topbar-badge .count{background:var(--danger);color:#fff;font-size:11px;font-weight:700;padding:1px 6px;border-radius:10px;}
/* CONTENT */
#content{margin-left:var(--sidebar-w);padding-top:var(--topbar-h);min-height:100vh;}
.page{display:none;padding:20px;}
.page.active{display:block;}

/* ============================================================
   CARDS & PANELS
   ============================================================ */
.card{background:var(--surface);border-radius:var(--radius);box-shadow:0 2px 10px rgba(0,0,0,.08);padding:20px;border:1px solid var(--border);}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.card-header h3{font-size:15px;font-weight:700;}
.split{display:grid;grid-template-columns:260px 1fr;gap:16px;}
.split.wide{grid-template-columns:300px 1fr;}

/* ============================================================
   TABLES
   ============================================================ */
.tbl-wrap{overflow-x:auto;border-radius:var(--radius);}
table{width:100%;border-collapse:collapse;font-size:14px;}
thead{background:#1a2636;}
th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.6px;border-bottom:none;}
td{padding:10px 12px;border-bottom:1px solid var(--border);}
tr:nth-child(even) td{background:rgba(0,0,0,.025);}
tr:last-child td{border-bottom:none;}
tr.clickable{cursor:pointer;}
tr.clickable:hover td{background:#e8f5e9;}
tr.selected td{background:#c8e6c9;}

/* ============================================================
   LIST PANEL (left list + right detail)
   ============================================================ */
.list-panel{background:var(--surface);border-radius:var(--radius);box-shadow:0 2px 10px rgba(0,0,0,.08);overflow:hidden;border:1px solid var(--border);}
/* Headers colorés par module */
.page-alertes-header{background:linear-gradient(135deg,var(--c-alerte-dark),var(--c-alerte))!important;color:#fff!important;}
.page-alertes-header h3,.page-alertes-header label,.page-alertes-header small,.page-alertes-header a{color:#fff!important;}
.page-alertes-header .btn{background:rgba(255,255,255,.2)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-alertes-header select{background:rgba(255,255,255,.15)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-interv-header h3,.page-interv-header label,.page-interv-header small{color:#fff!important;}
.page-interv-header .btn{background:rgba(255,255,255,.2)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-interv-header select{background:rgba(255,255,255,.15)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-bat-header h3,.page-bat-header label,.page-bat-header small{color:#fff!important;}
.page-bat-header .btn{background:rgba(255,255,255,.2)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-agent-header h3,.page-agent-header label{color:#fff!important;}
.page-agent-header .btn{background:rgba(255,255,255,.2)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-entrep-header h3,.page-entrep-header label{color:#fff!important;}
.page-entrep-header .btn{background:rgba(255,255,255,.2)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-cmd-header h3,.page-cmd-header label{color:#fff!important;}
.page-cmd-header .btn{background:rgba(255,255,255,.2)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-cmd-header select{background:rgba(255,255,255,.15)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-contrat-header h3{color:#fff!important;}
.page-planning-header h3,.page-planning-header .btn{color:#fff!important;}
.page-planning-header .btn{background:rgba(255,255,255,.2)!important;border:1px solid rgba(255,255,255,.3)!important;}
.page-interv-header{background:linear-gradient(135deg,var(--c-interv-dark),var(--c-interv))!important;color:#fff!important;}
.page-interv-header *{color:#fff!important;}
.page-bat-header{background:linear-gradient(135deg,var(--c-bat-dark),var(--c-bat))!important;color:#fff!important;}
.page-bat-header *{color:#fff!important;}
.page-agent-header{background:linear-gradient(135deg,var(--c-agent-dark),var(--c-agent))!important;color:#fff!important;}
.page-agent-header *{color:#fff!important;}
.page-entrep-header{background:linear-gradient(135deg,var(--c-entrep-dark),var(--c-entrep))!important;color:#fff!important;}
.page-entrep-header *{color:#fff!important;}
.page-cmd-header{background:linear-gradient(135deg,var(--c-cmd-dark),var(--c-cmd))!important;color:#fff!important;}
.page-cmd-header *{color:#fff!important;}
.page-contrat-header{background:linear-gradient(135deg,var(--c-contrat-dark),var(--c-contrat))!important;color:#fff!important;}
.page-contrat-header *{color:#fff!important;}
.page-planning-header{background:linear-gradient(135deg,var(--c-planning-dark),var(--c-planning))!important;color:#fff!important;}
.page-planning-header *{color:#fff!important;}
.list-panel .list-col{border-right:1px solid var(--border);overflow-y:auto;max-height:calc(100vh - 140px);}
.list-item{display:flex;align-items:center;padding:11px 14px;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border);gap:8px;}
.list-item:hover{background:#f0f9f4;}
.list-item.active{background:#c8e6c9;border-left:4px solid var(--accent);font-weight:600;}
.list-item .main{font-weight:600;font-size:14px;}
.list-item .sub{font-size:12px;color:var(--muted);}
.list-item .indent{margin-left:20px;}
.detail-col{padding:20px;overflow-y:auto;max-height:calc(100vh - 140px);}

/* ============================================================
   FORMS
   ============================================================ */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.form-row.single{grid-template-columns:1fr;}
.form-row.triple{grid-template-columns:1fr 1fr 1fr;}
.field label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px;}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--border);border-radius:6px;padding:8px 10px;font-size:14px;transition:border-color var(--transition);}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);}
.field textarea{resize:vertical;min-height:70px;}
.checkbox-row{display:flex;align-items:center;gap:8px;margin:8px 0;}
.checkbox-row input[type=checkbox]{width:16px;height:16px;}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-radius:6px;font-size:13px;font-weight:600;transition:all var(--transition);cursor:pointer;}
.btn-primary{background:var(--accent);color:#fff;}
.btn-primary:hover{background:var(--accent2);}
.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border);}
.btn-secondary:hover{background:var(--border);}
.btn-danger{background:var(--danger);color:#fff;}
.btn-danger:hover{background:#b71c1c;}
.btn-warn{background:var(--warn);color:#fff;}
.btn-warn:hover{background:#bf360c;}
.btn-info{background:var(--info);color:#fff;}
.btn-info:hover{background:#01579b;}
.btn-sm{padding:5px 10px;font-size:12px;}
.btn-icon{padding:6px 8px;}
.btn-group{display:flex;gap:8px;flex-wrap:wrap;}

/* ============================================================
   BADGES / STATUS
   ============================================================ */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;}
.badge-red{background:var(--c-alerte-bg);color:var(--c-alerte);border:1px solid #ef9a9a;}
.badge-orange{background:var(--c-interv-bg);color:var(--c-interv);border:1px solid #ffab91;}
.badge-green{background:var(--c-bat-bg);color:var(--c-bat);border:1px solid #a5d6a7;}
.badge-blue{background:var(--c-agent-bg);color:var(--c-agent);border:1px solid #90caf9;}
.badge-gray{background:#eceff1;color:var(--muted);border:1px solid #cfd8dc;}

/* ============================================================
   DASHBOARD
   ============================================================ */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:24px;}
.dash-kpi{background:var(--surface);border-radius:var(--radius);box-shadow:0 2px 8px rgba(0,0,0,.08);padding:18px 20px;display:flex;flex-direction:column;gap:4px;border:1px solid var(--border);border-left:4px solid var(--accent);transition:transform .15s,box-shadow .15s;cursor:pointer;}
.dash-kpi:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.12);}
.dash-kpi .kpi-icon{font-size:24px;margin-bottom:4px;}
.dash-kpi .kpi-val{font-size:28px;font-weight:800;color:var(--accent);}
.dash-kpi .kpi-label{font-size:12px;color:var(--muted);font-weight:600;}
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* ============================================================
   ALERT STATUS COLORS
   ============================================================ */
trtr.alerte-declanchee td{background:#fce4e4;border-left:4px solid var(--c-alerte);}
tr.alerte-encours td{background:#fbe9e7;border-left:4px solid var(--c-interv);}
tr.alerte-clos-interv td{background:#e3f2fd;border-left:4px solid var(--c-agent);}
tr.alerte-clos td{background:var(--c-bat-bg);border-left:4px solid var(--c-bat);opacity:.75;}

/* ============================================================
   MODALS
   ============================================================ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.2);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;}
.modal-lg{max-width:720px;}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);}
.modal-header h3{font-size:16px;font-weight:700;}
.modal-close{background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer;padding:4px;}
.modal-body{padding:20px;}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;}

/* ============================================================
   TREE VIEW (Bâtiments)
   ============================================================ */
.tree-item{display:flex;align-items:center;gap:8px;padding:9px 12px;cursor:pointer;border-radius:6px;font-size:14px;transition:background var(--transition);}
.tree-item:hover{background:var(--bg);}
.tree-item.active{background:#e8f5e9;font-weight:700;}
.tree-item .tree-ref{font-size:11px;color:var(--muted);font-family:monospace;min-width:70px;}
.tree-child{margin-left:22px;border-left:2px solid var(--border);padding-left:8px;}
.notices-list a{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;border:1px solid var(--border);margin-bottom:6px;font-size:13px;transition:background var(--transition);}
.notices-list a:hover{background:var(--bg);}

/* ============================================================
   AVAILABILITY GRID
   ============================================================ */
.dispo-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:8px;}
.dispo-day{text-align:center;padding:6px 2px;border-radius:6px;background:var(--bg);font-size:11px;}
.dispo-day .day-name{font-weight:700;font-size:10px;color:var(--muted);}
.dispo-day .day-val{font-size:11px;margin-top:2px;color:var(--text);}
.dispo-day.absent-day{background:#ffebee;}

/* ============================================================
   TOAST
   ============================================================ */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:8px;}
.toast{background:#1a2636;color:#fff;padding:12px 18px;border-radius:8px;font-size:14px;box-shadow:0 4px 16px rgba(0,0,0,.25);animation:toastIn .25s ease;max-width:320px;}
.toast.success{border-left:4px solid var(--accent);}
.toast.error{border-left:4px solid var(--danger);}
.toast.info{border-left:4px solid var(--info);}
@keyframes toastIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

/* ============================================================
   MOBILE
   ============================================================ */
#mobile-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:var(--sidebar);z-index:100;
  padding-bottom:env(safe-area-inset-bottom,0px);
}
#mobile-nav .mob-items{display:flex;justify-content:space-around;padding:4px 0;}
#mobile-nav .mob-item{
  position:relative;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:6px 12px;color:rgba(255,255,255,.55);font-size:10px;
  cursor:pointer;border-radius:10px;
  transition:color var(--transition),background var(--transition);
  min-width:52px;
}
#mobile-nav .mob-item:active{background:rgba(255,255,255,.08);}
#mobile-nav .mob-item.active{color:var(--accent2);}
#mobile-nav .mob-item .mi{font-size:22px;line-height:1.2;}
#hamburger{display:none;background:none;border:none;font-size:22px;color:var(--text);padding:4px;}

/* ============================================================
   LOADER
   ============================================================ */
.loader{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--muted);font-size:14px;gap:10px;}
.spinner{width:20px;height:20px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================ */
/* ============================================================
   MOBILE RESPONSIVE — Full HD + scalable
   ============================================================ */

/* Tablette et mobile (≤800px) */
@media(max-width:800px){
  /* Sidebar masquée par défaut */
  #sidebar{transform:translateX(-100%);}
  #sidebar.open{transform:translateX(0);}
  #topbar{left:0;}
  /* Espace pour bottom tab bar (56px) + safe area iOS */
  #content{
    margin-left:0;
    padding-bottom:calc(56px + env(safe-area-inset-bottom, 0px));
  }
  #mobile-nav{display:block;}
  #hamburger{display:block;}
  /* Grilles */
  .split,.split.wide{grid-template-columns:1fr;}
  .dash-row{grid-template-columns:1fr;}
  .form-row.triple{grid-template-columns:1fr 1fr;}
  #bat-layout{grid-template-columns:1fr !important;}
  #bat-right{grid-template-columns:1fr !important;}
  /* Cards plus compactes */
  .page{padding:12px;}
  .card{border-radius:10px;}
  /* Tableaux : scroll horizontal */
  .tbl-wrap{-webkit-overflow-scrolling:touch;}
  /* Masquer colonnes secondaires sur mobile */
  .col-hide-mobile{display:none !important;}
  /* Masquer éléments desktop uniquement sur mobile */
  .hide-on-mobile{display:none !important;}
  /* Afficher uniquement sur mobile */
  .show-on-mobile{display:inline !important;}
  /* KPI dashboard : 3 colonnes */
  #kpi-grid{grid-template-columns:repeat(3,1fr) !important;max-width:100% !important;}
  /* Bottom sheet modals */
  .modal-overlay{align-items:flex-end !important;}
  .modal, .modal.modal-lg{
    max-width:100% !important;
    width:100% !important;
    max-height:92vh !important;
    border-radius:20px 20px 0 0 !important;
    margin:0 !important;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .modal-header{
    padding:10px 16px 14px !important;
    position:sticky;top:0;background:#fff;z-index:10;
  }
  /* Poignée de bottom sheet */
  .modal-header::before{
    content:'';display:block;width:36px;height:4px;
    background:#dde3ea;border-radius:2px;
    margin:0 auto 10px;
  }
  .modal-body{padding:12px 16px !important;}
  .modal-footer{
    padding:10px 16px !important;
    position:sticky;bottom:0;background:#fff;z-index:10;
    padding-bottom:calc(10px + env(safe-area-inset-bottom, 0px)) !important;
  }
  /* Champs tactiles : hauteur minimum 48px */
  .field input, .field select, .field textarea{
    min-height:48px !important;
    font-size:16px !important; /* évite le zoom iOS */
    padding:12px 14px !important;
    border-radius:8px !important;
  }
  .field select{min-height:48px !important;}
  .field textarea{min-height:80px !important;}
  /* Boutons tactiles */
  .btn{min-height:44px;font-size:14px;padding:10px 16px;}
  .btn-sm{min-height:36px;font-size:13px;}
  /* Labels plus lisibles */
  .field label{font-size:13px !important;margin-bottom:6px !important;}
  /* Formulaires : 1 colonne */
  .form-row{grid-template-columns:1fr !important;}
  /* Section title */
  .section-title{font-size:13px;}
  /* Dash grid */
  .dash-grid{grid-template-columns:repeat(3,1fr);}
  /* Topbar */
  #topbar h2{font-size:15px;}
  /* Sidebar mobile : compacte */
  nav a{padding:8px 14px !important;}
  nav .nav-section{padding:10px 14px 3px !important;}
  .sidebar-logo{padding:12px 14px 10px !important;}
  .sidebar-footer{padding:8px 14px !important;}
  /* sidebar-profile toujours visible (géré inline) */
  /* Chrono panel */
  #chrono-panel .tbl-wrap{font-size:12px;}
  /* Photos grid */
  .photos-grid{gap:6px;}
  .photo-thumb{width:80px;height:80px;}
  .photo-add-btn{width:80px;height:80px;}
}

/* Petits mobiles (≤430px — iPhone 14 Pro Max et inférieurs) */
@media(max-width:430px){
  .form-row.triple{grid-template-columns:1fr !important;}
  .dash-grid{grid-template-columns:1fr 1fr !important;}
  .page{padding:8px;}
  .card{padding:12px;}
  #kpi-grid{grid-template-columns:1fr 1fr 1fr !important;}
  .dash-kpi .kpi-val{font-size:22px;}
  .dash-kpi .kpi-label{font-size:10px;}
  /* Tables : réduire padding */
  th,td{padding:7px 8px !important;font-size:12px !important;}
}

/* Full HD mobile (≥1080px largeur physique mais density élevée)
   — géré via viewport meta, pas de media query supplémentaire nécessaire */

.show-on-mobile{display:none;}
.cal-event-wrap{position:relative;display:block;}
.cal-tooltip{
  display:none;position:absolute;z-index:300;
  background:#1a2636;color:#fff;
  border-radius:8px;padding:10px 14px;
  font-size:12px;line-height:1.6;
  min-width:200px;max-width:280px;
  box-shadow:0 4px 16px rgba(0,0,0,.35);
  white-space:normal;
  bottom:calc(100% + 6px);left:0;
  pointer-events:none;
}
.cal-tooltip::after{
  content:'';position:absolute;top:100%;left:12px;
  border:6px solid transparent;border-top-color:#1a2636;
}
.cal-event-wrap:hover .cal-tooltip{display:block;}

/* ============================================================
   PHOTOS
   ============================================================ */
.photos-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.photo-thumb{position:relative;width:90px;height:90px;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid var(--border);flex-shrink:0;background:#f0f0f0;}
.photo-thumb img{width:100%;height:100%;object-fit:cover;transition:opacity .2s;}
.photo-thumb:hover img{opacity:.8;}
.photo-thumb .del-photo{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:11px;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1;}
.photo-thumb:hover .del-photo{display:flex;}
.photo-add-btn{width:90px;height:90px;border-radius:8px;border:2px dashed var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:11px;color:var(--muted);gap:4px;background:#fafafa;flex-shrink:0;transition:border-color .2s,background .2s;}
.photo-add-btn:hover{border-color:var(--accent);background:#f0faf4;color:var(--accent);}
.photo-add-btn .add-icon{font-size:22px;}
/* Lightbox */
#lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:500;display:none;align-items:center;justify-content:center;flex-direction:column;}
#lightbox.open{display:flex;}
#lightbox img{max-width:90vw;max-height:80vh;border-radius:8px;object-fit:contain;}
#lightbox-caption{color:#fff;font-size:13px;margin-top:10px;opacity:.7;}
#lightbox-close{position:absolute;top:16px;right:20px;color:#fff;font-size:28px;cursor:pointer;background:none;border:none;}
#lightbox-prev,#lightbox-next{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:32px;cursor:pointer;background:rgba(255,255,255,.15);border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;}
#lightbox-prev{left:12px;}
#lightbox-next{right:12px;}

/* ============================================================
   SECTION DIVIDERS
   ============================================================ */
.section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin:16px 0 8px;}
.separator{border:none;border-top:1px solid var(--border);margin:16px 0;}
.empty-state{text-align:center;padding:36px;color:var(--muted);font-size:14px;}
.empty-state .es-icon{font-size:36px;margin-bottom:8px;}
