/* /Layout/MainLayout.razor.rz.scp.css */
/* ============================================================
   MAIN LAYOUT — CSS isolation (MainLayout.razor.css)
   ============================================================ */

/* ============================================================
   SKIP LINK (accessibilità tastiera)
   ============================================================ */

.skip-link[b-tcbmsgd8t1] {
    position: absolute;
    top: 0.5rem;
    left: 0.5rem;
    z-index: calc(var(--z-fixed) + 10);
    padding: 0.5rem 1rem;
    background: var(--color-ocean-blue);
    color: var(--color-on-accent);
    border-radius: var(--border-radius-md);
    font-weight: var(--font-weight-medium);
    font-size: var(--text-sm);
    text-decoration: none;
    transform: translateY(-200%);
    transition: transform var(--motion-fast) var(--motion-easing);
}

.skip-link:focus[b-tcbmsgd8t1] {
    transform: translateY(0);
}

/* ============================================================
   PAGE SHELL
   ============================================================ */

.page[b-tcbmsgd8t1] {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* ============================================================
   HEADER
   ============================================================ */

.site-header[b-tcbmsgd8t1] {
    background-color: var(--header-bg);
    border-bottom: 0.5px solid var(--header-border);
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    transition: box-shadow var(--motion-base) var(--motion-easing),
                background-color var(--motion-base) var(--motion-easing);
}

.site-header.is-scrolled[b-tcbmsgd8t1] {
    box-shadow: var(--shadow-sm);
}

.header-inner[b-tcbmsgd8t1] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

/* ============================================================
   MAIN CONTENT
   ============================================================ */

.main-content[b-tcbmsgd8t1] {
    flex: 1;
    position: relative;
    /* Rimossa l'animazione aggressiva contentFadeIn su tutti i figli */
}

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer[b-tcbmsgd8t1] {
    background-color: var(--footer-bg);
    color: var(--footer-text);
    position: relative;
    padding: 3.5rem 0 1.75rem;
}

/* Semantica heading nel footer: usiamo h2 con stile visivo da h5 */
.footer-heading[b-tcbmsgd8t1] {
    color: var(--footer-heading);
    position: relative;
    padding-bottom: 0.75rem;
    margin-bottom: 1rem;
    font-weight: var(--font-weight-medium);
    font-size: 0.9375rem;    /* 15px — visivo, non h1-h6 scalato */
    letter-spacing: 0.02em;
    font-family: var(--font-primary);  /* usa sans nel footer per leggibilità */
}

/* Accento sotto il titolo footer */
.footer-heading[b-tcbmsgd8t1]::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 28px;
    height: 2px;
    background: var(--color-coastal-light);
    border-radius: var(--border-radius-full);
}

/* Orari: definition list semantica */
.footer-hours[b-tcbmsgd8t1] {
    margin: 0;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.25rem 1rem;
}

.footer-hours dt[b-tcbmsgd8t1] {
    font-weight: var(--font-weight-medium);
    color: var(--footer-heading);
    opacity: 0.9;
    font-size: var(--text-sm);
}

.footer-hours dd[b-tcbmsgd8t1] {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--footer-text);
}

/* Links nel footer */
.site-footer a[b-tcbmsgd8t1] {
    color: var(--footer-text);
    transition: color var(--motion-fast) var(--motion-easing);
    display: inline-block;
}

.site-footer a:hover[b-tcbmsgd8t1] {
    color: var(--footer-heading);
}

.site-footer a:focus-visible[b-tcbmsgd8t1] {
    outline: 2px solid var(--color-coastal-light);
    outline-offset: 3px;
    border-radius: 3px;
}

/* Liste nel footer */
.site-footer ul[b-tcbmsgd8t1] {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.site-footer ul li[b-tcbmsgd8t1] {
    margin-bottom: 0.4rem;
}

/* Separatore bottom */
.footer-bottom[b-tcbmsgd8t1] {
    border-top: 0.5px solid var(--footer-line);
}

.footer-bottom small[b-tcbmsgd8t1] {
    font-size: var(--text-xs);
    color: rgba(255, 255, 255, 0.55);
}



/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
    .site-footer[b-tcbmsgd8t1] {
        padding: 2.25rem 0 1.25rem;
    }

    .site-footer .col-md-4[b-tcbmsgd8t1] {
        padding-bottom: 1.5rem;
        margin-bottom: 1.5rem;
        border-bottom: 0.5px solid var(--footer-line);
    }

    .site-footer .col-md-4:last-of-type[b-tcbmsgd8t1] {
        border-bottom: 0;
        margin-bottom: 0.5rem;
    }
}

/* ============================================================
   PRINT
   ============================================================ */

@media print {
    .site-header[b-tcbmsgd8t1],
    .site-footer[b-tcbmsgd8t1],
    .toast-region[b-tcbmsgd8t1] {
        display: none !important;
    }

    .main-content[b-tcbmsgd8t1] {
        padding-top: 0;
    }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
    .site-header[b-tcbmsgd8t1],
    .site-footer a[b-tcbmsgd8t1],
    .skip-link[b-tcbmsgd8t1] {
        animation: none;
        transition: none;
    }
}
/* /Layout/NavMenu.razor.rz.scp.css */
/* ========================================
   NAVBAR - OCEANSIDE DENTAL CENTRE
   Horizontal Layout with Modern Effects
   ======================================== */

.navbar[b-9fotgp9diy] {
    transition: all var(--transition-base);
}

.navbar-brand[b-9fotgp9diy] {
    transition: opacity var(--transition-base);
}

.navbar-brand:hover[b-9fotgp9diy] {
    opacity: 0.85;
}

.navbar-brand img[b-9fotgp9diy] {
    transition: filter var(--transition-base);
}

.navbar-brand img:hover[b-9fotgp9diy] {
    filter: brightness(1.05);
}

/* ========================================
   MOBILE LOGO CALIBRATION
   On the collapsed (hamburger) layout the full 224×100 logo towers over the
   ~53px toggler and inflates the header. Scale it to sit in harmony with the
   menu button while keeping the original aspect ratio. Desktop (xl+) keeps
   the full-size logo.
   ======================================== */
@media (max-width: 1199.98px) {
    .navbar-brand img[b-9fotgp9diy] {
        height: 56px;
        width: auto;
    }
}

@media (max-width: 575.98px) {
    .navbar-brand img[b-9fotgp9diy] {
        height: 50px;
    }
}

/* ========================================
   NAVBAR TOGGLER (Mobile)
   ======================================== */

.navbar-toggler[b-9fotgp9diy] {
    padding: 0.5rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
}

.navbar-toggler:hover[b-9fotgp9diy] {
    background-color: var(--color-ocean-blue);
    transform: scale(1.05);
}

.navbar-toggler:hover .navbar-toggler-icon[b-9fotgp9diy] {
    filter: brightness(0) invert(1);
}

.navbar-toggler:focus-visible[b-9fotgp9diy] {
    box-shadow: var(--shadow-glow);
}

.navbar-toggler-icon[b-9fotgp9diy] {
    transition: filter var(--transition-base);
}

/* ========================================
   NAV LINKS
   ======================================== */

.navbar-nav .nav-link[b-9fotgp9diy] {
    position: relative;
    color: var(--color-secondary-text);
    font-weight: var(--font-weight-medium);
    font-size: 0.9375rem; /* 15px */
    transition: color var(--motion-base) var(--motion-easing);
    padding: 0.5rem 0.875rem;
}

.navbar-nav .nav-link[b-9fotgp9diy]::before {
    content: '';
    position: absolute;
    bottom: 0.25rem;
    left: 0.875rem;
    right: 0.875rem;
    height: 2px;
    background: var(--color-ocean-blue);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--transition-base);
    border-radius: var(--radius-full);
}

.navbar-nav .nav-link:hover[b-9fotgp9diy],
.navbar-nav .nav-link:focus[b-9fotgp9diy] {
    color: var(--color-primary-text);
    text-decoration: none;
}

.navbar-nav .nav-link:hover[b-9fotgp9diy]::before {
    transform: scaleX(1);
}

.navbar-nav .nav-link.active[b-9fotgp9diy] {
    color: var(--color-ocean-blue);
}

.navbar-nav .nav-link.active[b-9fotgp9diy]::before {
    transform: scaleX(1);
}

.navbar-nav .nav-link:focus-visible[b-9fotgp9diy] {
    outline: 2px solid var(--color-coastal-light);
    outline-offset: 2px;
}


/* ========================================
   MOBILE MENU (Collapsed)
   ======================================== */

@media (max-width: 1199.98px) {
    .navbar-collapse[b-9fotgp9diy] {
        background: var(--color-surface);
        border-radius: var(--border-radius-lg);
        margin-top: 1rem;
        padding: 1rem;
        box-shadow: var(--shadow-lg);
        animation: mobileMenuSlide-b-9fotgp9diy var(--motion-base) var(--motion-easing) both;
    }

    @keyframes mobileMenuSlide-b-9fotgp9diy {
        from {
            opacity: 0;
            transform: translateY(-20px);
        }

        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    .nav-link[b-9fotgp9diy] {
        margin: 0.25rem 0;
    }

    .dropdown-menu[b-9fotgp9diy] {
        box-shadow: none;
        background: var(--color-bg-tint);
        margin-top: 0.25rem;
        margin-left: 1rem;
        border-left: 3px solid var(--color-coastal-light);
    }

    .dropdown-item[b-9fotgp9diy] {
        font-size: 0.9rem;
    }
}

/* ========================================
   DESKTOP ENHANCEMENTS
   ======================================== */

@media (min-width: 1200px) {
    .navbar-nav[b-9fotgp9diy] {
        gap: 0.25rem;
    }

    .dropdown-menu[b-9fotgp9diy] {
        min-width: 280px;
    }

    /* Smooth dropdown appearance */
    .dropdown:hover .dropdown-menu[b-9fotgp9diy] {
        display: block;
    }
}

/* ========================================
   ACCESSIBILITY
   ======================================== */

/* Focus states for keyboard navigation */
.nav-link:focus[b-9fotgp9diy],
.dropdown-item:focus[b-9fotgp9diy],
.navbar-toggler:focus[b-9fotgp9diy] {
    outline: 2px solid var(--color-ocean-blue);
    outline-offset: 2px;
}

/* Reduced motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
    .nav-link[b-9fotgp9diy]::before,
    .dropdown-item[b-9fotgp9diy]::before,
    .dropdown-toggle[b-9fotgp9diy]::after,
    .navbar-collapse[b-9fotgp9diy],
    .dropdown-menu[b-9fotgp9diy] {
        animation: none !important;
        transition: none !important;
    }
}

/* ========================================
   STICKY NAVBAR (Optional Enhancement)
   ======================================== */

.navbar.sticky-top[b-9fotgp9diy] {
    box-shadow: var(--shadow-md);
    transition: all var(--transition-base);
}

.navbar.navbar-scrolled[b-9fotgp9diy] {
    background-color: rgba(255, 255, 255, 0.98) !important;
    box-shadow: var(--shadow-lg);
}
/* /Layout/ToastContainer.razor.rz.scp.css */
/* ============================================================
   TOAST CONTAINER — CSS isolation (ToastContainer.razor.css)
   Spec: slide-in 300ms, no position fixed (usa flusso normale
   tramite portal posizionato nel layout).
   ============================================================ */

.toast-region[b-1g8v5qkafw] {
    position: fixed;            /* portal overlay visivo */
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: var(--z-toast, 1070);
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    width: 340px;
    max-width: calc(100vw - 2rem);
    pointer-events: none;       /* passa attraverso clic se vuoto */
}

/* ============================================================
   TOAST ITEM
   ============================================================ */

.toast-item[b-1g8v5qkafw] {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    background: var(--color-surface);
    border: 0.5px solid var(--color-border-subtle);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-lg);
    pointer-events: all;
    position: relative;

    /* Slide-in da destra — 300ms come da spec */
    animation: toast-slide-in-b-1g8v5qkafw var(--motion-open, 300ms) var(--motion-easing, cubic-bezier(0.4, 0, 0.2, 1)) both;
}

/* Accento laterale colorato per tipologia */
.toast-item[b-1g8v5qkafw]::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    border-radius: var(--border-radius-lg) 0 0 var(--border-radius-lg);
}

.toast-item--success[b-1g8v5qkafw]::before { background: var(--color-status-success); }
.toast-item--error[b-1g8v5qkafw]::before   { background: var(--color-status-danger); }
.toast-item--warning[b-1g8v5qkafw]::before { background: var(--color-status-warning); }
.toast-item--info[b-1g8v5qkafw]::before    { background: var(--color-ocean-blue); }

/* ============================================================
   TOAST ICON
   ============================================================ */

.toast-item__icon[b-1g8v5qkafw] {
    flex-shrink: 0;
    margin-top: 1px;
}

.toast-item--success .toast-item__icon[b-1g8v5qkafw] { color: var(--color-status-success); }
.toast-item--error   .toast-item__icon[b-1g8v5qkafw] { color: var(--color-status-danger); }
.toast-item--warning .toast-item__icon[b-1g8v5qkafw] { color: var(--color-status-warning); }
.toast-item--info    .toast-item__icon[b-1g8v5qkafw] { color: var(--color-ocean-blue); }

/* ============================================================
   TOAST CONTENT
   ============================================================ */

.toast-item__content[b-1g8v5qkafw] {
    flex: 1;
    min-width: 0;
}

.toast-item__title[b-1g8v5qkafw] {
    margin: 0 0 0.125rem;
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary-text);
    line-height: 1.35;
}

.toast-item__body[b-1g8v5qkafw] {
    margin: 0;
    font-size: var(--text-xs);
    color: var(--color-secondary-text);
    line-height: 1.4;
}

/* ============================================================
   TOAST CLOSE BUTTON
   ============================================================ */

.toast-item__close[b-1g8v5qkafw] {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: var(--border-radius-sm);
    color: var(--color-text-muted);
    cursor: pointer;
    margin-top: -2px;
    transition: color var(--motion-fast) var(--motion-easing),
                background-color var(--motion-fast) var(--motion-easing);
}

.toast-item__close:hover[b-1g8v5qkafw] {
    color: var(--color-primary-text);
    background-color: var(--color-surface-muted);
}

.toast-item__close:focus-visible[b-1g8v5qkafw] {
    outline: 2px solid var(--color-ocean-blue);
    outline-offset: 1px;
}

/* ============================================================
   ANIMATION
   ============================================================ */

@keyframes toast-slide-in-b-1g8v5qkafw {
    from {
        opacity: 0;
        transform: translateX(100%);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* ============================================================
   RESPONSIVE — stack bottom-center su mobile
   ============================================================ */

@media (max-width: 575.98px) {
    .toast-region[b-1g8v5qkafw] {
        bottom: 1rem;
        right: 0.75rem;
        left: 0.75rem;
        width: auto;
    }

    @keyframes toast-slide-in-b-1g8v5qkafw {
        from {
            opacity: 0;
            transform: translateY(1rem);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
}
