:root {
  --bg: #ece9e6; --surface: rgba(255,255,255,0.62); --surface-strong: rgba(255,255,255,0.78);
  --surface-warm: rgba(246, 236, 234, 0.88); --border: rgba(196, 150, 128, 0.32);
  --border-accent: rgba(245, 161, 141, 0.9); --text: #3d1f12; --muted: #8d5a3e;
  --shadow: 0 10px 30px rgba(109, 83, 64, 0.10); --shadow-soft: 0 8px 18px rgba(109, 83, 64, 0.08);
  --accent: #b26c28; --accent-2: #b1963c; --accent-3: #c19a19; --success: #5c7c3d;
  --radius-xl: 24px; --max: 1360px;
}
* { box-sizing: border-box; } html, body { min-height: 100%; }
body {
  margin: 0; font-family: "Segoe UI", Inter, Arial, sans-serif; color: var(--text);
  background: radial-gradient(circle at top left, rgba(255,255,255,0.65), transparent 30%),
              radial-gradient(circle at 85% 15%, rgba(255,255,255,0.45), transparent 18%),
              linear-gradient(180deg, #f2efec 0%, #ece9e6 100%);
  background-attachment: fixed; position: relative;
}
body::before { content:""; position:fixed; inset:0; background:rgba(255,255,255,0.52); backdrop-filter:blur(2px); z-index:-1; }
a{color:#6f3a1a;text-decoration:none} a:hover{text-decoration:underline} .hidden{display:none!important}
.shell{max-width:var(--max);margin:0 auto;padding:16px 20px 24px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:18px;padding:16px 20px;background:rgba(255,255,255,0.55);border:1px solid rgba(255,255,255,0.72);border-radius:18px;box-shadow:var(--shadow-soft);backdrop-filter:blur(10px);position:sticky;top:14px;z-index:30}
.brand-mini{display:flex;align-items:center;gap:12px;min-width:0}
.brand-mini img{width:52px;height:52px;border-radius:14px;background:white;object-fit:contain;box-shadow:0 2px 10px rgba(0,0,0,0.05);padding:3px;flex:0 0 auto}
.brand-mini strong{display:block;font-size:1rem}
.brand-mini span{display:block;color:var(--muted);font-size:0.92rem;line-height:1.35}
.topbar-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.pill{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,0.82);border:1px solid rgba(255,255,255,0.88);box-shadow:var(--shadow-soft);font-size:0.92rem;min-height:42px}
.status-dot{width:10px;height:10px;border-radius:999px;background:var(--success);box-shadow:0 0 0 4px rgba(92,124,61,0.12);flex:0 0 auto}
.button{appearance:none;border:0;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:white;padding:11px 18px;font-size:0.95rem;font-weight:600;cursor:pointer;box-shadow:0 8px 20px rgba(178,108,40,0.22);transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease;min-height:44px}
.button:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(178,108,40,0.28);text-decoration:none}
.button.secondary{background:rgba(255,255,255,0.88);color:var(--text);box-shadow:var(--shadow-soft)}
.hero{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(300px,0.7fr);gap:20px;margin-bottom:20px}
.card{background:rgba(255,255,255,0.52);backdrop-filter:blur(12px);border-radius:var(--radius-xl);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,0.62)}
.header-card{display:flex;align-items:center;gap:26px;padding:22px 28px;min-height:118px}
.header-card .logo-wrap{flex:0 0 126px;display:flex;justify-content:center;align-items:center}
.header-card .logo-wrap img{width:124px;height:auto;display:block;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(109,83,64,0.08))}
.header-card h1{margin:0 0 8px;font-size:clamp(1.8rem,2.2vw,2.9rem);line-height:1.06;color:var(--text)}
.header-card p{margin:0;color:var(--muted);font-size:1.02rem;line-height:1.55;max-width:900px}
.alert-card{padding:22px 24px;border:1px solid var(--border-accent);background:rgba(246,236,234,0.82)}
.alert-card h2{margin:0 0 12px;font-size:1.1rem}.alert-card ul{list-style:none;padding:0;margin:0;display:grid;gap:8px;color:var(--muted)}.alert-card li strong{color:var(--text)}
.meta-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:20px;margin-bottom:24px}
.info-card{padding:22px 24px;min-height:168px}.info-card h3{margin:0 0 14px;font-size:1.1rem}
.contact-list{display:grid;gap:10px}.contact-list a{display:inline-flex;align-items:center;gap:10px;width:fit-content}
.grid-title{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:0 0 16px;flex-wrap:wrap}.grid-title h2{margin:0;font-size:1.25rem}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.toolbar select,.toolbar input{border:1px solid rgba(111,58,26,0.14);background:rgba(255,255,255,0.90);color:var(--text);border-radius:14px;padding:11px 14px;font-size:0.95rem;min-height:44px;min-width:190px;outline:none}
.notice{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;margin-bottom:16px}
.notice strong{display:block;margin-bottom:4px}.notice p{margin:0;color:var(--muted)}
#toolsGrid{display:block}.section{margin-bottom:26px}.section>h3{margin:0 0 14px;font-size:1.08rem;color:var(--text)}
.tools-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.tool-card{position:relative;min-height:172px;padding:20px 18px 18px;border-radius:24px;background:rgba(255,255,255,0.78);border:1px solid rgba(255,255,255,0.84);box-shadow:var(--shadow-soft);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;display:flex;flex-direction:column;gap:10px;overflow:hidden}
.tool-card::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:linear-gradient(180deg,var(--accent),var(--accent-3));opacity:0;transition:opacity .18s ease}
.tool-card:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(109,83,64,0.16);border-color:rgba(245,161,141,0.8)} .tool-card:hover::before{opacity:1}
.tool-top{display:flex;align-items:center;gap:10px}.tool-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(178,108,40,0.12),rgba(193,154,25,0.18));font-size:1.35rem;flex:0 0 auto}
.tool-meta{min-width:0}.tool-meta h3{margin:0;font-size:1.06rem;line-height:1.2}
.tag{display:inline-flex;align-items:center;gap:6px;width:fit-content;font-size:0.78rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);padding:7px 10px;background:rgba(255,255,255,0.86);border-radius:999px;border:1px solid rgba(111,58,26,0.08)}
.tool-desc{color:var(--muted);line-height:1.45;margin:0;flex:1 1 auto}
.tool-links{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}
.link-main{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--text)}
.role-badge{font-size:0.78rem;padding:7px 10px;border-radius:999px;color:white;background:linear-gradient(135deg,#9e6d3f,#c08a50);white-space:nowrap}
.panel{margin-top:22px;padding:22px 24px}.panel h2{margin-top:0;margin-bottom:10px;font-size:1.2rem}.panel p{color:var(--muted);line-height:1.55;margin:8px 0}
.auth-box{display:grid;gap:12px;margin-top:14px;grid-template-columns:repeat(3,minmax(0,1fr))}
.auth-card{padding:18px;border-radius:20px;background:rgba(255,255,255,0.76);border:1px solid rgba(111,58,26,0.08);box-shadow:var(--shadow-soft)} .auth-card h3{margin:0 0 8px;font-size:1rem}
.empty-state{padding:26px;text-align:center;color:var(--muted);background:rgba(255,255,255,0.58);border-radius:22px;border:1px dashed rgba(111,58,26,0.15)}
.footer{text-align:center;color:var(--muted);padding:26px 10px 8px;font-size:0.98rem}
#realRoleBadge{font-weight:700;border-radius:999px;padding:8px 14px;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow-soft);margin-top:12px;background:rgba(255,255,255,0.82);border:1px solid rgba(111,58,26,0.16)}
body.theme-neutral{--accent:#b26c28;--accent-2:#b1963c;--accent-3:#c19a19}
body.theme-accueil{--accent:#b07a35;--accent-2:#c59a4b;--accent-3:#d9bb57;background:url("../assets/wallpapers/01_accueil.jpg") center/cover no-repeat fixed}
body.theme-benevole{--accent:#8f6b2a;--accent-2:#b1963c;--accent-3:#d8b84d;background:url("../assets/wallpapers/02_benevole.jpg") center/cover no-repeat fixed}
body.theme-admin,body.theme-secretaire{--accent:#6f3a1a;--accent-2:#a56a2a;--accent-3:#d0a13b;background:url("../assets/wallpapers/03_admin.jpg") center/cover no-repeat fixed}
body.theme-admin .topbar,body.theme-secretaire .topbar{box-shadow:0 12px 30px rgba(111,58,26,0.18)}
@media (max-width:1200px){.tools-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.hero,.meta-grid{grid-template-columns:1fr}}
@media (max-width:900px){.topbar{position:static}.tools-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.header-card{flex-direction:column;text-align:center}.auth-box{grid-template-columns:1fr}}
@media (max-width:640px){.shell{padding:12px}.tools-grid{grid-template-columns:1fr}.toolbar{width:100%}.toolbar select,.toolbar input{min-width:0;width:100%}.topbar{flex-direction:column;align-items:stretch}.topbar-actions{width:100%;justify-content:stretch}.button,.pill{width:100%;justify-content:center}}
