html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;text-rendering:optimizeLegibility}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}button{font-family:inherit}input,select,textarea{font-family:inherit;font-size:1em}@media (max-width:768px){a,button,input[type=button],input[type=submit]{min-height:44px;min-width:44px}}*{transition:background-color .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease}:root{--bg-primary:#0a0a0a;--bg-secondary:#000;--text-primary:#ededed;--text-secondary:#a1a1aa;--text-muted:#71717a;--border:#ffffff1a;--border-strong:#ffffff2e;--surface:#ffffff08;--surface-raised:#ffffff0d;--surface-hover:#ffffff0f;--surface-input:#ffffff0a;--accent:#fff;--accent-weak:#ffffff14;--link:#ffffffeb;--link-hover:#fff;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--info:#60a5fa;--shadow:0 1px 0 #ffffff0a,0 8px 30px #0000008c;--radius:14px;--transition:all 0.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#000;background:var(--bg-secondary);color:#ededed;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;line-height:1.6}.App{background:radial-gradient(1200px 600px at 20% -10%,#ffffff1a,#0000 55%),radial-gradient(900px 500px at 90% 0,#ffffff0f,#0000 55%),linear-gradient(180deg,#000,#050505);min-height:100vh}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column}.content-wrapper{flex:1 1}.container{margin:0 auto;max-width:1200px;padding:40px 32px 64px;width:100%}.card{background:#0a0a0a;background:var(--bg-primary);border:1px solid #ffffff1a;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 0 #ffffff0a,0 8px 30px #0000008c;box-shadow:var(--shadow);padding:24px;transition:all .2s ease;transition:var(--transition)}.card:hover{box-shadow:0 4px 16px #0000000f}.tab-content{gap:20px}h1,h2,h3{font-weight:600;letter-spacing:-.02em}p{color:#a1a1aa;color:var(--text-secondary)}.button{align-items:center;background:#ffffff08;border:1px solid #ffffff1a;border:1px solid var(--border);border-radius:10px;color:#ededed;color:var(--text-primary);cursor:pointer;display:inline-flex;font-weight:500;justify-content:center;padding:10px 16px;transition:all .2s ease;transition:var(--transition)}.button:hover{background:#ffffff0f}.button.primary{background:#ffffffeb;border-color:#ffffffeb;color:#000}.button.primary:hover{opacity:.9}.input{background:#ffffff08;border:1px solid #ffffff1a;border:1px solid var(--border);border-radius:10px;color:#ededed;color:var(--text-primary);padding:10px 14px;transition:all .2s ease;transition:var(--transition);width:100%}.input:focus{border-color:#ffffff38;box-shadow:0 0 0 3px #ffffff0f;outline:none}.loading-container{align-items:center;display:flex;justify-content:center;min-height:100vh}.spinner{animation:spin .7s linear infinite;border-top:2px solid var(--text-primary)}.divider{background:#ffffff1a;background:var(--border);height:1px;margin:16px 0}@media (max-width:1024px){.container{padding:32px 24px 56px}}@media (max-width:768px){.container{padding:24px 16px 48px}.tab-content{gap:16px}}@media (max-width:480px){.container{padding:20px 12px 40px}.tab-content{gap:12px}}header.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0009;border-bottom:1px solid var(--border);box-shadow:0 1px 0 #ffffff0d;padding:14px 0;position:sticky;top:0;transition:all .2s ease;z-index:100}.header-content{justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 40px}.header-content,.header-logo{align-items:center;display:flex}.header-logo{cursor:pointer;gap:12px;transition:all .2s}.header-logo:hover{opacity:.75}.header-logo svg{color:var(--text-primary);flex-shrink:0}.header-logo h1{color:var(--text-primary);font-size:18px;font-weight:700;letter-spacing:-.5px;margin:0}.header-controls{align-items:center;display:flex;gap:12px}.currency-selector{background:#0000;border-radius:6px;display:flex;gap:4px;padding:0}.currency-btn{background:#ffffff08;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;padding:8px 14px;transition:all .2s ease}.currency-btn:hover{background:#ffffff0f;border-color:#ffffff2e;color:var(--text-primary);transform:translateY(-1px)}.currency-btn.active{background:#ffffffeb;border-color:#ffffffeb;box-shadow:0 10px 30px #0000008c;color:#000}.logout-btn{align-items:center;background:#ffffff08;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.logout-btn:hover{background:#ef444414;border-color:#ef444480;color:#ef4444f2;transform:translateY(-1px)}@media (max-width:768px){.header-content{padding:0 16px}.header-logo h1{font-size:16px}.currency-btn{font-size:11px;padding:6px 10px}}@media (max-width:480px){header.header{padding:12px 0}.header-content{gap:8px;padding:0 12px}.header-logo{gap:8px}.header-logo h1{font-size:14px}.header-controls{gap:8px}.currency-btn{font-size:10px;padding:6px 8px}}@media (max-width:768px){.header-logo h1{font-size:18px}.header-controls{gap:12px}}.tab-navigation{background-color:#0000008c;border-bottom:1px solid var(--border);box-shadow:0 1px 0 #ffffff0a;position:sticky;top:60px;z-index:10}.tabs-container{-webkit-overflow-scrolling:touch;display:flex;gap:0;margin:0 auto;max-width:1400px;overflow-x:auto;padding:0 40px}.tab-button{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:500;gap:8px;letter-spacing:-.3px;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.tab-button:hover{background-color:#ffffff0a;border-bottom-color:#ffffff38;color:var(--text-primary)}.tab-button.active{background-color:#ffffff05;border-bottom-color:#ffffffeb;color:var(--text-primary);font-weight:600}.tab-icon{align-items:center;display:flex;height:16px;justify-content:center;width:16px}.tab-label{font-size:14px;font-weight:500}@media (max-width:1024px){.tabs-container{padding:0 32px}.tab-button{padding:12px 16px}}@media (max-width:768px){.tab-navigation{top:54px}.tabs-container{padding:0 16px}.tab-button{font-size:13px;gap:6px;padding:12px 14px}.tab-label{display:inline}}@media (max-width:480px){.tab-navigation{top:50px}.tabs-container{padding:0 12px}.tab-button{font-size:12px;min-width:auto;padding:10px}.tab-icon{height:14px;width:14px}.tab-label{display:inline}}.pagination{flex-wrap:wrap;gap:4px;margin-top:20px;padding:20px 0}.pagination,.pagination-btn{align-items:center;display:flex;justify-content:center}.pagination-btn{background-color:var(--surface-input);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:500;height:32px;min-width:32px;padding:0 8px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background-color:var(--surface-hover);border-color:var(--border-strong);transform:translateY(-1px)}.pagination-btn.active{background-color:#ffffffeb;border-color:#ffffffeb;box-shadow:var(--shadow);color:#000}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-ellipsis{color:var(--text-muted);padding:0 4px}@media (max-width:768px){.pagination{gap:2px;margin-top:16px;padding:16px 0}.pagination-btn{font-size:12px;height:28px;min-width:28px;padding:0 6px}}@media (max-width:480px){.pagination{gap:2px;margin-top:12px;padding:12px 0}.pagination-btn{font-size:11px;height:24px;min-width:24px;padding:0 4px}}.audio-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px}.audio-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;padding:20px;transition:all .2s ease}.audio-stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.audio-stat-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.audio-stat-card h3{color:var(--text-secondary);flex:1 1;font-size:14px;font-weight:600;letter-spacing:-.3px;margin:0;text-transform:uppercase}.audio-stat-header svg{color:var(--text-primary);flex-shrink:0;opacity:.6}.audio-stat-value{color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin-bottom:8px}.audio-stat-meta{color:var(--text-secondary);font-size:12px;letter-spacing:-.2px}@media (max-width:768px){.audio-stats-grid{gap:12px;grid-template-columns:1fr}.audio-stat-card{padding:16px}.audio-stat-value{font-size:24px}}@media (max-width:480px){.audio-stat-card{padding:14px}.audio-stat-value{font-size:20px}.audio-stat-card h3{font-size:12px}}.tab-content{display:flex;flex-direction:column;gap:24px}.summaries-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.stat-card{gap:8px}.stat-label{font-size:12px;font-weight:700}.models-breakdown-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:24px}.models-breakdown-section h3{color:var(--text-primary);font-size:16px;font-weight:700;margin:0 0 16px}.models-table-wrapper{overflow-x:auto}.models-table{border-collapse:collapse;font-size:14px;width:100%}.models-table td,.models-table th{border-bottom:1px solid var(--border);padding:12px 16px;text-align:left}.models-table thead{background:var(--surface-raised)}.models-table th{color:var(--text-secondary);font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.models-table td,.summary-model{color:var(--text-primary)}.summary-model{font-size:13px;font-weight:600}.summary-like-dislike-counts{color:var(--text-secondary);display:flex;font-size:12px;gap:10px;margin-top:6px}.summary-like-dislike-counts span{align-items:center;display:inline-flex;gap:6px}.meta-like{color:var(--success)}.meta-dislike{color:var(--danger)}.chart-container{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:24px}.chart-card h3{font-weight:700;margin:0 0 24px}.recent-summaries-section{background:#ffffff08;border:1px solid var(--border);border-radius:8px;overflow:hidden}.recent-summaries-section h2{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:18px;font-weight:700;margin:0;padding:24px}.summaries-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.summaries-table{border-collapse:collapse;width:100%}.summaries-table thead{background:#ffffff08;border-bottom:1px solid var(--border)}.summaries-table th{color:var(--text-secondary);font-size:12px;font-weight:700;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.summaries-table td{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:14px;padding:12px 16px}.summaries-table tr:last-child td{border-bottom:none}.summary-title{color:var(--text-primary);font-weight:600;max-width:300px}.user-link{color:#ffffffeb;font-size:14px;transition:all .2s ease}.user-link:hover{opacity:.8}.summary-date{color:var(--text-secondary);font-size:13px}.summary-ratings{align-items:center;gap:12px}.rating{border-radius:12px}.rating.like{background:#22c55e1f;color:var(--success)}.rating.dislike{background:#ef44441f;color:var(--danger)}.rating.neutral{background:var(--surface-raised)}.rating.neutral,.views{color:var(--text-secondary)}.views{display:flex}.summary-link{color:#ffffffeb}.generation-meta{color:var(--text-secondary);display:flex;flex-direction:column;font-size:12px;gap:4px}.generation-status{background:#ffffff08;border:1px solid var(--border);border-radius:999px;display:inline-flex;padding:2px 8px;width:fit-content}.generation-status-succeed,.generation-status-success{background:#22c55e1f;border-color:#22c55e4d;color:var(--success)}.generation-status-error,.generation-status-failed{background:#ef44441f;border-color:#ef44444d;color:var(--danger)}.generation-status-pending,.generation-status-processing{background:#f59e0b1f;border-color:#f59e0b4d;color:var(--warning)}.summary-link:hover{opacity:.8;text-decoration:underline}.platform-badge{background:var(--surface-raised);border:1px solid var(--border);border-radius:12px;color:var(--text-secondary);display:inline-block;font-size:12px;font-weight:500;padding:2px 8px}.platform-badge--bot{background:#60a5fa1f;border-color:#60a5fa4d;color:var(--info)}.views-today{color:var(--success);font-size:.85em;margin-left:4px}.loading-state{padding:48px}.spinner{border:2px solid #ffffff24;border-top-color:#ffffffeb;height:24px;width:24px}.empty-chart-message{align-items:center;border-radius:6px;display:flex;height:300px;justify-content:center}.empty-title{background-color:#ef44441f;border-radius:4px;color:var(--danger);font-size:12px;font-style:italic;font-weight:400;padding:2px 6px}@media (max-width:1280px){.summaries-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.summaries-stats-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.stat-card{padding:16px}.stat-value{font-size:24px}.chart-container{padding:16px}.chart-card h3{font-size:16px;margin-bottom:16px}.recent-summaries-section h2{font-size:16px;padding:16px}.summaries-table th{font-size:11px;padding:10px 12px}.summaries-table td{font-size:13px;padding:10px 12px}.summary-title{max-width:150px}}@media (max-width:480px){.summaries-stats-grid{gap:12px;grid-template-columns:1fr}.stat-card{padding:14px}.stat-value{font-size:20px}.stat-label{font-size:11px}.chart-container{padding:12px}.chart-card h3{font-size:14px;margin-bottom:12px}.recent-summaries-section h2{font-size:14px;padding:12px}.summaries-table th{font-size:10px;padding:8px}.summaries-table td{font-size:12px;padding:8px}.summary-title{max-width:100px}.empty-chart-message{height:200px}.loading-state{padding:32px}}.model-reactions{width:100%}.model-reactions h2{color:var(--text-primary);font-size:24px;font-weight:600;margin-bottom:24px;margin-top:0}.models-table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);margin-bottom:24px;overflow:hidden}.models-reactions-table{border-collapse:collapse;font-size:14px;width:100%}.models-reactions-table thead{background:var(--surface-raised);border-bottom:2px solid var(--border)}.models-reactions-table th{color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.models-reactions-table tbody tr{border-bottom:1px solid var(--border);transition:background-color .2s ease}.models-reactions-table tbody tr:hover{background-color:var(--surface-hover)}.models-reactions-table tbody tr:last-child{border-bottom:none}.models-reactions-table td{color:var(--text-primary);padding:14px 16px}.model-name{color:var(--text-primary);font-weight:500;max-width:300px}.model-name span{display:block;white-space:normal;word-break:break-word}.dislikes-cell,.likes-cell{font-weight:500;text-align:right}.dislikes-count,.likes-count{font-size:13px;font-weight:600}.rating-cell{min-width:200px;text-align:center}.rating-bar{justify-content:center}.rating-bar,.rating-percentage{align-items:center;display:flex;gap:8px}.rating-percentage{flex:1 1;min-width:120px}.rating-value{color:var(--text-primary);font-size:13px;font-weight:600;min-width:35px}.rating-progress{background-color:#ffffff1a;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .3s ease}.total-reactions{color:var(--text-primary);font-weight:600;text-align:right}.model-reactions-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:24px}.summary-stat{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);padding:20px;text-align:center}.summary-stat .stat-label{color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.summary-stat .stat-value{color:var(--text-primary);font-size:28px;font-weight:700}.empty-message{background:var(--surface)}.spinner{animation:spin .8s linear infinite}@media (max-width:768px){.models-reactions-table{font-size:12px}.models-reactions-table td,.models-reactions-table th{padding:12px 8px}.model-name{max-width:150px}.rating-bar{flex-direction:column}.rating-percentage{width:100%}.model-reactions-summary{grid-template-columns:1fr}}.notification-panel{background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);margin-bottom:24px;padding:24px}.notification-panel__header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px}.notification-panel__header h2{color:var(--text-primary);font-size:20px;margin:0 0 8px}.notification-panel__header p{color:var(--text-secondary);line-height:1.6;margin:0}.notification-panel__grid{grid-gap:16px;display:grid;gap:16px}.notification-panel__field{display:flex;flex-direction:column;gap:8px}.notification-panel__field label{color:var(--text-secondary);font-size:13px;font-weight:500}.notification-panel__field.full-width{grid-column:1/-1}.notification-panel__field input,.notification-panel__field select,.notification-panel__field textarea{background:var(--surface-input);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:14px;padding:12px 14px}.notification-panel__field input::placeholder,.notification-panel__field textarea::placeholder{color:var(--text-muted)}.notification-panel__field textarea{min-height:120px;resize:vertical}.notification-panel__buttons-section{background:var(--surface-raised);border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;gap:12px;padding:16px}.notification-panel__buttons-header{align-items:center;color:var(--text-primary);display:flex;gap:12px;justify-content:space-between}.notification-panel__button-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr auto}.notification-panel__button-row input{background:var(--surface-input);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);padding:10px 12px}.notification-panel__button,.notification-panel__remove-button,.notification-panel__secondary-button{border:none;border-radius:12px;cursor:pointer;font-size:14px;padding:10px 14px}.notification-panel__secondary-button{background:var(--surface-hover);border:1px solid var(--border);color:var(--text-primary)}.notification-panel__remove-button{background:#ef44441f;border:1px solid #ef44444d;color:var(--danger)}.notification-panel__button{background:var(--surface-hover);border:1px solid var(--border);color:var(--text-primary)}.notification-panel__button--primary{background:#ffffffeb;border:1px solid #ffffffeb;color:#000}.notification-panel__footer{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-top:20px}.notification-panel__actions{display:flex;flex-wrap:wrap;gap:12px}.notification-panel__meta{color:var(--text-secondary);font-size:14px}.notification-panel__status{grid-gap:12px;background:var(--surface-raised);border:1px solid var(--border);border-radius:16px;display:grid;gap:12px;margin-top:20px;padding:16px}.notification-panel__status-row{color:var(--text-primary);display:flex;font-size:14px;gap:12px;justify-content:space-between}.notification-panel__progress-bar{background:#ffffff1a;border-radius:9999px;height:12px;overflow:hidden;width:100%}.notification-panel__progress-fill{background:var(--success);height:100%;transition:width .3s ease}.notification-panel__error{background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;color:var(--danger);padding:12px}.notifications-current-status,.notifications-history{background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);padding:24px}.notifications-current-status__header,.notifications-history__header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px}.notifications-current-status__header h3,.notifications-history__header h3{color:var(--text-primary);font-size:20px;margin:0 0 6px}.notifications-current-status__header p,.notifications-history__header p{color:var(--text-secondary);margin:0}.notifications-current-status__campaign-id{background:var(--surface-raised);border:1px solid var(--border);border-radius:999px;color:var(--text-primary);font-size:13px;font-weight:600;padding:8px 12px;white-space:nowrap}.notifications-current-status__empty{color:var(--text-secondary);padding:8px 0}.notifications-current-status__grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.notifications-current-status__card{background:var(--surface-raised);border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;gap:8px;padding:16px}.notifications-current-status__card span{color:var(--text-secondary);font-size:13px}.notifications-current-status__card strong{color:var(--text-primary);font-size:18px;line-height:1.3}.notifications-current-status__last-error{margin-top:16px}.notifications-current-status__last-error,.notifications-history__error{background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;color:var(--danger);padding:12px 14px}.notifications-history__error{margin-bottom:16px}.notifications-history__table-wrap{border:1px solid var(--border);border-radius:16px;overflow-x:auto}.notifications-history__table{border-collapse:collapse;min-width:980px;width:100%}.notifications-history__table td,.notifications-history__table th{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:14px;padding:14px 16px;text-align:left;vertical-align:middle}.notifications-history__table th{background:var(--surface-raised);color:var(--text-secondary);font-weight:600}.notifications-history__table tbody tr:hover{background:var(--surface-hover)}.notifications-history__table tbody tr:last-child td{border-bottom:none}.notifications-history__empty,.notifications-history__loading{color:var(--text-secondary);padding:20px 0;text-align:center}.notifications-history__status{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px}.notifications-history__status--idle{background:#ffffff14;color:var(--text-secondary)}.notifications-history__status--pending{background:#f59e0b1f;color:var(--warning)}.notifications-history__status--in_progress{background:#f59e0b2e;color:#fbbf24}.notifications-history__status--completed{background:#22c55e1f;color:var(--success)}.notifications-history__status--test_sent{background:#60a5fa1f;color:var(--info)}.notifications-history__status--canceled,.notifications-history__status--failed{background:#ef44441f;color:var(--danger)}.notifications-history__footer{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-top:20px}.notifications-history__meta{color:var(--text-secondary);font-size:14px}@media (max-width:768px){.notifications-current-status,.notifications-history{padding:16px}.notifications-current-status__header,.notifications-history__header{flex-direction:column}.notifications-history__footer{align-items:stretch;flex-direction:column}}.users-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.section-header{align-items:center;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:24px}.section-header h2{color:var(--text-primary);font-size:16px;font-weight:600;letter-spacing:-.4px;margin:0}.search-box{align-items:center;display:flex;flex:1 1;min-width:200px;position:relative}.search-box svg{color:var(--text-muted);left:12px;pointer-events:none;position:absolute}.search-box input{background:var(--surface-input);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:13px;padding:8px 12px 8px 36px;transition:all .2s;width:100%}.search-box input:focus{background:var(--surface-hover);border-color:var(--border-strong);outline:none}.search-box input::placeholder{color:var(--text-muted)}.table-wrapper{overflow-x:auto}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:var(--surface-raised);border-bottom:1px solid var(--border)}.users-table th{color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.users-table td{border-bottom:1px solid var(--border);color:var(--text-primary);font-size:14px;padding:12px 16px}.users-table tbody tr:hover{background:var(--surface-hover)}.user-row:last-child td{border-bottom:none}.user-name-link{background:none;border:none;color:var(--link);cursor:pointer;font-size:14px;font-weight:500;padding:0;text-decoration:none;transition:color .2s ease}.user-name-link:hover{color:var(--link-hover);text-decoration:underline}.user-info-cell{align-items:center;display:flex;gap:12px}.user-avatar-small{background-color:var(--surface-raised);border:1px solid var(--border);border-radius:50%;height:32px;object-fit:cover;width:32px}.user-name{color:var(--text-primary);font-weight:500}.user-username{color:var(--text-secondary);font-size:13px}.user-id{color:var(--text-muted);font-family:Monaco,Courier,monospace;font-size:12px}.hours-badge{background:#60a5fa1f;border-radius:4px;color:var(--info);display:inline-block;font-size:12px;font-weight:600;padding:4px 8px}.hours-badge.low{background:#ef44441f;color:var(--danger)}.actions-cell{display:flex;gap:8px}.action-btn{background:var(--surface-input);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s;white-space:nowrap}.action-btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.action-btn.primary{background:#ffffffeb;border-color:#ffffffeb;color:#000}.action-btn.primary:hover{background:#fff}.action-btn.secondary{color:var(--text-primary)}.empty-state{padding:60px 20px}.empty-state svg{color:var(--text-muted);margin-bottom:16px}.empty-state p{font-size:14px}.users-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:24px}.stat-label{letter-spacing:.5px;text-transform:uppercase}.stat-label,.stat-subtext{color:var(--text-secondary)}.stat-subtext{font-size:12px}.chart-container{margin-bottom:24px}.chart-card{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:24px}.chart-card h3{color:var(--text-primary);font-size:16px;font-weight:600;letter-spacing:-.4px;margin:0 0 20px}.chart-card canvas{max-height:400px}.empty-chart-message{background:#ffffff05;border-radius:8px;color:var(--text-secondary);font-size:14px;padding:40px;text-align:center}@media (max-width:768px){.users-stats-grid{gap:12px;grid-template-columns:1fr}.stat-card{padding:16px}.stat-value{font-size:24px}}.modal-overlay{align-items:center;animation:fadeIn .2s ease-in-out;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-dialog{animation:slideUp .3s ease-out;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);max-height:90vh;max-width:420px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.modal-close:hover{background:var(--surface-hover);color:var(--text-primary)}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--border);display:flex;gap:8px;padding:20px}.form-group{margin-bottom:16px}.form-group label{font-weight:600;margin-bottom:6px}.form-group input{background:var(--surface-input);font-family:inherit;padding:10px 12px;transition:all .2s ease}.form-group input:disabled{background:var(--surface-raised);color:var(--text-secondary);cursor:not-allowed}.form-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:6px;color:var(--danger);font-size:12px;margin-bottom:16px;padding:10px 12px}.btn{border:1px solid var(--border);flex:1 1;font-family:inherit;min-height:40px;padding:10px 16px}.btn-primary{background:#ffffffeb;border-color:#ffffffeb;color:#000}.btn-primary:hover{background:#fff;box-shadow:var(--shadow)}.btn-secondary{background:var(--surface-input);color:var(--text-primary)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--border-strong)}.payment-info{border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:16px}.user-info{color:var(--text-secondary);font-size:13px;margin:0}.payment-list{display:flex;flex-direction:column;gap:12px}.payment-item{background:var(--surface);border:1px solid var(--border);padding:12px}.payment-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.payment-left{gap:12px}.payment-icon,.payment-left{align-items:center;display:flex}.payment-icon{background:var(--surface-raised);border-radius:6px;color:var(--text-primary);flex-shrink:0;height:40px;justify-content:center;width:40px}.payment-date{color:var(--text-primary);font-size:13px}.payment-status{color:var(--text-secondary);font-size:12px}.payment-amount{color:var(--text-primary);font-size:14px}.empty-state{color:var(--text-secondary);padding:32px 20px;text-align:center}.empty-state p{font-size:13px;margin:0}@media (max-width:480px){.modal-dialog{width:95%}.form-group{margin-bottom:12px}}.user-detail-page{margin:0 auto;max-width:1400px;padding:20px 40px 40px}.back-button{background:none;border:none;color:#0969da;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:20px;padding:0;transition:color .2s ease}.back-button:hover{color:#054aaf}.user-header{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:20px;margin-bottom:30px;padding:30px}.user-avatar{align-items:center;background:linear-gradient(135deg,#0969da,#0550ae);color:#fff;display:flex;font-size:32px;font-weight:700;justify-content:center}.user-avatar,.user-avatar-img{border-radius:50%;flex-shrink:0;height:80px;width:80px}.user-avatar-img{border:1px solid #e5e7eb;object-fit:cover}.user-info{flex:1 1}.user-info h1{color:#0b1117;font-size:24px;margin:0 0 4px}.username{color:#666;font-size:14px;margin:0 0 4px}.user-id{margin:0 0 4px}.join-date,.user-id{color:#999;font-size:13px}.join-date{margin:0}.utm-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.utm-tag{align-items:center;background-color:#f6f8fa;border:1px solid #e5e7eb;border-radius:4px;color:#656d76;display:inline-flex;font-size:11px;padding:4px 8px;white-space:nowrap}.utm-key{color:#0b1117;font-weight:600;margin-right:4px;text-transform:capitalize}.user-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.user-finance-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.finance-metric-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.metric-meta{color:#4b5563;font-size:13px;line-height:1.6}.stat-card{background:#fff;border:1px solid #e5e7eb}.stat-card:hover{border-color:#d0d7de;box-shadow:0 1px 3px #0000000d}.stat-label{color:#666;font-size:13px;font-weight:500;margin-bottom:8px}.stat-value{color:#0b1117;font-size:24px;font-weight:600}.section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:20px;padding:20px}.section h2{color:#0b1117;font-size:16px;font-weight:600;margin:0 0 20px}.empty-message{background-color:#f9fafb;border-radius:6px;color:#999;padding:20px}.payments-list{display:flex;flex-direction:column;gap:12px}.payment-item{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;justify-content:space-between;padding:16px;transition:all .2s ease}.payment-item:hover{background-color:#f6f8fa;border-color:#d0d7de}.payment-date{color:#0b1117;font-size:14px;font-weight:500}.payment-status{color:#28a745;font-size:13px;font-weight:500}.payment-amount{color:#0b1117;font-size:16px;font-weight:600}.summaries-list{display:flex;flex-direction:column;gap:12px}.summary-item{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;gap:16px;justify-content:space-between;padding:16px;transition:all .2s ease}.summary-item:hover{background-color:#f6f8fa;border-color:#d0d7de}.summary-info{flex:1 1;min-width:0}.summary-title{color:#0b1117;font-size:14px;font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-meta{color:#999;font-size:12px}.summary-generation-meta{color:#4b5563;display:inline-block;margin-left:10px}.summary-ratings{display:flex;gap:8px}.rating{align-items:center;background-color:#f6f8fa;border:1px solid #e5e7eb;border-radius:4px;color:#666;display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:4px 8px;white-space:nowrap}.rating.like{background-color:#f0fdf4;border-color:#bbf7d0;color:#16a34a}.rating.dislike{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.views{align-items:center;border:1px solid #e5e7eb;border-radius:4px;display:inline-flex;font-size:12px;gap:4px;padding:4px 8px}.rating.neutral,.views{background-color:#f6f8fa;color:#666}.rating.neutral{border-color:#e5e7eb}.rating svg{height:14px;width:14px}.summary-link{background-color:#fff;border:1px solid #e5e7eb;border-radius:4px;color:#0969da;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;text-decoration:none;transition:all .2s ease;white-space:nowrap}.summary-link:hover{background-color:#f6f9ff;border-color:#0969da;color:#054aaf}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.btn-primary{background-color:#0b1117;color:#fff}.btn-primary:hover{background-color:#1a1f26}.loading-state{color:#666;padding:80px 20px}.spinner{border:3px solid #e5e7eb;border-top-color:#0b1117;height:40px;margin-bottom:16px;width:40px}@media (max-width:768px){.user-detail-page{padding:16px 20px 30px}.user-header{flex-direction:column;padding:20px}.user-header,.user-info{text-align:center}.user-stats-grid{grid-template-columns:1fr 1fr}.payment-item,.summary-item{align-items:flex-start;flex-direction:column;gap:8px}.summary-item{align-items:flex-start}.payment-amount,.payment-status{width:100%}}.stats-section{margin-bottom:24px}.stats-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.stats-header h2{color:var(--text-primary);font-size:20px;font-weight:700;letter-spacing:-.4px;margin:0}.stats-caption{color:var(--text-secondary);font-size:13px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.stat-card{background:#ffffff08;border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 0 #ffffff0a;display:flex;flex-direction:column;padding:20px;transition:all .2s ease}.stat-card:hover{border-color:#ffffff2e;box-shadow:0 10px 30px #0000008c;transform:translateY(-2px)}.stat-header-content{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.stat-card h3{color:var(--text-secondary);font-size:12px;font-weight:700;letter-spacing:.5px;margin:0;text-transform:uppercase}.stat-card svg{color:#ffffff40;flex-shrink:0;height:20px;opacity:.7;width:20px}.stat-value{color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin-bottom:8px}.stat-meta{color:var(--text-secondary);font-size:12px;line-height:1.5}.loading-state{min-height:180px}.empty-message{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:24px}.spinner{border-top-color:#ffffffe6}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width:768px){.stats-header{align-items:flex-start;flex-direction:column;gap:12px}.stats-grid{gap:12px;grid-template-columns:1fr}.stat-card{padding:16px}.stat-value{font-size:24px}.stats-header h2{font-size:18px}}@media (max-width:480px){.stat-card{padding:14px}.stat-value{font-size:20px}.stat-card h3{font-size:11px}.stats-header h2{font-size:16px}}.recent-purchases{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-top:20px;padding:24px}.recent-purchases h2{color:var(--text-primary);font-size:16px;font-weight:600;letter-spacing:-.4px;margin:0 0 20px}.recent-purchases-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.purchases-meta{color:var(--text-secondary);font-size:12px}.top-tariffs-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:20px}.top-tariff-card{background:var(--surface-raised);border:1px solid var(--border);border-radius:8px;padding:16px}.top-tariff-rank{color:var(--info);font-size:12px;font-weight:700;margin-bottom:8px}.top-tariff-name{color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:6px}.top-tariff-revenue{color:var(--text-primary);font-size:22px;font-weight:700;margin:10px 0 4px}.purchase-secondary,.top-tariff-meta{color:var(--text-secondary);font-size:12px}.purchases-table-wrapper{overflow-x:auto}.purchases-table{border-collapse:collapse;font-size:14px;width:100%}.purchases-table thead{background-color:var(--surface-raised);border-bottom:1px solid var(--border)}.purchases-table th{color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.purchases-table tbody tr{border-bottom:1px solid var(--border);transition:background-color .2s ease}.purchases-table tbody tr:hover{background-color:var(--surface-hover)}.purchases-table tbody tr:last-child{border-bottom:none}.purchases-table td{color:var(--text-primary);padding:14px 16px}.user-link{background:none;border:none;color:var(--link);cursor:pointer;font-weight:500;padding:0;text-decoration:none;transition:color .2s ease}.user-link:hover{color:var(--link-hover);text-decoration:underline}.purchase-date{color:var(--text-secondary);font-size:13px}.purchase-amount{color:var(--text-primary);font-weight:600}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:4px 12px}.status-badge.status-succeeded,.status-badge.success{background-color:#22c55e1f;border:1px solid #22c55e4d;color:var(--success)}.status-badge.status-waiting_for_capture{background-color:#f59e0b1f;border:1px solid #f59e0b4d;color:var(--warning)}.status-badge.status-canceled{background-color:#ef44441f;border:1px solid #ef44444d;color:var(--danger)}.confirmation-link{color:var(--link);display:inline-block;font-size:12px;margin-left:8px;text-decoration:none}.empty-message{font-size:14px;text-align:center}.empty-message,.loading-state{color:var(--text-secondary);padding:40px 20px}.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center}.spinner{animation:spin 1s linear infinite;border:3px solid #ffffff24;border-radius:50%;border-top:3px solid var(--text-primary);height:32px;margin-bottom:12px;width:32px}@media (max-width:768px){.recent-purchases{padding:16px}.purchases-table-wrapper{overflow-x:scroll}.purchases-table td,.purchases-table th{font-size:12px;padding:10px 8px}}.product-metrics-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.product-stat-card{overflow:hidden;position:relative}.product-stat-card:before{background:radial-gradient(800px 240px at 20% 0,#ffffff0f,#0000 60%);content:"";inset:0;pointer-events:none;position:absolute}.health-badge{align-items:center;background:#ffffff0a;border:1px solid var(--border);border-radius:999px;color:var(--text-secondary);display:inline-flex;font-size:11px;font-weight:700;gap:6px;letter-spacing:.02em;padding:4px 10px}.health-warning{background:#f59e0b14;border-color:#f59e0b59;color:#f59e0bf2}.health-critical{background:#ef444414;border-color:#ef444459;color:#ef4444f2}.health-ok{background:#22c55e14;border-color:#22c55e59;color:#22c55ef2}.login-page{align-items:center;background:radial-gradient(1200px 600px at 20% -10%,#ffffff1a,#0000 55%),linear-gradient(180deg,#000,#050505);display:flex;justify-content:center;min-height:100vh}.login-container{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);max-width:400px;padding:32px;width:100%}.login-header{margin-bottom:24px;text-align:center}.login-header h1{color:var(--text-primary);font-size:24px;margin:0 0 8px}.login-header p{color:var(--text-secondary);font-size:14px;margin:0}.login-form{gap:16px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{color:var(--text-primary);font-size:13px;font-weight:500}.form-group input{background-color:var(--surface-input);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px;padding:8px 12px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{background-color:var(--surface-hover);border-color:var(--border-strong);box-shadow:0 0 0 3px #ffffff0f;outline:none}.error-message{background-color:#ef44441a;border:1px solid #ef44444d;border-radius:6px;color:var(--danger);font-size:13px;padding:12px}.login-button{align-items:center;background-color:#ffffffeb;border:1px solid #ffffffeb;border-radius:6px;color:#000;cursor:pointer;display:flex;font-size:14px;font-weight:600;justify-content:center;margin-top:8px;min-height:40px;padding:10px;transition:background-color .2s}.login-button:hover{background-color:#fff}.login-button:disabled{background-color:#fff6;border-color:#0000;cursor:not-allowed}.login-footer{border-top:1px solid var(--border);color:var(--text-secondary);font-size:12px;margin-top:24px;padding-top:16px;text-align:center}.spinner-small{animation:spin 1s linear infinite;border:2px solid #0003;border-radius:50%;border-top-color:#000;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.65bfa343.css.map*/