/*
Theme Name:  Iron Swans
Theme URI:   http://ironswanbuhurt.com
Author:      Iron Swans
Author URI:  http://ironswanbuhurt.com
Description: Custom heraldic theme for the ACW Iron Swans — Alabama's first buhurt team.
Version:     4.0
License:     GNU General Public License v2 or later
Text Domain: iron-swans
*/

/* ================================================================
   VARIABLES & RESET
   ================================================================ */
:root{
  --black:#0c0a09; --black2:#141010; --panel:#1b1614; --panel2:#221b18;
  --crimson:#7d2020; --crimson-bright:#9c2b22;
  --gold1:#b8923f; --gold2:#e7cd83; --gold3:#8a6a2b;
  --bone:#ece4d4; --bone-dim:#c7bca6; --steel:#7d838b;
  --line:rgba(201,164,76,0.22);
  --gold-grad:linear-gradient(135deg,#8a6a2b 0%,#e7cd83 38%,#b8923f 60%,#f3e2a8 80%,#9a7730 100%);
  --max:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--bone);font-family:'Spectral',Georgia,serif;line-height:1.7;overflow-x:hidden;min-height:100vh}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(120% 80% at 50% -10%, rgba(124,32,32,0.18), transparent 60%),
             radial-gradient(100% 120% at 50% 120%, rgba(0,0,0,0.6), transparent 50%);}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:2;opacity:0.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.wrap{max-width:var(--max);margin:0 auto;padding:0 26px;position:relative;z-index:3}
img{max-width:100%;height:auto}

/* ================================================================
   TYPOGRAPHY
   ================================================================ */
h1,h2,h3,.cz{font-family:'Cinzel',serif;font-weight:600;letter-spacing:.5px}
.display{font-family:'Cinzel Decorative',serif;font-weight:900}
.gold{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.eyebrow{font-family:'Cinzel',serif;font-size:.74rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold1);font-weight:600}
a{color:inherit;text-decoration:none}

/* ================================================================
   BUTTONS
   ================================================================ */
.btn{font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:11px 20px;border-radius:2px;cursor:pointer;border:1px solid var(--gold3);
  transition:all .25s;display:inline-block;background:transparent;color:var(--gold2)}
.btn:hover{background:rgba(201,164,76,0.12);border-color:var(--gold1)}
.btn-solid{background:var(--gold-grad);color:#1a1206;border:none;font-weight:700}
.btn-solid:hover{filter:brightness(1.08)}
.btn-ghost{border-color:rgba(201,164,76,0.3);color:var(--bone-dim)}

/* ================================================================
   NAVIGATION
   ================================================================ */
header{position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .35s,border-color .35s,padding .35s;
  border-bottom:1px solid transparent;padding:18px 0}
header.scrolled{background:rgba(10,8,7,0.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:11px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand svg{width:38px;height:44px;flex:none}
.brand .bn{font-family:'Cinzel',serif;font-weight:700;font-size:1.04rem;letter-spacing:.16em;line-height:1;text-transform:uppercase}
.brand .bn small{display:block;font-size:.56rem;letter-spacing:.34em;color:var(--gold1);margin-top:4px;font-weight:600}
.navlinks{display:flex;gap:26px;align-items:center}
.navlinks a{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--bone-dim);transition:color .2s;position:relative}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;
  background:var(--gold-grad);transition:width .25s}
.navlinks a:hover,.navlinks a.current-menu-item{color:var(--bone)}
.navlinks a:hover::after,.navlinks a.current-menu-item::after{width:100%}
.nav-cta{display:flex;gap:12px;align-items:center}
.hamb{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.hamb span{width:26px;height:2px;background:var(--gold2);transition:.3s}
.mobmenu{position:fixed;inset:0;z-index:49;background:rgba(8,6,5,0.97);backdrop-filter:blur(8px);
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobmenu.open{display:flex}
.mobmenu a{font-family:'Cinzel',serif;font-size:1.2rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone)}

/* ================================================================
   HERO — home page
   ================================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px 0 60px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:radial-gradient(80% 60% at 50% 38%, rgba(124,32,32,0.28), transparent 60%),
             linear-gradient(180deg,#0c0a09 0%,#160f0d 55%,#0c0a09 100%)}
.hero-bg::before{content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-conic-gradient(from 0deg at 50% 40%, rgba(201,164,76,0.04) 0deg 6deg, transparent 6deg 12deg);
  -webkit-mask:radial-gradient(60% 50% at 50% 40%, #000, transparent 72%);
          mask:radial-gradient(60% 50% at 50% 40%, #000, transparent 72%)}
.hero-inner{position:relative;z-index:3;text-align:center;width:100%}
.crest-hero{width:150px;height:174px;margin:0 auto 26px;filter:drop-shadow(0 10px 30px rgba(0,0,0,.6));animation:rise .9s ease both}
.hero h1{font-size:clamp(2.6rem,7vw,5.4rem);line-height:.96;margin-bottom:8px;text-transform:uppercase;letter-spacing:.02em}
.hero .sub{font-family:'Cinzel',serif;font-size:clamp(.8rem,1.8vw,1.05rem);letter-spacing:.34em;
  text-transform:uppercase;color:var(--bone-dim);margin-bottom:26px}
.hero .lead{max-width:640px;margin:0 auto 34px;font-size:1.12rem;color:var(--bone-dim);font-weight:300}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  color:var(--gold1);font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:.3em;
  text-transform:uppercase;opacity:.7;animation:bob 2s infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ================================================================
   PAGE HERO — interior pages
   ================================================================ */
.page-hero{position:relative;padding:160px 0 64px;text-align:center;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero-bg{position:absolute;inset:0;
  background:radial-gradient(80% 90% at 50% 0%, rgba(124,32,32,0.3), transparent 65%),
             linear-gradient(180deg,#0c0a09,#160f0d)}
.page-hero .crest-sm{width:74px;height:86px;margin:0 auto 18px;display:block;position:relative;z-index:3}
.page-hero h1{position:relative;z-index:3;font-size:clamp(2.2rem,6vw,4rem);text-transform:uppercase;line-height:1}
.page-hero p{position:relative;z-index:3;color:var(--bone-dim);max-width:600px;margin:16px auto 0;font-weight:300;font-size:1.08rem}

/* ================================================================
   HERALD BAR
   ================================================================ */
.herald{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.herald div{padding:28px 16px;text-align:center;border-right:1px solid var(--line)}
.herald div:last-child{border-right:none}
.herald .num{font-family:'Cinzel Decorative',serif;font-size:2rem;font-weight:900}
.herald .lbl{font-family:'Cinzel',serif;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bone-dim);margin-top:6px}

/* ================================================================
   SECTIONS
   ================================================================ */
section{position:relative;z-index:3}
.sec{padding:96px 0}
.sec-alt{background:linear-gradient(180deg,var(--black),var(--black2));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 56px}
.sec-head h2{font-size:clamp(1.9rem,4vw,3rem);text-transform:uppercase;margin:14px 0 16px;line-height:1.05}
.sec-head p{color:var(--bone-dim);font-size:1.06rem;font-weight:300}
.rule{display:flex;align-items:center;justify-content:center;gap:14px;margin:8px 0}
.rule::before,.rule::after{content:"";height:1px;width:54px;background:linear-gradient(90deg,transparent,var(--gold1))}
.rule::after{background:linear-gradient(90deg,var(--gold1),transparent)}
.rule span{color:var(--gold1)}

/* ================================================================
   CARDS — discipline / feature cards
   ================================================================ */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{border:1px solid var(--line);background:linear-gradient(165deg,var(--panel),var(--black2));
  padding:30px 26px;border-radius:3px;transition:transform .3s,border-color .3s}
.card:hover{transform:translateY(-5px);border-color:rgba(201,164,76,0.45)}
.card .ic{width:42px;height:42px;margin-bottom:16px;color:var(--gold1)}
.card h3{font-size:1.15rem;text-transform:uppercase;margin-bottom:10px;color:var(--bone)}
.card p{color:var(--bone-dim);font-size:.96rem;font-weight:300}

/* ================================================================
   ABOUT SECTION
   ================================================================ */
.about{display:grid;grid-template-columns:1.3fr 1fr;gap:54px;align-items:center}
.about p{margin-bottom:18px;color:var(--bone-dim);font-size:1.08rem}
.dropcap{float:left;font-family:'Cinzel Decorative',serif;font-size:3.6rem;line-height:.8;
  padding:6px 12px 0 0;color:transparent;background:var(--gold-grad);
  -webkit-background-clip:text;background-clip:text}
.about-card{border:1px solid var(--line);background:linear-gradient(160deg,var(--panel),var(--black2));padding:34px;border-radius:3px}
.about-card h3{color:var(--gold2);font-size:1.05rem;letter-spacing:.08em;margin-bottom:18px;text-transform:uppercase}
.about-card ul{list-style:none}
.about-card li{padding:11px 0;border-bottom:1px solid rgba(255,255,255,0.05);display:flex;justify-content:space-between;gap:14px;font-size:.96rem}
.about-card li:last-child{border-bottom:none}
.about-card li span:first-child{color:var(--bone-dim)}
.about-card li span:last-child{color:var(--bone);font-family:'Cinzel',serif;font-size:.84rem;text-align:right}

/* ================================================================
   GALLERY
   ================================================================ */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:12px}
.tile{position:relative;overflow:hidden;border-radius:3px;border:1px solid var(--line);
  cursor:pointer;background-size:cover;background-position:center;background-color:var(--panel)}
.tile.tall{grid-row:span 2}
.tile.wide{grid-column:span 2}
.tile .cap{position:absolute;left:0;right:0;bottom:0;padding:22px 14px 12px;
  background:linear-gradient(0deg,rgba(8,6,5,0.92),transparent);
  font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--bone);transform:translateY(4px);opacity:0;transition:.3s}
.tile:hover .cap{transform:translateY(0);opacity:1}
.tile:hover{border-color:rgba(201,164,76,0.5)}
.tile .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,rgba(124,32,32,0.25),rgba(12,10,9,0.85));}

/* WordPress gallery block override — matches .gallery-grid styling */
.wp-block-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.wp-block-gallery figure{margin:0;border:1px solid var(--line);border-radius:3px;overflow:hidden;cursor:pointer}
.wp-block-gallery figure img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s}
.wp-block-gallery figure:hover img{transform:scale(1.04)}
.wp-block-gallery figcaption{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--bone-dim);padding:8px 12px;background:rgba(0,0,0,0.6)}

/* ================================================================
   RANKS ACCORDION
   ================================================================ */
.ranks{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.rank{border:1px solid var(--line);background:linear-gradient(165deg,var(--panel),var(--black2));border-radius:3px;overflow:hidden}
.rank-head{display:flex;align-items:center;gap:20px;padding:20px 24px;cursor:pointer}
.rank-ins{width:54px;height:54px;flex:none;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:3px;background:rgba(0,0,0,0.3)}
.rank-ins svg{width:38px;height:38px;color:var(--gold2)}
.rank-title{flex:1}
.rank-title h3{font-size:1.12rem;text-transform:uppercase;color:var(--bone)}
.rank-title .tier{font-family:'Cinzel',serif;font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold1)}
.rank-toggle{color:var(--gold1);font-size:1.4rem;transition:transform .3s;font-family:'Cinzel',serif}
.rank.open .rank-toggle{transform:rotate(45deg)}
.rank-body{max-height:0;overflow:hidden;transition:max-height .4s ease}
.rank.open .rank-body{max-height:400px}
.rank-body-inner{padding:0 24px 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rank-body-inner h4{font-family:'Cinzel',serif;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold1);margin-bottom:8px}
.rank-body-inner p,.rank-body-inner li{color:var(--bone-dim);font-size:.9rem;font-weight:300}
.rank-body-inner ul{list-style:none}
.rank-body-inner li{padding:3px 0;padding-left:14px;position:relative}
.rank-body-inner li::before{content:"";position:absolute;left:0;top:11px;width:5px;height:5px;background:var(--gold1);transform:rotate(45deg)}

/* ================================================================
   ROSTER
   ================================================================ */
.roster{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.fighter{border:1px solid var(--line);background:linear-gradient(170deg,var(--panel),var(--black2));
  border-radius:3px;overflow:hidden;text-align:center;transition:transform .3s,border-color .3s}
.fighter:hover{transform:translateY(-5px);border-color:rgba(201,164,76,0.45)}
.fighter .portrait{height:200px;background:linear-gradient(150deg,rgba(124,32,32,0.3),rgba(12,10,9,0.85));
  display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center top}
.fighter .portrait svg{width:54px;height:62px;opacity:.45;color:var(--gold1)}
.fighter .info{padding:20px 16px}
.fighter .info h3{font-size:1.04rem;text-transform:uppercase;color:var(--bone)}
.fighter .info .role{font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold1);margin:5px 0 10px}
.fighter .info p{color:var(--bone-dim);font-size:.85rem;font-weight:300}

/* ================================================================
   EVENTS
   ================================================================ */
.events-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.event{display:flex;align-items:center;gap:24px;border:1px solid var(--line);
  background:linear-gradient(160deg,var(--panel),var(--black2));border-radius:3px;padding:22px 26px}
.event .date{text-align:center;flex:none;width:74px}
.event .date .mo{font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold1)}
.event .date .dy{font-family:'Cinzel Decorative',serif;font-size:1.9rem;font-weight:900;line-height:1}
.event .det{flex:1}
.event .det h3{font-size:1.08rem;text-transform:uppercase;color:var(--bone);margin-bottom:3px}
.event .det p{color:var(--bone-dim);font-size:.9rem;font-weight:300}
.event .etag{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--gold3);color:var(--gold2);border-radius:2px;white-space:nowrap}

/* ================================================================
   JOIN / RECRUIT
   ================================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.step{text-align:center;padding:10px}
.step .n{font-family:'Cinzel Decorative',serif;font-size:2.4rem;font-weight:900;
  color:transparent;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text}
.step h3{font-size:1.04rem;text-transform:uppercase;margin:6px 0 8px}
.step p{color:var(--bone-dim);font-size:.92rem;font-weight:300}
.costs{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;max-width:760px;margin:0 auto 48px}
.cost{display:flex;justify-content:space-between;align-items:center;
  border:1px solid var(--line);background:rgba(0,0,0,0.25);padding:16px 22px;border-radius:3px}
.cost .l{color:var(--bone-dim)}
.cost .v{font-family:'Cinzel',serif;color:var(--gold2);font-size:.9rem;letter-spacing:.06em}
.rec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px}

/* FAQ */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.qa{border:1px solid var(--line);background:linear-gradient(160deg,var(--panel),var(--black2));border-radius:3px}
.qa .q{display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px 24px;cursor:pointer;font-family:'Cinzel',serif;font-size:.98rem;color:var(--bone);letter-spacing:.02em}
.qa .q .t{color:var(--gold1);font-size:1.3rem;transition:transform .3s}
.qa.open .q .t{transform:rotate(45deg)}
.qa .a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.qa .a p{padding:0 24px 20px;color:var(--bone-dim);font-weight:300;font-size:.96rem}
.qa.open .a{max-height:260px}

/* Contact Form 7 overrides */
.wpcf7 .wpcf7-form p{margin-bottom:18px}
.wpcf7 label{display:block;font-family:'Cinzel',serif;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold1);margin-bottom:7px}
.wpcf7 input[type=text],.wpcf7 input[type=email],.wpcf7 input[type=tel],.wpcf7 select,.wpcf7 textarea{
  width:100%;background:rgba(0,0,0,0.4);border:1px solid var(--line);border-radius:2px;
  padding:12px 14px;color:var(--bone);font-family:'Spectral',serif;font-size:.98rem;transition:border-color .2s}
.wpcf7 input:focus,.wpcf7 select:focus,.wpcf7 textarea:focus{outline:none;border-color:var(--gold1)}
.wpcf7 textarea{resize:vertical;min-height:90px}
.wpcf7 input[type=submit]{background:var(--gold-grad);color:#1a1206;border:none;font-weight:700;
  font-family:'Cinzel',serif;font-size:.84rem;letter-spacing:.14em;text-transform:uppercase;
  padding:15px 30px;border-radius:2px;cursor:pointer;width:100%;margin-top:8px}
.wpcf7 input[type=submit]:hover{filter:brightness(1.08)}
.wpcf7-response-output{margin-top:12px;padding:10px 16px;border-radius:2px;font-family:'Cinzel',serif;
  font-size:.78rem;letter-spacing:.1em;color:var(--bone)}
.wpcf7-mail-sent-ok{border:1px solid #2f6b3a;background:rgba(47,107,58,0.15)}
.wpcf7-validation-errors{border:1px solid var(--gold3);background:rgba(138,106,43,0.15)}

/* ================================================================
   FORM BOX
   ================================================================ */
.form-box{max-width:680px;margin:0 auto;border:1px solid var(--line);
  background:linear-gradient(165deg,var(--panel),var(--black));padding:42px;border-radius:4px}
.form-note{text-align:center;color:var(--bone-dim);font-size:.82rem;margin-top:16px;font-weight:300}
.form-note a{color:var(--gold2)}

/* ================================================================
   CTA STRIP
   ================================================================ */
.cta-strip{background:radial-gradient(120% 90% at 50% 0%, rgba(124,32,32,0.25), transparent 60%),var(--black2);
  text-align:center;padding:80px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-strip h2{font-size:clamp(1.8rem,4vw,2.8rem);text-transform:uppercase;margin-bottom:16px}
.cta-strip p{color:var(--bone-dim);max-width:520px;margin:0 auto 28px;font-weight:300}

/* VIDEO */
.watch{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.video-frame{position:relative;aspect-ratio:16/9;border:1px solid var(--line);border-radius:3px;overflow:hidden;
  background:linear-gradient(150deg,rgba(124,32,32,0.3),rgba(12,10,9,0.92));display:flex;align-items:center;justify-content:center}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.play-ph{width:74px;height:74px;border-radius:50%;border:1px solid var(--gold1);
  display:flex;align-items:center;justify-content:center;color:var(--gold2);background:rgba(12,10,9,0.4)}
.watch p{color:var(--bone-dim);margin-bottom:14px;font-weight:300}

/* ================================================================
   FOOTER
   ================================================================ */
footer{background:var(--black);border-top:1px solid var(--line);padding:64px 0 30px;position:relative;z-index:3}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
.foot .brand{margin-bottom:18px}
.foot > div > p{color:var(--bone-dim);font-size:.92rem;font-weight:300;max-width:300px}
.foot h4{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold1);margin-bottom:16px}
.foot ul{list-style:none}
.foot li{padding:5px 0}
.foot a{color:var(--bone-dim);font-size:.92rem;transition:color .2s}
.foot a:hover{color:var(--gold2)}
.copy{text-align:center;border-top:1px solid rgba(255,255,255,0.06);padding-top:26px;
  color:var(--steel);font-size:.78rem;font-family:'Cinzel',serif;letter-spacing:.1em}

/* ================================================================
   LIGHTBOX
   ================================================================ */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(6,4,4,0.95);
  display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:82vh;border:1px solid var(--line);border-radius:3px}
.lb-close{position:absolute;top:24px;right:30px;color:var(--gold2);font-size:2rem;
  cursor:pointer;font-family:'Cinzel',serif;line-height:1;z-index:201}
.lb-cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;
  font-family:'Cinzel',serif;letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;color:var(--bone-dim)}

/* ================================================================
   MODAL
   ================================================================ */
.modal{position:fixed;inset:0;z-index:300;background:rgba(6,4,4,0.85);
  backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-box{width:100%;max-width:420px;border:1px solid var(--line);
  background:linear-gradient(170deg,var(--panel),var(--black));border-radius:4px;padding:38px;position:relative}
.modal-box .crest-sm2{width:50px;height:58px;margin:0 auto 14px;display:block}
.modal-box h3{text-align:center;text-transform:uppercase;font-size:1.3rem;margin-bottom:6px}
.modal-box .msub{text-align:center;color:var(--bone-dim);font-size:.86rem;font-weight:300;margin-bottom:24px}
.modal-box .lb-close{position:absolute;top:16px;right:20px;font-size:1.5rem}
.modal-box .field{margin-bottom:18px}
.modal-box .field label{display:block;font-family:'Cinzel',serif;font-size:.66rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold1);margin-bottom:7px}
.modal-box .field input{width:100%;background:rgba(0,0,0,0.4);border:1px solid var(--line);
  border-radius:2px;padding:12px 14px;color:var(--bone);font-family:'Spectral',serif;font-size:.98rem}
.modal-box .field input:focus{outline:none;border-color:var(--gold1)}

/* ================================================================
   SCROLL REVEAL
   ================================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:900px){
  .navlinks,.nav-cta .btn-ghost{display:none}
  .hamb{display:flex}
  .about,.watch{grid-template-columns:1fr;gap:30px}
  .cards,.rec-grid,.steps{grid-template-columns:1fr 1fr}
  .roster{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .tile.wide{grid-column:span 2}
  .herald{grid-template-columns:1fr 1fr}
  .herald div:nth-child(2){border-right:none}
  .costs{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .cards,.rec-grid,.steps,.roster{grid-template-columns:1fr}
  .rank-body-inner{grid-template-columns:1fr;gap:14px}
  .rank.open .rank-body{max-height:640px}
  .event{flex-wrap:wrap}
}

/* ================================================================
   HERO — charter line
   ================================================================ */
.hero-charter{
  font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold1);opacity:.8;margin-top:22px;
}

/* ================================================================
   SHOP
   ================================================================ */
.shop-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.shop-card{
  border:1px solid var(--line);background:linear-gradient(165deg,var(--panel),var(--black2));
  border-radius:3px;overflow:hidden;transition:transform .3s,border-color .3s;
}
.shop-card:hover{transform:translateY(-5px);border-color:rgba(201,164,76,.45)}
.shop-img{
  height:180px;background:linear-gradient(150deg,rgba(124,32,32,.22),rgba(12,10,9,.85));
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.shop-img img{width:100%;height:100%;object-fit:cover}
.shop-info{padding:20px 18px}
.shop-info h3{font-size:1.05rem;text-transform:uppercase;color:var(--bone);margin-bottom:8px}
.shop-info p{color:var(--bone-dim);font-size:.88rem;font-weight:300;margin-bottom:14px}
.shop-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.shop-price{
  font-family:'Cinzel Decorative',serif;font-size:1.3rem;font-weight:900;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.shop-buy{padding:8px 16px;font-size:.72rem}
.shop-note{
  text-align:center;color:var(--bone-dim);font-size:.84rem;margin-top:28px;
  font-weight:300;max-width:600px;margin-left:auto;margin-right:auto;
}
/* homepage shop teaser reuses .card — add price line */
.card .shop-price{
  font-family:'Cinzel Decorative',serif;font-size:1.2rem;font-weight:900;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;margin-top:10px;
}
.card .shop-img-ph{
  height:120px;background:linear-gradient(150deg,rgba(124,32,32,.22),rgba(12,10,9,.8));
  border-radius:2px;margin-bottom:14px;
}

@media(max-width:900px){
  .shop-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .shop-grid{grid-template-columns:1fr}
}

/* ================================================================
   LOGO IMAGES — transparent PNGs, no white-bg treatment needed
   ================================================================ */

/* ---- Nav / footer brand mark ---- */
.logo-brand{
  width:40px;height:40px;
  object-fit:contain;
  flex:none;
  display:block;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,0.6));
}

/* ---- Home page hero crest (fallback for non-split layout) ---- */
.crest-hero-img{
  width:200px;height:auto;
  margin:0 auto 26px;
  display:block;
  filter:drop-shadow(0 12px 36px rgba(0,0,0,.65));
  animation:rise .9s ease both;
}

/* ---- Interior page-hero crest ---- */
.crest-sm-img{
  width:80px;height:80px;
  object-fit:contain;
  margin:0 auto 18px;
  display:block;
  position:relative;
  z-index:3;
  filter:drop-shadow(0 4px 14px rgba(0,0,0,0.5));
}

/* ---- Modal header crest ---- */
.crest-sm2-img{
  width:56px;height:56px;
  object-fit:contain;
  margin:0 auto 14px;
  display:block;
}

/* ---- ACW league badge ---- */
.acw-badge{
  width:38px !important;height:38px !important;
  object-fit:contain;
  flex:none;
  display:inline-block;
}
.acw-member{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:'Cinzel',serif;
  font-size:.68rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--bone-dim);
}

/* ---- About card ACW member strip ---- */
.about-card .acw-member{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

/* ================================================================
   HERO — TWO-COLUMN SPLIT LAYOUT
   ================================================================ */

/* Override centered layout from .hero-inner for the split */
.hero-split{
  display:grid;
  grid-template-columns:1fr 1.25fr;
  gap:clamp(30px,5vw,80px);
  align-items:center;
  width:100%;
}

/* ---- Left column: large crest ---- */
.hero-crest-col{
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-crest-wrap{
  position:relative;
  display:inline-block;
}
/* Atmospheric glow behind the crest */
.hero-crest-wrap::before{
  content:"";
  position:absolute;
  inset:-15%;
  border-radius:50%;
  background:radial-gradient(60% 60% at 50% 52%,
    rgba(124,32,32,0.55) 0%,
    rgba(180,80,20,0.18) 45%,
    transparent 72%);
  z-index:0;
  pointer-events:none;
}
.hero-crest-side{
  position:relative;
  z-index:1;
  width:clamp(220px,32vw,420px);
  height:auto;
  display:block;
  filter:drop-shadow(0 20px 50px rgba(0,0,0,0.75))
         drop-shadow(0 4px 12px rgba(180,80,20,0.3));
  animation:rise 1s ease both;
}

/* ---- Right column: text content ---- */
.hero-content-col{
  text-align:left;
}
.hero-content-col h1{
  font-size:clamp(3rem,7vw,5.4rem);
  line-height:.94;
  margin-bottom:12px;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.hero-content-col .sub{
  font-family:'Cinzel',serif;
  font-size:clamp(.75rem,1.4vw,1rem);
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--bone-dim);
  margin-bottom:24px;
}
.hero-content-col .lead{
  max-width:560px;
  margin:0 0 30px;
  font-size:clamp(.95rem,1.6vw,1.12rem);
  color:var(--bone-dim);
  font-weight:300;
  line-height:1.75;
}
.hero-content-col .hero-cta{
  justify-content:flex-start;
  margin-bottom:28px;
}

/* ACW charter credential line */
.hero-charter{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:'Cinzel',serif;
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold1);
  opacity:.8;
}
.hero-acw-icon{
  width:32px;
  height:32px;
  object-fit:contain;
  flex:none;
  opacity:.75;
}

/* Remove the old centered .crest-hero-img if it leaks (hide it in split context) */
.hero-split .crest-hero-img{ display:none }

/* ---- Responsive breakpoint ---- */
@media(max-width:820px){
  .hero-split{
    grid-template-columns:1fr;
    text-align:center;
    gap:30px;
  }
  .hero-content-col{ text-align:center }
  .hero-content-col .hero-cta{ justify-content:center }
  .hero-content-col .lead{ margin:0 auto 30px }
  .hero-charter{ justify-content:center }
  .hero-crest-side{ width:clamp(180px,55vw,300px) }
}
