:root{
  /* Palette Nouvelle-Calédonie & Pacifique */
  --ink:#0A2540;              /* bleu nuit profond (océan pacifique) */
  --ink-2:#143860;
  --line:#E2EEF2;             /* blanc nacré */
  --muted:#5e7a8c;            /* bleu gris coquillage */
  --bg:#F4F9FB;               /* écume blanche */
  --card:#ffffff;
  --accent:#0077B6;           /* bleu lagon */
  --accent-2:#06B6A6;         /* turquoise récif */
  --accent-3:#F4A261;         /* corail chaud (flamboyant) */
  --danger:#E63946;           /* rouge flamboyant */
  --warn:#F9A03F;             /* coucher de soleil */
  --ok:#2A9D8F;               /* vert mangrove */
  --yellow:#FFD166;           /* soleil Pacifique */
  --sand:#FBF4E8;             /* sable nacré */
  --kanak:#8B3A3A;            /* terre de case */
  --shadow: 0 4px 20px rgba(10,37,64,.08);
  --radius:10px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
body{
  font-family:-apple-system,"Inter","SF Pro Display","Segoe UI",sans-serif;
  background:
    radial-gradient(circle at 100% 0%, rgba(6,182,166,.07) 0, transparent 40%),
    radial-gradient(circle at 0% 100%, rgba(244,162,97,.05) 0, transparent 35%),
    var(--bg);
  color:var(--ink);min-height:100vh;
  letter-spacing:-0.01em;
}
/* Motif tapa subtil en filigrane (losanges kanak) */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.025;
  background-image:
    linear-gradient(45deg, var(--ink) 25%, transparent 25%),
    linear-gradient(-45deg, var(--ink) 25%, transparent 25%);
  background-size:24px 24px;
}

.top{padding:20px 28px;background:#fff;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.logo{
  width:44px;height:44px;border-radius:10px;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color:#fff;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-family:"SF Mono","Courier New",monospace;font-weight:800;font-size:16px;letter-spacing:-1px;
  box-shadow:0 4px 12px rgba(6,182,166,.3);
}
.logo::after{
  content:"";position:absolute;top:-4px;left:50%;transform:translateX(-50%);
  width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;
  border-bottom:10px solid var(--yellow);
}
.brand h1{font-size:18px;font-weight:700;letter-spacing:-.5px}
.brand p{color:var(--muted);font-size:12px;margin-top:2px}
.tabs{display:flex;flex-wrap:wrap;gap:4px}
.tab{
  padding:9px 14px;border:1px solid var(--line);background:#fff;
  border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;
  color:var(--ink-2);transition:all .15s;text-transform:uppercase;letter-spacing:.03em;
}
.tab:hover{border-color:var(--ink);color:var(--ink)}
.tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}

.stage{display:grid;grid-template-columns:auto 1fr;gap:40px;padding:40px;align-items:start;max-width:1400px;margin:0 auto}
@media(max-width:900px){.stage{grid-template-columns:1fr;padding:20px}}

.phone{
  width:380px;height:780px;background:#000;border-radius:44px;padding:10px;
  box-shadow:0 20px 50px rgba(0,0,0,.25), inset 0 0 0 2px #1a1a1a;
  position:relative;margin:0 auto;
}
.notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:100px;height:26px;background:#000;border-radius:0 0 16px 16px;z-index:10}
.home-indicator{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:120px;height:4px;background:#333;border-radius:4px}
.screen{width:100%;height:100%;background:var(--bg);border-radius:36px;overflow:hidden;position:relative}

.info{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);position:sticky;top:20px;border:1px solid var(--line)}
.info h2{margin-bottom:10px;font-size:16px;font-weight:700;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}
.info h2::before{content:"";width:3px;height:14px;background:var(--accent);display:inline-block}
.info p{font-size:13px;line-height:1.55;color:var(--ink-2)}
.info ul{margin:14px 0;padding:0;list-style:none}
.info li{margin:8px 0;font-size:13px;color:var(--ink-2);padding-left:14px;position:relative;line-height:1.5}
.info li::before{content:"";width:4px;height:4px;background:var(--ink);border-radius:50%;position:absolute;left:0;top:8px}
.info .badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;margin-right:6px;text-transform:uppercase;letter-spacing:.05em}
.badge.sec{background:#ffecec;color:#b91c1c}
.badge.ux{background:#e7f0ff;color:#0057FF}
.badge.nc{background:#e0faf5;color:#006b5f}

/* ========== Écrans mobiles ========== */
.m-status{height:44px;display:flex;justify-content:space-between;align-items:center;padding:0 22px;font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.3px}
.m-header{padding:14px 18px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.m-header h2{font-size:17px;font-weight:700;letter-spacing:-.3px}
.m-header .kicker{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:2px}
.m-avatar{width:34px;height:34px;border-radius:6px;background:var(--ink);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12px;letter-spacing:.02em}
.m-body{padding:16px;overflow-y:auto;height:calc(100% - 160px)}
.m-tabbar{position:absolute;bottom:0;left:0;right:0;height:68px;background:#fff;border-top:1px solid var(--line);display:flex;justify-content:space-around;align-items:flex-start;padding-top:8px}
.m-tabitem{flex:1;text-align:center;font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.m-tabitem.active{color:var(--ink)}
.m-tabitem .ic{display:block;height:22px;margin-bottom:4px;display:flex;align-items:center;justify-content:center}
.m-tabitem svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8}
.m-tabitem.active svg{stroke-width:2.2}

/* Bouton SOS — rouge flamboyant NC */
.sos{
  position:absolute;right:16px;bottom:84px;width:58px;height:58px;
  background:linear-gradient(135deg, #FF6B6B 0%, var(--danger) 100%);
  color:#fff;border:none;cursor:pointer;border-radius:50%;
  box-shadow:0 6px 16px rgba(230,57,70,.45), 0 0 0 4px rgba(230,57,70,.15);
  font-size:13px;font-weight:800;letter-spacing:.05em;
  display:flex;align-items:center;justify-content:center;z-index:5;
  font-family:"SF Mono",monospace;
}
.sos:hover{transform:scale(1.05)}

/* Cartes éditoriales */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:10px;position:relative}
.card .kicker{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:8px}
.card .kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.card h3{font-size:15px;font-weight:700;line-height:1.3;letter-spacing:-.2px;margin-bottom:4px}
.card p{font-size:12px;color:var(--muted);line-height:1.5}
.card .stat{display:flex;gap:20px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.card .stat .v{font-size:20px;font-weight:800;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.card .stat .l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:2px}

.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.chip .dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.chip.green{background:#e0faf5;color:#006b5f}.chip.green .dot{background:var(--ok)}
.chip.blue{background:#e7f0ff;color:var(--accent)}.chip.blue .dot{background:var(--accent)}
.chip.orange{background:#fff4e0;color:#a0570f}.chip.orange .dot{background:var(--warn)}
.chip.red{background:#ffecec;color:#b91c1c}.chip.red .dot{background:var(--danger)}
.chip.gray{background:#f1f3f6;color:var(--muted)}.chip.gray .dot{background:var(--muted)}

/* ========== ONBOARDING ========== */
.ob-hero{height:180px;background:var(--ink);color:#fff;padding:30px 24px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}
.ob-hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 80% 20%, rgba(0,87,255,.4) 0, transparent 40%),
  radial-gradient(circle at 10% 90%, rgba(0,194,168,.3) 0, transparent 40%);}
.ob-hero h1{font-size:28px;font-weight:800;letter-spacing:-.8px;position:relative;z-index:1}
.ob-hero .sub{font-size:13px;opacity:.75;margin-top:4px;position:relative;z-index:1}
.ob-hero .kicker{font-size:10px;opacity:.6;text-transform:uppercase;letter-spacing:.15em;margin-bottom:8px;position:relative;z-index:1}
.ob-content{padding:20px}
.ob-step{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);align-items:center}
.ob-step:last-child{border-bottom:none}
.ob-step .n{width:32px;height:32px;border-radius:8px;background:#f1f3f6;color:var(--muted);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;font-family:"SF Mono",monospace}
.ob-step h4{font-size:14px;font-weight:700;letter-spacing:-.2px}
.ob-step p{font-size:12px;color:var(--muted);margin-top:2px}
.ob-step.done .n{background:var(--ok);color:#fff}
.ob-step.current .n{background:var(--ink);color:#fff}
.ob-step.current{background:#f8fafc;margin:0 -20px;padding:14px 20px;border-radius:0;border-left:3px solid var(--accent)}

.btn-primary{display:flex;align-items:center;justify-content:center;width:100%;padding:16px;background:var(--ink);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:14px;margin-top:16px;cursor:pointer;text-transform:uppercase;letter-spacing:.08em}
.btn-primary:hover{background:var(--accent)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}

/* ========== CARTE QUARTIER — ambiance lagon NC ========== */
.hood{
  height:380px;position:relative;overflow:hidden;
  background:
    linear-gradient(180deg, #BCE8E3 0%, #C9E5DA 50%, #D7E8D1 100%);
}
.hood::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:24px;
  background:linear-gradient(180deg, transparent, rgba(6,182,166,.15));
  pointer-events:none;
}
.hood::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.5) 1px, transparent 1px);
  background-size: 40px 40px;
}
/* parcs / zones vertes */
.hood .park{position:absolute;background:#c4d9c0;border-radius:4px}
.hood .water{position:absolute;background:#a5c6d9;border-radius:6px;background:linear-gradient(135deg,#a5c6d9,#8db5c9)}

.road{position:absolute;background:#f5f6f8;box-shadow:0 0 0 1px #b4bec8}
.road.h{left:-10px;right:-10px;height:18px}
.road.v{top:-10px;bottom:-10px;width:18px}
.road.main{background:#fff;box-shadow:0 0 0 1px #8b95a3}
.road-label{
  position:absolute;font-size:9px;color:var(--ink-2);padding:1px 4px;font-weight:600;
  font-family:"SF Mono",monospace;letter-spacing:-.2px;
}

/* Maisons — inspirées de la case kanak (flèche faîtière) */
.house{
  position:absolute;width:30px;height:30px;cursor:pointer;
  background:#fff;border:1.5px solid var(--ink);border-radius:3px;
  transition:all .2s;display:flex;align-items:center;justify-content:center;
  font-family:"SF Mono",monospace;font-size:10px;font-weight:800;color:var(--ink);
}
.house::before{
  content:"";position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;
  border-bottom:10px solid var(--ink);
}
.house.me::before{border-bottom-color:var(--ink)}
.house.online::before{border-bottom-color:var(--ok)}
.house.alert::before{border-bottom-color:var(--danger)}
.house:hover{transform:scale(1.3);z-index:20;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.house.me{background:var(--ink);color:#fff;border-color:var(--ink);box-shadow:0 0 0 3px rgba(11,15,23,.15)}
.house.online{background:var(--ok);color:#fff;border-color:var(--ok)}
.house.online::after{content:"";position:absolute;top:-2px;right:-2px;width:6px;height:6px;background:var(--ok);border:1.5px solid #fff;border-radius:50%}
.house.alert{
  background:var(--danger);color:#fff;border-color:var(--danger);z-index:15;
  box-shadow:0 0 0 0 rgba(255,59,48,.8);
  animation:alertPulse 1.5s infinite;
}
@keyframes alertPulse{
  0%{box-shadow:0 0 0 0 rgba(255,59,48,.7)}
  70%{box-shadow:0 0 0 16px rgba(255,59,48,0)}
  100%{box-shadow:0 0 0 0 rgba(255,59,48,0)}
}
.house .tooltip{
  position:absolute;top:-24px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:#fff;font-size:9px;padding:2px 6px;border-radius:3px;
  white-space:nowrap;opacity:0;pointer-events:none;font-family:-apple-system,sans-serif;font-weight:600;
  transition:opacity .15s;letter-spacing:-.1px;
}
.house:hover .tooltip{opacity:1}
.house.alert .tooltip{opacity:1;background:var(--danger)}
.house.me .tooltip{opacity:1}

/* Tracé itinéraire */
.route{position:absolute;top:0;left:0;pointer-events:none;width:100%;height:100%}

/* Panneau infos alerte en haut de map */
.alert-banner{
  position:absolute;top:10px;left:10px;right:10px;
  background:var(--ink);color:#fff;border-radius:8px;padding:10px 14px;
  display:flex;align-items:center;gap:10px;z-index:5;
}
.alert-banner .live{
  display:flex;align-items:center;gap:6px;padding:3px 8px;background:var(--danger);
  border-radius:4px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  font-family:"SF Mono",monospace;
}
.alert-banner .live .pulse{width:6px;height:6px;border-radius:50%;background:#fff;animation:blink 1s infinite}
@keyframes blink{50%{opacity:.3}}
.alert-banner .title{flex:1;font-size:12px;font-weight:700}
.alert-banner .meta{font-size:10px;opacity:.7;margin-top:1px;font-variant-numeric:tabular-nums}

.route-info{
  position:absolute;left:12px;right:12px;bottom:12px;
  background:#fff;border-radius:8px;padding:12px 14px;
  display:flex;align-items:center;gap:12px;box-shadow:0 8px 24px rgba(0,0,0,.15);
  border:1px solid var(--line);
}
.route-info .dist{font-family:"SF Mono",monospace;font-size:22px;font-weight:800;letter-spacing:-1px;color:var(--ink)}
.route-info .meta{flex:1}
.route-info h4{font-size:12px;font-weight:700;letter-spacing:-.1px}
.route-info p{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:2px}
.route-info .go{padding:10px 14px;background:var(--ink);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}
.route-info .go:hover{background:var(--accent)}

.map-filters{position:absolute;top:62px;left:10px;right:10px;display:flex;gap:4px;z-index:5}
.map-filters .f{flex:1;padding:6px 8px;background:rgba(255,255,255,.95);font-size:10px;font-weight:700;text-align:center;border:1px solid var(--line);border-radius:4px;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-2);backdrop-filter:blur(8px)}
.map-filters .f.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ========== URGENCE ========== */
.sos-screen{background:var(--ink);height:100%;color:#fff;padding:30px 20px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.sos-screen::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 50% 0%, rgba(255,59,48,.15) 0, transparent 50%);pointer-events:none}
.sos-screen > *{position:relative}
.sos-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.sos-head .back{font-size:20px;cursor:pointer}
.sos-head h2{font-size:13px;text-transform:uppercase;letter-spacing:.15em;font-weight:800;font-family:"SF Mono",monospace}
.sos-intro{opacity:.7;margin-bottom:24px;font-size:12px;line-height:1.6;border-left:2px solid #fff;padding-left:12px;margin-top:8px}
.sos-level{
  display:block;width:100%;padding:20px;border-radius:8px;border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.03);color:#fff;font-size:16px;font-weight:800;margin:6px 0;text-align:left;cursor:pointer;
  text-transform:uppercase;letter-spacing:.05em;position:relative;
  transition:all .2s;
}
.sos-level:hover{background:rgba(255,255,255,.08);transform:translateX(4px)}
.sos-level small{display:block;font-weight:500;font-size:11px;opacity:.7;margin-top:6px;text-transform:none;letter-spacing:0;line-height:1.5}
.sos-level .code{font-family:"SF Mono",monospace;font-size:11px;opacity:.5;position:absolute;top:16px;right:16px}
.sos-level .bar{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:8px 0 0 8px}
.sos-level.l1 .bar{background:var(--ok)}
.sos-level.l2 .bar{background:var(--warn)}
.sos-level.l3 .bar{background:var(--danger)}
.sos-level.l3{border-color:rgba(255,59,48,.3);background:rgba(255,59,48,.08)}

.karma-bar{margin-top:auto;padding:14px 16px;background:rgba(255,255,255,.06);border-radius:8px;border:1px solid rgba(255,255,255,.08)}
.karma-bar .lbl{font-size:10px;opacity:.6;text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-bottom:6px}
.karma-bar .val{display:flex;align-items:baseline;gap:6px}
.karma-bar .val strong{font-size:24px;font-weight:800;font-family:"SF Mono",monospace}
.karma-bar .val span{font-size:12px;opacity:.7}
.karma-bar .track{margin-top:8px;height:3px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.karma-bar .fill{height:100%;width:87%;background:var(--ok)}

/* ========== JEU ========== */
.game-wrap{padding:16px}
.game-head{display:flex;justify-content:space-between;align-items:stretch;margin-bottom:16px;gap:10px}
.stat-block{flex:1;background:#fff;border:1px solid var(--line);border-radius:8px;padding:12px}
.stat-block .l{font-size:9px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--muted)}
.stat-block .v{font-size:26px;font-weight:800;letter-spacing:-1px;margin-top:2px;font-variant-numeric:tabular-nums;font-family:"SF Mono",monospace}
.stat-block.accent .v{color:var(--accent)}
.stat-block.warn .v{color:var(--warn)}

.game-board{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:10px;background:var(--ink);border-radius:8px;margin-bottom:14px}
.cell{aspect-ratio:1;border-radius:3px;background:rgba(255,255,255,.04)}
.cell.f1{background:#0057FF}
.cell.f2{background:#00C2A8}
.cell.f3{background:#FF9500}
.cell.f4{background:#FF3B30}
.cell.f5{background:#AF52DE}

.shop-item{display:flex;align-items:center;gap:12px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:8px;margin-bottom:6px}
.shop-ic{width:40px;height:40px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--ink);color:#fff}
.shop-item h3{font-size:13px;font-weight:700}
.shop-item p{font-size:11px;color:var(--muted);margin-top:2px}
.price{margin-left:auto;font-weight:800;font-family:"SF Mono",monospace;font-size:14px;letter-spacing:-.3px}

/* ========== CLASSEMENT ========== */
.rank-head{display:flex;padding:10px 16px;gap:6px;background:#fff;border-bottom:1px solid var(--line)}
.rank-head .f{padding:8px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border:1px solid var(--line);border-radius:6px;cursor:pointer}
.rank-head .f.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.rank-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#fff;border-bottom:1px solid var(--line)}
.rank-pos{
  width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;font-family:"SF Mono",monospace;
  background:#f1f3f6;color:var(--muted);
}
.rank-pos.top{background:var(--ink);color:#fff}
.rank-info{flex:1}
.rank-info h4{font-size:14px;font-weight:700;letter-spacing:-.2px}
.rank-info p{font-size:11px;color:var(--muted);margin-top:2px}
.rank-val{font-weight:800;font-family:"SF Mono",monospace;font-size:15px;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.rank-item.me{background:#f8fafc;border-left:3px solid var(--accent)}
.rank-delta{font-size:10px;color:var(--ok);margin-top:2px;font-weight:700;font-family:"SF Mono",monospace}
.rank-delta.down{color:var(--danger)}

/* ========== VIP ========== */
.vip-badge{
  display:inline-flex;align-items:center;gap:4px;padding:2px 8px;
  background:linear-gradient(135deg, #FFD166, #F4A261);
  color:#6B3410;border-radius:4px;font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;
  box-shadow:0 2px 6px rgba(244,162,97,.4);
}
.vip-badge::before{content:"✦"}

.plan{padding:20px;border-radius:12px;background:#fff;border:1px solid var(--line);margin-bottom:12px;position:relative;transition:all .2s}
.plan.vip{background:linear-gradient(135deg, #FBF4E8 0%, #fff 60%);border:2px solid var(--accent-3);box-shadow:0 6px 20px rgba(244,162,97,.2)}
.plan.vip::before{content:"VIP · OR";position:absolute;top:-10px;right:16px;background:linear-gradient(135deg, #FFD166, #F4A261);color:#6B3410;padding:4px 12px;border-radius:4px;font-size:10px;font-weight:800;letter-spacing:1.5px;box-shadow:0 2px 8px rgba(244,162,97,.4)}
.plan h3{font-size:14px;font-weight:800;letter-spacing:-.3px}
.plan .price{font-size:32px;font-weight:800;letter-spacing:-1.5px;margin:8px 0;font-family:"SF Mono",monospace}
.plan .price small{font-size:12px;opacity:.6;font-weight:600}
.plan ul{margin:12px 0 16px;padding-left:0;list-style:none}
.plan li{font-size:12px;color:var(--ink-2);padding:5px 0 5px 20px;position:relative;line-height:1.4}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:800}
.plan li.exclusive::before{content:"✦";color:var(--accent-3)}
.plan .cta{display:block;width:100%;padding:12px;border:none;border-radius:8px;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:1px;cursor:pointer}
.plan.basic .cta{background:var(--ink);color:#fff}
.plan.vip .cta{background:linear-gradient(135deg, #FFD166, #F4A261);color:#6B3410}

.info-svc{background:linear-gradient(135deg, rgba(255,209,102,.12) 0%, transparent 100%);border:1px solid rgba(244,162,97,.35);border-left:3px solid var(--accent-3)}
.info-svc .kicker .dot{background:var(--accent-3)}

/* ========== HALL DE LA RENOMMÉE ========== */
.hall{
  position:relative;padding:28px 18px 22px;border-radius:16px;margin-bottom:14px;overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,209,102,.18), transparent 55%),
    radial-gradient(ellipse at 50% 100%, rgba(244,162,97,.1), transparent 50%),
    linear-gradient(180deg, #0A1424 0%, #0F1A2B 100%);
  border:1px solid rgba(255,209,102,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 0 40px rgba(255,209,102,.05),
    0 10px 30px rgba(10,37,64,.35);
}
.hall::before{
  /* Texture noise + rayons */
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.4;
  background:
    repeating-conic-gradient(from 0deg at 50% 50%, transparent 0deg, rgba(255,209,102,.03) 3deg, transparent 6deg);
}
.hall-header{display:flex;align-items:center;justify-content:space-between;position:relative;margin-bottom:18px}
.hall-header .ornaments{display:flex;gap:4px;align-items:center;color:rgba(255,209,102,.4);font-size:14px}
.hall-header h3{font-family:"Georgia",serif;font-style:italic;color:#FFE58C;font-size:13px;letter-spacing:2px;text-transform:uppercase;font-weight:400;text-align:center;flex:1}

/* Médaille hero au centre */
.hero-medal{
  width:160px;height:160px;margin:0 auto 16px;position:relative;
  display:flex;align-items:center;justify-content:center;
}
.hero-medal .aura{
  position:absolute;inset:-20px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,209,102,.4) 0%, transparent 55%);
  animation:heroPulse 3s ease-in-out infinite;
}
@keyframes heroPulse{
  0%,100%{transform:scale(1);opacity:.8}
  50%{transform:scale(1.1);opacity:1}
}
.hero-medal .ring{
  position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg, #FFE58C, #C9941A, #6B3410, #C9941A, #FFE58C, #6B3410, #FFE58C);
  animation:spin 8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-medal .core{
  position:absolute;inset:8px;border-radius:50%;
  background:
    radial-gradient(circle at 30% 25%, #FFF5CC 0%, #FFE58C 20%, #E8B84B 45%, #C9941A 70%, #8B5A0A 100%);
  box-shadow:
    inset 0 4px 12px rgba(255,255,255,.5),
    inset 0 -6px 12px rgba(107,52,16,.5),
    0 4px 20px rgba(255,209,102,.5);
  display:flex;align-items:center;justify-content:center;
}
.hero-medal .core::before{
  /* Reflet qui brille */
  content:"";position:absolute;top:15%;left:20%;width:35%;height:25%;
  background:radial-gradient(ellipse, rgba(255,255,255,.7) 0%, transparent 70%);
  filter:blur(6px);
  animation:shimmer 4s ease-in-out infinite;
}
@keyframes shimmer{
  0%,100%{opacity:.6;transform:translateX(0)}
  50%{opacity:1;transform:translateX(10px)}
}
.hero-medal .core svg{position:relative;z-index:2;filter:drop-shadow(0 2px 3px rgba(107,52,16,.5))}
.hero-medal .tier{
  position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);
  background:linear-gradient(180deg, #FFE58C, #C9941A);
  color:#3d1f05;padding:4px 16px;border-radius:20px;
  font-family:"Georgia",serif;font-style:italic;font-weight:700;font-size:12px;letter-spacing:2px;
  border:1.5px solid #8B5A0A;
  box-shadow:0 3px 8px rgba(107,52,16,.5);
  z-index:3;
}

.hero-caption{text-align:center;color:#fff;margin-top:8px;position:relative}
.hero-caption .name{font-family:"Georgia",serif;font-size:20px;font-weight:700;letter-spacing:-.3px}
.hero-caption .desc{font-family:"Georgia",serif;font-style:italic;font-size:11px;color:rgba(255,209,102,.7);margin-top:3px;letter-spacing:.5px}
.hero-caption .stats{display:flex;justify-content:center;gap:20px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,209,102,.15)}
.hero-caption .stat-val{font-family:"SF Mono",monospace;font-size:16px;font-weight:800;color:#FFE58C;letter-spacing:-.5px}
.hero-caption .stat-lbl{font-size:9px;letter-spacing:1.5px;color:rgba(255,255,255,.4);text-transform:uppercase;margin-top:2px;font-weight:700}

/* Écrin de présentation des autres médailles */
.medal-case{
  margin-top:14px;padding:14px 10px;border-radius:12px;
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,.25) 0px, rgba(0,0,0,.25) 1px, transparent 1px, transparent 8px),
    linear-gradient(180deg, #1a1008 0%, #0D0904 100%);
  border:1px solid rgba(255,209,102,.15);
  box-shadow:inset 0 2px 4px rgba(0,0,0,.5);
  position:relative;
}
.medal-case::before{
  content:"ÉCRIN · COLLECTION";position:absolute;top:-8px;left:50%;transform:translateX(-50%);
  background:#0A1424;color:rgba(255,209,102,.6);
  padding:2px 10px;font-size:8px;letter-spacing:2px;font-family:"Georgia",serif;font-style:italic;
  border-radius:4px;border:1px solid rgba(255,209,102,.2);
}
.medal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.medal{
  aspect-ratio:.85;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  padding:10px 4px 10px;position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 15%, rgba(255,255,255,.05), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.02) 0%, rgba(0,0,0,.3) 100%);
  border:1px solid rgba(255,209,102,.08);
}
.medal .disc{width:44px;height:44px;border-radius:50%;position:relative;margin-bottom:6px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 2px 4px rgba(255,255,255,.4), inset 0 -2px 4px rgba(0,0,0,.3), 0 3px 8px rgba(0,0,0,.6);
}
.medal .disc svg{filter:drop-shadow(0 1px 1px rgba(0,0,0,.5))}
.medal .disc::before{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  background:conic-gradient(from 0deg, rgba(255,255,255,.4), transparent 30%, rgba(255,255,255,.2) 60%, transparent 90%);
  z-index:0;
}
.medal .disc::after{
  content:"";position:absolute;inset:3px;border-radius:50%;
  background:inherit;z-index:1;
}
.medal .disc > *{position:relative;z-index:2}
.medal .label{font-size:9px;font-family:"Georgia",serif;font-style:italic;color:rgba(255,255,255,.6);letter-spacing:.5px;text-align:center}
.medal .value{font-size:10px;font-family:"SF Mono",monospace;color:#fff;font-weight:800;letter-spacing:1px;margin-top:2px}

/* Tiers métalliques */
.medal.bronze .disc{background:radial-gradient(circle at 30% 30%, #D08C5A, #8B4513 70%)}
.medal.bronze .disc::after{background:radial-gradient(circle at 30% 30%, #D08C5A, #8B4513 70%)}
.medal.silver .disc{background:radial-gradient(circle at 30% 30%, #E8E8E8, #8A8A94 70%)}
.medal.silver .disc::after{background:radial-gradient(circle at 30% 30%, #E8E8E8, #8A8A94 70%)}
.medal.gold .disc{background:radial-gradient(circle at 30% 30%, #FFE58C, #C9941A 70%)}
.medal.gold .disc::after{background:radial-gradient(circle at 30% 30%, #FFE58C, #C9941A 70%)}
.medal.platinum .disc{background:radial-gradient(circle at 30% 30%, #E3ECEF, #7FA8B9 50%, #3A5B6B 100%)}
.medal.platinum .disc::after{background:radial-gradient(circle at 30% 30%, #E3ECEF, #7FA8B9 50%, #3A5B6B 100%)}
.medal.diamond .disc{background:radial-gradient(circle at 30% 30%, #E8F4FF, #9EC9E8 50%, #5FA0D2 100%)}
.medal.diamond .disc::after{background:radial-gradient(circle at 30% 30%, #E8F4FF, #9EC9E8 50%, #5FA0D2 100%)}

.medal.active{border-color:rgba(255,209,102,.5);background:linear-gradient(180deg, rgba(255,209,102,.08), rgba(244,162,97,.04) 100%), #12203A}
.medal.active::before{content:"ACTUEL";position:absolute;top:6px;right:6px;font-size:7px;font-weight:800;letter-spacing:1.5px;color:#FFD166;background:rgba(255,209,102,.12);padding:2px 5px;border-radius:3px}
.medal.locked{opacity:.35;filter:saturate(0.3)}
.medal.locked::after{content:"✕";position:absolute;top:10px;right:10px;font-size:10px;color:#fff;opacity:.4}

/* Couronne de laurier pour le contour */
.medal .laurel{position:absolute;inset:0;pointer-events:none;display:flex;align-items:flex-start;justify-content:center;padding-top:6px}
.medal .laurel svg{width:64px;height:56px;opacity:.25}

/* Ruban sous la médaille */
.medal .ribbon{display:inline-block;width:22px;height:10px;background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:0 0 3px 3px;margin-top:-4px;position:relative;z-index:0}
.medal .ribbon::before,.medal .ribbon::after{content:"";position:absolute;top:0;width:6px;height:10px;background:inherit}
.medal .ribbon::before{left:-4px;clip-path:polygon(0 0, 100% 0, 100% 100%, 50% 60%, 0 100%)}
.medal .ribbon::after{right:-4px;clip-path:polygon(0 0, 100% 0, 100% 100%, 50% 60%, 0 100%)}

/* ========== TROPHÉES LUXE ========== */
.trophy-card{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:16px 18px;
  background:
    radial-gradient(ellipse at top right, rgba(255,209,102,.12) 0%, transparent 60%),
    linear-gradient(180deg, #111D33, #0A1424);
  border:1px solid rgba(255,209,102,.15);
  border-radius:12px;margin-bottom:10px;position:relative;overflow:hidden;
  color:#fff;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 4px 12px rgba(10,37,64,.4);
}
/* Ornements dorés aux 4 coins */
.trophy-card::before,.trophy-card::after{
  content:"";position:absolute;width:14px;height:14px;pointer-events:none;
}
.trophy-card::before{
  top:4px;left:4px;
  border-top:1px solid rgba(255,209,102,.5);
  border-left:1px solid rgba(255,209,102,.5);
}
.trophy-card::after{
  bottom:4px;right:4px;
  border-bottom:1px solid rgba(255,209,102,.5);
  border-right:1px solid rgba(255,209,102,.5);
}
.trophy-card::before{
  content:"";position:absolute;top:0;right:0;width:120px;height:120px;
  background:radial-gradient(circle, rgba(255,209,102,.15), transparent 60%);pointer-events:none;
}
.trophy-card .crest{
  width:54px;height:54px;border-radius:50%;position:relative;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 30% 25%, #FFF5CC 0%, #FFE58C 25%, #C9941A 75%, #6B3410 100%);
  box-shadow:
    inset 0 2px 4px rgba(255,255,255,.5),
    inset 0 -2px 6px rgba(107,52,16,.4),
    0 4px 10px rgba(201,148,26,.5);
}
.trophy-card .crest::before{
  content:"";position:absolute;inset:-3px;border-radius:50%;z-index:-1;
  background:conic-gradient(from 0deg, #FFE58C, #6B3410, #FFE58C, #C9941A, #FFE58C);
  animation:spin 12s linear infinite;
}
.trophy-card .crest svg{width:32px;height:32px}
.trophy-card h4{font-family:"Georgia",serif;font-size:15px;font-weight:700;letter-spacing:-.2px;color:#FFE58C}
.trophy-card p{font-size:11px;color:rgba(255,255,255,.55);margin-top:2px;letter-spacing:.02em}
.trophy-card .date{font-family:"SF Mono",monospace;font-size:10px;color:rgba(255,255,255,.4);letter-spacing:1px}

.trophy-card.locked{background:#F5F6F8;color:var(--ink);border:1px dashed #CBD5DC}
.trophy-card.locked p{color:var(--muted)}
.trophy-card.locked::before{display:none}
.trophy-card.locked .crest{background:#E2EEF2}
.trophy-card.locked .progress{height:3px;background:var(--line);border-radius:2px;margin-top:6px;overflow:hidden}
.trophy-card.locked .progress > span{display:block;height:100%;background:var(--accent-2)}

/* ========== FOYER ========== */
.sub-card{
  padding:20px;border-radius:10px;background:var(--ink);color:#fff;
  position:relative;overflow:hidden;
}
.sub-card::before{content:"";position:absolute;right:-40px;top:-40px;width:140px;height:140px;background:var(--accent);border-radius:50%;opacity:.3}
.sub-card .k{font-size:10px;text-transform:uppercase;letter-spacing:.1em;opacity:.6;font-weight:700;position:relative}
.sub-card .v{font-size:32px;font-weight:800;letter-spacing:-1px;margin-top:4px;position:relative;font-family:"SF Mono",monospace}
.sub-card .sub{font-size:11px;opacity:.7;margin-top:2px;position:relative}
.sub-card .actions{display:flex;gap:8px;margin-top:14px;position:relative}
.sub-card .actions button{padding:6px 12px;background:rgba(255,255,255,.1);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;cursor:pointer}

.section-title{font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--muted);margin:20px 0 8px}
.member{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:8px;margin-bottom:6px}
.m-av{width:38px;height:38px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12px;letter-spacing:.02em}
.m-av.admin{background:var(--ink)}
.m-av.mb{background:var(--accent)}
.m-av.add{background:transparent;color:var(--ink);border:1.5px dashed var(--line)}
.member h4{font-size:13px;font-weight:700}
.member p{font-size:11px;color:var(--muted);margin-top:2px}

/* ========== CHAT ========== */
.chat-search{padding:10px 16px;background:#fff;border-bottom:1px solid var(--line)}
.chat-search input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--line);border-radius:6px;font-size:13px;outline:none;font-family:inherit}
.chat-list{padding:0;overflow-y:auto}
.chat-room{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);cursor:pointer;background:#fff;align-items:center}
.chat-room:hover{background:var(--bg)}
.chat-av{width:42px;height:42px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:14px;letter-spacing:-.2px;flex-shrink:0}
.chat-av.general{background:var(--ink)}
.chat-av.entraide{background:var(--accent-2)}
.chat-av.securite{background:var(--danger)}
.chat-av.evt{background:#AF52DE}
.chat-av.dm{background:var(--muted)}
.chat-meta{flex:1;min-width:0}
.chat-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3px}
.chat-top h4{font-size:14px;font-weight:700;letter-spacing:-.2px}
.chat-top time{font-size:10px;color:var(--muted);text-transform:uppercase;font-weight:600;letter-spacing:.05em;font-family:"SF Mono",monospace}
.chat-preview{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}
.unread{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--danger);color:#fff;border-radius:9px;font-size:10px;font-weight:800;font-family:"SF Mono",monospace;flex-shrink:0}

/* ========== CALENDRIER AVENT NC ========== */
.avent-card{
  margin:0 16px 12px;padding:16px;border-radius:14px;position:relative;overflow:hidden;
  background:linear-gradient(135deg, #8B0000 0%, #2D0808 100%);color:#fff;
}
.avent-card::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 20% 30%, rgba(255,255,255,.15) 0, transparent 40%),
             radial-gradient(circle at 80% 70%, rgba(255,209,102,.2) 0, transparent 50%);}
.avent-kicker{font-size:10px;letter-spacing:2px;text-transform:uppercase;font-weight:800;color:#FFD166;margin-bottom:8px;position:relative}
.avent-title{font-family:"Georgia",serif;font-size:18px;font-weight:700;letter-spacing:-.3px;position:relative;margin-bottom:12px}
.avent-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;position:relative}
.avent-day{aspect-ratio:1;border-radius:6px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;
  font-family:"SF Mono",monospace;font-size:11px;font-weight:800;color:rgba(255,255,255,.5);cursor:pointer;position:relative}
.avent-day.opened{background:linear-gradient(135deg,#FFD166,#C9941A);color:#3d1f05}
.avent-day.opened::before{content:"✓";position:absolute}
.avent-day.today{background:rgba(255,209,102,.25);color:#FFD166;border:1.5px solid #FFD166;animation:flamePulse 1.5s ease-in-out infinite alternate}
.avent-day.locked{opacity:.35}

/* ========== RECETTE DU JOUR ========== */
.recipe-card{
  margin:0 16px 12px;padding:0;border-radius:12px;overflow:hidden;background:#fff;border:1px solid var(--line);
}
.recipe-hero{
  height:120px;background:linear-gradient(135deg,#F4A261 0%,#E63946 100%);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;font-size:60px;
}
.recipe-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.3))}
.recipe-badge{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);color:#fff;padding:4px 10px;border-radius:4px;font-size:9px;letter-spacing:1.5px;font-weight:800;z-index:1}
.recipe-body{padding:14px}
.recipe-body h3{font-family:"Georgia",serif;font-size:16px;font-weight:700;letter-spacing:-.3px}
.recipe-body p{font-size:11px;color:var(--muted);margin-top:2px}
.recipe-meta{display:flex;gap:12px;margin-top:8px;font-size:10px;color:var(--muted);font-family:"SF Mono",monospace;font-weight:700}

/* ========== SERVICES · Artisans ========== */
.service-hero{padding:16px;background:linear-gradient(135deg,#0A2540,#0077B6);color:#fff;margin-bottom:14px}
.service-hero .k{font-size:10px;letter-spacing:2px;opacity:.7;font-weight:700}
.service-hero h2{font-family:"Georgia",serif;font-size:20px;letter-spacing:-.5px;margin-top:2px}
.service-hero .sub{font-size:11px;opacity:.7;margin-top:4px}

.artisan{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:6px;position:relative}
.artisan .av{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}
.artisan h4{font-size:13px;font-weight:700}
.artisan .spec{font-size:11px;color:var(--muted);margin-top:2px}
.artisan .stars{display:flex;gap:2px;margin-top:4px;font-size:10px;color:#FFD166}
.artisan .stars span{color:var(--muted)}
.artisan .verified{position:absolute;top:10px;right:10px;background:#e0faf5;color:#006b5f;padding:2px 7px;border-radius:3px;font-size:9px;font-weight:800;letter-spacing:1px}

/* ========== BONS PLANS ========== */
.deal{display:flex;gap:10px;padding:10px;background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:6px;align-items:center}
.deal .badge{width:44px;height:44px;border-radius:8px;background:linear-gradient(135deg,#FFD166,#F4A261);color:#3d1f05;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;flex-shrink:0;text-align:center;line-height:1;padding:4px}
.deal h4{font-size:13px;font-weight:700}
.deal .where{font-size:10px;color:var(--muted);margin-top:2px}
.deal .votes{margin-left:auto;text-align:right;font-family:"SF Mono",monospace}
.deal .votes .n{font-size:14px;font-weight:800;color:var(--ok)}
.deal .votes .l{font-size:8px;color:var(--muted);letter-spacing:.5px;text-transform:uppercase}

/* ========== LISTE NOIRE ========== */
.warn-card{padding:14px;background:linear-gradient(135deg,rgba(230,57,70,.08),#fff);border:1px solid rgba(230,57,70,.3);border-left:3px solid var(--danger);border-radius:10px;margin-bottom:6px}
.warn-card .k{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-weight:800;color:var(--danger);margin-bottom:4px}
.warn-card h4{font-size:13px;font-weight:700}
.warn-card p{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.5}
.warn-card .reports{display:flex;gap:10px;margin-top:6px;font-size:10px;color:var(--danger);font-family:"SF Mono",monospace;font-weight:700}

/* ========== PANIER SOLIDAIRE + BOURSE ========== */
.solidaire{padding:14px;background:linear-gradient(135deg,rgba(42,157,143,.08),#fff);border:1px solid rgba(42,157,143,.2);border-radius:10px;margin-bottom:6px;display:flex;gap:10px;align-items:center}
.solidaire .ic{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--ok),var(--accent-2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.solidaire h4{font-size:13px;font-weight:700}
.solidaire p{font-size:11px;color:var(--muted);margin-top:2px}
.solidaire .cta{padding:7px 12px;background:var(--ok);color:#fff;border:none;border-radius:6px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1px}

/* ========== MODE ENFANT ========== */
.kid-toggle{padding:16px;border-radius:12px;background:linear-gradient(135deg,#AF52DE 0%,#7C3AED 100%);color:#fff;margin-bottom:12px;position:relative;overflow:hidden}
.kid-toggle::before{content:"";position:absolute;right:-20px;top:-20px;width:120px;height:120px;background:radial-gradient(circle,rgba(255,255,255,.2),transparent 60%);pointer-events:none}
.kid-toggle .k{font-size:10px;letter-spacing:2px;opacity:.7;font-weight:800;text-transform:uppercase}
.kid-toggle h3{font-family:"Georgia",serif;font-size:18px;margin-top:2px}
.kid-toggle p{font-size:11px;opacity:.85;margin-top:6px;line-height:1.5}
.kid-toggle .switch{display:flex;align-items:center;gap:10px;margin-top:12px}
.kid-toggle .switch-track{width:48px;height:26px;background:rgba(0,0,0,.3);border-radius:13px;position:relative}
.kid-toggle .switch-track::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.2s}
.kid-toggle.active .switch-track{background:var(--accent-2)}
.kid-toggle.active .switch-track::after{left:25px}
.kid-toggle .switch-label{font-size:11px;font-weight:700;letter-spacing:.5px}

/* ========== STORIES 24H (horizontal scroll) ========== */
.stories{display:flex;gap:10px;padding:14px 16px 4px;overflow-x:auto;scrollbar-width:none}
.stories::-webkit-scrollbar{display:none}
.story{flex-shrink:0;width:62px;text-align:center;cursor:pointer}
.story-ring{
  width:62px;height:62px;border-radius:50%;padding:2.5px;
  background:conic-gradient(from 0deg, #FFD166, #E63946, #06B6A6, #0077B6, #FFD166);
  position:relative;
}
.story-ring::before{content:"";position:absolute;inset:2.5px;border-radius:50%;background:#fff}
.story.seen .story-ring{background:conic-gradient(from 0deg, #C8D0D8, #C8D0D8);opacity:.5}
.story-ring .av{
  position:relative;z-index:1;width:100%;height:100%;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;letter-spacing:-.5px;
}
.story.me .story-ring{background:linear-gradient(135deg, var(--ink), var(--accent-2));padding:2px}
.story.me .story-ring::before{inset:2px}
.story.me .story-ring::after{
  content:"+";position:absolute;bottom:-2px;right:-2px;width:20px;height:20px;
  background:var(--accent);color:#fff;border-radius:50%;font-size:16px;font-weight:800;
  display:flex;align-items:center;justify-content:center;border:2px solid #fff;z-index:2;
}
.story-name{font-size:10px;margin-top:4px;color:var(--muted);font-weight:600;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ========== BONJOUR + STREAK ========== */
.bonjour{
  padding:16px;border-radius:14px;margin:0 16px 12px;position:relative;overflow:hidden;
  background:linear-gradient(135deg, #0A2540 0%, #0077B6 60%, #06B6A6 120%);
  color:#fff;
}
.bonjour::before{
  content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;
  background:radial-gradient(circle, rgba(255,209,102,.5), transparent 60%);pointer-events:none;
}
.bonjour .hi{font-size:11px;opacity:.7;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
.bonjour .name{font-family:"Georgia",serif;font-size:22px;font-weight:700;letter-spacing:-.5px;margin-top:2px}
.bonjour .meta{font-size:12px;opacity:.85;margin-top:6px;display:flex;gap:16px;flex-wrap:wrap}
.bonjour .meta span{display:flex;align-items:center;gap:4px}

.streak{
  display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:12px;
  border-top:1px solid rgba(255,255,255,.15);
}
.flame{
  width:36px;height:44px;position:relative;
  background:linear-gradient(180deg, #FFD166 0%, #F4A261 50%, #E63946 100%);
  border-radius:50% 50% 50% 50% / 60% 60% 40% 40%;
  transform-origin:bottom center;animation:flamePulse 1.2s ease-in-out infinite alternate;
  box-shadow:0 0 20px rgba(244,162,97,.6), 0 0 40px rgba(230,57,70,.3);
}
.flame::before{content:"";position:absolute;bottom:5px;left:50%;transform:translateX(-50%);
  width:50%;height:60%;background:linear-gradient(180deg, #FFF5CC, #FFD166);border-radius:50%;filter:blur(1px)}
@keyframes flamePulse{from{transform:scale(1) skewX(0)}to{transform:scale(1.08) skewX(-3deg)}}
.streak-info{flex:1}
.streak-info .d{font-family:"SF Mono",monospace;font-size:22px;font-weight:800;letter-spacing:-.5px}
.streak-info .l{font-size:10px;opacity:.7;letter-spacing:1.2px;text-transform:uppercase;font-weight:700;margin-top:2px}
.streak-next{text-align:right;font-size:11px;opacity:.7;font-family:"SF Mono",monospace}

/* ========== MOT KANAK ========== */
.kanak-card{
  margin:0 16px 12px;padding:14px 16px;border-radius:12px;position:relative;
  background:
    linear-gradient(135deg, #FBF4E8 0%, #fff 60%);
  border:1px solid rgba(139,58,58,.15);
  overflow:hidden;
}
.kanak-card::before{
  content:"";position:absolute;top:0;right:0;bottom:0;width:80px;
  background:
    linear-gradient(45deg, transparent 49%, rgba(139,58,58,.1) 49%, rgba(139,58,58,.1) 51%, transparent 51%),
    linear-gradient(-45deg, transparent 49%, rgba(139,58,58,.1) 49%, rgba(139,58,58,.1) 51%, transparent 51%);
  background-size:12px 12px;pointer-events:none;
}
.kanak-kicker{font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--kanak);font-weight:800;margin-bottom:6px}
.kanak-word{font-family:"Georgia",serif;font-size:28px;font-weight:700;letter-spacing:-.5px;color:var(--kanak);line-height:1.1}
.kanak-lang{font-size:10px;color:var(--muted);font-style:italic;margin-top:2px}
.kanak-translation{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(139,58,58,.2);font-size:13px;color:var(--ink-2)}
.kanak-translation strong{color:var(--ink);font-weight:700}

/* ========== MINI-MISSIONS ========== */
.mission{
  margin:0 16px 8px;padding:14px 16px;border-radius:12px;
  background:#fff;border:1px solid var(--line);border-left:3px solid var(--accent-2);
  display:flex;align-items:center;gap:12px;
}
.mission .ic{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg, var(--accent-2), var(--ok));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}
.mission .meta{flex:1}
.mission h4{font-size:13px;font-weight:700}
.mission .needs{font-size:11px;color:var(--muted);margin-top:2px;display:flex;gap:10px}
.mission .needs span{font-family:"SF Mono",monospace;font-weight:700;color:var(--ink)}
.mission .go{padding:8px 14px;background:var(--ink);color:#fff;border:none;border-radius:6px;
  font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1px;cursor:pointer}
.mission.urgent{border-left-color:var(--danger)}
.mission.urgent .ic{background:linear-gradient(135deg, #FF6B6B, var(--danger))}

/* ========== COLLECTION CARTES NC ========== */
.collection{
  margin:16px 0;padding:16px;border-radius:14px;
  background:linear-gradient(180deg, #1a1008 0%, #0D0904 100%);
  color:#fff;position:relative;overflow:hidden;
}
.collection::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.12;
  background:repeating-linear-gradient(45deg, transparent, transparent 12px, rgba(255,209,102,.15) 12px, rgba(255,209,102,.15) 13px);
}
.collection-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;position:relative}
.collection-head h3{font-family:"Georgia",serif;font-size:13px;font-style:italic;color:#FFE58C;letter-spacing:1px}
.collection-head .progress{font-family:"SF Mono",monospace;font-size:14px;font-weight:800;color:#FFE58C}
.cards-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;position:relative}
.card-nc{
  aspect-ratio:.7;border-radius:6px;position:relative;overflow:hidden;
  background:linear-gradient(135deg, rgba(255,209,102,.08), rgba(255,255,255,.02));
  border:1px solid rgba(255,209,102,.15);
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.card-nc.owned{
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  border-color:rgba(255,255,255,.3);
  box-shadow:inset 0 0 10px rgba(255,255,255,.15);
}
.card-nc.rare{background:linear-gradient(135deg, #FFD166, #F4A261);border-color:#C9941A;box-shadow:0 0 8px rgba(255,209,102,.4)}
.card-nc.locked{opacity:.3;color:rgba(255,255,255,.3)}
.card-nc .rarity{position:absolute;top:3px;right:3px;font-size:8px;color:#FFE58C;font-weight:800;letter-spacing:1px;font-family:"SF Mono",monospace}
.card-nc .num{position:absolute;bottom:3px;left:4px;font-size:7px;opacity:.5;font-family:"SF Mono",monospace}

/* ========== ACCUEIL ========== */
.feed-head{padding:20px 16px 12px;display:flex;justify-content:space-between;align-items:flex-end}
.feed-head .kicker{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:700}
.feed-head h1{font-size:24px;font-weight:800;letter-spacing:-.8px;margin-top:2px}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 16px 16px}
.stat-tile{background:#fff;border:1px solid var(--line);border-radius:8px;padding:12px}
.stat-tile .k{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700}
.stat-tile .v{font-size:22px;font-weight:800;letter-spacing:-.8px;margin-top:2px;font-family:"SF Mono",monospace}
.stat-tile .d{font-size:10px;color:var(--ok);margin-top:2px;font-weight:700;font-family:"SF Mono",monospace}
.stat-tile .d.down{color:var(--danger)}
