@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Poppins:wght@500;600;700;800&display=swap";@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.news-ticker{background:linear-gradient(135deg, var(--clarity-primary,#005687) 0%, #4770d1 100%);color:#fff;z-index:90;border-bottom:1px solid #ffffff1a;position:relative;overflow:hidden}.news-ticker-track{width:max-content;animation:30s linear infinite ticker-scroll;display:flex}.news-ticker-track:hover{animation-play-state:paused}.news-ticker-item{cursor:pointer;white-space:nowrap;border-right:1px solid #ffffff26;align-items:center;gap:.75rem;padding:.5rem 2rem;font-size:.875rem;transition:background .2s;display:flex}.news-ticker-item:hover{background:#ffffff1a}.news-ticker-badge{text-transform:uppercase;letter-spacing:.05em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-radius:9999px;align-items:center;padding:.125rem .5rem;font-size:.7rem;font-weight:700;display:inline-flex}.news-ticker-icon{flex-shrink:0;font-size:1.25rem}.news-ticker-dismiss{background:linear-gradient(90deg, transparent, var(--clarity-primary,#005687) 40%);cursor:pointer;color:#fff;z-index:1;border:none;align-items:center;padding:0 .75rem;font-size:1rem;transition:opacity .2s;display:flex;position:absolute;top:0;bottom:0;right:0}.news-ticker-dismiss:hover{opacity:.8}[data-theme=dark] .news-ticker{background:linear-gradient(135deg,#1a365d 0%,#2d4a7a 100%)}@media (width<=768px){.news-ticker-track{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;animation:none;overflow-x:auto}.news-ticker-item{scroll-snap-align:start;justify-content:center;min-width:100%}}.preview-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--space-4);background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.preview-modal{background:var(--clarity-bg-default);border-radius:var(--radius-xl);flex-direction:column;width:95vw;max-width:1400px;height:85vh;max-height:900px;animation:.3s ease-out slideUp;display:flex;box-shadow:0 25px 50px -12px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.preview-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--clarity-border-default);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.preview-title{align-items:center;gap:var(--space-3);display:flex}.preview-icon{font-size:32px}.preview-title h2{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--clarity-text-default);margin:0}.preview-subtitle{font-size:var(--text-sm);color:var(--clarity-text-tertiary);margin-top:2px;display:block}.preview-close{cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);color:var(--clarity-text-tertiary);background:0 0;border:none;transition:all .15s}.preview-close:hover{background:var(--clarity-bg-subtle);color:var(--clarity-text-default)}.preview-content{flex:1;position:relative;overflow:hidden}.preview-loading{height:100%;color:var(--clarity-text-tertiary);justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.preview-spinner{border:3px solid var(--clarity-border-default);border-top-color:var(--clarity-accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.preview-error{height:100%;color:var(--clarity-text-tertiary);justify-content:center;align-items:center;gap:var(--space-4);text-align:center;flex-direction:column;display:flex}.preview-error svg{color:var(--clarity-error);opacity:.7}.excel-container{background:var(--clarity-bg-subtle);height:100%;overflow:auto}.excel-table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--text-sm);font-family:var(--font-mono)}.excel-table thead{z-index:10;position:sticky;top:0}.excel-table th{padding:var(--space-2) var(--space-3);text-align:left;font-weight:var(--weight-semibold);color:var(--clarity-text-default);white-space:nowrap;text-overflow:ellipsis;background:linear-gradient(#f8f9fa 0%,#e9ecef 100%);border-bottom:2px solid #dee2e6;border-right:1px solid #dee2e6;min-width:100px;max-width:250px;overflow:hidden}[data-theme=dark] .excel-table th{background:linear-gradient(#2d3748 0%,#1a202c 100%);border-bottom:2px solid #4a5568;border-right:1px solid #4a5568}.excel-table th:first-child,.excel-table td:first-child{z-index:5;position:sticky;left:0}.excel-table thead th:first-child{z-index:15}.excel-table .row-number{color:var(--clarity-text-tertiary);text-align:center;font-weight:var(--weight-medium);width:50px;min-width:50px;max-width:50px;font-size:var(--text-xs);background:linear-gradient(90deg,#f1f3f4 0%,#e8eaed 100%);border-right:2px solid #dee2e6}[data-theme=dark] .excel-table .row-number{background:linear-gradient(90deg,#2d3748 0%,#1a202c 100%);border-right:2px solid #4a5568}.excel-table td{padding:var(--space-2) var(--space-3);color:var(--clarity-text-default);white-space:nowrap;text-overflow:ellipsis;background:#fff;border-bottom:1px solid #e9ecef;border-right:1px solid #e9ecef;max-width:300px;overflow:hidden}[data-theme=dark] .excel-table td{background:#1a202c;border-bottom:1px solid #2d3748;border-right:1px solid #2d3748}.excel-table tbody tr.odd td{background:#f8f9fa}[data-theme=dark] .excel-table tbody tr.odd td{background:#2d3748}.excel-table tbody tr.odd td.row-number{background:linear-gradient(90deg,#e8eaed 0%,#e1e4e8 100%)}[data-theme=dark] .excel-table tbody tr.odd td.row-number{background:linear-gradient(90deg,#374151 0%,#2d3748 100%)}.excel-table tbody tr:hover td{background:#e3f2fd!important}[data-theme=dark] .excel-table tbody tr:hover td{background:#1e3a5f!important}.excel-table tbody tr:hover td.row-number{background:#bbdefb!important}[data-theme=dark] .excel-table tbody tr:hover td.row-number{background:#1e3a5f!important}.json-container{height:100%;padding:var(--space-4);background:var(--clarity-bg-subtle);overflow:auto}.json-container pre{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--clarity-text-default);margin:0;line-height:1.6}.preview-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--clarity-border-default);background:var(--clarity-bg-subtle);border-radius:0 0 var(--radius-xl) var(--radius-xl);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.preview-pagination{align-items:center;gap:var(--space-2);display:flex}.page-info{font-size:var(--text-sm);color:var(--clarity-text-secondary);padding:0 var(--space-3)}.page-detail{color:var(--clarity-text-tertiary);margin-left:var(--space-2)}.preview-actions{align-items:center;gap:var(--space-4);display:flex}.file-size{font-size:var(--text-sm);color:var(--clarity-text-tertiary)}@media (width<=768px){.preview-modal{border-radius:0;width:100%;height:100%;max-height:100%}.preview-footer{gap:var(--space-4);border-radius:0;flex-direction:column}.preview-pagination{order:2}.preview-actions{order:1;justify-content:center;width:100%}}:root{--clarity-primary:#005687;--clarity-primary-hover:#004a73;--clarity-primary-dark:#0b4261;--clarity-primary-subtle:#00568714;--clarity-primary-light:#d0e9ff;--clarity-secondary:#4770d1;--clarity-secondary-hover:#3a5cb8;--clarity-accent:#8cb5d8;--clarity-accent-light:#e8f4fc;--clarity-success:#059669;--clarity-success-bg:#ecfdf5;--clarity-success-border:#a7f3d0;--clarity-warning:#d97706;--clarity-warning-bg:#fffbeb;--clarity-warning-border:#fde68a;--clarity-error:#dc2626;--clarity-error-bg:#fef2f2;--clarity-error-border:#fecaca;--clarity-info:#4770d1;--clarity-info-bg:#eff6ff;--clarity-info-border:#bfdbfe;--clarity-bg-page:#f7f5f1;--clarity-bg-canvas:#fff;--clarity-bg-card:#fff;--clarity-bg-elevated:#fff;--clarity-bg-subtle:#f3f1ed;--clarity-bg-muted:#ebe9e4;--clarity-bg-hover:#0056870a;--clarity-bg-active:#00568714;--clarity-bg-warm:#f7f5f1;--clarity-text-primary:#1a1a1a;--clarity-text-secondary:#6b7280;--clarity-text-tertiary:#9ca3af;--clarity-text-muted:#d1d5db;--clarity-text-inverse:#fff;--clarity-text-link:#005687;--clarity-text-link-hover:#004a73;--clarity-border:#e5e7eb;--clarity-border-subtle:#f0ede8;--clarity-border-strong:#d1d5db;--clarity-border-focus:#005687;--clarity-gradient-primary:linear-gradient(135deg, #005687 0%, #0b4261 100%);--clarity-gradient-warm:linear-gradient(180deg, #f7f5f1 0%, #fff 100%);--font-display:"Poppins", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"SF Mono", "JetBrains Mono", "Consolas", monospace;--weight-normal:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--weight-extrabold:800;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--tracking-tighter:-.05em;--tracking-tight:-.025em;--tracking-normal:0;--tracking-wide:.025em;--tracking-wider:.05em;--space-0:0;--space-1:.25rem;--space-1-5:.375rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--max-width-sm:640px;--max-width-md:768px;--max-width-lg:1024px;--max-width-xl:1200px;--max-width-2xl:1400px;--sidebar-width:260px;--header-height:64px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #0000000d, 0 2px 4px #0000000a;--shadow-lg:0 10px 15px #0000000f, 0 4px 6px #0000000a;--shadow-xl:0 20px 25px #00000014, 0 10px 10px #0000000a;--shadow-card:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-card-hover:0 4px 12px #0000001a, 0 2px 4px #0000000f;--shadow-focus:0 0 0 3px #00568726;--duration-fast:.15s;--duration-normal:.2s;--duration-slow:.3s;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1)}.text-display{font-family:var(--font-display);font-size:var(--text-5xl);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--clarity-text-primary)}.text-display-sm{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.text-h1{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);color:var(--clarity-text-primary);margin:0 0 var(--space-4)}.text-h2{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);line-height:var(--leading-snug);color:var(--clarity-text-primary);margin:0 0 var(--space-3)}.text-h3{font-family:var(--font-body);font-size:var(--text-xl);font-weight:var(--weight-semibold);line-height:var(--leading-snug);color:var(--clarity-text-primary);margin:0 0 var(--space-2)}.text-h4{font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--weight-medium);line-height:var(--leading-normal);color:var(--clarity-text-primary);margin:0 0 var(--space-2)}.text-body{font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--clarity-text-primary)}.text-body-lg{font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--clarity-text-secondary)}.text-body-sm{font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--clarity-text-secondary)}.text-caption{font-size:var(--text-xs);font-weight:var(--weight-medium);line-height:var(--leading-normal);color:var(--clarity-text-tertiary)}.text-overline{font-size:11px;font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--clarity-text-tertiary);line-height:1}.text-label{font-size:var(--text-sm);font-weight:var(--weight-medium);line-height:var(--leading-normal);color:var(--clarity-text-primary);margin-bottom:var(--space-1-5);display:block}.text-link{color:var(--clarity-text-link);transition:color var(--duration-fast) var(--ease-out);text-decoration:none}.text-link:hover{color:var(--clarity-text-link-hover);text-underline-offset:2px;text-decoration:underline}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-4);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;border:none;line-height:1;text-decoration:none;display:inline-flex}.btn:focus-visible{box-shadow:var(--ring-focus)}.btn-primary{background-color:var(--clarity-primary);color:var(--clarity-text-inverse);box-shadow:var(--shadow-xs), inset 0 1px 0 #ffffff1a}.btn-primary:hover{background-color:var(--clarity-primary-hover);box-shadow:var(--shadow-sm), var(--shadow-primary);transform:translateY(-1px)}.btn-primary:active{box-shadow:var(--shadow-xs);transform:translateY(0)}.btn-secondary{background-color:var(--clarity-bg-card);color:var(--clarity-text-primary);border:1px solid var(--clarity-border);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background-color:var(--clarity-bg-subtle);border-color:var(--clarity-border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary:active{background-color:var(--clarity-bg-muted);transform:translateY(0)}.btn-ghost{color:var(--clarity-text-secondary);background-color:#0000}.btn-ghost:hover{background-color:var(--clarity-bg-hover);color:var(--clarity-text-primary)}.btn-danger{background-color:var(--clarity-error);color:var(--clarity-text-inverse)}.btn-danger:hover{box-shadow:var(--shadow-sm), 0 4px 12px #ef444433;background-color:#dc2626;transform:translateY(-1px)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;padding:0}.card{background-color:var(--clarity-bg-card);border-radius:var(--radius-xl);border:1px solid var(--clarity-border-subtle);box-shadow:var(--shadow-sm);transition:all var(--duration-normal) var(--ease-out)}.card:hover{border-color:var(--clarity-border);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--clarity-border-subtle);background-color:var(--clarity-bg-subtle);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.card-flat{box-shadow:none;border:1px solid var(--clarity-border)}.card-flat:hover{box-shadow:var(--shadow-sm);transform:none}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-stat{padding:var(--space-6)}.card-stat .stat-value{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--weight-semibold);letter-spacing:var(--tracking-tight);color:var(--clarity-text-primary);margin-bottom:var(--space-1);line-height:1}.card-stat .stat-label{font-size:var(--text-sm);color:var(--clarity-text-tertiary);font-weight:var(--weight-medium)}.card-stat .stat-change{align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:var(--weight-medium);margin-top:var(--space-3);display:inline-flex}.card-stat .stat-change.positive{color:var(--clarity-success)}.card-stat .stat-change.negative{color:var(--clarity-error)}.input{width:100%;padding:var(--space-2-5) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--clarity-text-primary);background-color:var(--clarity-bg-card);border:1px solid var(--clarity-border);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.input:hover{border-color:var(--clarity-border-strong)}.input:focus{border-color:var(--clarity-primary);box-shadow:var(--ring-focus)}.input:disabled{background-color:var(--clarity-bg-muted);color:var(--clarity-text-tertiary);cursor:not-allowed}.input-group{align-items:center;display:flex;position:relative}.input-group .input-icon{left:var(--space-3);width:18px;height:18px;color:var(--clarity-text-muted);pointer-events:none;position:absolute}.input-group .input{padding-left:var(--space-10)}.input-error{border-color:var(--clarity-error)}.input-error:focus{box-shadow:var(--ring-focus-error)}.input-success{border-color:var(--clarity-success)}.textarea{resize:vertical;min-height:120px}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%235E6770' viewBox='0 0 16 16'%3E%3Cpath d='M4.5 6l3.5 4 3.5-4h-7z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-10)}.checkbox,.radio{appearance:none;border:1.5px solid var(--clarity-border-strong);background-color:var(--clarity-bg-card);cursor:pointer;width:18px;height:18px;transition:all var(--duration-fast) var(--ease-out);flex-shrink:0}.checkbox{border-radius:var(--radius-sm)}.radio{border-radius:var(--radius-full)}.checkbox:checked,.radio:checked{background-color:var(--clarity-primary);border-color:var(--clarity-primary)}.checkbox:checked{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat}.radio:checked{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' fill='white' viewBox='0 0 8 8'%3E%3Ccircle cx='4' cy='4' r='4'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat}.checkbox:focus-visible,.radio:focus-visible{box-shadow:var(--ring-focus)}.table-container{border-radius:var(--radius-lg);border:1px solid var(--clarity-border-subtle);background-color:var(--clarity-bg-card);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--weight-medium);color:var(--clarity-text-secondary);background-color:var(--clarity-bg-subtle);border-bottom:1px solid var(--clarity-border);white-space:nowrap}.table th:first-child{padding-left:var(--space-6)}.table th:last-child{padding-right:var(--space-6)}.table td{padding:var(--space-4);color:var(--clarity-text-primary);border-bottom:1px solid var(--clarity-border-subtle);vertical-align:middle}.table td:first-child{padding-left:var(--space-6)}.table td:last-child{padding-right:var(--space-6)}.table tbody tr{transition:background-color var(--duration-fast) var(--ease-out)}.table tbody tr:hover{background-color:var(--clarity-bg-hover)}.table tbody tr:last-child td{border-bottom:none}.table .cell-mono{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--clarity-text-secondary)}.table .cell-number{font-family:var(--font-mono);font-weight:var(--weight-medium);text-align:right}.nav-header{height:var(--header-height);padding:0 var(--space-6);background-color:var(--clarity-bg-card);border-bottom:1px solid var(--clarity-border-subtle);justify-content:space-between;align-items:center;display:flex}.nav-logo{align-items:center;gap:var(--space-3);font-family:var(--font-display);font-weight:var(--weight-bold);font-size:var(--text-lg);color:var(--clarity-text-primary);text-decoration:none;display:flex}.nav-logo img{width:auto;height:32px}.nav-links{align-items:center;gap:var(--space-1);display:flex}.nav-link{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--clarity-text-secondary);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out);text-decoration:none}.nav-link:hover{color:var(--clarity-text-primary);background-color:var(--clarity-bg-hover)}.nav-link.active{color:var(--clarity-primary);background-color:var(--clarity-primary-subtle)}.sidebar{width:var(--sidebar-width);background-color:var(--clarity-bg-card);border-right:1px solid var(--clarity-border-subtle);height:100vh;padding:var(--space-4);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-header{padding:var(--space-2) var(--space-3);margin-bottom:var(--space-6)}.sidebar-nav{flex:1;overflow-y:auto}.sidebar-section{margin-bottom:var(--space-6)}.sidebar-section-title{padding:var(--space-2) var(--space-3);font-size:11px;font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--clarity-text-muted)}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2-5) var(--space-3);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--clarity-text-secondary);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out);text-decoration:none;display:flex}.sidebar-link:hover{color:var(--clarity-text-primary);background-color:var(--clarity-bg-hover)}.sidebar-link.active{color:var(--clarity-primary);background-color:var(--clarity-primary-subtle)}.sidebar-link svg{opacity:.7;width:18px;height:18px}.sidebar-link.active svg{opacity:1}.badge{padding:var(--space-1) var(--space-2);font-size:11px;font-weight:var(--weight-medium);border-radius:var(--radius-sm);white-space:nowrap;align-items:center;line-height:1;display:inline-flex}.badge-default{background-color:var(--clarity-bg-muted);color:var(--clarity-text-secondary)}.badge-primary{background-color:var(--clarity-primary-subtle);color:var(--clarity-primary)}.badge-success{background-color:var(--clarity-success-bg);color:var(--clarity-success)}.badge-warning{background-color:var(--clarity-warning-bg);color:#b45309}.badge-error{background-color:var(--clarity-error-bg);color:var(--clarity-error)}.status-dot{border-radius:var(--radius-full);width:8px;height:8px;margin-right:var(--space-2);display:inline-block}.status-dot.active{background-color:var(--clarity-success);box-shadow:0 0 0 2px var(--clarity-success-bg)}.status-dot.pending{background-color:var(--clarity-warning);box-shadow:0 0 0 2px var(--clarity-warning-bg)}.status-dot.inactive{background-color:var(--clarity-text-muted)}.pill{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);background-color:var(--clarity-bg-muted);color:var(--clarity-text-secondary);align-items:center;display:inline-flex}.avatar{border-radius:var(--radius-full);background-color:var(--clarity-primary-subtle);width:40px;height:40px;color:var(--clarity-primary);font-weight:var(--weight-medium);font-size:var(--text-sm);justify-content:center;align-items:center;display:inline-flex}.avatar img{-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-full);width:100%;height:100%}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--text-lg)}.avatar-group{display:flex}.avatar-group .avatar{border:2px solid var(--clarity-bg-card);margin-left:-8px}.avatar-group .avatar:first-child{margin-left:0}.alert{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);display:flex}.alert-icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}.alert-info{background-color:var(--clarity-info-bg);color:var(--clarity-info);border:1px solid var(--clarity-info-border)}.alert-success{background-color:var(--clarity-success-bg);color:#065f46;border:1px solid var(--clarity-success-border)}.alert-warning{background-color:var(--clarity-warning-bg);color:#92400e;border:1px solid var(--clarity-warning-border)}.alert-error{background-color:var(--clarity-error-bg);color:#991b1b;border:1px solid var(--clarity-error-border)}.divider{background-color:var(--clarity-border-subtle);height:1px;margin:var(--space-6) 0;border:none}.divider-vertical{background-color:var(--clarity-border);width:1px;height:24px}.container{width:100%;max-width:var(--max-width-xl);padding:0 var(--container-padding);margin:0 auto}.container-sm{max-width:var(--max-width-sm)}.container-md{max-width:var(--max-width-md)}.container-lg{max-width:var(--max-width-lg)}.page{background-color:var(--clarity-bg-page);min-height:100vh}.page-content{padding:var(--space-8)}.page-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);color:var(--clarity-text-primary);letter-spacing:var(--tracking-tight);margin:0 0 var(--space-2)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-1{flex:1}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.mt-0{margin-top:0}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--duration-normal) var(--ease-out) forwards}.animate-scale-in{opacity:0;animation:scaleIn var(--duration-slow) var(--ease-spring) forwards}.delay-1{animation-delay:50ms}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}.delay-4{animation-delay:.2s}.delay-5{animation-delay:.25s}.empty-state{text-align:center;padding:var(--space-16) var(--space-8)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--clarity-text-muted)}.empty-state-title{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--clarity-text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--clarity-text-secondary);max-width:360px;margin:0 auto var(--space-6)}.skeleton{background:linear-gradient(90deg, var(--clarity-bg-muted) 25%, var(--clarity-bg-subtle) 50%, var(--clarity-bg-muted) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;margin-bottom:var(--space-2)}.skeleton-title{width:60%;height:24px;margin-bottom:var(--space-3)}.skeleton-circle{border-radius:var(--radius-full)}[data-theme=dark]{--clarity-bg-page:#141210;--clarity-bg-canvas:#1c1917;--clarity-bg-card:#231f1c;--clarity-bg-elevated:#2a2521;--clarity-bg-subtle:#262220;--clarity-bg-muted:#332d29;--clarity-bg-hover:#88b6d814;--clarity-bg-active:#88b6d81f;--clarity-bg-warm:#141210;--clarity-text-primary:#f5f3f0;--clarity-text-secondary:#a8a29e;--clarity-text-tertiary:#78716c;--clarity-text-muted:#57534e;--clarity-text-inverse:#141210;--clarity-text-link:#7cb8e4;--clarity-text-link-hover:#a5d6ff;--clarity-border:#3d3733;--clarity-border-subtle:#2e2926;--clarity-border-strong:#4a443f;--clarity-border-focus:#58a6ff;--clarity-primary:#58a6ff;--clarity-primary-hover:#79c0ff;--clarity-primary-dark:#3d8bd4;--clarity-primary-subtle:#58a6ff1f;--clarity-primary-light:#58a6ff33;--clarity-secondary:#818cf8;--clarity-secondary-hover:#a5b4fc;--clarity-accent:#79c0ff;--clarity-accent-light:#79c0ff26;--clarity-success:#34d399;--clarity-success-bg:#34d39926;--clarity-success-border:#34d39966;--clarity-warning:#fbbf24;--clarity-warning-bg:#fbbf2426;--clarity-warning-border:#fbbf2466;--clarity-error:#f87171;--clarity-error-bg:#f8717126;--clarity-error-border:#f8717166;--clarity-info:#60a5fa;--clarity-info-bg:#60a5fa26;--clarity-info-border:#60a5fa66;--clarity-gradient-primary:linear-gradient(135deg, #58a6ff 0%, #3d8bd4 100%);--clarity-gradient-warm:linear-gradient(180deg, #141210 0%, #1c1917 100%);--shadow-xs:0 1px 2px #0003;--shadow-sm:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 6px #0000004d, 0 2px 4px #0003;--shadow-lg:0 10px 15px #00000059, 0 4px 6px #0003;--shadow-xl:0 20px 25px #0006, 0 10px 10px #0003;--shadow-card:0 1px 3px #00000040, 0 1px 2px #00000026;--shadow-card-hover:0 8px 16px #0000004d, 0 2px 4px #0003;--shadow-focus:0 0 0 3px #58a6ff40}html{font-size:16px}body{font-family:var(--font-body);background-color:var(--clarity-bg-page);color:var(--clarity-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}.app-layout{background-color:var(--clarity-bg-page);min-height:100vh}.app-main{padding:32px 24px}.app-content{max-width:1200px;margin:0 auto}.top-nav{background:var(--clarity-bg-card);border-bottom:1px solid var(--clarity-border);z-index:100;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.top-nav-brand{align-items:center;gap:12px;display:flex}.top-nav-logo{align-items:center;gap:8px;text-decoration:none;display:flex}.logo-icon{background:var(--clarity-gradient-primary);color:#fff;width:36px;height:36px;font-family:var(--font-display);font-weight:var(--weight-bold);border-radius:8px;justify-content:center;align-items:center;font-size:14px;display:flex}.logo-img{width:auto;height:32px}.logo-text{font-family:var(--font-display);font-weight:var(--weight-semibold);color:var(--clarity-primary-dark);font-size:18px}[data-theme=dark] .logo-text{color:var(--clarity-text-primary)}.logo-divider{background:var(--clarity-border);width:1px;height:24px;margin:0 4px}.logo-product{font-family:var(--font-body);font-weight:var(--weight-medium);color:var(--clarity-text-tertiary);font-size:14px}.top-nav-links{gap:4px;margin:0;padding:0;list-style:none;display:flex}.top-nav-link{color:var(--clarity-text-secondary);font-weight:var(--weight-medium);border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;text-decoration:none;transition:all .15s;display:flex}.top-nav-link svg{width:18px;height:18px}.top-nav-link:hover{background:var(--clarity-bg-hover);color:var(--clarity-text-primary)}.top-nav-link.active{background:var(--clarity-primary);color:#fff}.top-nav-right{align-items:center;gap:16px;display:flex}.top-nav-icon-btn{cursor:pointer;width:36px;height:36px;color:var(--clarity-text-secondary);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.top-nav-icon-btn:hover{background:var(--clarity-bg-hover);color:var(--clarity-text-primary)}.top-nav-icon-btn svg{width:20px;height:20px}.top-nav-user{align-items:center;gap:12px;display:flex}.user-info{text-align:right}.user-name{font-weight:var(--weight-semibold);color:var(--clarity-text-primary);font-size:14px}.user-id{color:var(--clarity-text-tertiary);font-size:12px}.user-avatar{background:var(--clarity-gradient-primary);color:#fff;width:36px;height:36px;font-weight:var(--weight-semibold);border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.connection-card{background:var(--clarity-gradient-primary);border-radius:var(--radius-xl);padding:var(--space-6);color:#fff;margin-bottom:var(--space-6);gap:var(--space-6);grid-template-columns:1fr auto;align-items:center;display:grid}.connection-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-semibold);margin-bottom:var(--space-4);align-items:center;gap:var(--space-2);display:flex}.connection-title svg{width:20px;height:20px}.connection-details{gap:var(--space-4);grid-template-columns:5fr 1fr 2fr;align-items:start;display:grid}.connection-item label{text-transform:uppercase;letter-spacing:.5px;opacity:.8;margin-bottom:var(--space-1);font-size:11px;display:block}.connection-item code{font-family:var(--font-mono);font-size:var(--text-sm);padding:var(--space-1-5) var(--space-2);border-radius:var(--radius-sm);word-break:break-all;background:#ffffff26;display:inline-block}.connection-status{text-align:center}.status-indicator{width:64px;height:64px;margin:0 auto var(--space-2);background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;display:flex}.status-indicator.active{background:#34d3994d}.status-indicator svg{width:28px;height:28px}.status-text{font-size:var(--text-sm);font-weight:var(--weight-medium)}.status-link{font-size:var(--text-sm);font-weight:var(--weight-medium);color:#ffffffe6;text-underline-offset:2px;cursor:pointer;text-decoration:underline;transition:color .15s}.status-link:hover{color:#fff}.stats-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-trend{font-size:var(--text-xs);margin-top:var(--space-2);align-items:center;gap:var(--space-1);display:flex}.stat-trend.up{color:var(--clarity-success)}.stat-trend.down{color:var(--clarity-warning)}.usage-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.usage-label{font-size:var(--text-sm);color:var(--clarity-text-secondary)}.usage-count{font-family:var(--font-display);font-weight:var(--weight-semibold);color:var(--clarity-text-primary)}.usage-bar{background:var(--clarity-border);border-radius:var(--radius-full);height:8px;overflow:hidden}.usage-fill{background:linear-gradient(90deg, var(--clarity-primary) 0%, var(--clarity-success) 100%);border-radius:var(--radius-full);height:100%;transition:width .3s}.content-grid{gap:var(--space-6);grid-template-columns:2fr 1fr;display:grid}@media (width<=1024px){.content-grid{grid-template-columns:1fr}}.dataset-item{padding:var(--space-4);border-bottom:1px solid var(--clarity-border-subtle);justify-content:space-between;align-items:center;transition:background-color .15s;display:flex}.dataset-item:last-child{border-bottom:none}.dataset-item:hover{background-color:var(--clarity-bg-hover)}.dataset-info{align-items:center;gap:var(--space-3);display:flex}.dataset-icon{background:var(--clarity-bg-subtle);width:40px;height:40px;color:var(--clarity-primary);border-radius:10px;justify-content:center;align-items:center;display:flex}.dataset-icon svg{width:20px;height:20px}.dataset-name{font-weight:var(--weight-semibold);color:var(--clarity-text-primary);margin-bottom:2px;font-size:14px}.dataset-meta{color:var(--clarity-text-tertiary);font-size:12px}.quick-link{border-bottom:1px solid var(--clarity-border-subtle);align-items:center;gap:var(--space-3);color:var(--clarity-text-primary);padding:14px 20px;text-decoration:none;transition:background-color .15s;display:flex}.quick-link:last-child{border-bottom:none}.quick-link:hover{background-color:var(--clarity-bg-hover)}.quick-link-icon{background:var(--clarity-bg-subtle);width:36px;height:36px;color:var(--clarity-primary);border-radius:8px;justify-content:center;align-items:center;display:flex}.quick-link-icon svg{width:18px;height:18px}.quick-link-text{flex:1}.quick-link-title{font-weight:var(--weight-medium);margin-bottom:2px;font-size:14px}.quick-link-desc{color:var(--clarity-text-tertiary);font-size:12px}.quick-link-arrow{color:var(--clarity-text-muted)}.quick-link-arrow svg{width:16px;height:16px}.settings-tabs{gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-1);background:var(--clarity-bg-card);border-radius:var(--radius-lg);border:1px solid var(--clarity-border-subtle);display:flex}.settings-tab{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--clarity-text-secondary);cursor:pointer;background:0 0;border:none;transition:all .15s;display:flex}.settings-tab svg{width:18px;height:18px}.settings-tab:hover{color:var(--clarity-text-primary);background:var(--clarity-bg-hover)}.settings-tab.active{color:#fff;background:var(--clarity-primary)}.settings-content{animation:.2s fadeIn}.settings-section-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;display:flex}.settings-section-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--clarity-text-primary);margin:0 0 var(--space-1)}.settings-section-desc{font-size:var(--text-sm);color:var(--clarity-text-secondary);margin:0}.settings-form-grid{gap:var(--space-6) var(--space-4);grid-template-columns:1fr 1fr;display:grid}.settings-form-grid>div{margin-bottom:0}.settings-form-grid .input{box-sizing:border-box;max-width:100%}.settings-actions{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--clarity-border-subtle);justify-content:flex-end;gap:var(--space-3);display:flex}.btn{border-radius:var(--radius-lg,.5rem);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;line-height:1;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--clarity-gradient-primary,linear-gradient(135deg, #1a5a7a 0%, #2d7d9a 100%));color:#fff;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#14475f 0%,#246a84 100%);transform:translateY(-1px);box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--clarity-bg-card,white);color:var(--clarity-text-primary,#1a1a1a);border:1px solid var(--clarity-border,#e0dcd4);box-shadow:0 1px 2px #0000000d}.btn-secondary:hover:not(:disabled){background:var(--clarity-bg-subtle,#f5f3ef);border-color:var(--clarity-border-strong,#ccc8c0)}.btn-ghost{color:var(--clarity-text-secondary,#666);background:0 0;padding:.5rem 1rem}.btn-ghost:hover:not(:disabled){background:var(--clarity-bg-subtle,#f5f3ef);color:var(--clarity-text-primary,#1a1a1a)}.btn-danger{color:#fff;background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%)}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c 0%,#991b1b 100%)}.btn-sm{padding:.5rem 1rem;font-size:.8125rem}.btn-lg{padding:1rem 2rem;font-size:1rem}.btn-icon{width:2.5rem;height:2.5rem;padding:.5rem}.btn-icon svg{width:1.25rem;height:1.25rem}.input{width:100%;color:var(--clarity-text-primary,#1a1a1a);background:var(--clarity-bg-card,white);border:1px solid var(--clarity-border,#e0dcd4);border-radius:var(--radius-md,.375rem);padding:.75rem 1rem;font-size:.875rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--clarity-primary,#1a5a7a);outline:none;box-shadow:0 0 0 3px #1a5a7a1a}.input:disabled{background:var(--clarity-bg-subtle,#f5f3ef);color:var(--clarity-text-tertiary,#999);cursor:not-allowed}.input::placeholder{color:var(--clarity-text-tertiary,#999)}.text-label{color:var(--clarity-text-secondary,#666);margin-bottom:.375rem;font-size:.8125rem;font-weight:500;display:block}.notification-list{gap:var(--space-2);flex-direction:column;display:flex}.notification-item{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--clarity-bg-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:background .15s;display:flex}.notification-item:hover{background:var(--clarity-bg-muted)}.notification-toggle{position:relative}.notification-toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--clarity-border-strong);border-radius:12px;width:44px;height:24px;transition:background .2s;display:block;position:relative}.notification-toggle input:checked+.toggle-track{background:var(--clarity-primary)}.toggle-thumb{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.notification-toggle input:checked+.toggle-track .toggle-thumb{transform:translate(20px)}.notification-info{flex:1}.notification-label{font-weight:var(--weight-medium);color:var(--clarity-text-primary);margin-bottom:2px}.notification-desc{font-size:var(--text-sm);color:var(--clarity-text-secondary)}.security-item{align-items:center;gap:var(--space-4);display:flex}.security-icon{background:var(--clarity-bg-subtle);border-radius:var(--radius-lg);width:48px;height:48px;color:var(--clarity-primary);justify-content:center;align-items:center;display:flex}.security-icon.success{background:var(--clarity-success-bg);color:var(--clarity-success)}.security-icon svg{width:24px;height:24px}.security-info{flex:1}.security-title{font-weight:var(--weight-semibold);color:var(--clarity-text-primary)}.security-desc{font-size:var(--text-sm);color:var(--clarity-text-secondary)}.api-key-list{margin-top:var(--space-4)}.api-key-item{padding:var(--space-4);background:var(--clarity-bg-subtle);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;display:flex}.api-key-name{font-weight:var(--weight-semibold);color:var(--clarity-text-primary);margin-bottom:var(--space-1)}.api-key-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--clarity-text-secondary);background:var(--clarity-bg-muted);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.api-key-meta{font-size:var(--text-xs);color:var(--clarity-text-tertiary);margin-top:var(--space-1)}.api-key-actions{gap:var(--space-2);display:flex}.empty-state-small{text-align:center;padding:var(--space-8);color:var(--clarity-text-tertiary)}.empty-state-small p{margin-top:var(--space-2);font-size:var(--text-sm)}.route-loading{background:var(--clarity-bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex}.route-spinner{border:3px solid var(--clarity-border-subtle);border-top-color:var(--clarity-primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.auth-page{background:var(--clarity-bg-page,#f7f5f1);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-bg,.auth-bg-gradient,.auth-bg-grid,.auth-bg-glow,.auth-bg-glow-1,.auth-bg-glow-2{display:none}@keyframes float{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-30px)scale(1.1)}66%{transform:translate(-20px,20px)scale(.9)}}.auth-container{z-index:1;width:100%;max-width:420px;padding:var(--space-6);flex-direction:column;align-items:center;display:flex;position:relative}.auth-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);display:flex}.auth-logo img{width:auto;height:44px}.auth-logo-text{flex-direction:column;display:flex}.auth-logo-brand{font-family:var(--font-display);font-weight:var(--weight-bold);font-size:var(--text-xl);color:#1a1a2e;letter-spacing:-.02em}.auth-logo-product{font-size:var(--text-xs);color:#64748b;font-weight:var(--weight-medium);letter-spacing:.05em;text-transform:uppercase}.auth-card{border-radius:var(--radius-xl);width:100%;padding:var(--space-8);background:#fff;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d,0 10px 30px -5px #00568714}.auth-card-header{text-align:center;margin-bottom:var(--space-6)}.auth-card-header h1{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-semibold);color:#1a1a2e;margin:0 0 var(--space-2)}.auth-card-header p{font-size:var(--text-sm);color:#64748b;margin:0}.auth-error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:#dc2626;font-size:var(--text-sm);margin-bottom:var(--space-4);background:#fef2f2;border:1px solid #fecaca;display:flex}.auth-error svg{flex-shrink:0;width:18px;height:18px}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.auth-input-group{gap:var(--space-2);flex-direction:column;display:flex}.auth-input-group label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:#374151}.auth-input-wrapper{align-items:center;display:flex;position:relative}.auth-input-wrapper svg{left:var(--space-4);color:#9ca3af;pointer-events:none;width:18px;height:18px;position:absolute}.auth-input-wrapper input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) 48px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);color:#1a1a2e;background:#f8fafc;border:1px solid #e2e8f0;outline:none;transition:all .2s}.auth-input-wrapper input::placeholder{color:#9ca3af}.auth-input-wrapper input:focus{background:#fff;border-color:#005687;box-shadow:0 0 0 3px #0056871a}.auth-options{justify-content:space-between;align-items:center;display:flex}.auth-remember{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:#64748b;cursor:pointer;display:flex}.auth-remember input{accent-color:#005687;width:16px;height:16px}.auth-forgot{font-size:var(--text-sm);color:#005687;font-weight:var(--weight-medium);text-decoration:none}.auth-forgot:hover{text-decoration:underline}.auth-terms{align-items:flex-start;gap:var(--space-2);font-size:var(--text-xs);color:#64748b;cursor:pointer;display:flex}.auth-terms input{accent-color:#005687;width:16px;height:16px;margin-top:2px}.auth-terms a{color:#005687;text-decoration:none}.auth-terms a:hover{text-decoration:underline}.auth-submit{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:#fff;cursor:pointer;background:linear-gradient(135deg,#005687 0%,#003d5c 100%);border:none;transition:all .2s;display:flex}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #00568740}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-submit svg{width:18px;height:18px}.auth-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.auth-divider{align-items:center;gap:var(--space-4);margin:var(--space-6) 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#e2e8f0;flex:1;height:1px}.auth-divider span{font-size:var(--text-xs);color:#94a3b8;text-transform:uppercase;letter-spacing:.1em}.auth-sso{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--weight-medium);color:#374151;cursor:pointer;background:#fff;border:1px solid #e2e8f0;transition:all .2s;display:flex}.auth-sso:hover{background:#f8fafc;border-color:#cbd5e1}.auth-sso svg{color:#64748b;width:18px;height:18px}.auth-footer{justify-content:center;align-items:center;gap:var(--space-2);margin-top:var(--space-6);padding-top:var(--space-6);font-size:var(--text-sm);border-top:1px solid #e2e8f0;display:flex}.auth-footer span{color:#64748b}.auth-footer a{color:#005687;font-weight:var(--weight-medium);text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-bottom{width:100%;margin-top:var(--space-8);font-size:var(--text-xs);color:#94a3b8;justify-content:space-between;align-items:center;display:flex}.auth-bottom-links{gap:var(--space-4);display:flex}.auth-bottom-links a{color:#94a3b8;text-decoration:none}.auth-bottom-links a:hover{color:#64748b}.auth-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.auth-input-hint{color:#64748b;margin-top:.25rem;font-size:.75rem;display:block}.auth-link-button{color:#3b82f6;cursor:pointer;background:0 0;border:none;padding:0;font-size:.875rem;text-decoration:none}.auth-link-button:hover{text-decoration:underline}.auth-demo-badge{color:#fff;text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:9999px;margin-top:.5rem;padding:.25rem .5rem;font-size:.625rem;font-weight:600;display:inline-block}.auth-success{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e4d;border-radius:.5rem;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.auth-success svg{flex-shrink:0;width:1rem;height:1rem}.auth-input-wrapper select{color:#f8fafc;appearance:none;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:.5rem;width:100%;padding:.75rem 1rem .75rem 2.5rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.auth-input-wrapper select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.sftp-centered{justify-content:center;align-items:center;min-height:100vh;display:flex}.landing-page{background:var(--clarity-bg-page,#f7f5f1);min-height:100vh;color:var(--clarity-text-primary,#1a1a1a);position:relative;overflow-x:hidden}.landing-bg{z-index:0;pointer-events:none;position:fixed;inset:0}.landing-bg-gradient{background:radial-gradient(at 30% 0,#00568714 0%,#0000 50%),radial-gradient(at 70% 100%,#4770d10f 0%,#0000 50%);position:absolute;inset:0}.landing-bg-grid{background-image:linear-gradient(#00568708 1px,#0000 1px),linear-gradient(90deg,#00568708 1px,#0000 1px);background-size:80px 80px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 30%,#0000 80%);mask-image:radial-gradient(#000 30%,#0000 80%)}.landing-nav{z-index:100;padding:var(--space-4) var(--space-6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--clarity-border-subtle,#f0ede8);background:#f7f5f1e6;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.landing-logo{align-items:center;gap:var(--space-2);text-decoration:none;display:flex}.landing-logo img{width:auto;height:32px}.landing-logo-text{font-family:var(--font-display);font-weight:var(--weight-bold);font-size:var(--text-lg);color:var(--clarity-text-primary,#1a1a1a)}.landing-logo-divider{background:var(--clarity-border,#e5e7eb);width:1px;height:20px;margin:0 var(--space-2)}.landing-logo-product{font-size:var(--text-sm);color:var(--clarity-text-secondary,#6b7280);font-weight:var(--weight-medium)}.landing-nav-links{align-items:center;gap:var(--space-4);display:flex}.landing-nav-link{color:var(--clarity-text-secondary,#6b7280);font-weight:var(--weight-medium);font-size:var(--text-sm);text-decoration:none;transition:color .2s}.landing-nav-link:hover{color:var(--clarity-text-primary,#1a1a1a)}.landing-btn-primary{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--clarity-primary);color:#fff;font-weight:var(--weight-medium);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;border:none;text-decoration:none;transition:all .2s;display:inline-flex}.landing-btn-primary:hover{background:var(--clarity-primary-hover);transform:translateY(-1px)}.landing-btn-primary svg{width:16px;height:16px}.landing-btn-secondary{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--clarity-border,#e5e7eb);color:var(--clarity-text-primary,#1a1a1a);font-weight:var(--weight-medium);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;background:#fff;text-decoration:none;transition:all .2s;display:inline-flex}.landing-btn-secondary:hover{background:var(--clarity-bg-subtle,#f3f1ed);border-color:var(--clarity-border-strong,#d1d5db)}.landing-btn-white{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:var(--clarity-primary);font-weight:var(--weight-semibold);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;background:#fff;border:none;text-decoration:none;transition:all .2s;display:inline-flex}.landing-btn-white:hover{transform:translateY(-1px);box-shadow:0 10px 30px #fff3}.landing-btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.landing-hero{z-index:1;text-align:center;min-height:100vh;padding:120px var(--space-6) var(--space-20);justify-content:center;align-items:center;display:flex;position:relative}.landing-hero-content{max-width:800px}.landing-badge{align-items:center;gap:var(--space-2);padding:var(--space-1-5) var(--space-4);background:var(--clarity-primary-subtle,#00568714);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--clarity-primary,#005687);margin-bottom:var(--space-6);border:1px solid #00568726;display:inline-flex}.landing-badge-dot{background:#10b981;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.landing-title{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,4rem);font-weight:var(--weight-bold);letter-spacing:-.03em;margin:0 0 var(--space-6);color:var(--clarity-text-primary,#1a1a1a);line-height:1.1}.landing-title-gradient{background:linear-gradient(135deg, var(--clarity-primary) 0%, #4770d1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-subtitle{font-size:var(--text-xl);color:var(--clarity-text-secondary,#6b7280);margin:0 auto var(--space-8);max-width:600px;line-height:1.6}.landing-cta{justify-content:center;align-items:center;gap:var(--space-4);margin-bottom:var(--space-12);display:flex}.landing-trust{font-size:var(--text-sm);color:var(--clarity-text-tertiary,#9ca3af)}.landing-section{z-index:1;padding:var(--space-20) var(--space-6);position:relative}.landing-section-dark{background:#fff}.landing-container{max-width:1200px;margin:0 auto}.landing-section-header{text-align:center;margin-bottom:var(--space-12)}.landing-section-header h2{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);margin:0 0 var(--space-2);color:var(--clarity-text-primary,#1a1a1a)}.landing-section-header p{font-size:var(--text-lg);color:var(--clarity-text-secondary,#6b7280);margin:0}.landing-features{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.landing-feature{padding:var(--space-6);border:1px solid var(--clarity-border-subtle,#f0ede8);border-radius:var(--radius-xl);text-align:center;box-shadow:var(--shadow-card);background:#fff;transition:all .3s}.landing-feature:hover{border-color:var(--clarity-border,#e5e7eb);box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.landing-feature-icon{width:56px;height:56px;margin:0 auto var(--space-4);background:var(--clarity-primary-subtle,#00568714);border-radius:var(--radius-lg);color:var(--clarity-primary,#005687);justify-content:center;align-items:center;display:flex}.landing-feature-icon svg{width:28px;height:28px}.landing-feature h3{font-size:var(--text-lg);font-weight:var(--weight-semibold);margin:0 0 var(--space-2);color:var(--clarity-text-primary,#1a1a1a)}.landing-feature p{font-size:var(--text-sm);color:var(--clarity-text-secondary,#6b7280);margin:0;line-height:1.6}.landing-datasets{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.landing-dataset{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--clarity-bg-subtle,#f3f1ed);border:1px solid var(--clarity-border-subtle,#f0ede8);border-radius:var(--radius-lg);display:flex}.landing-dataset-icon{font-size:40px}.landing-dataset-info h4{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--clarity-text-primary,#1a1a1a);margin:0 0 2px}.landing-dataset-info span{font-size:var(--text-sm);color:var(--clarity-text-secondary,#6b7280)}.landing-cta-section{background:var(--clarity-gradient-primary);text-align:center;color:#fff}.landing-cta-section h2{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);margin:0 0 var(--space-2);color:#fff}.landing-cta-section p{font-size:var(--text-lg);opacity:.9;margin:0 0 var(--space-6);color:#fff}.landing-footer{z-index:1;padding:var(--space-6);border-top:1px solid var(--clarity-border-subtle,#f0ede8);background:#fff;position:relative}.landing-footer-inner{justify-content:space-between;align-items:center;display:flex}.landing-footer-brand{align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--clarity-text-tertiary,#9ca3af);display:flex}.landing-footer-brand img{height:24px}.landing-footer-links{gap:var(--space-6);display:flex}.landing-footer-links a{font-size:var(--text-sm);color:var(--clarity-text-tertiary,#9ca3af);text-decoration:none}.landing-footer-links a:hover{color:var(--clarity-text-secondary,#6b7280)}@media (width<=768px){.landing-features,.landing-datasets{grid-template-columns:1fr}.landing-cta{flex-direction:column}}.page-title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--weight-semibold);color:var(--clarity-text-primary);margin:0 0 var(--space-2);letter-spacing:-.02em}.page-subtitle{font-size:var(--text-base);color:var(--clarity-text-secondary);margin:0}.page-header{margin-bottom:var(--space-6)}.card{background:var(--clarity-bg-card);border:1px solid var(--clarity-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:all .2s}.card:hover{box-shadow:var(--shadow-card-hover)}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--clarity-border-subtle)}.card-body{padding:var(--space-5)}.animate-fade-up{opacity:1;animation:.4s ease-out fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}[data-theme=dark] .connection-card{box-shadow:0 0 60px #00568726}[data-theme=dark] .top-nav-link.active{box-shadow:0 0 20px #0056874d}[data-theme=dark] .card{border-color:#ffffff0f}.badge{font-size:11px;font-weight:var(--weight-medium);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:4px;padding:4px 10px;display:inline-flex}.badge svg{width:12px;height:12px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--clarity-border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--clarity-text-muted)}*{transition-property:background-color,border-color,color,box-shadow,transform;transition-duration:.15s;transition-timing-function:ease}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
