diff --git a/Bootstrap_new/css/style-portail.css b/Bootstrap_new/css/style-portail.css index 60ab9369..2f4e31b4 100644 --- a/Bootstrap_new/css/style-portail.css +++ b/Bootstrap_new/css/style-portail.css @@ -1,27 +1,25 @@ /* ============================================================ style-portail.css – INTER SANTE · Portail Gestionnaire + v2 – Image1 (icônes FA, overlay gradient, badge carrousel, + bouton avec icône) + Image2 (logo grand, titre uppercase + imposant, aération, focus fond bleu, proportions 42/58) ============================================================ */ /* ---------- Variables ---------- */ :root { - /* Brand Colors — Charcoal / Gris neutre (zéro vert) */ - --color-primary: #212E53; /*#2e3440;*/ /* charcoal foncé */ - --color-primary-light: #4c566a; /* slate moyen */ - --color-primary-dark: #1a1d24; /* quasi-noir */ - --color-primary-ghost: rgba(33, 46, 83, 0.05); /* Ajusté sur le Charcoal */ - - --brand: #0088cf; - --brand-dark: #006ba3; + --brand: #212E53; + --brand-dark: #1a1d24; --brand-light: #4c566a; + --brand-focus: #0c4b65; --white: #ffffff; --text-dark: #1a2e3b; --text-muted: #6b8a9a; + --text-label: #3a5060; --danger: #dc3545; --border-r: 10px; - --input-h: 46px; - --transition: 0.25s ease; - --shadow-card: 0 8px 32px rgba(0,136,207,.13); - --shadow-btn: 0 2px 4px rgba(0,0,0,0.05); + --input-h: 48px; + --transition: 0.22s ease; + --shadow-btn: 0 4px 16px rgba(0,136,207,.38); } /* ---------- Reset / Base ---------- */ @@ -31,13 +29,13 @@ html, body { height: 100%; overflow: hidden; font-family: 'Poppins', 'Segoe UI', sans-serif; - background: var(--brand-light); + background: var(--white); color: var(--text-dark); } a { text-decoration: none; } -/* ---------- Layout principal ---------- */ +/* ---------- Wrapper principal ---------- */ .portail-wrapper { display: flex; height: 100vh; @@ -45,11 +43,13 @@ a { text-decoration: none; } overflow: hidden; } -/* ---------- Panneau carrousel (gauche) ---------- */ +/* ============================================= + PANNEAU GAUCHE — Carrousel 42 % (Image 2) + ============================================= */ .slide-container { position: relative; - width: 55%; - flex: 0 0 55%; + width: 42%; + flex: 0 0 42%; height: 100vh; overflow: hidden; } @@ -67,60 +67,61 @@ a { text-decoration: none; } height: 100%; object-fit: cover; left: -100%; - transition: none; } .slides .slide.active { left: 0; } -/* overlay gradient pour lisibilité */ +/* Overlay dégradé bleu profond (Image 1) */ .slide-container::after { content: ''; position: absolute; inset: 0; background: linear-gradient( - 135deg, - rgba(0,136,207,.35) 0%, - rgba(0,40,80,.55) 100% + 160deg, + rgba(0, 100, 180, .28) 0%, + rgba(0, 28, 65, .58) 100% ); pointer-events: none; z-index: 1; } -/* badge marque sur le carrousel */ +/* Badge marque bas-gauche (Image 1) */ .slide-brand { position: absolute; - bottom: 48px; - left: 40px; + bottom: 52px; + left: 36px; z-index: 5; color: var(--white); } .slide-brand h2 { - font-size: 1.6rem; + font-size: 1.5rem; font-weight: 700; - letter-spacing: .5px; + letter-spacing: .6px; line-height: 1.2; + text-shadow: 0 2px 8px rgba(0,0,0,.4); } .slide-brand p { - font-size: .85rem; - opacity: .8; - margin-top: 4px; + font-size: .80rem; + opacity: .85; + margin-top: 5px; + text-shadow: 0 1px 4px rgba(0,0,0,.35); } -/* boutons prev / next */ +/* Boutons prev / next (Image 1 style) */ .slide-btn { position: absolute; top: 50%; transform: translateY(-50%); z-index: 5; - background: rgba(255,255,255,.18); + background: rgba(255,255,255,.20); border: none; color: var(--white); - width: 40px; - height: 40px; + width: 38px; + height: 38px; border-radius: 50%; - font-size: 1rem; + font-size: .88rem; cursor: pointer; backdrop-filter: blur(4px); transition: background var(--transition); @@ -129,11 +130,11 @@ a { text-decoration: none; } justify-content: center; } -.slide-btn:hover { background: rgba(255,255,255,.38); } -.slide-btn.prev { left: 18px; } -.slide-btn.next { right: 18px; } +.slide-btn:hover { background: rgba(255,255,255,.42); } +.slide-btn.prev { left: 16px; } +.slide-btn.next { right: 16px; } -/* points indicateurs */ +/* Indicateurs dots */ .dotsContainer { position: absolute; bottom: 18px; @@ -145,74 +146,79 @@ a { text-decoration: none; } } .dotsContainer .dot { - width: 8px; - height: 8px; + width: 9px; + height: 9px; border-radius: 50%; - background: rgba(255,255,255,.45); + background: rgba(255,255,255,.40); cursor: pointer; transition: background var(--transition), transform var(--transition); + border: none; + padding: 0; } .dotsContainer .dot.active { background: var(--white); - transform: scale(1.3); + transform: scale(1.35); } -/* ---------- Panneau formulaire (droite) ---------- */ +/* ============================================= + PANNEAU DROIT — Formulaire 58 % (Image 2) + ============================================= */ .form-panel { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; - padding: 28px 36px; + padding: 0 52px 56px; /* bottom padding = place pour le footer absolu */ background: var(--white); - overflow-y: auto; + overflow: hidden; position: relative; } -/* Logo */ +/* Logo grand et centré (Image 2) */ .form-logo { - width: 90px; - height: 90px; + width: 115px; + height: 115px; object-fit: contain; - margin-bottom: 10px; + margin-bottom: 12px; } -/* Titre portail */ +/* Titre imposant uppercase (Image 2) */ .portail-title { - font-size: 1.35rem; - font-weight: 700; - color: var(--color-primary); - letter-spacing: .4px; - margin-bottom: 6px; + font-size: 1.5rem; + font-weight: 800; + color: var(--brand); + letter-spacing: 1.8px; + text-transform: uppercase; text-align: center; + margin-bottom: 8px; + line-height: 1.2; } /* Séparateur */ .portail-divider { - width: 48px; + width: 44px; height: 3px; - background: var(--color-primary); + background: var(--brand); border-radius: 2px; - margin: 0 auto 18px; + margin: 0 auto 20px; } /* Formulaire */ .login100-form { width: 100%; - max-width: 340px; + max-width: 355px; display: flex; flex-direction: column; - gap: 0; } -/* Alerte erreur / maintenance */ +/* Alerte maintenance / erreur */ .alert-portail { border-radius: var(--border-r); - font-size: .85rem; + font-size: .83rem; padding: 10px 14px; - margin-bottom: 12px; + margin-bottom: 14px; text-align: center; } @@ -222,21 +228,21 @@ a { text-decoration: none; } color: var(--danger); } -/* Groupe champ */ +/* Groupe champ — aéré (Image 2) */ .field-group { - margin-bottom: 12px; + margin-bottom: 13px; } .field-group label { display: block; - font-size: .78rem; + font-size: .79rem; font-weight: 600; - color: var(--text-muted); - margin-bottom: 4px; - letter-spacing: .3px; + color: var(--text-label); + margin-bottom: 5px; + letter-spacing: .2px; } -/* Input wrapper avec icône */ +/* Wrapper input + icône (Image 1) */ .input-icon-wrap { position: relative; display: flex; @@ -245,141 +251,170 @@ a { text-decoration: none; } .input-icon-wrap .field-icon { position: absolute; - left: 13px; - color: var(--color-primary); - font-size: .95rem; + left: 14px; + color: var(--brand); + font-size: .90rem; pointer-events: none; z-index: 2; } -.input-icon-wrap .input100, -.input-icon-wrap select { +/* Inputs text / password */ +.input-icon-wrap .input100 { width: 100%; height: var(--input-h); - padding: 0 14px 0 38px; - border: 2px solid var(--color-primary); + padding: 0 14px 0 40px; + border: 2px solid #c5e1f3; border-radius: var(--border-r); font-size: .9rem; - color: var(--text-dark); + color: var(--brand); background: var(--white); - transition: border-color var(--transition), box-shadow var(--transition); + transition: border-color var(--transition), background var(--transition), box-shadow var(--transition); outline: none; - appearance: none; } -.input-icon-wrap .input100::placeholder { color: #b0c8d8; } +.input-icon-wrap .input100::placeholder { color: #a8cce0; } -.input-icon-wrap .input100:focus, -.input-icon-wrap select:focus { - border-color: var(--color-primary); - box-shadow: 0 0 0 3px rgba(0,136,207,.12); +/* Focus : fond bleu clair + bordure pleine (Image 2) */ +.input-icon-wrap .input100:focus { + border-color: var(--brand); + background: var(--brand-focus); + box-shadow: 0 0 0 3px rgba(0,136,207,.10); } -/* Sélecteur langue / bootstrap-select */ +/* Bootstrap-select langue */ .bootstrap-select.field-select { width: 100% !important; } .bootstrap-select.field-select > .dropdown-toggle { height: var(--input-h); - padding: 0 14px 0 38px; - border: 2px solid #d0e8f5 !important; + padding: 0 14px 0 40px; + border: 2px solid #c5e1f3 !important; border-radius: var(--border-r) !important; background: var(--white) !important; - color: var(--text-dark); + color: var(--brand); font-size: .9rem; box-shadow: none !important; display: flex; align-items: center; + transition: border-color var(--transition), background var(--transition); } -.bootstrap-select.field-select > .dropdown-toggle:focus, -.bootstrap-select.field-select.show > .dropdown-toggle { +.bootstrap-select.field-select.show > .dropdown-toggle, +.bootstrap-select.field-select > .dropdown-toggle:active { border-color: var(--brand) !important; - box-shadow: 0 0 0 3px rgba(0,136,207,.12) !important; + background: var(--brand-focus) !important; + box-shadow: 0 0 0 3px rgba(0,136,207,.10) !important; outline: none !important; } .bootstrap-select.field-select .filter-option-inner-inner { - color: var(--text-dark) !important; + color: var(--brand) !important; background: transparent !important; text-align: left; font-size: .9rem; height: auto; + line-height: normal; } +/* Masque la caret native Bootstrap-select, on utilise notre icône FA */ .bootstrap-select.field-select .caret { display: none !important; } -/* Bouton connexion */ +/* Flèche custom positionnée à droite du select */ +.select-arrow { + position: absolute; + right: 13px; + color: var(--brand); + font-size: .78rem; + pointer-events: none; + z-index: 3; +} + +/* Bouton connexion (Image 1 icône + Image 2 propreté) */ .btn-login { width: 100%; - height: 46px; - background: var(--color-primary); + height: 48px; + background: var(--brand); color: var(--white); - border: 2px solid var(--color-primary); + border: 2px solid var(--brand); border-radius: var(--border-r); font-size: 1rem; font-weight: 700; - letter-spacing: .4px; + letter-spacing: .5px; cursor: pointer; transition: background var(--transition), color var(--transition), box-shadow var(--transition); box-shadow: var(--shadow-btn); - margin-top: 6px; + margin-top: 4px; display: flex; align-items: center; justify-content: center; - gap: 8px; + gap: 9px; } .btn-login:hover { background: var(--white); - color: var(--color-primary); + color: var(--brand); box-shadow: none; } /* Lien mot de passe oublié */ .link-forgot { text-align: center; - margin-top: 14px; + margin-top: 15px; } .link-forgot a { font-size: .82rem; color: var(--text-muted); transition: color var(--transition); + display: inline-flex; + align-items: center; + gap: 5px; } .link-forgot a:hover { color: var(--brand); } -/* Footer droits réservés */ +/* Footer ancré en bas du panneau (Image 2) */ .portail-footer { position: absolute; - bottom: 12px; + bottom: 14px; left: 0; right: 0; text-align: center; font-size: .72rem; color: var(--text-muted); + line-height: 1.6; +} + +.portail-footer a { + color: var(--brand); + font-weight: 600; } -.portail-footer a { color: var(--brand); } .portail-footer a:hover { text-decoration: underline; } -/* ---------- Animations carrousel ---------- */ -@keyframes next1 { from { left: 0% } to { left: -100%; } } -@keyframes next2 { from { left: 100% } to { left: 0%; } } -@keyframes prev1 { from { left: 0% } to { left: 100%; } } +/* ============================================= + ANIMATIONS CARROUSEL + ============================================= */ +@keyframes next1 { from { left: 0% } to { left: -100%; } } +@keyframes next2 { from { left: 100% } to { left: 0%; } } +@keyframes prev1 { from { left: 0% } to { left: 100%; } } @keyframes prev2 { from { left: -100% } to { left: 0%; } } -/* ---------- Responsive (mobile) ---------- */ +/* ============================================= + RESPONSIVE MOBILE + ============================================= */ @media screen and (max-width: 768px) { .slide-container { display: none; } .portail-wrapper { justify-content: center; } - .form-panel { padding: 24px 20px; } + .form-panel { + padding: 36px 24px 64px; + justify-content: flex-start; + } .login100-form { max-width: 100%; } - .portail-footer { position: static; margin-top: 16px; } + .portail-footer { bottom: 10px; } } diff --git a/Vue/Ajaxconnexioncookie/english.php b/Vue/Ajaxconnexioncookie/english.php index bd2b24dd..ab262272 100755 --- a/Vue/Ajaxconnexioncookie/english.php +++ b/Vue/Ajaxconnexioncookie/english.php @@ -1,7 +1,9 @@ - + Manager Portal
- +
@@ -39,6 +40,7 @@ if ($maintenance === '1') { onchange="javascript:changer_langue_connexion();"> + @@ -90,7 +92,7 @@ if ($maintenance === '1') { - + - + + -
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
-
-

INTER SANTE

-

ERP SaaS — Solution de gestion intégrée

-
- - + +
+

INTER SANTE

+

ERP SaaS — Solution de gestion intégrée

+
+ + - -
- - + +
+ + - - + + - - + + +
+ -
- + - + + + + + + + - - - - + /* ---- Carrousel ---- */ + var slideImages = document.querySelectorAll('.slide'); + var nextBtn = document.querySelector('.next'); + var prevBtn = document.querySelector('.prev'); + var dots = document.querySelectorAll('.dot'); + var counter = 0; + var deletInterval; - - + function switchImage(el) { + var id = parseInt(el.getAttribute('attr')); + if (id === counter) return; + if (id > counter) { + slideImages[counter].style.animation = 'next1 0.5s ease-in forwards'; + counter = id; + slideImages[counter].style.animation = 'next2 0.5s ease-in forwards'; + } else { + slideImages[counter].style.animation = 'prev1 0.5s ease-in forwards'; + counter = id; + slideImages[counter].style.animation = 'prev2 0.5s ease-in forwards'; + } + indicators(); + } + +