/* ============================================================
   components.css — reusable content components across pages
   ============================================================ */

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:var(--navy-800);color:#fff;position:relative;overflow:hidden;padding:clamp(56px,8vw,96px) 0 clamp(48px,6vw,72px)}
.page-hero::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(120% 90% at 80% 0,#000,transparent 75%);pointer-events:none}
.page-hero .container{position:relative;z-index:1}
.page-hero .eyebrow{color:#8aa0b3}
.page-hero .eyebrow::before{background:#8aa0b3}
.page-hero h1{color:#fff;margin:16px 0 0;max-width:18ch}
.page-hero .lead{color:#b9c6d2;margin-top:18px;max-width:62ch}
.crumb{display:flex;gap:8px;align-items:center;font-size:.84rem;color:#8aa0b3;font-family:var(--font-mono)}
.crumb a:hover{color:#fff}
.crumb span{opacity:.5}

/* ---------- Stat band ---------- */
.stat-band{background:var(--navy-700);color:#fff;position:relative;overflow:hidden}
.stat-band::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:52px 52px;mask-image:radial-gradient(130% 100% at 50% 0,#000,transparent 80%)}
.stat-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:clamp(48px,6vw,76px) 0}
.stat{text-align:center;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:14%;height:72%;width:1px;background:rgba(255,255,255,.14)}
.stat .num{font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,4.5vw,3.4rem);line-height:1;letter-spacing:-.02em;display:flex;justify-content:center;align-items:baseline}
.stat .lab{margin-top:12px;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:#9fb6c8;font-family:var(--font-mono)}
.stat .sub{font-size:.78rem;color:#7f97aa;margin-top:4px}
@media (max-width:760px){.stat-grid{grid-template-columns:1fr 1fr;gap:34px 20px}.stat:nth-child(2)::after{display:none}}

/* ---------- Discipline accordion (home) ---------- */
.disc-acc{display:flex;gap:14px;min-height:420px;align-items:stretch}
.disc-panel{
  position:relative;flex:1;min-width:0;border-radius:var(--r-md);overflow:hidden;cursor:pointer;
  background:#fff;border:1px solid var(--line);
  transition:flex .5s cubic-bezier(.4,0,.2,1),box-shadow .3s ease,border-color .3s;
  display:flex;
}
.disc-panel[data-accent="m"]{--ac:var(--mech);--ac-ink:var(--mech-ink);--ac-soft:var(--mech-soft);--ac-line:var(--mech-line)}
.disc-panel[data-accent="e"]{--ac:var(--elec);--ac-ink:var(--elec-ink);--ac-soft:var(--elec-soft);--ac-line:var(--elec-line)}
.disc-panel[data-accent="p"]{--ac:var(--plumb);--ac-ink:var(--plumb-ink);--ac-soft:var(--plumb-soft);--ac-line:var(--plumb-line)}
.disc-panel.active{flex:3.4;box-shadow:var(--shadow-lg);border-color:var(--ac-line)}
.disc-panel::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--ac)}
.disc-collapsed{display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:28px 0;width:100%;min-width:74px}
.disc-panel.active .disc-collapsed{display:none}
.disc-ico{width:50px;height:50px;border-radius:12px;background:var(--ac-soft);color:var(--ac-ink);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.disc-ico svg{width:26px;height:26px}
.disc-vlabel{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--font-head);font-weight:800;font-size:1.4rem;color:var(--navy-700);letter-spacing:.02em}
.disc-num{font-family:var(--font-mono);font-size:.8rem;color:var(--ac-ink)}
.disc-full{display:none;flex-direction:column;padding:34px;width:100%;min-width:420px}
.disc-panel.active .disc-full{display:flex;animation:fadeUp .5s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.disc-full .disc-ico{margin-bottom:20px}
.disc-full h3{font-size:1.55rem;color:var(--navy-800)}
.disc-full .disc-sub{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ac-ink);margin-bottom:14px}
.disc-full p{color:var(--slate);margin:6px 0 18px;font-size:1rem}
.disc-std{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:auto}
.disc-std .chip{font-family:var(--font-mono);font-size:.72rem;background:var(--ac-soft);color:var(--ac-ink);padding:5px 10px;border-radius:6px;border:1px solid var(--ac-line)}
.disc-link{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-weight:600;color:var(--ac-ink)}
.disc-link svg{width:18px;height:18px;transition:transform .2s}
.disc-panel.active:hover .disc-link svg{transform:translateX(4px)}
.disc-meta{display:flex;gap:26px;margin:8px 0 20px}
.disc-meta div .k{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2)}
.disc-meta div .v{font-family:var(--font-head);font-weight:800;font-size:1.3rem;color:var(--navy-800)}
@media (max-width:860px){
  .disc-acc{flex-direction:column;height:auto;min-height:0}
  .disc-panel{flex:none!important;box-shadow:var(--shadow-sm)}
  .disc-panel .disc-collapsed{flex-direction:row;justify-content:flex-start;gap:18px;padding:18px 22px}
  .disc-panel .disc-vlabel{writing-mode:horizontal-tb;transform:none;font-size:1.2rem}
  .disc-panel.active .disc-collapsed{display:none}
  .disc-full{min-width:0;padding:24px}
}

/* ---------- Resource / news card ---------- */
.res-card{display:flex;flex-direction:column;height:100%}
.res-card .res-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.res-card h4{color:var(--navy-800);line-height:1.3;margin-bottom:8px;transition:color .15s}
.res-card:hover h4{color:var(--navy-600)}
.res-card .res-desc{font-size:.92rem;color:var(--slate);margin-bottom:18px}
.res-card .res-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--line-2);font-family:var(--font-mono);font-size:.74rem;color:var(--slate-2)}
.res-card .res-type{display:flex;align-items:center;gap:6px}
.res-card .res-arrow{color:var(--navy-600);transition:transform .2s}
.res-card:hover .res-arrow{transform:translateX(3px)}

/* ---------- Event card ---------- */
.event-card{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start}
.event-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:78px;height:84px;border-radius:var(--r-sm);background:var(--navy-700);color:#fff;flex-shrink:0}
.event-date .d{font-family:var(--font-head);font-weight:800;font-size:1.9rem;line-height:1}
.event-date .m{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-top:4px;color:#aebecb}
.event-body h4{color:var(--navy-800);margin-bottom:6px}
.event-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:.84rem;color:var(--slate);margin-top:10px}
.event-meta span{display:flex;align-items:center;gap:6px}
.event-meta svg{width:15px;height:15px;color:var(--slate-2)}

/* ---------- Pillar card ---------- */
.pillar{display:flex;flex-direction:column;height:100%;position:relative;overflow:hidden}
.pillar .p-ico{width:54px;height:54px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:var(--bg-softer);color:var(--navy-700);margin-bottom:20px}
.pillar .p-ico svg{width:28px;height:28px}
.pillar h3{margin-bottom:10px}
.pillar p{color:var(--slate);font-size:.96rem;margin-bottom:20px}
.pillar .p-body{margin-bottom:22px}
.pillar .p-foot{margin-top:auto}
.pillar .p-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--navy-700)}
.pillar .p-link svg{width:18px;height:18px;transition:transform .2s}
.pillar .p-link:hover svg{transform:translateX(4px)}
.mini-tags{display:flex;flex-wrap:wrap;gap:7px}
.tier-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line-2);font-size:.9rem}
.tier-row:last-child{border-bottom:0}
.tier-row .tr-name{font-weight:500;color:var(--navy-800)}
.tier-row .tr-fee{font-family:var(--font-mono);color:var(--slate);font-size:.84rem}

/* ---------- Profile card (committee) ---------- */
.profile{text-align:left}
.profile .p-photo{aspect-ratio:1/1;border-radius:var(--r-md) var(--r-md) 0 0;overflow:hidden}
.profile .p-photo .ph{height:100%;border-radius:0;border:0;border-bottom:1px solid var(--line)}
.profile .p-info{padding:20px 22px 24px}
.profile .post-tag{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--navy-600);font-weight:500}
.profile h4{margin:8px 0 4px;font-size:1.18rem;color:var(--navy-800)}
.profile .p-bio{font-size:.88rem;color:var(--slate);margin-top:8px}
.profile .p-social{display:flex;gap:8px;margin-top:16px}
.profile .p-social a{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;background:var(--bg-soft);color:var(--slate);transition:.15s}
.profile .p-social a:hover{background:var(--navy-700);color:#fff}
.profile .p-social svg{width:16px;height:16px}
.profile.lead-card{box-shadow:var(--shadow-md);border-color:var(--navy-600)}

/* ---------- Doc card ---------- */
.doc-card{display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;padding:24px 26px}
.doc-ico{width:54px;height:66px;border-radius:6px;background:var(--bg-soft);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--navy-600);position:relative}
.doc-ico svg{width:26px;height:26px}
.doc-ico .ext{position:absolute;bottom:-1px;left:-1px;font-family:var(--font-mono);font-size:.56rem;background:var(--navy-700);color:#fff;padding:2px 5px;border-radius:0 5px 0 5px;letter-spacing:.05em}
.doc-card h4{color:var(--navy-800);margin-bottom:4px}
.doc-card .doc-meta{font-family:var(--font-mono);font-size:.76rem;color:var(--slate-2);display:flex;gap:14px;flex-wrap:wrap}
@media (max-width:620px){.doc-card{grid-template-columns:auto 1fr;gap:16px}.doc-card .btn{grid-column:1/-1}}

/* ---------- Filter bar (knowledge base / events) ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.search-field{position:relative;flex:1;min-width:240px}
.search-field svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--slate-2)}
.search-field input{width:100%;padding:14px 16px 14px 46px;border:1px solid var(--line);border-radius:var(--r-sm);font-family:var(--font-body);font-size:1rem;background:#fff;transition:border-color .15s,box-shadow .15s}
.search-field input:focus{outline:none;border-color:var(--navy-600);box-shadow:0 0 0 3px rgba(44,62,80,.1)}
.chip-filter{display:flex;flex-wrap:wrap;gap:8px}
.chip-btn{font-family:var(--font-mono);font-size:.76rem;font-weight:500;letter-spacing:.03em;padding:8px 14px;border-radius:7px;background:#fff;border:1px solid var(--line);color:var(--slate);transition:.15s;cursor:pointer}
.chip-btn:hover{border-color:var(--slate-2);color:var(--navy-800)}
.chip-btn.on{background:var(--navy-700);border-color:var(--navy-700);color:#fff}
.chip-btn.on.m{background:var(--mech);border-color:var(--mech)}
.chip-btn.on.e{background:var(--elec);border-color:var(--elec)}
.chip-btn.on.p{background:var(--plumb);border-color:var(--plumb)}
.result-count{font-family:var(--font-mono);font-size:.8rem;color:var(--slate-2)}
.no-results{padding:60px 20px;text-align:center;color:var(--slate);font-family:var(--font-mono);font-size:.9rem}
