body {
    font-family: 'EB Garamond', serif;
    font-size: 16pt;
    padding: 0;
    margin: 0;
    background-color: #000;
    overflow-y: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

a {
    color: #3cbaf8;
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

a.button {
    display: inline-block;
    padding: 0.5em;
    border: 1px solid currentColor;
    cursor: pointer;
    transition: background-color linear 0.3s;
}

a.button:before {
    content: '\00bb\00a0';
}

a.button:after {
    content: '\00a0\00ab';
}

a.button:hover {
    background-color: rgba(60, 186, 248, 0.1);
    text-decoration: none;
}

section.page {
    text-align: center;
    color: #fff;
}

.feature,
.subfeature {
    padding-left: 72pt;
    padding-right: 72pt;
}

.feature {
    overflow-x: hidden;
    position: relative;
    box-sizing: border-box;
    min-height: 100%;
    min-height: 100vh;
    flex-direction: column;
    align-items: center;
    display: flex;
}

section.page {
    padding-top: 24pt;
    padding-bottom: 120pt;
}

.fancy {
    font-family: 'Cormorant SC', serif;
    font-size: 1.5em;
}

.note {
    display: block;
    font-size: 0.6em;
    font-family: 'Cormorant SC', serif;
    color: #000;
}

.name {
    white-space: nowrap;
    font-family: 'Italianno', cursive;
    display: block;
    font-size: 40pt;
    line-height: 1.5em;
    color: #ff8900;
}

.part {
    display: block;
    margin: 0 auto;
    max-width: 10em;
}

h1 {
    font-weight: normal;
    font-size: 3.8em;
    margin: 0.2em 0;
    font-family: 'Italianno', cursive;
}

h2 {
    font-family: 'Cormorant SC';
    font-weight: normal;
    font-size: 30pt;
}

.time,
.price {
    color: #ff8900;
    font-size: 0.8em;
}

.day {
    display: block;
    font-size: 1.4em;
}

p.invitation {
    font-size: 1.2em;
}

.dayofweek {
    display: block;
}

.address address {
    font-style: normal;
}

.map {
    width: 100%;
    height: 300px;
    border: none;
}

.card {
    position: relative;
    color: #000;
    margin: auto;
    padding: 12pt 12pt;
    border: 8pt solid #ff8900;
    background-color: white;
    box-shadow: 0 0 12pt 0 rgba(0, 0, 0, 0.5);
    max-width: 576pt;
    align-self: stretch;
}

.card ul {
    margin: 0 auto;
    padding: 0;
    max-width: 75%;
    text-align: left;
}

.card ul li {
    padding: 0;
    margin: 0.5em 0;
}

.card ul ul {
    margin: 0 1em;
    max-width: 100%;
}

nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    color: #fff;
    padding: 1em 0;
    font-size: 1.5em;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 2;
}

nav ul {
    list-style: none;
    margin: 0 auto;
    padding: 0;
    text-align: center;
}

nav ul li {
    display: inline-block;
    margin: 0 0.3em;
    padding: 0;
}

nav ul li a {
    text-decoration: none;
    color: inherit;
    border-bottom: 2pt solid transparent;
}

nav ul li a:hover {
    text-decoration: none;
}

nav ul li a:active,
nav ul li a:hover,
nav ul li.active a {
    border-color: #ff8900;
}

section.page:not(.active) {
    display: none;
}

section.welcome.page {
    background-color: #ffedd9;
}

body.welcome nav {
    color: #000;
    background-color: rgba(255, 237, 217, 0.5); /* #ffedd9 */
}

section.schedule.page {
    background-color: #683800;
    background-image: url('../images/schedule.png');
    background-repeat: no-repeat;
    background-position: center top;
    padding-top: 300px;
}

.schedule.card {
    border-color: #d9c500;
    color: #000;
}

.schedule.card h1 {
    color: #1f0147;
}

.schedule.card h2 {
    color: #410393;
}

body.schedule nav {
    background-color: rgba(104, 56, 0, 0.5);
    color: #fff;
}

section.attire.page {
    background-color: #1f0147;
    background-image: url('../images/attire.png');
    background-repeat: no-repeat;
    background-position: center top;
    padding-top: 300px;
}

.attire.card {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.1);
    border-color: transparent;
    box-shadow: none;
}

.attire.card h1 {
    color: #ffe800;
}

.attire.card h2 {
    color: #ffed33;
}

.attire.card h3 {
    color: #fff8b1;
}

body.attire nav {
    background-color: rgba(31, 1, 71, 0.5);
}

section.blacktie.page {
    background-color: #000;
}

.blacktie.card {
    border-color: #ddd;
}

body.blacktie nav {
    background-color: rgba(0, 0, 0, 0.5); /* #ffedd9 */
}

section.accommodations.page {
    background-color: #012d42;
    background-image: url('../images/accommodations.png'), linear-gradient(#012d42, #1f0147);
    background-repeat: no-repeat;
    background-position: center top;
    padding-top: 300px;
}

.accommodations.card {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.1);
    border-color: transparent;
    box-shadow: none;
}

.accommodations.card h1 {
    color: #ff8900;
}

.accommodations.card h2 {
    color: #ffa133;
}

body.accommodations nav {
    /* background-color: rgba(1, 45, 66, 0.5); */
    background-color: rgba(31, 1, 65, 0.5); /* #1f0147 */
}

section.transportation.page {
    background-color: #410393;
    background-image: url('../images/transportation.png');
    background-repeat: no-repeat;
    background-position: center top;
    padding-top: 300px;
}

.transportation.card {
    border-color: #fff8b1;
}

body.transportation nav {
    background-color: rgba(65, 3, 147, 0.5); /* #410393 */
}

section.gifts.page {
    background-color: #81d8d0;
    background-image: url('../images/gifts.png');
    background-repeat: no-repeat;
    background-position: center top;
    padding-top: 0;
    padding-bottom: 0;
    position: relative;
    min-height: 100%;
    min-height: 100vh;
}

.gifts.subfeature {
    padding-bottom: 120pt;
}

.gifts.card {
    border-color: #25b3a6;
}

.gifts.card h1 {
    color: #81d8d0;
}

body.gifts nav {
    background-color: rgba(129, 216, 208, 0.5);
    color: #000;
}

section.seattle.page {
    background-color: #addcf3;
    background-image: url('../images/seattle.png'), url('../images/seattle-background.png'), url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mPMsGD4DwADUQGhRnfNkwAAAABJRU5ErkJggg==');
    background-repeat: no-repeat, repeat-x, repeat-x;
    background-position: center bottom 100px, center bottom 100px, center bottom;
    background-size: auto, 100% 600px, 100% 100px;
    padding-bottom: 650px;
}

.seattle.card {
    border-color: #3cbaf8;
}

.seattle.card h1 {
    color: #04a9f8;
}

.seattle.card h2 {
    color: #015d89;
}

.seattle.card h3 {
    color: #012d42;
}

body.seattle nav {
    background-color: rgba(104, 56, 0, 0.5);
    color: #fff;
}

@media (max-width: 740px) {
    body {
        font-size: 16pt;
    }

    p.fancy {
        font-size: 1.4em;
    }

    p.fancy.invitation {
        font-size: 1.2em;
    }

    .day {
        font-size: 1.2em;
    }

    nav {
        font-size: 1.3em;
        padding: 0.5em 0;
    }

    .feature,
    .subfeature {
        padding-left: 24pt;
        padding-right: 24pt;
    }

    section.page {
        padding-top: 24pt;
        padding-bottom: 80pt;
    }

    .gifts.subfeature {
        padding-bottom: 80pt;
    }

    h1 {
        font-size: 40pt;
    }

    .name {
        font-size: 28pt;
    }

    section.schedule.page,
    section.accommodations.page,
    section.attire.page,
    section.accommodations.page,
    section.transportation.page {
        padding-top: 200px;
        background-position-y: -100px;
    }

    section.gifts.page {
        background-position-y: -100px;
    }
}

@media (max-width: 420px) {
    body {
        font-size: 12pt;
    }

    .feature,
    .subfeature {
        padding-left: 12pt;
        padding-right: 12pt;
    }

    section.page {
        padding-top: 12pt;
        padding-bottom: 80pt;
    }

    .gifts.subfeature {
        padding-bottom: 80pt;
    }

    h1 {
        font-size: 2.8em;
    }

    h2 {
        font-size: 1.7em;
    }

    p.fancy {
        font-size: 1.2em;
    }

    section.schedule.page,
    section.accommodations.page,
    section.attire.page,
    section.accommodations.page,
    section.transportation.page {
        background-position-y: -100px;
        padding-top: 100px;
    }

    section.gifts.page {
        background-position-y: -100px;
    }
}

@media (max-height: 640px) {
    nav {
        font-size: 1.2em;
    }

    section.welcome.page p.fancy {
        margin: 0.5em 0;
        font-size: 1.1em;
    }

    .map {
        height: 200px;
    }

    section.schedule.page,
    section.accommodations.page,
    section.attire.page,
    section.accommodations.page,
    section.transportation.page {
        background-position-y: -100px;
        padding-top: 100px;
    }

    section.gifts.page {
        background-position-y: -100px;
    }

    section.seattle.page {
        background-position: center bottom 0, center bottom 0, center bottom -100px;
        padding-bottom: 450px
    }
}

@media (max-height: 420px) and (min-width: 720px) {
    section.page {
        padding-bottom: 36pt;
    }

    .gifts.subfeature {
        padding-bottom: 36pt;
    }

    nav {
        font-size: 1em;
    }

    section.seattle.page {
        background-position: center bottom -100px, center bottom -100px, center bottom -200px;
        padding-bottom: 250px
    }
}

@media (max-width: 380px) {
    .feature,
    .subfeature {
        padding-left: 4pt;
        padding-right: 4pt;
    }

    section.page {
        padding-top: 4pt;
        padding-bottom: 80pt;
    }

    .gifts.subfeature {
        padding-bottom: 80pt;
    }
}