:root{
    --color-primary:#012233;
    --color-text:#5d5d5d;
    --color-divider:#fcdca9;
    --color-overlay:rgba(156,169,176,0.20);
    --color-bg:#ffffff;
    --max-width:1170px;
}

*{
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    margin:0;
    background:var(--color-bg);
    color:var(--color-text);
    font-family:"Roboto", Arial, sans-serif;
    line-height:1.8;
}

img{
    max-width:100%;
    height:auto;
    display:block;
}

a{
    color:#d98972;
    text-decoration:none;
    transition:color 250ms ease;
}

a:hover{
    color:#c46f57;
    text-decoration:none;
}

.container{
    width:min(calc(100% - 40px), var(--max-width));
    margin:0 auto;
}

/* Header */
.site-header{
    background:#ffffff;
    position:sticky;
    top:0;
    z-index:1000;
}

.site-header-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    padding:10px 0;
}

.site-title{
    font-family:"Cabin", Arial, sans-serif;
    font-size:24px;
    font-weight:700;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--color-primary);
    margin:0;
}

.site-nav ul{
    list-style:none;
    display:flex;
    gap:0;
    margin:0;
    padding:0;
}

.site-nav a{
    display:block;
    padding:10px 25px;
    font-family:"Cabin", Arial, sans-serif;
    font-size:13px;
    font-weight:700;
    text-transform:uppercase;
    color:var(--color-primary);
}

/* Hero */
.hero{
    position:relative;
    padding:110px 0 90px;
    overflow:hidden;
}

.hero::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:url("../img/banner.jpg");
    background-position:center;
    background-repeat:no-repeat;
    background-size:cover;
    transform:scaleX(-1);
    transform-origin:center;
}

.hero::after{
    content:"";
    position:absolute;
    inset:0;
    background:var(--color-overlay);
}

.hero-inner{
    position:relative;
    z-index:1;
    text-align:center;
}

.hero-title{
    margin:0;
    font-family:"Cabin", Arial, sans-serif;
    font-size:65px;
    font-weight:900;
    letter-spacing:18px;
    text-transform:uppercase;
    color:var(--color-primary);
    line-height:1.2;
}

.hero-subtitle{
    display:inline-block;
    margin:35px auto 0;
    max-width:900px;
    padding:10px 18px;
    font-size:20px;
    line-height:1.8;
    color:#000000;
    background:radial-gradient(
        ellipse at center,
        rgba(255,255,255,0.25) 0%,
        rgba(255,255,255,0.22) 45%,
        rgba(255,255,255,0.12) 70%,
        rgba(255,255,255,0) 100%
    );
}

/* Sections */
.section{
    padding:80px 0;
}

.section-title{
    margin:0;
    text-align:center;
    font-family:"Cabin", Arial, sans-serif;
    font-size:30px;
    font-weight:700;
    letter-spacing:5px;
    text-transform:uppercase;
    color:var(--color-primary);
}

.divider{
    width:7%;
    min-width:70px;
    margin:10px auto 30px;
    border-top:2px solid var(--color-divider);
}

.intro-text{
    max-width:760px;
    margin:0 auto;
    text-align:center;
    font-size:14px;
    color:var(--color-text);
}

.intro-text p{
    margin:0 0 1.4em;
}

.intro-text strong{
    font-weight:700;
}

.intro-section{
    padding-bottom:12px;
}

.signature{
    font-style:italic;
    font-weight:500;
}

/* Photo block */
.photo-block{
    padding:0px 0 10px;
}

.photo-wrap{
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
}

.photo-image-link{
    display:inline-block;
    margin:0 auto;
}

.photo-image{
    display:block;
    margin:0 auto;
    max-width:100%;
    width:auto;
}

.photo-caption{
    margin:18px auto 0;
    text-align:center;
    font-size:14px;
    color:var(--color-text);
}

.rule{
    border:0;
    border-top:1px solid #999999;
    margin:30px 0 0;
}

/* CTA */
.cta-band{
    padding:115px 0 30px;
}

.cta-button{
    display:block;
    width:100%;
    margin:0 auto;
    border:2px solid var(--color-divider);
    background:#ffffff;
    color:#000000;
    text-align:center;
    font-family:"Cabin", Arial, sans-serif;
    font-size:14px;
    font-weight:700;
    line-height:1.2;
    text-transform:uppercase;
    padding:19px 20px;
    transition:all 400ms ease;
}

.cta-button:hover{
    background:#faf7f0;
}

/* Footer */
.site-footer{
    background-color:#012233;
    color:#ffffff;
    padding:60px 0;
}

.footer-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
}

.footer-title{
    margin:0 0 24px;
    font-family:"Cabin", Arial, sans-serif;
    font-size:30px;
    font-weight:700;
    letter-spacing:5px;
    text-transform:uppercase;
    color:#ffffff;
}

.footer-text{
    margin:0;
    font-size:14px;
    line-height:1.8;
    color:#ffffff;
}

.footer-contact{
    display:flex;
    gap:14px;
    align-items:flex-start;
}

.footer-contact-icon{
    font-size:22px;
    line-height:1;
    margin-top:2px;
    color:#ffffff;
}

/* About page */
.page-hero{
    position:relative;
    background-position:center;
    background-repeat:no-repeat;
    background-size:cover;
    padding:150px 0;
    overflow:hidden;
}

.page-hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:var(--color-overlay);
}

.page-hero-inner{
    position:relative;
    z-index:1;
    text-align:center;
}

.page-hero-title{
    margin:0;
    font-family:"Cabin", Arial, sans-serif;
    font-size:35px;
    font-weight:700;
    letter-spacing:5px;
    text-transform:uppercase;
    color:var(--color-primary);
}

.story-section{
    padding:0 0 80px;
}

.story-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:30px;
    align-items:center;
}

.story-copy{
    padding-right:15%;
}

.story-copy.rightless{
    padding-right:0;
    padding-left:15%;
}

.story-heading{
    margin:0;
    font-family:"Cabin", Arial, sans-serif;
    font-size:30px;
    font-weight:700;
    line-height:1.5;
    letter-spacing:5px;
    text-transform:uppercase;
    color:var(--color-primary);
}

.story-divider{
    width:20%;
    min-width:70px;
    margin:10px 0 20px;
    border-top:2px solid var(--color-divider);
}

.story-text{
    font-size:14px;
    color:var(--color-text);
}

.story-text p{
    margin:0 0 1.4em;
}

.story-image-wrap{
    display:flex;
    justify-content:center;
}

.story-image{
    display:block;
    max-width:100%;
    height:auto;
}

.story-button{
    display:inline-block;
    border:2px solid var(--color-divider);
    background:#ffffff;
    color:#303030;
    text-align:center;
    font-family:"Cabin", Arial, sans-serif;
    font-size:14px;
    font-weight:700;
    line-height:1.2;
    text-transform:uppercase;
    padding:16px 20px;
    transition:all 400ms ease;
}

.story-button:hover{
    background:#faf7f0;
}

/* Reveal animations */
.reveal{
    opacity:0;
    transform:translateY(70px);
    transition:opacity 1100ms ease, transform 1100ms ease;
}

.reveal.is-visible{
    opacity:1;
    transform:translateY(0);
}

.reveal-down{
    opacity:0;
    transform:translateY(-70px);
    transition:opacity 1100ms ease, transform 1100ms ease;
}

.reveal-down.is-visible{
    opacity:1;
    transform:translateY(0);
}

.reveal-left{
    opacity:0;
    transform:translateX(-110px);
    transition:opacity 1100ms ease, transform 1100ms ease;
}

.reveal-left.is-visible{
    opacity:1;
    transform:translateX(0);
}

.reveal-right{
    opacity:0;
    transform:translateX(110px);
    transition:opacity 1100ms ease, transform 1100ms ease;
}

.reveal-right.is-visible{
    opacity:1;
    transform:translateX(0);
}

/* Responsive */
@media (max-width:780px){
    .site-header-inner{
        flex-direction:column;
        align-items:flex-start;
    }

    .site-nav ul{
        flex-wrap:wrap;
    }

    .hero{
        padding:100px 0;
    }

    .hero-title{
        font-size:30px;
        letter-spacing:6px;
    }

    .hero-subtitle{
        font-size:16px;
    }

    .section{
        padding:50px 0;
    }

    .section-title{
        font-size:25px;
    }

    .cta-band{
        padding:70px 0 25px;
    }

    .site-footer{
        padding:40px 0;
    }

    .footer-grid{
        grid-template-columns:1fr;
        gap:30px;
    }

    .footer-title{
        font-size:25px;
    }

    .page-hero{
        padding:120px 0;
    }

    .page-hero-title{
        font-size:30px;
    }

    .story-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .story-copy,
    .story-copy.rightless{
        padding-right:0;
        padding-left:0;
    }
}

@media (max-width:480px){
    .site-title{
        font-size:22px;
    }

    .site-nav a{
        padding:10px 14px;
    }

    .hero{
        padding:80px 0;
    }

    .hero-title{
        font-size:25px;
        letter-spacing:5px;
    }

    .hero-subtitle{
        font-size:14px;
    }

    .section{
        padding:40px 0;
    }

    .section-title{
        font-size:20px;
    }

    .intro-text{
        max-width:100%;
    }

    .footer-title{
        font-size:20px;
    }

    .page-hero{
        padding:100px 0;
    }

    .page-hero-title{
        font-size:22px;
    }

    .story-section{
        padding:0 0 40px;
    }

    .story-heading{
        font-size:20px;
    }
}
/* Contact page */
/* Contact page */
.contact-intro{
    padding:90px 0 0;
}

.contact-copy{
    max-width:650px;
    margin:0 auto;
    text-align:center;
    font-size:14px;
    color:var(--color-text);
}

.contact-copy p{
    margin:0 0 1.6em;
}

.contact-copy strong{
    font-weight:700;
}

.contact-band{
    background:#012233;
    margin-top:70px;
    padding:70px 0;
    text-align:center;
}

.contact-band-inner{
    max-width:1170px;
    margin:0 auto;
}

.contact-band-title{
    margin:0 0 14px;
    font-family:"Cabin", Arial, sans-serif;
    font-size:24px;
    font-weight:700;
    letter-spacing:5px;
    text-transform:uppercase;
    color:#ffffff;
    text-align:center;
}

.contact-address{
    color:#ffffff;
    font-family:"Cabin", Arial, sans-serif;
    font-size:14px;
    line-height:1.6;
    text-align:center;
}



.contact-rule{
    border:0;
    border-top:1px solid #2d4b59;
    margin:0;
}

.comments-section{
    padding:50px 0 80px;
}

.comments-title{
    margin:0 0 30px;
    font-family:"Cabin", Arial, sans-serif;
    font-size:24px;
    font-weight:700;
    letter-spacing:3px;
    text-transform:none;
    color:var(--color-primary);
}

.comment-item{
    padding:28px 0;
    border-top:1px solid #d7d7d7;
}

.comment-item:last-child{
    border-bottom:1px solid #d7d7d7;
}

.comment-author{
    margin:0 0 6px;
    font-family:"Cabin", Arial, sans-serif;
    font-size:18px;
    font-weight:700;
    color:var(--color-primary);
}

.comment-meta{
    margin:0 0 14px;
    font-size:14px;
    color:#777777;
}

.comment-body{
    font-size:14px;
    color:var(--color-text);
}

.comment-body p{
    margin:0 0 1.2em;
}

@media (max-width:780px){
    .contact-intro{
        padding:50px 0 0;
    }

    .contact-band{
        margin-top:40px;
        padding:40px 0;
    }

    .comments-section{
        padding:40px 0 50px;
    }
}

@media (max-width:480px){
    .contact-band{
        margin-top:35px;
        padding:35px 0;
    }

    .contact-band-title{
        font-size:20px;
    }

    .comments-title{
        font-size:20px;
    }

    .comment-author{
        font-size:16px;
    }
}