:root{--th-blue: #0066cc;--th-dark-blue: #004c99;--th-light-blue: #e6f2ff;--th-green: #28a745;--th-red: #dc3545;--th-orange: #fd7e14;--th-gray: #6c757d;--th-light-gray: #f8f9fa;--border-radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--th-light-gray);color:#333}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;border-bottom:2px solid var(--th-blue);box-shadow:0 2px 4px #0000001a}.header-top{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem .5rem}.header-brand{display:flex;align-items:center;gap:1rem}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.logo-small{height:40px;margin-right:1rem}.user-info{display:flex;align-items:center;gap:1rem}.app-main{flex:1;max-width:1200px;width:100%;margin:2rem auto;padding:0 2rem}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--th-blue) 0%,var(--th-dark-blue) 100%)}.login-card{background:#fff;padding:3rem;border-radius:var(--border-radius);box-shadow:0 10px 40px #0003;text-align:center;max-width:400px}.logo{height:60px;margin-bottom:2rem}.login-card h1{color:var(--th-blue);margin-bottom:1rem}.login-card p{color:var(--th-gray);margin-bottom:2rem}button{border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-primary{background:var(--th-blue);color:#fff}.btn-primary:hover{background:var(--th-dark-blue)}.btn-secondary{background:var(--th-gray);color:#fff}.btn-secondary:hover{background:#5a6268}.request-access-link{display:inline-block;margin-top:1rem;text-decoration:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:1rem;font-weight:500}.access-hint{margin-top:.75rem;font-size:.85rem;color:var(--th-gray)}.btn-danger{background:var(--th-red);color:#fff}.btn-danger:hover{background:#c82333}.btn-block{width:100%;margin-top:1rem}.key-manager{background:#fff;border-radius:var(--border-radius);padding:2rem;box-shadow:0 2px 8px #0000001a}.manager-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--th-light-blue)}.header-actions{display:flex;gap:1rem}.key-list{display:flex;flex-direction:column;gap:1rem}.key-card{border:1px solid #dee2e6;border-radius:var(--border-radius);padding:1.5rem;display:flex;justify-content:space-between;align-items:center;transition:box-shadow .2s}.key-card:hover{box-shadow:0 4px 12px #0000001a}.key-info{flex:1}.key-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.key-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;gap:.5rem;align-items:center}.label{font-weight:600;color:var(--th-gray);min-width:120px}code{background:var(--th-light-gray);padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge-active{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-expired{background:#f8d7da;color:#721c24}.badge-revoked{background:#e2e3e5;color:#383d41}.empty-state{text-align:center;padding:3rem;color:var(--th-gray)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:var(--border-radius);max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-large{max-width:800px}.modal-header{padding:1.5rem;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center}.close-btn{background:none;border:none;font-size:2rem;color:var(--th-gray);cursor:pointer;padding:0;width:2rem;height:2rem}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end;gap:1rem}.alert{padding:1rem;border-radius:var(--border-radius);margin-bottom:1rem}.alert-warning{background:#fff3cd;border:1px solid #ffc107;color:#856404}.credential-box{margin-bottom:1rem}.credential-box label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--th-gray)}.credential-row{display:flex;gap:.5rem}.credential-row code{flex:1;padding:.75rem;word-break:break-all}.btn-copy{background:var(--th-blue);color:#fff;padding:.5rem 1rem}.key-info-box{background:var(--th-light-blue);padding:1rem;border-radius:var(--border-radius);margin:1rem 0}.instructions section{margin-bottom:2rem}.instructions h3{color:var(--th-blue);margin-bottom:1rem}.instructions h4{margin-top:1rem;margin-bottom:.5rem}.instructions pre{background:#f8f9fa;padding:1rem;border-radius:var(--border-radius);overflow-x:auto;margin:.5rem 0}.instructions ul,.instructions ol{margin-left:1.5rem;margin-top:.5rem}.instructions li{margin-bottom:.5rem}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.spinner{border:4px solid var(--th-light-blue);border-top:4px solid var(--th-blue);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-tool-selector{max-width:1200px;margin:0 auto}.selector-description{text-align:center;color:var(--th-gray);margin-bottom:2rem;font-size:1.1rem}.tool-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem}.tool-card{background:#fff;border:2px solid #dee2e6;border-radius:var(--border-radius);padding:2rem;cursor:pointer;transition:all .3s;position:relative;display:flex;flex-direction:column;align-items:center}.tool-card:hover{border-color:var(--th-blue);box-shadow:0 4px 12px #0066cc1a;transform:translateY(-2px)}.tool-card.selected{border-color:var(--th-blue);background:var(--th-light-blue);box-shadow:0 4px 12px #06c3}.tool-card.current{border-color:var(--th-green)}.tool-card h3{color:var(--th-blue);margin-bottom:.5rem;text-align:center}.current-badge{display:inline-block;background:var(--th-green);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;margin-top:auto;margin-bottom:0}.tool-description{color:var(--th-gray);text-align:center;margin-bottom:1rem;min-height:3rem}.tool-features{list-style:none;padding:0;margin:0}.tool-features li{padding:.5rem 0;color:#333;font-size:.95rem}.selector-actions{text-align:center}.switch-warning{background:#fff3cd;border:1px solid #ffc107;color:#856404;padding:1rem;border-radius:var(--border-radius);margin-bottom:1rem;text-align:center}.btn-large{padding:1rem 3rem;font-size:1.1rem}.allocation-details{max-width:800px;margin:0 auto}.allocation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.allocation-card{background:#fff;border:1px solid #dee2e6;border-radius:var(--border-radius);padding:2rem;margin-bottom:2rem}.allocation-info{margin-bottom:2rem}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-row .label{font-weight:600;color:var(--th-gray)}.info-row .value{color:#333}.allocation-actions{display:flex;gap:1rem;justify-content:center}.quick-tips{background:var(--th-light-blue);padding:1.5rem;border-radius:var(--border-radius);margin-bottom:2rem}.quick-tips h3{color:var(--th-blue);margin-bottom:1rem}.quick-tips ul{margin-left:1.5rem}.quick-tips li{margin-bottom:.5rem;color:#333}.switch-section{margin-top:3rem;padding-top:3rem;border-top:2px solid #dee2e6}.switch-section h3{color:var(--th-blue);margin-bottom:.5rem}.switch-section p{color:var(--th-gray);margin-bottom:2rem}.setup-instructions{padding:1rem 0}.tabs{display:flex;gap:.5rem;border-bottom:2px solid #dee2e6;margin-bottom:2rem}.tab{background:none;border:none;padding:1rem 1.5rem;cursor:pointer;color:var(--th-gray);font-weight:500;border-bottom:3px solid transparent;transition:all .2s}.tab:hover{color:var(--th-blue);background:var(--th-light-blue)}.tab.active{color:var(--th-blue);border-bottom-color:var(--th-blue)}.tab-content{padding:1rem 0}.tab-content h3{color:var(--th-blue);margin-bottom:1rem}.tab-content h4{color:#333;margin-top:1.5rem;margin-bottom:.75rem}.tab-content ol,.tab-content ul{margin-left:1.5rem;margin-bottom:1rem}.tab-content li{margin-bottom:.5rem}.tab-content pre{background:#f8f9fa;padding:1rem;border-radius:var(--border-radius);overflow-x:auto;margin:1rem 0;border:1px solid #dee2e6}.credentials-box{background:var(--th-light-blue);padding:1.5rem;border-radius:var(--border-radius);margin:1rem 0}.credential-row{display:flex;flex-direction:column;margin-bottom:1rem}.credential-row:last-child{margin-bottom:0}.credential-row label{font-weight:600;color:var(--th-gray);margin-bottom:.5rem}.warning{background:#fff3cd;border:1px solid #ffc107;color:#856404;padding:1rem;border-radius:var(--border-radius);margin:1rem 0}.download-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin:2rem 0}.download-card{background:var(--th-light-blue);padding:2rem;border-radius:var(--border-radius);text-align:center;border:2px solid var(--th-blue)}.download-card h4{font-size:1.5rem;margin-bottom:.5rem}.download-card p{color:var(--th-gray);margin-bottom:1rem}.download-note{font-size:.85rem;color:var(--th-gray);margin-top:.5rem}.header-nav{display:flex;gap:.25rem;max-width:1200px;margin:0 auto;padding:0 2rem}.nav-tab{background:none;border:none;padding:.5rem 1rem;color:var(--th-gray);font-weight:500;border-bottom:3px solid transparent;border-radius:0;cursor:pointer;transition:all .2s}.nav-tab:hover{color:var(--th-blue);background:var(--th-light-blue)}.nav-tab.active{color:var(--th-blue);border-bottom-color:var(--th-blue)}.license-dashboard h2{color:var(--th-blue);margin-bottom:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #dee2e6;border-radius:var(--border-radius);padding:1.25rem;text-align:center;box-shadow:0 1px 3px #0000000d}.stat-value{font-size:2rem;font-weight:700;color:#333}.stat-label{font-size:.85rem;color:var(--th-gray);margin-top:.25rem}.stat-green .stat-value{color:var(--th-green)}.stat-orange .stat-value{color:var(--th-orange)}.stat-red .stat-value{color:var(--th-red)}.stat-gray .stat-value{color:var(--th-gray)}.stat-blue .stat-value{color:var(--th-blue)}.filter-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.btn-filter{background:var(--th-light-gray);color:var(--th-gray);padding:.4rem .8rem;font-size:.85rem;border-radius:16px}.btn-filter.active{background:var(--th-blue);color:#fff}.license-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--border-radius);overflow:hidden;box-shadow:0 1px 3px #0000000d}.license-table th,.license-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #dee2e6}.license-table th{background:var(--th-light-gray);font-weight:600;color:var(--th-gray);font-size:.85rem;text-transform:uppercase}.license-table tr:hover{background:#f8f9fa}.action-buttons{display:flex;gap:.25rem}.btn-sm{padding:.3rem .6rem;font-size:.8rem;border-radius:4px}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid var(--th-light-blue);border-top:2px solid var(--th-blue);border-radius:50%;animation:spin .8s linear infinite}.dashboard-footer{margin-top:1rem;font-size:.85rem;color:var(--th-gray);text-align:right}.tier-selector{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.tier-selector h3{margin-bottom:1rem;color:#2d3748}.tier-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.tier-card{border:2px solid #e2e8f0;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s;position:relative}.tier-card:hover{border-color:#4299e1;box-shadow:0 2px 8px #4299e126}.tier-card.selected{border-color:#3182ce;background:#ebf8ff}.tier-card.current-tier{border-color:#48bb78}.tier-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.tier-header h4{margin:0;font-size:1.1rem}.tier-price{font-weight:600;color:#3182ce}.tier-credits{font-size:.9rem;color:#4a5568;margin:.25rem 0}.tier-description{font-size:.85rem;color:#718096}.approval-badge{display:inline-block;background:#fefcbf;color:#975a16;font-size:.75rem;padding:2px 8px;border-radius:4px;margin-top:.5rem}.current-tier-badge{display:inline-block;background:#c6f6d5;color:#276749;font-size:.75rem;padding:2px 8px;border-radius:4px;margin-top:.5rem}.approval-notice{background:#fefcbf;border:1px solid #ecc94b;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:#744210}.upgrade-pending-banner{background:#ebf8ff;border:1px solid #90cdf4;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:#2a4365}.admin-badge{display:inline-block;background:#805ad5;color:#fff;font-size:.7rem;padding:2px 8px;border-radius:4px;margin-left:.5rem;text-transform:uppercase;font-weight:600}.admin-panel{max-width:1000px;margin:0 auto}.admin-description{color:#718096;margin-bottom:1.5rem}@media (max-width: 768px){.tier-cards{grid-template-columns:1fr}}.admin-tabs{display:flex;gap:0;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem}.admin-tabs .nav-tab{border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:4px 4px 0 0}.admin-tabs .nav-tab.active{border-bottom-color:#3182ce}.text-warning{color:#dd6b20;font-weight:600}.stat-purple{border-left:4px solid #805ad5}.stat-blue{border-left:4px solid #3182ce}.tool-logo{height:64px;width:64px;object-fit:contain}.tool-icon{display:flex;align-items:center;justify-content:center;height:80px;margin-bottom:.5rem}.tool-pricing{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0;width:100%}.pricing-label{font-weight:600;color:#2d3748;font-size:.95rem}.pricing-detail{font-size:.85rem;color:var(--th-gray)}.pricing-link{font-size:.85rem;color:var(--th-blue);text-decoration:none}.pricing-link:hover{text-decoration:underline}@media (max-width: 600px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.usage-analytics{max-width:1100px;margin:0 auto;position:relative}.usage-refreshing{opacity:.6;pointer-events:none;transition:opacity .2s}.usage-loading-bar{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--th-blue) 0%,#60a5fa 50%,var(--th-blue) 100%);background-size:200% 100%;animation:loading-slide 1.5s ease-in-out infinite;border-radius:2px;z-index:10}@keyframes loading-slide{0%{background-position:200% 0}to{background-position:-200% 0}}.usage-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.usage-tabs{display:flex;gap:0;border-bottom:2px solid #e2e8f0}.usage-tabs .nav-tab{border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:4px 4px 0 0}.usage-tabs .nav-tab.active{border-bottom-color:#3182ce}.usage-summary{margin-bottom:1.5rem}.summary-period{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;color:var(--th-gray)}.heatmap-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.heatmap-title{font-size:1rem;color:#24292f;margin-bottom:1rem;font-weight:400}.heatmap-filter-label{color:var(--th-gray);font-size:.9rem}.heatmap-scroll{overflow-x:auto;padding-bottom:.5rem}.heatmap-cell{cursor:pointer;outline:1px solid rgba(27,31,35,.06);outline-offset:-1px;transition:outline-color .1s}.heatmap-cell:hover{outline:2px solid rgba(27,31,35,.4);outline-offset:-1px}.heatmap-month-label,.heatmap-day-label{font-size:10px;fill:#57606a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:3px;margin-top:.75rem;font-size:.75rem;color:#57606a}.heatmap-legend-label{margin:0 4px}.heatmap-legend-cell{display:inline-block;width:12px;height:12px;border-radius:2px;outline:1px solid rgba(27,31,35,.06)}.heatmap-tooltip{background:#24292f;color:#fff;padding:8px 12px;border-radius:6px;font-size:.8rem;z-index:1000;pointer-events:none;white-space:nowrap;box-shadow:0 2px 8px #0000004d}.tooltip-date{font-weight:600;margin-bottom:2px}.tooltip-count{color:#8b949e}.tooltip-users,.tooltip-tool{color:#8b949e;font-size:.75rem}.mini-heatmap{display:flex;gap:1px;align-items:center;flex-wrap:nowrap;max-width:200px}.mini-cell{display:inline-block;width:2px;height:14px;border-radius:1px;flex-shrink:0}.user-activity-table{margin-top:1rem}.user-id-cell{font-family:SFMono-Regular,Consolas,monospace;font-size:.85rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-subtitle{font-size:.75rem;color:var(--th-gray);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}@media (max-width: 768px){.usage-header{flex-direction:column;align-items:flex-start}.mini-heatmap{display:none}}.period-range{font-size:.85rem;color:var(--th-gray);margin-left:.5rem}
