/* ================================================================
   BLACK BLOOD v2 — main.css
   Navigation · Hero · All components · Footer
================================================================ */

/* ── ANNOUNCE ── */
.bb-announce{background:var(--red-dark);padding:11px 0;border-bottom:1px solid rgba(255,255,255,0.08);position:relative;z-index:200}
.bb-announce .bb-wrap{display:flex;align-items:center;justify-content:center;gap:12px}
.bb-announce p{font-size:0.8rem;margin:0;color:rgba(255,255,255,0.85);text-align:center}
.bb-announce p a{color:#fff;font-weight:700;text-decoration:underline}
.bb-announce__close{color:rgba(255,255,255,0.4);font-size:0.8rem;padding:4px;margin-left:8px;transition:color var(--t)}
.bb-announce__close:hover{color:#fff}

/* ── NAV ── */
.bb-nav{position:sticky;top:0;z-index:100;background:rgba(6,6,6,0.94);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background var(--t)}
.bb-nav.solid{background:var(--black)}
.bb-nav__inner{display:flex;align-items:center;justify-content:space-between;height:66px}
.bb-nav__logo{display:flex;align-items:center;gap:11px;flex-shrink:0;text-decoration:none}
.bb-nav__logo-icon{transition:transform var(--t)}
.bb-nav__logo:hover .bb-nav__logo-icon{transform:scale(1.06)}
.bb-nav__logo-name{font-family:var(--display);font-size:1.35rem;color:#fff;letter-spacing:0.04em;line-height:1}
.bb-nav__logo-tag{font-size:0.55rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold-light);margin-top:3px;display:block}
.bb-nav__menu{display:flex;align-items:center;gap:6px}
.bb-nav__links{display:flex;align-items:center;gap:2px;margin-right:12px}
.bb-nav__links li a{display:block;padding:7px 12px;font-size:0.82rem;font-weight:500;color:rgba(255,255,255,0.65);border-radius:4px;transition:color var(--t),background var(--t)}
.bb-nav__links li a:hover,.bb-nav__links li.current-menu-item a{color:#fff;background:rgba(255,255,255,0.05)}
.bb-nav__cta{padding:9px 20px!important;font-size:0.8rem!important}
.bb-nav__cta+.bb-nav__cta{margin-left:4px}
.bb-nav__toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.bb-nav__toggle span{display:block;width:23px;height:2px;background:#fff;border-radius:2px;transition:all var(--t)}
.bb-nav__toggle.on span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.bb-nav__toggle.on span:nth-child(2){opacity:0}
.bb-nav__toggle.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── HERO ── */
.bb-hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:110px 0 80px;overflow:hidden}
.bb-hero__vid-wrap{position:absolute;inset:0;z-index:0}
.bb-hero__video{position:absolute;top:50%;left:50%;width:100%;height:100%;min-width:100%;min-height:100%;transform:translate(-50%,-50%);object-fit:cover;object-position:center;z-index:0;pointer-events:none}
.bb-hero__cinematic{position:absolute;inset:0;background:linear-gradient(160deg,#060606 0%,#1E0000 25%,#3E1F0D 55%,#0A0000 80%,#060606 100%)}
.bb-hero__cin-1{position:absolute;inset:0;background:radial-gradient(ellipse 90% 80% at 80% 35%,rgba(140,0,0,0.7),transparent 60%);animation:cpulse 9s ease-in-out infinite alternate}
.bb-hero__cin-2{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 15% 75%,rgba(62,31,13,0.55),transparent 55%);animation:cpulse 13s ease-in-out infinite alternate-reverse}
@keyframes cpulse{0%{opacity:.7;transform:scale(1)}100%{opacity:1;transform:scale(1.06)}}
.bb-hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,6,6,0.90) 0%,rgba(6,6,6,0.72) 40%,rgba(92,0,0,0.2) 70%,rgba(6,6,6,0.65) 100%);z-index:2}
.bb-hero__grid{position:absolute;inset:0;z-index:1;background-image:linear-gradient(rgba(255,255,255,0.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.022) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 30%,transparent 100%)}
.bb-hero__content{position:relative;z-index:3}
.bb-hero__inner{max-width:820px}
.bb-hero__kicker{display:inline-flex;align-items:center;gap:10px;background:rgba(184,0,0,0.12);border:1px solid rgba(184,0,0,0.3);border-radius:100px;padding:6px 16px 6px 8px;margin-bottom:28px}
.bb-hero__kicker-dot{width:8px;height:8px;border-radius:50%;background:var(--red-light);flex-shrink:0;animation:bb-p 2s infinite}
.bb-hero__kicker-text{font-size:0.7rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.8)}
.bb-hero__title{color:#fff;margin-bottom:0;line-height:0.92}
.bb-hero__title em{font-style:italic;color:var(--red-light);font-family:var(--serif);text-transform:none;letter-spacing:-0.02em;font-size:0.95em;display:block}
.bb-hero__sub{font-size:clamp(1rem,1.5vw,1.15rem);color:var(--grey-l);max-width:580px;margin:24px 0 40px;line-height:1.8}
.bb-hero__ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:64px}
.bb-hero__stats{display:flex;gap:40px;flex-wrap:wrap;padding-top:40px;border-top:1px solid rgba(255,255,255,0.1)}
.bb-stat strong{display:block;font-family:var(--display);font-size:clamp(2rem,4vw,2.8rem);color:var(--red-light);line-height:1}
.bb-stat span{font-size:0.7rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:6px;display:block}
.bb-hero__scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px}
.bb-hero__scroll span{font-size:0.6rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.25)}
.bb-hero__scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,0.25),transparent);animation:sline 2.5s ease-in-out infinite}
@keyframes sline{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:.8;transform:scaleY(1.1)}}

/* ── TICKER ── */
.bb-ticker{background:var(--red-dark);padding:13px 0;overflow:hidden;border-top:1px solid rgba(255,255,255,0.06);border-bottom:1px solid rgba(255,255,255,0.06)}
.bb-ticker__track{display:flex;gap:48px;width:max-content;animation:tick 50s linear infinite;font-size:0.72rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.7)}
.bb-ticker__dot{color:rgba(255,255,255,0.3)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── BLOCKQUOTE ── */
.bb-blockquote{background:rgba(0,0,0,0.3);border-left:4px solid var(--red);border-radius:0 var(--r12) var(--r12) 0;padding:36px 32px 28px;position:relative;overflow:hidden}
.bb-blockquote::before{content:'\201C';font-family:var(--serif);font-size:8rem;line-height:0.8;color:var(--red);opacity:0.18;position:absolute;top:16px;left:20px}
.bb-blockquote p{font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.3rem);font-weight:600;color:#fff;line-height:1.65;margin:0 0 18px;position:relative}
.bb-blockquote footer{font-size:0.8rem;color:rgba(255,255,255,0.4);font-style:italic}

/* ── IMPACT NUMBERS ── */
.bb-impact-num{text-align:center;padding:32px 20px}
.bb-impact-num .num{font-family:var(--display);font-size:clamp(3rem,6vw,5.5rem);color:var(--red-light);line-height:1;display:block}
.bb-impact-num .label{font-size:0.74rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-top:8px;display:block;max-width:180px;margin-left:auto;margin-right:auto;line-height:1.5}

/* ── BARRIER CARD ── */
.bb-barrier{display:flex;gap:14px;align-items:flex-start;background:var(--card);border:1px solid var(--border);border-radius:var(--r12);padding:20px;transition:border-color var(--t)}
.bb-barrier:hover{border-color:var(--border-red)}
.bb-barrier__ico{width:38px;height:38px;background:var(--red-glow);border:1px solid var(--border-red);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.bb-barrier__ico svg{width:17px;height:17px;color:var(--red-light)}
.bb-barrier h4{font-size:0.9rem;font-weight:700;margin-bottom:4px}
.bb-barrier p{font-size:0.83rem;color:var(--grey);margin:0}

/* ── PARTNER STRIP ── */
.bb-partner-strip{padding:52px 0;background:var(--black);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.bb-partner-strip__label{font-size:0.68rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--grey);text-align:center;margin-bottom:24px}
.bb-partner-badges{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:24px}
.bb-pbadge{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:11px 22px;font-size:0.8rem;font-weight:600;color:rgba(255,255,255,0.45);transition:all var(--t)}
.bb-pbadge:hover{border-color:var(--border-red);color:#fff}

/* ── 3-COL ACTION STRIP ── */
.bb-action-strip .bb-card{text-align:center;padding:36px 28px}
.bb-action-strip .bb-ico{margin:0 auto 18px}

/* ── PLEDGE ── */
.bb-pledge{text-align:center;background:radial-gradient(ellipse 60% 60% at 50% 0%,rgba(92,0,0,0.28),transparent),var(--black)}
.bb-pledge__inner{max-width:680px;margin:0 auto}
.bb-pledge h2{margin-bottom:18px}
.bb-pledge p{color:var(--grey-l);max-width:520px;margin:0 auto 40px}
.bb-pledge__ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* ── NEWSLETTER STRIP ── */
.bb-nl-strip{background:var(--card);border-top:1px solid var(--border);padding:48px 0}
.bb-nl-strip__inner{display:flex;align-items:center;gap:40px;flex-wrap:wrap}
.bb-nl-strip__text{flex:1;min-width:200px}
.bb-nl-strip__text h3{font-family:var(--display);font-size:1.8rem;margin-bottom:4px;text-transform:uppercase;letter-spacing:0.02em}
.bb-nl-strip__text p{color:var(--grey);margin:0;font-size:0.9rem}
.bb-nl-strip__form{display:flex;gap:8px;flex-wrap:wrap;flex:2;min-width:300px}
.bb-nl-strip__form input{flex:1;min-width:150px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:6px;padding:12px 15px;color:#fff;font-size:0.9rem;outline:none;transition:border-color var(--t)}
.bb-nl-strip__form input:focus{border-color:var(--red-light)}
.bb-nl-strip__form input::placeholder{color:rgba(255,255,255,0.22)}
.bb-nl-name{max-width:160px}
.bb-nl-success{font-size:0.95rem;color:#F0C0A0;font-weight:600;display:flex;align-items:center;gap:10px}

/* ── FOOTER ── */
.bb-footer{background:var(--brown);border-top:1px solid rgba(255,255,255,0.07);padding:64px 0 32px}
.bb-footer__top{display:grid;grid-template-columns:300px 1fr;gap:64px;margin-bottom:48px}
.bb-footer__logo{display:flex;align-items:center;gap:11px;margin-bottom:14px;text-decoration:none}
.bb-footer__logo-name{font-family:var(--display);font-size:1.2rem;color:#fff;letter-spacing:0.04em;line-height:1;display:block}
.bb-footer__logo-tag{font-size:0.56rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold-light);margin-top:3px;display:block}
.bb-footer__tagline{font-size:0.86rem;color:rgba(255,255,255,0.4);line-height:1.7;margin-bottom:18px}
.bb-footer__social{display:flex;gap:10px}
.bb-footer__social a{width:34px;height:34px;border-radius:7px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.45);transition:all var(--t)}
.bb-footer__social a:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-2px)}
.bb-footer__social svg{width:16px;height:16px}
.bb-footer__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.bb-footer__nav-col h4{font-size:0.66rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:14px}
.bb-footer__nav-col ul{display:flex;flex-direction:column;gap:8px}
.bb-footer__nav-col a{font-size:0.86rem;color:rgba(255,255,255,0.45);transition:color var(--t)}
.bb-footer__nav-col a:hover{color:#fff}
.bb-footer__bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 20px;padding-top:24px;font-size:0.78rem;color:rgba(255,255,255,0.22)}
.bb-footer__bottom strong{color:rgba(255,255,255,0.45)}
.bb-footer__bottom a{color:var(--red-light)}

/* ── ENQUIRE PAGE ── */
.bb-enq-grid{display:grid;grid-template-columns:1fr 400px;gap:40px;align-items:start}
.bb-enq-who h4{font-size:0.68rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold-light);margin-bottom:18px}
.bb-enq-who-list{display:flex;flex-direction:column;gap:14px}
.bb-enq-who-item{display:flex;gap:12px;align-items:flex-start}
.bb-enq-who-item__ico{width:36px;height:36px;background:var(--red-glow);border:1px solid var(--border-red);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.bb-enq-who-item__ico svg{width:16px;height:16px;color:var(--red-light)}
.bb-enq-who-item strong{display:block;font-size:0.88rem;margin-bottom:2px}
.bb-enq-who-item p{font-size:0.82rem;color:var(--grey);margin:0}
.bb-enq-contact a{display:flex;align-items:center;gap:8px;font-size:0.87rem;color:var(--red-light);margin-bottom:10px}
.bb-enq-contact svg{width:14px;height:14px}

@media(max-width:960px){.bb-enq-grid{grid-template-columns:1fr}}

/* ── BOOKING PAGE ── */
.bb-book-grid{display:grid;grid-template-columns:1fr 360px;gap:36px;align-items:start}
@media(max-width:960px){.bb-book-grid{grid-template-columns:1fr}.bb-sidebar{position:static}}

/* ── MOBILE NAV ── */
@media(max-width:768px){
  .bb-nav__menu{display:none;flex-direction:column}
  .bb-nav__menu.open{display:flex;position:fixed;inset:0;top:66px;background:rgba(6,6,6,0.98);backdrop-filter:blur(20px);padding:28px 24px;z-index:99}
  .bb-nav__links{flex-direction:column;width:100%;margin:0 0 20px;gap:0}
  .bb-nav__links li a{font-size:1.05rem;padding:13px 0;border-bottom:1px solid var(--border)}
  .bb-nav__cta{width:100%;justify-content:center}
  .bb-nav__toggle{display:flex}
  .bb-hero__title{font-size:clamp(3rem,10vw,5rem)}
  .bb-hero__ctas{flex-direction:column}
  .bb-hero__stats{gap:22px}
  .bb-row2{grid-template-columns:1fr}
  .bb-nl-strip__inner{flex-direction:column}
  .bb-nl-name{max-width:100%}
  .bb-footer__top{grid-template-columns:1fr;gap:36px}
  .bb-footer__nav{grid-template-columns:1fr 1fr}
  .bb-footer__bottom{flex-direction:column;align-items:flex-start;gap:5px}
}
@media(max-width:480px){
  .bb-footer__nav{grid-template-columns:1fr}
  .bb-pledge__ctas{flex-direction:column;align-items:center}
  .bb-event__cal{min-width:60px;padding:14px 10px}
}

/* ── OPT CHIPS ── */
.bb-opt-chip{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:100px;padding:7px 18px;font-size:0.83rem;color:rgba(255,255,255,0.55);cursor:pointer;transition:all .18s;font-family:var(--body)}
.bb-opt-chip:hover,.bb-opt-chip.selected{background:var(--red-glow);border-color:var(--red-light);color:#fff}

/* ── PARTNER / ACTION strip responsive ── */
@media(max-width:840px){.g3.bb-action-strip{grid-template-columns:1fr}}

/* ── BOOK DONATION specific ── */
.bb-book-grid{display:grid;grid-template-columns:1fr 360px;gap:36px;align-items:start}
@media(max-width:960px){.bb-book-grid{grid-template-columns:1fr}}

/* ================================================================
   HERO — CINEMATIC CSS BACKGROUND v2
   Stunning visual that works on every device, zero loading time
================================================================ */

/* Video (if custom URL set in BB Settings) */
.bb-hero__video {
  position: absolute;
  top: 50%; left: 50%;
  width: 100%; height: 100%;
  min-width: 100%; min-height: 100%;
  transform: translate(-50%, -50%);
  object-fit: cover;
  object-position: center;
  z-index: 0;
  pointer-events: none;
}

/* Cinematic background layers */
.bb-hero__cinematic {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.bb-hero__cin-1 {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 120% 80% at 75% 30%, rgba(140,0,0,0.75) 0%, transparent 55%),
    radial-gradient(ellipse 80% 100% at 100% 60%, rgba(92,0,0,0.5) 0%, transparent 50%),
    #060606;
  animation: cin1 10s ease-in-out infinite alternate;
}
.bb-hero__cin-2 {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 10% 80%, rgba(62,31,13,0.6) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 30% 20%, rgba(80,0,0,0.3) 0%, transparent 50%);
  animation: cin2 14s ease-in-out infinite alternate-reverse;
}
.bb-hero__cin-3 {
  position: absolute; inset: 0;
  background:
    linear-gradient(160deg, rgba(6,6,6,0.4) 0%, transparent 40%, rgba(6,6,6,0.6) 100%);
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 2px,
      rgba(0,0,0,0.03) 2px,
      rgba(0,0,0,0.03) 4px
    );
}
@keyframes cin1 {
  0%   { opacity: 0.85; transform: scale(1); }
  100% { opacity: 1;    transform: scale(1.06); }
}
@keyframes cin2 {
  0%   { opacity: 0.6; transform: scale(1) translate(0,0); }
  100% { opacity: 0.9; transform: scale(1.04) translate(-1%,1%); }
}

/* Scan lines texture */
.bb-hero__scanlines {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0px,
    transparent 3px,
    rgba(0,0,0,0.04) 3px,
    rgba(0,0,0,0.04) 4px
  );
  opacity: 0.6;
}

/* Grid overlay */
.bb-hero__grid {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 20%, transparent 100%);
}

/* Animated blood drop particles */
.bb-hero__particles {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
}
.bb-hero__drop {
  position: absolute;
  opacity: 0;
  filter: blur(0.3px);
}
.bb-hero__drop svg { fill: var(--red); }

.bb-hero__drop--1 { width: 52px; right: 22%; top: 8%;  animation: drop-fall 8s  ease-in-out 0s   infinite; }
.bb-hero__drop--2 { width: 34px; right: 14%; top: 15%; animation: drop-fall 11s ease-in-out 2s   infinite; }
.bb-hero__drop--3 { width: 24px; right: 30%; top: 5%;  animation: drop-fall 7s  ease-in-out 4s   infinite; }
.bb-hero__drop--4 { width: 44px; right: 8%;  top: 22%; animation: drop-fall 13s ease-in-out 1.5s infinite; }
.bb-hero__drop--5 { width: 18px; right: 38%; top: 10%; animation: drop-fall 9s  ease-in-out 3s   infinite; }

@keyframes drop-fall {
  0%   { opacity: 0;    transform: translateY(-40px) scale(0.7) rotate(-5deg); }
  10%  { opacity: 0.8; }
  60%  { opacity: 0.5;  transform: translateY(80px)  scale(1)   rotate(5deg); }
  100% { opacity: 0;    transform: translateY(180px) scale(0.6) rotate(-3deg); }
}

/* Overlay sits above everything */
.bb-hero__overlay {
  position: absolute; inset: 0; z-index: 3;
  background: linear-gradient(
    135deg,
    rgba(6,6,6,0.88) 0%,
    rgba(6,6,6,0.65) 40%,
    rgba(80,0,0,0.15) 65%,
    rgba(6,6,6,0.70) 100%
  );
}

/* Content and scroll above overlay */
.bb-hero__content { position: relative; z-index: 4; }
.bb-hero__scroll  { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); z-index: 4; display: flex; flex-direction: column; align-items: center; gap: 8px; }
