/* Family Dentistry of Livonia - Core Styles */

/* Color palette (from logo/business card) */
:root {
    --fdl-blue: #1f7fbc;
    --fdl-blue-dark: #165a82;
    --fdl-green: #7ab73b;
    --fdl-green-deep: #4a8c24;
    --fdl-gray-light: #f5f7fb;
    --fdl-gray-mid: #8b96a6;
    --fdl-text-dark: #233142;
    --fdl-white: #ffffff;
}

/* Global */
html, body {
    scroll-behavior: smooth;
}

body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--fdl-text-dark);
    background-color: var(--fdl-white);
}

/* Logo and brand */
.navbar-brand {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.fdl-logo {
    height: 70px;
    width: auto;
    display: block;
    margin-top: -18px;
}

.fdl-brand-text {
    font-family: "Poppins", sans-serif;
    font-weight: 700;
    font-size: 1.3rem;
    letter-spacing: 0.06em;
    color: var(--fdl-blue-dark);
    text-transform: uppercase;
    line-height: 1.1;
    padding-top: 2px;
}

/* Navbar */
.navbar-light .navbar-nav .nav-link {
    font-weight: 500;
    color: var(--fdl-text-dark);
}

.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link:focus {
    color: var(--fdl-blue);
}

.navbar .btn-primary {
    background: linear-gradient(135deg, var(--fdl-blue), var(--fdl-green));
    border: none;
    font-weight: 600;
    padding-inline: 1.5rem;
    border-radius: 999px;
}

.navbar .btn-primary:hover {
    background: linear-gradient(135deg, var(--fdl-blue-dark), var(--fdl-green-deep));
}

/* Hero */
.fdl-hero {
    position: relative;
    background: radial-gradient(circle at top left, #e5f6ff, #ffffff);
    overflow: hidden;
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
}

.fdl-hero-wave {
    position: absolute;
    inset-inline: 0;
    bottom: -60px;
    height: 160px;
    background: radial-gradient(circle at top, #cdeed9, #ffffff);
    transform: skewY(-4deg);
    z-index: -1;
}

.fdl-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-size: 0.95rem;
    color: var(--fdl-green-deep);
    font-weight: 600;
}

.fdl-hero-title {
    font-size: clamp(2.2rem, 4vw, 2.8rem);
    font-weight: 700;
    color: var(--fdl-blue-dark);
}

.fdl-hero-subtitle {
    font-size: 1.05rem;
    color: var(--fdl-gray-mid);
}

.fdl-hero-phone .fdl-label {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--fdl-gray-mid);
}

.fdl-phone-link {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--fdl-blue-dark);
    text-decoration: none;
}

.fdl-phone-link:hover {
    color: var(--fdl-blue);
}

/* Pill cards under hero text - FIXED to stay single line */
.fdl-pill-card {
    background: rgba(255, 255, 255, 0.9);
    border-radius: 999px;
    padding: 0.8rem 1rem;
    font-size: 0.85rem;
    color: var(--fdl-blue-dark);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
    white-space: nowrap;
    text-align: center;
}

/* Hero doctor card */
.fdl-hero-card {
    background: var(--fdl-white);
    border-radius: 24px;
    padding: 1.75rem;
}

.fdl-hero-photo-wrapper {
    border-radius: 20px;
    overflow: hidden;
    border: 3px solid rgba(127, 191, 95, 0.4);
}

.fdl-hero-photo {
    width: 100%;
    height: auto;
    display: block;
}

/* Sections */
.fdl-section-title {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--fdl-blue-dark);
}

.fdl-section-subtitle {
    max-width: 540px;
    margin: 0.25rem auto 0;
    color: var(--fdl-gray-mid);
}

/* Feature cards */
.fdl-feature-card {
    background: var(--fdl-white);
    border-radius: 18px;
    padding: 1.5rem 1.6rem;
    box-shadow: 0 14px 40px rgba(15, 35, 52, 0.06);
}

/* Services section background */
#services {
    background: radial-gradient(circle at top, #f0f7ff, #ffffff);
}

/* Service cards */
.fdl-service-card {
    background: var(--fdl-white);
    border-radius: 16px;
    padding: 1.4rem 1.4rem 1.2rem;
    border: 1px solid #e3e8f0;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.fdl-service-card:hover {
    transform: translateY(-4px);
    border-color: var(--fdl-blue);
    box-shadow: 0 16px 40px rgba(21, 101, 192, 0.18);
}

/* New patients section background */
#new-patients {
    background: linear-gradient(135deg, #f4fbf4, #ffffff);
}

/* New patients */
.fdl-checklist {
    list-style: none;
    padding-left: 0;
    margin-bottom: 0;
}

.fdl-checklist li {
    position: relative;
    padding-left: 1.6rem;
    margin-bottom: 0.6rem;
}

.fdl-checklist li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0.05rem;
    color: var(--fdl-green-deep);
    font-weight: 700;
}

.fdl-info-card {
    background: var(--fdl-white);
    border-radius: 16px;
    padding: 1.6rem 1.8rem;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.06);
}

/* Map placeholder */
.fdl-map-placeholder {
    background: linear-gradient(135deg, #e1f2ff, #e6f6ec);
    border-radius: 18px;
    padding: 1.8rem;
    color: var(--fdl-blue-dark);
    display: flex;
    align-items: center;
    min-height: 220px;
}

/* Contact form card */
.fdl-form-card {
    background: var(--fdl-white);
    border-radius: 18px;
    padding: 1.8rem 1.9rem;
}

.fdl-form-note {
    font-size: 0.85rem;
    color: var(--fdl-gray-mid);
}

/* Buttons */
.btn-primary {
    background: linear-gradient(135deg, var(--fdl-blue), var(--fdl-green));
    border: none;
    font-weight: 600;
}

.btn-primary:hover,
.btn-primary:focus {
    background: linear-gradient(135deg, var(--fdl-blue-dark), var(--fdl-green-deep));
}

.btn-outline-primary {
    color: var(--fdl-blue-dark);
    border-color: var(--fdl-blue);
    font-weight: 600;
}

.btn-outline-primary:hover {
    background: var(--fdl-blue);
    border-color: var(--fdl-blue);
    color: var(--fdl-white);
}

/* Footer */
.fdl-footer {
    background: #0f2233;
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.88rem;
}

.fdl-footer a {
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
}

.fdl-footer a:hover {
    text-decoration: underline;
}

/* Tighten section spacing */
section {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
    .fdl-hero {
        padding-top: 1.5rem !important;
    }

    .fdl-hero-card {
        margin-top: 1.5rem;
    }

    .fdl-hero-wave {
        bottom: -90px;
    }
    
    .fdl-pill-card {
        font-size: 0.8rem;
    }
}
