.login-page{align-items:center;background:linear-gradient(135deg,var(--color-bg) 0,var(--color-bg-elevated) 100%);display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-xl)}.login-container{background-color:var(--color-bg-card);border:1px solid var(--color-border);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:#ef444426;border:1px solid var(--color-error);color:var(--color-error);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:var(--color-text);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:var(--color-text)}.stats-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:var(--spacing-md);padding:var(--spacing-lg)}.stat-card,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:var(--radius-md);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:#6366f133;color:#818cf8}.stat-icon.today{background-color:#22d3ee33;color:#22d3ee}.stat-icon.ratio{background-color:#fbbf2433;color:#fbbf24}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;line-height:1.2}.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(400px,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)}.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-md)}.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,#6366f1,#818cf8)}.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}.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:#6366f133;color:#818cf8}@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:600px}}@media (max-width:480px){.stats-grid,.system-grid{grid-template-columns:1fr}.analytics-header{align-items:flex-start;flex-direction:column}}.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:#6366f10d;border-color:var(--color-primary)}.upload-zone.dragging{background-color:#6366f11a;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:var(--color-text);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:var(--color-text)}.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-success);border-radius:var(--radius-md);color:var(--color-text);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:#059669}.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-hover);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-elevated);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 #6366f133;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:var(--color-text);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:var(--color-text)}.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:#0f0f1a;--color-bg-elevated:#1a1a2e;--color-bg-card:#252540;--color-primary:#6366f1;--color-primary-hover:#818cf8;--color-accent:#22d3ee;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-border:#334155;--color-border-light:#475569;--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 #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--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:#0f0f1a;background-color:var(--color-bg);color:#f1f5f9;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 #334155;border-top-color:#6366f1;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:#94a3b8;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:#10b98126;border:1px solid #10b981;border:1px solid var(--color-success);color:#10b981;color:var(--color-success)}.message.error{background-color:#ef444426;border:1px solid #ef4444;border:1px solid var(--color-error);color:#ef4444;color:var(--color-error)}:focus-visible{outline:2px solid #6366f1;outline:2px solid var(--color-primary);outline-offset:2px}
/*# sourceMappingURL=main.8472be3f.css.map*/