/* Simple, clean styles for DJ Loufy (moved to styles/styles.css) */
:root{
  --bg:#070708;
  --surface:#0b0b0d;
  --card:#0f1113;
  --glass:rgba(255,255,255,0.03);
  --accent: #ff4d6d;
  --accent-gradient: linear-gradient(90deg,#ff6b84,#ff4d6d);
  --muted: rgba(255,255,255,0.65);
  --text:#ffffff;
  --radius:12px;
  --shadow: 0 10px 30px rgba(2,6,23,0.6);
} 
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;background:radial-gradient(1200px 400px at 10% 10%, rgba(255,255,255,0.02), transparent),var(--bg);color:var(--text);font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.55;overflow-x:hidden}

/* Keep headings bold for emphasis */
h1,h2,h3,h4,h5,h6{font-weight:700}
.container{max-width:1200px;margin:0 auto;padding:3rem} 
.top-nav{display:flex;align-items:center;justify-content:space-between;padding:0.9rem 1.25rem;background:rgba(255,255,255,0.02);backdrop-filter:blur(8px);position:sticky;top:12px;z-index:60;border-radius:14px;margin:1rem;box-shadow:0 8px 30px rgba(2,6,23,0.6);transition:transform .15s ease}
.top-nav:hover{transform:translateY(-2px)}
.nav-right a{position:relative;transition:opacity .15s,transform .15s}
.nav-right a::after{content:"";position:absolute;left:50%;transform:translateX(-50%) scaleX(0);bottom:6px;height:2px;width:60%;background:var(--accent);transition:transform .18s cubic-bezier(.2,.8,.2,1)}
.nav-right a:hover::after,.nav-right a:focus::after{transform:translateX(-50%) scaleX(1)}
.brand{display:flex;align-items:center;text-decoration:none;color:inherit}
.logo{width:48px;height:48px;margin-right:0.8rem;border-radius:8px;object-fit:cover}
.brand-name{font-weight:700;font-size:1.1rem}
.card-media{aspect-ratio:1/1;width:100%;min-height:140px;border-radius:12px;overflow:hidden;margin-bottom:0.75rem;border:1px solid rgba(255,255,255,0.04);display:block}
.card-media img{width:100%;height:100%;object-fit:cover;display:block}
.nav-right ul{list-style:none;margin:0;padding:0;display:flex;gap:1rem}
.nav-right a{color:var(--text);text-decoration:none;padding:0.5rem 0.6rem;border-radius:6px}
.nav-right a:hover{background:rgba(255,255,255,0.03)}
.nav-toggle{display:none;background:none;border:0;padding:0.5rem;border-radius:6px}
.hamburger{display:block;width:24px;height:2px;background:var(--text);position:relative}
.hamburger::before,.hamburger::after{content:"";position:absolute;left:0;width:24px;height:2px;background:var(--text)}
.hamburger::before{top:-7px}
.hamburger::after{top:7px}
.section{padding:4rem 0}
.hero{padding:8rem 0 6rem;text-align:center;background-image:linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.45)), url('/assets/banner.jpg');background-size:cover;background-position:center;border-radius:12px;margin:1rem 0}
.hero h1{font-size:2.6rem;margin:0 0 0.6rem;letter-spacing:-0.02em}
.hero p{color:var(--muted);max-width:720px;margin:0 auto 1.25rem;font-size:1.05rem}
.btn{background:var(--accent-gradient);color:#fff;padding:0.6rem 1rem;border-radius:999px;text-decoration:none;box-shadow:0 6px 20px rgba(255,77,109,0.08);display:inline-block;transition:transform .15s ease} 
.song-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 600px) {
  .song-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 900px) {
  .song-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Compact card variant for home page (bigger, square thumbnails) */
.card.compact{padding:1.25rem;border-radius:12px;display:flex;align-items:center;gap:1rem}
.card.compact .card-media{width:120px;height:120px;flex:0 0 120px;border-radius:8px;overflow:hidden;display:block}
.card.compact .card-media img{width:100%;height:100%;object-fit:cover;display:block}
.card.compact h4{margin:0;font-size:1.05rem;line-height:1.2}
.card.compact .btn{margin-left:auto;padding:0.6rem 1rem;font-size:0.98rem}
@media (max-width:900px){
  .card.compact .card-media{width:96px;height:96px;flex:0 0 96px}
}
@media (max-width:640px){
  .card.compact .card-media{width:72px;height:72px;flex:0 0 72px}
  .card.compact{padding:0.8rem}
}

.empty{color:var(--muted);padding:1.5rem;background:transparent;border-radius:8px}
.card{background:var(--card);padding:1rem;border-radius:8px}
.site-footer{padding:2.25rem 0;color:var(--muted);background:linear-gradient(180deg, rgba(255,255,255,0.01), transparent);border-top:1px solid rgba(255,255,255,0.04);margin-top:2.5rem}
.site-footer .footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.footer-left{font-weight:700;color:var(--text);letter-spacing:0.01em}
.footer-right{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.footer-link{color:var(--muted);text-decoration:none;font-weight:700;display:inline-flex;align-items:center;gap:0.6rem;padding:0.35rem 0.5rem;border-radius:8px;transition:color .12s,transform .12s,background .12s}
.footer-link:hover{color:var(--accent);background:rgba(255,77,109,0.04);transform:translateY(-2px)}
.footer-link:focus-visible{outline:2px solid rgba(255,77,109,0.18);outline-offset:3px;border-radius:8px}
.footer-icon svg{width:20px;height:20px;display:block;color:var(--muted)}
.footer-logo{width:20px;height:20px;display:inline-block;vertical-align:middle;margin-right:0.5rem}
.footer-text{display:inline-block}

@media (max-width:600px){
  .site-footer .footer-inner{flex-direction:column;text-align:center}
  .footer-right{justify-content:center}
}

/* Responsive */
@media (max-width:760px){
  .nav-right{position:absolute;right:1rem;top:64px;background:linear-gradient(#071021, #081225);border-radius:8px;padding:0.75rem;display:none;box-shadow:0 10px 30px rgba(2,6,23,0.6)}
  .nav-right.open{display:block}
  .nav-right ul{flex-direction:column;gap:0.25rem}
  .nav-toggle{display:block}
  .brand-name{font-size:1rem}
}

/* Site-wide card/meta/button adjustments to match songs theme */
.card{background:var(--card);padding:1.25rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,0.04);box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(2,6,23,0.7)}
.meta{color:var(--muted);font-weight:400;margin:0.25rem 0 0.75rem}
.btn{background:var(--accent-gradient);color:#fff;font-weight:700;padding:0.65rem 1.05rem;border-radius:999px;border:0;box-shadow:0 6px 18px rgba(255,77,109,0.12);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}

/* Subtle horizontal rule for section separation (avoids large visible bands) */
hr{border:0;height:1px;background:rgba(255,255,255,0.04);margin:2rem 0}

/* Form inputs: readable contrast on dark background */
.form-input,
form input,
form textarea,
form select{background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.02));border:1px solid rgba(255,255,255,0.06);color:var(--text);padding:0.9rem;border-radius:10px;font-weight:400;transition:box-shadow .12s ease,border-color .12s ease}
.form-row{display:flex;gap:1rem;flex-wrap:wrap}
.form-row > *{flex:1}
.form-input::placeholder{color:rgba(255,255,255,0.45);font-weight:400}
.form-input:focus{outline:none;box-shadow:0 10px 30px rgba(255,77,109,0.09);border-color:rgba(255,77,109,0.95)}
textarea.form-input{min-height:140px;resize:vertical}
.form-group {
  margin-bottom: 1.5rem;
}

.form-group label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 700;
}

.form-input,
form input,
form textarea,
form select {
  width: 100%;
}