:root{--color-primary: #0f172a;--color-primary-light: #334155;--color-primary-dark: #020617;--color-secondary: #0891b2;--color-secondary-light: #06b6d4;--color-secondary-dark: #0e7490;--color-neutral-50: #f8fafc;--color-neutral-100: #f1f5f9;--color-neutral-200: #e2e8f0;--color-neutral-300: #cbd5e1;--color-neutral-400: #94a3b8;--color-neutral-500: #64748b;--color-neutral-600: #475569;--color-neutral-700: #334155;--color-neutral-800: #1e293b;--color-neutral-900: #0f172a;--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--color-info: #3b82f6;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-neutral-900);background-color:var(--color-neutral-50)}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;display:block}html{margin:0;padding:0}h1,h2,h3,h4,h5,h6{font-weight:700;color:var(--color-neutral-900)}a{font-weight:500;color:var(--color-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary-dark)}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}#root{min-height:100vh;width:100%;display:block;margin:0;padding:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-neutral-100)}::-webkit-scrollbar-thumb{background:var(--color-neutral-400);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-500)}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#334155);padding:1rem;position:relative}.login-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(8,145,178,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(6,182,212,.1) 0%,transparent 50%);pointer-events:none}.login-card{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;padding:4rem 3rem;width:100%;max-width:500px;animation:slideUp .4s ease-out}.login-header{text-align:center;margin-bottom:3rem}.login-header h1{font-size:2rem;font-weight:700;color:#0f172a;margin:0 0 .5rem;line-height:1.4}.login-subtitle{font-size:1.063rem;color:#64748b;margin:0;font-weight:500}.login-form{margin-bottom:0}.form-group{margin-bottom:2rem}.form-label{display:block;font-size:.938rem;font-weight:600;color:#334155;margin-bottom:.625rem}.form-input{width:100%;padding:.875rem 1.125rem;font-size:1rem;border:2px solid #e2e8f0;border-radius:.5rem;transition:all .2s;box-sizing:border-box;font-family:inherit}.form-input:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 3px #0891b21a}.form-input-error{border-color:#ef4444}.form-input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.input-hint{display:block;font-size:.75rem;color:#0891b2;margin-top:.375rem;font-weight:500}.form-error{display:block;font-size:.875rem;color:#ef4444;margin-top:.375rem;font-weight:500}.btn-primary{width:100%;padding:1rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#0f172a,#1e293b);border:none;border-radius:.5rem;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 6px -1px #0f172a4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0f172a80;background:linear-gradient(135deg,#1e293b,#334155)}.btn-primary:active{transform:translateY(0)}@media(max-width:580px){.login-card{padding:3rem 2rem}.login-header{margin-bottom:2rem}.login-header h1{font-size:1.75rem}.form-group{margin-bottom:1.5rem}}.otp-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#334155);padding:1rem;position:relative}.otp-container:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(8,145,178,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(6,182,212,.1) 0%,transparent 50%);pointer-events:none}.otp-card{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;padding:2rem;width:100%;max-width:480px;position:relative;animation:slideUp .4s ease-out}.back-button{position:absolute;top:1.5rem;left:1.5rem;display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.875rem;font-weight:600;color:#64748b;background:transparent;border:none;border-radius:.375rem;cursor:pointer;transition:all .2s}.back-button:hover{background:#f1f5f9;color:#334155;transform:translate(-2px)}.otp-header{text-align:center;margin-bottom:2.5rem;margin-top:2rem}.otp-icon{display:flex;justify-content:center;margin-bottom:1.5rem}.otp-header h1{font-size:1.875rem;font-weight:700;color:#0f172a;margin:0 0 .75rem;line-height:1.2}.otp-subtitle{color:#64748b;font-size:.938rem;margin:0;line-height:1.6}.otp-subtitle strong{color:#2563eb;font-weight:600}.otp-form{margin-bottom:2rem}.otp-inputs{display:flex;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.otp-input{width:3.5rem;height:3.5rem;text-align:center;font-size:1.5rem;font-weight:600;border:2px solid #e2e8f0;border-radius:.75rem;transition:all .2s;font-family:SF Mono,Monaco,Courier New,monospace;color:#0f172a}.otp-input:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 3px #0891b21a;transform:scale(1.05)}.otp-input-filled{border-color:#0891b2;background:#0891b20d}.otp-input-error{border-color:#ef4444}.otp-input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.btn-primary{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#0f172a,#1e293b);border:none;border-radius:.5rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px -1px #0f172a4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 15px -3px #0f172a80;background:linear-gradient(135deg,#1e293b,#334155)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.otp-footer{text-align:center;padding-top:1.5rem;border-top:1px solid #e2e8f0}.timer-section{margin-bottom:1rem}.timer-section p{font-size:.938rem;color:#64748b;margin:0}.timer-section strong{color:#0891b2;font-weight:600}.btn-link{background:none;border:none;color:#0891b2;font-size:.938rem;font-weight:600;cursor:pointer;padding:.5rem 1rem;border-radius:.375rem;transition:all .2s}.btn-link:hover{background:#ecfeff;text-decoration:underline}.help-text p{font-size:.813rem;color:#94a3b8;margin:0;line-height:1.5}@media(max-width:480px){.otp-card{padding:1.5rem}.otp-header{margin-top:2.5rem}.otp-header h1{font-size:1.5rem}.otp-inputs{gap:.5rem}.otp-input{width:2.75rem;height:2.75rem;font-size:1.25rem}}.dashboard-container{min-height:100vh;background:#f8fafc;position:relative}.dashboard-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(226,232,240,.6);position:sticky;top:0;z-index:100;box-shadow:0 4px 6px -1px #0000000d}.header-content{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo-section{display:flex;align-items:center;gap:1rem}.logo{display:flex;align-items:center}.logo-section h1{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0;line-height:1.2}.header-subtitle{font-size:.75rem;color:#64748b;margin:0}.header-actions{display:flex;align-items:center;gap:.75rem}.btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;color:#0891b2;background:#ecfeff;border:1px solid #cffafe;border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000d}.btn-secondary:hover{background:#cffafe;border-color:#a5f3fc;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.btn-outline{padding:.625rem 1rem;font-size:.875rem;font-weight:600;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000000d}.btn-outline:hover{background:#0f172a;border-color:#0f172a;color:#fff;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.pwa-badge{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.813rem;font-weight:600;color:#059669;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:.5rem;box-shadow:0 1px 2px #0000000d;border:1px solid #a7f3d0}.dashboard-main{padding:2.5rem 2rem;position:relative}.dashboard-content{max-width:1400px;margin:0 auto}.welcome-section{margin-bottom:2.5rem}.welcome-card{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;padding:2.5rem 3rem;border-radius:1rem;box-shadow:0 10px 20px -5px #0003;border:none;position:relative;overflow:hidden}.welcome-card:before{content:"";position:absolute;top:0;right:0;width:200px;height:200px;background:radial-gradient(circle,rgba(8,145,178,.3) 0%,transparent 70%);border-radius:50%;transform:translate(40%,-40%)}.welcome-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;position:relative;z-index:1}.welcome-card h2{font-size:2rem;font-weight:700;margin:0;color:#fff}.welcome-card p{font-size:1.063rem;margin:0;color:#ffffffd9;font-weight:400;position:relative;z-index:1}.welcome-card strong{font-weight:600;color:#06b6d4}.btn-logout-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;color:#fffc;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-logout-icon:hover{color:#fff;background:#fff3;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 6px -1px #0003}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:0 1px 3px #0000000d;display:flex;gap:1rem;transition:all .2s;border:1px solid #e2e8f0}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.stat-icon{width:3rem;height:3rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-blue .stat-icon{background:#eff6ff;color:#2563eb}.stat-card-green .stat-icon{background:#d1fae5;color:#059669}.stat-card-purple .stat-icon{background:#f3e8ff;color:#7c3aed}.stat-card-orange .stat-icon{background:#fff7ed;color:#ea580c}.stat-info{flex:1}.stat-label{font-size:.875rem;color:#64748b;margin:0 0 .25rem;font-weight:500}.stat-value{font-size:1.875rem;font-weight:700;color:#0f172a;margin:0 0 .25rem;line-height:1}.stat-change{font-size:.813rem;font-weight:600;margin:0}.stat-change.positive{color:#059669}.stat-change.negative{color:#dc2626}.panels-section{margin-bottom:3rem}.panels-section h3{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 .5rem;letter-spacing:-.025em}.section-description{font-size:1rem;color:#64748b;margin:0 0 1.75rem;font-weight:400}.panels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.25rem}.panel-card{background:#fff;border:1px solid #e2e8f0;border-radius:.875rem;padding:1.5rem;display:flex;align-items:center;gap:1.25rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left;position:relative;overflow:hidden;box-shadow:0 1px 2px #0000000d}.panel-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;transition:all .3s cubic-bezier(.4,0,.2,1)}.panel-card-blue:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.panel-card-green:before{background:linear-gradient(90deg,#34d399,#10b981)}.panel-card-purple:before{background:linear-gradient(90deg,#a78bfa,#7c3aed)}.panel-card-orange:before{background:linear-gradient(90deg,#fb923c,#ea580c)}.panel-card-pink:before{background:linear-gradient(90deg,#f472b6,#ec4899)}.panel-card:hover{transform:translateY(-3px);box-shadow:0 10px 20px -5px #00000026;border-color:transparent}.panel-card-blue:hover{border-color:#3b82f6}.panel-card-green:hover{border-color:#34d399}.panel-card-purple:hover{border-color:#a78bfa}.panel-card-orange:hover{border-color:#fb923c}.panel-card-pink:hover{border-color:#f472b6}.panel-icon{width:3.5rem;height:3.5rem;border-radius:.875rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.panel-card:hover .panel-icon{transform:scale(1.05)}.panel-icon-blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.panel-icon-green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.panel-icon-purple{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#7c3aed}.panel-icon-orange{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#ea580c}.panel-icon-pink{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#ec4899}.panel-content{flex:1;min-width:0}.panel-content h4{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .375rem;letter-spacing:-.025em}.panel-content p{font-size:.875rem;color:#64748b;margin:0;line-height:1.5;font-weight:400}.panel-arrow{color:#cbd5e1;flex-shrink:0;transition:all .3s cubic-bezier(.4,0,.2,1);opacity:.5}.panel-card:hover .panel-arrow{color:#0f172a;transform:translate(6px);opacity:1}@media(max-width:768px){.header-content{padding:1rem;flex-direction:column;gap:1rem}.dashboard-main{padding:1.5rem 1rem}.welcome-card{padding:2rem 1.5rem}.welcome-header{flex-wrap:wrap}.welcome-card h2{font-size:1.5rem}.welcome-card p{font-size:.938rem}.stats-grid,.panels-grid{grid-template-columns:1fr}.panel-card{padding:1.25rem}.panel-icon{width:3rem;height:3rem}.panels-section h3{font-size:1.25rem}.section-description{font-size:.938rem}.panel-content h4{font-size:1rem}.panel-content p{font-size:.813rem}}.panel-layout{min-height:100vh;background:#f8fafc}.panel-header{background:linear-gradient(135deg,#0f172a,#1e293b);border-bottom:none;position:sticky;top:0;z-index:100;box-shadow:0 10px 20px -5px #0003;position:relative;overflow:hidden}.panel-header:before{content:"";position:absolute;top:0;right:0;width:300px;height:300px;background:radial-gradient(circle,rgba(8,145,178,.2) 0%,transparent 70%);border-radius:50%;transform:translate(40%,-40%);pointer-events:none}.panel-header-wrapper{max-width:1400px;margin:0 auto;padding:2rem;position:relative;z-index:1}.back-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#fffc;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-bottom:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-btn:hover{background:#fff3;color:#fff;border-color:#ffffff4d;transform:translate(-3px);box-shadow:0 4px 6px -1px #0003}.panel-header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem}.panel-title-section{display:flex;align-items:center;gap:1.5rem;flex:1}.panel-title-icon{width:4rem;height:4rem;border-radius:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 6px -1px #0000004d;position:relative}.panel-title-icon-blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.panel-title-icon-green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.panel-title-icon-purple{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#7c3aed}.panel-title-icon-orange{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#ea580c}.panel-title-icon-pink{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#ec4899}.panel-title-info{flex:1}.panel-title-section h1{font-size:2.25rem;font-weight:700;color:#fff;margin:0 0 .5rem;line-height:1.2;letter-spacing:-.03em}.panel-title-section p{font-size:1.063rem;color:#fffc;margin:0;line-height:1.5;font-weight:400}.btn-add-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;color:#fff;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.btn-add-icon:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.05);box-shadow:0 4px 6px -1px #0003}.btn-primary{display:inline-flex;align-items:center;gap:.625rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#0f172a;background:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0003;white-space:nowrap;flex-shrink:0}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000004d;background:#f8fafc}.panel-content{max-width:1400px;margin:0 auto;padding:2rem}.panel-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.75rem}.search-box{flex:1;min-width:300px;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:1rem;color:#94a3b8;pointer-events:none;z-index:1}.search-box input{width:100%;padding:.875rem 1rem .875rem 3rem;font-size:.938rem;border:1px solid #e2e8f0;border-radius:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;background:#fff}.search-box input::placeholder{color:#94a3b8}.search-box input:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 3px #0891b21a}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.625rem 1rem;font-size:.875rem;font-weight:600;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.filter-btn:hover{border-color:#cbd5e1;color:#334155;background:#f8fafc}.filter-btn-active{color:#0891b2;background:#ecfeff;border-color:#0891b2}.data-table{background:#fff;border-radius:.875rem;border:1px solid #e2e8f0;overflow-x:auto;overflow-y:visible;box-shadow:0 1px 2px #0000000d;position:relative}.data-table table{width:100%;border-collapse:collapse;min-width:600px;table-layout:auto}.data-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.data-table th{padding:1rem;text-align:left;font-size:.813rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.05em;position:relative}.data-table th:not(:last-child){max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table th:last-child{position:sticky;right:0;background:#f8fafc;z-index:10;box-shadow:-2px 0 4px #0000000d;min-width:80px;width:80px}.data-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .2s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:#f8fafc;cursor:default}.data-table tbody tr.clickable-row{cursor:pointer}.data-table tbody tr.clickable-row:hover{background:#eff6ff}.data-table td{padding:1rem;font-size:.938rem;color:#334155;position:relative}.data-table td:not(:last-child){max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table td:last-child{position:sticky;right:0;background:#fff;z-index:5;box-shadow:-2px 0 4px #0000000d;min-width:80px;width:80px}.data-table tbody tr:hover td:last-child{background:#f8fafc}.id-badge{display:inline-block;padding:.25rem .625rem;font-size:.75rem;font-weight:600;font-family:Monaco,Courier New,monospace;color:#475569;background:#f1f5f9;border-radius:.375rem}.name-cell{font-weight:600;color:#0f172a;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.url-cell{color:#334155;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suffix-chips{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.suffix-chip{display:inline-block;padding:.375rem .75rem;font-size:.813rem;font-weight:600;color:#0891b2;background:#ecfeff;border:1px solid #cffafe;border-radius:9999px;white-space:nowrap}.form-suffix-chips{padding:.5rem 0}.status-badge{display:inline-block;padding:.375rem .75rem;font-size:.75rem;font-weight:600;border-radius:9999px;text-transform:capitalize}.status-active{color:#059669;background:#d1fae5}.status-inactive{color:#dc2626;background:#fee2e2}.role-badge,.type-badge,.category-badge{display:inline-block;padding:.25rem .625rem;font-size:.813rem;font-weight:600;color:#7c3aed;background:#f3e8ff;border-radius:.375rem}.required-badge{display:inline-block;padding:.25rem .625rem;font-size:.75rem;font-weight:600;border-radius:.375rem}.required-yes{color:#dc2626;background:#fee2e2}.required-no{color:#64748b;background:#f1f5f9}.suffix-code{font-family:Monaco,Courier New,monospace;font-size:.938rem;font-weight:600;color:#ea580c;background:#fff7ed;padding:.25rem .625rem;border-radius:.375rem}.action-buttons{display:flex;gap:.5rem}.action-btn{padding:.5rem;background:transparent;border:none;border-radius:.375rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center}.action-btn-edit{color:#2563eb}.action-btn-edit:hover{background:#eff6ff;transform:scale(1.1)}.action-btn-view{color:#059669}.action-btn-view:hover{background:#d1fae5;transform:scale(1.1)}.action-btn-delete{color:#dc2626}.action-btn-delete:hover{background:#fee2e2;transform:scale(1.1)}.query-search-section{background:#fff;border-radius:.75rem;border:1px solid #e2e8f0;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000000d}.query-search-form{margin-bottom:1.5rem}.query-search-input{display:flex;align-items:center;gap:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:.75rem;padding:.75rem 1rem;transition:all .2s}.query-search-input:focus-within{border-color:#0891b2;box-shadow:0 0 0 3px #0891b21a}.query-search-input svg{color:#64748b;flex-shrink:0}.query-input{flex:1;padding:.5rem;font-size:1rem;border:none;background:transparent;outline:none;font-family:inherit}.query-search-btn{padding:.625rem 1.5rem;font-size:.938rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ec4899,#db2777);border:none;border-radius:.5rem;cursor:pointer;transition:all .2s;white-space:nowrap}.query-search-btn:hover:not(:disabled){transform:scale(1.05)}.query-search-btn:disabled{opacity:.6;cursor:not-allowed}.query-tips{border-top:1px solid #e2e8f0;padding-top:1rem}.query-tips p{font-size:.875rem;color:#334155;margin:0 0 .5rem}.query-tips ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.query-tips li{font-size:.813rem;color:#64748b;padding-left:1.25rem;position:relative}.query-tips li:before{content:"•";position:absolute;left:.5rem;color:#cbd5e1}.query-results-section{animation:fadeIn .3s ease-out}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.results-header h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0}.results-count{font-size:.938rem;color:#64748b;font-weight:600}.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(450px,1fr));gap:1.5rem}.result-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;transition:all .2s;box-shadow:0 1px 3px #0000000d}.result-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.result-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.result-card-header h4{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.result-id{font-size:.75rem;font-weight:600;color:#94a3b8}.result-card-body{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.result-row{display:flex;justify-content:space-between;gap:1rem}.result-label{font-size:.875rem;font-weight:600;color:#64748b;flex-shrink:0}.result-value{font-size:.875rem;color:#334155;text-align:right}.result-card-footer{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid #f1f5f9}.result-action-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.813rem;font-weight:600;color:#2563eb;background:#eff6ff;border:1px solid #dbeafe;border-radius:.5rem;cursor:pointer;transition:all .2s}.result-action-btn:hover{background:#dbeafe;border-color:#bfdbfe}.no-results,.query-empty-state{text-align:center;padding:4rem 2rem}.no-results svg,.query-empty-state svg{margin:0 auto 1.5rem}.no-results h3,.query-empty-state h3{font-size:1.25rem;font-weight:700;color:#334155;margin:0 0 .5rem}.no-results p,.query-empty-state p{font-size:.938rem;color:#64748b;margin:0}.suffixes-list{margin-top:1.5rem}.suffixes-grid{display:flex;flex-wrap:wrap;gap:.75rem}.suffix-pill{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ea580c,#c2410c);border:none;border-radius:9999px;cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #ea580c33;font-family:Monaco,Courier New,monospace}.suffix-pill:hover{transform:translateY(-2px);box-shadow:0 4px 8px #ea580c4d}.suffix-pill:active{transform:translateY(0)}.empty-state{text-align:center;padding:3rem 2rem;color:#64748b}.empty-state p{font-size:1rem;margin:0}.aip-pill-container{display:flex;align-items:center;gap:.5rem}.aip-pill{display:inline-block;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#2563eb;background:#eff6ff;border:1px solid #dbeafe;border-radius:9999px}@media(max-width:768px){.panel-header-wrapper{padding:1.25rem 1rem 1.5rem}.back-btn{font-size:.813rem;padding:.5rem .875rem}.panel-header-content{gap:1.25rem;align-items:flex-start}.panel-title-section{flex-direction:row;align-items:center;gap:1rem}.panel-title-icon{width:3.5rem;height:3.5rem}.panel-title-section h1{font-size:1.75rem;color:#fff}.panel-title-section p{font-size:.938rem;color:#fffc}.btn-add-icon{width:2.25rem;height:2.25rem}.btn-add-icon svg{width:20px;height:20px}.panel-content{padding:1.5rem 1rem}.panel-controls{flex-direction:column}.search-box{min-width:100%}.data-table{overflow-x:auto}.results-grid{grid-template-columns:1fr}.result-row{flex-direction:column;gap:.25rem}.result-value{text-align:left}}.tabs-container{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.tab-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#64748b;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;transition:all .2s;position:relative;margin-bottom:-2px}.tab-button:hover{color:#334155;background:#f8fafc}.tab-button.tab-active{color:#0891b2;border-bottom-color:#0891b2}.tab-button.tab-active:hover{color:#0891b2;background:transparent}.action-btn-approve{color:#059669}.action-btn-approve:hover{background:#d1fae5;color:#047857}.action-btn-reject{color:#ef4444}.action-btn-reject:hover{background:#fee2e2;color:#dc2626}.confirm-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.confirm-modal{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:400px;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-modal-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e2e8f0}.confirm-modal-header h3{margin:0;font-size:1.25rem;font-weight:700;color:#0f172a}.confirm-modal-content{padding:1.5rem}.confirm-modal-content p{margin:0;font-size:1rem;color:#475569;line-height:1.5}.confirm-modal-actions{padding:1rem 1.5rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}.btn-cancel{padding:.625rem 1.25rem;font-size:.938rem;font-weight:600;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#f8fafc;border-color:#cbd5e1;color:#334155}.btn-confirm-approve{padding:.625rem 1.25rem;font-size:.938rem;font-weight:600;color:#fff;background:#059669;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s}.btn-confirm-approve:hover{background:#047857;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0596694d}.btn-confirm-reject{padding:.625rem 1.25rem;font-size:.938rem;font-weight:600;color:#fff;background:#ef4444;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s}.btn-confirm-reject:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 6px -1px #ef44444d}.tray-overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .3s ease-out}.tray-container{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:1.5rem 1.5rem 0 0;box-shadow:0 -4px 20px #00000026;z-index:1000;max-height:90vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.tray-container.tray-open{transform:translateY(0)}.tray-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 2rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.tray-header h2{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.025em}.tray-close-btn{padding:.5rem;background:transparent;border:none;border-radius:.5rem;cursor:pointer;color:#64748b;transition:all .2s;display:flex;align-items:center;justify-content:center}.tray-close-btn:hover{background:#f1f5f9;color:#334155}.tray-content{flex:1;overflow-y:auto;padding:2rem}.tray-screen{max-width:600px;margin:0 auto}.tray-form{display:flex;flex-direction:column;gap:1.5rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-size:.938rem;font-weight:600;color:#334155}.required-asterisk{color:#ef4444;margin-left:.25rem}.form-field input{padding:.875rem 1rem;font-size:1rem;border:1px solid #e2e8f0;border-radius:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;background:#fff}.form-field input:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 3px #0891b21a}.form-input-disabled{background:#f8fafc;color:#64748b;cursor:not-allowed}.form-input-disabled:focus{border-color:#e2e8f0;box-shadow:none}.form-input-error{border-color:#ef4444!important;background:#fef2f2}.form-input-error:focus{border-color:#ef4444!important;box-shadow:0 0 0 3px #ef44441a!important}.form-error-message{display:block;font-size:.875rem;color:#ef4444;margin-top:.25rem;font-weight:500}.tray-actions{display:flex;gap:1rem;margin-top:.5rem;flex-wrap:wrap}.tray-actions-spaced{display:flex;justify-content:space-between;align-items:center;gap:0;width:100%}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.625rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#0f172a;background:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0003;white-space:nowrap;flex-shrink:0}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000004d;background:#0f172a;color:#fff}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;color:#0891b2;background:#ecfeff;border:1px solid #cffafe;border-radius:.5rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-secondary:hover{background:#cffafe;border-color:#a5f3fc}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;color:#64748b;background:transparent;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-outline:hover{background:#f8fafc;border-color:#cbd5e1;color:#334155}.btn-full-width{width:100%}.api-key-display{display:flex;flex-direction:column;gap:1.5rem}.api-key-message{font-size:1.125rem;font-weight:600;color:#334155;margin:0;text-align:center}.api-key-box{background:#f8fafc;border:2px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.api-key-text{font-family:Monaco,Courier New,monospace;font-size:.938rem;font-weight:600;color:#0f172a;word-break:break-all;background:#fff;padding:1rem;border-radius:.5rem;border:1px solid #e2e8f0;text-align:center;letter-spacing:.05em}.api-key-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.logo-preview{margin-top:.5rem;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;display:inline-block}.logo-preview img{max-width:100px;max-height:100px;object-fit:contain}.logo-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:.5rem;color:#94a3b8;font-size:.875rem}.logo-placeholder svg{color:#cbd5e1}.form-field input[type=file]{padding:.5rem;font-size:.938rem;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;background:#fff;transition:all .3s cubic-bezier(.4,0,.2,1)}.form-field input[type=file]:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 3px #0891b21a}@media(max-width:768px){.tray-container{max-height:95vh}.tray-header{padding:1.25rem 1.5rem}.tray-header h2{font-size:1.25rem}.tray-content{padding:1.5rem}.tray-actions{flex-direction:row;align-items:end}.tray-actions button{width:max-content}.api-key-actions{flex-direction:column}.api-key-actions button{width:100%}}.file-input-hidden{position:absolute;width:0;height:0;opacity:0;overflow:hidden;z-index:-1}.file-upload-zone{position:relative;border:2px dashed #cbd5e1;border-radius:.75rem;padding:2rem;background:#f8fafc;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:180px;display:flex;align-items:center;justify-content:center}.file-upload-zone:hover{border-color:#0891b2;background:#ecfeff}.file-upload-zone.file-upload-dragging{border-color:#0891b2;background:#cffafe;border-style:solid;transform:scale(1.02)}.file-upload-zone.file-upload-has-file{padding:1rem;min-height:auto;border-color:#0891b2;background:#fff}.file-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center}.file-upload-placeholder svg{color:#64748b;transition:all .3s}.file-upload-zone:hover .file-upload-placeholder svg{color:#0891b2;transform:translateY(-2px)}.file-upload-text{display:flex;flex-direction:column;gap:.375rem}.file-upload-primary-text{font-size:1rem;font-weight:600;color:#334155}.file-upload-secondary-text{font-size:.875rem;color:#64748b}.file-upload-preview{position:relative;width:100%;display:flex;align-items:center;justify-content:center}.file-upload-preview img{max-width:100%;max-height:200px;object-fit:contain;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a}.file-upload-remove{position:absolute;top:-.5rem;right:-.5rem;width:32px;height:32px;border-radius:50%;background:#ef4444;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #ef444466;transition:all .2s;z-index:10}.file-upload-remove:hover{background:#dc2626;transform:scale(1.1);box-shadow:0 4px 12px #ef444499}.file-upload-remove:active{transform:scale(.95)}#root{min-height:100vh}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-muted{color:var(--color-neutral-500)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}.slide-up{animation:slideUp .4s ease-out}.slide-down{animation:slideDown .4s ease-out}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.install-button{background-color:#1976d2;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .3s}.install-button:hover{background-color:#1565c0}.pwa-badge{background-color:#4caf50;color:#fff;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;font-weight:500}.pwa-info{margin-top:1rem;padding:1rem;background-color:#f5f5f5;border-radius:4px;color:#666}
