.version-footer{display:flex;justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);background:var(--bg-secondary);border-top:1px solid var(--border-default);font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.version-label{display:flex;align-items:center;gap:var(--space-xs)}.version-tag,.version-commit{font-weight:600;color:var(--text-primary)}.version-separator{color:var(--neutral-300)}@media (max-width: 768px){.version-footer{padding:var(--space-xs) var(--space-sm);flex-wrap:wrap;gap:var(--space-sm)}.version-label{flex:1;min-width:120px;justify-content:center}}.layout{display:flex;flex-direction:column;min-height:100vh}.navbar{background:var(--bg-secondary);padding:var(--space-sm) var(--space-lg);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:var(--z-sticky);border-bottom:1px solid var(--border-default)}.navbar-brand a{display:flex;align-items:center;gap:var(--space-xs);text-decoration:none;color:var(--text-primary)}.logo{font-size:var(--text-3xl)}.title{font-size:var(--text-xl);font-weight:var(--font-bold);background:linear-gradient(135deg,var(--primary-600) 0%,var(--secondary-600) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-menu{display:flex;gap:var(--space-xs)}.nav-link{text-decoration:none;color:var(--text-secondary);font-weight:var(--font-medium);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-lg);transition:all var(--transition-normal);min-height:var(--touch-target-min);display:flex;align-items:center}.nav-link:hover{background:var(--primary-50);color:var(--primary-600)}.nav-link.active{background:linear-gradient(135deg,var(--primary-600) 0%,var(--secondary-600) 100%);color:var(--text-inverse);box-shadow:var(--shadow-md)}.main-content{padding:var(--space-lg);max-width:1400px;margin:0 auto;width:100%;flex:1}@media (max-width: 768px){.navbar{flex-direction:column;gap:var(--space-sm);padding:var(--space-sm)}.navbar-menu{gap:var(--space-xs);flex-wrap:wrap;justify-content:center}.nav-link{padding:var(--space-xs) var(--space-md);font-size:var(--text-sm)}.main-content{padding:var(--space-sm)}}@media (min-width: 769px){.navbar{padding:var(--space-sm) var(--space-xl)}.main-content{padding:var(--space-xl)}}@media (min-width: 1024px){.navbar{padding:var(--space-md) var(--space-2xl)}.title{font-size:var(--text-2xl)}}@media (prefers-reduced-motion: reduce){.nav-link{transition:none}}.hero{position:relative;display:flex;align-items:center;justify-content:center;min-height:520px;padding:80px 24px 64px;background:linear-gradient(135deg,var(--primary-900) 0%,var(--primary-800) 50%,var(--primary-700) 100%);overflow:hidden}.hero-bg-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.05) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.03) 0%,transparent 40%);pointer-events:none}.hero-content{position:relative;max-width:720px;text-align:center;z-index:1}.hero-badge{display:inline-block;padding:6px 16px;margin-bottom:24px;font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-300);background:#fbbf241f;border:1px solid rgba(251,191,36,.2);border-radius:var(--radius-md)}.hero-title{font-size:2.75rem;font-weight:800;line-height:1.15;color:#fff;margin:0 0 20px}.text-gradient{background:linear-gradient(135deg,var(--accent-300) 0%,var(--accent-400) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.15rem;line-height:1.6;color:#ffffffbf;max-width:560px;margin:0 auto 36px}.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.hero .btn-primary{background:#fff;color:var(--primary-800);border:1px solid rgba(255,255,255,.9);font-weight:700}.hero .btn-primary:hover{background:var(--neutral-50);transform:translateY(-2px);box-shadow:0 8px 24px #00000040}.hero .btn-secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}.hero .btn-secondary:hover{background:#ffffff1a;border-color:#ffffff80;transform:translateY(-2px)}.hero .btn.pulse{animation:btnPulse 2.5s ease-in-out infinite}@keyframes btnPulse{0%,to{box-shadow:0 0 #fff6}50%{box-shadow:0 0 0 12px #fff0}}.section-header{text-align:center;max-width:600px;margin:0 auto 48px}.section-badge{display:inline-block;padding:4px 14px;margin-bottom:16px;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--primary-700);background:var(--primary-50);border-radius:var(--radius-md)}.section-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0 0 12px;line-height:1.2}.section-subtitle{font-size:1.05rem;color:var(--text-secondary);line-height:1.6;margin:0}.features-section{padding:80px 24px;background:var(--bg-primary)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto}.feature-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:32px 24px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;margin-bottom:20px;background:var(--primary-50);border-radius:var(--radius-lg)}.feature-icon{font-size:28px;line-height:1}.feature-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0 0 10px}.feature-description{font-size:.925rem;color:var(--text-secondary);line-height:1.6;margin:0}.steps-section{padding:80px 24px;background:var(--bg-tertiary)}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:900px;margin:0 auto}.step-card{position:relative;text-align:center;padding:0 12px}.step-number{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;margin-bottom:20px;font-size:1.25rem;font-weight:700;color:#fff;background:var(--primary-800);border-radius:50%}.step-connector{display:none}@media (min-width: 768px){.step-card:not(:last-child) .step-connector{display:block;position:absolute;top:24px;left:calc(50% + 32px);width:calc(100% - 32px);height:2px;background:linear-gradient(90deg,var(--primary-300),var(--primary-100))}}.step-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 10px}.step-description{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0}.stats-section{padding:64px 24px;background:var(--bg-primary);border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:800px;margin:0 auto;text-align:center}.stat-card{display:flex;flex-direction:column;gap:4px;padding:24px 16px}.stat-value{font-size:2.25rem;font-weight:800;color:var(--primary-800);line-height:1.1}.stat-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.cta-section{padding:80px 24px;background:linear-gradient(135deg,var(--primary-900) 0%,var(--primary-800) 100%);text-align:center}.cta-content{max-width:560px;margin:0 auto}.cta-title{font-size:1.85rem;font-weight:700;color:#fff;margin:0 0 16px;line-height:1.2}.cta-subtitle{font-size:1.05rem;color:#ffffffbf;line-height:1.6;margin:0 0 32px}.cta-section .btn-primary{background:#fff;color:var(--primary-800);border:none;font-weight:700}.cta-section .btn-primary:hover{background:var(--neutral-50);transform:translateY(-2px);box-shadow:0 8px 24px #00000040}@media (max-width: 768px){.hero{min-height:420px;padding:60px 20px 48px}.hero-title{font-size:1.85rem}.hero-subtitle{font-size:1rem}.features-section,.steps-section,.cta-section{padding:56px 20px}.features-grid,.steps-grid,.stats-grid{grid-template-columns:1fr;gap:20px}.section-title{font-size:1.6rem}.stat-value{font-size:1.85rem}.step-card .step-connector{display:none!important}}@media (max-width: 480px){.hero-title{font-size:1.5rem}.hero-actions{flex-direction:column;align-items:center}.hero-actions .btn{width:100%;max-width:280px}}.generate{animation:fadeIn .5s ease}.generate h1{color:var(--text-primary);font-size:var(--text-4xl);margin-bottom:var(--space-xs);font-weight:var(--font-bold)}.page-subtitle{color:var(--text-secondary);font-size:var(--text-lg);margin-bottom:var(--space-xl)}.generate-form{background:var(--bg-secondary);padding:var(--space-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);margin-bottom:var(--space-xl);border:1px solid var(--border-default)}.form-group{margin-bottom:var(--space-lg)}.form-group label{display:block;font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-xs);font-size:var(--text-lg)}.form-group textarea{width:100%;padding:var(--space-md);border:2px solid var(--border-default);border-radius:var(--radius-lg);font-size:var(--text-base);font-family:var(--font-primary);resize:vertical;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:150px;background:var(--bg-secondary);color:var(--text-primary)}.form-group textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-100)}.form-group textarea:disabled{background:var(--neutral-100);cursor:not-allowed;opacity:.7}.char-count{text-align:right;color:var(--text-muted);font-size:var(--text-sm);margin-top:var(--space-xs)}.error-message{background:var(--error-50);color:var(--error-700);padding:var(--space-md);border-radius:var(--radius-lg);margin-bottom:var(--space-md);font-weight:var(--font-medium);border:1px solid var(--error-200)}.generate-form .btn{width:100%;padding:var(--space-md);font-size:var(--text-lg)}.spinner{display:inline-block;width:20px;height:20px;border:3px solid var(--primary-200);border-radius:50%;border-top-color:var(--primary-600);animation:spin 1s linear infinite;margin-right:var(--space-xs)}.result-card{background:var(--bg-secondary);padding:var(--space-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);margin-bottom:var(--space-xl);animation:fadeIn .5s ease;border:1px solid var(--border-default)}.result-card h2{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:var(--text-2xl);font-weight:var(--font-bold)}.result-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.detail-item{background:var(--bg-tertiary);padding:var(--space-md);border-radius:var(--radius-lg);border:1px solid var(--border-default)}.detail-label{display:block;color:var(--text-muted);font-size:var(--text-sm);margin-bottom:var(--space-xs);font-weight:var(--font-medium)}.detail-value{color:var(--text-primary);font-weight:var(--font-bold);font-size:var(--text-xl)}.result-actions{display:flex;gap:var(--space-md);flex-wrap:wrap}.result-actions .btn{flex:1;min-width:200px}.examples-section{background:var(--bg-tertiary);padding:var(--space-xl);border-radius:var(--radius-xl);border:1px solid var(--border-default)}.examples-section h3{color:var(--text-primary);margin-bottom:var(--space-lg);text-align:center;font-size:var(--text-xl);font-weight:var(--font-semibold)}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-md)}.example-card{background:var(--bg-secondary);border:2px solid var(--border-default);padding:var(--space-lg);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-normal);text-align:center;min-height:var(--touch-target-min)}.example-card:hover{border-color:var(--primary-400);background:var(--primary-50);transform:translateY(-4px);box-shadow:var(--shadow-md)}.example-card:active{transform:translateY(0)}.btn-danger{background:var(--error-500);color:var(--text-inverse)}.btn-danger:hover{background:var(--error-600)}@media (max-width: 768px){.generate h1{font-size:var(--text-3xl)}.page-subtitle{font-size:var(--text-base)}.generate-form{padding:var(--space-lg)}.result-actions{flex-direction:column}.result-actions .btn{min-width:100%}.examples-grid{grid-template-columns:1fr}}@media (min-width: 769px){.generate-form{padding:var(--space-xl)}}@media (min-width: 1024px){.generate h1{font-size:var(--text-5xl)}.generate-form{padding:var(--space-2xl)}}@media (prefers-reduced-motion: reduce){.example-card{transition:none}}.history{animation:fadeIn .5s ease}.history.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-primary)}.spinner-large{width:50px;height:50px;border:5px solid var(--neutral-200);border-radius:50%;border-top-color:var(--primary-600);animation:spin 1s linear infinite;margin-bottom:var(--space-md)}.history-header{margin-bottom:var(--space-xl)}.history-header h1{color:var(--text-primary);font-size:var(--text-4xl);margin-bottom:var(--space-xs);font-weight:var(--font-bold)}.page-subtitle{color:var(--text-secondary);font-size:var(--text-lg)}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--border-default)}.empty-icon{font-size:var(--text-5xl);margin-bottom:var(--space-md);display:block}.empty-state h2{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:var(--text-2xl);font-weight:var(--font-semibold)}.empty-state p{color:var(--text-muted);margin-bottom:var(--space-lg)}.history-list{display:flex;flex-direction:column;gap:var(--space-md)}.history-item{background:var(--bg-secondary);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal),box-shadow var(--transition-normal);border:1px solid var(--border-default)}.history-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.history-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md);gap:var(--space-md)}.history-item-title{display:flex;align-items:center;gap:var(--space-sm);flex:1}.project-icon{font-size:var(--text-2xl)}.history-item-title h3{color:var(--text-primary);font-size:var(--text-xl);margin:0;font-weight:var(--font-semibold)}.history-item-actions{display:flex;gap:var(--space-xs);flex-wrap:wrap}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--text-sm);border-radius:var(--radius-md);text-decoration:none;border:none;cursor:pointer;transition:all var(--transition-fast);min-height:var(--touch-target-min);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);font-weight:var(--font-medium)}.btn-sm.btn-primary{background:var(--primary-600);color:var(--text-inverse)}.btn-sm.btn-primary:hover{background:var(--primary-700);transform:translateY(-1px)}.btn-sm.btn-secondary{background:var(--neutral-100);color:var(--text-secondary);border:1px solid var(--border-default)}.btn-sm.btn-secondary:hover{background:var(--neutral-200)}.btn-sm.btn-danger{background:var(--error-500);color:var(--text-inverse)}.btn-sm.btn-danger:hover{background:var(--error-600)}.history-item-description{color:var(--text-secondary);margin-bottom:var(--space-md);line-height:var(--line-height-normal);font-style:italic;padding:var(--space-sm) 0;border-top:1px solid var(--border-default);border-bottom:1px solid var(--border-default)}.history-item-meta{display:flex;gap:var(--space-lg);flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:var(--space-xs);color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-medium)}.meta-icon{font-size:var(--text-base)}.status{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px}.status.completed{background:var(--success-100);color:var(--success-700)}.status.processing{background:var(--warning-100);color:var(--warning-700)}.status.error{background:var(--error-100);color:var(--error-700)}.error-message{background:var(--error-50);color:var(--error-700);padding:var(--space-md);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);font-weight:var(--font-medium);border:1px solid var(--error-200)}@media (max-width: 768px){.history-header h1{font-size:var(--text-3xl)}.history-item-header{flex-direction:column;gap:var(--space-md)}.history-item-title{flex-direction:column;align-items:flex-start}.history-item-actions{width:100%;justify-content:flex-start}.history-item-meta{flex-direction:column;gap:var(--space-sm)}.history-item{padding:var(--space-md)}}@media (min-width: 769px){.history-list{gap:var(--space-md)}}@media (min-width: 1024px){.history-header h1{font-size:var(--text-5xl)}.history-item{padding:var(--space-xl)}}@media (prefers-reduced-motion: reduce){.history-item{transition:none}}.project-detail{animation:fadeIn .5s ease}.project-detail.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-primary)}.project-detail.error{text-align:center;padding:var(--space-2xl) var(--space-lg)}.project-detail.error h2{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:var(--text-2xl)}.project-detail.error .btn{display:inline-block}.back-link{color:var(--primary-600);text-decoration:none;font-weight:var(--font-semibold);margin-bottom:var(--space-md);display:inline-flex;align-items:center;gap:var(--space-xs);transition:color var(--transition-fast);min-height:var(--touch-target-min)}.back-link:hover{color:var(--primary-700)}.project-header{background:var(--bg-secondary);padding:var(--space-xl);border-radius:var(--radius-xl);margin-bottom:var(--space-xl);box-shadow:var(--shadow-md);border:1px solid var(--border-default)}.project-header h1{color:var(--text-primary);font-size:var(--text-4xl);margin-bottom:var(--space-sm);font-weight:var(--font-bold)}.project-description{color:var(--text-secondary);font-size:var(--text-lg);line-height:var(--line-height-relaxed)}.project-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{background:var(--bg-secondary);padding:var(--space-lg);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--space-md);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal),box-shadow var(--transition-normal);border:1px solid var(--border-default)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-icon{font-size:var(--text-3xl)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--primary-600)}.stat-label{color:var(--text-muted);font-size:var(--text-sm);font-weight:var(--font-medium)}.project-section{background:var(--bg-secondary);padding:var(--space-xl);border-radius:var(--radius-xl);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-default)}.project-section h2{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:var(--text-2xl);font-weight:var(--font-bold);border-bottom:2px solid var(--border-default);padding-bottom:var(--space-sm)}.features-list{display:flex;flex-direction:column;gap:var(--space-sm)}.feature-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-default)}.feature-icon{color:var(--success-600);font-weight:var(--font-bold);font-size:var(--text-lg)}.pages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-md)}.page-card{background:var(--bg-tertiary);padding:var(--space-lg);border-radius:var(--radius-lg);text-align:center;transition:transform var(--transition-normal),box-shadow var(--transition-normal);border:1px solid var(--border-default)}.page-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.page-icon{font-size:var(--text-4xl);margin-bottom:var(--space-md);display:block}.page-card h3{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:var(--text-lg);font-weight:var(--font-semibold)}.page-card p{color:var(--text-muted);font-size:var(--text-sm);line-height:var(--line-height-normal)}.components-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-md)}.component-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);transition:background var(--transition-fast),transform var(--transition-fast);border:1px solid var(--border-default)}.component-item:hover{background:var(--neutral-100);transform:translate(4px)}.component-name{display:flex;align-items:center;gap:var(--space-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.component-icon{font-size:var(--text-lg)}.component-type{color:var(--text-muted);font-size:var(--text-sm);background:var(--neutral-200);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-weight:var(--font-medium)}.project-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;margin-top:var(--space-xl);padding:var(--space-xl);background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--border-default)}.project-actions .btn{min-width:250px}.btn-primary{background:var(--primary-600);color:var(--text-inverse);box-shadow:var(--shadow-md)}.btn-primary:hover{background:var(--primary-700);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-default)}.btn-secondary:hover{background:var(--neutral-100);border-color:var(--neutral-300);transform:translateY(-2px)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--text-lg)}@media (max-width: 768px){.project-header h1{font-size:var(--text-3xl)}.project-stats,.components-list{grid-template-columns:1fr}.project-actions{flex-direction:column}.project-actions .btn{min-width:100%}.project-header,.project-section{padding:var(--space-lg)}}@media (min-width: 769px){.project-header{padding:var(--space-xl)}}@media (min-width: 1024px){.project-header h1{font-size:var(--text-5xl)}.project-header,.project-section,.project-actions{padding:var(--space-2xl)}}@media (prefers-reduced-motion: reduce){.stat-card,.page-card,.component-item{transition:none}}.tenants-page{padding:var(--space-lg) var(--space-xl);max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--neutral-200)}.page-header-content{display:flex;flex-direction:column;gap:var(--space-xs)}.page-title{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0}.page-subtitle{font-size:var(--text-base);color:var(--neutral-500);margin:0}.filters-section{margin-bottom:var(--space-lg)}.filters-container{display:flex;gap:var(--space-md);align-items:center;background:var(--neutral-50);padding:var(--space-md);border-radius:var(--radius-lg)}.search-wrapper{flex:1;position:relative}.search-icon{position:absolute;left:var(--space-sm);top:50%;transform:translateY(-50%);font-size:var(--icon-sm);opacity:.5}.search-input{width:100%;padding:var(--space-sm) var(--space-sm) var(--space-sm) calc(var(--space-sm) * 2.5);border:1px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.filter-group{display:flex;align-items:center;gap:var(--space-sm)}.filter-label{font-size:var(--text-sm);color:var(--neutral-600);font-weight:var(--font-medium)}.filter-select{padding:var(--space-sm) var(--space-md);border:1px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);background:#fff;cursor:pointer;transition:border-color var(--transition-fast)}.filter-select:focus{outline:none;border-color:var(--primary-500)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card{display:flex;align-items:center;gap:var(--space-md);background:#fff;padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-100);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-icon{font-size:var(--icon-lg);background:var(--primary-50);padding:var(--space-sm);border-radius:var(--radius-md);width:var(--icon-container-sm);height:var(--icon-container-sm);display:flex;align-items:center;justify-content:center}.stat-card-content{display:flex;flex-direction:column;gap:var(--space-xs)}.stat-card-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--neutral-900)}.stat-card-label{font-size:var(--text-sm);color:var(--neutral-500)}.table-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--neutral-100);overflow:hidden}.table-container{overflow-x:auto}.tenants-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.tenants-table th{background:var(--neutral-50);padding:var(--space-md);text-align:left;font-weight:var(--font-semibold);color:var(--neutral-700);border-bottom:2px solid var(--neutral-200);white-space:nowrap}.tenants-table td{padding:var(--space-md);border-bottom:1px solid var(--neutral-100);vertical-align:middle}.tenants-table tbody tr:hover{background:var(--neutral-50)}.tenant-cell{display:flex;align-items:center;gap:var(--space-sm)}.tenant-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--secondary-500));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-sm);flex-shrink:0}.tenant-info{display:flex;flex-direction:column;gap:2px}.tenant-name{font-weight:var(--font-medium);color:var(--neutral-900)}.tenant-email{font-size:var(--text-xs);color:var(--neutral-500)}.property-cell{color:var(--neutral-700)}.contact-cell{color:var(--neutral-600);font-family:var(--font-mono);font-size:var(--text-xs)}.contract-cell{display:flex;flex-direction:column;gap:4px}.contract-dates{display:flex;flex-direction:column;gap:2px}.contract-label{font-size:var(--text-xs);color:var(--neutral-500);font-weight:var(--font-medium)}.contract-dates span:last-child{color:var(--neutral-700)}.rent-cell{font-weight:var(--font-semibold);color:var(--primary-600)}.badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);text-transform:capitalize}.badge-success{background:var(--success-100);color:var(--success-500)}.badge-warning{background:var(--warning-100);color:var(--warning-500)}.badge-error{background:var(--error-100);color:var(--error-500)}.actions-cell{display:flex;gap:var(--space-xs)}.btn-icon-btn{background:none;border:none;padding:var(--space-xs);cursor:pointer;font-size:var(--icon-sm);border-radius:var(--radius-sm);transition:background-color var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.btn-icon-btn:hover{background:var(--neutral-100)}.btn-icon-btn.edit:hover{background:var(--primary-100)}.btn-icon-btn.delete:hover{background:var(--error-100)}.empty-state{text-align:center;padding:var(--space-2xl)!important}.empty-state-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.empty-state-icon{font-size:var(--icon-xl);opacity:.5}.empty-state-text{font-size:var(--text-lg);color:var(--neutral-600);font-weight:var(--font-medium);margin:0}.empty-state-subtext{font-size:var(--text-sm);color:var(--neutral-400);margin:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--neutral-200)}.modal-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0}.modal-close{background:none;border:none;font-size:var(--text-2xl);cursor:pointer;color:var(--neutral-400);padding:var(--space-xs);line-height:1;transition:color var(--transition-fast)}.modal-close:hover{color:var(--neutral-600)}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--neutral-200)}.tenant-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700)}.form-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media (max-width: 1024px){.tenants-page{padding:var(--space-md)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.filters-container{flex-direction:column;align-items:stretch}.filter-group{width:100%}.filter-select{flex:1}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.stats-grid,.form-row{grid-template-columns:1fr}.modal{margin:var(--space-sm);max-width:calc(100% - var(--space-sm) * 2)}.table-container{overflow-x:scroll;-webkit-overflow-scrolling:touch}.tenants-table{min-width:800px}}@media (max-width: 640px){.page-title{font-size:var(--text-2xl)}.btn{width:100%;justify-content:center}}:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--secondary-50: #faf5ff;--secondary-100: #f3e8ff;--secondary-200: #e9d5ff;--secondary-300: #d8b4fe;--secondary-400: #c084fc;--secondary-500: #a855f7;--secondary-600: #9333ea;--secondary-700: #7e22ce;--secondary-800: #6b21a8;--secondary-900: #581c87;--neutral-50: #f9fafb;--neutral-100: #f3f4f6;--neutral-200: #e5e7eb;--neutral-300: #d1d5db;--neutral-400: #9ca3af;--neutral-500: #6b7280;--neutral-600: #4b5563;--neutral-700: #374151;--neutral-800: #1f2937;--neutral-900: #111827;--success-50: #f0fdf4;--success-100: #dcfce7;--success-500: #22c55e;--success-600: #16a34a;--success-700: #15803d;--error-50: #fef2f2;--error-100: #fee2e2;--error-500: #ef4444;--error-600: #dc2626;--error-700: #b91c1c;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-500: #f59e0b;--warning-600: #d97706;--warning-700: #b45309;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--text-primary: #111827;--text-secondary: #374151;--text-muted: #6b7280;--text-inverse: #ffffff;--border-default: #e5e7eb;--border-focus: #3b82f6;--border-error: #ef4444;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--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;--text-6xl: 4rem;--text-7xl: 5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-xs: .5rem;--space-sm: 1rem;--space-md: 1.5rem;--space-lg: 2rem;--space-xl: 3rem;--space-2xl: 4rem;--space-3xl: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .06);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--z-dropdown: 1000;--z-sticky: 1100;--z-fixed: 1200;--z-modal-backdrop: 1300;--z-modal: 1400;--z-tooltip: 1500;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--touch-target-min: 44px;--touch-target-recommended: 48px;--icon-xs: 24px;--icon-sm: 32px;--icon-md: 48px;--icon-lg: 64px;--icon-xl: 80px;--icon-2xl: 96px;--icon-mobile-min: 36px;--icon-default: 64px;--icon-container-sm: 4.5rem;--icon-container-md: 6rem;--icon-container-lg: 8rem}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-primary);background-color:var(--bg-primary);color:var(--text-primary);line-height:var(--line-height-normal);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.skip-to-main{position:absolute;top:-100%;left:0;padding:var(--space-sm);background:var(--bg-secondary);color:var(--text-primary);z-index:var(--z-tooltip);transition:top var(--transition-fast)}.skip-to-main:focus{top:0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--neutral-100);border-radius:var(--radius-md)}::-webkit-scrollbar-thumb{background:var(--neutral-400);border-radius:var(--radius-md)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}::selection{background-color:var(--primary-200);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--space-sm)}@media (min-width: 640px){.container{padding:0 var(--space-md)}}@media (min-width: 1024px){.container{padding:0 var(--space-lg)}}.loading-skeleton{background:linear-gradient(90deg,var(--neutral-200) 25%,var(--neutral-100) 50%,var(--neutral-200) 75%);background-size:200% 100%;animation:pulse 1.5s ease-in-out infinite}@media print{body{background:#fff;color:#000}.no-print{display:none!important}}
