@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Poppins:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--premium-primary: #6366f1;--premium-primary-dark: #4f46e5;--premium-secondary: #8b5cf6;--premium-accent: #06b6d4;--premium-surface: rgba(255, 255, 255, .95);--premium-glass: rgba(255, 255, 255, .1);--premium-glass-border: rgba(255, 255, 255, .2);--premium-text-primary: #0f172a;--premium-text-secondary: #64748b;--premium-gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #f093fb 100%);--premium-gradient-2: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--premium-gradient-3: linear-gradient(135deg, #0ea5e9 0%, #6366f1 50%, #8b5cf6 100%);--premium-shadow-sm: 0 2px 8px -2px rgba(99, 102, 241, .15);--premium-shadow-md: 0 12px 40px -12px rgba(99, 102, 241, .25);--premium-shadow-lg: 0 25px 60px -15px rgba(99, 102, 241, .3);--premium-shadow-glow: 0 0 60px rgba(99, 102, 241, .4)}.auth-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem;position:relative;overflow:hidden;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.auth-container:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.4) 0%,transparent 70%);border-radius:50%;top:-200px;right:-100px;animation:float 8s ease-in-out infinite}.auth-container:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(139,92,246,.3) 0%,transparent 70%);border-radius:50%;bottom:-150px;left:-100px;animation:float 10s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}.auth-container .grid-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.auth-card{position:relative;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a,inset 0 1px 1px #ffffff80;padding:3rem 2.5rem;width:100%;max-width:440px;z-index:10;animation:cardEntrance .8s cubic-bezier(.16,1,.3,1);overflow:hidden}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--premium-gradient-2)}@keyframes cardEntrance{0%{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-card .brand-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:.5rem}.auth-card .brand-icon{width:48px;height:48px;background:var(--premium-gradient-2);border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--premium-shadow-md)}.auth-card .brand-icon svg{width:28px;height:28px;color:#fff}.auth-card h1{font-family:Poppins,sans-serif;text-align:center;background:var(--premium-gradient-2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.75rem;font-weight:700;margin-bottom:.25rem;letter-spacing:-.025em}.auth-card h2{text-align:center;color:var(--premium-text-secondary);font-size:1rem;margin-bottom:2rem;font-weight:400;letter-spacing:.01em}.form-group{margin-bottom:1.25rem;position:relative}.form-group label{display:block;margin-bottom:.5rem;color:var(--premium-text-primary);font-weight:500;font-size:.875rem;letter-spacing:.01em}.form-group input.input{width:100%;padding:.875rem 1rem;font-size:.9375rem;border:2px solid #e2e8f0;border-radius:12px;background:#f8fafc;color:var(--premium-text-primary);transition:all .3s cubic-bezier(.4,0,.2,1);font-family:Inter,sans-serif}.form-group input.input:focus{outline:none;border-color:var(--premium-primary);background:#fff;box-shadow:0 0 0 4px #6366f11a}.form-group input.input::-moz-placeholder{color:#94a3b8}.form-group input.input::placeholder{color:#94a3b8}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;font-family:Inter,sans-serif;border:none;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.btn-primary{background:var(--premium-gradient-2);color:#fff;box-shadow:var(--premium-shadow-md),0 0 #6366f180}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--premium-shadow-lg),0 0 30px #6366f166}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(255,255,255,.2),transparent);pointer-events:none}.btn-block{width:100%;margin-top:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.auth-divider{display:flex;align-items:center;margin:1.75rem 0;gap:1rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,#e2e8f0,transparent)}.auth-divider span{color:var(--premium-text-secondary);font-size:.8125rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:var(--premium-text-primary);border:2px solid #e2e8f0;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-google:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;box-shadow:var(--premium-shadow-sm);transform:translateY(-1px)}.btn-google svg{flex-shrink:0}.auth-footer{text-align:center;margin-top:1.75rem;color:var(--premium-text-secondary);font-size:.875rem}.auth-footer a{color:var(--premium-primary);text-decoration:none;font-weight:600;transition:color .2s}.auth-footer a:hover{color:var(--premium-primary-dark)}.auth-legal{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.auth-legal a{color:var(--premium-text-secondary);text-decoration:none;font-size:.8125rem;font-weight:500;transition:color .2s}.auth-legal a:hover{color:var(--premium-primary)}.auth-legal .separator{color:#cbd5e1;font-size:.75rem}.error-message{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;padding:1rem;border-radius:12px;margin-bottom:1.25rem;font-size:.875rem;font-weight:500;border:1px solid #fecaca;display:flex;align-items:center;gap:.5rem}.error-message:before{content:"!";display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#dc2626;color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.info-message{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;border-radius:12px;padding:1rem;font-size:.875rem}.domain-notice{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.75rem;color:var(--premium-text-secondary);margin-top:.75rem;padding:.5rem;background:#f8fafc;border-radius:8px}.domain-notice svg{width:14px;height:14px;color:var(--premium-primary)}.particles{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.particle{position:absolute;width:6px;height:6px;background:#ffffff4d;border-radius:50%;animation:particleFloat 15s infinite}.particle:nth-child(1){left:10%;animation-delay:0s;animation-duration:12s}.particle:nth-child(2){left:20%;animation-delay:2s;animation-duration:14s}.particle:nth-child(3){left:30%;animation-delay:4s;animation-duration:16s}.particle:nth-child(4){left:40%;animation-delay:1s;animation-duration:13s}.particle:nth-child(5){left:50%;animation-delay:3s;animation-duration:15s}.particle:nth-child(6){left:60%;animation-delay:5s;animation-duration:11s}.particle:nth-child(7){left:70%;animation-delay:2.5s;animation-duration:17s}.particle:nth-child(8){left:80%;animation-delay:4.5s;animation-duration:14s}.particle:nth-child(9){left:90%;animation-delay:1.5s;animation-duration:12s}@keyframes particleFloat{0%{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh) rotate(720deg);opacity:0}}.feature-highlights{display:none;position:absolute;left:60px;top:50%;transform:translateY(-50%);max-width:400px;color:#fff;z-index:5}@media (min-width: 1200px){.feature-highlights{display:block}.auth-container{justify-content:flex-end;padding-right:10%}}.feature-highlights h3{font-family:Poppins,sans-serif;font-size:2.5rem;font-weight:700;margin-bottom:1rem;line-height:1.2}.feature-highlights p{font-size:1.125rem;opacity:.8;margin-bottom:2rem;line-height:1.6}.feature-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.1);transition:transform .3s,background .3s}.feature-item:hover{transform:translate(10px);background:#ffffff26}.feature-icon{width:44px;height:44px;background:linear-gradient(135deg,#fff3,#ffffff1a);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.feature-text h4{font-weight:600;font-size:1rem;margin-bottom:.25rem}.feature-text p{font-size:.875rem;opacity:.7;margin:0}@media (max-width: 480px){.auth-card{padding:2rem 1.5rem;border-radius:20px}.auth-card h1{font-size:1.5rem}.auth-container:before,.auth-container:after{display:none}}.btn-primary.loading{position:relative;color:transparent}.btn-primary.loading:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.btn:focus-visible,.form-group input:focus-visible{outline:2px solid var(--premium-primary);outline-offset:2px}*{-webkit-tap-highlight-color:transparent}input,button{-webkit-appearance:none;-moz-appearance:none;appearance:none}.dashboard{padding:0}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.dashboard-header h1{margin:0}.page-subtitle{color:var(--text-secondary);margin-top:.5rem;margin-bottom:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{background:var(--surface-color);border-radius:.5rem;padding:1.25rem;box-shadow:var(--shadow);display:flex;gap:1rem;align-items:flex-start;border:1px solid var(--border-color)}.stat-icon{font-size:1.5rem;width:3rem;height:3rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.stat-meta{font-size:.75rem;color:var(--text-secondary)}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.chart-card{background:var(--surface-color);border-radius:.5rem;padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border-color)}.chart-card h3{margin:0 0 1rem;font-size:1rem;color:var(--text-primary)}.chart-wide{grid-column:span 2}.empty-chart{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-secondary);font-style:italic}.chart-tooltip{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.375rem;padding:.75rem;box-shadow:var(--shadow-md)}.chart-tooltip .tooltip-label{font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.chart-tooltip p{margin:.25rem 0;font-size:.875rem}.dashboard-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.dashboard-section h2{font-size:1.125rem;margin:0 0 1rem;color:var(--text-primary)}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.action-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1.25rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-decoration:none;color:var(--text-primary);transition:all .2s}.action-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary-color)}.action-icon{font-size:1.75rem}.action-label{font-weight:500;font-size:.8rem;text-align:center}.card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem}.payments-list{display:flex;flex-direction:column;gap:.5rem}.payment-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--background-color);border-radius:.375rem}.payment-info{display:flex;flex-direction:column;gap:.125rem}.payment-client{font-weight:500;color:var(--text-primary)}.payment-date{font-size:.75rem;color:var(--text-secondary)}.payment-amount{font-weight:600;color:var(--primary-color)}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.summary-item{text-align:center;padding:.75rem;background:var(--background-color);border-radius:.375rem}.summary-value{display:block;font-size:1.5rem;font-weight:700;color:var(--primary-color)}.summary-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.activity-item{padding:.75rem 0;border-bottom:1px solid var(--border-color)}.activity-item:last-child{border-bottom:none}.empty-state-text{text-align:center;color:var(--text-secondary);padding:2rem;font-style:italic}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}.chart-wide{grid-column:span 1}}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:1rem}.header-actions{width:100%}.header-actions .btn{flex:1}.stats-grid,.action-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}}.timer-container{background:#fff;border-radius:.5rem;padding:2rem;box-shadow:var(--shadow)}.timer-display{text-align:center;margin-bottom:2rem}.timer-time{font-size:3rem;font-weight:700;color:var(--primary-color);font-variant-numeric:tabular-nums;letter-spacing:.05em}.timer-info{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.timer-client{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.timer-description{font-size:.875rem;color:var(--text-secondary)}.timer-controls{display:flex;flex-direction:column;gap:1rem}.btn-lg{padding:1rem 2rem;font-size:1rem;font-weight:600}@media (min-width: 768px){.timer-time{font-size:4rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:.5rem;box-shadow:var(--shadow-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background-color .2s}.modal-close:hover{background-color:var(--bg-color)}.modal-content form{padding:1.5rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}textarea.input{resize:vertical;font-family:inherit}.time-entry-list{background:#fff;border-radius:.5rem;overflow:hidden;box-shadow:var(--shadow)}.data-table{width:100%;border-collapse:collapse}.data-table thead{background-color:var(--bg-color)}.data-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.data-table td{padding:1rem;border-top:1px solid var(--border-color)}.data-table tbody tr:hover{background-color:var(--bg-color)}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.125rem;padding:.25rem;opacity:.7;transition:opacity .2s}.btn-icon:hover{opacity:1}.text-small{font-size:.75rem;color:var(--text-secondary)}.font-bold{font-weight:600}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary)}@media (max-width: 768px){.data-table{font-size:.875rem}.data-table th,.data-table td{padding:.75rem .5rem}}.client-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.client-card{background:#fff;border-radius:.5rem;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .2s}.client-card:hover{box-shadow:var(--shadow-md)}.client-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid var(--border-color);background-color:var(--bg-color)}.client-card-header h3{margin:0;font-size:1.125rem;color:var(--text-primary)}.client-company{margin:.25rem 0 0;font-size:.875rem;color:var(--text-secondary)}.client-actions{display:flex;gap:.5rem}.client-card-body{padding:1.5rem}.client-info{display:flex;justify-content:space-between;margin-bottom:.75rem;font-size:.875rem}.client-label{color:var(--text-secondary);font-weight:500}.client-rate{font-weight:600;color:var(--primary-color)}.client-notes{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);font-size:.875rem;color:var(--text-secondary);font-style:italic}.modal-large{max-width:800px}.invoice-form-content{padding:1.5rem}.billing-type-tabs{display:flex;gap:.5rem;margin-bottom:.5rem}.billing-tab{flex:1;padding:.75rem 1rem;border:2px solid var(--border-color);background:#fff;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .2s}.billing-tab:hover{border-color:var(--primary-color);color:var(--text-primary)}.billing-tab.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.line-items-container{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.line-item-row{display:flex;gap:.5rem;align-items:flex-start}.line-item-header{font-weight:600;font-size:.875rem;color:var(--text-secondary);margin-bottom:-.25rem}.line-item-header .line-item-fields{align-items:center}.line-item-header .line-item-fields span{padding:.5rem;text-align:left}.line-item-fields{flex:1;display:grid;grid-template-columns:2fr .7fr .7fr .9fr;gap:.5rem}.input-small{min-width:0}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.25rem;padding:.5rem;opacity:.6;transition:opacity .2s}.btn-icon:hover:not(:disabled){opacity:1}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.time-entries-list{max-height:300px;overflow-y:auto;border:1px solid var(--border-color);border-radius:.375rem;padding:.5rem}.entry-checkbox{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:.375rem;cursor:pointer;transition:background-color .2s}.entry-checkbox:hover{background-color:var(--bg-color)}.entry-checkbox input[type=checkbox]{margin-top:.25rem;cursor:pointer}.entry-details{flex:1;display:flex;justify-content:space-between;align-items:center}.entry-info{display:flex;flex-direction:column;gap:.25rem}.entry-date{font-size:.75rem;color:var(--text-secondary)}.entry-description{font-size:.875rem;color:var(--text-primary)}.entry-amount{text-align:right;display:flex;flex-direction:column;gap:.25rem}.entry-hours{font-size:.75rem;color:var(--text-secondary)}.entry-price{font-size:.875rem;font-weight:600;color:var(--text-primary)}.invoice-summary{background-color:var(--bg-color);padding:1rem;border-radius:.375rem;margin-top:1rem}.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.875rem}.summary-total{border-top:2px solid var(--border-color);margin-top:.5rem;padding-top:.75rem;font-weight:700;font-size:1rem;color:var(--primary-color)}.btn-link{background:none;border:none;color:var(--primary-color);font-size:.875rem;cursor:pointer;text-decoration:underline}.text-secondary{color:var(--text-secondary)}.text-small{font-size:.875rem}@media (max-width: 640px){.line-item-fields,.form-row{grid-template-columns:1fr}.billing-type-tabs{flex-direction:column}}.filter-bar{display:flex;gap:.5rem;margin-bottom:1.5rem}.filter-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:#fff;border-radius:.375rem;font-size:.875rem;cursor:pointer;transition:all .2s}.filter-btn:hover{background:var(--bg-color)}.filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.invoice-list{background:#fff;border-radius:.5rem;box-shadow:var(--shadow);overflow:hidden}.font-mono{font-family:Courier New,monospace;font-weight:600}.btn-sm{padding:.25rem .75rem;font-size:.875rem}.payment-summary{margin-bottom:2rem}.summary-card{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);color:#fff;border-radius:.5rem;padding:2rem;box-shadow:var(--shadow-md)}.summary-label{font-size:.875rem;opacity:.9;margin-bottom:.5rem}.summary-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.summary-meta{font-size:.875rem;opacity:.8}.payment-list{background:#fff;border-radius:.5rem;box-shadow:var(--shadow);overflow:hidden}.gateway-badge{display:inline-block;padding:.25rem .5rem;background-color:var(--bg-color);border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.link{color:var(--primary-color);text-decoration:none}.link:hover{text-decoration:underline}.subscriptions-page{padding:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-header h1{margin:0 0 .25rem}.page-header .subtitle{color:var(--text-secondary);margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1.25rem;text-align:center}.stat-value{font-size:1.75rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.filter-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.filter-tab{background:none;border:none;padding:.5rem 1rem;color:var(--text-secondary);cursor:pointer;border-radius:.375rem;transition:all .2s}.filter-tab:hover{background:var(--hover-bg);color:var(--text-primary)}.filter-tab.active{background:var(--primary-color);color:#fff}.empty-state{text-align:center;padding:4rem 2rem;background:var(--surface-color);border:1px dashed var(--border-color);border-radius:.5rem}.empty-state h3{margin:0 0 .5rem;color:var(--text-primary)}.empty-state p{color:var(--text-secondary);margin:0 0 1.5rem}.subscriptions-list{display:grid;gap:1rem}.subscription-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem}.subscription-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.subscription-client h3{margin:0 0 .25rem;font-size:1.125rem}.client-email{font-size:.875rem;color:var(--text-secondary)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-secondary{background:#f3f4f6;color:#6b7280}.subscription-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1rem;padding:1rem;background:var(--background-color);border-radius:.375rem}.detail-row{display:flex;flex-direction:column}.detail-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.detail-value{font-weight:500;color:var(--text-primary)}.detail-value.amount{font-size:1.125rem;color:var(--primary-color)}.subscription-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;font-style:italic}.subscription-actions{display:flex;gap:.5rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--border-color)}.btn-sm{padding:.375rem .75rem;font-size:.875rem}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover{background:var(--hover-bg)}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.action-loading{font-size:.875rem;color:var(--text-secondary);font-style:italic}.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;padding:1rem}.modal-content{background:var(--surface-color);border-radius:.5rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;padding:2rem;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-close:hover{background:var(--hover-bg)}.subscription-form{display:flex;flex-direction:column;gap:1.25rem}.subscription-form h2{margin:0 0 1rem}.subscription-form .form-group{display:flex;flex-direction:column;gap:.375rem}.subscription-form label{font-weight:500;color:var(--text-primary)}.subscription-form input[type=text],.subscription-form input[type=number],.subscription-form input[type=date],.subscription-form select,.subscription-form textarea{padding:.625rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:1rem}.subscription-form input:focus,.subscription-form select:focus,.subscription-form textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f133}.subscription-form small{font-size:.75rem;color:var(--text-secondary)}.subscription-form input[type=checkbox]{margin-right:.5rem}.subscription-form .form-actions{display:flex;gap:.75rem;margin-top:1rem}.subscription-form .form-actions button{flex:1}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 640px){.page-header{flex-direction:column;gap:1rem}.page-header button{width:100%}.subscription-details{grid-template-columns:repeat(2,1fr)}.subscription-actions{flex-direction:column}.subscription-actions button{width:100%}}.pricing-calculator{background:#fff;border-radius:.5rem;border:1px solid var(--border-color);padding:2rem}.calculator-header{margin-bottom:2rem;text-align:center}.calculator-header h2{margin:0 0 .5rem;color:var(--text-primary)}.calculator-header p{color:var(--text-secondary);margin:0}.calculator-layout{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.calculator-inputs,.calculator-results{display:flex;flex-direction:column;gap:1.5rem}.calculator-inputs h3,.calculator-results h3{margin:0 0 1rem;color:var(--text-primary);padding-bottom:.75rem;border-bottom:2px solid var(--border-color)}.slider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;-webkit-appearance:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none}.margin-display{text-align:center;font-size:1.5rem;font-weight:700;color:var(--primary-color);margin-top:.5rem}.btn-block{width:100%;margin-top:1rem}.result-card{background:var(--bg-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem;text-align:center}.result-card.highlight{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;box-shadow:0 4px 12px #667eea66}.result-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:.5rem}.result-card.highlight .result-label{color:#ffffffe6}.result-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.result-value.large{font-size:2.5rem}.result-value.profit{color:#2e7d32}.result-card.highlight .result-value{color:#fff}.result-description{font-size:.875rem;color:var(--text-secondary)}.result-card.highlight .result-description{color:#fffc}.result-breakdown{display:flex;justify-content:space-around;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);font-size:.875rem;color:var(--text-secondary)}.result-breakdown div{text-align:center}.pricing-tiers{background:#fff;border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem}.pricing-tiers h4{margin:0 0 1rem;color:var(--text-primary);font-size:1rem}.tier{display:flex;justify-content:space-between;align-items:center;padding:.75rem;margin-bottom:.5rem;background:var(--bg-color);border-radius:.25rem;transition:transform .2s}.tier:hover{transform:translate(4px)}.tier-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.tier-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.calculator-tips{background:#e3f2fd;border:1px solid #90caf9;border-radius:.5rem;padding:1.5rem}.calculator-tips h4{margin:0 0 1rem;color:#1565c0;font-size:1rem}.calculator-tips ul{margin:0;padding-left:1.5rem}.calculator-tips li{font-size:.875rem;color:#1976d2;margin-bottom:.5rem;line-height:1.5}.cost-calculator-section{background:var(--bg-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem;margin-top:1rem}.cost-calculator-section h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.125rem}.suggested-rate-box{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:.5rem;text-align:center;margin-top:1.5rem}.suggested-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;opacity:.9;margin-bottom:.5rem}.suggested-value{font-size:2.5rem;font-weight:700;margin-bottom:.75rem}.suggested-rate-box .btn-link{color:#fff;text-decoration:underline;background:none;border:none;cursor:pointer;font-size:.875rem;padding:0}.suggested-rate-box .btn-link:hover{opacity:.8}.quality-rating-input{display:flex;align-items:center;gap:.5rem}.star-btn{background:none;border:none;font-size:2rem;color:#e0e0e0;cursor:pointer;padding:0;transition:transform .1s}.star-btn:hover{transform:scale(1.1)}.star-btn.active{color:#ffc107}.rating-label{margin-left:.5rem;font-weight:600;color:var(--text-primary)}@media (max-width: 1024px){.calculator-layout{grid-template-columns:1fr;gap:2rem}}@media (max-width: 768px){.pricing-calculator{padding:1rem}.result-value{font-size:1.5rem}.result-value.large{font-size:2rem}.result-breakdown{flex-direction:column;gap:.5rem}}.pricing-optimization{padding:2rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.page-header h1{font-size:2rem;color:var(--text-primary);margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);font-size:.95rem;max-width:600px}.header-actions{display:flex;gap:.75rem;flex-shrink:0}.country-selector{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--bg-color);border-radius:.5rem}.country-selector label{font-weight:600;color:var(--text-primary)}.country-selector .input{max-width:250px}.tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border-color);margin-bottom:2rem}.tab{padding:.75rem 1.5rem;border:none;background:none;color:var(--text-secondary);font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.tab:hover{color:var(--text-primary);background:var(--bg-color)}.tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.tab-content{animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-card{background:#fff;padding:1.5rem;border-radius:.5rem;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000d}.metric-label{font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.metric-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.metric-subtitle{font-size:.875rem;color:var(--text-secondary)}.recommendations-section{margin-bottom:3rem}.recommendations-section h2{margin-bottom:1.5rem;color:var(--text-primary)}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.recommendation-card{background:#fff;border:2px solid var(--border-color);border-radius:.5rem;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s}.recommendation-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.rec-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.rec-header h3{font-size:1.25rem;color:var(--text-primary);margin:0}.confidence-badge{padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.confidence-badge.high{background:#e8f5e9;color:#2e7d32}.confidence-badge.medium{background:#fff3e0;color:#ef6c00}.confidence-badge.low{background:#ffebee;color:#c62828}.pricing-comparison{display:flex;align-items:center;justify-content:space-around;padding:1.5rem;background:var(--bg-color);border-radius:.5rem;margin-bottom:1rem}.price-col{text-align:center}.price-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.5rem}.price-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.price-col.highlight .price-value{color:var(--primary-color)}.price-arrow{font-size:2rem;color:var(--primary-color);font-weight:700}.localized-rate{text-align:center;font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;padding:.5rem;background:#f5f5f5;border-radius:.25rem}.market-position{text-align:center;margin-bottom:1rem}.position-badge{display:inline-block;padding:.5rem 1rem;border-radius:.25rem;font-size:.875rem;font-weight:600}.position-badge.budget{background:#e3f2fd;color:#1565c0}.position-badge.competitive{background:#f3e5f5;color:#6a1b9a}.position-badge.premium{background:#fff8e1;color:#f57f17}.reasoning{margin-bottom:1rem}.reasoning ul{margin:.5rem 0 0 1rem;padding:0}.reasoning li{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.adjustment-factors{border-top:1px solid var(--border-color);padding-top:1rem}.factor{display:flex;justify-content:space-between;padding:.5rem;margin:.25rem 0;border-radius:.25rem;font-size:.875rem}.factor.increase{background:#e8f5e9}.factor.decrease{background:#ffebee}.factor-name{color:var(--text-primary);font-weight:500}.factor-amount{font-weight:700}.service-performance,.client-insights{margin-bottom:3rem}.service-performance h2,.client-insights h2{margin-bottom:1.5rem;color:var(--text-primary)}.performance-table{background:#fff;border-radius:.5rem;border:1px solid var(--border-color);overflow:hidden}.performance-table table{width:100%;border-collapse:collapse}.performance-table th{background:var(--bg-color);padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.performance-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.performance-table tr:last-child td{border-bottom:none}.performance-table tr:hover{background:var(--bg-color)}.client-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.client-card{background:#fff;border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.client-card h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.125rem}.client-stat{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.client-stat:last-child{border-bottom:none}.stat-label{color:var(--text-secondary);font-size:.875rem}.stat-value{font-weight:600;color:var(--text-primary)}.section-header h2{margin:0;color:var(--text-primary)}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:.5rem;border:2px dashed var(--border-color)}.empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.service-card{background:#fff;border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d;transition:transform .2s,box-shadow .2s}.service-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.service-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.service-header h3{margin:0;font-size:1.125rem;color:var(--text-primary)}.service-category{background:var(--primary-color);color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600}.service-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.service-pricing{border-top:1px solid var(--border-color);padding-top:1rem;margin-bottom:1rem}.price-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.875rem}.price-row.suggested{color:var(--primary-color);font-weight:600}.service-costs{background:var(--bg-color);padding:.75rem;border-radius:.25rem;font-size:.75rem;color:var(--text-secondary)}.cost-item{padding:.25rem 0}.competitors-table{background:#fff;border-radius:.5rem;border:1px solid var(--border-color);overflow-x:auto}.competitors-table table{width:100%;border-collapse:collapse;min-width:800px}.competitors-table th{background:var(--bg-color);padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.competitors-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.competitors-table tr:last-child td{border-bottom:none}.competitors-table tr:hover{background:var(--bg-color)}.quality-stars{color:#ffc107;font-size:1rem}.loading{text-align:center;padding:4rem;color:var(--text-secondary)}@media (max-width: 768px){.pricing-optimization{padding:1rem}.page-header{flex-direction:column}.header-actions{width:100%}.header-actions button{flex:1}.metrics-grid,.recommendations-grid{grid-template-columns:1fr}.tabs{overflow-x:auto;white-space:nowrap}.services-grid,.client-cards{grid-template-columns:1fr}}.ai-agents-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem}.tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0}.tabs button{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#666;transition:all .3s}.tabs button.active{color:#1976d2;border-bottom-color:#1976d2}.agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.agent-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.agent-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.agent-icon{font-size:3rem;margin-bottom:1rem}.agent-card h3{font-size:1.3rem;margin-bottom:.5rem}.agent-description{color:#666;margin-bottom:1rem;min-height:3em}.agent-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.9rem}.schedule{color:#666}.status{padding:.25rem .75rem;border-radius:20px;font-weight:500}.status.active{background:#e8f5e9;color:#2e7d32}.status.paused{background:#fff3e0;color:#e65100}.agent-stats{margin-bottom:1rem}.last-run{display:flex;justify-content:space-between;font-size:.85rem;color:#666}.last-run .success{color:#2e7d32}.last-run .error{color:#c62828}.trigger-btn{width:100%;padding:.75rem;background:#1976d2;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.trigger-btn:hover:not(:disabled){background:#1565c0}.trigger-btn:disabled{background:#ccc;cursor:not-allowed}.activity-logs h2,.flagged-issues h2{margin-bottom:1.5rem}.logs-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.logs-table table{width:100%;border-collapse:collapse}.logs-table th{background:#f5f5f5;padding:1rem;text-align:left;font-weight:600;color:#333}.logs-table td{padding:1rem;border-bottom:1px solid #e0e0e0}.logs-table tr:last-child td{border-bottom:none}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.badge.completed{background:#e8f5e9;color:#2e7d32}.badge.failed{background:#ffebee;color:#c62828}.log-message{color:#666;font-size:.9rem}.flags-list{display:grid;gap:1rem}.flag-card{background:#fff;border-radius:12px;padding:1.5rem;border-left:4px solid;box-shadow:0 2px 8px #0000001a}.flag-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.flag-agent{font-weight:500;color:#666}.flag-severity{padding:.25rem .75rem;border-radius:12px;color:#fff;font-size:.85rem;font-weight:500}.flag-card h4{margin-bottom:.5rem;color:#333}.flag-card p{color:#666;margin-bottom:1rem}.flag-data{background:#f5f5f5;padding:1rem;border-radius:8px;font-size:.85rem;overflow-x:auto;margin-bottom:1rem}.flag-footer{display:flex;justify-content:space-between;align-items:center}.flag-footer small{color:#999}.resolve-btn{padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.resolve-btn:hover{background:#45a049}.no-flags{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.api-keys-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{font-size:2rem;margin-bottom:.5rem}.page-header p{color:#666;font-size:1.1rem}.create-key-btn{padding:.75rem 1.5rem;background:#1976d2;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.create-key-btn:hover{background:#1565c0}.new-key-alert{background:#fff3cd;border:2px solid #ffc107;border-radius:12px;padding:2rem;margin-bottom:2rem}.new-key-alert h3{color:#856404;margin-bottom:.5rem}.new-key-alert p{color:#856404;margin-bottom:1rem}.key-display{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}.key-display code{flex:1;background:#fff;padding:1rem;border-radius:8px;font-family:Courier New,monospace;font-size:.9rem;overflow-x:auto}.key-display button{padding:.75rem 1.5rem;background:#1976d2;color:#fff;border:none;border-radius:8px;cursor:pointer}.close-alert{padding:.75rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h2,.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.permissions-list{display:grid;gap:.75rem}.permission-checkbox{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f5f5f5;border-radius:8px;cursor:pointer;transition:background .2s}.permission-checkbox:hover{background:#e8e8e8}.permission-checkbox input{width:auto;cursor:pointer}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.form-actions button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s}.form-actions button[type=button]{background:#f5f5f5;color:#333}.form-actions button[type=submit]{background:#1976d2;color:#fff}.form-actions button[type=submit]:disabled{background:#ccc;cursor:not-allowed}.api-keys-list{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;overflow-x:auto}.keys-table{width:100%;border-collapse:collapse}.keys-table th{background:#f5f5f5;padding:1rem;text-align:left;font-weight:600;color:#333}.keys-table td{padding:1rem;border-bottom:1px solid #e0e0e0}.keys-table tr:last-child td{border-bottom:none}.masked-key{font-family:Courier New,monospace;font-size:.9rem;background:#f5f5f5;padding:.25rem .5rem;border-radius:4px}.env-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.env-badge.test{background:#e3f2fd;color:#1565c0}.env-badge.production{background:#fce4ec;color:#c2185b}.permissions-tags{display:flex;gap:.5rem;flex-wrap:wrap}.perm-tag{padding:.25rem .5rem;background:#e8f5e9;color:#2e7d32;border-radius:8px;font-size:.8rem;font-weight:500}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.disabled{background:#ffebee;color:#c62828}.revoke-btn{padding:.5rem 1rem;background:#f44336;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.revoke-btn:hover:not(:disabled){background:#d32f2f}.revoke-btn:disabled{background:#ccc;cursor:not-allowed}.empty-state{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.api-documentation{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.api-documentation h2{margin-bottom:1.5rem}.code-example{margin-bottom:2rem}.code-example h3{margin-bottom:.75rem;color:#333}.code-example pre{background:#1e1e1e;color:#d4d4d4;padding:1.5rem;border-radius:8px;overflow-x:auto;font-family:Courier New,monospace;font-size:.9rem;line-height:1.6}.gateway-settings{padding:1.5rem}.gateway-settings.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.gateway-settings .spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.settings-header{margin-bottom:1.5rem}.settings-header h2{margin:0 0 .5rem;color:#1e293b}.settings-description{color:#64748b;margin:0}.gateway-list{display:grid;gap:1rem;margin-bottom:2rem}.gateway-card{background:#fff;border:2px solid #e2e8f0;border-radius:.5rem;padding:1.25rem;transition:all .2s}.gateway-card.active{border-color:#3b82f6;background:#eff6ff}.gateway-card.configured:not(.active){border-color:#10b981}.gateway-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.gateway-info{display:flex;align-items:center;gap:.75rem}.gateway-info h3{margin:0;font-size:1.125rem;color:#1e293b}.active-badge{background:#3b82f6;color:#fff;font-size:.625rem;font-weight:600;padding:.25rem .5rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.05em}.configured-badge{background:#d1fae5;color:#065f46;font-size:.625rem;font-weight:600;padding:.25rem .5rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.05em}.gateway-actions{display:flex;gap:.5rem}.gateway-description{color:#64748b;margin:0 0 1rem;font-size:.875rem}.gateway-details{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem;background:#f8fafc;border-radius:.375rem;margin-bottom:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem;min-width:150px}.detail-item .label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.detail-item .value{font-size:.875rem;color:#1e293b}.test-result{padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem}.test-result.success{background:#d1fae5;color:#065f46}.test-result.error{background:#fee2e2;color:#991b1b}.key-form{border-top:1px solid #e2e8f0;padding-top:1rem;margin-top:.5rem}.key-form h4{margin:0 0 1rem;font-size:.875rem;color:#1e293b}.key-form .form-group{margin-bottom:1rem}.key-form .form-group label{display:block;font-size:.75rem;font-weight:500;color:#64748b;margin-bottom:.25rem}.key-form .form-actions{display:flex;gap:.5rem;margin-top:1rem}.configure-btn{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;padding:0}.configure-btn:hover{text-decoration:underline}.gateway-help{background:#f8fafc;border-radius:.5rem;padding:1.5rem}.gateway-help h3{margin:0 0 1rem;font-size:1rem;color:#1e293b}.help-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.help-card{background:#fff;border:1px solid #e2e8f0;border-radius:.375rem;padding:1rem}.help-card h4{margin:0 0 .75rem;font-size:.875rem;color:#1e293b}.help-card ol{margin:0;padding-left:1.25rem;font-size:.875rem;color:#475569}.help-card li{margin-bottom:.5rem}.help-card a{color:#3b82f6}@media (max-width: 640px){.gateway-header{flex-direction:column;gap:1rem}.gateway-actions{width:100%}.gateway-actions .btn{flex:1}.gateway-details{flex-direction:column;gap:.5rem}.key-form .form-actions{flex-direction:column}.key-form .form-actions .btn{width:100%}}.settings-container{display:grid;grid-template-columns:250px 1fr;gap:2rem;margin-top:2rem}.alert{padding:1rem;border-radius:.375rem;font-size:.875rem;margin-bottom:1rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-success{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.loading-spinner{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1rem}.settings-tabs{display:flex;flex-direction:column;gap:.5rem}.tab-button{padding:.75rem 1rem;border:none;background:#fff;border-radius:.375rem;text-align:left;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .2s;box-shadow:var(--shadow)}.tab-button:hover{background-color:var(--bg-color);color:var(--text-primary)}.tab-button.active{background-color:var(--primary-color);color:#fff;box-shadow:var(--shadow-md)}.settings-content{min-height:400px}.settings-content h2{margin:0 0 1.5rem;font-size:1.5rem}.settings-content h3{margin:0 0 .5rem;font-size:1.125rem}.help-text{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.payment-gateway-section{padding:1.5rem 0;border-bottom:1px solid var(--border-color)}.payment-gateway-section:last-child{border-bottom:none}.notification-option{padding:1rem 0;border-bottom:1px solid var(--border-color)}.notification-option:last-child{border-bottom:none}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.875rem}.checkbox-label input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer}@media (max-width: 768px){.settings-container{grid-template-columns:1fr}.settings-tabs{flex-direction:row;overflow-x:auto}.tab-button{white-space:nowrap}}.portal-container{min-height:100vh;background-color:#f8fafc}.portal-loading,.portal-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem}.portal-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.portal-error h2{color:#ef4444;margin-bottom:.5rem}.portal-header{background:linear-gradient(135deg,#2563eb,#1d4ed8,#1e40af);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px -1px #0000001a}.portal-brand h1{font-size:1.5rem;margin:0}.portal-label{font-size:.75rem;background:#fff3;padding:.25rem .5rem;border-radius:4px;margin-left:.5rem}.portal-client-info{text-align:right}.client-name{display:block;font-weight:600}.client-email{display:block;font-size:.875rem;opacity:1;color:#fffffff2}.portal-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 2rem;display:flex;gap:0}.nav-tab{background:none;border:none;padding:1rem 1.5rem;font-size:.875rem;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.nav-tab:hover{color:#3b82f6}.nav-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.portal-main{max-width:1200px;margin:0 auto;padding:2rem}.portal-section{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.portal-section h2{margin:0 0 1.5rem;color:#1e293b;font-size:1.25rem}.section-header h2{margin:0}.empty-state{text-align:center;padding:3rem;color:#64748b}.empty-state .text-small{font-size:.875rem;margin-top:.5rem}.portal-table{width:100%;border-collapse:collapse}.portal-table th,.portal-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e2e8f0}.portal-table th{font-weight:600;color:#64748b;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.portal-table td{color:#1e293b}.portal-table .font-mono{font-family:monospace}.portal-table .amount{font-weight:600}.portal-table .due-info{font-size:.75rem;color:#64748b}.action-buttons{display:flex;gap:.5rem}.btn-sm{padding:.375rem .75rem;font-size:.75rem;border-radius:.25rem;border:none;cursor:pointer;font-weight:500}.btn-sm.btn-primary{background:#3b82f6;color:#fff}.btn-sm.btn-primary:hover{background:#2563eb}.btn-sm.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-sm.btn-secondary{background:#e2e8f0;color:#475569}.btn-sm.btn-secondary:hover{background:#cbd5e1}.cost-breakdown{display:grid;gap:1.5rem}.project-costs{border:1px solid #e2e8f0;padding:1.5rem}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.project-header h3{margin:0;font-size:1.125rem}.project-header .period{font-size:.875rem;color:#64748b}.total-cost{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f1f5f9;border-radius:.375rem;margin-bottom:1rem}.total-cost strong{font-size:1.25rem;color:#1e293b}.services-list h4{font-size:.875rem;color:#64748b;margin:0 0 .5rem}.services-table{width:100%}.services-table td{padding:.5rem 0;border-bottom:1px solid #f1f5f9}.services-table .amount{text-align:right;font-weight:500}.payment-methods-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:2rem}.payment-method-card{border:1px solid #e2e8f0;border-radius:.5rem;padding:1.25rem;position:relative}.payment-method-card.default{border-color:#3b82f6;background:#eff6ff}.card-brand{font-weight:700;font-size:.875rem;color:#1e293b;margin-bottom:.5rem}.card-number{font-family:monospace;font-size:1rem;letter-spacing:.1em;margin-bottom:.25rem}.card-expiry{font-size:.875rem;color:#64748b}.default-badge{position:absolute;top:.75rem;right:.75rem;background:#3b82f6;color:#fff;font-size:.625rem;padding:.25rem .5rem;border-radius:9999px;font-weight:600;text-transform:uppercase}.auto-charge-section{border-top:1px solid #e2e8f0;padding-top:1.5rem}.auto-charge-section h3{margin:0 0 .5rem;font-size:1rem}.auto-charge-section .text-small{color:#64748b;margin-bottom:1rem}.project-auto-charge{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border:1px solid #e2e8f0;border-radius:.375rem;margin-bottom:.5rem}.project-auto-charge .status{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:.25rem}.project-auto-charge .status.enabled{background:#d1fae5;color:#065f46}.project-auto-charge .status.disabled{background:#fef3c7;color:#92400e}.portal-footer{text-align:center;padding:2rem;color:#64748b;font-size:.875rem}@media (max-width: 768px){.portal-header{flex-direction:column;text-align:center;gap:1rem}.portal-client-info{text-align:center}.portal-nav{padding:0 1rem;overflow-x:auto}.nav-tab{padding:.75rem 1rem;white-space:nowrap}.portal-main{padding:1rem}.portal-table{display:block;overflow-x:auto}.section-header{flex-direction:column;gap:1rem;align-items:stretch}}.invoice-detail-container{min-height:100vh;background-color:#f8fafc}.invoice-loading,.invoice-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem}.invoice-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.invoice-detail-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.back-button{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;padding:.5rem 0}.header-actions{display:flex;gap:.75rem}.invoice-document{max-width:800px;margin:2rem auto;background:#fff;box-shadow:0 4px 6px -1px #0000001a;border-radius:.5rem;padding:3rem}.invoice-header-section{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;border-bottom:2px solid #1e293b;padding-bottom:1.5rem}.invoice-branding h1{font-size:2rem;margin:0;color:#1e293b;letter-spacing:.1em}.invoice-number{font-family:monospace;font-size:1rem;color:#64748b;margin:.5rem 0 0}.invoice-status-badge{padding:.5rem 1rem;border-radius:.25rem;font-weight:700;font-size:.75rem;letter-spacing:.05em}.invoice-status-badge.paid{background:#d1fae5;color:#065f46}.invoice-status-badge.pending{background:#fef3c7;color:#92400e}.invoice-status-badge.overdue{background:#fee2e2;color:#991b1b}.invoice-parties{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.invoice-parties h4{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.invoice-parties .company-name{font-weight:600;font-size:1.125rem;margin:0 0 .25rem}.invoice-parties p{margin:0;color:#475569}.invoice-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;padding:1rem;background:#f8fafc;border-radius:.375rem}.meta-item{display:flex;flex-direction:column}.meta-item .label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.meta-item .value{font-weight:500;color:#1e293b}.meta-item .value.overdue{color:#ef4444}.invoice-items{margin-bottom:2rem}.items-table{width:100%;border-collapse:collapse}.items-table th{text-align:left;padding:.75rem;border-bottom:2px solid #e2e8f0;font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.items-table td{padding:1rem .75rem;border-bottom:1px solid #f1f5f9;color:#1e293b}.items-table .text-right{text-align:right}.invoice-totals{margin-left:auto;width:300px}.totals-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.totals-row.total{border-bottom:none;border-top:2px solid #1e293b;margin-top:.5rem;padding-top:1rem;font-weight:700;font-size:1.25rem}.payment-info{margin-top:3rem;text-align:center;padding:2rem;background:#d1fae5;border-radius:.5rem}.paid-stamp{display:inline-block;font-size:2rem;font-weight:900;color:#065f46;border:4px solid #065f46;padding:.5rem 1.5rem;border-radius:.25rem;transform:rotate(-5deg);margin-bottom:1rem}.payment-info p{color:#065f46;margin:0}.invoice-detail-footer{text-align:center;padding:2rem;color:#64748b}@page{size:A4;margin:15mm}@media print{html,body{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.invoice-detail-header,.invoice-detail-footer,.header-actions,.back-button{display:none!important}.invoice-detail-container{background:#fff!important;min-height:auto!important;padding:0!important}.invoice-document{box-shadow:none!important;margin:0!important;padding:20px!important;max-width:100%!important;border-radius:0!important;page-break-inside:avoid}.invoice-header-section{margin-bottom:1.5rem!important;padding-bottom:1rem!important}.invoice-branding h1{font-size:1.5rem!important}.invoice-parties{margin-bottom:1rem!important;gap:1rem!important}.invoice-meta{margin-bottom:1rem!important;padding:.5rem!important}.invoice-items{margin-bottom:1rem!important}.items-table td,.items-table th{padding:.5rem!important;font-size:.875rem!important}.invoice-totals{width:250px!important}.totals-row{padding:.25rem 0!important;font-size:.875rem!important}.totals-row.total{font-size:1rem!important;padding-top:.5rem!important}.payment-info{margin-top:1rem!important;padding:1rem!important}.paid-stamp{font-size:1.5rem!important}}@media (max-width: 768px){.invoice-detail-header{flex-direction:column;gap:1rem;align-items:stretch}.header-actions{justify-content:stretch}.header-actions .btn{flex:1}.invoice-document{margin:1rem;padding:1.5rem}.invoice-header-section{flex-direction:column;gap:1rem}.invoice-parties{grid-template-columns:1fr}.invoice-meta{grid-template-columns:1fr 1fr}.items-table{font-size:.875rem}.invoice-totals{width:100%}}.payment-setup-container{min-height:100vh;background-color:#f8fafc}.payment-loading,.payment-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem}.payment-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.payment-setup-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 2rem}.back-button{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;padding:.5rem 0;margin-bottom:.5rem}.back-button:hover{text-decoration:underline}.payment-setup-header h1{margin:0;font-size:1.5rem;color:#1e293b}.payment-setup-main{max-width:800px;margin:0 auto;padding:2rem}.payment-methods-section{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0;font-size:1.125rem;color:#1e293b}.empty-state{text-align:center;padding:3rem 1rem}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state p{color:#64748b;margin-bottom:.5rem}.empty-state .text-small{font-size:.875rem;margin-bottom:1.5rem}.payment-methods-grid{display:grid;gap:1rem}.payment-card{border:1px solid #e2e8f0;border-radius:.5rem;overflow:hidden}.payment-card.default{border-color:#3b82f6}.card-visual{background:linear-gradient(135deg,#1e293b,#475569);color:#fff;padding:1.5rem;position:relative}.card-brand-logo{font-size:1rem;margin-bottom:1rem}.card-number-display{font-family:monospace;font-size:1.25rem;letter-spacing:.15em;margin-bottom:.5rem}.card-expiry-display{font-size:.875rem;opacity:.8}.card-actions{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8fafc}.default-label{color:#3b82f6;font-weight:600;font-size:.875rem}.btn-link{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;padding:.25rem}.btn-link:hover{text-decoration:underline}.btn-link.danger{color:#ef4444}.add-card-section{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:1.5rem}.add-card-section h3{margin:0 0 1.5rem;color:#1e293b}.card-form{max-width:400px}.card-error{background:#fee2e2;color:#991b1b;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.card-number-input{font-family:monospace;letter-spacing:.1em}.stripe-card-element{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;background:#fff;transition:border-color .2s,box-shadow .2s}.stripe-card-element:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.test-card-notice{margin-top:1.5rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;padding:1rem 1.5rem}.test-card-notice h4{margin:0 0 .5rem;color:#92400e;font-size:.875rem}.test-card-notice p{margin:0 0 .5rem;color:#78350f;font-size:.875rem}.test-card-notice ul{margin:0;padding-left:1.25rem}.test-card-notice li{color:#78350f;font-size:.8125rem;margin-bottom:.25rem}.test-card-notice li strong{font-weight:600}.secure-notice{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f0fdf4;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem;color:#166534}.lock-icon{font-size:1rem}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem}.stripe-notice{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0;text-align:center;color:#64748b}.stripe-notice p{margin:0}.stripe-notice .text-small{font-size:.75rem;margin-top:.5rem}.info-section{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.info-section h3{margin:0 0 1rem;color:#1e293b;font-size:1rem}.info-section p{color:#64748b;margin-bottom:1rem}.info-section ul{list-style:none;padding:0;margin:0}.info-section li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#475569}.info-section li:before{content:"✓";position:absolute;left:0;color:#10b981}@media (max-width: 640px){.payment-setup-main{padding:1rem}.section-header{flex-direction:column;gap:1rem;align-items:stretch}.section-header .btn{width:100%}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.legal-container{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:2rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.legal-card{max-width:800px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:3rem;position:relative}.legal-back{display:inline-flex;align-items:center;gap:8px;color:#6366f1;text-decoration:none;font-weight:500;font-size:.9375rem;margin-bottom:2rem;transition:color .2s,transform .2s}.legal-back:hover{color:#4f46e5;transform:translate(-4px)}.legal-back svg{transition:transform .2s}.legal-back:hover svg{transform:translate(-2px)}.legal-card h1{font-size:2.25rem;font-weight:700;color:#0f172a;margin-bottom:.5rem;letter-spacing:-.025em}.legal-updated{color:#64748b;font-size:.875rem;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e2e8f0}.legal-content{color:#334155;line-height:1.75}.legal-content section{margin-bottom:2.5rem}.legal-content section:last-child{margin-bottom:0}.legal-content h2{font-size:1.375rem;font-weight:600;color:#0f172a;margin-bottom:1rem;padding-top:.5rem}.legal-content h3{font-size:1.125rem;font-weight:600;color:#1e293b;margin-top:1.5rem;margin-bottom:.75rem}.legal-content p{margin-bottom:1rem;font-size:.9375rem}.legal-content ul{margin:1rem 0;padding-left:1.5rem}.legal-content li{margin-bottom:.5rem;font-size:.9375rem;position:relative}.legal-content li::marker{color:#6366f1}.legal-content strong{color:#0f172a;font-weight:600}.legal-content a{color:#6366f1;text-decoration:none;font-weight:500;transition:color .2s}.legal-content a:hover{color:#4f46e5;text-decoration:underline}.contact-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem;margin-top:1rem}.contact-info p{margin-bottom:.25rem;font-size:.9375rem}.contact-info p:last-child{margin-bottom:0}.legal-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.legal-footer a{color:#6366f1;text-decoration:none;font-weight:500;font-size:.875rem;transition:color .2s}.legal-footer a:hover{color:#4f46e5}.legal-footer .separator{color:#cbd5e1}@media (max-width: 640px){.legal-container{padding:1rem}.legal-card{padding:1.5rem;border-radius:12px}.legal-card h1{font-size:1.75rem}.legal-content h2{font-size:1.25rem}.legal-content h3{font-size:1rem}}@media print{.legal-container{background:#fff;padding:0}.legal-card{box-shadow:none;padding:0}.legal-back,.legal-footer{display:none}.legal-content{font-size:12pt}}.layout{min-height:100vh;display:flex;flex-direction:column;background:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.nav{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.1)}.nav:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(99,102,241,.05) 25%,rgba(139,92,246,.05) 50%,rgba(99,102,241,.05) 75%,transparent 100%);pointer-events:none}.nav-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:4rem;position:relative}.nav-brand{display:flex;align-items:center;gap:.75rem}.nav-brand-icon{width:36px;height:36px;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #6366f166,inset 0 1px #fff3;transition:transform .3s ease,box-shadow .3s ease}.nav-brand:hover .nav-brand-icon{transform:scale(1.05) rotate(-2deg);box-shadow:0 6px 20px #6366f180,inset 0 1px #fff3}.nav-brand-icon svg{width:20px;height:20px;color:#fff}.nav-brand a{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,#fff,#e2e8f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;letter-spacing:-.025em;transition:opacity .2s}.nav-brand a:hover{opacity:.9}.nav-links{display:flex;gap:.25rem;align-items:center;background:#ffffff0d;padding:.25rem;border-radius:12px;border:1px solid rgba(255,255,255,.08)}.nav-links a{color:#ffffffb3;text-decoration:none;font-weight:500;font-size:.875rem;padding:.5rem .875rem;border-radius:8px;transition:all .2s ease;position:relative;white-space:nowrap}.nav-links a:hover{color:#fff;background:#ffffff1a}.nav-links a.active{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 8px #6366f166}.nav-link-icon{display:flex;align-items:center;gap:.5rem}.nav-link-icon svg{width:16px;height:16px;opacity:.8}.nav-user{display:flex;align-items:center;gap:1rem}.user-menu{display:flex;align-items:center;gap:.75rem;padding:.375rem .75rem .375rem .5rem;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:50px;transition:all .2s ease;cursor:pointer}.user-menu:hover{background:#ffffff1f;border-color:#ffffff26}.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase}.user-info{display:flex;flex-direction:column;align-items:flex-start}.user-email{color:#ffffffe6;font-size:.8125rem;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#ffffff80;font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.btn-signout{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-signout:hover{background:#ef444440;border-color:#ef444480;color:#fecaca;transform:translateY(-1px)}.btn-signout svg{width:16px;height:16px}.main-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:2rem 1.5rem}.mobile-menu-btn{display:none;padding:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s}.mobile-menu-btn:hover{background:#ffffff26}.mobile-menu-btn svg{width:24px;height:24px}.mobile-menu-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;opacity:0;transition:opacity .3s ease}.mobile-menu-overlay.open{opacity:1}.mobile-menu{display:none;position:fixed;top:0;right:-100%;width:280px;height:100vh;background:linear-gradient(180deg,#0f172a,#1e293b);z-index:201;padding:1.5rem;transition:right .3s ease;overflow-y:auto}.mobile-menu.open{right:0}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:1.5rem}.mobile-menu-close{padding:.5rem;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s}.mobile-menu-close:hover{background:#ffffff26}.mobile-nav-links{display:flex;flex-direction:column;gap:.5rem}.mobile-nav-links a{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;color:#fffc;text-decoration:none;font-weight:500;font-size:.9375rem;border-radius:10px;transition:all .2s}.mobile-nav-links a:hover,.mobile-nav-links a.active{background:#ffffff1a;color:#fff}.mobile-nav-links a.active{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.mobile-nav-links a svg{width:20px;height:20px;opacity:.8}.mobile-user-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.mobile-user-info{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#ffffff0d;border-radius:12px;margin-bottom:1rem}.mobile-user-info .user-avatar{width:40px;height:40px;font-size:.875rem}.mobile-btn-signout{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#fca5a5;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s}.mobile-btn-signout:hover{background:#ef444440}@media (max-width: 1200px){.nav-links{gap:.125rem}.nav-links a{padding:.5rem .625rem;font-size:.8125rem}}@media (max-width: 1024px){.nav-links,.nav-user{display:none}.mobile-menu-btn{display:flex}.mobile-menu-overlay,.mobile-menu{display:block}}@media (max-width: 640px){.nav-container{padding:0 1rem}.nav-brand a{font-size:1.125rem}.nav-brand-icon{width:32px;height:32px}.nav-brand-icon svg{width:18px;height:18px}.main-content{padding:1.5rem 1rem}}@media (prefers-color-scheme: dark){.layout,.main-content{background:#0f172a}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 221.2 83.2% 53.3%;--primary-foreground: 210 40% 98%;--secondary: 210 40% 96.1%;--secondary-foreground: 222.2 47.4% 11.2%;--muted: 210 40% 96.1%;--muted-foreground: 215.4 16.3% 46.9%;--accent: 210 40% 96.1%;--accent-foreground: 222.2 47.4% 11.2%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 214.3 31.8% 91.4%;--input: 214.3 31.8% 91.4%;--ring: 221.2 83.2% 53.3%;--radius: .5rem;--primary-color: #3b82f6;--primary-hover: #2563eb;--secondary-color: #64748b;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--bg-color: #f8fafc;--surface-color: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--hover-bg: #f1f5f9;--background-color: #f8fafc}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground));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}.btn{display:inline-flex;cursor:pointer;align-items:center;justify-content:center;border-radius:calc(var(--radius) - 2px);border-style:none;padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;animation-duration:.2s}.btn-primary{background-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.btn-primary:hover{background-color:hsl(var(--primary) / .9)}.btn-secondary{background-color:hsl(var(--secondary));color:hsl(var(--secondary-foreground))}.btn-secondary:hover{background-color:hsl(var(--secondary) / .8)}.btn-success{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.btn-success:hover{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.btn-danger{background-color:hsl(var(--destructive));color:hsl(var(--destructive-foreground))}.btn-danger:hover{background-color:hsl(var(--destructive) / .9)}.btn-outline{border-width:1px;border-color:hsl(var(--input));background-color:hsl(var(--background))}.btn-outline:hover{background-color:hsl(var(--accent));color:hsl(var(--accent-foreground))}.card{border-radius:var(--radius);border-width:1px;background-color:hsl(var(--card));padding:1.5rem;color:hsl(var(--card-foreground));--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.input{display:flex;height:2.5rem;width:100%;border-radius:calc(var(--radius) - 2px);border-width:1px;border-color:hsl(var(--input));background-color:hsl(var(--background));padding:.5rem .75rem;font-size:.875rem;line-height:1.25rem;--tw-ring-offset-color: hsl(var(--background))}.input::file-selector-button{border-width:0px;background-color:transparent;font-size:.875rem;line-height:1.25rem;font-weight:500}.input::-moz-placeholder{color:hsl(var(--muted-foreground))}.input::placeholder{color:hsl(var(--muted-foreground))}.input:focus-visible{outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-color: hsl(var(--ring));--tw-ring-offset-width: 2px}.input:disabled{cursor:not-allowed;opacity:.5}.badge{display:inline-flex;align-items:center;border-radius:9999px;padding:.125rem .625rem;font-size:.75rem;line-height:1rem;font-weight:600;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.badge-success{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.badge-warning{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.badge-danger{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.badge-info{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-4{right:1rem}.top-4{top:1rem}.top-\[50\%\]{top:50%}.z-50{z-index:50}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.mb-1{margin-bottom:.25rem}.ml-auto{margin-left:auto}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.aspect-square{aspect-ratio:1 / 1}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-2{height:.5rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.max-h-96{max-height:24rem}.min-h-\[80px\]{min-height:80px}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-2{width:.5rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-\[1px\]{width:1px}.w-full{width:100%}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-lg{max-width:32rem}.shrink-0{flex-shrink:0}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.translate-x-\[-50\%\]{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-4{gap:1rem}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-destructive\/50{border-color:hsl(var(--destructive) / .5)}.border-green-500\/50{border-color:#22c55e80}.border-input{border-color:hsl(var(--input))}.border-transparent{border-color:transparent}.border-yellow-500\/50{border-color:#eab30880}.bg-background{background-color:hsl(var(--background))}.bg-black\/80{background-color:#000c}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-destructive{background-color:hsl(var(--destructive))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted\/50{background-color:hsl(var(--muted) / .5)}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-secondary{background-color:hsl(var(--secondary))}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-yellow-50{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.fill-current{fill:currentColor}.p-1{padding:.25rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pt-0{padding-top:0}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-secondary{color:hsl(var(--secondary))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-700{--tw-text-opacity: 1;color:rgb(161 98 7 / var(--tw-text-opacity, 1))}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.underline-offset-4{text-underline-offset:4px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.fade-in-0{--tw-enter-opacity: 0}.zoom-in-95{--tw-enter-scale: .95}.duration-200{animation-duration:.2s}.running{animation-play-state:running}.paused{animation-play-state:paused}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-destructive\/80:hover{background-color:hsl(var(--destructive) / .8)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-green-600:hover{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.hover\:bg-muted\/50:hover{background-color:hsl(var(--muted) / .5)}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary) / .8)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-5[data-state=checked]{--tw-translate-x: 1.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:hsl(var(--foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=active\]\:shadow-sm[data-state=active]{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.data-\[state\=open\]\:animate-in[data-state=open]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity: initial;--tw-exit-scale: initial;--tw-exit-rotate: initial;--tw-exit-translate-x: initial;--tw-exit-translate-y: initial}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity: 0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity: 0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale: .95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale: .95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y: -.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x: .5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x: -.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y: .5rem}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x: -50%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y: -48%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x: -50%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y: -48%}.dark\:border-destructive:is(.dark *){border-color:hsl(var(--destructive))}.dark\:border-green-500:is(.dark *){--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.dark\:border-yellow-500:is(.dark *){--tw-border-opacity: 1;border-color:rgb(234 179 8 / var(--tw-border-opacity, 1))}.dark\:bg-blue-900:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(30 58 138 / var(--tw-bg-opacity, 1))}.dark\:bg-green-900:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(20 83 45 / var(--tw-bg-opacity, 1))}.dark\:bg-green-950:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(5 46 22 / var(--tw-bg-opacity, 1))}.dark\:bg-yellow-900:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(113 63 18 / var(--tw-bg-opacity, 1))}.dark\:bg-yellow-950:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(66 32 6 / var(--tw-bg-opacity, 1))}.dark\:text-blue-100:is(.dark *){--tw-text-opacity: 1;color:rgb(219 234 254 / var(--tw-text-opacity, 1))}.dark\:text-green-100:is(.dark *){--tw-text-opacity: 1;color:rgb(220 252 231 / var(--tw-text-opacity, 1))}.dark\:text-yellow-100:is(.dark *){--tw-text-opacity: 1;color:rgb(254 249 195 / var(--tw-text-opacity, 1))}@media (min-width: 640px){.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:rounded-lg{border-radius:var(--radius)}.sm\:text-left{text-align:left}}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y: -3px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:left-4>svg{left:1rem}.\[\&\>svg\]\:top-4>svg{top:1rem}.\[\&\>svg\]\:text-destructive>svg{color:hsl(var(--destructive))}.\[\&\>svg\]\:text-foreground>svg{color:hsl(var(--foreground))}.\[\&\>svg\]\:text-green-600>svg{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.\[\&\>svg\]\:text-yellow-600>svg{--tw-text-opacity: 1;color:rgb(202 138 4 / var(--tw-text-opacity, 1))}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:1.75rem}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0px}.\[\&_p\]\:leading-relaxed p{line-height:1.625}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0px}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}
