:root{--dark:#102515;--dark2:#07140c;--green:#1d5b38;--orange:#ff8a00;--orange2:#e87500;--bg:#f4f7f2;--card:#ffffff;--line:#dfe8dd;--text:#102515;--muted:#6f7f70;--danger:#dc2626;--ok:#15803d;--shadow:0 18px 50px rgba(10,33,18,.10)}
*{box-sizing:border-box}html{height:100%}body{margin:0;min-height:100%;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{width:282px;background:linear-gradient(180deg,var(--dark),var(--dark2));color:#fff;position:fixed;inset:0 auto 0 0;padding:20px;display:flex;flex-direction:column;gap:20px;z-index:5}.brand{display:flex;gap:12px;align-items:center;text-decoration:none}.brand-mark{width:46px;height:46px;display:grid;place-items:center;background:var(--orange);color:var(--dark);font-weight:900;border-radius:14px}.brand strong{display:block;font-size:18px}.brand small{display:block;color:#cfe0d1;margin-top:2px}.nav{display:grid;gap:7px}.nav a{display:flex;align-items:center;gap:10px;text-decoration:none;color:#e9f4e9;padding:12px 12px;border-radius:12px;font-weight:700}.nav a:hover,.nav a.active{background:rgba(255,255,255,.10);color:#fff}.nav a.active{box-shadow:inset 4px 0 0 var(--orange)}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.12);padding-top:14px;color:#cfe0d1}.sidebar-footer a{color:#fff;text-decoration:none;font-weight:800}.admin-mini{font-weight:800;margin-bottom:8px}.main{margin-left:282px;flex:1;min-width:0}.topbar{position:sticky;top:0;z-index:4;background:rgba(244,247,242,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:18px 26px;display:flex;align-items:center;justify-content:space-between;gap:16px}.eyebrow{margin:0 0 4px;color:var(--orange2);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.12em}.topbar h1{margin:0;font-size:27px}.top-actions{display:flex;gap:10px;align-items:center}.ghost,.btn{border:0;background:var(--dark);color:#fff;text-decoration:none;font-weight:900;border-radius:12px;padding:11px 15px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.ghost{background:#fff;color:var(--dark);border:1px solid var(--line)}.btn:hover,.ghost:hover{filter:brightness(.97)}.btn.soft{background:#edf4eb;color:var(--dark);border:1px solid var(--line)}.btn.danger{background:var(--danger);color:#fff}.btn.full{width:100%;padding:14px 16px}.btn.tiny{font-size:12px;padding:8px 10px;border-radius:9px}.content{padding:26px;max-width:1640px}.grid{display:grid;gap:16px}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:18px}.stat{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow)}.stat span{display:block;color:var(--muted);font-weight:800;font-size:13px}.stat strong{display:block;font-size:34px;line-height:1.1;margin:7px 0;color:var(--dark)}.stat small{color:var(--muted)}.stat.orange{border-color:#fed7aa;background:#fff7ed}.stat.green{border-color:#bbf7d0;background:#f0fdf4}.stat.red{border-color:#fecaca;background:#fff1f2}.stat.dark{background:var(--dark);color:#fff}.stat.dark span,.stat.dark small{color:#d7e6d8}.stat.dark strong{color:#fff}.panel,.card,.empty{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}.panel{padding:18px;margin-bottom:18px}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-head h2,.help-panel h2{font-size:18px;margin:0}.panel-head a{color:var(--orange2);font-weight:900;text-decoration:none}.two-col{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}.list{display:grid;gap:10px}.list-item{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:14px;padding:12px}.list-item strong,.list-item small{display:block}.list-item small{color:var(--muted);margin-top:4px}.badge{display:inline-flex;align-items:center;white-space:nowrap;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;background:#eef2ef;color:#304030}.badge-orange{background:#ffedd5;color:#9a3412}.badge-green{background:#dcfce7;color:#166534}.badge-red{background:#fee2e2;color:#991b1b}.badge-gray{background:#eef2ef;color:#475647}.toolbar{display:flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;margin-bottom:18px;box-shadow:var(--shadow)}input,textarea,select{width:100%;border:1px solid #cdd9cc;background:#fff;border-radius:12px;padding:11px 12px;font:inherit;color:var(--text)}textarea{resize:vertical}.toolbar input{flex:1}.toolbar select{max-width:220px}.table-wrap{overflow:auto}.table-wrap.panel{padding:0}table{width:100%;border-collapse:separate;border-spacing:0;min-width:980px}th,td{padding:13px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}th{background:#f8fbf6;font-size:12px;color:#556655;text-transform:uppercase;letter-spacing:.04em}td small{display:block;color:var(--muted);margin-top:4px}.actions-cell{min-width:260px}.inline-form{display:inline-flex;margin:2px}.edit-row td{background:#f8fbf6}.edit-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.edit-grid label,.form-stack label{display:grid;gap:6px;font-size:13px;font-weight:800;color:#415041}.edit-grid .wide{grid-column:1/-1}.form-actions{display:flex;align-items:end}.form-stack{display:grid;gap:13px}.form-stack.small{gap:10px}.check{display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;font-weight:700!important}.check input{width:auto}.cards-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.card{padding:16px}.card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}.card-head strong,.card-head small{display:block}.card-head small{color:var(--muted);margin-top:5px}.meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.meta-grid span{border:1px solid var(--line);background:#f8fbf6;border-radius:12px;padding:10px;font-size:13px}.meta-grid b{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;margin-bottom:5px}.desc{background:#fff7ed;border:1px solid #fed7aa;border-radius:14px;padding:12px;line-height:1.6}.action-panel{border-top:1px solid var(--line);padding-top:12px}.actions-row{display:flex;gap:8px;flex-wrap:wrap}.report-edit{margin-top:12px}.empty{padding:28px;text-align:center}.empty strong{display:block;font-size:18px}.empty p{color:var(--muted);margin-bottom:0}.flash{margin:18px 26px 0;padding:13px 14px;border-radius:14px;font-weight:800}.flash-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.flash-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top,#1d5b38 0,#102515 44%,#07140c 100%);padding:18px}.login-card{width:min(440px,100%);background:#fff;border-radius:22px;padding:26px;box-shadow:0 28px 80px rgba(0,0,0,.22)}.login-card h1{margin:18px 0 6px}.login-card p{color:var(--muted)}.login-brand{color:var(--dark)}code{background:#edf4eb;border:1px solid var(--line);border-radius:8px;padding:2px 5px}.mobile-nav{display:none}
.mobile-topbar,.mobile-menu-backdrop{display:none}
.mobile-menu-panel[hidden],.mobile-menu-backdrop[hidden]{display:none!important}
.install-btn{background:var(--orange);color:var(--dark)}
@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cards-grid,.two-col{grid-template-columns:1fr}.meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.edit-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){body{background:#f6f8f3}.sidebar{display:none}.main{margin-left:0;padding-bottom:72px}.topbar{padding:14px 12px;align-items:flex-start}.topbar h1{font-size:21px}.top-actions .ghost{display:none}.content{padding:12px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.stat,.panel,.card,.empty,.toolbar,.flash,.login-card,.meta-grid span,.desc{border-radius:0;box-shadow:none}.stat{padding:13px}.stat strong{font-size:27px}.toolbar{display:grid;grid-template-columns:1fr;position:sticky;top:68px;z-index:3}.toolbar select{max-width:none}.cards-grid{grid-template-columns:1fr;gap:10px}.meta-grid{grid-template-columns:1fr}.edit-grid{grid-template-columns:1fr}.actions-cell{min-width:240px}.top-actions{display:block}.mobile-nav{position:fixed;z-index:9;left:0;right:0;bottom:0;height:66px;background:#07140c;border-top:1px solid rgba(255,255,255,.12);display:grid;grid-template-columns:repeat(5,1fr);padding-bottom:env(safe-area-inset-bottom)}.mobile-nav a{color:#fff;text-decoration:none;display:grid;place-items:center;font-size:18px}.mobile-nav small{font-size:10px;color:#d7e6d8}.btn,.ghost,input,textarea,select{border-radius:0}.panel{padding:12px;margin-bottom:12px}table{min-width:900px}.flash{margin:12px}}
/* V2 — adaptations schéma complet SignalNids */
.toolbar-select{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #dfe8dd;padding:8px 10px;border-radius:14px;color:#52604f;font-size:12px;font-weight:700}
.toolbar-select select{border:0;background:transparent;font-weight:800;color:#102515;outline:0;min-width:110px}
.kpi-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr))}
.chart-panel h2,.panel h2{margin:0 0 14px;color:#102515;font-size:18px}.mini-chart{min-height:155px;display:flex;align-items:flex-end;gap:10px;padding:14px 4px 4px;overflow:auto}.bar{width:44px;min-width:44px;background:linear-gradient(180deg,#ff8a00,#d65f00);border-radius:12px 12px 4px 4px;position:relative;display:flex;justify-content:center}.bar span{position:absolute;top:-24px;font-size:12px;font-weight:900;color:#102515}.bar small{position:absolute;bottom:-24px;font-size:11px;color:#71806f}.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}.list-cards{display:grid;gap:10px}.mini-card{display:block;text-decoration:none;color:#102515;background:#f8fbf6;border:1px solid #e4eddf;border-radius:16px;padding:12px}.mini-card strong{display:block}.mini-card span,.mini-card small,td small{display:block;color:#657361;font-size:12px;margin-top:3px;line-height:1.35}.muted{color:#71806f}.edit-grid .wide{grid-column:1/-1}.edit-grid select,.edit-grid textarea{width:100%;border:1px solid #dbe6d7;border-radius:12px;padding:10px;font:inherit;background:#fff}.check{display:flex!important;align-items:center;gap:8px;background:#f8fbf6;border:1px solid #e2ecd9;border-radius:12px;padding:10px}.check input{width:auto!important}.actions-cell form.inline-form{margin:2px 0}.reports-table td{vertical-align:top}.btn.tiny{white-space:nowrap}
@media (max-width:900px){.two-cols,.kpi-grid.compact{grid-template-columns:1fr}.toolbar{align-items:stretch}.toolbar-select{width:100%;justify-content:space-between;border-radius:0}.mini-chart{padding-bottom:28px}.bar{min-width:34px;width:34px}.table-wrap{border-radius:0}.edit-grid{grid-template-columns:1fr!important}.top-actions a.ghost:nth-child(2){display:none}}


/* V2.2 — Topbar mobile admin */
@media(max-width:760px){
  body.mobile-menu-open{overflow:hidden}
  .app-shell{display:block;min-height:100vh}
  .main{padding-top:64px}
  .topbar{display:none}
  .mobile-topbar{position:fixed;display:flex;align-items:center;justify-content:space-between;gap:10px;left:0;right:0;top:0;z-index:30;height:64px;background:#07140c;color:#fff;border-bottom:1px solid rgba(255,255,255,.12);padding:8px 10px calc(8px + env(safe-area-inset-top,0px));box-shadow:0 10px 30px rgba(0,0,0,.18)}
  .mobile-brand{display:flex;align-items:center;gap:9px;color:#fff;text-decoration:none;min-width:0}
  .mobile-brand-mark{width:38px;height:38px;display:grid;place-items:center;background:#ff8a00;color:#102515;font-weight:900;border-radius:0;flex:0 0 auto}
  .mobile-brand strong{display:block;font-size:16px;line-height:1.05;letter-spacing:.01em}
  .mobile-brand small{display:block;color:#cfe0d1;font-size:11px;line-height:1.2;max-width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .mobile-menu-btn{width:52px;height:46px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:#fff;display:grid;place-items:center;border-radius:0;padding:6px;cursor:pointer}
  .mobile-menu-btn span{display:block;width:24px;height:2px;background:#fff;margin:2px 0;transition:transform .18s ease,opacity .18s ease}
  .mobile-menu-btn b{font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:#d7e6d8;line-height:1}
  body.mobile-menu-open .mobile-menu-btn span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  body.mobile-menu-open .mobile-menu-btn span:nth-child(2){opacity:0}
  body.mobile-menu-open .mobile-menu-btn span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  .mobile-menu-backdrop{position:fixed;display:block;inset:64px 0 0 0;z-index:28;background:rgba(7,20,12,.55);backdrop-filter:blur(2px)}
  .mobile-menu-panel{position:fixed;display:block;left:0;right:0;top:64px;z-index:31;background:#fff;color:#102515;border-bottom:1px solid #dfe8dd;box-shadow:0 28px 60px rgba(0,0,0,.22);padding:12px;max-height:calc(100vh - 64px);overflow:auto}
  .mobile-menu-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #e5eee2}
  .mobile-menu-head strong{font-size:16px}
  .mobile-menu-close{width:38px;height:38px;border:1px solid #dfe8dd;background:#f6f8f3;color:#102515;font-size:28px;line-height:1;border-radius:0;cursor:pointer}
  .mobile-menu-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
  .mobile-menu-grid a{display:grid;gap:5px;place-items:center;text-align:center;text-decoration:none;background:#f7faf5;border:1px solid #dfe8dd;color:#102515;padding:11px 6px;min-height:78px;font-size:12px;font-weight:900;border-radius:0}
  .mobile-menu-grid a span{font-size:20px;line-height:1}
  .mobile-menu-grid a.active{background:#102515;color:#fff;border-color:#102515;box-shadow:inset 0 -4px 0 #ff8a00}
  .mobile-menu-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
  .mobile-menu-actions a{display:flex;align-items:center;justify-content:center;text-align:center;text-decoration:none;background:#102515;color:#fff;border:1px solid #102515;padding:12px 8px;font-weight:900;border-radius:0}
  .mobile-menu-actions a.danger{grid-column:1/-1;background:#fee2e2;color:#991b1b;border-color:#fecaca}
  .toolbar{top:64px}
}
@media(max-width:390px){.mobile-menu-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-brand small{max-width:145px}}

/* V2.3 — correction dashboard KPI + topbar mobile propre */
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(180px,1fr));
  gap:14px;
  margin:0 0 18px;
}
.kpi{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:17px 18px;
  box-shadow:var(--shadow);
  min-height:118px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
}
.kpi span{
  display:block;
  color:#64745f;
  font-size:12px;
  line-height:1.2;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.055em;
  white-space:normal;
}
.kpi strong{
  display:block;
  margin:8px 0 6px;
  color:#102515;
  font-size:34px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.04em;
}
.kpi small{
  display:block;
  color:#657361;
  font-size:12px;
  line-height:1.35;
  white-space:normal;
}
.kpi:nth-child(1),.kpi:nth-child(4),.kpi:nth-child(8){border-color:#bbf7d0;background:linear-gradient(180deg,#f0fdf4,#fff)}
.kpi:nth-child(2),.kpi:nth-child(5),.kpi:nth-child(9){border-color:#fed7aa;background:linear-gradient(180deg,#fff7ed,#fff)}
.kpi:nth-child(3){background:#102515;border-color:#102515;color:#fff}
.kpi:nth-child(3) span,.kpi:nth-child(3) small,.kpi:nth-child(3) strong{color:#fff}

/* Empêche le menu gauche de rester en mini-bande sur PC */
@media(min-width:981px){
  .app-shell{display:flex!important}
  .sidebar{
    display:flex!important;
    width:282px!important;
    min-width:282px!important;
    max-width:282px!important;
    transform:none!important;
    left:0!important;
    right:auto!important;
    overflow:visible!important;
    padding:20px!important;
  }
  .brand,.nav,.sidebar-footer{opacity:1!important;visibility:visible!important;display:flex}
  .nav{display:grid!important}
  .main{margin-left:282px!important;padding-top:0!important;width:auto!important}
  .mobile-topbar,.mobile-menu-backdrop,.mobile-menu-panel,.mobile-nav{display:none!important}
  body{overflow-x:hidden}
}

@media(max-width:1280px) and (min-width:981px){
  .kpi-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}
  .content{padding:22px}
}

/* Topbar activée sur mobile/tablette compacte */
@media(max-width:980px){
  body{background:#f6f8f3}
  body.mobile-menu-open{overflow:hidden}
  .app-shell{display:block!important;min-height:100vh}
  .sidebar{display:none!important}
  .main{margin-left:0!important;padding-top:64px!important;padding-bottom:76px!important;width:100%!important}
  .topbar{display:none!important}
  .content{padding:12px!important;max-width:none!important}
  .mobile-topbar{position:fixed;display:flex!important;align-items:center;justify-content:space-between;gap:10px;left:0;right:0;top:0;z-index:100;height:64px;background:#07140c;color:#fff;border-bottom:1px solid rgba(255,255,255,.12);padding:8px 10px;box-shadow:0 10px 30px rgba(0,0,0,.18)}
  .mobile-brand{display:flex;align-items:center;gap:9px;color:#fff;text-decoration:none;min-width:0}
  .mobile-brand-mark{width:38px;height:38px;display:grid;place-items:center;background:#ff8a00;color:#102515;font-weight:900;border-radius:0;flex:0 0 auto}
  .mobile-brand strong{display:block;font-size:16px;line-height:1.05;letter-spacing:.01em}
  .mobile-brand small{display:block;color:#cfe0d1;font-size:11px;line-height:1.2;max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .mobile-menu-btn{width:54px;height:46px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:#fff;display:grid;place-items:center;border-radius:0;padding:6px;cursor:pointer}
  .mobile-menu-btn span{display:block;width:24px;height:2px;background:#fff;margin:2px 0;transition:transform .18s ease,opacity .18s ease}
  .mobile-menu-btn b{font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:#d7e6d8;line-height:1}
  body.mobile-menu-open .mobile-menu-btn span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  body.mobile-menu-open .mobile-menu-btn span:nth-child(2){opacity:0}
  body.mobile-menu-open .mobile-menu-btn span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  .mobile-menu-backdrop{position:fixed;display:block;inset:64px 0 0 0;z-index:98;background:rgba(7,20,12,.55);backdrop-filter:blur(2px)}
  .mobile-menu-panel{position:fixed;display:block;left:0;right:0;top:64px;z-index:101;background:#fff;color:#102515;border-bottom:1px solid #dfe8dd;box-shadow:0 28px 60px rgba(0,0,0,.22);padding:12px;max-height:calc(100vh - 64px);overflow:auto}
  .mobile-menu-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #e5eee2}
  .mobile-menu-head strong{font-size:16px}
  .mobile-menu-close{width:38px;height:38px;border:1px solid #dfe8dd;background:#f6f8f3;color:#102515;font-size:28px;line-height:1;border-radius:0;cursor:pointer}
  .mobile-menu-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
  .mobile-menu-grid a{display:grid;gap:5px;place-items:center;text-align:center;text-decoration:none;background:#f7faf5;border:1px solid #dfe8dd;color:#102515;padding:11px 6px;min-height:78px;font-size:12px;font-weight:900;border-radius:0}
  .mobile-menu-grid a span{font-size:20px;line-height:1}
  .mobile-menu-grid a.active{background:#102515;color:#fff;border-color:#102515;box-shadow:inset 0 -4px 0 #ff8a00}
  .mobile-menu-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
  .mobile-menu-actions a{display:flex;align-items:center;justify-content:center;text-align:center;text-decoration:none;background:#102515;color:#fff;border:1px solid #102515;padding:12px 8px;font-weight:900;border-radius:0}
  .mobile-menu-actions a.danger{grid-column:1/-1;background:#fee2e2;color:#991b1b;border-color:#fecaca}
  .kpi-grid,.kpi-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px}
  .kpi{border-radius:0;box-shadow:none;padding:12px;min-height:104px}
  .kpi strong{font-size:28px}
  .toolbar{top:64px!important}
  .mobile-nav{display:none!important}
}
@media(max-width:480px){
  .kpi-grid,.kpi-grid.compact{grid-template-columns:1fr!important}
  .mobile-menu-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .mobile-brand small{max-width:145px}
}


/* V2.4 — topbar + menu bas mobile conservés */
@media(max-width:980px){
  .main{padding-bottom:calc(84px + env(safe-area-inset-bottom,0px))!important}
  .mobile-nav{
    position:fixed!important;
    z-index:90!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    height:70px!important;
    display:grid!important;
    grid-template-columns:repeat(5,1fr)!important;
    background:#07140c!important;
    border-top:1px solid rgba(255,255,255,.14)!important;
    padding:4px 0 calc(4px + env(safe-area-inset-bottom,0px))!important;
    box-shadow:0 -12px 34px rgba(0,0,0,.22)!important;
  }
  .mobile-nav a{
    color:#fff!important;
    text-decoration:none!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:3px!important;
    min-width:0!important;
    font-weight:900!important;
    border-radius:0!important;
    position:relative!important;
  }
  .mobile-nav a span{font-size:18px!important;line-height:1!important}
  .mobile-nav a small{
    display:block!important;
    max-width:100%!important;
    padding:0 2px!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
    font-size:10px!important;
    line-height:1.1!important;
    color:#d7e6d8!important;
  }
  .mobile-nav a.active{background:rgba(255,138,0,.12)!important;color:#fff!important}
  .mobile-nav a.active:before{
    content:"";
    position:absolute;
    top:0;
    left:18%;
    right:18%;
    height:3px;
    background:#ff8a00;
  }
  body.mobile-menu-open .mobile-nav{display:none!important}
}
@media(min-width:981px){.mobile-nav{display:none!important}}

/* V2.5 — bannière d’installation PWA fiable mobile + fallback iPhone/Firefox */
.pwa-install-card{
  margin:16px 26px 0;
  background:linear-gradient(135deg,#102515,#1d5b38);
  color:#fff;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  box-shadow:0 18px 50px rgba(10,33,18,.14);
  padding:14px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
}
.pwa-install-card[hidden]{display:none!important}
.pwa-install-main{display:flex;align-items:center;gap:12px;min-width:0}
.pwa-install-icon{width:42px;height:42px;display:grid;place-items:center;background:#ff8a00;color:#102515;font-size:22px;font-weight:900;flex:0 0 auto;border-radius:12px}
.pwa-install-main strong{display:block;font-size:16px;line-height:1.2}
.pwa-install-main small{display:block;color:#d7e6d8;margin-top:4px;line-height:1.35}
.pwa-install-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.pwa-install-actions .install-btn{background:#ff8a00;color:#102515;border:0}
.pwa-install-close{width:38px;height:38px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;font-size:26px;line-height:1;cursor:pointer;border-radius:12px}
.pwa-install-help{grid-column:1/-1;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);padding:12px;line-height:1.5;border-radius:14px}
.pwa-install-help p{margin:6px 0 0;color:#edf7eb}
@media(max-width:980px){
  .pwa-install-card{margin:12px 12px 0;border-radius:0;box-shadow:none;grid-template-columns:1fr;gap:10px;padding:12px}
  .pwa-install-icon{border-radius:0;width:38px;height:38px}
  .pwa-install-actions{display:grid;grid-template-columns:1fr 1fr 42px;gap:8px;width:100%}
  .pwa-install-actions .btn,.pwa-install-close{border-radius:0;width:100%;height:42px;padding:0 8px}
  .pwa-install-help{border-radius:0}
}
@media(min-width:981px){
  .pwa-install-card{display:none!important}
}
