/* ==========================================================
   Epic Mayan Tours
   Digital Business Card
   style.css
========================================================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{

    font-family:'Montserrat',sans-serif;

    background:#f5fbff;

    color:#333;

    line-height:1.6;

}

/* ===========================
        HERO
=========================== */

.hero{

    width:100%;

    height:100vh;

    background-image:
        linear-gradient(
            rgba(0,40,80,.45),
            rgba(0,40,80,.45)
        ),
        url("hero.jpg");

    background-position:center;

    background-size:cover;

    background-repeat:no-repeat;

    display:flex;

    justify-content:center;

    align-items:center;

}

.overlay{

    text-align:center;

    padding:40px;

    backdrop-filter:blur(10px);

    background:rgba(255,255,255,.12);

    border-radius:25px;

    color:white;

    width:min(90%,700px);

}

.logo{

    width:170px;

    margin-bottom:20px;

}

h1{

    font-family:'Cinzel',serif;

    font-size:3rem;

    letter-spacing:2px;

}

h2{

    font-size:1.3rem;

    margin-top:10px;

    color:#ffd86b;

}

.company{

    margin-top:15px;

    font-size:1.1rem;

    font-weight:600;

}

.tagline{

    margin-top:20px;

    font-size:1.05rem;

    opacity:.95;

}

/* ===========================
      SECTION
=========================== */

section{

    padding:70px 20px;

}

section h3{

    text-align:center;

    font-size:2rem;

    color:#005a8d;

    margin-bottom:35px;

}

/* ===========================
     CONTACT CARD
=========================== */

.card{

    max-width:700px;

    margin:auto;

    background:white;

    border-radius:20px;

    box-shadow:0 15px 35px rgba(0,0,0,.10);

    overflow:hidden;

}

.row{

    padding:18px 30px;

    border-bottom:1px solid #eeeeee;

    font-size:1rem;

}

.row:last-child{

    border-bottom:none;

}

.row a{

    color:#005a8d;

    text-decoration:none;

    font-weight:600;

}

.row a:hover{

    color:#d4af37;

}

/* ===========================
      BUTTONS
=========================== */

.buttons{

    display:flex;

    justify-content:center;

    flex-wrap:wrap;

    gap:18px;

}

.btn{

    text-decoration:none;

    color:white;

    padding:15px 35px;

    border-radius:40px;

    font-weight:700;

    transition:.35s;

    box-shadow:0 10px 20px rgba(0,0,0,.15);

}

.btn:hover{

    transform:translateY(-4px);

    box-shadow:0 18px 30px rgba(0,0,0,.25);

}

.green{

    background:#25D366;

}

.blue{

    background:#0099ff;

}

.navy{

    background:#003b73;

}

.gold{

    background:#d4af37;

    color:#222;

}

/* ===========================
        ABOUT
=========================== */

.about{

    background:white;

}

.about p{

    max-width:900px;

    margin:auto;

    text-align:center;

    font-size:1.05rem;

}

/* ===========================
      TOURS GRID
=========================== */

.grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));

    gap:25px;

    max-width:1100px;

    margin:auto;

}

.tour{

    background:white;

    border-radius:18px;

    padding:35px;

    box-shadow:0 10px 25px rgba(0,0,0,.08);

    transition:.35s;

}

.tour:hover{

    transform:translateY(-8px);

}

.tour h4{

    color:#005a8d;

    margin-bottom:15px;

    font-size:1.4rem;

}

.tour p{

    color:#666;

}

/* ===========================
      DOWNLOAD
=========================== */

.download{

    background:#eef9ff;

    text-align:center;

}

.download p{

    margin-bottom:25px;

}

.download-btn{

    display:inline-block;

    background:#d4af37;

    color:#222;

    text-decoration:none;

    padding:16px 40px;

    border-radius:35px;

    font-weight:bold;

    transition:.3s;

}

.download-btn:hover{

    background:#c89b19;

    transform:translateY(-3px);

}

/* ===========================
        FOOTER
=========================== */

footer{

    background:#003b73;

    color:white;

    text-align:center;

    padding:60px 20px;

}

.footer-logo{

    width:120px;

    margin-bottom:20px;

}

footer h4{

    font-family:'Cinzel',serif;

    font-size:2rem;

    margin-bottom:10px;

}

footer p{

    margin-top:8px;

    opacity:.9;

}

/* ===========================
     RESPONSIVE
=========================== */

@media(max-width:768px){

.hero{

    height:80vh;

}

.overlay{

    padding:25px;

}

.logo{

    width:120px;

}

h1{

    font-size:2.2rem;

}

h2{

    font-size:1.1rem;

}

.company{

    font-size:1rem;

}

.tagline{

    font-size:.95rem;

}

.buttons{

    flex-direction:column;

    align-items:center;

}

.btn{

    width:280px;

    text-align:center;

}

section{

    padding:50px 15px;

}

section h3{

    font-size:1.7rem;

}

.row{

    padding:16px 18px;

}

}
.hero{

    height:100vh;

    background:

    linear-gradient(
        rgba(0,40,80,.35),
        rgba(0,40,80,.35)
    ),

    url("hero.jpg");

    background-size:cover;

    background-position:center;

    background-repeat:no-repeat;

}
/*==========================================
        OUR EXPERIENCES
==========================================*/

.gallery{

    padding:100px 20px;

    background:#ffffff;

}

.container{

    max-width:1450px;

    margin:auto;

}

.gallery-title{

    text-align:center;

    font-size:52px;

    font-family:'Cinzel',serif;

    color:#003B73;

    margin-bottom:15px;

}

.gallery-subtitle{

    text-align:center;

    font-size:24px;

    color:#C89B19;

    letter-spacing:2px;

    margin-bottom:60px;

}

.gallery-card{

    overflow:hidden;

    border-radius:24px;

    box-shadow:0 20px 45px rgba(0,0,0,.18);

    transition:.45s;

}

.gallery-card:hover{

    transform:translateY(-8px);

    box-shadow:0 30px 60px rgba(0,0,0,.25);

}

.gallery-image{

    width:100%;

    max-width:1400px;

    margin:auto;

    display:block;

    
}

.gallery-card:hover .gallery-image{

    transform:scale(1.02);

}
.gallery-card {
    overflow: hidden;
    border-radius: 24px;
    box-shadow: 0 20px 45px rgba(0,0,0,.18);
}

.gallery-card img {
    display: block;
    width: 100%;
    transition: transform .5s ease;
}

.gallery-card:hover img {
    transform: scale(1.03);
}
/*==========================================
            QR CODE SECTION
==========================================*/

.qr-section{

    background:#f7fbff;

    padding:90px 20px;

    text-align:center;

}

.qr-section h2{

    font-size:42px;

    color:#003B73;

    font-family:'Cinzel',serif;

    margin-bottom:15px;

}

.qr-section p{

    color:#666;

    font-size:20px;

    margin-bottom:40px;

}

.qr-card{

    display:inline-block;

    background:white;

    padding:25px;

    border-radius:25px;

    box-shadow:0 15px 40px rgba(0,0,0,.18);

    transition:.4s;

}

.qr-card:hover{

    transform:translateY(-6px);

}

.qr-image{

    width:260px;

    max-width:100%;

    display:block;

}

.qr-buttons{

    margin-top:40px;

    display:flex;

    justify-content:center;

    flex-wrap:wrap;

    gap:20px;

}