:root{--weclap-orange:#ffb800;--weclap-orange-light:#ffd54f;--weclap-orange-dark:#e5a600;--weclap-purple:#a665d1;--weclap-purple-light:#c49be4;--weclap-green:#5cb85c;--weclap-green-light:#81c784;--weclap-dark:#1a1a1a;--platform-tiktok:#000;--platform-instagram:#e1306c;--platform-facebook:#1877f2;--platform-x:#14171a;--bg-primary:#f8fafc;--bg-secondary:#f1f5f9;--bg-card:#fff;--bg-card-hover:#fafbff;--bg-sidebar:#0f172a;--bg-sidebar-active:#1e293b;--bg-sidebar-hover:#ffffff0f;--bg-glass:#ffffffb8;--bg-glass-strong:#ffffffe0;--bg-overlay:#0f172a80;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-on-dark:#f1f5f9;--text-on-dark-muted:#f1f5f999;--text-on-orange:#1a1a1a;--score-excellent:#22c55e;--score-excellent-bg:#22c55e1a;--score-good:#84cc16;--score-good-bg:#84cc161a;--score-warning:#f59e0b;--score-warning-bg:#f59e0b1a;--score-danger:#ef4444;--score-danger-bg:#ef44441a;--score-neutral:#94a3b8;--score-neutral-bg:#94a3b81a;--cat-emission-tv:#2196f3;--cat-humour:#e91e63;--cat-theatre:#ff9800;--cat-musique:#00bcd4;--cat-cinema:#9c27b0;--cat-sport:#4caf50;--cat-enfants:#ff5722;--cat-culture:#795548;--cat-evenements:#607d8b;--priority-critical:#ef4444;--priority-high:#f59e0b;--priority-medium:#3b82f6;--priority-low:#94a3b8;--font-ui:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Consolas", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--weight-light:300;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--weight-extrabold:800;--leading-tight:1.2;--leading-normal:1.5;--leading-relaxed:1.6;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--border-subtle:1px solid #0000000f;--border-light:1px solid #00000014;--border-medium:1px solid #0000001f;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-glow-orange:0 0 20px #ffb80026;--shadow-glow-green:0 0 20px #22c55e26;--shadow-glow-red:0 0 20px #ef444426;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--page-max-width:1440px;--z-sidebar:40;--z-header:30;--z-modal:50;--z-tooltip:60;--z-toast:70}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-ui);font-size:var(--text-base);font-weight:var(--weight-regular);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{font-weight:var(--weight-bold);line-height:var(--leading-tight)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#00000026}::-webkit-scrollbar-thumb:hover{background:#00000040}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);min-height:100vh;color:var(--text-on-dark);z-index:var(--z-sidebar);transition:width var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar-logo{padding:var(--space-6) var(--space-5);align-items:center;gap:var(--space-3);border-bottom:1px solid #ffffff14;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--weclap-orange), var(--weclap-orange-dark));border-radius:var(--radius-md);width:36px;height:36px;font-weight:var(--weight-extrabold);font-size:var(--text-lg);color:var(--text-on-orange);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-text{font-size:var(--text-lg);font-weight:var(--weight-bold);letter-spacing:-.02em}.sidebar-logo-text span{color:var(--weclap-orange)}.sidebar-logo-sub{font-size:var(--text-xs);color:var(--text-on-dark-muted);margin-top:2px}.sidebar-nav{padding:var(--space-4) 0;flex:1}.sidebar-section{margin-bottom:var(--space-2)}.sidebar-section-title{padding:var(--space-2) var(--space-5);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-on-dark-muted);text-transform:uppercase;letter-spacing:.08em}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-5);margin:1px var(--space-2);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-on-dark-muted);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;display:flex;position:relative}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:var(--text-on-dark)}.sidebar-link.active{background:var(--bg-sidebar-active);color:var(--weclap-orange)}.sidebar-link.active:before{content:"";background:var(--weclap-orange);border-radius:0 var(--radius-full) var(--radius-full) 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link-icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-link.disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.sidebar-link .coming-soon{border-radius:var(--radius-full);color:var(--text-on-dark-muted);text-transform:uppercase;letter-spacing:.05em;background:#ffffff14;margin-left:auto;padding:2px 6px;font-size:.625rem}.sidebar-sub-links{padding-left:var(--space-10)}.sidebar-sub-links .sidebar-link{padding:6px var(--space-3);font-size:var(--text-xs)}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid #ffffff14}.sync-status{align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-on-dark-muted);display:flex}.sync-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;box-shadow:0 0 8px #22c55e80}.sidebar-logout-btn{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#ef4444;font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-3);background:#ef44440d;border:1px solid #ef44441a;font-weight:600;display:flex}.sidebar-logout-btn:hover{background:#ef44441a;border-color:#ef444433;transform:translate(2px)}.sync-dot.syncing{animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.main-content{margin-left:var(--sidebar-width);background:var(--bg-primary);flex:1;min-height:100vh}.page-header{z-index:var(--z-header);background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);border-bottom:var(--border-subtle);padding:var(--space-4) var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);min-height:var(--header-height);display:flex;position:sticky;top:0}.page-header-left{flex-direction:column;gap:2px;display:flex}.page-header-title{font-size:var(--text-xl);font-weight:var(--weight-bold);letter-spacing:-.02em;color:var(--text-primary)}.page-header-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.page-header-actions{align-items:center;gap:var(--space-3);display:flex}.page-content{padding:var(--space-6) var(--space-8);max-width:var(--page-max-width)}.kpi-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));display:grid}.kpi-grid-compact{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.charts-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.charts-grid-3{grid-template-columns:repeat(3,1fr)}.charts-grid .chart-card.full-width{grid-column:1/-1}.charts-grid .chart-card.span-2{grid-column:span 2}.section-title{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-4);align-items:center;gap:var(--space-2);display:flex}.section-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);margin-top:calc(-1 * var(--space-2))}@media (width<=1280px){.charts-grid{grid-template-columns:1fr}.charts-grid .chart-card.span-2{grid-column:span 1}}@media (width<=1024px){.sidebar{width:var(--sidebar-collapsed)}.sidebar-logo-text,.sidebar-logo-sub,.sidebar-section-title,.sidebar-link span,.sidebar-link .coming-soon{display:none}.sidebar-link{padding:var(--space-3);margin:1px var(--space-1);justify-content:center}.sidebar-sub-links{padding-left:0}.main-content{margin-left:var(--sidebar-collapsed)}.page-content{padding:var(--space-4) var(--space-5)}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media (width<=768px){.page-header{padding:var(--space-3) var(--space-4);flex-direction:column;align-items:flex-start}.page-header-actions{width:100%;overflow-x:auto}}.kpi-card{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-5);gap:var(--space-2);transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.kpi-card:before{content:"";background:linear-gradient(90deg, var(--kpi-color,var(--weclap-orange)), transparent);opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.kpi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.kpi-card:hover:before{opacity:1}.kpi-card-header{justify-content:space-between;align-items:center;display:flex}.kpi-card-icon{border-radius:var(--radius-lg);background:var(--kpi-bg,var(--score-neutral-bg));width:40px;height:40px;color:var(--kpi-color,var(--text-secondary));flex-shrink:0;justify-content:center;align-items:center;display:flex}.kpi-card-trend{font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--radius-full);align-items:center;gap:4px;padding:3px 8px;display:flex}.kpi-card-trend.up{color:var(--score-excellent);background:var(--score-excellent-bg)}.kpi-card-trend.down{color:var(--score-danger);background:var(--score-danger-bg)}.kpi-card-trend.neutral{color:var(--text-muted);background:var(--score-neutral-bg)}.kpi-card-value{font-family:var(--font-mono);font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--text-primary);letter-spacing:-.02em;line-height:1}.kpi-card-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--weight-medium)}.kpi-card-tooltip{font-size:var(--text-xs);color:var(--text-muted);line-height:var(--leading-relaxed);display:none}.kpi-card:hover .kpi-card-tooltip{display:block}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-semibold);white-space:nowrap;align-items:center;gap:4px;padding:3px 10px;line-height:1.4;display:inline-flex}.badge-excellent{background:var(--score-excellent-bg);color:var(--score-excellent)}.badge-good{background:var(--score-good-bg);color:var(--score-good)}.badge-warning{background:var(--score-warning-bg);color:var(--score-warning)}.badge-danger{background:var(--score-danger-bg);color:var(--score-danger)}.badge-neutral{background:var(--score-neutral-bg);color:var(--score-neutral)}.badge-category{border-radius:var(--radius-sm);font-size:.6875rem;font-weight:var(--weight-semibold);color:#fff;padding:2px 8px}.badge-priority{padding:2px 8px;font-size:.6875rem}.badge-priority.critical{color:var(--priority-critical);background:#ef44441a}.badge-priority.high{color:var(--priority-high);background:#f59e0b1a}.badge-priority.medium{color:var(--priority-medium);background:#3b82f61a}.badge-priority.low{color:var(--priority-low);background:#94a3b81a}.score-gauge{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.score-gauge svg{filter:drop-shadow(0 0 6px var(--gauge-color,var(--score-neutral)));transform:rotate(-90deg)}.score-gauge-value{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:var(--weight-bold)}.score-gauge-label{font-size:var(--text-sm);color:var(--text-secondary);text-align:center}.btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-semibold);transition:all var(--transition-base);cursor:pointer;white-space:nowrap;padding:8px 16px;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--weclap-orange), var(--weclap-orange-dark));color:var(--text-on-orange);box-shadow:var(--shadow-sm), 0 0 0 0 #ffb80000}.btn-primary:hover{box-shadow:var(--shadow-md), var(--shadow-glow-orange);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:var(--border-light)}.btn-secondary:hover{background:var(--bg-secondary);border-color:#00000026}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-danger{background:var(--score-danger-bg);color:var(--score-danger)}.btn-danger:hover{background:#ef444426}.btn-sm{font-size:var(--text-xs);padding:5px 12px}.btn-icon{border-radius:var(--radius-md);padding:8px}.data-table-container{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden}.data-table-header{padding:var(--space-4) var(--space-5);border-bottom:var(--border-subtle);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.data-table-title{font-size:var(--text-md);font-weight:var(--weight-bold)}.data-table-actions{align-items:center;gap:var(--space-2);display:flex}.data-table{width:100%;font-size:var(--text-sm)}.data-table thead{background:var(--bg-secondary);z-index:1;position:sticky;top:0}.data-table th{padding:var(--space-3) var(--space-4);font-weight:var(--weight-semibold);color:var(--text-secondary);text-align:left;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em}.data-table th:hover{color:var(--text-primary)}.data-table th.sorted{color:var(--weclap-orange)}.data-table th .sort-icon{opacity:.4;margin-left:4px;display:inline-flex}.data-table th.sorted .sort-icon{opacity:1}.data-table td{padding:var(--space-3) var(--space-4);border-top:var(--border-subtle);color:var(--text-primary);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-card-hover)}.data-table tbody tr.clickable{cursor:pointer}.data-table-cell-mono{font-family:var(--font-mono);font-size:var(--text-xs)}.data-table-footer{padding:var(--space-3) var(--space-5);border-top:var(--border-subtle);font-size:var(--text-sm);color:var(--text-secondary);justify-content:space-between;align-items:center;display:flex}.pagination{align-items:center;gap:var(--space-1);display:flex}.pagination button{border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);transition:all var(--transition-fast);padding:6px 10px}.pagination button:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.pagination button.active{background:var(--weclap-orange);color:var(--text-on-orange)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.alert-card{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);gap:var(--space-4);transition:all var(--transition-base);display:flex;position:relative;overflow:hidden}.alert-card:before{content:"";background:var(--alert-color,var(--score-neutral));width:4px;height:100%;position:absolute;top:0;left:0}.alert-card:hover{box-shadow:var(--shadow-md)}.alert-card-icon{border-radius:var(--radius-md);background:var(--alert-bg,var(--score-neutral-bg));width:36px;height:36px;color:var(--alert-color,var(--score-neutral));flex-shrink:0;justify-content:center;align-items:center;display:flex}.alert-card-body{flex:1;min-width:0}.alert-card-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);margin-bottom:4px}.alert-card-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.alert-card-meta{align-items:center;gap:var(--space-3);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.alert-card-actions{gap:var(--space-2);margin-top:var(--space-3);display:flex}.diagnostic-card{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);align-items:flex-start;gap:var(--space-3);display:flex}.diagnostic-icon{border-radius:var(--radius-md);width:28px;height:28px;font-size:var(--text-md);flex-shrink:0;justify-content:center;align-items:center;display:flex}.diagnostic-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.chart-card{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-5);transition:box-shadow var(--transition-base)}.chart-card:hover{box-shadow:var(--shadow-md)}.chart-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.chart-card-title{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--text-primary)}.chart-card-subtitle{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.chart-card-body{width:100%;min-height:250px}.filter-bar{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.filter-select{border-radius:var(--radius-md);border:var(--border-light);background:var(--bg-card);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2394A3B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:7px 28px 7px 12px}.filter-select:hover{border-color:#0003}.filter-select:focus{border-color:var(--weclap-orange);box-shadow:0 0 0 3px #ffb8001a}.period-selector{background:var(--bg-secondary);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.period-btn{border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);transition:all var(--transition-fast);padding:5px 12px}.period-btn:hover{color:var(--text-primary)}.period-btn.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-xs)}.search-input{position:relative}.search-input input{border-radius:var(--radius-md);border:var(--border-light);background:var(--bg-card);font-size:var(--text-sm);color:var(--text-primary);width:260px;transition:all var(--transition-base);outline:none;padding:8px 12px 8px 36px}.search-input input::placeholder{color:var(--text-muted)}.search-input input:focus{border-color:var(--weclap-orange);width:320px;box-shadow:0 0 0 3px #ffb8001a}.search-input-icon{color:var(--text-muted);width:18px;height:18px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.tooltip-wrapper{cursor:help;display:inline-flex;position:relative}.tooltip-content{background:var(--bg-sidebar);color:var(--text-on-dark);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);white-space:nowrap;white-space:normal;max-width:280px;line-height:var(--leading-relaxed);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:var(--z-tooltip);pointer-events:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-wrapper:hover .tooltip-content{opacity:1;visibility:visible}.state-container{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.state-icon{border-radius:var(--radius-xl);width:56px;height:56px;margin-bottom:var(--space-4);background:var(--bg-secondary);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.state-title{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.state-text{font-size:var(--text-sm);color:var(--text-secondary);max-width:400px}.spinner{border:3px solid var(--bg-secondary);border-top-color:var(--weclap-orange);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.tabs{border-bottom:2px solid var(--bg-secondary);margin-bottom:var(--space-6);gap:0;display:flex}.tab-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);transition:all var(--transition-base);position:relative}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--weclap-orange);font-weight:var(--weight-semibold)}.tab-btn.active:after{content:"";background:var(--weclap-orange);border-radius:var(--radius-full) var(--radius-full) 0 0;height:2px;position:absolute;bottom:-2px;left:0;right:0}.export-btn{align-items:center;gap:var(--space-2);border:var(--border-light);border-radius:var(--radius-md);background:var(--bg-card);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);transition:all var(--transition-base);padding:8px 16px;display:inline-flex}.export-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:#00000026}.reco-card{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-5) var(--space-6);transition:all var(--transition-base);position:relative}.reco-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.reco-card-header{align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.reco-card-title{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--text-primary);flex:1}.reco-card-badges{gap:var(--space-2);flex-wrap:wrap;display:flex}.reco-card-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.reco-card-data{font-size:var(--text-xs);color:var(--text-muted);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.reco-card-actions{gap:var(--space-2);flex-wrap:wrap;display:flex}.reco-card.treated{opacity:.6}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.animate-in{animation:.4s ease-out both fadeIn}.animate-in-delay-1{animation-delay:50ms}.animate-in-delay-2{animation-delay:.1s}.animate-in-delay-3{animation-delay:.15s}.animate-in-delay-4{animation-delay:.2s}.cal-grid-container{background:var(--bg-card);border-radius:var(--radius-lg);border:var(--border-light);box-shadow:var(--shadow-sm);overflow:hidden}.cal-header{background:var(--bg-secondary);border-bottom:var(--border-light);grid-template-columns:repeat(7,1fr);display:grid}.cal-header-day{padding:var(--space-3);text-align:center;font-weight:600;font-size:var(--text-sm);color:var(--text-secondary)}.cal-grid{background:var(--bg-card);grid-template-columns:repeat(7,1fr);display:grid}.cal-cell{min-height:120px;padding:var(--space-2);border-right:var(--border-subtle);border-bottom:var(--border-subtle);flex-direction:column;display:flex}.cal-cell:nth-child(7n){border-right:none}.cal-cell-empty{background:#00000005}.cal-cell-today{background:#ffb8000d}.cal-cell-today .cal-cell-day{background:var(--weclap-orange);color:var(--text-on-orange);border-radius:var(--radius-full);justify-content:center;align-items:center;width:24px;height:24px;font-weight:700;display:flex}.cal-cell-day{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2);align-self:flex-end;font-weight:500}.cal-cell-posts{flex-direction:column;flex:1;gap:4px;display:flex}.cal-post{background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-fast);border-left:3px solid #0000;border-radius:4px;align-items:center;gap:6px;padding:4px 6px;font-size:10px;display:flex}.cal-post:hover{box-shadow:var(--shadow-sm);background:var(--bg-card-hover);transform:translateY(-1px)}.cal-post-tiktok{border-left-color:var(--platform-tiktok)}.cal-post-instagram{border-left-color:var(--platform-instagram)}.cal-post-facebook{border-left-color:var(--platform-facebook)}.cal-post-x{border-left-color:var(--platform-x)}.cal-post-text{white-space:nowrap;text-overflow:ellipsis;color:var(--text-primary);flex:1;overflow:hidden}.cal-post-score{font-family:var(--font-mono);border-radius:3px;padding:2px 4px;font-weight:700}.cal-post-more{color:var(--text-muted);text-align:center;cursor:pointer;background:#00000005;border-radius:4px;padding:2px;font-size:10px}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--bg-secondary)}.recharts-text{font-family:var(--font-ui);fill:var(--text-muted);font-size:11px}.recharts-tooltip-wrapper{outline:none}.chart-tooltip{background:var(--bg-sidebar)!important;border-radius:var(--radius-lg)!important;padding:var(--space-3) var(--space-4)!important;box-shadow:var(--shadow-xl)!important;border:none!important}.chart-tooltip .recharts-tooltip-label{font-weight:var(--weight-semibold);margin-bottom:var(--space-2);font-size:var(--text-sm);color:var(--text-on-dark)!important}.chart-tooltip .recharts-tooltip-item{color:var(--text-on-dark)!important;font-size:var(--text-xs)!important;padding:2px 0!important}.heatmap-container{width:100%;overflow-x:auto}.heatmap-grid{gap:3px;min-width:600px;display:grid}.heatmap-cell{border-radius:var(--radius-sm);font-size:.625rem;font-family:var(--font-mono);font-weight:var(--weight-medium);transition:transform var(--transition-fast);cursor:default;aspect-ratio:1.5;justify-content:center;align-items:center;display:flex}.heatmap-cell:hover{z-index:2;box-shadow:var(--shadow-lg);transform:scale(1.15)}.heatmap-label{font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--weight-medium);justify-content:center;align-items:center;display:flex}.funnel-container{gap:var(--space-2);padding:var(--space-4) 0;flex-direction:column;display:flex}.funnel-step{align-items:center;gap:var(--space-3);display:flex}.funnel-bar{border-radius:var(--radius-md);height:40px;padding:0 var(--space-4);transition:all var(--transition-base);align-items:center;min-width:60px;display:flex}.funnel-bar:hover{filter:brightness(1.05);box-shadow:var(--shadow-md)}.funnel-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-primary);min-width:100px}.funnel-value{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:#fff}.funnel-pct{font-size:var(--text-xs);color:var(--text-muted);margin-left:var(--space-2);font-family:var(--font-mono)}.campaign-detail-header{gap:var(--space-6);margin-bottom:var(--space-6);display:flex}.campaign-detail-info{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);flex:1}.campaign-detail-score{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);width:200px;padding:var(--space-6);flex-direction:column;justify-content:center;align-items:center;display:flex}.campaign-info-row{align-items:center;gap:var(--space-2);padding:var(--space-2) 0;border-bottom:var(--border-subtle);display:flex}.campaign-info-row:last-child{border-bottom:none}.campaign-info-label{font-size:var(--text-sm);color:var(--text-muted);min-width:140px}.campaign-info-value{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-primary)}.comparison-bar{align-items:center;gap:var(--space-3);padding:var(--space-2) 0;display:flex}.comparison-label{font-size:var(--text-sm);color:var(--text-secondary);min-width:160px}.comparison-track{background:var(--bg-secondary);border-radius:var(--radius-full);flex:1;height:8px;position:relative;overflow:hidden}.comparison-fill{border-radius:var(--radius-full);height:100%;transition:width .6s}.comparison-value{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-align:right;min-width:50px}.settings-section{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-4)}.settings-section-title{font-size:var(--text-md);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-4);align-items:center;gap:var(--space-2);display:flex}.settings-row{align-items:center;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:var(--border-subtle);display:flex}.settings-row:last-child{border-bottom:none}.settings-label{flex:1}.settings-label-title{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-primary)}.settings-label-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.settings-input{border:var(--border-light);border-radius:var(--radius-md);background:var(--bg-primary);font-size:var(--text-sm);color:var(--text-primary);width:300px;transition:all var(--transition-base);outline:none;padding:8px 12px}.settings-input:focus{border-color:var(--weclap-orange);box-shadow:0 0 0 3px #ffb8001a}.settings-input[type=password]{font-family:var(--font-mono);letter-spacing:.1em}.toggle{cursor:pointer;width:44px;height:24px;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--bg-secondary);border-radius:var(--radius-full);transition:all var(--transition-base);position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--weclap-orange)}.toggle-thumb{width:18px;height:18px;box-shadow:var(--shadow-sm);transition:all var(--transition-base);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.toggle input:checked~.toggle-thumb{left:23px}.export-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.export-card{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-5);gap:var(--space-3);transition:all var(--transition-base);flex-direction:column;display:flex}.export-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.export-card-icon{border-radius:var(--radius-lg);width:44px;height:44px;color:var(--weclap-orange);background:linear-gradient(135deg,#ffb8001a,#ffb8000d);justify-content:center;align-items:center;display:flex}.export-card-title{font-size:var(--text-md);font-weight:var(--weight-semibold)}.export-card-desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}.placeholder-page{text-align:center;min-height:60vh;padding:var(--space-8);flex-direction:column;justify-content:center;align-items:center;display:flex}.placeholder-icon{border-radius:var(--radius-2xl);background:linear-gradient(135deg, var(--bg-secondary), #ffb8000d);width:80px;height:80px;color:var(--text-muted);margin-bottom:var(--space-6);justify-content:center;align-items:center;display:flex}.placeholder-title{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.placeholder-text{font-size:var(--text-md);color:var(--text-secondary);max-width:500px;line-height:var(--leading-relaxed)}.table-scroll{overflow-x:auto}.reco-filters{gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.reco-counter{gap:var(--space-3);margin-bottom:var(--space-6);display:flex}.reco-counter-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);background:var(--bg-card);border:var(--border-subtle);font-size:var(--text-sm);display:flex}.reco-counter-num{font-family:var(--font-mono);font-weight:var(--weight-bold);font-size:var(--text-lg)}.reco-list{gap:var(--space-4);flex-direction:column;display:flex}.login-container{width:100%;min-height:100vh;padding:var(--space-4);background:#0f172a;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-bg-shapes{z-index:1;position:absolute;inset:0}.shape{filter:blur(80px);opacity:.5;border-radius:50%;position:absolute}.shape-1{background:var(--weclap-orange);width:500px;height:500px;animation:10s infinite alternate float;top:-100px;right:-100px}.shape-2{background:var(--weclap-purple);width:400px;height:400px;animation:8s infinite alternate-reverse float;bottom:-100px;left:-100px}@keyframes float{0%{transform:translate(0)}to{transform:translate(40px,40px)}}.login-card{-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-2xl);width:100%;max-width:440px;padding:var(--space-10);z-index:2;background:#ffffff08;border:1px solid #ffffff1a;box-shadow:0 25px 50px -12px #00000080}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{background:var(--weclap-orange);width:56px;height:56px;color:var(--text-on-orange);font-weight:800;font-size:var(--text-2xl);border-radius:var(--radius-lg);margin:0 auto var(--space-4);justify-content:center;align-items:center;display:flex;box-shadow:0 0 20px #ffb80066}.login-title{color:#fff;font-size:var(--text-2xl);font-weight:700}.login-title span{color:var(--weclap-orange)}.login-subtitle{color:var(--text-on-dark-muted);font-size:var(--text-sm);margin-top:var(--space-1)}.login-form .form-group{margin-bottom:var(--space-5)}.login-form label{color:var(--text-on-dark);font-size:var(--text-xs);margin-bottom:var(--space-2);font-weight:600;display:block}.login-form .input-wrapper{position:relative}.login-form .input-icon{left:var(--space-3);color:var(--text-on-dark-muted);position:absolute;top:50%;transform:translateY(-50%)}.login-form input[type=email],.login-form input[type=password]{border-radius:var(--radius-md);width:100%;padding:var(--space-3) var(--space-3) var(--space-3) 42px;color:#fff;font-size:var(--text-sm);transition:all var(--transition-base);background:#ffffff0d;border:1px solid #ffffff1a}.login-form input:focus{border-color:var(--weclap-orange);background:#ffffff14;outline:none;box-shadow:0 0 0 4px #ffb8001a}.forgot-password{color:var(--weclap-orange);font-size:var(--text-xs);text-decoration:none}.form-options{margin:var(--space-4) 0}.login-btn{background:var(--weclap-orange);width:100%;color:var(--text-on-orange);border-radius:var(--radius-md);padding:var(--space-3);font-weight:700;font-size:var(--text-sm);justify-content:center;align-items:center;gap:var(--space-2);cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-6);border:none;display:flex}.login-btn:hover:not(:disabled){background:var(--weclap-orange-light);transform:translateY(-1px);box-shadow:0 10px 15px -3px #ffb8004d}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-error{border-radius:var(--radius-md);padding:var(--space-3);color:#ef4444;font-size:var(--text-xs);align-items:center;gap:var(--space-2);margin-bottom:var(--space-5);background:#ef44441a;border:1px solid #ef444433;display:flex}.login-footer{margin-top:var(--space-8);text-align:center;color:var(--text-on-dark-muted);font-size:10px}.checkbox-container{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;padding-left:28px;display:flex;position:relative;color:var(--text-on-dark-muted)!important;font-weight:400!important}.checkbox-container input{opacity:0;cursor:pointer;position:absolute}.checkmark{background:#ffffff1a;border:1px solid #fff3;border-radius:4px;width:18px;height:18px;position:absolute;top:0;left:0}.checkbox-container:hover input~.checkmark{background:#ffffff26}.checkbox-container input:checked~.checkmark{background:var(--weclap-orange);border-color:var(--weclap-orange)}.checkmark:after{content:"";border:solid var(--text-on-orange);border-width:0 2px 2px 0;width:4px;height:9px;display:none;position:absolute;top:2px;left:6px;transform:rotate(45deg)}.checkbox-container input:checked~.checkmark:after{display:block}
