:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--bg-secondary:#f7f7f8;--bg-tertiary:#efefef;--surface:#fff;--border:#e5e5e5;--border-light:#f0f0f0;--text:#111;--text-secondary:#666;--text-muted:#999;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-light:#eff6ff;--success:#22c55e;--danger:#ef4444;--danger-light:#fef2f2;--sidebar-w:240px;--header-h:56px;--radius:8px;--radius-lg:12px;--shadow:0 1px 3px #00000014;--shadow-lg:0 4px 16px #0000001a;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html{font-size:14px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select{font-family:inherit;font-size:inherit}img{max-width:100%}.landing{background:var(--bg);min-height:100vh;overflow-x:hidden}.landing-header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#fffffff2;position:sticky;top:0}.landing-header-inner{justify-content:space-between;align-items:center;max-width:1100px;height:56px;margin:0 auto;padding:0 16px;display:flex}.landing-logo{align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.landing-logo-icon{width:24px;height:24px;color:var(--accent)}.landing-logo-icon svg{width:100%;height:100%}.landing-nav{align-items:center;gap:16px;display:flex}.landing-nav a{color:var(--text-secondary);font-size:.85rem;display:none}.landing-btn-outline{border:1px solid var(--border);border-radius:var(--radius);color:var(--text);align-items:center;padding:7px 14px;font-size:.8rem;font-weight:500;transition:all .15s;display:flex}.landing-btn-outline:hover{border-color:var(--text);background:var(--bg-secondary)}.landing-hero{text-align:center;padding:56px 16px 48px}.landing-hero-badge{background:var(--accent-light);color:var(--accent);border-radius:100px;margin-bottom:20px;padding:5px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.landing-hero-title{letter-spacing:-.03em;margin-bottom:16px;font-size:clamp(1.8rem,8vw,3rem);font-weight:700;line-height:1.1}.landing-hero-subtitle{color:var(--text-secondary);margin-bottom:28px;padding:0 8px;font-size:.95rem;line-height:1.7}.landing-hero-actions{flex-direction:column;align-items:center;gap:12px;display:flex}.landing-btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);justify-content:center;align-items:center;gap:8px;width:100%;max-width:320px;padding:14px 24px;font-size:.95rem;font-weight:600;transition:background .15s;display:inline-flex}.landing-btn-primary:hover{background:var(--accent-hover)}.landing-btn-primary svg{width:16px;height:16px}.landing-btn-ghost{color:var(--text-secondary);justify-content:center;align-items:center;gap:6px;padding:12px 20px;font-size:.9rem;font-weight:500;display:inline-flex}.landing-logos{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 0;overflow:hidden}.landing-logos-track{white-space:nowrap;justify-content:center;gap:40px;animation:20s linear infinite scroll-logos;display:flex}.landing-logos-track span{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.75rem;font-weight:600}@keyframes scroll-logos{0%{transform:translate(0)}to{transform:translate(-50%)}}.landing-services{padding:60px 16px}.landing-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:10px;font-size:.7rem;font-weight:700}.landing-section-title{letter-spacing:-.02em;margin-bottom:32px;font-size:clamp(1.4rem,5vw,2rem);font-weight:700;line-height:1.2}.landing-services-grid{grid-template-columns:1fr;gap:16px;display:grid}.landing-service-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.landing-service-icon{width:32px;height:32px;color:var(--accent);margin-bottom:12px}.landing-service-icon svg{width:100%;height:100%}.landing-service-card h3{margin-bottom:6px;font-size:.95rem;font-weight:600}.landing-service-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.6}.landing-why{flex-direction:column;gap:40px;padding:60px 16px;display:flex}.landing-why-text{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem;line-height:1.7}.landing-why-stats{gap:24px;display:flex}.landing-why-stat-value{letter-spacing:-.02em;font-size:1.6rem;font-weight:700}.landing-why-stat-label{color:var(--text-muted);font-size:.75rem;font-weight:500}.landing-feature-list{flex-direction:column;gap:16px;display:flex}.landing-feature{align-items:flex-start;gap:12px;display:flex}.landing-feature-check{width:18px;min-width:18px;height:18px;color:var(--success);margin-top:2px}.landing-feature-check svg{width:100%;height:100%}.landing-feature strong{margin-bottom:2px;font-size:.875rem;font-weight:600;display:block}.landing-feature p{color:var(--text-secondary);font-size:.8rem}.landing-cta{background:var(--bg-secondary);border-top:1px solid var(--border);text-align:center;padding:60px 16px}.landing-cta-content{max-width:500px;margin:0 auto}.landing-cta h2{letter-spacing:-.02em;margin-bottom:10px;font-size:1.5rem;font-weight:700}.landing-cta p{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem}.landing-cta .landing-btn-primary{width:auto;max-width:none;display:inline-flex}.landing-footer{border-top:1px solid var(--border);padding:24px 16px}.landing-footer-content{text-align:center;flex-direction:column;gap:8px;max-width:1100px;margin:0 auto;display:flex}.landing-footer p{color:var(--text-muted);font-size:.75rem}.landing-footer-logo{justify-content:center;align-items:center;gap:8px;font-weight:700;display:flex}.login-page{flex-direction:column;min-height:100dvh;display:flex}.login-split-left{display:none}.login-split-right{flex:1;justify-content:center;align-items:center;padding:32px 20px;display:flex}.login-card{width:100%;max-width:380px}.login-card-header{margin-bottom:24px}.login-card-header h2{letter-spacing:-.02em;margin-bottom:6px;font-size:1.4rem;font-weight:700}.login-card-header p{color:var(--text-secondary);font-size:.875rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.login-field input{border:1px solid var(--border);border-radius:var(--radius);width:100%;padding:12px 14px;font-size:.95rem;transition:border-color .15s}.login-field input:focus{border-color:var(--accent);outline:none}.login-error{background:var(--danger-light);color:var(--danger);border-radius:var(--radius);padding:10px 14px;font-size:.85rem}.login-submit{background:var(--accent);color:#fff;border-radius:var(--radius);width:100%;margin-top:4px;padding:14px;font-size:.95rem;font-weight:600;transition:background .15s}.login-submit:hover{background:var(--accent-hover)}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-back{text-align:center;margin-top:20px}.login-back a{color:var(--text-muted);cursor:pointer;font-size:.85rem;transition:color .15s}.login-back a:hover{color:var(--text)}.dashboard{background:var(--bg-secondary);flex-direction:column;min-height:100dvh;display:flex}.sidebar{height:100dvh;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:200;flex-direction:column;transition:transform .25s;display:flex;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.sidebar-logo{align-items:center;gap:8px;font-size:.9rem;font-weight:700;display:flex}.sidebar-logo-icon{width:22px;height:22px;color:var(--accent)}.sidebar-logo-icon svg{width:100%;height:100%}.sidebar-close{color:var(--text-muted);padding:4px;display:flex}.sidebar-close svg{width:18px;height:18px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex;overflow-y:auto}.sidebar-nav-link{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;align-items:center;gap:10px;padding:12px;font-size:.9rem;font-weight:500;transition:all .15s;display:flex}.sidebar-nav-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-nav-link:hover{background:var(--bg-secondary);color:var(--text)}.sidebar-nav-link.active{background:var(--accent-light);color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.sidebar-status{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:10px;font-size:.75rem;display:flex}.sidebar-status-dot{background:var(--success);border-radius:50%;width:7px;height:7px}.sidebar-logout{color:var(--text-muted);align-items:center;gap:8px;width:100%;padding:8px 0;font-size:.85rem;transition:color .15s;display:flex}.sidebar-logout svg{width:16px;height:16px}.sidebar-logout:hover{color:var(--danger)}.main{flex-direction:column;flex:1;min-height:100dvh;display:flex}.main-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:100;align-items:center;gap:12px;padding:0 16px;display:flex;position:sticky;top:0}.main-header-badge{background:var(--accent-light);color:var(--accent);border:1px solid var(--accent);letter-spacing:.02em;border-radius:100px;margin-left:8px;padding:2px 7px;font-size:.65rem;font-weight:600}.main-header-menu{color:var(--text);padding:6px;display:flex}.main-header-menu svg{width:22px;height:22px}.main-header-title{flex:1;font-size:.95rem;font-weight:600}.main-header-actions{gap:6px;display:flex}.main-body{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex}.icon-btn{border-radius:var(--radius);width:34px;height:34px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.icon-btn svg{width:16px;height:16px}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text)}.icon-btn.danger:hover{background:var(--danger-light);color:var(--danger)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.stat-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.7rem;font-weight:600}.stat-icon{width:18px;height:18px;color:var(--text-muted)}.stat-icon svg{width:100%;height:100%}.stat-value{letter-spacing:-.02em;margin-bottom:6px;font-size:1.5rem;font-weight:700}.stat-bar{background:var(--bg-tertiary);border-radius:2px;height:4px;margin-bottom:6px;overflow:hidden}.stat-bar-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.stat-detail{color:var(--text-muted);font-size:.7rem}.section-title{margin-bottom:14px;font-size:.95rem;font-weight:600}.home-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.containers-list{flex-direction:column;gap:2px;display:flex}.container-row{border-radius:var(--radius);align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.container-row:hover{background:var(--bg-secondary)}.container-status{border-radius:50%;flex-shrink:0;width:7px;height:7px}.container-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.85rem;font-weight:500;overflow:hidden}.container-state{color:var(--text-muted);text-transform:capitalize;flex-shrink:0;font-size:.7rem}.docker-list{grid-template-columns:1fr;gap:12px;display:grid}.docker-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;overflow:hidden}.docker-card-header{flex-wrap:wrap;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.docker-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:6px}.docker-name{word-break:break-all;flex:60%;min-width:0;font-size:.875rem;font-weight:600;line-height:1.3}.docker-card-body{flex-direction:column;gap:4px;display:flex}.docker-info{color:var(--text-secondary);word-break:break-all;font-size:.75rem}.docker-info span{color:var(--text-muted);font-weight:500}.docker-actions{flex-wrap:wrap;flex-shrink:0;gap:6px;display:flex}.docker-action-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border-radius:8px;justify-content:center;align-items:center;min-width:40px;height:40px;padding:0 10px;transition:all .15s;display:flex}.docker-action-btn svg{flex-shrink:0;width:16px;height:16px}.docker-action-btn.start{color:var(--success)}.docker-action-btn.start:hover{border-color:var(--success);background:#f0fdf4}.docker-action-btn.stop{color:var(--danger)}.docker-action-btn.stop:hover{background:var(--danger-light);border-color:var(--danger)}.docker-action-btn.restart{color:var(--text-secondary)}.docker-action-btn.restart:hover{background:var(--bg-secondary)}.docker-action-btn:disabled{opacity:.5;cursor:not-allowed}.projects-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.projects-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;padding:16px;transition:all .15s}.project-card:hover{border-color:var(--accent)}.project-card-icon{width:28px;height:28px;color:var(--accent);margin-bottom:10px}.project-card-icon svg{width:100%;height:100%}.project-card-name{text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:.85rem;font-weight:600;overflow:hidden}.project-card-meta{color:var(--text-muted);font-size:.7rem}.project-detail-header{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.back-btn{color:var(--text-secondary);align-self:flex-start;padding:4px 0;font-size:.8rem;transition:color .15s}.back-btn:hover{color:var(--accent)}.project-detail-title{font-size:.95rem;font-weight:600}.project-detail-actions{flex-wrap:wrap;gap:8px;display:flex}.upload-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:8px 12px;font-size:.8rem;font-weight:500;transition:background .15s;display:flex}.upload-btn:hover{background:var(--accent-hover)}.upload-btn svg{width:14px;height:14px}.project-breadcrumbs{flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:12px;display:flex}.breadcrumb-sep{color:var(--text-muted);margin:0 2px}.breadcrumb-item{color:var(--text-secondary);font-size:.8rem;transition:color .15s}.breadcrumb-item:hover{color:var(--accent)}.project-toolbar{flex-direction:column;gap:10px;margin-bottom:12px;display:flex}.search-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:8px;padding:10px 12px;display:flex}.search-box svg{width:16px;height:16px;color:var(--text-muted);flex-shrink:0}.search-box input{background:0 0;border:none;outline:none;flex:1;font-size:.875rem}.sort-controls{align-items:center;gap:6px;display:flex}.sort-controls select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);flex:1;padding:7px 10px;font-size:.8rem}.upload-progress{background:var(--accent-light);border-radius:var(--radius);color:var(--accent);justify-content:space-between;margin-bottom:12px;padding:12px 14px;font-size:.8rem;display:flex}.files-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.file-row{border-bottom:1px solid var(--border-light);align-items:center;gap:10px;padding:12px 14px;transition:background .15s;display:flex}.file-row:last-child{border-bottom:none}.file-row:hover{background:var(--bg-secondary)}.file-icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.file-icon svg{width:100%;height:100%}.file-info{flex:1;min-width:0}.file-name{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;font-size:.85rem;font-weight:500;overflow:hidden}.file-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.file-actions{flex-shrink:0;gap:4px;display:flex}.shared-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.images-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.image-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.image-preview{aspect-ratio:1;background:var(--bg-tertiary);overflow:hidden}.image-preview img{object-fit:cover;width:100%;height:100%}.image-footer{justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;display:flex}.image-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.7rem;overflow:hidden}.loading{text-align:center;color:var(--text-muted);padding:40px;font-size:.875rem}.mobile-overlay{z-index:150;background:#0006;display:none;position:fixed;inset:0}.mobile-overlay.active{display:block}@media (width>=768px){.landing-nav a{display:block}.landing-hero{text-align:left;padding:80px 24px 60px}.landing-hero-actions{flex-direction:row;justify-content:flex-start}.landing-btn-primary{width:auto;max-width:none}.landing-services-grid{grid-template-columns:repeat(2,1fr);gap:20px}.landing-why{flex-direction:row;align-items:flex-start;gap:60px}.landing-footer-content{text-align:left;flex-direction:row;justify-content:space-between}.login-split-left{border-right:1px solid var(--border);background:var(--bg-secondary);flex-direction:column;flex:1;justify-content:space-between;padding:40px;display:flex}.login-split-right{flex:1;padding:40px}.login-left-content h1{font-size:1.8rem}.login-left-content>p{font-size:.95rem}.main-body{gap:20px;padding:24px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{padding:20px}.stat-value{font-size:1.8rem}.docker-list{grid-template-columns:repeat(2,1fr)}.project-toolbar{flex-direction:row}.project-toolbar .search-box{flex:1}}@media (width>=1024px){.sidebar{transform:translate(0)}.sidebar-close{display:none}.sidebar-nav-link{padding:10px 12px}.main{margin-left:var(--sidebar-w)}.main-header-menu{display:none}.projects-grid{grid-template-columns:repeat(3,1fr)}.images-grid{grid-template-columns:repeat(4,1fr);gap:16px}.file-actions{opacity:0}.file-row:hover .file-actions{opacity:1}.products-grid{grid-template-columns:repeat(2,1fr)}}.products-list{flex-direction:column;gap:8px;display:flex}.product-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:all .15s;display:flex}.product-row:hover{border-color:var(--accent)}.product-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.product-name{flex:1;font-size:.9rem;font-weight:600}.product-url{color:var(--text-muted);font-size:.75rem}.product-health{flex-shrink:0;font-size:.75rem;font-weight:500}.products-grid{grid-template-columns:1fr;gap:16px;display:grid}.product-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.product-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.product-status-indicator{border-radius:50%;flex-shrink:0;width:10px;height:10px}.product-card-name{flex:1;font-size:1rem;font-weight:700}.product-status-badge{text-transform:uppercase;border-radius:100px;padding:4px 10px;font-size:.7rem;font-weight:600}.product-status-badge.healthy{color:#22c55e;background:#22c55e20}.product-status-badge.degraded{color:#f59e0b;background:#f59e0b20}.product-status-badge.down{color:#ef4444;background:#ef444420}.product-card-desc{color:var(--text-secondary);margin-bottom:16px;font-size:.85rem}.product-card-info{flex-direction:column;gap:8px;display:flex}.product-info-row{justify-content:space-between;align-items:center;display:flex}.product-info-label{color:var(--text-muted);font-size:.75rem;font-weight:500}.product-info-value{align-items:center;gap:4px;font-size:.8rem;font-weight:500;display:flex}.product-info-value svg{width:12px;height:12px}.product-info-value.lifetime-text{color:#8b5cf6;font-weight:700}.product-containers{flex-direction:column;gap:4px;margin-top:8px;display:flex}.product-container-row{color:var(--text-secondary);align-items:center;gap:8px;font-size:.75rem;display:flex}.container-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.cobros-summary{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.cobro-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:16px}.cobro-summary-label{text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;font-size:.7rem;font-weight:600}.cobro-summary-value{font-size:1.5rem;font-weight:700}.cobro-summary-card.paid .cobro-summary-value{color:var(--success)}.cobro-summary-card.pending .cobro-summary-value{color:#f59e0b}.cobro-summary-card.revenue .cobro-summary-value{color:var(--accent)}.cobros-list{flex-direction:column;gap:12px;display:flex}.cobro-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.cobro-card-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.cobro-product{font-size:.95rem;font-weight:700}.cobro-amount{color:var(--accent);font-size:1.2rem;font-weight:700}.cobro-amount span{color:var(--text-muted);font-size:.7rem;font-weight:400}.cobro-card-body{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;display:grid}.cobro-info{flex-direction:column;gap:2px;display:flex}.cobro-label{color:var(--text-muted);font-size:.7rem;font-weight:500}.cobro-value{font-size:.8rem;font-weight:500}.cobro-status-badge{border-radius:100px;align-items:center;padding:6px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.Respaldos-header,.respaldos-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.section-subtitle{color:var(--text-muted);margin-top:2px;font-size:.8rem}.backup-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;align-items:center;gap:8px;padding:10px 16px;font-size:.85rem;font-weight:600;transition:background .15s;display:flex}.backup-btn:hover{background:var(--accent-hover)}.backup-btn:disabled{opacity:.6;cursor:not-allowed}.backup-btn svg{width:16px;height:16px}.backup-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:16px}.backup-section-title{align-items:center;gap:8px;margin-bottom:14px;font-size:.85rem;font-weight:600;display:flex}.backup-section-title svg{width:16px;height:16px;color:var(--text-muted)}.backup-status-card{background:var(--bg-secondary);border-radius:var(--radius);padding:14px}.backup-status-header{align-items:center;gap:10px;margin-bottom:8px;font-size:.9rem;font-weight:600;display:flex}.backup-indicator{border-radius:50%;width:8px;height:8px}.backup-indicator.ok{background:var(--success)}.backup-indicator.error{background:var(--danger)}.backup-status-detail{color:var(--text-secondary);font-size:.8rem}.backup-date{margin-bottom:12px;font-size:.9rem;font-weight:600}.backup-files-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.backup-file-card{background:var(--bg-secondary);border-radius:var(--radius);padding:12px}.backup-file-name{color:var(--text-muted);margin-bottom:6px;font-size:.75rem;font-weight:500}.backup-file-status{font-size:.8rem;font-weight:600}.backup-file-status.ok{color:var(--success)}.backup-file-status.empty{color:#f59e0b}.backup-file-status.missing{color:var(--danger)}.backup-history{flex-direction:column;gap:6px;display:flex}.backup-history-row{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:8px 0;display:flex}.backup-history-row:last-child{border-bottom:none}.backup-history-date{min-width:80px;font-size:.8rem;font-weight:600}.backup-history-items{flex:1;gap:16px;display:flex}.backup-history-item{font-size:.75rem}.backup-history-item.ok{color:var(--success)}.backup-history-item.empty{color:#f59e0b}.servidor-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.servidor-summary{color:var(--text-muted);font-size:.85rem}.estado-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.estado-summary{gap:16px;display:flex}.estado-summary-item{border-radius:var(--radius);flex-direction:column;align-items:center;min-width:90px;padding:12px 20px;display:flex}.estado-summary-item.healthy{background:#22c55e1a;border:1px solid #22c55e4d}.estado-summary-item.unhealthy{background:#ef44441a;border:1px solid #ef44444d}.estado-summary-num{font-size:1.8rem;font-weight:800;line-height:1}.estado-summary-item.healthy .estado-summary-num{color:#22c55e}.estado-summary-item.unhealthy .estado-summary-num{color:#ef4444}.estado-summary-label{text-transform:uppercase;opacity:.8;margin-top:4px;font-size:.72rem;font-weight:600}.estado-run-all{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;align-items:center;gap:8px;padding:10px 18px;font-size:.82rem;font-weight:600;transition:all .15s;display:flex}.estado-run-all:hover{opacity:.9}.estado-run-all:disabled{opacity:.6;cursor:not-allowed}.estado-run-all svg{width:16px;height:16px}.estado-products{flex-direction:column;gap:12px;display:flex}.estado-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.estado-card.card-healthy{border-left:4px solid #22c55e}.estado-card.card-unhealthy{border-left:4px solid #ef4444}.estado-card.card-unknown{border-left:4px solid #94a3b8}.estado-card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.estado-card-title{align-items:center;gap:10px;font-size:1rem;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.status-dot.healthy{background:#22c55e}.status-dot.unhealthy{background:#ef4444;animation:2s infinite pulse-red}.status-dot.unknown{background:#94a3b8}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.5}}.critical-badge{text-transform:uppercase;color:#ef4444;background:#fef2f2;border-radius:100px;padding:2px 7px;font-size:.65rem;font-weight:700}.estado-card-actions{gap:8px;display:flex}.estado-btn-check,.estado-btn-deploy{border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex}.estado-btn-check{background:var(--bg-secondary);color:var(--text-secondary)}.estado-btn-check:hover{background:var(--accent-light);color:var(--accent)}.estado-btn-deploy{color:#d97706;background:#fef3c7}.estado-btn-deploy:hover{color:#fff;background:#f59e0b}.estado-btn-check svg,.estado-btn-deploy svg{width:16px;height:16px}.estado-btn-check:disabled,.estado-btn-deploy:disabled{opacity:.5;cursor:not-allowed}.estado-card-body{padding:14px 16px}.estado-card-info{flex-direction:column;gap:5px;display:flex}.estado-card-info span{color:var(--text-secondary);font-size:.82rem}.estado-card-info strong{color:var(--text);margin-right:4px}.estado-card-error{border-radius:var(--radius);color:#ef4444;background:#fef2f2;align-items:center;gap:8px;margin-top:10px;padding:10px 12px;font-size:.82rem;display:flex}.estado-card-error svg{flex-shrink:0;width:15px;height:15px}.config-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:16px}.config-section-title{margin-bottom:14px;font-size:.9rem;font-weight:600}.config-info-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.config-info-card{background:var(--bg-secondary);border-radius:var(--radius);padding:12px}.config-info-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:.7rem;font-weight:600}.config-info-value{font-size:.85rem;font-weight:600}.quick-links{flex-direction:column;gap:8px;display:flex}.quick-link{background:var(--bg-secondary);border-radius:var(--radius);align-items:center;gap:10px;padding:12px;font-size:.85rem;font-weight:500;transition:all .15s;display:flex}.quick-link:hover{background:var(--accent-light);color:var(--accent)}.quick-link svg{width:16px;height:16px}.empty-state{text-align:center;color:var(--text-muted);padding:32px;font-size:.85rem}.clientes-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.clientes-header .section-title{margin-bottom:2px}.section-subtitle{color:var(--text-muted);font-size:.8rem}.clientes-list{flex-direction:column;gap:12px;display:flex}.cliente-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.cliente-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.cliente-status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cliente-name{flex:1;font-size:1rem;font-weight:700}.cliente-status-badge{font-size:.75rem;font-weight:600}.cliente-card-body{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.cliente-info{color:var(--text-secondary);font-size:.82rem}.cliente-info span{color:var(--text);margin-right:6px;font-weight:600}.cliente-products{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.cliente-products-label{color:var(--text);font-size:.82rem;font-weight:600}.cliente-product-tag{background:var(--accent-light);color:var(--accent);border-radius:100px;align-items:center;gap:6px;padding:3px 10px;font-size:.75rem;font-weight:600;display:flex}.cliente-product-price{opacity:.8}.cliente-no-products{color:var(--text-muted);font-size:.75rem;font-style:italic}.cliente-card-actions{border-top:1px solid var(--border-light);gap:8px;padding-top:12px;display:flex}.cliente-action-btn{border-radius:var(--radius);cursor:pointer;align-items:center;gap:6px;padding:7px 12px;font-size:.78rem;font-weight:600;transition:all .15s;display:flex}.cliente-action-btn.assign{background:var(--accent-light);color:var(--accent)}.cliente-action-btn.assign:hover{background:var(--accent);color:#fff}.cliente-action-btn.delete{background:var(--danger-light);color:var(--danger)}.cliente-action-btn.delete:hover{background:var(--danger);color:#fff}.cliente-action-btn svg{width:14px;height:14px}.cliente-confirm-delete{background:var(--danger-light);border-radius:var(--radius);margin-top:12px;padding:12px}.cliente-confirm-delete p{margin-bottom:10px;font-size:.82rem}.cliente-confirm-btns{gap:8px;display:flex}.cliente-confirm-yes,.cliente-confirm-no{border-radius:var(--radius);cursor:pointer;padding:6px 14px;font-size:.78rem;font-weight:600}.cliente-confirm-yes{background:var(--danger);color:#fff}.cliente-confirm-no{background:var(--bg-secondary);color:var(--text)}.cliente-assign-form{background:var(--bg-secondary);border-radius:var(--radius);margin-top:12px;padding:16px}.cliente-assign-form h4{margin-bottom:12px;font-size:.85rem}.cliente-select,.cliente-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;margin-bottom:8px;padding:9px 12px;font-size:.82rem}.cliente-select:focus,.cliente-input:focus{border-color:var(--accent);outline:none}.cliente-assign-btns{gap:8px;margin-top:4px;display:flex}.cliente-assign-save,.cliente-assign-cancel{border-radius:var(--radius);cursor:pointer;padding:8px 16px;font-size:.78rem;font-weight:600}.cliente-assign-save{background:var(--accent);color:#fff}.cliente-assign-save:disabled{opacity:.7;cursor:not-allowed}.cliente-assign-cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:24px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h3{font-size:1.1rem;font-weight:700}.modal-close{border-radius:var(--radius);width:32px;height:32px;color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-secondary);color:var(--text)}.modal-close svg{width:16px;height:16px}.modal-form{flex-direction:column;gap:4px;display:flex}.modal-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;margin-bottom:10px;padding:12px 14px;font-size:.9rem}.modal-input:focus{border-color:var(--accent);outline:none}.modal-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;width:100%;margin-top:8px;padding:14px;font-size:.9rem;font-weight:600}.modal-btn:hover{background:var(--accent-hover)}.modal-btn:disabled{opacity:.7;cursor:not-allowed}.cliente-action-btn.detail{color:var(--accent);background:#eff6ff}.cliente-action-btn.detail:hover{background:var(--accent);color:#fff}.cliente-action-btn.edit{color:var(--text-secondary);background:#f9fafb}.cliente-action-btn.edit:hover{background:var(--text-secondary);color:#fff}.modal-lg{max-width:600px}.detail-modal-body{flex-direction:column;gap:16px;display:flex}.detail-status-bar{justify-content:space-between;align-items:center;display:flex}.detail-status-badge{border-radius:100px;padding:4px 12px;font-size:.78rem;font-weight:600}.detail-toggle-btn{border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;padding:6px 14px;font-size:.78rem;font-weight:600}.detail-toggle-btn:hover{background:var(--text-secondary);color:#fff}.detail-info-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.detail-info-item{background:var(--bg-secondary);border-radius:var(--radius);padding:10px 12px}.detail-info-item span{color:var(--text-muted);text-transform:uppercase;margin-bottom:2px;font-size:.68rem;font-weight:600;display:block}.detail-info-item strong{font-size:.82rem}.detail-section{border-top:1px solid var(--border-light);padding-top:14px}.detail-section h4{color:var(--text-secondary);margin-bottom:10px;font-size:.8rem;font-weight:700}.detail-portal-access{background:var(--bg-secondary);border-radius:var(--radius);padding:10px 12px}.detail-portal-user{font-size:.82rem}.detail-portal-user span{color:var(--text-muted);margin-right:6px}.detail-portal-user code{background:var(--bg-tertiary);border-radius:4px;padding:2px 8px;font-size:.8rem}.detail-products-list,.detail-projects-list{flex-direction:column;gap:6px;display:flex}.detail-product-item,.detail-project-item{background:var(--bg-secondary);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:8px 10px;font-size:.82rem;display:flex}.detail-product-info{flex-direction:column;gap:2px;display:flex}.detail-product-info strong{font-size:.85rem}.detail-product-info span{color:var(--text-muted);font-size:.72rem}.detail-product-status{font-size:.72rem;font-weight:600}.detail-project-status{color:var(--text-muted);font-size:.72rem}.detail-payments-list{flex-direction:column;gap:6px;display:flex}.detail-payment-item{background:var(--bg-secondary);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.detail-payment-left{flex-direction:column;gap:2px;display:flex}.detail-payment-product{font-size:.82rem;font-weight:600}.detail-payment-date{color:var(--text-muted);font-size:.72rem}.detail-payment-right{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.detail-payment-amount{color:var(--accent);font-size:.85rem;font-weight:700}.detail-payment-status{font-size:.72rem;font-weight:600}.portal-body{min-height:calc(100vh - 60px);display:flex}.portal-nav{border-right:1px solid var(--border-light);background:#fff;flex-direction:column;gap:4px;width:200px;padding:16px 0;display:flex}.portal-nav-link{color:var(--text-secondary);border-radius:var(--radius);align-items:center;gap:10px;margin:0 8px;padding:10px 16px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.portal-nav-link:hover{background:var(--bg-secondary);color:var(--text-primary)}.portal-nav-link.active{background:var(--accent-light);color:var(--accent);font-weight:600}.portal-nav-link svg{flex-shrink:0;width:16px;height:16px}.portal-content{flex:1;padding:24px;overflow-y:auto}.portal-home,.portal-pagos,.portal-perfil{max-width:800px}.portal-pagos-summary{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.portal-pagos-summary-card{border:1px solid var(--border-light);border-radius:var(--radius);background:#fff;flex-direction:column;gap:4px;padding:16px;display:flex}.portal-pagos-summary-card span{color:var(--text-muted);text-transform:uppercase;font-size:.72rem;font-weight:600}.portal-pagos-summary-card strong{color:var(--accent);font-size:1.2rem}.portal-perfil-card{border:1px solid var(--border-light);border-radius:var(--radius);background:#fff;padding:24px}.portal-perfil-form{flex-direction:column;gap:16px;display:flex}.portal-perfil-field{flex-direction:column;gap:6px;display:flex}.portal-perfil-field label{color:var(--text-secondary);font-size:.78rem;font-weight:600}.portal-perfil-field input{border:1px solid var(--border-light);border-radius:var(--radius);outline:none;padding:10px 12px;font-size:.9rem;transition:border-color .15s}.portal-perfil-field input:focus{border-color:var(--accent)}.portal-perfil-msg{border-radius:var(--radius);padding:10px 14px;font-size:.82rem;font-weight:500}.portal-perfil-msg.success{color:#22c55e;background:#22c55e20}.portal-perfil-msg.error{color:#ef4444;background:#ef444420}.portal-perfil-save{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-self:flex-start;padding:12px;font-size:.9rem;font-weight:600;transition:background .15s}.portal-perfil-save:hover{background:var(--accent-hover)}.portal-perfil-save:disabled{opacity:.7;cursor:not-allowed}.portal-perfil-danger{border-top:1px solid var(--border-light);margin-top:32px;padding-top:24px}.portal-perfil-danger h3{color:#ef4444;margin-bottom:8px;font-size:.85rem;font-weight:700}.portal-perfil-danger p{color:var(--text-muted);margin-bottom:12px;font-size:.82rem}.portal-perfil-logout{color:#ef4444;border-radius:var(--radius);cursor:pointer;background:#fef2f2;border:1px solid #fecaca;align-items:center;gap:8px;padding:10px 16px;font-size:.82rem;font-weight:600;display:flex}.portal-perfil-logout:hover{color:#fff;background:#ef4444;border-color:#ef4444}.portal-header{background:var(--bg);border-bottom:1px solid var(--border);z-index:100;position:sticky;top:0}.portal-header-inner{justify-content:space-between;align-items:center;max-width:800px;height:56px;margin:0 auto;padding:0 16px;display:flex}.portal-logo{align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.portal-logo-icon{width:24px;height:24px;color:var(--accent)}.portal-logo-icon svg{width:100%;height:100%}.portal-header-right{align-items:center;gap:12px;display:flex}.portal-user-name{color:var(--text-secondary);font-size:.82rem;font-weight:500}.portal-logout-btn{border-radius:var(--radius);width:36px;height:36px;color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;display:flex}.portal-logout-btn:hover{background:var(--bg-secondary);color:var(--danger)}.portal-logout-btn svg{width:18px;height:18px}.portal-main{max-width:800px;margin:0 auto;padding:24px 16px}.portal-welcome{margin-bottom:24px}.portal-welcome h1{margin-bottom:4px;font-size:1.4rem;font-weight:700}.portal-welcome p{color:var(--text-secondary);font-size:.85rem}.portal-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:16px}.portal-section-title{align-items:center;gap:8px;margin-bottom:14px;font-size:.9rem;font-weight:700;display:flex}.portal-section-title svg{width:16px;height:16px;color:var(--accent)}.portal-products{flex-direction:column;gap:12px;display:flex}.portal-product-card{background:var(--bg-secondary);border-radius:var(--radius);padding:16px}.portal-product-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.portal-product-header h3{font-size:.95rem;font-weight:700}.portal-product-status{font-size:.75rem;font-weight:600}.lifetime-badge{color:#8b5cf6!important}.lifetime-text{color:#8b5cf6!important;font-weight:700!important}.portal-product-desc{color:var(--text-secondary);margin-bottom:12px;font-size:.8rem}.portal-product-details{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.portal-product-detail{justify-content:space-between;align-items:center;display:flex}.portal-detail-label{color:var(--text-muted);font-size:.75rem;font-weight:600}.portal-detail-value{font-size:.82rem;font-weight:600}.portal-detail-highlight{background:var(--accent-light);border-radius:var(--radius);padding:6px 10px}.portal-detail-highlight .portal-detail-label,.portal-detail-highlight .portal-detail-value{color:var(--accent)}.portal-product-link{background:var(--accent);color:#fff;border-radius:var(--radius);align-items:center;gap:6px;padding:8px 14px;font-size:.8rem;font-weight:600;transition:background .15s;display:inline-flex}.portal-product-link:hover{background:var(--accent-hover)}.portal-product-link svg{width:14px;height:14px}.portal-payment-alert{background:var(--accent-light);border-color:var(--accent);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.portal-payment-info{align-items:center;gap:12px;display:flex}.portal-payment-icon{background:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.portal-payment-icon svg{color:#fff;width:20px;height:20px}.portal-payment-info h3{margin-bottom:2px;font-size:.85rem;font-weight:700}.portal-payment-info p{color:var(--text-secondary);font-size:.78rem}.portal-pay-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;padding:10px 20px;font-size:.82rem;font-weight:600}.portal-pay-btn:hover{background:var(--accent-hover)}.portal-pay-btn:disabled{opacity:.6;cursor:not-allowed}.portal-paypal-container{background:var(--bg-secondary);border:2px solid var(--accent);border-radius:var(--radius);text-align:center;margin-bottom:16px;padding:20px}.portal-paypal-label{color:var(--text);margin-bottom:12px;font-size:.85rem;font-weight:600}#paypal-button-container{max-width:350px;margin:0 auto}.portal-pay-cancel-btn{border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;background:0 0;margin-top:10px;padding:6px 16px;font-size:.78rem}.portal-pay-cancel-btn:hover{background:var(--bg-hover)}.portal-pay-result{border-radius:var(--radius);justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;padding:14px 16px;font-size:.85rem;display:flex}.portal-pay-success{color:#166534;background:#dcfce7;border:1px solid #86efac}.portal-pay-error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.portal-pay-result-close{cursor:pointer;color:inherit;background:0 0;border:none;flex-shrink:0;padding:0;font-size:1rem;line-height:1}.portal-payments-list{flex-direction:column;gap:8px;display:flex}.portal-payment-row{border-bottom:1px solid var(--border-light);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 0;display:flex}.portal-payment-row:last-child{border-bottom:none}.portal-payment-product{flex:1;font-size:.82rem;font-weight:600}.portal-payment-amount{color:var(--accent);font-size:.82rem;font-weight:700}.portal-payment-date{color:var(--text-muted);font-size:.75rem}.portal-payment-status{font-size:.75rem;font-weight:600}.portal-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:.82rem}.login-logo{align-items:center;gap:8px;margin-bottom:24px;font-size:.9rem;font-weight:700;display:flex}.login-logo-icon{width:28px;height:28px;color:var(--accent)}.login-logo-icon svg{width:100%;height:100%}.login-title{letter-spacing:-.02em;margin-bottom:24px;font-size:1.4rem;font-weight:700}.login-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;margin-bottom:12px;padding:12px 14px;font-size:.95rem;transition:border-color .15s}.login-input:focus{border-color:var(--accent);outline:none}.login-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;width:100%;margin-top:8px;padding:14px;font-size:.95rem;font-weight:600;transition:background .15s}.login-btn:hover{background:var(--accent-hover)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-error{background:var(--danger-light);color:var(--danger);border-radius:var(--radius);margin-bottom:12px;padding:10px 14px;font-size:.85rem}
