diff --git a/css/public.css b/css/public.css index 72de23c..4ca79ae 100644 --- a/css/public.css +++ b/css/public.css @@ -1,758 +1,54 @@ -/* --- VARIABLES DE DESIGN ET PALETTE SOMBRE --- */ -:root { - --background: #0a0a0a; - --surface: #1a1a1a; - --surface-card: #1e1e1e; - --surface-hover: #272727; - --border: #2e2e2e; - --border-hover: #444444; - --text: #ffffff; - --text-secondary: #e4e4e7; - --muted: #aaaab8; - --gold: #C9A84C; - --gold-glow: rgba(201, 168, 76, 0.2); - --gold-dim: rgba(201, 168, 76, 0.08); - --shadow-cinematic: 0 15px 35px rgba(0, 0, 0, 0.7); - --shadow-overlay: 0 30px 70px rgba(0, 0, 0, 0.9); -} - -* { - box-sizing: border-box; - margin: 0; - padding: 0; -} - - -/* page visibility (used by index.html wrapper) */ -.page { display: none; } -.page.active { display: block; } - -body { - background-color: var(--background); - color: var(--text); - font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif; - -webkit-font-smoothing: antialiased; - padding: 3rem 1rem; -} - -.site-wrap { - max-width: 1040px; - margin: 0 auto; -} - -/* --- EN-TÊTE CENTRÉ --- */ -.site-header { - text-align: center; - margin-bottom: 3.5rem; -} - -.site-title { - font-family: 'Playfair Display', Georgia, serif; - font-size: 3.2rem; - font-weight: 700; - letter-spacing: -0.03em; - margin-bottom: 0.6rem; -} - -.site-title span { - color: var(--gold); - text-shadow: 0 0 20px var(--gold-glow); -} - -.site-subtitle { - color: #c0c0cc; - font-size: 0.95rem; - letter-spacing: 0.08em; - text-transform: uppercase; -} - -/* --- NAVIGATION PAR ONGLETS --- */ -.pub-tabs-container { - display: flex; - justify-content: center; - margin-bottom: 3rem; -} - -.pub-tabs { - background-color: var(--surface); - border: 1px solid var(--border); - padding: 0.4rem; - border-radius: 30px; - display: inline-flex; - gap: 0.4rem; -} - -.tab-btn { - background: none; - border: none; - color: #d4d4de; - font-family: 'DM Sans', sans-serif; - font-size: 0.9rem; - font-weight: 500; - cursor: pointer; - padding: 0.65rem 1.6rem; - border-radius: 25px; - display: flex; - align-items: center; - gap: 0.6rem; - transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); -} - -.tab-btn i { font-size: 1.15rem; } - -.tab-btn:hover { - color: var(--text); - background-color: var(--surface-hover); -} - -.tab-btn.active { - color: var(--background); - background-color: var(--gold); - font-weight: 600; - box-shadow: 0 4px 15px var(--gold-glow); -} - -/* --- BARRE D'OUTILS --- */ -.pub-toolbar { - display: flex; - justify-content: space-between; - align-items: center; - margin-bottom: 2rem; - border-bottom: 1px solid var(--border); - padding-bottom: 1rem; -} - -.count { - font-size: 0.9rem; - color: #ccccd6; - font-weight: 500; -} - -.btn-admin-link { - color: #d4b05a !important; - text-decoration: none; - font-size: 0.8rem; - letter-spacing: 0.06em; - text-transform: uppercase; - display: inline-flex; - align-items: center; - gap: 0.5rem; - border: 1px solid rgba(201, 168, 76, 0.2); - padding: 0.5rem 1rem; - border-radius: 4px; - transition: all 0.25s ease; -} - -.btn-admin-link:hover { - background: var(--gold-dim); - border-color: var(--gold); -} - -/* --- GRILLE PRINCIPALE ET CARTES --- */ -.grid { - display: grid; - grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); - gap: 2.5rem 1.8rem; - margin-top: 1rem; -} - -.card { - background: transparent; - cursor: pointer; - display: flex; - flex-direction: column; -} - -.card-poster-wrap { - width: 100%; - aspect-ratio: 2 / 3; - position: relative; - border-radius: 8px; - overflow: hidden; - background: #121212; - box-shadow: var(--shadow-cinematic); - border: 1px solid var(--border); - transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1); -} - -.card-poster { - width: 100%; - height: 100%; - object-fit: cover; /* Garantit que l'affiche remplit harmonieusement la carte */ - display: block; /* Supprime les espaces blancs sous l'image */ - transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1); -} - -.card-poster-wrap::after { - content: ''; - position: absolute; - top: 0; left: -150%; width: 120%; height: 100%; - background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.08), transparent); - transform: skewX(-20deg); -} - -.card:hover .card-poster-wrap { - transform: translateY(-8px); - border-color: var(--border-hover); - box-shadow: 0 20px 30px rgba(0, 0, 0, 0.8); -} - -.card:hover .card-poster-wrap::after { - left: 150%; - transition: all 0.75s ease; -} - -.card:hover .card-poster { transform: scale(1.05); } -.card:hover .card-title { color: var(--gold); } - -.card-poster-placeholder { - width: 100%; height: 100%; - display: flex; flex-direction: column; justify-content: center; align-items: center; - padding: 1.2rem; text-align: center; - background: linear-gradient(135deg, #181818, #0a0a0a); -} - -.card-poster-placeholder i { font-size: 2.5rem; color: var(--gold); margin-bottom: 0.7rem; } -.card-body { padding: 0.9rem 0 0 0; } - -.card-title { - font-size: 0.95rem; margin: 0 0 0.3rem 0; font-weight: 600; color: #ffffff; - white-space: nowrap; overflow: hidden; text-overflow: ellipsis; - transition: color 0.25s ease; -} - -.card-meta { font-size: 0.8rem; color: #c4c4d0; font-weight: 500; } -.card-stars { - color: #FFD700; - margin-top: 0.4rem; - font-size: 0.85rem; - letter-spacing: 1px; -} - -.card-stars .stars-muted { - color: #ffffff; - opacity: 0.45; -} - -.card-video-footer { display: flex; justify-content: space-between; align-items: center; margin-top: 0.5rem; } - -.badge-format { - background: var(--gold-dim); color: var(--gold); font-size: 0.7rem; font-weight: bold; - padding: 0.15rem 0.5rem; border-radius: 3px; border: 1px solid rgba(201, 168, 76, 0.2); - text-transform: uppercase; -} - -.video-length { color: #a8a8b8; font-size: 0.75rem; display: inline-flex; align-items: center; gap: 0.25rem; } - -/* ========================================================================== - REFONTE IMMERSIVE DE LA POP-UP (MODALE PREMIUM) - ========================================================================== */ -.detail-overlay { - position: fixed; - top: 0; left: 0; width: 100%; height: 100%; - background: rgba(3, 3, 3, 0.85); - backdrop-filter: blur(25px); - -webkit-backdrop-filter: blur(25px); - display: flex; - justify-content: center; - align-items: center; - z-index: 9999; - padding: 2rem 1rem; - opacity: 0; - pointer-events: none; - transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1); -} - -.detail-overlay.open { - opacity: 1; - pointer-events: all; -} - -.detail-modal { - background: #0f0f10; - border: 1px solid var(--border); - border-radius: 16px; - max-width: 840px; - width: 100%; - max-height: 85vh; - overflow-y: auto; - position: relative; - display: flex; - gap: 3.5rem; - padding: 3.5rem; - box-shadow: var(--shadow-overlay); - transform: scale(0.96) translateY(20px); - transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); - scrollbar-width: thin; - scrollbar-color: var(--border) transparent; -} - -.detail-overlay.open .detail-modal { - transform: scale(1) translateY(0); -} - -.detail-modal.no-poster { - max-width: 620px; - display: block; -} - -/* Bouton Fermer */ -.modal-close { - position: absolute; - top: 1.5rem; right: 1.5rem; - background: rgba(255, 255, 255, 0.03); - border: 1px solid var(--border); - color: #d0d0da; - width: 38px; height: 38px; border-radius: 50%; - display: flex; align-items: center; justify-content: center; - font-size: 1.1rem; cursor: pointer; - transition: all 0.25s ease; - z-index: 10; -} - -.modal-close:hover { - color: var(--text); - background: rgba(255, 255, 255, 0.08); - border-color: #444; - transform: scale(1.05); -} - -/* Colonne Image (Affiche) */ -.detail-poster { - flex: 0 0 240px; - width: 240px; - border-radius: 12px; - overflow: hidden; - border: 1px solid rgba(255, 255, 255, 0.05); - box-shadow: 0 20px 45px rgba(0, 0, 0, 0.8); - background: #141414; - align-self: flex-start; -} - -.detail-poster.poster-critique { aspect-ratio: unset; } -.detail-poster.poster-critique img { width: 100%; height: auto; display: block; } - -.detail-poster.poster-video { aspect-ratio: 2 / 3; display: flex; align-items: center; justify-content: center; } -.detail-poster.poster-video img { width: 100%; height: 100%; object-fit: contain; display: block; } - -/* Colonne Contenu */ -.detail-content { - flex: 1; - min-width: 0; - display: flex; - flex-direction: column; -} - -.detail-header-block { - margin-bottom: 1.8rem; - border-bottom: 1px solid rgba(255, 255, 255, 0.04); - padding-bottom: 1.2rem; -} - -.detail-title { - font-family: 'Playfair Display', Georgia, serif; - font-size: 2.4rem; - font-weight: 700; - margin-bottom: 0.5rem; - line-height: 1.2; - color: var(--text); -} - -.detail-meta { - font-size: 0.95rem; - color: #d0d0da; - margin-bottom: 0.8rem; - font-weight: 500; - letter-spacing: 0.02em; -} - -/* --- VISIBILITÉ DES ÉTOILES DANS LA POP-UP --- */ -.detail-stars { - color: #FFD700; /* Un or plus lumineux et chaud (YellowGold) */ - font-size: 1.6rem; /* Taille augmentée pour une meilleure accroche visuelle */ - letter-spacing: 0.12em; /* Espace subtil entre les étoiles */ - margin-bottom: 1.2rem; - /* Effet de néon cinématographique discret sur les étoiles pleines */ - text-shadow: 0 0 12px rgba(255, 215, 0, 0.6), 0 0 20px rgba(255, 215, 0, 0.2); - display: inline-flex; - align-items: center; -} - -/* Style appliqué aux étoiles vides (masquées en arrière-plan) */ -.detail-stars .stars-muted { - color: #ffffff; - opacity: 0.35; /* Très estompé dans le noir pour faire ressortir la note réelle */ - text-shadow: none; /* Pas d'effet de lueur pour les étoiles vides */ -} - -/* --- DESIGN SUBLIMÉ DE LA CRITIQUE --- */ -.pub-review-card { - position: relative; - background: linear-gradient(145deg, #151516, #111112); - border: 1px solid var(--border); - border-radius: 12px; - padding: 2.2rem 2rem 2rem 2rem; - margin-top: 0.5rem; - box-shadow: inset 0 1px 2px rgba(255, 255, 255, 0.03); -} - -.pub-review-quote-icon { - position: absolute; - top: -14px; left: 24px; - background: #181819; - border: 1px solid var(--border); - color: var(--gold); - width: 30px; height: 30px; - border-radius: 50%; - display: flex; align-items: center; justify-content: center; - font-size: 0.95rem; - box-shadow: 0 4px 10px rgba(0, 0, 0, 0.4); -} - -.pub-review-text { - font-family: 'DM Sans', sans-serif; - color: var(--text-secondary); - font-size: 1.05rem; - line-height: 1.8; - white-space: pre-wrap; -} - -/* --- DESIGN INTERNE : VIDEOTHEQUE --- */ -.pub-tech-badges { - display: flex; - flex-wrap: wrap; - gap: 0.6rem; - margin-bottom: 1.5rem; -} - -.tech-pill { - background: rgba(255, 255, 255, 0.03); - border: 1px solid var(--border); - padding: 0.38rem 0.85rem; - border-radius: 6px; - font-size: 0.78rem; - font-weight: 600; - text-transform: uppercase; - color: #dddddd; - letter-spacing: 0.02em; - display: inline-flex; - align-items: center; - gap: 0.4rem; -} - -.tech-pill.format-gold { - background: var(--gold-dim); - border-color: rgba(201, 168, 76, 0.3); - color: var(--gold); -} - -.pub-tech-grid { - display: grid; - grid-template-columns: repeat(2, 1fr); - gap: 1rem; - background: #141415; - border: 1px solid var(--border); - padding: 1.1rem 1.3rem; - border-radius: 8px; - margin-bottom: 1.8rem; -} - -.tech-meta-item { display: flex; flex-direction: column; gap: 0.25rem; } -.tech-meta-label { font-size: 0.75rem; text-transform: uppercase; color: #c0c0cc; letter-spacing: 0.05em; font-weight: 500; } -.tech-meta-value { font-size: 0.9rem; color: var(--text); font-weight: 500; } - -.pub-synopsis-box h4 { - color: var(--text); margin-bottom: 0.6rem; font-size: 0.85rem; - font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; -} - -.pub-synopsis-box p { color: #e0e0e0; font-size: 0.95rem; line-height: 1.7; white-space: pre-wrap; } - -/* --- FIN DE PAGE & ACCESSOIRES --- */ -footer { - margin-top: 6rem; border-top: 1px solid var(--border); - padding-top: 2rem; text-align: center; color: var(--muted); - font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.06em; -} - -.empty-state { text-align: center; padding: 6rem 1rem; color: var(--muted); } -.empty-state i { font-size: 3.5rem; color: #444450; margin-bottom: 1.2rem; display: block; } - -/* ========================================================================== - COMPORTEMENT RESPONSIVE MOBILE (APPLICATION NATIVE APP-LIKE) - ========================================================================== */ -@media (max-width: 720px) { - body { padding: 2rem 1rem; } - .site-title { font-size: 2.6rem; } - - .detail-overlay { padding: 0; } - - .detail-modal { - flex-direction: column; - gap: 1.5rem; - padding: 4.5rem 1.5rem 2.5rem 1.5rem; - max-height: 100vh; - height: 100vh; - border-radius: 0; - border: none; - } - - .detail-poster { - margin: 0 auto; - width: 170px; - flex: 0 0 auto; - } - - .detail-header-block { - text-align: center; - padding-bottom: 1.5rem; - } - - .detail-title { font-size: 2rem; } - .detail-stars { justify-content: center; display: flex; } - - .pub-review-card { padding: 1.8rem 1.3rem; } - .pub-tech-grid { grid-template-columns: 1fr; gap: 0.9rem; } - - .pub-tabs { width: 100%; justify-content: center; } - .tab-btn { padding: 0.6rem 1.1rem; font-size: 0.85rem; } -} -/* ========================================================================== - FILTRE PAR NOTES (ÉTOILES) - ========================================================================== */ -.rating-filter-bar { - display: flex; - align-items: center; - justify-content: center; - gap: 1rem; - margin-bottom: 2rem; - flex-wrap: wrap; -} - -.rf-label { - font-size: 0.75rem; - text-transform: uppercase; - letter-spacing: 0.1em; - color: #ccccda; - font-weight: 500; -} - -.rf-buttons { - display: flex; - gap: 0.4rem; - flex-wrap: wrap; - justify-content: center; -} - -.rating-filter-btn { - background: #1e1e1e; - border: 1px solid #3a3a3a; - border-radius: 8px; - padding: 0.45rem 0.85rem; - cursor: pointer; - display: flex; - gap: 1px; - align-items: center; - transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1); -} - -.rating-filter-btn:hover { - border-color: var(--gold); - background: var(--gold-dim); -} - -.rating-filter-btn.active { - border-color: var(--gold); - background: var(--gold-dim); - box-shadow: 0 0 12px var(--gold-glow); -} - -.rf-star { - font-size: 0.85rem; - color: #7a7a88; - transition: color 0.2s ease, text-shadow 0.2s ease; - line-height: 1; -} - -.rating-filter-btn:hover .rf-star, -.rating-filter-btn.active .rf-star { - color: #FFD700; - text-shadow: 0 0 6px rgba(255, 215, 0, 0.5); -} - -/* On hover: light up stars progressively via sibling trick */ -.rating-filter-btn:not(.active):hover .rf-star:not(.filled) { - color: rgba(255, 215, 0, 0.35); -} - -/* Active state: filled stars glow, empty ones stay dim */ -.rating-filter-btn.active .rf-star.filled { - color: #FFD700; - text-shadow: 0 0 8px rgba(255, 215, 0, 0.6); -} - -.rating-filter-btn.active .rf-star:not(.filled) { - color: #555560; - text-shadow: none; -} - -@media (max-width: 720px) { - .rating-filter-bar { gap: 0.7rem; } - .rf-label { display: none; } - .rf-star { font-size: 0.8rem; } - .rating-filter-btn { padding: 0.4rem 0.65rem; } -} - /* ══════════════════════════════════════════════════════════════ - AMÉLIORATIONS UI PUBLIQUE (Recherche, Pagination, Cartes) + FILTRE PAR PLATEFORME DE STREAMING ═══════════════════════════════════════════════════════════════ */ -/* Barre de recherche publique */ -.pub-filters { +.streaming-filter-bar { display: flex; + align-items: center; justify-content: center; - margin-bottom: 2.5rem; -} -.pub-search-box { - position: relative; - width: 100%; - max-width: 480px; -} -.pub-search-box input { - width: 100%; - padding: 0.85rem 1.2rem 0.85rem 3rem; + gap: 1rem; + margin-bottom: 2rem; + flex-wrap: wrap; + padding: 1rem; background: var(--surface); border: 1px solid var(--border); - border-radius: 30px; - color: var(--text); - font-family: inherit; - font-size: 0.95rem; - transition: all 0.25s; -} -.pub-search-box input:focus { - outline: none; - border-color: var(--gold); - box-shadow: 0 0 0 3px var(--gold-dim); - background: var(--surface-card); -} -.pub-search-box input::placeholder { - color: var(--muted); -} -.pub-search-box i { - position: absolute; - left: 1.2rem; - top: 50%; - transform: translateY(-50%); - color: var(--muted); - font-size: 1.2rem; + border-radius: 12px; } -/* Pagination publique */ -.pub-pagination { - display: flex; - justify-content: center; - align-items: center; - gap: 0.4rem; - margin-top: 3rem; - padding: 1rem 0; - flex-wrap: wrap; -} -.pub-pagination button { - background: var(--surface); +.streaming-filter-btn { + background: var(--surface-card); border: 1px solid var(--border); - color: var(--text-secondary); - min-width: 40px; - height: 40px; - border-radius: 10px; - display: flex; - align-items: center; - justify-content: center; + border-radius: 20px; + padding: 0.5rem 1rem; cursor: pointer; - transition: all 0.25s; + font-size: 0.85rem; font-weight: 500; - font-size: 0.9rem; + color: var(--text-secondary); + transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1); font-family: inherit; } -.pub-pagination button:hover:not(:disabled):not(.active) { + +.streaming-filter-btn:hover { border-color: var(--gold); - color: var(--gold); background: var(--gold-dim); + color: var(--gold); } -.pub-pagination button.active { + +.streaming-filter-btn.active { + border-color: var(--gold); background: var(--gold); color: var(--background); - border-color: var(--gold); font-weight: 600; - box-shadow: 0 4px 12px var(--gold-glow); -} -.pub-pagination button:disabled { - opacity: 0.3; - cursor: not-allowed; -} -.pub-pagination-info { - color: var(--muted); - font-size: 0.85rem; - margin: 0 1rem; - font-weight: 500; - letter-spacing: 0.03em; -} - -/* Amélioration des cartes */ -.card { - position: relative; -} -.card-streaming-badge { - position: absolute; - top: 10px; - right: 10px; - background: rgba(0, 0, 0, 0.75); - backdrop-filter: blur(8px); - color: var(--gold); - font-size: 0.7rem; - font-weight: 600; - padding: 0.25rem 0.6rem; - border-radius: 20px; - border: 1px solid rgba(201, 168, 76, 0.3); - z-index: 2; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - max-width: 140px; -} -.card-physical-badge { - position: absolute; - top: 10px; - right: 10px; - background: rgba(0, 0, 0, 0.75); - backdrop-filter: blur(8px); - color: var(--muted); - font-size: 0.7rem; - font-weight: 600; - padding: 0.25rem 0.6rem; - border-radius: 20px; - border: 1px solid rgba(255, 255, 255, 0.1); - z-index: 2; -} -.card-rating-badge { - display: inline-block; - background: var(--surface); - border: 1px solid var(--border); - color: var(--gold); - font-size: 0.75rem; - font-weight: 600; - padding: 0.1rem 0.45rem; - border-radius: 5px; - margin-left: 0.4rem; - vertical-align: middle; -} -.card-director { - font-size: 0.78rem; - color: var(--muted); - margin-top: 0.2rem; - font-style: italic; + box-shadow: 0 0 12px var(--gold-glow); } @media (max-width: 720px) { - .pub-search-box { max-width: 100%; } - .pub-pagination button { min-width: 36px; height: 36px; font-size: 0.85rem; } + .streaming-filter-bar { + gap: 0.5rem; + padding: 0.8rem; + } + .streaming-filter-btn { + padding: 0.4rem 0.8rem; + font-size: 0.8rem; + } } \ No newline at end of file