  :root{
    --bg:#0a0908; --panel:#15110f; --panel2:#1d1815; --ink:#f4ece1;
    --muted:#8c8076; --gold:#e0a13c; --gold-bright:#f4b94e; --red:#c0392b;
    --line:#2c2420; --green:#6b8e4e;
    /* camadas globais (escala única; z-index locais pequenos ficam nos componentes):
       autocomplete < badge versão < modal < menus flutuantes < sub-modais < leitor de cifra < confirmar < toast */
    --z-autocomplete:40; --z-badge:50; --z-modal:100; --z-float:130; --z-modal2:150;
    --z-reader:400; --z-ask:500; --z-toast:600;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;font-size:20px;}   /* base do PC; tablet/celular reduzem abaixo p/ tirar a sensação de "zoom" (todos os rem caem juntos) */
  @media (max-width:1024px) and (min-width:601px){ html{font-size:14px;} }                       /* tablet em pé / janela estreita: −30% */
  @media (pointer:coarse) and (min-width:601px) and (max-width:1366px){ html{font-size:14px;} }  /* tablet DEITADO (1024–1366 caía na base de PC) */
  @media (max-width:600px), ((max-height:500px) and (pointer:coarse)){ html{font-size:13px;} }   /* celular em pé OU deitado (deitado caía na faixa de tablet): −35% */
  body{
    background:
      radial-gradient(1200px 600px at 80% -10%, rgba(224,161,60,.10), transparent 60%),
      radial-gradient(900px 500px at -10% 110%, rgba(192,57,43,.10), transparent 55%),
      var(--bg);
    color:var(--ink); font-family:'Oswald',sans-serif; font-weight:300;
    letter-spacing:.3px; min-height:100vh; padding:0 0 90px;
  }
  .wrap{max-width:1500px;margin:0 auto;padding:0 32px;position:relative;}
  header{text-align:center;padding:86px 0 12px;}   /* folga p/ a barra de pílulas (absolute) não encostar + respiro acima do título */
  .kicker{font-weight:500;text-transform:uppercase;letter-spacing:8px;font-size:.74rem;color:var(--gold);margin-bottom:4px;}
  h1{font-family:'Anton',sans-serif;font-size:clamp(2.4rem,7.5vw,5rem);line-height:1.12;text-transform:uppercase;letter-spacing:1px;padding-top:.1em;margin-bottom:.06em;
     background:linear-gradient(180deg,#fff 0%,var(--gold-bright) 55%,var(--gold) 75%,#9c6a1c 100%);
     -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
     filter:drop-shadow(0 6px 24px rgba(224,161,60,.25));}
  .maker{display:inline-block;font-family:'Oswald',sans-serif;font-weight:700;font-size:.18em;letter-spacing:3px;color:#e74c3c;background:none;-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:#e74c3c;vertical-align:baseline;margin-left:.4em;filter:none;text-shadow:0 0 8px rgba(231,76,60,.4);}
  .login-card h2 .maker{font-size:.32em;margin-left:.35em;}
  /* ===== Logo SetZone (caixa alta · Set dourado / Zone vermelho mesmo tamanho · ™ no topo · tagline na largura do logo) ===== */
  .sz{text-transform:uppercase;}
  .sz-set,.sz-zone{display:inline-block;}
  .sz-set{background:linear-gradient(180deg,#fff 0%,var(--gold-bright) 55%,var(--gold) 75%,#9c6a1c 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 16px rgba(224,161,60,.4));}
  .sz-zone{color:#ee2b2b;-webkit-text-fill-color:#ee2b2b;margin-left:.04em;filter:drop-shadow(0 4px 18px rgba(238,43,43,.35));}
  .sz-tm{font-family:'Oswald',sans-serif;font-weight:500;font-size:.19em;vertical-align:top;position:relative;top:.12em;color:var(--gold);-webkit-text-fill-color:var(--gold);margin-left:.04em;filter:drop-shadow(0 0 6px rgba(224,161,60,.4));}
  .sz-tag{display:inline-block;font-family:'Oswald',sans-serif;font-weight:500;font-size:14px;text-transform:uppercase;letter-spacing:.26em;line-height:1;color:var(--gold-bright);opacity:.97;white-space:nowrap;margin-top:0;filter:drop-shadow(0 0 7px rgba(244,185,78,.28));}
  .login-card .sz-tag{margin-bottom:22px;}
  .subtitle{margin-top:14px;color:var(--muted);font-size:.95rem;letter-spacing:3px;text-transform:uppercase;}
  .rule{height:2px;width:120px;margin:26px auto 0;background:linear-gradient(90deg,transparent,var(--gold),transparent);}

  /* === sino de recados (pílula do topo) + badge de não lidas === */
  #noticeBell{position:relative;}
  .bell-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--red);color:#fff;font-family:'Oswald';font-weight:600;font-size:.62rem;line-height:18px;text-align:center;box-shadow:0 0 0 2px var(--bg);}
  #noticeBell.has-unread{border-color:var(--gold);color:var(--gold-bright);}

  /* === modal "Mural da banda" === (.modal.notices-modal p/ vencer o max-width base do .modal) */
  .modal.notices-modal{max-width:560px;}
  .notices-list{display:flex;flex-direction:column;gap:10px;max-height:46vh;overflow-y:auto;margin-bottom:14px;padding-right:4px;}
  .nt-empty{color:var(--muted);font-size:.9rem;text-align:center;padding:18px 8px;line-height:1.5;}
  .nt-item{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;}
  .nt-item.nt-unread{border-color:rgba(224,161,60,.45);box-shadow:0 0 0 1px rgba(224,161,60,.25) inset;}
  .nt-head{display:flex;align-items:center;gap:7px;margin-bottom:5px;}
  .nt-dot{width:9px;height:9px;border-radius:50%;flex:none;box-shadow:0 0 6px color-mix(in srgb, currentColor 40%, transparent);}
  .nt-author{font-weight:500;color:var(--ink);font-size:.9rem;letter-spacing:.4px;}
  .nt-time{color:var(--muted);font-size:.72rem;}
  .nt-new{font-size:.56rem;letter-spacing:1.5px;text-transform:uppercase;color:#1a1206;background:var(--gold-bright);border-radius:5px;padding:2px 6px;font-weight:600;}
  .nt-del{margin-left:auto;background:transparent;border:none;color:#5a4a40;cursor:pointer;padding:4px;display:flex;border-radius:6px;transition:.15s;}
  .nt-del svg{width:14px;height:14px;}
  .nt-del:hover{color:var(--red);background:rgba(192,57,43,.12);}
  .nt-text{color:var(--ink);font-size:.95rem;line-height:1.45;white-space:pre-wrap;word-break:break-word;}
  .nt-reads{margin-top:7px;font-size:.72rem;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:5px 7px;}
  .nt-read-label{color:#7ea65a;font-weight:500;}
  .nt-reader{display:inline-flex;align-items:center;gap:3px;}
  .nt-rdot{width:7px;height:7px;border-radius:50%;display:inline-block;}
  .nt-missing{color:#a08b5a;}
  /* compor novo recado */
  .notices-compose{border-top:1px solid var(--line);padding-top:12px;display:flex;flex-direction:column;gap:8px;}
  .notices-compose textarea{width:100%;min-height:60px;resize:vertical;background:var(--panel2);border:1px solid var(--line);border-radius:9px;color:var(--ink);font-family:'Oswald';font-weight:300;font-size:.95rem;padding:10px 12px;letter-spacing:.4px;}
  .notices-compose textarea:focus{outline:none;border-color:var(--gold);}
  .notices-compose-foot{display:flex;align-items:center;gap:10px;}
  .nt-count{flex:1;font-size:.72rem;color:var(--muted);}

  /* === Agenda: pílula + badge de dias até o próximo show === */
  #showsBtn{position:relative;}
  .show-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--gold);color:#1a1206;font-family:'Oswald';font-weight:700;font-size:.6rem;line-height:18px;text-align:center;box-shadow:0 0 0 2px var(--bg);}
  #showsBtn.show-soon{border-color:var(--gold-bright);color:var(--gold-bright);}
  #showsBtn.show-soon .show-badge{background:var(--gold-bright);}

  /* === card "próximo show" (aviso na tela) === */
  .next-show{max-width:1060px;margin:22px auto 0;display:flex;align-items:center;gap:12px;padding:11px 18px;background:linear-gradient(180deg,rgba(224,161,60,.08),rgba(224,161,60,.03));border:1px solid rgba(224,161,60,.25);border-radius:12px;cursor:pointer;transition:.18s;}
  .next-show:hover{border-color:var(--gold);}
  .next-show .ns-ico{font-size:1.2rem;line-height:1;flex:none;}
  .next-show .ns-body{display:flex;flex-direction:column;gap:1px;min-width:0;}
  .next-show .ns-label{font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600;}
  .next-show .ns-venue{font-family:'Oswald';font-weight:500;font-size:1rem;color:var(--ink);letter-spacing:.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .next-show .ns-city{color:var(--muted);font-weight:300;font-size:.85rem;}
  .next-show .ns-when{margin-left:auto;font-family:'Oswald';font-weight:500;font-size:.82rem;color:var(--gold-bright);text-transform:uppercase;letter-spacing:1px;white-space:nowrap;}
  .next-show .ns-count{flex:none;font-family:'Oswald';font-weight:600;font-size:.72rem;letter-spacing:.5px;color:var(--muted);background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:3px 10px;white-space:nowrap;}
  .next-show.urgent{border-color:var(--gold-bright);background:linear-gradient(180deg,rgba(244,185,78,.16),rgba(244,185,78,.05));box-shadow:0 0 24px -10px rgba(244,185,78,.6);}
  .next-show.urgent .ns-count{background:var(--gold-bright);color:#1a1206;border-color:var(--gold-bright);}
  @media(max-width:560px){ .next-show{flex-wrap:wrap;} .next-show .ns-when{margin-left:0;} }

  /* === modal Agenda (.modal.shows-modal vence o max-width base do .modal) === */
  .modal.shows-modal{max-width:600px;}
  #showAddBtn{margin-bottom:14px;}
  .show-form{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:16px;display:flex;flex-direction:column;gap:9px;}
  .show-form .sf-title{font-family:'Oswald';font-weight:500;color:var(--gold);letter-spacing:1px;text-transform:uppercase;font-size:.78rem;}
  .show-form .show-notes{min-height:58px;resize:vertical;font-family:'Oswald';font-weight:300;}
  .show-form input[type="datetime-local"]{color-scheme:dark;}
  .sf-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
  .shows-next{display:flex;flex-direction:column;gap:10px;}
  .shows-empty{color:var(--muted);font-size:.9rem;text-align:center;padding:18px 8px;line-height:1.5;}
  .show-item{display:flex;gap:13px;align-items:flex-start;background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:11px 13px;}
  .show-item.urgent{border-color:rgba(244,185,78,.5);box-shadow:0 0 0 1px rgba(244,185,78,.25) inset;}
  .show-item.past{opacity:.6;}
  .si-date{flex:none;width:54px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:6px 4px;}
  .si-dow{font-size:.6rem;letter-spacing:1px;color:var(--gold);text-transform:uppercase;font-weight:600;}
  .si-day{font-family:'Bebas Neue';font-size:1.7rem;line-height:1;color:var(--ink);}
  .si-mon{font-size:.6rem;letter-spacing:1px;color:var(--muted);text-transform:uppercase;}
  .si-info{flex:1;min-width:0;}
  .si-venue{font-family:'Oswald';font-weight:500;font-size:1rem;color:var(--ink);letter-spacing:.4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
  .si-count{font-size:.66rem;font-weight:600;letter-spacing:.5px;color:var(--gold-bright);background:rgba(224,161,60,.14);border-radius:20px;padding:2px 9px;text-transform:uppercase;}
  .show-item.past .si-count{color:var(--muted);background:rgba(255,255,255,.05);}
  .si-meta{color:var(--muted);font-size:.82rem;margin-top:2px;}
  .si-notes{color:var(--ink);font-size:.84rem;margin-top:5px;opacity:.85;white-space:pre-wrap;word-break:break-word;}
  .si-creator{color:var(--muted);font-size:.68rem;margin-top:5px;font-style:italic;}
  .si-actions{flex:none;display:flex;gap:2px;}
  .si-edit,.si-del{background:transparent;border:none;color:#5a4a40;cursor:pointer;padding:5px;display:flex;border-radius:6px;transition:.15s;}
  .si-edit svg,.si-del svg{width:15px;height:15px;}
  .si-edit:hover{color:var(--gold-bright);background:rgba(224,161,60,.12);}
  .si-del:hover{color:var(--red);background:rgba(192,57,43,.12);}
  .shows-past{margin-top:16px;}
  .shows-past summary{cursor:pointer;color:var(--muted);font-size:.8rem;letter-spacing:1px;text-transform:uppercase;padding:6px 0;user-select:none;}
  .shows-past summary:hover{color:var(--gold);}
  .shows-past-list{display:flex;flex-direction:column;gap:10px;margin-top:10px;}

  .who{margin:30px 0 0;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 22px 22px;box-shadow:0 14px 50px -22px rgba(0,0,0,.7), 0 0 46px -26px rgba(224,161,60,.35);}
  .add-q{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:22px;}
  .add-q-label{color:var(--gold);}
  .add-q-left{display:inline-flex;align-items:center;}
  /* .add-band-link compartilha o MESMO estilo de "+ Criar SetList" (.add-setlist-link) — ver regra agrupada abaixo */
  .live-badge{display:inline-block;vertical-align:middle;margin-left:8px;font-family:'Oswald';font-weight:600;font-size:.58rem;letter-spacing:1.5px;color:#fff;background:var(--red);border-radius:4px;padding:1px 5px;}
  /* toggle "LIVE" dentro do campo Nome da música */
  .add-title-wrap{position:relative;flex:1;min-width:110px;display:flex;}
  .add-title-wrap input{flex:1;width:100%;padding-right:62px;}
  .live-chip{position:absolute;right:5px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;gap:3px;font-family:'Oswald';font-weight:600;font-size:.6rem;letter-spacing:1.5px;color:var(--muted);background:transparent;border:1px solid rgba(239,68,68,.35);border-radius:6px;padding:3px 7px;cursor:pointer;transition:.15s;}
  .live-chip svg{width:10px;height:10px;opacity:.35;transition:.15s;}
  .live-chip:hover{border-color:var(--red);color:#e88;}
  .live-chip.on{background:var(--red);border-color:var(--red);color:#fff;box-shadow:0 0 0 3px rgba(239,68,68,.18);}
  .live-chip.on svg{opacity:1;}
  .add-row{display:flex;align-items:center;gap:9px;flex-wrap:wrap;}
  .add-row input{flex:1;min-width:110px;background:var(--panel2);border:1px solid var(--line);border-radius:7px;color:var(--ink);font-family:'Oswald';font-size:.92rem;padding:9px 11px;}
  .add-row input::placeholder{color:var(--muted);}
  .add-row input:focus{outline:none;border-color:var(--gold);}
  /* autocomplete de música/banda (dropdown de sugestões do Spotify) */
  .ac-wrap{position:relative;flex:1;min-width:110px;display:flex;}
  .ac-wrap input{flex:1;width:100%;}
  .ac-box{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:var(--z-autocomplete);max-height:264px;overflow-y:auto;background:#17171b;border:1px solid rgba(224,161,60,.3);border-radius:10px;box-shadow:0 14px 32px rgba(0,0,0,.6);}
  .ac-item{display:flex;flex-direction:column;gap:1px;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.06);padding:8px 12px;cursor:pointer;}
  .ac-item:last-child{border-bottom:none;}
  .ac-item:hover{background:rgba(224,161,60,.13);}
  .ac-t{color:#ededed;font-family:'Oswald';font-size:.9rem;letter-spacing:.3px;}
  .ac-b{color:var(--muted);font-size:.74rem;}
  .add-btn{font-family:'Oswald';font-weight:500;font-size:.78rem;letter-spacing:1px;text-transform:uppercase;color:#1a1206;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border:none;border-radius:7px;padding:10px 18px;cursor:pointer;white-space:nowrap;transition:.15s;}
  .add-btn:hover{filter:brightness(1.1);}
  .add-btn.alt{background:linear-gradient(180deg,#2a2017,#1a1410);color:var(--gold-bright);border:1px solid var(--line);}
  .add-btn.cf-import{font-size:.66rem;padding:6px 11px;letter-spacing:.6px;opacity:.85;}
  .add-btn.cf-import:hover{opacity:1;}
  .add-box.shake,.bulk-panel.shake{animation:shake .4s;}
  @keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
  .bulk-panel{margin-top:10px;}
  .bulk-panel textarea{width:100%;min-height:120px;resize:vertical;background:var(--panel2);border:1px solid var(--line);border-radius:9px;color:var(--ink);font-family:'Oswald';font-weight:300;font-size:.92rem;padding:11px 13px;line-height:1.5;}
  .bulk-panel textarea:focus{outline:none;border-color:var(--gold);}
  .bulk-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;flex-wrap:wrap;}
  .bulk-info{font-size:.7rem;color:var(--muted);letter-spacing:.5px;}
  .bulk-info.over{color:var(--red);}
  .add-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:16px;}
  .add-hint{font-size:.68rem;color:var(--muted);letter-spacing:.5px;}
  .yt-hint{display:inline-flex;align-items:center;gap:8px;font-family:'Oswald';font-size:.72rem;letter-spacing:.5px;color:var(--muted);background:transparent;border:1px solid var(--line);border-radius:8px;padding:6px 11px;cursor:pointer;transition:.15s;text-align:left;}
  .yt-hint svg{width:15px;height:15px;flex:none;opacity:.85;}
  .yt-hint strong{color:var(--muted);font-weight:600;}
  .yt-hint:hover{background:rgba(255,255,255,.03);border-color:var(--muted);}
  .add-status{font-size:.68rem;color:var(--muted);letter-spacing:.5px;margin-top:6px;min-height:0;}
  .add-member-link{margin-left:auto;align-self:center;font-family:'Oswald';font-weight:500;font-size:.7rem;letter-spacing:.5px;text-transform:none;color:var(--gold-bright);background:transparent;border:1px solid rgba(224,161,60,.4);border-radius:8px;padding:5px 11px;cursor:pointer;transition:.15s;white-space:nowrap;}
  .add-member-link:hover{background:rgba(224,161,60,.12);border-color:var(--gold-bright);}
  .limit-ctrl{font-size:.68rem;color:var(--muted);letter-spacing:.5px;display:flex;align-items:center;gap:6px;}
  .limit-display{font-size:.68rem;color:var(--muted);letter-spacing:.5px;display:flex;align-items:center;gap:5px;text-transform:lowercase;}
  .limit-display strong{color:var(--gold-bright);font-weight:600;font-family:'Bebas Neue';font-size:1rem;letter-spacing:.5px;}
  .lim-btn{font-family:'Oswald';font-size:1rem;line-height:1;width:24px;height:24px;border-radius:6px;border:1px solid var(--line);background:var(--panel2);color:var(--gold-bright);cursor:pointer;}
  .lim-btn:hover{border-color:var(--gold);}
  #limVal{color:var(--gold-bright);font-weight:600;min-width:20px;text-align:center;display:inline-block;}
  .quota-row{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px;}
  .quota{font-size:.64rem;letter-spacing:.5px;padding:3px 9px;border-radius:20px;color:var(--muted);background:rgba(255,255,255,.045);border:1px solid var(--line);}
  .quota.full{background:rgba(192,57,43,.18);border-color:var(--red);color:#e88;font-weight:600;}
  .q{font-size:.78rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:16px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;}
  .vote-kicker{font-family:'Anton',sans-serif;font-weight:400;color:var(--gold-bright);white-space:nowrap;font-size:1.05rem;line-height:1;text-transform:uppercase;letter-spacing:.5px;}
  .band-title{margin-bottom:14px;}
  @keyframes scoreBump{0%{transform:scale(1)}35%{transform:scale(1.45);color:var(--gold)}100%{transform:scale(1)}}
  @keyframes starPop{0%{transform:scale(1)}40%{transform:scale(1.5)}100%{transform:scale(1)}}
  .voted-pulse .score .total{animation:scoreBump .45s ease;}
  .voted-pulse .star.lit{animation:starPop .4s ease;}
  .who-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;align-items:flex-start;}
  .who-col{display:flex;flex-direction:column;align-items:center;gap:8px;}
  .who-btn{font-family:'Oswald';font-weight:500;font-size:.95rem;letter-spacing:1px;padding:11px 13px;border-radius:9px;cursor:pointer;background:var(--panel2);border:1.5px solid var(--line);color:var(--ink);transition:.16s;display:inline-flex;align-items:center;gap:9px;}
  .who-dot{width:9px;height:9px;border-radius:50%;flex:none;box-shadow:0 0 6px color-mix(in srgb, currentColor 40%, transparent);}
  .who-inst{font-size:.92em;line-height:1;margin:0 -2px 0 -4px;}   /* emoji do instrumento: pequeno p/ não inchar o botão */
  .who-btn:hover{border-color:var(--gold);}
  .who-btn.active{background:linear-gradient(180deg,#3a2a14,#241906);border-color:var(--gold-bright);color:var(--gold-bright);box-shadow:0 0 0 1px var(--gold-bright) inset;}
  .who-btn.who-add{border-style:dashed;color:var(--muted);background:transparent;}
  .who-btn.who-add:hover{color:var(--gold);border-color:var(--gold);}
  .rename{margin-top:12px;font-size:.74rem;color:var(--muted);text-align:center;}
  .rename input{background:transparent;border:none;border-bottom:1px dashed var(--line);color:var(--gold-bright);font-family:'Oswald';font-size:.82rem;text-align:center;width:120px;padding:2px 4px;}
  .rename input:focus{outline:none;border-bottom-color:var(--gold);}

  .toolbar{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;margin:24px 0 4px;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);}
  .toolbar .seg{display:flex;gap:6px;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:4px;}
  .toolbar .seg button{font-family:'Oswald';font-weight:500;font-size:.74rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);background:transparent;border:none;padding:7px 13px;border-radius:6px;cursor:pointer;}
  .toolbar .seg button.on{background:var(--gold);color:#1a1206;}
  .sync-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);margin-right:6px;vertical-align:middle;animation:pulse 2s infinite;}
  /* legenda das notas (★) — onde antes ficava a ordenação */
  .star-legend{display:flex;gap:16px;flex-wrap:wrap;align-items:center;text-transform:none;letter-spacing:.3px;font-size:.98rem;color:var(--muted);}
  .star-legend span{display:inline-flex;align-items:center;}
  .star-legend i{font-style:normal;color:var(--gold-bright);letter-spacing:-1px;margin-right:6px;font-size:1.2rem;}
  .star-legend i.veto{color:var(--red);}
  /* ordenação agora vive no cabeçalho da "Sugestão da Banda" */
  .set-head{flex-wrap:wrap;}
  .set-head .sl-sort{display:flex;gap:5px;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:4px;align-self:center;}
  .set-head .sl-sort button{font-family:'Oswald';font-weight:500;font-size:.68rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);background:transparent;border:none;padding:5px 10px;border-radius:6px;cursor:pointer;}
  .set-head .sl-sort button.on{background:var(--gold);color:#1a1206;}
  /* anti-cópia leve: sem seleção de texto nas listas/votação (campos de digitação seguem selecionáveis) */
  .song,.sl-row,.sl-break,.set-head,.sl-pick,.who-tag,.breakdown,.sl-foot{-webkit-user-select:none;user-select:none;}
  input,textarea,.sl-break-label{-webkit-user-select:text;user-select:text;}
  @keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

  .set{margin-top:30px;}
  .top-block{background:linear-gradient(180deg,rgba(224,161,60,.06),transparent 70%);border:1px solid rgba(224,161,60,.22);border-radius:16px;padding:8px 16px 18px;margin-top:10px;box-shadow:0 16px 50px -24px rgba(0,0,0,.65), 0 0 54px -22px rgba(224,161,60,.3);}
  .top-block .set-head .tag span{color:var(--gold-bright);}
  .empty-rank{text-align:center;padding:30px 16px;color:var(--muted);font-size:.9rem;}
  .set-head{display:flex;align-items:baseline;gap:16px;padding-bottom:12px;margin-bottom:6px;border-bottom:1px solid var(--line);}
  .set-head .tag{font-family:'Anton';font-size:clamp(1.2rem,3.6vw,1.75rem);text-transform:uppercase;}
  .set-head .tag span{color:var(--red);font-size:.55em;letter-spacing:1px;}
  .set-head .tag span.gold-sub{color:var(--gold-bright);}
  .set-head .count{margin-left:auto;font-size:.76rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
  .set-head-right{margin-left:auto;display:flex;flex-direction:row;align-items:center;gap:10px;}
  .set-head-right .count{margin-left:0;}
  .add-setlist-link,.add-band-link{font-family:'Oswald';font-weight:500;font-size:.72rem;letter-spacing:.8px;text-transform:uppercase;color:var(--gold-bright);background:transparent;border:none;padding:0;cursor:pointer;transition:.15s;white-space:nowrap;}
  .add-setlist-link:hover,.add-band-link:hover{color:var(--gold);text-decoration:underline;}

  /* cabeçalho com o seletor de ordenação: título à esquerda, seletor centralizado, contador à direita */
  .set-head:has(.sl-sort){display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;}
  .set-head:has(.sl-sort) .count{margin-left:0;text-align:right;}

  .song{display:grid;grid-template-columns:42px 1fr auto auto auto auto;align-items:center;gap:14px;padding:12px 14px;border-radius:11px;border:1px solid transparent;transition:.22s ease;position:relative;}
  .song:nth-child(odd){background:var(--panel);}
  .song:nth-child(even){background:var(--panel2);}
  .song.top3{border-color:rgba(224,161,60,.4);box-shadow:0 0 22px rgba(224,161,60,.08);}
  .song .rank{font-family:'Bebas Neue';font-size:1.6rem;color:var(--gold);text-align:center;opacity:.85;}
  .song.top1 .rank{color:var(--gold-bright);text-shadow:0 0 12px rgba(244,185,78,.5);}
  .title-cell .t{font-weight:500;font-size:1.08rem;letter-spacing:.4px;display:flex;align-items:center;gap:9px;flex-wrap:wrap;}
  .title-cell .b{font-size:.8rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:1px;}
  .tags{display:flex;flex-direction:row;gap:4px;align-items:center;justify-content:flex-end;flex-wrap:wrap;max-width:220px;}
  .who-tag{font-size:.6rem;letter-spacing:.5px;text-transform:uppercase;font-weight:500;padding:2px 8px;border-radius:20px;color:var(--tc);background:color-mix(in srgb, var(--tc) 14%, transparent);border:1px solid color-mix(in srgb, var(--tc) 35%, transparent);white-space:nowrap;}
  .yt-ic{display:inline-flex;color:#e74c3c;text-decoration:none;}
  .yt-ic:hover{color:#ff5e4d;}
  .yt-ic svg{width:17px;height:17px;}
  .sp-ic{display:inline-flex;color:#1db954;text-decoration:none;margin-left:1px;}
  .sp-ic:hover{color:#1ed760;}
  .sp-ic svg{width:17px;height:17px;}
  /* pílulas de links externos: cifra, tablatura */
  .ext-ic{display:inline-flex;align-items:center;justify-content:center;height:18px;padding:0 8px;font-family:'Oswald';font-weight:400;font-size:.65rem;letter-spacing:.6px;line-height:1;text-decoration:none;border-radius:9px;border:1px solid color-mix(in srgb, currentColor 38%, transparent);background:transparent;transition:.15s ease;margin-left:3px;text-transform:uppercase;}
  .ext-ic:hover{background:color-mix(in srgb, currentColor 14%, transparent);border-color:color-mix(in srgb, currentColor 60%, transparent);}
  .ext-ic.ss{color:#93bdde;}
  .ext-ic.lt{color:#f0d268;}
  .ext-ic.cf{color:#f0985a;}   /* Cifra (laranja) → Cifra Club */
  /* link discreto mas perceptível: off-white + sublinhado pontilhado (sinaliza "clicável" sem poluir) */
  .wiki-link{font-size:.78rem;color:#d9d2c7;text-decoration:underline dotted;text-decoration-thickness:1px;text-underline-offset:3px;text-decoration-color:rgba(217,210,199,.55);opacity:.95;letter-spacing:.5px;text-transform:lowercase;font-weight:600;}
  .wiki-link:hover{color:var(--gold-bright);text-decoration-color:var(--gold-bright);opacity:1;}
  .score{display:flex;align-items:center;gap:7px;}
  .score .total{font-family:'Bebas Neue';font-size:1.7rem;color:var(--gold-bright);line-height:1;min-width:24px;text-align:right;}
  .breakdown{display:flex;gap:3px;}
  .chip{font-size:.6rem;min-width:22px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:var(--panel2);border:1px solid var(--line);color:var(--muted);padding:0 3px;}
  .chip.has{color:var(--gold-bright);border-color:rgba(224,161,60,.4);}
  .chip.veto{color:#e88;border-color:rgba(192,57,43,.55);background:rgba(192,57,43,.12);}
  .stars{display:flex;gap:3px;}
  .star{width:26px;height:26px;cursor:pointer;color:#3a322b;transition:.12s ease;}
  .star.lit{color:var(--gold-bright);filter:drop-shadow(0 0 4px rgba(244,185,78,.5));}
  .star.veto{color:var(--red);filter:drop-shadow(0 0 4px rgba(192,57,43,.55));}
  .star.disabled{cursor:default;opacity:.5;}
  .del-btn{background:transparent;border:none;color:#5a4a40;cursor:pointer;padding:6px;border-radius:7px;display:flex;align-items:center;justify-content:center;}
  .del-btn svg{width:17px;height:17px;}
  .del-btn:hover{color:var(--red);background:rgba(192,57,43,.12);}
  .row-actions{display:flex;gap:2px;align-items:center;}
  .edit-btn{background:transparent;border:none;color:#5a4a40;cursor:pointer;padding:6px;border-radius:7px;display:flex;align-items:center;justify-content:center;}
  .edit-btn svg{width:16px;height:16px;}
  .edit-btn:hover{color:var(--gold-bright);background:rgba(224,161,60,.12);}
  .my-label{font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
  .bpm-loading{font-size:.62rem;color:var(--gold);font-style:italic;}
  .not-found{font-size:.62rem;color:var(--red);font-style:italic;letter-spacing:.5px;}

  @media(max-width:720px){
    header{padding-top:118px;}   /* no mobile os 2 grupos de pílulas podem ir pra 2 linhas + respiro acima do título */
    /* linha de música em 3 "andares" fixos: título+ações · banda/info+sugeridores · voto.
       Antes .tags e .row-actions dividiam a MESMA célula (sobrepunham) e os links fluíam
       junto do título → linhas de altura aleatória ("distorcido"). */
    .song{grid-template-columns:24px minmax(0,1fr) auto;gap:2px 8px;padding:10px 11px;}
    .song .rank{grid-row:1;grid-column:1;font-size:1.15rem;}
    .title-cell{grid-row:1 / span 2;grid-column:2;min-width:0;}
    .row-actions, .del-btn{grid-row:1;grid-column:3;justify-self:end;align-self:start;}
    .tags{grid-row:2;grid-column:3;align-self:end;justify-content:flex-end;max-width:120px;padding:0;}
    .score{grid-row:3;grid-column:1 / 3;flex-direction:row;justify-content:flex-start;margin-top:6px;}
    .stars{grid-row:3;grid-column:3;justify-content:flex-end;margin-top:6px;}
    .star{width:30px;height:30px;}
    /* título SEMPRE numa linha só (corta com "…"; nome dourado segue avisando que tem cifra)
       e o separador nome→links vira QUEBRA: ouvir/tocar ganham a linha de baixo, alinhados */
    .title-cell .t{gap:4px 5px;}
    .title-cell .t .song-name{flex:0 1 auto;min-width:0;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;}
    .title-cell .t:has(.live-badge) .song-name{max-width:calc(100% - 46px);}   /* reserva o lugar do LIVE na MESMA linha */
    .title-cell .t .song-name .cs-mark{vertical-align:-2px;}
    .title-cell .t .nm-sep{flex-basis:100%;width:auto;height:0;margin:0;background:none;}
    /* linha de links compacta (cabe yt+sp+Letras/Cifra/Tablatura sem quebrar) */
    .title-cell .t .lk-sep{margin:0 4px;height:13px;}
    .title-cell .t .ext-ic{padding:0 6px;font-size:.62rem;letter-spacing:.4px;margin-left:1px;}
    .tags{font-size:0;}
    .tags .who-tag{font-size:.5rem;padding:2px 5px;}
  }

  /* pílulas de topo (Config + Regras) */
  .top-pills{position:absolute;top:18px;left:18px;right:18px;z-index:20;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;}
  .pills-group{display:flex;gap:8px;flex-wrap:wrap;}   /* esquerda: Banda+Setlist · direita: Config+Regras+Sair */
  .pill-btn{display:inline-flex;align-items:center;gap:6px;font-family:'Oswald';font-weight:500;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);background:rgba(224,161,60,.08);border:1px solid rgba(224,161,60,.3);border-radius:20px;padding:7px 13px;cursor:pointer;transition:.15s;}
  .pill-btn:hover{background:rgba(224,161,60,.16);border-color:var(--gold);}
  .pill-btn.accent{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1206;border-color:var(--gold-bright);box-shadow:0 0 14px rgba(224,161,60,.25);}
  .pill-btn.accent:hover{filter:brightness(1.08);background:linear-gradient(180deg,var(--gold-bright),var(--gold));}
  .pill-btn svg{width:15px;height:15px;}
  /* seletor de banda (Fase 2) — pílula + dropdown data-driven */
  .band-switch{position:relative;}
  .band-switch .band-chev{width:13px;height:13px;opacity:.7;}
  #bandPillName{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .band-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:190px;background:var(--panel);border:1px solid var(--gold);border-radius:12px;padding:6px;box-shadow:0 18px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(224,161,60,.14);z-index:var(--z-float);}
  .band-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:none;color:var(--ink);font-family:'Oswald';font-size:.82rem;letter-spacing:.5px;padding:9px 10px;border-radius:8px;cursor:pointer;}
  .band-item:hover{background:rgba(224,161,60,.12);}
  .band-item.on{color:var(--gold-bright);}
  .band-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .band-item em{color:var(--muted);font-style:normal;font-size:.66rem;text-transform:uppercase;letter-spacing:1px;}
  .band-item-dot{width:7px;height:7px;border-radius:50%;background:var(--line);flex:none;}
  .band-item.on .band-item-dot{background:var(--gold-bright);}
  .band-item.band-new{border-top:1px solid var(--line);margin-top:4px;color:var(--gold);text-transform:uppercase;font-size:.72rem;letter-spacing:1px;}

  /* ícone (i) informativo inline */
  .info-tip{display:inline-flex;align-items:center;justify-content:center;color:var(--muted);opacity:.65;cursor:help;vertical-align:middle;margin-left:6px;background:none;border:none;padding:0;}
  .info-tip:hover{opacity:1;color:var(--gold-bright);}
  .info-tip svg{width:14px;height:14px;}

  /* modal de configurações */
  .modal.config-modal{max-width:660px;max-height:85vh;overflow-y:auto;}
  .cfg-section{margin-bottom:22px;}
  .cfg-section:last-child{margin-bottom:6px;}
  .cfg-label{display:block;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;font-weight:500;}
  .cfg-maint{display:flex;flex-direction:column;gap:14px;}
  .cfg-maint-item{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}
  .cfg-hint{font-size:.72rem;color:var(--muted);line-height:1.5;flex:1;min-width:160px;}
  .cfg-input{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:8px;color:var(--ink);font-family:'Oswald';font-weight:300;font-size:.98rem;padding:11px 14px;letter-spacing:.5px;}
  .cfg-input:focus{outline:none;border-color:var(--gold);}
  .cfg-input::placeholder{color:var(--muted);}
  .cfg-limit{display:flex;align-items:center;gap:14px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:8px 14px;width:fit-content;}
  .cfg-limit button{font-family:'Oswald';font-size:1.4rem;line-height:1;width:34px;height:34px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--gold-bright);cursor:pointer;}
  .cfg-limit button:hover{border-color:var(--gold);background:rgba(224,161,60,.08);}
  #cfgLimVal{font-family:'Bebas Neue';font-size:1.7rem;color:var(--gold-bright);min-width:36px;text-align:center;}
  .cfg-members{display:flex;flex-direction:column;gap:7px;}
  .cfg-member{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;}
  .cfg-member-color{width:10px;height:10px;border-radius:50%;flex:none;background:var(--mc);}
  .cfg-member-name{flex:1;background:transparent;border:none;color:var(--ink);font-family:'Oswald';font-weight:300;font-size:.98rem;padding:3px 0;letter-spacing:.5px;}
  .cfg-member-name:focus{outline:none;background:rgba(224,161,60,.06);border-radius:4px;padding:3px 6px;}
  .cfg-member-del{background:transparent;border:none;color:#5a4a40;cursor:pointer;padding:6px;display:flex;border-radius:6px;}
  .cfg-member-del:hover{color:var(--red);background:rgba(192,57,43,.12);}
  .cfg-member-del svg{width:16px;height:16px;}
  /* instrumento agora é um botão (abre o seletor multi de instrumentos) */
  .cfg-member-wrap{display:flex;flex-direction:column;gap:8px;}
  .cfg-member-inst{display:inline-flex;align-items:center;gap:5px;background:transparent;border:none;border-left:1px solid var(--line);color:var(--muted);font-family:'Oswald';font-weight:300;font-size:.82rem;padding:3px 0 3px 10px;letter-spacing:.4px;cursor:pointer;transition:.15s;white-space:nowrap;}
  .cfg-member-inst .cmi-emojis{font-size:1.05rem;line-height:1;}
  .cfg-member-inst .cmi-cap{display:none;}
  .cfg-member-inst.empty{color:#6a5d50;}
  .cfg-member-inst.empty .cmi-cap{display:inline;}
  .cfg-member-inst:hover,.cfg-member-inst.open{color:var(--gold-bright);}
  .cfg-inst-picker{display:flex;flex-wrap:wrap;gap:6px;padding:2px 2px 4px;}
  .cfg-inst-chip{display:inline-flex;align-items:center;gap:5px;background:var(--panel);border:1px solid var(--line);border-radius:18px;color:var(--muted);font-family:'Oswald';font-weight:300;font-size:.78rem;letter-spacing:.4px;padding:5px 11px;cursor:pointer;transition:.14s;}
  .cfg-inst-chip .ci-emoji{font-size:.95rem;line-height:1;}
  .cfg-inst-chip:hover{border-color:var(--gold);color:var(--ink);}
  .cfg-inst-chip.on{background:linear-gradient(180deg,#3a2a14,#241906);border-color:var(--gold-bright);color:var(--gold-bright);}
  .cfg-add-member{margin-top:4px;width:100%;font-family:'Oswald';font-size:.74rem;letter-spacing:1px;text-transform:uppercase;color:var(--gold);background:transparent;border:1px dashed var(--line);border-radius:8px;padding:9px;cursor:pointer;}
  .cfg-add-member:hover{background:rgba(224,161,60,.08);border-color:var(--gold);}
  .modal-overlay{position:fixed;inset:0;background:rgba(5,4,3,.78);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;overflow-y:auto;z-index:var(--z-modal);padding:20px;}
  .modal-overlay.show{display:flex;}
  .modal{position:relative;margin:auto;background:var(--panel);border:1px solid var(--gold);border-radius:16px;padding:26px 24px;max-width:420px;width:100%;box-shadow:0 32px 90px -16px rgba(0,0,0,.88), 0 0 0 1px rgba(224,161,60,.14), 0 0 80px -22px rgba(224,161,60,.42);}
  .modal-overlay.show .modal{animation:modalPop .22s cubic-bezier(.2,.8,.2,1);}
  @keyframes modalPop{from{opacity:0;transform:translateY(10px) scale(.97);}to{opacity:1;transform:none;}}
  .modal-x{position:absolute;top:12px;right:12px;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;font-size:1.35rem;line-height:1;color:var(--muted);background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:9px;cursor:pointer;transition:.15s;z-index:3;}
  .modal-x:hover{color:var(--ink);border-color:var(--gold);background:rgba(224,161,60,.14);}
  .modal-title{font-family:'Anton',sans-serif;font-size:1.5rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;padding-right:30px;}
  .modal-body{font-size:.95rem;color:var(--muted);line-height:1.55;margin-bottom:22px;}
  .modal-body strong{color:var(--gold-bright);font-weight:500;}
  .modal-btns{display:flex;gap:12px;justify-content:flex-end;}
  .modal-btn{font-family:'Oswald';font-weight:500;font-size:.85rem;letter-spacing:1px;text-transform:uppercase;padding:11px 20px;border-radius:9px;cursor:pointer;border:1px solid var(--line);}
  .modal-btn.cancel{background:var(--panel2);color:var(--ink);}
  .modal-btn.ico{display:inline-flex;align-items:center;gap:7px;}
  .exp-ico{width:15px;height:15px;flex:none;}
  .modal-btn.confirm{background:linear-gradient(180deg,#d4493a,#a8281c);color:#fff;border:none;}
  .modal-btn.confirm.gold{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1206;}
  .rules-modal{max-width:660px;max-height:92vh;overflow-y:auto;}
  .rule-item{display:flex;gap:13px;align-items:flex-start;margin-bottom:15px;text-align:left;}
  .rule-n{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(224,161,60,.14);border:1px solid rgba(224,161,60,.4);color:var(--gold-bright);font-family:'Bebas Neue';font-size:1.05rem;display:flex;align-items:center;justify-content:center;}
  .rule-item div{font-size:.9rem;line-height:1.5;color:var(--ink);}
  .rule-item strong{color:var(--gold-bright);font-weight:500;}
  .rule-item .rule-head{font-weight:700;}

  /* added-song modal */
  .added-modal{max-width:440px;text-align:center;}
  .added-modal .modal-title{text-align:center;margin-top:4px;padding-left:30px;}
  .added-modal .modal-body{text-align:center;}
  /* onboarding (modal de boas-vindas — aparece em toda entrada / mural de novidades) */
  .welcome-modal{max-width:560px;max-height:88vh;display:flex;flex-direction:column;}
  .welcome-modal>.modal-title{flex:0 0 auto;}
  .welcome-modal>.modal-body{flex:1 1 auto;min-height:0;overflow-y:auto;padding-right:6px;}
  .welcome-modal>.welcome-ask,.welcome-modal>.modal-btns{flex:0 0 auto;}
  .welcome-modal>.welcome-ask{margin-top:14px;}
  .welcome-title{font-size:1.72rem;letter-spacing:.5px;}
  .wn-badge{display:inline-block;font-family:'Oswald';font-weight:700;font-size:.58rem;letter-spacing:1px;color:#fff;background:var(--red);border-radius:5px;padding:2px 6px;vertical-align:middle;margin-left:4px;}
  .rules-intro{color:var(--muted);font-size:.9rem;margin:0 0 15px;line-height:1.5;}
  .rules-intro strong{color:var(--ink);}
  /* o botão "Abrir Config" das Regras só faz sentido logado → some na tela de login */
  body.login-mode #rulesConfig{display:none;}
  .slm-logo{font-family:'Anton',sans-serif;letter-spacing:.5px;background:linear-gradient(180deg,#fff 0%,var(--gold-bright) 50%,var(--gold) 78%,#9c6a1c 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
  .welcome-news{background:rgba(224,161,60,.07);border:1px solid rgba(224,161,60,.22);border-radius:12px;padding:13px 16px;margin:14px 0 4px;}
  .wn-head{font-family:'Oswald';font-weight:600;font-size:.82rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-bright);margin-bottom:8px;}
  .wn-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:8px;font-size:.92rem;line-height:1.5;color:var(--muted);}
  .wn-list .wn-hidden{display:none;}   /* novidades antigas — abrem no "ver anteriores" */
  .wn-more-btn{display:block;margin:8px auto 0;background:none;border:none;color:var(--gold);font-family:'Oswald';font-weight:500;font-size:.78rem;letter-spacing:.5px;cursor:pointer;text-decoration:underline;padding:5px;}
  .wn-more-btn:hover{color:var(--gold-bright);}
  .wn-list b{color:var(--ink);font-weight:500;}
  .welcome-ask{margin:16px 2px 0;font-size:.92rem;color:var(--muted);line-height:1.5;}
  .welcome-ask b{color:var(--gold);}
  .spinner{width:50px;height:50px;border:3px solid rgba(224,161,60,.2);border-top-color:var(--gold-bright);border-radius:50%;margin:6px auto 18px;animation:spin .9s linear infinite;}
  @keyframes spin{to{transform:rotate(360deg)}}
  .check-icon{width:56px;height:56px;border-radius:50%;background:rgba(107,142,78,.18);border:2px solid var(--green);color:#a8d176;display:flex;align-items:center;justify-content:center;font-size:1.9rem;margin:4px auto 14px;font-family:'Bebas Neue';}
  .check-icon.warn{background:rgba(224,161,60,.18);border-color:var(--gold-bright);color:var(--gold-bright);}
  .added-info-line{font-size:.96rem;line-height:1.5;color:var(--ink);}
  .added-info-line.muted{color:var(--muted);font-size:.86rem;margin-top:8px;}
  .added-info-line strong{color:var(--gold-bright);font-weight:500;}
  .added-info-line .bpm{font-family:'Bebas Neue';font-size:1.1em;letter-spacing:.5px;}
  .yt-link{display:inline-flex;align-items:center;gap:7px;margin-top:14px;padding:9px 16px;background:rgba(192,57,43,.12);border:1px solid rgba(192,57,43,.35);border-radius:8px;color:#e88;text-decoration:none;font-weight:500;font-size:.82rem;letter-spacing:1.2px;text-transform:uppercase;font-family:'Oswald';}
  .yt-link:hover{background:rgba(192,57,43,.22);color:#f99;}
  .yt-link svg{width:18px;height:18px;}
  .yt-link.sp-link{background:rgba(29,185,84,.12);border-color:rgba(29,185,84,.4);color:#5fd587;}
  .yt-link.sp-link:hover{background:rgba(29,185,84,.22);color:#7fe39c;}
  .added-skip{margin-top:14px;font-size:.7rem;color:var(--muted);letter-spacing:.5px;cursor:pointer;background:none;border:none;font-family:'Oswald';text-transform:uppercase;}
  .added-skip:hover{color:var(--gold);}

  /* version tag */
  .version-tag{position:fixed;right:14px;bottom:10px;font-family:'Oswald';font-size:.65rem;letter-spacing:.5px;color:var(--muted);opacity:.55;background:rgba(15,11,9,.7);padding:4px 9px;border-radius:6px;border:1px solid var(--line);backdrop-filter:blur(2px);z-index:var(--z-badge);font-variant-numeric:tabular-nums;}
  .version-tag:hover{opacity:1;}
  .version-tag .v{color:var(--gold);}
  .version-tag .c{color:var(--muted);margin-left:6px;font-family:monospace;}

  /* toast */
  .toast{position:fixed;left:50%;top:20px;transform:translateX(-50%) translateY(-20px);background:linear-gradient(180deg,#d4493a,#a8281c);color:#fff;font-family:'Oswald';font-weight:500;font-size:.95rem;letter-spacing:.5px;padding:12px 22px;border-radius:9px;box-shadow:0 10px 30px rgba(0,0,0,.5);z-index:var(--z-toast);opacity:0;pointer-events:none;transition:opacity .25s, transform .25s;max-width:90vw;text-align:center;}
  .toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
  .toast.info{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1206;}

  /* login */
  body.login-mode{padding-bottom:0;}
  .login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;}
  .login-foot{position:absolute;bottom:16px;left:0;right:0;text-align:center;padding:0 16px;font-size:.7rem;letter-spacing:.5px;color:var(--muted);opacity:.85;}
  .login-foot sup{font-size:.6em;}
  .login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:32px 30px;max-width:400px;width:100%;text-align:center;box-shadow:0 32px 90px -16px rgba(0,0,0,.88), 0 0 0 1px rgba(224,161,60,.11), 0 0 76px -25px rgba(224,161,60,.31);}
  .login-card h2{font-family:'Anton';font-size:2rem;text-transform:uppercase;line-height:1.12;margin-bottom:-.25em;letter-spacing:1px;background:linear-gradient(180deg,#fff 0%,var(--gold-bright) 55%,var(--gold) 75%,#9c6a1c 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 16px rgba(224,161,60,.4));}
  .login-card p{color:var(--muted);font-size:.85rem;margin-bottom:20px;}
  .login-card input{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:9px;color:var(--ink);font-family:'Oswald';font-size:1rem;padding:12px 14px;text-align:center;letter-spacing:2px;}
  .login-card input:focus{outline:none;border-color:var(--gold);}
  .login-card .add-btn{width:100%;margin-top:14px;padding:15px;}
  /* celular / telas pequenas (inclui landscape baixo): login SEM zoom, empilhado e SCROLLÁVEL — botão sempre acessível */
  @media (max-width:600px){
    .login-wrap{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:24px 14px;}
    .login-card{max-width:100%;padding:24px 20px;}
    .login-card h2{font-size:1.5rem;}
    .login-card input{letter-spacing:1px;}
    .login-foot{position:static;margin:0;}
  }
  /* login DEITADO (celular landscape, altura baixa): compacta p/ caber; se ainda não couber
     (ex.: teclado aberto), encosta no topo e ROLA em vez de cortar (safe center + 100dvh) */
  @media (max-height:500px){
    .login-wrap{min-height:100dvh;padding:10px 8px;align-items:safe center;}
    .login-card{padding:12px 26px;max-width:480px;}
    .login-card h2{font-size:1.15rem;margin-bottom:6px;}
    .login-card p{display:none;}                 /* subtítulo escondido no deitado (título já identifica) */
    .login-card input{padding:7px 12px;}
    .login-card #loginUser, .login-card #pwInput{margin-bottom:7px;}
    .login-card .add-btn{padding:9px;margin-top:7px;}
    .login-err{min-height:0;margin-top:6px;}     /* não reserva 18px de altura quando vazio */
    .login-links{margin-top:9px;}
    .login-rules-row{display:none;}              /* REGRAS escondido no deitado (acessível dentro do app) */
    .login-foot{display:none;}
  }
  /* modais no celular: usam mais a tela e NÃO estouram a largura */
  @media (max-width:600px){
    .modal-overlay{padding:8px;}
    .modal{padding:20px 15px;overflow-x:hidden;}
    .modal-title{font-size:1.3rem;}
  }
  .login-err{color:var(--red);font-size:.8rem;margin-top:2px;min-height:18px;}
  .login-request{display:inline-block;margin-top:14px;color:var(--muted);font-family:'Oswald';font-size:.78rem;letter-spacing:.5px;background:none;border:none;border-bottom:1px dotted var(--muted);padding:0 0 1px;cursor:pointer;transition:.15s;}
  .login-request:hover{color:var(--gold);border-bottom-color:var(--gold);}
  .login-rules-row{margin-top:18px;display:flex;justify-content:center;}
  footer{text-align:center;margin-top:54px;padding-top:24px;border-top:1px solid var(--line);color:var(--muted);font-size:.74rem;letter-spacing:1px;}
  footer .note{margin-top:9px;font-size:.7rem;line-height:1.6;max-width:600px;margin:9px auto 0;}
  footer .copyright{margin-top:18px;font-size:.7rem;letter-spacing:.5px;color:var(--muted);opacity:.85;}
  footer .copyright strong{color:var(--ink);font-weight:500;}
  footer .copyright sup{font-size:.6em;}

  /* modal Setlist */
  .setlist-modal{max-width:940px;max-height:90vh;display:flex;flex-direction:column;}
  /* header e rodapé fixos; só a lista (sl-rows) e o picker rolam por dentro */
  .setlist-modal>.modal-title,.setlist-modal>.sl-head,.setlist-modal>.sl-saved,.setlist-modal>.sl-bar,.setlist-modal>.sl-foot,.setlist-modal>.modal-btns{flex:0 0 auto;}
  .setlist-modal>.sl-picker{flex:1 1 auto;min-height:0;}
  .setlist-modal>.sl-rows{flex:1 1 auto;min-height:40px;overflow-y:auto;}
  /* enquanto seleciona músicas (+ Adicionar), esconde a lista/totais e dá todo o espaço ao picker */
  #setlistOverlay.picking>.modal>.sl-rows,#setlistOverlay.picking>.modal>.sl-foot{display:none;}
  .sl-head{display:flex;flex-wrap:wrap;align-items:center;gap:9px;margin-bottom:12px;padding-right:42px;}   /* nome + ações na mesma linha; reserva o canto p/ o × (título removido) */
  .sl-head .cfg-input{flex:1 1 200px;min-width:150px;padding:7px 12px;font-size:.86rem;}   /* mesma altura dos botões compactos da linha */
  .sl-saved{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px;min-height:8px;}
  .sl-saved-empty{font-size:.72rem;color:var(--muted);letter-spacing:.5px;align-self:center;}
  .sl-chip{display:flex;align-items:center;gap:7px;background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:4px 7px 4px 12px;font-size:.74rem;cursor:pointer;}
  .sl-chip.on{border-color:var(--gold);background:rgba(224,161,60,.1);}
  .sl-chip.mine{border-color:var(--gold);box-shadow:inset 0 0 0 1px rgba(224,161,60,.35);}
  .sl-chip-by{font-size:.6rem;color:var(--muted);letter-spacing:.3px;font-style:italic;}
  .sl-chip-name{cursor:pointer;color:var(--ink);letter-spacing:.5px;}
  .sl-chip-n{cursor:pointer;font-size:.6rem;color:var(--gold-bright);background:rgba(224,161,60,.14);border-radius:10px;padding:1px 7px;}
  .sl-chip-del{background:none;border:none;color:#5a4a40;cursor:pointer;font-size:1.1rem;line-height:1;padding:0 2px;}
  .sl-chip-del:hover{color:var(--red);}
  .sl-bar{display:flex;align-items:center;gap:9px;margin-bottom:11px;flex-wrap:wrap;}
  .sl-new{font-family:'Oswald';font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--gold);background:transparent;border:1px solid var(--gold);border-radius:7px;padding:7px 14px;cursor:pointer;}
  .sl-new:hover{background:rgba(224,161,60,.12);}
  .sl-new.ghost{color:var(--muted);border:1px dashed var(--line);}
  .sl-new.ghost:hover{color:var(--ink);border-color:var(--muted);background:transparent;}
  /* na linha do nome: tudo no tamanho compacto do "+ Músicas"; +Músicas e +Break iguais entre si */
  .sl-head #setlistAddSongs,.sl-head #setlistAddBreak{min-width:92px;text-align:center;}
  .sl-head #setlistSave{font-size:.72rem;letter-spacing:1px;padding:7px 16px;}
  /* "Fechar" no mesmo tamanho compacto dos botões de export ao lado */
  .setlist-modal>.modal-btns>#setlistClose{font-size:.72rem;letter-spacing:.4px;padding:8px 14px;}
  /* picker de músicas */
  .sl-picker{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:12px;display:flex;flex-direction:column;max-height:48vh;min-height:0;}
  .sl-pick-scroll{flex:1 1 auto;overflow-y:auto;min-height:0;}
  .sl-pick-add{flex:0 0 auto;margin-top:10px;}
  .sl-pick-empty{font-size:.78rem;color:var(--muted);text-align:center;padding:10px;line-height:1.5;}
  .sl-pick{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:7px;cursor:pointer;}
  .sl-pick:hover{background:rgba(255,255,255,.03);}
  .sl-pick input{width:16px;height:16px;accent-color:var(--gold);cursor:pointer;}
  .sl-pick-name{flex:1;font-size:.86rem;color:var(--ink);}
  .sl-pick-name em{font-style:normal;font-size:.68rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-left:5px;}
  .sl-pick-score{font-family:'Bebas Neue';font-size:1rem;color:var(--gold-bright);}
  .sl-acc{border:1px solid var(--line);border-radius:8px;margin-bottom:8px;background:rgba(255,255,255,.02);}
  .sl-acc summary{cursor:pointer;list-style:none;padding:9px 12px;font-family:'Oswald';font-weight:500;font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:8px;}
  .sl-acc summary::-webkit-details-marker{display:none;}
  .sl-acc summary::before{content:"▸";color:var(--muted);transition:transform .15s;}
  .sl-acc[open] summary::before{transform:rotate(90deg);}
  .sl-acc-n{font-family:'Bebas Neue';font-size:.9rem;color:var(--gold-bright);background:rgba(224,161,60,.14);border-radius:10px;padding:0 8px;}
  .sl-acc-body{padding:2px 4px 8px;}
  /* linhas do set */
  .sl-rows{display:flex;flex-direction:column;gap:5px;margin-bottom:6px;min-height:30px;}
  .sl-row{display:grid;grid-template-columns:auto 24px 1fr auto auto auto auto;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px 12px;}
  .sl-handle{cursor:grab;color:#6a5a4d;font-size:.95rem;letter-spacing:-3px;user-select:none;touch-action:none;}
  .sl-handle:active{cursor:grabbing;}
  .sl-n{font-family:'Bebas Neue';font-size:1.2rem;color:var(--gold);text-align:center;}
  .sl-title{display:flex;flex-direction:column;min-width:0;}
  .sl-links{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:flex-end;max-width:330px;}
  .sl-links .yt-ic svg,.sl-links .sp-ic svg{width:16px;height:16px;}
  .sl-title strong{font-weight:500;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .sl-band{font-size:.68rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
  .sl-score{font-family:'Bebas Neue';font-size:1.05rem;color:var(--gold-bright);background:rgba(224,161,60,.12);border-radius:8px;padding:1px 9px;white-space:nowrap;}
  .sl-meta{font-family:'Bebas Neue';font-size:.95rem;color:var(--muted);letter-spacing:.5px;white-space:nowrap;text-align:right;}
  .sl-del{background:none;border:none;color:#5a4a40;cursor:pointer;font-size:1.25rem;line-height:1;padding:0 2px;}
  .sl-del:hover{color:var(--red);}
  /* break / intervalo */
  .sl-break{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;background:rgba(224,161,60,.07);border:1px dashed var(--gold);border-radius:9px;padding:8px 12px;}
  .sl-break-label{flex:1;background:transparent;border:none;font-family:'Oswald';font-weight:500;font-size:.82rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold-bright);outline:none;min-width:0;}
  .sl-break-label::placeholder{color:#7a6648;}
  .sl-break-sub{font-family:'Bebas Neue';font-size:.92rem;color:var(--muted);letter-spacing:.5px;white-space:nowrap;}
  .sl-ghost{opacity:.4;}
  .sl-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.74rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:12px 2px 14px;margin-top:8px;border-top:1px solid var(--line);flex-wrap:wrap;}
  .sl-foot strong{color:var(--gold-bright);font-family:'Bebas Neue';font-size:1.15rem;}
  .sl-foot-total strong{color:var(--gold);}
  .sl-export{display:flex;gap:6px;flex-wrap:wrap;}
  /* botões da barra de export compactos p/ caber em 1 linha */
  .sl-export .modal-btn{font-size:.72rem;letter-spacing:.4px;padding:8px 11px;gap:5px;}
  .sl-export .exp-ico{width:13px;height:13px;}
  /* barra de export do setlist: Imprimir · PDF · Salvar */

  /* área de impressão (escondida na tela) */
  #printArea{display:none;}
  @media print{
    body *{visibility:hidden;}
    #printArea,#printArea *{visibility:visible;}
    #printArea{display:block;position:absolute;left:0;top:0;width:100%;padding:24px 28px;color:#000;background:#fff;font-family:'Oswald',Arial,sans-serif;}
    #printArea h1{font-family:'Bebas Neue',sans-serif;font-size:30px;margin:0;letter-spacing:1px;}
    #printArea h2{font-size:15px;font-weight:500;margin:2px 0 16px;color:#444;letter-spacing:2px;text-transform:uppercase;}
    #printArea table{width:100%;border-collapse:collapse;}
    #printArea td{padding:6px 6px;border-bottom:1px solid #ddd;font-size:13px;vertical-align:middle;}
    #printArea td.pn{font-family:'Bebas Neue',sans-serif;font-size:17px;width:26px;color:#888;}
    #printArea td.sc{font-family:'Bebas Neue',sans-serif;font-size:15px;color:#a36b00;white-space:nowrap;width:42px;text-align:center;}
    #printArea td small{color:#777;font-size:11px;text-transform:uppercase;letter-spacing:1px;margin-left:6px;}
    #printArea tr.br td{background:#f1f1f1;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-align:center;border-bottom:2px solid #999;color:#333;}
    #printArea p.tot{margin-top:16px;font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:13px;}
    @page{margin:14mm;}
  }

  /* ===== Fase 1 — contas/papéis/convites/permissões ===== */
  .who-btn.who-me{cursor:default;}
  .cfg-member-role{background:var(--panel);border:1px solid var(--line);color:var(--ink);font-family:'Oswald';font-weight:300;font-size:.8rem;border-radius:6px;padding:3px 6px;cursor:pointer;}
  .cfg-member-role:focus{outline:none;border-color:var(--gold);}
  .cfg-member-role-tag{font-size:.66rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);border:1px solid rgba(224,161,60,.4);border-radius:5px;padding:2px 7px;white-space:nowrap;}
  .cfg-member-del-spacer{width:28px;flex:none;}
  .cfg-invite-row .cfg-input{font-size:.85rem;padding:7px 10px;}
  .cfg-invite-out{margin-top:12px;}
  .cfg-invite-link{display:flex;gap:8px;align-items:center;}
  .cfg-invite-link input{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--ink);font-family:'Oswald';font-weight:300;font-size:.82rem;border-radius:6px;padding:8px 10px;}
  .cfg-perms{display:flex;gap:14px;flex-wrap:wrap;}
  .cfg-perm-group{flex:1;min-width:200px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:12px 14px;}
  .cfg-perm-role{font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:500;}
  .cfg-perm-item{display:flex;align-items:center;gap:8px;padding:5px 0;color:var(--ink);font-size:.9rem;cursor:pointer;}
  .cfg-perm-item input{accent-color:var(--gold);width:15px;height:15px;cursor:pointer;}
  /* ajustes pós-teste */
  .login-card #loginUser, .login-card #pwInput{margin-bottom:10px;}        /* (7) empilhado, espaçado */
  .login-links{display:flex;justify-content:center;gap:22px;flex-wrap:wrap;margin-top:2px;}   /* (3) mesma linha */
  #createMemberOverlay.show,#resetPwOverlay.show,#resetBandOverlay.show,#deleteBandOverlay.show{z-index:var(--z-modal2);}   /* acima do Config */
  .ui-ask.show{z-index:var(--z-ask);}   /* confirmar/perguntar próprio — acima de TUDO, incl. o leitor/editor de cifra (--z-reader) */
  .ui-ask .modal{max-width:400px;}
  .ui-ask-field{margin-top:4px;}
  .login-links .login-forgot,.login-links .login-request{background:none;border:none;color:var(--muted);font-family:'Oswald';font-weight:300;font-size:.82rem;cursor:pointer;text-decoration:underline;margin:0;padding:0;}
  .login-links .login-forgot:hover,.login-links .login-request:hover{color:var(--gold);}
  .pw-show{display:flex;align-items:center;gap:6px;margin-top:9px;color:var(--muted);font-size:.82rem;cursor:pointer;}
  .pw-show input{accent-color:var(--gold);width:14px;height:14px;cursor:pointer;margin:0;}
  .cfg-invite-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px;}  /* (2) alinhado */
  .cfg-invite-row .cfg-input{flex:1;min-width:130px;margin:0;font-size:.85rem;padding:8px 10px;}
  .cfg-invite-row #cfgInviteRole{flex:0 0 auto;min-width:118px;}
  .cfg-invite-row .modal-btn{margin:0;white-space:nowrap;}
  .cfg-saved{display:none;color:var(--green);font-size:.72rem;letter-spacing:1px;margin-left:8px;text-transform:none;font-weight:400;}  /* (7) */
  .cfg-saved.show{display:inline;}
  .cfg-member-reset{background:transparent;border:none;cursor:pointer;padding:4px 5px;font-size:.95rem;line-height:1;opacity:.9;border-radius:6px;}
  .cfg-member-reset:hover{opacity:1;background:rgba(224,161,60,.14);}
  /* (5/6) ação sem permissão: cinza (continua clicável p/ avisar "peça ao Admin") */
  .cap-off{opacity:.45!important;filter:grayscale(1);cursor:not-allowed;}
  /* tabela "o que cada um pode" (informativa) */
  .perm-table{width:100%;border-collapse:collapse;font-size:.86rem;}
  .perm-table th,.perm-table td{padding:7px 8px;text-align:left;border-bottom:1px solid var(--line);}
  .perm-table th{color:var(--gold);font-weight:500;text-transform:uppercase;font-size:.68rem;letter-spacing:1px;}
  .perm-table th:not(:first-child),.perm-table td:not(:first-child){text-align:center;width:84px;}
  .perm-yes{color:var(--green);font-weight:700;}
  .perm-no{color:#6a5d50;}

  /* ===== Celular: aproveitar a largura + lista compacta estilo Songsterr (em PÉ e DEITADO; tablet fica de fora) ===== */
  @media (max-width:600px), (orientation:landscape) and (max-height:500px) and (pointer:coarse){
    .wrap{padding:0 12px;}                 /* era 0 32px — encosta mais nas bordas no celular */
    .who{padding:12px 13px 18px;}          /* card de cadastro com menos respiro lateral */
    .top-block{padding:8px 11px 16px;}     /* bloco "Aprovadas" */
    .next-show{padding:11px 13px;}
    /* lista densa: fontes, estrelas e espaços menores p/ caber mais sem amontoar */
    .song{padding:9px 10px;gap:3px 8px;}
    .song .rank{font-size:1.3rem;}
    .title-cell .t{font-size:.95rem;gap:6px;}
    .title-cell .b{font-size:.7rem;letter-spacing:.4px;}
    .yt-ic svg,.sp-ic svg{width:15px;height:15px;}
    .score .total{font-size:1.4rem;min-width:20px;}
    .chip{height:16px;min-width:20px;font-size:.56rem;}
    .who-tag{font-size:.55rem;padding:2px 7px;}
    .star{width:23px;height:23px;}
    .stars{gap:2px;}
    /* modal Setlist: rola o MODAL INTEIRO (não a lista por dentro, que ficava espremida);
       a barra de baixo (export + Fechar) fica fixa enquanto rola */
    .setlist-modal{max-height:none;}
    .setlist-modal>.sl-rows{overflow-y:visible;flex:0 0 auto;}
    .setlist-modal>.sl-picker,.sl-picker{max-height:none;}
    .sl-pick-scroll{overflow-y:visible;}
    #setlistOverlay{padding-bottom:0;}   /* footer encostado no fundo real da tela (sem sobra abaixo) */
    .setlist-modal>.modal-btns{position:sticky;bottom:0;z-index:2;background:var(--panel);margin:8px -24px -26px;padding:9px 24px 10px;border-top:1px solid var(--line);box-shadow:0 -10px 22px -10px rgba(0,0,0,.6);}
  }

  /* ===== Celular EM PÉ: pílulas viram barra no topo ===== */
  @media (max-width:600px) and (orientation:portrait){
    /* topo: barra no fluxo (não-absolute) ocupando a largura toda — título limpo logo abaixo */
    .top-pills{position:static;top:auto;left:auto;right:auto;width:100%;justify-content:center;gap:7px;margin-bottom:6px;}
    .pills-group{display:contents;}        /* os 7 botões fluem juntos, centralizados, com wrap */
    header{padding-top:14px;}              /* não precisa mais reservar espaço pra barra absolute */
    .star{width:26px;height:26px;}         /* votar é a ação nº 1: alvo de toque maior (em pé sobra altura) */
    /* cabeçalho com ordenação: o grid 1fr/auto/1fr espreme o seletor → título+ações na 1ª linha, seletor inteiro na 2ª */
    .set-head:has(.sl-sort){display:flex;flex-wrap:wrap;gap:8px 12px;}
    .set-head:has(.sl-sort) .tag{flex:1;}
    .set-head:has(.sl-sort) .sl-sort{order:3;flex-basis:100%;justify-content:center;}
  }

  /* ===== Metrônomo (abre clicando no BPM de uma música) ===== */
  .bpm-link{font:inherit;color:inherit;background:none;border:none;padding:0;letter-spacing:inherit;cursor:pointer;text-decoration:underline dotted;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:rgba(224,161,60,.5);transition:.15s;}
  .bpm-link:hover{color:var(--gold-bright);text-decoration-color:var(--gold-bright);}
  .modal.metronome-modal{max-width:340px;text-align:center;}
  .metro-song{color:var(--muted);font-size:.84rem;letter-spacing:.5px;margin-bottom:16px;min-height:1.1em;}
  .metro-beat{width:62px;height:62px;border-radius:50%;margin:4px auto 22px;background:var(--panel2);border:2px solid var(--line);}
  .metro-beat.on{background:var(--gold);border-color:var(--gold-bright);box-shadow:0 0 24px rgba(244,185,78,.6);animation:metroPulse .12s ease-out;}
  .metro-beat.on.accent{background:var(--gold-bright);box-shadow:0 0 34px rgba(244,185,78,.85);}
  @keyframes metroPulse{0%{transform:scale(1.18)}100%{transform:scale(1)}}
  .metro-bpm{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:22px;}
  .metro-bpm-val{display:flex;flex-direction:column;align-items:center;line-height:1;min-width:92px;}
  .metro-bpm-val span{font-family:'Bebas Neue';font-size:3rem;color:var(--gold-bright);line-height:1;}
  .metro-bpm-val small{color:var(--muted);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;margin-top:2px;}
  .metro-step{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--panel2);color:var(--gold-bright);font-size:1.6rem;line-height:1;cursor:pointer;transition:.15s;}
  .metro-step:hover{border-color:var(--gold);background:rgba(224,161,60,.1);}
  .metro-toggle{width:100%;font-family:'Oswald';font-weight:500;font-size:.95rem;letter-spacing:1px;text-transform:uppercase;color:#1a1206;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border:none;border-radius:9px;padding:12px;cursor:pointer;transition:.15s;}
  .metro-toggle:hover{filter:brightness(1.08);}
  .metro-toggle.on{background:linear-gradient(180deg,#caa24a,#9c6a1c);color:#fff;}
  .metro-tap{width:100%;font-family:'Oswald';font-weight:500;font-size:.82rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold-bright);background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px;cursor:pointer;margin-bottom:16px;transition:.1s;}
  .metro-tap:hover{border-color:var(--gold);}
  .metro-tap:active{background:rgba(224,161,60,.18);transform:scale(.98);}
  .metro-tap small{display:block;font-size:.6rem;letter-spacing:1px;color:var(--muted);text-transform:none;margin-top:2px;}
  .metro-seg-label{font-size:.64rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);text-align:left;margin:0 0 6px 3px;}
  .metro-seg{display:flex;gap:5px;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:4px;margin-bottom:14px;}
  .metro-seg button{flex:1;font-family:'Oswald';font-weight:500;font-size:.72rem;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);background:transparent;border:none;padding:7px 4px;border-radius:6px;cursor:pointer;transition:.12s;white-space:nowrap;}
  .metro-seg button.on{background:var(--gold);color:#1a1206;}
  .metro-seg button:not(.on):hover{color:var(--gold-bright);}
  .metro-sounds{flex-wrap:wrap;}
  .metro-sounds button{flex:1 1 28%;min-width:52px;}
  /* botão minimizar (no lugar do × — recolhe pro mini-player, continua tocando) */
  .metro-min{position:absolute;top:12px;right:14px;width:30px;height:30px;border:none;background:none;color:var(--muted);font-size:1.9rem;line-height:1;cursor:pointer;border-radius:7px;display:flex;align-items:center;justify-content:center;padding-bottom:6px;}
  .metro-min:hover{color:var(--gold-bright);background:rgba(224,161,60,.1);}
  /* mini-player flutuante */
  .metro-mini{position:fixed;right:16px;bottom:72px;z-index:var(--z-float);display:none;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--gold);border-radius:30px;padding:7px 10px 7px 13px;box-shadow:0 12px 34px rgba(0,0,0,.55), 0 0 0 1px rgba(224,161,60,.18), 0 0 40px -16px rgba(224,161,60,.5);}
  .metro-mini.show{display:flex;}
  .metro-mini-beat{width:16px;height:16px;border-radius:50%;background:var(--panel2);border:1.5px solid var(--line);flex:none;}
  .metro-mini-beat.on{background:var(--gold);border-color:var(--gold-bright);box-shadow:0 0 12px rgba(244,185,78,.7);animation:metroPulse .12s ease-out;}
  .metro-mini-beat.on.accent{background:var(--gold-bright);box-shadow:0 0 16px rgba(244,185,78,.95);}
  .metro-mini-exp{font-family:'Bebas Neue';font-size:1.25rem;letter-spacing:.5px;color:var(--gold-bright);background:none;border:none;cursor:pointer;line-height:1;padding:0 2px;white-space:nowrap;}
  .metro-mini-exp:hover{color:#fff;}
  .metro-mini-stop{width:30px;height:30px;border-radius:50%;border:none;background:var(--red);color:#fff;font-size:.78rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex:none;}
  .metro-mini-stop:hover{filter:brightness(1.12);}

  /* ===== Cifras / Leitor / Modo Apresentação ===== */
  /* nome da música = entrada do leitor próprio (palco). O glifo 🎸 dourado é um selo que
     SÓ aparece quando a música já tem cifra salva ("pronta p/ o palco"); sem cifra, some
     (nome limpo, ainda clicável — hover/cursor dão a pista). */
  .song-name{display:inline-flex;align-items:center;gap:5px;cursor:pointer;transition:color .14s;}
  .song-name:hover,.song-name:focus-visible{color:var(--gold-bright);outline:none;}
  .song-name .cs-mark{display:none;}   /* oculto quando não há cifra própria cadastrada */
  .song-name .cs-mark svg{width:14px;height:14px;}
  .song-name.has-cs{color:var(--gold-bright);}
  .song-name.has-cs .cs-mark{display:inline-flex;color:var(--gold-bright);}
  .sl-song-name{cursor:pointer;transition:color .14s;}
  .sl-song-name:hover,.sl-song-name:focus-visible{color:var(--gold-bright);outline:none;}
  .sl-song-name.has-cs{color:var(--gold-bright);}
  .lk-sep{display:inline-block;width:1px;height:16px;margin:0 10px;background:var(--muted);opacity:.65;vertical-align:middle;}
  .chord-overlay{position:fixed;inset:0;z-index:var(--z-reader);display:none;flex-direction:column;color:var(--ink);
    background:radial-gradient(1100px 520px at 75% -8%,rgba(224,161,60,.10),transparent 60%),linear-gradient(180deg,#171210,#0c0a08);}
  .chord-overlay.show{display:flex;animation:csFade .18s ease-out;}
  @keyframes csFade{from{opacity:0}to{opacity:1}}
  .chord-overlay.dark{background:#08080a;color:#eef0f2;}
  .chord-head{display:flex;align-items:center;gap:14px;padding:11px 18px 11px 26px;border-bottom:1px solid var(--line);background:rgba(8,6,4,.55);backdrop-filter:blur(8px);flex:none;flex-wrap:wrap;position:relative;}
  .chord-overlay.dark .chord-head{border-color:#1d1d22;background:rgba(0,0,0,.7);}
  .chord-title{flex:1;min-width:140px;display:flex;flex-direction:column;gap:5px;overflow:hidden;}
  .chord-title strong{font-family:'Oswald',sans-serif;font-weight:600;font-size:1.5rem;letter-spacing:.3px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .chord-meta{display:flex;flex-wrap:wrap;align-items:center;gap:7px;}
  .cs-band{color:var(--ink);opacity:.82;font-size:.96rem;letter-spacing:.3px;}
  .cs-chip{font-size:.64rem;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--gold-bright);background:rgba(224,161,60,.12);border:1px solid rgba(224,161,60,.28);border-radius:20px;padding:2px 9px;}
  .chord-ctrls{display:flex;align-items:center;gap:7px;flex:none;flex-wrap:wrap;}
  .cg{display:flex;align-items:center;gap:2px;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:10px;padding:3px;}
  .chord-overlay.dark .cg{background:rgba(255,255,255,.04);border-color:#222;}
  .chord-btn{min-width:34px;height:34px;padding:0 9px;border:none;background:none;color:var(--gold-bright);border-radius:8px;font-size:1rem;line-height:1;cursor:pointer;transition:.12s;display:flex;align-items:center;justify-content:center;}
  .chord-ctrls>.chord-btn{border:1px solid var(--line);background:rgba(0,0,0,.28);}
  .chord-btn:hover{color:#fff;background:rgba(224,161,60,.16);}
  .chord-btn.on{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1206;box-shadow:0 0 14px rgba(244,185,78,.45);}
  .chord-btn.sm{min-width:26px;height:26px;font-size:.85rem;padding:0;}
  .chord-x{font-size:1.6rem;color:var(--muted);}
  .chord-x:hover{color:#fff;background:rgba(192,57,43,.25);}
  .chord-key{min-width:30px;text-align:center;font-family:'Bebas Neue';font-size:1.3rem;color:var(--gold-bright);padding:0 2px;}
  .chord-body{flex:1;overflow:auto;padding:24px calc(26px + var(--cs-pad,0px)) 45vh;}
  .cs-render{max-width:980px;margin:0;padding:24px 30px;background:rgba(0,0,0,.18);border:1px solid var(--line);border-radius:16px;box-shadow:0 14px 40px rgba(0,0,0,.28);font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.5;}
  .chord-overlay.dark .cs-render{background:rgba(255,255,255,.015);border-color:#1d1d22;}
  .cs-loading{color:var(--muted);text-align:center;margin-top:50px;font-family:'Inter',sans-serif;}
  .cs-raw{max-width:980px;margin:0;padding:24px 30px;background:rgba(0,0,0,.18);border:1px solid var(--line);border-radius:16px;white-space:pre-wrap;font-family:'Inter',sans-serif;}
  /* render do ChordSheetJS (HtmlDivFormatter): acorde alinhado sobre a sílaba via flex */
  .cs-render .paragraph{margin:0 0 1.15em;}
  .cs-render .row{display:flex;flex-wrap:wrap;align-items:flex-end;margin-bottom:var(--cs-rowgap,2px);}
  .cs-render .column{display:flex;flex-direction:column;}
  .cs-render .chord{font-weight:700;color:var(--cs-chord,var(--gold-bright));white-space:pre;min-height:1.12em;padding-right:.7ch;letter-spacing:.2px;}
  .cs-render .chord.cs-empty{min-height:0;height:0;line-height:0;overflow:hidden;}
  .cs-render .lyrics{white-space:pre;}
  .cs-render .comment{display:inline-block;font-weight:600;color:var(--gold);background:rgba(224,161,60,.1);border-left:3px solid var(--gold);margin:1.5em 0 .5em;padding:3px 12px;font-size:.78em;letter-spacing:1.5px;text-transform:uppercase;border-radius:0 6px 6px 0;}
  .chord-overlay.dark .cs-render .comment{color:#e9c477;background:rgba(233,196,119,.08);border-color:#e9c477;}
  .cs-render .paragraph.cs-hl{border-left:3px solid var(--gold);padding-left:14px;background:linear-gradient(90deg,rgba(224,161,60,.07),transparent 65%);border-radius:0 8px 8px 0;}
  .chord-overlay.dark .cs-render .paragraph.cs-hl{border-color:#e9c477;background:linear-gradient(90deg,rgba(233,196,119,.06),transparent 65%);}
  /* seções diferenciadas por TIPO (classe nativa do HtmlDivFormatter após a normalização: verse/chorus/bridge/intro/solo) */
  .cs-render .label{font-family:'Oswald',sans-serif;font-weight:600;font-size:.72em;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold);margin:0 0 .45em;opacity:.92;}
  .cs-render .paragraph.chorus{border-left:3px solid var(--gold-bright);padding-left:15px;background:linear-gradient(90deg,rgba(244,185,78,.10),transparent 72%);border-radius:0 8px 8px 0;}
  .cs-render .paragraph.chorus .label{color:var(--gold-bright);}
  .cs-render .paragraph.bridge{border-left:3px solid #8a7dd6;padding-left:15px;background:linear-gradient(90deg,rgba(138,125,214,.12),transparent 72%);border-radius:0 8px 8px 0;}
  .cs-render .paragraph.bridge .label{color:#b3a7f0;}
  .cs-render .paragraph.intro,.cs-render .paragraph.solo,.cs-render .paragraph.outro,.cs-render .paragraph.instrumental{border-left:3px solid rgba(140,128,118,.5);padding-left:15px;}
  .cs-render .paragraph.intro .label,.cs-render .paragraph.solo .label,.cs-render .paragraph.outro .label,.cs-render .paragraph.instrumental .label{color:var(--muted);}
  /* toggles de exibição (menu ⚙): vira só letra / esconde rótulos */
  .chord-overlay.hide-chords .cs-render .chord{display:none;}
  .chord-overlay.hide-sections .cs-render .label,.chord-overlay.hide-sections .cs-render .comment{display:none;}
  .chord-overlay.hide-divisions .cs-render .paragraph{border-left:none!important;background:none!important;padding-left:0!important;}
  /* painel de exibição ⚙ (margem · espaço entre linhas · acordes · seções) */
  .chord-menu{position:absolute;top:calc(100% + 6px);right:12px;z-index:6;min-width:236px;display:flex;flex-direction:column;gap:6px;padding:11px;background:var(--panel);border:1px solid var(--line);border-radius:13px;box-shadow:0 16px 40px rgba(0,0,0,.55);font-family:'Inter',sans-serif;}
  .chord-overlay.dark .chord-menu{background:#15151a;border-color:#2a2a33;}
  .chord-menu[hidden]{display:none;}
  .cm-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.86rem;color:var(--ink);padding:1px 3px;}
  .cm-pm{display:flex;gap:4px;}
  .cm-tog{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.86rem;color:var(--ink);background:rgba(0,0,0,.24);border:1px solid var(--line);border-radius:9px;padding:8px 11px;cursor:pointer;}
  .chord-overlay.dark .cm-tog{background:rgba(255,255,255,.04);}
  .cm-tog:hover{border-color:var(--gold);}
  /* ----- Modo Palco: barra de navegação do set no rodapé do leitor (stage-mode.js) ----- */
  .stage-bar{flex:none;display:flex;align-items:center;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));
    border-top:1px solid var(--line);background:rgba(8,6,4,.72);backdrop-filter:blur(8px);}
  .chord-overlay.dark .stage-bar{border-color:#1d1d22;background:rgba(0,0,0,.78);}
  .stage-btn{flex:none;min-width:54px;height:46px;border:1px solid var(--line);background:rgba(0,0,0,.28);color:var(--gold-bright);
    border-radius:12px;font-size:1.7rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.12s;}
  .stage-btn:hover{color:#fff;background:rgba(224,161,60,.16);}
  .stage-btn:disabled{opacity:.3;cursor:default;}
  .stage-btn.stage-fs{font-size:1.15rem;min-width:46px;}
  .stage-mid{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0;}
  .stage-pos{font-family:'Bebas Neue';font-size:1.25rem;letter-spacing:1px;color:var(--gold-bright);line-height:1;}
  .stage-next{font-family:'Inter',sans-serif;font-size:.78rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
  .cm-tog b{font-family:'Oswald';font-weight:500;text-transform:uppercase;font-size:.68rem;letter-spacing:.8px;color:var(--muted);background:rgba(0,0,0,.25);padding:2px 9px;border-radius:20px;}
  .cm-tog.on b{color:#1a1206;background:linear-gradient(180deg,var(--gold-bright),var(--gold));}
  /* editor de colar/editar — no modo editor, esconde os controles de leitura (transpor/scroll/metrônomo) do header */
  .chord-overlay.editing .chord-ctrls > :not(.chord-x){display:none;}
  .chord-overlay.editing .chord-menu{display:none;}
  .cs-editor{max-width:980px;margin:24px auto;padding:24px 26px;background:rgba(8,6,4,.5);border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 50px rgba(0,0,0,.4);font-family:'Inter',sans-serif;}
  .cs-hint{color:var(--muted);font-size:.88rem;margin:0 0 12px;line-height:1.5;}
  .cs-hint code{background:var(--panel2);padding:1px 6px;border-radius:4px;color:var(--gold-bright);font-family:monospace;}
  .cs-textarea{width:100%;min-height:40vh;font-family:'Inter',ui-monospace,monospace;font-size:.98rem;line-height:1.55;background:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:12px;padding:14px 16px;resize:vertical;}
  .cs-textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,161,60,.12);}
  .cs-editor-actions{display:flex;gap:10px;margin-top:14px;}
  .cs-save{font-family:'Oswald';font-weight:500;text-transform:uppercase;letter-spacing:1px;color:#1a1206;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border:none;border-radius:10px;padding:12px 24px;cursor:pointer;}
  .cs-save:hover{filter:brightness(1.08);}
  .cs-cancel{background:var(--panel2);border:1px solid var(--line);color:var(--muted);border-radius:10px;padding:12px 20px;cursor:pointer;}
  .cs-cancel:hover{color:var(--gold-bright);border-color:var(--gold);}
  .cs-editor-actions{align-items:center;flex-wrap:wrap;}
  .cs-spacer{flex:1;min-width:8px;}
  .cs-organize{font-family:'Oswald';font-weight:500;text-transform:uppercase;letter-spacing:.8px;color:var(--gold-bright);background:rgba(224,161,60,.12);border:1px solid rgba(224,161,60,.4);border-radius:10px;padding:11px 18px;cursor:pointer;transition:.14s;}
  .cs-organize:hover{background:rgba(224,161,60,.22);color:#fff;box-shadow:0 0 16px rgba(224,161,60,.3);}
  .cs-source{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;}
  .cs-cc-open{font-family:'Oswald';font-weight:500;text-transform:uppercase;letter-spacing:.6px;font-size:.82rem;color:#1a1206;background:linear-gradient(180deg,#ff8a3c,#f06a1e);border:none;border-radius:9px;padding:9px 15px;cursor:pointer;transition:.14s;}
  .cs-cc-open:hover{filter:brightness(1.08);box-shadow:0 0 14px rgba(240,106,30,.4);}
  .cs-file-btn{font-family:'Oswald';font-weight:500;text-transform:uppercase;letter-spacing:.6px;font-size:.82rem;color:var(--ink);background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px 15px;cursor:pointer;transition:.14s;}
  .cs-file-btn:hover{border-color:var(--gold);color:var(--gold-bright);}
  .cs-source-hint{color:var(--muted);font-size:.8rem;}
  .cs-howto{font-family:'Inter',sans-serif;color:var(--ink);font-size:.95rem;font-weight:600;margin:0 0 10px;}
  .cs-clear{background:var(--panel2);border:1px solid var(--line);color:var(--muted);border-radius:10px;padding:11px 16px;cursor:pointer;transition:.14s;}
  .cs-clear:hover{color:#ff6b60;border-color:rgba(192,57,43,.5);background:rgba(192,57,43,.1);}
  /* modal de importar cifras em lote */
  #chordImportOverlay .modal{max-width:520px;}
  .ci-body{font-family:'Inter',sans-serif;color:var(--ink);margin:6px 0 4px;}
  .ci-body>p{font-size:.92rem;color:var(--muted);margin:0 0 10px;}
  .ci-list{list-style:none;margin:0;padding:0;max-height:42vh;overflow:auto;}
  .ci-list li{padding:7px 10px;border:1px solid var(--line);border-radius:9px;margin-bottom:6px;font-size:.92rem;display:flex;justify-content:space-between;align-items:center;gap:10px;}
  .ci-band{color:var(--muted);font-size:.82rem;}
  .ci-none{color:var(--muted);justify-content:center!important;}
  .ci-warn{color:#e7a07a;font-size:.84rem;margin:10px 0 0;line-height:1.4;}
  /* cifra no celular/tablet: card e paddings menores, sem desperdício de espaço */
  @media (max-width:680px){
    .cs-editor{max-width:100%;margin:10px 0;padding:15px 13px;border-radius:13px;}
    .cs-textarea{min-height:34vh;}
    .cs-howto{font-size:.92rem;}
    .cs-hint{font-size:.82rem;line-height:1.45;}
    .chord-head{padding:9px 12px;gap:9px;}
    .chord-title strong{font-size:1.18rem;}
    .chord-body{padding:16px calc(14px + var(--cs-pad,0px)) 42vh;}
    .cs-render,.cs-raw{padding:16px 15px;border-radius:13px;}
    #chordImportOverlay .modal{max-width:94vw;}
    .cs-editor-actions{gap:8px;}
    .cs-organize,.cs-clear,.cs-save,.cs-cancel{padding:10px 14px;font-size:.92rem;}
  }
