:root{--bg:#f7f3ea;--card:#fffaf0;--ink:#2e241b;--accent:#b36b2c;--accent2:#ffd98a;--border:#ead9bd}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(135deg,#fff8e8,#f5efe3);color:var(--ink)}a{color:inherit}.topbar{height:64px;display:flex;align-items:center;gap:16px;padding:0 18px;background:#fff7e6;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}.burger,.menu-close{font-size:28px;border:0;background:var(--accent);color:white;border-radius:12px;padding:6px 12px;cursor:pointer}.brand{font-weight:800;text-decoration:none;display:flex;align-items:center;gap:10px}.brand img{width:38px}.hello{margin-left:auto;font-weight:700}.container{max-width:1100px;margin:0 auto;padding:28px 18px 90px}.hero,.card,.grid-card{background:rgba(255,250,240,.9);border:1px solid var(--border);border-radius:22px;padding:24px;box-shadow:0 10px 30px #00000010}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}.btn{display:inline-block;background:var(--accent);color:white;text-decoration:none;border:0;border-radius:12px;padding:11px 16px;font-weight:700;cursor:pointer}.btn.light{background:#fff;border:1px solid var(--border);color:var(--ink)}input,select,textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:12px;background:white;margin:6px 0 14px}.flash{padding:12px 16px;border-radius:14px;margin-bottom:16px;background:#eaf7ea}.flash.err{background:#ffe4df}.side-menu{position:fixed;inset:0;background:#0008;opacity:0;pointer-events:none;transition:.2s;z-index:10}.menu-open .side-menu{opacity:1;pointer-events:auto}.menu-panel{width:min(330px,88vw);height:100%;background:#fff7e6;padding:18px;display:flex;flex-direction:column;gap:9px;transform:translateX(-100%);transition:.2s}.menu-open .menu-panel{transform:none}.menu-panel a{text-decoration:none;padding:10px 12px;border-radius:12px}.menu-panel a:hover{background:var(--accent2)}.menu-panel strong{margin-top:12px;color:var(--accent)}table{width:100%;border-collapse:collapse;background:white;border-radius:16px;overflow:hidden}th,td{padding:12px;border-bottom:1px solid var(--border);text-align:left}.footer{position:fixed;bottom:0;left:0;right:0;background:#fff7e6;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;padding:10px 18px;font-size:14px}.copy{text-align:center}.footer-logo img{display:none;width:30px;margin-top:4px}@media(max-width:800px){.footer{font-size:12px}.footer-logo img,.mobile{display:inline-block}.brand{font-size:0}.hello{font-size:14px}.container{padding-bottom:120px}}

/* GaChiPan 02.1 - Administration centrale */
.table-wrap{overflow:auto}.actions{white-space:nowrap;display:flex;gap:6px;align-items:center}.inline{display:inline;margin:0}.icon-btn{border:1px solid var(--border);background:#fff;border-radius:10px;padding:7px 9px;cursor:pointer;font-size:16px}.icon-btn:hover{background:var(--accent2)}.icon-btn.danger,.btn.danger{background:#b33a2c;color:#fff}.icon-btn.disabled{opacity:.45;cursor:not-allowed}.badge{display:inline-block;margin-left:6px;padding:3px 7px;border-radius:999px;background:var(--accent2);font-size:12px}.status{padding:4px 8px;border-radius:999px;background:#eee}.status.actif{background:#e5f7e5}.status.attente{background:#fff0c7}.status.bloque{background:#ffe1dc}.admin-create{margin:16px 0;padding:14px;border:1px solid var(--border);border-radius:16px;background:#fff}.admin-create summary{font-weight:800;cursor:pointer}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px 16px;margin-top:14px}.gcp-modal{border:0;border-radius:22px;padding:22px;max-width:min(620px,92vw);box-shadow:0 30px 90px #0006;background:#fffaf0;color:var(--ink)}.gcp-modal::backdrop{background:#0009}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:12px}code{background:#fff;border:1px solid var(--border);border-radius:8px;padding:2px 6px}

.checkline{display:flex;align-items:center;gap:.6rem;margin:.8rem 0}.checkline input{width:auto}.muted{opacity:.75}.maintenance-card{max-width:720px;margin:8vh auto;text-align:center}.maintenance-page .topbar{display:none}

/* 03.0 - services */
.badge{display:inline-block;padding:.25rem .6rem;border-radius:999px;background:#eef2ff;font-weight:700}.actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}code{background:#f4f4f5;padding:.2rem .35rem;border-radius:.35rem}.full{grid-column:1/-1}


/* 04.0 - services simples */
.wheel-result{display:flex;align-items:center;justify-content:space-between;gap:1rem;border:1px dashed var(--accent);border-radius:18px;padding:18px;margin:16px 0;background:#fff}
.wheel-result span{font-size:clamp(1.4rem,4vw,2.6rem);font-weight:900;color:var(--accent)}
.choice-list{columns:2;line-height:1.9}
.calendar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px}
.month{background:#fff;border:1px solid var(--border);border-radius:16px;padding:12px;break-inside:avoid}
.month h3{text-align:center;margin:.2rem 0 .7rem}.mini-cal{font-size:13px}.mini-cal th,.mini-cal td{text-align:center;padding:6px;border:1px solid #f0e3ce}.mini-cal .sunday{background:#eee}.print-zone{background:#fff}
@media print{.topbar,.side-menu,.footer,.actions,.btn,form,.flash{display:none!important}.container{max-width:none;padding:0}.card,.hero{box-shadow:none;border:0}.calendar-grid{grid-template-columns:repeat(3,1fr)}}


/* 04.2 - personnalisation visuelle du portail */
body.has-portal-background{background-image:var(--portal-bg);background-size:cover;background-position:center;background-attachment:fixed;background-color:transparent}.brand img{height:38px;width:38px;object-fit:contain}.visual-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:14px 0 24px}.visual-setting-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:16px}.visual-setting-card.full{grid-column:1/-1}.image-preview{display:flex;align-items:center;gap:14px;margin-bottom:14px}.image-preview .thumb{width:96px;height:72px;border:1px solid var(--border);border-radius:14px;background:#fff8e8;display:flex;align-items:center;justify-content:center;overflow:hidden}.image-preview .thumb img{max-width:100%;max-height:100%;object-fit:contain}.visual-setting-card.full .image-preview .thumb{width:150px;height:90px}input[type=file]{padding:9px;background:#fff}


/* 04.3 - fond personnalisé sans masque de couleur global */
body.has-portal-background{background-image:var(--portal-bg);background-size:cover;background-position:center;background-attachment:fixed;background-color:transparent}
