.stats-container{display:flex;flex-direction:column;gap:2rem}.stats-section{display:flex;flex-direction:column;gap:1rem}.stats-section-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;flex-shrink:0}.stat-card-content{display:flex;flex-direction:column;gap:.125rem;min-width:0}.stat-card-title{font-size:.875rem;color:#6b7280;font-weight:500}.stat-card-value{font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1.2}.stat-card-subtitle{font-size:.75rem;color:#9ca3af}.stats-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:#6b7280}.loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.stats-error{padding:2rem;text-align:center;color:#ef4444;background:#fef2f2;border-radius:12px;border:1px solid #fecaca}.purchases-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.purchases-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb}.purchases-title{display:flex;align-items:center;gap:.5rem;color:#1f2937}.purchases-title h2{font-size:1.125rem;font-weight:600;margin:0}.purchases-count{font-size:.875rem;color:#6b7280}.table-wrapper{overflow-x:auto}.purchases-table{width:100%;border-collapse:collapse}.purchases-table th,.purchases-table td{padding:.875rem 1.5rem;text-align:left}.purchases-table th{background:#f9fafb;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;border-bottom:1px solid #e5e7eb}.purchases-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .15s}.purchases-table tbody tr:hover{background-color:#f9fafb}.purchases-table tbody tr:last-child{border-bottom:none}.user-cell{display:flex;flex-direction:column;gap:.125rem}.username{font-weight:500;color:#1f2937}.email{font-size:.75rem;color:#9ca3af}.product-name{font-weight:500;color:#1f2937}.price{font-weight:600;color:#22c55e}.date{font-size:.875rem;color:#6b7280}.table-loading,.table-empty{text-align:center;padding:3rem 1.5rem!important;color:#6b7280}.table-loading{display:flex;align-items:center;justify-content:center;gap:.75rem}.pagination{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.pagination-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .15s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.purchases-error{padding:2rem;text-align:center;color:#ef4444;background:#fef2f2;border-radius:12px;border:1px solid #fecaca}.revenuecat-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.revenuecat-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb}.header-title{display:flex;align-items:center;gap:.5rem;color:#1f2937}.header-title h2{font-size:1.125rem;font-weight:600;margin:0}.revenuecat-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1.25rem 1.5rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.summary-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb;color:#6366f1}.summary-content{display:flex;flex-direction:column}.summary-value{font-size:1.25rem;font-weight:700;color:#1f2937}.summary-label{font-size:.75rem;color:#6b7280}.subscribers-list{max-height:400px;overflow-y:auto}.list-header{padding:.75rem 1.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb}.list-loading,.list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem;color:#9ca3af}.subscriber-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background-color .15s}.subscriber-row:hover{background-color:#f9fafb}.subscriber-row:last-child{border-bottom:none}.subscriber-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.subscriber-email{font-weight:500;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subscriber-id{font-size:.75rem;color:#9ca3af;font-family:monospace}.subscriber-stats{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.subscription-count{font-size:.75rem;color:#6b7280;display:flex;align-items:center;gap:.5rem}.active-badge{padding:.125rem .375rem;font-size:.625rem;font-weight:600;background:#dcfce7;color:#22c55e;border-radius:4px}.revenue{font-weight:600;color:#22c55e}.arrow{color:#d1d5db}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:1.125rem;font-weight:600;margin:0;color:#1f2937}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .15s}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.modal-loading,.modal-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem;color:#9ca3af}.modal-error{color:#ef4444}.subscriber-info{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.info-row.highlight{padding:.75rem;background:#f9fafb;border-radius:8px;border:none;margin-top:.5rem}.info-label{font-size:.875rem;color:#6b7280}.info-value{font-weight:500;color:#1f2937}.info-value.mono{font-family:monospace;font-size:.875rem}.info-value.revenue{font-size:1.125rem;font-weight:700;color:#22c55e}.subscriptions-section,.purchases-section{display:flex;flex-direction:column;gap:.75rem}.subscriptions-section h4,.purchases-section h4{font-size:.875rem;font-weight:600;color:#1f2937;margin:0}.subscription-card{padding:1rem;border-radius:8px;border:1px solid #e5e7eb}.subscription-card.active{border-color:#86efac;background:#f0fdf4}.subscription-card.expired{background:#f9fafb}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.product-id{font-weight:600;color:#1f2937}.status-badge{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;border-radius:4px}.status-badge.active{background:#dcfce7;color:#22c55e}.status-badge.expired{background:#f3f4f6;color:#6b7280}.subscription-details{display:flex;flex-direction:column;gap:.375rem}.detail-row{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280}.detail-row.warning{color:#f59e0b}.sandbox-badge{padding:.125rem .375rem;font-size:.625rem;font-weight:600;background:#fef3c7;color:#d97706;border-radius:4px}.non-subscription-card{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f9fafb;border-radius:8px}.purchase-meta{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:#6b7280}.revenuecat-error{padding:2rem;text-align:center;color:#ef4444;background:#fef2f2;border-radius:12px;border:1px solid #fecaca}.dashboard{display:flex;min-height:100vh;background:#f3f4f6}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:#1f2937;display:flex;flex-direction:column;z-index:100;transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}@media (min-width: 768px){.sidebar{transform:translate(0)}}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:50}.sidebar.open~.sidebar-overlay{display:block}@media (min-width: 768px){.sidebar-overlay{display:none!important}}.sidebar-header{display:flex;align-items:center;gap:.5rem;padding:1.5rem;border-bottom:1px solid #374151}.logo{font-size:1.25rem;font-weight:700;color:#fff;margin:0}.logo-sub{font-size:.75rem;font-weight:500;color:#9ca3af;padding:.125rem .5rem;background:#374151;border-radius:4px}.sidebar-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin-left:auto;background:none;border:none;border-radius:6px;cursor:pointer;color:#9ca3af;transition:all .15s}.sidebar-close:hover{background:#374151;color:#fff}@media (min-width: 768px){.sidebar-close{display:none}}.sidebar-nav{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9375rem;font-weight:500;color:#9ca3af;background:none;border:none;border-radius:8px;cursor:pointer;transition:all .15s;text-align:left;width:100%}.nav-item:hover{background:#374151;color:#fff}.nav-item.active{background:#6366f1;color:#fff}.sidebar-footer{padding:1rem;border-top:1px solid #374151}.logout-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;font-size:.9375rem;font-weight:500;color:#9ca3af;background:none;border:none;border-radius:8px;cursor:pointer;transition:all .15s}.logout-btn:hover{background:#374151;color:#ef4444}.main-content{flex:1;margin-left:0;display:flex;flex-direction:column;min-height:100vh}@media (min-width: 768px){.main-content{margin-left:260px}}.main-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}.menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;border-radius:8px;cursor:pointer;color:#374151;transition:all .15s}.menu-btn:hover{background:#f3f4f6}@media (min-width: 768px){.menu-btn{display:none}}.header-title{display:flex;align-items:center;gap:.75rem;color:#1f2937}.header-title h2{font-size:1.25rem;font-weight:600;margin:0}.content-area{flex:1;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}@media (min-width: 768px){.content-area{padding:2rem;gap:2rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1f2937,#111827);padding:1rem}.login-card{width:100%;max-width:400px;background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;overflow:hidden}.login-header{padding:2rem 2rem 1.5rem;text-align:center}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:16px;color:#fff;margin-bottom:1.5rem}.login-header h1{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.login-header p{font-size:.875rem;color:#6b7280;margin:0}.login-form{padding:0 2rem 2rem;display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.token-input-wrapper{position:relative}.token-input-wrapper input{width:100%;padding:.75rem 3rem .75rem 1rem;font-size:.9375rem;border:1px solid #d1d5db;border-radius:8px;background:#f9fafb;transition:all .15s;box-sizing:border-box}.token-input-wrapper input:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f11a}.token-input-wrapper input::placeholder{color:#9ca3af}.toggle-visibility{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .15s}.toggle-visibility:hover{background:#e5e7eb;color:#374151}.login-error{padding:.75rem 1rem;font-size:.875rem;color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.login-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;font-size:.9375rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;cursor:pointer;transition:all .15s}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.login-btn:disabled{opacity:.7;cursor:not-allowed}.spinning{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{padding:1rem 2rem;background:#f9fafb;text-align:center;border-top:1px solid #e5e7eb}.login-footer p{font-size:.75rem;color:#9ca3af;margin:0}*,*:before,*:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;color:#1f2937;background:#f3f4f6}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}:focus-visible{outline:2px solid #6366f1;outline-offset:2px}::selection{background:#c7d2fe;color:#1e1b4b}:root{font-size:16px}@media (max-width: 480px){:root{font-size:14px}}
