/**
 * RÉNDUM - Estilos v2.0
 * Colores: Celeste argentino + blanco + azul marino
 * Mobile-first, Reddit-inspired
 */

/* ============ VARIABLES ============ */
:root {
    --color-primary: #75AADB;       /* Celeste argentino */
    --color-primary-dark: #4A90D9;
    --color-accent: #1B3A5C;        /* Azul marino */
    --color-accent-dark: #0F2440;
    --color-success: #28a745;
    --color-error: #dc3545;
    --color-warning: #ffc107;
    --color-info: #17a2b8;
    --color-donate: #ff6b6b;
    
    --color-bg: #f0f4f8;
    --color-surface: #ffffff;
    --color-surface-hover: #f8fafc;
    --color-border: #d1dce6;
    --color-border-light: #e8eef3;
    
    --color-text: #1a2a3a;
    --color-text-light: #4a6079;
    --color-text-muted: #8a9ab0;
    
    --color-success-bg: #d4edda;
    --color-error-bg: #f8d7da;
    --color-warning-bg: #fff3cd;
    --color-info-bg: #d1ecf1;
    
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 2rem;
    
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --radius-full: 999px;
    
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.12);
    
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.5rem;
    --space-6: 2rem;
    --space-8: 3rem;
}

/* ============ RESET ============ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body {
    font-family: var(--font-family);
    color: var(--color-text);
    background: var(--color-bg);
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

a { color: var(--color-primary-dark); text-decoration: none; }
a:hover { color: var(--color-accent); }
img { max-width: 100%; height: auto; }
ul { list-style: none; }

/* ============ LAYOUT ============ */
.container { max-width: 1100px; margin: 0 auto; padding: 0 var(--space-4); }
.main-content { flex: 1; padding: var(--space-6) 0; }

/* ============ HEADER ============ */
.main-header {
    background: var(--color-accent);
    color: white;
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: var(--shadow-md);
}
.header-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-4);
    height: 60px;
}
.logo { display: flex; align-items: center; gap: var(--space-2); text-decoration: none; color: white; flex-shrink: 0; }
.logo-img { height: 36px; width: 36px; border-radius: 50%; object-fit: cover; }
.logo-text { font-weight: 700; font-size: var(--font-size-lg); color: white; }

.main-nav { flex: 1; }
.nav-list { display: flex; gap: var(--space-1); }
.nav-link {
    color: rgba(255,255,255,0.85);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    font-weight: 500;
    transition: all 0.2s;
    white-space: nowrap;
}
.nav-link:hover { background: rgba(255,255,255,0.15); color: white; }
.nav-admin { color: var(--color-warning) !important; }

.header-actions { display: flex; align-items: center; gap: var(--space-3); flex-shrink: 0; }

/* Points Indicator */
.points-indicator {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    background: rgba(255,255,255,0.15);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    color: white;
}
.points-icon { font-size: var(--font-size-base); }
.points-value { font-weight: 700; }
.points-max { opacity: 0.7; font-size: var(--font-size-xs); }

/* Notification Bell */
.notif-bell {
    position: relative;
    color: white;
    font-size: 1.2rem;
    text-decoration: none;
    padding: var(--space-1);
}
.notif-count {
    position: absolute;
    top: -4px; right: -6px;
    background: var(--color-error);
    color: white;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 1px 5px;
    border-radius: var(--radius-full);
    min-width: 16px;
    text-align: center;
}

/* User Menu */
.user-menu { position: relative; }
.user-menu-toggle {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: none;
    border: none;
    color: white;
    cursor: pointer;
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
}
.user-menu-toggle:hover { background: rgba(255,255,255,0.1); }
.user-avatar { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; }
.user-name { font-size: var(--font-size-sm); font-weight: 500; }
.dropdown-arrow { font-size: 0.6rem; opacity: 0.7; }

.user-dropdown {
    position: absolute;
    right: 0; top: 100%;
    background: var(--color-surface);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    min-width: 200px;
    overflow: hidden;
    display: none;
    z-index: 200;
}
.user-dropdown.active { display: block; }
.dropdown-item {
    display: block;
    padding: var(--space-3) var(--space-4);
    color: var(--color-text);
    font-size: var(--font-size-sm);
    transition: background 0.15s;
}
.dropdown-item:hover { background: var(--color-surface-hover); }
.dropdown-item-danger { color: var(--color-error); }
.dropdown-divider { border: none; border-top: 1px solid var(--color-border-light); margin: 0; }

/* Auth Buttons */
.auth-buttons { display: flex; gap: var(--space-2); }

/* Mobile Menu Toggle */
.mobile-menu-toggle {
    display: none;
    flex-direction: column;
    gap: 4px;
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-2);
}
.mobile-menu-toggle span {
    width: 22px; height: 2px;
    background: white;
    border-radius: 2px;
    transition: all 0.3s;
}

/* ============ BUTTONS ============ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    border: 2px solid transparent;
    border-radius: var(--radius-sm);
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    line-height: 1.4;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-primary { background: var(--color-primary-dark); color: white; border-color: var(--color-primary-dark); }
.btn-primary:hover { background: var(--color-accent); border-color: var(--color-accent); color: white; }
.btn-secondary { background: var(--color-bg); color: var(--color-text); border-color: var(--color-border); }
.btn-outline { background: transparent; color: var(--color-primary-dark); border-color: var(--color-primary-dark); }
.btn-outline:hover { background: var(--color-primary-dark); color: white; }
.btn-success { background: var(--color-success); color: white; border-color: var(--color-success); }
.btn-danger { background: var(--color-error); color: white; border-color: var(--color-error); }
.btn-donate { background: var(--color-donate); color: white; border-color: var(--color-donate); }
.btn-donate:hover { background: #e74c3c; color: white; }

.btn-sm { padding: var(--space-1) var(--space-3); font-size: var(--font-size-xs); }
.btn-lg { padding: var(--space-3) var(--space-6); font-size: var(--font-size-lg); }
.btn-block { width: 100%; }
.btn-full { width: 100%; text-align: center; }

.btn-vote {
    background: var(--color-primary-dark);
    color: white;
    border: none;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: var(--font-size-sm);
    cursor: pointer;
    transition: all 0.2s;
}
.btn-vote:hover { background: var(--color-accent); }
.btn-vote.voted { background: var(--color-success); cursor: default; }
.btn-vote:disabled { opacity: 0.5; cursor: not-allowed; }

/* ============ BADGES ============ */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 600;
    white-space: nowrap;
}
.badge-sm { padding: 1px 6px; font-size: 0.65rem; }
.badge-validated { background: #d4edda; color: #155724; }
.badge-pending { background: var(--color-warning-bg); color: #856404; }
.badge-mod1 { background: #ffd700; color: #333; }
.badge-mod2 { background: #b0c4de; color: #1a3a5c; }
.badge-ciudadano { background: #e3f0ff; color: var(--color-accent); }
.badge-politico { background: #e8d5f5; color: #5b2d90; }
.badge-comunicador { background: #ffecd2; color: #c05621; }
.badge-project { background: #ffeeba; color: #856404; }
.badge-polemica { background: var(--color-error-bg); color: var(--color-error); }
.badge-official { background: var(--color-accent); color: white; }
.badge-user-ref { background: var(--color-bg); color: var(--color-text-light); }

/* ============ ALERTS ============ */
.alert {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-4);
    position: relative;
    font-size: var(--font-size-sm);
}
.alert-success { background: var(--color-success-bg); color: #155724; border-left: 4px solid var(--color-success); }
.alert-error { background: var(--color-error-bg); color: #721c24; border-left: 4px solid var(--color-error); }
.alert-warning { background: var(--color-warning-bg); color: #856404; border-left: 4px solid var(--color-warning); }
.alert-info { background: var(--color-info-bg); color: #0c5460; border-left: 4px solid var(--color-info); }
.alert-close { position: absolute; right: var(--space-3); top: var(--space-2); background: none; border: none; font-size: 1.2rem; cursor: pointer; opacity: 0.5; }

/* ============ FORMS ============ */
.form-group { margin-bottom: var(--space-4); }
.form-group label { display: block; font-weight: 600; font-size: var(--font-size-sm); margin-bottom: var(--space-1); color: var(--color-text); }
.form-group input, .form-group textarea, .form-group select {
    width: 100%;
    padding: var(--space-3);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    transition: border-color 0.2s;
    background: var(--color-surface);
}
.form-group input:focus, .form-group textarea:focus {
    outline: none;
    border-color: var(--color-primary-dark);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }

/* ============ PROPOSALS ============ */
.proposals-section { margin-bottom: var(--space-6); }
.proposals-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-4);
    margin-bottom: var(--space-5);
    flex-wrap: wrap;
}
.proposals-header h1 { font-size: var(--font-size-2xl); color: var(--color-accent); }
.page-description { color: var(--color-text-light); font-size: var(--font-size-sm); margin-top: var(--space-1); }
.header-actions-inline { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }

.proposals-filters { display: flex; gap: var(--space-2); }
.filter-btn {
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text-light);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    text-decoration: none;
    transition: all 0.2s;
}
.filter-btn:hover { border-color: var(--color-primary-dark); color: var(--color-primary-dark); }
.filter-btn.active { background: var(--color-primary-dark); color: white; border-color: var(--color-primary-dark); }

.proposals-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: var(--space-4); }

.proposal-card {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.2s;
    border: 1px solid var(--color-border-light);
}
.proposal-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.proposal-card.polemica { border-left: 4px solid var(--color-error); }

.proposal-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border-light);
}
.proposal-author { display: flex; align-items: center; gap: var(--space-2); }
.author-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }
.author-info { display: flex; flex-direction: column; }
.author-name { font-weight: 600; font-size: var(--font-size-sm); }
.author-name a { color: var(--color-text); }
.author-name a:hover { color: var(--color-primary-dark); }
.author-date { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.proposal-badges { display: flex; gap: var(--space-1); flex-wrap: wrap; }

.proposal-card-body { padding: var(--space-4); }
.proposal-title { font-size: var(--font-size-lg); margin-bottom: var(--space-2); line-height: 1.3; }
.proposal-title a { color: var(--color-text); }
.proposal-title a:hover { color: var(--color-primary-dark); }
.proposal-description { color: var(--color-text-light); font-size: var(--font-size-sm); line-height: 1.5; }

.proposal-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-3) var(--space-4);
    border-top: 1px solid var(--color-border-light);
    background: var(--color-surface-hover);
}
.proposal-stats { display: flex; gap: var(--space-3); font-size: var(--font-size-sm); color: var(--color-text-light); }
.support-points { font-weight: 600; color: var(--color-primary-dark); }

/* ============ PROPOSAL DETAIL ============ */
.proposal-detail { max-width: 800px; margin: 0 auto; }
.proposal-detail-header {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-5);
}
.proposal-detail-title { font-size: var(--font-size-2xl); margin-bottom: var(--space-4); color: var(--color-accent); }
.proposal-detail-meta { margin-bottom: var(--space-4); }
.proposal-detail-content {
    font-size: var(--font-size-base);
    line-height: 1.8;
    color: var(--color-text);
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-5);
    border-bottom: 1px solid var(--color-border-light);
}

/* Vote Stats Grid */
.vote-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: var(--space-3);
    margin-bottom: var(--space-5);
}
.vote-stat {
    text-align: center;
    padding: var(--space-3);
    background: var(--color-bg);
    border-radius: var(--radius-sm);
}
.vote-stat-value { display: block; font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-primary-dark); }
.vote-stat-label { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.validated-stat { background: var(--color-success-bg); }
.validated-stat .vote-stat-value { color: var(--color-success); }

.proposal-voting-section { text-align: center; margin-bottom: var(--space-5); }

/* Voters List */
.voters-section { margin-bottom: var(--space-4); }
.voters-section h4 { font-size: var(--font-size-sm); color: var(--color-text-muted); margin-bottom: var(--space-2); }
.voters-list { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.voter-chip {
    background: var(--color-bg);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
}

/* Report Section */
.report-section { text-align: center; margin-top: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--color-border-light); }

/* Polemica Warning */
.polemica-warning {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-4);
    background: var(--color-error-bg);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-4);
    border-left: 4px solid var(--color-error);
}

/* ============ COMMENTS (Reddit style) ============ */
.comments-section {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
}
.comments-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
    gap: var(--space-2);
}
.comments-sort { display: flex; gap: var(--space-2); }

.comment-form { margin-bottom: var(--space-5); }
.comment-form textarea {
    width: 100%;
    padding: var(--space-3);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    resize: vertical;
    min-height: 80px;
    margin-bottom: var(--space-2);
}
.comment-form textarea:focus { outline: none; border-color: var(--color-primary-dark); }

.comment {
    display: flex;
    gap: var(--space-2);
    padding: var(--space-3) 0;
    border-left: 2px solid var(--color-border-light);
    margin-left: var(--space-2);
    padding-left: var(--space-3);
}
.comment[data-depth="0"] { border-left: none; margin-left: 0; padding-left: 0; }

.comment-votebar {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
}
.comment-vote-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.8rem;
    color: var(--color-text-muted);
    padding: 2px;
    line-height: 1;
    transition: color 0.15s;
}
.comment-vote-btn.upvote:hover { color: var(--color-primary-dark); }
.comment-vote-btn.downvote:hover { color: var(--color-error); }
.comment-score { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-light); }

.comment-body { flex: 1; min-width: 0; }
.comment-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-1);
    flex-wrap: wrap;
}
.comment-author {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-weight: 600;
    font-size: var(--font-size-sm);
    color: var(--color-text);
}
.comment-author:hover { color: var(--color-primary-dark); }
.avatar-xs { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; }
.comment-date { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.comment-content { font-size: var(--font-size-sm); line-height: 1.5; margin-bottom: var(--space-2); }
.comment-content .mention { color: var(--color-primary-dark); font-weight: 600; }
.comment-actions { display: flex; gap: var(--space-3); }
.comment-action {
    background: none;
    border: none;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    cursor: pointer;
    font-weight: 500;
}
.comment-action:hover { color: var(--color-primary-dark); }

.reply-form { margin-top: var(--space-2); margin-bottom: var(--space-2); }
.reply-form textarea {
    width: 100%;
    padding: var(--space-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    resize: vertical;
    min-height: 60px;
    margin-bottom: var(--space-2);
}
.reply-form-actions { display: flex; gap: var(--space-2); }
.replies { margin-top: var(--space-2); }

/* ============ REFERENDUM ============ */
.referendum-detail { max-width: 800px; margin: 0 auto; }
.referendum-header { margin-bottom: var(--space-4); }
.referendum-badges-row { display: flex; gap: var(--space-2); margin-bottom: var(--space-3); }
.referendum-header h1 { font-size: var(--font-size-2xl); color: var(--color-accent); }
.referendum-info {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
    padding: var(--space-3);
    background: var(--color-bg);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
}
.referendum-description {
    background: var(--color-surface);
    padding: var(--space-4);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-4);
}

/* Status badges */
.status-badge {
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 600;
}
.status-badge.active { background: var(--color-success-bg); color: var(--color-success); }
.status-badge.upcoming { background: var(--color-info-bg); color: var(--color-info); }
.status-badge.closed { background: var(--color-bg); color: var(--color-text-muted); }

/* Voting Section */
.voting-section {
    background: var(--color-surface);
    padding: var(--space-5);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
}
.vote-form { margin-top: var(--space-4); }
.vote-options { display: flex; gap: var(--space-3); flex-wrap: wrap; justify-content: center; margin-bottom: var(--space-4); }
.vote-option {
    flex: 1;
    min-width: 140px;
    cursor: pointer;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    text-align: center;
    transition: all 0.2s;
}
.vote-option input { display: none; }
.vote-option:has(input:checked).si { border-color: var(--color-success); background: var(--color-success-bg); }
.vote-option:has(input:checked).no { border-color: var(--color-error); background: var(--color-error-bg); }
.vote-option:has(input:checked).abstencion { border-color: var(--color-text-muted); background: var(--color-bg); }
.vote-option:hover { border-color: var(--color-primary-dark); }
.option-label { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); font-weight: 500; }
.option-label .icon { font-size: 1.5rem; }

.already-voted, .login-to-vote {
    text-align: center;
    padding: var(--space-4);
    background: var(--color-bg);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-4);
}

/* Results */
.results-section {
    background: var(--color-surface);
    padding: var(--space-5);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
}
.results-display { margin-top: var(--space-4); }
.result-item { margin-bottom: var(--space-3); }
.result-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-1);
    font-size: var(--font-size-sm);
}
.result-bar-container {
    height: 12px;
    background: var(--color-bg);
    border-radius: var(--radius-full);
    overflow: hidden;
}
.result-bar { height: 100%; border-radius: var(--radius-full); transition: width 0.5s; }
.result-bar.si { background: var(--color-success); }
.result-bar.no { background: var(--color-error); }
.result-bar.abstencion { background: var(--color-text-muted); }
.total-votes { margin-top: var(--space-3); font-size: var(--font-size-sm); color: var(--color-text-light); }

.referendum-actions { margin-top: var(--space-4); }

/* Referendums Grid */
.referendums-page { margin-bottom: var(--space-6); }
.referendums-section { margin-bottom: var(--space-6); }
.referendums-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-4); }
.referendum-card {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    border: 1px solid var(--color-border-light);
}
.referendum-card.active { border-left: 4px solid var(--color-success); }
.referendum-card.upcoming { border-left: 4px solid var(--color-info); }
.referendum-card.closed { border-left: 4px solid var(--color-text-muted); }
.referendum-card-top { display: flex; justify-content: space-between; align-items: center; padding: var(--space-3) var(--space-4); }
.referendum-card-body { padding: var(--space-3) var(--space-4); }
.referendum-card-body h3 { margin-bottom: var(--space-2); }
.referendum-card-action { padding: var(--space-3) var(--space-4); }
.referendum-dates { font-size: var(--font-size-sm); color: var(--color-text-muted); margin-bottom: var(--space-2); }
.referendum-status { font-size: var(--font-size-xs); font-weight: 600; padding: 2px 8px; border-radius: var(--radius-full); }
.referendum-status.active { background: var(--color-success-bg); color: var(--color-success); }
.referendum-status.upcoming { background: var(--color-info-bg); color: var(--color-info); }
.referendum-status.closed { background: var(--color-bg); color: var(--color-text-muted); }

.results-preview { margin-top: var(--space-2); }
.mini-result-bar { display: flex; height: 8px; border-radius: var(--radius-full); overflow: hidden; }
.result-si { background: var(--color-success); }
.result-no { background: var(--color-error); }
.result-abstencion { background: var(--color-text-muted); }
.result-labels { display: flex; gap: var(--space-3); font-size: var(--font-size-xs); margin-top: var(--space-1); color: var(--color-text-light); }

/* ============ ARTICLES ============ */
.articles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-4); }
.article-card {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
}
.article-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-2); }
.article-card h3 { margin-bottom: var(--space-2); }
.article-card h3 a { color: var(--color-text); }
.article-card h3 a:hover { color: var(--color-primary-dark); }
.article-card-footer { display: flex; justify-content: space-between; font-size: var(--font-size-sm); color: var(--color-text-muted); margin-top: var(--space-3); }

.article-detail { max-width: 800px; margin: 0 auto; }
.article-detail h1 { font-size: var(--font-size-2xl); color: var(--color-accent); margin-bottom: var(--space-3); }
.article-meta { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-5); font-size: var(--font-size-sm); color: var(--color-text-light); flex-wrap: wrap; }
.article-meta a { display: flex; align-items: center; gap: var(--space-1); color: var(--color-text); font-weight: 600; }
.article-content {
    font-size: var(--font-size-base);
    line-height: 1.8;
    margin-bottom: var(--space-5);
    padding: var(--space-5);
    background: var(--color-surface);
    border-radius: var(--radius-md);
}
.article-reactions { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); }

/* ============ SHARE BUTTONS ============ */
.share-section {
    text-align: center;
    padding: var(--space-4);
    margin: var(--space-4) 0;
    background: var(--color-bg);
    border-radius: var(--radius-md);
}
.share-label { font-size: var(--font-size-sm); font-weight: 600; margin-bottom: var(--space-2); color: var(--color-text-light); }
.share-buttons { display: flex; gap: var(--space-2); justify-content: center; flex-wrap: wrap; }
.share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px; height: 40px;
    border-radius: 50%;
    font-size: var(--font-size-base);
    font-weight: 700;
    color: white;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: transform 0.2s;
}
.share-btn:hover { transform: scale(1.1); color: white; }
.share-twitter { background: #1da1f2; }
.share-facebook { background: #1877f2; }
.share-whatsapp { background: #25d366; }
.share-telegram { background: #0088cc; }
.share-copy { background: var(--color-text-muted); }

/* ============ VOTE MODAL ============ */
.modal-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: var(--space-4);
}
.modal {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    width: 100%;
    max-width: 400px;
    box-shadow: var(--shadow-lg);
}
.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-4) var(--space-5);
    border-bottom: 1px solid var(--color-border-light);
}
.modal-header h3 { font-size: var(--font-size-lg); }
.modal-close { background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--color-text-muted); }
.modal-body { padding: var(--space-5); text-align: center; }
.modal-footer { padding: var(--space-4) var(--space-5); border-top: 1px solid var(--color-border-light); display: flex; gap: var(--space-2); justify-content: center; }

.vote-slider-container { position: relative; padding: var(--space-4) 0; }
.vote-slider {
    -webkit-appearance: none;
    width: 100%;
    height: 8px;
    border-radius: var(--radius-full);
    background: linear-gradient(to right, var(--color-border), var(--color-primary-dark), var(--color-accent));
    outline: none;
}
.vote-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--color-primary-dark);
    cursor: pointer;
    box-shadow: var(--shadow-md);
}
.vote-slider-value {
    font-size: var(--font-size-3xl);
    font-weight: 800;
    color: var(--color-primary-dark);
    margin-top: var(--space-2);
}
.vote-slider-labels {
    display: flex;
    justify-content: space-between;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: var(--space-1);
}
.vote-secret-label {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    justify-content: center;
    margin-top: var(--space-3);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* ============ NOTIFICATIONS ============ */
.notifications-page { max-width: 700px; margin: 0 auto; }
.notifications-page h1 { margin-bottom: var(--space-4); }
.notifications-list { display: flex; flex-direction: column; gap: var(--space-2); }
.notification-item {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-surface);
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border-light);
}
.notification-item.unread { background: var(--color-info-bg); border-color: var(--color-info); }
.notif-icon { font-size: var(--font-size-lg); flex-shrink: 0; }
.notif-content { flex: 1; }
.notif-content a { color: var(--color-text); font-weight: 500; }
.notif-time { display: block; font-size: var(--font-size-xs); color: var(--color-text-muted); margin-top: 2px; }

/* ============ PROFILE ============ */
.profile-page { max-width: 800px; margin: 0 auto; }
.profile-header {
    display: flex;
    gap: var(--space-5);
    align-items: flex-start;
    margin-bottom: var(--space-5);
    background: var(--color-surface);
    padding: var(--space-5);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}
.profile-avatar-section { flex-shrink: 0; text-align: center; }
.profile-avatar-large img { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; border: 3px solid var(--color-primary); }
.profile-info { flex: 1; }
.profile-username { font-size: var(--font-size-xl); display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-2); }
.profile-meta { color: var(--color-text-muted); font-size: var(--font-size-sm); margin-bottom: var(--space-2); }
.profile-bio { color: var(--color-text-light); margin-bottom: var(--space-2); }

.points-card {
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
    color: white;
    padding: var(--space-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
}
.points-card h3 { margin-bottom: var(--space-2); }
.points-progress { height: 8px; background: rgba(255,255,255,0.3); border-radius: var(--radius-full); overflow: hidden; margin-bottom: var(--space-2); }
.points-bar { height: 100%; background: white; border-radius: var(--radius-full); transition: width 0.3s; }

.profile-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); margin-bottom: var(--space-5); }
.stat-card {
    text-align: center;
    padding: var(--space-4);
    background: var(--color-surface);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}
.stat-number { display: block; font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-primary-dark); }
.stat-label { font-size: var(--font-size-xs); color: var(--color-text-muted); }

.profile-edit-card {
    background: var(--color-surface);
    padding: var(--space-5);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-5);
    box-shadow: var(--shadow-sm);
}

.profile-tabs {
    display: flex;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
    border-bottom: 2px solid var(--color-border);
    padding-bottom: 0;
}
.tab-btn {
    padding: var(--space-2) var(--space-4);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all 0.2s;
}
.tab-btn:hover { color: var(--color-text); }
.tab-btn.active { color: var(--color-primary-dark); border-bottom-color: var(--color-primary-dark); }

.tab-content { display: none; }
.tab-content.active { display: block; }

.mini-proposals-list { display: flex; flex-direction: column; gap: var(--space-2); }
.mini-proposal-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-3) var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-sm);
    text-decoration: none;
    color: var(--color-text);
    transition: background 0.15s;
}
.mini-proposal-card:hover { background: var(--color-surface-hover); }
.mini-proposal-card h4 { font-size: var(--font-size-sm); margin-bottom: 2px; }

/* ============ AUTH PAGES ============ */
.auth-page {
    display: flex;
    justify-content: center;
    padding: var(--space-6) 0;
}
.auth-card {
    background: var(--color-surface);
    padding: var(--space-6);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    width: 100%;
    max-width: 440px;
}
.auth-card h1 { text-align: center; margin-bottom: var(--space-5); color: var(--color-accent); }
.auth-link { text-align: center; margin-top: var(--space-4); font-size: var(--font-size-sm); }

/* ============ CREATE PROPOSAL / FORM PAGES ============ */
.create-proposal-page { max-width: 700px; margin: 0 auto; }
.create-proposal-page h1 { color: var(--color-accent); margin-bottom: var(--space-2); }
.subtitle { color: var(--color-text-light); margin-bottom: var(--space-5); }
.proposal-form { background: var(--color-surface); padding: var(--space-5); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }
.form-actions { display: flex; gap: var(--space-3); margin-top: var(--space-4); }

/* ============ DONATE PAGE ============ */
.donate-page { max-width: 600px; margin: 0 auto; text-align: center; }
.donate-hero { background: var(--color-surface); padding: var(--space-8); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.donate-hero h1 { color: var(--color-donate); margin-bottom: var(--space-4); }

/* ============ ABOUT PAGE ============ */
.about-page { max-width: 700px; margin: 0 auto; }
.about-hero { text-align: center; margin-bottom: var(--space-6); }
.about-logo { width: 120px; height: 120px; border-radius: 50%; margin-bottom: var(--space-3); }
.about-content { background: var(--color-surface); padding: var(--space-6); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }
.about-content h2 { color: var(--color-accent); margin: var(--space-5) 0 var(--space-3); }
.about-content h2:first-child { margin-top: 0; }
.about-content p { margin-bottom: var(--space-3); line-height: 1.7; }
.about-cta { display: flex; gap: var(--space-3); justify-content: center; margin: var(--space-6) 0; }
.about-consultora { text-align: center; margin-top: var(--space-6); padding-top: var(--space-4); border-top: 1px solid var(--color-border); }
.consultora-logo-large { max-height: 50px; margin-top: var(--space-2); }

/* ============ PROJECTS PAGE ============ */
.projects-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: var(--space-4); }
.project-card {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
    border-top: 4px solid var(--color-warning);
}
.project-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-3); }
.project-badge { background: var(--color-warning-bg); color: #856404; font-weight: 700; font-size: var(--font-size-xs); padding: 2px 8px; border-radius: var(--radius-full); }
.project-date { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.project-title { font-size: var(--font-size-xl); margin-bottom: var(--space-2); }
.project-description { color: var(--color-text-light); font-size: var(--font-size-sm); margin-bottom: var(--space-3); }
.project-stats { display: flex; gap: var(--space-4); margin-bottom: var(--space-3); }
.project-stats .stat { text-align: center; }
.project-stats .stat-value { display: block; font-size: var(--font-size-xl); font-weight: 700; color: var(--color-primary-dark); }
.project-author { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); margin-bottom: var(--space-3); }
.author-avatar-small { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
.contributors-section { margin-bottom: var(--space-3); }
.contributors-section h4 { font-size: var(--font-size-sm); margin-bottom: var(--space-2); }
.contributors-list { display: flex; gap: var(--space-1); flex-wrap: wrap; margin-bottom: var(--space-2); }
.contributor img { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; }
.contribution-legend { display: flex; gap: var(--space-3); font-size: var(--font-size-xs); color: var(--color-text-muted); }

.info-box {
    background: var(--color-info-bg);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    margin-top: var(--space-6);
}
.info-box h3 { margin-bottom: var(--space-3); }
.info-box ol { padding-left: var(--space-5); }
.info-box li { margin-bottom: var(--space-2); }

/* ============ ADMIN ============ */
.admin-page { max-width: 1100px; margin: 0 auto; }
.admin-stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: var(--space-3); margin-bottom: var(--space-5); }
.admin-stat-card {
    background: var(--color-surface);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    text-align: center;
    box-shadow: var(--shadow-sm);
    transition: box-shadow 0.2s;
}
.admin-stat-card:hover { box-shadow: var(--shadow-md); }
.stat-icon { font-size: 1.5rem; margin-bottom: var(--space-1); }
.stat-value { display: block; font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-accent); }

.admin-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--color-surface);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    font-size: var(--font-size-sm);
}
.admin-table th, .admin-table td { padding: var(--space-3) var(--space-4); text-align: left; border-bottom: 1px solid var(--color-border-light); }
.admin-table th { background: var(--color-accent); color: white; font-weight: 600; }
.admin-table tr:hover { background: var(--color-surface-hover); }
.admin-actions { display: flex; gap: var(--space-2); flex-wrap: wrap; align-items: center; }
.admin-form-section { background: var(--color-surface); padding: var(--space-5); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }

/* ============ EMPTY STATE ============ */
.empty-state {
    text-align: center;
    padding: var(--space-8);
    color: var(--color-text-muted);
}
.empty-icon { font-size: 3rem; margin-bottom: var(--space-3); }
.empty-state h3 { margin-bottom: var(--space-2); color: var(--color-text-light); }

/* ============ FOOTER ============ */
.main-footer {
    background: var(--color-accent);
    color: rgba(255,255,255,0.85);
    margin-top: auto;
}
.footer-container { max-width: 1200px; margin: 0 auto; padding: var(--space-6) var(--space-4); }
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-5); margin-bottom: var(--space-5); }
.footer-col h4 { color: white; margin-bottom: var(--space-3); font-size: var(--font-size-sm); text-transform: uppercase; letter-spacing: 1px; }
.footer-logo { height: 40px; width: 40px; border-radius: 50%; object-fit: cover; margin-bottom: var(--space-2); }
.footer-tagline { font-weight: 600; color: white; }
.footer-desc { font-size: var(--font-size-sm); opacity: 0.8; }
.footer-links li { margin-bottom: var(--space-2); }
.footer-links a { color: rgba(255,255,255,0.8); font-size: var(--font-size-sm); }
.footer-links a:hover { color: white; }
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.2);
    padding-top: var(--space-4);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-3);
}
.footer-consultora {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
}
.consultora-logo { height: 30px; vertical-align: middle; }
.footer-copy { font-size: var(--font-size-xs); opacity: 0.6; }

/* ============ TOAST ============ */
.toast {
    position: fixed;
    bottom: 20px; right: 20px;
    padding: var(--space-3) var(--space-5);
    border-radius: var(--radius-sm);
    color: white;
    font-weight: 500;
    font-size: var(--font-size-sm);
    z-index: 9999;
    cursor: pointer;
    animation: slideIn 0.3s ease;
    box-shadow: var(--shadow-lg);
    max-width: 350px;
}
.toast-success { background: var(--color-success); }
.toast-error { background: var(--color-error); }
.toast-info { background: var(--color-info); }

@keyframes slideIn { from { transform: translateY(100px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes slideOut { from { transform: translateY(0); opacity: 1; } to { transform: translateY(100px); opacity: 0; } }

/* ============ UTILITY ============ */
.text-muted { color: var(--color-text-muted); }
.text-sm { font-size: var(--font-size-sm); }
.page-header { margin-bottom: var(--space-5); }
.page-header h1 { color: var(--color-accent); font-size: var(--font-size-2xl); margin-bottom: var(--space-1); }

/* ============ RESPONSIVE ============ */
@media (max-width: 768px) {
    .header-container { gap: var(--space-2); }
    .main-nav { display: none; position: fixed; top: 60px; left: 0; right: 0; background: var(--color-accent); padding: var(--space-4); z-index: 99; box-shadow: var(--shadow-lg); }
    .main-nav.active { display: block; }
    .nav-list { flex-direction: column; gap: var(--space-1); }
    .nav-link { display: block; padding: var(--space-3); }
    .mobile-menu-toggle { display: flex; }
    .user-name { display: none; }
    .dropdown-arrow { display: none; }
    .points-max { display: none; }
    
    .proposals-header { flex-direction: column; }
    .header-actions-inline { width: 100%; }
    .proposals-grid { grid-template-columns: 1fr; }
    .referendums-grid { grid-template-columns: 1fr; }
    .projects-grid { grid-template-columns: 1fr; }
    .articles-grid { grid-template-columns: 1fr; }
    
    .profile-header { flex-direction: column; align-items: center; text-align: center; }
    .profile-username { justify-content: center; }
    .profile-stats-grid { grid-template-columns: repeat(2, 1fr); }
    
    .vote-options { flex-direction: column; }
    .form-row { grid-template-columns: 1fr; }
    
    .footer-grid { grid-template-columns: 1fr; }
    .footer-bottom { flex-direction: column; text-align: center; }
    
    .admin-stats-grid { grid-template-columns: repeat(2, 1fr); }
    
    .vote-stats-grid { grid-template-columns: repeat(2, 1fr); }
    
    .about-cta { flex-direction: column; align-items: center; }
}

/* ============ RECAPTCHA ============ */
.g-recaptcha { display: flex; justify-content: center; margin: var(--space-3) 0; }
