/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek-ext */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek-ext */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek-ext */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek-ext */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek-ext */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* =====================================================================
   SIMBUHAN BED — HI-FI EDITORIAL STYLESHEET
   "Be brave. Be the light." — campus journalism, the lamp.
   Palette: deep forest green · warm cream paper · brass gold · ink
   Type: Playfair Display (display serif) + Source Sans 3 (text/UI)
   ===================================================================== */

:root {
  --forest-900: #0f1f18;
  --forest-800: #15291f;
  --forest-700: #1c3a2c;
  --forest-600: #265240;
  --forest-300: #7c9a8b;

  --paper:      #f6f1e6;
  --paper-2:    #efe7d6;
  --card:       #fffdf8;
  --line:       #d9cfbb;
  --line-soft:  #e7dfcd;

  --gold-600:   #a07d2c;
  --gold-500:   #bd9540;
  --gold-400:   #d4ad55;
  --gold-glow:  rgba(189,149,64,0.22);

  --ink:        #1d2420;
  --ink-soft:   #4a554d;
  --ink-mute:   #74807a;
  --on-dark:    #f2ece0;
  --on-dark-mute:#aebdb2;

  --serif: "Playfair Display", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --sans:  "Source Sans 3", "Helvetica Neue", Arial, sans-serif;

  --maxw: 1240px;
  --gutter: clamp(20px, 4vw, 56px);

  --sh-sm: 0 1px 2px rgba(15,31,24,.06), 0 2px 8px rgba(15,31,24,.05);
  --sh-md: 0 4px 14px rgba(15,31,24,.08), 0 18px 50px -28px rgba(15,31,24,.45);
  --sh-lg: 0 10px 30px rgba(15,31,24,.12), 0 40px 80px -40px rgba(15,31,24,.5);

  --r: 4px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background-color: var(--paper);
  background-image:
    radial-gradient(120% 60% at 50% -10%, rgba(189,149,64,.06), transparent 60%),
    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.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  font-size: 17px;
}

/* ---------- LAYOUT ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }
.narrow { max-width: 760px; margin-inline: auto; }
section { padding-block: clamp(56px, 8vw, 104px); }
.sec-divider { border: none; border-top: 1px solid var(--line); margin: 0; }

/* ---------- TYPE ---------- */
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 700; line-height: 1.08; margin: 0; color: var(--ink); letter-spacing: -0.01em; }
.display { font-size: clamp(2.7rem, 6.2vw, 5.2rem); line-height: 1.015; font-weight: 800; letter-spacing: -0.022em; text-wrap: balance; }
.h2 { font-size: clamp(1.9rem, 3.6vw, 3rem); text-wrap: balance; }
.h3 { font-size: clamp(1.3rem, 2vw, 1.7rem); }
p { margin: 0 0 1rem; text-wrap: pretty; }
.lede { font-size: clamp(1.1rem, 1.5vw, 1.32rem); color: var(--ink-soft); line-height: 1.62; }
.muted { color: var(--ink-soft); }

.eyebrow, .label-caps {
  font-family: var(--sans); font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.2em; font-size: 0.72rem; color: var(--gold-600);
  display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before { content: ""; width: 22px; height: 1.5px; background: var(--gold-500); display: inline-block; }
.label-caps { color: var(--ink-mute); letter-spacing: 0.16em; }
.label-caps::before { display: none; }
.note { font-family: var(--sans); font-size: 0.82rem; color: var(--ink-mute); line-height: 1.6; }

/* ---------- IMAGE PLACEHOLDERS ---------- */
.ph {
  display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--forest-700), var(--forest-800));
  color: var(--on-dark-mute); font-family: var(--sans); font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; text-align: center; border-radius: var(--r);
  padding: 10px;
}
.ph::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(70% 90% at 30% 20%, rgba(189,149,64,.18), transparent 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.06'%3E%3Cpath d='M0 40h80M40 0v80'/%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}
.ph { z-index: 0; }
.ph--16x9 { aspect-ratio: 16/9; }
.ph--4x3  { aspect-ratio: 4/3; }
.ph--1x1, .ph--circle { aspect-ratio: 1/1; }
.ph--wide { aspect-ratio: 21/9; }
.ph--circle { border-radius: 50%; }
.ph--light { background: linear-gradient(135deg, var(--paper-2), #e3d9c4); color: var(--ink-mute); }
.ph--light::before { background-image: radial-gradient(70% 90% at 30% 20%, rgba(189,149,64,.16), transparent 55%); }

/* label chip inside placeholders */
.ph-label { position: relative; z-index: 1; padding: 6px 12px; border: 1px solid rgba(242,236,224,.26); border-radius: 2px; }
.ph--light .ph-label { border-color: rgba(116,128,122,.32); }

/* ---------- TAGS ---------- */
.tag {
  display: inline-flex; align-items: center; gap: 6px; font-family: var(--sans); font-weight: 700;
  font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 5px 10px;
  border: 1px solid var(--line); color: var(--ink-soft); background: var(--card); border-radius: 2px;
}
.tag--solid { background: var(--forest-700); color: var(--on-dark); border-color: var(--forest-700); }
.tag--gold  { background: transparent; color: var(--gold-600); border-color: var(--gold-500); }
.tag-row { display: flex; flex-wrap: wrap; gap: 8px; }

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 9px; font-family: var(--sans); font-weight: 700;
  font-size: 0.86rem; letter-spacing: 0.04em; padding: 14px 26px;
  border: 1.5px solid var(--forest-700); background: transparent; color: var(--forest-700);
  cursor: pointer; text-decoration: none; border-radius: 2px;
  transition: background .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.btn:hover { background: var(--forest-700); color: var(--on-dark); transform: translateY(-2px); box-shadow: var(--sh-md); }
.btn--solid { background: var(--forest-700); color: var(--on-dark); }
.btn--solid:hover { background: var(--forest-800); }
.btn--gold { background: var(--gold-500); border-color: var(--gold-500); color: var(--forest-900); }
.btn--gold:hover { background: var(--gold-400); border-color: var(--gold-400); }
.btn--ghost { border-color: var(--line); color: var(--ink-soft); }
.btn--ghost:hover { background: var(--card); color: var(--ink); border-color: var(--ink-soft); box-shadow: var(--sh-sm); }
.btn--on-dark { border-color: rgba(242,236,224,.5); color: var(--on-dark); background: transparent; }
.btn--on-dark:hover { background: var(--on-dark); color: var(--forest-800); border-color: var(--on-dark); }
.btn--gold.btn--on-dark { background: var(--gold-500); color: var(--forest-900); border-color: var(--gold-500); }
.btn--gold.btn--on-dark:hover { background: var(--gold-400); border-color: var(--gold-400); }

.arrow-link {
  font-family: var(--sans); font-weight: 700; font-size: 0.86rem; letter-spacing: 0.02em;
  color: var(--forest-700); text-decoration: none; display: inline-flex; gap: 8px; align-items: center;
  padding-bottom: 2px; border-bottom: 1.5px solid var(--gold-500); cursor: pointer;
  transition: gap .18s ease, color .18s ease; background: none;
}
.arrow-link:hover { gap: 13px; color: var(--gold-600); }

/* ---------- HEADER / NAV ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100; background: rgba(246,241,230,.82);
  backdrop-filter: saturate(150%) blur(12px); border-bottom: 1px solid var(--line);
  transition: box-shadow .2s ease, background .2s ease;
}
.site-header.is-stuck { box-shadow: var(--sh-sm); background: rgba(246,241,230,.95); }
.nav { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-block: 14px; }
.brand { display: flex; align-items: center; gap: 13px; text-decoration: none; color: inherit; cursor: pointer; }
.brand-mark { width: 34px; height: 40px; flex: none; }
/* recolor lamp marks via CSS (overrides SVG presentation attrs) */
.brand-mark path, .brand-mark rect, .brand-mark line { stroke: var(--forest-700); }
.brand-mark path:first-of-type { stroke: var(--gold-500); }
.hero-lamp path, .hero-lamp rect, .hero-lamp line { stroke: var(--forest-700); }
.hero-lamp path:first-of-type, .hero-lamp path:nth-of-type(2) { stroke: var(--gold-500); }
.brand-text { display: flex; flex-direction: column; line-height: 1; }
.wordmark { font-family: var(--serif); font-weight: 800; font-size: 1.55rem; letter-spacing: 0.02em; color: var(--ink); }
.brand-sub { font-family: var(--sans); font-weight: 700; font-size: 0.58rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-600); margin-top: 5px; }
.nav-links { display: flex; align-items: center; gap: 2px; }
.nav-link {
  font-family: var(--sans); font-weight: 600; font-size: 0.92rem; color: var(--ink-soft);
  text-decoration: none; padding: 9px 14px; border: none; background: none; cursor: pointer;
  border-radius: 2px; position: relative; white-space: nowrap;
}
.nav-link::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: 5px; height: 1.5px; background: var(--gold-500); transform: scaleX(0); transform-origin: left; transition: transform .2s ease; }
.nav-link:hover { color: var(--ink); }
.nav-link:hover::after { transform: scaleX(1); }
.nav-link.is-active { color: var(--forest-700); font-weight: 700; }
.nav-link.is-active::after { transform: scaleX(1); }
.nav-toggle { display: none; border: 1px solid var(--line); border-radius: 2px; }

/* ---------- PAGE SWITCH ---------- */
.page { display: none; }
.page.is-active { display: block; }

/* ---------- GRIDS ---------- */
.grid { display: grid; gap: clamp(22px, 2.6vw, 36px); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: clamp(30px, 4vw, 52px); flex-wrap: wrap; }
.sec-head .eyebrow { margin-bottom: 14px; }

/* ---------- EDITORIAL CARD ---------- */
.card {
  display: flex; flex-direction: column; background: var(--card); border: 1px solid var(--line-soft);
  border-radius: var(--r); overflow: hidden; box-shadow: var(--sh-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--line); }
.card .ph { border-radius: 0; }
.card-body { display: flex; flex-direction: column; gap: 11px; padding: 22px 22px 24px; }
.card h3 { font-size: 1.4rem; line-height: 1.14; }
.card .headline-link { color: inherit; text-decoration: none; cursor: pointer; }
.card .headline-link:hover { color: var(--forest-700); }
.card .byline { font-family: var(--sans); font-weight: 700; font-size: 0.74rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gold-600); }
.card p { font-size: 0.98rem; color: var(--ink-soft); margin: 0; }
.card .arrow-link { font-size: 0.8rem; margin-top: 2px; align-self: flex-start; }

/* ---------- HERO ---------- */
.hero { position: relative; padding-block: clamp(0px, 1vw, 5px); border-bottom: 1px solid var(--line); overflow: hidden; }
.hero-inner { display: grid; grid-template-columns: 1.45fr 1fr; gap: clamp(36px, 5vw, 76px); align-items: center; position: relative; z-index: 1; }
.hero-lamp-wrap { position: relative; display: flex; justify-content: center; }
.hero-lamp { width: 100%; max-width: 300px; filter: drop-shadow(0 18px 40px rgba(15,31,24,.16)); }
.hero-glow { position: absolute; z-index: 0; top: 6%; right: 2%; width: 46vw; max-width: 640px; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, var(--gold-glow), transparent 62%); pointer-events: none; }
.cta-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }

/* ---------- SPLIT / WHO WE ARE / DEPARTMENTS ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(34px, 5vw, 68px); align-items: start; }
.dept-block {
  border: 1px solid var(--line-soft); border-top: 3px solid var(--gold-500);
  padding: clamp(24px, 3vw, 36px); background: var(--card); border-radius: var(--r);
  box-shadow: var(--sh-sm); transition: transform .2s ease, box-shadow .2s ease;
}
.dept-block:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.dept-block .label-caps { display: block; margin-bottom: 6px; }
.dept-block .dept-name { font-family: var(--serif); font-weight: 800; font-size: clamp(1.7rem, 2.6vw, 2.4rem); margin-bottom: 12px; color: var(--forest-700); }

/* committee blocks inside departments */
.committee { padding-block: 20px; border-top: 1px solid var(--line-soft); }
.committee:first-of-type { border-top: none; padding-top: 4px; }
.committee .c-name { font-family: var(--serif); font-weight: 700; font-size: 1.25rem; color: var(--ink); }
.committee .c-fn { font-family: var(--sans); font-weight: 700; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--gold-600); margin: 4px 0 9px; }
.committee p { font-size: 0.97rem; color: var(--ink-soft); margin: 0; }

/* ---------- BANDS ---------- */
.band { position: relative; background: var(--forest-800); color: var(--on-dark); overflow: hidden; }
.band::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(60% 130% at 88% 50%, var(--gold-glow), transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.04'%3E%3Cpath d='M0 40h80M40 0v80'/%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}
.band > .wrap { position: relative; z-index: 1; }
.band .eyebrow { color: var(--gold-400); }
.band .eyebrow::before { background: var(--gold-400); }
.band h2 { color: var(--on-dark); }
.band p { color: var(--on-dark-mute); }
.band-inner { display: grid; grid-template-columns: 1.6fr 1fr; gap: 40px; align-items: center; }

.slim-band { position: relative; background: var(--forest-700); color: var(--on-dark); overflow: hidden; }
.slim-band::before { content: ""; position: absolute; inset: 0; background: radial-gradient(50% 140% at 80% 50%, var(--gold-glow), transparent 60%); pointer-events: none; }
.slim-band .wrap { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.slim-band .label-caps { color: var(--on-dark-mute); }
.slim-band .arrow-link { color: var(--on-dark); border-color: var(--gold-400); }
.slim-band .arrow-link:hover { color: var(--gold-400); }

/* ---------- MISSION HERO (about/join) ---------- */
.mission-hero { position: relative; border-bottom: 1px solid var(--line); overflow: hidden; }
.mission-hero::before { content: ""; position: absolute; top: -20%; right: -10%; width: 50vw; max-width: 680px; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, var(--gold-glow), transparent 62%); pointer-events: none; }
.mission-hero .wrap { position: relative; z-index: 1; }

/* mission statement pullout */
.pullout {
  font-family: var(--serif); font-weight: 700; font-style: italic;
  font-size: clamp(1.9rem, 4.4vw, 3.2rem); line-height: 1.2; color: var(--forest-700);
  text-align: center; border-top: 1px solid var(--gold-500); border-bottom: 1px solid var(--gold-500);
  padding-block: clamp(30px, 5vw, 54px); margin-block: clamp(32px, 5vw, 52px); position: relative;
}
.pullout::after { content: "✦"; position: absolute; left: 50%; bottom: -11px; transform: translateX(-50%); background: var(--paper); color: var(--gold-500); padding: 0 12px; font-size: 0.9rem; font-style: normal; }

/* ---------- EDITORIAL BOARD ---------- */
.role-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 2.6vw, 34px); }
.role-card { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 13px; }
.role-card .ph { width: 122px; }
.role-ph-name { width: 72%; height: 15px; background: var(--line); border-radius: 3px; }
.role-ph-role { width: 52%; height: 11px; background: var(--line-soft); border-radius: 3px; }

/* ---------- EDITORIAL BOARD ACCORDION ---------- */
.accordion { display: flex; flex-direction: column; gap: 16px; }
.acc-item { border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; background: var(--card); box-shadow: var(--sh-sm); }
.acc-trigger {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 20px;
  background: var(--forest-700); color: var(--on-dark); border: none; cursor: pointer;
  padding: 20px clamp(20px, 3vw, 32px); text-align: left;
  font-family: var(--serif); font-weight: 700; font-size: clamp(1.3rem, 2.4vw, 1.8rem);
  transition: background .2s ease;
}
.acc-trigger:hover { background: var(--forest-600); }
.acc-trigger .acc-yr-sub { font-family: var(--sans); font-weight: 600; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-400); display: block; margin-top: 4px; }
.acc-chevron { font-family: var(--sans); color: var(--gold-400); font-size: 1rem; transition: transform .3s ease; flex: none; }
.acc-item.is-open .acc-chevron { transform: rotate(180deg); }
.acc-panel { max-height: 0; overflow: hidden; transition: max-height .42s ease; }
.acc-item.is-open .acc-panel { max-height: 1400px; }
.acc-inner { display: grid; grid-template-columns: 55fr 45fr; gap: clamp(24px, 4vw, 44px); padding: clamp(24px, 3.5vw, 40px); align-items: start; }
.board-photo-cap { font-family: var(--sans); font-style: italic; font-size: 0.86rem; color: var(--ink-mute); margin-top: 12px; }

/* masthead table */
.masthead { width: 100%; border-collapse: collapse; font-family: var(--sans); }
.masthead caption { caption-side: top; text-align: left; font-weight: 700; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-600); padding: 16px 0 8px; }
.masthead + .masthead caption { padding-top: 26px; }
.masthead td { padding: 9px 12px; font-size: 0.94rem; border: none; }
.masthead tr:nth-child(odd) td { background: var(--paper-2); }
.masthead .m-rank { color: var(--ink); }
.masthead .m-member { text-align: right; color: var(--ink); font-weight: 600; }
.masthead .m-open { color: var(--gold-600); font-style: italic; font-weight: 600; }
.masthead .lvl-1 .m-rank { padding-left: 26px; }
.masthead .lvl-2 .m-rank { padding-left: 42px; color: var(--ink-soft); }
.board-note { font-family: var(--sans); font-style: italic; font-size: 0.86rem; color: var(--ink-soft); margin-top: 18px; }

/* ---------- FILTER BAR ---------- */
.filter-bar { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255,253,248,.9); backdrop-filter: blur(8px); position: sticky; top: 70px; z-index: 50; }
.filter-bar .wrap { display: flex; flex-wrap: wrap; gap: clamp(20px, 4vw, 52px); padding-block: 18px; }
.filter-group { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.filter-group > .label-caps { margin-right: 2px; }
.chip {
  font-family: var(--sans); font-weight: 700; font-size: 0.74rem; letter-spacing: 0.04em;
  padding: 7px 14px; border: 1px solid var(--line); background: var(--card); color: var(--ink-soft);
  cursor: pointer; border-radius: 100px; transition: all .15s ease;
}
.chip:hover { border-color: var(--forest-600); color: var(--forest-700); }
.chip.is-on { background: var(--forest-700); color: var(--on-dark); border-color: var(--forest-700); }

/* ---------- ARTICLE ---------- */
.breadcrumb { font-family: var(--sans); font-weight: 600; font-size: 0.78rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-mute); display: flex; gap: 9px; flex-wrap: wrap; align-items: center; }
.breadcrumb a { color: var(--gold-600); text-decoration: none; cursor: pointer; }
.breadcrumb a:hover { text-decoration: underline; }
.article-body { max-width: 700px; margin-inline: auto; }
.article-body p { font-family: var(--serif); font-size: 1.18rem; line-height: 1.78; color: var(--ink); font-weight: 400; }
.article-body img {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  margin: 24px 0;
}
.dropcap::first-letter { font-family: var(--serif); font-weight: 800; font-size: 4.4rem; line-height: 0.78; float: left; padding: 8px 14px 0 0; color: var(--forest-700); }
.pull-quote { font-family: var(--serif); font-weight: 700; font-style: italic; border-left: 3px solid var(--gold-500); padding: 6px 0 6px 26px; margin: 36px 0; font-size: 1.55rem; line-height: 1.36; color: var(--forest-700); }
.embed-block { border: 1px solid var(--line); background: var(--card); margin: 36px 0; border-radius: var(--r); overflow: hidden; box-shadow: var(--sh-sm); }
.embed-block .ph { border-radius: 0; }
.embed-cap { font-family: var(--sans); font-size: 0.82rem; color: var(--ink-mute); margin-top: 12px; font-style: normal; }

/* ---------- JOIN: ROLE DETAIL ---------- */
.role-detail {
  border: 1px solid var(--line-soft); border-top: 3px solid var(--gold-500);
  padding: clamp(22px, 2.4vw, 30px); background: var(--card); border-radius: var(--r);
  display: flex; flex-direction: column; gap: 7px; box-shadow: var(--sh-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}
.role-detail:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
.role-detail .r-fn { font-family: var(--sans); font-weight: 700; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gold-600); }
.role-detail .r-name { font-family: var(--serif); font-weight: 800; font-size: 1.55rem; color: var(--forest-700); }
.role-detail .r-tag { font-family: var(--serif); font-style: italic; font-weight: 600; color: var(--ink); margin-top: auto; padding-top: 12px; border-top: 1px solid var(--line-soft); }

/* ---------- JOIN: STEPS ---------- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 3vw, 36px); }
.step { position: relative; padding-top: 24px; border-top: 2px solid var(--forest-700); }
.step-num { font-family: var(--serif); font-weight: 800; font-size: 1.6rem; color: var(--gold-500); display: block; margin-bottom: 12px; line-height: 1; }
.step h3 { font-size: 1.22rem; margin-bottom: 8px; }
.step p { font-size: 0.95rem; color: var(--ink-soft); margin: 0; }

/* ---------- CONTACT ---------- */
.contact-cols { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 56px); }
.contact-card { border: 1px solid var(--line-soft); padding: clamp(26px, 3vw, 38px); background: var(--card); border-radius: var(--r); box-shadow: var(--sh-sm); }
.contact-card h3 { font-size: 1.5rem; margin-bottom: 16px; color: var(--forest-700); }
.contact-list { font-family: var(--sans); font-size: 1.02rem; line-height: 1.95; }
.contact-list a { color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--gold-500); }
.contact-list a:hover { color: var(--gold-600); }

form.wf { display: grid; gap: 20px; max-width: 760px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-family: var(--sans); font-weight: 700; font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-mute); }
.field input, .field select, .field textarea {
  font-family: var(--sans); font-size: 1rem; padding: 13px 15px; border: 1px solid var(--line);
  background: var(--card); border-radius: 2px; color: var(--ink); transition: border-color .15s ease, box-shadow .15s ease;
}
.field input::placeholder, .field textarea::placeholder { color: var(--ink-mute); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--forest-600); box-shadow: 0 0 0 3px var(--gold-glow); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

.find-us { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(28px, 5vw, 56px); align-items: center; }

/* ---------- FOOTER ---------- */
.site-footer { position: relative; border-top: 1px solid var(--line); background: var(--forest-900); color: var(--on-dark); overflow: hidden; }
.site-footer::before { content: ""; position: absolute; inset: 0; background: radial-gradient(40% 90% at 12% 0%, var(--gold-glow), transparent 55%); pointer-events: none; }
.footer-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.5fr 1fr 1.5fr; gap: clamp(28px, 5vw, 68px); padding-block: clamp(48px, 6vw, 76px); }
.site-footer .wordmark { color: var(--on-dark); }
.site-footer .brand-sub { color: var(--gold-400); }
.site-footer .brand-mark path, .site-footer .brand-mark rect, .site-footer .brand-mark line { stroke: var(--on-dark); }
.footer-col h4 { font-family: var(--sans); font-weight: 700; font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-400); margin-bottom: 18px; }
.footer-desc { font-family: var(--sans); font-size: 0.97rem; color: var(--on-dark-mute); max-width: 34ch; margin-top: 18px; }
.footer-motto { font-family: var(--serif); font-style: italic; font-weight: 600; font-size: 1.2rem; color: var(--on-dark); margin-top: 16px; }
.footer-nav { display: flex; flex-direction: column; gap: 11px; }
.footer-nav button { background: none; border: none; padding: 0; text-align: left; cursor: pointer; font-family: var(--sans); font-size: 1.02rem; color: var(--on-dark-mute); width: fit-content; border-bottom: 1px solid transparent; transition: color .15s ease, border-color .15s ease; }
.footer-nav button:hover { color: var(--on-dark); border-color: var(--gold-400); }
.footer-contact { font-family: var(--sans); font-size: 0.97rem; color: var(--on-dark-mute); line-height: 1.85; }
.footer-contact a { color: var(--on-dark); text-decoration: none; border-bottom: 1px solid var(--forest-600); word-break: break-word; }
.footer-contact a:hover { border-color: var(--gold-400); }
.footer-strip { position: relative; z-index: 1; border-top: 1px solid rgba(242,236,224,.12); padding-block: 20px; font-family: var(--sans); font-size: 0.78rem; letter-spacing: 0.04em; color: var(--on-dark-mute); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-lamp { max-width: 200px; }
  .band-inner { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr 1fr; }
  .grid-4, .role-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .steps { grid-template-columns: 1fr 1fr; }
  .find-us { grid-template-columns: 1fr; }
}
@media (max-width: 780px) {
  .nav-links { display: none; }
  .nav-links.is-open { display: flex; position: absolute; top: 100%; right: 0; left: 0; flex-direction: column; align-items: stretch; background: var(--paper); border-bottom: 1px solid var(--line); padding: 12px var(--gutter); gap: 2px; box-shadow: var(--sh-md); }
  .nav-toggle { display: inline-flex; }
  .filter-bar { position: static; }
}
@media (max-width: 600px) {
  .split, .grid-2, .grid-3, .grid-4, .role-grid, .contact-cols, .steps, .field-row, .footer-grid { grid-template-columns: 1fr; }
  .band-inner > div:last-child { justify-self: start; }
}

