.login-page{min-height:100vh;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:32px}.login-card{width:100%;max-width:420px;background:var(--bg-primary);border-radius:8px;padding:36px 32px;border:1px solid var(--border-primary);text-align:center}.login-logo{font-weight:700;color:var(--primary-600);letter-spacing:.05em;margin-bottom:12px}.login-card h1{margin:0}.login-form{display:flex;flex-direction:column;gap:16px;margin-top:24px}.login-form label{display:flex;flex-direction:column;text-align:left;gap:6px;color:var(--text-primary);font-weight:500}.login-form input{border-radius:6px;border:1px solid var(--border-primary);padding:10px 12px;font-size:.95rem;background:var(--bg-primary);color:var(--text-primary)}.login-form input:focus{outline:none;border-color:var(--primary-600)}.login-form button{margin-top:12px;border:none;border-radius:6px;background:var(--primary-600);color:var(--white);padding:10px 16px;font-weight:500;font-size:.95rem;cursor:pointer;transition:all .2s ease}.login-form button:hover:not(:disabled){background:var(--primary-700)}.login-form button:disabled{opacity:.6;cursor:default}.login-error{background:#dc26261a;border-radius:10px;padding:10px 12px;color:var(--downtrend);font-size:.9rem;border:1px solid rgba(220,38,38,.2)}.login-footnote{margin-top:16px;font-size:.85rem;color:var(--text-tertiary)}.menu-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:2rem}.menu-container{width:100%;max-width:1200px}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;max-width:800px;margin:0 auto}.menu-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:2rem 1.5rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:160px;justify-content:center;color:var(--text-primary)}.menu-card:hover{border-color:var(--primary-400);background:var(--primary-100)}.menu-card:hover .menu-card-label{color:var(--primary-700)}.menu-card:active{background:var(--primary-100)}.menu-card:active .menu-card-label{color:var(--primary-700)}.menu-card-icon{color:var(--primary-600);display:flex;align-items:center;justify-content:center}.menu-card-label{font-size:1.1rem;font-weight:500;color:var(--text-primary);text-align:center}@media (max-width: 768px){.menu-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.menu-card{padding:2rem 1.5rem;min-height:160px}.menu-card-icon svg{width:40px;height:40px}.menu-card-label{font-size:1.1rem}}@media (max-width: 480px){.menu-grid{grid-template-columns:1fr;gap:1rem}}.page-layout{min-height:calc(100vh - 80px);display:flex;flex-direction:column;gap:1.5rem;background:var(--bg-primary);padding:8px}.page-tabs{display:flex;gap:1rem;flex-wrap:wrap}.page-tab{border:1px solid var(--border-primary);border-radius:8px;padding:12px 20px;background:var(--bg-primary);text-align:left;cursor:pointer;flex:1;min-width:200px}.page-tab.active{border-color:var(--primary-600);background:var(--primary-100)}.page-tab.active .page-tab-label{color:var(--primary-700)}.page-tab.active .page-tab-desc{color:var(--primary-600)}.page-tab-label{display:block;font-weight:500;color:var(--text-primary);font-size:.95rem}.page-tab-desc{display:block;color:var(--text-tertiary);margin-top:.25rem;font-size:.85rem}.page-content{padding:0}@media (max-width: 640px){.page-content{padding:1.5rem}}.admin-input{width:100%;padding:.6rem .75rem;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit}.admin-input:focus{outline:none;border-color:var(--border-primary)}.admin-input:disabled{opacity:.6;cursor:not-allowed}.admin-input::placeholder{color:var(--text-tertiary)}.admin-select{width:100%;padding:.6rem .75rem;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;cursor:pointer}.admin-select:focus{outline:none;border-color:var(--primary-600)}.admin-select:disabled{opacity:.6;cursor:not-allowed}.admin-select option{background:var(--bg-primary);color:var(--text-primary)}.admin-textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;resize:vertical}.admin-textarea:focus{outline:none;border-color:var(--primary-600)}.admin-textarea:disabled{opacity:.6;cursor:not-allowed}.admin-textarea::placeholder{color:var(--text-tertiary)}.admin-btn{padding:.6rem 1rem;border:1px solid transparent;border-radius:6px;font-size:.9rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.admin-btn:disabled{opacity:.6;cursor:not-allowed}.admin-btn-small{padding:.4rem .75rem;font-size:.85rem}.admin-btn-medium{padding:.6rem 1rem;font-size:.9rem}.admin-btn-large{padding:.75rem 1.25rem;font-size:1rem}.admin-btn-default{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-primary)}.admin-btn-default:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.admin-btn-primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.admin-btn-primary:hover:not(:disabled){background:var(--primary-700);border-color:var(--primary-700)}.admin-btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-primary)}.admin-btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.admin-btn-danger{background:var(--bg-primary);color:var(--downtrend);border-color:var(--downtrend)}.admin-btn-danger:hover:not(:disabled){background:#dc26261a}.admin-btn-success{background:var(--uptrend);color:#fff;border-color:var(--uptrend)}.admin-btn-success:hover:not(:disabled){background:#15803d;border-color:#15803d}.admin-btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.admin-btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.metric-search-wrapper{position:relative;width:100%}.metric-search-input{width:100%}.metric-search-results{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:var(--white);border:1px solid var(--neutral-300);border-radius:.5rem;box-shadow:var(--box-shadow-lg);max-height:300px;overflow-y:auto;z-index:1000;padding:.5rem}.metric-search-item{width:100%;padding:.75rem;border:none;background:transparent;text-align:left;cursor:pointer;border-radius:.375rem;transition:background-color .15s ease;display:flex;flex-direction:column;gap:.25rem}.metric-search-item:hover{background:var(--neutral-100)}.metric-search-item-name{font-weight:500;color:var(--neutral-900);font-size:.875rem}.metric-search-item-unit{font-size:.8125rem;color:var(--neutral-600)}.metric-search-item-group{font-size:.75rem;color:var(--neutral-500)}.metric-search-selected{margin-top:.75rem;padding:.75rem;background:var(--neutral-50);border:1px solid var(--neutral-300);border-radius:.375rem;display:flex;align-items:center;gap:.5rem;font-size:.875rem}.metric-search-selected-label{color:var(--neutral-600);font-weight:500}.metric-search-selected-name{flex:1;color:var(--neutral-900)}.metric-search-clear{background:transparent;border:none;color:var(--neutral-500);font-size:1.25rem;line-height:1;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .15s ease}.metric-search-clear:hover{background:var(--neutral-300);color:var(--downtrend)}.featured-analyses-manager{display:flex;flex-direction:column;gap:2rem}.featured-analyses-heading{display:flex;justify-content:space-between;gap:1.5rem;align-items:flex-start}.featured-analyses-heading h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.featured-analyses-kicker{text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;color:var(--text-tertiary);margin-bottom:.25rem;font-weight:500}.featured-analyses-subtitle{margin:.5rem 0 0;color:var(--text-tertiary);max-width:640px;font-size:.9rem}.featured-analyses-summary{display:flex;align-items:baseline;gap:.35rem;font-weight:600;color:var(--text-tertiary)}.featured-analyses-count{font-size:2rem;color:var(--text-primary);font-weight:600}.featured-analyses-error{border-radius:.75rem;padding:.9rem 1.25rem;background:#dc26261a;color:var(--downtrend);border:1px solid rgba(220,38,38,.2)}.featured-analyses-content{display:grid;grid-template-columns:minmax(0,2fr) minmax(320px,1fr);gap:1.75rem}.featured-analyses-selected,.featured-analyses-form{border:1px solid var(--border-primary);padding:1.25rem;background:var(--bg-primary)}.featured-analyses-selected header h3,.featured-analyses-form header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.featured-analyses-selected header p,.featured-analyses-form header p{margin:.25rem 0 0;color:var(--text-tertiary);font-size:.85rem}.featured-analyses-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.featured-analyses-card{border:1px solid var(--border-primary);border-radius:6px;padding:.875rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--bg-secondary)}.featured-analyses-card-content{display:flex;align-items:center;gap:.75rem;flex:1}.featured-analyses-card-actions{display:flex;flex-direction:column;gap:.25rem}.featured-analyses-sort-btn{border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-primary);padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.featured-analyses-sort-btn:hover:not(:disabled){background:var(--bg-tertiary)}.featured-analyses-sort-btn:disabled{opacity:.4;cursor:not-allowed}.featured-analyses-card-main{flex:1}.featured-analyses-card-title{font-weight:500;color:var(--text-primary);font-size:.95rem;display:flex;align-items:center;gap:.5rem}.featured-analyses-edit-btn{border:none;background:transparent;cursor:pointer;font-size:.85rem;opacity:.6;transition:opacity .2s ease;padding:0}.featured-analyses-edit-btn:hover{opacity:1}.featured-analyses-edit-title{display:flex;flex-direction:column;gap:.5rem}.featured-analyses-edit-actions{display:flex;gap:.5rem}.featured-analyses-card-title{font-weight:500;color:var(--text-primary);font-size:.95rem}.featured-analyses-card-meta{color:var(--text-tertiary);font-size:.8rem;display:flex;gap:.4rem;flex-wrap:wrap}.featured-analyses-remove{border:none;background:#dc26261a;color:var(--downtrend);padding:.5rem .9rem;border-radius:999px;font-weight:600;cursor:pointer;transition:all .2s ease}.featured-analyses-remove:hover:not(:disabled){background:#dc262633}.featured-analyses-remove:disabled{opacity:.6;cursor:not-allowed}.featured-analyses-empty{margin-top:1rem;padding:1.25rem;border-radius:.75rem;background:var(--bg-secondary);color:var(--text-tertiary);text-align:center}.featured-analyses-form form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.featured-analyses-form label{display:flex;flex-direction:column;gap:.4rem;font-weight:500;color:var(--text-secondary);font-size:.9rem}.featured-analyses-form input,.featured-analyses-form select{border:1px solid var(--border-primary);border-radius:6px;padding:.6rem .75rem;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary)}.featured-analyses-form input:focus,.featured-analyses-form select:focus{outline:none;border-color:var(--primary-600)}.featured-analyses-search-wrapper{position:relative}.featured-analyses-search{margin-bottom:.5rem}.featured-analyses-search-results{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;margin-top:.25rem;z-index:1000;box-shadow:0 4px 6px #0000001a}.featured-analyses-search-group{border-bottom:1px solid var(--border-primary)}.featured-analyses-search-group:last-child{border-bottom:none}.featured-analyses-search-group-title{padding:.5rem .75rem;font-weight:600;font-size:.85rem;color:var(--text-primary);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.featured-analyses-search-item{width:100%;padding:.75rem;border:none;background:var(--bg-primary);text-align:left;cursor:pointer;transition:background-color .2s ease;display:flex;justify-content:space-between;align-items:center;gap:.5rem;border-radius:0}.featured-analyses-search-item:hover{background:var(--bg-tertiary)}.featured-analyses-search-item-name{color:var(--text-primary);font-weight:500;font-size:.9rem}.featured-analyses-search-item-meta{color:var(--text-tertiary);font-size:.85rem}.featured-analyses-selected-series{padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;margin-top:.5rem;display:flex;justify-content:space-between;align-items:center;color:var(--text-primary);font-size:.9rem}.featured-analyses-clear-selection{border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;font-size:1rem;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.featured-analyses-clear-selection:hover{background:var(--bg-tertiary);color:var(--text-primary)}.featured-analyses-form button{border:none;padding:.75rem 1.25rem;color:var(--white);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.featured-analyses-form button:hover:not(:disabled){background:var(--primary-700)}.featured-analyses-form button:disabled{opacity:.6;cursor:not-allowed}.featured-analyses-footnote{margin:0;font-size:.8rem;color:var(--text-tertiary)}@media (max-width: 1024px){.featured-analyses-content{grid-template-columns:1fr}}@media (max-width: 640px){.featured-analyses-heading{flex-direction:column}.featured-analyses-card{flex-direction:column;align-items:flex-start}}.dashboard-tables-manager{display:flex;flex-direction:column;gap:2rem}.dashboard-tables-heading{display:flex;justify-content:space-between;gap:1.5rem;align-items:flex-start}.dashboard-tables-heading h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.dashboard-tables-kicker{text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;color:var(--text-tertiary);margin-bottom:.25rem;font-weight:500}.dashboard-tables-subtitle{margin:.5rem 0 0;color:var(--text-tertiary);max-width:640px;font-size:.9rem}.dashboard-tables-summary{display:flex;align-items:baseline;gap:.35rem;font-weight:600;color:var(--text-tertiary)}.dashboard-tables-count{font-size:2rem;color:var(--text-primary);font-weight:600}.dashboard-tables-error{border-radius:.75rem;padding:.9rem 1.25rem;background:#dc26261a;color:var(--downtrend);border:1px solid rgba(220,38,38,.2)}.dashboard-tables-content{display:grid;grid-template-columns:minmax(0,2fr) minmax(320px,1fr);gap:1.75rem}.dashboard-tables-selected,.dashboard-tables-form{border:1px solid var(--border-primary);border-radius:8px;padding:1.25rem;background:var(--bg-primary)}.dashboard-tables-selected header h3,.dashboard-tables-form header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.dashboard-tables-selected header p,.dashboard-tables-form header p{margin:.25rem 0 0;color:var(--text-tertiary);font-size:.85rem}.dashboard-tables-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.dashboard-tables-card{border:1px solid var(--border-primary);border-radius:6px;padding:.875rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--bg-secondary)}.dashboard-tables-card-content{display:flex;align-items:center;gap:.75rem;flex:1}.dashboard-tables-card-actions{display:flex;flex-direction:column;gap:.25rem}.dashboard-tables-sort-btn{border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-primary);padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.dashboard-tables-sort-btn:hover:not(:disabled){background:var(--bg-tertiary)}.dashboard-tables-sort-btn:disabled{opacity:.4;cursor:not-allowed}.dashboard-tables-card-main{flex:1}.dashboard-tables-card-title{font-weight:500;color:var(--text-primary);font-size:.95rem;display:flex;align-items:center;gap:.5rem}.dashboard-tables-edit-btn{border:none;background:transparent;cursor:pointer;font-size:.85rem;opacity:.6;transition:opacity .2s ease;padding:0}.dashboard-tables-edit-btn:hover{opacity:1}.dashboard-tables-edit-title{display:flex;flex-direction:column;gap:.5rem}.dashboard-tables-edit-actions{display:flex;gap:.5rem}.dashboard-tables-card-meta{color:var(--text-tertiary);font-size:.8rem;display:flex;gap:.4rem;flex-wrap:wrap}.dashboard-tables-remove{border:none;background:#dc26261a;color:var(--downtrend);padding:.5rem .9rem;border-radius:999px;font-weight:600;cursor:pointer;transition:all .2s ease}.dashboard-tables-remove:hover:not(:disabled){background:#dc262633}.dashboard-tables-remove:disabled{opacity:.6;cursor:not-allowed}.dashboard-tables-empty{margin-top:1rem;padding:1.25rem;border-radius:.75rem;background:var(--bg-secondary);color:var(--text-tertiary);text-align:center}.dashboard-tables-form form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.dashboard-tables-form label{display:flex;flex-direction:column;gap:.4rem;font-weight:500;color:var(--text-secondary);font-size:.9rem}.dashboard-tables-form input,.dashboard-tables-form select{border:1px solid var(--border-primary);border-radius:6px;padding:.6rem .75rem;font-size:.9rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s ease}.dashboard-tables-form input:focus,.dashboard-tables-form select:focus{outline:none;border-color:var(--primary-600)}.dashboard-tables-search-wrapper{position:relative}.dashboard-tables-search{margin-bottom:.5rem}.dashboard-tables-search-results{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;margin-top:.25rem;z-index:1000;box-shadow:0 4px 6px #0000001a}.dashboard-tables-search-group{border-bottom:1px solid var(--border-primary)}.dashboard-tables-search-group:last-child{border-bottom:none}.dashboard-tables-search-group-title{padding:.5rem .75rem;font-weight:600;font-size:.85rem;color:var(--text-primary);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.dashboard-tables-search-item{width:100%;padding:.75rem;border:none;background:var(--bg-primary);text-align:left;cursor:pointer;transition:background-color .2s ease;display:flex;justify-content:space-between;align-items:center;gap:.5rem;border-radius:0}.dashboard-tables-search-item:hover{background:var(--bg-tertiary)}.dashboard-tables-search-item-name{color:var(--text-primary);font-weight:500;font-size:.9rem}.dashboard-tables-search-item-meta{color:var(--text-tertiary);font-size:.85rem}.dashboard-tables-selected-series{padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;margin-top:.5rem;display:flex;justify-content:space-between;align-items:center;color:var(--text-primary);font-size:.9rem}.dashboard-tables-clear-selection{border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;font-size:1rem;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.dashboard-tables-clear-selection:hover{background:var(--bg-tertiary);color:var(--text-primary)}.dashboard-tables-form button{border:none;padding:.85rem 1.25rem;color:var(--white);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.dashboard-tables-form button:hover:not(:disabled){background:var(--primary-700)}.dashboard-tables-form button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 1024px){.dashboard-tables-content{grid-template-columns:1fr}}@media (max-width: 640px){.dashboard-tables-heading{flex-direction:column}.dashboard-tables-card{flex-direction:column;align-items:flex-start}}.media-library-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.media-library-modal{background:#fff;border-radius:8px;width:90%;max-width:1000px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.media-library-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb}.media-library-header h2{margin:0;font-size:20px;font-weight:600}.close-button{background:none;border:none;font-size:28px;cursor:pointer;color:#6b7280;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-button:hover{background:#f3f4f6;color:#111827}.media-library-toolbar{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;gap:12px}.toolbar-left{display:flex;gap:12px;flex:1}.toolbar-left select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.search-input{flex:1;max-width:300px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.upload-button{padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.media-library-content{flex:1;overflow-y:auto;padding:20px}.loading,.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.media-item{position:relative;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;background:#f9fafb}.media-item img{width:100%;height:150px;object-fit:cover;display:block}.media-placeholder{width:100%;height:150px;display:flex;align-items:center;justify-content:center;color:#9ca3af;background:#f3f4f6}.media-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000;transition:background .2s;display:flex;align-items:flex-start;justify-content:flex-end;padding:8px}.media-item:hover .media-overlay{background:#0000004d}.delete-button{background:#ef4444e6;color:#fff;border:none;border-radius:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;opacity:0;transition:opacity .2s}.media-item:hover .delete-button{opacity:1}.delete-button:hover{background:#dc2626}.media-name{padding:8px;font-size:12px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#fff}.media-library-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid #e5e7eb;gap:12px}.media-library-pagination button{padding:8px 16px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer;font-size:14px}.media-library-pagination button:hover:not(:disabled){background:#f3f4f6}.media-library-pagination button:disabled{opacity:.5;cursor:not-allowed}.media-library-pagination span{color:#6b7280;font-size:14px}.rich-text-editor{border:1px solid var(--border-primary, #e5e7eb);border-radius:8px;background:var(--bg-primary, #ffffff);overflow:hidden}.rich-text-toolbar{display:flex;align-items:center;gap:4px;padding:8px;border-bottom:1px solid var(--border-primary, #e5e7eb);background:var(--bg-secondary, #f9fafb);flex-wrap:wrap}.toolbar-group{display:flex;align-items:center;gap:2px;padding-right:8px;border-right:1px solid var(--border-primary, #e5e7eb)}.toolbar-group:last-child{border-right:none;padding-right:0}.rich-text-toolbar button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary, #64748b);cursor:pointer;border-radius:4px;transition:all .15s ease;font-size:.875rem;font-weight:600}.rich-text-toolbar button:hover:not(:disabled){background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a)}.rich-text-toolbar button.is-active{background:var(--primary-100, #dbeafe);color:var(--primary-700, #1e40af)}.rich-text-toolbar button:disabled{opacity:.4;cursor:not-allowed}.rich-text-content{min-height:300px;max-height:600px;overflow-y:auto;padding:16px;font-size:.9375rem;line-height:1.6;color:var(--text-primary, #0f172a)}.rich-text-content .ProseMirror{outline:none}.rich-text-content .ProseMirror p{margin:0 0 1em}.rich-text-content .ProseMirror p:last-child{margin-bottom:0}.rich-text-content .ProseMirror h1{font-size:2rem;font-weight:700;margin:1.5em 0 .5em;line-height:1.2;color:var(--text-primary, #0f172a)}.rich-text-content .ProseMirror h1:first-child{margin-top:0}.rich-text-content .ProseMirror h2{font-size:1.5rem;font-weight:600;margin:1.25em 0 .5em;line-height:1.3;color:var(--text-primary, #0f172a)}.rich-text-content .ProseMirror h2:first-child{margin-top:0}.rich-text-content .ProseMirror h3{font-size:1.25rem;font-weight:600;margin:1em 0 .5em;line-height:1.4;color:var(--text-primary, #0f172a)}.rich-text-content .ProseMirror h3:first-child{margin-top:0}.rich-text-content .ProseMirror ul,.rich-text-content .ProseMirror ol{margin:.5em 0;padding-left:1.5em}.rich-text-content .ProseMirror ul{list-style-type:disc}.rich-text-content .ProseMirror ol{list-style-type:decimal}.rich-text-content .ProseMirror li{margin:.25em 0}.rich-text-content .ProseMirror blockquote{border-left:4px solid var(--primary-500, #3b82f6);padding-left:1em;margin:1em 0;font-style:italic;color:var(--text-secondary, #64748b)}.rich-text-content .ProseMirror img{max-width:100%;height:auto;border-radius:8px;margin:1em 0;display:block}.rich-text-content .ProseMirror a.rich-text-link{color:var(--primary-600, #2563eb);text-decoration:underline;cursor:pointer}.rich-text-content .ProseMirror a.rich-text-link:hover{color:var(--primary-700, #1e40af)}.rich-text-content .ProseMirror strong{font-weight:700}.rich-text-content .ProseMirror em{font-style:italic}.rich-text-content .ProseMirror u{text-decoration:underline}.rich-text-content .ProseMirror s{text-decoration:line-through}.rich-text-content .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-tertiary, #94a3b8);pointer-events:none;height:0}@media (max-width: 768px){.rich-text-toolbar{padding:6px}.rich-text-toolbar button{width:28px;height:28px;font-size:.75rem}.rich-text-content{min-height:250px;max-height:400px;padding:12px}}.news-page{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:24px}.news-form{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:16px}.news-form-header{display:flex;align-items:center;justify-content:space-between}.news-form-header h3{margin:0;color:var(--text-primary)}.news-form-header p{margin:4px 0 0;color:var(--text-secondary);font-size:.9rem}.news-field{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--text-primary)}.news-field label{color:var(--text-secondary);font-weight:500}.news-field input,.news-field textarea{border:1px solid var(--border-primary);border-radius:10px;padding:10px 12px;font-size:.95rem;font-family:inherit;transition:border-color .2s ease;background:var(--bg-primary);color:var(--text-primary)}.news-field input:focus,.news-field textarea:focus{outline:none;border-color:var(--primary-600)}.news-field input::placeholder,.news-field textarea::placeholder{color:var(--text-tertiary)}.news-checkbox{display:flex;align-items:center;gap:8px;color:var(--text-primary)}.news-form-actions{display:flex;justify-content:flex-end}.news-table{width:100%;border-collapse:collapse;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.news-table th,.news-table td{padding:12px 14px;border-bottom:1px solid var(--border-primary);text-align:left;vertical-align:top;font-size:.9rem}.news-table thead{background:var(--bg-secondary)}.news-table th{color:var(--text-secondary);font-weight:500;font-size:.85rem}.news-table tbody tr:last-child td{border-bottom:none}.news-title{font-weight:500;color:var(--text-primary);display:flex;flex-direction:column;gap:4px}.news-summary{font-weight:400;color:var(--text-tertiary);font-size:.8rem}.news-status{border:none;border-radius:999px;padding:6px 14px;cursor:pointer;font-weight:600;font-size:.85rem}.news-status.active{background:#16a34a26;color:var(--uptrend)}.news-status.inactive{background:#dc262626;color:var(--downtrend)}.news-actions{display:flex;gap:8px}.news-btn{border-radius:6px;padding:6px 12px;border:1px solid transparent;cursor:pointer;font-weight:500;font-size:.85rem;transition:all .15s ease}.news-btn:hover{opacity:.9}.news-btn.primary{background:var(--primary-600);color:var(--white);border-color:var(--primary-600)}.news-btn.primary:hover{background:var(--primary-700)}.news-btn.ghost{background:transparent;color:var(--primary-600);border:1px solid var(--primary-400)}.news-btn.outline{background:transparent;border:1px solid var(--neutral-300);color:var(--neutral-700)}.news-btn.danger{background:transparent;border:1px solid rgba(220,38,38,.4);color:var(--downtrend)}.news-empty{padding:20px;text-align:center;color:var(--text-tertiary);background:var(--bg-primary);border:1px dashed var(--border-primary);border-radius:8px;font-size:.9rem}@media (max-width: 1024px){.news-page{grid-template-columns:1fr}}.construction-costs-page-admin{display:flex;flex-direction:column;gap:2rem}.form-section{display:flex;flex-direction:column;gap:1rem}.form-section h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.error-message{padding:1rem;background:#fee2e2;color:#b91c1c;border-radius:.5rem;margin-bottom:1rem}.table-editor{border:1px solid var(--border-primary);border-radius:.5rem;overflow:hidden;background:#fff}.editable-table{width:100%;border-collapse:collapse}.editable-table thead{background:var(--neutral-100)}.editable-table th{padding:.75rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);border-bottom:2px solid var(--border-primary)}.editable-table td{padding:.5rem;border-bottom:1px solid var(--border-primary)}.editable-table input{width:100%;padding:.5rem;border:1px solid var(--border-primary);border-radius:.25rem;font-size:.875rem;font-family:inherit}.editable-table input:focus{outline:none;border-color:var(--primary-600);box-shadow:0 0 0 3px #2563eb1a}.editable-table tbody tr:hover{background:var(--neutral-50)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-primary)}.hierarchical-table{table-layout:auto}.hierarchical-table tbody tr{transition:background-color .15s ease,box-shadow .15s ease;position:relative}.hierarchical-table tbody tr.dragging{background:var(--primary-50);opacity:.3}.hierarchical-table tbody tr.is-active-drag{opacity:.3}.hierarchical-table tbody tr.drop-before{box-shadow:inset 0 3px 0 0 var(--primary-500)}.hierarchical-table tbody tr.drop-after{box-shadow:inset 0 -3px 0 0 var(--primary-500)}.hierarchical-table tbody tr.drop-inside{background:var(--primary-100)!important;box-shadow:inset 0 0 0 2px var(--primary-500)}.drag-handle-cell{width:40px;text-align:center;padding:0!important}.drag-handle{display:flex;align-items:center;justify-content:center;width:100%;height:36px;background:none;border:none;cursor:grab;color:var(--neutral-400);font-size:1rem;letter-spacing:-2px;transition:color .15s ease,background .15s ease;border-radius:.25rem}.drag-handle:hover{color:var(--neutral-600);background:var(--neutral-100)}.drag-handle:active{cursor:grabbing;color:var(--primary-600);background:var(--primary-50)}.depth-cell{width:80px;text-align:center}.depth-controls{display:flex;align-items:center;justify-content:center;gap:.25rem}.depth-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--neutral-100);border:1px solid var(--border-primary);border-radius:.25rem;cursor:pointer;color:var(--neutral-600);font-size:.75rem;font-weight:600;transition:all .15s ease}.depth-btn:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-600)}.depth-btn:disabled{opacity:.3;cursor:not-allowed}.depth-indicator{display:flex;align-items:center;justify-content:center;min-width:20px;height:20px;background:var(--neutral-200);border-radius:.25rem;font-size:.75rem;font-weight:600;color:var(--neutral-600)}.drag-overlay-table{width:100%;background:#fff;box-shadow:0 8px 24px #00000026;border-radius:.5rem;overflow:hidden;pointer-events:none}.drag-overlay-row{background:var(--primary-50)}.drag-overlay-row td{padding:.5rem;border-bottom:none}.hierarchy-hint{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.hierarchy-hint strong{color:var(--text-primary)}.hierarchy-hint em{font-style:normal;background:var(--primary-100);padding:.125rem .375rem;border-radius:.25rem;font-weight:500;color:var(--primary-700)}.hierarchical-table td:first-child input{transition:border-color .15s ease}@media (max-width: 768px){.depth-controls{flex-direction:column;gap:.125rem}.depth-btn{width:20px;height:20px;font-size:.625rem}.drag-handle{height:28px;font-size:.875rem}}.roles-page{display:flex;flex-direction:column;gap:1.5rem}.roles-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.roles-list{display:flex;flex-direction:column;gap:1rem}.role-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:1.5rem}.role-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.role-name{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary)}.role-description{margin:0;color:var(--text-secondary);font-size:.95rem}.role-actions{display:flex;gap:.5rem}.role-permissions{padding-top:1rem;border-top:1px solid var(--border-primary)}.role-permissions strong{display:block;margin-bottom:.5rem;color:var(--text-primary)}.role-permissions ul{margin:.5rem 0 0;padding-left:1.5rem;color:var(--text-secondary)}.role-permissions li{margin-bottom:.25rem}.permission-key-small{color:var(--secondary-300);font-size:.85rem}.no-permissions{color:var(--secondary-300);font-style:italic}.role-form-container{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:2rem}.role-form-container h2{margin:0 0 1.5rem;color:var(--text-primary)}.role-form{display:flex;flex-direction:column;gap:1.5rem}.form-group input[type=text],.form-group textarea{padding:10px;border:1px solid var(--border-primary);border-radius:6px;font-size:1rem;transition:border-color .2s ease;background:var(--bg-primary);color:var(--text-primary)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-600)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.form-group input:disabled{background-color:var(--bg-secondary);color:var(--text-tertiary);cursor:not-allowed}.permissions-table-container{border:1px solid var(--border-primary);border-radius:6px;overflow:hidden}.permissions-table{width:100%;border-collapse:collapse;background:var(--bg-primary)}.permissions-table thead{background-color:var(--bg-secondary)}.permissions-table th{padding:12px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-primary)}.permissions-table td{padding:12px;border-bottom:1px solid var(--border-primary);color:var(--text-primary)}.permissions-table tbody tr:hover{background-color:var(--bg-secondary)}.checkbox-column{width:60px;text-align:center}.checkbox-column input[type=checkbox]{width:18px;height:18px;cursor:pointer}.permission-key{font-family:monospace;font-size:.9rem;color:var(--text-secondary)}.permission-name{color:var(--text-primary)}.users-page{display:flex;flex-direction:column;gap:1.5rem;position:relative}.error-message{padding:12px 16px;background-color:#dc26261a;color:var(--downtrend);border-radius:8px;border:1px solid rgba(220,38,38,.2)}.users-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.btn-primary{padding:10px 20px;background-color:var(--primary-600);color:var(--white);border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:var(--primary-700)}.btn-primary:disabled{background-color:var(--secondary-300);cursor:not-allowed}.btn-secondary{padding:8px 16px;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:var(--bg-tertiary)}.btn-danger{padding:8px 16px;background-color:var(--downtrend);color:var(--white);border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-danger:hover{background-color:#b91c1c}.users-list{display:flex;flex-direction:column;gap:1rem}.user-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:1.5rem}.user-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.user-name{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary)}.user-meta{margin:0;color:var(--text-secondary);font-size:.9rem}.user-actions{display:flex;gap:.5rem;flex-wrap:wrap}.user-roles{padding-top:1rem;border-top:1px solid var(--border-primary)}.user-roles strong{display:block;margin-bottom:.5rem;color:var(--text-primary)}.user-roles ul{margin:.5rem 0 0;padding-left:1.5rem;color:var(--text-secondary)}.user-roles li{margin-bottom:.25rem}.role-description-small{color:var(--secondary-300);font-size:.85rem}.no-roles{color:var(--secondary-300);font-style:italic}.user-form-container{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:2rem}.user-form-container h2{margin:0 0 1.5rem;color:var(--text-primary)}.user-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-secondary)}.form-group input[type=text],.form-group input[type=password]{padding:10px;border:1px solid var(--border-primary);border-radius:6px;font-size:1rem;transition:border-color .2s ease;background:var(--bg-primary);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--primary-600)}.form-group input::placeholder{color:var(--text-tertiary)}.roles-checkbox-list{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;max-height:300px;overflow-y:auto}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s;color:var(--text-primary)}.checkbox-label strong{color:var(--text-primary)}.checkbox-label:hover{background-color:var(--bg-tertiary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.role-desc{color:var(--text-secondary);font-size:.9rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-primary)}.password-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.password-form-container{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;padding:2rem;min-width:400px;max-width:90%}.password-form-container h3{margin:0 0 1.5rem;color:var(--text-primary)}.password-form-container form{display:flex;flex-direction:column;gap:1.5rem}.contact-email-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.contact-email-modal{background:var(--bg-primary);border-radius:.5rem;width:90%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 25px #0003}.contact-email-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-primary)}.contact-email-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.contact-email-modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .2s ease}.contact-email-modal-close:hover{background:var(--bg-secondary)}.contact-email-modal-content{padding:1.5rem;flex:1;overflow-y:auto}.contact-email-modal-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:1.5rem}.contact-email-modal-error{padding:.75rem;background:#fee2e2;color:#b91c1c;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem}.contact-email-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.contact-email-item{display:flex;gap:.5rem;align-items:center}.contact-email-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:.375rem;font-size:.875rem;color:var(--text-primary);background:var(--bg-primary)}.contact-email-input:focus{outline:none;border-color:var(--primary-600)}.contact-email-remove{padding:.5rem 1rem;background:var(--downtrend);color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.contact-email-remove:hover{background:#b91c1c}.contact-email-add{padding:.5rem 1rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.contact-email-add:hover{background:var(--primary-100);border-color:var(--primary-400)}.contact-email-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border-primary)}.contact-messages-page{padding-top:24px;max-width:1400px;margin:0 auto}.contact-messages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.contact-messages-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.contact-messages-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-primary)}.contact-messages-tab{padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:-2px}.contact-messages-tab:hover{color:var(--text-primary)}.contact-messages-tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600)}.contact-messages-refresh,.contact-messages-email-settings{padding:.5rem 1rem;background:var(--primary-600);color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.contact-messages-refresh:hover,.contact-messages-email-settings:hover{background:var(--primary-700)}.contact-messages-error{color:var(--downtrend);text-align:center;padding:2rem}.contact-messages-layout{display:grid;grid-template-columns:400px 1fr;gap:2rem;height:calc(100vh - 200px)}.contact-messages-list{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:.5rem;overflow-y:auto;padding:1rem}.contact-messages-empty{text-align:center;color:var(--text-secondary);padding:2rem}.contact-message-item{padding:1rem;border:1px solid var(--border-primary);border-radius:.375rem;margin-bottom:.75rem;cursor:pointer;transition:all .2s ease;background:var(--bg-primary)}.contact-message-item:hover{border-color:var(--primary-400);background:var(--bg-secondary)}.contact-message-item.unread{background:var(--primary-100);border-color:var(--primary-400)}:root[data-theme=dark] .contact-message-item.unread{background:var(--bg-tertiary);border-color:var(--primary-400)}.contact-message-item.selected{border-color:var(--primary-600);background:var(--primary-100)}:root[data-theme=dark] .contact-message-item.selected{background:var(--bg-tertiary);border-color:var(--primary-600)}.contact-message-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.contact-message-item-subject{font-weight:600;color:var(--text-primary);font-size:.9375rem;flex:1}.contact-message-unread-badge{background:var(--primary-600);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem;font-weight:500}.contact-message-replied-badge{background:var(--uptrend);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem;font-weight:500}.contact-message-item-name{font-weight:500;color:var(--text-primary);font-size:.875rem;margin-bottom:.25rem}.contact-message-item-email{color:var(--text-secondary);font-size:.8125rem;margin-bottom:.5rem}.contact-message-item-phone{color:var(--text-secondary);font-size:.8125rem;margin-bottom:.25rem}.contact-message-item-area{color:var(--text-secondary);font-size:.8125rem;margin-bottom:.5rem;font-weight:500}.contact-message-item-date{color:var(--text-tertiary);font-size:.75rem}.contact-message-detail{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:.5rem;padding:2rem;overflow-y:auto}.contact-message-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-primary)}.contact-message-detail-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0;flex:1}.contact-message-mark-replied,.contact-message-send-email,.contact-message-delete{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.contact-message-mark-replied{background:var(--uptrend);color:#fff}.contact-message-mark-replied:hover{background:#15803d}.contact-message-send-email{background:var(--primary-600);color:#fff}.contact-message-send-email:hover:not(:disabled){background:var(--primary-700)}.contact-message-send-email:disabled{opacity:.6;cursor:not-allowed}.contact-message-delete{background:var(--downtrend);color:#fff}.contact-message-delete:hover{background:#b91c1c}.contact-message-detail-info{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-primary)}.contact-message-detail-info div{margin-bottom:.75rem;color:var(--text-primary);font-size:.9375rem}.contact-message-detail-info strong{color:var(--text-primary);font-weight:600;margin-right:.5rem}.contact-message-detail-content h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.contact-message-detail-content p{color:var(--text-primary);line-height:1.7;white-space:pre-wrap;font-size:.9375rem}@media (max-width: 1024px){.contact-messages-layout{grid-template-columns:1fr;height:auto}.contact-messages-list{max-height:400px}}.web-users-page{padding:1rem}.web-users-error{background-color:var(--error-bg, #fee);color:var(--error-text, #c33);padding:1rem;border-radius:.5rem;margin-bottom:1rem}.web-users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.web-users-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.web-users-stat{background:var(--bg-secondary, #f5f5f5);padding:1rem 1.5rem;border-radius:.5rem;text-align:center;min-width:120px}.web-users-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #333);margin-bottom:.25rem}.web-users-stat-label{font-size:.875rem;color:var(--text-secondary, #666)}.web-users-refresh{padding:.5rem 1rem;background:var(--primary, #007bff);color:#fff;border:none;border-radius:.25rem;cursor:pointer;font-size:.875rem;transition:background .2s}.web-users-refresh:hover{background:var(--primary-hover, #0056b3)}.web-users-empty{text-align:center;padding:3rem;color:var(--text-secondary, #666);font-size:1.1rem}.web-users-table-container{overflow-x:auto;border:1px solid var(--border-primary, #ddd);border-radius:.5rem}.web-users-table{width:100%;border-collapse:collapse;background:var(--bg-primary, #fff)}.web-users-table thead{background:var(--bg-secondary, #f5f5f5)}.web-users-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary, #333);border-bottom:2px solid var(--border-primary, #ddd);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.web-users-table td{padding:1rem;border-bottom:1px solid var(--border-primary, #eee)}.web-users-table tbody tr:hover{background:var(--bg-secondary, #f9f9f9)}.web-users-table tbody tr:last-child td{border-bottom:none}.web-users-name{font-weight:500;color:var(--text-primary, #333)}.web-users-email{color:var(--text-primary, #333);font-family:monospace;font-size:.9rem}.web-users-date{color:var(--text-secondary, #666);font-size:.875rem}.web-users-status{display:flex;gap:.5rem;flex-wrap:wrap}.web-users-badge{display:inline-block;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.web-users-badge-verified{background:var(--success-bg, #d4edda);color:var(--success-text, #155724)}.web-users-badge-unverified{background:var(--warning-bg, #fff3cd);color:var(--warning-text, #856404)}.web-users-badge-inactive{background:var(--error-bg, #f8d7da);color:var(--error-text, #721c24)}.web-users-actions{display:flex;gap:.5rem;flex-wrap:wrap}.web-users-action-btn{padding:.375rem .75rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .2s;white-space:nowrap}.web-users-action-btn-verified{background:var(--success-bg, #d4edda);color:var(--success-text, #155724)}.web-users-action-btn-verified:hover{background:var(--success-hover, #c3e6cb)}.web-users-action-btn-unverified{background:var(--warning-bg, #fff3cd);color:var(--warning-text, #856404)}.web-users-action-btn-unverified:hover{background:var(--warning-hover, #ffeaa7)}.web-users-action-btn-active{background:var(--primary, #007bff);color:#fff}.web-users-action-btn-active:hover{background:var(--primary-hover, #0056b3)}.web-users-action-btn-inactive{background:var(--bg-secondary, #6c757d);color:var(--text-primary, #000)}.web-users-action-btn-inactive:hover{background:var(--bg-secondary-hover, #5a6268);color:var(--text-primary, #000)}@media (max-width: 768px){.web-users-header{flex-direction:column;align-items:stretch}.web-users-stats{justify-content:space-around}.web-users-table-container{overflow-x:scroll}.web-users-table{min-width:600px}}.media-library-page{padding:20px}.media-library-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}.toolbar-left{display:flex;gap:12px;flex:1;min-width:300px}.toolbar-left select{padding:10px 14px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff}.search-input{flex:1;max-width:400px;padding:10px 14px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.toolbar-right{display:flex;gap:12px}.upload-button{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.upload-button:hover{background:#2563eb}.upload-button:disabled{background:#9ca3af;cursor:not-allowed}.loading,.empty-state{text-align:center;padding:80px 20px;color:#6b7280}.empty-state p{margin-bottom:20px;font-size:16px}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-bottom:24px}.media-item{position:relative;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff;transition:transform .2s,box-shadow .2s}.media-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.media-item img{width:100%;height:200px;object-fit:cover;display:block}.media-placeholder{width:100%;height:200px;display:flex;align-items:center;justify-content:center;color:#9ca3af;background:#f3f4f6}.media-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000;transition:background .2s;display:flex;align-items:flex-start;justify-content:flex-end;padding:12px;gap:8px}.media-item:hover .media-overlay{background:#0006}.action-button{background:#ffffffe6;border:none;border-radius:6px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;opacity:0;transition:opacity .2s,background .2s}.media-item:hover .action-button{opacity:1}.action-button:hover{background:#fff}.delete-button{color:#ef4444}.copy-button{font-size:16px}.media-info{padding:12px;background:#fff}.media-name{font-size:13px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.media-meta{font-size:11px;color:#6b7280}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.pagination button{padding:10px 20px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s}.pagination button:hover:not(:disabled){background:#f3f4f6}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{color:#6b7280;font-size:14px}.layout-root{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary)}.layout-topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;background:var(--bg-primary);color:var(--text-primary);padding:16px 32px;border-bottom:1px solid var(--border-primary)}.layout-brand{font-size:1.2rem;font-weight:700;letter-spacing:.08em}.layout-home-link{display:flex;align-items:center;gap:8px;color:var(--text-secondary);text-decoration:none;padding:6px 12px;border-radius:6px;font-size:.9rem;font-weight:500}.layout-home-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.layout-home-link svg{width:18px;height:18px}.layout-nav{display:flex;gap:8px;align-items:center}.layout-nav-group{position:relative}.layout-link{padding:8px 14px;border-radius:6px;text-decoration:none;color:var(--text-secondary);font-weight:500;font-size:.9rem;display:inline-flex;align-items:center;gap:4px}.layout-link-trigger{background:transparent;border:none;cursor:pointer;font-family:inherit}.layout-link-trigger .layout-dropdown-arrow{font-size:.65rem;transition:transform .15s}.layout-link-trigger .layout-dropdown-arrow.open{transform:rotate(180deg)}.layout-link.active{background:var(--primary-100);color:var(--primary-700)}.layout-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.layout-dropdown{position:absolute;top:100%;left:0;margin-top:4px;min-width:180px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:6px;z-index:100}.layout-dropdown-item{display:block;padding:8px 12px;border-radius:6px;color:var(--text-secondary);text-decoration:none;font-size:.9rem}.layout-dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.layout-dropdown-item.active{background:var(--primary-100);color:var(--primary-700)}.layout-user{display:flex;align-items:center;gap:16px}.layout-theme-toggle{background:transparent;border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);cursor:pointer;padding:6px 10px;display:flex;align-items:center;justify-content:center}.layout-theme-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-secondary)}.layout-user-name{font-weight:500;color:var(--text-secondary);font-size:.9rem}.layout-logout{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;margin-top:4px;font-size:.85rem}.layout-logout:hover{color:var(--downtrend)}.layout-logout:hover{opacity:.8}.layout-content{flex:1;min-height:0}@media (max-width: 900px){.layout-topbar{flex-direction:column;align-items:stretch}.layout-nav{flex-wrap:wrap}}:root{--primary-900: #0F3254;--primary-700: #1E7AD6;--primary-600: #36ADFF;--primary-400: #74C3FF;--primary-100: #E0F3FF;--secondary-600: #6F8489;--secondary-300: #A6BDC2;--secondary-100: #E4EBED;--uptrend: #16A34A;--downtrend: #DC2626;--alert: #F59E0B}:root[data-theme=light]{--bg-primary: #FFFFFF;--bg-secondary: #F9FAFB;--bg-tertiary: #F3F4F6;--text-primary: #1A1A1A;--text-secondary: #4B5563;--text-tertiary: #9CA3AF;--border-primary: #E5E7EB;--border-secondary: #D1D5DB;--neutral-900: #1A1A1A;--neutral-700: #4B5563;--neutral-500: #9CA3AF;--neutral-300: #E5E7EB;--neutral-100: #F9FAFB;--neutral-50: #FFFFFF;--white: #FFFFFF;--black: #000000}:root[data-theme=dark]{--bg-primary: #1E293B;--bg-secondary: #0F172A;--bg-tertiary: #334155;--text-primary: #F1F5F9;--text-secondary: #CBD5E1;--text-tertiary: #94A3B8;--border-primary: #475569;--border-secondary: #64748B;--neutral-900: #F1F5F9;--neutral-700: #CBD5E1;--neutral-500: #94A3B8;--neutral-300: #64748B;--neutral-100: #475569;--neutral-50: #334155;--white: #1E293B;--black: #F1F5F9}*,*:before,*:after{box-sizing:border-box;transition:background-color .2s ease,color .2s ease,border-color .2s ease}html,body,#root{height:100%;margin:0}body{font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5}button,input,textarea{font:inherit}select{font:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-primary)}select option{background:var(--bg-primary);color:var(--text-primary)}input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-600)}
