:root {
    --bg: #121212; --panel: #1e1e24; --border: #333;
    --text: #e0e0e0; --accent: #3498db; --valid: #2ecc71;
    --danger: #e74c3c; --warning: #f1c40f; --highlight: #9b59b6;
    --scroll-track: #1a1a1a; --scroll-thumb: #444;
    --watermark-pattern: url("img/MEKADOTO_LINESOLO_pattern.svg");
    --watermark-size: 180px 180px;
}
body { margin: 0; padding: 0; background: var(--bg); color: var(--text); font-family: 'Segoe UI', sans-serif; overflow: hidden; height: 100vh; }

/* YEAR PROGRESS */
#year-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: #111;
    z-index: 3000;
}
#year-progress-bar {
    height: 100%;
    width: 0%;
    background: var(--accent);
    transition: width 0.15s linear;
}

/* LAYOUT HORIZONTAL FLEX (Mobile Friendly) */
#game-container {
    display: flex;
    flex-direction: row;
    height: 100vh;
    overflow-x: auto; /* Scroll horizontal global */
    overflow-y: hidden;
    scroll-behavior: smooth;
    gap: 1px;
    background-color: var(--border);
    background-image: url("img/MEKADOTO_LINESOLO.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 100% auto;
}

/* COLONNES */
.col {
    min-width: 300px; /* Largeur fixe minimale pour lisibilité mobile */
    max-width: 320px;
    background-color: var(--bg);
    background-image: var(--watermark-pattern);
    background-size: var(--watermark-size);
    background-repeat: repeat;
    background-position: center;
    display: flex;
    flex-direction: column;
    padding: 10px;
    border-right: 1px solid var(--border);
    flex-shrink: 0; /* Empêche les colonnes de s'écraser */
    height: 100vh; /* Force la hauteur de l'écran */
    overflow-y: hidden; /* Empêche la colonne elle-même de scroller, c'est le contenu qui le fera */
    transition: min-width 0.3s ease, max-width 0.3s ease, background 0.3s;
    position: relative;
}

/* CUSTOM SCROLLBARS (Webkit) */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--scroll-track); }
::-webkit-scrollbar-thumb { background: var(--scroll-thumb); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: #666; }

/* Conteneurs internes scrollables (Y) */
.scroll-box { 
    overflow-y: auto; /* Active le scroll vertical */
    padding-right: 5px; 
    flex: 1; /* Prend toute la hauteur disponible dans la colonne */
    min-height: 0; /* CRUCIAL pour que flexbox autorise le rétrécissement et le scroll */
}
.full-height { flex: 1; } /* Prend toute la place restante */

/* HEADER & ELEMENTS */
.header-box { background: var(--panel); padding: 15px; border-radius: 8px; border-bottom: 2px solid var(--accent); margin-bottom: 10px; }
h1 { margin: 0; font-size: 1.2rem; text-transform: uppercase; color: var(--accent); letter-spacing: 2px; }
.header-title-row { display:flex; align-items:center; justify-content:space-between; }
.header-title { display:flex; align-items:center; gap:6px; }
.options-wrap { position:relative; display:flex; align-items:center; }
.options-toggle { background:#1a1a1a; border:1px solid #333; color:#aaa; width:18px; height:18px; border-radius:4px; padding:0; font-size:0.7rem; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.options-toggle:hover { color:#fff; border-color:#555; }
.options-menu { position:absolute; top:26px; right:0; background:#1e1e24; border:1px solid #333; border-radius:6px; padding:6px; min-width:170px; box-shadow:0 12px 24px rgba(0,0,0,0.5); display:flex; flex-direction:column; gap:4px; z-index:20; }
.options-item { background:#2a2a2a; border:1px solid #444; color:#fff; padding:6px 8px; border-radius:4px; font-size:0.8rem; text-align:left; cursor:pointer; display:block; width:100%; box-sizing:border-box; font-family:inherit; line-height:1.2; }
.options-item:hover { background:#333; }
a.options-item { text-decoration:none; color:#fff; }
a.options-item:visited { color:#fff; }
.options-sep { height:1px; background:#333; margin:4px 2px; }
.stats-row { display: flex; justify-content: space-between; font-size: 1.4rem; font-weight: bold; margin-top: 10px; }
.stat-block { display: flex; flex-direction: column; gap: 2px; }
.stat-label { font-size: 0.65rem; text-transform: uppercase; color: #777; letter-spacing: 0.5px; font-weight: normal; }
.stats-row-sm { display: flex; justify-content: space-between; font-size: 0.8rem; color: #888; margin-top: 5px; }
.section-title { font-size: 0.8rem; text-transform: uppercase; color: #666; border-bottom: 1px solid #333; padding-bottom: 2px; margin-top: 15px; margin-bottom: 10px; font-weight: bold; }

/* CARTES */
.project-card, .email-item, .contact-item, .employee-card, .catalogue-card, .stock-card, .partner-card {
    background: var(--panel); border: 1px solid var(--border); border-radius: 6px; padding: 10px; margin-bottom: 8px; position: relative;
}

.staff-card { display:flex; justify-content:space-between; gap:10px; align-items:flex-start; }
.staff-main { display:flex; flex-direction:column; gap:2px; min-width:0; }
.staff-name { font-weight:bold; color:#fff; }
.staff-meta { font-size:0.7rem; color:#aaa; margin-top:2px; word-break:break-word; }
.staff-meta.empty { color:#666; font-style:italic; }
.staff-skills { font-size:0.7rem; color:#f1c40f; margin-top:2px; word-break:break-word; }
.staff-skills.empty { color:#666; font-style:italic; }
.staff-cost { font-size:0.75rem; color:#aaa; white-space:nowrap; }
.staff-info { display:flex; flex-direction:column; gap:4px; min-width:0; }
.staff-spec { font-size:0.6rem; text-transform:uppercase; letter-spacing:0.4px; color:#8a8a8a; }
.staff-stat { display:flex; flex-direction:column; align-items:flex-end; gap:6px; }
.staff-badges { display:flex; flex-wrap:wrap; gap:4px; margin-top:4px; }
.badge { display:inline-flex; align-items:center; gap:4px; padding:2px 6px; border-radius:999px; font-size:0.65rem; border:1px solid #333; background:#1a1a1a; color:#bbb; }
.badge-label { font-size:0.55rem; text-transform:uppercase; letter-spacing:0.3px; color:#777; }
.badge-value { font-weight:bold; color:#eee; }
.badge-stat { background:#16202a; border-color:#2c3e50; }
.badge-skill { background:#181818; border-color:#333; color:#f1c40f; }
.badge-skill.lvl-1 { color:#bdc3c7; }
.badge-skill.lvl-2 { color:#95a5a6; }
.badge-skill.lvl-3 { color:#f1c40f; }
.badge-skill.lvl-4 { color:#f39c12; }
.badge-skill.lvl-5 { color:#e67e22; }
.badge-empty { color:#666; border-style:dashed; }
.staff-impact { display:flex; flex-wrap:wrap; gap:4px; margin-top:4px; }
.impact-item { display:inline-flex; align-items:center; gap:4px; padding:2px 6px; border-radius:6px; font-size:0.6rem; border:1px dashed #333; background:#151515; color:#aaa; }
.impact-label { font-size:0.55rem; text-transform:uppercase; letter-spacing:0.3px; color:#777; }
.impact-value { font-weight:bold; color:#e0e0e0; }

.profile-card { background: #1b1b1f; border: 1px solid #333; border-radius: 8px; padding: 12px; }
.profile-header { display:flex; justify-content:space-between; align-items:flex-start; gap:8px; margin-bottom:8px; }
.profile-name { font-weight:bold; color:#fff; font-size:1rem; }
.profile-cost { font-size:0.85rem; color:#aaa; }
.profile-section { margin-top:10px; }
.profile-section-title { font-size:0.6rem; text-transform:uppercase; letter-spacing:0.4px; color:#888; margin-bottom:4px; }
.profile-actions { display:flex; gap:6px; margin-top:12px; }
.btn-recruit, .btn-discard, .btn-back { flex:1; border:1px solid #444; background:#2a2a2a; color:#fff; padding:6px; border-radius:4px; }
.btn-recruit { background: var(--valid); color:#000; border:none; font-weight:bold; }
.btn-discard { background: var(--danger); border:none; }
.btn-back { background:#333; border:1px solid #444; }

/* SPECIFIQUE */
#history-log { height: 200px; font-family: monospace; font-size: 0.75rem; color: #aaa; background: #000; padding: 5px; border-radius: 4px; border: 1px solid #333; }
.catalogue-card { border-left: 3px solid var(--valid); }
.catalogue-card.attn-high { border-left-color: var(--danger); box-shadow: 0 0 0 1px rgba(231, 76, 60, 0.15); }
.catalogue-card.attn-mid { border-left-color: var(--warning); box-shadow: 0 0 0 1px rgba(241, 196, 15, 0.12); }
.catalogue-card.attn-low { border-left-color: var(--accent); box-shadow: 0 0 0 1px rgba(52, 152, 219, 0.12); }
.stock-card { border-left: 3px solid var(--warning); font-size: 0.8rem; }
.stock-header { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.stock-title { font-weight: bold; color: #fff; }
.stock-tag { font-size: 0.65rem; padding: 2px 6px; border-radius: 10px; background: #2a2a2a; color: #bbb; border: 1px solid #333; white-space: nowrap; }
.stock-tag.sale { background: rgba(241, 196, 15, 0.12); color: #f1c40f; border-color: #5c4b00; }
.stock-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 10px; margin-top: 6px; }
.stock-cell { display: flex; flex-direction: column; gap: 2px; }
.stock-label-sm { font-size: 0.65rem; color: #777; text-transform: uppercase; letter-spacing: 0.3px; }
.partner-card { border-left: 3px solid #9b59b6; font-size: 0.8rem; }
.partner-card.late { border-left-color: var(--danger); }
.partner-meta { font-size: 0.7rem; color: #aaa; display: flex; justify-content: space-between; }
.stock-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; margin-top: 8px; }
.partner-actions { display: flex; flex-direction: column; gap: 4px; margin-top: 6px; }
.hype-container { background: #000; height: 6px; border-radius: 3px; overflow: hidden; margin: 5px 0; }
.hype-bar { height: 100%; transition: width 0.5s; }

/* BUTTONS & UI */
button { cursor: pointer; }
.btn-refine, .btn-job-hire, .btn-upgrade, .btn-event { width: 100%; border: 1px solid #444; background: #2a2a2a; color: #fff; padding: 6px; border-radius: 4px; margin-top: 2px; }
.btn-refine.btn-possible { border-color: var(--valid); box-shadow: 0 0 0 1px var(--valid) inset; background: rgba(46, 204, 113, 0.12); }
.refine-title { font-weight: bold; }
.refine-meta { display: flex; justify-content: space-between; font-size: 0.65rem; color: #aaa; margin-top: 4px; gap: 6px; }
.gain-tag { font-size: 0.7rem; color: var(--valid); }
.btn-valid { background: var(--valid); border: none; color: #000; font-weight: bold; padding: 5px 10px; border-radius: 4px; }
.btn-trash { background: var(--danger); border: none; color: #fff; padding: 5px 10px; border-radius: 4px; }
.btn-pilon { background: #444; color: #fff; border: none; padding: 2px 6px; border-radius: 3px; font-size: 0.7rem; }
.btn-ship { background: var(--accent); color: #fff; width: 100%; border: none; padding: 8px; border-radius: 4px; font-weight: bold; }
.btn-ship:disabled { background: #444; color: #888; }

/* MODAL */
.hidden { display: none !important; }
#modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.85); z-index: 2000; display: flex; justify-content: center; align-items: center; }
#modal-box { background: #1e1e24; border: 1px solid #555; width: 90%; max-width: 500px; max-height: 80vh; display: flex; flex-direction: column; border-radius: 8px; }
.modal-header { padding: 15px; border-bottom: 1px solid #333; display: flex; justify-content: space-between; background: #252525; }
.modal-content { overflow-y: auto; padding: 10px; }
.staff-row { display: grid; grid-template-columns: 1fr 120px; gap: 10px; align-items: start; background: #2c3e50; margin-bottom: 5px; padding: 10px; border-radius: 4px; }
.staff-row.busy { opacity: 0.5; pointer-events: none; }

/* COMPANY NAME */
.company-name { font-size: 0.7rem; color: #aaa; letter-spacing: 1px; text-transform: uppercase; margin-top: 4px; }

/* ANIMATIONS */
.floater { position: absolute; font-weight: bold; pointer-events: none; animation: floatUp 1s forwards; z-index: 9999; text-shadow: 1px 1px 0 #000; }
@keyframes floatUp { 0% { transform: translateY(0); opacity: 1; } 100% { transform: translateY(-30px); opacity: 0; } }


/* NOUVEAUX BOUTONS STATUTS */
.btn-status-0 { background: transparent; border: 1px solid var(--accent); color: var(--accent); }
.btn-status-1 { background: transparent; border: 1px solid var(--warning); color: var(--warning); }
.btn-status-2 { background: var(--danger); border: 1px solid var(--danger); color: #fff; }

.btn-logistics { width: 100%; padding: 8px; background: var(--panel); border: 1px dashed #666; color: #aaa; margin-bottom: 10px; cursor: pointer; }
.btn-logistics.active { border-style: solid; border-color: var(--valid); color: var(--valid); background: #1a2e22; }

/* Indicateur livraison bloquée */
.delivery-blocked-box { border: 2px solid var(--danger); background: #3c1f1f; padding: 10px; border-radius: 4px; margin-top: 5px; animation: pulse 1s infinite; }

/* --- GESTION COLONNES & NOTIFICATIONS --- */

/* État plié (Collapsed) */
.col.collapsed {
    min-width: 50px !important;
    max-width: 50px !important;
    padding: 0;
    cursor: pointer;
    background: #181818;
}

.col.collapsed:hover {
    background: #222;
}

/* Cacher le contenu quand plié, sauf le titre */
.col.collapsed > *:not(.section-title-header) {
    display: none !important;
}

/* Style du header de colonne */
.section-title-header {
    font-size: 0.9rem;
    text-transform: uppercase;
    color: #888;
    border-bottom: 1px solid #333;
    padding: 10px;
    margin-bottom: 10px;
    font-weight: bold;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    white-space: nowrap;
}

/* Rotation du titre quand plié */
.col.collapsed .section-title-header {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    height: 100%;
    width: 100%;
    border-bottom: none;
    border-left: 1px solid #333;
    margin: 0;
    justify-content: center;
    gap: 10px;
}

/* La pastille de notification (Point rouge) */
.notify-badge {
    display: inline-block;
    width: 10px;
    height: 10px;
    background-color: var(--danger);
    border-radius: 50%;
    box-shadow: 0 0 5px var(--danger);
    opacity: 0;
    transition: opacity 0.3s;
}

.notify-badge.active {
    opacity: 1;
    animation: pulseRed 1s infinite;
}

@keyframes pulseRed {
    0% { transform: scale(1); opacity: 0.8; }
    50% { transform: scale(1.4); opacity: 1; }
    100% { transform: scale(1); opacity: 0.8; }
}

/* Forcer la 1ère colonne (Dashboard) à rester ouverte */
#col-dashboard.collapsed {
    min-width: 300px !important;
    max-width: 320px !important;
    padding: 10px;
    cursor: default;
}
#col-dashboard.collapsed > * { display: flex !important; } /* Restore flex for dashboard */
#col-dashboard .section-title-header { cursor: default; }

/* ANIMATIONS & UI STATES (moved from script) */
@keyframes shake {
    0% { transform: translateX(0); color: #e74c3c; }
    25% { transform: translateX(-5px); }
    50% { transform: translateX(5px); }
    75% { transform: translateX(-5px); }
    100% { transform: translateX(0); }
}
@keyframes flashGold {
    0% { border-color: #444; box-shadow: none; }
    50% { border-color: #f1c40f; box-shadow: 0 0 8px rgba(241, 196, 15, 0.4); }
    100% { border-color: #444; box-shadow: none; }
}
.anim-shake { animation: shake 0.4s ease-in-out; }
.anim-flash-gold { animation: flashGold 0.5s ease-in-out; }
.btn-cant-afford { opacity: 0.5; filter: grayscale(0.5); }

/* CATALOGUE */
.cat-stock-bar-bg { background: #111; height: 8px; border-radius: 4px; overflow: hidden; margin-top: 5px; border: 1px solid #333; position: relative; }
.cat-stock-bar-fill { height: 100%; transition: width 0.5s ease; }
.cat-expander { cursor: pointer; display: flex; justify-content: space-between; align-items: center; padding: 5px; }
.cat-expander:hover { background: #2a2a2a; }
.catalogue-empty { color: #666; text-align: center; padding: 12px; }

/* FILTERS */
.filter-bar { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.btn-filter { background: #1a1a1a; border: 1px solid #333; color: #aaa; padding: 4px 6px; font-size: 0.7rem; border-radius: 4px; }
.btn-filter.active { color: #fff; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; background: rgba(52, 152, 219, 0.15); }
.filter-count { background: #333; color: #fff; padding: 0 4px; border-radius: 6px; font-size: 0.65rem; margin-left: 4px; }

/* RANGE */
.range-track { position: relative; height: 10px; background: #000; border-radius: 5px; margin: 10px 0; border: 1px solid #333; overflow: hidden; }
.range-fill { position: absolute; height: 100%; top: 0; background: rgba(255,255,255,0.2); transition: all 0.3s; }
.range-val-text { font-size: 0.7rem; color: #aaa; display: flex; justify-content: space-between; }

/* REALIZATION TASKS */
.job-container { display: grid; grid-template-columns: 90px 1fr; gap: 6px; align-items: center; margin: 6px 0; }
.job-label { font-size: 0.75rem; color: #ddd; }
.job-actions { display: flex; align-items: center; gap: 6px; font-size: 0.75rem; color: #aaa; }
.job-task-btn { flex: 1; margin-top: 0; text-align: left; position: relative; overflow: hidden; }
.job-task-title { font-size: 0.75rem; font-weight: bold; display: block; }
.job-task-meta { font-size: 0.65rem; color: #ddd; margin-top: 4px; }

/* MANAGERS */
.manager-active-box { border: 1px solid var(--valid); background: rgba(46, 204, 113, 0.1); padding: 5px; border-radius: 4px; margin-bottom: 5px; font-size: 0.8rem; display: flex; justify-content: space-between; align-items: center; }

/* SKILL GRID */
.skills-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5px; margin: 10px 0; }
.skill-box { background: #2c3e50; border: 1px solid #444; border-radius: 4px; padding: 5px; font-size: 0.8rem; display: flex; flex-direction: column; justify-content: center; }
.skill-box-empty { background: #1a1a1a; color: #555; border: 1px dashed #333; align-items: center; }
.skill-slots { display:flex; flex-direction:column; gap:6px; margin-top:4px; }
.skill-slots.compact { gap:4px; }
.skill-slot { background:#1a1a1a; border:1px solid #333; border-radius:6px; padding:4px 6px; }
.skill-slot.compact { padding:3px 5px; }
.skill-slot.empty { background:#141414; border-style:dashed; color:#666; }
.skill-slot-header { display:flex; justify-content:space-between; align-items:center; gap:6px; font-size:0.65rem; color:#aaa; }
.skill-slot-name { font-weight:bold; color:#fff; }
.skill-slot.empty .skill-slot-name { color:#666; font-weight:normal; }
.skill-slot-level { font-size:0.6rem; color:#999; }
.skill-slot-bar { height:6px; background:#111; border:1px solid #333; border-radius:4px; overflow:hidden; margin-top:4px; }
.skill-slot-bar-fill { height:100%; background:var(--accent); }
.skill-bar-track { width: 100%; height: 4px; background: #111; margin-top: 4px; border-radius: 2px; overflow: hidden; }
.skill-bar-fill { height: 100%; background: #f1c40f; transition: width 0.3s; }

/* ONBOARDING */
.onboarding-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(5, 5, 5, 0.92); z-index: 3500; display: flex; align-items: center; justify-content: center; padding: 20px; }
.onboarding-card { width: 100%; max-width: 520px; background: #121212; border: 1px solid #333; border-radius: 10px; padding: 20px; box-shadow: 0 0 30px rgba(0,0,0,0.6); display: flex; flex-direction: column; gap: 12px; }
.onboarding-title { font-size: 1.2rem; font-weight: bold; color: var(--accent); text-transform: uppercase; letter-spacing: 2px; }
.onboarding-tagline { font-size: 0.9rem; color: #bbb; line-height: 1.4; }
.onboarding-label { font-size: 0.65rem; text-transform: uppercase; color: #888; letter-spacing: 0.5px; }
.onboarding-input { background: #0c0c0c; border: 1px solid #333; color: #fff; padding: 8px; border-radius: 4px; font-size: 0.9rem; }
.onboarding-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.onboarding-fields { display: grid; gap: 10px; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.onboarding-field { display: flex; flex-direction: column; gap: 6px; }
.onboarding-select { background: #0c0c0c; border: 1px solid #333; color: #fff; padding: 8px; border-radius: 4px; font-size: 0.85rem; }
.onboarding-select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.onboarding-help { font-size: 0.7rem; color: #666; line-height: 1.3; }
.onboarding-error { font-size: 0.75rem; color: var(--danger); min-height: 1em; }
.onboarding-actions { display: flex; justify-content: flex-end; gap: 8px; }
.onboarding-support { border: 1px solid #222; background: #0d0d0d; padding: 10px; border-radius: 8px; display: flex; flex-direction: column; gap: 8px; }
.onboarding-support-title { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.6px; color: #777; }
.onboarding-support-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.onboarding-support-link { display: block; text-decoration: none; color: #fff; border: 1px solid #2a2a2a; background: #151515; padding: 8px; border-radius: 6px; text-align: center; font-size: 0.75rem; transition: color 0.2s, border-color 0.2s; }
.onboarding-support-link:hover { border-color: var(--accent); color: var(--accent); }
.onboarding-meta { margin-top: 6px; border-top: 1px solid #222; padding-top: 8px; font-size: 0.75rem; color: #888; }
.onboarding-version { font-weight: bold; color: #aaa; }
.onboarding-changelog-title { margin-top: 6px; text-transform: uppercase; font-size: 0.65rem; letter-spacing: 0.5px; color: #666; }
.onboarding-changelog { margin: 6px 0 0 16px; padding: 0; color: #999; }
.onboarding-changelog li { margin-bottom: 4px; }
.onboarding-login { border: 1px solid #222; background: #0d0d0d; padding: 8px; border-radius: 8px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.onboarding-login-text { font-size: 0.65rem; text-transform: uppercase; color: #888; letter-spacing: 0.5px; }
.onboarding-login .btn-back { padding: 5px 10px; font-size: 0.75rem; flex: 0 0 auto; }

.account-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(5, 5, 5, 0.92); z-index: 3600; display: flex; align-items: center; justify-content: center; padding: 20px; }
.account-card { width: 100%; max-width: 420px; background: #121212; border: 1px solid #333; border-radius: 10px; padding: 18px; box-shadow: 0 0 30px rgba(0,0,0,0.6); display: flex; flex-direction: column; gap: 12px; }
.account-title { font-size: 1rem; font-weight: bold; color: var(--accent); text-transform: uppercase; letter-spacing: 1.5px; }
.account-body { display: flex; flex-direction: column; gap: 10px; }
.account-label { font-size: 0.65rem; text-transform: uppercase; color: #888; letter-spacing: 0.5px; }
.account-input { background: #0c0c0c; border: 1px solid #333; color: #fff; padding: 8px; border-radius: 4px; font-size: 0.9rem; }
.account-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.account-actions { display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }
.account-actions .btn-back,
.account-actions .btn-valid { flex: 0 0 auto; }
.account-error { font-size: 0.75rem; color: var(--danger); min-height: 1em; }
.account-note { font-size: 0.7rem; color: #777; line-height: 1.3; }
.account-current { font-size: 0.75rem; color: #bbb; }
.account-option { border: 1px solid #333; background: #151515; border-radius: 6px; padding: 10px; text-align: left; cursor: pointer; width: 100%; box-sizing: border-box; font-family: inherit; }
.account-option:hover { border-color: var(--accent); }
.account-option-title { font-weight: bold; color: #fff; font-size: 0.85rem; }
.account-option-meta { font-size: 0.7rem; color: #888; margin-top: 4px; }
