/* Reset CSS complet pour placer avant vos règles personnalisées */

/* Box sizing global */
:root { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; box-sizing: border-box; }
*, *::before, *::after { box-sizing: inherit; }

/* Réinitialisation de base */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strong, sub, sup, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    vertical-align: baseline;
    background: transparent;
    color: inherit;
    font: inherit;
}

/* HTML / Body */
html, body {
    height: 100%;
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
}

/* Content flow */
main { display: block; }

/* Lists */
ol, ul { list-style: none; }

/* Links */
a {
    color: inherit;
    text-decoration: none;
    background-color: transparent;
}

/* Images / media */
img, picture, video, canvas, svg, iframe {
    display: block;
    max-width: 100%;
    height: auto;
}

/* Tables */
table {
    border-collapse: collapse;
    border-spacing: 0;
}

/* Form elements */
button, input, select, textarea {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    color: inherit;
    background: transparent;
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/* Buttons & clickable elements */
button, [type="button"], [type="submit"], [role="button"] {
    cursor: pointer;
    background: none;
}

/* Inputs specifics */
textarea {
    resize: vertical;
}

/* Fieldset / legend / hr */
fieldset { border: 0; margin: 0; padding: 0; }
legend { padding: 0; }
hr {
    border: none;
    height: 1px;
    background-color: currentColor;
    opacity: 0.12;
}

/* Code / pre */
pre, code, kbd, samp {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, "Roboto Mono", "Courier New", monospace;
    font-size: 1em;
}

/* Abbreviations */
abbr[title] { text-decoration: underline dotted; cursor: help; }

/* Details / summary */
details { display: block; }
summary { display: list-item; }


/* Accessibility helpers */
.sr-only {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0 0 0 0);
    white-space: nowrap; border: 0;
}

/* Utility defaults */
.hidden { display: none !important; }
.clearfix::after { content: ""; display: block; clear: both; }

/* Ensure SVGs inherit color by default */
svg { fill: currentColor; stroke: none; }

/* Prevent images from being draggable/selectable by default */
img, svg, video { user-select: none; -webkit-user-drag: none; }

/* Default transition smoothing for small UI changes */
* { transition: background-color .12s ease, color .12s ease, border-color .12s ease; }

/* Variables CSS pour multios admin theme */
:root {
    /* Couleurs principales multios */
    --multios-primary: #03a9f4;
    --multios-secondary: #f79007;
    --multios-success: #00bf87;
    --multios-accent: #1194ff;
    --multios-hover: rgba(3, 168, 244, 0.685);
    --multios-white: #fff;
    --multios-dark: #17252a;
    
    /* Couleurs système light */
    --multios-bg-primary: var(--multios-white);
    --multios-bg-main-primary: #03a8f409;
    --multios-bg-secondary: #fafbff;
    --multios-text-primary: var(--multios-dark);
    --multios-text-secondary: #555;
    --multios-border: #e0e7ff;
    
    /* Ombres */
    --multios-shadow-natural: 6px 6px 9px rgba(0,0,0,.2);
    --multios-shadow-deep: 12px 12px 50px rgba(0,0,0,.4);
    --multios-shadow-light: 0 2px 8px rgba(0,0,0,.1);
    
    /* Rayons de bordure */
    --multios-border-radius: 12px;
    --multios-border-radius-sm: 8px;
    
    /* Transitions */
    --multios-transition: all 0.3s ease;
}

/* Variables pour le dark mode */
.pf-v5-theme-dark {
    --multios-bg-primary: #1b1d21;
    --multios-bg-secondary: #2a2d32;
    --multios-text-primary: #e0e0e0;
    --multios-text-secondary: #b0b0b0;
    --multios-border: #404040;
    --multios-hover: rgba(3, 168, 244, 0.685);
    --multios-shadow-light: 0 2px 8px rgba(0,0,0,.3);
}

.pf-v5-theme-dark main {
    background-color: #1e293b;
}

/* Header / Masthead */
.pf-v5-c-masthead {
    background-color: var(--multios-bg-primary);
    border-bottom: 1px solid var(--multios-border);
    box-shadow: var(--multios-shadow-light);
}

/* Logo dans le header */
.keycloak__pageheader_brand {
    content: url("../images/Nouveau\ logo\ -\ Multios\ -\ bleu\ fond\ transparent.png");
    min-height: 5rem;
    object-fit: contain; /* Garde le ratio */
    width: auto;
    height: auto;
}
.pf-v5-theme-dark .keycloak__pageheader_brand {
    content: url("../images/Nouveau\ logo\ -\ Multios\ -\ blanc\ fond\ transparent.png");
    max-width: 5rem;
    object-fit: contain; /* Garde le ratio */
    width: auto;
    height: auto;
}
/* Navigation toggle button */
.pf-v5-c-masthead__toggle .pf-v5-c-button {
    color: var(--multios-text-primary);
    transition: var(--multios-transition);
}

.pf-v5-c-masthead__toggle .pf-v5-c-button:hover {
    background-color: var(--multios-hover);
    color: var(--multios-primary);
}

/* Icônes SVG */
.pf-v5-svg {
    fill: var(--multios-primary);
    transition: var(--multios-transition);
}

.pf-v5-c-masthead__content >  .pf-v5-c-toolbar{
    background-color: var(--multios-bg-primary);
}
.pf-v5-c-page__main-section > * {
    background-color: var(--multios-bg-secondary);
}

/* Menu toggles dans le header */
.pf-v5-c-menu-toggle {
    color: var(--multios-text-primary);
    background-color: transparent;
    border-radius: var(--multios-border-radius-sm);
    transition: var(--multios-transition);
}

.pf-v5-c-menu-toggle:before{
    border-style: none;
}

.pf-v5-c-masthead .pf-v5-c-menu-toggle::before,
.pf-v5-c-masthead .pf-v5-c-menu-toggle::after {
    border: none ;
    box-shadow: none ;
}


.pf-v5-c-menu-toggle:hover {
    background-color: var(--multios-hover);
    border-color: var(--multios-primary);
    color: var(--multios-primary);
}

.pf-v5-c-menu-toggle.pf-m-plain {
    border: none;
    padding: 8px;
}

.pf-v5-c-menu-toggle.pf-m-plain:hover {
    background-color: var(--multios-hover);
    border-radius: var(--multios-border-radius-sm);
}

/* Sidebar */
.pf-v5-c-page__sidebar {
    background-color: var(--multios-bg-primary);
    border-right: 1px solid var(--multios-border);
}

.pf-v5-c-page__sidebar-body {
    background-color: var(--multios-bg-primary);
    color: var(--multios-text-primary);
}

/* Navigation dans la sidebar */
.pf-v5-c-nav {
    background-color: transparent;
}


.pf-v5-c-nav__section-title {
    color: var(--multios-text-primary);
    font-weight: 700;
    margin-bottom: 1rem;
}

.pf-v5-c-nav__list a {
    color: var(--multios-text-primary);
    padding: 12px 16px;
    border-radius: var(--multios-border-radius-sm);
    margin: 2px 8px;
    transition: var(--multios-transition);
    text-decoration: none;
    font-weight: 500;
}

.pf-v5-c-nav__list a:hover {
    background-color: var(--multios-primary);
    color: var(--multios-white);
    transform: translateX(4px);
}

.pf-v5-c-nav__link.pf-m-current {
    background-color: var(--multios-primary);
    color: var(--multios-white);
    font-weight: 600;
}

/* Page principale */
.pf-v5-c-page__main {
    background-color: var(--multios-bg-secondary);
}

.pf-v5-c-page__main-section {
    background-color: var(--multios-bg-primary);
}

.pf-v5-c-page__main-section.pf-m-light {
    background-color: var(--multios-bg-secondary);
    border-radius: var(--multios-border-radius);
    margin: 1rem;
    padding: 2rem;
    box-shadow: var(--multios-shadow-light);
}

.pf-v5-c-menu-toggle::after{
    border-block-end: none;
}



/* Titres */
h1, h2, h3, h4, h5, h6 {
    color: var(--multios-text-primary);
}

/* Formulaires */
.pf-v5-c-form {
    background-color: transparent;
}

.pf-v5-c-form__label {
    color: var(--multios-text-primary);
    font-weight: 600;
}

.pf-v5-c-form__group-control .pf-v5-c-menu-toggle {
    background-color: var(--multios-bg-primary);
    border-radius: var(--multios-border-radius);
    padding: 12px 16px;
    color: var(--multios-text-primary);
    border: var(--multios-dark) 2px solid;
}



/* Switches */
.pf-v5-c-switch__input:checked + .pf-v5-c-switch__toggle {
    background-color: var(--multios-primary);
}

.pf-v5-c-switch__input:focus + .pf-v5-c-switch__toggle {
    box-shadow: 0 0 0 4px rgba(3,169,244,0.1);
}

/* Boutons */
.pf-v5-c-button.pf-m-primary {
    background-color: var(--multios-primary);
    border-color: var(--multios-primary);
    color: var(--multios-white);
    border-radius: var(--multios-border-radius);
    padding: 12px 24px;
    font-weight: 600;
    transition: var(--multios-transition);
}

.pf-v5-c-button.pf-m-primary:hover {
    background-color: var(--multios-hover);
    transform: translateY(-2px);
}

.pf-v5-c-button.pf-m-link {
    color: var(--multios-primary);
    transition: var(--multios-transition);
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.pf-v5-c-button.pf-m-link:hover {
    color: var(--multios-hover);
    text-decoration: underline;
}

/* Tabs */
.pf-v5-c-tabs {
    background-color: var(--multios-bg-primary);
    border-bottom: 1px solid var(--multios-border);
}

.pf-v5-c-tabs__link {
    color: var(--multios-text-secondary);
    padding: 16px 24px;
    border-radius: var(--multios-border-radius-sm) var(--multios-border-radius-sm) 0 0;
    transition: var(--multios-transition);
    font-weight: 500;
}

.pf-v5-c-tabs__link:hover {
    color: var(--multios-primary);
    background-color: var(--multios-hover);
}

.pf-v5-c-tabs__item.pf-m-current .pf-v5-c-tabs__link {
    color: var(--multios-primary);
    background-color: var(--multios-bg-secondary);
    font-weight: 600;
}

/* Labels */
.pf-v5-c-label {
    border-radius: var(--multios-border-radius-sm);
    font-weight: 500;
}

.pf-v5-c-label.pf-m-blue {
    background-color: rgba(3,169,244,0.1);
    color: var(--multios-primary);
}

/* Avatar */
.pf-v5-c-avatar {
    border: 2px solid var(--multios-border);
    transition: var(--multios-transition);
}

.pf-v5-c-avatar:hover {
    border-color: var(--multios-primary);
    box-shadow: 0 0 0 4px rgba(3,169,244,0.1);
}

/* Alertes */
.pf-v5-c-alert-group {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1000;
}

/* Content et descriptions */
.pf-v5-c-content {
    color: var(--multios-text-primary);
}

.pf-v5-c-content p {
    color: var(--multios-text-secondary);
    line-height: 1.6;
}

.pf-v5-c-content a {
    color: var(--multios-primary);
    transition: var(--multios-transition);
}

.pf-v5-c-content a:hover {
    color: var(--multios-hover);
}

.pf-v5-c-toolbar__content{
  border-radius: var(--multios-border-radius-sm);
}

/* Animations d'entrée */
.pf-v5-c-page__main {
    animation: slideInFromRight 0.4s ease-out;
}

@keyframes slideInFromRight {
    from {
        opacity: 0;
        transform: translateX(20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Responsive design */
@media (max-width: 768px) {
    .pf-v5-c-page__main-section.pf-m-light {
        margin: 0.5rem;
        padding: 1rem;
    }
    
    .pf-v5-c-tabs__link {
        padding: 12px 16px;
        font-size: 0.9rem;
    }
    
    .pf-v5-c-button.pf-m-primary {
        padding: 10px 20px;
    }
}


/* États de chargement */
.keycloak__loading-container {
    background: linear-gradient(135deg, var(--multios-bg-primary) 0%, var(--multios-bg-secondary) 100%);
    color: var(--multios-text-primary);
}


#pf-random-id-1{
    background-color:unset ;
}
.pf-v5-l-stack__item > a {
    color: var(--multios-text-primary);
}
.pf-v5-c-check__input{
    border-radius: var(--multios-border-radius-sm);
    background-color: var(--multios-bg-light);
    border: var(--multios-border) 2px solid;
}

main {
    background-color: var(--multios-bg-main-primary ) !important;
}
.pf-v5-c-text-input-group__main::before,
.pf-v5-c-text-input-group__main::after {
    border: none !important;
}

.pf-v5-c-tabs.pf-m-inset-2xl-on-2xl {
    padding-inline-start: 0rem ;
}
.pf-v5-theme-dark .pf-v5-c-card__header{
    color: var(--multios-text-primary);
    background-color: var(--multios-bg-main-primary);
    margin: 0.5rem ;
}