@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;700&family=EB+Garamond:wght@400;500;600;700&display=swap');

:root {
    --ms-bg: #1F1D1A;
    --ms-mid-dark: #342F28;
    --ms-text: #E7DCC6;
    --ms-secondary: #4C453B;
    --ms-stone-light: #433D34;
    --ms-stone-dark: #302B24;
    --ms-red: #9A3630;
    --ms-yellow: #B89238;
    --ms-green: #4F6D3A;
    --ms-blue: #365E7B;
}

html,
body {
    background-color: var(--ms-bg);
}

body {
    color: var(--ms-text);
    font-family: 'EB Garamond', serif;
    text-align: center;
    margin: 0;
    padding: 20px 16px;
    min-height: 100vh;
    box-sizing: border-box;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Cinzel', serif;
    letter-spacing: 0.04em;
}

img,
table {
    margin-left: auto;
    margin-right: auto;
}

ul,
ol {
    display: inline-block;
    text-align: left;
}

form {
    max-width: 700px;
    margin: 0 auto;
    background-color: var(--ms-secondary);
    border: 1px solid var(--ms-mid-dark);
    padding: 16px;
}

a {
    color: var(--ms-blue);
    font-weight: 600;
}

a:visited {
    color: var(--ms-yellow);
}

a:hover,
a:focus-visible {
    color: var(--ms-red);
}

hr {
    border: 0;
    border-top: 1px solid var(--ms-secondary);
    margin: 18px auto;
    max-width: 900px;
}

.ms-index-page .ms-index__links {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
}

.ms-index-page .ms-index__tile {
    display: inline-block;
    line-height: 0;
    border: 2px solid var(--ms-secondary);
    background-color: var(--ms-stone-dark);
    text-decoration: none;
}

.ms-index-page .ms-index__tile:hover,
.ms-index-page .ms-index__tile:focus-visible {
    border-color: var(--ms-yellow);
}

.ms-index-page .ms-index__tile img {
    display: block;
}

.ms-personal-page .ms-personal__about {
    color: var(--ms-red);
}

.ms-personal-page .ms-personal__hobbies {
    color: var(--ms-green);
}

.ms-personal-page .ms-personal__education {
    color: var(--ms-blue);
}

.ms-personal-page .ms-personal__edu-degree {
    font-weight: bold;
}

.ms-personal-page .ms-personal__edu-diploma {
    font-style: italic;
}

.ms-personal-page .ms-personal__edu-certificate {
    text-decoration: underline;
}

.ms-personal-page img {
    max-width: 3in;
    max-height: 3in;
    width: auto;
    height: auto;
}

.ms-personal-page a {
    font-size: 100%;
}

.ms-personal-page a:hover {
    font-size: 150%;
    color: var(--ms-yellow);
}

.ms-schedule-page .ms-schedule__table th,
.ms-schedule-page .ms-schedule__table td {
    text-align: center;
    vertical-align: middle;
    border: 1px solid var(--ms-secondary);
    padding: 10px 14px;
    color: var(--ms-text);
}

.ms-schedule-page .ms-schedule__table th {
    background-color: var(--ms-yellow);
    color: var(--ms-bg);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.ms-schedule-page .ms-schedule__table {
    border-collapse: collapse;
    border: 1px solid var(--ms-secondary);
}

.ms-schedule-page .ms-schedule__table tr:nth-child(odd) td {
    background-color: var(--ms-stone-light);
}

.ms-schedule-page .ms-schedule__table tr:nth-child(even) td {
    background-color: var(--ms-stone-dark);
}

.ms-schedule-page .ms-schedule__events > li > ol > li {
    color: var(--ms-text);
}

.ms-schedule-page .ms-schedule__events {
    list-style-type: decimal;
    display: inline-block;
    text-align: left;
    padding-left: 28px;
}

.ms-schedule-page .ms-schedule__events ol {
    list-style-type: upper-alpha;
    display: block;
    margin-top: 6px;
    margin-left: 26px;
    padding-left: 0;
}

.ms-schedule-page .ms-schedule__events > li {
    color: var(--ms-yellow);
    margin-bottom: 8px;
}

.ms-account-page input,
.ms-account-page button,
.ms-account-page fieldset {
    border: 2px solid var(--ms-mid-dark);
    border-radius: 0;
    background-color: var(--ms-mid-dark);
    color: var(--ms-text);
}

.ms-account-page legend {
    color: var(--ms-yellow);
    font-weight: 700;
    font-family: 'Cinzel', serif;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--ms-yellow);
    background-color: var(--ms-stone-dark);
    padding: 4px 10px;
}

.ms-account-page button {
    cursor: pointer;
}

.ms-account-page button:hover,
.ms-account-page button:focus-visible {
    background-color: var(--ms-secondary);
    border-color: var(--ms-yellow);
}

.ms-account-page .ms-account__row {
    display: grid;
    grid-template-columns: 170px 1fr;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 10px;
}

.ms-account-page .ms-account__row label {
    text-align: right;
}

.ms-account-page .ms-account__choice-groups {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 12px;
}

.ms-account-page .ms-account__actions {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 10px;
}

.ms-account-page .ms-account__major,
.ms-account-page .ms-account__languages {
    min-height: 220px;
    border: 2px solid var(--ms-yellow);
    padding: 14px 12px 12px;
}

.ms-account-page .ms-account__options-list {
    display: grid;
    gap: 10px;
    justify-content: center;
}

.ms-account-page .ms-account__options-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 24px;
    justify-content: center;
}

.ms-account-page .ms-account__option-item {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    min-width: 190px;
}

.ms-account-page .ms-account__option-item a,
.ms-account-page .ms-account__option-item span {
    text-align: left;
}

.ms-account-page input[type="radio"][name="major"] {
    appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background-color: var(--ms-secondary);
    border: 1px solid var(--ms-yellow);
    vertical-align: middle;
    margin-right: 6px;
}

.ms-account-page input[type="radio"][name="major"]:checked {
    background-color: var(--ms-green);
    border-color: var(--ms-green);
}

.ms-account-page input[type="checkbox"][name^="lang-"] {
    appearance: none;
    width: 16px;
    height: 16px;
    background-color: var(--ms-secondary);
    border: 1px solid var(--ms-yellow);
    vertical-align: middle;
    margin-right: 6px;
}

.ms-account-page input[type="checkbox"][name^="lang-"]:checked {
    background-color: var(--ms-blue);
    border-color: var(--ms-blue);
}

.ms-account-page a,
.ms-account-page a:visited {
    color: var(--ms-yellow);
}

.ms-account-page a:hover,
.ms-account-page a:focus-visible {
    color: var(--ms-red);
}

.ms-account-page input[type="text"],
.ms-account-page input[type="password"],
.ms-account-page input[type="date"] {
    border: 2px solid var(--ms-secondary);
    background-color: var(--ms-stone-dark);
    padding: 6px 8px;
}

.ms-account-page input[type="text"]:focus,
.ms-account-page input[type="password"]:focus,
.ms-account-page input[type="date"]:focus {
    outline: none;
    border-color: var(--ms-yellow);
    box-shadow: inset 0 0 0 1px var(--ms-yellow);
}

@media (max-width: 760px) {
    .ms-account-page .ms-account__row {
        grid-template-columns: 1fr;
    }

    .ms-account-page .ms-account__row label {
        text-align: center;
    }

    .ms-account-page .ms-account__choice-groups {
        grid-template-columns: 1fr;
    }

    .ms-account-page .ms-account__options-grid {
        grid-template-columns: 1fr;
    }
}

.ms-payment-page form {
    max-width: 860px;
    background: linear-gradient(180deg, rgba(76, 69, 59, 0.94), rgba(48, 43, 36, 0.98));
    border: 1px solid var(--ms-yellow);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.3);
}

.ms-payment-page h1 {
    margin-bottom: 20px;
}

.ms-payment-page .ms-payment__section {
    margin-bottom: 24px;
    padding: 18px 18px 12px;
    background-color: rgba(31, 29, 26, 0.4);
    border: 1px solid var(--ms-secondary);
}

.ms-payment-page .ms-payment__section h2 {
    margin-top: 0;
    margin-bottom: 16px;
}

.ms-payment-page .ms-payment__section h2 {
    color: var(--ms-yellow);
}

.ms-payment-page p {
    display: grid;
    grid-template-columns: 190px minmax(0, 1fr);
    align-items: center;
    gap: 12px;
    margin: 0 0 12px;
}

.ms-payment-page label {
    text-align: right;
    font-weight: 600;
}

.ms-payment-page input,
.ms-payment-page select,
.ms-payment-page button {
    font: inherit;
}

.ms-payment-page input[type="text"],
.ms-payment-page input[type="date"],
.ms-payment-page input[type="month"],
.ms-payment-page select {
    width: 100%;
    box-sizing: border-box;
    padding: 8px 10px;
    border: 2px solid var(--ms-secondary);
    background-color: var(--ms-stone-dark);
    color: var(--ms-text);
}

.ms-payment-page input[type="text"]:focus,
.ms-payment-page input[type="date"]:focus,
.ms-payment-page input[type="month"]:focus,
.ms-payment-page select:focus {
    outline: none;
    border-color: var(--ms-yellow);
    box-shadow: inset 0 0 0 1px var(--ms-yellow);
}

.ms-payment-page .ms-payment__cards {
    grid-template-columns: 1fr;
    justify-items: center;
    margin-bottom: 18px;
}

.ms-payment-page .ms-payment__cards img {
    width: min(260px, 100%);
    height: auto;
    border-radius: 14px;
}

.ms-payment-page .ms-payment__checkbox-row {
    grid-template-columns: auto 1fr;
    justify-content: center;
    justify-items: start;
    align-items: center;
    gap: 10px;
}

.ms-payment-page label[for="sameAsShipping"] {
    text-align: left;
    cursor: pointer;
}

.ms-payment-page #sameAsShipping {
    appearance: none;
    width: 18px;
    height: 18px;
    margin: 0;
    border: 2px solid var(--ms-yellow);
    background-color: #7b7b7b;
    display: inline-grid;
    place-content: center;
    vertical-align: middle;
}

.ms-payment-page #sameAsShipping::after {
    content: "";
    width: 8px;
    height: 8px;
    transform: scale(0);
    transition: transform 0.15s ease-in-out;
    background-color: var(--ms-text);
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0, 43% 62%);
}

.ms-payment-page #sameAsShipping:checked {
    background-color: #2a73d9;
}

.ms-payment-page #sameAsShipping:checked::after {
    transform: scale(1);
}

.ms-payment-page #sameAsShipping:focus-visible {
    outline: 2px solid var(--ms-text);
    outline-offset: 2px;
}

.ms-payment-page label[for="cvvCode"] {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
}

.ms-payment-page .ms-payment__tooltip {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    cursor: help;
    outline: none;
}

.ms-payment-page .ms-payment__info-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background-color: var(--ms-blue);
    color: #fff;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 0.9rem;
    font-weight: 700;
    font-style: normal;
    font-variant: normal;
    text-transform: none;
}

.ms-payment-page .ms-payment__tooltip-text {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 10px);
    transform: translateX(-50%);
    width: 220px;
    padding: 10px 12px;
    border: 1px solid var(--ms-yellow);
    background-color: var(--ms-bg);
    color: var(--ms-text);
    text-align: left;
    font-weight: 400;
    line-height: 1.35;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.18s ease;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.35);
}

.ms-payment-page .ms-payment__tooltip-text::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 100%;
    transform: translateX(-50%);
    border-width: 7px;
    border-style: solid;
    border-color: var(--ms-yellow) transparent transparent transparent;
}

.ms-payment-page .ms-payment__tooltip:hover .ms-payment__tooltip-text,
.ms-payment-page .ms-payment__tooltip:focus-visible .ms-payment__tooltip-text {
    opacity: 1;
    visibility: visible;
}

.ms-payment-page .ms-payment__actions {
    grid-template-columns: repeat(2, auto);
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}

.ms-payment-page .ms-payment__actions button {
    border: 0;
    background: transparent;
    padding: 0;
    cursor: pointer;
}

.ms-payment-page .ms-payment__actions button:focus-visible,
.ms-payment-page .ms-payment__actions button:hover {
    outline: 2px solid var(--ms-yellow);
    outline-offset: 4px;
}

.ms-payment-page .ms-payment__actions img {
    display: block;
}

.ms-payment-page .ms-payment__bottom-nav {
    display: flex;
    justify-content: center;
    margin-top: 18px;
}

@media (max-width: 760px) {
    .ms-payment-page p {
        grid-template-columns: 1fr;
    }

    .ms-payment-page label,
    .ms-payment-page label[for="cvvCode"] {
        text-align: left;
        justify-content: flex-start;
    }

}
