@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300..800;1,300..800&family=DM+Sans:ital,opsz,wght@0,9..40,300..700;1,9..40,300..700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.auth-page{font-family:var(--font-body);background:var(--bg-primary);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;-webkit-font-smoothing:antialiased}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:40px;width:100%;max-width:420px}.auth-logo{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--accent);letter-spacing:-.02em;margin-bottom:32px;display:block}.auth-heading{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:6px}.auth-subheading{font-size:14px;color:var(--text-secondary);margin-bottom:28px;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--text-primary)}.form-input{font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;outline:none;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.form-input.error{border-color:var(--error);box-shadow:0 0 0 3px #c44b4b1a}.form-input::placeholder{color:var(--text-muted)}.field-error{font-size:12px;color:var(--error)}.auth-submit{font-family:var(--font-body);font-size:14px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:var(--radius-sm);padding:11px 16px;cursor:pointer;transition:background var(--transition);margin-top:4px;width:100%}.auth-submit:hover:not(:disabled){background:var(--accent-hover)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-banner{font-size:13px;border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:16px;line-height:1.5}.auth-banner.error{background:var(--error-bg);color:var(--error)}.auth-banner.success{background:var(--success-bg);color:var(--success)}.auth-footer{font-size:13px;color:var(--text-secondary);text-align:center;margin-top:24px}.auth-link{color:var(--accent);text-decoration:none;font-weight:500}.auth-link:hover{color:var(--accent-hover);text-decoration:underline}.chat-page{display:flex;flex-direction:column;height:100vh;max-width:800px;margin:0 auto;padding:0 24px}.chat-header{padding:32px 0 20px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-title{font-family:var(--font-heading);font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.chat-subtitle{color:var(--text-secondary);font-size:14px}.chat-body{flex:1;overflow-y:auto;padding:20px 0}.message-list{display:flex;flex-direction:column;gap:12px}.message{max-width:75%;padding:12px 16px;border-radius:var(--radius-md);font-size:14px;line-height:1.5}.message-user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message-assistant{align-self:flex-start;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary);border-bottom-left-radius:4px}.typing-indicator{display:flex;align-items:center;gap:4px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);border-bottom-left-radius:4px;width:fit-content;margin-top:12px}.typing-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.2s ease-in-out infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.plan-ready-banner{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--success-bg);border:1px solid var(--success);border-radius:var(--radius-md);margin-bottom:16px;color:var(--success);font-size:14px;font-weight:600;flex-shrink:0}.chat-footer{padding:16px 0 24px;flex-shrink:0}.message-input-container{display:flex;gap:10px;align-items:flex-end}.message-input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:var(--bg-surface);resize:none;outline:none;transition:var(--transition);line-height:1.5}.message-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.message-input:disabled{opacity:.6;cursor:not-allowed}.message-send-btn{flex-shrink:0}.plan-review-page{max-width:760px;margin:0 auto;padding:40px 24px 48px}.plan-review-header{margin-bottom:32px}.plan-review-title{font-family:var(--font-heading);font-size:26px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}.plan-review-subtitle{color:var(--text-secondary);font-size:14px;line-height:1.5}.plan-approved-notice{background:var(--success-bg);border:1px solid var(--success);border-radius:var(--radius-md);padding:12px 16px;color:var(--success);font-size:14px;margin-bottom:24px}.plan-approved-notice a{color:var(--success);font-weight:600}.plan-content-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:28px 32px;margin-bottom:32px}.plan-renderer{display:flex;flex-direction:column;gap:24px}.plan-title{font-family:var(--font-heading);font-size:20px;font-weight:700;letter-spacing:-.02em}.plan-description{color:var(--text-secondary);font-size:14px;line-height:1.6}.plan-sections{display:flex;flex-direction:column;gap:20px}.plan-section-heading{font-family:var(--font-heading);font-size:15px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.plan-section-content{font-size:14px;line-height:1.6;color:var(--text-secondary)}.plan-components-heading{font-family:var(--font-heading);font-size:15px;font-weight:600;margin-bottom:12px}.plan-components-list{display:flex;flex-direction:column;gap:8px}.plan-component{display:flex;gap:12px;padding:10px 14px;background:var(--bg-surface-hover);border-radius:var(--radius-sm);font-size:13px}.plan-component-type{font-weight:600;color:var(--accent);min-width:90px}.plan-component-description{color:var(--text-secondary)}.plan-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.build-status-page{max-width:700px;margin:0 auto;padding:40px 24px 48px}.build-status-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.build-status-title{font-family:var(--font-heading);font-size:26px;font-weight:700;letter-spacing:-.02em}.build-status-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:28px 32px;display:flex;flex-direction:column;gap:28px}.build-steps{display:flex;align-items:flex-start;gap:0;position:relative}.build-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.build-step:not(:last-child):after{content:"";position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--border);z-index:0}.build-step.completed:not(:last-child):after,.build-step.active:not(:last-child):after{background:var(--accent)}.build-step-indicator{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-muted);z-index:1;transition:var(--transition)}.build-step.active .build-step-indicator{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}.build-step.completed .build-step-indicator{border-color:var(--accent);background:var(--accent);color:#fff}.build-step.failed .build-step-indicator{border-color:var(--error);background:var(--error-bg);color:var(--error)}.build-step-label{margin-top:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.build-step.active .build-step-label{color:var(--accent)}.build-step.completed .build-step-label{color:var(--text-secondary)}.build-step.failed .build-step-label{color:var(--error)}.build-live-section{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--success-bg);border:1px solid var(--success);border-radius:var(--radius-md);gap:16px}.build-live-message{font-size:14px;font-weight:600;color:var(--success)}.build-failed-section{padding:16px 20px;background:var(--error-bg);border:1px solid var(--error);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:16px}.build-error-message{font-size:14px;color:var(--error);line-height:1.5}.build-failed-actions{display:flex;gap:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:var(--font-body);font-weight:600;border-radius:var(--radius-pill);cursor:pointer;transition:var(--transition);text-decoration:none;border:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-hover);background:var(--bg-surface-hover)}.btn-md{padding:9px 20px;font-size:13px}:root,[data-theme=light]{--status-active: #4a9e5c;--status-active-bg: rgba(74, 158, 92, .1);--status-expired: #b08030;--status-expired-bg: rgba(176, 128, 48, .1);--status-depleted: #c44b4b;--status-depleted-bg: rgba(196, 75, 75, .1);--status-inactive: #8b7e6e;--status-inactive-bg: rgba(139, 126, 110, .1)}[data-theme=dark]{--status-active: #5cb870;--status-active-bg: rgba(92, 184, 112, .12);--status-expired: #d4a04a;--status-expired-bg: rgba(212, 160, 74, .12);--status-depleted: #d46060;--status-depleted-bg: rgba(212, 96, 96, .12);--status-inactive: #5e5d58;--status-inactive-bg: rgba(94, 93, 88, .12)}.admin-page{animation:fadeUp .3s cubic-bezier(.4,0,.2,1)}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px}.admin-header h1{font-family:var(--font-heading);font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.admin-header p{font-size:13px;color:var(--text-secondary);margin-top:3px}.admin-stats{display:flex;gap:10px;margin-bottom:20px}.stat-card{flex:1;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 18px;transition:border-color var(--transition)}.stat-card:hover{border-color:var(--border-hover)}.stat-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.stat-value{font-family:var(--font-heading);font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.stat-value.accent{color:var(--accent)}.admin-table-container{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table thead th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-surface)}.admin-table tbody td{font-size:13px;padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr{transition:background var(--transition)}.admin-table tbody tr:hover{background:var(--bg-surface-hover)}.code-cell{display:flex;align-items:center;gap:8px}.code-value{font-family:monospace;font-weight:600;font-size:13px;letter-spacing:.06em;color:var(--text-primary)}.code-cell.inactive .code-value{opacity:.5}.copy-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:color var(--transition),background var(--transition);flex-shrink:0}.copy-btn:hover{color:var(--accent);background:var(--accent-subtle)}.copy-btn.copied{color:var(--status-active)}.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.01em;padding:3px 8px;border-radius:var(--radius-pill)}.status-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.badge-active{background:var(--status-active-bg);color:var(--status-active)}.badge-active .status-dot{background:var(--status-active)}.badge-expired{background:var(--status-expired-bg);color:var(--status-expired)}.badge-expired .status-dot{background:var(--status-expired)}.badge-depleted{background:var(--status-depleted-bg);color:var(--status-depleted)}.badge-depleted .status-dot{background:var(--status-depleted)}.badge-deactivated{background:var(--status-inactive-bg);color:var(--status-inactive)}.badge-deactivated .status-dot{background:var(--status-inactive)}.uses-cell{color:var(--text-secondary)}.uses-current{color:var(--text-primary);font-weight:600}.date-cell{color:var(--text-secondary);font-size:12px}.actions-cell{display:flex;gap:4px}.btn-deactivate{font-family:var(--font-body);font-size:12px;font-weight:500;padding:4px 10px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background var(--transition),color var(--transition);background:transparent;color:var(--status-depleted)}.btn-deactivate:hover:not(:disabled){background:var(--status-depleted-bg)}.btn-deactivate:disabled{opacity:.35;cursor:not-allowed}.btn-generate{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:13px;font-weight:600;padding:9px 18px;border-radius:var(--radius-pill);border:none;cursor:pointer;background:var(--accent);color:#fff;box-shadow:var(--shadow-sm);transition:background var(--transition),box-shadow var(--transition),transform var(--transition)}.btn-generate:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.admin-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;width:420px;max-width:90vw;box-shadow:var(--shadow-hover)}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.admin-modal-header h2{font-family:var(--font-heading);font-size:17px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.admin-modal-close{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:15px;transition:color var(--transition),background var(--transition)}.admin-modal-close:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.admin-form-row{display:flex;gap:12px;margin-bottom:0}.admin-form-group{flex:1;margin-bottom:18px}.admin-form-label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}.admin-form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}.admin-form-input{width:100%;padding:9px 11px;font-family:var(--font-body);font-size:13px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.admin-form-input::placeholder{color:var(--text-muted)}.admin-form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.admin-modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:18px;border-top:1px solid var(--border)}.btn-cancel{font-family:var(--font-body);font-size:13px;font-weight:500;padding:8px 16px;border-radius:var(--radius-pill);border:1px solid var(--border);cursor:pointer;background:transparent;color:var(--text-primary);transition:border-color var(--transition),background var(--transition)}.btn-cancel:hover{border-color:var(--border-hover);background:var(--bg-surface-hover)}.admin-empty{text-align:center;padding:48px 24px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted)}.admin-empty-icon{font-size:28px;margin-bottom:10px;opacity:.5}.admin-empty p{font-size:14px;color:var(--text-secondary)}:root,[data-theme=light]{--font-heading: "Plus Jakarta Sans", sans-serif;--font-body: "DM Sans", sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 100px;--transition: .2s cubic-bezier(.4, 0, .2, 1);--bg-primary: #faf8f5;--bg-surface: #ffffff;--bg-surface-hover: #f5f2ee;--bg-sidebar: #ffffff;--border: #ebe6df;--border-hover: #d9d2c8;--text-primary: #2c2418;--text-secondary: #8b7e6e;--text-muted: #b5aa9a;--accent: #d4603a;--accent-hover: #c0532e;--accent-subtle: rgba(212, 96, 58, .08);--error: #c44b4b;--error-bg: #f8e0e0;--success: #4a9e5c;--success-bg: #e8f5eb;--status-live: #4a9e5c;--status-live-bg: #e8f5eb;--status-building: #3d8fca;--status-building-bg: #e0eef8;--status-planning: #7c5cbf;--status-planning-bg: #ede8f8;--status-approved: #4a9e5c;--status-approved-bg: #e8f5eb;--status-draft: #8b7e6e;--status-draft-bg: #f0ece6;--status-failed: #c44b4b;--status-failed-bg: #f8e0e0;--shadow-sm: 0 1px 3px rgba(44, 36, 24, .04);--shadow-md: 0 4px 12px rgba(44, 36, 24, .06);--shadow-hover: 0 8px 24px rgba(44, 36, 24, .08)}[data-theme=dark]{--bg-primary: #161616;--bg-surface: #1e1e1d;--bg-surface-hover: #272726;--bg-sidebar: #1e1e1d;--border: #2e2e2c;--border-hover: #3d3d3a;--text-primary: #ededea;--text-secondary: #9c9b94;--text-muted: #5e5d58;--accent: #e87b52;--accent-hover: #f09070;--accent-subtle: rgba(232, 123, 82, .12);--error: #d46060;--error-bg: rgba(212, 96, 96, .12);--success: #5cb870;--success-bg: rgba(92, 184, 112, .12);--status-live: #5cb870;--status-live-bg: rgba(92, 184, 112, .12);--status-building: #5ba3d9;--status-building-bg: rgba(91, 163, 217, .12);--status-planning: #9b82d4;--status-planning-bg: rgba(155, 130, 212, .12);--status-approved: #5cb870;--status-approved-bg: rgba(92, 184, 112, .12);--status-draft: #9a8e7d;--status-draft-bg: rgba(154, 142, 125, .12);--status-failed: #d46060;--status-failed-bg: rgba(212, 96, 96, .12);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-hover: 0 8px 24px rgba(0, 0, 0, .35)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}.layout{display:grid;grid-template-columns:220px 1fr;grid-template-rows:auto 1fr;min-height:100vh}.topnav{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary)}.logo-icon{width:26px;height:26px;background:linear-gradient(135deg,var(--accent),#F2A07B);border-radius:7px;display:flex;align-items:center;justify-content:center}.logo-text{font-family:var(--font-heading);font-size:17px;font-weight:700;letter-spacing:-.03em}.nav-right{display:flex;align-items:center;gap:8px}.user-menu{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 5px;border-radius:var(--radius-pill);background:var(--bg-surface-hover);border:1px solid var(--border);cursor:pointer;transition:var(--transition);font-family:var(--font-body);font-size:13px;color:var(--text-primary)}.user-menu:hover{border-color:var(--border-hover)}.user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#F2A07B);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);padding:20px 12px;display:flex;flex-direction:column;gap:2px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:var(--transition);cursor:pointer}.sidebar-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.sidebar-item.active{background:var(--accent-subtle);color:var(--accent)}.icon{width:20px;height:20px;stroke:currentColor;fill:none}.main{padding:36px 44px;overflow-y:auto}.welcome{margin-bottom:32px;animation:fadeUp .4s ease-out}.welcome h1{font-family:var(--font-heading);font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.welcome p{color:var(--text-secondary);font-size:14px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;animation:fadeUp .4s ease-out .08s both}.create-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-pill);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:0 2px 8px #d4603a33}.create-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 14px #d4603a4d}.create-btn:disabled{opacity:.6;cursor:not-allowed}.view-toggle{display:flex;background:var(--bg-surface-hover);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;gap:2px}.view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;border:none;border-radius:5px;background:transparent;cursor:pointer;transition:var(--transition);color:var(--text-muted)}.view-btn.active{background:var(--bg-surface);box-shadow:var(--shadow-sm);color:var(--text-primary)}.view-btn:hover:not(.active){color:var(--text-secondary)}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:.01em}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-dot-pulse{animation:pulse 2s ease-in-out infinite}.status-live{background:var(--status-live-bg);color:var(--status-live)}.status-live .status-dot{background:var(--status-live)}.status-building{background:var(--status-building-bg);color:var(--status-building)}.status-building .status-dot{background:var(--status-building)}.status-planning{background:var(--status-planning-bg);color:var(--status-planning)}.status-planning .status-dot{background:var(--status-planning)}.status-approved{background:var(--status-approved-bg);color:var(--status-approved)}.status-approved .status-dot{background:var(--status-approved)}.status-draft{background:var(--status-draft-bg);color:var(--status-draft)}.status-draft .status-dot{background:var(--status-draft)}.status-failed{background:var(--status-failed-bg);color:var(--status-failed)}.status-failed .status-dot{background:var(--status-failed)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.app-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;transition:var(--transition);cursor:pointer;animation:fadeUp .35s ease-out both;outline:none}.app-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.app-card:focus-visible{box-shadow:0 0 0 3px var(--accent-subtle);border-color:var(--accent)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.card-name{font-family:var(--font-heading);font-size:16px;font-weight:650;margin-bottom:4px;letter-spacing:-.01em}.card-desc{font-size:13px;color:var(--text-secondary);line-height:1.45;margin-bottom:16px}.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border)}.card-link{font-size:13px;color:var(--accent);font-weight:600}.app-list{display:block}.list-table{width:100%;border-collapse:separate;border-spacing:0}.list-table th{text-align:left;padding:8px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border)}.list-table td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--border);transition:var(--transition);vertical-align:middle}.list-table tbody tr{cursor:pointer;animation:fadeUp .25s ease-out both}.list-table tbody tr:hover td{background:var(--bg-surface-hover)}.list-name{display:flex;align-items:center;gap:10px;font-weight:600}.list-desc{color:var(--text-secondary);max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.state-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;gap:12px;text-align:center}.state-text{color:var(--text-secondary);font-size:14px}.state-error{color:var(--status-failed);font-size:14px;font-weight:500}.spinner{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-retry{padding:8px 20px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg-surface);cursor:pointer;font-size:13px;font-weight:600;color:var(--text-primary);transition:var(--transition)}.btn-retry:hover{border-color:var(--border-hover);background:var(--bg-surface-hover)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;gap:12px;text-align:center;animation:fadeUp .4s ease-out}.empty-icon{font-size:48px;margin-bottom:4px}.empty-title{font-family:var(--font-heading);font-size:20px;font-weight:700;letter-spacing:-.02em}.empty-desc{color:var(--text-secondary);font-size:14px;margin-bottom:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c241866;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease-out;padding:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg-surface);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:440px;box-shadow:var(--shadow-hover);animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-family:var(--font-heading);font-size:18px;font-weight:700;letter-spacing:-.02em}.modal-close{width:28px;height:28px;border:none;background:var(--bg-surface-hover);border-radius:6px;cursor:pointer;font-size:12px;color:var(--text-secondary);transition:var(--transition)}.modal-close:hover{background:var(--border);color:var(--text-primary)}.field{margin-bottom:16px}.field-label,.input-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.required{color:var(--accent)}.optional{color:var(--text-muted);font-weight:400}.field-input,.input-field{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:var(--bg-surface);transition:var(--transition);outline:none;box-sizing:border-box}.field-input:focus,.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.field-textarea{resize:vertical;min-height:80px}.input-error{border-color:var(--status-failed)}.input-error:focus{box-shadow:0 0 0 3px #ef444433}.input-error-message{display:block;color:var(--status-failed);font-size:12px;margin-top:4px}.input-helper{display:block;color:var(--text-muted);font-size:12px;margin-top:4px}.input-wrapper{margin-bottom:0}.input-wrapper-disabled{opacity:.5}.form-error{color:var(--status-failed);font-size:13px;margin-bottom:12px}.modal-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:20px}.btn-ghost{padding:9px 16px;border:none;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--text-secondary);border-radius:var(--radius-pill);transition:var(--transition)}.btn-ghost:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.menu-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface-hover);color:var(--text-secondary);cursor:pointer;transition:var(--transition);flex-shrink:0}.menu-toggle:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-surface)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface-hover);color:var(--text-secondary);cursor:pointer;transition:var(--transition);flex-shrink:0}.theme-toggle:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-surface)}@media(max-width:900px){.layout{grid-template-columns:1fr}.sidebar{display:none}.main{padding:24px 20px}.app-grid{grid-template-columns:1fr}}
