.login-page{align-items:center;background:linear-gradient(135deg,var(--color-bg) 0,#e8e6e1 100%);display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-xl)}.login-container{background-color:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:400px;padding:var(--spacing-2xl);width:100%}.login-header{margin-bottom:var(--spacing-2xl);text-align:center}.login-header h1{color:var(--color-text);font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-xs)}.login-header p{color:var(--color-text-secondary);font-size:.9375rem}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group input::placeholder{color:var(--color-text-muted)}.error-message{background-color:#ef44441a;border:1px solid var(--color-error);color:#dc2626;font-size:.875rem;padding:var(--spacing-md);text-align:center}.error-message,.login-button{border-radius:var(--radius-md)}.login-button{align-items:center;background-color:var(--color-primary);color:#fff;display:flex;font-size:1rem;font-weight:600;justify-content:center;padding:var(--spacing-md) var(--spacing-lg);transition:background-color var(--transition-fast);width:100%}.login-button:hover:not(:disabled){background-color:var(--color-primary-hover)}.login-button:disabled{cursor:not-allowed;opacity:.7}.analytics-dashboard{display:flex;flex-direction:column;gap:var(--spacing-lg)}.analytics-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between}.analytics-header h2{font-size:1.5rem;font-weight:600;margin:0}.date-range-selector{background-color:var(--color-bg-card);border-radius:var(--radius-md);display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs)}.date-range-selector button{background-color:initial;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast)}.date-range-selector button:hover{color:var(--color-text)}.date-range-selector button.active{background-color:var(--color-primary);color:#fff}.analytics-tabs{border-bottom:2px solid var(--color-border);display:flex;flex-wrap:nowrap;gap:0;overflow:hidden}.analytics-tab{background:#0000;border-bottom:2px solid #0000;border-radius:0;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;margin-bottom:-2px;padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-fast);white-space:nowrap}.analytics-tab:hover{color:var(--color-text)}.analytics-tab.active{border-bottom-color:var(--color-primary);color:var(--color-primary)}.analytics-tab-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.stats-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{align-items:center;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);position:relative;transition:all var(--transition-fast)}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #2d6a4f1f;transform:translateY(-1px)}.stat-expand{color:var(--color-text-muted);height:16px;opacity:0;position:absolute;right:var(--spacing-sm);top:var(--spacing-sm);transition:opacity var(--transition-fast);width:16px}.stat-card.clickable:hover .stat-expand{opacity:1}.stat-expand svg{height:14px;width:14px}.stat-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-icon svg{height:24px;width:24px}.stat-icon.visitors{background-color:#2d6a4f33;color:#40916c}.stat-icon.views{background-color:#1b4d3e26;color:#1b4d3e}.stat-icon.today{background-color:#52b78833;color:#40916c}.stat-icon.ratio{background-color:#fbbf2433;color:#fbbf24}.stat-content{display:flex;flex-direction:column;min-width:0}.stat-value{font-size:1.75rem;font-weight:700;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-value-compact{font-size:1rem;font-weight:600;line-height:1.4;overflow-wrap:break-word;white-space:normal;word-break:break-all}.stat-label{color:var(--color-text-secondary);font-size:.875rem}.charts-row{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(380px,1fr))}.chart-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.chart-card h3{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-md)}.photo-views-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(10,1fr);margin:0 auto;max-width:1200px}.photo-views-grid--modal{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin-top:var(--spacing-lg);max-width:none}.photo-views-item{position:relative;width:100%}.photo-views-thumb{aspect-ratio:4/3;border-radius:var(--radius-md);display:block;object-fit:cover;width:100%}.photo-views-rank{background:#0009;border-radius:4px;color:#fff;font-size:.65rem;font-weight:700;left:4px;padding:2px 5px;position:absolute;top:4px}.photo-views-badge{align-items:center;background:#52b788;border-radius:0 0 var(--radius-md) var(--radius-md);color:#fff;display:flex;font-size:.65rem;font-weight:600;gap:0;margin-top:-4px;padding:4px 6px}.photo-views-badge-duration,.photo-views-badge-views{align-items:center;display:flex;flex:1 1;gap:3px;justify-content:center}.photo-views-badge-sep{align-self:stretch;background:#ffffff73;flex-shrink:0;margin:0 4px;width:1px}.badge-icon{display:block;flex-shrink:0;height:10px;width:10px}.chart-loading,.no-data{align-items:center;display:flex;height:250px;justify-content:center}.no-data{color:var(--color-text-muted);font-size:.9375rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-top:var(--spacing-sm)}.section-header h3{font-size:1.125rem;font-weight:600;margin:0}.live-indicator{align-items:center;color:var(--color-success);display:flex;font-size:.75rem;gap:var(--spacing-sm);letter-spacing:.05em;text-transform:uppercase}.pulse{animation:pulse 2s infinite;background-color:var(--color-success);border-radius:50%;height:8px;width:8px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.system-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.system-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.system-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.system-label{color:var(--color-text-secondary);font-size:.875rem}.system-value{font-size:1.25rem;font-weight:700}.system-value.uptime{color:var(--color-text-secondary);font-size:1rem}.progress-bar{background-color:var(--color-bg-elevated);border-radius:4px;height:8px;margin-bottom:var(--spacing-sm);overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width var(--transition-normal)}.progress-fill.cpu{background:linear-gradient(90deg,#40916c,#52b788)}.progress-fill.memory{background:linear-gradient(90deg,#2d6a4f,#40916c)}.progress-fill.disk{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.system-detail{color:var(--color-text-muted);font-size:.75rem}.network-stats{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.network-stat{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.875rem;gap:var(--spacing-xs)}.network-stat svg{height:16px;width:16px}.network-stat:first-child svg{color:var(--color-success)}.network-stat:last-child svg{color:var(--color-accent)}.visitors-table-container{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.table-loading{align-items:center;display:flex;justify-content:center;padding:var(--spacing-2xl)}.visitors-table{border-collapse:collapse;width:100%}.visitors-table td,.visitors-table th{border-bottom:1px solid var(--color-border);padding:var(--spacing-md);text-align:left}.visitors-table th{background-color:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.visitors-table td{font-size:.875rem}.visitors-table tr:last-child td{border-bottom:none}.visitors-table tr:hover td{background-color:var(--color-bg-elevated)}.referrer-cell{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ip-cell{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.8125rem}.location-cell{color:var(--color-text-secondary);font-size:.8125rem}.visitor-badge{border-radius:var(--radius-sm);display:inline-block;font-size:.75rem;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm)}.visitor-badge.new{background-color:#10b98133;color:var(--color-success)}.visitor-badge.returning{background-color:#1b4d3e26;color:#1b4d3e}.see-more-container{border-top:1px solid var(--color-border);display:flex;justify-content:center;padding:var(--spacing-md)}.see-more-button{background-color:var(--color-bg-elevated);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-fast)}.see-more-button:hover{background-color:var(--color-primary);color:#fff}.table-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.table-card h3{border-bottom:1px solid var(--color-border);font-size:1rem;font-weight:600;margin:0;padding:var(--spacing-lg)}.data-table{border-collapse:collapse;width:100%}.data-table td,.data-table th{border-bottom:1px solid var(--color-border);font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md);text-align:left}.data-table th{background-color:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background-color:var(--color-bg-elevated)}.modal-overlay{align-items:center;animation:fadeIn .15s ease;background-color:#0009;display:flex;inset:0;justify-content:center;padding:var(--spacing-lg);position:fixed;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-panel{animation:slideUp .2s ease;background-color:#fff;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:620px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:var(--spacing-lg)}.modal-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.modal-close{align-items:center;background:#f1f5f9;border-radius:var(--radius-sm);color:#64748b;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.modal-close:hover{background:#e2e8f0;color:#1e293b}.modal-close svg{height:16px;width:16px}.modal-body{color:#1e293b;padding:var(--spacing-lg)}.modal-stats-row{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.modal-stat{display:flex;flex-direction:column;gap:2px;min-width:80px}.modal-stat-value{color:#1e293b;font-size:1.5rem;font-weight:700;line-height:1.2}.modal-stat-label{color:#64748b;font-size:.75rem}.modal-chart-title{color:#334155;font-size:.875rem;font-weight:600;margin:0 0 var(--spacing-sm) 0}@media (max-width:768px){.charts-row{grid-template-columns:1fr}.stats-grid,.system-grid{grid-template-columns:repeat(2,1fr)}.visitors-table-container{overflow-x:auto}.visitors-table{min-width:700px}.analytics-tabs{gap:0}.analytics-tab{font-size:.8125rem;padding:var(--spacing-sm) var(--spacing-md)}}@media (max-width:480px){.stats-grid,.system-grid{grid-template-columns:1fr}.analytics-header{align-items:flex-start;flex-direction:column}.modal-stats-row{gap:var(--spacing-md)}}.photo-manager{display:flex;flex-direction:column;gap:var(--spacing-xl)}.photo-manager.loading{align-items:center;color:var(--color-text-secondary);justify-content:center;min-height:400px}.section-header h2{font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-xs)}.section-header p{color:var(--color-text-secondary);font-size:.9375rem}.upload-zone{align-items:center;background-color:var(--color-bg-card);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;padding:var(--spacing-2xl);transition:all var(--transition-fast)}.upload-zone:hover{background-color:#1b4d3e0d;border-color:var(--color-primary)}.upload-zone.dragging{background-color:#1b4d3e1a;border-color:var(--color-primary)}.upload-zone.uploading{cursor:wait;opacity:.7}.upload-zone input{display:none}.upload-zone svg{color:var(--color-text-muted);height:48px;width:48px}.upload-zone p{color:var(--color-text);font-weight:500}.upload-zone span{color:var(--color-text-muted);font-size:.875rem}.empty-state{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;padding:var(--spacing-2xl)}.empty-state svg{height:64px;opacity:.5;width:64px}.empty-state p{color:var(--color-text-secondary);font-size:1.125rem;font-weight:500}.photos-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.photo-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:grab;overflow:hidden;transition:all var(--transition-fast)}.photo-card:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.photo-card.dragging{opacity:.5;transform:scale(.98)}.photo-image{aspect-ratio:4/3;overflow:hidden;position:relative}.photo-image img{height:100%;object-fit:cover;width:100%}.photo-overlay{align-items:flex-end;background:linear-gradient(#0000 50%,#000c);bottom:0;display:flex;justify-content:flex-end;left:0;opacity:0;padding:var(--spacing-sm);position:absolute;right:0;top:0;transition:opacity var(--transition-fast)}.photo-card:hover .photo-overlay{opacity:1}.delete-button{align-items:center;background-color:var(--color-error);border-radius:var(--radius-md);color:#fff;display:flex;height:36px;justify-content:center;transition:background-color var(--transition-fast);width:36px}.delete-button:hover{background-color:#dc2626}.delete-button svg{height:18px;width:18px}.photo-info{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md)}.photo-name{font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drag-hint{align-items:center;color:var(--color-text-muted);display:flex;font-size:.75rem;gap:var(--spacing-xs)}.drag-hint svg{height:14px;width:14px}@media (max-width:600px){.photos-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.description-editor{display:flex;flex-direction:column;gap:var(--spacing-xl)}.description-editor.loading{align-items:center;color:var(--color-text-secondary);justify-content:center;min-height:400px}.editor-toolbar{align-items:center;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;padding:var(--spacing-md)}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:var(--spacing-sm)}.toolbar-button{align-items:center;background-color:initial;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);display:flex;font-size:.875rem;font-weight:600;height:36px;justify-content:center;min-width:36px;padding:0 var(--spacing-sm);transition:all var(--transition-fast)}.toolbar-button:hover{background-color:var(--color-bg-elevated);border-color:var(--color-border-light);color:var(--color-text)}.toolbar-button svg{height:16px;width:16px}.toolbar-button.preview-toggle{min-width:auto;padding:0 var(--spacing-md)}.toolbar-button.preview-toggle.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.toolbar-button.reset{color:var(--color-text-muted)}.toolbar-button.reset:hover{border-color:var(--color-error);color:var(--color-error)}.toolbar-divider{background-color:var(--color-border);height:24px;margin:0 var(--spacing-sm);width:1px}.save-button{align-items:center;background-color:var(--color-primary);border-radius:var(--radius-md);color:#fff;display:flex;font-size:.875rem;font-weight:600;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);transition:background-color var(--transition-fast)}.save-button:hover:not(:disabled){background-color:var(--color-primary-hover)}.save-button:disabled{cursor:not-allowed;opacity:.7}.editor-container{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:0 0 var(--radius-lg) var(--radius-lg);min-height:500px}.editor-textarea{background-color:initial;border:none;color:var(--color-text);font-family:SF Mono,Consolas,Liberation Mono,Menlo,monospace;font-size:.9375rem;height:500px;line-height:1.7;padding:var(--spacing-lg);resize:vertical;width:100%}.editor-textarea:focus{outline:none}.editor-textarea::placeholder{color:var(--color-text-muted)}.editor-preview{min-height:500px;padding:var(--spacing-lg)}.editor-preview h1{border-bottom:1px solid var(--color-border);font-size:1.75rem;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.editor-preview h2{font-size:1.375rem;margin-bottom:var(--spacing-md);margin-top:var(--spacing-xl)}.editor-preview h3{font-size:1.125rem;margin-bottom:var(--spacing-sm);margin-top:var(--spacing-lg)}.editor-preview p{line-height:1.7;margin-bottom:var(--spacing-md)}.editor-preview ol,.editor-preview ul{margin-bottom:var(--spacing-md);padding-left:var(--spacing-xl)}.editor-preview li{margin-bottom:var(--spacing-xs)}.editor-preview strong{color:var(--color-primary);font-weight:600}.editor-preview a{color:var(--color-accent);text-decoration:underline}.editor-preview code{background-color:var(--color-bg-elevated);border-radius:var(--radius-sm);font-family:SF Mono,Consolas,monospace;font-size:.875em;padding:.1em .4em}.markdown-help{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.markdown-help h4{color:var(--color-text-secondary);font-size:.875rem;font-weight:600;margin-bottom:var(--spacing-md)}.help-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.help-grid code{background-color:var(--color-bg-elevated);border-radius:var(--radius-sm);color:var(--color-text-muted);font-family:SF Mono,Consolas,monospace;font-size:.8125rem;padding:var(--spacing-sm) var(--spacing-md)}@media (max-width:768px){.editor-toolbar{align-items:stretch;flex-direction:column}.toolbar-left,.toolbar-right{flex-wrap:wrap;justify-content:center}.editor-textarea{height:400px}}.password-change{display:flex;flex-direction:column;gap:var(--spacing-xl);max-width:600px}.settings-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.settings-card h3{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-xs)}.settings-card>p{color:var(--color-text-secondary);font-size:.9375rem;margin-bottom:var(--spacing-xl)}.password-form{gap:var(--spacing-lg)}.form-group,.password-form{display:flex;flex-direction:column}.form-group{gap:var(--spacing-sm)}.form-group label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.form-group input{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem;padding:var(--spacing-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1b4d3e26;outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.6}.helper-text{color:var(--color-text-muted);font-size:.75rem}.submit-button{align-items:center;background-color:var(--color-primary);border-radius:var(--radius-md);color:#fff;display:flex;font-size:1rem;font-weight:600;justify-content:center;margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);transition:background-color var(--transition-fast)}.submit-button:hover:not(:disabled){background-color:var(--color-primary-hover)}.submit-button:disabled{cursor:not-allowed;opacity:.7}.dashboard{display:flex;flex-direction:column;min-height:100vh}.dashboard-header{align-items:center;background-color:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl)}.header-left h1{font-size:1.25rem;font-weight:600}.header-right{gap:var(--spacing-lg)}.header-right,.view-site-link{align-items:center;display:flex}.view-site-link{color:var(--color-text-secondary);font-size:.875rem;gap:var(--spacing-sm);transition:color var(--transition-fast)}.view-site-link:hover{color:var(--color-text)}.view-site-link svg{height:16px;width:16px}.logout-button{background-color:initial;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-fast)}.logout-button:hover{border-color:var(--color-error);color:var(--color-error)}.dashboard-nav{background-color:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);display:flex;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-xl)}.nav-tab{align-items:center;border-radius:var(--radius-md);color:var(--color-text-secondary);display:flex;font-size:.9375rem;font-weight:500;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-fast)}.nav-tab svg{height:18px;width:18px}.nav-tab:hover{background-color:var(--color-bg-card);color:var(--color-text)}.nav-tab.active{background-color:var(--color-primary);color:#fff}.dashboard-content{flex:1 1;margin:0 auto;max-width:1400px;padding:var(--spacing-xl);width:100%}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md)}.dashboard-nav{overflow-x:auto;padding:var(--spacing-sm)}.nav-tab{white-space:nowrap}.dashboard-content{padding:var(--spacing-md)}}.app{min-height:100vh}:root{--color-bg:#f8f9f7;--color-bg-elevated:#fff;--color-bg-card:#fff;--color-primary:#1b4d3e;--color-primary-hover:#2d6a4f;--color-primary-light:#40916c;--color-accent:#52b788;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--color-text:#2c2c2c;--color-text-secondary:#666;--color-text-muted:#9b9b9b;--color-border:#e8e6e1;--color-border-light:#d1cfc9;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--transition-fast:150ms ease;--transition-normal:250ms ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9f7;background-color:var(--color-bg);color:#2c2c2c;color:var(--color-text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);font-weight:400;line-height:1.6}img{display:block;height:auto;max-width:100%}button{background:none;border:none;cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}input,textarea{font-family:inherit;font-size:inherit}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e8e6e1;border-top-color:#1b4d3e;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:32px;width:32px}.button-spinner{animation:spin .8s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;display:inline-block;height:16px;margin-right:.5rem;margin-right:var(--spacing-sm);width:16px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container{align-items:center;color:#666;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg);justify-content:center;min-height:100vh}.message{border-radius:8px;border-radius:var(--radius-md);font-weight:500;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1rem;padding:var(--spacing-md)}.message.success{background-color:#10b9811a;border:1px solid #10b981;border:1px solid var(--color-success);color:#059669}.message.error{background-color:#ef44441a;border:1px solid #ef4444;border:1px solid var(--color-error);color:#dc2626}:focus-visible{outline:2px solid #1b4d3e;outline:2px solid var(--color-primary);outline-offset:2px}
/*# sourceMappingURL=main.a079ded1.css.map*/