* { box-sizing: border-box; }

html{
  height: 100%;
  scrollbar-gutter: stable;
  overflow-x: clip;
  background: var(--bg) !important;
  background-image: none !important;
  background-repeat: no-repeat !important;
}

body{
  height: 100%;
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: var(--text);
  background: radial-gradient(900px 420px at 10% 0%, rgba(217, 134, 107, .10), transparent 60%),
              radial-gradient(900px 420px at 90% 0%, rgba(239, 182, 163, .10), transparent 60%),
              radial-gradient(900px 420px at 50% 10%, rgba(246, 214, 203, .12), transparent 60%),
              var(--bg);
  background-repeat: no-repeat;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

:root{
  --max: 1040px;
  --pad: clamp(20px, 6vw, 28px);
  --topbar-h: 86px;

  --t900: #7A2E22;
  --t700: #9B3D2B;
  --t500: #B95B42;
  --t300: #D9866B;
  --t200: #EFB6A3;
  --t100: #F6D6CB;

  --bg: #ffffff;
  --surface: #ffffff;

  --ink: #231716;
  --ink2: rgba(35,23,22,.66);

  --text: var(--ink);
  --muted: var(--ink2);

  --accent: #C85A4A;
  --border: rgba(35,23,22,.10);

  --radius: 18px;
  --pill: 14px;

  --accentSoft: rgba(185, 91, 66, .18);
  --accentSoft2: rgba(185, 91, 66, .10);

  --neutral: rgba(255, 255, 255, .80);
  --shadow-soft: 0 1px 2px rgba(122, 46, 34, .04), 0 18px 50px rgba(122, 46, 34, .08);

  --shadow1: 0 1px 2px rgba(35,23,22,.06);
  --shadow2: 0 10px 28px rgba(35,23,22,.10);

  --lavender: var(--t100);
  --mint: var(--t200);
  --peach: var(--t100);
}

.wrap{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad);
  padding-left: calc(var(--pad) + env(safe-area-inset-left));
  padding-right: calc(var(--pad) + env(safe-area-inset-right));
  min-width: 0;
}

body.page{
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  padding-top: calc(var(--topbar-h) + env(safe-area-inset-top)) !important;
}

main.content{ flex: 1; }
footer.footer{ margin-top: auto; }

.content{ padding: 28px 0 40px; }

.block{
  max-width: 78ch;
  margin: 28px 0;
}

.block, .timeline, .iconlist, .contactcard{ max-width: none !important; }

.wrap, .block, .degrees, .degree, .excur-rail, .expast, .formgrid, .apptlist{ min-width: 0; }
.degree *, .excur-rail *, .expast *, .formpill *, .apptcard *{ min-width: 0; }

h2{
  letter-spacing: -.01em;
  font-size: 20px;
  margin: 0 0 8px;
  line-height: 1.25;
}

h3{
  margin: 0 0 8px;
  font-size: 16px;
}

p{
  margin: 10px 0;
  line-height: 1.65;
}

.muted{ color: var(--muted); }
.small{ font-size: 13px; }
.sep{ color: rgba(122, 46, 34, .25); }

.intro{ margin: 18px 0 10px; }
.intro__title{
  font-size: 24px;
  margin: 0 0 10px;
}

a, a:visited{ color: inherit; }

.prose{
  display: block !important;
  text-align: left !important;
}
.prose > p{
  display: block !important;
  width: 100% !important;
  text-align: left !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
main.wrap.content{ text-align: left !important; }

h2, h3, .intro__title, .tile__title, .degree__title{
  color: var(--t900) !important;
}

.topbar{
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2000;
  width: 100%;
  background: rgba(255,255,255,.96) !important;
  border-bottom: 1px solid var(--border) !important;
  backdrop-filter: saturate(1.1) blur(8px);
}

.topbar__inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 0;
  min-height: var(--topbar-h);
}

.topbar__inner > *{ min-width: 0; }
.logo, .logo__text, .nav{ min-width: 0; }

.logo{
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  padding: 4px 0;
}

.logo__banner{
  height: 42px;
  width: auto;
  display: block;
  margin: 4px 0;
}

.logo__text{
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.logo__name{
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

.logo__tag1, .logo__tag2{
  font-size: 13px;
  color: var(--muted);
  margin-top: 2px;
}
.logo__tag2{ margin-top: 0; }

.nav{
  display: flex;
  gap: 18px;
  justify-content: flex-end;
  align-items: flex-end;
  flex-wrap: nowrap !important;
  white-space: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.nav::-webkit-scrollbar{ display: none; }

.nav__link{
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 10px 0 12px;
  text-decoration: none;
  color: var(--text);
  font-size: 14px;
  font-weight: 650;
  letter-spacing: -.01em;
  opacity: .82;
  transition: opacity .15s ease, transform .15s ease;
  flex: 0 0 auto;
}

.nav__link, .nav__link:visited{
  color: var(--t900) !important;
  opacity: .92 !important;
}

.nav__link:hover,
.nav__link:focus-visible{
  color: var(--t700) !important;
  opacity: 1 !important;
}

.nav__link:hover{ transform: translateY(-1px); }

.nav__link::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 4px;
  height: 3px;
  background: transparent;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .18s ease, background .18s ease;
}

.nav__link:hover::after{
  transform: scaleX(1);
  background: rgba(122,46,34,.28) !important;
}

.nav__link.is-active{ opacity: 1; }

.nav__link.is-active::after{
  transform: scaleX(1);
  background: linear-gradient(90deg, rgba(200,90,74,.70), rgba(122,46,34,.85)) !important;
}

.nav__link:focus-visible{
  outline: 2px solid rgba(200,90,74,.26) !important;
  outline-offset: 4px;
}

.footer{
  background: rgba(255,255,255,.96) !important;
  border-top: 1px solid var(--border) !important;
}

.footer__inner{ padding: 18px 0 26px; }

.footer__links{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}

.footer__link{
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.footer__link,
.footer__link:visited,
.footer a,
.footer a:visited{
  color: rgba(35,23,22,.55) !important;
  text-decoration-color: rgba(35,23,22,.28) !important;
}

.footer__link:hover,
.footer a:hover{
  color: rgba(35,23,22,.78) !important;
  text-decoration-color: rgba(35,23,22,.45) !important;
}

.tiles{
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.tile{
  border-radius: var(--radius);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, .72);
  box-shadow: 0 1px 2px rgba(122, 46, 34, .03);
  display: flex;
  flex-direction: column;
}

.tile__media{
  height: 150px;
  flex: 0 0 auto;
  overflow: hidden;
}

.tile__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.tile__body{
  padding: 14px 14px 16px;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  gap: 12px;
}

.tile__title{
  font-size: 18px;
  margin-bottom: 4px;
  font-weight: 720 !important;
  letter-spacing: 0 !important;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

.tile__desc{
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.tile__details{
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
  display: grid;
  gap: 10px;
}
.tile__detail{ margin: 0; }

.tile__d-main{
  display: block;
  font-weight: 500;
  color: rgba(122, 46, 34, .92);
  opacity: .95;
  font-size: 13px;
}

.tile__d-sub{
  display: block;
  margin-top: 2px;
  font-size: 13px;
  color: var(--muted);
  font-style: italic;
  line-height: 1.35;
  padding-left: 10px;
  border-left: 2px solid rgba(122, 46, 34, .18);
}

.tile__hint{
  margin-top: auto;
  align-self: flex-end;
  font-size: 13px;
  text-decoration: none !important;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px !important;
  padding: 5px 5px;
  padding-bottom: 3px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: rgba(35,23,22,.72) !important;
}
.tile__hint::marker{ content: ""; }
.tile__hint::after{
  opacity: .55 !important;
  content: "" !important;
}
.tile__hint::before{
  content: "→" !important;
  position: static !important;
  width: auto !important;
  height: auto !important;
  background: none !important;
  transform: none !important;
  transition: none !important;
  opacity: .55;
  margin-right: 2px;
}

.tile__hint:hover{ color: rgba(35,23,22,.88) !important; }
.tile__hint:hover::before{
  background: rgba(35,23,22,.42);
  transform: scaleX(1);
}

.tile:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 50px rgba(122, 46, 34, .09);
}

.apptlist{
  flex-direction: column;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
  margin-top: 12px;
  padding: 0;
  list-style: none;
}

.apptlist, .svclist, .apptlist ul, .apptlist ol, .svclist ul, .svclist ol{
  margin: 0;
  padding: 0;
  list-style: none;
}

.apptlist>li, .svclist>li{
  margin: 0;
  padding: 0;
  list-style: none;
}

.apptlist>li::marker, .svclist>li::marker{ content: ""; }

.apptcard, .svcrow{ list-style: none; }

.apptcard{
  --card-bg: rgba(255, 255, 255, .78);
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: 16px 16px 14px;
  border: 1px solid rgba(122, 46, 34, .16);
  border-radius: 14px;
  background: rgba(255, 255, 255, .78);
  box-shadow: 0 1px 2px rgba(122, 46, 34, .03);
  color: inherit;
  text-decoration: none !important;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}

.apptcard *{ text-decoration: none !important; }

.apptcard:hover{
  --card-bg: rgba(255, 255, 255, .90);
  transform: translateY(-1px);
  background: rgba(255, 255, 255, .90);
  border-color: rgba(122, 46, 34, .22);
  box-shadow: 0 16px 40px rgba(122, 46, 34, .10);
}

.apptcard.is-disabled{
  opacity: .55;
  cursor: not-allowed;
}
.apptcard.is-disabled:hover{
  transform: none;
  box-shadow: 0 1px 2px rgba(122, 46, 34, .03);
  background: rgba(255, 255, 255, .78);
}

.apptlist .apptcard{
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  padding: 16px 16px 14px !important;
}
.apptlist .apptcard>*{ grid-column: auto !important; }
.apptlist .apptmain{
  margin: 0 !important;
  padding: 0 !important;
  max-width: none !important;
}
.apptlist .apptcta{
  margin-top: auto !important;
  align-self: flex-end !important;
}
.apptlist .apptcard> :is(.apptcard__rail, .apptcard__icon, .apptcard__media, .apptcard__left){
  display: none !important;
}

.apptmain{ min-width: 0; }

.appttitle{
  letter-spacing: -.01em;
  font-size: 15px;
  line-height: 1.25;
  margin-bottom: 8px;
  font-weight: 600 !important;
}

.appttext{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.appttext, .apptmeta{
  display: block !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
  overflow: visible !important;
  white-space: normal !important;
  text-overflow: clip !important;
}

.apptafter{ font-size: 12px; }

.apptcta{
  flex: 0 0 auto;
  line-height: 1.25;
  margin-top: auto;
  align-self: flex-end;
  width: max-content;
  text-align: right;
  padding-top: 12px;
  font-size: 13px;
  white-space: nowrap;
  color: var(--text);
  font-weight: 750;
  opacity: .9;
  position: relative;
  padding-bottom: 4px;
}
.apptcta::before{
  content: "→ " !important;
  opacity: .55;
}
.apptcta::after{
  content: "" !important;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  transform: scaleX(.35);
  transform-origin: right;
  transition: transform .18s ease, background .18s ease;
  background: linear-gradient(90deg, rgba(200,90,74,.16), rgba(122,46,34,.38)) !important;
}

.apptcard:hover .apptcta{ color: var(--t900); }
.apptcard:hover .apptcta::after{
  background: rgba(122, 46, 34, .55);
  transform: scaleX(1);
}

.apptprices{
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.apptprices .apptprice{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 7ch max-content;
  column-gap: 12px;
  align-items: start;
  padding: 2px 0;
  background: none !important;
}

.apptprices .apptprice::before,
.apptprices .apptprice::after{ content: none !important; }

.apptprices .apptprice__k{
  grid-column: 1;
  font-size: 12px;
  color: rgba(122, 46, 34, .82);
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.apptprices .apptprice__d{
  grid-column: 2;
  justify-self: end;
  text-align: right;
  white-space: nowrap;
  font-size: 12px;
  color: rgba(122, 46, 34, .62);
  font-variant-numeric: tabular-nums;
  align-self: start;
  padding-top: .02em;
}

.apptprices .apptprice__v{
  grid-column: 3;
  justify-self: end;
  text-align: right;
  font-size: 12px;
  color: rgba(122, 46, 34, .78);
  font-variant-numeric: tabular-nums;
  align-self: start;
  white-space: normal;
  overflow-wrap: break-word;
  max-width: 24ch;
}

.apptprices--3col .apptprice{
  display: grid;
  grid-template-columns: 1fr 6.5ch 18ch;
  column-gap: 12px;
  padding: 2px 0;
  background: none !important;
  align-items: start !important;
}

.apptprices--3col .apptprice::before,
.apptprices--3col .apptprice::after{ content: none !important; }

.apptprices--3col .apptprice__k,
.apptprices--3col .apptprice__d,
.apptprices--3col .apptprice__v{
  background: transparent !important;
  padding: 0 !important;
}

.apptprices--3col .apptprice__k{
  min-width: 0;
  font-size: 12px;
  color: rgba(122, 46, 34, .82);
  white-space: normal;
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: none;
}

.apptprices--3col .apptprice__d{
  justify-self: end;
  text-align: right;
  white-space: nowrap;
  font-size: 12px;
  color: rgba(122, 46, 34, .62);
  font-variant-numeric: tabular-nums;
}

.apptprices--3col .apptprice__v{
  justify-self: end;
  text-align: right;
  min-width: 0;
  font-size: 12px;
  white-space: normal;
  overflow-wrap: break-word;
  font-variant-numeric: tabular-nums;
  color: rgba(122, 46, 34, .78);
}

.apptprices--3col .apptprice__d,
.apptprices--3col .apptprice__v{ align-self: start; }

.apptprice__k, .apptprice__d, .apptprice__v{ font-weight: 400 !important; }
.apptprices .apptprice__k, .apptprices .apptprice__d, .apptprices .apptprice__v,
.apptprices--3col .apptprice__k, .apptprices--3col .apptprice__d, .apptprices--3col .apptprice__v{
  color: rgba(35,23,22,.62) !important;
  font-weight: 400 !important;
}

.apptprice__d, .apptprice__v{ color: rgba(35,23,22,.60) !important; }
.apptprice__v{
  color: rgba(35,23,22,.72) !important;
  font-weight: 650;
}
.apptprices .apptprice__v, .apptprices--3col .apptprice__v{
  color: rgba(35,23,22,.70) !important;
}

.formgrid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px !important;
  margin-top: 8px !important;
}

.formpill{
  border: 1px solid rgba(122, 46, 34, .14);
  background: rgba(255, 255, 255, .72);
  min-width: 0;
  padding: 10px 10px 9px !important;
  border-radius: 12px !important;
}

.formpill__kicker{
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-size: 11px;
  color: var(--muted);
  margin: 0 0 3px !important;
  line-height: 1.1;
  white-space: nowrap;
}

.formpill__title{
  letter-spacing: -.01em;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  display: block !important;
  margin: 0 !important;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.22;
  overflow: visible !important;
  white-space: normal !important;
  text-overflow: clip !important;
}

.formpill__text{
  margin-top: 6px !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
}

.formpill__meta{
  display: block;
  -webkit-line-clamp: unset;
  -webkit-box-orient: unset;
  overflow: visible;
  white-space: normal;
  text-overflow: clip;
  margin-top: 4px !important;
  font-size: 11px !important;
  line-height: 1.25 !important;
  opacity: .85;
  color: rgba(35,23,22,.55) !important;
}

.formpill__title, .formpill__meta, .formpill__text, .train__title, .train__meta{
  display: block !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
  overflow: visible !important;
  white-space: normal !important;
  text-overflow: clip !important;
}

.degrees, .degree-duo, .degree_duo{ min-width: 0; }

.degrees{
  margin: 10px 0 6px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 18px !important;
  min-width: 0;
}

.degree{
  --deg-accent: var(--t500);
  --deg-icon: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%2064%2064%27%3E%3Crect%20x%3D%2710%27%20y%3D%2710%27%20width%3D%2744%27%20height%3D%2734%27%20rx%3D%274%27%20fill%3D%27none%27%20stroke%3D%27%23000%27%20stroke-width%3D%274%27/%3E%3Cpath%20d%3D%27M18%2022h22%27%20stroke%3D%27%23000%27%20stroke-width%3D%274%27%20stroke-linecap%3D%27round%27/%3E%3Cpath%20d%3D%27M18%2030h18%27%20stroke%3D%27%23000%27%20stroke-width%3D%274%27%20stroke-linecap%3D%27round%27/%3E%3Ccircle%20cx%3D%2746%27%20cy%3D%2740%27%20r%3D%276%27%20fill%3D%27none%27%20stroke%3D%27%23000%27%20stroke-width%3D%274%27/%3E%3Cpath%20d%3D%27M44%2046l-4%208%206-4%206%204-4-8%27%20fill%3D%27none%27%20stroke%3D%27%23000%27%20stroke-width%3D%274%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E");
  position: relative;
  border: 1px solid rgba(122, 46, 34, .18);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .86));
  box-shadow: 0 1px 2px rgba(122, 46, 34, .04), 0 18px 50px rgba(122, 46, 34, .08);
  padding: 18px 18px 16px 22px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.degree::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 6px;
  background: linear-gradient(180deg, var(--deg-accent), rgba(185, 91, 66, .25));
}

.degree::after{
  content: "";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 34px;
  height: 34px;
  background-image: var(--deg-icon);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: .28;
}

.degree__kicker{
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 750;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: rgba(122, 46, 34, .85);
  background: rgba(246, 214, 203, .55);
  border: 1px solid rgba(122, 46, 34, .14);
  border-radius: 10px;
  padding: 4px 8px;
  margin-bottom: 12px;
}

.degree__title{
  font-weight: 900;
  letter-spacing: -.02em;
  display: block !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
  max-width: 100% !important;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
  font-size: 15px;
  line-height: 1.22;
  margin-bottom: 6px;
}

.degree__title, .degree .muted{
  max-width: none !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  -webkit-line-clamp: unset !important;
  -webkit-box-orient: unset !important;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

.degree--gold{ --deg-accent: var(--t500); }

.degree .muted,
.degree p.muted{
  color: rgba(35,23,22,.60) !important;
  margin: 0;
}

.expast{
  gap: 0;
  display: flex;
  flex-direction: column;
  border-top: 1px solid rgba(122, 46, 34, .10);
  margin-top: 8px;
}

.expast__metaLine{
  display: flex;
  align-items: baseline;
  gap: 10px;
  min-width: 0;
}

.expast__when{
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
  flex: 0 0 auto;
}

.expast__dot{
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: rgba(122, 46, 34, .28);
  flex: 0 0 auto;
  transform: translateY(-1px);
}

.expast__loc{
  font-size: 12px;
  color: var(--muted);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.expast__row{
  display: grid;
  padding: 12px 0;
  border-bottom: 1px solid rgba(122, 46, 34, .08);
  align-items: start;
  grid-template-columns: max-content 1fr !important;
  gap: 12px !important;
}

.expast__title{
  gap: 8px;
  align-items: baseline;
  font-size: 13px;
  font-weight: 750;
  min-width: 0;
  display: block !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.expast__text{
  font-weight: 500;
  white-space: normal !important;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.expast__row.is-stage{ opacity: .62; }
.expast__row.is-stage .expast__tag{
  color: rgba(122, 46, 34, .50);
  background: rgba(122, 46, 34, .06);
  border-color: rgba(122, 46, 34, .12);
}
.expast__row.is-stage .expast__when,
.expast__row.is-stage .expast__title,
.expast__row.is-stage .expast__meta{
  color: rgba(130, 130, 130, 1);
}
.expast__row.is-stage .expast__when,
.expast__row.is-stage .expast__title,
.expast__row.is-stage .expast__text,
.expast__row.is-stage .expast__meta{
  color: rgba(130, 130, 130, .95);
}

.excur-rail{
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.excur-rail__item{
  position: relative;
  padding-left: 16px;
}

.excur-rail__rail{
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 2px;
  border-radius: 2px;
  background: rgba(122, 46, 34, .22);
}

.excur-rail, .excur-rail__item, .excur-rail__title, .excur-rail__text{
  max-width: none !important;
  width: 100%;
}

.excur-rail__metaLine{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  font-size: 12px;
  color: var(--muted);
}

.excur-rail__when{
  font-size: 12px;
  color: var(--muted);
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 0;
  white-space: nowrap;
}

.excur-rail__dot{
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(122, 46, 34, .35);
  flex: 0 0 auto;
}

.excur-rail__meta{
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.excur-rail__title{
  font-size: 14px;
  line-height: 1.25;
  font-weight: 720 !important;
  letter-spacing: 0 !important;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

.excur-rail__text{
  margin-top: 4px;
  line-height: 1.5;
  max-width: 90ch;
}

.visually-hidden{
  max-width: 1px !important;
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  border: 0 !important;
  clip: auto !important;
  -webkit-clip-path: inset(50%) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  contain: layout paint !important;
}

.tile, .apptcard, .degree{
  background: rgba(255,255,255,.98) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow1) !important;
}

.tile:hover, .apptcard:hover{
  border-color: rgba(200,90,74,.20) !important;
  box-shadow: var(--shadow2) !important;
  transform: translateY(-1px) !important;
}

.prose a, .prose a:visited{
  color: var(--accent) !important;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

.prose a:hover{ color: rgba(122,46,34,.95) !important; }

.degree__kicker, .formpill__kicker{ color: rgba(122,46,34,.82) !important; }

.appttitle, .degree__title, .formpill__title{
  font-weight: 760 !important;
  letter-spacing: 0 !important;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

@media (max-width: 900px){
  :root{ --topbar-h-mobile: 133px; }

  body.page{ padding-top: var(--topbar-h-mobile) !important; }

  .topbar__inner{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding-top: 10px !important;
    padding-bottom: 12px !important;
    align-items: start !important;
  }

  .logo{
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
    padding: 2px 0 !important;
  }

  .logo__banner{
    height: 36px !important;
    margin: 2px 0 !important;
    flex: 0 0 auto !important;
  }

  .logo__text{
    position: static !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    clip: auto !important;
    clip-path: none !important;
    white-space: normal !important;
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
  }

  .logo__name{
    font-size: 15px !important;
    line-height: 1.05 !important;
  }

  .logo__tag1, .logo__tag2{
    display: block !important;
    font-size: 11px !important;
    line-height: 1.1 !important;
    margin-top: 1px !important;
  }

  .nav{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
    gap: 6px 12px !important;
    justify-items: center !important;
    align-items: center !important;
    overflow: hidden !important;
  }

  .nav__link{
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    font-size: 13px !important;
    line-height: 1.1 !important;
    padding: 6px 0 8px !important;
    white-space: normal !important;
  }

  .nav__link::after{
    bottom: 2px !important;
    height: 2px !important;
  }

  .formgrid{ grid-template-columns: 1fr !important; }
}

html, body{
  background: var(--bg) !important;
  background-image: none !important;
}

body{
  background: var(--bg) !important;
  background-image: none !important;
}

:root{
  --pad: clamp(16px, 4vw, 24px);
}

.wrap{
  padding-left: calc(var(--pad) + env(safe-area-inset-left));
  padding-right: calc(var(--pad) + env(safe-area-inset-right));
}

:root{
  --ink2: rgba(35,23,22,.85);
  --muted: var(--ink2);
}

.apptcard,
.apptcard p,
.apptcard li,
.apptcard .appttext,
.apptcard .apptmeta,
.apptcard .apptafter,
.apptprices .apptprice__k,
.apptprices .apptprice__d,
.apptprices .apptprice__v,
.apptprices--3col .apptprice__k,
.apptprices--3col .apptprice__d,
.apptprices--3col .apptprice__v{
  color: rgba(35,23,22,.85) !important;
}

@media (max-width: 900px){
  .apptprices--3col .apptprice__k br,
  .apptprices--3col .apptprice__v br{
    display: none !important;
  }

  .apptprices{
    margin-top: 8px !important;
    gap: 8px !important;
  }

  .apptprices--3col .apptprice{
    grid-template-columns: max-content minmax(0, 1fr) !important;
    grid-template-areas:
      "k k"
      "d v" !important;
    column-gap: .35em !important;
    row-gap: 3px !important;
    padding: 8px 0 !important;
    border: 0 !important;
    align-items: start !important;
  }

  .apptprices--3col .apptprice:first-child{
    border-top: 1px solid var(--border) !important;
    padding-top: 10px !important;
  }

  .apptprices--3col .apptprice__k{
    grid-area: k;
    overflow-wrap: anywhere !important;
    hyphens: auto !important;
    line-height: 1.35 !important;
  }

  .apptprices--3col .apptprice__d{
    grid-area: d;
    justify-self: start !important;
    text-align: left !important;
    white-space: nowrap !important;
    line-height: 1.25 !important;
  }

  .apptprices--3col .apptprice__v{
    grid-area: v;
    justify-self: start !important;
    text-align: left !important;
    max-width: none !important;
    line-height: 1.25 !important;
  }

  .apptprices--3col .apptprice__v::before{
    content: "•" !important;
    margin-right: .35em !important;
    color: rgba(35,23,22,.55) !important;
    font-weight: 400 !important;
  }

}
