@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=Italiana&display=swap');

:root {
  --ink: #17231d;
  --forest: #173d31;
  --forest-deep: #0e2c23;
  --cream: #f2eee4;
  --paper: #faf8f2;
  --gold: #c9a45c;
  --gold-light: #e1c47f;
  --red: #8f3e36;
  --blue: #315e7b;
  --muted: #777b72;
  --line: rgba(23, 35, 29, .16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "DM Sans", sans-serif;
  font-weight: 400;
}
body.drawer-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
button { color: inherit; }

.site-header {
  height: 86px;
  padding: 0 5vw;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: absolute;
  inset: 0 0 auto;
  z-index: 20;
  color: var(--cream);
  border-bottom: 1px solid rgba(255,255,255,.14);
}
.brand { display: flex; align-items: center; gap: 12px; font-size: 14px; font-weight: 600; letter-spacing: .02em; }
.brand em { color: var(--gold-light); font-family: "Italiana", serif; font-size: 17px; font-weight: 400; }
.brand-mark { width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid rgba(225,196,127,.5); border-radius: 50%; }
.brand-mark svg { width: 25px; fill: none; stroke: var(--gold-light); stroke-width: 1.5; }
.site-header nav { display: flex; gap: 34px; font-size: 12px; text-transform: uppercase; letter-spacing: .14em; }
.site-header nav a { opacity: .75; transition: .2s; }
.site-header nav a:hover { opacity: 1; color: var(--gold-light); }
.menu-button { display: none; background: none; border: 0; }

.hero {
  min-height: 920px;
  position: relative;
  overflow: hidden;
  padding: 190px 8vw 55px;
  color: var(--cream);
  background:
    radial-gradient(circle at 80% 39%, rgba(184,150,83,.12), transparent 24%),
    linear-gradient(120deg, var(--forest-deep), #17382e 64%, #102c24);
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .035;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E");
}
.hero-copy { position: relative; z-index: 2; width: 59%; max-width: 790px; }
.eyebrow, .section-number { text-transform: uppercase; letter-spacing: .2em; font-size: 10px; font-weight: 600; color: var(--gold); }
.eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 35px; }
.eyebrow span { display: block; width: 34px; height: 1px; background: var(--gold); }
h1, h2 { font-family: "Italiana", Georgia, serif; font-weight: 400; margin: 0; }
h1 { font-size: clamp(66px, 7.6vw, 124px); line-height: .91; letter-spacing: -.035em; }
h1 i, h2 i { color: var(--gold-light); font-weight: 400; }
.hero-intro { max-width: 550px; margin: 38px 0 40px; font-size: 17px; line-height: 1.75; color: rgba(242,238,228,.72); }
.hero-actions { display: flex; align-items: center; gap: 34px; }
.button { display: inline-flex; align-items: center; gap: 28px; padding: 17px 20px 17px 24px; text-transform: uppercase; letter-spacing: .13em; font-size: 10px; font-weight: 600; }
.button-primary { color: var(--forest-deep); background: var(--gold-light); }
.button span { font-size: 16px; }
.text-link { font-size: 11px; text-transform: uppercase; letter-spacing: .12em; border-bottom: 1px solid rgba(255,255,255,.3); padding: 10px 0; }
.text-link span { color: var(--gold-light); margin-left: 8px; }

.hero-emblem { position: absolute; z-index: 1; width: 420px; height: 480px; right: 7vw; top: 170px; text-align: center; }
.hero-emblem svg { width: 100%; filter: drop-shadow(0 20px 40px rgba(0,0,0,.18)); }
.emblem-line, .emblem-circle, .emblem-g { fill: none; stroke: var(--gold-light); stroke-width: 1.2; }
.emblem-line { opacity: .82; }
.emblem-circle { opacity: .34; }
.emblem-g { stroke-width: 2.2; }
.emblem-dot { fill: var(--gold-light); }
.hero-emblem p { margin: -4px 0 0; text-transform: uppercase; font-size: 9px; line-height: 1.7; letter-spacing: .23em; color: rgba(242,238,228,.5); }
.emblem-ring { position: absolute; inset: -18px; border: 1px solid rgba(225,196,127,.17); border-radius: 50%; animation: spin 40s linear infinite; }
.emblem-ring span { position: absolute; font-size: 8px; letter-spacing: .2em; text-transform: uppercase; color: rgba(225,196,127,.5); }
.emblem-ring span:nth-child(1) { top: 8%; left: 47%; }
.emblem-ring span:nth-child(2) { top: 48%; right: -5%; transform: rotate(90deg); }
.emblem-ring span:nth-child(3) { bottom: 7%; left: 42%; transform: rotate(180deg); }
.emblem-ring span:nth-child(4) { top: 48%; left: -8%; transform: rotate(-90deg); }
@keyframes spin { to { transform: rotate(360deg); } }
.hero-orbit { position: absolute; border: 1px solid rgba(225,196,127,.08); border-radius: 50%; }
.hero-orbit-one { width: 760px; height: 760px; right: -90px; top: 50px; }
.hero-orbit-two { width: 580px; height: 580px; right: 0; top: 140px; }
.hero-stats { position: absolute; z-index: 2; left: 8vw; right: 8vw; bottom: 48px; padding-top: 32px; display: flex; gap: 70px; border-top: 1px solid rgba(255,255,255,.13); }
.hero-stats div { display: flex; align-items: baseline; gap: 13px; }
.hero-stats strong { color: var(--gold-light); font-family: "Italiana", serif; font-size: 30px; font-weight: 400; }
.hero-stats span { max-width: 110px; color: rgba(242,238,228,.45); font-size: 9px; line-height: 1.4; text-transform: uppercase; letter-spacing: .12em; }

.intro-section { padding: 135px 8vw; display: grid; grid-template-columns: 1fr 1fr; gap: 9vw; background: var(--cream); }
.intro-section h2, .section-heading h2, .principles-section h2 { margin-top: 23px; font-size: clamp(52px, 5vw, 80px); line-height: 1; }
.intro-section h2 i, .orders-section h2 i, .principles-section h2 i { color: var(--forest); }
.intro-copy { padding-top: 34px; max-width: 600px; }
.intro-copy > p:first-child { font-family: "Italiana", Georgia, serif; font-size: 25px; line-height: 1.55; }
.fine-print { margin-top: 30px; padding-left: 20px; border-left: 2px solid var(--gold); color: var(--muted); font-size: 12px; line-height: 1.7; }

.map-section { padding: 120px 6vw 110px; background: var(--forest); color: var(--cream); overflow: hidden; }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 30px; margin: 0 auto 60px; max-width: 1500px; }
.section-heading h2 { margin-top: 18px; }
.section-number.light { color: var(--gold-light); }
.map-legend { display: flex; gap: 24px; font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.map-legend span { display: flex; align-items: center; gap: 8px; }
.legend-dot { width: 7px; height: 7px; border-radius: 50%; }
.legend-dot.universal { background: var(--gold-light); }
.legend-dot.christian { background: #a9665e; }
.legend-dot.invitational { border: 1px solid #e6ded0; }
.legend-dot.wider { background: transparent; border: 1px dashed var(--gold-light); border-radius: 0; transform: rotate(45deg); }
.map-shell { max-width: 1500px; margin: auto; position: relative; min-height: 880px; border: 1px solid rgba(255,255,255,.12); background: rgba(5,24,18,.25); overflow: auto hidden; }
.map-shell::before { content:""; position:absolute; inset:0; opacity:.08; background-image: linear-gradient(rgba(255,255,255,.2) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.2) 1px,transparent 1px); background-size:45px 45px; }
.map-toolbar { height: 60px; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; position: relative; z-index: 5; border-bottom: 1px solid rgba(255,255,255,.1); }
.map-toolbar p { font-size: 9px; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.45); }
.reset-map { border: 0; background: none; color: var(--gold-light); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; }
.tree { position: relative; min-width: 1530px; height: 820px; transition: .4s; }
.tree-svg { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.tree-svg path { fill: none; stroke: rgba(225,196,127,.28); stroke-width: 1.2; transition: .3s; }
.tree-svg path.muted { opacity: .12; }
.tree-svg path.active { stroke: var(--gold-light); stroke-width: 2; }
.tree-node {
  width: 130px; min-height: 70px; padding: 12px 10px; position: absolute; z-index: 2;
  border: 1px solid rgba(255,255,255,.15); background: #17382e; color: var(--cream);
  text-align: left; cursor: pointer; transition: .25s;
}
.tree-node:hover, .tree-node.active { border-color: var(--gold-light); transform: translateY(-3px); box-shadow: 0 10px 25px rgba(0,0,0,.2); }
.tree-node.muted { opacity: .25; }
.tree-node .node-number { display: block; margin-bottom: 8px; color: var(--gold-light); font-size: 8px; letter-spacing: .16em; }
.tree-node strong { display: block; font-family: "Italiana", serif; font-size: 15px; line-height: 1.15; font-weight: 400; }
.tree-node .node-dot { position: absolute; top: 9px; right: 9px; width: 6px; height: 6px; border-radius: 50%; background: var(--gold-light); }
.tree-node[data-category="christian"] .node-dot { background: #b36a60; }
.tree-node[data-invited="true"] .node-dot { background: transparent; border: 1px solid #eee5d6; }
.tree-node[data-scope="wider"] { border-style: dashed; background: #1d4035; }
.map-detail { position: absolute; z-index: 4; right: 0; bottom: 0; width: 310px; min-height: 190px; padding: 27px 30px; background: var(--gold-light); color: var(--forest-deep); }
.detail-kicker { margin: 0 0 12px; font-size: 8px; text-transform: uppercase; letter-spacing: .16em; opacity: .65; }
.map-detail h3 { margin: 0; font-family: "Italiana", serif; font-size: 27px; font-weight: 400; }
.map-detail > p:not(.detail-kicker) { min-height: 48px; font-size: 11px; line-height: 1.55; opacity: .78; }
.map-detail button { border: 0; border-bottom: 1px solid rgba(15,44,35,.35); padding: 5px 0; background: none; cursor: pointer; font-size: 9px; text-transform: uppercase; letter-spacing: .13em; }
.map-detail button span { margin-left: 8px; }

.orders-section { padding: 130px 7vw; background: var(--paper); }
.section-heading.dark { color: var(--ink); }
.section-heading.dark > p { max-width: 430px; color: var(--muted); font-size: 12px; line-height: 1.7; }
.filter-bar { max-width: 1500px; margin: 0 auto 42px; padding: 16px 0; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.search-box { width: 42%; display: flex; align-items: center; gap: 10px; }
.search-box span { font-size: 25px; color: var(--gold); transform: rotate(-20deg); }
.search-box input { width: 100%; padding: 10px; border: 0; outline: 0; background: transparent; color: var(--ink); font-size: 12px; }
.filter-buttons { display: flex; gap: 6px; }
.filter-buttons button { border: 1px solid var(--line); padding: 9px 14px; background: transparent; font-size: 9px; text-transform: uppercase; letter-spacing: .11em; cursor: pointer; }
.filter-buttons button.active { background: var(--forest); color: var(--cream); border-color: var(--forest); }
.order-grid { max-width: 1500px; margin: auto; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.order-card { min-height: 330px; padding: 27px; display: flex; flex-direction: column; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--paper); cursor: pointer; transition: .25s; }
.order-card:hover { background: var(--cream); transform: translateY(-4px); box-shadow: 0 13px 30px rgba(34,42,37,.08); }
.card-top { display: flex; justify-content: space-between; }
.card-number { color: var(--gold); font-size: 9px; letter-spacing: .13em; }
.card-symbol { width: 62px; height: 62px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; font-family: "Italiana", serif; color: var(--forest); font-size: 20px; }
.card-symbol.has-logo { padding: 7px; overflow: hidden; background: var(--cream); }
.card-symbol img { display: block; width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; }
.order-card h3 { margin: 33px 0 12px; font-family: "Italiana", serif; font-weight: 400; font-size: 25px; line-height: 1.08; }
.order-card > p { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.6; }
.card-bottom { margin-top: auto; padding-top: 20px; display: flex; justify-content: space-between; align-items: end; }
.qualification { max-width: 70%; font-size: 8px; line-height: 1.45; letter-spacing: .11em; text-transform: uppercase; }
.qualification span { display: block; margin-bottom: 5px; color: var(--muted); }
.card-arrow { font-size: 18px; color: var(--gold); }
.empty-state { text-align: center; padding: 60px; color: var(--muted); }

.ad-zone {
  position: relative;
  isolation: isolate;
  background: #eae5da;
  color: var(--ink);
}
.ad-zone-leaderboard, .ad-zone-content { padding: 30px 7vw; }
.ad-zone-leaderboard { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.ad-zone-content { background: #e5dfd2; border-top: 1px solid rgba(23,35,29,.12); border-bottom: 1px solid rgba(23,35,29,.12); }
.ad-label {
  display: block;
  max-width: 970px;
  margin: 0 auto 8px;
  color: #77756e;
  font-size: 7px;
  line-height: 1;
  letter-spacing: .16em;
  text-align: center;
  text-transform: uppercase;
}
.ad-slot {
  width: 100%;
  max-width: 970px;
  min-height: 100px;
  margin: auto;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.ad-zone-content .ad-slot { min-height: 250px; }
.ad-placeholder {
  width: 100%;
  min-height: inherit;
  display: none;
  place-items: center;
  align-content: center;
  gap: 7px;
  border: 1px dashed rgba(23,35,29,.23);
  color: rgba(23,35,29,.4);
  text-align: center;
  background: rgba(255,255,255,.16);
}
.ad-preview-mode .ad-placeholder { display: grid; }
.ad-placeholder strong { font-family: "Italiana", serif; font-size: 18px; font-weight: 400; }
.ad-placeholder span { font-size: 7px; text-transform: uppercase; letter-spacing: .15em; }
.ad-zone-infeed {
  grid-column: 1 / -1;
  min-height: 190px;
  padding: 24px 5%;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.ad-zone-infeed .ad-slot { min-height: 130px; }
.adsbygoogle { width: 100%; min-height: inherit; }

.pathway-section { padding: 120px 8vw; display: grid; grid-template-columns: .8fr 1.2fr; gap: 8vw; background: var(--forest-deep); color: var(--cream); }
.pathway-copy h2 { margin: 22px 0 35px; font-size: clamp(60px, 6vw, 94px); line-height: .92; }
.pathway-copy > p:not(.section-number):not(.pathway-note) { max-width: 430px; color: rgba(255,255,255,.65); line-height: 1.7; font-size: 14px; }
.pathway-note { max-width: 430px; margin-top: 35px; padding-left: 20px; border-left: 1px solid var(--gold); color: rgba(255,255,255,.4); font-size: 10px; line-height: 1.6; }
.pathway-tool { align-self: center; }
.tool-label { font-size: 9px; text-transform: uppercase; letter-spacing: .16em; color: var(--gold-light); }
.stage-options { border-top: 1px solid rgba(255,255,255,.16); }
.stage-options button { width: 100%; padding: 18px 14px; display: flex; align-items: center; gap: 25px; border: 0; border-bottom: 1px solid rgba(255,255,255,.16); background: transparent; color: rgba(255,255,255,.7); text-align: left; cursor: pointer; transition: .2s; }
.stage-options button:hover, .stage-options button.active { padding-left: 24px; color: var(--forest-deep); background: var(--gold-light); }
.stage-options button span { font-size: 9px; letter-spacing: .12em; opacity: .6; }
.pathway-result { min-height: 150px; margin-top: 28px; padding: 23px; border: 1px solid rgba(225,196,127,.35); }
.pathway-result > p { margin: 0; color: rgba(255,255,255,.45); font-size: 11px; }
.result-title { margin: 0 0 15px; color: var(--gold-light); font-family: "Italiana", serif; font-size: 22px; }
.result-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.result-tags button { border: 1px solid rgba(255,255,255,.2); padding: 8px 10px; background: rgba(255,255,255,.04); color: var(--cream); font-size: 9px; cursor: pointer; }

.principles-section { padding: 130px 8vw; background: var(--cream); }
.principles-grid { margin-top: 25px; display: grid; grid-template-columns: 1.3fr repeat(3, 1fr); gap: 45px; align-items: start; }
.principle { padding-top: 15px; border-top: 1px solid var(--line); }
.principle span { color: var(--gold); font-size: 9px; }
.principle h3 { margin: 30px 0 15px; font-family: "Italiana", serif; font-size: 22px; font-weight: 400; }
.principle p { color: var(--muted); font-size: 11px; line-height: 1.7; }

footer { padding: 85px 8vw 25px; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 70px; background: #0b211a; color: var(--cream); }
.footer-brand { display: flex; align-items: flex-start; gap: 18px; }
.brand-mark.small { width: 42px; flex: 0 0 42px; }
.footer-brand h2 { font-size: 29px; line-height: 1.05; }
.footer-copy p { margin: 0 0 18px; max-width: 370px; color: rgba(255,255,255,.45); font-size: 10px; line-height: 1.7; }
.footer-copy a { color: rgba(255,255,255,.7); border-bottom: 1px solid rgba(255,255,255,.2); }
.privacy-settings { padding: 0; border: 0; border-bottom: 1px solid rgba(255,255,255,.2); background: none; color: rgba(255,255,255,.7); font-size: inherit; cursor: pointer; }
.footer-links { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.footer-links h3 { margin: 0 0 8px; color: var(--gold-light); font-size: 9px; text-transform: uppercase; letter-spacing: .14em; }
.footer-links a { border-bottom: 1px solid rgba(255,255,255,.15); padding-bottom: 4px; font-size: 10px; color: rgba(255,255,255,.65); }
.copyright { grid-column: 1/-1; margin: 30px 0 0; padding-top: 20px; display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.1); color: rgba(255,255,255,.28); font-size: 8px; text-transform: uppercase; letter-spacing: .14em; }

.drawer-backdrop { position: fixed; z-index: 90; inset: 0; background: rgba(4,15,11,.68); opacity: 0; pointer-events: none; transition: .35s; backdrop-filter: blur(4px); }
.order-drawer { position: fixed; z-index: 100; top: 0; right: 0; bottom: 0; width: min(620px, 100%); padding: 70px 55px; overflow-y: auto; background: var(--paper); transform: translateX(102%); transition: .4s cubic-bezier(.77,0,.18,1); box-shadow: -20px 0 60px rgba(0,0,0,.22); }
.drawer-open .drawer-backdrop { opacity: 1; pointer-events: auto; }
.drawer-open .order-drawer { transform: translateX(0); }
.drawer-close { position: absolute; top: 22px; right: 25px; width: 40px; height: 40px; border: 1px solid var(--line); border-radius: 50%; background: transparent; font-size: 25px; font-weight: 300; cursor: pointer; }
.drawer-header { padding-bottom: 30px; border-bottom: 1px solid var(--line); }
.drawer-index { color: var(--gold); font-size: 9px; letter-spacing: .15em; text-transform: uppercase; }
.drawer-header h2 { margin: 22px 0 15px; font-size: 52px; line-height: .95; }
.drawer-full-name { color: var(--muted); font-size: 11px; line-height: 1.5; }
.drawer-badges { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; }
.drawer-badges span { padding: 7px 9px; border: 1px solid var(--line); font-size: 8px; text-transform: uppercase; letter-spacing: .11em; }
.drawer-image { min-height: 260px; margin: 28px 0 0; padding: 28px; display: grid; place-items: center; background: var(--cream); border: 1px solid var(--line); }
.drawer-image a { display: grid; width: 100%; place-items: center; }
.drawer-image img { display: block; width: 100%; height: 250px; object-fit: contain; mix-blend-mode: multiply; }
.drawer-image figcaption { width: 100%; margin-top: 18px; padding-top: 13px; display: flex; justify-content: space-between; gap: 15px; border-top: 1px solid var(--line); color: var(--muted); font-size: 8px; line-height: 1.5; text-transform: uppercase; letter-spacing: .1em; }
.drawer-image figcaption a { display: inline; width: auto; color: var(--forest); white-space: nowrap; }
.drawer-image-unavailable { min-height: 250px; align-content: center; text-align: center; background: repeating-linear-gradient(135deg, var(--cream), var(--cream) 10px, #ebe5d8 10px, #ebe5d8 11px); }
.drawer-image-unavailable span { width: 90px; height: 90px; display: grid; place-items: center; border: 1px solid var(--gold); border-radius: 50%; color: var(--forest); font-family: "Italiana", serif; font-size: 27px; }
.drawer-image-unavailable p { max-width: 300px; margin: 20px auto 0; color: var(--muted); font-size: 10px; line-height: 1.6; text-transform: uppercase; letter-spacing: .08em; }
.drawer-facts { margin-top: 28px; display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.drawer-facts div { min-height: 105px; padding: 17px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.drawer-facts span { display: block; margin-bottom: 10px; color: var(--gold); font-size: 7px; text-transform: uppercase; letter-spacing: .14em; }
.drawer-facts strong { display: block; color: var(--forest); font-family: "Italiana", serif; font-size: 16px; line-height: 1.4; font-weight: 400; }
.drawer-section { padding: 27px 0; border-bottom: 1px solid var(--line); }
.drawer-section h3 { margin: 0 0 13px; color: var(--gold); font-size: 9px; text-transform: uppercase; letter-spacing: .15em; }
.drawer-section p { margin: 0; color: #4f5751; font-family: "Italiana", serif; font-size: 20px; line-height: 1.55; }
.drawer-section.requirement p { padding: 18px; border-left: 3px solid var(--gold); background: var(--cream); font-family: "DM Sans", sans-serif; font-size: 12px; line-height: 1.65; }
.themes { display: flex; flex-wrap: wrap; gap: 8px; }
.themes span { padding: 8px 10px; background: var(--forest); color: var(--cream); font-size: 9px; }
.source-link { display: inline-block; margin-top: 30px; padding-bottom: 5px; border-bottom: 1px solid var(--gold); color: var(--forest); font-size: 10px; text-transform: uppercase; letter-spacing: .12em; }
.drawer-gallery { margin: 28px 0 0; }
.drawer-gallery figure { margin: 0; background: var(--cream); border: 1px solid var(--line); }
.drawer-gallery img { display: block; width: 100%; height: 260px; object-fit: cover; }
.drawer-gallery figcaption { padding: 11px 14px; color: var(--muted); font-size: 8px; text-transform: uppercase; letter-spacing: .1em; }
.drawer-references { padding: 30px 0 10px; }
.drawer-references h3 { margin: 0 0 12px; color: var(--gold); font-size: 9px; text-transform: uppercase; letter-spacing: .15em; }
.drawer-references a { padding: 13px 0; display: grid; grid-template-columns: 30px 1fr auto; gap: 8px; align-items: center; border-top: 1px solid var(--line); color: var(--forest); font-size: 11px; }
.drawer-references a:last-child { border-bottom: 1px solid var(--line); }
.drawer-references a span { color: var(--gold); font-size: 8px; }
.drawer-references a i { color: var(--gold); font-style: normal; }

.privacy-notice {
  position: fixed;
  z-index: 120;
  left: 24px;
  right: 24px;
  bottom: 24px;
  max-width: 940px;
  margin: auto;
  padding: 24px 28px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 35px;
  border: 1px solid rgba(225,196,127,.4);
  background: var(--forest-deep);
  color: var(--cream);
  box-shadow: 0 20px 50px rgba(0,0,0,.3);
}
.privacy-notice[hidden] { display: none; }
.privacy-kicker { margin: 0 0 8px; color: var(--gold-light); font-size: 8px; text-transform: uppercase; letter-spacing: .14em; }
.privacy-notice h2 { font-size: 25px; }
.privacy-notice div > p:last-child { max-width: 570px; margin: 10px 0 0; color: rgba(255,255,255,.55); font-size: 10px; line-height: 1.6; }
.privacy-actions { display: flex; gap: 8px; }
.privacy-actions a, .privacy-actions button { padding: 10px 12px; border: 1px solid rgba(255,255,255,.2); background: transparent; color: var(--cream); font-size: 8px; text-transform: uppercase; letter-spacing: .1em; cursor: pointer; }
.privacy-actions button { background: var(--gold-light); color: var(--forest-deep); border-color: var(--gold-light); }

.legal-page { background: var(--cream); }
.legal-header { min-height: 85px; padding: 20px 8vw; display: flex; align-items: center; background: var(--forest-deep); color: var(--cream); }
.legal-content { max-width: 850px; margin: auto; padding: 100px 28px 130px; }
.legal-content > h1 { margin: 25px 0 35px; color: var(--forest); font-size: clamp(55px, 8vw, 95px); }
.legal-intro { padding: 24px; border-left: 3px solid var(--gold); background: var(--paper); color: var(--muted); line-height: 1.7; }
.legal-content section { padding: 35px 0; border-bottom: 1px solid var(--line); }
.legal-content section h2 { margin-bottom: 15px; color: var(--forest); font-size: 28px; }
.legal-content section p { margin: 0; color: #535b55; font-size: 13px; line-height: 1.8; }
.legal-back { display: inline-block; margin-top: 40px; padding-bottom: 5px; border-bottom: 1px solid var(--gold); color: var(--forest); font-size: 10px; text-transform: uppercase; letter-spacing: .12em; }

@media (max-width: 1100px) {
  .hero { min-height: 870px; }
  .hero-copy { width: 67%; }
  .hero-emblem { right: -80px; opacity: .45; }
  .order-grid { grid-template-columns: repeat(3, 1fr); }
  .principles-grid { grid-template-columns: 1fr 1fr; }
  .principles-grid h2 { grid-column: 1/-1; }
}

@media (max-width: 780px) {
  .site-header { height: 70px; padding: 0 20px; }
  .site-header nav { position: absolute; top: 70px; left: 0; right: 0; padding: 25px; display: none; flex-direction: column; background: var(--forest-deep); }
  .site-header.menu-open nav { display: flex; }
  .menu-button { display: grid; gap: 5px; }
  .menu-button span { width: 23px; height: 1px; background: var(--cream); }
  .hero { min-height: 850px; padding: 145px 24px 45px; }
  .hero-copy { width: 100%; }
  h1 { font-size: 62px; }
  .hero-emblem { width: 270px; height: 300px; top: 450px; right: -75px; opacity: .32; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 14px; }
  .hero-stats { left: 24px; right: 24px; bottom: 28px; gap: 18px; }
  .hero-stats div { gap: 7px; }
  .hero-stats strong { font-size: 22px; }
  .intro-section, .pathway-section { grid-template-columns: 1fr; padding: 85px 24px; }
  .intro-section { gap: 35px; }
  .intro-copy { padding-top: 0; }
  .map-section, .orders-section, .principles-section { padding: 85px 20px; }
  .section-heading { align-items: flex-start; flex-direction: column; }
  .map-legend { flex-wrap: wrap; }
  .map-shell { overflow-x: auto; }
  .map-detail { position: sticky; left: calc(100vw - 350px); }
  .filter-bar { align-items: stretch; flex-direction: column; gap: 15px; }
  .search-box { width: 100%; }
  .filter-buttons { overflow-x: auto; }
  .filter-buttons button { white-space: nowrap; }
  .order-grid { grid-template-columns: 1fr 1fr; }
  .order-card { min-height: 290px; padding: 20px; }
  .ad-zone-leaderboard, .ad-zone-content { padding: 22px 20px; }
  .ad-zone-content .ad-slot { min-height: 220px; }
  .principles-grid { grid-template-columns: 1fr; gap: 25px; }
  .principles-grid h2 { grid-column: auto; }
  footer { grid-template-columns: 1fr; gap: 35px; padding: 70px 24px 25px; }
  .copyright { gap: 20px; flex-direction: column; }
  .order-drawer { padding: 70px 28px; }
  .drawer-facts { grid-template-columns: 1fr; }
  .drawer-facts div { min-height: auto; }
  .privacy-notice { grid-template-columns: 1fr; gap: 18px; }
}

@media (max-width: 480px) {
  .brand > span:last-child { font-size: 11px; }
  .brand em { font-size: 14px; }
  h1 { font-size: 52px; }
  .hero-intro { font-size: 14px; }
  .hero-stats span { display: none; }
  .order-grid { grid-template-columns: 1fr; }
  .order-card { min-height: 270px; }
  .ad-slot { min-height: 100px; }
  .ad-zone-content .ad-slot { min-height: 250px; }
  .ad-zone-infeed { min-height: 300px; padding: 20px; }
  .ad-zone-infeed .ad-slot { min-height: 250px; }
  .pathway-copy h2 { font-size: 60px; }
  .drawer-header h2 { font-size: 43px; }
  .privacy-notice { left: 12px; right: 12px; bottom: 12px; padding: 20px; }
  .privacy-actions { flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}

/* Country guides */
.country-page { background: var(--paper); }
.country-header { min-height: 82px; padding: 0 6vw; display: flex; align-items: center; justify-content: space-between; background: var(--forest-deep); color: var(--cream); border-bottom: 1px solid rgba(255,255,255,.12); }
.country-header nav { display: flex; gap: 25px; }
.country-header nav a { padding: 8px 0; color: rgba(255,255,255,.55); font-size: 9px; text-transform: uppercase; letter-spacing: .13em; }
.country-header nav a.active { color: var(--gold-light); border-bottom: 1px solid var(--gold-light); }
.country-hero { min-height: 650px; padding: 130px 8vw 100px; position: relative; display: flex; align-items: center; overflow: hidden; background: var(--forest); color: var(--cream); }
.country-hero::before { content:""; position:absolute; inset:0; opacity:.08; background-image: linear-gradient(rgba(255,255,255,.2) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.2) 1px,transparent 1px); background-size:55px 55px; }
.country-hero > div:first-child { position: relative; z-index: 2; max-width: 850px; }
.country-hero h1 { font-size: clamp(75px, 9vw, 135px); }
.country-hero > div > p:last-child { max-width: 600px; margin-top: 35px; color: rgba(255,255,255,.65); font-size: 16px; line-height: 1.75; }
.country-monogram { position: absolute; right: 6vw; width: 330px; height: 330px; display: grid; place-items: center; border: 1px solid rgba(225,196,127,.28); border-radius: 50%; color: rgba(225,196,127,.3); font-family: "Italiana",serif; font-size: 110px; }
.country-monogram::before,.country-monogram::after { content:""; position:absolute; border:1px solid rgba(225,196,127,.12); border-radius:50%; }
.country-monogram::before { inset:-55px; }.country-monogram::after { inset:-115px; }
.usa-hero { background: #20364a; }
.country-intro { padding: 120px 8vw; display: grid; grid-template-columns: .8fr 1.2fr; gap: 10vw; background: var(--cream); }
.country-intro h2 { margin-top: 20px; color: var(--forest); font-size: clamp(55px,6vw,85px); line-height:.98; }
.country-lead { margin: 0; font-family:"Italiana",serif; font-size:26px; line-height:1.55; }
.country-callout { margin-top:35px; padding:22px; border-left:3px solid var(--gold); background:var(--paper); }
.country-callout strong { color:var(--forest); font-size:10px; text-transform:uppercase; letter-spacing:.13em; }
.country-callout p { margin:10px 0 0; color:var(--muted); font-size:12px; line-height:1.7; }
.country-paths { padding:120px 7vw; background:var(--forest); color:var(--cream); }
.country-section-heading { max-width:1400px; margin:0 auto 55px; }
.country-section-heading h2 { margin:20px 0; font-size:clamp(55px,6vw,90px); }
.country-section-heading > p:last-child { max-width:620px; color:rgba(255,255,255,.55); font-size:12px; line-height:1.7; }
.series-grid { max-width:1400px; margin:auto; display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid rgba(255,255,255,.15); border-left:1px solid rgba(255,255,255,.15); }
.series-card { min-height:480px; padding:32px; border-right:1px solid rgba(255,255,255,.15); border-bottom:1px solid rgba(255,255,255,.15); }
.series-card.featured { background:var(--gold-light); color:var(--forest-deep); }
.series-card > span { font-size:8px; text-transform:uppercase; letter-spacing:.14em; color:var(--gold-light); }
.series-card.featured > span { color:rgba(14,44,35,.55); }
.series-card h3 { min-height:75px; margin:28px 0; font-family:"Italiana",serif; font-size:32px; font-weight:400; }
.series-card ol { padding:0; margin:0; list-style:none; counter-reset:series; }
.series-card li { padding:17px 0; display:grid; grid-template-columns:1fr; border-top:1px solid rgba(255,255,255,.14); counter-increment:series; }
.series-card.featured li { border-color:rgba(14,44,35,.18); }
.series-card b { font-size:12px; font-weight:500; }.series-card small { margin-top:5px; opacity:.55; font-size:9px; }
.series-card > p { color:rgba(255,255,255,.6); font-size:13px; line-height:1.8; }
.featured > p { color:rgba(14,44,35,.7); }
.differences-section { padding:120px 8vw; background:var(--cream); }
.country-section-heading.dark { color:var(--ink); }
.country-section-heading.dark h2 i { color:var(--forest); }
.difference-grid { max-width:1400px; margin:auto; display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--line); border-left:1px solid var(--line); }
.difference-grid article { min-height:280px; padding:27px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); }
.difference-grid span { color:var(--gold); font-size:9px; }.difference-grid h3 { margin:40px 0 15px; font-family:"Italiana",serif; font-size:24px; font-weight:400; }
.difference-grid p { color:var(--muted); font-size:11px; line-height:1.7; }
.country-bodies { padding:120px 8vw; background:var(--paper); }
.country-bodies .country-section-heading > p:last-child { color:var(--muted); }
.body-grid { max-width:1400px; margin:auto; display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--line); border-left:1px solid var(--line); }
.body-card { min-height:360px; padding:34px; display:grid; grid-template-columns:150px 1fr; gap:35px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); }
.body-mark { width:150px; height:150px; display:grid; place-items:center; align-self:start; background:#fff; border:1px solid var(--line); }
.body-mark img { width:115px; height:115px; object-fit:contain; }
.body-mark.wide img { width:130px; height:90px; }
.body-card span,.jurisdiction-card > span,.rite-grid span,.route-facts span { color:var(--gold); font-size:8px; text-transform:uppercase; letter-spacing:.14em; }
.body-card h3 { margin:18px 0; color:var(--forest); font-family:"Italiana",serif; font-size:28px; font-weight:400; }
.body-card p { color:var(--muted); font-size:11px; line-height:1.8; }
.body-card div > a,.jurisdiction-card > a,.route-intro a,.route-facts a,.rite-grid a { margin-top:22px; display:inline-block; color:var(--forest); border-bottom:1px solid var(--gold); font-size:9px; text-transform:uppercase; letter-spacing:.1em; }
.letter-mark { color:var(--forest); font-family:"Italiana",serif; font-size:48px; }
.usa-jurisdictions { background:var(--cream); }
.jurisdiction-grid { max-width:1400px; margin:auto; display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); }
.jurisdiction-card { min-height:490px; padding:50px; background:var(--paper); }
.jurisdiction-card.prince-hall { background:#ece5d8; }
.jurisdiction-card img { width:135px; height:135px; margin-bottom:35px; object-fit:contain; }
.jurisdiction-card h3 { margin:18px 0; color:var(--forest); font-family:"Italiana",serif; font-size:38px; font-weight:400; }
.jurisdiction-card p { max-width:600px; color:var(--muted); font-size:12px; line-height:1.85; }
.route-detail { padding:120px 8vw; background:var(--cream); }
.route-intro { max-width:1400px; margin:auto; display:grid; grid-template-columns:.65fr 1.35fr; gap:8vw; align-items:center; }
.route-intro > img { width:min(330px,100%); justify-self:center; }
.route-intro h2 { margin:20px 0 30px; color:var(--forest); font-size:clamp(55px,6vw,85px); }
.route-intro p:not(.section-number) { max-width:680px; color:var(--muted); font-size:14px; line-height:1.9; }
.route-facts { max-width:1400px; margin:80px auto 0; display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); border-left:1px solid var(--line); }
.route-facts article { min-height:300px; padding:32px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); }
.route-facts h3 { margin:30px 0 16px; color:var(--forest); font-family:"Italiana",serif; font-size:28px; font-weight:400; }
.route-facts p { color:var(--muted); font-size:11px; line-height:1.8; }
.rite-compare { padding:120px 8vw; background:#20364a; color:var(--cream); }
.rite-grid { max-width:1400px; margin:auto; display:grid; grid-template-columns:1fr 1fr; border-top:1px solid rgba(255,255,255,.15); border-left:1px solid rgba(255,255,255,.15); }
.rite-grid article { min-height:500px; padding:50px; border-right:1px solid rgba(255,255,255,.15); border-bottom:1px solid rgba(255,255,255,.15); }
.rite-grid img { width:260px; height:130px; margin-bottom:40px; object-fit:contain; object-position:left center; filter:brightness(0) invert(1); }
.rite-eagle { width:130px; height:130px; margin-bottom:40px; display:grid; place-items:center; border:1px solid var(--gold-light); border-radius:50%; color:var(--gold-light); font-family:"Italiana",serif; font-size:42px; }
.rite-grid h3 { margin:20px 0; font-family:"Italiana",serif; font-size:38px; font-weight:400; }
.rite-grid p { color:rgba(255,255,255,.6); font-size:12px; line-height:1.85; }
.rite-grid a { color:var(--gold-light); }
.route-note { max-width:900px; margin:45px auto 0; padding-left:22px; border-left:2px solid var(--gold); color:rgba(255,255,255,.55); font-size:11px; line-height:1.8; }
.route-note a { color:var(--gold-light); border-bottom:1px solid rgba(225,196,127,.45); }
.american-family { background:var(--cream); }
.verify-section { padding:120px 8vw; display:grid; grid-template-columns:.8fr 1.2fr; gap:8vw; background:var(--paper); }
.verify-section h2 { margin-top:20px; color:var(--forest); font-size:clamp(55px,6vw,85px); }
.verify-section ol { margin:0; padding:0; list-style:none; border-top:1px solid var(--line); }
.verify-section li { padding:25px 5px; display:grid; grid-template-columns:45px 1fr; border-bottom:1px solid var(--line); }
.verify-section li > span { color:var(--gold); font-size:9px; }
.verify-section b { color:var(--forest); font-size:13px; font-weight:500; }
.verify-section p { margin:8px 0 0; color:var(--muted); font-size:10px; line-height:1.75; }
.country-sources { padding:120px 8vw; display:grid; grid-template-columns:.8fr 1.2fr; gap:8vw; background:var(--forest-deep); color:var(--cream); }
.country-sources h2 { margin-top:20px; font-size:clamp(55px,6vw,85px); }
.source-list { border-top:1px solid rgba(255,255,255,.15); }
.source-list a { padding:19px 10px; display:grid; grid-template-columns:35px 1fr auto; gap:15px; align-items:center; border-bottom:1px solid rgba(255,255,255,.15); transition:.2s; }
.source-list a:hover { padding-left:18px; background:rgba(255,255,255,.04); }
.source-list span { color:var(--gold-light); font-size:8px; }.source-list b { font-size:12px;font-weight:500; }.source-list i { color:rgba(255,255,255,.4); font-size:9px;font-style:normal; }
.next-country { padding:60px 8vw; display:flex; align-items:center; justify-content:space-between; background:var(--gold-light); color:var(--forest-deep); }
.next-country > p { font-size:9px;text-transform:uppercase;letter-spacing:.14em; }
.next-country a { display:flex;align-items:baseline;gap:25px; }.next-country strong { font-family:"Italiana",serif;font-size:34px;font-weight:400; }.next-country span { font-size:9px;text-transform:uppercase;letter-spacing:.12em; }
.country-footer { padding:35px 8vw; display:flex;justify-content:space-between;gap:25px;background:#091d17;color:rgba(255,255,255,.45);font-size:9px; }
.country-footer a { color:var(--gold-light); }

@media(max-width:780px){
  .country-header { padding:18px 20px; align-items:flex-start; gap:20px; flex-direction:column; }
  .country-header nav { width:100%; gap:15px; overflow:auto; }
  .country-hero { min-height:600px;padding:100px 24px; }.country-monogram{width:220px;height:220px;right:-70px;bottom:40px;font-size:70px;opacity:.5}
  .country-intro,.country-sources{grid-template-columns:1fr;padding:85px 24px;gap:45px}
  .series-grid{grid-template-columns:1fr}.series-card{min-height:auto}
  .country-paths,.differences-section,.country-bodies,.route-detail,.rite-compare,.verify-section{padding:85px 20px}
  .difference-grid{grid-template-columns:1fr 1fr}
  .body-grid,.jurisdiction-grid,.route-intro,.rite-grid,.verify-section{grid-template-columns:1fr}
  .body-card{grid-template-columns:110px 1fr;padding:25px;gap:22px;min-height:auto}.body-mark{width:110px;height:110px}.body-mark img{width:85px;height:85px}.body-mark.wide img{width:95px;height:70px}
  .jurisdiction-card,.rite-grid article{min-height:auto;padding:35px 25px}.route-facts{grid-template-columns:1fr}.route-facts article{min-height:auto}
  .route-intro>img{width:210px}.verify-section{gap:45px}
  .source-list a{grid-template-columns:30px 1fr}.source-list i{grid-column:2}
  .next-country{align-items:flex-start;flex-direction:column;gap:20px;padding:45px 24px}.next-country a{align-items:flex-start;flex-direction:column;gap:8px}
  .country-footer{flex-direction:column;padding:30px 24px}
}
@media(max-width:480px){.difference-grid{grid-template-columns:1fr}.country-hero h1{font-size:62px}.country-lead{font-size:22px}.body-card{grid-template-columns:1fr}.body-card h3,.jurisdiction-card h3,.rite-grid h3{font-size:30px}.jurisdiction-card img{width:105px;height:105px}}
