/*
Theme Name: Epic Events v3
Description: Comic book style events hire theme. DJ hire, Sweet Bar, Giant Games.
Version: 3.0
Text Domain: epic-events
*/

@import url('https://fonts.googleapis.com/css2?family=Bangers&family=Nunito:wght@400;700;800;900&family=Permanent+Marker&display=swap');

/* ============================================================
   CSS VARIABLES
============================================================ */
:root {
  --ee-cyan:    #00C8E0;
  --ee-magenta: #E8006A;
  --ee-yellow:  #FFD700;
  --ee-lime:    #8BC34A;
  --ee-purple:  #7B2FBE;
  --ee-sky:     #29B6F6;
  --ee-black:   #111111;
  --ee-white:   #FFFEF5;
  --ee-cream:   #FFF9E3;

  --ee-outline:  3px solid var(--ee-black);
  --ee-shadow:   5px 5px 0 var(--ee-black);
  --ee-shadow-lg:9px 9px 0 var(--ee-black);

  --ee-font-hero:   'Bangers', cursive;
  --ee-font-accent: 'Permanent Marker', cursive;
  --ee-font-body:   'Nunito', sans-serif;
}

/* ============================================================
   BASE
============================================================ */
body {
  font-family: var(--ee-font-body);
  background: var(--ee-cream);
  overflow-x: hidden;
}

/* Global halftone dot texture */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: radial-gradient(circle, rgba(0,0,0,0.06) 1.5px, transparent 1.5px);
  background-size: 18px 18px;
  pointer-events: none;
  z-index: 0;
}

h1, h2, h3, h4, h5 {
  font-family: var(--ee-font-hero);
  letter-spacing: 2px;
  text-transform: uppercase;
}

/* ============================================================
   NAVIGATION
============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--ee-black);
  border-bottom: 4px solid var(--ee-yellow);
}

.site-logo {
  font-family: var(--ee-font-hero);
  font-size: 1.8rem;
  letter-spacing: 3px;
  color: var(--ee-white);
  text-decoration: none;
}

.site-logo:hover { color: var(--ee-yellow); text-decoration: none; }

.site-logo .logo-highlight {
  background: var(--ee-yellow);
  color: var(--ee-black);
  padding: 1px 8px;
  margin-left: 4px;
  display: inline-block;
  transform: rotate(-2deg);
}

.navbar-nav .nav-link {
  color: rgba(255,255,255,0.85) !important;
  font-weight: 800;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  border: 2px solid transparent;
  transition: all 0.15s;
}

.navbar-nav .nav-link:hover {
  color: var(--ee-yellow) !important;
  border-color: var(--ee-yellow);
}

.navbar-toggler { border-color: var(--ee-yellow); }
.navbar-toggler-icon { filter: invert(1); }

.nav-cta-btn {
  background: var(--ee-magenta) !important;
  color: white !important;
  border: 2px solid var(--ee-magenta) !important;
  font-family: var(--ee-font-hero) !important;
  font-size: 1rem !important;
  letter-spacing: 2px !important;
  box-shadow: 4px 4px 0 var(--ee-yellow);
  transition: all 0.15s !important;
}

.nav-cta-btn:hover {
  background: var(--ee-yellow) !important;
  color: var(--ee-black) !important;
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--ee-magenta) !important;
}

/* ============================================================
   HERO
============================================================ */
.hero {
  position: relative;
  min-height: 92vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  border-bottom: 4px solid var(--ee-black);
}

.hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.hero-video-wrap video {
  width: 100%; height: 100%;
  object-fit: cover;
}

/* Colour + dark overlay on top of video */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,0.82) 0%, rgba(232,0,106,0.28) 50%, rgba(0,0,0,0.72) 100%);
  z-index: 2;
}

/* Halftone dots over video */
.hero-halftone {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.12) 1.5px, transparent 1.5px);
  background-size: 18px 18px;
  z-index: 3;
  pointer-events: none;
}

/* Placeholder shown until a video is uploaded */
.hero-placeholder {
  width: 100%; height: 100%;
  min-height: 92vh;
  background: #0a0a0a;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.hero-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(0,200,224,0.35) 0%, transparent 55%),
              radial-gradient(ellipse at 80% 30%, rgba(232,0,106,0.40) 0%, transparent 55%),
              radial-gradient(ellipse at 50% 85%, rgba(255,215,0,0.20) 0%, transparent 55%);
}

.hero-placeholder::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-conic-gradient(rgba(255,215,0,0.05) 0deg 10deg, transparent 10deg 20deg);
  animation: spin 35s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

.placeholder-icon {
  position: relative;
  z-index: 5;
  text-align: center;
}

.placeholder-disc {
  width: 100px; height: 100px;
  background: var(--ee-yellow);
  border: 4px solid var(--ee-black);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem;
  margin: 0 auto 1rem;
  animation: pulse 2s ease-in-out infinite;
  box-shadow: var(--ee-shadow-lg);
}

@keyframes pulse { 0%,100%{transform:scale(1);}50%{transform:scale(1.08);} }

.placeholder-label {
  font-family: var(--ee-font-hero);
  font-size: 0.9rem;
  letter-spacing: 3px;
  color: rgba(255,255,255,0.5);
  background: rgba(0,0,0,0.5);
  border: 2px dashed rgba(255,255,255,0.2);
  padding: 6px 18px;
  display: inline-block;
}

/* Hero text content */
.hero-content {
  position: relative;
  z-index: 5;
  width: 100%;
  padding: 4rem 0 6rem;
}

.hero-eyebrow {
  display: inline-block;
  font-family: var(--ee-font-accent);
  font-size: 1rem;
  background: var(--ee-cyan);
  color: var(--ee-black);
  border: var(--ee-outline);
  padding: 4px 16px;
  box-shadow: var(--ee-shadow);
  transform: rotate(-2deg);
  margin-bottom: 1.25rem;
}

.hero h1 {
  color: var(--ee-white);
  -webkit-text-stroke: 3px var(--ee-black);
  text-shadow: 8px 8px 0 var(--ee-black);
  margin-bottom: 0.5rem;
  line-height: 1;
}

.hero h1 .h1-highlight {
  color: var(--ee-yellow);
  -webkit-text-stroke: 3px var(--ee-black);
  display: block;
}

.hero-subtext {
  font-size: 1.05rem;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  background: rgba(0,0,0,0.5);
  display: inline-block;
  padding: 10px 18px;
  border-left: 5px solid var(--ee-cyan);
  margin-bottom: 2rem;
  max-width: 560px;
  line-height: 1.6;
}

/* Floating speech bubble */
.hero-bubble {
  position: absolute;
  right: 6%;
  top: 12%;
  z-index: 6;
}

.speech-bubble {
  background: var(--ee-white);
  border: 4px solid var(--ee-black);
  box-shadow: var(--ee-shadow-lg);
  padding: 12px 20px;
  border-radius: 50%;
  font-family: var(--ee-font-hero);
  font-size: 1.8rem;
  letter-spacing: 2px;
  color: var(--ee-magenta);
  min-width: 100px;
  text-align: center;
  position: relative;
  animation: wobble 3s ease-in-out infinite;
}

.speech-bubble::after {
  content: '';
  position: absolute;
  bottom: -20px; left: 24px;
  border: 10px solid transparent;
  border-top: 10px solid var(--ee-black);
}

.speech-bubble::before {
  content: '';
  position: absolute;
  bottom: -13px; left: 26px;
  border: 8px solid transparent;
  border-top: 8px solid var(--ee-white);
  z-index: 1;
}

@keyframes wobble { 0%,100%{transform:rotate(-3deg);}50%{transform:rotate(3deg) scale(1.05);} }

.hero-starburst {
  position: absolute;
  right: 7%; bottom: 20%;
  z-index: 6;
  font-family: var(--ee-font-hero);
  font-size: 2rem;
  color: var(--ee-yellow);
  -webkit-text-stroke: 2px var(--ee-black);
  text-shadow: 4px 4px 0 var(--ee-black);
  transform: rotate(12deg);
  animation: zap 2s ease-in-out infinite;
}

@keyframes zap { 0%,100%{transform:rotate(12deg) scale(1);}50%{transform:rotate(16deg) scale(1.1);} }

/* Diagonal bottom cut */
.hero::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  height: 70px;
  background: var(--ee-cream);
  clip-path: polygon(0 100%, 100% 0%, 100% 100%);
  z-index: 7;
}

/* ============================================================
   MARQUEE BANNER
============================================================ */
.marquee-banner {
  background: var(--ee-yellow);
  border-top: 4px solid var(--ee-black);
  border-bottom: 4px solid var(--ee-black);
  padding: 0.8rem 0;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.marquee-track {
  display: flex;
  gap: 2rem;
  width: max-content;
  animation: marquee 18s linear infinite;
}

.marquee-item {
  font-family: var(--ee-font-hero);
  font-size: 1.3rem;
  letter-spacing: 3px;
  white-space: nowrap;
  color: var(--ee-black);
}

.marquee-sep { color: var(--ee-magenta); margin: 0 0.5rem; }

@keyframes marquee { 0%{transform:translateX(0);}100%{transform:translateX(-50%);} }

/* ============================================================
   SECTION LABELS & HEADINGS
============================================================ */
.section-label {
  font-family: var(--ee-font-accent);
  font-size: 0.95rem;
  display: inline-block;
  background: var(--ee-yellow);
  border: var(--ee-outline);
  padding: 3px 14px;
  box-shadow: var(--ee-shadow);
  margin-bottom: 0.75rem;
  transform: rotate(-1.5deg);
}

.section-title {
  font-family: var(--ee-font-hero);
  font-size: clamp(2rem, 4vw, 3.5rem);
  letter-spacing: 3px;
}

/* ============================================================
   BOOTSTRAP CARD OVERRIDES — Comic book style
   All card backgrounds/colours driven by Customiser CSS vars
============================================================ */

/* Services cards */
.services-section { background: var(--ee-cream); }

.service-card {
  border: 4px solid var(--ee-black) !important;
  box-shadow: var(--ee-shadow-lg);
  border-radius: 0 !important;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
  height: 100%;
}

.service-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 13px 13px 0 var(--ee-black);
}

.service-card .card-header {
  border-radius: 0 !important;
  border-bottom: 4px solid var(--ee-black) !important;
  padding: 1.5rem 1.25rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Sunburst rays in card header */
.service-card .card-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-conic-gradient(rgba(255,255,255,0.1) 0deg 8deg, transparent 8deg 16deg);
}

/* Halftone dots in card header */
.service-card .card-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(0,0,0,0.07) 1.5px, transparent 1.5px);
  background-size: 14px 14px;
}

.service-card .card-header .card-icon {
  font-size: 3rem;
  display: block;
  margin-bottom: 0.5rem;
  position: relative;
  z-index: 1;
  filter: drop-shadow(2px 2px 0 rgba(0,0,0,0.2));
}

.service-card .card-header .card-title {
  font-family: var(--ee-font-hero);
  font-size: 1.8rem;
  letter-spacing: 3px;
  margin: 0;
  position: relative;
  z-index: 1;
}

.service-card .card-body { background: var(--ee-white); padding: 1.5rem; }
.service-card .card-body p { font-size: 0.93rem; color: #444; }

.service-card .card-body .list-group-item {
  font-weight: 800;
  font-size: 0.88rem;
  border: none;
  border-bottom: 2px dashed rgba(0,0,0,0.12) !important;
  padding: 0.5rem 0;
  background: transparent;
}

.service-card .card-body .list-group-item::before {
  content: '★';
  color: var(--ee-yellow);
  -webkit-text-stroke: 1px var(--ee-black);
  margin-right: 8px;
}

.service-card .card-footer {
  background: var(--ee-white);
  border-top: 2px dashed rgba(0,0,0,0.12) !important;
  padding: 1rem 1.25rem;
}

/* Steps / How It Works cards */
.steps-section { background: var(--ee-black); }

.step-card {
  border: 4px solid var(--ee-black) !important;
  box-shadow: var(--ee-shadow-lg);
  border-radius: 0 !important;
  overflow: hidden;
  height: 100%;
  position: relative;
}

.step-card .card-body { padding: 2rem 1.5rem; text-align: center; position: relative; }

/* Big ghost number behind content */
.step-card .step-number {
  position: absolute;
  top: -8px; right: 8px;
  font-family: var(--ee-font-hero);
  font-size: 5rem;
  line-height: 1;
  color: rgba(0,0,0,0.12);
  pointer-events: none;
  z-index: 0;
}

/* Halftone overlay */
.step-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(0,0,0,0.07) 1.5px, transparent 1.5px);
  background-size: 14px 14px;
  pointer-events: none;
  z-index: 1;
}

.step-card .step-emoji {
  font-size: 2.8rem;
  display: block;
  margin-bottom: 0.75rem;
  position: relative;
  z-index: 2;
}

.step-card .card-title {
  font-family: var(--ee-font-hero);
  font-size: 1.1rem;
  letter-spacing: 2px;
  position: relative;
  z-index: 2;
}

.step-card .card-text {
  font-size: 0.85rem;
  line-height: 1.5;
  position: relative;
  z-index: 2;
}

/* Packages cards */
.packages-section { background: var(--ee-cream); }

.package-card {
  border: 4px solid var(--ee-black) !important;
  box-shadow: var(--ee-shadow-lg);
  border-radius: 0 !important;
  overflow: hidden;
  height: 100%;
  transition: transform 0.2s, box-shadow 0.2s;
}

.package-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 13px 13px 0 var(--ee-black);
}

.package-card .card-header {
  border-radius: 0 !important;
  border-bottom: 4px solid var(--ee-black) !important;
  text-align: center;
  padding: 0.75rem;
  font-family: var(--ee-font-hero);
  font-size: 1rem;
  letter-spacing: 2px;
  position: relative;
  overflow: hidden;
}

.package-card .card-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.1) 1.5px, transparent 1.5px);
  background-size: 12px 12px;
  pointer-events: none;
}

.package-card .package-price-wrap { padding: 1.5rem; text-align: center; border-bottom: 4px solid var(--ee-black); background: var(--ee-white); }

.package-card .package-price {
  font-family: var(--ee-font-hero);
  font-size: 4rem;
  line-height: 1;
  letter-spacing: 0;
}

.package-card .package-price sup { font-size: 1.6rem; vertical-align: super; }
.package-card .package-name { font-family: var(--ee-font-hero); font-size: 1.6rem; letter-spacing: 2px; }
.package-card .package-tagline { font-size: 0.82rem; color: #666; margin-top: 4px; }

.package-card .card-body { background: var(--ee-white); padding: 1.5rem; }

.package-card .list-group-item {
  font-weight: 800;
  font-size: 0.9rem;
  border: none !important;
  border-bottom: 2px dashed rgba(0,0,0,0.1) !important;
  padding: 0.5rem 0;
  background: transparent;
  display: flex;
  align-items: center;
  gap: 8px;
}

.package-card .list-group-item .check {
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: 0.75rem;
  border: 2px solid var(--ee-black);
  box-shadow: 2px 2px 0 var(--ee-black);
  flex-shrink: 0;
}

.package-card .card-footer {
  background: var(--ee-white);
  border-top: 4px solid var(--ee-black) !important;
  padding: 1rem 1.25rem;
}

/* ============================================================
   COMIC BUTTONS
============================================================ */
.btn-comic {
  font-family: var(--ee-font-hero);
  font-size: 1.1rem;
  letter-spacing: 2px;
  border: 3px solid var(--ee-black) !important;
  box-shadow: var(--ee-shadow);
  border-radius: 0 !important;
  text-transform: uppercase;
  transition: transform 0.1s, box-shadow 0.1s !important;
}

.btn-comic:hover {
  transform: translate(-3px, -3px);
  box-shadow: 8px 8px 0 var(--ee-black) !important;
}

.btn-comic:active {
  transform: translate(4px, 4px);
  box-shadow: 1px 1px 0 var(--ee-black) !important;
}

.btn-comic-yellow  { background: var(--ee-yellow);  color: var(--ee-black); }
.btn-comic-magenta { background: var(--ee-magenta); color: white; }
.btn-comic-cyan    { background: var(--ee-cyan);    color: var(--ee-black); }
.btn-comic-white   { background: var(--ee-white);   color: var(--ee-black); }
.btn-comic-black   { background: var(--ee-black);   color: var(--ee-yellow); }

/* ============================================================
   CONTACT SECTION
============================================================ */
.contact-section { background: var(--ee-black); }

.contact-form-wrap {
  background: var(--ee-white);
  border: 4px solid var(--ee-black);
  box-shadow: var(--ee-shadow-lg);
  padding: 2.5rem;
}

.contact-form-wrap .form-control,
.contact-form-wrap .form-select {
  border: 3px solid var(--ee-black) !important;
  border-radius: 0 !important;
  background: var(--ee-cream);
  font-weight: 700;
}

.contact-form-wrap .form-control:focus,
.contact-form-wrap .form-select:focus {
  box-shadow: 4px 4px 0 var(--ee-magenta) !important;
  border-color: var(--ee-black) !important;
}

.contact-form-wrap label {
  font-weight: 900;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.contact-detail {
  background: rgba(255,255,255,0.07);
  border: 2px solid rgba(255,255,255,0.15);
  padding: 1rem 1.25rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  font-weight: 800;
  color: rgba(255,255,255,0.9);
}

.contact-detail .icon { font-size: 1.8rem; flex-shrink: 0; }

.area-tag {
  font-family: var(--ee-font-hero);
  font-size: 0.9rem;
  letter-spacing: 2px;
  padding: 4px 12px;
  border: 3px solid var(--ee-black);
  box-shadow: 3px 3px 0 var(--ee-black);
  display: inline-block;
  margin: 3px;
}

/* ============================================================
   FOOTER
============================================================ */
.site-footer {
  background: var(--ee-black);
  border-top: 4px solid var(--ee-yellow);
  color: rgba(255,255,255,0.8);
}

.footer-logo {
  font-family: var(--ee-font-hero);
  font-size: 2rem;
  letter-spacing: 3px;
  color: var(--ee-white);
}

.footer-logo span {
  background: var(--ee-yellow);
  color: var(--ee-black);
  padding: 1px 8px;
}

.footer-heading {
  font-family: var(--ee-font-hero);
  font-size: 1.1rem;
  letter-spacing: 2px;
  color: var(--ee-yellow);
  border-bottom: 2px solid rgba(255,215,0,0.25);
  padding-bottom: 6px;
  margin-bottom: 1rem;
}

.footer-links a {
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  font-weight: 700;
  font-size: 0.9rem;
  display: block;
  margin-bottom: 0.4rem;
  transition: color 0.2s;
}

.footer-links a:hover { color: var(--ee-yellow); }

.footer-bottom {
  border-top: 2px solid rgba(255,255,255,0.08);
  padding: 1.25rem 0;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.4);
}

/* ============================================================
   SCROLL ANIMATIONS
============================================================ */
.animate-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.animate-in.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   RESPONSIVE TWEAKS
============================================================ */
@media (max-width: 768px) {
  .hero-bubble, .hero-starburst { display: none; }
  .hero::after { display: none; }
}
