/* Agency-inspired: Clean modern with warm 'ice cream' accents (soft orange/pink), Inter for body, Playfair for headings */
* { margin: 0; padding: 0; box-sizing: border-box; }
body { 
    font-family: 'Inter', sans-serif; 
    line-height: 1.7; 
    color: #2d2d2d; 
    background: linear-gradient(to bottom, #fff8f0, #fff5f2); /* Subtle cream-to-peach gradient */
}
.container { max-width: 1000px; margin: 0 auto; padding: 0 20px; }

h1, h2 { font-family: 'Playfair Display', serif; color: #22bfe6; /* Warm orange accent */ }
h1 { font-size: 4rem; font-weight: 700; margin-bottom: 0.5rem; }
h2 { font-size: 2.5rem; font-weight: 400; margin: 3rem 0 1.5rem; text-align: center; }

.hero { 
    background: linear-gradient(135deg, #090909 0%, #3bd2f4 100%); /* Playful pink-orange gradient */
    text-align: center; 
    padding: 100px 20px; 
    box-shadow: inset 0 2px 10px rgba(0,0,0,0.05);
}
.tagline { 
    font-size: 2rem; 
    color: #fff; 
    margin: 1rem 0; 
    font-weight: 300; 
}
.subtitle { 
    font-size: 1.4rem; 
    color: #fff; 
    font-weight: 400; 
    opacity: 0.9;
}
.hero-card {
    background: rgba(255,255,255,0.9);
    padding: 20px;
    border-radius: 20px;
    margin: 2rem auto;
    max-width: 600px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.1);
}
.hero-card p { font-size: 1.3rem; font-weight: 600; color: #e67e22; }

.about-card, .contact-card, .gallery-card {
    background: #fff;
    padding: 40px;
    border-radius: 20px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
    margin: 2rem 0;
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Subtle hover lift */
}
.about-card:hover, .contact-card:hover { transform: translateY(-5px); box-shadow: 0 12px 35px rgba(0,0,0,0.12); }
.about ul { margin: 1.5rem 0; padding-left: 2rem; }
.about li { margin: 1rem 0; font-size: 1.2rem; color: #555; }

.contact { text-align: center; }
.contact-info p { font-size: 1.5rem; margin: 1rem 0; }
.contact a { color: #e67e22; text-decoration: none; font-weight: 600; border-bottom: 2px solid transparent; transition: border 0.3s; }
.contact a:hover { border-bottom-color: #e67e22; }
.small { font-size: 1.1rem; color: #777; margin-top: 1rem; }

.gallery { 
    display: grid; 
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); 
    gap: 25px; 
    margin-top: 2rem; 
}
.gallery-card { 
    text-align: center; 
    padding: 20px; 
    border-radius: 15px; 
    background: #fff; 
    box-shadow: 0 4px 15px rgba(0,0,0,0.06);
}
.gallery-card img { 
    width: 100%; 
    height: 200px; 
    object-fit: cover; 
    border-radius: 12px; 
    margin-bottom: 1rem;
}
.gallery-card p { font-size: 1.1rem; color: #666; font-style: italic; }

footer { 
    text-align: center; 
    padding: 40px; 
    background: linear-gradient(135deg, #090909 20%, #3bd2f4 100%);
    color: #fff; 
    margin-top: 4rem; 
    font-size: 1rem; 
    font-weight: 300;
}

@media (max-width: 768px) {
    h1 { font-size: 3rem; }
    .tagline { font-size: 1.6rem; }
    .about-card, .contact-card, .gallery-card { padding: 25px; }
    .gallery { grid-template-columns: 1fr; }
}