*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0a0c; --bg2:#0e0e11; --surface:#141418; --surface2:#1b1c22;
  --line:rgba(255,255,255,.09); --line2:rgba(255,255,255,.16);
  --text:#f4f4f2; --dim:#a2a29b; --dimmer:#6c6c66;
  --lime:#d4ff3a; --lime-soft:rgba(212,255,58,.13);
  --mag:#ff4d8d; --mag-soft:rgba(255,77,141,.14);
  --disp:'Anton',system-ui,sans-serif;
}
html,body{background:var(--bg);color:var(--text);
  font-family:'Space Grotesk',ui-sans-serif,system-ui,-apple-system,sans-serif;
  line-height:1.5;-webkit-font-smoothing:antialiased}
/* luz de palco subtil no topo */
body{background-image:radial-gradient(900px 360px at 50% -120px,rgba(212,255,58,.10),transparent 70%)}
a{color:var(--lime)}
::selection{background:var(--lime);color:#000}
.wrap{max-width:960px;margin:0 auto;padding:34px 20px 90px}

/* header / brand */
header{margin-bottom:22px}
.brand{font-size:30px;font-weight:700;letter-spacing:-.03em;text-decoration:none;color:var(--text);display:inline-block}
.brand .pt{color:var(--lime)}
.tag{color:var(--dim);font-size:15px;margin-top:6px}
.stat{color:var(--dimmer);font-size:12.5px;margin-top:10px;letter-spacing:.02em;text-transform:uppercase}
.back{font-size:13px;font-weight:600;text-decoration:none;display:inline-block;margin-bottom:16px;
  color:var(--dim);letter-spacing:.02em}
.back:hover{color:var(--lime)}

/* search */
.controls{position:sticky;top:0;background:rgba(10,10,12,.85);backdrop-filter:blur(10px);
  padding:14px 0;z-index:5;border-bottom:1px solid var(--line);margin-bottom:8px}
.search{width:100%;padding:12px 16px;border:1px solid var(--line2);border-radius:12px;
  font:inherit;font-size:15px;background:var(--surface);color:var(--text);outline:none;transition:.15s}
.search::placeholder{color:var(--dimmer)}
.search:focus{border-color:var(--lime);box-shadow:0 0 0 3px var(--lime-soft)}

/* section labels */
.section{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--lime);margin:34px 0 14px;display:flex;align-items:center;gap:10px}
.section::after{content:"";flex:1;height:1px;background:var(--line)}

/* recent cards (home) */
.recent{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.rcard{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 20px;
  text-decoration:none;color:inherit;display:block;position:relative;overflow:hidden;
  transition:border-color .18s,transform .15s,box-shadow .18s}
.rcard::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--lime);opacity:0;transition:opacity .18s}
.rcard:hover{border-color:var(--line2);transform:translateY(-3px);box-shadow:0 10px 30px -16px rgba(212,255,58,.4)}
.rcard:hover::before{opacity:1}
.rcard .rn{font-size:17px;font-weight:700;letter-spacing:-.01em}
.rcard .rd{color:var(--dim);font-size:13px;margin-top:4px}
.rcard .ru{color:var(--lime);font-size:12px;font-weight:600;margin-top:12px;letter-spacing:.01em}

/* list head + sort toggle (home) */
.lhead{display:flex;align-items:center;gap:14px;margin:34px 0 14px}
.lhead-label{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--lime);white-space:nowrap}
.sort{margin-left:auto;display:flex;gap:6px}
.sortbtn{font:inherit;font-size:12px;font-weight:600;padding:6px 13px;border-radius:999px;
  border:1px solid var(--line2);background:var(--surface);color:var(--dim);cursor:pointer;letter-spacing:.02em;transition:.15s}
.sortbtn:hover{border-color:var(--lime);color:var(--text)}
.sortbtn.on{background:var(--lime);color:#000;border-color:var(--lime);font-weight:700}
.month{font-family:var(--disp);font-size:16px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;
  color:var(--lime);padding:16px 18px 8px;border-top:1px solid var(--line)}
.flist .month:first-child{border-top:none}

/* festival list (home) */
.flist{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface)}
.frow{display:flex;align-items:center;gap:12px;padding:15px 18px;text-decoration:none;color:inherit;
  border-top:1px solid var(--line);transition:background .15s}
.frow:first-child{border-top:none}
.frow:hover{background:var(--surface2)}
.frow .fn{font-weight:600;font-size:16px;flex:1}
.frow:hover .fn{color:var(--lime)}
.frow .fmeta{color:var(--dim);font-size:13px;text-align:right;flex:0 1 auto}
.frow .arrow{color:var(--dimmer);font-weight:700;transition:.15s}
.frow:hover .arrow{color:var(--lime);transform:translateX(3px)}

/* festival detail header */
.fest h1{font-family:var(--disp);font-size:clamp(34px,7vw,64px);font-weight:400;line-height:.95;
  letter-spacing:.01em;text-transform:uppercase;margin-top:4px}
.fest .meta{color:var(--dim);font-size:14.5px;margin-top:10px}
.fest .meta a{font-weight:600;text-decoration:none}
.fest .meta a:hover{text-decoration:underline}
.badge{display:inline-block;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;
  padding:3px 10px;border-radius:999px;vertical-align:middle;margin-left:10px;
  letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.badge.completo{background:var(--lime-soft);color:var(--lime)}
.badge.parcial{background:rgba(255,200,90,.14);color:#ffcf6b}
.badge.fonte{background:rgba(255,255,255,.08);color:var(--dim)}
.badge.anunciar{background:var(--mag-soft);color:var(--mag)}
/* compat antigo */
.badge.fechado{background:var(--lime-soft);color:var(--lime)}

/* view bar */
.viewbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  position:sticky;top:0;background:rgba(10,10,12,.85);backdrop-filter:blur(10px);
  padding:14px 0;z-index:5;border-bottom:1px solid var(--line);margin:20px 0 4px}
.views{display:flex;gap:6px}
.vbtn{font:inherit;font-size:13px;font-weight:600;padding:8px 16px;border-radius:999px;
  border:1px solid var(--line2);background:var(--surface);color:var(--dim);cursor:pointer;
  transition:.15s;letter-spacing:.02em}
.vbtn:hover{border-color:var(--lime);color:var(--text)}
.vbtn.on{background:var(--lime);color:#000;border-color:var(--lime);font-weight:700}
.vsearch{flex:1;min-width:180px}

/* VISTA cartaz */
.cartaz{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:20px}
.col{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.col-day{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:#000;background:var(--lime);border-radius:8px;padding:7px 12px;
  text-align:center;margin-bottom:12px}
.col-stage{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--lime);margin:14px 0 6px;border-top:1px solid var(--line);padding-top:10px}
.col-stage:first-of-type{border-top:none;padding-top:0}
.col .name{display:block;padding:4px 0;line-height:1.2}
.col .name.h{font-size:19px;font-weight:700;letter-spacing:-.01em;color:#fff}
.col .name.d{font-size:15px;font-weight:600;color:var(--text)}
.col .name.n{font-size:13px;font-weight:400;color:var(--dim)}
.col .name .flag{display:inline-block}

/* VISTA lista */
.day{margin-top:22px}
.day-h{font-family:var(--disp);font-size:20px;font-weight:400;letter-spacing:.02em;text-transform:uppercase;
  color:var(--text);padding-bottom:6px;border-bottom:2px solid var(--lime);display:inline-block;margin-bottom:10px}
.stage-h{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--lime);margin:12px 0 2px}
table{width:100%;border-collapse:collapse;font-size:15px}
td{padding:8px 8px;border-top:1px solid var(--line);vertical-align:top}
td.hora{color:var(--dim);font-size:13px;white-space:nowrap;width:62px;font-variant-numeric:tabular-nums}
td.art{font-weight:500}
td.bill{color:var(--dimmer);font-size:11px;text-align:right;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;width:96px}
tr.headliner td.art{font-weight:700;color:#fff}

/* VISTA A-Z */
.az{margin-top:20px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface);
  columns:2;column-gap:0}
.azrow{padding:11px 18px;border-top:1px solid var(--line);break-inside:avoid}
.azrow:first-child{border-top:none}
.azrow .nm{display:block;font-weight:600;font-size:14.5px}
.azrow .azmeta{display:block;margin-top:2px;color:var(--dim);font-size:12px;text-transform:capitalize}

/* flags, notas */
.flag{font-size:10px;font-weight:700;color:var(--mag);margin-left:8px;letter-spacing:.04em;text-transform:uppercase}
.lacunas{margin-top:20px;background:var(--surface);border:1px solid var(--line);border-left:2px solid var(--mag);
  border-radius:10px;padding:12px 14px;font-size:12.5px;color:var(--dim)}
.lacunas b{color:var(--mag)}
.sources{margin-top:12px;font-size:12px;color:var(--dimmer)}
.sources a{margin-right:10px}

.notice{margin-top:20px;background:var(--surface);border:1px solid var(--line2);border-left:3px solid var(--lime);
  border-radius:14px;padding:22px 24px;color:var(--dim);font-size:15px;line-height:1.6}
.notice b{color:var(--text);font-weight:700}
.notice-cta{margin-top:14px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.notice-src{font-weight:600;text-decoration:none;color:var(--dim)}
.notice-src:hover{color:var(--lime)}
.invite{margin-top:20px;background:var(--lime-soft);border:1px solid rgba(212,255,58,.25);border-radius:12px;
  padding:13px 16px;color:var(--dim);font-size:14px;line-height:1.55}
.invite b{color:var(--text);font-weight:700}
/* comunidade: sugere uma banda + falta uma banda */
#community{margin-top:40px;padding-top:8px;border-top:1px solid var(--line)}
.comm-sub{color:var(--dim);font-size:14px;margin:-6px 0 12px}
.suggest-row{display:flex;gap:8px;align-items:stretch}
.suggest-row .search{flex:1}
.suggest-row .vbtn{white-space:nowrap}
.sg-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.sg-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line2);
  border-radius:999px;padding:7px 8px 7px 14px;color:var(--text);font:inherit;font-size:13.5px;cursor:pointer;transition:.15s}
.sg-chip:hover{border-color:var(--lime)}
.sg-chip b{background:var(--lime-soft);color:var(--lime);border-radius:999px;padding:1px 9px;font-size:12px;font-weight:700}
.sg-empty{color:var(--dimmer);font-size:13px}
.comm-foot{margin-top:18px;color:var(--dim);font-size:13.5px}
.linkbtn{background:none;border:none;color:var(--lime);font:inherit;font-weight:600;cursor:pointer;padding:0}
.linkbtn:hover{text-decoration:underline}
.m-msg{color:var(--lime);font-size:13px;margin-top:8px;display:inline-block}

/* modal */
.modal{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:20px}
.modal[hidden]{display:none}
.modal-box{background:var(--surface);border:1px solid var(--line2);border-radius:16px;
  padding:24px;max-width:440px;width:100%;position:relative}
.modal-box h3{font-size:20px;font-weight:700;margin-bottom:4px}
.modal-box .search{margin-top:10px}
.modal-box textarea.search{resize:vertical;font-family:inherit}
.modal-x{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--dim);font-size:18px;cursor:pointer}
.modal-x:hover{color:var(--text)}
.modal-actions{display:flex;align-items:center;gap:12px;margin-top:14px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}

mark{background:var(--lime);color:#000;padding:0 2px;border-radius:2px}
.empty{color:var(--dim);text-align:center;padding:48px 0;font-size:14px}
footer{margin-top:48px;padding-top:18px;border-top:1px solid var(--line);font-size:12px;color:var(--dimmer)}

@media (max-width:560px){
  .az{columns:1}
  .recent{grid-template-columns:1fr}
}
