O:41:"Symfony\Component\AssetMapper\MappedAsset":12:{s:10:"sourcePath";s:58:"/home/cpamduga/parcours_connect/assets/styles/frontend.css";s:10:"publicPath";s:35:"/assets/styles/frontend-AwCT-x0.css";s:23:"publicPathWithoutDigest";s:27:"/assets/styles/frontend.css";s:15:"publicExtension";s:3:"css";s:7:"content";s:50721:"/* =============================================================================== PARCOURS CONNECT - CSS NETTOYÉ ET OPTIMISÉ Version épurée des règles obsolètes =============================================================================== */ /* ============================================================================= 01. FONDATIONS - Variables CSS épurées ============================================================================= */ :root { /* === ESPACEMENT SYSTÈME === */ --spacing-xs: 0.25rem; --spacing-sm: 0.5rem; --spacing-md: 1rem; --spacing-lg: 1.5rem; --spacing-xl: 2rem; --spacing-xxl: 3rem; /* === COULEURS FONDAMENTALES === */ --white: #ffffff; --black: #000000; --gray-50: #f9fafb; --gray-100: #f3f4f6; --gray-200: #e5e7eb; --gray-300: #d1d5db; --gray-400: #9ca3af; --gray-500: #6b7280; --gray-600: #4b5563; --gray-700: #374151; --gray-800: #1f2937; --gray-900: #111827; /* === COULEURS SÉMANTIQUES === */ --primary-color: #0056b3; --primary-hover: #003d73; --secondary-color: #6c757d; --success-color: #28a745; --danger-color: #dc3545; --warning-color: #ffc107; --info-color: #17a2b8; --light-color: #f8f9fa; --dark-color: #343a40; /* === COULEURS SPÉCIFIQUES MÉTIER === */ --assurance-maladie-blue: #3b4a6b; /* === COULEURS D'INTERFACE === */ --light-bg-color: #E8EDF7; --link-color: var(--primary-color); --link-hover-color: var(--primary-hover); --heading-color: var(--dark-color); --text-color: var(--gray-800); --text-muted: var(--gray-600); --border-color: #dee2e6; /* === SYSTÈME DE BORDURES === */ --border-width: 1px; --border-style: solid; --border: var(--border-width) var(--border-style) var(--border-color); --border-radius-sm: 0.25rem; --border-radius: 0.5rem; --border-radius-md: 0.75rem; --border-radius-lg: 1rem; --border-radius-xl: 1.5rem; --border-radius-full: 9999px; /* === SYSTÈME D'OMBRES === */ --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05); --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06); --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06); --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); /* === TRANSITIONS === */ --transition-fast: 0.15s ease; --transition-base: 0.2s ease; --transition-slow: 0.3s ease; --transition-colors: color var(--transition-base), background-color var(--transition-base), border-color var(--transition-base); --transition-transform: transform var(--transition-base); --transition-shadow: box-shadow var(--transition-base); --transition-all: all var(--transition-base); /* === HEADER & NAVIGATION === */ --header-bg: var(--assurance-maladie-blue); --header-text: var(--white); --header-padding: var(--spacing-xl) 0; --header-z-index: 100; --logo-spacing: var(--spacing-lg); --nav-button-size: 40px; --nav-button-icon-size: 24px; --nav-gap: var(--spacing-md); --nav-z-index: 1000; --nav-offset: 20px; /* === TIMELINE === */ --timeline-line-color: #4a5568; --timeline-line-width: 4px; --timeline-item-gap: 100px; --timeline-circle-size: 16px; --timeline-icon-size: 70px; --timeline-icon-border: 4px solid var(--white); --timeline-active-color: #3182ce; --timeline-number-size: 2.5rem; --timeline-title-width: 200px; --timeline-vertical-height: 100px; /* === CONTENEURS === */ --container-max-width: 1200px; --container-padding: var(--spacing-md); --sidebar-max-width: 280px; --sidebar-bg: #C4D0EB; --content-max-height: calc(100vh - 250px); } /* Variables responsive consolidées */ @media (max-width: 768px) { :root { --spacing-xs: 0.2rem; --spacing-sm: 0.4rem; --spacing-md: 0.8rem; --spacing-lg: 1.2rem; --spacing-xl: 1.6rem; --spacing-xxl: 2rem; --container-padding: var(--spacing-sm); --timeline-item-gap: 90px; --timeline-icon-size: 60px; --timeline-number-size: 1.8rem; --timeline-title-width: 180px; --timeline-vertical-height: 80px; --nav-button-size: 35px; --nav-button-icon-size: 18px; --nav-offset: 10px; } } @media (max-width: 480px) { :root { --border-radius: 0.3rem; --border-radius-lg: 0.6rem; --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05); --shadow: 0 2px 4px rgba(0, 0, 0, 0.1); --shadow-md: 0 2px 6px rgba(0, 0, 0, 0.1); --timeline-icon-size: 50px; --timeline-number-size: 1.6rem; --timeline-title-width: 160px; --timeline-vertical-height: 70px; --container-padding: 5px; } } /* ============================================================================= 02. RESET & BASE ============================================================================= */ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } html { -webkit-text-size-adjust: 100%; -webkit-tap-highlight-color: transparent; height: 100%; width: 100%; overflow-x: hidden; } body { font-family: var(--font-family); line-height: 1.6; color: var(--dark-color); background-color: var(--light-bg-color); height: 100vh; display: flex; flex-direction: column; width: 100%; max-width: 100%; margin: 0; padding: 0; overflow: hidden; } h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); margin-bottom: var(--spacing-md); line-height: 1.2; color: var(--heading-color); } a { color: var(--link-color); text-decoration: none; transition: var(--transition-colors); cursor: pointer; } a:hover, a:focus { color: var(--link-hover-color); text-decoration: underline; outline: none; } img { max-width: 100%; height: auto; vertical-align: middle; border-style: none; } /* ============================================================================= 03. LAYOUT & GRILLES ============================================================================= */ #body-content { flex: 1; width: 100%; max-width: 100%; display: flex; flex-direction: column; background-color: var(--light-bg-color); gap: 15px; margin: 0; padding: 0; box-sizing: border-box; overflow-y: auto; } .main-container { flex: 1; width: 100%; max-width: 100%; padding: 0; margin: 0 auto; box-sizing: border-box; } .container { width: 100%; max-width: var(--container-max-width); margin: 0 auto; padding: 0 15px; box-sizing: border-box; } /* --------- Page d'accueil --------*/ .content-area { display: flex; flex-direction: column; align-items: center; width: 100%; max-width: 100%; padding: 0; margin: 0 auto; flex: 1; background-color: var(--light-bg-color); box-sizing: border-box; } .left-content { flex: 3; padding-right: 30px; min-width: 0; } /* HOME LAYOUT - Optimisé */ .main-content.home-layout { display: grid; grid-template-columns: 1fr minmax(400px, 480px); grid-template-areas: "left right" "contact right"; grid-auto-flow: row; gap: 30px; align-items: start; width: 90%; max-width: 1400px; margin: 0 auto; } .main-content.home-layout > .left-content { grid-area: left; display: flex; align-items: stretch; } .main-content.home-layout > .right-sidebar { grid-area: right; background: #C9DDED; border-radius: 16px; padding: 30px; box-shadow: var(--shadow-md); max-height: none; overflow: visible; margin: 20px 0; } .main-content.home-layout > .contact-button-container { grid-area: contact; } /* --------- Visualisation FO1 --------*/ .page-header { padding: 0; margin-bottom: 0.25rem; width: 100%; } /* BREADCRUMB */ .breadcrumb-bar { padding: var(--spacing-xs) 0; } .breadcrumb-bar nav[aria-label="breadcrumb"] { margin: 0; } .breadcrumb-bar .breadcrumb { flex-wrap: wrap; margin-bottom: 0; } .breadcrumb-bar nav.pc-breadcrumb { margin-left: 0; padding-left: clamp(8px, 2vw, 24px); padding-right: clamp(8px, 2vw, 24px); } .breadcrumb-bar nav.pc-breadcrumb > ol.breadcrumb { flex-wrap: wrap; gap: 0.25rem 0.5rem; margin-bottom: 0; padding-left: 0; } /* ============================================================================= 04. EN-TÊTE & NAVIGATION ============================================================================= */ .header-banner { display: flex; align-items: center; gap: var(--spacing-md); padding: var(--spacing-md) var(--spacing-lg); background-color: var(--header-bg); color: var(--header-text); border-bottom: var(--border-width) solid var(--border-color); position: relative; z-index: var(--header-z-index); min-height: 120px; } .header-banner .logo-container { flex-shrink: 0; } .header-banner .logo-container img { height: 60px; width: auto; } .header-banner .parcours-logo-container { flex-shrink: 0; padding: var(--spacing-xs); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); transition: var(--transition-all); } .header-banner .parcours-logo-container:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); } .header-banner .parcours-logo-img { height: 50px; width: auto; display: block; } .header-banner h1 { flex: 1; text-align: center; margin: 0; font-family: var(--font-moretype-medium); font-weight: 500; font-size: 2.5rem; color: var(--header-text); letter-spacing: 1px; text-transform: uppercase; } /* Navigation buttons */ .navigation-buttons { gap: var(--nav-gap); z-index: var(--nav-z-index); top: var(--nav-offset); right: var(--nav-offset); position: fixed; display: flex; } .nav-button { width: var(--nav-button-size); height: var(--nav-button-size); background-color: var(--white); box-shadow: var(--shadow); transition: var(--transition-all); display: flex; justify-content: center; align-items: center; border-radius: 50%; text-decoration: none; cursor: pointer; border: none; padding: 0; } .nav-button:hover { transform: scale(1.1); box-shadow: var(--shadow-md); } .nav-button img { width: var(--nav-button-icon-size); height: var(--nav-button-icon-size); display: block; } /* Menu public consolidé */ .assurance-maladie-logo { display: flex; align-items: center; justify-content: space-between; padding: 10px 20px; background-color: white; border-bottom: 1px solid #dee2e6; width: 100%; box-sizing: border-box; margin-bottom: 0; z-index: 1000; position: relative; } .assurance-maladie-logo img { max-width: 300px; height: auto; display: block; } .public-menu { display: flex; align-items: center; justify-content: flex-start; flex-grow: 1; padding: 0 20px 0 40px; font-family: 'cabin-regular', sans-serif; background-color: #fff; height: 50px; overflow: visible; position: relative; width: 100%; box-sizing: border-box; } .public-menu-list { display: flex; list-style: none; margin: 0; padding: 0; justify-content: flex-start; height: 100%; align-items: center; width: 100%; flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; } .public-menu-item { margin: 0; padding: 0 20px; height: 100%; display: flex; align-items: center; position: relative; } .public-menu-item.dropdown { transform: translateY(2px); } .public-menu-item:not(.dropdown) { transform: translateY(-9px); align-items: center; } .public-menu-item:not(:last-child)::after { content: ''; position: absolute; right: 0; top: 10%; height: 80%; width: 1px; background: repeating-linear-gradient( 0deg, #3b4a6b, #3b4a6b 2px, transparent 2px, transparent 4px ); } .public-menu-item:last-child { position: relative; padding-right: 0; margin-right: 0; } .public-menu-link { color: #3b4a6b; text-decoration: none; font-size: 1.1rem; font-weight: 500; font-family: 'cabin-regular', sans-serif; padding: 0 20px; transition: var(--transition-colors); display: flex; align-items: center; position: relative; height: 100%; white-space: nowrap; justify-content: center; } .public-menu-link:hover, .public-menu-link.active, .public-menu-link.show { color: #0066cc; text-decoration: none; } .public-menu-link::after { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 3px; background-color: transparent; transition: background-color 0.2s ease; } .public-menu-link.active::after, .public-menu-link.show::after { background-color: #3b4a6b; } /* Dropdown styles */ .public-menu .dropdown-menu { margin-top: 3px; border: 1px solid #e0e0e0; border-radius: 0 0 4px 4px; box-shadow: var(--shadow-md); padding: 0; min-width: 200px; } .public-menu .dropdown-toggle { position: relative; padding-bottom: 24px; } .public-menu .dropdown-toggle::after { content: ''; border: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%233b4a6b' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; background-size: contain; width: 24px; height: 24px; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); transition: var(--transition-transform); } .public-menu .dropdown-toggle.show::after { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important; transform: translateX(-50%) rotate(180deg) !important; } .public-menu .dropdown-item { padding: 10px 20px; color: #333; font-size: 0.9rem; transition: var(--transition-colors); } .public-menu .dropdown-item:hover { background-color: #f5f9ff; color: #3b4a6b; } .public-menu .dropdown-divider { margin: 0; border-top: 1px solid #e9ecef; } /* Style pour le menu déroulant ouvert */ .public-menu .dropdown-toggle.show { color: #0066cc; } /* Suppression des icônes dans le menu */ .public-menu-link i { display: none; } /* Styles pour la navbar Bootstrap responsive */ .public-navbar { background-color: white !important; border-bottom: 1px solid #e9ecef; padding: 0.5rem 1rem; min-height: 60px; align-items: center; } /* Logo intégré dans la navbar */ .public-navbar .assurance-maladie-logo { margin-right: 1.5rem; margin-left: 0; /* Pas de marge à gauche */ padding: 0; text-decoration: none !important; /* Supprime le trait horizontal */ border-bottom: none !important; display: flex; align-items: center; width: auto; /* Largeur automatique */ flex-shrink: 0; /* Empêche la compression */ } .public-navbar .assurance-maladie-logo:hover, .public-navbar .assurance-maladie-logo:focus { text-decoration: none !important; border-bottom: none !important; } .public-navbar .assurance-maladie-logo img { height: 40px; width: auto; display: block; } .public-navbar .container-fluid { display: flex; align-items: center; justify-content: flex-start; /* Éléments groupés à gauche */ gap: 1rem; /* Espacement entre logo et bouton hamburger */ } .public-navbar .navbar-nav { flex-grow: 1; justify-content: center; margin-left: 1rem; /* Compense l'espace du logo */ } .public-navbar .nav-link { color: #3b4a6b !important; font-size: 1.1rem; font-weight: 500; font-family: 'cabin-regular', sans-serif; padding: 0.5rem 1rem; transition: all 0.2s ease; white-space: nowrap; } /* Bordures en pointillés entre les éléments du menu */ .public-navbar .nav-item:not(:last-child) { border-right: 1px dotted #ccc; } .public-navbar .nav-item:not(:last-child) .nav-link { margin-right: 0.5rem; } .public-navbar .nav-item:not(:first-child) .nav-link { margin-left: 0.5rem; } /* Personnalisation des chevrons dropdown */ .public-navbar .dropdown-toggle::after { display: none; /* Cache le chevron Bootstrap par défaut */ } .public-navbar .dropdown-toggle { position: relative; padding-bottom: 1rem; /* Espace pour le chevron en dessous */ } .public-navbar .dropdown-toggle::before { content: ''; position: absolute; bottom: 0.2rem; left: 50%; transform: translateX(-50%) rotate(45deg); width: 10px; height: 10px; border-right: 2.5px solid #3b4a6b; border-bottom: 2.5px solid #3b4a6b; border-radius: 1px; transition: border-color 0.2s ease; } .public-navbar .dropdown-toggle:hover::before, .public-navbar .dropdown-toggle.show::before { border-right-color: #0066cc; border-bottom-color: #0066cc; } .public-navbar .nav-link:hover, .public-navbar .nav-link.active, .public-navbar .nav-link.show { color: #0066cc !important; } .public-navbar .dropdown-menu { border: 1px solid rgba(0,0,0,.15); border-radius: 0.375rem; box-shadow: 0 0.5rem 1rem rgba(0,0,0,.175); min-width: 200px; display: none; /* Caché par défaut */ } .public-navbar .dropdown-menu.show { display: block; /* Visible quand activé par Bootstrap */ } .public-navbar .dropdown-item { color: #212529; padding: 0.5rem 1rem; font-size: 1rem; transition: background-color 0.2s ease; } .public-navbar .dropdown-item:hover, .public-navbar .dropdown-item:focus { background-color: #f5f9ff; color: #3b4a6b; } .public-navbar .navbar-toggler { border: 1px solid #3b4a6b; padding: 0.25rem 0.5rem; margin-right: 0; /* Supprime la marge par défaut */ } .public-navbar .navbar-toggler:focus { box-shadow: 0 0 0 0.2rem rgba(59, 74, 107, 0.25); } /* Styles spécifiques pour les résolutions desktop (1200px+) */ @media (min-width: 1200px) { .public-navbar .dropdown-menu { display: none !important; /* Force le masquage par défaut */ } .public-navbar .dropdown-menu.show { display: block !important; /* Visible seulement avec la classe .show */ } } /* Responsive adjustments */ @media (max-width: 1199.98px) { .public-navbar .assurance-maladie-logo { margin-right: 0.5rem; /* Réduit la marge sur mobile */ } .public-navbar .assurance-maladie-logo img { height: 35px; /* Légèrement plus petit sur mobile */ } .public-navbar .navbar-nav { text-align: center; margin-left: 0; /* Supprime la compensation sur mobile */ width: 100%; } .public-navbar .nav-link { padding: 0.75rem 1rem; border-bottom: 1px solid #f8f9fa; } /* Suppression des bordures verticales sur mobile */ .public-navbar .nav-item:not(:last-child) { border-right: none; } .public-navbar .nav-item:not(:last-child) .nav-link, .public-navbar .nav-item:not(:first-child) .nav-link { margin-left: 0; margin-right: 0; } .public-navbar .dropdown-toggle { padding-bottom: 0.75rem; /* Ajustement pour mobile */ } .public-navbar .dropdown-toggle::before { bottom: 0.1rem; /* Position ajustée pour mobile */ width: 8px; height: 8px; border-right: 2px solid #3b4a6b; border-bottom: 2px solid #3b4a6b; border-radius: 0.5px; /* Chevron symétrique pour mobile */ } .public-navbar .dropdown-menu { position: static !important; transform: none !important; box-shadow: none; border: none; background-color: #f8f9fa; margin-top: 0; } .public-navbar .dropdown-item { padding: 0.5rem 2rem; font-size: 0.95rem; } } /* Permettre les retours à la ligne dans le menu en mode mobile (évite le texte tronqué) */ @media (max-width: 1199.98px) { .public-navbar .nav-link { white-space: normal; /* override du nowrap desktop */ word-break: break-word; overflow-wrap: anywhere; line-height: 1.3; } /* Chaque item prend toute la largeur pour laisser le texte s'étendre sur plusieurs lignes */ .public-navbar .navbar-nav { align-items: stretch; } .public-navbar .nav-item { width: 100%; } } /* Bannières et logos */ .assurance-maladie-banner { background-color: white; width: 100%; padding: 6px 0; margin-bottom: 0; } .assurance-maladie-banner .container { max-width: 100%; margin: 0 auto; padding: 0; } .logo-container svg, .logo-container img { height: 60px; width: auto; } /* ============================================================================= 05. COMPOSANTS UI - Boutons, Formulaires, Cartes ============================================================================= */ /* ============================================================================= 05. TIMELINE ============================================================================= */ .etape-timeline-container { position: relative; padding: 140px 20px; margin: 40px 0 70px 0; background-color: transparent; } .etape-timeline-line { position: absolute; top: 50%; left: 40px; right: 40px; height: var(--timeline-line-width); background-color: var(--timeline-line-color); transform: translateY(-50%); z-index: 1; } .etape-timeline { display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 2; padding: 0 40px; overflow: visible; max-width: 100%; } .etape-item { display: flex; flex-direction: column; align-items: center; position: relative; flex: 1; max-width: var(--timeline-title-width); cursor: pointer; margin: 0 10px; } .etape-item::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: var(--timeline-circle-size); height: var(--timeline-circle-size); background-color: var(--timeline-line-color); border-radius: 50%; z-index: 3; border: 3px solid white; box-shadow: var(--shadow-sm); transition: var(--transition-all); } .etape-item::after { content: ''; position: absolute; left: 50%; transform: translateX(-50%); width: 2px; background-color: var(--timeline-line-color); z-index: 2; transition: var(--transition-all); } .etape-item:nth-child(odd)::after { bottom: 50%; height: var(--timeline-vertical-height); } .etape-item:nth-child(even)::after { top: 50%; height: var(--timeline-vertical-height); } .etape-icon { width: var(--timeline-icon-size); height: var(--timeline-icon-size); background-color: var(--timeline-line-color); border-radius: 50%; display: flex; align-items: center; justify-content: center; position: absolute; left: 50%; margin-left: calc(var(--timeline-icon-size) / -2); z-index: 4; transition: var(--transition-all); box-shadow: var(--shadow-md); border: 4px solid transparent; } .etape-item:nth-child(odd) .etape-icon { bottom: 50%; margin-bottom: var(--timeline-vertical-height); } .etape-item:nth-child(even) .etape-icon { top: 50%; margin-top: var(--timeline-vertical-height); } .etape-icon i { color: white; font-size: 1.8rem; } .etape-icon img, .etape-icon .etape-icon-image { width: 55px; height: 55px; object-fit: contain; } .etape-number { position: absolute; font-size: var(--timeline-number-size); font-weight: 700; color: #2c5aa0; line-height: 1; font-family: var(--font-family-heading, 'cabin-semibold', sans-serif); right: 50%; margin-right: 15px; z-index: 5; } .etape-title { position: absolute; font-size: 0.95rem; font-weight: 500; color: var(--timeline-line-color); line-height: 1.4; max-width: var(--timeline-title-width); width: var(--timeline-title-width); font-family: var(--font-family, 'cabin-regular', sans-serif); word-wrap: break-word; hyphens: auto; left: 50%; margin-left: 15px; z-index: 5; text-align: left; } .etape-item:nth-child(odd) .etape-number { bottom: 50%; margin-bottom: 35px; top: auto; } .etape-item:nth-child(odd) .etape-title { bottom: 50%; margin-bottom: 40px; top: auto; } .etape-item:nth-child(even) .etape-number { top: 50%; margin-top: 35px; } .etape-item:nth-child(even) .etape-title { top: 50%; margin-top: 40px; } /* États actifs */ .etape-item.active::before { background-color: var(--timeline-active-color); } .etape-item.active::after { background-color: var(--timeline-active-color); } .etape-item.active .etape-icon { background-color: var(--timeline-active-color); transform: scale(1.1); border: 4px solid var(--white); box-shadow: 0 0 0 4px rgba(49, 130, 206, 0.25), var(--shadow-lg); } .etape-item.active .etape-number { color: var(--timeline-active-color); font-weight: 800; } .etape-item.active .etape-title { color: var(--timeline-active-color); font-weight: 600; } /* Effets de hover */ .etape-item:hover::before { background-color: var(--timeline-active-color); } .etape-item:hover::after { background-color: var(--timeline-active-color); } .etape-item:hover .etape-icon { background-color: var(--timeline-active-color); transform: scale(1.05); } .etape-item:hover .etape-number { color: var(--timeline-active-color); } .etape-item:hover .etape-title { color: #2d3748; } .etape-separator { width: 100%; height: 2px; background: linear-gradient(90deg, transparent 0%, #3b4a6b 50%, transparent 100%); margin: 2.5rem 0 0.1rem 0; } /* ============================================================================= 06. FICHES-OUTILS ============================================================================= */ .fiche-outil-show .page-header { margin-bottom: 2rem; } .fiche-outil-show .page-header img { max-height: 50px; margin-bottom: 1rem; } .fiche-outil-show .page-header .date { text-align: right; color: #666; font-size: 0.9rem; } .fiche-outil-show .page-title { color: #0051A4; text-transform: uppercase; font-size: 2rem; } .fiche-outil-show .fiche-standard-panel { background-color: var(--white); border-radius: var(--border-radius); box-shadow: var(--shadow-sm); padding: 1.25rem; display: flex; flex-direction: column; } .fiche-outil-show .fo-footer { margin-top: auto; margin-bottom: 0; padding-top: var(--spacing-xl); } /* Rapprocher le footer du bas en vue mobile */ @media (max-width: 768px) { .fiche-outil-show .fiche-standard-panel { padding-bottom: 0; } .fiche-outil-show .fo-footer { padding-top: var(--spacing-sm); } } .fiche-outil-show nav[aria-label="breadcrumb"] { margin-bottom: 0 !important; } .fiche-outil-show .question-answer-container { margin-bottom: 2rem; } .fiche-outil-show .question-box { display: flex; align-items: center; margin-bottom: 1rem; gap: 1rem; position: relative; } .fiche-outil-show .question-icon { width: 120px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; position: relative; z-index: 10; margin-right: -50px; } .fiche-outil-show .question-content { flex-grow: 1; font-size: 1.1rem; color: #333; padding: 1rem; border: 2px solid var(--danger-color); border-radius: 8px; position: relative; z-index: 2; } .fiche-outil-show .answer-box { display: flex; align-items: center; margin-bottom: 1rem; gap: 1rem; position: relative; } .fiche-outil-show .answer-content { flex-grow: 1; font-size: 1.1rem; color: #333; padding: 1rem; border: 2px solid var(--danger-color); border-radius: 8px; position: relative; z-index: 2; } .fiche-outil-show .answer-icon { width: 120px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; position: relative; z-index: 10; margin-left: -50px; } .fiche-outil-show .info-section { margin-top: 2rem; } .fiche-outil-show .info-title { color: #333; font-size: 1.1rem; font-weight: bold; margin-bottom: 0.5rem; } .fiche-outil-show .info-content { color: #333; font-size: 1rem; } .fiche-outil-show .info-link { color: #0051A4; text-decoration: underline; word-break: break-all; } .fiche-content { margin-bottom: 2rem; font-size: 1.1rem; color: #333; } .fiche-description { margin-bottom: 2rem; font-size: 1.1rem; color: #555; font-style: italic; } .associated-fiches { margin-top: 3rem; padding-top: 1.5rem; border-top: 1px solid #ddd; } .associated-fiches-title { color: #0051A4; font-size: 1.4rem; margin-bottom: 1.5rem; } .fiche-link { display: block; padding: 1rem; background-color: #f8f9fa; border-radius: 0.5rem; margin-bottom: 1rem; text-decoration: none; color: #333; border-left: 4px solid #0051A4; transition: var(--transition-all); } .fiche-link:hover { background-color: #e9ecef; transform: translateX(5px); } .fiche-link i { color: #0051A4; margin-right: 0.5rem; } .back-link { display: inline-block; margin-top: 2rem; color: #0051A4; text-decoration: none; } .back-link:hover { text-decoration: underline; } /* ============================================================================= 07. PAGES SPÉCIFIQUES ============================================================================= */ /* Page d'accueil */ .hero-section { background: linear-gradient(135deg, #2c3e50 0%, #3498db 100%); color: white; padding: 5rem 0; margin-bottom: 3.5rem; position: relative; overflow: hidden; box-shadow: var(--shadow-lg); } .hero-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: url('data:image/svg+xml,') repeat; opacity: 0.1; } .hero-title { font-size: 3.5rem; font-weight: 700; margin-bottom: 1rem; text-shadow: 2px 2px 4px rgba(0,0,0,0.2); letter-spacing: 0.5px; color: #ffffff; background-color: rgba(0, 0, 0, 0.2); display: inline-block; padding: 10px 20px; border-radius: 8px; } .hero-subtitle { font-size: 1.5rem; opacity: 0.9; margin-bottom: 2rem; font-weight: 300; } .section-title { position: relative; padding-bottom: 1rem; margin-bottom: 2rem; color: #2c3e50; } .section-title::after { content: ''; position: absolute; bottom: 0; left: 0; width: 50px; height: 3px; background: #3498db; } .parcours-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 2rem; padding: 1.5rem; margin-bottom: 2rem; } .parcours-logo { height: 200px; background: #f8f9fa; display: flex; align-items: center; justify-content: center; padding: 1.5rem; position: relative; overflow: visible; width: auto; max-width: 100%; max-height: 250px; border-radius: 8px; box-shadow: var(--shadow-md); transition: var(--transition-transform); } .parcours-logo:hover { transform: scale(1.05); } .parcours-logo img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: scale-down; transition: var(--transition-transform); } .parcours-logo-placeholder { width: 150px; height: 150px; background-color: #e9ecef; border-radius: 8px; display: flex; align-items: center; justify-content: center; color: #adb5bd; font-size: 3rem; } .parcours-content { padding: 1.75rem; flex-grow: 1; display: flex; flex-direction: column; } .parcours-illustration { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 6rem 0; max-width: 1100px; margin-left: auto; margin-right: auto; } .illustration-left img, .illustration-right img { height: auto; width: auto; max-width: 100%; max-height: 380px; object-fit: contain; } .illustration-title { padding: 0 1rem; text-align: center; flex: 1 1 auto; } .guide-subtitle { margin: 0; line-height: 1.25; font-size: 1.9rem; } .parcours-title { font-size: 1.75rem; margin-bottom: 1.25rem; color: #2c3e50; font-weight: 600; line-height: 1.3; } .parcours-description { color: #666; margin-bottom: 1.5rem; display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; line-height: 1.6; flex-grow: 1; } .parcours-footer { padding: 1rem 1.75rem; background: #f8f9fa; border-top: 1px solid #eee; } .section-header { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; padding: 1rem 1.5rem; } .section-header h2 { margin: 0; font-size: 2rem; color: #2c3e50; } .doctor-patient-image { width: 100%; aspect-ratio: 16 / 9; height: auto; border-radius: 16px; margin-top: 20px; display: flex; align-items: center; justify-content: center; overflow: hidden; background-image: url("../images/medecin_homme_patiente_femme-l_ZkBz7.jpeg"); background-size: cover; background-position: center; box-shadow: var(--shadow-md); } /* Liste des pathologies */ .pathology-list { list-style: none; padding: 0; margin: 0; font-family: 'cabin-semibold', sans-serif; } .pathology-list h3 { color: #3b4b6b; font-size: 1.4rem; margin-bottom: 15px; font-family: 'cabin-semibold', sans-serif; border-bottom: 2px solid #3b4b6b; padding-bottom: 10px; font-weight: bold; } .pathology-item { margin-bottom: 10px; padding: 12px 0; position: relative; } .pathology-item:not(:last-child)::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1px; background: repeating-linear-gradient( to right, #0670B8, #0670B8 2px, transparent 2px, transparent 4px ); } .pathology-item a { color: #0060A1; font-size: 1.1rem; text-decoration: none; display: flex; align-items: center; transition: var(--transition-all); padding: 8px 0; } .pathology-item a:hover { color: #003366; transform: translateX(5px); } .pathology-item i { margin-right: 10px; color: #0060A1; transition: var(--transition-colors); } .pathology-item a:hover i { color: #003366; } .parcours-connect-text { color: #6c757d; font-style: italic; font-size: 0.9rem; margin-top: 20px; text-align: center; } /* Formulaire de contact */ .contact-container { max-width: 100%; padding: 2rem; } .contact-header h2 { color: var(--assurance-maladie-blue); margin-bottom: 1rem; font-size: 1.8rem; font-weight: 600; } .contact-description { color: #666; margin-bottom: 2rem; line-height: 1.6; font-size: 1.1rem; } .contact-form .form-group label { font-weight: 600; color: var(--assurance-maladie-blue); margin-bottom: 0.5rem; display: block; font-size: 1rem; } .contact-form .form-control { border: 2px solid #e1e5e9; border-radius: 8px; padding: 0.75rem 1rem; font-size: 1rem; transition: var(--transition-all); width: 100%; font-family: inherit; } .contact-form .form-control:focus { border-color: #0066cc; box-shadow: 0 0 0 0.2rem rgba(0, 102, 204, 0.25); outline: none; } .contact-form textarea.form-control { min-height: 120px; resize: vertical; } .contact-form .btn-primary { background-color: #0066cc; border-color: #0066cc; padding: 0.75rem 2.5rem; font-weight: 600; border-radius: 8px; font-size: 1rem; transition: var(--transition-all); border: none; cursor: pointer; } .contact-form .btn-primary:hover { background-color: #0056b3; border-color: #0056b3; transform: translateY(-1px); box-shadow: 0 4px 8px rgba(0, 102, 204, 0.3); } .form-submit { text-align: center; margin-top: 1.5rem; } .contact-info { margin-top: 2rem; padding-top: 2rem; border-top: 2px solid #e1e5e9; } .contact-info h3 { color: var(--assurance-maladie-blue); font-size: 1.3rem; margin-bottom: 1.5rem; font-weight: 600; } .contact-details { background-color: #f8f9fa; padding: 1.5rem; border-radius: 8px; border-left: 4px solid #0066cc; } .contact-item { margin-bottom: 1rem; color: #666; font-size: 1rem; } .contact-item:last-child { margin-bottom: 0; } .contact-item strong { color: var(--assurance-maladie-blue); font-weight: 600; } .contact-item a { color: #0066cc; text-decoration: none; font-weight: 500; } .contact-item a:hover { text-decoration: underline; } /* Bouton contact page d'accueil */ .contact-button-container { text-align: center; margin-top: 2rem; padding: 1.5rem; } .contact-button { display: inline-flex; align-items: center; gap: 0.75rem; background: linear-gradient(135deg, #0066cc 0%, #0056b3 100%); color: white; padding: 1rem 2rem; border-radius: 50px; text-decoration: none; font-weight: 600; font-size: 1.1rem; box-shadow: 0 4px 15px rgba(0, 102, 204, 0.3); transition: var(--transition-all); border: none; cursor: pointer; } .contact-button:hover { color: white; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0, 102, 204, 0.4); background: linear-gradient(135deg, #0056b3 0%, #004494 100%); text-decoration: none; } .contact-button i { font-size: 1.2rem; } .contact-subtitle { margin-top: 0.75rem; color: #666; font-size: 0.95rem; font-style: italic; margin-bottom: 0; } /* Messages et alertes */ .alert { border-radius: 8px; margin-bottom: 1.5rem; padding: 1rem 1.25rem; border: none; } .alert-success { background-color: #d1edff; color: #0c5460; border-left: 4px solid #0066cc; } .alert-danger { background-color: #f8d7da; color: #721c24; border-left: 4px solid var(--danger-color); } .form-error { color: var(--danger-color); font-size: 0.875rem; margin-top: 0.25rem; display: block; } .contact-form .form-control.is-invalid { border-color: var(--danger-color); } .contact-form .form-control.is-invalid:focus { border-color: var(--danger-color); box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25); } /* Champ honeypot caché */ .contact-form input[name="contact[website]"] { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; pointer-events: none; } /* ============================================================================= 08. RESPONSIVE CONSOLIDÉ ============================================================================= */ /* Tablettes et ordinateurs (jusqu'à 1200px) */ @media (max-width: 1200px) { .etape-item { max-width: 180px; margin: 0 8px; } .etape-title { max-width: 160px; width: 160px; font-size: 0.9rem; } .etape-number { font-size: 2.2rem; } .illustration-left img, .illustration-right img { max-height: 280px; } .guide-subtitle { font-size: 1.6rem; } } /* Tablettes (jusqu'à 992px) */ @media (max-width: 992px) { .left-content { width: 100%; padding-right: 0; margin-bottom: 20px; } .right-sidebar { width: 100%; max-height: none; min-width: auto; } .main-container { padding: 0 10px; } .parcours-illustration { gap: 0.75rem; } .illustration-left img, .illustration-right img { max-height: 220px; } .guide-subtitle { font-size: 1.4rem; } /* Home: passer la colonne droite (liste pathologies) au-dessus de l'image */ .main-content.home-layout { display: grid; grid-template-columns: 1fr; grid-template-areas: "right" "left" "contact"; gap: 20px; } /* Home: ajuster les hauteurs pour éviter la scrollbar globale */ .doctor-patient-image { aspect-ratio: 16 / 8; } .main-content.home-layout > .right-sidebar { max-height: 72vh; overflow: auto; } .main-content.home-layout > .contact-button-container { margin-top: 0.75rem; } } /* Mobiles (jusqu'à 768px) */ @media (max-width: 768px) { .header-banner { flex-direction: row; flex-wrap: wrap; gap: 0; text-align: center; min-height: auto; padding: var(--spacing-sm) var(--spacing-md); justify-content: flex-start; align-items: center; } .header-banner .logo-container { order: 1; flex: 0 1 auto; box-sizing: border-box; display: flex; align-items: center; justify-content: flex-start; padding-right: 0; margin-right: 0; margin-left: 6px; } .header-banner .parcours-logo-container { order: 2; flex: 0 1 auto; box-sizing: border-box; display: flex; align-items: center; justify-content: flex-start; margin-left: 8px; padding: 0; box-shadow: none; } .header-banner h1 { order: 3; flex: 0 0 100%; font-size: 2rem; margin-top: var(--spacing-xs); } .header-banner .logo-container img { height: 42px; } .header-banner .parcours-logo-img { height: 42px; } .header-banner .parcours-logo-container:hover { box-shadow: none; transform: none; } .navigation-buttons { top: 10px; right: 10px; gap: 10px; } /* Etape: inverser l'ordre en mobile (contenu d'abord, timeline ensuite) */ .etape-page { display: flex; flex-direction: column-reverse; gap: 1rem; } .main-content.home-layout { display: grid; grid-template-columns: 1fr; grid-template-areas: "right" "left" "contact"; gap: 20px; } .main-content.home-layout > .right-sidebar { max-height: none; margin: 0; padding: 20px; } .breadcrumb-bar nav.pc-breadcrumb { padding-left: clamp(0px, 0.8vw, 8px); padding-right: clamp(6px, 1.5vw, 16px); } .breadcrumb-bar nav.pc-breadcrumb > ol.breadcrumb { gap: 0.2rem 0.4rem; } .page-header { padding: 1rem 0; } .page-header h1 { font-size: 1.5rem; } .main-container { padding: 0 8px; gap: 10px; } .container { padding: 0 8px; } .doctor-patient-image { height: 250px; } .pathology-list h3 { font-size: 1.2rem; } .pathology-item a { font-size: 1rem; } .parcours-illustration { flex-direction: column; align-items: center; } .illustration-left img, .illustration-right img { max-height: 180px; } .contact-container { padding: 1rem; } .contact-header h2 { font-size: 1.5rem; } .contact-form .btn-primary { width: 100%; padding: 1rem; font-size: 1.1rem; } .contact-details { padding: 1rem; } .contact-form .form-control { font-size: 16px; } .contact-button-container { margin-top: 1.5rem; padding: 1rem; } .contact-button { padding: 0.875rem 1.5rem; font-size: 1rem; gap: 0.5rem; } .contact-button i { font-size: 1.1rem; } .contact-subtitle { font-size: 0.9rem; } /* TIMELINE MOBILE - Version verticale */ .etape-timeline-container { padding: 40px 10px; } .etape-timeline { flex-direction: column; gap: 100px; padding: 0; align-items: stretch; justify-content: flex-start; } .etape-timeline-line { width: 4px; height: 100%; left: 35px; right: auto; top: 0; bottom: 0; transform: none; } .etape-item { display: flex; flex-direction: row; align-items: center; max-width: 100%; padding-left: 0px; padding-right: 15px; margin: 0; position: relative; width: 100%; min-height: 80px; } .etape-item::before { left: 35px; top: 50%; transform: translate(-50%, -50%); position: absolute; } .etape-item::after { display: none !important; } .etape-icon { position: absolute !important; left: 0px; top: 50%; margin-top: -35px !important; margin-left: 0 !important; margin-bottom: 0 !important; width: 70px; height: 70px; z-index: 10; } .etape-item a { text-decoration: none; position: relative; width: 100%; display: block; padding-left: 90px; } .etape-item .etape-number, .etape-item .etape-title { position: static !important; transform: none !important; margin: 0 !important; top: auto !important; bottom: auto !important; left: auto !important; display: inline-block; vertical-align: middle; } .etape-number { font-size: 1.8rem; line-height: 1.3; margin-right: 15px !important; } .etape-title { font-size: 0.9rem; line-height: 1.3; display: inline-block; vertical-align: middle; } .etape-icon i { font-size: 1.8rem; } .etape-icon img, .etape-icon .etape-icon-image { width: 55px; height: 55px; } } /* Très petits écrans (jusqu'à 480px) */ @media (max-width: 480px) { .main-container { padding: 0 5px; } .container { padding: 0 5px; } .doctor-patient-image { height: 350px; } .parcours-grid { grid-template-columns: 1fr; padding: 1rem; } .hero-title { font-size: 2.5rem; } .hero-subtitle { font-size: 1.2rem; } .contact-button { width: 100%; justify-content: center; padding: 1rem; } } /* ============================================================================= 09. ANIMATIONS ============================================================================= */ @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } .fa-spinner.fa-spin { animation: spin 1s linear infinite; } /* ============================================================================= FIN DU FICHIER CSS NETTOYÉ ============================================================================= */";s:6:"digest";s:32:"030093fb1d0bdaeb9c61f523ab4b696b";s:13:"isPredigested";b:0;s:11:"logicalPath";s:19:"styles/frontend.css";s:8:"isVendor";b:0;s:55:"Symfony\Component\AssetMapper\MappedAssetdependencies";a:1:{i:0;O:41:"Symfony\Component\AssetMapper\MappedAsset":12:{s:10:"sourcePath";s:79:"/home/cpamduga/parcours_connect/assets/images/medecin_homme_patiente_femme.jpeg";s:10:"publicPath";s:56:"/assets/images/medecin_homme_patiente_femme-l_ZkBz7.jpeg";s:23:"publicPathWithoutDigest";s:48:"/assets/images/medecin_homme_patiente_femme.jpeg";s:15:"publicExtension";s:4:"jpeg";s:7:"content";N;s:6:"digest";s:32:"97f664073edc0334922b1931817a581f";s:13:"isPredigested";b:0;s:11:"logicalPath";s:40:"images/medecin_homme_patiente_femme.jpeg";s:8:"isVendor";b:0;s:55:"Symfony\Component\AssetMapper\MappedAssetdependencies";a:0:{}s:59:"Symfony\Component\AssetMapper\MappedAssetfileDependencies";a:0:{}s:60:"Symfony\Component\AssetMapper\MappedAssetjavaScriptImports";a:0:{}}}s:59:"Symfony\Component\AssetMapper\MappedAssetfileDependencies";a:0:{}s:60:"Symfony\Component\AssetMapper\MappedAssetjavaScriptImports";a:0:{}}