/*
Theme Name: Zorg Metal
Theme URI: https://zorgmetal.com
Author: Zorg Metal
Description: A mobile-first link-in-bio theme for Zorg Metal. Card-style links with image, title, description and optional price, set against the band's sunset-starfield brand palette. Built as a Linktree-style landing page.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: zorg-metal
*/

/* =========================================================
   Zorg Metal — design tokens
   Palette sourced from brand book + album sunset gradient
   ========================================================= */
:root{
  /* Brand book swatches */
  --zm-simpsons:#FFEEA9;
  --zm-sherbet:#FCB76F;
  --zm-salmon:#F5979E;
  --zm-redish:#F16268;
  --zm-ice:#79CDD5;
  --zm-wood:#C2B065;
  --zm-black:#231F20;

  /* Sunset gradient stops (album cover) */
  --zm-sky:#F6D64F;
  --zm-orange:#E06748;
  --zm-coral:#DA4058;
  --zm-magenta:#B9467F;
  --zm-violet:#763C90;
  --zm-indigo:#3C2E83;
  --zm-night:#1B1B1D;

  /* Roles */
  --zm-ink:#1B1B1D;
  --zm-paper:#FFF7E6;
  --zm-card:#FFFBF2;
  --zm-card-line:#231F20;
  --zm-accent:var(--zm-redish);
  --zm-accent-2:var(--zm-ice);

  --zm-radius:18px;
  --zm-shadow:6px 6px 0 0 var(--zm-black);
  --zm-shadow-press:3px 3px 0 0 var(--zm-black);
  --zm-maxw:480px;

  --zm-font-display:"Anton","Arial Narrow",Impact,sans-serif;
  --zm-font-body:"Space Grotesk",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}

html{ -webkit-text-size-adjust:100%; }

body{
  margin:0;
  font-family:var(--zm-font-body);
  color:var(--zm-ink);
  background:var(--zm-night);
  -webkit-font-smoothing:antialiased;
  line-height:1.45;
  min-height:100vh;
}

/* Fixed sunset starfield behind everything */
.zm-bg{
  position:fixed;
  inset:0;
  z-index:-2;
  background:linear-gradient(
    180deg,
    var(--zm-sky) 0%,
    var(--zm-orange) 20%,
    var(--zm-coral) 38%,
    var(--zm-magenta) 55%,
    var(--zm-violet) 74%,
    var(--zm-indigo) 90%,
    var(--zm-night) 100%
  );
}
.zm-bg::after{
  /* starfield */
  content:"";
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(1.5px 1.5px at 20% 30%, rgba(255,255,255,.9), transparent),
    radial-gradient(1.5px 1.5px at 70% 18%, rgba(255,255,255,.7), transparent),
    radial-gradient(1px 1px at 40% 12%, rgba(255,255,255,.8), transparent),
    radial-gradient(1px 1px at 85% 40%, rgba(255,255,255,.7), transparent),
    radial-gradient(2px 2px at 88% 8%, rgba(255,255,255,1), transparent),
    radial-gradient(1px 1px at 12% 55%, rgba(255,255,255,.6), transparent),
    radial-gradient(1.5px 1.5px at 55% 48%, rgba(255,255,255,.5), transparent);
  background-repeat:no-repeat;
  opacity:.9;
  pointer-events:none;
}

.zm-shell{
  width:100%;
  max-width:var(--zm-maxw);
  margin:0 auto;
  padding:28px 20px 64px;
  position:relative;
}

/* ---------- Header / profile ---------- */
.zm-header{ text-align:center; margin-bottom:26px; }

.zm-logo{
  width:min(72%,300px);
  height:auto;
  display:block;
  margin:6px auto 4px;
  filter:drop-shadow(3px 4px 0 rgba(0,0,0,.55));
}
.zm-logo-fallback{
  font-family:var(--zm-font-display);
  font-size:clamp(44px,16vw,72px);
  line-height:.9;
  letter-spacing:2px;
  color:#fff;
  text-transform:uppercase;
  -webkit-text-stroke:3px var(--zm-black);
  text-shadow:4px 4px 0 var(--zm-black);
  margin:8px 0 0;
}
.zm-tagline{
  font-family:var(--zm-font-display);
  letter-spacing:6px;
  font-size:14px;
  color:#fff;
  text-transform:uppercase;
  margin:2px 0 14px;
  text-shadow:2px 2px 0 var(--zm-black);
}
.zm-bio{
  color:#fff;
  font-size:15px;
  max-width:340px;
  margin:0 auto;
  text-shadow:0 1px 2px rgba(0,0,0,.5);
}

/* ---------- Social row ---------- */
.zm-socials{
  display:flex;
  justify-content:center;
  gap:14px;
  margin:18px 0 4px;
  list-style:none;
  padding:0;
}
.zm-socials a{
  display:grid;
  place-items:center;
  width:44px;height:44px;
  border-radius:50%;
  background:var(--zm-card);
  border:2.5px solid var(--zm-black);
  box-shadow:3px 3px 0 0 var(--zm-black);
  color:var(--zm-black);
  transition:transform .12s ease, box-shadow .12s ease;
}
.zm-socials a:hover,.zm-socials a:focus-visible{
  transform:translate(1.5px,1.5px);
  box-shadow:1px 1px 0 0 var(--zm-black);
}
.zm-socials svg{width:20px;height:20px;}

/* ---------- Link cards ---------- */
.zm-cards{ display:flex; flex-direction:column; gap:18px; margin-top:8px; }

.zm-card{
  display:flex;
  align-items:stretch;
  gap:0;
  text-decoration:none;
  color:var(--zm-ink);
  background:var(--zm-card);
  border:3px solid var(--zm-card-line);
  border-radius:var(--zm-radius);
  overflow:hidden;
  box-shadow:var(--zm-shadow);
  transition:transform .14s ease, box-shadow .14s ease;
  position:relative;
}
.zm-card:active,
.zm-card:hover,
.zm-card:focus-visible{
  transform:translate(3px,3px);
  box-shadow:var(--zm-shadow-press);
  outline:none;
}
.zm-card:focus-visible{ outline:3px dashed var(--zm-ice); outline-offset:4px; }

.zm-card__media{
  flex:0 0 92px;
  background:var(--zm-simpsons);
  border-right:3px solid var(--zm-card-line);
  overflow:hidden;
}
.zm-card__media img{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
/* No featured image: collapse to a slim colored spine instead of a big block. */
.zm-card.no-media .zm-card__media{ flex-basis:14px; }
.zm-card.no-media .zm-card__media img{ display:none; }

.zm-card__body{
  flex:1 1 auto;
  padding:13px 14px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-width:0;
}
.zm-card__title{
  font-family:var(--zm-font-display);
  font-size:19px;
  line-height:1.05;
  letter-spacing:.5px;
  text-transform:uppercase;
  margin:0;
}
.zm-card__desc{
  font-size:13.5px;
  margin:5px 0 0;
  color:#3a3536;
  overflow:hidden;
}
.zm-card__price{
  align-self:flex-start;
  margin-top:9px;
  font-family:var(--zm-font-display);
  font-size:14px;
  letter-spacing:.5px;
  background:var(--zm-redish);
  color:#fff;
  border:2.5px solid var(--zm-black);
  border-radius:999px;
  padding:3px 12px;
  box-shadow:2px 2px 0 0 var(--zm-black);
}
.zm-card__chev{
  flex:0 0 auto;
  align-self:center;
  padding-right:14px;
  color:var(--zm-black);
  opacity:.5;
}

/* Rotating accent stripe on each card's left media when no image set */
.zm-card:nth-child(6n+1) .zm-card__media{background:var(--zm-ice);}
.zm-card:nth-child(6n+2) .zm-card__media{background:var(--zm-sherbet);}
.zm-card:nth-child(6n+3) .zm-card__media{background:var(--zm-salmon);}
.zm-card:nth-child(6n+4) .zm-card__media{background:var(--zm-simpsons);}
.zm-card:nth-child(6n+5) .zm-card__media{background:var(--zm-wood);}
.zm-card:nth-child(6n+6) .zm-card__media{background:var(--zm-redish);}

/* ---------- Footer ---------- */
.zm-footer{
  text-align:center;
  margin-top:38px;
  color:#fff;
  font-size:12px;
  letter-spacing:.5px;
  text-shadow:0 1px 2px rgba(0,0,0,.5);
}
.zm-footer a{ color:var(--zm-simpsons); }

/* ---------- Empty / admin hint ---------- */
.zm-empty{
  background:var(--zm-card);
  border:3px dashed var(--zm-black);
  border-radius:var(--zm-radius);
  padding:22px;
  text-align:center;
  font-size:14px;
}
.zm-empty strong{font-family:var(--zm-font-display);font-size:18px;letter-spacing:.5px;}

/* ---------- Motion / a11y ---------- */
@media (prefers-reduced-motion:reduce){
  *{transition:none !important; animation:none !important;}
}

/* Slightly roomier on larger phones / tablets but stays narrow */
@media (min-width:600px){
  .zm-shell{ padding-top:44px; }
  .zm-card__media{ flex-basis:104px; }
}
