

/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/global.css ===== */

:root { --ink: #141414; --muted: #5a5a5a; --paper: #ffffff; --line: #d7d7d7; --header: #f3f3f3; --hero: #e9e9e9; --seal: #f6f6f6; --accent: #a50020; --accent-soft: rgba(165,0,32,.22); --max: 1200px; --pad: clamp(16px, 3vw, 40px); --radius: 18px; --shadow: 0 8px 22px rgba(0,0,0,.08); }


* { box-sizing: border-box; }


html, body { height: 100%; }


body { margin: 0px; font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif; color: var(--ink); background: var(--paper); }


a { color: inherit; text-decoration: none; }


img { max-width: 100%; display: block; }


.sr-only { position: absolute; width: 1px; height: 1px; padding: 0px; margin: -1px; overflow: hidden; clip: rect(0px, 0px, 0px, 0px); white-space: nowrap; border: 0px; }


.inner { max-width: var(--max); margin: 0px auto; padding-left: var(--pad); padding-right: var(--pad); }


.priory-record-title { margin: 0px 0px 10px; font-family: "Playfair Display", Georgia, serif; font-size: clamp(1.2rem, 2vw, 2.1rem); line-height: 1.05; color: var(--ink); }


.priory-record-sub { margin: 0px; font-size: 0.95rem; line-height: 1.55; letter-spacing: 0.02em; color: var(--accent); max-width: none; }




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/public_header.css ===== */

.topbar { background: var(--header); border-bottom: 2px solid var(--accent); overflow: visible; }


.topbar .inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding-top: 14px; padding-bottom: 14px; position: relative; overflow: visible; }


.brand { min-width: 260px; }


.brand-mark { display: inline-flex; flex-direction: row; align-items: center; gap: 12px; padding: 6px 0px; letter-spacing: 0.04em; }


.brand-crest { height: 48px; width: auto; max-width: none; display: block; margin-top: 2px; }


.brand-text { display: flex; flex-direction: column; gap: 2px; }


.brand-kicker { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); }


.brand-name { font-family: Georgia, "Times New Roman", Times, serif; font-size: 18px; letter-spacing: 0.04em; }


.primary-nav { display: flex; align-items: center; justify-content: flex-end; gap: 22px; min-width: 360px; white-space: nowrap; }


.navlink { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); padding: 10px 2px; border-bottom: 1px solid transparent; }


.navlink:hover { color: var(--ink); border-bottom-color: var(--accent); border-bottom-width: 1.5px; }


.nav-item--dd { position: relative; display: inline-flex; align-items: center; }


.navlink--label { cursor: default; user-select: none; display: inline-flex; align-items: center; gap: 6px; }


.nav-caret { font-size: 10px; line-height: 1; transform: translateY(-1px); opacity: 0.85; }


.nav-dropdown { position: absolute; top: 100%; margin-top: 8px; left: 0px; min-width: 240px; background: var(--paper); border: 1px solid var(--line); box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 24px; padding: 10px 12px; display: none; z-index: 9999; }


.nav-item--dd:hover .nav-dropdown, .nav-item--dd:focus-within .nav-dropdown { display: block; }


.nav-dropdown::before { content: ""; position: absolute; left: 0px; right: 0px; top: -10px; height: 10px; }


.navlink--drop { display: block; padding: 10px 6px; border-bottom: 1px solid rgba(0, 0, 0, 0.06); text-transform: uppercase; letter-spacing: 0.16em; font-size: 12px; color: var(--muted); }


.navlink--drop:last-child { border-bottom: none; }


.navlink--drop { display: block; padding: 10px 6px 10px 10px; border-bottom: 1px solid rgba(0, 0, 0, 0.06); text-transform: uppercase; letter-spacing: 0.16em; font-size: 12px; color: var(--muted); position: relative; transition: color 0.15s; }


.navlink--drop:hover { color: var(--ink); }


.navlink--drop { border-bottom: 1px solid rgba(0, 0, 0, 0.06); }


.navlink--drop:hover { border-bottom-color: rgba(0, 0, 0, 0.06); }


.navlink--drop { border-bottom-width: 1px !important; }


.navlink--drop:hover { border-bottom-width: 1px !important; }


.navlink--drop:hover::before { content: ""; position: absolute; left: 0px; top: 50%; transform: translateY(-50%); width: 3px; height: 60%; background: var(--accent); }


.nav-item--dd.is-active > .navlink--label { color: var(--ink); border-bottom: 1.5px solid var(--accent); }


.navlink.is-active { color: var(--ink); border-bottom-color: var(--accent); border-bottom-width: 1.5px; }


@media (max-width: 900px) {
  .topbar .inner { flex-direction: column; align-items: center; gap: 10px; padding-bottom: 10px; }
  .brand { min-width: auto; text-align: center; }
  .primary-nav { width: 100%; justify-content: center; gap: 18px; border-top: 1px solid var(--line); padding-top: 10px; margin-top: 4px; min-width: 0px; flex-wrap: wrap; }
}


@media (max-width: 520px) {
  .navlink { font-size: 11px; letter-spacing: 0.14em; }
}




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/home/section1.css ===== */

.hero { position: relative; overflow: hidden; background: var(--hero); }


.hero::before { content: ""; position: absolute; inset: 0px; background-image: url("/assets/images/hero_background (1).png"); background-size: cover; background-position: center center; opacity: 1; z-index: 0; }


.hero .inner { position: relative; z-index: 3; padding-top: clamp(32px, 6vw, 76px); min-height: clamp(520px, 70vh, 760px); }


.hero-identity { position: absolute; left: clamp(24px, 4vw, 64px); bottom: 30px; }


.hero-identity .kicker { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin: 0px 0px 10px; text-shadow: rgba(255, 255, 255, 0.65) 0px 1px 0px; }


.hero-identity h1 { margin: 0px 0px 18px; font-family: Georgia, "Times New Roman", Times, serif; font-weight: 500; text-transform: uppercase; font-size: clamp(32px, 3.6vw, 50px); line-height: 1.02; letter-spacing: 0.015em; }


.hero-mission { margin: 0px; max-width: 42rem; font-size: 15px; line-height: 1.6; letter-spacing: 0.02em; color: var(--muted); }


.figure-wrap { display: flex; justify-content: flex-end; align-items: flex-end; }


.hero-curve { position: absolute; left: 0px; right: 0px; bottom: -2px; height: clamp(170px, 20vw, 300px); z-index: 2; pointer-events: none; }


.hero-curve svg { display: block; width: 100%; height: 100%; }


.inline-action { color: var(--accent); text-decoration: none; border-bottom: 1px solid rgba(165, 0, 32, 0.35); }


.inline-action:hover { border-bottom-color: var(--accent); }


@media (max-width: 900px) {
  .hero .inner { grid-template-columns: 1fr; align-items: start; padding-bottom: 160px; }
  .figure-wrap { justify-content: flex-start; }
  .hero-identity { max-width: 92vw; }
}


@media (max-width: 520px) {
  .hero-identity h1 { font-size: clamp(30px, 9vw, 40px); }
}


@media (max-width: 900px) {
  .hero-identity { position: static; padding: 0 var(--pad); margin-top: 24px; }
}




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/home/section2.css ===== */

.section--order-definition { background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.016), rgba(0, 0, 0, 0.06)); position: relative; border-bottom: 1px solid rgba(0, 0, 0, 0.18); overflow: visible; }


.order-definition-inner { width: min(90%, 100%); margin: 0px auto; padding-left: var(--pad, clamp(20px, 4vw, 64px)); padding-right: var(--pad, clamp(20px, 4vw, 64px)); backdrop-filter: blur(1px); border-left: 1px solid rgba(0, 0, 0, 0.08); border-right: 1px solid rgba(0, 0, 0, 0.08); position: relative; overflow: visible; }


.order-definition-rule { height: 1px; background: rgba(0, 0, 0, 0.12); }


.order-definition-rule.top { margin-bottom: clamp(28px, 4vw, 36px); }


.order-definition-head { margin-bottom: clamp(20px, 3vw, 28px); }


.order-definition-body { position: relative; display: block; padding-right: min(680px, 56%); }


.section--order-definition { position: relative; z-index: 10; isolation: isolate; }


.order-definition-figure { position: absolute; right: -200px; bottom: 0px; width: auto; z-index: 999; display: flex; justify-content: flex-end; align-items: flex-end; pointer-events: none; }


.order-definition-copy p { margin: 0px 0px 20px; font-size: clamp(16px, 1.25vw, 18px); line-height: 1.7; opacity: 0.92; }


.order-definition-copy p:last-child { margin-bottom: 0px; }


.order-definition-figure img { width: auto; height: 620px; max-height: none; display: block; transform: none; }


.order-definition-closure { position: relative; margin-top: 0px; padding: 14px 0px; display: flex; justify-content: center; align-items: center; background: linear-gradient(0deg, rgb(123, 30, 30) 60%, rgba(255, 255, 255, 0) 60%); z-index: 1; }


.order-definition-closure .rule { position: absolute; left: 0px; right: 0px; height: 1px; background: rgba(0, 0, 0, 0.12); }


.order-definition-closure img { width: 150px; height: auto; }


.section--order-definition { overflow: clip visible; }


.order-definition-inner, .order-definition-body { overflow: clip visible !important; }


@media (max-width: 900px) {
  .order-definition-figure { display: none !important; }
  .order-definition-body { padding-right: 0px !important; }
}




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/home/section3.css ===== */

.section--history { padding: 0px 2rem; background: rgb(255, 255, 255); border-top: 1px solid rgba(0, 0, 0, 0.12); }


.history-head { max-width: 150ch; margin: 0px auto; text-align: center; padding: 60px; }


.hc-lede { margin: 0px; line-height: 1.55; opacity: 0.92; }


.history-frame { display: block; align-items: stretch; }


.history-record { padding: 0px 40px; }


.record-list { margin: 0px; padding-left: 18px; line-height: 1.6; }


.record-list li { margin: 10px 0px; }


.record-foot { margin-top: 16px; padding-top: 14px; border-top: 1px solid rgba(0, 0, 0, 0.16); opacity: 0.9; line-height: 1.55; }


.history-rail { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(360px, 1fr); overflow-x: auto; }


.history-period { padding: 36px 40px; display: flex; flex-direction: column; position: relative; z-index: 1; }


.period-label { letter-spacing: 0.14em; text-transform: uppercase; font-size: 0.7rem; opacity: 0.65; }


.history-period h3 { margin: 6px 0px 10px; font-size: 1.15rem; }


.history-period p { margin: 0px 0px 16px; line-height: 1.55; max-width: 42ch; }


.period-media { margin-top: auto; height: 250px; border: 1px solid rgba(0, 0, 0, 0.14); background: rgba(0, 0, 0, 0.03); }


.history-period::before { content: ""; position: absolute; top: 24px; bottom: 24px; left: 0px; width: 3px; }


@media (max-width: 900px) {
  .history-frame { grid-template-columns: 1fr; }
  .history-record { border-right: 0px; border-bottom: 1px solid rgba(0, 0, 0, 0.2); padding-bottom: 32px; }
}




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/home/section4.css ===== */

.section--recent-work { --rw-paper: #ffffff; --rw-ink: #18212b; --rw-body: #2f2f2f; --rw-band: #bf0d23; padding: 10px 0px clamp(60px, 7vw, 96px); position: relative; background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.01), rgba(0, 0, 0, 0.043)); }


.section--recent-work::after { content: ""; position: absolute; left: 0px; right: 0px; bottom: 0px; height: 90px; background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.04)); pointer-events: none; }


.recent-work-inner { margin: 0px auto; padding: 0px clamp(12px, 2vw, 28px); }


.recent-work-head { max-width: 980px; margin: 0px auto clamp(36px, 4vw, 50px); text-align: center; }


.recent-work-grid { display: grid; grid-template-columns: repeat(4, minmax(0px, 1fr)); gap: clamp(14px, 1.4vw, 18px); align-items: stretch; padding: 0px 2rem; }


.recent-work-panel { display: flex; flex-direction: column; min-height: 100%; background: transparent; overflow: visible; }


.recent-work-panel-top { min-height: 90px; padding: 20px 18px 16px; display: flex; align-items: center; justify-content: center; text-align: center; border-bottom: 1px solid rgba(0, 0, 0, 0.08); }


.recent-work-panel-title { margin: 0px; font-size: clamp(1.08rem, 1.05vw, 1.18rem); line-height: 1.18; font-weight: 700; letter-spacing: 0.055em; text-transform: uppercase; color: var(--rw-ink); text-wrap: balance; }


.recent-work-panel-band { position: relative; margin-bottom: 18px; z-index: 1; }


.recent-work-panel-band::before { content: ""; position: absolute; top: 0px; left: 50%; transform: translate(-50%, -100%); width: 0px; height: 0px; border-left: 18px solid transparent; border-right: 18px solid transparent; border-bottom: 18px solid var(--rw-band); z-index: 3; }


.recent-work-panel-band::after { content: ""; position: absolute; bottom: 0px; left: 50%; transform: translate(-50%, 100%); width: 0px; height: 0px; border-left: 18px solid transparent; border-right: 18px solid transparent; border-top: 18px solid var(--rw-band); z-index: 3; }


.recent-work-panel-media { position: relative; margin: 0px; aspect-ratio: 3 / 2; overflow: hidden; background: rgb(243, 241, 236); border: 2px solid var(--rw-band); box-shadow: rgba(0, 0, 0, 0.12) 0px 2px 5px, rgba(255, 255, 255, 0.25) 0px 1px 0px inset; }


.recent-work-panel-media img { width: 100%; height: 100%; display: block; object-fit: cover; border: none; transform: scale(0.96); }


.recent-work-panel-media::after { content: ""; position: absolute; inset: 0px; pointer-events: none; box-shadow: rgba(255, 255, 255, 0.16) 0px 0px 0px 1px inset; }


.recent-work-panel-body { flex: 1 1 auto; padding: 26px 22px 22px; background: var(--rw-paper); margin-top: 10px; }


.recent-work-panel-divider { width: 42px; height: 2px; margin: 0px auto 12px; background: rgb(199, 194, 184); }


.recent-work-panel-teaser { max-width: 28ch; margin: 0px auto; font-size: 125%; line-height: 1.68; color: var(--rw-body); text-align: center; }


.recent-work-panel-foot { height: 16px; background: linear-gradient(rgb(245, 243, 238), rgb(235, 231, 223)); border-top: 1px solid rgba(0, 0, 0, 0.08); }


.recent-work-empty { max-width: 900px; margin: 0px auto; text-align: center; color: rgb(68, 68, 68); }


@media (max-width: 1180px) {
  .recent-work-grid { grid-template-columns: repeat(2, minmax(0px, 1fr)); gap: 22px; }
  .recent-work-panel-top { min-height: 82px; }
}


@media (max-width: 640px) {
  .section--recent-work { padding: 50px 0px 62px; }
  .recent-work-head { margin-bottom: 26px; }
  .recent-work-grid { grid-template-columns: 1fr; gap: 18px; }
  .recent-work-panel-top { min-height: auto; padding: 18px 16px 14px; }
  .recent-work-panel-band { margin-bottom: 16px; }
  .recent-work-panel-band::before, .recent-work-panel-band::after { border-left-width: 14px; border-right-width: 14px; }
  .recent-work-panel-band::before { border-bottom-width: 14px; }
  .recent-work-panel-band::after { border-top-width: 14px; }
  .recent-work-panel-media { border-width: 3px; }
  .recent-work-panel-body { padding: 22px 16px 16px; }
  .recent-work-panel-teaser { font-size: 0.95rem; line-height: 1.6; }
}




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/home/section5.css ===== */

.section--formation-evidence { background: var(--paper); }


.formation-evidence-inner { max-width: none; margin: 0px auto; padding: clamp(25px, 5vw, 60px) clamp(48px, 6vw, 96px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 56px); align-items: start; }


.formation-evidence-media { margin: 0px; }


.formation-evidence-img { width: 100%; height: clamp(240px, 30vw, 380px); border-radius: 6px; background-size: cover; background-position: center center; border: 1px solid rgba(0, 0, 0, 0.08); box-shadow: rgba(0, 0, 0, 0.08) 0px 4px 12px; }


.formation-evidence-body { border-top: 2px solid rgba(140, 0, 0, 0.2); padding-top: 16px; }


.formation-evidence-body p { margin: 0px 0px 14px; line-height: 1.65; }


.formation-evidence-closing { margin-top: 18px; font-weight: 500; }


@media (max-width: 900px) {
  .formation-evidence-inner { grid-template-columns: 1fr; }
  .formation-evidence-img { height: clamp(260px, 56vw, 460px); }
}




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/home/section6.css ===== */

.paths-inner { margin: 0px auto; }


.paths-head { text-align: center; }


.paths-title { font-family: var(--serif, ui-serif, Georgia, "Times New Roman", serif); font-size: clamp(28px, 3vw, 38px); letter-spacing: 0.02em; color: var(--ink); margin: 0px; }


.paths-lede { margin: 10px auto 0px; color: var(--muted); line-height: 1.55; }


.paths-rule { margin: 16px auto 0px; border: 0px; height: 2px; background: var(--accent); width: min(72ch, 100%); }


.paths-acct { max-width: 90ch; color: var(--muted); line-height: 1.55; font-size: 14px; text-align: center; }


.cards { width: 100%; display: flex; justify-content: center; }


.card--1 .card__img, .card--1 .card__img--hover { background-image: url("/assets/images/card1.jpg"); }


.card--2 .card__img, .card--2 .card__img--hover { background-image: url("/assets/images/card3a.png"); }


.card--3 .card__img, .card--3 .card__img--hover { background-image: url("/assets/images/card3b.png"); }


.card__img { visibility: hidden; background-size: cover; background-position: center center; background-repeat: no-repeat; width: 100%; height: 235px; border-top-left-radius: 12px; border-top-right-radius: 12px; }


.card__img--hover { transition: 0.2s ease-out; background-size: cover; background-position: center center; background-repeat: no-repeat; width: 100%; position: absolute; height: 235px; border-top-left-radius: 12px; border-top-right-radius: 12px; top: 0px; }


.card { margin-right: 25px; transition: 0.4s cubic-bezier(0.175, 0.885, 0, 1); background-color: rgb(255, 255, 255); width: 33.3%; position: relative; border-radius: 12px; overflow: hidden; box-shadow: rgba(0, 0, 0, 0.1) 0px 13px 10px -7px; border: 1px solid rgb(204, 204, 204); }


.card:hover { box-shadow: rgba(0, 0, 0, 0.1) 0px 30px 18px -8px; }


.card__info { z-index: 2; background-color: rgb(255, 255, 255); border-bottom-left-radius: 12px; border-bottom-right-radius: 12px; padding: 16px 24px 24px; }


.card__category { font-family: Raleway, sans-serif; text-transform: uppercase; font-size: 13px; letter-spacing: 2px; font-weight: 500; color: rgb(134, 134, 134); }


.card__title { margin-top: 5px; margin-bottom: 10px; font-family: "Roboto Slab", serif; }


.card__by { font-size: 12px; font-family: Raleway, sans-serif; font-weight: 500; }


.card__author { font-weight: 600; text-decoration: none; color: rgb(173, 125, 82); }


.card:hover .card__img--hover { height: 100%; opacity: 0.15; }


.card:hover .card__info { background-color: transparent; position: relative; }




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/support.css ===== */



/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/public_footer.css ===== */

.inst-footer { background: var(--paper); }


.inst-footer__inner { margin: 0px; padding: clamp(40px, 5vw, 72px) 0px clamp(24px, 3vw, 36px); background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0.16)); }


.inst-footer__grid { max-width: var(--max, 1200px); margin-left: auto; margin-right: auto; padding-left: var(--pad, clamp(24px, 4vw, 64px)); padding-right: var(--pad, clamp(24px, 4vw, 64px)); display: grid; grid-template-columns: 1.2fr 0.8fr; gap: clamp(22px, 3vw, 44px); align-items: start; }


@media (max-width: 900px) {
  .inst-footer__grid { grid-template-columns: 1fr; }
}


.inst-footer__name { font-family: var(--serif, ui-serif, Georgia, "Times New Roman", serif); font-size: clamp(20px, 1.6vw, 24px); letter-spacing: 0.02em; color: var(--ink); line-height: 1.2; }


.inst-footer__affil { margin-top: 6px; font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }


.inst-footer__tagline { margin-top: 12px; max-width: 56ch; color: var(--ink); line-height: 1.55; }


.inst-footer__jurisdiction { margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--line); max-width: 60ch; }


.inst-footer__label { font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }


.inst-footer__links { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 10px; align-items: baseline; }


.inst-footer__sep { color: var(--muted); opacity: 0.7; }


.inst-footer__link { color: var(--ink); text-decoration: none; border-bottom: 1px solid transparent; padding-bottom: 2px; }


.inst-footer__link:hover { border-bottom-color: var(--ink); }


.inst-footer__custody { color: var(--muted); line-height: 1.6; max-width: 60ch; }


.inst-footer__custody p { margin: 10px 0px 0px; }


.inst-footer__motto { background: rgb(123, 30, 30); color: rgb(255, 255, 255); border-top: 1px solid rgba(255, 255, 255, 0.18); padding-bottom: 3rem; }


.inst-footer__mottoInner { max-width: var(--max, 1200px); margin: 0px auto; padding: 18px var(--pad, clamp(24px, 4vw, 64px)) 34px; text-align: center; font-style: italic; letter-spacing: 0.01em; }




/* ===== STYLESHEET: https://crm.inteletic.com/assets/css/pages/contact.css ===== */

.contact-page { background: rgba(255, 255, 255, 0.7); }


.contact-scene { position: relative; overflow: hidden; }


.contact-scene-image { position: absolute; inset: 0px 0px auto; height: 870px; background: url("/assets/images/contact/cathedral.png") center center / cover no-repeat; z-index: 1; }


.contact-shell { position: relative; z-index: 3; width: min(19200px, 100% - 96px); margin: 0px auto; padding: 110px 0px 0px; }


.contact-hero { max-width: 720px; margin-bottom: 100px; color: rgb(255, 255, 255); margin-left: 90px; }


.contact-kicker, .contact-label { margin: 0px 0px 12px; font-size: 0.74rem; line-height: 1.2; letter-spacing: 0.16em; text-transform: uppercase; }


.contact-kicker { color: rgba(255, 255, 255, 0.84); }


.contact-hero h1 { margin: 0px 0px 18px; font-family: Georgia, "Times New Roman", serif; font-size: clamp(2.8rem, 4.8vw, 4.6rem); line-height: 1; color: rgb(255, 255, 255); }


.contact-lede { margin: 0px 0px 16px; font-size: 1.08rem; line-height: 1.78; color: rgba(255, 255, 255, 0.9); }


.contact-subtext { margin: 0px; font-size: 1rem; line-height: 1.72; color: rgba(255, 255, 255, 0.72); }


.contact-figure { height: 200%; width: auto; object-fit: contain; pointer-events: none; z-index: 1; margin-top: -500px; }


.full-height { height: 100%; width: 100%; display: flex; flex-direction: column; justify-content: flex-end; }


.bottom { background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.25) 25%, rgba(255, 255, 255, 0.85) 75%); padding: 20px; }


.contact-writing-zone { display: grid; grid-template-columns: minmax(0px, 1.25fr) minmax(300px, 0.75fr); gap: 70px; align-items: start; margin-top: 60px; padding: 90px 80px; background: url("/assets/images/contact/templar_and_shield.png") right center / contain no-repeat; }


.contact-writing-column { padding: 80px; background: linear-gradient(to bottom, rgb(255 255 255) 21%, rgb(251 251 251) 22%, rgba(0, 0, 0, 0) 84%); }


.contact-intro { margin-bottom: 34px; }


.contact-context { margin: 0px 0px 18px; font-size: 0.76rem; line-height: 1.5; letter-spacing: 0.08em; text-transform: uppercase; color: rgb(63, 59, 53); }


.contact-label { color: rgb(139, 0, 0); }


.written-inquiry { display: block; border-top: 3px solid rgb(139, 0, 0); padding-top: 14px; margin-bottom: 12px; background: none; }


.contact-intro h2 { margin: 0px 0px 14px; font-family: Georgia, "Times New Roman", serif; font-size: 2rem; line-height: 1.08; color: rgb(31, 27, 23); }


.contact-instruction { margin: 0px; font-size: 1rem; line-height: 1.72; color: rgb(74, 69, 62); }


.contact-form, .contact-form input, .contact-form select, .contact-form textarea, .contact-form button { font-family: inherit; }


.form-status { margin: 0px 0px 14px; font-size: 0.92rem; color: rgb(139, 0, 0); }


.form-row { margin-bottom: 24px; }


.form-row label { display: block; margin-bottom: 8px; font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgb(104, 99, 91); }


.form-row input, .form-row select, .form-row textarea { width: 100%; border-top: none; border-right: none; border-left: none; border-image: initial; border-bottom: 1px solid rgba(38, 29, 20, 0.45); padding: 12px; font-size: 1rem; color: rgb(31, 27, 23); outline: none; background: rgb(255, 255, 255); box-shadow: gainsboro 0px 1px 5px; transition: border-color 0.2s, box-shadow 0.2s; }


.form-row textarea { min-height: 170px; resize: vertical; }


.form-row input:focus, .form-row select:focus, .form-row textarea:focus { border-color: rgb(140, 29, 24); box-shadow: rgba(140, 29, 24, 0.1) 0px 0px 0px 2px; }


.select-wrapper { position: relative; }


.select-wrapper::after { content: "▾"; position: absolute; right: 0px; top: 50%; transform: translateY(-50%); font-size: 0.8rem; color: rgb(85, 85, 85); }


.contact-bridge { margin: 20px 0px 16px; font-size: 0.92rem; line-height: 1.65; color: rgb(86, 81, 73); }


.form-actions { margin-top: 12px; }


.contact-submit { padding: 16px 32px; background: rgb(139, 0, 0); color: rgb(255, 255, 255); border: 1px solid rgb(139, 0, 0); font-size: 0.84rem; letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer; transition: 0.2s; margin-top: 20px; }


.contact-submit:hover { background: transparent; color: rgb(139, 0, 0); box-shadow: rgba(0, 0, 0, 0.08) 0px 6px 14px; }


.guidance-block + .guidance-block { margin-top: 28px; }


.guidance-block h2, .guidance-block h3 { font-family: Georgia, "Times New Roman", serif; color: rgb(31, 27, 23); }


.guidance-block h2 { margin-bottom: 12px; font-size: 1.9rem; }


.guidance-block h3 { margin-bottom: 8px; font-size: 1.15rem; }


.guidance-block p, .guidance-list li { font-size: 0.98rem; line-height: 1.7; color: rgb(75, 73, 68); }


.guidance-divider { height: 1px; margin: 24px 0px; background: linear-gradient(to right, rgba(139, 0, 0, 0.6), transparent); }


.direct-email a { color: rgb(139, 0, 0); text-decoration: none; border-bottom: 1px solid rgba(139, 0, 0, 0.3); }


.guidance-list { margin: 0px; padding-left: 18px; }


.contact-info-anchor {
    position: relative;
    z-index: 5;

    width: 100%;
    display: flex;
    justify-content: center;

    margin-top: -220px; /* controlled overlap */
    padding: 0 40px;
}

.guidance-card {
    max-width: 900px;
    width: 100%;

    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(6px);

    padding: 36px 42px;
    box-shadow: 0 20px 50px rgba(0,0,0,0.15);

    border-top: 3px solid var(--accent);
}


.contact-success[hidden] { display: none; }


.contact-success { opacity: 0; transform: translateY(10px); transition: 0.3s; }


.contact-success.is-visible { opacity: 1; transform: translateY(0px); }


.contact-honeypot { display: none; }


@media (max-width: 1024px) {
  .contact-shell { width: calc(100% - 48px); padding-bottom: 0px; }
  .contact-writing-zone { grid-template-columns: 1fr; gap: 50px; }
  .contact-figure { display: none; }
  .contact-info-anchor { bottom: 0px; }
  .contact-writing-zone { background: none; }
}


@media (max-width: 640px) {
  .contact-scene-image { height: 620px; }
  .contact-shell { width: calc(100% - 32px); padding: 80px 0px 64px; }
  .contact-hero h1 { font-size: 2.6rem; }
  .contact-submit { width: 100%; }
}

