/* ===========================================================
   3-S Texas Outdoors — Trophy Room + The Herd
   Extends the core design system (styles.css). Loaded only on
   /trophy-room/ and /the-herd/ pages.
   =========================================================== */

/* ---------- stat strip (animated counters) ---------- */
.statstrip{border-block:1px solid var(--line);background:var(--charcoal-2)}
.statstrip .wrap{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,5vw,4rem);justify-content:center;
  padding-block:2.2rem;text-align:center}
.statstrip .ss{min-width:120px}
.statstrip .ss .num{font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.9rem,4vw,3rem);color:var(--brass-bright);line-height:1}
.statstrip .ss .lbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--bone-dim);margin-top:.5rem}
.demo-note{font-size:.78rem;color:var(--brass);border:1px solid var(--line);
  border-radius:99px;padding:.45em 1.1em;display:inline-flex;align-items:center;gap:.5em;margin-top:1.4rem}
.demo-note::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--brass)}

/* ---------- featured trophy (trophy of the month) ---------- */
.feat-trophy{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--line);
  border-radius:4px;overflow:hidden;background:var(--charcoal-2);margin-top:2.5rem;cursor:pointer;
  transition:border-color .4s,transform .4s cubic-bezier(.16,1,.3,1)}
.feat-trophy:hover{border-color:var(--brass);transform:translateY(-3px)}
.feat-trophy .ft-media{position:relative;min-height:340px;overflow:hidden}
.feat-trophy .ft-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .9s cubic-bezier(.16,1,.3,1)}
.feat-trophy:hover .ft-media img{transform:scale(1.05)}
.feat-trophy .ft-ribbon{position:absolute;top:1.2rem;left:1.2rem;z-index:2;background:var(--oxblood);
  color:var(--bone);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:.5em 1em;border-radius:2px}
.feat-trophy .ft-body{padding:clamp(1.8rem,3vw,2.8rem);display:flex;flex-direction:column;justify-content:center}
.feat-trophy .ft-body h2{font-size:clamp(1.6rem,3vw,2.4rem);margin:.4rem 0 .2rem}
.feat-trophy .ft-score{font-family:var(--font-display);font-weight:600;color:var(--brass-bright);
  font-size:1.3rem;margin:.6rem 0}
.feat-trophy .ft-story{color:var(--bone-dim);font-size:.98rem;margin:.6rem 0 1.2rem;max-width:46ch}
.feat-trophy .ft-meta{font-size:.85rem;color:var(--bone-dim)}
@media(max-width:780px){.feat-trophy{grid-template-columns:1fr}.feat-trophy .ft-media{min-height:280px}}

/* ---------- filter bar (sticky) ---------- */
.filterbar{position:sticky;top:64px;z-index:40;background:rgba(14,14,12,.92);
  backdrop-filter:blur(14px);border-block:1px solid var(--line);padding-block:.9rem}
.filterbar .fb-inner{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.fb-group{position:relative}
.fb-toggle{display:inline-flex;align-items:center;gap:.5em;border:1px solid var(--line-strong);
  background:var(--charcoal-2);color:var(--bone-dim);border-radius:99px;padding:.55em 1.05em;
  font-size:.84rem;font-family:inherit;cursor:pointer;transition:.25s;white-space:nowrap}
.fb-toggle:hover{border-color:var(--brass);color:var(--bone)}
.fb-toggle.has-sel{border-color:var(--brass);color:var(--brass-bright)}
.fb-toggle .caret{width:9px;height:9px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
  transform:rotate(45deg);transition:transform .25s;margin-left:.2em;margin-top:-3px}
.fb-group.open .fb-toggle .caret{transform:rotate(-135deg);margin-top:2px}
.fb-pop{position:absolute;top:calc(100% + .5rem);left:0;z-index:50;min-width:200px;
  background:var(--charcoal-3);border:1px solid var(--line-strong);border-radius:4px;
  padding:.6rem;display:none;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.fb-group.open .fb-pop{display:block}
.fb-opt{display:flex;align-items:center;gap:.6em;padding:.45em .55em;border-radius:3px;cursor:pointer;
  font-size:.88rem;color:var(--bone-dim);transition:.2s}
.fb-opt:hover{background:var(--charcoal-2);color:var(--bone)}
.fb-opt input{appearance:none;width:16px;height:16px;border:1.5px solid var(--line-strong);border-radius:3px;
  cursor:pointer;position:relative;flex:0 0 16px}
.fb-opt input:checked{background:var(--brass);border-color:var(--brass)}
.fb-opt input:checked::after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;font-size:.7rem;color:var(--charcoal);font-weight:700}
.fb-search{flex:1;min-width:160px;display:flex;align-items:center;gap:.5em;
  background:var(--charcoal-2);border:1px solid var(--line-strong);border-radius:99px;padding:.45em 1em}
.fb-search input{flex:1;background:none;border:none;color:var(--bone);font-family:inherit;font-size:.86rem}
.fb-search input:focus{outline:none}
.fb-search svg{width:16px;height:16px;color:var(--bone-dim);flex:0 0 16px}
.fb-clear{background:none;border:none;color:var(--brass);font-family:inherit;font-size:.82rem;
  cursor:pointer;text-decoration:underline;padding:.4em}
.fb-sort{margin-left:auto}
.fb-sort select{background:var(--charcoal-2);border:1px solid var(--line-strong);color:var(--bone);
  border-radius:99px;padding:.55em 1em;font-family:inherit;font-size:.84rem;cursor:pointer}
.fb-count{font-size:.8rem;color:var(--bone-dim);letter-spacing:.06em}

/* mobile: collapse filters into a drawer trigger */
.fb-mobile-trigger{display:none}
@media(max-width:780px){
  .filterbar .fb-inner > .fb-group,
  .filterbar .fb-inner > .fb-clear{display:none}
  .fb-mobile-trigger{display:inline-flex;align-items:center;gap:.5em;border:1px solid var(--brass);
    background:var(--charcoal-2);color:var(--brass-bright);border-radius:99px;padding:.6em 1.2em;
    font-size:.86rem;font-family:inherit;cursor:pointer}
  .fb-sort{margin-left:0}
}
.fb-count-line{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  margin-top:.7rem;flex-wrap:wrap}

/* mobile drawer */
.fb-drawer{position:fixed;inset:0;z-index:120;display:none}
.fb-drawer.open{display:block}
.fb-drawer .fb-scrim{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.fb-drawer .fb-sheet{position:absolute;left:0;right:0;bottom:0;max-height:85vh;overflow:auto;
  background:var(--charcoal-2);border-top:1px solid var(--line-strong);border-radius:14px 14px 0 0;
  padding:1.4rem var(--gutter) 2rem;transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.fb-drawer.open .fb-sheet{transform:translateY(0)}
.fb-sheet h3{font-size:1.3rem;margin-bottom:.3rem}
.fb-sheet .fb-section{border-top:1px solid var(--line);padding-top:1rem;margin-top:1rem}
.fb-sheet .fb-section .k{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brass);margin-bottom:.6rem}
.fb-sheet .fb-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.fb-sheet .fb-chip{border:1px solid var(--line-strong);border-radius:99px;padding:.5em 1em;
  font-size:.84rem;color:var(--bone-dim);cursor:pointer;transition:.2s}
.fb-sheet .fb-chip.sel{background:var(--oxblood);border-color:var(--oxblood);color:var(--bone)}
.fb-sheet .fb-apply{display:flex;gap:1rem;margin-top:1.6rem;position:sticky;bottom:0;
  background:var(--charcoal-2);padding-top:1rem}
.fb-sheet-close{position:absolute;top:1.1rem;right:var(--gutter);background:none;border:none;
  color:var(--bone-dim);font-size:1.6rem;cursor:pointer;line-height:1}

/* ---------- trophy grid (masonry-ish) ---------- */
.tr-grid{columns:4 260px;column-gap:1.1rem;margin-top:2rem}
@media(max-width:560px){.tr-grid{columns:1}}
.tr-card{break-inside:avoid;margin-bottom:1.1rem;position:relative;border-radius:3px;overflow:hidden;
  cursor:pointer;display:block;isolation:isolate;background:var(--charcoal-2);
  transition:transform .4s cubic-bezier(.16,1,.3,1)}
.tr-card:hover{transform:translateY(-3px)}
.tr-card img{width:100%;display:block;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.tr-card:hover img{transform:scale(1.05)}
.tr-card::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(14,14,12,.9) 100%);pointer-events:none}
.tr-card .tr-tag{position:absolute;top:.7rem;left:.7rem;z-index:2;font-size:.6rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;background:rgba(176,141,69,.92);color:var(--charcoal);
  padding:.35em .7em;border-radius:2px}
.tr-card .tr-info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1rem;
  transform:translateY(8px);opacity:.85;transition:.4s cubic-bezier(.16,1,.3,1)}
.tr-card:hover .tr-info{transform:translateY(0);opacity:1}
.tr-card .tr-sp{font-family:var(--font-display);font-weight:600;font-size:1.05rem;line-height:1.1}
.tr-card .tr-sub{font-size:.78rem;color:var(--bone-dim);margin-top:.25rem}
.tr-card .tr-score{display:inline-block;font-family:var(--font-display);font-weight:600;
  color:var(--brass-bright);font-size:.82rem;margin-top:.4rem;max-height:0;overflow:hidden;
  opacity:0;transition:.4s cubic-bezier(.16,1,.3,1)}
.tr-card:hover .tr-score{max-height:30px;opacity:1}

.empty-state{text-align:center;padding:4rem 1rem;color:var(--bone-dim)}
.empty-state h3{color:var(--bone);margin-bottom:.5rem}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:200;display:none}
.modal.open{display:block}
.modal .m-scrim{position:absolute;inset:0;background:rgba(8,8,7,.82);backdrop-filter:blur(4px)}
.modal .m-box{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  padding:clamp(1rem,4vw,3rem);overflow:auto}
.modal .m-inner{position:relative;width:min(960px,100%);background:var(--charcoal-2);
  border:1px solid var(--line-strong);border-radius:5px;overflow:hidden;display:grid;
  grid-template-columns:1fr 1fr;max-height:90vh;animation:mpop .4s cubic-bezier(.16,1,.3,1)}
@keyframes mpop{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
@media(max-width:760px){.modal .m-inner{grid-template-columns:1fr;max-height:92vh;overflow:auto}}
.modal .m-media{position:relative;min-height:300px;background:var(--charcoal-3)}
.modal .m-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:760px){.modal .m-media{min-height:240px;position:relative}.modal .m-media img{position:relative}}
.modal .m-body{padding:clamp(1.6rem,3vw,2.4rem);overflow:auto}
.modal .m-close{position:absolute;top:.8rem;right:.8rem;z-index:5;width:38px;height:38px;border-radius:50%;
  background:rgba(14,14,12,.6);border:1px solid var(--line-strong);color:var(--bone);cursor:pointer;
  font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:.25s}
.modal .m-close:hover{background:var(--oxblood);border-color:var(--oxblood)}
.modal .m-eyebrow{color:var(--brass);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.modal .m-body h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:.5rem 0}
.modal .m-score{font-family:var(--font-display);font-weight:600;color:var(--brass-bright);font-size:1.4rem;margin:.4rem 0 1rem}
.modal .m-specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:3px;overflow:hidden;margin:1rem 0}
.modal .m-specs .si{background:var(--charcoal);padding:.9rem 1rem}
.modal .m-specs .si .k{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass)}
.modal .m-specs .si .v{font-family:var(--font-display);font-weight:600;font-size:1.02rem;margin-top:.25rem}
.modal .m-story{color:var(--bone-dim);font-size:.96rem;margin:1rem 0;line-height:1.55}
.modal .m-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.3rem}
.modal .m-share{display:flex;gap:.6rem;align-items:center;margin-top:1.4rem;
  padding-top:1.3rem;border-top:1px solid var(--line)}
.modal .m-share .lbl{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim)}
.share-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--line-strong);
  background:var(--charcoal);color:var(--bone-dim);cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:.25s}
.share-btn:hover{border-color:var(--brass);color:var(--brass-bright)}
.share-btn svg{width:16px;height:16px}
.copied-toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%);z-index:300;
  background:var(--brass);color:var(--charcoal);font-weight:600;font-size:.86rem;padding:.7em 1.4em;
  border-radius:99px;opacity:0;transition:opacity .3s;pointer-events:none}
.copied-toast.show{opacity:1}

/* ---------- submit trophy form ---------- */
.submit-trophy{background:var(--charcoal-2)}
.submit-trophy .form-card{max-width:760px;margin:2.5rem auto 0}
.file-drop{border:1.5px dashed var(--line-strong);border-radius:3px;padding:1.6rem;text-align:center;
  color:var(--bone-dim);font-size:.9rem;cursor:pointer;transition:.25s}
.file-drop:hover{border-color:var(--brass);color:var(--bone)}

/* ===========================================================
   THE HERD
   =========================================================== */
.herd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2rem}
@media(max-width:980px){.herd-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.herd-grid{grid-template-columns:1fr}}
.hcard{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--charcoal-2);
  display:flex;flex-direction:column;transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .4s}
.hcard:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.hcard.is-breeder{border-color:rgba(140,110,200,.5);box-shadow:0 0 0 1px rgba(140,110,200,.25) inset}
.hcard.is-breeder:hover{border-color:rgba(160,130,220,.8)}
.hcard-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.hcard-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.hcard:hover .hcard-media img{transform:scale(1.05)}
.hcard-badges{position:absolute;top:.7rem;left:.7rem;right:.7rem;z-index:2;display:flex;
  gap:.4rem;flex-wrap:wrap;align-items:flex-start}
.badge{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  padding:.35em .7em;border-radius:2px;backdrop-filter:blur(4px)}
.badge--class{background:rgba(20,19,15,.75);color:var(--bone);border:1px solid var(--line-strong)}
.badge--trophy{color:var(--brass-bright);border-color:var(--brass)}
.badge--prop{background:rgba(20,19,15,.75);color:var(--bone-dim);border:1px solid var(--line-strong);margin-left:auto}
.badge--genetics{background:rgba(120,90,180,.9);color:#fff}
.hcard-body{padding:1.3rem;display:flex;flex-direction:column;flex:1}
.hcard .h-name{font-family:var(--font-display);font-weight:600;font-size:1.25rem;line-height:1.1}
.hcard .h-name .unnamed{color:var(--bone-dim);font-weight:500;font-size:1.05rem}
.hcard .h-sp{font-size:.85rem;color:var(--bone-dim);margin-top:.3rem}
.hcard .h-horn{font-family:var(--font-display);font-weight:600;color:var(--brass-bright);
  font-size:1.05rem;margin-top:.7rem}
.hcard .h-seen{font-size:.76rem;color:var(--bone-dim);margin-top:.5rem;display:flex;align-items:center;gap:.4em}
.hcard .h-seen svg{width:13px;height:13px;color:var(--brass)}
.hcard .h-foot{margin-top:auto;padding-top:1rem;display:flex;align-items:center;justify-content:space-between;gap:.8rem}
.status-pill{font-size:.74rem;font-weight:600;letter-spacing:.04em;padding:.4em .85em;border-radius:99px;
  display:inline-flex;align-items:center;gap:.45em}
.status-pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.status-available{background:rgba(70,130,60,.16);color:#7bc46a}
.status-reserved{background:rgba(176,141,69,.16);color:var(--brass-bright)}
.status-breeder{background:rgba(120,140,200,.16);color:#9fb0e6}
.hcard .reserve-btn{font-size:.82rem;padding:.6em 1.1em}
.hcard.is-breeder .h-name{color:#c9bcec}

/* ===========================================================
   GALLERY CARDS (simplified — photo + species caption)
   =========================================================== */
.gcard{position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;
  background:var(--charcoal-2);display:block;
  transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .4s}
.gcard:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.gcard-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.gcard-media img{width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.16,1,.3,1)}
.gcard:hover .gcard-media img{transform:scale(1.05)}
.gcard-caption{position:absolute;left:0;right:0;bottom:0;
  padding:.85rem 1rem;
  background:linear-gradient(to top,rgba(20,19,15,.92) 0%,rgba(20,19,15,.6) 70%,rgba(20,19,15,0) 100%);
  color:var(--bone);font-family:var(--font-display);font-weight:600;
  font-size:1.02rem;letter-spacing:.01em;line-height:1.2}
@media(max-width:560px){.gcard-caption{font-size:.95rem;padding:.75rem .85rem}}

/* count-up helper hidden state */
[data-count]{font-variant-numeric:tabular-nums}

/* breadcrumb tabs (hall of records) */
.rec-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:2rem;border-bottom:1px solid var(--line);padding-bottom:0}
.rec-tab{background:none;border:none;color:var(--bone-dim);font-family:inherit;font-size:.9rem;
  padding:.7em 1.1em;cursor:pointer;position:relative;transition:color .25s;white-space:nowrap}
.rec-tab:hover{color:var(--bone)}
.rec-tab.active{color:var(--brass-bright)}
.rec-tab.active::after{content:"";position:absolute;left:.6em;right:.6em;bottom:-1px;height:2px;background:var(--brass)}

.rec-table{width:100%;border-collapse:collapse;margin-top:2rem}
.rec-table thead th{text-align:left;font-family:var(--font-body);font-weight:600;font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--brass);padding:.8rem 1rem;border-bottom:1px solid var(--line-strong)}
.rec-table tbody tr{border-bottom:1px solid var(--line);cursor:pointer;transition:background .25s}
.rec-table tbody tr:hover{background:var(--charcoal-2)}
.rec-table td{padding:1.1rem 1rem;font-size:.95rem;vertical-align:middle}
.rec-table .rk{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:var(--bone-dim);width:60px}
.rec-table tbody tr:nth-child(1) .rk{color:var(--brass-bright)}
.rec-table tbody tr:nth-child(2) .rk{color:#c9c2b2}
.rec-table tbody tr:nth-child(3) .rk{color:#b08d45}
.rec-table .hunter-cell{font-family:var(--font-display);font-weight:600;font-size:1.1rem}
.rec-table .score-cell{font-family:var(--font-display);font-weight:600;color:var(--brass-bright);font-size:1.15rem}
.rec-table td.muted{color:var(--bone-dim);font-size:.86rem}
@media(max-width:620px){
  .rec-table .hide-sm{display:none}
  .rec-table td{padding:.9rem .5rem;font-size:.88rem}
  .rec-table .rk{font-size:1.2rem;width:40px}
}
