/* ═══════════════════════════════════════════════════════════════════════════
   Michitareas – Complete Stylesheet with Light/Dark Themes
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── CSS Variables ──────────────────────────────────────────────────────── */
:root {
    --font-main: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --radius: 8px;
    --radius-lg: 12px;
    --shadow: 0 2px 8px rgba(0,0,0,0.12);
    --shadow-lg: 0 4px 24px rgba(0,0,0,0.18);
    --transition: 0.2s ease;
    --top-bar-h: 56px;
    --side-nav-w: 260px;
    /* Pelea de Michis flame colors (used for streaks) */
    --flame-1: #FF4500;
    --flame-2: #FF8C00;
    --flame-3: #FFD700;
    --flame-grad: linear-gradient(135deg, #FF4500, #FF8C00, #FFD700);
    --flame-glow: 0 0 12px rgba(255,140,0,0.5);
    /* Fight / challenge gold colors */
    --fight-gold-1: #B8860B;
    --fight-gold-2: #FFD700;
    --fight-gold-grad: linear-gradient(135deg, #B8860B, #FFD700);
    --fight-gold-glow: 0 0 12px rgba(184,134,11,0.45);
}

/* ─── Dark Theme (default) ───────────────────────────────────────────────── */
[data-theme="dark"] {
    --bg: #0a0a0a;
    --bg-card: #141414;
    --bg-card-hover: #1e1e1e;
    --bg-input: #1a1a1a;
    --bg-modal: #181818;
    --border: #2a2a2a;
    --text: #e8e8e8;
    --text-secondary: #888;
    --text-muted: #555;
    --accent: #ffffff;
    --accent-hover: #cccccc;

    /* Task status colors – neon */
    --color-done: #39ff14;
    --color-skipped: #808080;
    --color-pending: #00bfff;
    --color-warning: #ff9500;
    --color-urgent: #ff3b30;

    /* Tema/Lugar colors – neon */
    --clr-purple: #bf5af2;
    --clr-pink: #ff2d55;
    --clr-teal: #30d5c8;
    --clr-brown: #ac8e68;
    --clr-indigo: #5e5ce6;
    --clr-magenta: #ff00ff;
    --clr-cyan: #00ffff;
    --clr-yellow: #ffd60a;
    --clr-lavender: #c8a2ff;
    --clr-mint: #64ffda;

    --scrollbar-track: #1a1a1a;
    --scrollbar-thumb: #333;
}

/* ─── Light Theme ────────────────────────────────────────────────────────── */
[data-theme="light"] {
    --bg: #f5f5f5;
    --bg-card: #ffffff;
    --bg-card-hover: #f0f0f0;
    --bg-input: #ffffff;
    --bg-modal: #ffffff;
    --border: #e0e0e0;
    --text: #1a1a1a;
    --text-secondary: #666;
    --text-muted: #999;
    --accent: #1a1a1a;
    --accent-hover: #333;

    /* Task status colors – pastel */
    --color-done: #a8d5a2;
    --color-skipped: #c0c0c0;
    --color-pending: #a3c4e6;
    --color-warning: #f0d0a0;
    --color-urgent: #e6a3a3;

    /* Tema/Lugar colors – pastel */
    --clr-purple: #c9a7e0;
    --clr-pink: #f0b3c7;
    --clr-teal: #a7d8d1;
    --clr-brown: #c4a98a;
    --clr-indigo: #a3b1d6;
    --clr-magenta: #e0a3d0;
    --clr-cyan: #a3dce6;
    --clr-yellow: #f0e6a3;
    --clr-lavender: #d0c4e8;
    --clr-mint: #a8e6cf;

    --scrollbar-track: #f0f0f0;
    --scrollbar-thumb: #ccc;
}

/* ─── Reset & Base ───────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; }

body {
    font-family: var(--font-main);
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--scrollbar-track); }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btn-primary {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 20px; border: 1px solid var(--accent);
    background: var(--accent); color: var(--bg);
    border-radius: var(--radius); cursor: pointer;
    font-size: 0.9rem; font-weight: 600;
    transition: var(--transition);
}
.btn-primary:hover { opacity: 0.85; }

.btn-secondary {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 20px; border: 1px solid var(--border);
    background: transparent; color: var(--text);
    border-radius: var(--radius); cursor: pointer;
    font-size: 0.9rem; transition: var(--transition);
}
.btn-secondary:hover { background: var(--bg-card-hover); }

.btn-danger {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 20px; border: 1px solid var(--color-urgent);
    background: var(--color-urgent); color: #fff;
    border-radius: var(--radius); cursor: pointer;
    font-size: 0.9rem; transition: var(--transition);
}
.btn-danger:hover { opacity: 0.85; }

.btn-sm {
    padding: 6px 14px; border: 1px solid var(--border);
    background: transparent; color: var(--text);
    border-radius: var(--radius); cursor: pointer;
    font-size: 0.8rem; transition: var(--transition);
}
.btn-sm:hover, .btn-sm.active { background: var(--accent); color: var(--bg); border-color: var(--accent); }
.btn-sm-danger { border-color: var(--color-skipped, #e74c3c); color: var(--color-skipped, #e74c3c); }
.btn-sm-danger:hover { background: var(--color-skipped, #e74c3c); color: #fff; border-color: var(--color-skipped, #e74c3c); }
.btn-sm-inactive { opacity: 0.38; border-color: var(--text-muted) !important; color: var(--text-muted) !important; pointer-events: none; cursor: default; }

.btn-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; border: none;
    background: transparent; color: var(--text);
    border-radius: 50%; cursor: pointer;
    font-size: 1.1rem; transition: var(--transition);
}
.btn-icon:hover { background: var(--bg-card-hover); }

.btn-full { width: 100%; justify-content: center; }

.btn-ghost {
    border: none; background: none; color: var(--text-secondary);
    cursor: pointer; padding: 4px 8px; font-size: 0.85rem;
    transition: var(--transition);
}
.btn-ghost:hover { color: var(--text); }

/* ─── Inputs ─────────────────────────────────────────────────────────────── */
.input-field {
    width: 100%; padding: 10px 14px;
    border: 1px solid var(--border);
    background: var(--bg-input); color: var(--text);
    border-radius: var(--radius); font-size: 0.9rem;
    transition: var(--transition);
}
.input-field:focus { outline: none; border-color: var(--accent); }

select.input-field { cursor: pointer; }

textarea.input-field { resize: vertical; min-height: 80px; font-family: var(--font-main); }

.form-group { margin-bottom: 16px; }
.form-group label {
    display: block; margin-bottom: 6px; font-size: 0.85rem;
    color: var(--text-secondary); font-weight: 500;
}
.form-group label i { margin-right: 4px; width: 16px; text-align: center; }

.form-row { display: flex; gap: 12px; }
.form-row .form-group { flex: 1; }

.form-check {
    display: flex; align-items: center; gap: 8px;
    margin-bottom: 12px; cursor: pointer;
}
.form-check input[type="checkbox"] {
    width: 18px; height: 18px; accent-color: var(--accent);
}

/* ─── Top Bar ────────────────────────────────────────────────────────────── */
.top-bar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    height: var(--top-bar-h); display: flex; align-items: center;
    padding: 0 12px; gap: 8px;
    background: var(--bg-card); border-bottom: 1px solid var(--border);
}
.app-title { flex: 1; font-size: 1.1rem; font-weight: 700; }
.top-bar-actions { display: flex; align-items: center; gap: 2px; }

.notification-bell { position: relative; }
.notification-bell .badge {
    position: absolute; top: 4px; right: 4px;
    min-width: 18px; height: 18px; padding: 0 5px;
    background: var(--color-urgent); color: #fff;
    border-radius: 9px; font-size: 0.7rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
}

/* ─── Side Nav ───────────────────────────────────────────────────────────── */
.side-nav { position: fixed; top: 0; left: 0; bottom: 0; z-index: 200; pointer-events: none; }
.side-nav.open { pointer-events: auto; }
.side-nav-overlay {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.5); opacity: 0; transition: opacity 0.3s;
}
.side-nav.open .side-nav-overlay { opacity: 1; }
.side-nav-content {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: var(--side-nav-w); background: var(--bg-card);
    border-right: 1px solid var(--border);
    transform: translateX(-100%); transition: transform 0.3s;
    padding-top: 20px; overflow-y: auto;
    display: flex; flex-direction: column;
}
.side-nav.open .side-nav-content { transform: translateX(0); }

.side-nav-header {
    padding: 20px 20px 16px; font-size: 1rem; font-weight: 700;
    border-bottom: 1px solid var(--border); margin-bottom: 8px;
    display: flex; align-items: center; gap: 10px;
}

.nav-list { list-style: none; }
.nav-link {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 20px; color: var(--text-secondary);
    font-size: 0.95rem; transition: var(--transition);
}
.nav-link i { width: 20px; text-align: center; }
.nav-link:hover, .nav-link.active { color: var(--text); background: var(--bg-card-hover); }

/* ─── Main Content ───────────────────────────────────────────────────────── */
.main-content {
    margin-top: var(--top-bar-h); padding: 20px;
    max-width: 1200px; margin-left: auto; margin-right: auto;
}

.view { display: none; }

.view-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 20px; flex-wrap: wrap; gap: 12px;
}
.view-header h2 { font-size: 1.4rem; font-weight: 700; }

/* ─── Cards ──────────────────────────────────────────────────────────────── */
.card-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}

.card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 20px;
    transition: var(--transition); cursor: default;
}
.card:hover { background: var(--bg-card-hover); }

.card-header {
    display: flex; align-items: center; gap: 8px; margin-bottom: 12px;
    flex-wrap: wrap;
}
.card-icon {
    width: 44px; height: 44px; border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; flex-shrink: 0;
}
.card-icon img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); }
.card-title { font-size: 1rem; font-weight: 600; }
.card-subtitle { font-size: 0.8rem; color: var(--text-secondary); }
.card-body { font-size: 0.85rem; color: var(--text-secondary); margin-bottom: 12px; }
.card-actions { display: flex; gap: 8px; justify-content: flex-end; flex-wrap: wrap; }

.card-list { display: flex; flex-direction: column; gap: 12px; }

/* ─── Dashboard ──────────────────────────────────────────────────────────── */
.dashboard-controls {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 12px; margin-bottom: 20px;
}
.view-switcher { display: flex; gap: 4px; }
.group-switcher { display: flex; gap: 4px; }
.task-card-time-prefix {
    font-variant-numeric: tabular-nums;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-right: 4px;
}
.date-nav { display: flex; align-items: center; gap: 8px; }
.date-display {
    font-size: 0.95rem; font-weight: 600; min-width: 160px;
    text-align: center;
}

.task-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 16px;
    margin-bottom: 12px; transition: var(--transition);
    border-left: 4px solid var(--color-pending);
    position: relative; overflow: hidden;
    cursor: pointer;
}
.task-card.done { border-left-color: var(--color-done); }
.task-card.skipped { border-left-color: var(--color-skipped); }
.task-card.warning { border-left-color: var(--color-warning); }
.task-card.urgent { border-left-color: var(--color-urgent); }

/* Full card status coloring */
.task-card.status-done {
    border-left-color: var(--color-done);
    border-color: var(--color-done);
    background: color-mix(in srgb, var(--color-done) 10%, var(--bg-card));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-done) 20%, transparent);
}
.task-card.status-skipped {
    border-left-color: var(--color-skipped);
    border-color: var(--color-skipped);
    background: color-mix(in srgb, var(--color-skipped) 10%, var(--bg-card));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-skipped) 20%, transparent);
}
.task-card.status-pending {
    border-left-color: var(--color-pending);
    border-color: color-mix(in srgb, var(--color-pending) 30%, var(--border));
    background: color-mix(in srgb, var(--color-pending) 6%, var(--bg-card));
}
.task-card.status-warning {
    border-left-color: var(--color-warning);
    border-color: var(--color-warning);
    background: color-mix(in srgb, var(--color-warning) 12%, var(--bg-card));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-warning) 20%, transparent);
}
.task-card.status-partial {
    border-left-color: var(--color-warning);
    border-color: var(--color-warning);
    background: color-mix(in srgb, var(--color-warning) 12%, var(--bg-card));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-warning) 20%, transparent);
}
.task-card.status-urgent {
    border-left-color: var(--color-urgent);
    border-color: var(--color-urgent);
    background: color-mix(in srgb, var(--color-urgent) 14%, var(--bg-card));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-urgent) 25%, transparent);
}

/* Streak badge — bottom-right corner of each task card */
.streak-badge-card {
    position: absolute;
    bottom: 6px;
    right: 8px;
    background: #aaa;
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    border-radius: 10px;
    padding: 2px 7px;
    display: flex;
    align-items: center;
    gap: 3px;
    pointer-events: none;
    z-index: 1;
    line-height: 1.4;
}

/* Global streak badge — dashboard controls right side */
#global-streak-badge,
.streak-global-badge {
    display: flex;
    align-items: center;
    gap: 5px;
    color: #fff;
    border-radius: 20px;
    padding: 5px 14px;
    font-weight: 700;
    font-size: 0.88rem;
    white-space: nowrap;
}
#global-streak-badge i, .streak-global-badge i { font-size: 0.95rem; }
#global-streak-badge small, .streak-global-badge small { font-weight: 400; font-size: 0.78rem; opacity: 0.9; }

/* Streak flame color tiers (replaces old medal tiers) */
.streak-flame-low  { background: #FF8C00 !important; color: #fff !important; }
.streak-flame-mid  { background: linear-gradient(135deg, #FF4500, #FF8C00) !important; color: #fff !important; }
.streak-flame-high { background: var(--flame-grad) !important; color: #fff !important; box-shadow: var(--flame-glow); }

/* Legacy medal color tiers (kept for compatibility) */
.streak-bronze { background: #CD7F32 !important; color: #fff !important; }
.streak-silver { background: #a8a9ad !important; color: #fff !important; }
.streak-gold   { background: linear-gradient(135deg, #FFD700, #FFA500) !important; color: #333 !important; }

/* Streak stat badges used in stats view */
.streak-stat-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border-radius: 12px;
    padding: 3px 10px;
    font-weight: 700;
    font-size: 0.82rem;
    color: #fff;
    background: #888;
}
.streak-best { background: #6c5ce7 !important; color: #fff !important; }

/* Fight rank badge — bottom-right corner of each fight task card, above streak badge */
.fight-rank-badge-card {
    position: absolute;
    bottom: 34px;
    right: 8px;
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    border-radius: 10px;
    padding: 2px 7px;
    display: flex;
    align-items: center;
    gap: 3px;
    pointer-events: none;
    z-index: 1;
    line-height: 1.4;
}

/* Fight rank badges by position */
.fight-rank-badge {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px; border-radius: 50%;
    font-size: 0.75rem; font-weight: 800; flex-shrink: 0;
}
.fight-rank-gold   { background: linear-gradient(135deg, #FFD700, #FFA500); color: #333; }
.fight-rank-silver { background: #a8a9ad; color: #fff; }
.fight-rank-bronze { background: #CD7F32; color: #fff; }
.fight-rank-grey   { background: #888; color: #fff; }

/* Input and button warning style (value below target) */
.input-warning { border-color: var(--color-warning) !important; background: color-mix(in srgb, var(--color-warning) 8%, var(--bg-input)) !important; }
.btn-warning { background: var(--color-warning) !important; color: #000 !important; border: none; }

.task-card-header {
    display: flex; align-items: center; gap: 12px; margin-bottom: 8px;
}
.task-card-icon {
    width: 36px; height: 36px; border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem; flex-shrink: 0;
}
.task-card-icon img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); }
.task-card-info { flex: 1; }
.task-card-name { font-weight: 600; font-size: 0.95rem; }
.task-card-meta { font-size: 0.75rem; color: var(--text-secondary); }
.task-card-progress {
    font-size: 0.8rem; font-weight: 600; padding: 2px 8px;
    border-radius: 10px; white-space: nowrap;
}
.task-card-progress-wrap {
    display: flex; flex-direction: column; align-items: flex-end; gap: 2px;
    flex-shrink: 0;
}
.task-card-time {
    font-size: 0.7rem; font-weight: 500; white-space: nowrap;
    display: inline-flex; align-items: center; gap: 3px;
}
.task-card-actions {
    display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px;
}
.task-btn {
    padding: 6px 12px; border: 1px solid var(--border);
    background: transparent; color: var(--text);
    border-radius: var(--radius); cursor: pointer;
    font-size: 0.8rem; transition: var(--transition);
    display: inline-flex; align-items: center; gap: 4px;
}
.task-btn:hover { background: var(--bg-card-hover); }
.task-btn.done-btn { border-color: var(--color-done); color: var(--color-done); }
.task-btn.done-btn:hover { background: var(--color-done); color: var(--bg); }
.task-btn.skip-btn { border-color: var(--color-skipped); color: var(--color-skipped); }
.task-btn.skip-btn:hover { background: var(--color-skipped); color: var(--bg); }
.task-btn.undo-btn { border-color: var(--color-pending); color: var(--color-pending); }

/* Week/Month calendar grid */
.calendar-grid {
    display: grid; gap: 8px;
}
.calendar-grid.week-grid { grid-template-columns: repeat(7, 1fr); }
.calendar-grid.month-grid { grid-template-columns: repeat(7, 1fr); }

.calendar-day {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 8px; min-height: 80px;
}
.calendar-day-header {
    font-size: 0.75rem; font-weight: 600; color: var(--text-secondary);
    margin-bottom: 6px; text-align: center;
}
.calendar-day.today { border-color: var(--accent); }
.calendar-day-tasks { font-size: 0.7rem; text-align: center; }
.calendar-dot {
    display: inline-block; width: 8px; height: 8px;
    border-radius: 50%; margin: 1px;
}

/* ─── Filter Bar ─────────────────────────────────────────────────────────── */
.filter-bar {
    display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap;
}
.filter-bar .input-field { max-width: 220px; }

/* ─── Stats ──────────────────────────────────────────────────────────────── */
.stats-controls {
    display: flex; gap: 12px; margin-bottom: 20px; flex-wrap: wrap;
}
.stats-controls .input-field { max-width: 200px; }

.stats-overview {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px; margin-bottom: 24px;
}
.stat-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 20px; text-align: center;
}
.stat-value { font-size: 2rem; font-weight: 800; margin-bottom: 4px; }
.stat-label { font-size: 0.8rem; color: var(--text-secondary); }
.stat-pct { font-size: 0.85rem; color: var(--text-muted); }

.chart-container {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 20px;
    margin-bottom: 20px; position: relative; max-height: 400px;
}
.chart-container canvas { max-height: 350px; }

.stats-details { margin-top: 20px; }

/* ─── Notification Panel ─────────────────────────────────────────────────── */
.notification-panel {
    position: fixed; top: var(--top-bar-h); right: 0;
    width: 360px; max-height: calc(100vh - var(--top-bar-h));
    background: var(--bg-card); border-left: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-lg); z-index: 150;
    overflow-y: auto; border-radius: 0 0 0 var(--radius-lg);
}
.notif-header {
    display: flex; flex-direction: column; gap: 10px;
    padding: 14px 16px; border-bottom: 1px solid var(--border);
    position: sticky; top: 0; background: var(--bg-card);
}
.notif-header h3 { font-size: 1rem; margin: 0; }
.notif-header-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.notif-list { padding: 8px; }
.notif-item {
    display: flex; gap: 12px; padding: 12px; border-radius: var(--radius);
    margin-bottom: 4px; cursor: pointer; transition: var(--transition);
    border: 2px solid transparent;
}
.notif-item:hover { border-color: var(--accent); background: transparent; }
.notif-item.unread { background: var(--bg-card-hover); }
.notif-item.unread:hover { border-color: var(--accent); }
.notif-icon { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; flex-shrink: 0; }
.notif-icon.reminder { color: var(--color-pending); }
.notif-icon.skipped-type { color: var(--color-skipped); }
.notif-content { flex: 1; }
.notif-title { font-size: 0.85rem; font-weight: 600; margin-bottom: 2px; }
.notif-body { font-size: 0.8rem; color: var(--text-secondary); }
.notif-time { font-size: 0.7rem; color: var(--text-muted); margin-top: 4px; }
.notif-empty { text-align: center; padding: 40px 20px; color: var(--text-muted); }
.notif-footer { padding: 8px 12px; border-top: 1px solid var(--border); display: flex; justify-content: center; }
.notif-footer .btn-ghost { font-size: 0.82rem; width: 100%; justify-content: center; }
.notif-icon svg { width: 32px; height: 32px; }

/* ─── Settings Panel ─────────────────────────────────────────────────────── */
.settings-panel {
    position: fixed; top: var(--top-bar-h); right: 0;
    width: 300px; background: var(--bg-card);
    border-left: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-lg); z-index: 150;
    border-radius: 0 0 0 var(--radius-lg);
    padding: 16px;
}
.settings-group { margin-bottom: 16px; }
.settings-group:last-child { margin-bottom: 0; }
.settings-label {
    font-size: 0.85rem; font-weight: 600; color: var(--text-secondary);
    margin-bottom: 8px; display: flex; align-items: center; gap: 6px;
}
.settings-options { display: flex; gap: 6px; flex-wrap: wrap; }
.lang-flag {
    width: 22px !important; height: 22px !important;
    min-width: 22px; min-height: 22px;
    border-radius: 50% !important; overflow: hidden;
    display: inline-block !important; flex-shrink: 0;
    background-size: cover !important;
    box-shadow: 0 0 0 1px var(--border);
}
.settings-option {
    padding: 8px 14px; border-radius: var(--radius); cursor: pointer;
    background: var(--bg-input); color: var(--text-secondary);
    border: 2px solid transparent; font-size: 0.85rem;
    transition: var(--transition); display: flex; align-items: center; gap: 6px;
}
.settings-option:hover { color: var(--text); background: var(--bg-card-hover); }
.settings-option.active {
    border-color: var(--accent); color: var(--text); background: var(--bg-card-hover);
}

/* ─── Modal ──────────────────────────────────────────────────────────────── */
.modal-overlay {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.6); z-index: 300;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
}
.modal {
    background: var(--bg-modal); border: 1px solid var(--border);
    border-radius: var(--radius-lg); width: 100%; max-width: 600px;
    max-height: 90vh; overflow-y: auto; box-shadow: var(--shadow-lg);
}
.modal-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 20px; border-bottom: 1px solid var(--border);
    position: sticky; top: 0; background: var(--bg-modal); z-index: 1;
}
.modal-body { padding: 20px; }
.modal-footer {
    display: flex; justify-content: flex-end; gap: 8px;
    padding: 16px 20px; border-top: 1px solid var(--border);
}

/* ─── Color Picker ───────────────────────────────────────────────────────── */
.color-picker { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.color-swatch {
    width: 36px; height: 36px; border-radius: 50%; cursor: pointer;
    border: 3px solid transparent; transition: var(--transition);
}
.color-swatch:hover, .color-swatch.selected { border-color: var(--text); transform: scale(1.15); }

/* ─── Icon Picker ────────────────────────────────────────────────────────── */
.icon-picker-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(48px, 1fr));
    gap: 6px; max-height: 200px; overflow-y: auto;
    border: 1px solid var(--border); border-radius: var(--radius);
    padding: 8px; margin-top: 8px;
}
.icon-option {
    width: 44px; height: 44px; display: flex; align-items: center;
    justify-content: center; border-radius: var(--radius);
    cursor: pointer; font-size: 1.2rem; color: var(--text-secondary);
    transition: var(--transition); border: 2px solid transparent;
}
.icon-option:hover { color: var(--text); background: var(--bg-card-hover); }
.icon-option.selected { border-color: var(--accent); color: var(--text); }

.icon-search {
    margin-bottom: 8px;
}

/* ─── Map ────────────────────────────────────────────────────────────────── */
.map-container {
    height: 250px; border-radius: var(--radius); overflow: hidden;
    border: 1px solid var(--border); margin-top: 8px;
}

/* ─── Image Upload ───────────────────────────────────────────────────────── */
.upload-area {
    border: 2px dashed var(--border); border-radius: var(--radius);
    padding: 30px; text-align: center; cursor: pointer;
    transition: var(--transition); margin-top: 8px;
}
.upload-area:hover { border-color: var(--accent); }
.upload-area i { font-size: 2rem; color: var(--text-muted); margin-bottom: 8px; display: block; }
.upload-area span { font-size: 0.85rem; color: var(--text-secondary); }

.image-preview-grid {
    display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px;
}
.image-preview {
    position: relative; width: 80px; height: 80px; border-radius: var(--radius);
    overflow: hidden; border: 1px solid var(--border);
}
.image-preview img { width: 100%; height: 100%; object-fit: cover; }
.image-preview .remove-btn {
    position: absolute; top: 2px; right: 2px;
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--color-urgent); color: #fff;
    border: none; font-size: 0.7rem; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
}

/* Cropper modal */
.cropper-container-modal { max-height: 400px; }
.cropper-container-modal img { max-width: 100%; max-height: 380px; }

/* ─── Auth Pages ─────────────────────────────────────────────────────────── */
.auth-container {
    min-height: 100vh; display: flex; align-items: center;
    justify-content: center; padding: 20px;
}
.auth-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 40px;
    width: 100%; max-width: 420px; box-shadow: var(--shadow-lg);
}
.auth-header {
    text-align: center; margin-bottom: 32px;
}
.auth-logo { display: block; width: 72px; height: 72px; margin: 0 auto 12px; }
/* Dark mode: white circle, black cat body, white eyes, pink cheeks */
.auth-logo .cat-bg    { fill: #FFFFFF; }
.auth-logo .cat-body  { fill: #000000; }
.auth-logo .cat-eye   { stroke: #FFFFFF; }
.auth-logo .cat-cheek { fill: #FFB6C1; }
/* Light mode: black circle, white cat body, black eyes, pink cheeks */
[data-theme="light"] .auth-logo .cat-bg    { fill: #000000; }
[data-theme="light"] .auth-logo .cat-body  { fill: #FFFFFF; }
[data-theme="light"] .auth-logo .cat-eye   { stroke: #000000; }
.auth-header h1 { font-size: 1.5rem; margin-bottom: 4px; }
.auth-header p { color: var(--text-secondary); font-size: 0.9rem; }

.auth-form { margin-bottom: 20px; }
.auth-links {
    display: flex; flex-direction: column; gap: 8px; text-align: center;
}
.auth-links a { font-size: 0.85rem; color: var(--text-secondary); }
.auth-links a:hover { color: var(--text); }

.theme-toggle-auth { position: fixed; top: 16px; right: 16px; }

/* ─── Flash Messages ─────────────────────────────────────────────────────── */
.flash {
    padding: 10px 16px; border-radius: var(--radius);
    margin-bottom: 12px; font-size: 0.85rem;
}
.flash-error { background: rgba(255,59,48,0.15); color: var(--color-urgent); border: 1px solid var(--color-urgent); }
.flash-success { background: rgba(57,255,20,0.1); color: var(--color-done); border: 1px solid var(--color-done); }
.flash-info { background: rgba(0,191,255,0.1); color: var(--color-pending); border: 1px solid var(--color-pending); }

/* ─── Toast ──────────────────────────────────────────────────────────────── */
.toast-container {
    position: fixed; bottom: 20px; right: 20px; z-index: 400;
    display: flex; flex-direction: column; gap: 8px;
}
.toast {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 12px 20px;
    box-shadow: var(--shadow-lg); font-size: 0.85rem;
    animation: slideIn 0.3s ease;
    display: flex; align-items: center; gap: 8px;
}
.toast.success { border-left: 4px solid var(--color-done); }
.toast.error { border-left: 4px solid var(--color-urgent); }
.toast.info { border-left: 4px solid var(--color-pending); }

.toast-cat {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    padding: 4px;
}
.toast-cat svg {
    width: 100%;
    height: 100%;
}

@keyframes slideIn {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

/* Cat celebration overlay */
.cat-celebration {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    animation: catFadeIn 0.3s ease;
    transition: opacity 0.4s ease;
}
.cat-celebration-inner {
    width: 120px;
    height: 120px;
    background: #2a2a3e;
    border-radius: 50%;
    padding: 16px;
    animation: catPop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    filter: drop-shadow(0 4px 24px rgba(0,0,0,0.3));
}
.cat-celebration-inner svg {
    width: 100%;
    height: 100%;
}
@keyframes catFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
@keyframes catPop {
    from { transform: scale(0.3); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}

/* ─── Status Tags ────────────────────────────────────────────────────────── */
.tag {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 10px; border-radius: 12px;
    font-size: 0.75rem; font-weight: 600;
}
.tag-done { background: var(--color-done); color: #000; }
.tag-partial { background: var(--color-warning); color: #000; }
.tag-skipped { background: var(--color-skipped); color: #000; }
.tag-pending { background: var(--color-pending); color: #000; }
.tag-warning { background: var(--color-warning); color: #000; }
.tag-urgent { background: var(--color-urgent); color: #fff; }
.tag-active { background: var(--color-done); color: #000; }
.tag-inactive { background: var(--color-skipped); color: #000; }

/* ─── Empty State ────────────────────────────────────────────────────────── */
.empty-state {
    text-align: center; padding: 60px 20px;
    color: var(--text-muted);
}
.empty-state i { font-size: 3rem; margin-bottom: 16px; display: block; }
.empty-state p { font-size: 0.95rem; margin-bottom: 12px; }

/* ─── Duration Input ─────────────────────────────────────────────────────── */
.duration-input { display: flex; align-items: center; gap: 8px; }
.duration-input .input-field { max-width: 100px; }

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .main-content { padding: 12px; }
    .card-grid { grid-template-columns: 1fr; }
    .form-row { flex-direction: column; gap: 0; }
    .notification-panel { width: 100%; }
    .settings-panel { width: 100%; }
    .dashboard-controls { flex-direction: column; align-items: stretch; }
    .view-switcher { justify-content: center; }
    .group-switcher { justify-content: center; }
    .date-nav { justify-content: center; }
    .stats-controls { flex-direction: column; }
    .stats-controls .input-field { max-width: 100%; }
    .filter-bar { flex-direction: column; }
    .filter-bar .input-field { max-width: 100%; }
    .modal { max-width: 100%; margin: 10px; }
    .calendar-grid.week-grid { grid-template-columns: 1fr; }
    .calendar-grid.month-grid { grid-template-columns: repeat(7, 1fr); }
    .calendar-day { min-height: 50px; padding: 4px; }
}

@media (max-width: 480px) {
    .auth-card { padding: 24px; }
    .top-bar { padding: 0 8px; }
    .date-display { min-width: 120px; font-size: 0.85rem; }
}

/* ─── Loading Spinner ────────────────────────────────────────────────────── */
.spinner {
    display: inline-block; width: 24px; height: 24px;
    border: 3px solid var(--border); border-top-color: var(--accent);
    border-radius: 50%; animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loading-center {
    display: flex; justify-content: center; align-items: center;
    padding: 40px;
}

/* ─── Utility ────────────────────────────────────────────────────────────── */
.text-done { color: var(--color-done); }
.text-skipped { color: var(--color-skipped); }
.text-pending { color: var(--color-pending); }
.text-warning { color: var(--color-warning); }
.text-urgent { color: var(--color-urgent); }
.text-muted { color: var(--text-muted); }
.text-center { text-align: center; }
.mt-8 { margin-top: 8px; }
.mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; }
.mb-8 { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.gap-8 { gap: 8px; }
.flex { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.hidden { display: none !important; }

/* ─── Subtareas ──────────────────────────────────────────────────────────── */
.subtarea-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.75rem;
    padding: 2px 8px;
    border-radius: 12px;
    background: var(--border);
    color: var(--text-secondary);
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
    transition: background 0.15s;
}
.subtarea-badge:hover {
    background: var(--input-bg);
}
.subtarea-badge-done {
    background: color-mix(in srgb, var(--color-done) 20%, transparent);
    color: var(--color-done);
}
.subtarea-checklist {
    padding: 8px 0 4px 0;
    border-top: 1px solid var(--border);
    margin-top: 4px;
}
.subtarea-checklist-modal {
    border-top: none;
    margin-top: 0;
    padding-top: 4px;
}
.subtarea-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 12px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--text-primary);
    transition: background 0.12s;
}
.subtarea-item:hover {
    background: var(--input-bg);
}
.subtarea-item input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--color-done);
    cursor: pointer;
    flex-shrink: 0;
}
.subtarea-item.subtarea-done span {
    text-decoration: line-through;
    opacity: 0.6;
}

/* Subtarea management (tarea form) */
.subtareas-manage-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 8px;
}
.subtarea-manage-item {
    display: flex;
    align-items: center;
    gap: 6px;
}
.subtarea-manage-item .subtarea-grip {
    color: var(--text-muted);
    cursor: grab;
    font-size: 0.8rem;
}
.subtarea-manage-item .subtarea-name-input {
    flex: 1;
    padding: 4px 8px;
    font-size: 0.85rem;
}
.subtarea-manage-item .subtarea-delete-btn {
    padding: 4px 6px;
    font-size: 0.8rem;
}
.subtarea-add-row {
    display: flex;
    gap: 6px;
    align-items: center;
}
.subtarea-detail-item { margin-bottom: 4px; }
.subtarea-detail-item.subtarea-done > label span:first-of-type { text-decoration: line-through; opacity: 0.6; }
.si-actual-form { display: flex; }
.subtarea-manage-item .subtarea-reps-input,
.subtarea-manage-item .subtarea-dur-input {
    padding: 4px 4px;
    font-size: 0.85rem;
    flex-shrink: 0;
}
.subtarea-add-row .input-field {
    font-size: 0.85rem;
    padding: 6px 10px;
}

/* ─── Cat Color Swatch ───────────────────────────────────────────────────── */
.cat-color-swatch {
    width: 14px; height: 14px; border-radius: 50%;
    background: var(--cc, #FFF);
    border: 1px solid var(--border);
    display: inline-block; flex-shrink: 0;
}

/* ─── Admin Panel ────────────────────────────────────────────────────────── */
.admin-user-list { display: flex; flex-direction: column; gap: 6px; max-height: 400px; overflow-y: auto; }
.admin-user-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 10px; border-radius: var(--radius);
    background: var(--bg-input); gap: 8px;
}
.admin-user-info { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: 1; min-width: 0; }
.admin-username { font-weight: 600; font-size: 0.9rem; }
.admin-email { font-size: 0.75rem; color: var(--text-secondary); word-break: break-all; }
.admin-user-actions { display: flex; gap: 4px; flex-shrink: 0; }
.badge-admin {
    font-size: 0.65rem; font-weight: 700; text-transform: uppercase;
    background: var(--clr-purple); color: #fff;
    padding: 2px 6px; border-radius: 999px;
}
.badge-blocked {
    font-size: 0.65rem; font-weight: 700; text-transform: uppercase;
    background: var(--color-urgent); color: #fff;
    padding: 2px 6px; border-radius: 999px;
}
.loading-spinner {
    width: 32px; height: 32px; border: 3px solid var(--border);
    border-top-color: var(--accent); border-radius: 50%;
    animation: spin .6s linear infinite; margin: 40px auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ─── Colonia Felina ───────────────────────────────────────────────────────── */
.invite-banner {
    display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
    background: var(--clr-teal, #2dd4bf)22; border: 1px solid var(--accent);
    border-radius: var(--radius); padding: 10px 14px;
    font-size: 0.9rem; margin-bottom: 8px;
}
.colonia-members-list {
    display: flex; flex-direction: column; gap: 6px;
}
.colonia-member-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px; background: var(--bg-card);
    border-radius: var(--radius); border: 1px solid var(--border);
}
.colonia-member-item i { color: var(--text-secondary); font-size: 1.1rem; }
.colonia-tarea-row {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px; background: var(--bg-card);
    border-radius: var(--radius); border: 1px solid var(--border);
    margin-bottom: 6px;
}
.colonia-tarea-icon {
    width: 36px; height: 36px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; flex-shrink: 0;
}
.btn-xs {
    padding: 3px 8px; font-size: 0.75rem;
}
.colonia-card:hover { border-color: var(--accent); }
.michi-cat-avatar { display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:6px;overflow:hidden; }
.michi-cat-avatar svg { width:100%;height:100%; }

/* colonia icon edit button overlay */
#btn-edit-colonia-icon { position: relative; overflow: hidden; }

/* ── Sidebar footer (logout) ─────────────────────────────────────── */
.side-nav-footer { padding: 12px 16px; border-top: 1px solid var(--border); margin-top: auto; }
.side-nav-footer .btn-ghost { width: 100%; justify-content: flex-start; gap: 10px; }

/* ── Cat color free picker ──────────────────────────────────────── */
.cat-color-pickers { display: flex; align-items: center; gap: 14px; padding: 4px 0; }
.cat-color-preview-box {
    width: 56px; height: 56px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; overflow: hidden;
}
.cat-color-preview-box svg { width: 100%; height: 100%; }
.cat-color-sliders { display: flex; flex-direction: column; gap: 8px; flex: 1; }
.cat-color-picker-label {
    display: flex; align-items: center; justify-content: space-between;
    gap: 8px; cursor: pointer; font-size: .85rem; color: var(--text-secondary);
}
.cat-color-picker-label input[type="color"] {
    width: 36px; height: 28px; border: 2px solid var(--border);
    border-radius: 6px; padding: 2px; cursor: pointer;
    background: transparent; flex-shrink: 0;
}

/* ── Colonias feed ────────────────────────────────────────────────── */
.colonia-feed-list { padding: 8px; display: flex; flex-direction: column; gap: 8px; }
.feed-event { margin: 0; }
.feed-event-header { display: flex; gap: 10px; align-items: flex-start; padding: 12px; }
.feed-event-tarea-icon {
    width: 36px; height: 36px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    color: #000; flex-shrink: 0; font-size: .9rem;
}
.feed-event-images { display: flex; gap: 6px; flex-wrap: wrap; padding: 0 12px 12px; }
.feed-event-img { width: 80px; height: 80px; object-fit: cover; border-radius: 6px; cursor: pointer; }

/* ── Pelea de Michis (Cat Fight) ──────────────────────────────────── */
.fights-section-header {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 4px 6px; font-weight: 700; font-size: .95rem;
    color: var(--fight-gold-1); letter-spacing: .5px;
}
.fights-section-header i { color: var(--fight-gold-2); }

.fight-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    border-left: 4px solid var(--fight-gold-2);
    box-shadow: var(--fight-gold-glow), var(--shadow);
    margin-bottom: 10px;
    overflow: hidden;
    animation: fightPulse 3s ease-in-out infinite;
}
@keyframes fightPulse {
    0%,100% { box-shadow: var(--fight-gold-glow), var(--shadow); }
    50% { box-shadow: 0 0 18px rgba(184,134,11,0.6), var(--shadow); }
}
.fight-card-header {
    display: flex; align-items: center; gap: 10px; padding: 12px;
    background: linear-gradient(90deg,rgba(184,134,11,.08) 0%,transparent 100%);
}
.fight-icon {
    width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
    background: var(--fight-gold-grad); color: #333;
    display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
    box-shadow: var(--fight-gold-glow);
}
.fight-title { font-weight: 700; font-size: 1rem; }
.fight-meta { font-size: .75rem; color: var(--text-secondary); margin-top: 2px; }
.fight-badges { display: flex; gap: 5px; flex-wrap: wrap; padding: 0 12px 6px; }
.fight-badge {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 8px; border-radius: 20px; font-size: .72rem; font-weight: 600;
}
.fight-badge-pending { background: rgba(184,134,11,.18); color: var(--fight-gold-1); }
.fight-badge-active  { background: rgba(255,215,0,.18); color: var(--fight-gold-1); }
.fight-badge-finished { background: var(--bg-card2,#333); color: var(--text-muted); }
.fight-badge-invited { background: rgba(255,215,0,.18); color: var(--fight-gold-1); border: 1px solid var(--fight-gold-2); }
.fight-badge-warming { background: rgba(255,80,0,.15); color: #ff6b00; border: 1px solid rgba(255,80,0,.3); }

.fight-participants { display: flex; gap: 6px; padding: 4px 12px 8px; flex-wrap: wrap; align-items: center; }
.fight-participant-avatar {
    width: 28px; height: 28px; border-radius: 50%;
    overflow: hidden; border: 2px solid var(--bg-card);
    position: relative; flex-shrink: 0;
}
.fight-participant-avatar.accepted { border-color: var(--fight-gold-2); }
.fight-participant-avatar.invited  { border-color: var(--fight-gold-1); opacity:.7; }
.fight-participant-avatar.declined { border-color: var(--text-muted); opacity:.4; }
.fight-participant-avatar svg { width: 100%; height: 100%; }

.fight-actions { display: flex; gap: 6px; padding: 8px 12px; flex-wrap: wrap; border-top: 1px solid var(--border); }

/* Fight progress modal */
.fight-progress-row {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 0; border-bottom: 1px solid var(--border);
}
.fight-progress-row:last-child { border-bottom: none; }
.fight-progress-avatar { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; flex-shrink: 0; }
.fight-progress-avatar svg { width: 100%; height: 100%; }
.fight-progress-info { flex: 1; min-width: 0; }
.fight-progress-name { font-weight: 600; font-size: .9rem; }
.fight-progress-count { font-size: .75rem; color: var(--text-secondary); }
.fight-progress-bar-wrap {
    height: 8px; background: var(--bg-input); border-radius: 4px;
    overflow: hidden; margin-top: 4px;
}
.fight-progress-bar {
    height: 100%; border-radius: 4px;
    background: var(--fight-gold-grad); transition: width .4s ease;
}
.fight-progress-pct { font-size: .85rem; font-weight: 700; color: var(--fight-gold-1); min-width: 38px; text-align:right; }

/* Flame notification styling */
.notif-item.fight-notif {
    border-left: 3px solid var(--fight-gold-2);
    background: linear-gradient(90deg, rgba(184,134,11,.08) 0%, transparent 60%);
}
.notif-item.fight-notif .notif-icon {
    background: var(--fight-gold-grad) !important;
}

