:root { --ink: #17202a; --muted: #667085; --line: #dfe6ef; --navy: #14213d; --accent: #0f766e; }
* { box-sizing: border-box; }
body { background: #f5f7fb; color: var(--ink); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; margin: 0; }
.portal { display: grid; grid-template-columns: minmax(330px, .9fr) minmax(570px, 1.4fr); min-height: 100vh; }
.portal__intro { background: radial-gradient(circle at 20% 20%, #244778 0, transparent 35%), linear-gradient(145deg, #13213e, #0e5360); color: #fff; display: flex; flex-direction: column; justify-content: center; padding: clamp(38px, 7vw, 96px); }
.brand { align-items: center; color: #fff; display: inline-flex; font-size: 1.15rem; font-weight: 800; gap: 10px; position: absolute; text-decoration: none; top: 32px; }
.brand__mark { align-items: center; background: #fff; border-radius: 9px; color: #0f766e; display: inline-flex; font-weight: 900; height: 32px; justify-content: center; width: 32px; }
.portal__eyebrow, .applications__eyebrow { font-size: .72rem; font-weight: 800; letter-spacing: .14em; }
.portal__eyebrow { color: #8be2d3; }
.portal h1 { font-size: clamp(2.25rem, 4vw, 4.15rem); letter-spacing: -.055em; line-height: 1.04; margin: 16px 0 22px; max-width: 620px; }
.portal__intro p { color: #d3e0ef; font-size: 1.05rem; line-height: 1.7; margin: 0; max-width: 520px; }
.portal__footer { color: #aabed3; font-size: .8rem; margin-top: auto; padding-top: 45px; }
.portal__applications { align-self: center; padding: clamp(38px, 7vw, 100px); }
.applications__heading { align-items: end; display: flex; justify-content: space-between; margin-bottom: 28px; }
.applications__eyebrow { color: var(--accent); display: block; margin-bottom: 8px; }
.applications__heading h2 { font-size: clamp(1.65rem, 2.8vw, 2.3rem); letter-spacing: -.04em; margin: 0; }
.applications__count { background: #e7f7f4; border-radius: 999px; color: #0f766e; font-size: .78rem; font-weight: 700; padding: 8px 11px; white-space: nowrap; }
.logout-link { border: 1px solid var(--line); border-radius: 999px; color: var(--muted); font-size: .78rem; font-weight: 700; padding: 8px 11px; text-decoration: none; }
.logout-link:hover { border-color: #dc2626; color: #dc2626; }
.applications__grid { display: grid; gap: 14px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.app-card { --color: #0f766e; background: #fff; border: 1px solid var(--line); border-radius: 16px; color: var(--ink); display: flex; flex-direction: column; min-height: 210px; padding: 22px; text-decoration: none; transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease; }
.app-card:hover { border-color: var(--color); box-shadow: 0 16px 30px rgba(20, 33, 61, .12); color: var(--ink); transform: translateY(-5px); }
.app-card:focus-visible { outline: 3px solid var(--color); outline-offset: 3px; }
.app-card__icon { align-items: center; background: color-mix(in srgb, var(--color) 12%, white); border-radius: 12px; color: var(--color); display: flex; font-size: 1.55rem; font-weight: 800; height: 46px; justify-content: center; width: 46px; }
.app-card__body { display: grid; gap: 7px; margin-top: 20px; }
.app-card__title { font-size: 1rem; font-weight: 800; line-height: 1.3; }
.app-card__text { color: var(--muted); font-size: .86rem; line-height: 1.45; }
.app-card__link { color: var(--color); font-size: .86rem; font-weight: 800; margin-top: auto; padding-top: 16px; }
.app-card--housing { --color: #2563eb; }.app-card--archive { --color: #0f766e; }.app-card--warehouse { --color: #d97706; }.app-card--projects { --color: #7c3aed; }.app-card--payroll { --color: #db2777; }
.applications__note { color: var(--muted); font-size: .82rem; margin: 22px 0 0; text-align: center; }
.login-page { align-items: center; background: radial-gradient(circle at 15% 15%, #244778 0, transparent 31%), linear-gradient(145deg, #13213e, #0e5360); display: flex; justify-content: center; min-height: 100vh; padding: 22px; }
.login-card { background: #fff; border-radius: 18px; box-shadow: 0 25px 60px rgba(0, 0, 0, .2); max-width: 430px; padding: 42px; width: 100%; }
.brand--dark { color: var(--navy); position: static; margin-bottom: 42px; }.brand--dark .brand__mark { background: var(--accent); color: #fff; }
.login-card .portal__eyebrow { color: var(--accent); }.login-card h1 { font-size: 2rem; margin: 12px 0 10px; }.login-card p { color: var(--muted); line-height: 1.55; margin: 0 0 25px; }
.login-form { display: grid; gap: 10px; }.login-form label { color: var(--ink); font-size: .88rem; font-weight: 700; }.login-form input { border: 1px solid var(--line); border-radius: 9px; font: inherit; outline: none; padding: 13px; }.login-form input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(15, 118, 110, .13); }.login-form button { background: var(--accent); border: 0; border-radius: 9px; color: #fff; cursor: pointer; font: inherit; font-weight: 800; margin-top: 8px; padding: 13px; }.login-form button:hover { background: #0b5f59; }.login-error { background: #fef2f2; border: 1px solid #fecaca; border-radius: 8px; color: #b91c1c; font-size: .88rem; margin-bottom: 16px; padding: 10px 12px; }
@media (max-width: 900px) { .portal { grid-template-columns: 1fr; }.portal__intro { min-height: 390px; }.brand { position: static; margin-bottom: auto; }.portal__footer { margin-top: 40px; }.portal__applications { padding: 42px 26px; } }
@media (max-width: 540px) { .portal__intro { min-height: 425px; padding: 28px; }.applications__heading { align-items: start; flex-direction: column; gap: 14px; }.applications__grid { grid-template-columns: 1fr; }.app-card { min-height: 180px; }.portal__applications { padding: 34px 18px; } }

/* Page de connexion */
.login-page { background: #eef2f7; display: block; padding: 0; }
.login-layout { display: grid; grid-template-columns: minmax(420px, 1fr) minmax(460px, .9fr); min-height: 100vh; }
.login-showcase { background: radial-gradient(circle at 15% 15%, rgba(57, 126, 174, .55), transparent 30%), radial-gradient(circle at 76% 78%, rgba(14, 130, 121, .42), transparent 31%), linear-gradient(145deg, #10213f 0%, #123d54 100%); color: #fff; display: flex; flex-direction: column; overflow: hidden; padding: clamp(32px, 6vw, 84px); position: relative; }
.login-showcase::after { border: 1px solid rgba(255, 255, 255, .11); border-radius: 999px; content: ""; height: 420px; position: absolute; right: -175px; top: -155px; width: 420px; }
.login-showcase .brand { position: static; z-index: 1; }.login-showcase .brand__mark { box-shadow: 0 8px 20px rgba(0, 0, 0, .16); }
.login-showcase__content { margin: auto 0; max-width: 575px; position: relative; z-index: 1; }.login-showcase__eyebrow { align-items: center; color: #85e7d8; display: flex; font-size: .72rem; font-weight: 800; gap: 8px; letter-spacing: .14em; }
.login-showcase h1 { font-size: clamp(2.6rem, 5vw, 5rem); letter-spacing: -.065em; line-height: .98; margin: 22px 0; }.login-showcase h1 em { color: #8de4d7; font-family: Georgia, serif; font-weight: 400; }.login-showcase p { color: #c4d8e7; font-size: 1.08rem; line-height: 1.7; margin: 0; max-width: 480px; }
.login-showcase__status { align-items: center; color: #c4d8e7; display: flex; font-size: .83rem; gap: 9px; position: relative; z-index: 1; }.login-showcase__status .status-dot { background: #75e2b5; box-shadow: 0 0 0 5px rgba(117, 226, 181, .13); margin: 0; }
.login-panel { align-items: center; background: #f8fafc; display: flex; justify-content: center; padding: 42px; }.login-panel .login-card { background: transparent; box-shadow: none; max-width: 410px; padding: 0; width: 100%; }.login-card__icon { align-items: center; background: #e3f4f1; border-radius: 14px; color: var(--accent); display: flex; font-size: 1.55rem; font-weight: 900; height: 52px; justify-content: center; margin-bottom: 30px; width: 52px; }
.login-card .portal__eyebrow { color: var(--accent); display: block; margin-bottom: 9px; }.login-card h2 { font-size: 2.35rem; letter-spacing: -.055em; margin: 0 0 10px; }.login-card > p:not(.login-card__help) { color: var(--muted); font-size: .98rem; line-height: 1.6; margin: 0 0 28px; }
.login-form { gap: 9px; }.login-form label { font-size: .82rem; letter-spacing: .01em; }.password-field { align-items: center; background: #fff; border: 1px solid #d7e0ea; border-radius: 11px; display: flex; gap: 10px; padding: 0 13px; transition: border-color .2s ease, box-shadow .2s ease; }.password-field > span { color: #7f8da1; font-size: 1.1rem; }.login-form input { background: transparent; border: 0; box-shadow: none; min-width: 0; padding: 14px 0; width: 100%; }.password-field:focus-within { border-color: var(--accent); box-shadow: 0 0 0 4px rgba(15, 118, 110, .11); }.login-form input:focus { box-shadow: none; }
.login-form button { align-items: center; background: linear-gradient(135deg, #0f766e, #0a5f66); border-radius: 11px; box-shadow: 0 11px 20px rgba(15, 118, 110, .2); display: flex; justify-content: space-between; margin-top: 12px; padding: 14px 17px; transition: transform .2s ease, box-shadow .2s ease; }.login-form button:hover { box-shadow: 0 14px 25px rgba(15, 118, 110, .28); transform: translateY(-2px); }.login-card__help { color: #8a98aa; font-size: .78rem; margin: 23px 0 0; text-align: center; }.login-error { margin-bottom: 18px; }
@media (max-width: 850px) { .login-layout { grid-template-columns: 1fr; }.login-showcase { min-height: 300px; padding: 28px; }.login-showcase__content { margin: auto 0 0; }.login-showcase h1 { font-size: 2.65rem; margin: 14px 0; }.login-showcase p { font-size: .94rem; }.login-showcase__status { display: none; }.login-panel { min-height: 500px; padding: 36px 26px; } }
@media (max-width: 450px) { .login-showcase { min-height: 270px; }.login-showcase p { display: none; }.login-panel { padding: 34px 23px; }.login-card h2 { font-size: 2.05rem; } }

/* Direction visuelle finale : sobre, professionnelle et lisible. */
.login-page { background: #e9f0f6; }
.login-layout { background: #fff; grid-template-columns: minmax(430px, 1.15fr) minmax(440px, .85fr); margin: 0; min-height: 100vh; }
.login-showcase { background: linear-gradient(140deg, #0b1f3a 0%, #123b5a 58%, #08716d 140%); padding: clamp(38px, 6vw, 90px); }
.login-showcase::before { background: rgba(117, 226, 181, .11); border-radius: 50%; content: ""; height: 310px; left: -155px; position: absolute; top: 42%; width: 310px; }.login-showcase::after { border-color: rgba(153, 237, 224, .22); height: 520px; right: -260px; top: -245px; width: 520px; }
.login-showcase__content { margin: auto 0 38px; }.login-showcase h1 { font-size: clamp(3rem, 5.2vw, 5.4rem); line-height: .94; margin: 24px 0; }.login-showcase h1 em { color: #95ecdd; }.login-showcase p { font-size: 1.03rem; max-width: 440px; }
.login-showcase__apps { align-items: center; backdrop-filter: blur(8px); background: rgba(255, 255, 255, .10); border: 1px solid rgba(255, 255, 255, .14); border-radius: 15px; display: flex; gap: 13px; margin-top: 38px; max-width: 310px; padding: 13px; }.login-showcase__apps-icon { align-items: center; background: #92e9da; border-radius: 10px; color: #083754; display: flex; font-size: 1.1rem; font-weight: 900; height: 40px; justify-content: center; width: 40px; }.login-showcase__apps strong { display: block; font-size: .84rem; }.login-showcase__apps small { color: #c7dce9; display: block; font-size: .74rem; margin-top: 3px; }
.login-panel { background: linear-gradient(145deg, #f9fbfd 0%, #edf4f6 100%); padding: clamp(30px, 7vw, 100px); }.login-panel .login-card { background: #fff; border: 1px solid #e2eaf0; border-radius: 22px; box-shadow: 0 20px 55px rgba(20, 49, 71, .12); max-width: 430px; padding: clamp(30px, 4vw, 46px); }.login-card__icon { background: linear-gradient(135deg, #e6f8f4, #d7f0ee); border-radius: 13px; font-size: 1.7rem; margin-bottom: 26px; }.login-card h2 { color: #10263d; font-size: 2.45rem; }.login-card > p:not(.login-card__help) { font-size: .94rem; margin-bottom: 27px; }
.login-form label { color: #3a4f63; }.password-field { border-radius: 10px; }.login-form button { background: linear-gradient(135deg, #08766f, #0a5e67); font-size: .93rem; }.login-card__help { border-top: 1px solid #edf1f4; margin-top: 24px; padding-top: 17px; }.login-card__help span { color: #0fb981; font-size: .6rem; margin-right: 5px; }
@media (max-width: 850px) { .login-layout { grid-template-columns: 1fr; }.login-showcase { min-height: 335px; }.login-showcase__apps { display: none; }.login-showcase__content { margin: auto 0 0; }.login-panel { padding: 38px 24px; } }

/* Garantit la séparation des deux colonnes, y compris après un ancien cache CSS. */
body.login-page { display: block !important; min-height: 100vh; padding: 0 !important; }
main.login-layout { display: grid !important; grid-template-columns: minmax(0, 1.12fr) minmax(430px, .88fr) !important; margin: 0 !important; min-height: 100vh !important; width: 100%; }
.login-showcase { color: #fff !important; grid-column: 1; grid-row: 1; min-width: 0; }.login-showcase h1 { color: #fff !important; }.login-showcase p { color: #cde0ed !important; }
.login-panel { background: #f8fafc !important; grid-column: 2; grid-row: 1; min-width: 0; }.login-panel .login-card { color: #10263d; }
@media (max-width: 850px) { main.login-layout { grid-template-columns: 1fr !important; }.login-showcase { grid-column: 1; grid-row: 1; }.login-panel { grid-column: 1; grid-row: 2; } }
