/* ==========================================================================
   PORTFOLIO - CLÉMENT CERVELLINI
   Thème : Tokyo Night (Day & Storm)
   Version Finale - Corrigée v2
   ========================================================================== */

/* ==========================================================================
   1. VARIABLES GLOBALES
   ========================================================================== */
:root {
  --md-primary-fg-color: #2e7de9;
  --md-primary-fg-color--light: #70a5fd;
  --md-primary-fg-color--dark: #1c54b2;
  --md-accent-fg-color: #9854cb;
}

/* ==========================================================================
   2. MODE CLAIR - TOKYO NIGHT DAY
   ========================================================================== */
[data-md-color-scheme="default"] {
  --md-default-bg-color: #e9e9ec;
  --md-default-fg-color: #3760bf;
  --md-code-bg-color: #d5d6db;
  --md-typeset-a-color: #2e7de9;
}

/* Header & Tabs */
[data-md-color-scheme="default"] .md-header {
  background-color: #d5d6db;
  color: #3760bf;
  border-bottom: 1px solid #c4c5ca;
}

[data-md-color-scheme="default"] .md-tabs {
  background-color: #d5d6db;
  color: #3760bf;
}

/* Fond de page principal - CORRIGÉ */
[data-md-color-scheme="default"] .md-main {
  background-color: #e9e9ec;
}

[data-md-color-scheme="default"] .md-content {
  background-color: #e9e9ec;
}

/* Typographie */
[data-md-color-scheme="default"] .md-typeset {
  color: #3760bf;
}

[data-md-color-scheme="default"] .md-typeset h1,
[data-md-color-scheme="default"] .md-typeset h2,
[data-md-color-scheme="default"] .md-typeset h3 {
  color: #1c54b2;
}

/* Sidebar */
[data-md-color-scheme="default"] .md-sidebar {
  background-color: #e9e9ec;
}

[data-md-color-scheme="default"] .md-sidebar__scrollwrap {
  background-color: #e9e9ec;
}

/* Footer */
[data-md-color-scheme="default"] .md-footer {
  background-color: #d5d6db;
  color: #3760bf;
}

/* Search - CORRIGÉ */
[data-md-color-scheme="default"] .md-search__input {
  background-color: #ffffff;
  border: 1px solid #c4c5ca;
  color: #3760bf;
}

[data-md-color-scheme="default"] .md-search__input::placeholder {
  color: #8b8fa3;
}

/* ==========================================================================
   3. MODE SOMBRE - TOKYO NIGHT STORM
   ========================================================================== */
[data-md-color-scheme="slate"] {
  --md-default-bg-color: #1a1b26;
  --md-default-fg-color: #a9b1d6;
  --md-default-fg-color--light: #9aa5ce;
  --md-primary-fg-color: #7aa2f7;
  --md-accent-fg-color: #bb9af7;
  --md-code-bg-color: #16161e;
  --md-admonition-bg-color: #16161e;
  --md-typeset-a-color: #7aa2f7;
}

/* Header & Tabs */
[data-md-color-scheme="slate"] .md-header {
  background-color: #16161e;
  border-bottom: 1px solid #292e42;
}

[data-md-color-scheme="slate"] .md-tabs {
  background-color: #13131a;
  border-bottom: 1px solid #292e42;
}

/* Sidebar */
[data-md-color-scheme="slate"] .md-sidebar {
  background-color: #1a1b26;
}

[data-md-color-scheme="slate"] .md-nav {
  background-color: transparent;
}

/* Footer */
[data-md-color-scheme="slate"] .md-footer {
  background-color: #13131a;
  border-top: 1px solid #292e42;
}

/* Search */
[data-md-color-scheme="slate"] .md-search__input {
  background-color: #24283b;
  border: 1px solid #292e42;
}

[data-md-color-scheme="slate"] .md-search__input::placeholder {
  color: #565f89;
}

/* ==========================================================================
   4. TABLE DES MATIÈRES (TOC) - CORRIGÉ
   ========================================================================== */
/* Mode Clair */
[data-md-color-scheme="default"] .md-nav--secondary .md-nav__title {
  color: #1c54b2;
}

[data-md-color-scheme="default"] .md-nav--secondary .md-nav__link {
  color: #3760bf;
}

[data-md-color-scheme="default"] .md-nav--secondary .md-nav__link:hover {
  color: #9854cb;
}

[data-md-color-scheme="default"] .md-nav--secondary .md-nav__link--active {
  color: #2e7de9;
}

/* Mode Sombre - CORRIGÉ : Tout en même couleur */
[data-md-color-scheme="slate"] .md-nav--secondary .md-nav__title {
  color: #a9b1d6 !important;  /* Même couleur que les liens */
  font-weight: 600;
}

[data-md-color-scheme="slate"] .md-nav--secondary .md-nav__link {
  color: #a9b1d6;
}

[data-md-color-scheme="slate"] .md-nav--secondary .md-nav__link:hover {
  color: #7aa2f7;
}

[data-md-color-scheme="slate"] .md-nav--secondary .md-nav__link--active {
  color: #bb9af7 !important;
}

/* ==========================================================================
   5. HERO SECTION
   ========================================================================== */
.hero {
  text-align: center;
  padding: 3rem 1rem;
  margin-bottom: 2rem;
  border-radius: 1rem;
}

.hero h1 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.hero p {
  font-size: 1.1rem;
  opacity: 0.9;
  max-width: 600px;
  margin: 0 auto 1.5rem;
}

/* Hero - Mode Clair */
[data-md-color-scheme="default"] .hero {
  background: linear-gradient(135deg, #2e7de9 0%, #1c54b2 100%);
  border: 1px solid #1c54b2;
  box-shadow: 0 20px 50px rgba(28, 84, 178, 0.4), 0 10px 20px rgba(0, 0, 0, 0.2);
  color: white;
}

[data-md-color-scheme="default"] .hero h1 {
  color: white;
}

[data-md-color-scheme="default"] .hero strong {
  color: #c4b5fd;
}

/* Hero - Mode Sombre */
[data-md-color-scheme="slate"] .hero {
  background: linear-gradient(135deg, #24283b 0%, #1f2335 50%, #1a1b26 100%);
  border: 1px solid #292e42;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  color: #c0caf5;
}

[data-md-color-scheme="slate"] .hero h1 {
  color: #c0caf5;
}

[data-md-color-scheme="slate"] .hero strong {
  color: #bb9af7;
}

/* ==========================================================================
   6. BOUTONS
   ========================================================================== */
.md-button {
  margin: 0.5rem;
  padding: 0.6rem 1.5rem;
  font-weight: 600;
  border-radius: 50px !important;
  transition: all 0.2s ease;
}

/* Boutons Hero - Mode Clair */
[data-md-color-scheme="default"] .hero .md-button--primary {
  background-color: #ffffff !important;
  border-color: #ffffff !important;
  color: #2e7de9 !important;
}

[data-md-color-scheme="default"] .hero .md-button--primary:hover {
  background-color: #f0f0f0 !important;
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(255, 255, 255, 0.4);
}

[data-md-color-scheme="default"] .hero .md-button:not(.md-button--primary) {
  background-color: rgba(255, 255, 255, 0.25) !important;
  color: white !important;
  border: 2px solid white !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

[data-md-color-scheme="default"] .hero .md-button:not(.md-button--primary):hover {
  background-color: white !important;
  color: #2e7de9 !important;
  border-color: white !important;
}

/* Boutons hors Hero - Mode Clair */
[data-md-color-scheme="default"] .md-content .md-button--primary {
  background-color: #2e7de9 !important;
  border-color: #2e7de9 !important;
  color: white !important;
}

[data-md-color-scheme="default"] .md-content .md-button--primary:hover {
  background-color: #1c54b2 !important;
  border-color: #1c54b2 !important;
}

[data-md-color-scheme="default"] .md-content .md-button:not(.md-button--primary) {
  background-color: transparent !important;
  color: #2e7de9 !important;
  border: 2px solid #2e7de9 !important;
}

[data-md-color-scheme="default"] .md-content .md-button:not(.md-button--primary):hover {
  background-color: #2e7de9 !important;
  color: white !important;
}

/* Boutons - Mode Sombre */
[data-md-color-scheme="slate"] .md-button--primary {
  background-color: #7aa2f7 !important;
  border-color: #7aa2f7 !important;
  color: #1a1b26 !important;
}

[data-md-color-scheme="slate"] .md-button--primary:hover {
  background-color: #89b4fa !important;
  border-color: #89b4fa !important;
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(122, 162, 247, 0.4);
}

[data-md-color-scheme="slate"] .md-button:not(.md-button--primary) {
  border-color: rgba(255, 255, 255, 0.5) !important;
  color: rgba(255, 255, 255, 0.9) !important;
}

[data-md-color-scheme="slate"] .md-button:not(.md-button--primary):hover {
  background-color: rgba(255, 255, 255, 0.1) !important;
  border-color: rgba(255, 255, 255, 0.8) !important;
}

/* ==========================================================================
   7. LIENS & NAVIGATION
   ========================================================================== */
/* Liens - Mode Clair */
[data-md-color-scheme="default"] .md-typeset a:not(.md-button) {
  color: #2e7de9;
}

[data-md-color-scheme="default"] .md-typeset a:not(.md-button):hover {
  color: #9854cb !important;
  text-decoration: none !important;
}

/* Liens - Mode Sombre */
[data-md-color-scheme="slate"] .md-typeset a:not(.md-button) {
  color: #7aa2f7;
}

[data-md-color-scheme="slate"] .md-typeset a:not(.md-button):hover {
  color: #bb9af7 !important;
}

/* Navigation Sidebar active */
[data-md-color-scheme="default"] .md-nav__link--active {
  color: #2e7de9 !important;
  font-weight: 600;
}

[data-md-color-scheme="slate"] .md-nav__link--active {
  color: #bb9af7 !important;
  font-weight: 600;
}

/* Navigation hover */
[data-md-color-scheme="default"] .md-nav__link:hover {
  color: #9854cb !important;
}

[data-md-color-scheme="slate"] .md-nav__link:hover {
  color: #7aa2f7 !important;
}

/* Header icons hover */
[data-md-color-scheme="default"] .md-header__button:hover {
  color: #9854cb !important;
}

/* ==========================================================================
   8. CARDS
   ========================================================================== */
.grid.cards > ul > li {
  transition: all 0.2s ease;
  border-radius: 0.75rem;
}

.grid.cards .lg {
  font-size: 2rem;
}

.grid.cards .middle {
  vertical-align: middle;
}

/* Cards - Mode Clair */
[data-md-color-scheme="default"] .grid.cards > ul > li {
  background-color: #ffffff;
  border-left: 3px solid #9854cb;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

[data-md-color-scheme="default"] .grid.cards > ul > li:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
}

[data-md-color-scheme="default"] .grid.cards .lg {
  color: #2e7de9;
}

/* Cards - Mode Sombre */
[data-md-color-scheme="slate"] .grid.cards > ul > li {
  background-color: #1f2335;
  border: 1px solid #292e42;
  border-left: 3px solid #7aa2f7;
}

[data-md-color-scheme="slate"] .grid.cards > ul > li:hover {
  transform: translateY(-4px);
  border-color: #3b4261;
  border-left-color: #bb9af7;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.4);
}

[data-md-color-scheme="slate"] .grid.cards .lg {
  color: #7aa2f7;
}

/* ==========================================================================
   9. TABLES
   ========================================================================== */
.md-typeset table:not([class]) {
  border-radius: 0.75rem;
  overflow: hidden;
}

/* Tables - Mode Clair */
[data-md-color-scheme="default"] .md-typeset table:not([class]) {
  background-color: white;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

[data-md-color-scheme="default"] .md-typeset table:not([class]) th {
  background-color: #2e7de9;
  color: white;
}

/* Tables - Mode Sombre */
[data-md-color-scheme="slate"] .md-typeset table:not([class]) {
  background-color: #1f2335;
  border: 1px solid #292e42;
}

[data-md-color-scheme="slate"] .md-typeset table:not([class]) th {
  background-color: #24283b;
  color: #c0caf5;
  border-bottom: 1px solid #292e42;
}

[data-md-color-scheme="slate"] .md-typeset table:not([class]) td {
  border-color: #292e42;
}

[data-md-color-scheme="slate"] .md-typeset table:not([class]) tr:hover {
  background-color: #24283b;
}

/* ==========================================================================
   10. CODE BLOCKS
   ========================================================================== */
.highlight {
  border-radius: 0.75rem;
}

[data-md-color-scheme="slate"] .highlight {
  border: 1px solid #292e42;
}

.md-typeset .highlight code {
  font-size: 0.85rem;
}

/* ==========================================================================
   11. ADMONITIONS
   ========================================================================== */
.md-typeset .admonition {
  border-radius: 0.75rem;
}

[data-md-color-scheme="default"] .md-typeset .admonition {
  background-color: #f5f5f7;
}

[data-md-color-scheme="slate"] .md-typeset .admonition {
  background-color: #1f2335;
  border-color: #292e42;
}

[data-md-color-scheme="slate"] .md-typeset .admonition.tip {
  border-left-color: #9ece6a;
}

[data-md-color-scheme="slate"] .md-typeset .admonition.info {
  border-left-color: #7aa2f7;
}

[data-md-color-scheme="slate"] .md-typeset .admonition.warning {
  border-left-color: #e0af68;
}

/* ==========================================================================
   12. SCROLLBAR (Mode Sombre)
   ========================================================================== */
[data-md-color-scheme="slate"] ::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

[data-md-color-scheme="slate"] ::-webkit-scrollbar-track {
  background: #1a1b26;
}

[data-md-color-scheme="slate"] ::-webkit-scrollbar-thumb {
  background: #292e42;
  border-radius: 4px;
}

[data-md-color-scheme="slate"] ::-webkit-scrollbar-thumb:hover {
  background: #3b4261;
}

/* ==========================================================================
   13. SELECTION
   ========================================================================== */
[data-md-color-scheme="slate"] ::selection {
  background-color: #364a82;
  color: #c0caf5;
}

[data-md-color-scheme="default"] ::selection {
  background-color: #2e7de9;
  color: white;
}

/* ==========================================================================
   14. UTILITAIRES
   ========================================================================== */
.center {
  text-align: center;
}

/* ==========================================================================
   15. RESPONSIVE
   ========================================================================== */
@media screen and (max-width: 76.25em) {
  .hero {
    padding: 2rem 1rem;
  }
  
  .hero h1 {
    font-size: 2rem;
  }
}

@media screen and (max-width: 44.9375em) {
  .hero h1 {
    font-size: 1.75rem;
  }
  
  .hero p {
    font-size: 1rem;
  }
}

/* ==========================================================================
   16. ANIMATIONS
   ========================================================================== */
.md-content {
  animation: fadeIn 0.3s ease-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ==========================================================================
   17. PRINT
   ========================================================================== */
@media print {
  .hero {
    background: #f5f5f5 !important;
    color: #333 !important;
    box-shadow: none;
  }
}

/* ==========================================================================
   18. BOUTON COPIER CODE - CORRIGÉ
   ========================================================================== */
/* Mode Clair */
[data-md-color-scheme="default"] .md-clipboard {
  color: #3760bf !important;
}

[data-md-color-scheme="default"] .md-clipboard:hover {
  color: #2e7de9 !important;
}

/* Message "Copié" - Mode Clair */
[data-md-color-scheme="default"] .md-typeset .md-clipboard::after {
  background-color: #2e7de9 !important;
  color: white !important;
}

/* Tooltip / Notification de copie */
[data-md-color-scheme="default"] .md-tooltip {
  background-color: #1c54b2 !important;
  color: white !important;
}

/* Mode Sombre */
[data-md-color-scheme="slate"] .md-clipboard {
  color: #a9b1d6 !important;
}

[data-md-color-scheme="slate"] .md-clipboard:hover {
  color: #7aa2f7 !important;
}

/* ==========================================================================
   19. NOTIFICATION "COPIÉ" - CORRIGÉ
   ========================================================================== */
/* Mode Clair - Notification clipboard */
[data-md-color-scheme="default"] .md-clipboard--inline::after,
[data-md-color-scheme="default"] .md-typeset .md-clipboard--inline::after {
  background-color: #1c54b2 !important;
  color: white !important;
}

/* Snackbar / Toast notification */
[data-md-color-scheme="default"] .md-snackbar {
  background-color: #1c54b2 !important;
  color: white !important;
}

[data-md-color-scheme="default"] .md-snackbar__inner {
  background-color: #1c54b2 !important;
  color: white !important;
}

/* Alternative - forcer sur tous les éléments clipboard */
[data-md-color-scheme="default"] [data-md-component="clipboard"] + .md-snackbar,
[data-md-color-scheme="default"] .md-dialog,
[data-md-color-scheme="default"] .md-dialog__inner {
  background-color: #1c54b2 !important;
  color: white !important;
}
