:root{
  --bg:#0b0b0d; --fg:#eaeaf0; --muted:#b8b8c6; --card:#141418; --accent:#f5c451;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,Arial,sans-serif;background:var(--bg);color:var(--fg)}
.site-footer{position:fixed;left:0;right:0;bottom:0;background:linear-gradient(180deg,#0b0b0d,#0a0a0c);z-index:999}
body{padding-bottom:72px}
.container{max-width:1100px;margin:0 auto;padding:20px}
/* Ensure content clears the fixed footer with extra breathing room */
main.container{padding-bottom:120px}
.site-header{background:linear-gradient(180deg,#111,#0b0b0d)}
.title{margin:0;font-size:28px}
.subtitle{margin:4px 0 0;color:var(--muted)}
.mini-nav{display:flex;gap:10px;margin-top:8px}
.mini-link{color:#fff;text-decoration:none;background:transparent;border:1px solid #242432;padding:6px 10px;border-radius:8px;font-size:14px}
.mini-link:hover{background:#1b1b22}
.mini-link:focus-visible{outline:2px dashed #fff;outline-offset:2px}
.mini-link.active{background:#1b1b22;border-color:#34344a;box-shadow:inset 0 -2px 0 #fff}
.navbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0}
.navbar-title{font-size:22px;color:#fff}
.navbar-links{display:flex;gap:10px}
.site-footer{border-top:1px solid #1f1f25;color:var(--muted)}
.site-footer .container{display:flex;align-items:center;justify-content:space-between;padding-top:12px;padding-bottom:12px}
.footer-admin{opacity:.6;color:var(--muted);text-decoration:none;background:#1b1b22;border:1px solid #242432;padding:6px 8px;border-radius:8px;font-size:13px}
.footer-admin:hover{opacity:1;background:#232333}

.hero{margin-top:20px}
.hero-card{background:var(--card);padding:18px;border-radius:12px;border:1px solid #222}
.hero-card h2{margin:0 0 6px;font-size:22px}
.hero-meta{display:flex;gap:8px;margin-top:10px}
.badge{background:#1b1b22;color:#cfcfe6;border:1px solid #242432;padding:6px 10px;border-radius:999px;font-size:13px;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.pager{display:flex;gap:10px;justify-content:center;margin:24px 0}
.btn{display:inline-block;background:#1b1b22;color:#fff;border:1px solid #242432;padding:8px 14px;border-radius:8px;text-decoration:none}
.btn:hover{background:#232333}
.btn-danger{background:#3b1111;border-color:#5a1515}
.btn-danger:hover{background:#5a1515}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.grid-item{position:relative;overflow:hidden;border-radius:12px;border:1px solid #222;background:#111}
.grid-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.grid-item:hover img{transform:scale(1.05)}

/* Albums list */
.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-top:10px}
.albums-grid{margin-bottom:20px}
.album-card{display:block;background:var(--card);border:1px solid #222;border-radius:14px;overflow:hidden;text-decoration:none;color:inherit}
.album-card:hover{border-color:#2a2a3a}
.album-cover{height:160px;background:#111;display:flex;align-items:center;justify-content:center}
.album-cover img{width:100%;height:100%;object-fit:cover;display:block}
.cover-placeholder{width:64px;height:64px;border-radius:12px;background:#1b1b22;color:#cfcfe6;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;border:1px solid #242432}
.album-info{padding:12px}
.album-title{margin:0 0 6px;font-size:18px}
.album-count{color:var(--muted);font-size:13px}

/* Home showcase */
.showcase-carousel{position:relative;background:var(--card);border:1px solid #222;border-radius:12px;overflow:hidden}
.carousel-viewport{overflow:hidden}
.carousel-track{display:flex;transition:transform .45s ease}
.carousel-item{min-width:100%;height:360px;background:#111;display:flex;align-items:center;justify-content:center}
.carousel-item img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;filter:grayscale(100%);transition:filter .2s ease}
.showcase-carousel:hover .carousel-item img{filter:grayscale(0%)}
.carousel-controls{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);display:flex;justify-content:space-between;padding:0 8px;pointer-events:none}
.carousel-prev,.carousel-next{pointer-events:auto;background:#1b1b22;border:1px solid #34344a;color:#fff;border-radius:10px;padding:8px 12px;cursor:pointer}
.carousel-prev:hover,.carousel-next:hover{background:#232333}
.carousel-dots{position:absolute;left:50%;bottom:10px;transform:translateX(-50%);display:flex;gap:6px}

/* Upload progress bar */
.progress{position:relative;background:#1b1b22;border:1px solid #242432;border-radius:10px;overflow:hidden;height:18px}
.progress-bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#f5c451,#f7d483);width:0%;transition:width .2s ease}
.progress-status{position:absolute;left:8px;top:50%;transform:translateY(-50%);font-size:12px;color:#000}
.carousel-dot{width:8px;height:8px;border-radius:999px;background:#444}
.carousel-dot.active{background:#fff}

@media (max-width:640px){
  .carousel-item{height:240px}
}

/* Lightbox */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.86);display:flex;align-items:center;justify-content:center;z-index:1000}
.lb.hidden{display:none}
#lb-img{max-width:90vw;max-height:90vh;border-radius:10px;box-shadow:0 10px 40px rgba(0,0,0,.5)}
.lb-close,.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:#1b1b22;border:1px solid #34344a;color:#fff;border-radius:10px;padding:10px 12px;cursor:pointer}
.lb-close{top:20px;right:20px;transform:none}
.lb-prev{left:20px}
.lb-next{right:20px}
.lb-download{position:fixed;top:60px;right:20px;background:#1b1b22;border:1px solid #34344a;color:#fff;border-radius:10px;padding:8px 12px;text-decoration:none}
.lb-download:hover{background:#232333}

@media (max-width:640px){
  .grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .navbar{flex-wrap:wrap}
  .navbar-title{width:100%;margin-bottom:8px}
}

/* Simple form styles */
.form{margin-top:10px}
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.form-row label{font-size:13px;color:var(--muted)}
.form-row input{background:#0f0f14;border:1px solid #242432;color:#fff;border-radius:8px;padding:10px 12px}
.form-actions{margin-top:8px}

/* Admin table */
.admin-table th, .admin-table td{padding:8px;border-bottom:1px solid #222}
.admin-table th{color:#cfcfe6;font-weight:600}
.admin-table tr:hover{background:#121218}
