/* =====================================================================
   INVERCARGILL RAGE ROOM — stylesheet
   Dark / gritty / hot-pink grunge aesthetic, matching brand mockup.
   ===================================================================== */

:root{
  --pink:#FF2D7A;
  --pink-deep:#d61d63;
  --black:#0B0B0B;
  --charcoal:#1A1A1A;
  --grey:#333333;
  --silver:#B3B3B3;
  --white:#FFFFFF;

  --ink-card: #161616;
  --border:#2c2c2c;

  --font-display:'Anton', Impact, sans-serif;       /* condensed heavy display */
  --font-brush:'Permanent Marker', cursive;          /* brush / handwritten accent */
  --font-cond:'Bebas Neue', sans-serif;              /* condensed labels / nav */
  --font-body:'Montserrat', system-ui, sans-serif;   /* body */

  --maxw:1340px;
  --header-h:74px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth; scroll-padding-top:var(--header-h);}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--white);
  background:var(--black);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  /* gritty charcoal base with subtle vignette + noise */
  background-image:
    radial-gradient(ellipse at 20% 0%, rgba(255,45,122,.06), transparent 45%),
    radial-gradient(ellipse at 100% 100%, rgba(255,45,122,.05), transparent 50%),
    repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0 1px, transparent 1px 3px);
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
ul{margin:0; padding:0; list-style:none;}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-cond);
  letter-spacing:.06em;
  font-size:1.05rem;
  border:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5em;
  padding:.7em 1.6em;
  border-radius:4px;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  text-transform:uppercase;
}
.btn .ico{width:1.1em; height:1.1em; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round;}
.btn-pink{background:var(--pink); color:#fff; box-shadow:0 6px 22px rgba(255,45,122,.35);}
.btn-pink:hover{background:var(--pink-deep); transform:translateY(-2px); box-shadow:0 10px 28px rgba(255,45,122,.5);}
.btn-outline-pink{background:transparent; color:#fff; border:2px solid var(--pink); box-shadow:inset 0 0 0 0 var(--pink);}
.btn-outline-pink:hover{background:var(--pink); transform:translateY(-2px);}
.btn-outline-light{background:transparent; color:#fff; border:2px solid #fff;}
.btn-outline-light:hover{background:#fff; color:var(--black);}
.btn-lg{font-size:1.3rem; padding:.75em 2.2em;}
.btn-block{width:100%;}

/* =====================================================================
   HEADER
   ===================================================================== */
.site-header{
  position:sticky; top:0; z-index:200;
  background:rgba(11,11,11,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid #1d1d1d;
}
.header-inner{
  max-width:var(--maxw); margin:0 auto;
  height:var(--header-h);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 24px; gap:20px;
}
.brand-logo img{height:62px; width:auto;}
.main-nav{display:flex; gap:30px;}
.main-nav a{
  font-family:var(--font-cond);
  font-size:1.18rem; letter-spacing:.05em;
  color:#f2f2f2; position:relative; padding:4px 0;
  transition:color .18s ease;
}
.main-nav a:hover{color:var(--pink);}
.main-nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--pink); transition:width .22s ease;
}
.main-nav a:hover::after{width:100%;}
.header-actions{display:flex; align-items:center; gap:14px;}
.btn-nav{font-size:1.05rem; padding:.6em 1.3em;}

.nav-toggle{display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px;}
.nav-toggle span{display:block; width:26px; height:3px; background:#fff; border-radius:2px; transition:.25s;}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{
  background:
    radial-gradient(circle at 30% 40%, rgba(255,45,122,.05), transparent 60%),
    #0d0d0d;
  border-bottom:3px solid var(--pink);
  position:relative;
  overflow:hidden;
}
.hero-grid{
  max-width:var(--maxw); margin:0 auto;
  position:relative;
  min-height:400px;
}
/* image sits on the right ~58%, text overlays on top of the left */
.hero-left{
  position:relative; z-index:3;
  padding:30px 24px 34px 32px;
  max-width:58%;
}
.hero-eyebrow{
  font-family:var(--font-brush);
  color:var(--pink);
  font-size:clamp(1.3rem,2vw,1.95rem);
  margin:0 0 -6px 10px;
  transform:rotate(-3deg);
  text-shadow:0 0 14px rgba(255,45,122,.5);
}
.hero-title{margin:0; line-height:.82; letter-spacing:.01em;}
.hero-title span{display:block; font-family:var(--font-display); text-transform:uppercase;}
.word-first{
  font-size:clamp(3.4rem,7.4vw,6.4rem);
  color:#fff;
  -webkit-text-stroke:1px rgba(255,255,255,.12);
  text-shadow:3px 4px 0 rgba(0,0,0,.6), 0 0 30px rgba(255,255,255,.08);
  transform:skewX(-5deg);
}
.word-rage{
  font-size:clamp(3rem,6.6vw,5.9rem);
  color:var(--pink);
  text-shadow:3px 4px 0 rgba(0,0,0,.55), 0 0 26px rgba(255,45,122,.5);
  transform:skewX(-5deg);
  margin-top:-.08em;
  white-space:nowrap;
}
.hero-tag{
  font-family:var(--font-cond);
  font-size:clamp(1.2rem,1.9vw,1.7rem);
  letter-spacing:.08em;
  margin:18px 0 26px;
  color:#fff;
}
.hero-tag .dot{color:var(--pink); margin:0 .15em;}
.hero-cta-row{display:flex; align-items:center; gap:16px; flex-wrap:wrap;}
.hero-arrow{color:var(--pink); font-size:1.6rem;}
.hero-note{font-family:var(--font-brush); font-size:1.25rem; color:#fff;}
.hero-note::first-letter{color:var(--pink);}

/* hero right (room image) — absolutely positioned, spans right ~62% */
.hero-right{
  position:absolute; top:0; right:0; bottom:0;
  width:64%; z-index:1; overflow:hidden;
}
.hero-room{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  object-position:78% center;
}
.hero-right::after{ /* left fade so image blends into dark hero behind the headline */
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, #0d0d0d 0%, rgba(13,13,13,.85) 12%, rgba(13,13,13,.15) 34%, transparent 50%);
  pointer-events:none;
}

/* =====================================================================
   FEATURES STRIP
   ===================================================================== */
.features{background:#0e0e0e; border-bottom:1px solid #1b1b1b;}
.features-inner{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  padding:30px 24px;
}
.feature{display:flex; gap:14px; align-items:flex-start; padding:6px 22px; position:relative;}
.feature + .feature::before{
  content:""; position:absolute; left:0; top:12%; height:76%; width:1px; background:#2a2a2a;
}
.feat-ico{width:38px; height:38px; flex:none; fill:none; stroke:var(--pink); stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;}
.feature h3{font-family:var(--font-cond); letter-spacing:.05em; font-size:1.25rem; margin:0 0 4px; color:#fff;}
.feature p{margin:0; font-size:.86rem; color:var(--silver); line-height:1.4;}

/* =====================================================================
   SECTION TITLES
   ===================================================================== */
.section-title{
  font-family:var(--font-display); text-transform:uppercase;
  text-align:center; color:#fff; font-size:clamp(2.4rem,4.5vw,3.6rem);
  letter-spacing:.02em; margin:0;
}
/* Brush-script titles like the mockup ("Packages", "How It Works") */
.section-title--brush{
  font-family:var(--font-brush);
  text-transform:uppercase;
  color:#fff;
  font-size:clamp(2.2rem,4.2vw,3.4rem);
  letter-spacing:.01em;
  transform:rotate(-2deg) skewX(-4deg);
  text-shadow:2px 3px 0 rgba(0,0,0,.5), 0 0 22px rgba(255,255,255,.06);
  position:relative; display:inline-block; left:50%; translate:-50% 0;
}
.section-title--brush::after{
  content:""; display:block; width:62%; height:4px; margin:8px auto 0;
  background:linear-gradient(90deg,transparent,var(--pink),transparent);
  border-radius:2px;
}

/* =====================================================================
   PACKAGES
   ===================================================================== */
.packages{
  max-width:var(--maxw); margin:0 auto; padding:56px 24px 48px;
}
.package-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:38px;
}
.pkg-card{
  position:relative;
  background:linear-gradient(180deg,#181818,#101010);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:visible;
  display:flex; flex-direction:column;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.pkg-card:hover{transform:translateY(-6px); border-color:var(--pink); box-shadow:0 14px 36px rgba(255,45,122,.18);}
.pkg-card--popular{border-color:var(--pink); box-shadow:0 0 0 1px var(--pink), 0 12px 30px rgba(255,45,122,.22);}
.pkg-flag{
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--pink); color:#fff; font-family:var(--font-cond);
  letter-spacing:.12em; font-size:.85rem; padding:4px 16px; border-radius:4px;
  box-shadow:0 4px 14px rgba(255,45,122,.5); text-transform:uppercase;
}
.pkg-head{
  display:flex; gap:12px; align-items:center; padding:18px 18px 14px;
  border-bottom:1px solid #242424;
}
.pkg-ico{width:34px; height:34px; flex:none; fill:none; stroke:var(--pink); stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;}
.pkg-name{font-family:var(--font-brush); text-transform:uppercase; font-size:1.4rem; margin:0; letter-spacing:.01em; transform:skewX(-4deg); line-height:1;}
.pkg-people{font-family:var(--font-cond); letter-spacing:.08em; color:var(--pink); font-size:.95rem;}
.pkg-body{padding:16px 18px 18px; display:flex; flex-direction:column; flex:1;}
.pkg-meta{display:flex; justify-content:space-between; align-items:center; margin-bottom:12px;}
.pkg-time{font-family:var(--font-cond); letter-spacing:.06em; font-size:1.25rem; color:#fff;}
.pkg-price{font-family:var(--font-display); color:var(--pink); font-size:2rem; line-height:1; text-shadow:0 0 14px rgba(255,45,122,.4);}
.pkg-list{margin-bottom:16px; flex:1;}
.pkg-list li{position:relative; padding-left:16px; font-size:.86rem; color:var(--silver); margin-bottom:6px;}
.pkg-list li::before{content:""; position:absolute; left:0; top:.55em; width:6px; height:6px; background:var(--pink); border-radius:50%;}

/* =====================================================================
   GIFT BANNER
   ===================================================================== */
.gift-banner{
  background:linear-gradient(90deg, rgba(255,45,122,.16), rgba(255,45,122,.05));
  border-top:2px solid var(--pink); border-bottom:2px solid var(--pink);
}
.gift-banner-inner{
  max-width:var(--maxw); margin:0 auto; padding:20px 24px;
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
}
.gift-ico{width:34px; height:34px; flex:none; fill:none; stroke:var(--pink); stroke-width:1.7; stroke-linejoin:round;}
.gift-title{font-family:var(--font-brush); color:var(--pink); font-size:1.7rem; margin:0; text-shadow:0 0 14px rgba(255,45,122,.4);}
.gift-sub{margin:0; color:#eee; font-size:1rem; flex:1; min-width:200px;}

/* =====================================================================
   HOW IT WORKS + BOOKING CTA  (side-by-side band, room image bleeds right)
   ===================================================================== */
.works-cta{
  position:relative;
  background:#0c0c0c;
  /* corridor room photo bleeds across the right third */
  background-image:linear-gradient(90deg, #0c0c0c 0%, #0c0c0c 55%, rgba(12,12,12,.78) 68%, rgba(12,12,12,.45) 86%, rgba(12,12,12,.55) 100%), url('assets/room-corridor.png');
  background-repeat:no-repeat;
  background-position:left, right center;
  background-size:auto, 46% 100%;
  border-bottom:1px solid #1a1a1a;
  overflow:hidden;
}
.works-cta-brush{
  position:absolute; right:30px; top:50%; transform:translateY(-50%);
  z-index:3; text-align:right; pointer-events:none;
}
.wcb-eyebrow{display:block; font-family:var(--font-brush); color:var(--pink); font-size:1rem; transform:rotate(-3deg); text-shadow:0 0 10px rgba(255,45,122,.5);}
.wcb-rage{display:block; font-family:var(--font-display); color:#fff; font-size:clamp(2rem,3.4vw,3rem); text-transform:uppercase; line-height:.85; text-shadow:2px 3px 0 rgba(0,0,0,.7); transform:skewX(-5deg); margin:2px 0;}
.wcb-lines{display:block; margin-top:10px; font-family:var(--font-cond); letter-spacing:.05em; color:#e6e6e6; font-size:.95rem; line-height:1.35;}
.works-cta-inner{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.1fr .75fr;
  align-items:center;
  padding:40px 220px 46px 24px;
  gap:20px;
}
.works{text-align:left;}
.works-title{margin-bottom:26px;}
.steps{display:flex; align-items:flex-start; justify-content:flex-start; gap:6px; flex-wrap:nowrap;}
.step{flex:1; min-width:0; max-width:160px; padding:0 4px; text-align:left;}
.step-ico{width:42px; height:42px; margin:0 0 10px; fill:none; stroke:var(--pink); stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round;}
.step h4{font-family:var(--font-brush); color:var(--pink); font-size:1.05rem; margin:0 0 6px; transform:skewX(-3deg);}
.step p{margin:0; color:var(--silver); font-size:.8rem; line-height:1.35;}
.step-sep{align-self:flex-start; color:#444; font-size:1.7rem; line-height:1; margin-top:8px;}

.book-cta{position:relative; z-index:2;}
.book-cta-text{text-align:center; display:flex; flex-direction:column; align-items:center; gap:12px; padding:0 8px;}
.cta-heading{font-family:var(--font-brush); color:var(--pink); font-size:clamp(1.8rem,3vw,2.5rem); margin:0; text-shadow:0 0 18px rgba(255,45,122,.45); transform:skewX(-3deg);}
.cta-text{margin:0; color:#eee; font-size:1.05rem;}
.cta-urgency{margin:2px 0 0; color:var(--silver); font-size:.9rem;}

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{background:#080808; border-top:2px solid var(--pink); padding-top:36px;}
.footer-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 24px 28px;
  display:grid; grid-template-columns:1.3fr 1.3fr 1fr 1.2fr; gap:30px; align-items:start;
}
.foot-logo-row{display:flex; align-items:center; gap:12px; margin-bottom:8px;}
.rr-circle{
  width:46px; height:46px; border-radius:50%; border:2px solid var(--pink);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-brush); color:var(--pink); font-size:1.1rem;
  box-shadow:0 0 16px rgba(255,45,122,.4);
}
.foot-name{font-family:var(--font-cond); letter-spacing:.06em; color:var(--pink); font-size:1.25rem;}
.foot-brand p{margin:3px 0; color:var(--silver); font-size:.85rem;}
.foot-contact p{display:flex; align-items:center; gap:9px; margin:0 0 10px; color:#ddd; font-size:.88rem;}
.foot-contact a:hover{color:var(--pink);}
.fi{width:18px; height:18px; flex:none; fill:none; stroke:var(--pink); stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;}
.follow{display:block; font-family:var(--font-brush); color:var(--pink); font-size:1.3rem; margin-bottom:12px;}
.social-row{display:flex; gap:12px;}
.social{width:40px; height:40px; border-radius:50%; border:1.5px solid #fff; display:flex; align-items:center; justify-content:center; transition:.2s;}
.social svg{width:20px; height:20px; fill:#fff;}
.social:hover{background:var(--pink); border-color:var(--pink);}
.foot-brush{text-align:right; font-family:var(--font-brush); color:#fff; font-size:1.3rem; line-height:1.2; transform:rotate(-2deg);}
.foot-brush span{display:block;}
.foot-brush span:nth-child(2){color:var(--pink);}
.footer-bottom{
  border-top:1px solid #1a1a1a; padding:16px 24px;
  max-width:var(--maxw); margin:0 auto;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px;
  color:#777; font-size:.8rem;
}
.foot-links a:hover{color:var(--pink);}
.foot-links .divider{margin:0 6px; color:#444;}

/* =====================================================================
   MODALS
   ===================================================================== */
.modal{position:fixed; inset:0; z-index:1000; display:none;}
.modal.open{display:block;}
.modal-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.78); backdrop-filter:blur(3px);}
.modal-card{
  position:relative; z-index:2;
  max-width:620px; margin:5vh auto; max-height:90vh; overflow-y:auto;
  background:linear-gradient(180deg,#171717,#0e0e0e);
  border:1px solid var(--pink);
  border-radius:12px; padding:34px 32px 30px;
  box-shadow:0 20px 60px rgba(0,0,0,.7), 0 0 40px rgba(255,45,122,.15);
  animation:pop .25s ease;
}
@keyframes pop{from{transform:translateY(20px) scale(.97); opacity:0;} to{transform:none; opacity:1;}}
.modal-close{position:absolute; top:14px; right:18px; background:none; border:none; color:#fff; font-size:2rem; line-height:1; cursor:pointer; transition:.2s;}
.modal-close:hover{color:var(--pink); transform:rotate(90deg);}
.modal-title{font-family:var(--font-display); text-transform:uppercase; text-align:center; font-size:2rem; margin:0 0 22px; letter-spacing:.02em;}
.modal-title .pink{color:var(--pink);}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.field{display:flex; flex-direction:column; gap:6px;}
.field--full{grid-column:1 / -1;}
.field span{font-family:var(--font-cond); letter-spacing:.06em; font-size:1rem; color:var(--pink);}
.field input,.field select,.field textarea{
  background:#0c0c0c; border:1px solid #333; border-radius:6px;
  color:#fff; padding:11px 12px; font-family:var(--font-body); font-size:.92rem;
  transition:border-color .18s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--pink); box-shadow:0 0 0 2px rgba(255,45,122,.25);}
.field textarea{resize:vertical;}
.booking-summary{
  margin:20px 0; padding:14px 16px; border:1px dashed var(--pink);
  border-radius:8px; background:rgba(255,45,122,.06);
}
.bs-label{font-family:var(--font-cond); letter-spacing:.08em; color:var(--silver); font-size:.9rem;}
.bs-row{display:flex; justify-content:space-between; align-items:center; margin-top:6px;}
.bs-row span:first-child{font-family:var(--font-cond); font-size:1.2rem;}
.bs-price{font-family:var(--font-display); color:var(--pink); font-size:1.7rem;}
.modal-success{text-align:center; padding:14px 4px;}
.success-mark{
  width:70px; height:70px; margin:0 auto 18px; border-radius:50%;
  background:var(--pink); color:#fff; font-size:2.4rem;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 30px rgba(255,45,122,.5);
}
.modal-success h3{font-family:var(--font-display); text-transform:uppercase; font-size:1.6rem; margin:0 0 10px;}
.modal-success p{color:var(--silver); margin:0 0 22px;}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media(max-width:1080px){
  .features-inner{grid-template-columns:1fr 1fr;}
  .feature:nth-child(3)::before{display:none;}
  .package-grid{grid-template-columns:1fr 1fr;}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .foot-brush{text-align:left;}
}
@media(max-width:860px){
  .main-nav{
    position:fixed; top:var(--header-h); left:0; right:0;
    flex-direction:column; gap:0; background:#0c0c0c;
    border-bottom:2px solid var(--pink);
    transform:translateY(-120%); transition:transform .3s ease;
    padding:10px 0; z-index:150;
  }
  .main-nav.open{transform:translateY(0);}
  .main-nav a{padding:14px 24px; font-size:1.4rem;}
  .main-nav a::after{display:none;}
  .nav-toggle{display:flex;}
  .btn-nav{display:none;}

  /* hero: stack — image becomes a banner on top, text below on solid dark */
  .hero-grid{min-height:auto;}
  .hero-left{position:relative; max-width:100%; padding:280px 24px 40px; text-align:center;}
  .hero-right{width:100%; height:260px; bottom:auto;}
  .hero-right::after{background:linear-gradient(0deg, #0d0d0d 0%, rgba(13,13,13,.2) 40%, transparent 70%);}
  .hero-eyebrow{margin-left:0;}
  .hero-cta-row{justify-content:center;}
  .word-rage{white-space:normal;}

  /* works + cta stack */
  .works-cta{background-image:none; background:#0c0c0c;}
  .works-cta-inner{grid-template-columns:1fr; padding:36px 24px 40px;}
  .works{text-align:center;}
  .steps{flex-direction:column; align-items:center;}
  .step{max-width:320px; text-align:center;}
  .step-ico{margin:0 auto 10px;}
  .step-sep{transform:rotate(90deg); margin:2px auto; align-self:center;}
  .works-cta-brush{display:none;}
}
@media(max-width:560px){
  .features-inner{grid-template-columns:1fr;}
  .feature::before{display:none !important;}
  .package-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr; text-align:left;}
  .form-grid{grid-template-columns:1fr;}
  .gift-banner-inner{flex-direction:column; text-align:center; align-items:center;}
  .footer-bottom{flex-direction:column; text-align:center;}
  .modal-card{margin:0; min-height:100vh; border-radius:0; max-height:100vh;}
  .word-first,.word-rage{transform:skewX(-3deg);}
}
