:root{--color-primary: #28a745;--color-primary-hover: #218838;--color-primary-light: #e7f5e7;--color-primary-gradient: linear-gradient(135deg, #28a745, #20c997);--color-danger: #dc3545;--color-danger-bg: #f8d7da;--color-danger-border: #f5c6cb;--color-danger-text: #721c24;--color-success: #28a745;--color-success-bg: #d4edda;--color-success-border: #c3e6cb;--color-success-text: #155724;--color-warning-bg: #fff3cd;--color-warning-text: #856404;--color-info-bg: #d1ecf1;--color-info-text: #0c5460;--color-info-border: #bee5eb;--color-text: #1a1a1a;--color-text-secondary: #495057;--color-text-muted: #6c757d;--color-text-light: #666;--color-bg: #f8f9fa;--color-bg-page: #f5f5f5;--color-bg-white: #fff;--color-border: #dee2e6;--color-border-light: #e9ecef;--color-border-lighter: #f1f3f4;--color-chart-1: #2d8a4e;--color-chart-2: #e09f3e;--color-chart-3: #5ab87a;--color-chart-4: #c75146;--color-chart-5: #3a9e8f;--color-chart-6: #8cb369;--color-chart-grid: #eee;--color-chart-tick: #999;--color-chart-label: #555;--color-chart-tooltip-bg: rgba(255,255,255,.96);--color-chart-tooltip-border: #ddd;--color-chart-dup: #7c9bb5;--heatmap-hourly: 45, 138, 78;--heatmap-city: 90, 184, 122;--heatmap-area: 58, 158, 143;--color-alert-warn-bg: #fef9ef;--color-alert-warn-border: #f5deb3;--color-alert-warn-text: #8a6d3b;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 32px;--space-4xl: 48px;--section-gap: 32px;--section-gap-lg: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 2px 8px rgba(0,0,0,.04);--shadow-hover: 0 4px 12px rgba(0,0,0,.08);--text-xs: 11px;--text-sm: 12px;--text-base: 14px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 24px;--text-3xl: 32px;--text-4xl: 36px;--touch-min: 44px;--color-plan-black: #1a1a1a;--color-plan-black-text: #ffffff;--color-plan-gold: #D4AF37;--color-plan-gold-text: #3d2b00;--color-plan-platinum: #e2e8f0;--color-plan-platinum-text: #334155;--color-plan-green: #4ade80;--color-plan-green-text: #14532d;--color-login-gradient: linear-gradient(135deg, #1a2e1a 0%, #163e2a 50%, #0f6034 100%)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-page)}.container{max-width:1200px;margin:0 auto;padding:20px}.header{background:var(--color-bg-white);padding:var(--space-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-xl)}.header h1{color:var(--color-text);margin-bottom:10px}.connection-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:5px;font-weight:500;color:var(--color-text-secondary)}.form-group input,.form-group select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #28a74540}.btn-primary:focus-visible,.btn-secondary:focus-visible,.btn-quick-date:focus-visible,.sidebar-menu-link:focus-visible,.hamburger-menu:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn{padding:10px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);font-weight:500;transition:background-color .2s;min-height:var(--touch-min)}.btn:hover{background:var(--color-primary-hover)}.btn:disabled{background:var(--color-text-muted);cursor:not-allowed}.btn-secondary{background:var(--color-text-muted)}.btn-secondary:hover{background:#545b62}.dashboard-grid{display:grid;grid-template-columns:300px 1fr;gap:20px}.sidebar{background:white;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:fit-content}.main-content{background:white;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.tables-list{list-style:none}.tables-list li{padding:8px 12px;border-radius:4px;cursor:pointer;margin-bottom:5px;transition:background-color .2s}.tables-list li:hover{background:#f8f9fa}.tables-list li.active{background:#007bff;color:#fff}.query-editor{margin-bottom:20px}.query-editor textarea{width:100%;height:150px;padding:12px;border:1px solid #ddd;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;resize:vertical}.query-editor textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.results-table{width:100%;border-collapse:collapse;margin-top:20px}.results-table th,.results-table td{padding:12px;text-align:left;border-bottom:1px solid #ddd}.results-table th{background:#f8f9fa;font-weight:600;color:#495057}.results-table tr:hover{background:#f8f9fa}.status-message{padding:12px;border-radius:4px;margin-bottom:20px}.status-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.status-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:#6c757d}.chart-container{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:8px}.dashboard{display:flex;min-height:100vh;background:var(--color-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.dashboard-sidebar{width:220px;background:var(--color-bg-white);border-right:1px solid var(--color-border-light);padding:var(--space-2xl) 0;position:fixed;height:100vh;overflow:hidden;transition:width .2s cubic-bezier(.4,0,.2,1);z-index:100}.dashboard-sidebar:not(.collapsed){box-shadow:4px 0 16px #00000014}.dashboard-sidebar.collapsed{width:70px}.sidebar-label{opacity:1;white-space:nowrap;overflow:hidden;transition:opacity .15s ease .05s}.dashboard-sidebar.collapsed .sidebar-label{opacity:0;width:0;transition:opacity .1s ease}.dashboard-sidebar.collapsed .sidebar-header{padding:0 var(--space-md) var(--space-2xl) var(--space-md)}.dashboard-sidebar.collapsed .sidebar-logo{justify-content:center}.dashboard-sidebar.collapsed .sidebar-menu-link{justify-content:center;padding:var(--space-md)}.dashboard-main{flex:1;margin-left:70px;padding:var(--space-xl) var(--space-2xl)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--section-gap)}.page-header{margin-bottom:var(--section-gap)}.page-header__top{display:flex;align-items:baseline;gap:var(--space-md);margin-bottom:var(--space-lg)}.page-header__controls{display:inline-flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap}@media (max-width: 768px){.page-header__controls{flex-direction:column;align-items:stretch}}.dashboard-title{margin:0;font-size:var(--text-3xl);font-weight:700;color:var(--color-text);margin-bottom:var(--space-sm)}.dashboard-subtitle{color:var(--color-text-muted);font-size:var(--text-lg);margin:0}.dashboard-actions{display:flex;gap:var(--space-md)}.btn-primary{background:var(--color-primary);color:#fff;border:none;padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-lg);font-weight:600;font-size:var(--text-base);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);transition:background-color .2s ease;min-height:var(--touch-min)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-bg-white);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-lg);font-weight:600;font-size:var(--text-base);cursor:pointer;transition:background-color .2s ease;min-height:var(--touch-min)}.btn-secondary:hover{background:var(--color-bg);border-color:#adb5bd}.btn-quick-date{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);background:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background-color .15s ease;font-weight:500;min-height:var(--touch-min);display:inline-flex;align-items:center}.btn-quick-date:hover{background:var(--color-border-light);border-color:#adb5bd}.btn-quick-date:active{background:var(--color-border)}.sidebar-header{padding:0 var(--space-2xl) var(--space-2xl) var(--space-2xl);border-bottom:1px solid var(--color-border-lighter)}.sidebar-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}.sidebar-logo-icon{width:var(--touch-min);height:var(--touch-min);background:var(--color-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:var(--text-lg);border:none}.hamburger-menu{cursor:default}.sidebar-logo-text{font-size:var(--text-xl);font-weight:700;color:#1a1a1a;transition:opacity .2s ease}.sidebar-search{position:relative}.sidebar-search input{width:100%;padding:8px 12px 8px 36px;border:1px solid #e9ecef;border-radius:8px;font-size:14px;background:#f8f9fa}.sidebar-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6c757d;font-size:14px}.sidebar-nav{padding:24px 0}.sidebar-section{margin-bottom:32px}.sidebar-section-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:var(--space-md);padding:0 var(--space-2xl)}.sidebar-menu{list-style:none;padding:0;margin:0}.sidebar-menu-item{margin-bottom:4px}.sidebar-menu-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-2xl);color:var(--color-text-secondary);text-decoration:none;font-size:var(--text-base);font-weight:500;transition:background-color .15s ease,color .15s ease;position:relative;min-height:var(--touch-min);border:none;background:none;width:100%;cursor:pointer}.sidebar-menu-link:hover{background:var(--color-bg);color:var(--color-primary)}.sidebar-menu-link.active{background:var(--color-primary-light);color:var(--color-primary);border-right:3px solid var(--color-primary)}.sidebar-menu-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.sidebar-menu-badge{background:var(--color-primary);color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px;margin-left:auto}.stats-section{margin-bottom:var(--space-2xl)}.stats-section-title{font-size:var(--text-sm);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:var(--space-md)}.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-lg)}.stats-card{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:var(--space-lg) var(--space-xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-lighter);transition:box-shadow .2s ease;position:relative;overflow:hidden}.stats-card:hover{box-shadow:var(--shadow-hover)}.stats-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm)}.stats-card-title{font-size:var(--text-base);font-weight:600;color:var(--color-text-muted);margin:0;display:flex;align-items:center;gap:var(--space-sm)}.stats-card-icon{width:20px;height:20px;border-radius:var(--radius-md);background:var(--color-bg);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);color:var(--color-text-muted)}.main-stat{margin-bottom:var(--space-xs)}.main-stat-value{font-size:var(--text-2xl);font-weight:700;line-height:1;margin-bottom:var(--space-xs);color:var(--color-text)}.main-stat-change{font-size:var(--text-sm);font-weight:500;display:flex;align-items:center;gap:var(--space-xs);color:var(--color-text-muted)}.main-stat-change.increase{color:var(--color-primary)}.main-stat-change.decrease{color:var(--color-danger)}.sub-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.sub-stat{text-align:left}.sub-stat-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-xs);font-weight:500}.sub-stat-value{font-size:var(--text-xl);font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:var(--space-sm)}.sub-stat-change{font-size:var(--text-xs);padding:2px 6px;border-radius:var(--radius-sm);background:var(--color-primary-light);color:var(--color-primary);font-weight:500}.sub-stat-change.decrease{background:rgba(220,53,69,.1);color:var(--color-danger)}.charts-section{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);margin-bottom:var(--section-gap)}.chart-section{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-lighter);overflow:hidden;min-width:0}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2xl)}.chart-title{font-size:var(--text-xl);font-weight:600;color:var(--color-text);margin:0}.chart-subtitle{font-size:var(--text-base);color:var(--color-text-muted);margin:4px 0 0}.chart-content{width:100%;height:400px;overflow:hidden;position:relative}.sidebar-panel{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-lighter)}.sidebar-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sidebar-panel-title{font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin:0}.sidebar-panel-action{font-size:var(--text-sm);color:var(--color-primary);text-decoration:none;font-weight:600;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-primary);border-radius:var(--radius-md);transition:background-color .15s ease,color .15s ease;min-height:var(--touch-min);display:inline-flex;align-items:center}.sidebar-panel-action:hover{background:var(--color-primary);color:#fff}.team-member{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f1f3f4}.team-member:last-child{border-bottom:none}.team-member-avatar{width:40px;height:40px;border-radius:var(--radius-lg);background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.team-member-info{flex:1}.team-member-name{font-size:var(--text-base);font-weight:600;color:var(--color-text);margin:0 0 2px}.team-member-role{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.team-member-status{font-size:10px;padding:4px 8px;border-radius:12px;font-weight:600;text-transform:uppercase}.status-completed{background:var(--color-success-bg);color:var(--color-success-text)}.status-progress{background:var(--color-warning-bg);color:var(--color-warning-text)}.status-pending{background:var(--color-danger-bg);color:var(--color-danger-text)}@media (max-width: 1200px){.charts-section{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard{flex-direction:column}.dashboard-sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--color-border-light);padding:var(--space-lg) 0}.dashboard-main{margin-left:0;padding:var(--space-lg)}.dashboard-header{flex-direction:column;gap:var(--space-lg);align-items:flex-start}.dashboard-title{font-size:var(--text-2xl)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.charts-section{grid-template-columns:1fr;gap:var(--space-xl)}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr;gap:var(--space-md)}.dashboard-main{padding:var(--space-md)}.main-stat-value{font-size:28px}.dashboard-actions{flex-direction:column;gap:var(--space-sm);align-items:stretch}.dashboard-actions>div{flex-direction:column;gap:var(--space-sm)}}@media (max-width: 375px){.dashboard-main{padding:var(--space-sm)}.stats-card{padding:var(--space-lg)}.main-stat-value{font-size:24px}.chart-section{padding:var(--space-lg)}}.heatmap-section{margin-bottom:var(--section-gap);width:100%}.heatmap-grid{width:100%!important;max-width:100%!important;overflow:hidden}.heatmap-cell{min-width:0!important;width:100%!important}@media (max-width: 1200px){.heatmap-grid{grid-template-columns:repeat(12,1fr)!important;gap:var(--space-xs)!important}}@media (max-width: 768px){.heatmap-grid{grid-template-columns:repeat(8,1fr)!important;gap:var(--space-xs)!important}.heatmap-cell{min-height:var(--touch-min)!important}.chart-content{height:300px!important}}@media (max-width: 480px){.heatmap-grid{grid-template-columns:repeat(6,1fr)!important;gap:3px!important}.heatmap-cell{min-height:var(--touch-min)!important}.chart-content{height:250px!important}.heatmap-legend{flex-direction:column!important;gap:12px!important;align-items:flex-start!important}.heatmap-content{padding:15px!important}}.taipei-area-heatmap-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))!important;gap:10px!important;width:100%!important}.taipei-area-heatmap-cell{min-height:85px!important;transition:all .2s ease!important}@media (max-width: 1200px){.taipei-area-heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))!important;gap:8px!important}.taipei-area-heatmap-cell{min-height:80px!important;padding:12px 8px!important}}@media (max-width: 768px){.taipei-area-heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))!important;gap:8px!important}.taipei-area-heatmap-cell{min-height:75px!important;padding:10px 6px!important;font-size:11px!important}}@media (max-width: 480px){.taipei-area-heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))!important;gap:6px!important}.taipei-area-heatmap-cell{min-height:70px!important;padding:8px 5px!important;font-size:10px!important}}.city-heatmap-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))!important;gap:12px!important;width:100%!important}.city-heatmap-cell{min-height:90px!important;transition:all .2s ease!important}@media (max-width: 1200px){.city-heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))!important;gap:10px!important}.city-heatmap-cell{min-height:85px!important;padding:12px 10px!important}}@media (max-width: 768px){.city-heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))!important;gap:8px!important}.city-heatmap-cell{min-height:80px!important;padding:10px 8px!important;font-size:12px!important}}@media (max-width: 480px){.city-heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))!important;gap:6px!important}.city-heatmap-cell{min-height:75px!important;padding:8px 6px!important;font-size:11px!important}}@media (max-width: 768px){.btn-quick-date{font-size:var(--text-xs);padding:var(--space-sm) var(--space-md);min-height:var(--touch-min)}}@media (max-width: 480px){.btn-quick-date{font-size:10px;padding:var(--space-sm);min-width:50px;min-height:var(--touch-min)}}.card{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-lighter)}.card--flush{padding:0;overflow:hidden}.table-empty{text-align:center;padding:var(--space-3xl) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.date-label{font-size:var(--text-base);color:var(--color-text-light);min-width:fit-content}.date-separator{color:var(--color-text-light);flex-shrink:0}.btn-retry{background:var(--color-primary);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-base);min-height:var(--touch-min)}.btn-retry:hover{background:var(--color-primary-hover)}.btn-action{padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-lg);font-weight:600;font-size:var(--text-base);cursor:pointer;min-height:var(--touch-min);display:inline-flex;align-items:center;gap:var(--space-sm)}.error-container{background:var(--color-danger-bg);border:1px solid var(--color-danger);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;color:var(--color-danger-text)}.data-table{width:100%;border-collapse:collapse;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table thead{background-color:var(--color-bg)}.data-table th{padding:var(--space-md) 15px;text-align:left;color:var(--color-text);font-size:.9rem;font-weight:600}.data-table td{padding:10px 15px;font-size:.85rem;color:var(--color-text-light)}.data-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .15s ease}.data-table tbody tr:hover{background-color:var(--color-bg)}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-left:var(--space-sm);vertical-align:middle;position:relative;top:-2px}.status-dot--on{background:var(--color-primary);box-shadow:0 0 0 3px #28a74533}.status-dot--off{background:var(--color-text-muted);animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:.4}50%{opacity:1}}.dashboard-actions-content{display:flex;gap:var(--space-md);align-items:center;flex-wrap:wrap}.date-range-inputs{display:flex;gap:var(--space-sm);align-items:center;flex-wrap:wrap;flex:1;min-width:200px}.date-range-separator{color:var(--color-text-light);flex-shrink:0}.quick-date-buttons{display:flex;gap:var(--space-sm);flex-wrap:wrap}.quick-date-group{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-right:var(--space-md)}@media (max-width: 768px){.dashboard-actions-content{flex-direction:column!important;align-items:stretch!important;gap:var(--space-md)!important}.dashboard-actions input[type=date]{min-width:120px;flex:1 1 100px}.dashboard-actions button{flex:1 1 auto;min-width:100px}}@media (max-width: 480px){.dashboard-actions label{text-align:center;margin-bottom:var(--space-sm)}.dashboard-actions input[type=date]{width:100%;min-width:unset}.dashboard-actions button{width:100%;min-width:unset;justify-content:center}}.heatmap-cell:hover{transform:scale(1.05);z-index:10}.city-heatmap-cell:hover,.taipei-area-heatmap-cell:hover,.country-heatmap-cell:hover{transform:scale(1.02);z-index:10;box-shadow:var(--shadow-hover)}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.status-badge{font-size:var(--text-sm);margin-left:10px;padding:2px var(--space-sm);border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:var(--space-xs)}.status-badge--error{color:var(--color-danger);background:var(--color-danger-bg)}.status-badge--success{color:var(--color-success);background:var(--color-success-bg)}.loading-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(255,255,255,.95);padding:var(--space-xl);border-radius:var(--radius-lg);z-index:1000;box-shadow:var(--shadow-hover);text-align:center}.heatmap-title{margin:0;font-size:var(--text-xl);font-weight:600;color:var(--color-text)}.heatmap-subtitle{margin:var(--space-xs) 0 0 0;font-size:var(--text-base);color:var(--color-text-light)}.heatmap-card{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);overflow:hidden}.date-range-label{font-size:var(--text-base);color:var(--color-text-light);min-width:fit-content}.date-input{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid #ddd;font-size:var(--text-base);min-height:var(--touch-min);flex:1}.date-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #28a74540}.retention-analysis .page-header{margin-bottom:30px}.retention-analysis .page-header h1{font-size:2.2rem;color:var(--color-text);margin-bottom:10px}.retention-analysis .page-header p{font-size:1.1rem;color:var(--color-text-muted);margin:0}.retention-analysis .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.retention-analysis .chart-container{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:25px;box-shadow:var(--shadow-sm);margin-bottom:25px;border:1px solid #e0e0e0}.retention-analysis .chart-container h3{font-size:1.4rem;color:#2c3e50;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #3498db}.retention-analysis .chart-wrapper{width:100%;height:100%}.retention-analysis .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:white;border-radius:12px;box-shadow:0 4px 6px #0000001a}.retention-analysis .loading-spinner{width:40px;height:40px;border:4px solid #ecf0f1;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.retention-analysis .recommendation-panel{background:white;border-radius:12px;padding:25px;box-shadow:0 4px 6px #0000001a;border:1px solid #e0e0e0}.retention-analysis .recommendation-panel h3{font-size:1.4rem;color:#2c3e50;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #f39c12}.retention-analysis .recommendations{display:flex;flex-direction:column;gap:15px}.retention-analysis .recommendation{display:flex;align-items:flex-start;gap:15px;padding:15px;border-radius:8px;border-left:4px solid}.retention-analysis .recommendation.success{background-color:#d4edda;border-left-color:#27ae60}.retention-analysis .recommendation.warning{background-color:#fff3cd;border-left-color:#f1c40f}.retention-analysis .recommendation.info{background-color:#d1ecf1;border-left-color:#3498db}.retention-analysis .recommendation .icon{font-size:1.5rem;flex-shrink:0}.retention-analysis .recommendation div{flex:1}.retention-analysis .recommendation strong{display:block;font-size:1.1rem;margin-bottom:5px;color:#2c3e50}.retention-analysis .recommendation p{margin:0;color:#5a6c7d;font-size:.95rem;line-height:1.4}@media (max-width: 768px){.retention-analysis{padding:15px}.retention-analysis .page-header h1{font-size:1.8rem}.retention-analysis .chart-container{padding:20px 15px}.retention-analysis .chart-container h3{font-size:1.2rem}.retention-analysis .stats-grid{grid-template-columns:1fr;gap:var(--space-lg)}.retention-analysis .recommendations{gap:12px}.retention-analysis .recommendation{padding:12px}}@media (max-width: 480px){.retention-analysis .page-header h1{font-size:1.5rem}.retention-analysis .page-header p{font-size:1rem}.retention-analysis .chart-container{padding:15px 10px}.retention-analysis .recommendation-panel{padding:20px 15px}}.dbe-container{display:flex;gap:0;min-height:calc(100vh - 40px);background:#f8f9fa}.dbe-sidebar{width:260px;min-width:260px;background:white;border-right:1px solid #e9ecef;overflow-y:auto;height:calc(100vh - 40px);position:sticky;top:20px}.dbe-main{flex:1;min-width:0;overflow:hidden;padding:0 0 0 20px}.dbe-table-list-header{padding:16px 16px 8px;border-bottom:1px solid #e9ecef}.dbe-table-list-header h3{font-size:14px;font-weight:600;color:#495057;margin:0}.dbe-table-list-search{padding:8px 12px;border-bottom:1px solid #e9ecef}.dbe-table-list-search input{width:100%;padding:6px 10px;border:1px solid #dee2e6;border-radius:6px;font-size:13px;background:#f8f9fa;outline:none}.dbe-table-list-search input:focus{border-color:#28a745;box-shadow:0 0 0 2px #28a74526}.dbe-table-list-items{list-style:none;padding:4px 0;margin:0}.dbe-table-list-item{display:flex;align-items:center;gap:8px;padding:7px 16px;cursor:pointer;font-size:13px;color:#495057;transition:all .15s ease;border-left:3px solid transparent}.dbe-table-list-item:hover{background:#f8f9fa;color:#28a745}.dbe-table-list-item.active{background:#e7f5e7;color:#28a745;border-left-color:#28a745;font-weight:600}.dbe-table-icon{font-size:14px;opacity:.7}.dbe-table-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dbe-table-list-empty{padding:20px 16px;color:#adb5bd;font-size:13px;text-align:center}.dbe-tabs{display:flex;gap:0;border-bottom:2px solid #e9ecef;margin-bottom:0;background:white;border-radius:12px 12px 0 0;padding:0 16px}.dbe-tab{padding:12px 20px;border:none;background:none;font-size:14px;font-weight:500;color:#6c757d;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s ease}.dbe-tab:hover{color:#28a745}.dbe-tab.active{color:#28a745;border-bottom-color:#28a745;font-weight:600}.dbe-content{background:white;border-radius:0 0 12px 12px;padding:20px;min-height:400px;overflow:hidden}.dbe-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#6c757d;background:white;border-radius:12px;padding:40px}.dbe-welcome-icon{font-size:64px;margin-bottom:16px;opacity:.5}.dbe-welcome h2{font-size:24px;font-weight:600;color:#495057;margin:0 0 8px}.dbe-welcome p{margin:0;font-size:15px}.dbe-table-wrapper{overflow:auto;border:1px solid #e9ecef;border-radius:8px;max-height:70vh;position:relative}.dbe-table{width:100%;border-collapse:collapse;font-size:13px}.dbe-table th,.dbe-table td{padding:4px 8px;text-align:left;border-bottom:1px solid #f1f3f4;white-space:nowrap;max-width:220px;overflow:hidden;text-overflow:ellipsis;font-size:12px}.dbe-table th{background:#f8f9fa;font-weight:600;color:#495057;position:sticky;top:0;z-index:2;border-bottom:2px solid #e9ecef;box-shadow:0 1px #e9ecef}.dbe-table th.dbe-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.dbe-table th.dbe-sortable:hover{background:#e9ecef}.dbe-table tbody tr:hover{background:#f8f9fa}.dbe-row-num{color:#adb5bd;font-size:11px;text-align:right!important;width:32px;min-width:32px;padding:4px 6px!important}.dbe-sort-icon{color:#28a745;font-weight:700}.dbe-cell-tooltip{position:absolute;top:100%;left:0;z-index:10;background:#1a1a1a;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;max-width:500px;white-space:pre-wrap;word-break:break-all;box-shadow:0 4px 12px #0003}.dbe-structure-header,.dbe-data-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.dbe-structure-header h3,.dbe-data-header h3{font-size:16px;font-weight:600;color:#1a1a1a;margin:0}.dbe-field-count{font-size:13px;color:#6c757d}.dbe-field-name{font-weight:600;font-family:Monaco,Menlo,monospace;color:#1a1a1a}.dbe-field-type{font-family:Monaco,Menlo,monospace;color:#6f42c1;font-size:12px}.dbe-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600}.dbe-badge-pk{background:#fff3cd;color:#856404}.dbe-badge-fk{background:#d1ecf1;color:#0c5460}.dbe-badge-uni{background:#e7f5e7;color:#155724}.dbe-refresh-btn{padding:6px 14px;border:1px solid #dee2e6;border-radius:6px;background:white;font-size:13px;cursor:pointer;color:#495057;transition:all .2s ease}.dbe-refresh-btn:hover{background:#f8f9fa;border-color:#28a745;color:#28a745}.dbe-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.dbe-pagination{display:flex;justify-content:space-between;align-items:center;padding:12px 0;margin-top:12px;border-top:1px solid #e9ecef;flex-wrap:wrap;gap:8px}.dbe-pagination-info{font-size:13px;color:#6c757d}.dbe-pagination-controls{display:flex;align-items:center;gap:6px}.dbe-pagination-label{font-size:13px;color:#6c757d}.dbe-pagination-select{padding:4px 8px;border:1px solid #dee2e6;border-radius:4px;font-size:13px;background:white}.dbe-pagination-btn{padding:4px 10px;border:1px solid #dee2e6;border-radius:4px;background:white;cursor:pointer;font-size:14px;color:#495057;transition:all .15s ease}.dbe-pagination-btn:hover:not(:disabled){background:#f8f9fa;border-color:#28a745;color:#28a745}.dbe-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.dbe-pagination-current{font-size:13px;font-weight:600;color:#495057;padding:0 4px}.dbe-pagination-jump{width:60px;padding:4px 8px;border:1px solid #dee2e6;border-radius:4px;font-size:13px;text-align:center}.dbe-query-editor{display:flex;flex-direction:column;gap:16px}.dbe-query-textarea{width:100%;min-height:300px;padding:16px;border:1px solid #dee2e6;border-radius:8px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;line-height:1.6;resize:vertical;outline:none;background:#fafbfc}.dbe-query-textarea:focus{border-color:#28a745;box-shadow:0 0 0 2px #28a74526;background:white}.dbe-query-toolbar{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.dbe-execute-btn{padding:8px 20px;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.dbe-execute-btn:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.dbe-execute-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.dbe-query-stats{display:flex;gap:16px;font-size:13px;color:#6c757d}.dbe-exec-time,.dbe-row-count{font-weight:500}.dbe-error{padding:10px 14px;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;font-size:13px}.dbe-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:#6c757d;font-size:14px}.dbe-empty{display:flex;align-items:center;justify-content:center;padding:40px;color:#adb5bd;font-size:14px}.dbe-history{border-top:1px solid #e9ecef;padding-top:12px}.dbe-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;font-weight:600;color:#495057}.dbe-history-clear{padding:2px 8px;border:1px solid #dee2e6;border-radius:4px;background:white;font-size:12px;cursor:pointer;color:#6c757d}.dbe-history-clear:hover{background:#f8d7da;color:#721c24;border-color:#f5c6cb}.dbe-history-list{list-style:none;padding:0;margin:0;max-height:200px;overflow-y:auto}.dbe-history-item{padding:8px 10px;border-radius:6px;cursor:pointer;transition:background .15s ease;border-bottom:1px solid #f1f3f4}.dbe-history-item:hover{background:#f8f9fa}.dbe-history-sql{font-family:Monaco,Menlo,monospace;font-size:12px;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.dbe-history-meta{display:flex;gap:12px;font-size:11px;color:#adb5bd}.dbe-history-error{color:#dc3545;font-weight:600}.dbe-history-empty{padding:20px;text-align:center;color:#adb5bd;font-size:13px}@media (max-width: 768px){.dbe-container{flex-direction:column}.dbe-sidebar{width:100%;min-width:unset;height:auto;max-height:200px;position:relative;top:0;border-right:none;border-bottom:1px solid #e9ecef}.dbe-main{padding:12px 0 0}.dbe-pagination{flex-direction:column;align-items:flex-start}.dbe-pagination-controls{flex-wrap:wrap}}.drp{position:relative}.drp-trigger{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);min-height:var(--touch-min);background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--text-base);color:var(--color-text);transition:border-color .15s ease;white-space:nowrap}.drp-trigger:hover{border-color:var(--color-primary)}.drp-trigger:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.drp-trigger-text{display:flex;align-items:center;gap:var(--space-xs)}.drp-trigger-sep{color:var(--color-text-muted);margin:0 2px}.drp-popover{position:absolute;top:calc(100% + var(--space-sm));left:0;z-index:200;background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;padding:var(--space-lg)}.drp-hint{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-md);text-align:center}.drp-calendars{display:flex;gap:var(--space-2xl)}.drp-month{width:260px}.drp-month-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);min-height:32px}.drp-month-title{font-size:var(--text-base);font-weight:600;color:var(--color-text);flex:1;text-align:center}.drp-nav{background:none;border:none;cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;width:28px;height:28px}.drp-nav:hover{background:var(--color-bg);color:var(--color-text)}.drp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:var(--space-xs)}.drp-weekday{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;padding:var(--space-xs) 0;font-weight:500}.drp-days{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.drp-day{display:flex;align-items:center;justify-content:center;width:36px;height:34px;font-size:var(--text-sm);color:var(--color-text);background:none;border:none;cursor:pointer;border-radius:var(--radius-sm);transition:background-color .1s ease}.drp-day:hover:not(.drp-empty){background:var(--color-bg)}.drp-day.drp-empty{cursor:default}.drp-day--today{font-weight:600;color:var(--color-primary)}.drp-day--start,.drp-day--end{background:var(--color-primary)!important;color:#fff!important;font-weight:600;border-radius:var(--radius-sm)}.drp-day--in-range{background:var(--color-primary-light);border-radius:0}.drp-day--start{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.drp-day--end{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.drp-day--start.drp-day--end{border-radius:var(--radius-sm)}@media (max-width: 620px){.drp-calendars{flex-direction:column;gap:var(--space-lg)}.drp-popover{left:50%;transform:translate(-50%)}}.premium-page{padding:var(--space-2xl);display:flex;min-height:100%;gap:0}.premium-page__main{flex:1;min-width:0}.premium-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-lg);margin-bottom:var(--section-gap);flex-wrap:wrap}.premium-eyebrow{font-size:var(--text-xs);letter-spacing:3px;color:var(--color-text-muted);margin-bottom:var(--space-xs);text-transform:uppercase}.premium-title{font-size:var(--text-2xl);font-weight:700;color:var(--color-text);margin:0}.premium-clock{text-align:right}.premium-clock__time{font-size:var(--text-3xl);font-weight:600;color:var(--color-text);letter-spacing:1px;line-height:1}.premium-clock__date{font-size:var(--text-base);color:var(--color-text-muted);margin-top:var(--space-xs)}.premium-clock__loading{font-size:var(--text-xs);color:var(--color-primary);margin-top:var(--space-xs)}.premium-refresh-btn{padding:var(--space-sm) var(--space-lg);background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;min-height:var(--touch-min);transition:border-color .15s ease,color .15s ease}.premium-refresh-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.premium-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.premium-error-banner{background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg);color:var(--color-danger-text);font-size:var(--text-sm)}.premium-row{display:flex;gap:var(--space-lg);margin-bottom:var(--space-lg);flex-wrap:wrap}.premium-row--tight{gap:var(--space-md)}.plan-card{flex:1;min-width:180px;padding:var(--space-xl) var(--space-2xl);border-radius:var(--radius-lg);border:1px solid var(--color-border-lighter);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.plan-card:hover{box-shadow:var(--shadow-hover)}.plan-card--black{background:var(--color-plan-black);color:var(--color-plan-black-text)}.plan-card--gold{background:var(--color-plan-gold);color:var(--color-plan-gold-text)}.plan-card--platinum{background:var(--color-plan-platinum);color:var(--color-plan-platinum-text)}.plan-card--green{background:var(--color-plan-green);color:var(--color-plan-green-text)}.plan-card--active{outline:2px solid rgba(255,255,255,.6);outline-offset:2px}.plan-card__label{font-size:var(--text-xs);letter-spacing:2px;opacity:.6;margin-bottom:var(--space-sm);text-transform:uppercase}.plan-card__value{font-size:var(--text-4xl);font-weight:700;line-height:1}.plan-card__sublabel{font-size:var(--text-sm);opacity:.6;margin-top:var(--space-xs)}.stat-callout{background:var(--color-bg-white);border:1px solid var(--color-border-lighter);border-left:4px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-2xl);flex:1;min-width:180px;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.stat-callout:hover{box-shadow:var(--shadow-hover)}.stat-callout--primary{border-left-color:var(--color-primary)}.stat-callout--success{border-left-color:var(--color-chart-3)}.stat-callout--warn{border-left-color:var(--color-chart-2)}.stat-callout--danger{border-left-color:var(--color-danger)}.stat-callout--accent{border-left-color:var(--color-chart-2)}.stat-callout--muted{border-left-color:var(--color-border)}.stat-callout__label{font-size:var(--text-xs);letter-spacing:2px;color:var(--color-text-muted);margin-bottom:var(--space-sm);text-transform:uppercase}.stat-callout__label--primary{color:var(--color-primary)}.stat-callout__label--warn{color:var(--color-warning-text)}.stat-callout__label--danger{color:var(--color-danger)}.stat-callout__label--accent{color:var(--color-chart-2)}.stat-callout__label--success{color:var(--color-success-text)}.stat-callout__value{font-size:var(--text-4xl);font-weight:700;line-height:1;color:var(--color-text)}.stat-callout__value--money{font-size:var(--text-2xl)}.stat-callout__value--primary{color:var(--color-primary)}.stat-callout__value--warn{color:var(--color-warning-text)}.stat-callout__value--danger{color:var(--color-danger)}.stat-callout__value--accent{color:var(--color-chart-2)}.stat-callout__value--success{color:var(--color-success-text)}.stat-callout__value-suffix{font-size:var(--text-lg);font-weight:400;color:var(--color-text-muted);margin-left:var(--space-xs)}.stat-callout__sublabel{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-xs)}.stat-callout__badge{font-size:var(--text-xs);letter-spacing:1px;font-weight:700;padding:2px var(--space-sm);border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;margin-left:var(--space-sm)}.stat-callout__badge--accent{background:var(--color-chart-2)}.detail-btn{margin-top:var(--space-md);font-size:var(--text-xs);background:transparent;border:none;cursor:pointer;padding:var(--space-xs) 0;color:inherit;opacity:.55;letter-spacing:.5px;display:inline-flex;align-items:center;gap:3px;min-height:var(--touch-min)}.detail-btn:hover,.detail-btn--active{opacity:1}.detail-btn:focus-visible{outline:2px solid currentColor;outline-offset:2px;border-radius:var(--radius-sm)}.plan-tag{display:inline-block;font-size:var(--text-xs);font-weight:600;padding:2px var(--space-sm);border-radius:var(--radius-sm);background:var(--color-border-light);color:var(--color-text)}.plan-tag--black{background:var(--color-plan-black);color:var(--color-plan-black-text)}.plan-tag--gold{background:var(--color-plan-gold);color:var(--color-plan-gold-text)}.plan-tag--platinum{background:var(--color-plan-platinum);color:var(--color-plan-platinum-text)}.plan-tag--green{background:var(--color-plan-green);color:var(--color-plan-green-text)}.status-pill{font-size:var(--text-xs);font-weight:700;padding:2px var(--space-sm);border-radius:var(--radius-sm);display:inline-block}.status-pill--success{background:var(--color-success-bg);color:var(--color-success-text)}.status-pill--danger{background:var(--color-danger-bg);color:var(--color-danger-text)}.status-pill--warn{background:var(--color-warning-bg);color:var(--color-warning-text)}.status-pill--info{background:var(--color-info-bg);color:var(--color-info-text)}.status-pill--fail{background:var(--color-border-light);color:var(--color-text-muted)}.count-badge{font-size:var(--text-xs);font-weight:700;padding:2px var(--space-md);border-radius:12px;display:inline-block}.count-badge--info{background:var(--color-info-bg);color:var(--color-info-text)}.count-badge--success{background:var(--color-success-bg);color:var(--color-success-text)}.count-badge--danger{background:var(--color-danger-bg);color:var(--color-danger-text)}.count-badge--warn{background:var(--color-warning-bg);color:var(--color-warning-text)}.count-badge--neutral{background:var(--color-border-light);color:var(--color-text-muted)}.collapsible{border-bottom:1px solid var(--color-border-lighter)}.collapsible__head{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:none;border:none;cursor:pointer;min-height:var(--touch-min);font:inherit;color:inherit}.collapsible__head:hover{background:var(--color-bg)}.collapsible__head:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.collapsible__title{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}.collapsible__indicator{font-size:var(--text-sm);color:var(--color-text-muted);margin-left:var(--space-sm)}.collapsible__extras{display:flex;align-items:center;gap:var(--space-sm)}.collapsible__body{border-top:1px solid var(--color-border-lighter)}.collapsible-plan-list{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md) var(--space-lg)}.plan-drilldown{margin-top:var(--space-xs);border:1px solid var(--color-border-lighter);border-radius:var(--radius-md);overflow:hidden}.failure-reason{max-width:180px;overflow:hidden;text-overflow:ellipsis}.plan-row-btn{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);cursor:pointer;border:1.5px solid var(--color-border-light);background:var(--color-bg-white);color:var(--color-text-secondary);font:inherit;min-height:var(--touch-min);transition:border-color .15s ease}.plan-row-btn:hover{border-color:var(--color-primary)}.plan-row-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.plan-row-btn--active{color:inherit}.plan-row-btn--active.plan-row-btn--black{background:var(--color-plan-black);color:var(--color-plan-black-text);border-color:var(--color-plan-black)}.plan-row-btn--active.plan-row-btn--gold{background:var(--color-plan-gold);color:var(--color-plan-gold-text);border-color:var(--color-plan-gold)}.plan-row-btn--active.plan-row-btn--platinum{background:var(--color-plan-platinum);color:var(--color-plan-platinum-text);border-color:var(--color-plan-platinum)}.plan-row-btn--active.plan-row-btn--green{background:var(--color-plan-green);color:var(--color-plan-green-text);border-color:var(--color-plan-green)}.plan-row-btn__swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}.plan-row-btn__name{flex:1;text-align:left;font-size:var(--text-sm);font-weight:600}.plan-row-btn__count{font-weight:700;font-size:var(--text-lg)}.plan-row-btn__sub{font-size:var(--text-sm);opacity:.7}.plan-row-btn__chevron{font-size:var(--text-xs);opacity:.65;margin-left:var(--space-xs)}.side-panel{width:420px;flex-shrink:0;border-left:1px solid var(--color-border-lighter);background:var(--color-bg-white);display:flex;flex-direction:column;min-height:100%}.side-panel__header{padding:var(--space-xl) var(--space-xl) var(--space-lg);border-bottom:1px solid var(--color-border-lighter);display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md)}.side-panel__eyebrow{font-size:var(--text-xs);letter-spacing:2px;color:var(--color-text-muted);margin-bottom:var(--space-xs);text-transform:uppercase}.side-panel__title{font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.side-panel__meta{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-xs)}.side-panel__close{background:none;border:none;cursor:pointer;font-size:var(--text-xl);color:var(--color-text-muted);padding:var(--space-xs);line-height:1;min-width:var(--touch-min);min-height:var(--touch-min);border-radius:var(--radius-sm)}.side-panel__close:hover{color:var(--color-text);background:var(--color-bg)}.side-panel__close:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.side-panel__body{flex:1;overflow-y:auto}.side-panel__toolbar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.ym-select{font-size:var(--text-sm);padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);cursor:pointer}.side-panel__empty{padding:var(--space-3xl);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.premium-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.premium-table th{padding:var(--space-sm) var(--space-md);font-size:var(--text-xs);font-weight:600;letter-spacing:.5px;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);text-align:left;white-space:nowrap}.premium-table th.th--num{text-align:right}.premium-table td{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-lighter);white-space:nowrap}.premium-table td.td--num{text-align:right}.premium-table td.td--tabular{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.premium-table td.td--muted{color:var(--color-text-muted)}.premium-table td.td--placeholder{color:var(--color-text-light);opacity:.5}.premium-table td.td--strong{font-weight:600;color:var(--color-text)}.premium-table td.td--highlight{font-weight:700;color:var(--color-danger)}.premium-table td.td--danger{color:var(--color-danger)}.premium-table td.td--success{color:var(--color-success-text)}.premium-table td.td--warn{color:var(--color-warning-text)}.premium-table tbody tr:nth-child(2n){background:var(--color-bg)}.premium-table tbody tr:hover{background:var(--color-border-lighter)}.premium-search{font-size:var(--text-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);min-width:220px;min-height:var(--touch-min);color:var(--color-text-secondary);background:var(--color-bg-white)}.premium-search:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #28a74526}.card-header{padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap}.card-header__left{display:flex;align-items:center;gap:var(--space-md)}.card-header__title{font-size:var(--text-base);font-weight:600;color:var(--color-text);margin:0}.card-header__swatch{width:10px;height:10px;border-radius:2px;flex-shrink:0;background:var(--color-border)}.card-header__swatch--black{background:var(--color-plan-black)}.card-header__swatch--gold{background:var(--color-plan-gold)}.card-header__swatch--platinum{background:var(--color-plan-platinum)}.card-header__swatch--green{background:var(--color-plan-green)}.card-header__count{background:var(--color-border-light);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:600;padding:2px var(--space-md);border-radius:20px}.chart-caption{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-md)}.overview-charts{display:flex;gap:var(--space-lg);flex-wrap:wrap}.overview-charts__bars{flex:2;min-width:300px}.overview-charts__donut{flex:1;min-width:240px}.chart-caption-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-md);gap:var(--space-md);flex-wrap:wrap}.chart-caption-row__title{font-size:var(--text-base);font-weight:600;color:var(--color-text);margin:0}.chart-caption-row__title--standalone{margin-bottom:var(--space-lg)}.status-pill+.status-pill{margin-left:var(--space-xs)}.donut-legend{margin-top:var(--space-sm)}.donut-legend__row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border-lighter)}.donut-legend__row:last-of-type{border-bottom:none}.donut-legend__label{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-secondary)}.donut-legend__swatch{width:10px;height:10px;border-radius:2px}.donut-legend__value{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}.donut-legend__pct{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:var(--space-xs)}.donut-legend__total{display:flex;justify-content:space-between;padding-top:var(--space-sm);font-weight:700}.placeholder-page{padding:var(--space-3xl) var(--space-2xl)}.placeholder-page__hint{color:var(--color-text-muted);font-size:var(--text-base);margin-top:var(--space-sm)}.sidebar-section-title--premium{color:var(--color-plan-gold)}.sidebar-footer{padding:var(--space-lg);border-top:1px solid var(--color-border-lighter)}@media (max-width: 1200px){.side-panel{width:360px}}@media (max-width: 960px){.premium-page{flex-direction:column}.side-panel{width:100%;border-left:none;border-top:1px solid var(--color-border-lighter)}}@media (max-width: 768px){.premium-page{padding:var(--space-lg)}.premium-header{flex-direction:column;align-items:flex-start}.premium-clock{text-align:left}.plan-card,.stat-callout{min-width:140px}}@media (max-width: 480px){.premium-page{padding:var(--space-md)}.plan-card__value,.stat-callout__value{font-size:var(--text-3xl)}.premium-row{flex-direction:column}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
