/* style.css — styles AlphaDesk (dashboard + portfolios + news) */
/* Ce fichier ne définit PAS la nav (voir base.css)             */

/* ============================================================ */
/* Identité visuelle AlphaDesk : fond sombre + texte clair       */
/* On cible les pages qui chargent style.css en remontant le     */
/* style sur body, mais avec une portée volontairement large     */
/* pour ne pas casser l'existant.                                */
/* ============================================================ */
body {
    background-color: #0f1117;
    color: #e0e0e0;
}
/* conteneur principal */
.container {
    max-width: 1100px;
    margin: 40px auto;
    padding: 0 24px;
}

h1 {
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 32px;
    color: #ffffff;
}

h2 {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 16px;
    margin-top: 40px;
    color: #a0a0b0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* tableau des scores */
table {
    width: 100%;
    border-collapse: collapse;
    background-color: #1a1d2e;
    border-radius: 8px;
    overflow: hidden;
}

thead {
    background-color: #222538;
}

th {
    padding: 12px 16px;
    text-align: left;
    font-size: 13px;
    color: #6b6f8a;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

td {
    padding: 12px 16px;
    font-size: 14px;
    border-top: 1px solid #2a2d3e;
}

tr:hover {
    background-color: #1f2235;
}

/* cartes analyses LLM */
.analysis-card {
    background-color: #1a1d2e;
    border-radius: 8px;
    padding: 20px 24px;
    margin-bottom: 16px;
    border-left: 3px solid #4f8ef7;
}

.analysis-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.analysis-header strong {
    font-size: 16px;
    color: #ffffff;
}

.badge {
    background-color: #2a2d3e;
    color: #4f8ef7;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 12px;
}

.analysis-card p {
    font-size: 14px;
    color: #c0c0d0;
    line-height: 1.7;
}
/* formulaire de saisie */
.form-card {
    background-color: #1a1d2e;
    border-radius: 8px;
    padding: 24px;
    margin-bottom: 32px;
}

.form-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 16px;
}

.form-row label {
    font-size: 13px;
    color: #6b6f8a;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.form-row input,
.form-row select {
    background-color: #222538;
    border: 1px solid #2a2d3e;
    border-radius: 6px;
    padding: 10px 12px;
    color: #e0e0e0;
    font-size: 14px;
    outline: none;
}

.form-row input:focus,
.form-row select:focus {
    border-color: #4f8ef7;
}

/* boutons */
.btn {
    background-color: #4f8ef7;
    color: #ffffff;
    border: none;
    border-radius: 6px;
    padding: 10px 20px;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.2s;
}

.btn:hover {
    background-color: #3a7de0;
}

.btn-danger {
    color: #f44336;
    font-size: 13px;
    text-decoration: none;
}

.btn-danger:hover {
    text-decoration: underline;
}

/* message vide */
.empty-message {
    color: #6b6f8a;
    font-size: 14px;
    padding: 24px 0;
}

/* autocomplétion ticker */
.ticker-suggestions {
    display: none;
    position: absolute;
    top: 100%;
    background-color: #222538;
    border: 1px solid #2a2d3e;
    border-radius: 6px;
    z-index: 100;
    width: 100%;
    max-height: 200px;
    overflow-y: auto;
}

.ticker-suggestion-item {
    padding: 10px 12px;
    font-size: 13px;
    cursor: pointer;
    color: #e0e0e0;
    border-bottom: 1px solid #2a2d3e;
}

.ticker-suggestion-item:hover {
    background-color: #2a2d3e;
}

.ticker-suggestion-item strong {
    color: #4f8ef7;
}

.ticker-suggestion-item span {
    color: #6b6f8a;
    font-size: 12px;
}

/* position relative pour le conteneur du champ ticker */
.form-row {
    position: relative;
}
/* indicateurs KPI */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 32px;
}

.kpi-card {
    background-color: #1a1d2e;
    border-radius: 8px;
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.kpi-label {
    font-size: 12px;
    color: #6b6f8a;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.kpi-value {
    font-size: 24px;
    font-weight: 500;
    color: #ffffff;
}
/* couleurs des scores */
.score-2 { color: #4caf50; font-weight: 700; }
.score-1 { color: #8bc34a; font-weight: 700; }
.score-0 { color: #a0a0b0; font-weight: 700; }
.score--1 { color: #ff9800; font-weight: 700; }
.score--2 { color: #f44336; font-weight: 700; }
/* grille graphiques */
.charts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 40px;
}

.chart-card {
    background-color: #1a1d2e;
    border-radius: 8px;
    padding: 20px 24px;
}

/* graphique P&L sur toute la largeur */
.chart-wide {
    grid-column: span 2;
}

.chart-card h2 {
    font-size: 14px;
    color: #6b6f8a;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 16px;
    margin-top: 0;
}

/* badges fraîcheur des analyses */
.badge-fresh {
    background-color: #1a3a1a;
    color: #4caf50;
}

.badge-stale {
    background-color: #3a2a1a;
    color: #ff9800;
}

/* onglets */
.tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
}

.tab {
    background-color: #1a1d2e;
    color: #a0a0b0;
    border: 1px solid #2a2d3e;
    border-radius: 6px;
    padding: 8px 20px;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s;
}

.tab.active {
    background-color: #4f8ef7;
    color: #ffffff;
    border-color: #4f8ef7;
}

/* grille formulaire spread */
.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}
/* sélecteur de devise */
.devise-selector {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 24px;
    font-size: 13px;
    color: #6b6f8a;
}

.btn-devise {
    background-color: #1a1d2e;
    color: #a0a0b0;
    border: 1px solid #2a2d3e;
    border-radius: 6px;
    padding: 6px 14px;
    font-size: 13px;
    text-decoration: none;
    transition: all 0.2s;
}

.btn-devise:hover {
    background-color: #2a2d3e;
    color: #ffffff;
}

.btn-devise.active {
    background-color: #4f8ef7;
    color: #ffffff;
    border-color: #4f8ef7;
}
/* message d'erreur */
.error-message {
    background-color: #3a1a1a;
    color: #f44336;
    padding: 16px 20px;
    border-radius: 8px;
    border: 1px solid #5a2a2a;
    margin-bottom: 24px;
}
/* tableau rendements mensuels */
.monthly-table {
    margin-bottom: 32px;
}

.monthly-table th,
.monthly-table td {
    text-align: center;
    font-size: 13px;
}

.monthly-table .empty-cell {
    color: #3a3d4e;
}
/* section hero — en-tête de la page d'accueil */
.hero {
    padding: 40px 32px;
    background-color: #1a1d2e;
    border-radius: 12px;
    margin-bottom: 40px;
    text-align: center;
}

.hero h1 {
    font-size: 42px;
    font-weight: 600;
    color: #4f8ef7;
    margin-bottom: 16px;
}

.hero-subtitle {
    font-size: 16px;
    color: #e0e0e0;
    max-width: 720px;
    margin: 0 auto 16px auto;
    line-height: 1.7;
}

.hero-description {
    font-size: 14px;
    color: #a0a0b0;
    max-width: 720px;
    margin: 0 auto 20px auto;
    line-height: 1.7;
}

.hero-author {
    font-size: 14px;
    color: #6b6f8a;
    padding-top: 20px;
    border-top: 1px solid #2a2d3e;
    max-width: 720px;
    margin: 20px auto 0 auto;
}

.hero-author strong {
    color: #e0e0e0;
}

/* grille des comptes */
.account-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 40px;
}

.account-card {
    background-color: #1a1d2e;
    border-radius: 8px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 20px;
    text-decoration: none;
    transition: all 0.2s;
    border: 1px solid #2a2d3e;
}

.account-card:hover {
    border-color: #4f8ef7;
    transform: translateY(-2px);
}

.account-logo {
    width: 60px;
    height: 60px;
    background-color: #4f8ef7;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
    color: #ffffff;
}

.account-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 6px;
}

.account-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.account-name {
    font-size: 16px;
    font-weight: 500;
    color: #ffffff;
}

.account-desc {
    font-size: 13px;
    color: #6b6f8a;
}

/* horloges des bourses */
.markets-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 40px;
}

.market-card {
    background-color: #1a1d2e;
    border-radius: 8px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
}

.market-status {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

.status-open {
    background-color: #4caf50;
    box-shadow: 0 0 12px rgba(76, 175, 80, 0.5);
}

.status-closed {
    background-color: #f44336;
}

.market-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.market-city {
    font-size: 14px;
    font-weight: 500;
    color: #ffffff;
}

.market-name {
    font-size: 12px;
    color: #6b6f8a;
}

.market-time {
    font-size: 18px;
    font-weight: 500;   
    color: #4f8ef7;
    margin-top: 4px;
}

.market-hours {
    font-size: 11px;
    color: #6b6f8a;
}

/* page news du jour */
.newsletter-card {
    background-color: #1a1d2e;
    border-radius: 8px;
    margin-bottom: 24px;
    overflow: hidden;
    border: 1px solid #2a2d3e;
}

.newsletter-meta {
    padding: 12px 20px;
    background-color: #222538;
    display: flex;
    align-items: center;
    gap: 16px;
    border-bottom: 1px solid #2a2d3e;
}

.newsletter-date {
    font-size: 13px;
    color: #6b6f8a;
}

.newsletter-content {
    padding: 0;
}

/* le contenu HTML de la newsletter contient déjà ses propres styles inline */
.newsletter-content > body {
    background-color: transparent !important;
}

/* ============================================================ */
/* Horloges des bourses                                         */
/* ============================================================ */
.market-clocks {
  margin: 2.5rem 0;
}

.clocks-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-top: 1rem;
}

@media (max-width: 768px) {
  .clocks-grid { grid-template-columns: repeat(2, 1fr); }
}

.clock-card {
  background: #161a23;
  border: 1px solid #252a36;
  border-radius: 12px;
  padding: 1.25rem 0.9rem;   /* padding horizontal légèrement réduit pour Tokyo */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;                /* gap réduit pour compacter */
  transition: border-color .2s ease;
}

.clock-card:hover { border-color: #3a4150; }

.clock-face {
  width: 110px;
  height: 110px;
}

/* Cadran */
.clock-bezel { fill: #0d1017; }
.clock-dial  { fill: #1d2230; }

/* Repères horaires principaux */
.clock-mark-major {
  stroke: #8a93a6;
  stroke-width: 2;
  stroke-linecap: round;
}

/* Aiguilles : on retire transform-origin CSS qui peut entrer en conflit */
/* avec le SVG transform attribute (la rotation se fait via rotate() SVG) */
.hand-hour {
  stroke: #e6e9f0;
  stroke-width: 2.8;
  stroke-linecap: round;
}
.hand-minute {
  stroke: #e6e9f0;
  stroke-width: 1.8;
  stroke-linecap: round;
}
.hand-second {
  stroke: #e94560;
  stroke-width: 1;
  stroke-linecap: round;
}
.clock-center { fill: #e94560; }

/* Bloc info sous l'horloge */
.clock-info {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
}
.clock-city {
  font-weight: 600;
  font-size: 0.95rem;
  color: #e6e9f0;
}
.clock-time {
  font-family: 'Courier New', monospace;
  font-size: 0.85rem;
  color: #8a93a6;
}
/* Nouvelle ligne : horaires d'ouverture de la bourse */
.clock-hours {
  font-family: 'Courier New', monospace;
  font-size: 0.72rem;
  color: #6b7280;
  letter-spacing: 0.3px;
  text-align: center;
}
.market-status {
  font-size: 1.2rem;
  line-height: 1;
}
/* Statut marché : rouge si fermé, vert si ouvert, orange si pause */
.market-status.open    { color: #22c55e; }   /* vert : ouvert */
.market-status.closed  { color: #ef4444; }   /* rouge : fermé */
.market-status.lunch   { color: #f59e0b; }   /* orange : pause */

/* ============================================================ */
/* Cards courtiers                                              */
/* ============================================================ */
.brokers-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  margin-top: 1rem;
}

@media (max-width: 768px) {
  .brokers-grid { grid-template-columns: 1fr; }
}

.broker-card {
  background: #161a23;
  border: 1px solid #252a36;
  border-radius: 12px;
  padding: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  text-decoration: none;
  color: inherit;
  transition: transform .2s ease, border-color .2s ease;
}

.broker-card:hover {
  transform: translateY(-2px);
  border-color: #3a4150;
}

.broker-logo {
  flex-shrink: 0;
  width: 100px;
}
.broker-logo svg { width: 100%; height: auto; display: block; }

.broker-info h3 {
  margin: 0 0 0.25rem 0;
  color: #e6e9f0;
  font-size: 1.05rem;
}
.broker-info p {
  margin: 0;
  color: #8a93a6;
  font-size: 0.85rem;
}
/* ============================================================ */
/* Couleurs sémantiques pour valeurs positives / négatives      */
/* ============================================================ */
.value-positive { color: #22c55e; }   /* vert : performance positive */
.value-negative { color: #ef4444; }   /* rouge : performance négative */

/* ============================================================ */
/* Responsive : breakpoints tablette + mobile                   */
/* Vague 1 : grids principaux                                   */
/* ============================================================ */

/* Tablette (≤ 1024px) */
@media (max-width: 1024px) {
  .kpi-grid     { grid-template-columns: repeat(2, 1fr); }
  .charts-grid  { grid-template-columns: 1fr; }
  .chart-wide   { grid-column: span 1; }
  .account-grid { grid-template-columns: 1fr; }
  .markets-grid { grid-template-columns: repeat(2, 1fr); }
  .form-grid    { grid-template-columns: 1fr; }
}

/* Mobile (≤ 600px) */
@media (max-width: 600px) {
  .container    { padding: 0 16px; margin: 24px auto; }
  .kpi-grid     { grid-template-columns: 1fr; gap: 12px; }
  .markets-grid { grid-template-columns: 1fr; }
  .hero         { padding: 24px 16px; }
  .hero h1      { font-size: 28px; }
  h1            { font-size: 22px; margin-bottom: 20px; }
}

/* Wrapper scrollable pour tableaux larges */
.table-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 32px;
  border-radius: 8px;
}

.table-wrapper table { margin-bottom: 0; }

.monthly-table { min-width: 720px; }     /* 13 colonnes : Année + 12 mois + Total */
.positions-table { min-width: 600px; }   /* à ajuster selon le nombre de colonnes */

/* ============================================================ */
/* Wrapper scrollable horizontal pour tableaux larges           */
/* ============================================================ */
.table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;   /* scroll fluide iOS */
    margin-bottom: 32px;
    border-radius: 8px;
}

/* la table garde son style mais cède son margin au wrapper */
.table-wrapper > table {
    margin-bottom: 0;
}

/* largeurs minimales pour que les colonnes ne s'écrasent pas */
.monthly-table   { min-width: 720px; }   /* Année + 12 mois + Total */
.positions-table { min-width: 600px; }   /* 5 ou 6 colonnes */

/* ============================================================ */
/* Card outil — Stratégies options                              */
/* CTA unique pleine largeur, cohérente avec les broker-cards   */
/* ============================================================ */
.strategy-section {
    margin-top: 2rem;
}

.strategy-card {
    background: #161a23;
    border: 1px solid #252a36;
    border-radius: 12px;
    padding: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1.25rem;
    text-decoration: none;
    color: inherit;
    transition: transform .2s ease, border-color .2s ease;
    margin-top: 1rem;
}

.strategy-card:hover {
    transform: translateY(-2px);
    border-color: #4f8ef7;
}

.strategy-icon {
    font-size: 2rem;
    flex-shrink: 0;
    width: 60px;
    text-align: center;
}

.strategy-info {
    flex-grow: 1;
}

.strategy-info h3 {
    margin: 0 0 0.25rem 0;
    color: #e6e9f0;
    font-size: 1.05rem;
}

.strategy-info p {
    margin: 0;
    color: #8a93a6;
    font-size: 0.85rem;
}

.strategy-arrow {
    font-size: 1.5rem;
    color: #4f8ef7;
    flex-shrink: 0;
    transition: transform .2s ease;
}

.strategy-card:hover .strategy-arrow {
    transform: translateX(4px);
}