/**********************************************************
  ______ ____  _   _ _______ _____ 
 |  ____/ __ \| \ | |__   __/ ____|
 | |__ | |  | |  \| |  | | | (___  
 |  __|| |  | | . ` |  | |  \___ \ 
 | |   | |__| | |\  |  | |  ____) |
 |_|    \____/|_| \_|  |_| |_____/ 
                                   
**********************************************************/

@font-face {
    font-family: "Nunito-Bold";
    src: url("/fonts/Nunito-Bold.ttf");
}

@font-face {
    font-family: "Nunito-BoldItalic";
    src: url("/fonts/Nunito-BoldItalic.ttf");
}

@font-face {
    font-family: "Nunito-Italic";
    src: url("/fonts/Nunito-Italic.ttf");
}

@font-face {
    font-family: "Nunito-Light";
    src: url("/fonts/Nunito-Light.ttf");
}

@font-face {
    font-family: "Nunito-LightItalic";
    src: url("/fonts/Nunito-LightItalic.ttf");
}

@font-face {
    font-family: "Nunito-Medium";
    src: url("/fonts/Nunito-Medium.ttf");
}

@font-face {
    font-family: "Nunito-MediumItalic";
    src: url("/fonts/Nunito-MediumItalic.ttf");
}

@font-face {
    font-family: "Nunito-Regular";
    src: url("/fonts/Nunito-Regular.ttf");
}

@font-face {
    font-family: "Nunito-SemiBold";
    src: url("/fonts/Nunito-SemiBold.ttf");
}

@font-face {
    font-family: "Nunito-SemiBoldItalic";
    src: url("/fonts/Nunito-SemiBoldItalic.ttf");
}

/**********************************************************
   _____ ______ _______ _______ _____ _   _  _____  _____ 
  / ____|  ____|__   __|__   __|_   _| \ | |/ ____|/ ____|
 | (___ | |__     | |     | |    | | |  \| | |  __| (___  
  \___ \|  __|    | |     | |    | | | . ` | | |_ |\___ \ 
  ____) | |____   | |     | |   _| |_| |\  | |__| |____) |
 |_____/|______|  |_|     |_|  |_____|_| \_|\_____|_____/ 

**********************************************************/

/* Variables de couleurs - Direction artistique L'Amusée Paris */
:root {
    --color-primary: #2c2c2c;
    --color-primary-dark: #1a1a1a;
    --color-primary-light: #4a4a4a;
    --color-secondary: #f5f5f5;
    --color-accent: #e8e8e8;
    --color-text: #1a1a1a;
    --color-text-light: #6b6b6b;
    --color-bg: #fafafa;
    --color-white: #ffffff;
    --color-border: #e0e0e0;
    --color-shadow: rgba(0, 0, 0, 0.06);
    --color-shadow-hover: rgba(0, 0, 0, 0.12);
}

/* Application des fonts personnalisées */
body {
    font-family: 'Nunito-Regular', 'Helvetica Neue', sans-serif;
    color: var(--color-text);
    background-color: var(--color-bg);
    line-height: 1.6;
}

h1, h2 {
    font-family: 'Nunito-Bold', 'Helvetica Neue', sans-serif;
    color: var(--color-text);
    letter-spacing: -0.02em;
}

h3 {
    font-family: 'Nunito-SemiBold', 'Helvetica Neue', sans-serif;
    color: var(--color-text);
}

h4, h5 {
    font-family: 'Nunito-Medium', 'Helvetica Neue', sans-serif;
    color: var(--color-text);
}

/* Layout principal */
main {
    margin-left: 200px;
    padding: 40px;
    min-height: 100vh;
    background-color: var(--color-bg);
}

/* Container pour le dashboard */
.d-flex.pb-4.gap-4 {
    flex-wrap: nowrap;
}

@media (max-width: 1200px) {
    .d-flex.pb-4.gap-4 {
        flex-wrap: wrap;
    }
    
    .d-flex.pb-4.gap-4 > .card:first-child {
        width: 100% !important;
        margin-bottom: 20px;
    }
    
    .d-flex.pb-4.gap-4 > .card:last-child {
        width: 100% !important;
    }
}

/* Header sidebar - Style épuré L'Amusée */
header {
    background: var(--color-white);
    width: 200px;
    height: 100%;
    min-height: 100vh;
    overflow-y: auto;
    position: fixed;
    top: 0;
    left: 0;
    box-shadow: 2px 0 8px var(--color-shadow);
    border-right: 1px solid var(--color-border);
    scrollbar-width: thin;
    scrollbar-color: var(--color-accent) var(--color-secondary);
}

header::-webkit-scrollbar {
    width: 6px;
}

header::-webkit-scrollbar-thumb {
    background-color: var(--color-accent);
    border-radius: 10px;
}

header::-webkit-scrollbar-track {
    background-color: var(--color-secondary);
}

/* Logo */
.logo {
    padding: 30px 20px;
    border-bottom: 1px solid var(--color-border);
    background: var(--color-secondary);
}

.logo a {
    transition: transform 0.3s ease;
}

.logo a:hover {
    transform: scale(1.05);
}

/* Styles pour les liens dans la sidebar */
header nav a,
header .sidebar-footer a {
    transition: all 0.2s ease;
    border-radius: 0;
    margin: 0;
    font-weight: 400;
    font-size: 0.9rem;
    letter-spacing: 0.02em;
}

header nav a:hover,
header .sidebar-footer a:hover {
    color: var(--color-text) !important;
    background-color: var(--color-secondary) !important;
    transform: none;
}

/* Styles pour les liens actifs dans la sidebar */
.active-link {
    color: var(--color-text) !important;
    background-color: var(--color-secondary) !important;
    font-weight: 600;
}

/* Cards - Style épuré L'Amusée */
.card {
    border: 1px solid var(--color-border);
    border-radius: 0;
    box-shadow: 0 1px 3px var(--color-shadow);
    transition: all 0.2s ease;
    background: var(--color-white);
    overflow: hidden;
}

.card:hover {
    box-shadow: 0 4px 12px var(--color-shadow-hover);
    border-color: var(--color-text-light);
}

/* Cartes imbriquées (dans le dashboard) */
.card .card {
    border: 1px solid var(--color-border);
    box-shadow: 0 1px 2px var(--color-shadow);
    background: var(--color-white);
}

.card .card:hover {
    box-shadow: 0 2px 6px var(--color-shadow-hover);
    border-color: var(--color-text-light);
}

.card-body {
    padding: 30px;
}

/* Badges - Style minimaliste L'Amusée */
.badge {
    padding: 6px 12px;
    border-radius: 0;
    font-weight: 400;
    font-size: 0.8rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border: 1px solid var(--color-border);
}

.bg-secondary {
    background-color: var(--color-white) !important;
    color: var(--color-text) !important;
    border-color: var(--color-border) !important;
}

.bg-success {
    background: var(--color-white) !important;
    color: var(--color-text) !important;
    border-color: #4a9b6e !important;
}

.bg-danger {
    background: var(--color-white) !important;
    color: var(--color-text) !important;
    border-color: #d87a6a !important;
}

/* Buttons - Style minimaliste L'Amusée */
.btn-primary {
    background: var(--color-primary);
    border: 1px solid var(--color-primary);
    border-radius: 0;
    padding: 12px 32px;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.875rem;
    transition: all 0.2s ease;
    box-shadow: none;
}

.btn-primary:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    transform: none;
    box-shadow: none;
}

.btn-link {
    color: var(--color-text-light);
    transition: all 0.3s ease;
}

.btn-link:hover {
    color: var(--color-primary);
    transform: scale(1.1);
}

/* Form controls - Style épuré L'Amusée */
.form-control {
    border: 1px solid var(--color-border);
    border-radius: 0;
    padding: 12px 16px;
    transition: all 0.2s ease;
    background: var(--color-white);
    color: var(--color-text);
    font-size: 0.95rem;
}

.form-control:focus {
    border-color: var(--color-text);
    box-shadow: none;
    outline: none;
    background: var(--color-white);
}

.form-label {
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 8px;
    font-size: 0.9rem;
}

/* Navigation pills - Style minimaliste L'Amusée */
.nav-pills .nav-link {
    border-radius: 0;
    padding: 12px 20px;
    color: var(--color-text);
    transition: all 0.2s ease;
    font-weight: 400;
    margin: 0 2px;
    border-bottom: 2px solid transparent;
    pointer-events: auto !important;
    position: relative;
    z-index: 11;
    cursor: pointer;
}

.nav-pills .nav-link:hover {
    background-color: transparent;
    color: var(--color-text);
    border-bottom-color: var(--color-border);
}

.nav-pills .nav-link.active {
    background: transparent;
    color: var(--color-text);
    border-bottom-color: var(--color-primary);
    font-weight: 600;
    box-shadow: none;
}

/* Assurer que la barre de navigation est toujours cliquable */
.pb-4 > .card {
    position: relative;
    z-index: 10;
}

.pb-4 > .card .card-body {
    position: relative;
    z-index: 10;
}

.pb-4 > .card .nav-pills {
    position: relative;
    z-index: 10;
}

.pb-4 > .card .nav-item {
    position: relative;
    z-index: 11;
}

/* Dropdown - Style épuré L'Amusée */
.dropdown-menu {
    border: 1px solid var(--color-border);
    border-radius: 0;
    box-shadow: 0 2px 8px var(--color-shadow);
    padding: 4px 0;
    margin-top: 4px;
}

.dropdown-item {
    border-radius: 0;
    padding: 10px 20px;
    transition: all 0.2s ease;
    color: var(--color-text);
    font-size: 0.9rem;
}

.dropdown-item:hover {
    background: var(--color-secondary);
    color: var(--color-text);
}

/* List group - Style épuré L'Amusée */
.list-group-item {
    border: none;
    border-bottom: 1px solid var(--color-border);
    padding: 14px 0;
    background: transparent;
    font-size: 0.9rem;
}

.list-group-item:last-child {
    border-bottom: 1px solid var(--color-border);
}

/* Responsive */
@media screen and (max-width: 1000px) {
    header {
        width: 55px;
    }

    main {
        margin-left: 55px;
        padding: 20px;
    }

    .logo svg {
        display: none !important;
    }

    .logo img {
        width: 100%;
        display: block !important;
    }

    nav a span,
    .sidebar-footer a span {
        display: none;
    }

    nav a,
    .sidebar-footer a {
        justify-content: center !important;
        padding: 15px !important;
        gap: 0 !important;
        margin: 4px 8px;
    }
}

/* Animations subtiles */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.card {
    animation: fadeIn 0.4s ease-out;
}

/* Décorations discrètes */
.ring {
    background: var(--color-primary) !important;
    color: var(--color-white) !important;
    border: 1px solid var(--color-primary) !important;
}
