@font-face {
    font-family: "Chronicle Text";
    font-weight: normal;
    src: url("/public/webfonts/ChronicleTextG1-RomanSC.ttf") format("truetype");
}
@font-face {
    font-family: "Chronicle Text Semi";
    font-weight: 600;
    src: url("/public/webfonts/ChronicleTextG1-Semibd-Pro.otf") format("truetype");
}
@font-face {
    font-family: "Chronicle Deck";
    font-weight: normal;
    src: url("/public/webfonts/ChronicleDeck-Roman.otf");
}
@font-face {
    font-family: "Chronicle Deck";
    font-weight: bold;
    src: url("/public/webfonts/ChronicleDeck-Bold.otf");
}
@font-face {
    font-family: "Helvetica Neue";
    font-weight: normal;
    src: url("/public/webfonts/HelveticaNeueLTStd-Roman.otf");
}
@font-face {
    font-family: "Helvetica Neue";
    font-weight: bold;
    src: url("/public/webfonts/HelveticaNeueLTStd-Bd.otf");
}

img {
    object-fit: cover;
}

p:last-child { margin-bottom: 0; }

.black { color: #000000; }
.dark-grey { color: #3C3732; }
.grey { color: #78736E; }
.light-grey { color: #96918C; }
.white { color: #ffffff }
.yellow { color: #F0A51E; }

.bg-black { background-color: #000000; }
.bg-yellow { background-color: #F0A51E; }

.container {
    max-width: 67rem;
    margin-left: auto;
    margin-right: auto;
}

.block-margins { margin: 3.75rem auto 0 auto; }
.mt2 { margin-top: 1rem }

.height-30 { height: 30rem; }
.height-27 { height: 27rem; }
.height-26 { height: 26.25rem; }
.height-12 { height: 12rem; }

.width-41 { width: 656px; }

@media (min-width: 52em) {
    .md-mx2 { margin-left: 2rem; margin-right: 2rem; }
}
@media (max-width: 52em) {
    .container { max-width: 100%; }
    .mob-height-auto { height: auto; }
    .mob-height-67vmin { height: 67vmin; }
    .mob-width-79vw { width: 79vw; }
    .mob-relative { position: relative; }
    .mob-m2 { margin: 2rem; }
    .mob-mt4 {margin-top: 4rem; }
    .mob-mx2 { margin-left: 2rem; margin-right: 2rem; }
    .mob-p0 { padding: 0; }
    .mob-font-1 { font-size: 1em; }
    .mob-bg-white { background-color: #ffffff; }
    .mob-block-mnb { margin-bottom: -3.75rem;}
}

.body-override {
    font-family: "Chronicle Deck", serif;
    font-style: normal;
    font-weight: normal;
    font-size: 1em;
    line-height: 1.5;
    background-color: #FFFFFF;
    color: #3C3732;
    margin: 0;
}

@media (min-width: 52em) {
    .md-flex-start { align-items: flex-start; }
    .md-flex-end { align-items: flex-end; }
    .md-ml4 {margin-left: 4rem;}
}

h2, .body_headline {
    font-family: "Chronicle Deck", serif;
    font-weight: 700;
    font-size: 2.25em;
    line-height: 1;
    margin-top: 1rem;
}

.body-text {
    font-family: "Chronicle Deck", serif;
    font-style: normal;
    font-weight: normal;
    font-size: 1em;
    line-height: 1.5;
}

.caption-text {
    font-family: Helvetica, sans-serif;
    font-size: 0.75em;
}

.rich-text {
    font-size: inherit;
    font-family: inherit;
    text-decoration: inherit;
    color: inherit;
}

h3, .section-descriptor-text {
    font-family: "Chronicle Text Semi", serif;
    font-style: normal;
    font-weight: 600;
    line-height: 1.5;
    margin: 0.75rem 0;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}
h4 {
    font-size: inherit;
    margin-top: 0;
    margin-bottom: 1.2rem;
}

.font-0 { font-size: 0.75em; }
.font-1 { font-size: 1em; }
.font-2 { font-size: 1.5em; }

span_size_8.size-8 { font-size: 8pt; }
span_size_12.size-12 { font-size: 12pt; }
span_size_14.size-14 { font-size: 14pt; }

span_center.text-center {
    text-align: center;
    display: block;
}
span_right.text-right {
    text-align: end;
    display: block;
}

span_arial.text-arial {
    font-family: Arial, sans-serif;
}
span_calibri.text-calibri {
    font-family: Calibri, sans-serif;
}
span_helvetica.text-helvetica {
    font-family: Helvetica, sans-serif;
}

span_underline.text-underline {
    text-decoration: underline;
}

a, .rich-text a {
    text-decoration: none;
    color: #F0A51E;
    font-weight: bold;
}
a:hover, .rich-text a:hover {
    text-decoration: none;
}

.link_underlined-on-hover .rich-text a {
    color: inherit;
    font-weight: inherit;
}
.link_underlined-on-hover .rich-text a:hover {
    text-decoration: underline #F0A51E;
}

/* GENERAL COLUMN GRID CSS */

.yellow-border-top {
    border-top: 9px solid #F1A51D;
}
.black-border-top {
    border-top: 3px solid #000000;
}

.four-column-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 24px;
    row-gap: 60px;
    grid-auto-flow: dense;
    height: inherit;
}

.three-column-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 24px;
    row-gap: 60px;
    grid-auto-flow: dense;
    height: inherit;
}
.three-column-grid.reverse .column:first-child {
    grid-column: 3;
}

.two-column-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 24px;
    height: inherit;
}

.column {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    height: inherit;
}
.column-wide {
    grid-column: span 2;
}
.column-wide img {
    width: 100%;
}
.column-text {
    justify-content: space-between;
}

.column.left-side {
    grid-column: 1;
}
.column.right-side {
    grid-column: 2;
}
.blockquote {
    margin-top: 40px;
    margin-left: 48px;
}
.blockquote::before {
    position: absolute;
    margin-left: -48px;
    margin-top: -60px;
    color: #F0A51E;
    content: open-quote;
    font-size: 7rem;
}
.blockquote sub {
    font-size: 0.9rem;
    font-weight: normal;
}
.blockquote .rich-text p {
    margin-top: 0;
}

.btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 180px;
    padding: 14px 0 11px 0;
    border: 1px solid #F0A51E;
    font-family: "Helvetica Neue", Helvetica, sans-serif;
    font-weight: bold;
    font-size: 0.75em;
    line-height: 1;
}
.btn:hover {
    color: #FFFFFF;
    background: #ED8300;
    border-color: #ED8300;
}
.btn:focus {
    outline: none;
    border-color: #F0A51E;
    box-shadow: none;
}

.column.text-align-right {
    text-align: end;
    padding-left: 50px;
}

.column.with-background {
    background-position: center;
    background-size: cover;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    font-weight: normal;
}
.column.with-background:hover {
    text-decoration: none;
    font-weight: normal;
}

.column__full-width {
    grid-column: span 3;
}
.column__sidebar {
    border-left: 1px solid #96918C;
    padding-left: 20px;
}
.column__sidebar .rich-text > p {
    padding-bottom: 0.75rem;
    margin-bottom: 0;
}
.column__sidebar .rich-text > p:first-child {
    margin-top: 0;
    padding-top: 0;
}
@media (max-width: 65em){
    .four-column-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 52em) {
    .four-column-grid {
        grid-template-columns: 1fr;
        padding: 0;
        column-gap: 0;
        row-gap: 60px;
    }
    .three-column-grid {
        grid-template-columns: 1fr;
        padding: 0;
        column-gap: 0;
        row-gap: 60px;
    }
    .three-column-grid.reverse .column:first-child {
        grid-column: 1 / span 1;
    }
    .two-column-grid {
        grid-template-columns: 1fr;
        padding: 0;
        column-gap: 0;
        row-gap: 60px;
    }
    .column-text {
        grid-row: end;
    }
    .column-wide {
        grid-column: span 1;
    }
    .column.with-background {
        height: 133vmin;
    }

    .column__body.blockquote {
        margin-top: 40px;
    }
    .column__link {
        padding: 0 30px;
    }
    .column.text .column__link {
        padding: 0;
    }
    .column__link.mobile {
        display: block;
    }
    .column__link.mobile a {
        padding: 0;
        border: none;
        border-bottom: 2px solid #F0A51E;
        padding-bottom: 4px;
    }
    .column__link.mobile a span {
        font-size: 1rem;
    }
    .column__deadlines {
        padding: 11px 30px 0 30px;
    }
    .column__sidebar {
        border-left: none;
        padding-left: 0;
    }
}


/* SIMPLE HERO BLOCK */
.hero-image {
    background-position: center;
    background-size: cover;
}
.hero-text-box {
    background: rgba(255, 255, 255, 0.9);
    padding: 0.4rem 1.5rem 1.25rem 1.5rem;
}
@media (max-width: 52em) {
    .hero-text-box {
        padding: 0.4rem 2rem 0 2rem;
    }
}

/* IMAGE ONLY BLOCK */
@media (max-width: 52em) {
    [data-block="image-only-block"] {
        height: auto;
    }
}


/* CONTENT IMAGE BLOCK */
@media (max-width: 52em) {
    [data-block="content-image-block"] .three-column-grid {
        row-gap: 30px;
    }
}

.thumbnail-cover_override {
    left: 50%;
    position: absolute;
    top: 50%;
    height: 50px;
    width: 70px;
    margin-left: -35px;
    margin-top: -25px;
    overflow: hidden;
}
.thumbnail-cover_override img {/*Play Button*/
    object-fit: contain;
    width: 70px;
    height: auto;
    opacity: 0.8;
}


/* THREE COLUMN BLOCK */
.two-column-grid.image-columns .column img {
    height: 280px;
    width: 100%;
}
.three-column-grid.image-columns .column img {
    height: 240px;
    width: 100%;
}
@media (max-width: 52em) {
    .two-column-grid.image-columns .column img {
        height: 58vmin;
    }
    .three-column-grid.image-columns .column img {
        height: 67vmin;
    }
}

/*  EVENTS BLOCK */
@media (max-width: 52em) {
    [data-block="new-style-events-block"] .three-column-grid {
        row-gap: 0;
    }
    [data-block="new-style-events-block"] .rich-text > a {
        color :#F0A51E;
        font-weight: normal;
    }
}

/*  FEATURED TWO COLUMN BLOCK */
@media (max-width: 52em) {
    [data-block="featured-two-column-block"] .three-column-grid {
        row-gap: 0;
    }
}

/* TEXT WITH OPTIONAL SIDEBAR BLOCK */
[data-block="text-with-optional-sidebar-block"] .rich-text p:first-child {
    margin-top: 0;
}
@media (max-width: 52em) {
    [data-block="text-with-optional-sidebar-block"] .three-column-grid {
        row-gap: 0;
    }
    [data-block="text-with-optional-sidebar-block"] .column.full-width {
        grid-row: 1;
    }
    [data-block="text-with-optional-sidebar-block"] .column-wide {
        grid-row: 2;
    }
    [data-block="text-with-optional-sidebar-block"] .column {
        grid-row: 3;
    }
}

/* CONTACT FORM BLOCK */
/* ================== */


/* ADMISSIONS DEADLINES BLOCK */
/* ========================== */
@media (max-width: 52em) {
    [data-block="application-deadlines-block"] .three-column-grid {
        row-gap: 36px;
    }
}

.yellow-arrow {
    height: 24px;
}

/* The Modal (background) */
.modal {
    display: none; /* Hidden by default */
    position: fixed; /* Stay in place */
    z-index: 1; /* Sit on top */
    left: 0;
    top: 0;
    width: 100%; /* Full width */
    height: 100%; /* Full height */
    overflow: auto; /* Enable scroll if needed */
    background-color: rgb(0,0,0); /* Fallback color */
    background-color: rgba(0,0,0,0.4); /* Black w/ opacity */
}
@media (max-width: 52em) {
    .modal {
        position: absolute;
        background-color: rgba(0,0,0,0.0);
        height: max-content;
        overflow: hidden;
    }
}

/* Modal Content/Box */
.modal-content {
    position: fixed;
    top: 18%;
    left: 0;
    right: 0;
    margin: auto;
    overflow: hidden;
    background-color: #FFFFFF;
    border-top: 9px solid #F1A51D;
    box-sizing: border-box;
}
@media (max-width: 52em) {
    .modal-content {
        position: relative;
        top: auto;
        width: 100%;
        margin: 1.5rem 0 0 0;
        border: 1px solid #96918C;
        border-top: 9px solid #F1A51D;
    }
}
#modal-button {
    cursor: pointer;
    color: #F1A51D;
}

  /* The Close Button */
  .close {
    color: #3C3732;
    float: right;
    font-size: 28px;
    font-weight: bold;
    padding-right: 14px;
    text-transform: uppercase;
    cursor: pointer;
  }

  .close:hover,
  .close:focus {
    color: black;
    text-decoration: none;
  }

iframe[src*="youtube"] {
    width: 800px;  /* Adapts to container */
    height: 450px;  /* Maintains 16:9 based on viewport height */
}
