:root{
  --bg:#0a0b0d; --bg2:#101216; --card:#15171c; --card2:#1a1d23; --line:#262a31;
  --txt:#eef1f4; --mut:#9aa3ad; --dim:#6b7177;
  --red:#E1001A; --red2:#ff2438; --ok:#19a463; --amber:#e9a020; --blue:#3a86ff;
  --r:16px; --r2:12px; --sb:64px;
  --ease:cubic-bezier(.16,1,.3,1);
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --disp:"Poppins",var(--font);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--font);-webkit-font-smoothing:antialiased}
body{padding-bottom:calc(var(--sb) + env(safe-area-inset-bottom));min-height:100vh}
h1,h2,h3{font-family:var(--disp);margin:0}
button,input,select{font:inherit;color:inherit}
a{color:inherit}
.muted{color:var(--mut);font-weight:500}

/* TOP BAR */
.top{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;background:rgba(10,11,13,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:baseline;gap:9px}
.wm{font-family:var(--disp);font-weight:800;font-size:20px;letter-spacing:.5px}
.wm b{color:var(--red)}
.tag{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--dim);font-weight:600}
.sync{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--mut)}
.sync .dot{width:8px;height:8px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 0 rgba(233,160,32,.5);transition:.3s}
.sync.ok .dot{background:var(--ok)} .sync.off .dot{background:var(--dim)} .sync.save .dot{background:var(--amber);animation:pulse 1s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(233,160,32,.5)}100%{box-shadow:0 0 0 7px rgba(233,160,32,0)}}

/* LAYOUT */
main{max-width:1080px;margin:0 auto;padding:18px 16px 30px}
.view{animation:fade .35s var(--ease)}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.hd{margin:6px 2px 18px}
.hd h1{font-size:clamp(26px,7vw,38px);font-weight:800;line-height:1.05}
.lead{color:var(--mut);font-size:14.5px;line-height:1.5;margin:8px 0 0;max-width:680px}
.sub{font-size:15px;font-weight:700;margin:24px 2px 12px;display:flex;align-items:center;gap:8px}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:4px 0 16px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r2);padding:14px}
.stat .v{font-family:var(--disp);font-size:26px;font-weight:800;line-height:1}
.stat .l{font-size:11.5px;color:var(--mut);margin-top:5px;text-transform:uppercase;letter-spacing:.5px}
.stat.done .v{color:var(--ok)} .stat.plan .v{color:var(--amber)} .stat.todo .v{color:var(--mut)}

.tip{background:linear-gradient(180deg,#1a130c,#15120e);border:1px solid #3a2c14;color:#f0d9b0;
  border-radius:var(--r2);padding:12px 14px;font-size:13px;line-height:1.5}
.tip b{color:#ffd98a}

/* LEGEND */
.legend{display:flex;flex-wrap:wrap;gap:14px;margin:-4px 2px 12px}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--mut);font-weight:500}
.ld{width:9px;height:9px;border-radius:3px;background:var(--dim)}
.ld.jeu{background:var(--red)} .ld.offre{background:var(--blue)} .ld.article{background:var(--ok)} .ld.culture{background:var(--amber)}

/* SLOTS */
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:9px}
.slot{background:var(--card);border:1px solid var(--line);border-radius:var(--r2);padding:11px 13px;position:relative;overflow:hidden}
.slot::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--dim)}
.slot.jeu::before{background:var(--red)} .slot.offre::before{background:var(--blue)} .slot.article::before{background:var(--ok)} .slot.culture::before{background:var(--amber)}
.slot .d{font-weight:700;font-size:13px}
.slot .h{color:var(--red2);font-weight:700;font-size:13px}
.slot .t{color:var(--mut);font-size:11.5px;margin-top:4px;line-height:1.35}

/* PLAN LIST */
.planhead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:24px 2px 12px}
.planhead .sub{margin:0}
.planlist{display:flex;flex-direction:column;gap:10px}
.pitem{background:var(--card);border:1px solid var(--line);border-radius:var(--r2);padding:13px 14px;
  display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}
.pitem .when{text-align:center;min-width:50px}
.pitem .when .day{font-family:var(--disp);font-weight:800;font-size:18px;line-height:1}
.pitem .when .mon{font-size:10px;text-transform:uppercase;color:var(--mut);letter-spacing:.5px}
.pitem .when .hr{font-size:11px;color:var(--red2);font-weight:700;margin-top:3px}
.pitem .mid .ttl{font-weight:600;font-size:14px;line-height:1.3}
.pitem .mid .meta{display:flex;gap:6px;align-items:center;margin-top:5px;flex-wrap:wrap}
.pitem .mid .note{font-size:11.5px;color:var(--dim);margin-top:4px}
.badge{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 7px;border-radius:6px;background:var(--card2);color:var(--mut);border:1px solid var(--line)}
.badge.offre{color:#9cc1ff;border-color:#24406b} .badge.jeu{color:#ff8a96;border-color:#5a2026} .badge.article{color:#88e0b4;border-color:#1e5238} .badge.culture{color:#f3cd82;border-color:#5a4418}
.st{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;cursor:pointer;border:1px solid;white-space:nowrap}
.st.todo{color:var(--mut);border-color:var(--line);background:var(--card2)}
.st.planned{color:#f3cd82;border-color:#5a4418;background:#1d1708}
.st.done{color:#fff;border-color:var(--ok);background:var(--ok)}
.pitem .del{background:none;border:none;color:var(--dim);font-size:16px;cursor:pointer;padding:4px}
.pitem .del:hover{color:var(--red2)}
.empty{color:var(--mut);text-align:center;padding:30px 16px;border:1px dashed var(--line);border-radius:var(--r2);font-size:14px}

/* CARDS (offres/jeux/articles) */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,transform .2s var(--ease)}
.card:hover{border-color:#39414a;transform:translateY(-2px)}
.card.done{border-color:var(--ok)}
.cph{position:relative;aspect-ratio:16/9;background:var(--bg2);cursor:zoom-in;overflow:hidden}
.cph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease)}
.card:hover .cph img{transform:scale(1.04)}
.cnum{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.6);border:1px solid var(--line);color:#fff;font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}
.cbody{padding:15px 16px 16px;display:flex;flex-direction:column;gap:10px;flex:1}
.clieu{color:var(--red2);font-weight:700;font-size:11px;letter-spacing:.5px;text-transform:uppercase}
.crole{font-family:var(--disp);font-weight:700;font-size:17px;line-height:1.2}
.ctech{display:inline-block;align-self:flex-start;font-size:11px;color:var(--mut);background:var(--card2);border:1px solid var(--line);padding:3px 9px;border-radius:7px}
.ctext{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r2);padding:13px 14px;font-size:13px;line-height:1.5;white-space:pre-wrap;color:#dce1e7;max-height:230px;overflow:auto}
.ctext::-webkit-scrollbar{width:7px}.ctext::-webkit-scrollbar-thumb{background:#2c3138;border-radius:8px}
.crow{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:auto}
.mini{font-size:11.5px;color:var(--mut);font-weight:600;margin:2px 0 -2px}
.note-cmt{background:#101319;border:1px dashed #2e353d;border-radius:10px;padding:10px 12px;font-size:12px;color:var(--mut);line-height:1.45}
.note-cmt b{color:#cfd5db}

/* BUTTONS */
.btn{border:1px solid var(--line);background:var(--card2);border-radius:10px;padding:9px 14px;font-weight:600;font-size:13px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:#3a3f47}
.btn.primary{background:var(--red);border-color:var(--red);color:#fff}
.btn.primary:hover{filter:brightness(1.1)}
.btn.full{width:100%;justify-content:center;padding:13px;font-size:14px;margin-top:8px}
.btn.copied{background:var(--ok);border-color:var(--ok);color:#fff}
.btn.sm{padding:7px 11px;font-size:12px}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.gcell{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--bg2);cursor:zoom-in;border:1px solid var(--line)}
.gcell img{width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .5s var(--ease),transform .4s var(--ease)}
.gcell img.in{opacity:1}
.gcell:hover img{transform:scale(1.06)}
.gcell .gid{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.55);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px}

/* TABBAR */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:50;height:calc(var(--sb) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);display:flex;background:rgba(13,14,17,.92);backdrop-filter:blur(16px);border-top:1px solid var(--line)}
.tab{flex:1;background:none;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--dim);font-size:10.5px;font-weight:600;cursor:pointer;transition:.18s;position:relative}
.tab .ic{font-size:19px;filter:grayscale(.6);opacity:.7;transition:.18s}
.tab.on{color:var(--txt)} .tab.on .ic{filter:none;opacity:1;transform:translateY(-1px)}
.tab.on::after{content:"";position:absolute;top:0;width:26px;height:3px;border-radius:0 0 3px 3px;background:var(--red)}

/* LIGHTBOX */
.lb{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.95);display:none;align-items:center;justify-content:center;flex-direction:column;gap:14px;padding:20px}
.lb.on{display:flex;animation:fade .2s}
.lb img{max-width:96vw;max-height:80vh;border-radius:10px;box-shadow:0 30px 90px rgba(0,0,0,.7)}
.lbdl{background:var(--red);color:#fff;font-weight:700;padding:11px 20px;border-radius:11px;text-decoration:none;font-size:14px}
.lbcap{color:var(--mut);font-size:13px}

/* SHEET */
.sheet{position:fixed;inset:0;z-index:95;background:rgba(0,0,0,.6);display:none;align-items:flex-end;justify-content:center}
.sheet.on{display:flex;animation:fade .2s}
.sheetcard{background:var(--card);border:1px solid var(--line);border-radius:20px 20px 0 0;width:100%;max-width:520px;
  padding:20px 20px calc(24px + env(safe-area-inset-bottom));animation:up .3s var(--ease)}
@keyframes up{from{transform:translateY(100%)}to{transform:none}}
@media(min-width:560px){.sheet{align-items:center}.sheetcard{border-radius:20px}}
.sheettop{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sheettop h3{font-size:18px;font-weight:700}
.sheettop .x{background:var(--card2);border:1px solid var(--line);border-radius:8px;width:30px;height:30px;cursor:pointer;color:var(--mut)}
.sheet label{display:block;font-size:12px;color:var(--mut);font-weight:600;margin:12px 0 5px}
.sheet input,.sheet select{width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:11px 12px;font-size:14px}
.sheet .two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.seg{display:flex;gap:6px}
.seg button{flex:1;background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:9px;font-size:12.5px;font-weight:600;color:var(--mut);cursor:pointer}
.seg button.on{background:var(--card2);color:var(--txt);border-color:#3a3f47}
.seg button[data-s="done"].on{background:var(--ok);border-color:var(--ok);color:#fff}
.seg button[data-s="planned"].on{background:#1d1708;border-color:#5a4418;color:#f3cd82}

/* TOAST */
.toast{position:fixed;bottom:calc(var(--sb) + 18px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(16px);
  background:var(--ok);color:#fff;font-weight:700;font-size:13.5px;padding:11px 18px;border-radius:11px;z-index:120;opacity:0;pointer-events:none;transition:.25s var(--ease)}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:560px){
  .cards{grid-template-columns:1fr}
  .stats{gap:8px}
  .gallery{grid-template-columns:repeat(3,1fr);gap:6px}
}
