/* WE OUTSIDE — mini-app démo V3, direction « Épuré d'abord ».
   Tokens = charte we-outside-brand, aucun hex hors variables. */
:root{
  --bg:#141416; --surface:#1D1D21; --border:#26262B; --border2:#2E2E34;
  --txt:#FFFFFF; --txt2:#9A9AA2; --txt3:#6D6D75;
  --gold:#E8B84B; --coral:#D85A30; --green:#1D9E75; --on-gold:#2A2410;
  --violet:#3A2F52; --teal:#0F6E56; --bordeaux:#503038; --nuit:#1D3A52;
  --violet2:#2E2352; --surface2:#232028;
  --hairline:rgba(255,255,255,.08); --hairline2:rgba(255,255,255,.12);
  --veil:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0) 42%);
  --shadow-soft:0 20px 44px -24px rgba(0,0,0,.65);
  --r-card:14px; --r-pill:22px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{height:100%}
body{background:var(--bg);color:var(--txt);
  font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.5;
  min-height:100%;overflow-x:hidden}
.display{font-family:'Unbounded','Inter',sans-serif}
button{font-family:inherit;cursor:pointer;color:inherit}
a{color:inherit}
img{max-width:100%;display:block}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:4px}

/* glows chauds en dérive très lente (passe vivante V3.3, transform only) */
body::before{content:"";position:fixed;inset:-22%;z-index:-1;pointer-events:none;
  background:radial-gradient(560px 400px at 18% 22%,rgba(216,90,48,.06),transparent 70%),
             radial-gradient(680px 500px at 84% 72%,rgba(232,184,75,.045),transparent 70%),
             radial-gradient(500px 420px at 60% 10%,rgba(58,47,82,.13),transparent 70%);
  animation:glow-drift 30s ease-in-out infinite alternate}
@keyframes glow-drift{to{transform:translate(2.5%,1.8%) scale(1.02)}}

/* grain subtil — tue l'aplat numérique (charte Matière & Typo) */
body::after{content:"";position:fixed;inset:0;z-index:120;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ===== coquille ===== */
.app{max-width:520px;margin:0 auto;min-height:100dvh;position:relative;
  display:flex;flex-direction:column;padding-bottom:84px}
@media(min-width:560px){.app{border-left:1px solid var(--hairline);border-right:1px solid var(--hairline)}}

.demo-badge{position:fixed;top:12px;right:12px;z-index:60;background:var(--coral);color:var(--bg);
  font-size:10px;font-weight:600;letter-spacing:.12em;padding:5px 11px;border-radius:var(--r-pill);text-transform:uppercase}

/* ===== écrans + transition sobre (200 ms, transform/opacity) ===== */
.screen{display:none;flex-direction:column;flex:1;padding:0 20px}
.screen.on{display:flex;animation:screen-in .2s ease both}
@keyframes screen-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.screen-title{font-family:'Unbounded';font-weight:600;font-size:22px;letter-spacing:-.02em;line-height:1.15;margin:26px 0 6px}
.screen-sub{color:var(--txt2);font-size:14px;margin-bottom:20px}

/* ===== header feed ===== */
.app-head{padding:22px 0 0}
.logo{font-family:'Unbounded';font-weight:800;font-size:15px;letter-spacing:.04em;
  text-decoration:none;white-space:nowrap;display:inline-block}
.logo span{color:var(--gold)}
.islands{display:flex;gap:8px;margin-top:18px}
.isl{background:transparent;border:1px solid var(--hairline2);color:var(--txt2);
  font-size:13px;font-weight:600;padding:8px 16px;border-radius:var(--r-pill);min-height:36px;
  display:inline-flex;align-items:center;
  transition:transform .15s,background-color .15s,color .15s}
.isl img{display:none;height:14px;width:auto;border-radius:2px;margin-right:8px}
.isl[aria-pressed="true"]{background:var(--gold);color:var(--on-gold);border-color:var(--gold)}
.isl[aria-pressed="true"] img{display:block;animation:flag-in .3s cubic-bezier(.22,.61,.36,1)}
@keyframes flag-in{from{opacity:0;transform:translateX(-5px) scale(.7)}to{opacity:1;transform:none}}
.isl:active{transform:scale(.96)}

/* ===== pills de filtres (taxonomie) ===== */
.filters{display:flex;gap:8px;overflow-x:auto;padding:18px 20px;margin:0 -20px;scrollbar-width:none}
.filters::-webkit-scrollbar{display:none}
.pill{flex-shrink:0;background:transparent;border:1px solid var(--hairline2);color:var(--txt2);
  font-size:13px;font-weight:500;padding:8px 16px;border-radius:var(--r-pill);min-height:36px;
  transition:transform .15s,background-color .15s,color .15s}
.pill[aria-pressed="true"]{background:var(--gold);color:var(--on-gold);border-color:var(--gold);font-weight:600}
.pill:active{transform:scale(.96)}

/* ===== sections ===== */
.sec-head{display:flex;justify-content:space-between;align-items:baseline;margin:14px 0 16px}
.sec-head h2{font-weight:600;font-size:15px;letter-spacing:.01em}
.sec-head .hint{color:var(--txt2);font-size:12px}
.fallback-note{color:var(--txt2);font-size:13.5px;padding:14px 0 10px}
.fallback-note b{color:var(--txt)}
.empty{color:var(--txt2);font-size:14px;text-align:center;padding:44px 20px}
.empty b{display:block;color:var(--txt);margin-bottom:6px;font-size:15px}

/* ===== affiches procédurales (SVG) — palettes par catégorie ===== */
.po-zouk{--pa:var(--violet);--pb:var(--gold)}
.po-bal{--pa:var(--violet);--pb:var(--coral)}
.po-after{--pa:var(--teal);--pb:var(--gold)}
.po-concert{--pa:var(--nuit);--pb:var(--teal)}
.po-club{--pa:var(--bordeaux);--pb:var(--coral)}
.po-soiree{--pa:var(--violet2);--pb:var(--teal)}
.po-festival{--pa:var(--nuit);--pb:var(--coral)}
.po-carnaval{--pa:var(--coral);--pb:var(--bordeaux)}
.po-yoles{--pa:var(--teal);--pb:var(--nuit)}
.po-spectacle{--pa:var(--bordeaux);--pb:var(--gold)}
.po-loisir{--pa:var(--teal);--pb:var(--green)}
.poster{width:100%;height:100%;display:block}
.poster .p-bg{fill:var(--surface2)}
.poster .p-a{fill:var(--pa)}
.poster .p-b{fill:var(--pb)}
.poster .p-line{stroke:var(--pb);stroke-width:1.4;fill:none;opacity:.8}
.poster text{font-family:'Unbounded','Inter',sans-serif;font-weight:800;fill:var(--txt);letter-spacing:.5px}
.poster .p-sub{font-family:'Inter';font-weight:500;fill:var(--txt2);letter-spacing:2.5px}

/* ===== cartes feed (épurées : cover, titre, une ligne, prix) ===== */
.card{display:block;width:100%;background:none;border:none;text-align:left;color:var(--txt);
  margin-bottom:30px;border-radius:var(--r-card);transition:transform .3s cubic-bezier(.22,.61,.36,1)}
.card:hover{transform:translateY(-4px)}
.card:active{transform:scale(.985)}
.card.anim-in{animation:card-in .45s cubic-bezier(.22,.61,.36,1) both}
@keyframes card-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.card .cover{aspect-ratio:16/10;border-radius:var(--r-card);overflow:hidden;position:relative;background:var(--surface2);
  outline:1px solid var(--hairline);outline-offset:-1px;box-shadow:var(--shadow-soft)}
.card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .35s cubic-bezier(.22,.61,.36,1)}
.card:hover .cover img{transform:scale(1.045)}
.card .going{color:var(--txt2)}
.card .going .cnt{color:var(--txt);font-weight:500;font-variant-numeric:tabular-nums}
.card .tag{position:absolute;top:10px;left:10px;background:rgba(20,20,22,.55);color:var(--txt);
  font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  padding:4px 11px;border-radius:12px;backdrop-filter:blur(8px);
  box-shadow:inset 0 0 0 1px var(--hairline)}
.card .body{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:12px 2px 0}
.card h3{font-size:17px;font-weight:600;letter-spacing:-.015em;line-height:1.25}
.card .meta{color:var(--txt2);font-size:14px;line-height:1.5;margin-top:4px}
.card .price{color:var(--gold);font-weight:600;font-size:15px;white-space:nowrap;font-variant-numeric:tabular-nums}
.card .price.free{color:var(--green)}

/* bande horizontale « À l'affiche » (réels, sobres) */
.strip{display:flex;gap:14px;overflow-x:auto;padding:2px 20px 8px;margin:0 -20px;
  scroll-snap-type:x mandatory;scrollbar-width:none}
.strip::-webkit-scrollbar{display:none}
.card-w{min-width:210px;max-width:210px;scroll-snap-align:start;background:none;border:none;
  text-align:left;color:var(--txt);border-radius:var(--r-card);transition:transform .18s;padding:0}
.card-w:active{transform:scale(.97)}
.card-w .cover{aspect-ratio:16/10;border-radius:var(--r-card);overflow:hidden;position:relative;background:var(--surface2)}
.card-w h3{font-size:13.5px;font-weight:600;line-height:1.3;margin-top:10px}
.card-w .meta{color:var(--txt2);font-size:12px;margin-top:2px}
.card-w .date{color:var(--txt2);font-size:12px;font-weight:600;margin-top:6px}

/* ===== skeletons ===== */
.sk{background:var(--surface);border-radius:var(--r-card);animation:sk-pulse 1.1s ease-in-out infinite alternate}
.sk-cover{aspect-ratio:16/10;margin-bottom:12px}
.sk-line{height:16px;width:60%;margin-bottom:30px}
@keyframes sk-pulse{from{opacity:.5}to{opacity:1}}

/* ===== fiche événement ===== */
.ev-cover{margin:0 -20px;position:relative;background:var(--surface2)}
.ev-cover .ratio{aspect-ratio:4/3;overflow:hidden;display:flex;align-items:stretch}
.ev-cover img{width:100%;height:100%;object-fit:cover}
.ev-cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,var(--bg));pointer-events:none}
.back{position:absolute;top:14px;left:14px;z-index:2;background:rgba(20,20,22,.72);border:none;color:var(--txt);
  font-size:13px;font-weight:600;padding:10px 16px;border-radius:var(--r-pill);min-height:44px;backdrop-filter:blur(4px)}
.ev-body{padding:20px 0 130px}
.ev-body h1{font-family:'Unbounded';font-weight:600;font-size:22px;line-height:1.15;letter-spacing:-.02em}
.ev-meta{color:var(--txt2);font-size:15px;margin:12px 0 0}
.ev-meta b{color:var(--txt);font-weight:600}
.genres{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 0}
.genre{border:1px solid var(--hairline2);color:var(--txt2);font-size:12px;padding:5px 13px;border-radius:var(--r-pill)}
.ev-desc{color:var(--txt2);font-size:15px;line-height:1.6;margin:18px 0 0}

.block{margin-top:32px}
.block>h2{font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--txt2);
  margin-bottom:12px;display:flex;align-items:baseline;gap:10px}
.block>h2 .demo-tag{color:var(--coral);font-size:10px;font-weight:600;letter-spacing:.08em}

/* bloc ambiance */
.ambiance{background:var(--surface);background-image:var(--veil);border-radius:var(--r-card);
  box-shadow:inset 0 0 0 1px var(--hairline);padding:16px}
.amb-row{display:flex;justify-content:space-between;align-items:center;gap:12px}
.amb-row+.amb-row{margin-top:14px;padding-top:14px;border-top:1px solid var(--hairline)}
.amb-row .l{color:var(--txt2);font-size:13px}
.amb-row .v{font-weight:600;font-size:14px}
.gauge{display:flex;align-items:center;gap:10px;min-width:130px}
.gauge .bar{flex:1;height:5px;border-radius:3px;background:var(--border2);overflow:hidden}
.gauge .bar i{display:block;height:100%;border-radius:3px;background:var(--green);
  transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.gauge.go .bar i{transform:scaleX(1)}
.gauge b{font-size:13px;color:var(--green)}

/* bloc y aller / en revenir */
.access{background:var(--surface);background-image:var(--veil);border-radius:var(--r-card);
  box-shadow:inset 0 0 0 1px var(--hairline);overflow:hidden}
.minimap{display:block;width:100%;aspect-ratio:5/2;background:var(--surface2)}
.minimap .m-road{stroke:var(--border2);stroke-width:7;fill:none;stroke-linecap:round}
.minimap .m-road2{stroke:var(--border);stroke-width:4;fill:none;stroke-linecap:round}
.minimap .m-water{fill:var(--nuit);opacity:.5}
.minimap .m-pin{fill:var(--gold)}
.minimap .m-pin-dot{fill:var(--on-gold)}
.minimap text{font-family:'Inter';font-size:9px;fill:var(--txt3)}
.access .a-body{padding:14px 16px 16px}
.access .a-row{display:flex;gap:10px;font-size:13.5px;color:var(--txt2)}
.access .a-row+.a-row{margin-top:10px}
.access .a-ico{flex-shrink:0}
.access .ok{color:var(--green);font-weight:600}
.access .no{color:var(--txt2)}

/* bloc organisateur */
.orga-row{display:flex;align-items:center;gap:14px;background:var(--surface);background-image:var(--veil);
  box-shadow:inset 0 0 0 1px var(--hairline);
  border:none;width:100%;text-align:left;border-radius:var(--r-card);padding:14px 16px}
.orga-row .avatar{width:44px;height:44px;border-radius:50%;background:var(--violet);color:var(--txt);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}
.orga-row .n{flex:1;min-width:0}
.orga-row .n b{font-size:14.5px;display:block}
.orga-row .n span{color:var(--txt2);font-size:12.5px}
.orga-row .chev{color:var(--txt2);font-size:18px}

/* billets (fiche) */
.tk{display:flex;justify-content:space-between;align-items:center;background:var(--surface);background-image:var(--veil);
  box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:10px;padding:15px 16px;margin-bottom:8px}
.tk .n b{font-size:15px;display:block}
.tk .n span{font-size:12px;color:var(--txt2)}
.tk .n span.low{color:var(--coral)}
.tk .p{color:var(--gold);font-weight:600;font-size:15px;font-variant-numeric:tabular-nums}
.tk.off{opacity:.45}
.tk.off .p{color:var(--txt2);text-decoration:line-through}
.agg-note{background:var(--surface);border-radius:var(--r-card);padding:16px;color:var(--txt2);font-size:13.5px}
.agg-note b{color:var(--txt)}
.buy-bar{position:fixed;bottom:64px;left:50%;transform:translateX(-50%);width:min(520px,100%);
  padding:14px 20px;background:linear-gradient(180deg,transparent,var(--bg) 40%);z-index:40}
.btn-main{width:100%;background-color:var(--gold);color:var(--on-gold);border:none;font-size:15px;font-weight:600;
  background-image:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,0) 55%);
  padding:16px;border-radius:28px;min-height:52px;transition:transform .15s ease;display:block;text-align:center;text-decoration:none}
.btn-main:active{transform:scale(.97)}
.btn-line{width:100%;background:transparent;border:1px solid var(--hairline2);color:var(--txt);
  font-size:14px;font-weight:600;padding:14px;border-radius:26px;min-height:48px;transition:transform .15s ease,border-color .15s ease}
.btn-line:hover{border-color:var(--hairline2);background:var(--surface)}
.btn-line:active{transform:scale(.97)}

/* ===== paiement simulé ===== */
.pay-banner{background:var(--coral);color:var(--bg);font-size:12.5px;font-weight:600;text-align:center;
  padding:10px 14px;border-radius:12px;margin:20px 0}
.ev-going{display:block;margin-top:8px;color:var(--txt2)}
.ev-going .cnt{color:var(--txt);font-weight:600;font-variant-numeric:tabular-nums}
.ev-going .demo-tag{color:var(--coral);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-left:4px}
.pay-recap{background:var(--surface);background-image:var(--veil);box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:var(--r-card);padding:16px;margin-bottom:22px}
.pay-recap .r{display:flex;justify-content:space-between;font-size:14px;padding:5px 0;color:var(--txt2)}
.pay-recap .r b{color:var(--txt);font-variant-numeric:tabular-nums}
.pay-recap .r.total{border-top:1px solid var(--hairline);margin-top:8px;padding-top:12px;font-size:15px}
.pay-recap .r.total b{color:var(--gold)}
.pay-form label{display:block;color:var(--txt2);font-size:12px;margin:14px 0 6px}
.pay-form input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;
  color:var(--txt2);padding:14px;font-size:14px;font-family:inherit}
.pay-form input:disabled{opacity:.75}
.pay-row{display:flex;gap:10px}
.pay-row>div{flex:1}
.pay-note{color:var(--txt2);font-size:12px;text-align:center;margin:16px 0 20px}
.confirm-wrap{text-align:center;padding:48px 0 0}
.confirm-ico{width:74px;height:74px;border-radius:50%;background:var(--green);color:var(--txt);
  font-size:34px;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;
  animation:pop .4s cubic-bezier(.22,.61,.36,1) both}
@keyframes pop{from{transform:scale(.55);opacity:0}to{transform:scale(1);opacity:1}}
.confirm-wrap h1{font-family:'Unbounded';font-weight:600;font-size:20px;margin-bottom:10px}
.confirm-wrap p{color:var(--txt2);font-size:14px;margin-bottom:28px}

/* ===== wallet ===== */
.ticket-card{background:linear-gradient(160deg,var(--surface),var(--surface2));
  box-shadow:inset 0 0 0 1px var(--hairline),var(--shadow-soft);
  border-radius:20px;padding:22px;margin-bottom:16px;text-align:center}
.t-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.t-head b{font-family:'Unbounded';font-size:12px;font-weight:600}
.offline-badge{color:var(--green);border:1px solid rgba(29,158,117,.45);font-size:10.5px;font-weight:600;
  padding:4px 11px;border-radius:var(--r-pill)}
.qr-box{width:min(210px,58vw);margin:0 auto;background:var(--txt);border-radius:14px;padding:13px;position:relative}
.qr-box svg{width:100%;height:auto;display:block}
.qr-box svg rect{fill:var(--txt)}
.qr-box svg path{fill:var(--bg)}
.qr-box.qr-max{position:fixed;inset:0;width:auto;z-index:80;border-radius:0;margin:0;
  display:flex;align-items:center;justify-content:center;padding:8vw}
.qr-box.qr-max svg{max-width:min(80vw,80vh)}
.qr-void::after{content:"ANNULÉ";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:20px;color:var(--coral);letter-spacing:.2em;
  background:rgba(20,20,22,.55);border-radius:14px}
.t-info{margin-top:16px}
.t-info b{font-size:16px;display:block}
.t-info span{color:var(--txt2);font-size:13px}
.t-code{margin-top:10px;color:var(--txt2);font-size:11px;letter-spacing:.2em;font-variant-numeric:tabular-nums}
.t-state{display:inline-block;margin-top:12px;font-size:11px;font-weight:600;padding:4px 12px;border-radius:12px}
.t-state.used{color:var(--txt2);border:1px solid var(--border2)}
.t-state.resale{color:var(--gold);border:1px solid rgba(232,184,75,.45)}
.t-state.transferred{color:var(--coral);border:1px solid rgba(216,90,48,.45)}
.t-actions{display:flex;gap:10px;margin-top:18px}
.t-actions button{flex:1;min-height:46px;border-radius:24px;font-size:13px;font-weight:600}
.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--txt)}
.btn-gold{background:var(--gold);border:none;color:var(--on-gold)}
.past-note{color:var(--txt2);font-size:12.5px;text-align:center;margin:20px 0}
.wallet-mini{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:var(--r-card);
  padding:14px 16px;margin-bottom:10px;width:100%;border:none;text-align:left;color:var(--txt)}
.wallet-mini .ic{width:40px;height:40px;border-radius:12px;background:var(--surface2);
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.wallet-mini .n{flex:1}
.wallet-mini .n b{font-size:14px;display:block}
.wallet-mini .n span{font-size:12px;color:var(--txt2)}

/* ===== portfolio organisateur ===== */
.orga-hero{text-align:center;padding:30px 0 6px}
.orga-hero .avatar{width:72px;height:72px;border-radius:50%;background:var(--violet);color:var(--txt);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:26px;margin:0 auto 14px;font-family:'Unbounded'}
.orga-hero h1{font-family:'Unbounded';font-weight:600;font-size:22px;letter-spacing:-.02em;line-height:1.15}
.orga-hero .bio{color:var(--txt2);font-size:13.5px;max-width:340px;margin:10px auto 0}
.orga-stats{display:flex;justify-content:center;gap:28px;margin:22px 0}
.orga-stats div{text-align:center}
.orga-stats b{font-size:17px;display:block;font-variant-numeric:tabular-nums}
.orga-stats span{color:var(--txt2);font-size:12px}
.follow{display:block;margin:0 auto;background:transparent;border:1px solid var(--gold);color:var(--gold);
  font-size:13.5px;font-weight:600;padding:10px 26px;border-radius:var(--r-pill);min-height:42px;
  transition:background-color .15s,color .15s}
.follow[aria-pressed="true"]{background:var(--gold);color:var(--on-gold)}
.list-ev{display:flex;align-items:center;gap:14px;background:var(--surface);background-image:var(--veil);
  box-shadow:inset 0 0 0 1px var(--hairline);border-radius:var(--r-card);
  border:none;width:100%;text-align:left;color:var(--txt);padding:12px 14px;margin-bottom:10px}
.list-ev .thumb{width:58px;height:44px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--surface2)}
.list-ev .thumb img{width:100%;height:100%;object-fit:cover}
.list-ev .n{flex:1;min-width:0}
.list-ev .n b{font-size:13.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-ev .n span{font-size:12px;color:var(--txt2)}
.list-ev.past{opacity:.55}

/* ===== amis ===== */
.friend-ev{background:var(--surface);background-image:var(--veil);box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:var(--r-card);border:none;width:100%;text-align:left;
  color:var(--txt);padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;gap:14px}
.avvy{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:var(--txt);flex-shrink:0}
.d1{background:var(--coral)}.d2{background:var(--teal)}.d3{background:var(--violet)}
.d4{background:var(--bordeaux)}.d5{background:var(--nuit)}.d6{background:var(--green)}
.avv-stack{display:flex;flex-shrink:0}
.avv-stack .avvy{width:30px;height:30px;font-size:11.5px;border:2px solid var(--bg);margin-left:-8px}
.avv-stack .avvy:first-child{margin-left:0}
.friend-ev .n{flex:1;min-width:0}
.friend-ev .n b{font-size:14px;display:block}
.friend-ev .n span{font-size:12.5px;color:var(--txt2)}
.friend-ev .who{font-size:12px;color:var(--gold);margin-top:2px;display:block}
.sug{display:flex;align-items:center;gap:12px;padding:10px 0}
.sug .n{flex:1}
.sug .n b{font-size:14px;display:block}
.sug .n span{font-size:12px;color:var(--txt2)}
.sug .follow{margin:0;padding:7px 16px;min-height:36px;font-size:12.5px}

/* ===== profil ===== */
.prof-head{display:flex;align-items:center;gap:16px;padding:28px 0 8px}
.prof-head .avvy{width:56px;height:56px;font-size:20px}
.prof-head h1{font-family:'Unbounded';font-weight:600;font-size:18px}
.prof-head span{color:var(--txt2);font-size:13px}
.wrapped{background:linear-gradient(150deg,var(--violet),var(--surface2) 70%);border-radius:20px;
  box-shadow:inset 0 0 0 1px var(--hairline),var(--shadow-soft);
  padding:22px;margin:18px 0 6px;position:relative;overflow:hidden}
.wrapped .w-title{font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.wrapped .w-sub{color:var(--txt2);font-size:12px;margin-top:3px}
.w-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.w-grid div b{font-size:22px;display:block;color:var(--gold);font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:-.01em}
.w-grid div span{font-size:12px;color:var(--txt2)}
.hist{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--hairline)}
.hist:last-child{border-bottom:none}
.hist .n{flex:1}
.hist .n b{font-size:14px;display:block;font-weight:600}
.hist .n span{font-size:12px;color:var(--txt2)}
.was{background:transparent;border:1px solid var(--border2);color:var(--txt2);font-size:12px;font-weight:600;
  padding:7px 14px;border-radius:var(--r-pill);min-height:36px;transition:background-color .15s,color .15s}
.was[aria-pressed="true"]{border-color:var(--green);color:var(--green)}
.privacy{background:var(--surface);background-image:var(--veil);box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:var(--r-card);padding:16px;margin-top:10px}
.priv-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 0}
.priv-row+.priv-row{border-top:1px solid var(--hairline)}
.priv-row .l b{font-size:13.5px;display:block}
.priv-row .l span{font-size:11.5px;color:var(--txt2)}
.toggle{width:46px;height:26px;border-radius:14px;background:var(--border2);border:none;position:relative;
  flex-shrink:0;transition:background-color .2s}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;
  background:var(--txt);transition:transform .2s}
.toggle[aria-pressed="true"]{background:var(--green)}
.toggle[aria-pressed="true"]::after{transform:translateX(20px)}
.seg{display:flex;background:var(--surface2);border-radius:var(--r-pill);padding:3px;gap:2px}
.seg button{flex:1;border:none;background:transparent;color:var(--txt2);font-size:11.5px;font-weight:600;
  padding:7px 10px;border-radius:18px;min-height:32px;transition:background-color .15s,color .15s}
.seg button[aria-pressed="true"]{background:var(--gold);color:var(--on-gold)}
.mock-note{color:var(--txt2);font-size:11px;margin-top:10px}

/* ===== dashboard orga ===== */
.orga-head{display:flex;justify-content:flex-start;gap:14px;align-items:center;margin:26px 0 4px}
.orga-head h1{font-family:'Unbounded';font-weight:600;font-size:22px;letter-spacing:-.02em;line-height:1.15}
.live{display:flex;align-items:center;gap:7px;color:var(--green);font-size:11px;font-weight:700;letter-spacing:.08em}
.live::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.8)}}
.orga-ev{color:var(--txt2);font-size:13px;margin-bottom:18px}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stat{background:var(--surface);background-image:var(--veil);box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:var(--r-card);padding:16px}
.stat span{color:var(--txt2);font-size:12px;display:block;margin-bottom:5px}
.stat b{font-size:22px;font-weight:600;color:var(--gold);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.stat b.w{color:var(--txt)}
.chart{background:var(--surface);background-image:var(--veil);box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:var(--r-card);padding:16px;margin-top:10px}
.chart .lbl{color:var(--txt2);font-size:12px;margin-bottom:12px}
.bars{display:flex;align-items:flex-end;gap:6px;height:92px}
.bars i{flex:1;background:var(--gold);opacity:.9;border-radius:3px 3px 0 0;
  transform:scaleY(0);transform-origin:bottom;transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.bars.go i{transform:scaleY(1)}
.hours{display:flex;gap:6px;margin-top:6px}
.hours span{flex:1;text-align:center;color:var(--txt2);font-size:9.5px}
.ticker{background:var(--surface);background-image:var(--veil);box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:var(--r-card);padding:16px;margin-top:10px}
.ticker .lbl{display:flex;justify-content:space-between;align-items:center;color:var(--txt2);font-size:12px;margin-bottom:8px}
.ticker .lbl .demo-tag{color:var(--coral);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.tick{display:flex;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--hairline);
  font-size:13px;animation:tick-in .25s ease both}
.tick:last-child{border-bottom:none}
.tick .who{color:var(--txt)}
.tick .what{color:var(--txt2);font-size:12px}
.tick .amt{color:var(--green);font-weight:600;white-space:nowrap;font-variant-numeric:tabular-nums}
@keyframes tick-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.payout{background:var(--surface);background-image:var(--veil);box-shadow:inset 0 0 0 1px var(--hairline);
  border-radius:var(--r-card);padding:16px;margin-top:10px}
.payout span{color:var(--txt2);font-size:12px;display:block}
.payout b{font-size:16px;font-variant-numeric:tabular-nums}
.payout .note{color:var(--txt2);font-size:12px;margin-top:5px;display:block}
.scan-link{margin:14px 0 20px}

/* ===== scan simulé ===== */
.scan-frame{position:relative;margin:18px 0;background:var(--surface2);border-radius:20px;
  aspect-ratio:4/5;overflow:hidden;display:flex;align-items:center;justify-content:center}
.scan-frame .corners{position:absolute;inset:14%;pointer-events:none}
.scan-frame .corners i{position:absolute;width:26px;height:26px;border:3px solid var(--gold)}
.scan-frame .corners i:nth-child(1){top:0;left:0;border-right:none;border-bottom:none;border-radius:8px 0 0 0}
.scan-frame .corners i:nth-child(2){top:0;right:0;border-left:none;border-bottom:none;border-radius:0 8px 0 0}
.scan-frame .corners i:nth-child(3){bottom:0;left:0;border-right:none;border-top:none;border-radius:0 0 0 8px}
.scan-frame .corners i:nth-child(4){bottom:0;right:0;border-left:none;border-top:none;border-radius:0 0 8px 0}
.scan-line{position:absolute;left:16%;right:16%;top:16%;height:2px;background:var(--gold);opacity:.85;
  animation:scanmove 2.2s ease-in-out infinite alternate}
@keyframes scanmove{from{transform:translateY(0)}to{transform:translateY(min(46vw,240px))}}
.scan-hint{color:var(--txt2);font-size:12px;text-align:center;position:absolute;bottom:12px;left:0;right:0}
.scan-result{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;background:rgba(20,20,22,.88);opacity:0;pointer-events:none;transition:opacity .2s}
.scan-result.on{opacity:1}
.scan-result .r-ico{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:28px;color:var(--txt)}
.scan-result.ok .r-ico{background:var(--green)}
.scan-result.ko .r-ico{background:var(--coral)}
.scan-result b{font-size:15px}
.scan-result span{color:var(--txt2);font-size:12.5px}
.scan-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.scan-count{font-size:13px;color:var(--txt2)}
.scan-count b{color:var(--txt);font-variant-numeric:tabular-nums}

/* ===== bottom sheet ===== */
.sheet-veil{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:70;opacity:0;pointer-events:none;transition:opacity .2s}
.sheet-veil.on{opacity:1;pointer-events:auto}
.sheet{position:fixed;bottom:0;left:50%;transform:translate(-50%,105%);width:min(520px,100%);z-index:71;
  background:var(--surface);border-radius:20px 20px 0 0;
  box-shadow:inset 0 1px 0 var(--hairline),var(--shadow-soft);
  padding:18px 22px calc(24px + env(safe-area-inset-bottom));transition:transform .25s cubic-bezier(.2,.7,.3,1)}
@supports (backdrop-filter:blur(16px)){
  .sheet{background:rgba(29,29,33,.86);backdrop-filter:blur(16px)}
}
.sheet.on{transform:translate(-50%,0)}
.sheet .grab{width:38px;height:4px;border-radius:2px;background:var(--hairline2);margin:0 auto 16px}
.sheet h2{font-weight:600;font-size:17px;letter-spacing:-.01em;margin-bottom:10px}
.sheet p{color:var(--txt2);font-size:14px;margin-bottom:18px}
.sheet .btn-main{min-height:48px}
.sheet .close{width:100%;min-height:44px;margin-top:8px;background:transparent;border:none;color:var(--txt2);font-size:13px}

/* ===== tab bar ===== */
.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:min(520px,100%);z-index:50;
  display:flex;background:var(--bg);border-top:1px solid var(--hairline);
  padding-bottom:env(safe-area-inset-bottom)}
@supports (backdrop-filter:blur(18px)){
  .tabbar{background:rgba(20,20,22,.78);backdrop-filter:blur(18px)}
}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 0 8px;min-height:58px;
  color:var(--txt2);text-decoration:none;font-size:11px;font-weight:500;background:none;border:none}
.tab svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.tab.on{color:var(--gold)}

.side-logo{display:none}

/* ===== grand écran (breakpoint unique — rien ne change en dessous) ===== */
@media(min-width:900px){
  /* sidebar gauche = la tab bar restylée */
  .tabbar{top:0;left:0;bottom:0;right:auto;transform:none;width:232px;
    flex-direction:column;justify-content:flex-start;gap:4px;
    border-top:none;border-right:1px solid var(--hairline);padding:26px 14px;background:var(--bg)}
  .side-logo{display:block;padding:6px 14px 26px}
  .tab{flex:none;flex-direction:row;justify-content:flex-start;gap:13px;
    font-size:14px;padding:12px 14px;min-height:auto;border-radius:12px}
  .tab.on{background:var(--surface)}

  /* coquille : contenu à droite de la sidebar */
  .app{max-width:none;margin:0;padding:0 44px 60px 276px;border:none!important}
  .screen{max-width:1120px;margin:0 auto;width:100%}
  #screen-amis,#screen-profil,#screen-orgapage,#screen-buy,#screen-billets{max-width:820px}

  /* feed : curation en grille (2 col., 3 au-dessus de 1300px) */
  #feed-body{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 30px;align-items:start}
  #feed-body .sec-head,#feed-body .strip,#feed-body .fallback-note,#feed-body .empty,
  #feed-body .sk-line{grid-column:1/-1}
  #feed-body .sk-cover{grid-column:auto}
  .card-w{min-width:236px;max-width:236px}

  /* fiche : flyer sticky à gauche, contenu à droite */
  #screen-event{display:grid;grid-template-columns:minmax(320px,430px) 1fr;gap:0 48px;align-items:start}
  #screen-event .ev-cover{grid-column:1;position:sticky;top:36px;margin:36px 0 0;
    border-radius:var(--r-card);overflow:hidden}
  #screen-event .ev-cover::after{display:none}
  #screen-event .ev-body{grid-column:2;padding:36px 0 60px}
  #screen-event .buy-bar{grid-column:2;position:static;transform:none;width:auto;
    padding:0 0 40px;background:none}

  /* billets : grille 2 colonnes */
  #wallet-body{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
  #wallet-body .past-note{grid-column:1/-1}

  /* dashboard : rangée de 3, graphique large, ticker à droite */
  #orga-body{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}
  #orga-body .stats{display:contents}
  #orga-body .payout{grid-row:1;grid-column:3;margin:0}
  #orga-body .chart{grid-column:1/3;margin:0}
  #orga-body .ticker{grid-column:3;margin:0}
  #orga-body .scan-link{grid-column:1/-1;margin:6px 0 0}

  /* scan : cadre contenu */
  #screen-scan{max-width:560px}
}
@media(min-width:1300px){
  #feed-body{grid-template-columns:repeat(3,1fr)}
}

/* ===== reduced motion ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .bars i,.gauge .bar i{transform:none}
  .screen.on{animation:none}
}
