/*
Theme Name: Shear Axis V3
Theme URI: https://example.com/
Author: Perplexity
Description: Scalable WordPress theme for the Shear Axis techno event series, designed to work with the Shear Axis Core plugin.
Version: 3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: shear-axis
*/

:root {
  --bg: #050505;
  --fg: #f2f2f2;
  --muted: #6c7075;
  --accent: #153245;
  --panel: rgba(255,255,255,0.035);
  --border: rgba(255,255,255,0.09);
  --max: 1220px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;background:var(--bg);color:var(--fg);font-family:Inter,Arial,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none} img,video{max-width:100%;display:block;height:auto} .mono{font-family:'IBM Plex Mono',monospace}
.shell{width:min(var(--max),calc(100% - 48px));margin:0 auto;position:relative;z-index:2}
.bg-grid{position:fixed;inset:0;pointer-events:none;opacity:.18;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:56px 56px}
.shear-line{position:fixed;top:-14vh;left:63%;height:150vh;width:3px;pointer-events:none;background:linear-gradient(to bottom,transparent,var(--accent),var(--accent),transparent);transform:rotate(33deg);opacity:.9}
.site-header{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 0;position:relative;z-index:3}.brand-lockup{display:flex;align-items:baseline;gap:10px}.brand{font-size:clamp(1.1rem,1.5vw,1.45rem);font-weight:900;letter-spacing:.16em}.edition{color:var(--muted);font-size:.95rem;font-weight:800;letter-spacing:.24em}
.nav{display:flex;gap:22px;flex-wrap:wrap;color:#d4d4d4;font-size:.9rem}.nav a:hover{color:var(--fg)}
.section{padding:64px 0}.hero{min-height:88vh;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;padding-top:30px}.eyebrow{margin:0 0 18px;color:var(--muted);letter-spacing:.25em;font-size:.8rem;font-weight:700;text-transform:uppercase}.hero h1,.page-title{margin:0;font-size:clamp(3rem,10vw,8rem);line-height:.9;font-weight:900;letter-spacing:-.05em}.hero h1 span{display:block;margin-top:12px;color:var(--muted);font-size:.34em;letter-spacing:.18em}.hero-city{margin:26px 0 16px;font-size:clamp(2rem,6vw,4.8rem);font-weight:800}.hero-meta{display:flex;flex-wrap:wrap;gap:10px 18px;color:#d7d7d7;margin-bottom:28px;font-size:.96rem}
.btn{min-height:52px;display:inline-flex;align-items:center;justify-content:center;padding:0 22px;border:1px solid var(--border);text-transform:uppercase;letter-spacing:.12em;font-weight:800;font-size:.82rem}.btn-primary{background:var(--accent);border-color:var(--accent)}.btn-secondary{background:transparent}.hero-actions,.ticket-actions{display:flex;gap:14px;flex-wrap:wrap}
.panel,.artist-card,.event-card,.tickets-box,.future-card,.media-card,.content-card{background:var(--panel);border:1px solid var(--border);backdrop-filter:blur(6px)}
.video-card{width:100%;aspect-ratio:4/5;position:relative;overflow:hidden;border:1px solid var(--border);background:#0b0f12}.video-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.15),rgba(5,5,5,.55) 40%,rgba(5,5,5,.9))}.hero-video{width:100%;height:100%;object-fit:cover;opacity:.24}
.seal{position:absolute;inset:0;margin:auto;width:220px;height:220px}.seal-circle{position:absolute;inset:20px;border:7px solid var(--fg);border-radius:50%}.seal-axis{position:absolute;top:36px;bottom:36px;left:50%;width:10px;transform:translateX(-50%);background:var(--fg)}.seal-cut{position:absolute;left:36px;right:36px;top:50%;height:6px;transform:translateY(-50%) rotate(-42deg);background:var(--accent)}.created{color:var(--muted);font-size:.8rem;letter-spacing:.15em;text-transform:uppercase}
.info-grid,.lineup-grid,.series-grid,.archive-grid,.artists-grid,.upcoming-grid,.stats-grid{display:grid;gap:18px}.info-grid,.series-grid,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.archive-grid,.artists-grid,.upcoming-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.lineup-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.panel,.content-card{padding:28px}.panel-label,.role,.meta-label{color:var(--muted);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem}.section-head{margin-bottom:24px}.section-head h2{margin:10px 0 0;font-size:clamp(1.8rem,4vw,3rem);line-height:.95}
.artist-card,.event-card{padding:26px;min-height:185px;display:flex;flex-direction:column;justify-content:flex-end}.artist-card h3,.event-card h3{margin:10px 0 0;font-size:clamp(1.6rem,3vw,2.6rem);line-height:.95}.artist-card.featured{border-color:rgba(21,50,69,.75);box-shadow:inset 0 0 0 1px rgba(21,50,69,.42)}
.archive-hero,.page-basic{padding:120px 0 40px}.archive-grid,.artists-grid{padding-bottom:40px}.event-meta,.mini-meta{display:flex;flex-wrap:wrap;gap:10px 14px;color:#d5d5d5;font-size:.88rem}.event-card .btn{margin-top:18px;align-self:flex-start}
.content-prose{max-width:72ch;line-height:1.7;color:#dadada}.single-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:22px}.single-sidebar{display:grid;gap:18px}.meta-stack{display:grid;gap:14px}
.site-footer{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:28px 0 42px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.84rem}.footer-meta,.footer-socials{display:flex;gap:18px;flex-wrap:wrap}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}
@media (max-width:980px){.hero,.single-grid,.info-grid,.series-grid,.archive-grid,.artists-grid,.upcoming-grid,.lineup-grid,.stats-grid{grid-template-columns:1fr}.site-header,.site-footer{flex-direction:column;align-items:flex-start}}
@media (max-width:640px){.shell{width:min(var(--max),calc(100% - 28px))}.nav{gap:12px}.seal{width:180px;height:180px}}
.hero-event-link {
  position: relative;
  display: block;
  text-decoration: none;
}

.event-seal {
  position: absolute;
  top: 20px;
  right: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: rgba(0,0,0,0.8);
  padding: 1rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
}

.event-info {
  margin-top: 0.5rem;
  text-align: center;
}

.event-date {
  font-size: 0.85rem;
  opacity: 0.8;
  display: block;
}

.event-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin-top: 0.25rem;
  max-width: 200px;
  line-height: 1.2;
}

/* Hover effect */
.hero-event-link:hover .event-seal {
  transform: scale(1.05);
  transition: transform 0.3s ease;
}
/* Hero Visual Enhanced */
.hero-event-link { position: relative; display: block; text-decoration: none; }

.video-overlay { 
  position: absolute; top: 0; left: 0; right: 0; bottom: 0; 
  background: linear-gradient(135deg, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.7) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
}

.hero-event-link:hover .video-overlay { opacity: 1; }

.countdown-container {
  position: absolute;
  top: 30px;
  left: 30px;
  background: rgba(0,0,0,0.9);
  padding: 1.5rem 2rem;
  border-radius: 16px;
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.1);
}

.countdown {
  display: flex;
  gap: 1.5rem;
  font-family: 'IBM Plex Mono', monospace;
}

.countdown-item {
  text-align: center;
}

.countdown-num {
  display: block;
  font-size: 2.2rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  min-width: 60px;
}

.countdown-label {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.8);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.event-seal {
  position: absolute;
  bottom: 30px;
  right: 30px;
  background: rgba(0,0,0,0.85);
  padding: 2rem 1.5rem;
  border-radius: 20px;
  backdrop-filter: blur(20px);
  max-width: 280px;
  border: 1px solid rgba(255,255,255,0.1);
}

.event-info h3 { 
  margin: 0.5rem 0 1rem 0; 
  font-size: 1.3rem; 
  line-height: 1.3;
  color: #fff;
}

.lineup-teaser {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.9rem;
}

.lineup-artist {
  color: #fff;
  text-decoration: none;
  font-weight: 500;
}

.lineup-artist:hover { text-decoration: underline; }

.lineup-more {
  color: rgba(255,255,255,0.7);
}

/* Responsive */
@media (max-width: 768px) {
  .countdown-container { 
    top: 20px; left: 20px; right: 20px; 
    padding: 1rem;
    position: relative;
  }
  .countdown { gap: 1rem; }
  .countdown-num { font-size: 1.8rem; }
  .event-seal { 
    bottom: 20px; right: 20px; left: 20px;
    padding: 1.5rem 1rem;
  }
}