[data-theme="custom"], :root{
	--primary-color-hue: 0;
	--primary-color-saturation: 0%;
	--primary-color-lightness: 90%;
	--banner-background: url(../img/banner.svg);
}

.login-page {
	--login-logo: url("https://www.vuillety.ch/SIGNATURE/START_email_signature.png"); /* for relative path, must be relative to the css file or use full url starting by http:// */
}
/* Here, the content of the common custom CSS defined into Home - Setup - Display - CSS */
/* ============================================================
   START solutions — Thème WebPortal bleu ciel
   Couleurs : #1a3a5c (foncé) · #2e6da4 (accent) · #5eb3e4 (ciel)
   ============================================================ */

/* ===================== PAGE LOGIN ===================== */

body.login-page {
    background: url('https://www.vuillety.ch/MEDIA/Plan.png') center/cover no-repeat fixed !important;
    font-family: "Segoe UI", "Helvetica Neue", Arial, sans-serif !important;
}

.login-screen__content {
    position: relative !important;
    background: #ffffff !important;
    border-radius: 16px !important;
    box-shadow: 0 12px 40px rgba(26, 58, 92, 0.35) !important;
    border: none !important;
    padding: 38px 32px !important;
    overflow: hidden !important;
}

/* Liseré bleu qui épouse les coins arrondis */
.login-screen__content::after {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 5px !important;
    background: linear-gradient(90deg, #5eb3e4, #2e6da4) !important;
    border-radius: 16px 16px 0 0 !important;
}

/* Texte en haut de la carte, séparé du logo */
.login-screen__content::before {
    content: "CLIENTS - FOURNISSEURS" !important;
    display: block !important;
    text-align: center !important;
    color: #1a3a5c !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    letter-spacing: 1px !important;
    margin-bottom: 20px !important;
}

/* Le bloc logo reste tel quel */
.login__logo {
    display: block !important;
}
.login__logo::before {
    content: none !important;
}

/* Masquer les formes décoratives */
.login-screen__background,
.login-screen__background__shape,
.login-screen__background__shape1,
.login-screen__background__shape2,
.login-screen__background__shape3,
.login-screen__background__shape4 {
    display: none !important;
}

/* Nettoyer les conteneurs autour de la carte */
.login-screen {
    background: transparent !important;
    box-shadow: none !important;
}
.login-page__container {
    background: transparent !important;
}

/* Champ = icône À GAUCHE puis input, parfaitement alignés */
.login__field {
    border: none !important;
    border-bottom: none !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 18px !important;
    background: transparent !important;
}
.login__icon {
    color: #2e6da4 !important;
    font-size: 18px !important;
    flex: 0 0 24px !important;
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: static !important;
    margin: 0 !important;
}
.login__input {
    flex: 1 1 auto !important;
    color: #1a3a5c !important;
    height: 44px !important;
    padding: 0 14px !important;
    border: 1px solid #cfe5f3 !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    box-sizing: border-box !important;
    font-size: 15px !important;
}
.login__input:focus {
    border-color: #5eb3e4 !important;
    box-shadow: 0 0 0 3px rgba(94, 179, 228, 0.25) !important;
    outline: none !important;
}
.login__input::placeholder {
    color: #9bb8cc !important;
}

.login__submit {
    background: linear-gradient(135deg, #5eb3e4 0%, #2e6da4 100%) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(46, 109, 164, 0.4) !important;
    transition: transform 0.15s ease, box-shadow 0.15s ease !important;
    margin-top: 8px !important;
}
.login__submit:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 18px rgba(46, 109, 164, 0.5) !important;
}
.button__text, .button__icon {
    color: #ffffff !important;
}

/* ===================== PAGES INTERNES ===================== */

body[data-theme="custom"] {
    background: linear-gradient(160deg, #e8f4fb 0%, #f4fafd 100%) !important;
    font-family: "Segoe UI", "Helvetica Neue", Arial, sans-serif !important;
    color: #2c3e50 !important;
}

/* Largeur commune : aligner nav + bannière + contenu */
.primary-top-nav,
.hero-header,
main.container,
.container {
    max-width: 1320px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Gestion du débordement horizontal des tableaux larges */
main.container,
.container {
    overflow-x: auto !important;
}

/* Barre de navigation supérieure */
.primary-top-nav {
    background: linear-gradient(135deg, #1a3a5c 0%, #2e6da4 60%, #5eb3e4 100%) !important;
    box-shadow: 0 2px 10px rgba(26, 58, 92, 0.25) !important;
    padding: 8px 18px !important;
    border-radius: 12px 12px 0 0 !important;
}
.primary-top-nav .nav-link {
    color: #ffffff !important;
    font-weight: 500 !important;
    transition: opacity 0.2s ease !important;
}
.primary-top-nav .nav-link:hover {
    opacity: 0.8 !important;
}
.brand__logo-img {
    max-height: 42px !important;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.2)) !important;
}

/* Bannière d'accueil */
.hero-header {
    background: linear-gradient(135deg, #2e6da4 0%, #5eb3e4 100%) !important;
    color: #ffffff !important;
    padding: 75px 20px 40px 20px !important;
    margin-top: 0 !important;
    border-radius: 18px !important;
    box-shadow: 0 4px 16px rgba(46, 109, 164, 0.2) !important;
    margin-bottom: 28px !important;
}
.hero-header__title {
    color: #ffffff !important;
    font-weight: 600 !important;
    margin-top: 20px !important;
    line-height: 1.3 !important;
}
.hero-header__desc {
    color: #e8f4fb !important;
}

/* Cartes de la page d'accueil (Devis / Factures) */
.home-links-card {
    background: #ffffff !important;
    border: 1px solid #cfe5f3 !important;
    border-radius: 14px !important;
    box-shadow: 0 3px 14px rgba(46, 109, 164, 0.10) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease !important;
    overflow: hidden !important;
}
.home-links-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 8px 22px rgba(46, 109, 164, 0.22) !important;
}
.home-links-card__icon {
    background: linear-gradient(135deg, #5eb3e4 0%, #2e6da4 100%) !important;
    min-height: 70px !important;
}
.home-links-card__link {
    color: #1a3a5c !important;
    font-weight: 500 !important;
    display: block !important;
    padding: 16px !important;
    text-decoration: none !important;
}
.home-links-card__link:hover {
    color: #2e6da4 !important;
}

/* Titres et liens */
h1, h2, h3 {
    color: #1a3a5c !important;
}
a {
    color: #2e6da4 !important;
}
a:hover {
    color: #1a3a5c !important;
}

/* ===== Listes / tableaux (factures, devis) ===== */
main table,
.container table {
    width: 100% !important;
    max-width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 10px rgba(46, 109, 164, 0.10) !important;
    background: #ffffff !important;
}

/* En-têtes de colonnes — texte blanc forcé partout */
main table thead tr,
.container table thead tr {
    background: linear-gradient(135deg, #2e6da4 0%, #5eb3e4 100%) !important;
}
main table thead th,
main table thead th a,
main table thead td,
main table thead td a,
.container table thead th,
.container table thead th a,
.liste_titre,
.liste_titre th,
.liste_titre td,
.liste_titre a,
tr.liste_titre th,
tr.liste_titre td {
    color: #ffffff !important;
    font-weight: 600 !important;
    padding: 11px 14px !important;
    text-align: left !important;
}

/* Barre de filtres (recherche + dates) en fond foncé lisible */
.liste_titre_filter,
tr.liste_titre_filter,
main table thead tr.liste_titre_filter {
    background: #1a3a5c !important;
}

/* Champs de filtre (Du / au / recherche) bien blancs */
.liste_titre input,
.liste_titre_filter input,
main table thead input,
.container table thead input {
    background: #ffffff !important;
    color: #1a3a5c !important;
    border: 1px solid #cfe5f3 !important;
    border-radius: 6px !important;
}

/* Lignes du tableau */
main table tbody tr:nth-child(even),
.container table tbody tr:nth-child(even) {
    background: #e8f4fb !important;
}
main table tbody tr:nth-child(odd),
.container table tbody tr:nth-child(odd) {
    background: #ffffff !important;
}
main table tbody tr:hover,
.container table tbody tr:hover {
    background: #d4ebf8 !important;
}
main table td,
.container table td {
    padding: 10px 14px !important;
    border-bottom: 1px solid #cfe5f3 !important;
}

/* Boutons génériques */
.button, button, .btn,
input[type="submit"] {
    background: linear-gradient(135deg, #5eb3e4 0%, #2e6da4 100%) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 18px !important;
    box-shadow: 0 2px 6px rgba(46, 109, 164, 0.3) !important;
    transition: transform 0.15s ease !important;
}
.button:hover, button:hover, .btn:hover {
    transform: translateY(-1px) !important;
}

/* Champs de formulaire (pages internes) */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
select, textarea {
    border: 1px solid #cfe5f3 !important;
    border-radius: 6px !important;
    padding: 8px 10px !important;
    background: #ffffff !important;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
select:focus, textarea:focus {
    border-color: #5eb3e4 !important;
    box-shadow: 0 0 0 3px rgba(94, 179, 228, 0.25) !important;
    outline: none !important;
}

/* Fenêtres modales (aperçu de documents) */
.dialog-header {
    background: linear-gradient(135deg, #2e6da4 0%, #5eb3e4 100%) !important;
    color: #ffffff !important;
}
.dialog-header-title {
    color: #ffffff !important;
}