:root{--bg-primary: #f5f9f7;--bg-secondary: #ffffff;--bg-tertiary: #e8f0ec;--bg-card: rgba(255, 255, 255, .85);--bg-card-hover: rgba(240, 250, 244, .95);--bg-glass: rgba(255, 255, 255, .6);--bg-overlay: rgba(0, 0, 0, .3);--accent: #16a34a;--accent-light: #22c55e;--accent-dark: #15803d;--accent-glow: rgba(22, 163, 74, .1);--accent-glow-strong: rgba(22, 163, 74, .18);--text-primary: #1a2e22;--text-secondary: #4a6352;--text-muted: #7a9484;--text-accent: #16a34a;--border: rgba(22, 163, 74, .15);--border-hover: rgba(22, 163, 74, .3);--border-active: rgba(22, 163, 74, .5);--risk-critical: #dc2626;--risk-high: #ea580c;--risk-medium: #ca8a04;--risk-low: #16a34a;--risk-none: #6b7280;--urgency-immediate: #dc2626;--urgency-soon: #ea580c;--urgency-normal: #2563eb;--urgency-low: #6b7280;--condition-good: #16a34a;--condition-fair: #ca8a04;--condition-poor: #ea580c;--condition-critical: #dc2626;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(22, 163, 74, .08);--shadow-glow-strong: 0 0 40px rgba(22, 163, 74, .15);--font-thai: "IBM Plex Sans Thai", sans-serif;--font-latin: "Inter", sans-serif;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary: #0a0f0d;--bg-secondary: #111916;--bg-tertiary: #1a2420;--bg-card: rgba(26, 36, 32, .7);--bg-card-hover: rgba(34, 50, 43, .8);--bg-glass: rgba(26, 36, 32, .5);--bg-overlay: rgba(0, 0, 0, .6);--accent: #22c55e;--accent-light: #4ade80;--accent-dark: #16a34a;--accent-glow: rgba(34, 197, 94, .15);--accent-glow-strong: rgba(34, 197, 94, .3);--text-primary: #f0fdf4;--text-secondary: #a3b8a8;--text-muted: #6b7c6f;--text-accent: #4ade80;--border: rgba(34, 197, 94, .12);--border-hover: rgba(34, 197, 94, .3);--border-active: rgba(34, 197, 94, .5);--risk-critical: #ef4444;--risk-high: #f97316;--risk-medium: #eab308;--risk-low: #22c55e;--risk-none: #6b7280;--urgency-immediate: #ef4444;--urgency-soon: #f97316;--urgency-normal: #3b82f6;--urgency-low: #6b7280;--condition-good: #22c55e;--condition-fair: #eab308;--condition-poor: #f97316;--condition-critical: #ef4444;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(34, 197, 94, .15);--shadow-glow-strong: 0 0 40px rgba(34, 197, 94, .25)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden}body{font-family:var(--font-thai);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden;transition:background var(--transition-normal),color var(--transition-normal)}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at 20% 50%,rgba(22,163,74,.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(22,163,74,.03) 0%,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(21,128,61,.03) 0%,transparent 50%);pointer-events:none;z-index:0}[data-theme=dark] body:before{background:radial-gradient(ellipse at 20% 50%,rgba(34,197,94,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(34,197,94,.03) 0%,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(16,163,74,.04) 0%,transparent 50%)}#root{position:relative;z-index:1;min-height:100vh}.theme-toggle-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;font-family:var(--font-thai);font-size:.85rem;transition:all var(--transition-fast);width:100%;margin-bottom:var(--space-sm)}.theme-toggle-btn:hover{background:var(--accent-glow-strong);border-color:var(--border-hover);color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-latin);font-weight:700;line-height:1.3;color:var(--text-primary)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}p{color:var(--text-secondary)}a{color:var(--accent-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent)}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border);padding:var(--space-lg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition-normal)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-md);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border);margin-bottom:var(--space-lg)}.sidebar-logo .logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow)}.sidebar-logo h1{font-size:1.25rem;background:linear-gradient(135deg,var(--accent-light),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-xs);flex:1}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:transparent;font-family:var(--font-thai);font-size:.95rem;text-decoration:none;width:100%;text-align:left}.sidebar-nav-item:hover{background:var(--accent-glow);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-glow-strong);color:var(--accent-light);font-weight:500}.main-content{flex:1;margin-left:260px;padding:var(--space-xl);min-height:100vh;max-width:100vw;overflow-x:hidden}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.card-flat{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-family:var(--font-thai);font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:var(--accent-glow);color:var(--text-primary);border-color:var(--border)}.btn-danger{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444440}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md)}.btn-fab{position:fixed;bottom:var(--space-xl);right:var(--space-xl);width:56px;height:56px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border:none;cursor:pointer;box-shadow:var(--shadow-lg),var(--shadow-glow-strong);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:50}.btn-fab:hover{transform:scale(1.1) translateY(-2px);box-shadow:var(--shadow-lg),0 0 60px #22c55e66}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.95rem;transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-textarea{resize:vertical;min-height:80px}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7c6f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-risk-critical{background:#ef444426;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.badge-risk-high{background:#f9731626;color:#ea580c;border:1px solid rgba(249,115,22,.3)}.badge-risk-medium{background:#eab30826;color:#b45309;border:1px solid rgba(234,179,8,.3)}.badge-risk-low{background:#22c55e26;color:#16a34a;border:1px solid rgba(34,197,94,.3)}.badge-urgency-immediate{background:#ef444426;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.badge-urgency-soon{background:#f9731626;color:#ea580c;border:1px solid rgba(249,115,22,.3)}.badge-urgency-normal{background:#3b82f626;color:#2563eb;border:1px solid rgba(59,130,246,.3)}.badge-urgency-low{background:#6b728026;color:#4b5563;border:1px solid rgba(107,114,128,.3)}.badge-condition-good{background:#22c55e26;color:#16a34a;border:1px solid rgba(34,197,94,.3)}.badge-condition-fair{background:#eab30826;color:#b45309;border:1px solid rgba(234,179,8,.3)}.badge-condition-poor{background:#f9731626;color:#ea580c;border:1px solid rgba(249,115,22,.3)}.badge-condition-critical{background:#ef444426;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.badge-tag{background:#22c55e1f;color:#15803d;border:1px solid rgba(34,197,94,.2)}.badge-size{background:#8b5cf626;color:#7c3aed;border:1px solid rgba(139,92,246,.3)}.tab-bar{display:flex;gap:var(--space-xs);padding:var(--space-xs);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto;margin-bottom:var(--space-xl)}.tab-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);border:none;background:transparent;font-family:var(--font-thai);white-space:nowrap}.tab-item:hover{color:var(--text-secondary);background:var(--accent-glow)}.tab-item.active{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:var(--shadow-glow)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn var(--transition-fast)}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);width:90%;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp var(--transition-normal)}.modal h2{margin-bottom:var(--space-lg)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.grid-2>*,.grid-3>*,.grid-4>*,.grid-auto>*{min-width:0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.page-header-left{display:flex;align-items:center;gap:var(--space-md)}.page-title{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.back-btn:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-card-hover)}.filter-pills{display:flex;align-items:center;gap:var(--space-xs)}.pill{display:inline-flex;align-items:center;gap:4px;padding:4px 14px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;font-family:var(--font-thai);cursor:pointer;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-muted);transition:all var(--transition-fast)}.pill:hover{border-color:var(--border-hover);color:var(--text-secondary)}.pill.active{background:var(--accent-glow);border-color:var(--accent);color:var(--accent-light);font-weight:600}.project-card{cursor:pointer;overflow:hidden;position:relative}.project-card-cover{width:100%;height:160px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:var(--space-md);background:var(--bg-tertiary)}.project-card-placeholder{width:100%;height:160px;border-radius:var(--radius-md);margin-bottom:var(--space-md);background:linear-gradient(135deg,var(--bg-tertiary),var(--accent-glow));display:flex;align-items:center;justify-content:center;color:var(--accent)}.project-card h3{margin-bottom:var(--space-xs)}.project-card-stats{display:flex;gap:var(--space-md);color:var(--text-muted);font-size:.85rem}.project-card-stats span{display:flex;align-items:center;gap:4px}.tree-card{display:flex;gap:var(--space-md);cursor:pointer;overflow:hidden}.tree-card-image{width:100px;height:100px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0;background:var(--bg-tertiary)}.tree-card-placeholder{width:100px;height:100px;border-radius:var(--radius-md);flex-shrink:0;background:linear-gradient(135deg,var(--bg-tertiary),var(--accent-glow));display:flex;align-items:center;justify-content:center;color:var(--accent)}.tree-card-content{flex:1;min-width:0}.tree-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-xs)}.tree-card-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.tree-card-code{font-size:.8rem;color:var(--text-muted);font-family:var(--font-latin)}.tree-card-desc{font-size:.85rem;color:var(--text-muted);margin-bottom:var(--space-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-card-badges{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-lg)}.search-input{flex:1;min-width:200px;padding:var(--space-sm) var(--space-md);padding-left:40px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.9rem;transition:all var(--transition-fast);outline:none}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-wrapper{position:relative;flex:1;min-width:200px}.search-wrapper svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.filter-select{padding:var(--space-sm) var(--space-md);padding-right:36px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.85rem;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7c6f' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:all var(--transition-fast)}.filter-select:focus{border-color:var(--accent)}.filter-select option{background:var(--bg-secondary)}.stat-card{text-align:center;padding:var(--space-xl)}.stat-value{font-size:2.5rem;font-weight:800;font-family:var(--font-latin);background:linear-gradient(135deg,var(--text-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:var(--space-xs)}.stat-label{font-size:.85rem;color:var(--text-muted)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}.photo-upload-area{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--space-2xl);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);cursor:pointer;transition:all var(--transition-fast);text-align:center;color:var(--text-muted);min-height:200px}.photo-upload-area:hover{border-color:var(--accent);background:var(--accent-glow);color:var(--accent-light)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md)}.photo-item{position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4/3}.photo-item img{width:100%;height:100%;object-fit:cover}.photo-item-actions{position:absolute;top:var(--space-sm);right:var(--space-sm);display:flex;gap:var(--space-xs);opacity:0;transition:opacity var(--transition-fast)}.photo-item:hover .photo-item-actions{opacity:1}.empty-state{text-align:center;padding:var(--space-3xl);color:var(--text-muted)}.empty-state svg{margin-bottom:var(--space-md);opacity:.4}.empty-state h3{color:var(--text-secondary);margin-bottom:var(--space-sm)}.map-container{width:100%;height:500px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}.map-container .leaflet-container{height:100%;width:100%;background:var(--bg-tertiary)}.zone-card{position:relative;overflow:hidden}.zone-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.zone-card[data-color=green]:before{background:#22c55e}.zone-card[data-color=blue]:before{background:#3b82f6}.zone-card[data-color=orange]:before{background:#f97316}.zone-card[data-color=purple]:before{background:#a855f7}.zone-card[data-color=red]:before{background:#ef4444}.zone-card[data-color=teal]:before{background:#14b8a6}.report-card{border-left:3px solid var(--accent)}.report-card-photos{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-top:var(--space-md)}.report-card-photo{border-radius:var(--radius-md);overflow:hidden;aspect-ratio:16/10;background:var(--bg-tertiary)}.report-card-photo img{width:100%;height:100%;object-fit:cover}.report-card-photo-label{font-size:.8rem;color:var(--text-muted);margin-top:var(--space-xs)}.report-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.report-count-badge{background:var(--accent-glow);color:var(--accent);font-size:.8rem;font-weight:600;padding:4px 12px;border-radius:var(--radius-full);border:1px solid var(--accent)}.report-timeline{position:relative;padding-left:32px;margin-bottom:var(--space-2xl)}.report-timeline:before{content:"";position:absolute;left:14px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--accent),var(--border));border-radius:2px}.report-timeline-item{position:relative;margin-bottom:var(--space-lg)}.report-timeline-item:last-child{margin-bottom:0}.report-timeline-dot{position:absolute;left:-32px;top:16px;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;z-index:2;box-shadow:0 0 0 4px var(--bg-primary),0 2px 6px #0000001a}.report-timeline-card{background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-lg);padding:var(--space-lg);transition:box-shadow .2s ease}.report-timeline-card:hover{box-shadow:0 4px 16px #0000000f}.report-timeline-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);flex-wrap:wrap;gap:var(--space-sm)}.report-timeline-reporter{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.85rem;color:var(--text-primary)}.report-timeline-reporter svg{color:var(--accent)}.report-timeline-date{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--text-muted)}.report-timeline-desc{font-size:.88rem;line-height:1.7;color:var(--text-secondary);margin-bottom:var(--space-md)}.report-timeline-rec{display:flex;gap:10px;padding:var(--space-sm) var(--space-md);background:#eab3080f;border:1px solid rgba(234,179,8,.2);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.83rem;line-height:1.6}.report-timeline-rec svg{color:#eab308;margin-top:2px;flex-shrink:0}.report-timeline-rec strong{display:block;font-size:.78rem;color:#ca8a04;margin-bottom:2px;text-transform:uppercase;letter-spacing:.5px}.report-timeline-rec p{margin:0;color:var(--text-secondary)}.report-timeline-photos{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.report-timeline-photo{display:flex;align-items:center;justify-content:center;gap:6px;padding:var(--space-md);background:var(--bg-tertiary);border:1.5px dashed var(--border);border-radius:var(--radius-md);color:var(--text-muted);font-size:.78rem}@media (max-width: 768px){.report-timeline{padding-left:28px}.report-timeline-dot{left:-28px;width:24px;height:24px;font-size:.65rem}.report-timeline-card{padding:var(--space-md)}.report-timeline-meta{flex-direction:column;align-items:flex-start}}.bar-chart{display:flex;gap:3px;align-items:flex-end;height:80px;padding-top:var(--space-sm)}.bar-chart-item{flex:1;border-radius:4px 4px 0 0;min-height:4px;position:relative;transition:all var(--transition-fast)}.bar-chart-item:hover{opacity:.8}.bar-chart-labels{display:flex;gap:3px;margin-top:var(--space-xs)}.bar-chart-labels span{flex:1;font-size:.7rem;text-align:center;color:var(--text-muted)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:var(--space-md);padding-top:60px}.page-header{padding-left:40px}.page-title{font-size:1.25rem}.grid-3,.grid-2{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.stat-card{padding:var(--space-md)}.stat-icon{width:36px;height:36px;margin-bottom:var(--space-sm)}.stat-icon svg{width:18px;height:18px}.stat-value{font-size:1.75rem}.stat-label{font-size:.75rem}.tab-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:2px;padding:3px}.tab-bar::-webkit-scrollbar{display:none}.tab-item{padding:var(--space-xs) var(--space-sm);font-size:.8rem;gap:4px;flex-shrink:0}.tab-item svg{width:14px;height:14px}.bar-chart{height:60px}.bar-chart-labels span{font-size:.6rem}.filter-bar{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xs)}.filter-bar .search-wrapper{grid-column:1 / -1}.search-wrapper{width:100%}.tree-card{flex-direction:column}.tree-card-image,.tree-card-placeholder{width:100%;height:160px}.tree-detail-header{flex-direction:column}.tree-detail-photo,.tree-detail-photo-placeholder{width:100%;height:200px}.map-container{height:300px}.notes-textarea{min-height:150px}.ai-result{max-height:300px}.card-flat{padding:var(--space-md);overflow:hidden}.card,.stat-card{overflow:hidden}.stat-value{word-break:break-all}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.fast-pass-item{gap:var(--space-sm);padding:var(--space-sm)}}@media (max-width: 480px){.main-content{padding:var(--space-sm);padding-top:56px}.page-header{padding-left:36px;margin-bottom:var(--space-md)}.page-title{font-size:1.1rem}.grid-4{grid-template-columns:repeat(2,1fr);gap:var(--space-xs)}.stat-card{padding:var(--space-sm) var(--space-xs)}.stat-value{font-size:1.5rem}.stat-label{font-size:.7rem}.stat-icon{width:32px;height:32px}.card-flat{padding:var(--space-sm)}.card-flat h4{font-size:.9rem}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s infinite}.tree-detail-header{display:flex;gap:var(--space-xl);margin-bottom:var(--space-xl)}.tree-detail-photo{width:280px;height:280px;border-radius:var(--radius-lg);object-fit:cover;flex-shrink:0;background:var(--bg-tertiary)}.tree-detail-photo-placeholder{width:280px;height:280px;border-radius:var(--radius-lg);flex-shrink:0;background:linear-gradient(135deg,var(--bg-tertiary),var(--accent-glow));display:flex;align-items:center;justify-content:center;color:var(--accent)}.tree-detail-info{flex:1}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.map-small{height:300px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);margin-top:var(--space-md)}.map-small .leaflet-container{height:100%;width:100%}.coords-display{display:flex;gap:var(--space-md);margin-top:var(--space-sm);font-size:.85rem;color:var(--text-muted);font-family:var(--font-latin)}.fast-pass-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md)}.fast-pass-priority{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0;font-family:var(--font-latin)}.fast-pass-content{flex:1}.admin-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{text-align:left;padding:var(--space-sm) var(--space-md);font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tbody tr:hover{background:var(--bg-card-hover)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-link{color:var(--accent);cursor:pointer;font-weight:500;transition:color var(--transition-fast)}.admin-link:hover{color:var(--accent-light);text-decoration:underline}.admin-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;background:var(--accent-glow);color:var(--accent)}.admin-status{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:.78rem;font-weight:600;white-space:nowrap}.admin-status-critical{background:#ef444426;color:var(--risk-critical)}.admin-status-high{background:#f9731626;color:var(--risk-high)}.admin-status-medium{background:#eab30826;color:var(--risk-medium)}.admin-status-low{background:#22c55e1f;color:var(--accent)}.admin-role-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;border:1px solid;background:transparent}.btn-icon-danger{width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;border:1px solid transparent;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-icon-danger:hover{background:#ef44441f;border-color:#ef44444d;color:var(--risk-critical)}.admin-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent);font-size:.7rem;font-weight:700;font-family:var(--font-latin)}.admin-toolbar{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg);box-shadow:0 1px 3px #0000000a}.admin-toolbar-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-md)}.admin-toolbar-actions{display:flex;gap:var(--space-sm)}.admin-search-bar{display:flex;align-items:center;gap:var(--space-md)}.admin-search-input-wrapper{position:relative;flex:1}.admin-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color var(--transition-fast)}.admin-search-input{width:100%;padding:10px 44px;background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-thai);font-size:.9rem;outline:none;transition:all .25s ease}.admin-search-input::placeholder{color:var(--text-muted);opacity:.7}.admin-search-input:hover{border-color:var(--border-hover);background:var(--bg-secondary)}.admin-search-input:focus{border-color:var(--accent);background:var(--bg-secondary);box-shadow:0 0 0 3px var(--accent-glow),0 1px 3px #0000000f}.admin-search-input:focus+.admin-search-icon,.admin-search-input-wrapper:focus-within .admin-search-icon{color:var(--accent)}.admin-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.admin-search-clear:hover{background:var(--bg-tertiary);color:var(--text-primary)}.admin-search-result-count{flex-shrink:0;padding:4px 12px;border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent);font-size:.8rem;font-weight:600;white-space:nowrap;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.pill-field{margin-bottom:var(--space-lg)}.pill-selector{display:flex;flex-wrap:wrap;gap:8px}.pill-option{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1.5px solid var(--border);border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);font-family:var(--font-thai);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.pill-option:hover{border-color:var(--border-hover);background:var(--bg-secondary);transform:translateY(-1px);box-shadow:0 2px 6px #0000000f}.pill-option.active{background:var(--pill-active-bg, var(--accent-glow));border-color:var(--pill-active-border, var(--accent));color:var(--pill-active-color, var(--accent));font-weight:600;box-shadow:0 2px 8px #00000014}.pill-icon{display:flex;align-items:center;line-height:1;flex-shrink:0}.pill-label{line-height:1}.pill-check{color:var(--pill-active-color, var(--accent));margin-left:2px;flex-shrink:0}.species-combobox{position:relative}.species-input-wrapper{display:flex;align-items:center;position:relative;cursor:pointer}.species-search-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none;z-index:1}.species-input{width:100%;padding:10px 36px;background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.9rem;outline:none;transition:all .2s ease}.species-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.species-input::placeholder{color:var(--text-muted)}.species-selected{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 36px;background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.9rem}.species-selected span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.species-clear{display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:var(--radius-full);transition:all .15s ease;flex-shrink:0}.species-clear:hover{color:var(--risk-critical);background:#ef44441a}.species-chevron{position:absolute;right:12px;color:var(--text-muted);pointer-events:none;transition:transform .2s ease}.species-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:240px;overflow-y:auto;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001f;z-index:100}.species-option{width:100%;display:flex;align-items:center;gap:8px;padding:10px 14px;border:none;border-bottom:1px solid var(--border);background:transparent;color:var(--text-primary);font-family:var(--font-thai);font-size:.85rem;cursor:pointer;text-align:left;transition:background .15s ease}.species-option:last-child{border-bottom:none}.species-option:hover{background:var(--accent-glow)}.species-option.selected{background:var(--accent-glow);color:var(--accent);font-weight:600}.species-option svg:first-child{color:var(--accent);flex-shrink:0}.species-option-check{margin-left:auto;color:var(--accent);flex-shrink:0}.species-empty{padding:var(--space-md);text-align:center;color:var(--text-muted);font-size:.85rem}@media (max-width: 768px){.pill-selector{gap:6px}.pill-option{padding:7px 10px;font-size:.8rem}.pill-icon{font-size:.9rem}}.members-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg)}.members-header-info{display:flex;align-items:center;gap:var(--space-sm)}.members-header-info strong{color:var(--text-primary);font-size:1rem}.members-count{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent);font-size:.8rem;font-weight:600;margin-left:var(--space-sm)}.member-cards{display:flex;flex-direction:column;gap:var(--space-sm)}.member-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.member-card:hover{border-color:var(--border-hover);box-shadow:0 2px 8px #0000000f}.member-card.member-expired{opacity:.6;background:var(--bg-tertiary)}.member-avatar{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;font-family:var(--font-latin);flex-shrink:0;letter-spacing:.02em}.member-info{flex:1;min-width:0}.member-name{font-weight:600;color:var(--text-primary);margin-bottom:2px}.member-email{font-size:.82rem;color:var(--text-muted);font-family:var(--font-latin);margin-bottom:6px}.member-meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.member-date{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.member-expiry{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--urgency-soon);font-weight:500}.member-expiry.expired{color:var(--risk-critical)}.member-permanent{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--accent);font-weight:500}.fast-pass-modal{max-width:520px}.fast-pass-modal-header{display:flex;align-items:center;gap:var(--space-sm);color:var(--accent);margin-bottom:var(--space-lg)}.fast-pass-modal-header h2{margin:0;color:var(--text-primary)}.fp-mode-toggle{display:flex;gap:0;margin-bottom:var(--space-lg);background:var(--bg-tertiary);border-radius:var(--radius-md);padding:3px}.fp-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-family:var(--font-thai);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.fp-mode-btn.active{background:var(--bg-secondary);color:var(--accent);font-weight:600;box-shadow:0 1px 3px #00000014}.fp-mode-btn:hover:not(.active){color:var(--text-primary)}.fp-section{margin-bottom:var(--space-md)}.fp-form-row{display:flex;gap:var(--space-md)}.fp-user-search-wrapper{position:relative;margin-bottom:var(--space-sm)}.fp-user-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.fp-user-search{padding-left:32px!important}.fp-user-list{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-tertiary)}.fp-user-option{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:8px 12px;border:none;border-bottom:1px solid var(--border);background:transparent;cursor:pointer;text-align:left;transition:background var(--transition-fast);font-family:var(--font-thai)}.fp-user-option:last-child{border-bottom:none}.fp-user-option:hover{background:var(--accent-glow)}.fp-user-option.selected{background:var(--accent-glow);border-left:3px solid var(--accent)}.fp-user-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.7rem;font-family:var(--font-latin);flex-shrink:0}.fp-user-detail{flex:1;min-width:0}.fp-user-name{font-weight:600;font-size:.85rem;color:var(--text-primary)}.fp-user-email{font-size:.75rem;color:var(--text-muted);font-family:var(--font-latin)}.fp-user-check{width:22px;height:22px;border-radius:var(--radius-full);background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.fp-user-empty{padding:var(--space-md);text-align:center;color:var(--text-muted);font-size:.85rem}.fp-duration-note{margin-top:var(--space-sm);padding:var(--space-xs) var(--space-sm);font-size:.8rem;color:var(--accent);font-weight:500;text-align:center}.mobile-nav-toggle{display:none;position:fixed;top:var(--space-md);left:var(--space-md);z-index:150;width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;align-items:center;justify-content:center}@media (max-width: 768px){.mobile-nav-toggle{display:flex}}.notes-textarea{width:100%;min-height:200px;resize:vertical;line-height:1.7;font-size:.95rem}.notes-saved-msg{color:var(--accent-light);font-size:.85rem;font-weight:500;animation:fadeIn var(--transition-fast)}.ai-badge{font-size:.7rem;font-weight:600;padding:2px 10px;border-radius:var(--radius-full);background:linear-gradient(135deg,#a78bfa33,#8b5cf633);color:#c4b5fd;border:1px solid rgba(139,92,246,.3);margin-left:4px}.btn-ai{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-family:var(--font-thai);font-size:.9rem;font-weight:500;cursor:pointer;border:1px solid rgba(139,92,246,.3);background:linear-gradient(135deg,#8b5cf626,#a78bfa1a);color:#c4b5fd;transition:all var(--transition-fast);margin-bottom:var(--space-md)}.btn-ai:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf640,#a78bfa33);border-color:#8b5cf680;box-shadow:0 0 20px #8b5cf626;transform:translateY(-1px)}.btn-ai:disabled{opacity:.7;cursor:not-allowed}.ai-result{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-lg);font-size:.9rem;line-height:1.8;color:var(--text-secondary);max-height:400px;overflow-y:auto}.ai-result strong{color:var(--text-primary)}.ai-result p{color:var(--text-secondary)}.ai-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:#fca5a5;font-size:.85rem;margin-bottom:var(--space-md)}.ai-placeholder{color:var(--text-muted);font-size:.85rem;font-style:italic}@keyframes spin{to{transform:rotate(360deg)}}.spin-animation{animation:spin 1s linear infinite}@keyframes quickEditSlideDown{0%{opacity:0;transform:translateY(-8px);max-height:0}to{opacity:1;transform:translateY(0);max-height:800px}}.quick-edit-wrapper{position:relative}.quick-edit-wrapper.is-editing>.tree-card{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow),var(--shadow-glow);border-bottom-left-radius:0;border-bottom-right-radius:0;transform:none}.quick-edit-toggle{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.quick-edit-toggle:hover{border-color:var(--accent);color:var(--accent-light);background:var(--accent-glow)}.quick-edit-toggle.active{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border-color:var(--accent);box-shadow:var(--shadow-glow)}.quick-edit-panel{background:var(--bg-secondary);border:1px solid var(--accent);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:var(--space-lg);animation:quickEditSlideDown .3s ease-out;box-shadow:0 4px 24px #0003,0 0 0 2px var(--accent-glow)}.quick-edit-header{display:flex;align-items:center;gap:var(--space-sm);font-size:.85rem;font-weight:600;color:var(--accent-light);margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}.quick-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.quick-edit-field{display:flex;flex-direction:column;gap:var(--space-xs)}.quick-edit-field.full-width{grid-column:1 / -1}.quick-edit-field label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.quick-edit-input,.quick-edit-select,.quick-edit-textarea{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.9rem;transition:all var(--transition-fast);outline:none}.quick-edit-input:focus,.quick-edit-select:focus,.quick-edit-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.quick-edit-textarea{resize:vertical;min-height:56px}.quick-edit-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7c6f' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.quick-edit-select option{background:var(--bg-secondary);color:var(--text-primary)}.quick-edit-pills{display:flex;flex-wrap:wrap;gap:6px}.quick-edit-pill{padding:6px 14px;border-radius:var(--radius-full);font-size:.82rem;font-weight:500;font-family:var(--font-thai);cursor:pointer;transition:all var(--transition-fast);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary)}.quick-edit-pill:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-card-hover)}.quick-edit-pill.pill-urgency.active{background:#ef44442e;border-color:#ef444480;color:#fca5a5;font-weight:600;box-shadow:0 0 10px #ef444426}.quick-edit-pill.pill-priority.active{background:#3b82f62e;border-color:#3b82f680;color:#93c5fd;font-weight:600;box-shadow:0 0 10px #3b82f626}.quick-edit-pill.pill-size.active{background:#8b5cf62e;border-color:#8b5cf680;color:#c4b5fd;font-weight:600;box-shadow:0 0 10px #8b5cf626}.quick-edit-pill.pill-condition.active{background:#22c55e2e;border-color:#22c55e80;color:#86efac;font-weight:600;box-shadow:0 0 10px #22c55e26}.quick-edit-tags{display:flex;flex-wrap:wrap;gap:6px}.quick-edit-tag{padding:4px 12px;border-radius:var(--radius-full);font-size:.78rem;font-weight:500;font-family:var(--font-thai);cursor:pointer;transition:all var(--transition-fast);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary)}.quick-edit-tag:hover{border-color:var(--accent);color:var(--accent-light)}.quick-edit-tag.active{background:var(--accent-glow-strong);border-color:var(--accent);color:var(--accent-light);font-weight:600;box-shadow:0 0 8px var(--accent-glow)}.quick-edit-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border)}.quick-edit-cancel{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);padding:6px 16px;font-size:.85rem}.quick-edit-cancel:hover{border-color:var(--border-hover);color:var(--text-primary)}.quick-edit-save{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:var(--shadow-glow);padding:6px 20px;font-size:.85rem}.quick-edit-save:hover{box-shadow:var(--shadow-glow-strong);transform:translateY(-1px)}.quick-edit-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.image-map-upload{border:2px dashed var(--border);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--bg-card);min-height:320px;display:flex;align-items:center;justify-content:center}.image-map-upload:hover,.image-map-upload.drag-over{border-color:var(--accent);background:var(--accent-glow);box-shadow:0 0 30px var(--accent-glow)}.image-map-upload-content h3{margin-bottom:var(--space-xs);color:var(--text-primary)}.image-map-upload-content p{font-size:.9rem;color:var(--text-muted);margin-bottom:var(--space-xs)}.image-map-upload-hint{font-size:.78rem!important;color:var(--text-muted)!important;opacity:.7}.image-map-upload-icon{width:72px;height:72px;border-radius:var(--radius-full);background:var(--accent-glow-strong);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg);color:var(--accent-light)}.image-map-zone-bar{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);padding:var(--space-xs);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}.image-map-zone-tabs{display:flex;gap:var(--space-xs);flex:1;min-width:0}.image-map-zone-tab{flex-shrink:0}.image-map-zone-tab-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);border:none;background:transparent;font-family:var(--font-thai);white-space:nowrap}.image-map-zone-tab-btn:hover{color:var(--text-secondary);background:var(--accent-glow)}.image-map-zone-tab.active .image-map-zone-tab-btn{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:var(--shadow-glow)}.image-map-zone-rename{display:flex;align-items:center;gap:4px}.image-map-zone-rename-input{padding:4px 10px;background:var(--bg-tertiary);border:1px solid var(--accent);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.85rem;outline:none;width:120px}.image-map-zone-rename-ok{width:28px;height:28px;border-radius:var(--radius-md);background:var(--accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.image-map-add-zone{flex-shrink:0;font-size:.82rem!important;padding:5px 12px!important}.image-map-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.image-map-toolbar-left,.image-map-toolbar-right{display:flex;align-items:center;gap:var(--space-sm)}.image-map-count{font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.image-map-select{padding:6px 32px 6px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-thai);font-size:.85rem;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7c6f' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:200px;cursor:pointer}.image-map-select option{background:var(--bg-secondary);color:var(--text-primary)}.image-map-instruction{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.85rem;margin-bottom:var(--space-md);background:var(--accent-glow);color:var(--accent-light);border:1px solid rgba(34,197,94,.3)}.image-map-instruction.warning{background:#eab3081a;color:#fde047;border-color:#eab3084d}.image-map-legend{display:flex;gap:var(--space-md);flex-wrap:wrap;align-items:center;padding:6px var(--space-md);margin-bottom:var(--space-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md)}.image-map-legend-label{font-size:.8rem;color:var(--text-muted)}.image-map-legend-item{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--text-secondary)}.image-map-legend-dot{width:9px;height:9px;border-radius:50%;display:inline-block;border:1.5px solid rgba(255,255,255,.2)}.image-map-container{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);background:var(--bg-tertiary);line-height:0;margin-top:var(--space-sm)}.image-map-container.pin-mode{cursor:crosshair;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.image-map-img{width:100%;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}@keyframes pinPulse{0%,to{box-shadow:0 0 0 0 var(--pin-color),0 2px 6px #0006}50%{box-shadow:0 0 0 6px transparent,0 2px 6px #0006}}.image-map-pin{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;cursor:pointer;z-index:10;border:none;background:none;padding:0;transition:transform var(--transition-fast);filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.image-map-pin:before{content:"";width:26px;height:26px;border-radius:50% 50% 50% 0;background:var(--pin-color);transform:rotate(-45deg);border:2px solid rgba(255,255,255,.85);box-sizing:border-box}.image-map-pin-id{position:absolute;top:3px;left:50%;transform:translate(-50%);font-size:.6rem;font-weight:700;color:#fff;font-family:var(--font-latin);line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.5);pointer-events:none}.image-map-pin:hover{transform:translate(-50%,-100%) scale(1.15);z-index:15}.image-map-pin.active{transform:translate(-50%,-100%) scale(1.2);z-index:20;animation:pinPulse 1.4s ease-in-out infinite}.image-map-popup{position:absolute;z-index:30;pointer-events:auto}.image-map-popup.above{transform:translate(-50%,calc(-100% - 36px))}.image-map-popup.below{transform:translate(-50%,10px)}.image-map-popup-arrow{position:absolute;left:50%;width:10px;height:10px;background:var(--bg-secondary);border:1px solid var(--border);transform:translate(-50%) rotate(45deg)}.image-map-popup.above .image-map-popup-arrow{bottom:-6px;border-top:none;border-left:none}.image-map-popup.below .image-map-popup-arrow{top:-6px;border-bottom:none;border-right:none}.image-map-popup-inner{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);min-width:210px;max-width:260px;box-shadow:0 8px 32px #00000073;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeIn .15s ease-out}.image-map-popup-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-sm)}.image-map-popup-name{font-size:.9rem;font-weight:600;color:var(--text-primary);line-height:1.3}.image-map-popup-sub{font-size:.72rem;color:var(--text-muted);margin-top:2px}.image-map-popup-x{width:24px;height:24px;flex-shrink:0;border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.image-map-popup-x:hover{background:#ef444426;border-color:#ef44444d;color:#fca5a5}.image-map-popup-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}.image-map-popup-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;color:var(--tc);background:color-mix(in srgb,var(--tc) 15%,transparent);border:1px solid color-mix(in srgb,var(--tc) 30%,transparent)}.image-map-popup-actions{display:flex;gap:6px}.image-map-popup-action{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-md);font-size:.75rem;font-weight:500;font-family:var(--font-thai);cursor:pointer;border:none;transition:all var(--transition-fast)}.image-map-popup-action.view{flex:1;justify-content:center;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:0 0 8px var(--accent-glow)}.image-map-popup-action.view:hover{box-shadow:0 0 16px var(--accent-glow)}.image-map-popup-action.remove{background:#ef44441f;color:#fca5a5;border:1px solid rgba(239,68,68,.25)}.image-map-popup-action.remove:hover{background:#ef444433}.zone-detail-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.zone-detail-title{display:flex;align-items:center;gap:var(--space-sm)}.zone-detail-title h3{margin:0}.zone-detail-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.zone-detail-count{font-size:.82rem;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 10px;border-radius:var(--radius-full)}.zone-card-clickable{cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.zone-card-clickable:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.zone-card-preview{position:relative;width:100%;height:120px;overflow:hidden;margin-bottom:var(--space-sm)}.zone-card-preview img{width:100%;height:100%;object-fit:cover;display:block}.zone-card-preview-overlay{position:absolute;bottom:6px;right:6px;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:.72rem;padding:3px 8px;border-radius:var(--radius-md);display:flex;align-items:center;gap:4px}@media (max-width: 768px){.quick-edit-grid{grid-template-columns:1fr}}
