:root{
  --bg0:#050505;
  --bg1:#0d0d0d;
  --ink:#e9edf3;
  --muted:#9aa6b2;
  --line:rgba(255,255,255,.10);
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.085);
  --shadow:0 18px 60px rgba(0,0,0,.55);
  --accent:#ec5b13; /* primary */
  --accent2:#00f2ff; /* cyber-blue */
  --accent3:#bc00ff; /* cyber-purple */
  --danger:#ff5b5b;
  --radius:18px;
  --radius2:24px;
  --serif:"Public Sans", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --sans:"Public Sans", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --ease:cubic-bezier(.2,.9,.2,1);
}

/* Garante comportamento consistente para o atributo hidden em todos os browsers */
[hidden]{display:none !important;}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:
    /* Evita "esverdeado" no menu: ciano mais fraco e mais para a direita */
    radial-gradient(900px 520px at 78% 16%, rgba(188,0,255,.18), transparent 55%),
    radial-gradient(900px 520px at 70% 10%, rgba(0,242,255,.08), transparent 60%),
    linear-gradient(135deg, #050505 0%, #0d0d0d 100%);
  color:var(--ink);
  font-family:var(--sans);
  letter-spacing:.2px;
}

.bg{position:fixed; inset:0; pointer-events:none; z-index:-1;}
.grain{
  position:absolute; inset:-20%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.25'/%3E%3C/svg%3E");
  transform:rotate(8deg);
  mix-blend-mode:overlay;
  opacity:.18;
}
.glow{position:absolute; width:520px; height:520px; border-radius:50%; filter:blur(45px); opacity:.22;}
/* Glow A roxo (menos "verde") */
.glow-a{left:-120px; top:80px; background:radial-gradient(circle at 30% 30%, var(--accent3), transparent 60%);}
.glow-b{right:-140px; top:220px; background:radial-gradient(circle at 30% 30%, var(--accent), transparent 55%);}

.material-symbols-outlined{
  font-variation-settings: "wght" 600, "FILL" 0, "GRAD" 0, "opsz" 24;
}

.top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:22px 26px;
  position:sticky;
  top:0;
  backdrop-filter: blur(10px);
  background: linear-gradient(180deg, rgba(11,15,20,.8), rgba(11,15,20,.35));
  border-bottom:1px solid rgba(255,255,255,.06);
}
.brand{display:flex; gap:12px; align-items:center;}
.mark{
  width:42px; height:42px;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(255,221,122,.25), rgba(122,231,255,.18));
  border:1px solid rgba(255,255,255,.12);
  display:grid; place-items:center;
  font-weight:700;
}
.name{font-family:var(--serif); font-size:18px; letter-spacing:.4px}
.tag{font-size:12px; color:var(--muted)}
.actions{display:flex; gap:10px; align-items:center;}

.app{
  min-height:100vh;
  display:grid;
  grid-template-columns: 280px 1fr;
}
.shell{min-width:0; display:flex; flex-direction:column;}
.content{
  max-width:1240px;
  margin:0 auto;
  padding:22px 22px 80px;
  width:100%;
}

.side{
  position:sticky;
  top:0;
  height:100vh;
  border-right:1px solid rgba(255,255,255,.06);
  /* Remove o "esverdeado": sidebar mais roxa/laranja como no modelo original */
  background:
    radial-gradient(520px 280px at 25% 0%, rgba(188,0,255,.20), transparent 55%),
    radial-gradient(520px 280px at 85% 18%, rgba(0,242,255,.08), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  backdrop-filter: blur(14px);
  padding:18px 14px;
  overflow:auto;
}
.side-top{padding:6px 8px 14px;}
.side-brand{display:flex; gap:12px; align-items:center;}
.logo{
  width:46px; height:46px;
  border-radius:14px;
  background:rgba(236,91,19,.18);
  border:1px solid rgba(236,91,19,.35);
  box-shadow:0 0 18px rgba(236,91,19,.24);
  display:grid; place-items:center;
}
.side-brand-text{display:flex; flex-direction:column; gap:2px}
.brand-name{
  font-weight:900;
  letter-spacing:.22em;
  font-size:12px;
  text-transform:uppercase;
  font-style:italic;
}
.brand-sub{font-size:11px; color:rgba(233,237,243,.55)}

.side-nav{display:flex; flex-direction:column; gap:8px; padding:8px 8px 14px}
.side-link{
  display:flex; gap:10px; align-items:center;
  padding:10px 10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  color:rgba(233,237,243,.78);
  text-decoration:none;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:11px;
}
.side-link:hover{background:rgba(255,255,255,.05); color:rgba(233,237,243,.92)}
.side-link.is-active{
  border-color:rgba(0,242,255,.22);
  background:linear-gradient(135deg, rgba(0,242,255,.12), rgba(188,0,255,.10));
  box-shadow:0 0 18px rgba(0,242,255,.12), 0 0 18px rgba(188,0,255,.10);
  color:rgba(233,237,243,.96);
}

.build{
  margin-top:10px;
  color:rgba(233,237,243,.30);
  font-size:10px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:6px 6px 0;
}
.side-foot{margin-top:16px; padding-top:12px; border-top:1px solid rgba(255,255,255,.06)}
.side-chip{
  display:flex; align-items:center; gap:10px;
  padding:10px 10px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(0,0,0,.22);
  color:rgba(233,237,243,.72);
  font-size:12px;
}
.pill{
  margin-left:auto;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  font-weight:800;
  font-size:10px;
  letter-spacing:.12em;
}

.topnav{
  position:sticky;
  top:0;
  z-index:70;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,.06);
  background:
    radial-gradient(900px 320px at 70% 0%, rgba(188,0,255,.14), transparent 60%),
    radial-gradient(900px 320px at 20% 0%, rgba(0,242,255,.10), transparent 60%),
    rgba(5,5,5,.62);
  backdrop-filter: blur(16px);
}
.top-left{display:flex; align-items:center; gap:14px; min-width:0}
.top-brand{display:flex; align-items:center; gap:10px; min-width:0}
.top-mark{
  width:36px; height:36px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  display:grid; place-items:center;
  font-weight:900;
}
.top-title{
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-style:italic;
  line-height:1.1;
}
.top-sub{font-size:11px; color:rgba(233,237,243,.52)}
.top-links{display:none; gap:18px; align-items:center;}
.top-link{
  display:inline-flex; gap:8px; align-items:center;
  color:rgba(233,237,243,.62);
  text-decoration:none;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.18em;
}
.top-link:hover{color:rgba(233,237,243,.92)}
.top-right{display:flex; align-items:center; gap:10px}

.searchbar{
  display:none;
  align-items:center;
  gap:10px;
  padding:0 12px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
}
.searchbar input{
  width:320px;
  border:none;
  outline:none;
  background:transparent;
  color:rgba(233,237,243,.92);
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.kbd{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
  color:rgba(233,237,243,.52);
  padding:4px 8px;
  border-radius:10px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.14em;
}

/* Menu button: so aparece no mobile */
#menuBtn{display:inline-flex;}

.dash-hero{padding:18px 0 8px;}
.dash-card{
  border-radius:28px;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(900px 520px at 78% 10%, rgba(0,242,255,.14), transparent 60%),
    radial-gradient(900px 520px at 20% 30%, rgba(188,0,255,.10), transparent 60%),
    rgba(255,255,255,.02);
  box-shadow:0 22px 70px rgba(0,0,0,.55);
  padding:22px 22px;
  overflow:hidden;
  position:relative;
}
.dash-card::after{
  content:"";
  position:absolute;
  inset:-40% -10% -20% -10%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='900' height='520'%3E%3Cpath d='M0 360 C 220 260 300 460 520 360 S 780 240 900 320' fill='none' stroke='rgba(0,242,255,.18)' stroke-width='3'/%3E%3Cpath d='M0 300 C 200 200 320 420 540 300 S 760 160 900 260' fill='none' stroke='rgba(188,0,255,.16)' stroke-width='3'/%3E%3Cpath d='M0 420 C 240 320 320 520 560 410 S 780 300 900 380' fill='none' stroke='rgba(236,91,19,.14)' stroke-width='3'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-size:cover;
  opacity:.9;
  filter:blur(.2px);
  pointer-events:none;
}
.dash-pill{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(0,242,255,.22);
  background:rgba(0,242,255,.06);
  color:rgba(233,237,243,.82);
  font-size:11px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.dash-title{
  margin:14px 0 8px;
  font-size:52px;
  line-height:1.0;
  font-weight:900;
  letter-spacing:-.02em;
  text-transform:uppercase;
  font-style:italic;
}
.dash-title .grad{
  background:linear-gradient(90deg, var(--accent2), #6f7bff 40%, var(--accent3));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.dash-sub{margin:0; max-width:780px; color:rgba(233,237,243,.64); line-height:1.6}
.dash-actions{display:flex; gap:12px; margin-top:16px; flex-wrap:wrap}

.stats{
  margin-top:14px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
}
.stat{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  padding:14px 14px;
}
.stat-k{
  font-size:10px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(233,237,243,.44);
}
.stat-v{
  margin-top:8px;
  font-size:26px;
  font-weight:900;
  letter-spacing:-.02em;
}

.section-head{margin-top:26px;}
.section-title{
  display:flex; align-items:center; gap:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:rgba(233,237,243,.86);
}
.bar{
  width:4px;
  height:18px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--accent3), var(--accent2));
  box-shadow:0 0 18px rgba(188,0,255,.22);
}
.section-sub{margin-top:6px; color:rgba(233,237,243,.46); font-size:12px}

.dash-panels{
  margin-top:14px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:12px;
}
.dash-panel{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  padding:14px 14px;
}
.dash-panel-title{
  font-size:10px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(233,237,243,.66);
}
.dash-panel-sub{margin-top:6px; font-size:12px; color:rgba(233,237,243,.44)}
.dash-chart{
  margin-top:10px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.barrow{display:flex; align-items:center; gap:10px}
.barname{
  width:160px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(233,237,243,.78);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.bartrack{
  flex:1;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.22);
  overflow:hidden;
}
.barfill{
  height:100%;
  width:0%;
  background:linear-gradient(90deg, var(--accent2), #6f7bff 45%, var(--accent3));
  border-radius:999px;
  box-shadow:0 0 16px rgba(188,0,255,.14);
}
.barval{
  width:70px;
  text-align:right;
  font-size:11px;
  font-weight:900;
  color:rgba(233,237,243,.62);
}

.dash-users{margin-top:12px; display:flex; flex-direction:column; gap:12px}
.dash-user{display:flex; gap:10px; align-items:center}
.dash-user .dot{
  width:10px; height:10px; border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.22);
}
.dash-user .dot.ok{background:rgba(0,242,255,.86);}
.u-title{font-weight:900; letter-spacing:.06em}
.u-sub{font-size:12px; color:rgba(233,237,243,.44)}

.pro-grid{
  margin-top:14px;
  padding:0;
  display:grid;
  /* cards maiores como no modelo: menos "miudo" e mais capa */
  grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
  gap:18px;
  align-items:stretch;
  justify-items:stretch;
}
.pro-card{
  height:auto;
  min-height:unset;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  aspect-ratio: 3 / 4;
  overflow:hidden;
  position:relative;
  width:100%;
}
.pro-card::before{
  /* "capa" mais bonita: usa a mesma imagem como fundo desfocado */
  content:"";
  position:absolute;
  inset:-18%;
  background-image:var(--cover);
  background-size:cover;
  background-position:center;
  filter:blur(18px) saturate(1.05);
  opacity:.55;
  transform:scale(1.04);
  pointer-events:none;
}
.pro-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.22) 32%, rgba(0,0,0,.88) 100%);
  pointer-events:none;
}
.pro-card .img{opacity:1; filter:none}
.pro-card .shade{
  background:linear-gradient(180deg, rgba(0,0,0,.02) 0%, rgba(0,0,0,.18) 40%, rgba(0,0,0,.92) 100%);
}
.pro-card .body{min-height:100%; padding:16px 16px}
.pro-card .title{
  font-family:var(--sans);
  font-size:22px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-style:italic;
}
.kinds{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px}
.tag{
  padding:6px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  font-size:10px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(233,237,243,.78);
}
.tag-primary{
  border-color:rgba(236,91,19,.28);
  background:rgba(236,91,19,.14);
}

.album-hero{
  height:260px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.06);
  background-size:cover;
  background-position:center;
  position:relative;
  overflow:hidden;
  box-shadow:0 22px 70px rgba(0,0,0,.55);
}
.album-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(5,5,5,.92) 0%, rgba(5,5,5,.62) 45%, rgba(5,5,5,.30) 100%);
}
.album-head{
  margin-top:-220px;
  position:relative;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:14px;
  padding:16px 10px 10px;
}
.album-left{display:flex; gap:12px; align-items:flex-end; min-width:0}
.album-titles{min-width:0}
.album-title{
  font-size:44px;
  font-weight:900;
  letter-spacing:-.02em;
  text-transform:uppercase;
  font-style:italic;
  line-height:1;
}
.album-sub{margin-top:6px; color:rgba(233,237,243,.56); font-size:12px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.filters{display:flex; gap:8px; align-items:center; flex-wrap:wrap; justify-content:flex-end}
.filters-k{
  color:rgba(233,237,243,.42);
  font-size:10px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-right:6px;
}

/* Responsivo */
@media (min-width: 980px){
  .top-links{display:flex;}
  .searchbar{display:flex;}
  #menuBtn{display:none;}
}
@media (max-width: 980px){
  .app{grid-template-columns: 1fr;}
  .side{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    width:280px;
    transform:translateX(-110%);
    transition:transform 260ms var(--ease);
    z-index:90;
  }
  .side.is-open{transform:translateX(0);}
  .content{padding:18px 16px 70px;}
  .dash-title{font-size:40px;}
  .stats{grid-template-columns: repeat(2, 1fr);}
  .dash-panels{grid-template-columns: 1fr;}
  .album-head{margin-top:-210px; flex-direction:column; align-items:flex-start}
  .filters{justify-content:flex-start}
}
.status-wrap{position:relative; display:inline-flex; align-items:center;}
.iconbtn{
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--ink);
  display:grid;
  place-items:center;
  cursor:pointer;
  position:relative;
}
.iconbtn:hover{background:rgba(255,255,255,.10)}
.iconbtn:active{transform:translateY(1px)}
.iconbtn .icon{
  font-family:var(--serif);
  font-weight:700;
  font-size:18px;
  opacity:.9;
}
.iconbtn .dot{
  position:absolute;
  top:10px;
  right:10px;
  width:10px;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.22);
  box-shadow:0 0 0 2px rgba(0,0,0,.18);
}
.iconbtn .dot[data-state="ok"]{background:rgba(107,214,255,.9);}
.iconbtn .dot[data-state="err"]{background:rgba(255,91,91,.9);}

.popover{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  width:min(320px, calc(100vw - 32px));
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(15,23,34,.96), rgba(11,15,20,.96));
  box-shadow:var(--shadow);
  padding:12px 12px;
  z-index:60;
}
.popover-title{font-weight:650; letter-spacing:.2px}
.popover-body{
  margin-top:8px;
  font-size:12px;
  color:rgba(233,237,243,.76);
  white-space:pre-wrap;
  line-height:1.45;
}

.btn{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--ink);
  border-radius:14px;
  padding:10px 12px;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.btn:hover{background:rgba(255,255,255,.10)}
.btn:active{transform:translateY(1px)}
.btn.is-active{
  border-color:rgba(0,242,255,.30);
  background:linear-gradient(135deg, rgba(0,242,255,.16), rgba(188,0,255,.10));
}
.btn-primary{
  border-color:rgba(236,91,19,.35);
  background:linear-gradient(135deg, rgba(236,91,19,.92), rgba(236,91,19,.72));
  box-shadow:0 0 22px rgba(236,91,19,.20);
}
.btn-ghost{
  background:transparent;
  border-color:rgba(255,255,255,.12);
}
.btn-small{padding:8px 10px; border-radius:12px; font-size:13px}

.main{max-width:1180px; margin:0 auto; padding:22px 26px 70px;}

.login{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px 16px;
}
.login-card{
  width:min(520px, 100%);
  border-radius:28px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:var(--shadow);
  padding:20px 18px 18px;
}
.login-brand{display:flex; gap:12px; align-items:center;}
.login-title{
  font-family:var(--serif);
  font-size:34px;
  margin:14px 0 6px;
  letter-spacing:.25px;
}
.login-sub{margin:0 0 14px; color:rgba(233,237,243,.78); line-height:1.55}
.login-form{display:flex; flex-direction:column; gap:12px}
.field{display:flex; flex-direction:column; gap:8px; color:rgba(233,237,243,.88); font-size:13px}
.field input{
  padding:12px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  color:var(--ink);
  outline:none;
}
.field input:focus{border-color:rgba(107,214,255,.35)}
.login-err{
  border:1px solid rgba(255,91,91,.25);
  background:rgba(255,91,91,.08);
  padding:10px 12px;
  border-radius:14px;
  color:rgba(233,237,243,.92);
  font-size:12px;
}
.hero{padding:28px 0 16px;}
.hero h1{
  font-family:var(--serif);
  font-size:clamp(34px, 4.8vw, 58px);
  line-height:1.05;
  margin:0 0 10px;
}
.hero p{
  margin:0;
  max-width:760px;
  color:rgba(233,237,243,.82);
  font-size:16px;
  line-height:1.6;
}
.hero-inner{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:18px;
  align-items:start;
}
.hero-copy{padding-right:6px;}
.hero-side{display:flex; justify-content:flex-end;}
.hero-card{
  width:min(420px, 100%);
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:var(--shadow);
  padding:16px 16px;
}
.hero-card-title{font-weight:650; letter-spacing:.2px}
.hero-card-sub{margin-top:4px; font-size:12px; color:rgba(233,237,243,.70)}
.hero-card-list{margin-top:12px; display:flex; flex-direction:column; gap:10px}
.hero-card-row{display:flex; gap:10px; align-items:center; color:rgba(233,237,243,.86); font-size:13px}
.hero-card-row .k{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  padding:6px 8px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:12px;
}
.chips{margin-top:14px; display:flex; gap:10px; flex-wrap:wrap}
.chip{
  font-size:12px;
  color:rgba(233,237,243,.88);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  padding:6px 10px;
  border-radius:999px;
}

.panel{
  margin-top:20px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  overflow:hidden;
  margin-bottom:28px;
}
.panel-head{
  padding:18px 18px 14px;
  display:flex;
  gap:12px;
  justify-content:space-between;
  align-items:flex-end;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.panel-title{font-weight:650; letter-spacing:.2px}
.panel-sub{font-size:12px; color:var(--muted); margin-top:4px}
.search input{
  width:min(420px, 52vw);
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.20);
  color:var(--ink);
  outline:none;
}
.search input:focus{border-color:rgba(122,231,255,.35)}

.grid{
  padding:18px;
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap:18px;
  align-items:stretch;
}
@media (max-width: 920px){
  .hero-inner{grid-template-columns: 1fr;}
  .hero-side{justify-content:flex-start;}
  .grid{grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));}
}
@media (max-width: 560px){
  .top{padding:16px}
  .main{padding:18px 16px 50px}
  .hero h1{font-size:32px}
  .grid{grid-template-columns: 1fr;}
  .search input{width:100%}
  .panel-head{flex-direction:column; align-items:stretch}
  .actions{gap:8px}
}

.card{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  border-radius:var(--radius);
  overflow:hidden;
  cursor:pointer;
  position:relative;
  /* Evita bugs de layout em alguns browsers com aspect-ratio + overlays absolutos */
  height:220px;
  min-height:220px;
  transform:translateY(0);
  transition:transform 260ms var(--ease), background 260ms var(--ease), border-color 260ms var(--ease), filter 260ms var(--ease);
}
.card:hover{border-color:rgba(255,255,255,.16); background:rgba(255,255,255,.07); transform:translateY(-3px)}
.card:active{transform:translateY(1px)}
.card .img{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  filter:saturate(1.05) contrast(1.03);
  opacity:.78;
}
.card .shade{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.65) 70%, rgba(0,0,0,.82) 100%);
}
.card .body{
  position:relative;
  padding:14px 14px 12px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  min-height:100%;
  gap:8px;
}
.card .title{
  font-family:var(--serif);
  font-size:20px;
  letter-spacing:.35px;
  line-height:1.1;
}
.card .meta{
  font-size:12px;
  color:rgba(233,237,243,.78);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.badge{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.25);
  padding:4px 8px;
  border-radius:999px;
}

.empty{padding:22px; color:var(--muted);}
.error{
  padding:18px;
  border:1px solid rgba(255,91,91,.25);
  background:rgba(255,91,91,.08);
  border-radius:16px;
}

.modal{position:fixed; inset:0; display:grid; place-items:center; z-index:50}
.modal-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.55); backdrop-filter: blur(6px);}
.modal-card{
  position:relative;
  width:min(980px, 96vw);
  max-height:min(88vh, 920px);
  display:flex;
  flex-direction:column;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(15,23,34,.95), rgba(11,15,20,.95));
  box-shadow:var(--shadow);
  overflow:hidden;
}
.modal-head{
  padding:14px 14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.modal-title{font-family:var(--serif); font-size:22px; letter-spacing:.3px}
.modal-body{padding:14px; overflow:auto}

.lib-hero{
  height:220px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.10);
  background-size:cover;
  background-position:center;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.lib-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(7,9,12,.18) 0%, rgba(7,9,12,.82) 78%, rgba(7,9,12,.96) 100%);
}
.lib-hero::after{
  content:"";
  position:absolute;
  inset:-18%;
  background:radial-gradient(900px 520px at 20% 20%, rgba(107,214,255,.16), transparent 60%),
             radial-gradient(900px 520px at 70% 30%, rgba(255,207,125,.12), transparent 60%);
  filter:blur(12px);
}
.lib-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:12px;
  padding:10px 0 12px;
  margin-top:14px;
  position:relative;
  padding-left:6px;
  padding-right:6px;
}
.lib-left{display:flex; gap:12px; align-items:flex-end;}
.lib-titles{display:flex; flex-direction:column; gap:4px;}
.lib-title{font-family:var(--serif); font-size:clamp(28px, 4vw, 44px); letter-spacing:.25px}
.lib-sub{font-size:12px; color:rgba(233,237,243,.70)}
.lib-meta{
  margin-top:6px;
  color:rgba(233,237,243,.72);
  font-size:12px;
  padding-left:10px;
  padding-right:10px;
}

.breadcrumb{
  padding:8px 2px 12px;
  color:rgba(233,237,243,.70);
  font-size:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.crumb{
  cursor:pointer;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  padding:6px 10px;
  border-radius:999px;
}
.crumb:hover{background:rgba(255,255,255,.08)}
.modal-tools{display:flex; justify-content:space-between; gap:10px; align-items:center; flex-wrap:wrap}
.pill{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:rgba(233,237,243,.8);
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
}

.lightbox{position:fixed; inset:0; z-index:80; display:grid; place-items:center}
.lightbox-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.72); backdrop-filter: blur(10px);}
.lightbox-card{
  position:relative;
  width:min(1200px, 98vw);
  height:min(86vh, 920px);
  border-radius:22px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(15,23,34,.96), rgba(11,15,20,.96));
  box-shadow:var(--shadow);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:0;
}
.lightbox-head{
  padding:12px 12px;
  display:flex;
  gap:10px;
  align-items:center;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.lightbox-title{min-width:0; flex:1; display:flex; flex-direction:column; gap:2px;}
.lb-title{font-family:var(--serif); font-size:18px; letter-spacing:.2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.lb-meta{font-size:12px; color:rgba(233,237,243,.62); overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.lightbox-actions{display:flex; gap:8px; align-items:center; flex-wrap:wrap; justify-content:flex-end}
.lb-count{font-size:12px; color:rgba(233,237,243,.62); padding:0 6px}
.lightbox-body{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px;
  background:radial-gradient(900px 520px at 50% 20%, rgba(122,231,255,.10), transparent 60%),
             radial-gradient(900px 520px at 70% 30%, rgba(255,221,122,.08), transparent 60%),
             rgba(0,0,0,.15);
  min-height:0;
  overflow:auto;
}
.lightbox-body .lb-media{
  max-width:100%;
  max-height:100%;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:#000;
  object-fit:contain;
}
.lightbox-card.lb-scroll .lightbox-body{
  align-items:flex-start;
  justify-content:center;
  padding:18px 14px 20px;
}
.lightbox-card.lb-scroll img.lb-media{
  max-height:none;
  height:auto;
  width:min(1120px, 100%);
}
.lb-mkv{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:center;
  justify-content:center;
}
.lb-mkv .lb-poster{
  width:min(860px, 100%);
  max-height:56vh;
  object-fit:contain;
  background:rgba(0,0,0,.28);
}

.lb-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:46px;
  height:56px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(11,15,20,.48);
  backdrop-filter: blur(10px);
  cursor:pointer;
  z-index:3;
  display:grid;
  place-items:center;
  transition:transform 180ms var(--ease), background 220ms var(--ease), border-color 220ms var(--ease);
}
.lb-nav:hover{background:rgba(11,15,20,.62); border-color:rgba(255,255,255,.20)}
.lb-nav:active{transform:translateY(-50%) scale(.98)}
.lb-nav-left{left:12px;}
.lb-nav-right{right:12px;}
.lb-nav::before{
  content:"";
  width:10px;
  height:10px;
  border-right:2px solid rgba(233,237,243,.9);
  border-bottom:2px solid rgba(233,237,243,.9);
  transform:rotate(135deg);
  margin-left:2px;
}
.lb-nav-right::before{
  transform:rotate(-45deg);
  margin-left:-2px;
}
@media (max-width: 560px){
  .lb-nav{width:42px; height:52px; border-radius:14px}
  .lb-nav-left{left:8px}
  .lb-nav-right{right:8px}
}
.lightbox-body .hint{
  color:rgba(233,237,243,.78);
  font-size:13px;
  line-height:1.5;
  text-align:center;
  max-width:860px;
}

/* Deixa o viewer "maior" em telas largas */
@media (min-width: 980px){
  .modal-card{width:min(1120px, 96vw);}
  .viewer-body video{max-height:62vh;}
  .viewer-body img{max-height:62vh;}
}

.items{margin-top:12px;}

.items-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
}
@media (max-width: 920px){ .items-grid{grid-template-columns: repeat(3, 1fr);} }
@media (max-width: 560px){ .items-grid{grid-template-columns: repeat(2, 1fr);} }

.folders{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
}
@media (max-width: 920px){ .folders{grid-template-columns: repeat(2, 1fr);} }
@media (max-width: 560px){ .folders{grid-template-columns: 1fr;} }

.folder-card{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  border-radius:18px;
  overflow:hidden;
  cursor:pointer;
  min-height:140px;
  position:relative;
}
.folder-card:hover{background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.14)}
.folder-card .img{position:absolute; inset:0; background-size:cover; background-position:center; opacity:.8;}
.folder-card .shade{position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.70) 90%);}
.folder-card .body{position:relative; padding:12px 12px; display:flex; flex-direction:column; justify-content:flex-end; min-height:140px; gap:6px;}
.folder-card .t{font-family:var(--serif); font-size:18px; letter-spacing:.2px}
.folder-card .m{font-size:12px; color:rgba(233,237,243,.70); display:flex; gap:10px; flex-wrap:wrap}

.item{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  border-radius:16px;
  overflow:hidden;
  cursor:pointer;
}
.item:hover{background:rgba(255,255,255,.07); border-color:rgba(255,255,255,.14)}
.item.active{border-color:rgba(122,231,255,.35); background:rgba(122,231,255,.08)}
.item .thumb{
  height:124px;
  background:rgba(255,255,255,.04);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.item .cap{
  padding:10px 10px 12px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.item .t{font-size:13px; line-height:1.25; color:rgba(233,237,243,.9)}
.item .m{font-size:11px; color:var(--muted); display:flex; gap:8px; flex-wrap:wrap}
.sep{opacity:.5}

.toast{
  position:fixed;
  left:16px;
  bottom:16px;
  max-width:min(760px, calc(100vw - 32px));
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,91,91,.25);
  background:rgba(15,23,34,.92);
  box-shadow:var(--shadow);
  color:rgba(233,237,243,.92);
  font-size:12px;
  line-height:1.4;
  z-index:100;
  white-space:pre-wrap;
}

.lb-audio{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(107,214,255,.10);
  color:rgba(233,237,243,.88);
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
}
.album-panel{
  margin-top:10px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
  backdrop-filter: blur(14px);
  padding:14px 14px 18px;
}

/* Tiles do album (pastas e arquivos) para ficarem retos e consistentes */
.items.items-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap:16px;
  margin-top:10px;
}
.tile{
  position:relative;
  border-radius:26px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  aspect-ratio: 1 / 1;
  cursor:pointer;
  transform:translateY(0);
  transition:transform 240ms var(--ease), border-color 240ms var(--ease), background 240ms var(--ease);
  --img1:none;
  --img2:none;
  --img3:none;
  --img4:none;
}
.tile:hover{transform:translateY(-4px); border-color:rgba(255,255,255,.12); background:rgba(255,255,255,.03)}
.tile:active{transform:translateY(1px)}
.tile-media{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  filter:saturate(1.02) contrast(1.02);
}
.tile.is-collage .tile-media{
  background-image:var(--img1), var(--img2), var(--img3), var(--img4);
  background-size:50% 50%;
  background-position:0 0, 100% 0, 0 100%, 100% 100%;
  background-repeat:no-repeat;
}
.tile.is-collage .tile-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.10), rgba(255,255,255,0)) 50% 0 / 1px 100% no-repeat,
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0)) 0 50% / 100% 1px no-repeat;
  opacity:.30;
}
.tile-shade{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.02) 0%, rgba(0,0,0,.25) 38%, rgba(0,0,0,.88) 100%);
}
.tile-body{
  position:absolute;
  inset:auto 0 0 0;
  padding:14px 14px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.tile-tags{display:flex; gap:8px; flex-wrap:wrap}
.tile-title{
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-style:italic;
  line-height:1.1;
  display:flex;
  gap:8px;
  align-items:center;
}
.tile-title .material-symbols-outlined{font-variation-settings:"wght" 700; opacity:.92;}
.tile-meta{
  font-size:11px;
  color:rgba(233,237,243,.62);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.tag-folder{
  border-color:rgba(0,242,255,.26);
  background:rgba(0,242,255,.10);
}
.tag-photo{
  border-color:rgba(188,0,255,.26);
  background:rgba(188,0,255,.12);
}
.tag-video{
  border-color:rgba(236,91,19,.28);
  background:rgba(236,91,19,.14);
}

@media (max-width: 980px){
  .pro-grid{grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));}
  .items.items-grid{grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));}
}

/* ========================================================================== */
/* Modelo 2: Overrides (mantem estas regras no fim do arquivo)                */
/* ========================================================================== */

/* Forca o grid "grande" na Home (o bloco legado .grid pode sobrescrever). */
.grid.pro-grid{
  margin-top:14px;
  padding:0;
  display:grid;
  /* Grande, mas ainda permite 2 colunas em telas 1366px com sidebar */
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap:18px;
  align-items:stretch;
  justify-content:center;
  justify-items:stretch;
}
@media (max-width: 980px){
  .grid.pro-grid{
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    justify-content:stretch;
  }
}

/* Forca o poster grande das bibliotecas */
.card.pro-card{
  aspect-ratio: 3 / 4;
  border-radius:26px;
  --img1:none;
  --img2:none;
  --img3:none;
  --img4:none;
}
.card.pro-card .title{font-size:22px;}

.card.pro-card .img{
  /* default (1 imagem): poster normal */
  background-image:var(--cover);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.card.pro-card.is-collage .img{
  /* 4 imagens: colagem 2x2 estilo template */
  background-image:var(--img1), var(--img2), var(--img3), var(--img4);
  background-size:50% 50%;
  background-position:0 0, 100% 0, 0 100%, 100% 100%;
  background-repeat:no-repeat;
  filter:none;
}
.card.pro-card.is-collage .img::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.10), rgba(255,255,255,0)) 50% 0 / 1px 100% no-repeat,
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0)) 0 50% / 100% 1px no-repeat;
  opacity:.35;
}

/* Estado ativo do menu lateral: evita "verde" e mantem ciano/roxo do modelo */
.side-link.is-active{
  border-color:rgba(0,242,255,.22);
  background:linear-gradient(135deg, rgba(0,242,255,.12), rgba(188,0,255,.10));
  box-shadow:0 0 18px rgba(0,242,255,.12), 0 0 18px rgba(188,0,255,.10);
}

/* Badge de pasta: somente icone, sem texto */
.tile-tags .tag .material-symbols-outlined{
  font-size:16px;
  line-height:1;
}
