/* ====================================================================
   NANTES CREW — affiche risographe d'un collectif nantais
   Papier crème + grain · encre noire · ligne verte acide · accent corail
   ==================================================================== */

:root{
  --paper:#F4EDDD;
  --paper-2:#ECE2CC;
  --card:#FBF7EC;
  --ink:#181610;
  --ink-2:#6a6350;
  --ink-3:#9b937c;
  --lime:#C9F24A;
  --lime-deep:#16361b;
  --lime-press:#b6e02f;
  --coral:#FF5A3C;
  --coral-deep:#7a1d0e;
  --hair:rgba(24,22,16,.14);
  --hair-2:rgba(24,22,16,.08);
  --shadow-hard:3px 3px 0 var(--ink);
  --shadow-soft:0 10px 30px -14px rgba(24,22,16,.4);
  --r:16px;
  --r-sm:11px;
  --maxw:560px;
  --font-display:"Bricolage Grotesque",Georgia,serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.45;
  min-height:100dvh;
  overflow-x:hidden;
  /* subtle warm vignette + faint radial light */
  background-image:
    radial-gradient(120% 80% at 80% -10%, rgba(201,242,74,.12), transparent 55%),
    radial-gradient(120% 90% at 0% 105%, rgba(255,90,60,.08), transparent 50%);
  background-attachment:fixed;
  padding-bottom:calc(96px + env(safe-area-inset-bottom));
}

/* ---- grain ---- */
.grain{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:9999;opacity:.05;mix-blend-mode:multiply}

#confetti{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:9000;display:none}

/* ---- selection ---- */
::selection{background:var(--lime);color:var(--lime-deep)}

/* ====================== TOPBAR ====================== */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:14px 18px calc(14px);
  padding-top:calc(14px + env(safe-area-inset-top));
  background:linear-gradient(var(--paper) 72%, rgba(244,237,221,0));
  backdrop-filter:blur(2px);
}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer;user-select:none}
.brand-mark{width:44px;height:28px;flex:none;overflow:visible}
#brandLine{stroke-dasharray:120;stroke-dashoffset:120;animation:draw 1.1s var(--ease) .15s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:1.16rem;letter-spacing:-.02em}
.brand-sub{font-size:.7rem;color:var(--ink-2);font-weight:500;margin-top:2px}

.me-chip{
  width:42px;height:42px;border-radius:50%;flex:none;
  border:2px solid var(--ink);background:var(--card);
  display:grid;place-items:center;font-size:1.2rem;cursor:pointer;
  overflow:hidden;box-shadow:var(--shadow-hard);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease);
  font-family:var(--font-display);font-weight:700;color:var(--ink);
}
.me-chip:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.me-chip img{width:100%;height:100%;object-fit:cover}
.me-chip.pulse{animation:mePulse 1.9s var(--ease) infinite}
@keyframes mePulse{0%,100%{box-shadow:var(--shadow-hard),0 0 0 0 rgba(255,90,60,.5)}50%{box-shadow:var(--shadow-hard),0 0 0 8px rgba(255,90,60,0)}}

/* ====================== VIEWS ====================== */
#app{max-width:var(--maxw);margin:0 auto;padding:4px 18px 0}
.view{animation:viewIn .42s var(--ease)}
@keyframes viewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.section-head{margin:10px 2px 16px}
.section-title{font-family:var(--font-display);font-weight:800;font-size:2rem;letter-spacing:-.03em;line-height:.98}
.section-sub{color:var(--ink-2);font-size:.92rem;margin-top:4px;font-weight:500}

/* ====================== HERO (agenda) ====================== */
.hero{position:relative;padding:14px 2px 6px;margin-bottom:6px}
.hero-line{position:absolute;left:-10px;right:-10px;top:54px;height:60px;opacity:.9;pointer-events:none}
.hero-line svg{width:100%;height:100%;overflow:visible}
#heroPath{stroke-dasharray:1000;stroke-dashoffset:1000;animation:draw 1.6s var(--ease) .3s forwards}
.hero-title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(3rem,17vw,4.6rem);line-height:.86;letter-spacing:-.045em;
  position:relative;z-index:1;
}
.hero-q{color:var(--coral);display:inline-block;animation:wobble 3.5s ease-in-out infinite;transform-origin:bottom center}
@keyframes wobble{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(8deg)}}

.hero-week{display:flex;align-items:center;gap:0;flex-wrap:wrap;margin-top:18px;min-height:46px}
.hero-week .hw-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2);font-weight:700;width:100%;margin-bottom:7px}
.hw-avatars{display:flex;align-items:center}
.hw-avatars .av{margin-left:-9px;border:2.5px solid var(--paper)}
.hw-avatars .av:first-child{margin-left:0}
.hw-empty{font-size:.92rem;color:var(--ink-2);font-weight:500}
.hero-best{
  margin-top:14px;display:none;align-items:center;gap:9px;
  background:var(--lime);color:var(--lime-deep);
  border:2px solid var(--ink);border-radius:var(--r-sm);
  padding:9px 13px;font-weight:700;font-size:.92rem;box-shadow:var(--shadow-hard);
  width:fit-content;max-width:100%;
}
.hero-best.show{display:flex;animation:popIn .5s var(--ease)}
@keyframes popIn{from{opacity:0;transform:scale(.9) translateY(6px)}to{opacity:1;transform:none}}

/* ====================== CALENDRIER ====================== */
.cal-bar{display:flex;align-items:center;gap:8px;margin:22px 0 12px}
.cal-month{font-family:var(--font-display);font-weight:700;font-size:1.45rem;letter-spacing:-.02em;flex:1;text-transform:capitalize}
.ghost-btn{
  width:38px;height:38px;border-radius:11px;border:2px solid var(--ink);
  background:var(--card);font-size:1.3rem;cursor:pointer;color:var(--ink);
  display:grid;place-items:center;line-height:1;font-weight:700;
  transition:transform .15s var(--ease),background .15s;
}
.ghost-btn:hover{background:var(--lime)}
.ghost-btn:active{transform:scale(.92)}
.today-btn{
  border:2px solid var(--ink);background:var(--ink);color:var(--paper);
  border-radius:11px;padding:0 13px;height:38px;font-weight:700;font-size:.82rem;
  cursor:pointer;font-family:var(--font-body);transition:transform .15s var(--ease);
}
.today-btn:active{transform:scale(.95)}

.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-dow span{text-align:center;font-size:.7rem;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.04em}

.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cell{
  position:relative;aspect-ratio:1/1.12;border-radius:11px;
  background:var(--card);border:1.5px solid var(--hair);
  padding:5px 4px 4px;cursor:pointer;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .14s var(--ease),border-color .14s,box-shadow .14s;
  animation:cellIn .4s var(--ease) backwards;
}
@keyframes cellIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:none}}
.cell.blank{background:transparent;border-color:transparent;cursor:default;pointer-events:none}
.cell:not(.blank):hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow-soft);z-index:2}
.cell.past{opacity:.5}
.cell .dnum{font-size:.82rem;font-weight:700;color:var(--ink-2);line-height:1}
.cell.today .dnum{color:var(--paper);background:var(--coral);width:21px;height:21px;border-radius:50%;display:grid;place-items:center;font-size:.74rem;box-shadow:0 0 0 2px var(--ink)}
.cell.has:not(.today) .dnum{color:var(--ink)}

.cell-chips{display:flex;flex-wrap:wrap;gap:2px;margin-top:auto;align-content:flex-end}
.cell-chips .pchip{
  width:15px;height:15px;border-radius:50%;border:1.5px solid var(--card);
  margin:-1px;font-size:8px;display:grid;place-items:center;font-weight:800;color:#fff;
}
.cell-chips .more{font-size:.62rem;font-weight:800;color:var(--ink-2);align-self:center;padding-left:2px}

/* busy day glow */
.cell.busy{border-color:var(--ink)}
.cell.fire::after{content:"🔥";position:absolute;top:3px;right:3px;font-size:.62rem;animation:flick 1.6s ease-in-out infinite}
.cell.fire{box-shadow:0 0 0 1.5px var(--ink),0 0 14px -2px var(--coral);animation:cellIn .4s var(--ease) backwards,fireGlow 2.4s ease-in-out infinite}
@keyframes fireGlow{0%,100%{box-shadow:0 0 0 1.5px var(--ink),0 0 10px -3px var(--coral)}50%{box-shadow:0 0 0 1.5px var(--ink),0 0 18px 0px var(--coral)}}
@keyframes flick{0%,100%{transform:rotate(-6deg) scale(1)}50%{transform:rotate(6deg) scale(1.15)}}

.cal-hint{text-align:center;color:var(--ink-3);font-size:.8rem;margin:18px 0 8px;font-weight:500}

/* ====================== CREW ====================== */
.crew-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.crew-card{
  position:relative;background:var(--card);border:2px solid var(--ink);
  border-radius:var(--r);padding:18px 14px 14px;text-align:center;
  box-shadow:var(--shadow-hard);cursor:pointer;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease);
  animation:cardIn .5s var(--ease) backwards;
}
@keyframes cardIn{from{opacity:0;transform:translateY(14px) rotate(-1deg)}to{opacity:1;transform:none}}
.crew-card:nth-child(even){transform:rotate(.6deg)}
.crew-card:nth-child(odd){transform:rotate(-.6deg)}
.crew-card:hover{transform:translateY(-4px) rotate(0);box-shadow:5px 7px 0 var(--ink)}
.crew-card.me{border-color:var(--coral)}
.crew-card.me::before{
  content:"toi";position:absolute;top:-9px;left:50%;transform:translateX(-50%) rotate(-3deg);
  background:var(--coral);color:#fff;font-weight:800;font-size:.66rem;
  padding:3px 9px;border-radius:20px;border:2px solid var(--ink);letter-spacing:.03em;
}
.crew-card .av{margin:0 auto 10px}
.crew-name{font-family:var(--font-display);font-weight:700;font-size:1.12rem;letter-spacing:-.02em;line-height:1}
.crew-days{font-size:.78rem;color:var(--ink-2);margin-top:6px;font-weight:600;min-height:1.1em}
.crew-next{font-size:.74rem;margin-top:7px;font-weight:600;padding:3px 8px;border-radius:20px;display:inline-block}
.crew-next.here{background:var(--lime);color:var(--lime-deep)}
.crew-next.soon{background:var(--paper-2);color:var(--ink-2)}
.crew-next.away{color:var(--ink-3)}

.crew-add{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:transparent;border:2px dashed var(--ink-3);border-radius:var(--r);
  padding:18px 14px;cursor:pointer;color:var(--ink-2);min-height:140px;
  transition:border-color .2s,color .2s,background .2s;font-weight:700;
}
.crew-add:hover{border-color:var(--coral);color:var(--coral);background:var(--card)}
.crew-add .plus{font-size:2rem;line-height:1}

/* shared avatar */
.av{
  width:62px;height:62px;border-radius:50%;display:grid;place-items:center;
  font-size:1.6rem;font-weight:800;color:#fff;overflow:hidden;flex:none;
  font-family:var(--font-display);border:2px solid var(--ink);
}
.av.sm{width:34px;height:34px;font-size:.92rem;border-width:2px}
.av img{width:100%;height:100%;object-fit:cover}

/* ====================== SPOTS ====================== */
.spot-filters{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 10px;margin:0 -2px 6px;scrollbar-width:none}
.spot-filters::-webkit-scrollbar{display:none}
.fbtn{
  flex:none;border:2px solid var(--ink);background:var(--card);color:var(--ink);
  border-radius:30px;padding:7px 15px;font-weight:700;font-size:.84rem;cursor:pointer;
  white-space:nowrap;transition:background .15s,color .15s,transform .12s;font-family:var(--font-body);
}
.fbtn:active{transform:scale(.94)}
.fbtn.on{background:var(--ink);color:var(--paper)}

.spot-list{display:flex;flex-direction:column;gap:13px}
.spot-card{
  display:block;text-decoration:none;color:inherit;position:relative;
  background:var(--card);border:1.5px solid var(--hair);border-radius:var(--r);
  padding:15px 16px;box-shadow:var(--shadow-soft);overflow:hidden;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s;
  animation:cardIn .45s var(--ease) backwards;
}
.spot-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--cat,var(--lime))}
.spot-card:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:6px 8px 0 var(--ink)}
.spot-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.spot-cat{font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-2);background:var(--paper-2);padding:3px 8px;border-radius:6px}
.spot-name{font-family:var(--font-display);font-weight:700;font-size:1.22rem;letter-spacing:-.02em;line-height:1.04;margin:9px 0 2px;padding-left:6px}
.spot-area{font-size:.76rem;color:var(--ink-2);font-weight:600;padding-left:6px;display:flex;align-items:center;gap:4px}
.spot-vibe{font-size:.9rem;color:var(--ink);margin:9px 0 0;padding-left:6px;line-height:1.4}
.spot-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;padding-left:6px}
.spot-price{font-weight:800;font-size:.86rem;background:var(--lime);color:var(--lime-deep);padding:4px 10px;border-radius:7px;border:1.5px solid var(--ink)}
.spot-price.free{background:var(--coral);color:#fff}
.spot-price.tba{background:transparent;border-color:var(--hair);color:var(--ink-2)}
.spot-go{font-weight:800;font-size:.82rem;color:var(--ink);display:flex;align-items:center;gap:5px}
.spot-go .arr{transition:transform .2s var(--ease)}
.spot-card:hover .spot-go .arr{transform:translateX(4px)}
.spot-dates{font-size:.74rem;font-weight:700;color:var(--coral-deep);padding-left:6px;margin-top:6px}

.spots-foot{text-align:center;color:var(--ink-3);font-size:.76rem;margin:18px 0 8px;font-weight:500}

/* ====================== TABBAR ====================== */
.tabbar{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:calc(16px + env(safe-area-inset-bottom));z-index:60;
  display:flex;gap:4px;padding:6px;
  background:var(--ink);border-radius:28px;
  box-shadow:0 14px 34px -10px rgba(24,22,16,.55);
}
.tab{
  border:none;background:transparent;cursor:pointer;color:var(--paper);
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:8px 17px;border-radius:22px;font-family:var(--font-body);
  transition:background .22s var(--ease),color .22s;opacity:.62;
}
.tab-ico{font-size:1.18rem;line-height:1;filter:grayscale(.2)}
.tab-lbl{font-size:.66rem;font-weight:700;letter-spacing:.01em}
.tab.is-active{background:var(--lime);color:var(--lime-deep);opacity:1}
.tab:not(.is-active):active{opacity:.9}

/* ====================== SHEETS / MODALS ====================== */
.sheet-wrap{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-end;justify-content:center}
.sheet-backdrop{position:absolute;inset:0;background:rgba(24,22,16,.42);backdrop-filter:blur(3px);animation:fade .3s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{
  position:relative;width:100%;max-width:var(--maxw);max-height:92dvh;overflow-y:auto;
  background:var(--paper);border-radius:24px 24px 0 0;
  border:2px solid var(--ink);border-bottom:none;
  padding:26px 20px calc(26px + env(safe-area-inset-bottom));
  animation:sheetUp .42s var(--ease);
  -webkit-overflow-scrolling:touch;
}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:none}}
.sheet-x{
  position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;
  border:2px solid var(--ink);background:var(--card);font-size:1.3rem;line-height:1;
  cursor:pointer;color:var(--ink);display:grid;place-items:center;z-index:2;
}
.sheet-x:active{transform:scale(.9)}
.sheet-title{font-family:var(--font-display);font-weight:800;font-size:1.6rem;letter-spacing:-.03em;margin-bottom:18px;padding-right:36px}

/* avatar editor */
.avatar-edit{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.avatar-preview{
  width:78px;height:78px;border-radius:50%;border:2px solid var(--ink);
  background:var(--card);cursor:pointer;overflow:hidden;flex:none;
  display:grid;place-items:center;font-size:2rem;color:#fff;font-weight:800;
  font-family:var(--font-display);box-shadow:var(--shadow-hard);
}
.avatar-preview img{width:100%;height:100%;object-fit:cover}
.avatar-actions{display:flex;flex-direction:column;gap:8px}

/* fields */
.field{display:block;margin-bottom:18px}
.field-lbl{display:block;font-size:.8rem;font-weight:700;color:var(--ink-2);margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}
.field-lbl em{font-style:normal;color:var(--ink-3);font-weight:600;text-transform:none;letter-spacing:0}
input[type=text],input[type=date]{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--card);border:2px solid var(--ink);border-radius:11px;
  padding:11px 13px;font-weight:600;
}
input[type=text]::placeholder{color:var(--ink-3);font-weight:500}
input:focus{outline:none;box-shadow:var(--shadow-hard)}
input[type=date]{font-family:var(--font-body)}

.emoji-row{display:flex;flex-wrap:wrap;gap:7px}
.emoji-row button{
  width:42px;height:42px;border-radius:11px;border:2px solid var(--hair);
  background:var(--card);font-size:1.35rem;cursor:pointer;transition:transform .12s,border-color .12s;
  display:grid;place-items:center;line-height:1;
}
.emoji-row button:active{transform:scale(.9)}
.emoji-row button.on{border-color:var(--ink);background:var(--lime);transform:scale(1.05)}

.color-row{display:flex;flex-wrap:wrap;gap:9px}
.swatch{
  width:38px;height:38px;border-radius:50%;cursor:pointer;position:relative;
  border:2.5px solid var(--paper);box-shadow:0 0 0 2px var(--hair);
  transition:transform .14s var(--ease),box-shadow .14s;
  display:grid;place-items:center;font-size:.8rem;font-weight:800;color:#fff;
}
.swatch:active{transform:scale(.9)}
.swatch.on{box-shadow:0 0 0 2.5px var(--ink),0 0 0 6px var(--lime);transform:scale(1.12)}
.swatch.taken{opacity:.45;cursor:not-allowed}
.swatch.taken::after{content:"";position:absolute;inset:0;border-radius:50%}

/* periods */
.periods{display:flex;flex-direction:column;gap:7px;margin-bottom:11px}
.period-chip{
  display:flex;align-items:center;gap:9px;background:var(--card);
  border:1.5px solid var(--hair);border-radius:11px;padding:9px 11px;
}
.period-chip .pc-dot{width:9px;height:9px;border-radius:50%;background:var(--lime);border:1.5px solid var(--ink);flex:none}
.period-chip .pc-txt{flex:1;font-size:.86rem;font-weight:600;line-height:1.25}
.period-chip .pc-txt small{display:block;color:var(--ink-2);font-weight:500;font-size:.76rem}
.period-chip .pc-del{border:none;background:transparent;font-size:1.2rem;cursor:pointer;color:var(--ink-3);padding:0 2px;line-height:1}
.period-chip .pc-del:hover{color:var(--coral)}
.periods-empty{font-size:.85rem;color:var(--ink-3);font-weight:500;padding:4px 2px}

.period-add{background:var(--paper-2);border-radius:13px;padding:12px;border:1.5px dashed var(--hair)}
.date-pair{display:flex;gap:10px;margin-bottom:9px}
.date-pair label{flex:1;font-size:.78rem;font-weight:700;color:var(--ink-2);display:flex;flex-direction:column;gap:5px}
.date-pair input{padding:9px 10px}
#pNote{margin-bottom:9px}

/* buttons */
.mini-btn{
  display:inline-flex;align-items:center;gap:5px;border:2px solid var(--ink);
  background:var(--card);color:var(--ink);border-radius:10px;padding:8px 13px;
  font-weight:700;font-size:.84rem;cursor:pointer;font-family:var(--font-body);
  transition:transform .12s,background .15s;
}
.mini-btn:active{transform:scale(.95)}
.mini-btn.ghost{border-color:var(--hair);color:var(--ink-2)}
.mini-btn.add{width:100%;justify-content:center;background:var(--ink);color:var(--paper)}

.sheet-foot{display:flex;gap:11px;align-items:center;margin-top:22px}
.save-btn{
  flex:1;border:2px solid var(--ink);background:var(--lime);color:var(--lime-deep);
  border-radius:13px;padding:15px;font-weight:800;font-size:1.02rem;cursor:pointer;
  font-family:var(--font-body);box-shadow:var(--shadow-hard);
  transition:transform .14s var(--ease),box-shadow .14s var(--ease);
}
.save-btn:active{transform:translate(3px,3px);box-shadow:0 0 0 var(--ink)}
.save-btn:disabled{opacity:.5;cursor:not-allowed}
.del-btn{border:none;background:transparent;color:var(--coral-deep);font-weight:700;font-size:.82rem;cursor:pointer;text-decoration:underline;padding:6px}

/* day sheet */
.day-sheet .day-row{display:flex;align-items:center;gap:13px;padding:12px 2px;border-bottom:1px solid var(--hair)}
.day-sheet .day-row:last-child{border-bottom:none}
.day-row .dr-info{flex:1;min-width:0}
.day-row .dr-name{font-family:var(--font-display);font-weight:700;font-size:1.08rem;letter-spacing:-.01em}
.day-row .dr-note{font-size:.82rem;color:var(--ink-2);font-weight:500}
.day-empty{text-align:center;color:var(--ink-2);padding:18px 0 8px;font-weight:500}
.day-empty .big{font-size:2.4rem;display:block;margin-bottom:8px}
.day-cta{margin-top:18px}
.day-count-badge{display:inline-flex;align-items:center;gap:6px;background:var(--lime);color:var(--lime-deep);border:2px solid var(--ink);border-radius:20px;padding:5px 12px;font-weight:800;font-size:.82rem;margin-bottom:6px}

/* ====================== TOAST ====================== */
.toast{
  position:fixed;left:50%;transform:translateX(-50%) translateY(120%);
  bottom:calc(96px + env(safe-area-inset-bottom));z-index:300;
  background:var(--ink);color:var(--paper);font-weight:700;font-size:.92rem;
  padding:13px 19px;border-radius:14px;max-width:90vw;text-align:center;
  box-shadow:0 14px 34px -10px rgba(0,0,0,.5);transition:transform .42s var(--ease);
  pointer-events:none;border:2px solid var(--lime);
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ====================== DESKTOP ====================== */
@media(min-width:680px){
  :root{--maxw:920px}
  #app{padding-top:10px}
  .hero-title{font-size:clamp(4rem,9vw,6.2rem)}
  .crew-grid{grid-template-columns:repeat(4,1fr)}
  .cell .dnum{font-size:.92rem}
  .cell-chips .pchip{width:18px;height:18px;font-size:9px}
  .spot-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
  .sheet-wrap{align-items:center}
  .sheet{border-radius:24px;border-bottom:2px solid var(--ink);max-height:88dvh;animation:sheetPop .4s var(--ease)}
  @keyframes sheetPop{from{opacity:0;transform:scale(.94) translateY(14px)}to{opacity:1;transform:none}}
  .tabbar{bottom:24px}
  body{padding-bottom:120px}
}
@media(min-width:680px) and (hover:hover){
  .tab{padding:9px 22px}
  .tab:not(.is-active):hover{opacity:1;background:rgba(244,237,221,.12)}
}

/* reduce motion */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  #brandLine,#heroPath{stroke-dashoffset:0}
}
