/* ============================================================
   MUZAFFARPUR RIFLE CLUB  —  style.css
   Athletic / editorial theme. Tricolor + crimson + gold accents.
   ============================================================ */

:root{
  --ink:#10130d;
  --ink-2:#171b12;
  --ink-3:#1f241a;
  --paper:#f6f2e8;
  --paper-2:#efe9da;
  --saffron:#ff7d1a;
  --saffron-deep:#e85d04;
  --green:#1a9140;
  --green-deep:#127031;
  --crimson:#d31527;
  --crimson-deep:#a30f1d;
  --gold:#f3b50a;
  --muted:#8c8a7e;
  --muted-d:#9aa08c;
  --line:#e3dcc9;
  --line-d:rgba(255,255,255,.10);
  --shadow:0 18px 50px -18px rgba(16,19,13,.55);
  --r:14px;
  --maxw:1200px;
  --ff-display:"Oswald",sans-serif;
  --ff-body:"Manrope",-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:92px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

h1,h2,h3,h4,.display{font-family:var(--ff-display);font-weight:600;line-height:1.04;letter-spacing:.01em;text-transform:uppercase}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:96px 0;position:relative}
.section--dark{background:var(--ink);color:var(--paper)}
.section--alt{background:var(--paper-2)}

/* ---------- shared bits ---------- */
.kicker{
  font-family:var(--ff-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.32em;font-size:.74rem;color:var(--crimson);
  display:inline-flex;align-items:center;gap:.7rem;margin-bottom:18px;
}
.kicker::before{content:"";width:26px;height:2px;background:var(--crimson)}
.section--dark .kicker{color:var(--gold)}
.section--dark .kicker::before{background:var(--gold)}

.h-sec{font-size:clamp(2rem,4.6vw,3.4rem);line-height:1}
.lead{font-size:1.06rem;color:#52503f;max-width:62ch;margin-top:18px}
.section--dark .lead{color:#cdcbbb}

.tri{height:5px;width:120px;border-radius:5px;margin-top:22px;
  background:linear-gradient(90deg,var(--saffron) 0 33%,#fff 33% 66%,var(--green) 66% 100%);
  box-shadow:0 0 0 1px rgba(0,0,0,.06)}

.btn{
  display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;
  font-family:var(--ff-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;font-size:.92rem;padding:14px 26px;border-radius:50px;
  border:2px solid transparent;transition:.25s;line-height:1;
}
.btn-primary{background:var(--crimson);color:#fff;box-shadow:0 12px 28px -10px rgba(211,21,39,.7)}
.btn-primary:hover{background:var(--crimson-deep);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn svg{width:17px;height:17px}

/* ============================================================
   TOP STRIP
   ============================================================ */
.topbar{background:var(--ink-2);color:#cfcdbf;font-size:.8rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;
  gap:14px;padding-top:9px;padding-bottom:9px;flex-wrap:wrap}
.topbar a{display:inline-flex;align-items:center;gap:6px;transition:.2s}
.topbar a:hover{color:var(--gold)}
.topbar .tb-left{display:flex;gap:22px;flex-wrap:wrap}
.topbar .tb-right{display:flex;gap:14px;align-items:center}
.tb-badge{background:var(--green);color:#fff;font-family:var(--ff-display);
  letter-spacing:.12em;text-transform:uppercase;font-size:.7rem;padding:4px 12px;border-radius:50px}
.topbar svg{width:14px;height:14px;flex:none}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.header{position:sticky;top:0;z-index:60;background:rgba(246,242,232,.92);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:.3s}
.header.scrolled{box-shadow:0 8px 30px -16px rgba(0,0,0,.35)}
.nav{display:flex;align-items:center;justify-content:space-between;
  padding-top:14px;padding-bottom:14px;transition:.3s}
.header.scrolled .nav{padding-top:9px;padding-bottom:9px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{width:50px;height:50px;border-radius:50%;object-fit:cover;
  box-shadow:0 0 0 2px var(--saffron),0 0 0 4px #fff,0 0 0 5px var(--green)}
.brand .bt{font-family:var(--ff-display);font-weight:700;line-height:.96;
  text-transform:uppercase;font-size:1.18rem;letter-spacing:.01em}
.brand .bt b{color:var(--crimson)}
.brand .bs{display:block;font-family:var(--ff-body);font-weight:600;
  text-transform:none;letter-spacing:.18em;font-size:.6rem;color:var(--muted)}

.menu{display:flex;align-items:center;gap:28px}
.menu a{font-family:var(--ff-display);font-weight:500;text-transform:uppercase;
  letter-spacing:.06em;font-size:.86rem;color:#33372b;position:relative;padding:4px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--crimson);transition:.25s}
.menu a:not(.nav-cta):hover{color:var(--crimson)}
.menu a:not(.nav-cta):hover::after{width:100%}
.menu .nav-cta{margin-left:6px;color:#fff}
.menu .nav-cta::after{display:none}
.menu .nav-cta:hover,.menu .nav-cta:focus{color:#fff}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.46}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(16,19,13,.96) 8%,rgba(16,19,13,.72) 48%,rgba(16,19,13,.30) 100%)}
.hero__tri{position:absolute;top:0;left:0;right:0;height:5px;z-index:3;
  background:linear-gradient(90deg,var(--saffron) 0 33%,#fff 33% 66%,var(--green) 66% 100%)}
.hero .wrap{position:relative;z-index:4;padding-top:118px;padding-bottom:120px}
.hero__badges{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-display);
  text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:500;
  padding:7px 14px;border-radius:50px;border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.05);color:#e9e7da}
.chip b{color:var(--gold)}
.chip.live{border-color:rgba(211,21,39,.6);background:rgba(211,21,39,.16)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--crimson);box-shadow:0 0 0 0 rgba(211,21,39,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(211,21,39,.6)}70%{box-shadow:0 0 0 9px rgba(211,21,39,0)}100%{box-shadow:0 0 0 0 rgba(211,21,39,0)}}
.hero h1{font-size:clamp(2.8rem,7vw,5.6rem);font-weight:700;max-width:16ch}
.hero h1 .c{color:var(--crimson)}
.hero h1 .o{-webkit-text-stroke:1.5px rgba(255,255,255,.85);color:transparent}
.hero__sub{font-size:1.15rem;color:#d8d6c8;max-width:54ch;margin-top:22px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero__stats{display:flex;gap:40px;flex-wrap:wrap;margin-top:54px;
  padding-top:30px;border-top:1px solid rgba(255,255,255,.14)}
.hero__stats .st b{font-family:var(--ff-display);font-weight:700;font-size:2.3rem;display:block;line-height:1;color:#fff}
.hero__stats .st b i{font-style:normal;color:var(--gold)}
.hero__stats .st span{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:#a8a99a}

/* affiliation marquee */
.affil{background:var(--ink-2);border-top:1px solid var(--line-d);color:#bdbcab}
.affil .wrap{display:flex;align-items:center;gap:12px 26px;flex-wrap:wrap;
  padding-top:18px;padding-bottom:18px;justify-content:center}
.affil span{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.2em;
  font-size:.8rem;color:#8d8c7c}
.affil b{color:#e9e7da;font-weight:600}
.affil .sep{display:none}
/* the three affiliations as subtle pills (label stays plain) — wraps cleanly, no stranded dots */
.affil .wrap > span:not(.sep):first-child{color:var(--gold);letter-spacing:.28em;opacity:.9}
.affil .wrap > span:not(.sep):not(:first-child){
  border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:7px 16px;
  letter-spacing:.12em;background:rgba(255,255,255,.02)}

/* ============================================================
   MARKS / TARGET MOTIF
   ============================================================ */
.target-mark{position:absolute;border-radius:50%;pointer-events:none;opacity:.5;
  background:
   radial-gradient(circle,transparent 0 14%,var(--saffron) 14% 16%,transparent 16% 30%,
   #fff 30% 32%,transparent 32% 46%,var(--green) 46% 48%,transparent 48%);
  mask:radial-gradient(circle,#000 70%,transparent 71%)}

/* ============================================================
   STATS BAR
   ============================================================ */
.stripbar{background:var(--crimson);color:#fff}
.stripbar .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  padding:0;background:rgba(255,255,255,.16)}
.stripbar .cell{background:var(--crimson);padding:30px 22px;text-align:center}
.stripbar .cell b{font-family:var(--ff-display);font-weight:700;font-size:1.9rem;display:block;line-height:1}
.stripbar .cell span{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;opacity:.9}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start}
.about-copy p{margin-top:16px;color:#4f4d3d}
.about-points{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:30px}
.about-points li{display:flex;gap:11px;align-items:flex-start;font-weight:600;font-size:.95rem}
.about-points svg{width:20px;height:20px;flex:none;color:var(--green);margin-top:2px}
.about-media{position:relative}
.about-media img{border-radius:var(--r);box-shadow:var(--shadow);width:100%;height:auto}
.about-media .cap{position:absolute;left:14px;bottom:14px;right:14px;
  background:rgba(16,19,13,.82);color:#fff;border-radius:10px;padding:12px 16px;
  font-size:.82rem;backdrop-filter:blur(6px)}
.about-media .cap b{font-family:var(--ff-display);color:var(--gold);display:block;letter-spacing:.04em}

/* officials */
.officials{margin-top:30px;border-top:2px solid var(--line);padding-top:26px}
.officials h4{font-size:1rem;letter-spacing:.14em;color:var(--crimson);margin-bottom:16px}
.off-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.off-grid .o{background:#fff;border:1px solid var(--line);border-radius:12px;padding:15px 17px}
.off-grid .o span{font-size:.68rem;text-transform:uppercase;letter-spacing:.13em;color:var(--muted);
  font-family:var(--ff-display)}
.off-grid .o b{display:block;font-family:var(--ff-display);font-weight:600;font-size:1.06rem;margin-top:3px}

/* ============================================================
   CARDS GRID (disciplines / training / facilities)
   ============================================================ */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:32px 28px;transition:.3s;position:relative;overflow:hidden}
.section--dark .card{background:var(--ink-2);border-color:var(--line-d)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .ico{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--saffron),var(--saffron-deep));color:#fff;margin-bottom:20px}
.card .ico svg{width:28px;height:28px}
.card.green .ico{background:linear-gradient(135deg,var(--green),var(--green-deep))}
.card.red .ico{background:linear-gradient(135deg,var(--crimson),var(--crimson-deep))}
.card h3{font-size:1.4rem;font-weight:600}
.card p{margin-top:10px;color:#56543f;font-size:.95rem}
.section--dark .card p{color:#bdbcab}
.card .tag{display:inline-block;margin-top:16px;font-family:var(--ff-display);
  text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--crimson)}
.section--dark .card .tag{color:var(--gold)}

/* distances pills inside discipline */
.dist{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.dist b{font-family:var(--ff-display);font-weight:600;background:var(--paper-2);
  border:1px solid var(--line);border-radius:50px;padding:5px 14px;font-size:.82rem;letter-spacing:.04em}
.section--dark .dist b{background:var(--ink-3);border-color:var(--line-d);color:#e9e7da}

/* ============================================================
   BENEFITS
   ============================================================ */
.ben-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:48px}
.ben{display:flex;gap:16px;align-items:flex-start;background:var(--ink-2);
  border:1px solid var(--line-d);border-radius:12px;padding:20px 22px}
.ben .n{font-family:var(--ff-display);font-weight:700;font-size:1.5rem;color:var(--gold);
  line-height:1;flex:none;width:42px}
.ben p{font-size:.96rem;color:#d4d3c4}
.ben p b{color:#fff}

/* ============================================================
   FACILITIES feature row
   ============================================================ */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:54px}
.feat__media img{border-radius:var(--r);box-shadow:var(--shadow);width:100%}
.feat__list li{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-bottom:1px dashed var(--line)}
.feat__list li:last-child{border-bottom:0}
.feat__list svg{width:22px;height:22px;color:var(--crimson);flex:none;margin-top:2px}
.feat__list b{font-family:var(--ff-display);font-weight:600;font-size:1.05rem;display:block}
.feat__list span{font-size:.9rem;color:#56543f}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:50px}
.gitem{position:relative;overflow:hidden;border-radius:12px;cursor:pointer;background:var(--ink-2)}
.gitem img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gitem:hover img{transform:scale(1.08)}
.gitem::after{content:"";position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(16,19,13,.6),transparent 55%);opacity:0;transition:.3s}
.gitem:hover::after{opacity:1}
.gitem .gcap{position:absolute;left:14px;bottom:12px;right:14px;color:#fff;z-index:2;
  font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;
  transform:translateY(8px);opacity:0;transition:.3s}
.gitem:hover .gcap{transform:none;opacity:1}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* ============================================================
   NEWS
   ============================================================ */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.news{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:.3s}
.news:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.news__img{height:200px;overflow:hidden;background:var(--paper-2);cursor:pointer;position:relative}
.news__img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:.5s}
.news:hover .news__img img{transform:scale(1.05)}
.news__src{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;
  font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;
  padding:5px 11px;border-radius:50px}
.news__body{padding:22px 24px;display:flex;flex-direction:column;flex:1}
.news__date{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.12em;
  font-size:.7rem;color:var(--crimson)}
.news__body h3{font-size:1.2rem;font-weight:600;margin-top:8px;line-height:1.15}
.news__body p{font-size:.92rem;color:#56543f;margin-top:10px;flex:1}
.news__more{margin-top:14px;font-family:var(--ff-display);text-transform:uppercase;
  letter-spacing:.08em;font-size:.78rem;color:var(--ink);display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.news__more svg{width:15px;height:15px;transition:.2s}
.news__more:hover svg{transform:translateX(4px)}

/* ============================================================
   ANNOUNCEMENTS
   ============================================================ */
.ann-wrap{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;margin-top:50px;align-items:stretch}
.ann-hero{background:linear-gradient(135deg,var(--crimson),var(--crimson-deep));color:#fff;
  border-radius:var(--r);padding:42px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.ann-hero .target-mark{width:340px;height:340px;right:-90px;top:-90px;opacity:.18}
.ann-hero .tagline{font-family:var(--ff-display);letter-spacing:.2em;text-transform:uppercase;font-size:.78rem;opacity:.9}
.ann-hero h3{font-size:clamp(1.7rem,3.6vw,2.6rem);margin-top:14px;position:relative}
.ann-hero .meta{display:flex;gap:30px;flex-wrap:wrap;margin-top:26px;position:relative}
.ann-hero .meta .m span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;opacity:.85}
.ann-hero .meta .m b{font-family:var(--ff-display);font-weight:600;font-size:1.25rem}
.ann-hero .live-tag{position:absolute;top:26px;right:26px;display:inline-flex;align-items:center;gap:7px;
  background:rgba(0,0,0,.28);padding:6px 13px;border-radius:50px;font-family:var(--ff-display);
  text-transform:uppercase;letter-spacing:.12em;font-size:.7rem}
.ann-hero .live-tag .dot{background:#fff}
.ann-list{display:flex;flex-direction:column;gap:16px}
.ann{background:#fff;border:1px solid var(--line);border-left:4px solid var(--saffron);
  border-radius:12px;padding:20px 22px}
.ann.green{border-left-color:var(--green)}
.ann.gold{border-left-color:var(--gold)}
.ann .t{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:var(--muted)}
.ann b{display:block;font-family:var(--ff-display);font-weight:600;font-size:1.18rem;margin-top:4px}
.ann p{font-size:.9rem;color:#56543f;margin-top:6px}

/* ============================================================
   CHAMPIONS
   ============================================================ */
.champ-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-top:46px}
.champ{background:var(--ink-2);border:1px solid var(--line-d);border-radius:12px;padding:22px 18px;text-align:center}
.champ .av{width:54px;height:54px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--gold),var(--saffron-deep));color:var(--ink);
  font-family:var(--ff-display);font-weight:700;font-size:1.2rem}
.champ b{font-family:var(--ff-display);font-weight:600;font-size:1.05rem;display:block}
.champ span{font-size:.76rem;color:var(--muted-d)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:50px;align-items:stretch}
.cinfo{display:flex;flex-direction:column;gap:14px}
.cline{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:20px 22px;transition:.25s}
.cline:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.cline .ci{width:46px;height:46px;border-radius:12px;flex:none;display:grid;place-items:center;
  background:var(--ink);color:#fff}
.cline .ci svg{width:21px;height:21px}
.cline span{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.13em;font-size:.7rem;color:var(--muted)}
.cline b{display:block;font-size:1.05rem;font-weight:700;margin-top:2px;word-break:break-word}
.cmap{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);min-height:340px;border:1px solid var(--line)}
.cmap iframe{width:100%;height:100%;min-height:340px;border:0;display:block}
.csoc{display:flex;gap:12px;margin-top:6px}
.csoc a{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--ink);color:#fff;transition:.25s}
.csoc a:hover{background:var(--crimson);transform:translateY(-3px)}
.csoc svg{width:20px;height:20px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#0b0d08;color:#a9a899;padding:64px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.foot-brand{display:flex;align-items:center;gap:13px;margin-bottom:18px}
.foot-brand img{width:54px;height:54px;border-radius:50%;
  box-shadow:0 0 0 2px var(--saffron),0 0 0 4px #0b0d08,0 0 0 5px var(--green)}
.foot-brand .bt{font-family:var(--ff-display);font-weight:700;text-transform:uppercase;
  font-size:1.18rem;color:#fff;line-height:.96}
.foot-brand .bt b{color:var(--crimson)}
.footer p{font-size:.9rem;line-height:1.7}
.footer h5{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.14em;
  font-size:.82rem;color:#fff;margin-bottom:16px}
.footer ul li{margin-bottom:10px}
.footer ul a{font-size:.92rem;transition:.2s}
.footer ul a:hover{color:var(--gold);padding-left:5px}
.foot-contact li{display:flex;gap:10px;font-size:.9rem;margin-bottom:12px;align-items:flex-start}
.foot-contact svg{width:17px;height:17px;color:var(--saffron);flex:none;margin-top:3px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:50px;padding:22px 0;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem}
.foot-bottom .tri{margin:0;width:90px;height:4px}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,9,6,.94);
  display:none;align-items:center;justify-content:center;padding:30px;opacity:0;transition:.3s}
.lightbox.show{display:flex;opacity:1}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);
  color:#fff;cursor:pointer;display:grid;place-items:center;border-radius:50%;transition:.2s}
.lb-close{top:24px;right:24px;width:46px;height:46px;font-size:1.4rem}
.lb-nav{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:1.8rem}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-close:hover,.lb-nav:hover{background:var(--crimson);border-color:var(--crimson)}
.lb-cap{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:#d8d6c8;
  font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.1em;font-size:.85rem}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* back to top */
.totop{position:fixed;right:22px;bottom:22px;z-index:80;width:48px;height:48px;border-radius:50%;
  background:var(--crimson);color:#fff;border:0;cursor:pointer;display:grid;place-items:center;
  opacity:0;pointer-events:none;transform:translateY(12px);transition:.3s;box-shadow:var(--shadow)}
.totop.show{opacity:1;pointer-events:auto;transform:none}
.totop svg{width:22px;height:22px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .about-grid,.feat,.ann-wrap,.contact-grid{grid-template-columns:1fr;gap:38px}
  .grid-3,.news-grid{grid-template-columns:1fr 1fr}
  .ben-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .feat.rev{direction:ltr}
}
/* ---- Nav: switch to hamburger before the desktop menu runs out of room (~900px) ---- */
@media(max-width:900px){
  /* backdrop-filter makes the header a containing block for fixed children,
     which traps the slide-in menu. Disable it while the slide-in menu is in use. */
  .header{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(246,242,232,.98)}
  .menu{position:fixed;inset:0 0 0 auto;width:min(82vw,330px);background:var(--ink);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:6px;
    padding:96px 30px 30px;transform:translateX(100%);transition:.35s;z-index:55;box-shadow:-20px 0 60px rgba(0,0,0,.4)}
  .menu.open{transform:none}
  .menu a{color:#e9e7da;font-size:1.05rem;width:100%;padding:12px 0;border-bottom:1px solid var(--line-d)}
  .menu a::after{display:none}
  .menu .nav-cta{margin-top:14px;align-self:flex-start;color:#fff}
  .burger{display:flex;z-index:60}
}
@media(max-width:760px){
  .section{padding:68px 0}
  .stripbar .wrap{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .g-wide{grid-column:span 2}.g-tall{grid-row:span 1}
  .about-points{grid-template-columns:1fr}
  .hero__stats{gap:26px}
  .topbar .tb-left{display:none}
  .topbar .wrap{justify-content:center}
}
@media(max-width:540px){
  .grid-3,.news-grid,.foot-grid{grid-template-columns:1fr}
  .stripbar .wrap{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .hero .wrap{padding-top:80px;padding-bottom:80px}
  .lb-nav{width:42px;height:42px}
}

/* Visually-hidden (screen-reader & crawler accessible, off-screen visually) */
.vh{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---- FAQ accordion (additive) ---- */
.faq{max-width:860px;margin:40px auto 0;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .25s,border-color .25s}
.faq-item[open]{border-color:var(--crimson);box-shadow:0 14px 34px -18px rgba(211,21,39,.4)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 56px 22px 24px;position:relative;
  font-family:var(--ff-display);font-weight:500;font-size:1.08rem;color:var(--ink);letter-spacing:.01em}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";position:absolute;right:24px;top:50%;width:11px;height:11px;
  border-right:2.5px solid var(--crimson);border-bottom:2.5px solid var(--crimson);
  transform:translateY(-65%) rotate(45deg);transition:transform .25s}
.faq-item[open] summary::after{transform:translateY(-35%) rotate(225deg)}
.faq-item summary:hover{color:var(--crimson)}
.faq-a{padding:0 24px 22px;color:#4a4d40;line-height:1.7;font-size:.98rem}
.faq-a p{margin:0}
.faq-a a{color:var(--crimson);font-weight:600;text-decoration:underline}
@media(max-width:540px){
  .faq-item summary{font-size:1rem;padding:18px 48px 18px 18px}
  .faq-a{padding:0 18px 18px}
}

/* ---- Footer developer credit (additive) ---- */
.foot-meta{display:flex;flex-direction:column;gap:6px}
.foot-credit{opacity:.85}
.foot-credit a{color:var(--gold);font-weight:600;transition:.2s}
.foot-credit a:hover{color:#fff}

/* ---- Mobile menu: visible close (X) + tap-outside backdrop ---- */
.burger.open span{background:#fff}            /* X shows white on the dark open panel */
.nav-backdrop{position:fixed;inset:0;background:rgba(8,10,6,.55);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;z-index:54;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.nav-backdrop.open{opacity:1;visibility:visible}
