/* Base */
body {
    font-family: 'Roboto', sans-serif;
    margin: 0;
    padding: 0;
    color: #e0e0e0;
    background-color: #121212;
}

a {
    text-decoration: none;
    color: #fff;
}

a:hover {
    color: #00bfff;
}

.container {
    max-width: 1100px;
    width: 92%;
    margin: 0 auto;
    padding: 0 1em;
}

/* =====================
   HEADER
   ===================== */

header {
    background-color: #1f1f1f;
    padding: 0.75em 0; /* REDUCED */
    text-align: center;
}

/* LOGO — FIXED */
header .logo {
    max-width: 160px;     /* Desktop */
    width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
}

/* NAV */
header nav {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1em;
    margin-top: 0.5em;
}

header nav a {
    font-weight: 500;
    font-size: 1rem;
}

/* =====================
   HERO SECTION
   ===================== */

.hero {
    position: relative;
    background-size: cover;
    background-position: center;
    min-height: 45vh;  /* WAS TOO BIG */
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    text-align: left;
    padding: 2em;
}

.hero h2 {
    font-size: 2rem;
    margin-bottom: 0.5em;
}

.hero p {
    font-size: 1rem;
}

/* =====================
   CONTENT / IMAGES
   ===================== */

.about,
.about-preview {
    padding: 3em 0;
    text-align: center;
}

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

/* =====================
   INSTAGRAM
   ===================== */

#instagram-feed {
    padding: 3em 0;
    text-align: center;
}

.snapwidget-widget {
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
    border-radius: 8px;
}

/* =====================
   CONTACT
   ===================== */

#contact {
    padding: 3em 0;
    text-align: center;
}

.contact-info {
    margin-bottom: 1.5em;
    font-size: 1rem;
    line-height: 1.5em;
}

.contact-button {
    display: inline-block;
    padding: 0.9em 1.8em;
    background-color: #00bfff;
    color: #fff;
    font-weight: bold;
    border-radius: 8px;
    transition: transform 0.2s;
}

.contact-button:hover {
    transform: scale(1.05);
}

/* =====================
   FOOTER
   ===================== */

footer {
    background-color: #1f1f1f;
    padding: 1em 0;
    text-align: center;
    color: #888;
}

/* =====================
   TABLET
   ===================== */

@media (max-width: 768px) {
    header .logo {
        max-width: 130px;
    }

    .hero {
        min-height: 35vh;
        padding: 1.5em;
    }

    .hero h2 {
        font-size: 1.6rem;
    }
}

/* =====================
   MOBILE — KEY FIX
   ===================== */

@media (max-width: 480px) {
    header {
        padding: 0.5em 0;   /* BIG FIX */
    }

    header .logo {
        max-width: 95px;    /* HARD CAP */
    }

    header nav a {
        font-size: 0.95rem;
    }

    .hero {
        min-height: 28vh;   /* HUGE FIX */
        padding: 1em;
    }

    .hero h2 {
        font-size: 1.3rem;
    }

    .hero p {
        font-size: 0.9rem;
    }
}
