@import"https://fonts.googleapis.com/css2?family=Public+Sans:wght@300;400;500;600;700&display=swap";:root{--color-primary: #13ec5b;--color-primary-dark: #0ea641;--color-primary-light: rgba(19, 236, 91, .1);--color-primary-hover: rgba(19, 236, 91, .15);--color-bg: #f6f8f6;--color-surface: #ffffff;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-text-primary: #0f172a;--color-text-secondary: #64748b;--color-text-tertiary: #94a3b8;--color-text-inverse: #ffffff;--color-red-bg: rgba(239, 68, 68, .08);--color-red-border: rgba(239, 68, 68, .15);--color-red-text: #dc2626;--color-red-badge: #fecaca;--color-orange-bg: rgba(249, 115, 22, .08);--color-orange-border: rgba(249, 115, 22, .15);--color-orange-text: #ea580c;--color-green-bg: rgba(19, 236, 91, .1);--color-green-text: #15803d;--color-green-badge: #dcfce7;--color-blue-bg: rgba(59, 130, 246, .08);--color-blue-text: #2563eb;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .07), 0 4px 6px -4px rgba(0, 0, 0, .05);--shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 260px;--header-height: 64px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:Public Sans,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--color-bg);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}#app{width:100%;height:100vh}.app-layout{display:flex;height:100vh;width:100%;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;justify-content:space-between;height:100%}.sidebar-brand{display:flex;gap:12px;align-items:center;padding:16px 20px}.sidebar-brand-logo{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-brand-logo svg{width:24px;height:24px}.sidebar-brand-title{font-size:1rem;font-weight:700;color:var(--color-text-primary);line-height:1.2}.sidebar-brand-subtitle{font-size:.75rem;color:var(--color-text-secondary);line-height:1.2}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 12px;margin-top:8px}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition-base);cursor:pointer}.sidebar-nav-item:hover{background:var(--color-bg);color:var(--color-text-primary)}.sidebar-nav-item.active{background:var(--color-primary-light);color:var(--color-primary-dark);font-weight:600}.sidebar-nav-item .material-symbols-outlined{font-size:22px}.sidebar-footer{padding:12px;border-top:1px solid var(--color-border-light)}.sidebar-logout{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;transition:all var(--transition-base);width:100%}.sidebar-logout:hover{background:var(--color-bg);color:var(--color-red-text)}.sidebar-logout-icon{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-bg);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0}.header-left{display:flex;align-items:center;gap:16px}.header-title{font-size:1.125rem;font-weight:700}.header-badge{background:var(--color-green-bg);color:var(--color-green-text);font-size:.75rem;font-weight:700;padding:2px 10px;border-radius:var(--radius-full);border:1px solid rgba(19,236,91,.2)}.header-right{display:flex;align-items:center;gap:16px}.header-search{position:relative}.header-search input{width:260px;padding:8px 12px 8px 40px;border:none;border-radius:var(--radius-lg);background:var(--color-bg);color:var(--color-text-primary);font-size:.875rem;outline:none;transition:box-shadow var(--transition-base)}.header-search input::placeholder{color:var(--color-text-tertiary)}.header-search input:focus{box-shadow:0 0 0 2px #13ec5b4d}.header-search .material-symbols-outlined{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--color-text-tertiary)}.header-actions{display:flex;align-items:center;gap:8px}.header-icon-btn{position:relative;padding:8px;color:var(--color-text-secondary);border-radius:var(--radius-lg);transition:background var(--transition-base)}.header-icon-btn:hover{background:var(--color-bg)}.header-icon-btn .badge-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-red-text);border:2px solid var(--color-surface)}.header-divider{width:1px;height:32px;background:var(--color-border);margin:0 4px}.header-user{display:flex;align-items:center;gap:12px;padding:6px;border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-base)}.header-user:hover{background:var(--color-bg)}.header-user-info{text-align:right}.header-user-name{font-size:.875rem;font-weight:600;line-height:1.2}.header-user-role{font-size:.75rem;color:var(--color-text-secondary);line-height:1.2}.header-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;border:2px solid var(--color-surface);box-shadow:var(--shadow-sm)}.page-content{flex:1;overflow-y:auto;padding:24px;background:var(--color-bg)}.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:16px;border:1px solid var(--color-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:4px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.kpi-card:hover{border-color:#13ec5b66;box-shadow:var(--shadow-md)}.kpi-card-header{display:flex;justify-content:space-between;align-items:flex-start}.kpi-card-label{font-size:.6875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.kpi-badge{font-size:.625rem;font-weight:700;padding:2px 6px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:2px}.kpi-badge .material-symbols-outlined{font-size:12px}.kpi-badge.up{background:var(--color-green-badge);color:var(--color-green-text)}.kpi-badge.down{background:var(--color-red-badge);color:var(--color-red-text)}.kpi-badge.neutral{background:var(--color-bg);color:var(--color-text-secondary)}.kpi-badge.alert{background:#fed7aa;color:#ea580c}.kpi-card-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin-top:4px}.kpi-card-desc{font-size:.75rem;color:var(--color-text-tertiary)}.dashboard-grid{display:grid;grid-template-columns:3fr 1fr;gap:24px;min-height:500px}.dashboard-left{display:flex;flex-direction:column;gap:24px}.card{background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-card);overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:20px}.card-title{font-size:1.125rem;font-weight:700}.card-body{padding:0 20px 20px}.map-container{flex:1;min-height:350px;position:relative}.map-placeholder{width:100%;height:100%;min-height:350px;background:var(--color-bg);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border:1px solid var(--color-border-light)}.map-placeholder img{width:100%;height:100%;object-fit:cover}.map-density-box{position:absolute;top:16px;left:16px;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:12px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);z-index:2}.map-density-title{font-size:.75rem;font-weight:700;margin-bottom:6px;color:var(--color-text-primary)}.map-density-row{display:flex;justify-content:space-between;gap:24px;font-size:.75rem;color:var(--color-text-secondary);padding:2px 0}.map-density-row span:last-child{font-weight:700}.map-controls{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:column;gap:4px;z-index:2}.map-controls button{background:var(--color-surface);padding:8px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:color var(--transition-base)}.map-controls button:hover{color:var(--color-primary-dark)}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.chart-card{min-height:220px;display:flex;flex-direction:column}.chart-content{flex:1;display:flex;align-items:center;justify-content:center;padding:16px 20px 20px}.donut-chart-wrapper{display:flex;align-items:center;gap:32px;width:100%}.donut-chart{position:relative;width:120px;height:120px;flex-shrink:0}.donut-chart canvas{width:100%!important;height:100%!important}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.donut-center-value{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);line-height:1}.donut-center-label{font-size:.625rem;color:var(--color-text-secondary);text-transform:uppercase;margin-top:2px}.chart-legend{display:flex;flex-direction:column;gap:8px}.chart-legend-item{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--color-text-secondary)}.chart-legend-dot{width:12px;height:12px;border-radius:var(--radius-full);flex-shrink:0}.bar-chart-wrapper{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;width:100%;height:100%;padding:0 8px}.bar-item{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.bar-visual{width:100%;border-radius:4px 4px 0 0;transition:background var(--transition-base);position:relative}.bar-item:hover .bar-visual{filter:brightness(.9)}.bar-item:hover .bar-tooltip{opacity:1}.bar-tooltip{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:.75rem;font-weight:700;color:var(--color-text-primary);opacity:0;transition:opacity var(--transition-base)}.bar-label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary)}.alerts-panel{display:flex;flex-direction:column;height:100%}.alerts-header{padding:20px;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;align-items:center;background:#f8fafc80}.alerts-header-title{font-size:1rem;font-weight:700}.alerts-count-badge{background:var(--color-red-badge);color:var(--color-red-text);font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}.alerts-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}.alert-item{padding:12px;border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-base)}.alert-item.critical{border:1px solid var(--color-red-border);background:var(--color-red-bg)}.alert-item.critical:hover{background:#ef44441f}.alert-item.warning{border:1px solid var(--color-orange-border);background:var(--color-orange-bg)}.alert-item.warning:hover{background:#f973161f}.alert-item.info{border:1px solid var(--color-border-light);background:var(--color-bg)}.alert-item.info:hover{background:var(--color-border-light)}.alert-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}.alert-type-badge{font-size:.625rem;font-weight:700;padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em}.alert-type-badge.critical{background:var(--color-red-badge);color:var(--color-red-text)}.alert-type-badge.warning{background:#fed7aa;color:var(--color-orange-text)}.alert-type-badge.info{background:var(--color-border);color:var(--color-text-secondary)}.alert-time{font-size:.625rem;color:var(--color-text-tertiary)}.alert-title{font-size:.875rem;font-weight:700;color:var(--color-text-primary);line-height:1.3;margin-bottom:4px}.alert-desc{font-size:.75rem;color:var(--color-text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.alerts-footer{padding:12px;border-top:1px solid var(--color-border-light);background:#f8fafc80}.alerts-footer button{width:100%;padding:8px;font-size:.75rem;font-weight:700;color:var(--color-primary-dark);display:flex;align-items:center;justify-content:center;gap:4px;transition:color var(--transition-base)}.alerts-footer button:hover{color:var(--color-primary)}.login-page{width:100%;height:100vh;display:flex;flex-direction:column;background:#e8ecec;background-image:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%),url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23cbd5e1' fill-opacity='0.12'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.login-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.login-topbar-brand{display:flex;align-items:center;gap:8px}.login-topbar-logo{width:32px;height:32px}.login-topbar-title{font-size:.875rem;font-weight:700}.login-topbar-title span{font-weight:400;color:var(--color-text-secondary)}.login-topbar-help{display:flex;align-items:center;gap:4px;font-size:.875rem;color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-base)}.login-topbar-help:hover{color:var(--color-text-primary)}.login-container{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px}.login-card{width:100%;max-width:420px;background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.login-hero{height:140px;background:linear-gradient(135deg,#0f172ab3,#0f172a66),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 200'%3E%3Cdefs%3E%3ClinearGradient id='g' x1='0%25' y1='0%25' x2='100%25' y2='100%25'%3E%3Cstop offset='0%25' style='stop-color:%230f766e'/%3E%3Cstop offset='100%25' style='stop-color:%23134e4a'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect fill='url(%23g)' width='400' height='200'/%3E%3Cg stroke='rgba(255,255,255,0.1)' stroke-width='1'%3E%3Cline x1='50' y1='0' x2='50' y2='200'/%3E%3Cline x1='100' y1='0' x2='100' y2='200'/%3E%3Cline x1='150' y1='0' x2='150' y2='200'/%3E%3Cline x1='200' y1='0' x2='200' y2='200'/%3E%3Cline x1='250' y1='0' x2='250' y2='200'/%3E%3Cline x1='300' y1='0' x2='300' y2='200'/%3E%3Cline x1='350' y1='0' x2='350' y2='200'/%3E%3Cline x1='0' y1='50' x2='400' y2='50'/%3E%3Cline x1='0' y1='100' x2='400' y2='100'/%3E%3Cline x1='0' y1='150' x2='400' y2='150'/%3E%3C/g%3E%3C/svg%3E");background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:flex-end;padding:24px 32px}.login-hero-label{font-size:.875rem;color:#ffffffb3;margin-bottom:4px}.login-hero-title{font-size:1.5rem;font-weight:700;color:#fff}.login-form{padding:24px 32px 28px}.login-form-desc{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:24px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin-bottom:6px}.form-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.form-forgot{font-size:.8125rem;color:var(--color-primary-dark);font-weight:600;cursor:pointer;transition:color var(--transition-base)}.form-forgot:hover{color:var(--color-primary)}.form-input-wrapper{position:relative}.form-input-wrapper .material-symbols-outlined{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--color-text-tertiary)}.form-input-wrapper .input-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);padding:4px;cursor:pointer}.form-input{width:100%;padding:10px 12px 10px 44px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:.875rem;color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #13ec5b26}.form-input::placeholder{color:var(--color-text-tertiary)}.form-checkbox-row{display:flex;align-items:center;gap:8px;margin-bottom:24px}.form-checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary)}.form-checkbox-row label{font-size:.875rem;color:var(--color-text-secondary)}.btn-primary{width:100%;padding:12px;background:var(--color-primary);color:var(--color-text-primary);font-size:.9375rem;font-weight:700;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-base),transform var(--transition-fast)}.btn-primary:hover{background:var(--color-primary-dark);color:#fff}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.login-divider{border:none;border-top:1px solid var(--color-border);margin:20px 0 16px}.login-warning{font-size:.75rem;color:var(--color-text-tertiary);text-align:center}.login-error{background:var(--color-red-bg);color:var(--color-red-text);padding:10px 14px;border-radius:var(--radius-md);font-size:.8125rem;margin-bottom:16px;display:none;border:1px solid var(--color-red-border)}.login-error.show{display:block}.login-footer{padding:24px;text-align:center}.login-footer-links{display:flex;justify-content:center;gap:24px;margin-bottom:8px}.login-footer-links a{font-size:.8125rem;color:var(--color-text-secondary);transition:color var(--transition-base)}.login-footer-links a:hover{color:var(--color-text-primary)}.login-footer-copy{font-size:.75rem;color:var(--color-text-tertiary)}.login-green-bar{height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));border-radius:0 0 var(--radius-xl) var(--radius-xl)}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:12px 16px;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg);border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table td{padding:12px 16px;font-size:.875rem;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-light)}.data-table tr:hover td{background:var(--color-bg)}.data-table .status-badge{display:inline-flex;padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.status-badge.aktif{background:var(--color-green-badge);color:var(--color-green-text)}.status-badge.pasif{background:var(--color-red-badge);color:var(--color-red-text)}.status-badge.iyi{background:var(--color-green-badge);color:var(--color-green-text)}.status-badge.orta{background:#fef3c7;color:#d97706}.status-badge.kotu{background:var(--color-red-badge);color:var(--color-red-text)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{font-size:1.25rem;font-weight:700}.page-subtitle{font-size:.875rem;color:var(--color-text-secondary);margin-top:2px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-lg);font-size:.875rem;font-weight:600;transition:all var(--transition-base);white-space:nowrap}.btn-sm{padding:6px 12px;font-size:.8125rem}.btn-green{background:var(--color-primary);color:var(--color-text-primary)}.btn-green:hover{background:var(--color-primary-dark);color:#fff}.btn-outline{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary)}.btn-outline:hover{background:var(--color-bg);color:var(--color-text-primary)}.filters-bar{display:flex;gap:12px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.filter-select{padding:6px 32px 6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);font-size:.8125rem;color:var(--color-text-secondary);outline:none;cursor:pointer;-webkit-appearance:revert;-moz-appearance:revert;appearance:revert}.filter-select:focus{border-color:var(--color-primary)}.filter-search{padding:6px 12px 6px 36px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);font-size:.8125rem;outline:none;min-width:200px}.filter-search:focus{border-color:var(--color-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;visibility:hidden;transition:opacity var(--transition-slow),visibility var(--transition-slow)}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:90%;max-width:600px;max-height:90vh;overflow-y:auto;transform:translateY(20px);transition:transform var(--transition-slow)}.modal-overlay.active .modal{transform:translateY(0)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border-light)}.modal-title{font-size:1.125rem;font-weight:700}.modal-close{padding:4px;color:var(--color-text-tertiary);border-radius:var(--radius-md);transition:background var(--transition-base)}.modal-close:hover{background:var(--color-bg);color:var(--color-text-primary)}.modal-body{padding:20px 24px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--color-border-light)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid .full-width{grid-column:1 / -1}.modal-body .form-group{margin-bottom:0}.modal-body .form-input,.modal-body .filter-select{width:100%;padding:8px 12px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state .material-symbols-outlined{font-size:48px;color:var(--color-text-tertiary);margin-bottom:12px}.empty-state-title{font-size:1rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px}.empty-state-desc{font-size:.875rem;color:var(--color-text-tertiary)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:40px}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;top:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}.toast{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:12px 16px;box-shadow:var(--shadow-lg);font-size:.875rem;display:flex;align-items:center;gap:8px;min-width:280px;animation:slideInRight .3s ease}.toast.success{border-left:3px solid var(--color-primary)}.toast.error{border-left:3px solid var(--color-red-text)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px}.detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}.detail-info-row{padding:10px 0;border-bottom:1px solid var(--color-border-light)}.detail-info-label{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:2px;font-weight:500}.detail-info-value{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.detail-address-block{margin-top:16px;padding-top:12px;border-top:1px solid var(--color-border-light)}.detail-address-block strong{font-size:.8125rem;color:var(--color-text-secondary)}.detail-address-block p{font-size:.875rem;margin-top:4px;color:var(--color-text-primary);line-height:1.5}.detail-contract-item{padding:10px 0;border-bottom:1px solid var(--color-border-light)}.detail-contract-item:last-child{border-bottom:none}.detail-contract-type{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.detail-contract-dates{font-size:.75rem;color:var(--color-text-secondary);margin-top:2px}.detail-contract-rent{font-size:.875rem;font-weight:700;color:var(--color-primary-dark);margin-top:2px}.edit-form-container{display:flex;flex-direction:column;gap:20px}.edit-card{transition:box-shadow var(--transition-base)}.edit-card:hover{box-shadow:var(--shadow-md)}.edit-card .card-title{display:flex;align-items:center;gap:6px;font-size:1rem}.edit-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.edit-form-grid .full-width{grid-column:1 / -1}.edit-form-group{display:flex;flex-direction:column;gap:6px}.edit-form-label{font-size:.8125rem;font-weight:600;color:var(--color-text-primary)}.edit-form-label-hint{font-weight:400;color:var(--color-text-tertiary);font-size:.75rem;margin-top:8px;line-height:1.4}.edit-form-input,.edit-form-select{width:100%;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-primary);background:var(--color-surface);outline:none;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.edit-form-input:focus,.edit-form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #13ec5b1f}.edit-form-input::placeholder{color:var(--color-text-tertiary)}.edit-form-textarea{width:100%;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-primary);background:var(--color-surface);outline:none;resize:vertical;font-family:inherit;line-height:1.5;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.edit-form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #13ec5b1f}.edit-input-with-unit{position:relative;display:flex;align-items:center}.edit-input-with-unit .edit-form-input{padding-right:40px}.edit-input-with-unit .edit-form-input.has-prefix{padding-left:28px;padding-right:12px}.edit-input-unit{position:absolute;right:12px;font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);pointer-events:none}.edit-input-prefix{position:absolute;left:12px;font-size:.875rem;font-weight:700;color:var(--color-text-secondary);pointer-events:none;z-index:1}.edit-ownership-empty{display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-bg);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.edit-ownership-empty .material-symbols-outlined{font-size:24px;color:var(--color-text-tertiary)}.edit-ownership-empty p{font-size:.8125rem;color:var(--color-text-tertiary);line-height:1.4}@media (max-width: 1280px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.dashboard-grid,.detail-grid{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-row,.form-grid,.edit-form-grid,.detail-info-grid,.detail-grid{grid-template-columns:1fr}.header-search,.header-user-info{display:none}}
