/* ================================
   K. MOON — Artistic Site Styles
   Palette: deep space + neon rose
   Accessibility: high-contrast text,
   keyboard focus, reduced motion
=================================== */

/* ---------- CSS Variables ---------- */
:root{
  --bg: #0a0b11;            /* deep night */
  --bg-2:#0e1018;
  --text: #f7f8fa;          /* near-white */
  --muted:#c6c9d4;          /* slate */
  --brand:#ff0066;          /* neon rose */
  --brand-2:#ff3b8e;        /* rose highlight */
  --brand-3:#cc0052;        /* darker rose */
  --glass: rgba(255,255,255,.08);
  --edge: rgba(255,255,255,.2);
  --shadow: 0 24px 60px rgba(0,0,0,.45);
  --maxw: 1120px;
}

/* Smooth typography + base reset */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text)}
body{
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  line-height:1.65; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}

/* Links + focus states */
a{color:inherit;text-decoration:none}
a:focus-visible, button:focus-visible, [tabindex]:focus-visible{
  outline:2px dashed var(--brand);
  outline-offset:3px;
  border-radius:.5rem;
}

/* Reduced motion respect */
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ---------- Layout helpers ---------- */
.main{max-width:var(--maxw);margin:3.5rem auto;padding:0 1.25rem}
.grid{display:grid;gap:1.25rem}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width: 860px){ .grid.cols-2{grid-template-columns:1fr} }

.center{display:grid;place-items:center}
.muted{color:var(--muted)}
.small{font-size:.92rem;color:var(--muted)}
.hidden{display:none}

/* ---------- Skip Link ---------- */
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden
}
.skip-link:focus{
  left:1rem;top:1rem;width:auto;height:auto;background:#000;padding:.6rem 1rem;
  border-radius:.5rem;z-index:9999
}

/* ---------- Header / Nav (glassy) ---------- */
header{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;justify-content:center;pointer-events:none;
}
.nav{
  pointer-events:auto;
  margin:1rem auto;padding:.6rem .9rem;
  display:flex;gap:.7rem;flex-wrap:wrap;align-items:center;justify-content:center;
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border:1px solid var(--edge);
  border-radius:999px;
  box-shadow:var(--shadow);
}
.nav a{
  text-decoration:none;font-weight:700;letter-spacing:.2px;
  padding:.55rem .9rem;border-radius:999px;position:relative;
  transition:transform .18s ease, background .18s ease, color .18s ease;
  color:var(--text);
}
.nav a[aria-current="page"]{background:var(--glass)}
.nav a:hover{background:var(--glass);transform:translateY(-1px)}
.nav a:active{transform:translateY(0) scale(.98)}

/* ---------- Hero (cinematic glow + slow gradient) ---------- */
.hero{
  min-height:100svh; /* better mobile viewport */
  display:grid;place-items:center;text-align:center;position:relative;isolation:isolate;
  padding:6rem 1.25rem 4rem;
  background:
    radial-gradient(1200px 600px at 75% 10%, rgba(255,0,102,.13), transparent 60%),
    radial-gradient(900px 600px at 15% 90%, rgba(102,0,255,.20), transparent 60%),
    var(--bg);
  overflow:hidden;
}
.hero::before{
  /* background.jpg sits under a soft vignette */
  content:"";position:absolute;inset:0;z-index:-2;
  background: center/cover no-repeat url('background.jpg');
  filter: saturate(115%) contrast(98%) brightness(90%);
  transform:scale(1.03);
}
.hero::after{
  /* animated aurora veil */
  content:"";position:absolute;inset:-40% -10%;z-index:-1;
  background: conic-gradient(from 180deg at 50% 50%, rgba(255,0,102,.20), rgba(255,255,255,0) 30%,
              rgba(60,130,255,.18) 60%, rgba(255,255,255,0) 85%, rgba(255,0,102,.20));
  mix-blend-mode: screen; opacity:.55;
  animation: aurora 18s linear infinite;
}
@keyframes aurora{
  0%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(-2%,1%,0) rotate(180deg)}
  100%{transform:translate3d(0,0,0) rotate(360deg)}
}

.hero .inner{max-width:880px;margin-inline:auto}
h1{
  font-weight:800;letter-spacing:.5px;
  font-size:clamp(2.4rem, 6vw, 4rem);
  line-height:1.1;margin:0 0 1rem;
  text-shadow:0 8px 32px rgba(0,0,0,.55), 0 1px 0 rgba(255,255,255,.04);
}
.sub{
  font-size:clamp(1rem, 2.6vw, 1.25rem);
  color:var(--muted); margin:0 0 1.75rem;
}

/* ---------- Buttons (neon pill) ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  background:linear-gradient(180deg, var(--brand), var(--brand-3));
  color:#fff; text-decoration:none; font-weight:800; letter-spacing:.3px;
  padding:.9rem 1.4rem; border-radius:999px; border:1px solid rgba(255,255,255,.14);
  box-shadow: 0 16px 40px rgba(255,0,102,.35), inset 0 1px 0 rgba(255,255,255,.18);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.07)}
.btn:active{transform:translateY(0) scale(.98)}
.btn.ghost{
  background:transparent;border-color:var(--edge);box-shadow:none;
}
.btn.ghost:hover{background:var(--glass)}

/* ---------- Quick Links Grid (homepage) ---------- */
[aria-label="Quick Links"]{
  margin-top:2.25rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
[aria-label="Quick Links"] .btn{
  justify-self:start;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  color:var(--text); border:1px solid var(--edge); box-shadow:var(--shadow);
}
[aria-label="Quick Links"] .btn:hover{
  background:linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.06));
}

/* ---------- Cards (press/blog/service sections) ---------- */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border:1px solid var(--edge); border-radius:1.1rem; padding:1.1rem 1.1rem;
  box-shadow:var(--shadow);
}
.card h3{margin:.2rem 0 .4rem}
.card p{margin:.2rem 0}

/* ---------- Platforms list (music page) ---------- */
.platforms{display:flex;flex-direction:column;gap:.95rem;align-items:center}
.platform{
  display:flex;align-items:center;gap:.7rem;padding:.6rem .75rem;border-radius:.9rem;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--edge); box-shadow:var(--shadow);
  transition: transform .16s ease, background .16s ease;
}
.platform:hover{transform:translateY(-1px);background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04))}
.platform img{width:28px;height:28px}

/* ---------- Gallery (gallery.html) ---------- */
.gallery{
  display:grid; gap:14px;
  grid-template-columns:repeat(12, 1fr);
}
.gallery .tile{
  position:relative; overflow:hidden; border-radius:1rem;
  aspect-ratio: 4/5; grid-column: span 3; background:var(--bg-2);
  border:1px solid var(--edge);
}
.gallery .tile.wide{aspect-ratio: 16/9; grid-column: span 6}
.gallery .tile.tall{aspect-ratio: 3/4; grid-column: span 3}
.gallery .tile img{width:100%;height:100%;object-fit:cover;transform:scale(1.02);transition:transform .25s ease}
.gallery .tile:hover img{transform:scale(1.06)}
@media (max-width: 1024px){ .gallery .tile{grid-column: span 6} .gallery .tile.wide{grid-column: span 12} }
@media (max-width: 640px){ .gallery{grid-template-columns:repeat(6,1fr)} .gallery .tile{grid-column: span 6} }

/* ---------- Blog list (blog.html) ---------- */
.posts{display:grid;gap:1rem;grid-template-columns:repeat(12,1fr)}
.post{
  grid-column: span 6; padding:1.1rem;border-radius:1rem;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border:1px solid var(--edge); box-shadow:var(--shadow)
}
.post h3{margin:.2rem 0}
.post .meta{color:var(--muted);font-size:.92rem}
@media (max-width: 860px){ .post{grid-column: span 12} }

/* ---------- Press / Media kit ---------- */
.press-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(12,1fr)}
.press-card{grid-column:span 6}
@media (max-width: 860px){ .press-card{grid-column: span 12} }
.kit{
  display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.5rem
}
.chip{
  padding:.45rem .7rem;border-radius:999px;background:var(--glass);border:1px solid var(--edge)
}

/* ---------- Forms (contact) ---------- */
form{display:grid;gap:1rem}
label{display:grid;gap:.4rem;font-weight:700}
input, textarea{
  background:rgba(255,255,255,.06); color:var(--text);
  border:1px solid var(--edge); border-radius:.7rem;
  padding:.8rem .9rem; transition: border-color .15s ease, box-shadow .15s ease;
}
input::placeholder, textarea::placeholder{color:#b6b9c4}
input:focus, textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(255,0,102,.25)}

/* ---------- Footer ---------- */
footer{color:var(--muted); text-align:center; padding:2.2rem 1rem}

/* ---------- Utilities for spacing/typography ---------- */
h2{font-size:clamp(1.4rem, 3.6vw, 2rem); margin:0 0 .6rem}
h3{font-size:clamp(1.1rem, 2.6vw, 1.35rem); margin:.2rem 0 .25rem}
p{margin:.2rem 0 1rem}
ul{margin:.2rem 0 1rem 1.2rem}
/* --- Lyrics (songbook style) --- */
pre.lyrics, .lyrics {
  white-space: pre-wrap;   /* keep your line breaks */
  word-wrap: break-word;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  font-size: 1.05rem;
  line-height: 1.9;
  letter-spacing: .2px;
  margin: .25rem 0;
}

.lyrics-wrap {            /* card padding already exists; this adds a gentle frame */
  padding: .4rem .2rem;
}

.lyric-section {
  display: block;
  margin: 1.2rem 0 .4rem;
  font-weight: 800;
  text-transform: uppercase;
  font-size: .92rem;
  color: var(--muted);
  letter-spacing: .12em;
}

/* Optional helpers if you want emphasis */
.lyric-chorus { font-weight: 700; }
.lyric-bridge { font-style: italic; }

