.dashboard{max-width:1400px;margin:0 auto}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;color:var(--text-muted);gap:16px}.dashboard-loading .spin{animation:spin 1s linear infinite}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.dashboard-title h1{font-size:34px;font-weight:700;margin-bottom:6px}.dashboard-date{font-size:15px;color:var(--text-muted)}.dashboard-actions{display:flex;align-items:center;gap:12px}.last-updated{font-size:14px;color:var(--text-muted)}.refresh-btn{width:40px;height:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.refresh-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.status-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}.status-card{background:linear-gradient(135deg,#00b4d8,#0077b6);border-radius:18px;padding:28px 30px;display:flex;align-items:center;cursor:pointer;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;animation:slideUp .5s ease-out both}.status-card:nth-child(1){animation-delay:0s}.status-card:nth-child(2){animation-delay:.1s}.status-card:nth-child(3){animation-delay:.2s}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.status-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00b4d84d}.status-card.active{background:linear-gradient(135deg,#00b4d8,#0077b6)}.status-card.break{background:linear-gradient(135deg,#f59e0b,#d97706)}.status-card.break:hover{box-shadow:0 8px 24px #f59e0b4d}.status-card.inactive{background:linear-gradient(135deg,#6366f1,#4f46e5)}.status-card.inactive:hover{box-shadow:0 8px 24px #6366f14d}.status-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.status-card-content{flex:1;z-index:1}.status-number{font-size:56px;font-weight:700;color:#fff;line-height:1;margin-bottom:6px}.status-label{font-size:15px;color:#ffffffd9;text-transform:uppercase;font-weight:600;letter-spacing:.8px}.status-icon{width:64px;height:64px;background:#fff3;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;margin-right:14px}.status-arrow{color:#fff9;position:absolute;right:20px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:28px}.dashboard-card{background:var(--bg-card);border-radius:18px;border:1px solid var(--border);overflow:hidden;animation:slideUp .5s ease-out both}.dashboard-grid .dashboard-card:nth-child(1){animation-delay:.15s}.dashboard-grid .dashboard-card:nth-child(2){animation-delay:.25s}.dashboard-grid .dashboard-card:nth-child(3){animation-delay:.35s}.card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 0}.card-header h2{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.card-link{background:none;border:none;color:var(--accent-blue);font-size:14px;cursor:pointer;padding:0;transition:color .2s}.card-link:hover{color:var(--accent-cyan);text-decoration:underline}.dashboard-activity{grid-row:span 2;display:flex;flex-direction:column}.dashboard-activity .activity-list{padding:4px 0;flex:1}.dashboard-activity .activity-item{display:flex;align-items:center;gap:14px;padding:14px 24px;border-bottom:1px solid var(--border);transition:background .2s}.dashboard-activity .activity-item:last-child{border-bottom:none}.dashboard-activity .activity-item:hover{background:var(--bg-hover)}.activity-avatar{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;letter-spacing:.5px;flex-shrink:0;color:#fff;position:relative}.activity-avatar.in{background:linear-gradient(135deg,#26de81,#20bf6b);box-shadow:0 3px 10px #26de8140}.activity-avatar.out{background:linear-gradient(135deg,#ff9f43,#ee5a24);box-shadow:0 3px 10px #ff9f4340}.pulse-dot{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;background:#26de81;border-radius:50%;border:2px solid var(--bg-card);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #26de8180}50%{box-shadow:0 0 0 5px #26de8100}}.dashboard-activity .activity-item.active-entry{background:#26de810a}.activity-info{flex:1;min-width:0}.activity-name-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}.activity-employee{font-size:15px;color:var(--text-primary);font-weight:600}.activity-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;letter-spacing:.3px;text-transform:uppercase;flex-shrink:0}.activity-badge.badge-in{background:#26de8126;color:#26de81}.activity-badge.badge-out{background:#ff9f4326;color:#ff9f43}.activity-meta-row{display:flex;align-items:center;gap:12px}.activity-site{font-size:12px;color:var(--text-muted);display:inline-flex;align-items:center;gap:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:color .2s}.activity-site:hover{color:var(--accent-blue)}.activity-site svg{flex-shrink:0;opacity:.7}.activity-duration{font-size:12px;font-weight:600;color:#26de81;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.activity-time-block{text-align:right;flex-shrink:0}.activity-time{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap}.activity-ago{font-size:11px;color:var(--text-muted);margin-top:2px}.empty-activity{padding:40px 20px;text-align:center;color:var(--text-muted)}.chart-card .card-header{padding-bottom:0}.chart-value{font-size:42px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:6px}.chart-label{font-size:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.chart-clip-rect{transform-origin:0 0;animation:clipReveal 1.8s cubic-bezier(.22,.61,.36,1) forwards}@keyframes clipReveal{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.chart-dot{opacity:0;transform-origin:center;animation:popDot .4s ease-out forwards}@keyframes popDot{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.3)}to{opacity:1;transform:scale(1)}}.bar-chart{display:flex;align-items:flex-end;justify-content:space-around;height:200px;padding:24px;gap:10px}.bar-column{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.bar{width:100%;max-width:40px;min-height:4px;border-radius:6px 6px 0 0;position:relative;display:flex;align-items:flex-start;justify-content:center;transition:all .3s ease;animation:growBar .8s ease-out forwards;transform-origin:bottom}.bar-column:nth-child(1) .bar{animation-delay:.1s}.bar-column:nth-child(2) .bar{animation-delay:.2s}.bar-column:nth-child(3) .bar{animation-delay:.3s}.bar-column:nth-child(4) .bar{animation-delay:.4s}.bar-column:nth-child(5) .bar{animation-delay:.5s}.bar-column:nth-child(6) .bar{animation-delay:.6s}@keyframes growBar{0%{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:1}}.bar:hover{transform:scaleY(1.02);filter:brightness(1.1)}.bar.purple{background:linear-gradient(180deg,#a78bfa,#8b5cf6);box-shadow:0 4px 12px #8b5cf64d}.bar.cyan{background:linear-gradient(180deg,#67e8f9,#22d3ee);box-shadow:0 4px 12px #22d3ee4d}.bar-value{position:absolute;top:-22px;font-size:12px;font-weight:600;color:var(--text-secondary)}.bar-label{margin-top:10px;font-size:12px;color:var(--text-muted);white-space:nowrap}.area-chart{padding:24px 24px 12px;position:relative}.area-chart svg{width:100%;height:140px;overflow:visible}.chart-x-axis{display:flex;justify-content:space-between;margin-top:12px;padding:0 4px}.axis-label{display:flex;flex-direction:column;align-items:center;gap:2px}.axis-value{font-size:13px;font-weight:600;color:var(--text-secondary)}.axis-month{font-size:11px;color:var(--text-muted)}.chart-tooltip{position:absolute;top:10px;transform:translate(-50%);background:linear-gradient(135deg,#8b5cf6,#7c3aed);padding:8px 14px;border-radius:10px;box-shadow:0 4px 16px #8b5cf666;pointer-events:none;z-index:10;animation:tooltipFadeIn .15s ease-out;white-space:nowrap}.chart-tooltip[style*="left: 0%"]{transform:translate(0)}.chart-tooltip[style*="left: 100%"]{transform:translate(-100%)}.chart-tooltip.edge-left{transform:translate(0)}.chart-tooltip.edge-right{transform:translate(-100%)}.chart-tooltip.cyan{background:linear-gradient(135deg,#22d3ee,#06b6d4);box-shadow:0 4px 16px #22d3ee66}.chart-tooltip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #7c3aed}.chart-tooltip.edge-left:after{left:20px;transform:none}.chart-tooltip.edge-right:after{left:auto;right:20px;transform:none}.chart-tooltip.cyan:after{border-top-color:#06b6d4}.tooltip-value{font-size:18px;font-weight:700;color:#fff;text-align:center;line-height:1.2}.tooltip-label{font-size:11px;color:#fffc;text-align:center}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.dashboard-map{margin-bottom:28px;animation:slideUp .5s ease-out both;animation-delay:.4s}.mini-map-wrapper{position:relative}.mini-map-container{width:100%;height:280px;background:var(--bg-card)}.mini-map-container .leaflet-tile-pane{filter:brightness(.85) saturate(.8)}.mini-map-empty{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);font-size:14px;background:var(--bg-card);z-index:500}.mini-map-legend{position:absolute;bottom:12px;left:12px;display:flex;align-items:center;gap:16px;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 14px;border-radius:10px;z-index:500;font-size:12px;color:#ffffffe6}.legend-item{display:flex;align-items:center;gap:6px;font-weight:500}.legend-dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.8)}.legend-dot.green{background:#22c55e;box-shadow:0 0 6px #22c55e66}.legend-dot.orange{background:#f97316;box-shadow:0 0 6px #f9731666}.legend-count{color:#ffffff80;font-size:11px;margin-left:4px}.mini-map-popup .leaflet-popup-content-wrapper{background:var(--bg-card, #1c1c1e);color:var(--text-primary, #fff);border-radius:12px;box-shadow:0 8px 24px #0006;border:1px solid var(--border, #333)}.mini-map-popup .leaflet-popup-tip{background:var(--bg-card, #1c1c1e)}.dashboard-tasks{margin-bottom:28px;animation:slideUp .5s ease-out both;animation-delay:.45s}.dashboard-tasks .card-header h2{display:flex;align-items:center;gap:8px}.task-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:8px;background:#ff6b6b26;color:#ff6b6b;font-size:12px;font-weight:700}.task-list{padding:4px 0}.task-item{display:flex;align-items:stretch;padding:14px 24px;border-bottom:1px solid var(--border);transition:background .2s;gap:14px}.task-item:last-child{border-bottom:none}.task-item:hover{background:var(--bg-hover)}.task-item.overdue{background:#ff6b6b0a}.task-priority-bar{width:4px;border-radius:4px;flex-shrink:0;min-height:100%}.task-info{flex:1;min-width:0}.task-title-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.task-title{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-status-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px}.task-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.task-assignee{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);font-weight:500}.task-assignee-avatar{width:20px;height:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}.task-site{display:flex;align-items:center;gap:3px;font-size:12px;color:var(--text-muted)}.task-due{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--text-muted)}.task-due.soon{color:#f59e0b;font-weight:600}.task-priority-label{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600}.empty-tasks{padding:40px 20px;text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:14px}.quick-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.quick-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:24px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s;animation:slideUp .5s ease-out both}.quick-stat:nth-child(1){animation-delay:.3s}.quick-stat:nth-child(2){animation-delay:.4s}.quick-stat:nth-child(3){animation-delay:.5s}.quick-stat:nth-child(4){animation-delay:.6s}.quick-stat:hover{border-color:var(--accent-blue);background:var(--bg-hover)}.quick-stat svg{color:var(--accent-cyan)}.quick-stat-value{font-size:28px;font-weight:700;color:var(--text-primary)}.quick-stat-label{font-size:14px;color:var(--text-muted)}.dashboard-activities{margin-bottom:28px;animation:slideUp .5s ease-out both;animation-delay:.5s}.dashboard-activities .card-header h2{display:flex;align-items:center;gap:8px}.tracker-header-actions{display:flex;align-items:center;gap:12px}.tracker-add-btn{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:8px;border:none;background:#90c73e;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s}.tracker-add-btn:hover{opacity:.85}.activity-tracker-stats{display:flex;gap:12px;padding:16px 24px 8px}.tracker-stat{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:10px;background:var(--bg-secondary);border:1px solid var(--border)}.tracker-stat.follow-ups .tracker-stat-value{color:#ff6b6b}.tracker-stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.tracker-stat-label{font-size:12px;color:var(--text-muted);font-weight:500}.tracker-activity-list{padding:4px 0}.tracker-activity-item{display:flex;align-items:center;padding:12px 24px;border-bottom:1px solid var(--border);transition:background .2s;gap:12px}.tracker-activity-item:last-child{border-bottom:none}.tracker-activity-item:hover{background:var(--bg-hover)}.tracker-priority-bar{width:4px;align-self:stretch;border-radius:2px;flex-shrink:0}.tracker-category-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tracker-activity-info{flex:1;min-width:0}.tracker-title-row{display:flex;align-items:center;gap:8px;margin-bottom:3px}.tracker-title{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tracker-status-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;white-space:nowrap;flex-shrink:0}.tracker-meta-row{display:flex;align-items:center;gap:10px}.tracker-contact{font-size:12px;color:var(--text-muted)}.tracker-site{display:flex;align-items:center;gap:3px;font-size:11px;color:#4a9eff}.tracker-time{font-size:12px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.tracker-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 24px;color:var(--text-muted);font-size:14px}.tracker-empty svg{opacity:.4}.tracker-empty-btn{margin-top:4px;padding:8px 18px;border-radius:8px;border:1px solid var(--border);background:transparent;color:#90c73e;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.tracker-empty-btn:hover{background:var(--bg-hover)}@media (max-width: 900px){.status-cards,.dashboard-grid{grid-template-columns:1fr}.dashboard-activity{grid-row:span 1}.quick-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:12px}.dashboard-actions{width:100%;justify-content:space-between}.quick-stats{grid-template-columns:1fr}.status-number{font-size:42px}.chart-value{font-size:32px}.activity-tracker-stats{flex-wrap:wrap}.tracker-header-actions{gap:8px}.tracker-add-btn{padding:5px 10px;font-size:11px}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes photoReveal{0%{opacity:0;transform:scale(.8) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.photos-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;animation:fadeSlideUp .4s cubic-bezier(.16,1,.3,1) both}.photos-nav{display:flex;align-items:center;gap:8px}.photos-period{font-size:16px;font-weight:600;margin-left:8px}.photos-stats{color:var(--text-secondary);font-size:14px}.photo-group{background:var(--bg-card);border-radius:10px;margin-bottom:16px;overflow:hidden;border:1px solid var(--border);animation:fadeSlideUp .45s cubic-bezier(.16,1,.3,1) both}.photo-group:nth-child(1){animation-delay:.05s}.photo-group:nth-child(2){animation-delay:.12s}.photo-group:nth-child(3){animation-delay:.19s}.photo-group:nth-child(4){animation-delay:.26s}.photo-group:nth-child(5){animation-delay:.33s}.photo-group:nth-child(n+6){animation-delay:.38s}.photo-group-header{display:flex;align-items:flex-start;padding:16px 20px}.photo-group-checkbox{width:20px;height:20px;border:2px solid var(--border);border-radius:4px;margin-right:16px;cursor:pointer;flex-shrink:0;margin-top:2px}.photo-group-info{flex:1}.photo-group-name{font-size:15px;font-weight:600;margin-bottom:4px}.photo-group-meta{font-size:13px;color:var(--text-secondary);margin-bottom:6px}.photo-group-caption{font-size:13px;color:var(--text-secondary)}.photo-tag{color:var(--accent-blue);cursor:pointer;margin-left:4px}.photo-tag:hover{text-decoration:underline}.photo-group-date{font-size:13px;color:var(--text-muted);white-space:nowrap;margin-left:16px}.photo-group-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:0 20px 20px 56px}.photo-grid-item{aspect-ratio:1;background:var(--bg-darker);border-radius:6px;overflow:hidden;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease;position:relative;animation:photoReveal .35s cubic-bezier(.16,1,.3,1) both}.photo-grid-item:nth-child(1){animation-delay:.04s}.photo-grid-item:nth-child(2){animation-delay:.08s}.photo-grid-item:nth-child(3){animation-delay:.12s}.photo-grid-item:nth-child(4){animation-delay:.16s}.photo-grid-item:nth-child(5){animation-delay:.2s}.photo-grid-item:nth-child(n+6){animation-delay:.24s}.photo-grid-item:hover{transform:scale(1.05);box-shadow:0 6px 20px #0006}.photo-grid-item img,.photo-grid-item video{width:100%;height:100%;object-fit:cover}.photo-grid-item.is-video .video-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:#0009;border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:background .2s}.video-player-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.video-player-container video{max-width:100%;max-height:100%;border-radius:4px}.video-fallback{flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px;text-align:center;color:var(--text-muted)}.video-fallback svg{color:var(--text-secondary);opacity:.5}.video-fallback p{font-size:14px;max-width:300px}} .photo-grid-item.is-video:hover .video-indicator{background:#4a9effcc}.photo-grid-item.is-video:after{content:"";position:absolute;bottom:6px;right:6px;width:8px;height:8px;background:var(--accent-red);border-radius:50%}.photo-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;z-index:2000;display:flex;align-items:center;justify-content:center;animation:modalFadeIn .25s ease-out}.photo-modal{position:relative;width:95%;max-width:1400px;height:90vh;background:var(--bg-darker);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideUp .35s cubic-bezier(.16,1,.3,1)}.photo-modal-close{position:absolute;top:16px;left:16px;width:40px;height:40px;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center}.photo-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center}.photo-set-indicator{position:absolute;top:16px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;z-index:10;background:#000000b3;padding:10px 20px;border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.photo-set-indicator .set-position{font-size:14px;font-weight:600;color:#fff}.photo-set-indicator .set-number{font-size:11px;color:#fff9}.photo-nav-btn:hover{background:#000000b3}.photo-nav-btn.prev{left:16px}.photo-nav-btn.next{right:340px}.photo-modal-content{display:flex;flex:1;overflow:hidden}.photo-modal-image{flex:1;display:flex;align-items:center;justify-content:center;background:#000;padding:20px}.photo-modal-image img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.photo-modal-sidebar{width:320px;background:var(--bg-card);display:flex;flex-direction:column;overflow-y:auto}.photo-modal-header{padding:20px;border-bottom:1px solid var(--border)}.photo-modal-header h2{font-size:18px;font-weight:600}.photo-detail-section{padding:20px;border-bottom:1px solid var(--border)}.photo-detail-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px}.photo-detail-row{margin-bottom:14px}.photo-detail-row:last-child{margin-bottom:0}.photo-detail-label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.photo-detail-value{display:block;font-size:13px;color:var(--text-secondary)}.photo-detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.photo-tag-badge{background:var(--accent-blue);color:#fff;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500}.photo-map{margin-top:8px;height:150px;border-radius:8px;overflow:hidden}.photo-map iframe{width:100%;height:100%;border:none}.map-link{display:block;margin-top:8px;font-size:12px;color:var(--accent-blue)}.page-with-sidebar>.page-sidebar .filter-section{animation:fadeSlideUp .5s ease-out both}.page-with-sidebar>.page-sidebar .filter-section:nth-child(1){animation-delay:.1s}.page-with-sidebar>.page-sidebar .filter-section:nth-child(2){animation-delay:.2s}.photo-modal-image img,.photo-modal-image .video-player-container{animation:modalFadeIn .2s ease-out}@media (max-width: 1024px){.photo-group-grid{grid-template-columns:repeat(3,1fr);padding-left:20px}.photo-nav-btn.next{right:16px}.photo-modal-sidebar{display:none}}.employee-detail{max-width:1400px;margin:0 auto}.employee-detail-loading,.employee-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:16px;color:var(--text-muted)}.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.back-btn{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:10px 16px;color:var(--text-secondary);cursor:pointer;font-size:14px;transition:all .2s}.back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.period-selector .form-select{min-width:150px}.profile-card{background:linear-gradient(135deg,#1e3a5f,#2d5a87);border-radius:20px;padding:32px;display:flex;align-items:center;gap:24px;margin-bottom:24px;position:relative;overflow:hidden}.profile-card:before{content:"";position:absolute;top:-50%;right:-20%;width:50%;height:150%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);pointer-events:none}.profile-avatar{width:100px;height:100px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:#fff;flex-shrink:0}.profile-info{flex:1}.profile-info h1{font-size:28px;font-weight:700;color:#fff;margin-bottom:8px}.profile-badges{display:flex;gap:10px;margin-bottom:12px}.role-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background:#ffffff26;color:#fff}.role-badge.manager{background:#6366f166}.role-badge.admin{background:#ef44444d}.role-badge.board-member{background:#8b5cf64d}.pay-badge{display:flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background:#22c55e4d;color:#4ade80}.profile-contact{display:flex;gap:20px;color:#ffffffb3;font-size:13px}.profile-contact span{display:flex;align-items:center;gap:6px}.profile-summary{display:flex;gap:32px;background:#0003;padding:20px 28px;border-radius:16px}.summary-item{text-align:center}.summary-value{font-size:28px;font-weight:700;color:#fff;line-height:1;margin-bottom:4px}.summary-label{font-size:12px;color:#fff9}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.stat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card.blue .stat-icon{background:#3b82f626;color:#3b82f6}.stat-card.green .stat-icon{background:#22c55e26;color:#22c55e}.stat-card.purple .stat-icon{background:#8b5cf626;color:#8b5cf6}.stat-card.orange .stat-icon{background:#f9731626;color:#f97316}.stat-card.cyan .stat-icon{background:#06b6d426;color:#06b6d4}.stat-card.teal .stat-icon{background:#14b8a626;color:#14b8a6}.stat-card.indigo .stat-icon{background:#6366f126;color:#6366f1}.stat-card.red .stat-icon{background:#ef444426;color:#ef4444}.stat-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.stat-label{font-size:13px;color:var(--text-muted)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.detail-section{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border)}.section-header h2{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text-primary)}.section-count{font-size:13px;color:var(--text-muted)}.entries-list{max-height:400px;overflow-y:auto}.empty-state{padding:40px;text-align:center;color:var(--text-muted)}.entry-row{display:flex;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .2s}.entry-row:last-child{border-bottom:none}.entry-row:hover{background:var(--bg-hover)}.entry-row.active{background:#22c55e0d}.entry-date{flex:1;min-width:0}.entry-day{font-weight:600;font-size:14px;margin-bottom:2px}.entry-site{font-size:12px;color:var(--text-muted)}.entry-times{display:flex;align-items:center;gap:8px;font-size:14px;min-width:160px}.time-in{color:var(--accent-green)}.time-separator{color:var(--text-muted)}.time-out{color:var(--accent-orange)}.entry-hours{font-weight:600;font-size:14px;min-width:80px;text-align:right}.entry-status{display:flex;align-items:center;gap:8px;min-width:80px;justify-content:flex-end}.violation-badge{color:var(--accent-orange)}.active-badge{background:#22c55e26;color:var(--accent-green);padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600}.breakdown-content{padding:20px}.breakdown-summary{font-size:16px;color:var(--text-secondary)}.breakdown-summary strong{color:var(--accent-cyan);font-size:24px}.breakdown-list{display:flex;flex-direction:column;gap:12px}.breakdown-row{display:flex;align-items:center;gap:12px}.breakdown-label{font-size:13px;color:var(--text-secondary);min-width:140px}.breakdown-bar-container{flex:1;height:8px;background:var(--bg-darker);border-radius:4px;overflow:hidden}.breakdown-bar{height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-blue));border-radius:4px;min-width:4px}.breakdown-value{font-size:14px;font-weight:600;color:var(--text-primary);min-width:60px;text-align:right}.payroll-section{grid-column:span 2}.payroll-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}.payroll-item{background:var(--bg-card);padding:20px;display:flex;flex-direction:column;gap:4px}.payroll-item.total{background:var(--bg-darker)}.payroll-label{font-size:13px;color:var(--text-muted)}.payroll-value{font-size:20px;font-weight:700;color:var(--text-primary)}.payroll-item.total .payroll-value{color:var(--accent-green)}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}.metric-item{background:var(--bg-card);padding:20px;display:flex;align-items:center;gap:14px}.metric-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.metric-icon.blue{background:#3b82f626;color:#3b82f6}.metric-icon.purple{background:#8b5cf626;color:#8b5cf6}.metric-icon.orange{background:#f9731626;color:#f97316}.metric-icon.green{background:#22c55e26;color:#22c55e}.metric-icon.teal{background:#14b8a626;color:#14b8a6}.metric-icon.red{background:#ef444426;color:#ef4444}.metric-value{font-size:24px;font-weight:700;color:var(--text-primary)}.metric-label{font-size:12px;color:var(--text-muted)}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}.payroll-section{grid-column:span 1}.payroll-grid,.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.profile-card{flex-direction:column;text-align:center}.profile-info{display:flex;flex-direction:column;align-items:center}.profile-contact{flex-direction:column;gap:8px}.profile-summary{width:100%;justify-content:center}}@media (max-width: 600px){.stats-grid,.payroll-grid,.metrics-grid{grid-template-columns:1fr}.entry-row{flex-wrap:wrap;gap:8px}.entry-times,.entry-hours,.entry-status{min-width:auto}.breakdown-row{flex-wrap:wrap}.breakdown-label{min-width:100%}}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.stat-card.clickable:after{content:"→";position:absolute;right:16px;top:50%;transform:translateY(-50%);opacity:0;transition:opacity .2s;color:var(--text-muted)}.stat-card.clickable:hover:after{opacity:1}.stat-card{position:relative}.detail-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.detail-modal{background:var(--bg-card);border-radius:20px;width:100%;max-width:900px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.detail-modal-close{position:absolute;top:20px;right:20px;background:var(--bg-darker);border:none;border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s;z-index:10}.detail-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.detail-modal-header{display:flex;align-items:center;gap:12px;padding:24px 24px 0;color:var(--text-primary)}.detail-modal-header h2{font-size:20px;font-weight:600}.detail-modal-header svg{color:var(--accent-cyan)}.detail-modal-summary{padding:20px 24px;text-align:center;border-bottom:1px solid var(--border)}.modal-stat{font-size:48px;font-weight:700;color:var(--accent-cyan);line-height:1;margin-bottom:4px}.modal-stat.green{color:var(--accent-green)}.modal-stat.purple{color:#8b5cf6}.modal-stat.orange{color:var(--accent-orange)}.modal-stat.cyan{color:#06b6d4}.modal-stat.teal{color:#14b8a6}.modal-stat.indigo{color:#6366f1}.modal-stat.red{color:var(--accent-red)}.modal-stat-label{font-size:14px;color:var(--text-muted)}.detail-modal-content{padding:24px;overflow-y:auto;flex:1}.detail-modal-content h3{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px}.detail-table{width:100%;border-collapse:collapse}.detail-table th,.detail-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);font-size:14px}.detail-table th{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;background:var(--bg-darker)}.detail-table tr:hover td{background:var(--bg-hover)}.active-tag{background:#22c55e26;color:var(--accent-green);padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600}.pay-breakdown{padding:0 24px 24px}.pay-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px}.pay-row.total{border-bottom:none;font-size:18px;font-weight:700;color:var(--accent-green);padding-top:16px}.status-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:capitalize}.status-badge.open,.status-badge.pending{background:#3b82f626;color:#3b82f6}.status-badge.in-progress{background:#f59e0b26;color:#f59e0b}.status-badge.completed,.status-badge.closed,.status-badge.done{background:#22c55e26;color:#22c55e}.priority-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:capitalize}.priority-badge.low{background:#6b728026;color:#6b7280}.priority-badge.normal{background:#3b82f626;color:#3b82f6}.priority-badge.high{background:#f9731626;color:#f97316}.priority-badge.urgent{background:#ef444426;color:#ef4444}.violation-type{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600}.violation-type.clockIn{background:#22c55e26;color:#22c55e}.violation-type.clockOut{background:#ef444426;color:#ef4444}.map-link{display:inline-flex;align-items:center;gap:4px;color:var(--accent-blue);text-decoration:none;font-size:13px}.map-link:hover{text-decoration:underline}.map-link-btn{display:inline-flex;align-items:center;gap:4px;color:var(--accent-blue);background:none;border:none;font-size:13px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s}.map-link-btn:hover{background:#4a9eff1a}.map-view-container{display:flex;flex-direction:column;gap:16px}.map-view-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:16px;border-bottom:1px solid var(--border)}.back-to-list{display:flex;align-items:center;gap:6px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;padding:8px 14px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.back-to-list:hover{background:var(--bg-hover);color:var(--text-primary)}.map-view-info{display:flex;align-items:center;gap:12px}.map-view-site{font-weight:600;color:var(--text-primary)}.map-view-date{color:var(--text-muted);font-size:13px}.map-embed{border-radius:12px;overflow:hidden;background:var(--bg-darker)}.map-embed iframe{display:block}.map-detail{display:flex;flex-direction:column;gap:2px}.map-detail-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.map-detail-value{font-size:14px;font-weight:600;color:var(--text-primary)}.map-detail-value.distance{color:var(--accent-orange)}.map-external-link{margin-left:auto;display:flex;align-items:center;gap:6px}.clickable-table tbody tr{cursor:pointer}.clickable-table tbody tr:hover td{background:#4a9eff1a}.clickable-row{cursor:pointer}.ticket-detail-view{display:flex;flex-direction:column;gap:20px}.ticket-detail-header{display:flex;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--border)}.ticket-detail-title{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.ticket-detail-title h3{font-size:22px;font-weight:700;color:var(--text-primary);margin:0;flex:1}.ticket-badges{display:flex;gap:8px;flex-shrink:0}.ticket-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;padding:20px;background:var(--bg-darker);border-radius:12px}.ticket-detail-item{display:flex;flex-direction:column;gap:4px}.ticket-detail-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.ticket-detail-value{font-size:15px;color:var(--text-primary)}.ticket-detail-value.completed{color:var(--accent-green);font-weight:600}.ticket-description,.ticket-notes,.ticket-location,.ticket-images{padding:20px;background:var(--bg-darker);border-radius:12px}.ticket-description h4,.ticket-notes h4,.ticket-location h4,.ticket-images h4{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin:0 0 12px}.ticket-description p,.ticket-notes p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0;white-space:pre-wrap}.ticket-notes{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2)}.ticket-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.ticket-images-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;cursor:pointer;transition:transform .2s}.ticket-images-grid img:hover{transform:scale(1.02)}.photo-detail-view{display:flex;flex-direction:column;gap:20px}.photo-detail-header{display:flex;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--border)}.photo-detail-image{display:flex;justify-content:center;background:var(--bg-darker);border-radius:12px;overflow:hidden}.photo-detail-image img{max-width:100%;max-height:400px;object-fit:contain}.photo-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;padding:20px;background:var(--bg-darker);border-radius:12px}.photo-detail-item{display:flex;flex-direction:column;gap:4px}.photo-detail-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.photo-detail-value{font-size:15px;color:var(--text-primary)}.photo-comment-section,.photo-location{padding:20px;background:var(--bg-darker);border-radius:12px}.photo-comment-section h4,.photo-location h4{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin:0 0 12px}.photo-comment-section p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}.photo-item-modal.clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.photo-item-modal.clickable:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.video-thumbnail{position:relative;width:100%;aspect-ratio:1;background:var(--bg-darker);overflow:hidden}.video-thumbnail img,.video-thumbnail video{width:100%;height:100%;object-fit:cover}.video-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;pointer-events:none}.media-type-badge{display:inline-block;background:var(--accent-purple);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;margin-right:6px;vertical-align:middle}.photo-detail-video{display:flex;justify-content:center;background:var(--bg-darker);border-radius:12px;padding:20px}.map-legend{display:flex;gap:24px;padding:12px 16px;background:var(--bg-darker);border-radius:8px;margin-bottom:16px}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.legend-marker{width:12px;height:12px;border-radius:50%}.legend-marker.employee{background:#ef4444;box-shadow:0 0 0 3px #ef44444d}.legend-marker.site{background:#22c55e;box-shadow:0 0 0 3px #22c55e4d}.map-external-links{display:flex;justify-content:flex-end;margin-top:16px}.map-view-details{display:flex;flex-wrap:wrap;gap:24px;padding:16px;background:var(--bg-darker);border-radius:12px}.photos-grid-modal{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.photo-item-modal{background:var(--bg-darker);border-radius:12px;overflow:hidden}.photo-item-modal img{width:100%;aspect-ratio:1;object-fit:cover}.photo-item-info{padding:12px}.photo-item-site{font-weight:600;font-size:13px;margin-bottom:4px}.photo-item-date{font-size:12px;color:var(--text-muted)}.photo-item-comment{font-size:12px;color:var(--text-secondary);margin-top:8px;font-style:italic}.avg-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:0 24px 24px}.avg-stat{background:var(--bg-darker);padding:16px;border-radius:12px;text-align:center}.avg-label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:4px}.avg-value{font-size:24px;font-weight:700;color:var(--text-primary)}.hours-chart{display:flex;align-items:flex-end;gap:8px;height:200px;padding:20px 0}.hours-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.hours-bar-container{flex:1;width:100%;max-width:40px;display:flex;align-items:flex-end;justify-content:center}.hours-bar{width:100%;background:linear-gradient(180deg,var(--accent-cyan),var(--accent-blue));border-radius:4px 4px 0 0;min-height:4px;transition:height .3s ease}.hours-bar.overtime{background:linear-gradient(180deg,var(--accent-orange),var(--accent-red))}.hours-bar-value{font-size:11px;font-weight:600;color:var(--text-primary);margin-top:8px}.hours-bar-label{font-size:10px;color:var(--text-muted);white-space:nowrap}.overtime-info{padding:0 24px;margin-bottom:16px}.overtime-info p{font-size:13px;color:var(--text-muted);background:var(--bg-darker);padding:12px 16px;border-radius:8px}.overtime-value{color:var(--accent-orange)}.overtime-pay{color:var(--accent-green)}.empty-modal{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}@media (max-width: 768px){.detail-modal{max-height:90vh;border-radius:16px 16px 0 0;margin-top:auto}.avg-stats{grid-template-columns:1fr}.photos-grid-modal{grid-template-columns:repeat(2,1fr)}.detail-table{font-size:12px}.detail-table th,.detail-table td{padding:8px 10px}}.timecards-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.timecards-stats{display:flex;gap:12px;flex-wrap:wrap}.timecards-actions{display:flex;gap:8px;align-items:center}.stat-badge{background:var(--bg-card);padding:10px 18px;border-radius:10px;font-size:13px;color:var(--text-secondary);border:1px solid var(--border);display:flex;align-items:center;gap:6px}.stat-badge strong{color:var(--text-primary);font-size:16px}.stat-badge.cyan{border-left:3px solid var(--accent-cyan);background:linear-gradient(90deg,rgba(0,212,170,.1),transparent)}.stat-badge.cyan strong{color:var(--accent-cyan)}.stat-badge.green{border-left:3px solid var(--accent-green);background:linear-gradient(90deg,rgba(38,222,129,.1),transparent)}.stat-badge.green strong,.status-active{color:var(--accent-green)}.status-completed{color:var(--text-muted)}.group-options{display:flex;flex-direction:column;gap:8px}.group-option{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.group-option:hover{border-color:var(--accent-blue)}.group-option input[type=radio]{accent-color:var(--accent-blue)}.group-option span{font-size:13px;color:var(--text-secondary)}.group-option:has(input:checked){border-color:var(--accent-blue);background:#4a9eff1a}.group-option:has(input:checked) span{color:var(--text-primary)}.timecards-groups{margin-top:16px}.timecard-group{background:var(--bg-card);border-radius:12px;margin-bottom:16px;overflow:hidden;border:1px solid var(--border)}.timecard-group-header{display:flex;align-items:center;padding:16px 20px;cursor:pointer;transition:background .2s}.timecard-group-header:hover{background:var(--bg-hover)}.group-toggle{color:var(--text-muted);margin-right:12px;display:flex;align-items:center}.group-avatar{margin-right:12px}.group-avatar .avatar.site{background:linear-gradient(135deg,var(--accent-orange),var(--accent-red))}.group-info{flex:1}.group-name{font-size:15px;font-weight:600;margin-bottom:4px}.group-meta{font-size:13px;color:var(--text-secondary)}.group-meta .active-badge{color:var(--accent-green)}.group-stats{text-align:right}.group-hours{font-size:18px;font-weight:700;color:var(--accent-cyan)}.timecard-group-body{border-top:1px solid var(--border)}.timecard-group-body .data-table th{background:var(--bg-card)}.time-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:2000;display:flex;align-items:center;justify-content:center;overflow-y:auto;padding:20px}.time-modal{background:var(--bg-card);border-radius:12px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto}.time-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-card);z-index:1}.time-modal-header h2{font-size:18px;font-weight:600}.time-modal-body{padding:20px}.time-detail-section{margin-bottom:24px}.time-detail-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px}.time-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.time-detail-card{background:var(--bg-darker);padding:16px;border-radius:8px}.time-detail-card.green{border-left:3px solid var(--accent-green)}.time-detail-card.red{border-left:3px solid var(--accent-red)}.time-detail-card .label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:6px}.time-detail-card .value{display:block;font-size:18px;font-weight:600}.time-detail-card .value.cyan{color:var(--accent-cyan)}.time-location-maps{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:12px}.time-location-box{background:var(--bg-darker);border-radius:8px;overflow:hidden}.time-location-header{padding:12px;display:flex;align-items:center;justify-content:space-between}.location-badge{font-size:12px;font-weight:600}.location-badge.green{color:var(--accent-green)}.location-badge.red{color:var(--accent-red)}.time-coords{font-size:11px;color:var(--text-muted);font-family:monospace}.time-map{height:150px;background:var(--bg-dark)}.time-map iframe{width:100%;height:100%;border:none}.time-map .no-location{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px}.map-link{display:block;padding:10px 12px;font-size:12px;color:var(--accent-blue);text-align:center;border-top:1px solid var(--border)}.map-link:hover{background:var(--bg-hover);text-decoration:none}@media (max-width: 768px){.time-location-maps,.time-detail-grid{grid-template-columns:1fr}}.edit-notice{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f59e0b26;border:1px solid rgba(245,158,11,.3);border-radius:10px;margin-bottom:20px;font-size:13px;color:#f59e0b}.edit-notice .edit-date{margin-left:auto;font-size:11px;color:var(--text-muted)}.time-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.time-detail-header .time-detail-title{margin-bottom:0}.btn-edit{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;color:var(--accent-blue);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-edit:hover{background:#4a9eff1a;border-color:var(--accent-blue)}.edit-actions{display:flex;gap:8px}.btn-cancel{padding:6px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--bg-hover)}.btn-save{display:flex;align-items:center;gap:6px;padding:6px 14px;background:var(--accent-green);border:none;border-radius:8px;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-save:hover{background:#16a34a}.btn-save:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.edit-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;margin-bottom:16px;font-size:13px;color:#ef4444}.edit-form{background:var(--bg-darker);border-radius:12px;padding:16px}.edit-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.edit-form-group{display:flex;flex-direction:column;gap:6px}.edit-form-group.full-width{grid-column:span 2}.edit-form-group label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.edit-form-group label .required{color:#ef4444}.edit-form-group input,.edit-form-group textarea{padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px}.edit-form-group input:focus,.edit-form-group textarea:focus{outline:none;border-color:var(--accent-cyan)}.edit-form-group textarea{resize:vertical;font-family:inherit}.edit-preview{display:flex;align-items:center;gap:8px;padding:12px;background:#22d3ee1a;border-radius:8px;margin-top:12px;font-size:14px;color:var(--text-secondary)}.edit-preview svg{color:var(--accent-cyan)}.edit-preview strong{color:var(--accent-cyan)}.edit-history{display:flex;flex-direction:column;gap:12px}.edit-history-item{background:var(--bg-darker);border-radius:10px;padding:14px;border-left:3px solid var(--accent-orange)}.edit-history-header{display:flex;justify-content:space-between;margin-bottom:10px}.edit-history-date{font-size:13px;font-weight:600;color:var(--text-primary)}.edit-history-by{font-size:12px;color:var(--text-muted)}.edit-history-changes{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.edit-change{display:flex;align-items:center;gap:8px;font-size:13px}.change-label{color:var(--text-muted);min-width:70px}.change-old{color:var(--accent-red);text-decoration:line-through}.change-arrow{color:var(--text-muted)}.change-new{color:var(--accent-green);font-weight:500}.edit-history-reason{font-size:12px;color:var(--text-secondary);padding-top:8px;border-top:1px solid var(--border)}.edit-history-reason strong{color:var(--text-primary)}@media (max-width: 600px){.edit-form-row{grid-template-columns:1fr}.edit-form-group.full-width{grid-column:span 1}}.row-archived{opacity:.55;background:#ef44440a}.row-archived:hover{opacity:.75}.text-strikethrough{text-decoration:line-through}.status-archived{color:#ef4444;background:#ef44441a;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:500;white-space:nowrap}.archive-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;padding:8px 0;margin-top:4px}.archive-toggle input[type=checkbox]{accent-color:#ef4444}.btn-archive{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;color:#ef4444;background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:6px;cursor:pointer;transition:all .2s}.btn-archive:hover{background:#ef44441a;border-color:#ef4444}.archive-form{background:#ef44440a;border:1px solid rgba(239,68,68,.15);border-radius:8px;padding:16px;margin-top:12px}.archive-warning{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#facc151a;border:1px solid rgba(250,204,21,.25);border-radius:6px;font-size:12px;color:var(--text-secondary);margin-bottom:12px}.archive-warning svg{color:#f59e0b;flex-shrink:0;margin-top:1px}.archive-reason-select{width:100%}.archive-form .form-group{margin-bottom:12px}.archive-form textarea{width:100%;padding:8px 10px;font-size:13px;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-primary);resize:vertical}.archive-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;color:#fff;background:#ef4444;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.archive-notice{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;margin-bottom:16px}.archive-notice-content{display:flex;align-items:flex-start;gap:10px;color:#ef4444}.archive-notice-content strong{display:block;font-size:13px;margin-bottom:2px}.archive-notice-meta{font-size:11px;color:var(--text-muted)}.btn-restore{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:12px;color:#22c55e;background:transparent;border:1px solid rgba(34,197,94,.3);border-radius:6px;cursor:pointer;font-weight:500;white-space:nowrap;transition:all .2s}.btn-restore:hover{background:#22c55e1a;border-color:#22c55e}.btn-restore:disabled{opacity:.6;cursor:not-allowed}.history-archive{border-left:3px solid #ef4444}.history-restore{border-left:3px solid #22c55e}.history-action-label{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;margin-bottom:4px}.archive-label{color:#ef4444;background:#ef44441a}.restore-label{color:#22c55e;background:#22c55e1a}.btn-clockout{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;color:#f59e0b;background:transparent;border:1px solid rgba(245,158,11,.3);border-radius:6px;cursor:pointer;transition:all .2s}.btn-clockout:hover{background:#f59e0b1a;border-color:#f59e0b}.clockout-form{background:#f59e0b0a;border:1px solid rgba(245,158,11,.15);border-radius:8px;padding:16px;margin-top:12px}.clockout-warning{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);border-radius:6px;font-size:12px;color:var(--text-secondary);margin-bottom:12px}.clockout-warning svg{color:#f59e0b;flex-shrink:0;margin-top:1px}.clockout-form .form-group,.clockout-form .edit-form-row{margin-bottom:12px}.clockout-form textarea{width:100%;padding:8px 10px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;resize:vertical}.history-clockout{border-left:3px solid #f59e0b}.clockout-label{color:#f59e0b;background:#f59e0b1a}.scheduling-page{display:flex;gap:24px}.scheduling-sidebar{width:280px;flex-shrink:0}.scheduling-main{flex:1;overflow:hidden}.employee-pool{max-height:300px;overflow-y:auto}.employee-drag-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;cursor:grab;transition:all .2s}.employee-drag-item:hover{border-color:var(--accent-blue);background:var(--bg-hover)}.employee-drag-item:active{cursor:grabbing}.emp-info{flex:1}.emp-name{font-size:13px;font-weight:600}.emp-rate{font-size:11px;color:var(--accent-green)}.budget-summary{padding:4px 0}.budget-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px}.budget-row span{color:var(--text-secondary)}.budget-row strong{color:var(--text-primary)}.budget-row .cost{color:var(--accent-cyan);font-size:16px}.budget-row .remaining{color:var(--accent-green);font-size:16px}.budget-row .over-budget{color:var(--accent-red);font-size:16px}.budget-divider{height:1px;background:var(--border);margin:8px 0}.budget-input{width:100px;padding:6px 10px;background:var(--bg-darker);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:13px;text-align:right}.budget-bar{height:8px;background:var(--bg-darker);border-radius:4px;overflow:hidden;margin-top:12px}.budget-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-green),var(--accent-cyan));border-radius:4px;transition:width .3s,background .3s}.budget-bar-fill.warning{background:linear-gradient(90deg,var(--accent-orange),var(--accent-red))}.scheduling-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}.scheduling-nav{display:flex;align-items:center;gap:8px}.nav-btn{width:36px;height:36px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.scheduling-period{font-size:16px;font-weight:600;margin-left:8px}.scheduling-actions{display:flex;gap:8px}.schedule-calendar{background:var(--bg-card);border-radius:12px;overflow:hidden;border:1px solid var(--border)}.schedule-header{display:grid;grid-template-columns:80px repeat(7,1fr);border-bottom:1px solid var(--border)}.schedule-header-cell{padding:12px 8px;text-align:center;font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--bg-darker)}.schedule-header-cell.time-col{text-align:left;padding-left:12px}.schedule-header-cell .date{display:block;font-size:18px;color:var(--text-primary);margin-top:2px}.schedule-header-cell.today{background:var(--accent-blue);color:#fff}.schedule-header-cell.today .date{color:#fff}.schedule-body{max-height:500px;overflow-y:auto}.schedule-row{display:grid;grid-template-columns:80px repeat(7,1fr);border-bottom:1px solid var(--border)}.schedule-row:last-child{border-bottom:none}.schedule-time{padding:8px 12px;font-size:11px;color:var(--text-muted);background:var(--bg-darker);display:flex;align-items:flex-start}.schedule-cell{min-height:60px;padding:4px;border-left:1px solid var(--border);position:relative;transition:background .2s}.schedule-cell:hover{background:var(--bg-hover)}.schedule-cell.today{background:#4a9eff0d}.schedule-shift{padding:6px 8px;border-radius:6px;font-size:11px;margin-bottom:4px;cursor:pointer;position:relative;transition:all .2s}.schedule-shift:hover{transform:scale(1.02)}.shift-name{font-weight:600;margin-bottom:2px}.shift-time{opacity:.8;font-size:10px}.shift-remove{position:absolute;top:2px;right:4px;width:16px;height:16px;border:none;background:#0000004d;color:#fff;border-radius:50%;font-size:10px;cursor:pointer;opacity:0;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.schedule-shift:hover .shift-remove{opacity:1}.shift-color-1{background:linear-gradient(135deg,#4a9eff,#7c6aef);color:#fff}.shift-color-2{background:linear-gradient(135deg,#00d4aa,#4a9eff);color:#fff}.shift-color-3{background:linear-gradient(135deg,#ff9f43,#ff6b6b);color:#fff}.shift-color-4{background:linear-gradient(135deg,#7c6aef,#ff6b6b);color:#fff}.shift-color-5{background:linear-gradient(135deg,#26de81,#00d4aa);color:#fff}@media (max-width: 1024px){.scheduling-page{flex-direction:column}.scheduling-sidebar{width:100%}.schedule-header,.schedule-row{grid-template-columns:60px repeat(7,1fr)}}.reports-page{max-width:1200px;margin:0 auto}.reports-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.reports-filters{display:flex;gap:16px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;color:var(--text-muted);font-weight:500}.filter-group .form-select,.filter-group .form-input{min-width:160px}.reports-actions{display:flex;gap:8px}.report-container{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);overflow:hidden}.report-header{display:flex;align-items:center;justify-content:space-between;padding:24px 32px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}.report-header-left{display:flex;align-items:center;gap:16px}.report-logo{font-size:40px;background:#fff3;width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center}.report-title-section h1{font-size:26px;font-weight:700;margin-bottom:4px}.report-date{font-size:15px;opacity:.9;display:flex;align-items:center;gap:8px}.today-badge{background:#ffffff40;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.report-header-right{text-align:right}.report-company{font-size:14px;font-weight:600;margin-bottom:4px}.report-generated{font-size:11px;opacity:.7}.report-summary{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;padding:20px 24px;background:var(--bg-darker);border-bottom:1px solid var(--border)}.summary-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border-radius:10px;border:1px solid var(--border)}.summary-icon{width:44px;height:44px;background:#4a9eff26;color:var(--accent-blue);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon.green{background:#26de8126;color:var(--accent-green)}.summary-icon.purple{background:#7c6aef26;color:var(--accent-purple)}.summary-icon.orange{background:#ff9f4326;color:var(--accent-orange)}.summary-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1}.summary-label{font-size:12px;color:var(--text-muted);margin-top:2px}.report-alert{display:flex;align-items:center;gap:10px;padding:12px 24px;background:#ff9f431a;border-bottom:1px solid var(--border);color:var(--accent-orange);font-size:13px}.report-section{padding:24px;border-bottom:1px solid var(--border)}.report-section:last-child{border-bottom:none}.report-section h2{font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px;color:var(--text-primary)}.no-data{text-align:center;color:var(--text-muted);padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.site-card{background:var(--bg-darker);border:1px solid var(--border);border-radius:10px;padding:16px}.site-card-header{margin-bottom:12px}.site-name{font-weight:600;font-size:15px;margin-bottom:2px}.site-address{font-size:12px;color:var(--text-muted)}.site-card-stats{display:flex;gap:16px}.site-stat{text-align:center}.site-stat-value{display:block;font-size:18px;font-weight:700;color:var(--accent-cyan)}.site-stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase}.employee-report-card{background:var(--bg-darker);border-radius:10px;border:1px solid var(--border);margin-bottom:16px;overflow:hidden}.employee-report-card:last-child{margin-bottom:0}.employee-report-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-card);border-bottom:1px solid var(--border)}.employee-info{display:flex;align-items:center;gap:14px}.avatar-lg{width:48px;height:48px;font-size:18px}.employee-name{font-weight:600;font-size:16px;margin-bottom:4px}.employee-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.role-badge{font-size:11px;padding:2px 8px;background:#ffffff1a;border-radius:4px;color:var(--text-secondary)}.role-badge.manager{background:#4a9eff26;color:var(--accent-blue)}.pay-rate{font-size:12px;color:var(--accent-green);font-weight:500}.sites-worked{font-size:12px;color:var(--text-muted)}.employee-summary{display:flex;gap:24px}.summary-stat{text-align:center}.summary-stat .stat-value{display:block;font-size:22px;font-weight:700;color:var(--accent-cyan)}.summary-stat .stat-value.cost{color:var(--accent-green)}.summary-stat .stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.employee-section{padding:16px 20px;border-bottom:1px solid var(--border)}.employee-section:last-child{border-bottom:none}.employee-section h4{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:6px}.mini-table{width:100%;border-collapse:collapse;font-size:13px}.mini-table th,.mini-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}.mini-table th{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;background:#0003}.mini-table tr:last-child td{border-bottom:none}.mini-table tr.active-row{background:#26de810d}.cell-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.cost{color:var(--accent-cyan);font-weight:600}.status-badge{font-size:12px;font-weight:500}.status-badge.active{color:var(--accent-green)}.status-badge.completed{color:var(--text-muted)}.gps-section{margin-top:16px;padding-top:16px;border-top:1px dashed var(--border)}.gps-section h5{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:6px}.gps-grid{display:flex;flex-direction:column;gap:8px}.gps-entry{background:var(--bg-card);padding:10px 12px;border-radius:6px}.gps-site{font-size:12px;font-weight:600;margin-bottom:6px}.gps-locations{display:flex;flex-wrap:wrap;gap:16px}.gps-item{display:flex;align-items:center;gap:6px;font-size:12px}.gps-item .gps-label{color:var(--text-muted);font-weight:500}.gps-item.in .gps-label{color:var(--accent-green)}.gps-item.out .gps-label{color:var(--accent-red)}.gps-item a{font-family:monospace;font-size:11px}.notes-section{margin-top:16px;padding-top:16px;border-top:1px dashed var(--border)}.notes-section h5{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:6px}.note-item{background:var(--bg-card);padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:6px}.note-site{font-weight:600;margin-right:8px}.note-text{color:var(--text-secondary)}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.photo-item{background:var(--bg-card);border-radius:8px;overflow:hidden;border:1px solid var(--border)}.photo-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.photo-overlay{padding:8px 10px;background:var(--bg-darker);display:flex;justify-content:space-between;align-items:center}.photo-time{font-size:11px;color:var(--text-secondary);font-weight:500}.photo-site{font-size:10px;color:var(--text-muted)}.photo-caption{padding:6px 10px;font-size:11px;color:var(--text-secondary);border-top:1px solid var(--border)}.photo-tags{padding:4px 10px 8px;display:flex;flex-wrap:wrap;gap:4px}.photo-tag{font-size:10px;color:var(--accent-blue)}.show-more-btn{width:100%;margin-top:12px;padding:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--accent-blue);font-size:13px;cursor:pointer;transition:all .2s}.show-more-btn:hover{background:var(--bg-hover)}.report-table{width:100%;border-collapse:collapse}.report-table th,.report-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.report-table th{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;background:var(--bg-darker)}.report-table tbody tr:hover td{background:var(--bg-hover)}.report-table tr.active-row td{background:#26de810d}.report-table tfoot td{background:var(--bg-darker);font-weight:600}.table-employee{display:flex;align-items:center;gap:10px}.report-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--bg-darker);font-size:12px;color:var(--text-muted);border-top:1px solid var(--border)}@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}body{background:#fff!important;color:#1a1a1a!important;font-size:11px}.no-print,.reports-toolbar,.sidebar,.header,.show-more-btn{display:none!important}.main-content{margin-left:0!important}.page-content{padding:0!important}.reports-page{max-width:100%}.report-container{border:none;box-shadow:none;border-radius:0}.report-header{background:#2563eb!important;padding:20px}.report-summary{grid-template-columns:repeat(6,1fr);gap:8px;padding:16px}.summary-card{padding:10px}.summary-value{font-size:18px}.summary-card,.employee-report-card,.report-section,.site-card{break-inside:avoid}.report-section{padding:16px}.report-table{font-size:10px}.report-table th,.report-table td,.mini-table th,.mini-table td{padding:6px 8px}.photos-grid{grid-template-columns:repeat(6,1fr);gap:6px}.photo-item{break-inside:avoid}.photo-overlay,.photo-caption,.photo-tags{padding:4px 6px;font-size:9px}.site-card,.employee-report-card{border:1px solid #ddd}a{color:inherit!important;text-decoration:none!important}.gps-item a{color:#2563eb!important}.report-footer{position:fixed;bottom:0;left:0;right:0;background:#fff!important;border-top:1px solid #ddd;padding:10px 16px}.employee-section{padding:12px 16px}.avatar,.avatar-lg,.avatar-sm{background:#e5e7eb!important;color:#374151!important}}@media (max-width: 1200px){.report-summary{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1024px){.report-summary{grid-template-columns:repeat(2,1fr)}.photos-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.reports-toolbar{flex-direction:column;align-items:stretch}.reports-filters{flex-direction:column}.filter-group .form-select,.filter-group .form-input{width:100%}.reports-actions{justify-content:stretch}.reports-actions .btn{flex:1}.report-header{flex-direction:column;gap:16px;text-align:center;padding:20px}.report-header-left{flex-direction:column}.report-header-right{text-align:center}.report-summary{grid-template-columns:repeat(2,1fr)}.employee-report-header{flex-direction:column;gap:16px;align-items:flex-start}.employee-summary{width:100%;justify-content:space-around}.photos-grid{grid-template-columns:repeat(3,1fr)}.gps-locations{flex-direction:column;gap:8px}.sites-grid{grid-template-columns:1fr}}.map-page{height:calc(100vh - 80px);display:flex;flex-direction:column}.map-page.loading{align-items:center;justify-content:center;color:var(--text-muted)}.map-header{padding:20px 24px;border-bottom:1px solid var(--border)}.map-header h1{font-size:24px;font-weight:700}.map-layout{flex:1;display:flex;overflow:hidden}.map-container-wrapper{flex:1;position:relative}.map-container{width:100%;height:100%;background:var(--bg-darker)}.map-style-toggle{position:absolute;top:16px;left:16px;z-index:1000;display:flex;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #00000026}.style-btn{padding:8px 16px;border:none;background:#fff;color:#333;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.style-btn:hover{background:#f5f5f5}.style-btn.active{background:var(--accent-cyan);color:#fff}.map-sidebar{width:320px;background:var(--bg-card);border-left:1px solid var(--border);overflow-y:auto;flex-shrink:0}.sidebar-section{padding:20px;border-bottom:1px solid var(--border)}.sidebar-section h3{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.settings-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-darker);border-radius:8px}.setting-label{font-size:14px;color:var(--text-primary)}.setting-close{color:var(--text-muted);cursor:pointer}.layer-toggles{display:flex;flex-direction:column;gap:12px}.layer-toggle{display:flex;align-items:center;gap:12px;cursor:pointer;padding:10px 12px;border-radius:8px;transition:background .2s}.layer-toggle:hover{background:var(--bg-hover)}.layer-toggle input{width:18px;height:18px;accent-color:var(--accent-cyan)}.toggle-indicator{width:12px;height:12px;border-radius:50%}.toggle-indicator.employee{background:#22c55e}.toggle-indicator.site{background:#3b82f6}.toggle-indicator.equipment{background:#f59e0b}.layer-toggle span{font-size:14px;color:var(--text-primary)}.toggle-count{margin-left:auto;font-size:12px;color:var(--text-muted);background:var(--bg-darker);padding:2px 8px;border-radius:10px}.filter-group{margin-bottom:16px}.filter-group label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px}.filter-select{width:100%;padding:10px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--accent-cyan)}.apply-btn{width:100%;margin-top:8px}.legend-items{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.employee{background:#6b7280}.legend-dot.employee.active{background:#22c55e}.legend-dot.site{background:#3b82f6}.legend-dot.equipment{background:#f59e0b}.map-stats{display:flex;flex-direction:column;gap:12px}.map-stat{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-darker);border-radius:8px}.map-stat svg{color:var(--accent-cyan)}.map-stat .stat-value{font-size:20px;font-weight:700;color:var(--text-primary);display:block}.map-stat .stat-label{font-size:12px;color:var(--text-muted)}.custom-marker{background:none;border:none}.marker-pin{width:36px;height:36px;background:#fff;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d}.marker-pin svg{transform:rotate(45deg)}.marker-pin.employee{background:#6b7280}.marker-pin.employee.active{background:#22c55e}.marker-pin.site{background:#3b82f6}.marker-pin.equipment{background:#f59e0b}.marker-pin svg{fill:#fff}.marker-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.marker-detail{background:var(--bg-card);border-radius:16px;width:100%;max-width:400px;overflow:hidden;position:relative}.marker-detail .close-btn{position:absolute;top:16px;right:16px;background:#0000004d;border:none;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;z-index:10}.detail-header{padding:24px;display:flex;align-items:center;gap:16px}.detail-header.employee{background:linear-gradient(135deg,#22c55e,#16a34a)}.detail-header.site{background:linear-gradient(135deg,#3b82f6,#2563eb)}.detail-avatar{width:56px;height:56px;background:#fff3;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}.detail-icon{width:56px;height:56px;background:#fff3;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff}.detail-info h3{font-size:18px;font-weight:700;color:#fff;margin-bottom:4px}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600}.status-badge.active{background:#fff3;color:#fff}.status-badge.offline{background:#0003;color:#fffc}.site-type{font-size:13px;color:#fffc}.detail-body{padding:20px 24px}.detail-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text-secondary)}.detail-row:last-child{border-bottom:none}.detail-row svg{color:var(--text-muted);flex-shrink:0}.detail-row.coordinates{font-size:12px;color:var(--text-muted)}.detail-actions{padding:16px 24px 24px}.detail-actions .btn{width:100%}@media (max-width: 900px){.map-layout{flex-direction:column}.map-sidebar{width:100%;max-height:300px;border-left:none;border-top:1px solid var(--border)}.map-container-wrapper{height:400px}}@media (max-width: 600px){.map-sidebar{max-height:250px}.sidebar-section{padding:16px}}.leaflet-container{font-family:inherit}.leaflet-popup-content-wrapper{border-radius:12px}.leaflet-control-zoom{border:none!important;box-shadow:0 2px 8px #00000026!important}.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-primary)!important;border:none!important}.leaflet-control-zoom a:hover{background:var(--bg-hover)!important}.budget-page{padding:24px;max-width:1400px;margin:0 auto}.budget-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.header-left{display:flex;align-items:center;gap:16px}.budget-header h1{font-size:28px;font-weight:700}.period-badge{background:var(--accent-cyan);color:#fff;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600}.header-actions{display:flex;gap:12px}.budget-filters{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.budget-filters .filter-group{display:flex;flex-direction:column;gap:6px}.budget-filters label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.budget-filters select{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;min-width:150px}.budget-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;position:relative}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.summary-card.total-budget .summary-icon{background:#3b82f626;color:#3b82f6}.summary-card.total-spent .summary-icon{background:#ef444426;color:#ef4444}.summary-card.remaining .summary-icon{background:#22c55e26;color:#22c55e}.summary-card.remaining.over-budget .summary-icon{background:#f59e0b26;color:#f59e0b}.summary-card.labor-cost .summary-icon{background:#8b5cf626;color:#8b5cf6}.summary-label{font-size:13px;color:var(--text-muted);margin-bottom:4px}.summary-value{font-size:24px;font-weight:700;color:var(--text-primary)}.summary-percent{position:absolute;top:16px;right:16px;font-size:13px;font-weight:600;color:var(--text-muted);background:var(--bg-darker);padding:4px 10px;border-radius:12px}.budget-progress-section{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:24px}.progress-header{display:flex;justify-content:space-between;margin-bottom:12px;font-size:14px;color:var(--text-secondary)}.progress-header .over{color:#ef4444;font-weight:600}.progress-bar-container{height:12px;background:var(--bg-darker);border-radius:6px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:6px;transition:width .5s ease}.progress-bar-fill.warning{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-bar-fill.over{background:linear-gradient(90deg,#ef4444,#dc2626)}.progress-bar-over{position:absolute;top:0;right:0;height:100%;background:repeating-linear-gradient(45deg,#ef4444,#ef4444 10px,#dc2626 10px,#dc2626 20px);border-radius:0 6px 6px 0}.budget-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}.budget-tabs .tab{padding:12px 20px;background:none;border:none;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}.budget-tabs .tab:hover{color:var(--text-primary)}.budget-tabs .tab.active{color:var(--accent-cyan);border-bottom-color:var(--accent-cyan)}.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.budget-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px}.budget-card.full-width{grid-column:span 2}.budget-card h3{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.budget-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.budget-card .card-header h3{margin-bottom:0}.btn-link{background:none;border:none;color:var(--accent-blue);font-size:13px;cursor:pointer}.btn-link:hover{text-decoration:underline}.category-list{display:flex;flex-direction:column;gap:16px}.category-item{padding-bottom:16px;border-bottom:1px solid var(--border)}.category-item:last-child{border-bottom:none;padding-bottom:0}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.category-name{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--text-primary)}.category-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.category-amounts{font-size:14px}.category-amounts .spent{font-weight:600;color:var(--text-primary)}.category-amounts .budget{color:var(--text-muted)}.category-progress{height:6px;background:var(--bg-darker);border-radius:3px;overflow:hidden}.category-bar{height:100%;border-radius:3px;transition:width .3s}.category-bar.warning{opacity:.8}.category-bar.over{background:#ef4444!important}.site-list{display:flex;flex-direction:column;gap:16px}.site-item{padding-bottom:16px;border-bottom:1px solid var(--border)}.site-item:last-child{border-bottom:none;padding-bottom:0}.site-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.site-name{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-primary)}.site-name svg{color:var(--text-muted)}.site-status{font-size:13px;font-weight:500;color:var(--accent-green)}.site-status.over{color:#ef4444}.site-progress{height:6px;background:var(--bg-darker);border-radius:3px;overflow:hidden;margin-bottom:8px}.site-bar{height:100%;background:var(--accent-cyan);border-radius:3px;transition:width .3s}.site-bar.warning{background:#f59e0b}.site-bar.over{background:#ef4444}.site-amounts{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}.expenses-table{overflow-x:auto}.expenses-table table{width:100%;border-collapse:collapse}.expenses-table th{text-align:left;padding:12px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border)}.expenses-table td{padding:14px 12px;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.expenses-table tbody tr:hover{background:var(--bg-hover)}.expenses-table .amount{font-weight:600;color:var(--text-primary)}.expenses-table .empty-row{text-align:center;color:var(--text-muted);padding:40px}.category-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}.expense-notes{display:block;font-size:12px;color:var(--text-muted);margin-top:2px}.expenses-table .actions{display:flex;gap:8px}.expenses-table .actions button{background:var(--bg-darker);border:none;border-radius:6px;padding:6px;color:var(--text-muted);cursor:pointer;transition:all .2s}.expenses-table .actions button:hover{background:var(--bg-hover);color:var(--text-primary)}.expenses-table.full{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px}.budgets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.budget-item{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px}.budget-item-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}.budget-item-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.budget-item-info{flex:1;min-width:0}.budget-item-info h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.budget-meta{font-size:12px;color:var(--text-muted)}.budget-item-actions{display:flex;gap:8px}.budget-item-actions button{background:var(--bg-darker);border:none;border-radius:8px;padding:8px;color:var(--text-muted);cursor:pointer;transition:all .2s}.budget-item-actions button:hover{background:var(--bg-hover);color:var(--text-primary)}.budget-item-amounts{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.budget-amount{font-size:28px;font-weight:700;color:var(--text-primary)}.budget-spent{font-size:14px;color:var(--text-muted)}.budget-item-progress{height:8px;background:var(--bg-darker);border-radius:4px;overflow:hidden;margin-bottom:12px}.budget-item-progress .progress-fill{height:100%;background:var(--accent-green);border-radius:4px;transition:width .3s}.budget-item-progress .progress-fill.warning{background:#f59e0b}.budget-item-progress .progress-fill.over{background:#ef4444}.budget-item-footer{display:flex;justify-content:space-between;font-size:13px;color:var(--text-muted)}.budget-item-footer .over{color:#ef4444;font-weight:600}.empty-state{text-align:center;padding:20px;color:var(--text-muted)}.empty-state-large{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px}.empty-state-large svg{color:var(--text-muted);margin-bottom:16px;opacity:.5}.empty-state-large h3{font-size:18px;color:var(--text-primary);margin-bottom:8px}.empty-state-large p{color:var(--text-muted);margin-bottom:20px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-card);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:18px;font-weight:600}.modal-close{background:var(--bg-darker);border:none;border-radius:8px;padding:8px;color:var(--text-muted);cursor:pointer}.modal form{padding:20px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-cyan)}.form-group textarea{resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon svg{position:absolute;left:12px;color:var(--text-muted)}.input-with-icon input{padding-left:38px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border);margin-top:20px}@media (max-width: 1200px){.budget-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.overview-grid{grid-template-columns:1fr}.budget-card.full-width{grid-column:span 1}.budgets-grid{grid-template-columns:1fr}}@media (max-width: 600px){.budget-page{padding:16px}.budget-header{flex-direction:column;align-items:flex-start;gap:16px}.header-actions{width:100%}.header-actions .btn{flex:1}.budget-summary{grid-template-columns:1fr}.budget-filters{flex-direction:column}.budget-filters select{width:100%}.form-row{grid-template-columns:1fr}}.announcements-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.announcements-header h2{margin:0 0 4px}.announcements-list{display:flex;flex-direction:column;gap:12px}.announcement-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:18px 22px;cursor:pointer;transition:all .2s ease;display:flex;gap:16px}.announcement-card:hover{border-color:var(--brand-green);transform:translateY(-2px);box-shadow:0 4px 20px #0003}.announcement-card.pinned{border-left:3px solid var(--brand-green)}.announcement-card.unread{background:var(--bg-card-secondary, var(--bg-card))}.announcement-card-left{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:90px}.announcement-card-content{flex:1;min-width:0}.announcement-title{font-size:16px;font-weight:600;margin:0 0 6px;color:var(--text-primary)}.announcement-preview{font-size:14px;color:var(--text-secondary);margin:0 0 12px;line-height:1.5}.announcement-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--text-secondary)}.announcement-author{display:flex;align-items:center;gap:6px}.announcement-reads{display:flex;align-items:center;gap:4px}.announcement-date{color:var(--text-secondary)}.priority-normal{--priority-color: var(--brand-blue)}.priority-important{--priority-color: #f59e0b}.pin-indicator{color:var(--brand-green)}.announcement-detail-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.announcement-detail h2{margin:0 0 12px;font-size:22px}.announcement-detail-meta{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.announcement-detail-content{line-height:1.7;font-size:15px;margin-bottom:20px}.announcement-detail-content p{margin:0 0 8px}.announcement-detail-reads{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:14px;padding-top:16px;border-top:1px solid var(--border)}.tasks-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.tasks-header h2{margin:0 0 4px}.tasks-header-actions{display:flex;align-items:center;gap:12px}.view-toggle{display:flex;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.view-toggle-btn{padding:8px 12px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;transition:all .2s}.view-toggle-btn:hover{color:var(--text-primary)}.view-toggle-btn.active{background:var(--brand-green);color:#fff}.kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;min-height:400px}.kanban-column{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;min-height:200px}.kanban-column-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border)}.kanban-column-dot{width:10px;height:10px;border-radius:50%;background:var(--column-color)}.kanban-column-title{font-size:14px;font-weight:600;flex:1}.kanban-column-count{background:var(--bg-hover, rgba(255,255,255,.1));padding:2px 8px;border-radius:10px;font-size:12px;font-weight:600;color:var(--text-secondary)}.kanban-column-body{padding:12px;flex:1;display:flex;flex-direction:column;gap:10px;overflow-y:auto}.kanban-empty{text-align:center;color:var(--text-secondary);font-size:13px;padding:20px 0}.task-card{background:var(--bg-card-secondary, rgba(255,255,255,.05));border:1px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;transition:all .2s ease}.task-card:hover{border-color:var(--brand-green);transform:translateY(-2px);box-shadow:0 4px 16px #0003}.task-card-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}.priority-dot{width:8px;height:8px;border-radius:50%;background:var(--priority-color)}.task-priority-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-secondary)}.task-card-title{font-size:14px;font-weight:600;margin:0 0 6px;color:var(--text-primary)}.task-card-desc{font-size:13px;color:var(--text-secondary);margin:0 0 10px;line-height:1.4}.task-card-footer{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-secondary)}.task-assignee{display:flex;align-items:center;gap:4px}.task-due{display:flex;align-items:center;gap:3px}.task-due.overdue{color:#ff6b6b;font-weight:600}.task-site{display:flex;align-items:center;gap:3px}.priority-badge-sm{font-size:11px;padding:2px 8px;border-radius:10px;background:color-mix(in srgb,var(--priority-color) 15%,transparent);color:var(--priority-color)}.priority-low{--priority-color: #6b7280}.priority-medium{--priority-color: var(--brand-blue)}.priority-high{--priority-color: #f59e0b}.priority-urgent{--priority-color: #ff6b6b}.task-list-view{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.task-list-row{cursor:pointer;transition:background .2s}.task-list-row:hover{background:var(--bg-hover, rgba(255,255,255,.05))}.text-danger{color:#ff6b6b!important;font-weight:600}.task-detail-badges{display:flex;gap:8px;margin-bottom:16px}.task-detail-title{font-size:22px;margin:0 0 12px}.task-detail-description{color:var(--text-secondary);line-height:1.6;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.task-detail-description p{margin:0 0 8px}.task-detail-info{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.task-detail-row{display:flex;align-items:center;gap:10px;font-size:14px}.task-detail-row svg{color:var(--text-secondary)}.task-detail-label{color:var(--text-secondary);font-weight:500}.task-status-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--border)}@media (max-width: 1200px){.kanban-board{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.kanban-board{grid-template-columns:1fr}}.dailylogs-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.dailylogs-header h2{margin:0 0 4px}.dailylogs-list{display:flex;flex-direction:column;gap:12px}.dailylog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:18px 22px;cursor:pointer;transition:all .2s ease}.dailylog-card:hover{border-color:var(--brand-green);transform:translateY(-2px);box-shadow:0 4px 20px #0003}.dailylog-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.dailylog-card-date{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--text-primary)}.dailylog-card-site{display:flex;align-items:center;gap:6px;font-size:15px;margin-bottom:8px}.dailylog-card-site svg{color:var(--brand-blue)}.dailylog-card-work{font-size:14px;color:var(--text-secondary);margin:0 0 12px;line-height:1.5}.dailylog-card-footer{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--text-secondary)}.dailylog-card-author{display:flex;align-items:center;gap:6px}.dailylog-card-weather,.dailylog-card-crew{display:flex;align-items:center;gap:4px}.dailylog-form{display:flex;flex-direction:column;gap:4px}.input-with-suffix{display:flex;gap:8px}.input-with-suffix .form-input:first-child{flex:1}.suffix-select{width:70px;flex-shrink:0}.crew-selector{display:flex;flex-wrap:wrap;gap:8px;padding:8px 0}.crew-chip{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--bg-card-secondary, rgba(255,255,255,.05));border:1px solid var(--border);cursor:pointer;font-size:13px;transition:all .2s ease}.crew-chip:hover{border-color:var(--brand-green)}.crew-chip.selected{background:color-mix(in srgb,var(--brand-green) 15%,transparent);border-color:var(--brand-green);color:var(--brand-green)}.crew-chip input[type=checkbox]{display:none}.dailylog-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.dailylog-detail-header h3{display:flex;align-items:center;gap:8px;margin:0 0 6px;font-size:18px}.detail-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.detail-section:last-child{border-bottom:none}.detail-section h4{display:flex;align-items:center;gap:8px;font-size:15px;margin:0 0 12px;color:var(--brand-blue)}.detail-section p{margin:0 0 8px;line-height:1.6}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.detail-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;font-weight:600}.detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.progress-bar-wrapper{display:flex;align-items:center;gap:12px;margin-top:10px}.progress-bar{flex:1;height:8px;background:var(--bg-card-secondary, rgba(255,255,255,.1));border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--brand-green);border-radius:4px;transition:width .3s}.progress-bar-wrapper span{font-size:13px;font-weight:600;color:var(--brand-green);white-space:nowrap}.crew-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 4px;background:var(--bg-card-secondary, rgba(255,255,255,.05));border-radius:20px;font-size:13px}.messages-layout{display:flex;height:calc(100vh - 120px);background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.messages-sidebar{width:320px;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;background:var(--bg-card)}.messages-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:16px 16px 12px}.messages-sidebar-header h3{margin:0;font-size:18px}.messages-search{display:flex;align-items:center;gap:8px;margin:0 12px 12px;padding:8px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:10px;transition:border-color .2s}.messages-search:focus-within{border-color:var(--brand-green)}.messages-search svg{color:var(--text-secondary);flex-shrink:0}.messages-search input{flex:1;background:transparent;border:none;outline:none;font-size:14px;color:var(--text-primary)}.messages-search input::placeholder{color:var(--text-muted)}.conversation-list{flex:1;overflow-y:auto}.conversation-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-secondary);gap:8px}.conversation-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.04)}.conversation-item:hover{background:var(--bg-hover, rgba(255,255,255,.05))}.conversation-item.active{background:color-mix(in srgb,var(--brand-green) 10%,transparent);border-left:3px solid var(--brand-green)}.conversation-item.unread{background:var(--bg-card-secondary, rgba(255,255,255,.03))}.conversation-avatar{flex-shrink:0}.avatar-site{background:color-mix(in srgb,var(--brand-blue) 20%,transparent)!important;color:var(--brand-blue)!important}.avatar-group{background:color-mix(in srgb,#8b5cf6 20%,transparent)!important;color:#8b5cf6!important}.conversation-info{flex:1;min-width:0}.conversation-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2px}.conversation-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-item.unread .conversation-name{color:var(--text-primary)}.conversation-time{font-size:11px;color:var(--text-muted);white-space:nowrap;margin-left:8px}.conversation-preview{font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-item.unread .conversation-preview{color:var(--text-secondary)}.unread-badge{background:var(--brand-green);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}.messages-main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-darker)}.messages-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:12px}.messages-empty svg{opacity:.3}.messages-empty h3{margin:0;color:var(--text-primary)}.messages-empty p{margin:0}.messages-thread-header{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg-card)}.thread-info{display:flex;align-items:center;gap:12px}.thread-info h4{margin:0;font-size:16px}.text-sm{font-size:12px}.mobile-back{display:none}.messages-thread{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:2px}.message-date-divider{display:flex;align-items:center;justify-content:center;margin:20px 0 12px;position:relative}.message-date-divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:#ffffff0f}.message-date-divider span{position:relative;background:var(--bg-darker);padding:4px 14px;border-radius:12px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.message-bubble-wrapper{display:flex;align-items:flex-end;gap:8px;max-width:70%;margin-bottom:2px}.message-bubble-wrapper.sent+.message-bubble-wrapper.received,.message-bubble-wrapper.received+.message-bubble-wrapper.sent{margin-top:12px}.message-bubble-wrapper.sent{align-self:flex-end;flex-direction:row-reverse}.message-bubble-wrapper.received{align-self:flex-start}.message-avatar{flex-shrink:0;margin-bottom:2px;visibility:visible}.message-avatar.hidden{visibility:hidden}.message-bubble{padding:8px 12px;border-radius:18px;max-width:100%;word-wrap:break-word;overflow-wrap:break-word}.message-bubble.sent{background:#2563eb;color:#fff;border-bottom-right-radius:6px}.message-bubble.received{background:#2a3a4e;border-bottom-left-radius:6px}.message-bubble-wrapper.sent+.message-bubble-wrapper.sent .message-bubble.sent{border-top-right-radius:6px}.message-bubble-wrapper.received+.message-bubble-wrapper.received .message-bubble.received{border-top-left-radius:6px}.message-sender{font-size:11px;font-weight:700;color:var(--brand-blue);display:block;margin-bottom:2px;letter-spacing:.2px}.message-reply-preview{display:flex;align-items:center;gap:4px;font-size:12px;padding:4px 8px;margin-bottom:4px;border-left:2px solid var(--brand-blue);opacity:.7;border-radius:0 4px 4px 0;background:#ffffff0d}.message-text{margin:0;font-size:14px;line-height:1.45;white-space:pre-wrap}.message-image{display:block;max-width:100%;max-height:300px;border-radius:10px;margin-top:4px;cursor:pointer;object-fit:cover}.message-video{display:block;max-width:100%;max-height:300px;border-radius:10px;margin-top:4px}.message-bubble.has-media{padding:3px}.message-bubble.has-media .message-text,.message-bubble.has-media .message-sender{margin:2px 5px 0}.message-bubble.has-media .message-meta{margin:2px 4px 1px}.message-bubble.image-only{position:relative;padding:3px}.message-bubble.image-only .message-image{margin:0}.message-bubble.image-only .message-meta{position:absolute;bottom:8px;right:8px;margin:0;background:#0000008c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border-radius:10px;padding:2px 8px}.message-bubble.image-only .message-time,.message-bubble.image-only .message-read-receipt{color:#ffffffe6!important;opacity:1!important}.message-meta{display:flex;justify-content:flex-end;align-items:center;gap:4px;margin-top:2px}.message-time{font-size:10px;opacity:.6}.message-read-receipt{display:inline-flex;align-items:center;opacity:.7}.message-read-receipt svg{width:14px;height:14px}.message-bubble.sent .message-time{color:#ffffffb3}.message-bubble.sent .message-read-receipt{color:#ffffffd9}.message-bubble.received .message-time{color:var(--text-muted)}.messages-input-area{border-top:1px solid var(--border);background:var(--bg-card)}.messages-input-bar{display:flex;align-items:center;gap:8px;padding:12px 16px}.hidden-file-input{display:none}.btn-attach{width:40px;height:40px;border-radius:50%;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.btn-attach:hover{color:var(--brand-green);background:color-mix(in srgb,var(--brand-green) 10%,transparent)}.message-input{flex:1;background:var(--bg-darker);border:1px solid var(--border);border-radius:24px;padding:10px 18px;font-size:14px;color:var(--text-primary);outline:none;transition:border-color .2s}.message-input:focus{border-color:var(--brand-green)}.message-input::placeholder{color:var(--text-muted)}.btn-send{width:42px;height:42px;min-width:42px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:none;background:#2563eb;color:#fff;cursor:pointer;transition:all .2s}.btn-send:hover:not(:disabled){transform:scale(1.05);background:#1d4ed8;box-shadow:0 4px 12px #2563eb59}.btn-send:disabled{opacity:.3;cursor:not-allowed}.media-preview-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-card-secondary, rgba(255,255,255,.05));border-bottom:1px solid var(--border)}.media-preview-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover}.media-preview-name{flex:1;font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-preview-remove{color:var(--text-secondary);background:transparent;border:none;cursor:pointer;padding:4px;border-radius:50%}.media-preview-remove:hover{color:#ff6b6b;background:color-mix(in srgb,#ff6b6b 10%,transparent)}.spin{animation:msg-spin 1s linear infinite}@keyframes msg-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000eb;display:flex;align-items:center;justify-content:center;animation:lightbox-fade-in .2s ease;cursor:zoom-out}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-image-wrapper{position:relative;max-width:90vw;max-height:90vh;cursor:default}.lightbox-image{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000080;transition:transform .2s ease;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.lightbox-close{position:fixed;top:16px;right:16px;width:44px;height:44px;border-radius:50%;border:none;background:#ffffff1f;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .2s;z-index:10000}.lightbox-close:hover{background:#ffffff40}.lightbox-controls{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:8px 16px;background:#0009;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:24px;z-index:10000}.lightbox-controls button{width:36px;height:36px;border-radius:50%;border:none;background:#ffffff1a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.lightbox-controls button:hover{background:#ffffff40}.lightbox-zoom-level{color:#ffffffb3;font-size:12px;font-weight:600;min-width:40px;text-align:center;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.messages-sidebar{width:100%}.messages-sidebar.hidden-mobile,.messages-main.hidden-mobile{display:none}.mobile-back{display:flex}.message-bubble-wrapper{max-width:85%}}.equipment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.equipment-header h2{margin:0 0 4px}.equipment-list{display:flex;flex-direction:column;gap:12px}.equipment-card{display:flex;gap:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;cursor:pointer;transition:all .2s ease}.equipment-card:hover{border-color:var(--brand-green);transform:translateY(-2px);box-shadow:0 4px 20px #0003}.equipment-card-icon{width:48px;height:48px;border-radius:12px;background:color-mix(in srgb,var(--brand-blue) 15%,transparent);color:var(--brand-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.equipment-card-content{flex:1;min-width:0}.equipment-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.equipment-card-name{font-size:15px;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.equipment-card-badges{display:flex;align-items:center;gap:8px;flex-shrink:0}.condition-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.equipment-card-desc{font-size:13px;color:var(--text-secondary);margin:0 0 8px;line-height:1.4}.equipment-card-footer{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary)}.equipment-card-category{font-weight:600;color:var(--brand-blue)}.equipment-card-assignee,.equipment-card-site{display:flex;align-items:center;gap:4px}.equipment-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.equipment-detail-header h3{margin:0;font-size:20px}.equipment-detail-desc{color:var(--text-secondary);line-height:1.6;margin:0 0 16px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.detail-item{display:flex;flex-direction:column;gap:2px}.detail-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.equipment-detail-notes{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.equipment-detail-notes h4{margin:0 0 8px;font-size:14px;color:var(--brand-blue)}.equipment-detail-notes p{margin:0;color:var(--text-secondary);line-height:1.6}.equipment-log-section{margin-top:16px}.equipment-log-section h4{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--brand-blue);margin:0 0 12px}.equipment-log-list{display:flex;flex-direction:column;gap:0}.equipment-log-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.equipment-log-dot{width:8px;height:8px;border-radius:50%;background:var(--brand-blue);margin-top:6px;flex-shrink:0}.equipment-log-content{flex:1;display:flex;flex-wrap:wrap;gap:4px;font-size:13px}.equipment-log-action{font-weight:600;color:var(--text-primary)}.equipment-log-by{color:var(--text-secondary)}.equipment-log-notes{color:var(--text-muted);font-size:12px;width:100%}.equipment-log-time{font-size:11px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.cert-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.cert-header h2{margin:0 0 4px}.cert-list{display:flex;flex-direction:column;gap:12px}.cert-card{display:flex;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;cursor:pointer;transition:all .2s ease}.cert-card:hover{border-color:var(--brand-green);transform:translateY(-2px);box-shadow:0 4px 20px #0003}.cert-card-left{position:relative;flex-shrink:0}.cert-verified-icon{position:absolute;bottom:-2px;right:-4px;color:#26de81;background:var(--bg-card);border-radius:50%}.cert-card-content{flex:1;min-width:0}.cert-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.cert-card-name{font-size:15px;font-weight:600;margin:0}.cert-card-employee{font-size:13px;color:var(--text-secondary)}.cert-card-badges{display:flex;gap:6px;flex-shrink:0}.cert-card-footer{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary)}.cert-card-expiry{display:flex;align-items:center;gap:4px;font-weight:600}.cert-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.cert-detail-header h3{margin:0 0 4px;font-size:20px}.incident-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.incident-header h2{margin:0 0 4px}.incident-list{display:flex;flex-direction:column;gap:12px}.incident-card{display:flex;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s ease}.incident-card:hover{border-color:var(--brand-green);transform:translateY(-2px);box-shadow:0 4px 20px #0003}.incident-card-severity{width:4px;flex-shrink:0}.incident-card-content{flex:1;padding:16px 20px}.incident-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.incident-card-title{font-size:15px;font-weight:600;margin:0}.incident-card-badges{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap}.incident-card-footer{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:var(--text-secondary)}.incident-card-footer span{display:flex;align-items:center;gap:4px}.incident-osha-tag{font-weight:700;color:#ff6b6b!important;background:#ff6b6b1f;padding:1px 6px;border-radius:4px;font-size:10px;text-transform:uppercase;letter-spacing:.5px}.incident-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.incident-detail-header h3{margin:0;font-size:20px}.incident-detail-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.incident-detail-section:last-of-type{border-bottom:none}.incident-detail-section h4{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--brand-blue);margin:0 0 8px}.incident-detail-section p{margin:0;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap}.injured-person-detail{padding:10px 14px;background:var(--bg-card-secondary, rgba(255, 255, 255, .03));border-radius:8px;margin-bottom:8px}.injured-person-info{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--text-secondary);margin-top:6px}.injured-person-form{background:var(--bg-card-secondary, rgba(255, 255, 255, .03));border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px}.injured-person-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:13px;font-weight:600;color:var(--text-secondary)}.incident-status-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--border);margin-top:16px}.form-section{padding:16px 0;border-bottom:1px solid var(--border)}.form-section:last-child{border-bottom:none}.form-section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;margin:0 0 14px;color:var(--brand-blue)}.activity-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.activity-header h2{margin:0 0 4px}.activity-header-actions{display:flex;align-items:center;gap:12px}.date-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px}.date-nav-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.date-nav-btn:hover{color:var(--text-primary);border-color:var(--brand-green)}.date-nav-current{font-size:15px;font-weight:600;color:var(--text-primary);min-width:160px;text-align:center}.date-mode-toggles{display:flex;gap:6px;margin-left:12px}.date-mode-btn{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.date-mode-btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.date-mode-btn.active{background:var(--brand-green);color:#fff;border-color:var(--brand-green)}.filter-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.filter-chip{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-chip:hover{border-color:var(--text-secondary);color:var(--text-primary)}.filter-chip.active{border-color:var(--chip-color, var(--brand-green));background:color-mix(in srgb,var(--chip-color, var(--brand-green)) 15%,transparent);color:var(--chip-color, var(--brand-green))}.activity-stats-banner{display:flex;gap:16px;margin-bottom:20px}.activity-stat-card{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}.activity-stat-value{font-size:24px;font-weight:700;color:var(--stat-color, var(--text-primary))}.activity-stat-label{font-size:12px;color:var(--text-secondary);margin-top:4px}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-card{display:flex;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease;overflow:hidden}.activity-card:hover{border-color:var(--brand-green);transform:translateY(-1px);box-shadow:0 4px 16px #0003}.activity-card-accent{width:4px;min-height:100%;border-radius:2px;background:var(--accent-color, var(--brand-blue));flex-shrink:0}.activity-card-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:color-mix(in srgb,var(--accent-color, var(--brand-blue)) 15%,transparent);color:var(--accent-color, var(--brand-blue))}.activity-card-content{flex:1;min-width:0}.activity-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.activity-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;background:color-mix(in srgb,var(--status-color, var(--brand-green)) 15%,transparent);color:var(--status-color, var(--brand-green))}.activity-card-contact{font-size:13px;color:var(--text-secondary);margin:0 0 6px}.activity-card-desc{font-size:13px;color:var(--text-secondary);margin:0 0 10px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.activity-card-meta{display:flex;flex-wrap:wrap;gap:8px}.meta-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500;background:var(--bg-hover);color:var(--text-secondary)}.meta-pill.cost{background:color-mix(in srgb,var(--accent-green) 15%,transparent);color:var(--accent-green)}.meta-pill.followup{background:color-mix(in srgb,var(--accent-orange) 15%,transparent);color:var(--accent-orange)}.meta-pill.followup.overdue{background:color-mix(in srgb,var(--accent-red) 15%,transparent);color:var(--accent-red)}.meta-pill.site{background:color-mix(in srgb,var(--brand-blue) 15%,transparent);color:var(--brand-blue)}.meta-pill.photos{background:color-mix(in srgb,var(--accent-purple) 15%,transparent);color:var(--accent-purple)}.activity-detail{display:flex;flex-direction:column;gap:20px}.activity-detail-hero{display:flex;align-items:center;gap:16px}.activity-detail-hero-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent-color, var(--brand-blue)) 15%,transparent);color:var(--accent-color, var(--brand-blue))}.activity-detail-hero-text{flex:1}.activity-detail-hero-text h2{margin:0 0 6px;font-size:20px}.activity-detail-hero-badges{display:flex;gap:8px}.activity-detail-category-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;background:color-mix(in srgb,var(--accent-color, var(--brand-blue)) 15%,transparent);color:var(--accent-color, var(--brand-blue))}.detail-section{background:var(--bg-card-secondary, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:12px;padding:16px}.detail-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin:0 0 12px}.detail-contact{display:flex;align-items:center;gap:12px}.detail-contact-avatar{width:44px;height:44px;border-radius:50%;background:var(--brand-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.detail-contact-info{flex:1}.detail-contact-name{font-weight:600;font-size:15px;margin:0 0 2px}.detail-contact-links{display:flex;gap:12px;margin-top:4px}.detail-contact-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--brand-blue);text-decoration:none;cursor:pointer}.detail-contact-link:hover{text-decoration:underline}.detail-description{color:var(--text-secondary);line-height:1.6;font-size:14px;white-space:pre-wrap}.detail-updates-list{display:flex;flex-direction:column;gap:10px}.detail-update-item{padding:10px 12px;background:var(--card-secondary, rgba(255,255,255,.04));border-radius:8px;border-left:3px solid #4d9ed6}.detail-update-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:#4d9ed6;font-weight:600;margin-bottom:4px}.detail-update-arrow{font-size:14px}.detail-update-date,.detail-update-author{color:#4d9ed6}.detail-update-text{color:var(--text-secondary);font-size:13px;line-height:1.5;padding-left:20px}.detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-info-item{display:flex;flex-direction:column;gap:4px}.detail-info-label{font-size:12px;color:var(--text-secondary)}.detail-info-value{font-size:14px;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:6px}.detail-followup{display:flex;flex-direction:column;gap:8px}.detail-followup-date{font-size:13px;display:flex;align-items:center;gap:6px}.detail-followup-date.overdue{color:var(--accent-red);font-weight:600}.detail-followup-notes{font-size:13px;color:var(--text-secondary);line-height:1.5}.detail-metadata{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted);padding-top:12px;border-top:1px solid var(--border)}.form-chips{display:flex;flex-wrap:wrap;gap:8px}.form-chip{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.form-chip:hover{border-color:var(--text-secondary)}.form-chip.selected{border-color:var(--chip-color, var(--brand-green));background:color-mix(in srgb,var(--chip-color, var(--brand-green)) 15%,transparent);color:var(--chip-color, var(--brand-green));font-weight:500}.followup-toggle{display:flex;align-items:center;gap:10px;padding:10px 0}.followup-toggle label{font-size:14px;color:var(--text-primary);cursor:pointer}.toggle-switch{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;cursor:pointer;transition:background .2s;border:none;padding:0}.toggle-switch.active{background:var(--brand-green)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}.toggle-switch.active:after{transform:translate(20px)}.activity-sidebar-categories{display:flex;flex-direction:column;gap:8px}.activity-sidebar-cat{display:flex;align-items:center;gap:8px;font-size:13px}.activity-sidebar-cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.activity-sidebar-cat-name{flex:1;color:var(--text-secondary)}.activity-sidebar-cat-count{font-weight:600;color:var(--text-primary)}.voice-input-container{min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}.voice-ready,.voice-listening,.voice-parsing,.voice-error,.voice-unsupported{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:20px;width:100%}.voice-ready h3,.voice-listening h3,.voice-parsing h3,.voice-error h3,.voice-unsupported h3,.voice-review h3,.voice-result h3{margin:0;font-size:18px}.voice-mic-btn{width:80px;height:80px;border-radius:50%;border:none;background:var(--brand-green);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;margin-bottom:8px}.voice-mic-btn:hover{transform:scale(1.05);box-shadow:0 4px 20px #00d4aa66}.voice-mic-btn.recording{background:#ff6b6b}.voice-pulse-container{position:relative;display:flex;align-items:center;justify-content:center}.voice-pulse{position:absolute;width:80px;height:80px;border-radius:50%;background:#ff6b6b4d;animation:voicePulse 1.5s ease-in-out infinite}@keyframes voicePulse{0%{transform:scale(1);opacity:.6}50%{transform:scale(1.4);opacity:.2}to{transform:scale(1);opacity:.6}}.voice-timer{font-size:24px;font-weight:700;font-family:monospace;color:#ff6b6b;margin-top:12px}.voice-hint{color:var(--text-secondary);font-size:14px;margin:0}.voice-example{color:var(--text-muted);font-size:13px;font-style:italic;margin:0;max-width:400px;line-height:1.5}.voice-live-transcript{background:var(--bg-card-secondary, rgba(255,255,255,.05));border:1px solid var(--border);border-radius:12px;padding:16px;width:100%;max-height:150px;overflow-y:auto;font-size:14px;color:var(--text-primary);line-height:1.5;text-align:left;margin-top:12px}.voice-review{width:100%;display:flex;flex-direction:column;gap:12px}.voice-transcript-edit{min-height:120px;font-size:14px;line-height:1.5}.voice-review-actions{display:flex;gap:8px;flex-wrap:wrap}.voice-spinner{margin-bottom:8px}.spinning{animation:spin 1s linear infinite}.voice-result{width:100%;display:flex;flex-direction:column;gap:16px}.voice-result-header{display:flex;align-items:center;gap:10px}.voice-result-fields{display:flex;flex-direction:column;gap:10px;background:var(--bg-card-secondary, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:12px;padding:16px}.voice-field{display:flex;align-items:flex-start;gap:12px}.voice-field-label{font-size:12px;font-weight:600;color:var(--text-secondary);min-width:80px;display:flex;align-items:center;gap:4px;padding-top:2px}.voice-field-value{font-size:14px;color:var(--text-primary);flex:1}.voice-field-desc{max-height:60px;overflow:hidden}.voice-field-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:500;background:color-mix(in srgb,var(--brand-green) 15%,transparent);color:var(--brand-green)}.voice-result-actions{display:flex;gap:8px}.voice-error-msg{color:#ff6b6b;font-size:14px;max-width:400px}.voice-error-actions{display:flex;gap:8px}.voice-input-trigger{display:flex;align-items:center;gap:8px}.report-container{display:flex;flex-direction:column;gap:20px}.report-week-selector{display:flex;align-items:center;gap:12px;justify-content:center}.report-week-label{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--text-primary);min-width:240px;justify-content:center}.report-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.report-stat{background:var(--bg-card-secondary, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--stat-color, var(--text-primary))}.report-stat svg{opacity:.7}.report-stat-value{font-size:22px;font-weight:700}.report-stat-label{font-size:11px;color:var(--text-secondary)}.report-section{display:flex;flex-direction:column;gap:10px}.report-section h4{margin:0;font-size:14px;color:var(--text-primary);padding-bottom:8px;border-bottom:1px solid var(--border)}.report-category{background:var(--bg-card-secondary, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:10px;overflow:hidden}.report-category-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:color-mix(in srgb,var(--cat-color) 10%,transparent);color:var(--cat-color);font-weight:600;font-size:13px}.report-category-count{margin-left:auto;background:color-mix(in srgb,var(--cat-color) 20%,transparent);padding:2px 8px;border-radius:10px;font-size:11px}.report-category-entries{padding:8px 14px;display:flex;flex-direction:column;gap:6px}.report-entry-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.report-entry-contact{font-weight:500;color:var(--text-primary)}.report-entry-sep{color:var(--text-muted)}.report-entry-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-entry-cost{color:#26de81;font-weight:600;font-size:12px}.report-entry-overflow{font-size:12px;color:var(--text-muted);font-style:italic}.report-empty{color:var(--text-secondary);text-align:center;padding:20px}.report-followup-row{display:flex;flex-wrap:wrap;gap:8px;padding:10px 14px;background:var(--bg-card-secondary, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:10px;font-size:13px;align-items:center}.report-followup-contact{font-weight:600;color:var(--text-primary)}.report-followup-title{color:var(--text-secondary);flex:1}.report-followup-notes{color:var(--text-muted);font-size:12px;width:100%}.report-followup-date{font-size:12px;color:var(--text-secondary);margin-left:auto}.report-followup-date.overdue{color:#ff6b6b;font-weight:700}.report-summary-hint{color:var(--text-muted);font-size:12px;margin:0}.report-photo-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary);padding:8px 0}.report-photo-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--brand-green, #90c73e);cursor:pointer}.report-photo-toggle svg{color:var(--text-secondary)}.report-photo-count{color:var(--text-secondary);font-size:12px}.report-site-filter{display:flex;gap:8px;flex-wrap:wrap;padding:4px 0}.report-site-chip{padding:5px 12px;border-radius:16px;border:1px solid var(--border);background:var(--bg-card-secondary, rgba(255,255,255,.03));color:var(--text-secondary);font-size:12px;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .2s}.report-site-chip:hover{border-color:var(--brand-blue, #4d9ed6);color:var(--text-primary)}.report-site-chip.active{background:color-mix(in srgb,var(--brand-blue, #4d9ed6) 15%,transparent);border-color:var(--brand-blue, #4d9ed6);color:var(--brand-blue, #4d9ed6);font-weight:600}.report-style-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}.report-style-card{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card-secondary, rgba(255,255,255,.03));cursor:pointer;text-align:left;transition:all .2s}.report-style-card:hover{border-color:var(--style-accent, var(--brand-blue))}.report-style-card.selected{border-color:var(--style-accent, var(--brand-blue));background:color-mix(in srgb,var(--style-accent, var(--brand-blue)) 8%,transparent)}.report-style-icon{position:relative;width:36px;height:36px;border-radius:8px;background:color-mix(in srgb,var(--style-accent, var(--brand-blue)) 12%,transparent);color:var(--style-accent, var(--brand-blue));display:flex;align-items:center;justify-content:center;flex-shrink:0}.report-style-check{position:absolute;bottom:-3px;right:-3px;background:var(--style-accent, var(--brand-blue));color:#fff;border-radius:50%;padding:1px}.report-style-info{display:flex;flex-direction:column;gap:2px;min-width:0}.report-style-name{font-size:13px;font-weight:600;color:var(--text-primary)}.report-style-desc{font-size:11px;color:var(--text-secondary);line-height:1.3}.report-entry-block{display:flex;flex-direction:column;gap:4px}.report-entry-updates{display:flex;flex-direction:column;gap:4px;padding-left:8px;margin-top:2px}.report-update-row{display:flex;gap:6px;font-size:12px}.report-update-arrow{color:var(--brand-blue, #4d9ed6);font-weight:600;flex-shrink:0;margin-top:1px}.report-update-content{display:flex;flex-direction:column;gap:1px;min-width:0}.report-update-meta{font-size:11px;font-weight:600;color:var(--brand-blue, #4d9ed6)}.report-update-text{color:var(--text-secondary);line-height:1.3}.report-entry-followup-note{display:flex;gap:6px;padding-left:8px;margin-top:4px}.report-entry-photos{display:flex;gap:4px;padding-left:8px;margin-top:4px;align-items:center}.report-entry-thumb{width:48px;height:48px;border-radius:6px;object-fit:cover;border:1px solid var(--border)}.report-entry-more-photos{font-size:11px;color:var(--text-muted);font-weight:600;padding:0 4px}.report-entry-updated{font-size:11px;color:#4a9eff;font-style:italic;flex-shrink:0}.report-overdue-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:8px;background:#ff6b6b;color:#fff;font-size:10px;font-weight:700;vertical-align:middle}.media-upload-actions{display:flex;gap:8px;flex-wrap:wrap}.media-count-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-top:12px}.media-thumb{position:relative;width:100%;aspect-ratio:1;border-radius:10px;overflow:hidden;border:2px solid var(--border);background:var(--bg-card-secondary, rgba(255,255,255,.03))}.media-thumb img,.media-thumb video{width:100%;height:100%;object-fit:cover;display:block}.media-thumb-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;border:none;background:#000000b3;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;z-index:2;transition:background .2s}.media-thumb-remove:hover{background:#ff6b6b}.media-thumb-badge{position:absolute;bottom:4px;left:4px;padding:2px 8px;border-radius:8px;font-size:10px;font-weight:600;background:var(--brand-green);color:#fff;z-index:2}.media-thumb.pending{border-color:var(--brand-green)}.media-thumb.video-thumb{cursor:default}.media-thumb-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;z-index:1;pointer-events:none}.detail-media-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.gallery-item{position:relative;width:100%;aspect-ratio:1;border-radius:10px;overflow:hidden;cursor:pointer;border:1px solid var(--border);transition:border-color .2s,transform .2s}.gallery-item:hover{border-color:var(--brand-blue);transform:scale(1.03)}.gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.gallery-item video{width:100%;height:100%;object-fit:cover;display:block}.video-gallery-item{cursor:default}.gallery-play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;pointer-events:none}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;z-index:10000;display:flex;align-items:center;justify-content:center;cursor:pointer}.lightbox-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;border:none;background:#ffffff26;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10001;transition:background .2s}.lightbox-close:hover{background:#ffffff4d}.lightbox-image{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px;cursor:default}.upload-indicator{display:flex;align-items:center;gap:8px;padding:10px 16px;background:color-mix(in srgb,var(--brand-blue) 15%,transparent);border:1px solid var(--brand-blue);border-radius:10px;color:var(--brand-blue);font-size:13px;font-weight:500}@media (max-width: 768px){.activity-header{flex-direction:column;gap:12px}.date-nav{flex-wrap:wrap}.date-mode-toggles{margin-left:0}.filter-chips{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.activity-stats-banner{flex-direction:column}.detail-info-grid{grid-template-columns:1fr}.report-stats{grid-template-columns:repeat(2,1fr)}.voice-review-actions,.voice-result-actions{flex-direction:column}.media-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.detail-media-gallery{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.media-upload-actions{flex-direction:column}}.filter-chip-count{background:var(--chip-color, var(--brand-green));color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.date-picker-wrapper{position:relative;display:inline-flex}.hidden-date-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.lightbox-video{max-width:90vw;max-height:90vh;border-radius:8px;cursor:default;background:#000}.video-gallery-item{cursor:pointer!important}.detail-document-list{display:flex;flex-direction:column;gap:8px}.document-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card-secondary, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:8px;color:var(--brand-blue);text-decoration:none;font-size:13px;transition:border-color .2s}.document-item:hover{border-color:var(--brand-blue);text-decoration:none}.document-item span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.document-list-form{display:flex;flex-direction:column;gap:6px;margin-top:10px}.document-form-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card-secondary, rgba(255,255,255,.03));border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text-secondary)}.document-form-item.pending{border-color:var(--brand-green)}.document-form-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-locale-selector{display:flex;gap:6px;margin-bottom:16px}.voice-locale-btn{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.voice-locale-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.voice-locale-btn.active{background:var(--brand-green);color:#fff;border-color:var(--brand-green)}.form-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.form-label-row .form-label{margin-bottom:0}.ai-rewrite-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid color-mix(in srgb,var(--brand-blue, #4d9ed6) 40%,transparent);background:color-mix(in srgb,var(--brand-blue, #4d9ed6) 8%,transparent);color:var(--brand-blue, #4d9ed6);border-radius:14px;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.ai-rewrite-btn:hover:not(:disabled){background:color-mix(in srgb,var(--brand-blue, #4d9ed6) 18%,transparent);border-color:var(--brand-blue, #4d9ed6)}.ai-rewrite-btn:disabled{opacity:.5;cursor:not-allowed}.ai-rewrite-btn.loading{color:var(--brand-green, #90c73e);border-color:color-mix(in srgb,var(--brand-green, #90c73e) 40%,transparent);background:color-mix(in srgb,var(--brand-green, #90c73e) 8%,transparent)}.picker-capacity{display:flex;align-items:center;gap:8px;padding:8px 14px;background:color-mix(in srgb,var(--brand-blue, #4d9ed6) 10%,transparent);border:1px solid color-mix(in srgb,var(--brand-blue, #4d9ed6) 25%,transparent);border-radius:8px;font-size:12px;color:var(--brand-blue, #4d9ed6);margin-bottom:12px}.picker-filters{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.picker-filters select,.picker-filters input{flex:1;min-width:120px;padding:8px 12px;background:var(--bg-secondary, #1c1c1e);border:1px solid var(--border, #333);border-radius:8px;color:var(--text-primary, #fff);font-size:13px}.picker-filters select{cursor:pointer}.picker-search-wrap{flex:1;min-width:120px;display:flex;align-items:center;gap:6px;padding:0 12px;background:var(--bg-secondary, #1c1c1e);border:1px solid var(--border, #333);border-radius:8px;color:var(--text-secondary, #8e8e93)}.picker-search-wrap input{flex:1;min-width:0;padding:8px 0;background:transparent;border:none;color:var(--text-primary, #fff);font-size:13px;outline:none}.picker-month-nav{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border, #333)}.picker-month-label{font-size:14px;font-weight:600;color:var(--text-primary, #fff)}.picker-photo-count{margin-left:auto;font-size:12px;color:var(--text-secondary, #8e8e93)}.picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-height:450px;overflow-y:auto;padding:8px}.picker-item{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;cursor:pointer;border:3px solid var(--border, #333);transition:border-color .2s,transform .15s,box-shadow .2s;min-height:120px}.picker-item img{width:100%;height:100%;object-fit:cover;display:block}.picker-item:hover:not(.disabled){border-color:var(--brand-blue, #4d9ed6);transform:scale(1.04)}.picker-item.selected{border-color:var(--brand-green, #90c73e);border-width:3px;box-shadow:0 0 0 3px color-mix(in srgb,var(--brand-green, #90c73e) 40%,transparent)}.picker-item.disabled{opacity:.45;cursor:not-allowed}.picker-checkbox{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.8);background:#00000080;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}.picker-checkbox.checked{background:var(--brand-green, #90c73e);border-color:var(--brand-green, #90c73e);color:#fff}.picker-video-badge{position:absolute;bottom:6px;left:6px;width:26px;height:26px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;z-index:1;pointer-events:none}.picker-duplicate-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:3px 10px;border-radius:8px;font-size:11px;font-weight:600;background:#000000bf;color:var(--text-secondary, #8e8e93);z-index:2}.picker-item-caption{position:absolute;bottom:0;left:0;right:0;padding:14px 6px 4px;background:linear-gradient(transparent,#000000b3);font-size:10px;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.picker-selection-count{margin-right:auto;font-size:13px;color:var(--text-secondary, #8e8e93)}.picker-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px;color:var(--text-secondary, #8e8e93);font-size:14px}.picker-empty p{margin:0}@media (max-width: 768px){.picker-filters{flex-direction:column}.picker-grid{grid-template-columns:repeat(3,1fr);gap:10px;max-height:300px}}@media (max-width: 480px){.picker-grid{grid-template-columns:repeat(2,1fr)}}.admin-portal-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.admin-sidebar{width:260px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.admin-sidebar-header{padding:20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);color:var(--accent-blue);font-size:18px;font-weight:700}.admin-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.admin-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s;text-align:left;width:100%}.admin-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-item.active{background:var(--accent-blue);color:#fff}.admin-sidebar-footer{padding:12px;border-top:1px solid var(--border)}.admin-main{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh}.admin-portal{min-height:100%;position:relative}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:16px;color:var(--text-secondary)}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:var(--bg-card);border-bottom:1px solid var(--border)}.admin-header-left{display:flex;align-items:center;gap:16px}.admin-header-left svg{color:var(--accent-purple)}.admin-header-left h1{font-size:24px;margin:0;font-weight:600}.admin-header-left p{font-size:13px;color:var(--text-secondary);margin:0}.admin-header-actions{display:flex;gap:12px}.admin-content{flex:1;padding:24px 30px;overflow-y:auto}.dashboard-tab{display:flex;flex-direction:column;gap:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:var(--bg-card);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-icon.blue{background:#3b82f626;color:#3b82f6}.stat-icon.green{background:#22c55e26;color:#22c55e}.stat-icon.purple{background:#8b5cf626;color:#8b5cf6}.stat-icon.orange{background:#f9731626;color:#f97316}.stat-icon.cyan{background:#06b6d426;color:#06b6d4}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:24px;font-weight:700}.stat-label{font-size:13px;color:var(--text-secondary)}.dashboard-section{background:var(--bg-card);border-radius:12px;padding:20px}.dashboard-section h3{margin:0 0 16px;font-size:16px}.plan-distribution{display:flex;flex-direction:column;gap:12px}.plan-dist-item{position:relative}.plan-dist-bar{height:32px;border-radius:6px;min-width:4px}.plan-dist-info{position:absolute;top:50%;left:12px;transform:translateY(-50%);display:flex;align-items:center;gap:12px}.plan-dist-name{font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.plan-dist-count{font-size:12px;color:#fffc}.recent-list{display:flex;flex-direction:column;gap:12px}.recent-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-darker);border-radius:8px;transition:all .2s;border:1px solid transparent}.recent-item.clickable:hover{background:var(--bg-hover);border-color:var(--accent-blue)}.recent-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.recent-info{flex:1}.recent-name{display:block;font-weight:500}.recent-meta{display:block;font-size:12px;color:var(--text-muted)}.companies-tab{display:flex;flex-direction:column;gap:20px}.filters-bar{display:flex;gap:12px;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex:1;min-width:200px}.search-box input{flex:1;background:none;border:none;padding:10px 0;font-size:14px;color:var(--text-primary)}.search-box svg{color:var(--text-muted)}.filters-bar select{padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer}.companies-table{background:var(--bg-card);border-radius:12px;overflow:hidden}.table-header{display:grid;grid-template-columns:40px 2fr 100px 100px 80px 140px 100px 120px;gap:12px;padding:14px 16px;background:var(--bg-darker);font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.table-row{display:grid;grid-template-columns:40px 2fr 100px 100px 80px 140px 100px 120px;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);align-items:center;transition:background .2s;position:relative}.table-row:hover{background:var(--bg-card-hover)}.table-row.selected{background:#3b82f61a}.table-row.deactivated{opacity:.7;background:#ef44440d}.table-empty{padding:40px;text-align:center;color:var(--text-muted)}.td.checkbox button,.th.checkbox button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}.td.checkbox button:hover{color:var(--accent-blue)}.company-cell{display:flex;align-items:center;gap:12px}.company-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-purple),var(--accent-blue));border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.company-details{min-width:0}.company-name{display:block;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-email{display:block;font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plan-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;color:#fff}.status-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;text-transform:capitalize}.status-badge.active{background:#22c55e26;color:#22c55e}.status-badge.trial{background:#3b82f626;color:#3b82f6}.status-badge.suspended{background:#f9731626;color:#f97316}.status-badge.deactivated{background:#ef444426;color:#ef4444}.status-badge.cancelled{background:#6b728026;color:#6b7280}.status-badge.paid{background:#22c55e26;color:#22c55e}.status-badge.pending{background:#f9731626;color:#f97316}.storage-cell{display:flex;flex-direction:column;gap:4px}.storage-bar{width:100%;height:4px;background:var(--bg-darker);border-radius:2px;overflow:hidden}.storage-fill{height:100%;background:var(--accent-blue);border-radius:2px}.storage-cell span{font-size:12px;color:var(--text-secondary)}.td.actions{display:flex;gap:8px;position:relative;z-index:10}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-darker);border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s;position:relative;z-index:11}.btn-icon svg{pointer-events:none}.btn-icon:hover{background:var(--accent-blue);color:#fff}.btn-icon.danger:hover{background:var(--accent-red)}.btn-icon.warning{color:var(--text-secondary)}.btn-icon.warning:hover{background:#f59e0b;color:#fff}.btn-icon.success{color:var(--accent-green)}.btn-icon.success:hover{background:var(--accent-green);color:#fff}.btn-icon.light{background:#fff3;color:#fff;cursor:pointer}.btn-icon.light:hover{background:#ffffff4d}.plans-tab{padding:0}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.plan-card{background:var(--bg-card);border-radius:12px;overflow:hidden}.plan-card-header{padding:20px;display:flex;align-items:center;gap:12px;color:#fff}.plan-card-header h3{flex:1;margin:0;font-size:18px}.plan-card-body{padding:20px}.plan-price{margin-bottom:16px}.price-amount{font-size:32px;font-weight:700}.price-period{font-size:14px;color:var(--text-secondary)}.plan-stats{margin-bottom:16px;font-size:13px;color:var(--text-secondary)}.plan-limits{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.limit-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.plan-features{display:flex;flex-direction:column;gap:8px}.feature-item{display:flex;align-items:center;gap:10px;font-size:13px}.feature-item.enabled{color:var(--text-primary)}.feature-item.enabled svg{color:var(--accent-green)}.feature-item.disabled{color:var(--text-muted)}.feature-item.disabled svg{color:var(--text-muted)}.billing-tab{display:flex;flex-direction:column;gap:24px}.billing-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.billing-stat{background:var(--bg-card);border-radius:12px;padding:20px}.billing-label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px}.billing-value{display:block;font-size:28px;font-weight:700}.invoices-table{background:var(--bg-card);border-radius:12px;overflow:hidden}.invoices-table .table-header,.invoices-table .table-row{grid-template-columns:150px 2fr 120px 120px 100px}.audit-tab{background:var(--bg-card);border-radius:12px;padding:20px}.audit-list{display:flex;flex-direction:column;gap:12px}.audit-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg-darker);border-radius:8px}.audit-icon{width:32px;height:32px;background:var(--bg-card);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.audit-info{flex:1}.audit-action{display:block;font-weight:500;text-transform:capitalize}.audit-details{display:block;font-size:13px;color:var(--text-secondary)}.audit-meta{text-align:right}.audit-time{display:block;font-size:12px;color:var(--text-muted)}.audit-user{display:block;font-size:11px;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state p{font-size:16px;font-weight:500;margin:0 0 4px}.empty-state span{font-size:13px}.modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#000000b3!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:9999!important;padding:20px}.modal{background:var(--bg-card);border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal.company-modal{max-width:700px}.modal.modal-small{max-width:400px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{display:flex;align-items:center;gap:10px;margin:0;font-size:18px}.modal-header.danger{background:#ef44441a}.modal-header.danger h2{color:var(--accent-red)}.btn-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.btn-close:hover{color:var(--text-primary)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border)}.company-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px}.company-stats .stat{background:var(--bg-darker);border-radius:8px;padding:16px;text-align:center}.company-stats .stat svg{color:var(--accent-blue);margin-bottom:8px}.company-stats .stat span{display:block;font-size:20px;font-weight:700}.company-stats .stat label{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text-secondary)}.form-group input,.form-group select{width:100%;padding:10px 12px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text-primary)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-blue)}.form-group input[type=color]{padding:4px;height:40px}.form-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.form-error{display:block;font-size:12px;color:var(--accent-red);margin-top:6px}.section-title{font-size:14px;font-weight:600;margin:20px 0 8px;color:var(--text-primary)}.section-hint{font-size:12px;color:var(--text-muted);margin-bottom:12px}.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.feature-toggle{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-darker);border-radius:8px;cursor:pointer;font-size:13px;color:var(--text-muted);transition:all .2s}.feature-toggle:hover{background:var(--bg-card-hover)}.feature-toggle.enabled{background:#22c55e1a;color:var(--text-primary)}.feature-toggle.enabled svg:last-child{color:var(--accent-green)}.feature-toggle.override{border:1px solid #f59e0b}.feature-toggle span{flex:1}.warning-text{color:var(--accent-red);font-size:13px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-card-hover)}.btn-danger:hover{background:#dc2626}@media (max-width: 1024px){.table-header,.table-row{grid-template-columns:40px 1.5fr 80px 80px 80px 120px 100px 80px;font-size:12px}.stats-grid{grid-template-columns:repeat(2,1fr)}.company-stats{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.admin-header{flex-direction:column;gap:16px;align-items:flex-start}.admin-tabs{overflow-x:auto}.filters-bar{flex-direction:column}.search-box{min-width:100%}.table-header,.table-row{grid-template-columns:40px 1fr 80px 80px}.td.employees,.td.storage,.td.last-active,.th.employees,.th.storage,.th.last-active{display:none}.form-row{grid-template-columns:1fr}.company-stats{grid-template-columns:repeat(2,1fr)}.features-grid{grid-template-columns:1fr}}:root{--bg-dark: #1a2332;--bg-darker: #151c28;--bg-sidebar: #1e2a3a;--bg-card: #243447;--bg-hover: #2a3d52;--accent-blue: #4a9eff;--accent-cyan: #00d4aa;--accent-purple: #7c6aef;--accent-orange: #ff9f43;--accent-red: #ff6b6b;--accent-green: #26de81;--text-primary: #fff;--text-secondary: #8899a8;--text-muted: #5a6a7a;--border: #2d3e50;--sidebar-w: 220px;--brand-green: #00d4aa;--brand-blue: #4a9eff;--bg-card-secondary: #2a3d52}[data-theme=light]{--bg-dark: #f5f7fa;--bg-darker: #edf0f4;--bg-sidebar: #ffffff;--bg-card: #ffffff;--bg-hover: #e8ecf1;--bg-card-secondary: #f0f2f5;--text-primary: #1a1a2e;--text-secondary: #5a6478;--text-muted: #8892a4;--border: #e0e4ea;--brand-green: #00d4aa;--brand-blue: #4a9eff}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;transition:background .3s ease,color .3s ease}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--accent-green)}.text-danger{color:var(--accent-red)}.text-cyan{color:var(--accent-cyan)}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-darker);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:9999}.spinner{width:40px;height:40px;border:3px solid transparent;border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{padding:60px 20px;text-align:center;color:var(--text-muted)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:3000;display:flex;flex-direction:column;gap:8px}.toast{padding:14px 18px;background:var(--bg-card);border-radius:8px;border-left:3px solid var(--accent-green);animation:slideIn .3s ease}.toast.error{border-left-color:var(--accent-red)}.toast.warning{border-left-color:var(--accent-orange)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px #4a9eff59}.btn-secondary{background:var(--bg-darker);border:1px solid var(--border);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--text-muted);color:var(--text-primary)}.btn-danger{background:var(--accent-red);color:#fff}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.btn-icon-warning{color:#f59e0b!important}.btn-icon-warning:hover{background:#f59e0b26!important;color:#d97706!important}.btn-sm{padding:8px 16px;font-size:13px}.btn-icon{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:6px}.btn-icon:hover{background:var(--bg-card);color:var(--text-primary)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:500}.form-input{width:100%;padding:12px 16px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;transition:all .2s ease}.form-input:hover{border-color:var(--text-muted)}.form-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #4a9eff26}.form-input::placeholder{color:var(--text-muted)}select.form-input{padding-right:40px;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238899a8' 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}.form-select{width:100%;padding:12px 40px 12px 16px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238899a8' 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;transition:all .2s ease}.form-select:hover{border-color:var(--accent-blue)}.form-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #4a9eff26}input[type=date],input[type=time]{color-scheme:dark}textarea.form-input,.form-textarea{resize:vertical;min-height:80px;line-height:1.6}.form-row{display:flex;gap:16px}@media (max-width: 600px){.form-row{flex-direction:column}}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;height:44px;padding:0 14px;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text-primary);transition:all .2s}.checkbox-label:hover{border-color:var(--accent-blue)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-cyan);cursor:pointer}.card{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-title{font-size:14px;font-weight:600}.card-body{padding:16px 20px}.badge{display:inline-flex;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500}.badge-success{background:#26de8126;color:var(--accent-green)}.badge-info{background:#4a9eff26;color:var(--accent-blue)}.badge-warning{background:#ff9f4326;color:var(--accent-orange)}.badge-danger{background:#ff6b6b26;color:var(--accent-red)}.badge-default{background:#ffffff1a;color:var(--text-secondary)}.badge-purple{background:#8b5cf626;color:#8b5cf6}.avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:#fff;flex-shrink:0}.avatar-sm{width:28px;height:28px;font-size:11px}.avatar-lg{width:48px;height:48px;font-size:16px}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:14px 20px;text-align:left;border-bottom:1px solid var(--border)}.data-table th{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;background:var(--bg-darker)}.data-table tr{cursor:pointer;transition:background .2s}.data-table tr:hover td{background:var(--bg-hover)}.data-table tr.clickable-row:hover td{background:#4a9eff14}.data-table tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all .25s ease}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:var(--bg-sidebar, var(--bg-card));border:1px solid var(--border);border-radius:16px;width:100%;max-width:520px;max-height:85vh;display:flex;flex-direction:column;transform:translateY(20px) scale(.97);transition:transform .3s cubic-bezier(.16,1,.3,1);box-shadow:0 25px 60px #00000080,0 0 0 1px #ffffff0d}.modal-lg{max-width:720px}.modal-sm{max-width:400px}.modal-overlay.active .modal{transform:translateY(0) scale(1)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header .btn-icon{width:34px;height:34px;border-radius:8px;background:#ffffff0f;transition:all .2s}.modal-header .btn-icon:hover{background:#ffffff1f;color:var(--accent-red)}.modal-title{font-size:18px;font-weight:600}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0;background:#00000026;border-radius:0 0 16px 16px}.filter-section{background:var(--bg-card);border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid var(--border)}.filter-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.filter-title:after{content:"";flex:1;height:1px;background:var(--border)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.photo-thumb{aspect-ratio:1;background:var(--bg-darker);border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s}.photo-thumb:hover{transform:scale(1.02)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.status-card{background:var(--accent-blue);border-radius:12px;padding:20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:transform .2s,box-shadow .2s}.status-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0000004d}.status-card.cyan{background:var(--accent-cyan)}.status-card.purple{background:var(--accent-purple)}.status-card.orange{background:var(--accent-orange)}.status-card h2{font-size:36px;font-weight:700}.status-card span{font-size:12px;text-transform:uppercase;opacity:.9}.status-card .arrow{font-size:20px;opacity:.7}.search-input-wrapper{position:relative}.search-input-wrapper svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.search-input-wrapper .form-input{padding-left:36px}.sidebar-stats{display:flex;flex-direction:column;gap:8px}.sidebar-stat{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.stat-label{color:var(--text-secondary);font-size:14px}.stat-value{font-weight:600;font-size:16px}.avatar-xs{width:24px;height:24px;font-size:10px}.priority-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px;background:color-mix(in srgb,var(--priority-color) 15%,transparent);color:var(--priority-color)}.app-container{display:flex;min-height:100vh}.admin-layout{min-height:100vh;background:var(--bg-primary)}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;border-right:1px solid var(--border);z-index:100;transition:width .3s ease,transform .3s ease,background .3s ease,border-color .3s ease;overflow:hidden}.sidebar-header{padding:16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.sidebar-logo{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}.sidebar-title{font-weight:600;font-size:14px}.company-selector{padding:12px;border-bottom:1px solid var(--border);position:relative}.company-selector-btn{width:100%;display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.company-selector-btn:hover{background:var(--bg-card-hover);border-color:var(--accent-blue)}.company-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-purple),var(--accent-blue));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.company-avatar.small{width:28px;height:28px;font-size:10px}.company-info{flex:1;text-align:left;min-width:0}.company-name{display:block;font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-plan{display:block;font-size:11px;color:var(--text-muted)}.company-selector-btn .chevron{color:var(--text-muted);transition:transform .2s}.company-selector-btn .chevron.open{transform:rotate(180deg)}.company-dropdown{position:absolute;top:100%;left:12px;right:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 40px #0006;z-index:1000;max-height:300px;overflow-y:auto}.company-dropdown-header{padding:10px 12px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.company-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;background:none;border:none;cursor:pointer;transition:background .2s}.company-dropdown-item:hover{background:var(--bg-card-hover)}.company-dropdown-item.active{background:#3b82f61a}.company-dropdown-info{flex:1;text-align:left;min-width:0}.company-dropdown-name{display:block;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-dropdown-meta{display:block;font-size:11px;color:var(--text-muted)}.company-dropdown-item .check-icon{color:var(--accent-blue)}.company-dropdown-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:13px}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-group{margin-bottom:4px}.nav-group-label{padding:12px 12px 4px;font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}.nav-group:first-child+.nav-group .nav-group-label{padding-top:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;color:var(--text-secondary);font-size:14px;border-radius:8px;cursor:pointer;margin-bottom:2px;text-decoration:none;transition:all .2s}.nav-item:hover{background:var(--bg-card);color:var(--text-primary);text-decoration:none}.nav-item.active{background:var(--accent-blue);color:#fff}.nav-divider{padding:16px 12px 8px;margin-top:8px}.nav-divider span{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:1px}.nav-item.admin-item{color:var(--accent-purple)}.nav-item.admin-item:hover{background:#8b5cf626}.nav-item.admin-item.active{background:var(--accent-purple);color:#fff}.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.user-info{display:flex;align-items:center;gap:12px;padding:8px 12px;margin-bottom:8px}.user-info-text h4{font-size:13px;font-weight:600}.user-info-text p{font-size:11px;color:var(--text-muted)}.main-content{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column}.header{height:56px;background:var(--bg-darker);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50;transition:background .3s ease,border-color .3s ease}.header-left{display:flex;align-items:center;gap:12px}.header-actions{display:flex;align-items:center;gap:4px}.header-title{font-size:14px;color:var(--text-secondary)}.theme-toggle svg{transition:transform .3s ease}.theme-toggle:hover svg{transform:rotate(30deg)}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--bg-card);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:background .2s;flex-shrink:0}.mobile-menu-btn:hover{background:var(--bg-hover)}.sidebar-overlay{display:none}.page-content{padding:28px 32px;flex:1}.page-with-sidebar{display:flex;gap:24px}.page-main{flex:1;min-width:0}.page-sidebar{width:280px;flex-shrink:0}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-darker)}.login-card{width:100%;max-width:400px;background:var(--bg-card);border-radius:12px;padding:40px}.login-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:32px}.login-logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.login-logo-text{font-size:24px;font-weight:700}.login-title{text-align:center;font-size:16px;margin-bottom:24px;color:var(--text-secondary)}.login-error{background:#ff6b6b1a;border:1px solid var(--accent-red);color:var(--accent-red);padding:12px;border-radius:8px;font-size:13px;margin-bottom:20px}@media (max-width: 1024px){.sidebar{width:60px}.sidebar .nav-label,.sidebar .sidebar-title,.sidebar .nav-group-label,.sidebar .company-selector,.sidebar .user-info-text{opacity:0;width:0;overflow:hidden;white-space:nowrap;transition:opacity .25s ease}.sidebar .nav-item{justify-content:center;padding:10px 0}.sidebar .nav-icon{margin:0}.sidebar .sidebar-header{justify-content:center;padding:16px 12px}.sidebar .sidebar-footer{padding:8px}.sidebar .user-info{justify-content:center;padding:8px 0}.sidebar .sidebar-footer .nav-item{justify-content:center}.sidebar:hover{width:var(--sidebar-w);box-shadow:4px 0 24px #0000004d}.sidebar:hover .nav-label,.sidebar:hover .sidebar-title,.sidebar:hover .nav-group-label,.sidebar:hover .company-selector,.sidebar:hover .user-info-text{opacity:1;width:auto}.sidebar:hover .nav-item{justify-content:flex-start;padding:10px 12px}.sidebar:hover .sidebar-header{justify-content:flex-start;padding:16px}.sidebar:hover .sidebar-footer{padding:12px}.sidebar:hover .user-info{justify-content:flex-start;padding:8px 12px}.sidebar:hover .sidebar-footer .nav-item{justify-content:flex-start}.main-content{margin-left:60px}.page-with-sidebar{flex-direction:column}.page-sidebar{width:100%}}@media (max-width: 768px){.mobile-menu-btn{display:flex}.sidebar{width:var(--sidebar-w);transform:translate(-100%);z-index:200;box-shadow:none}.sidebar.sidebar--open{transform:translate(0);box-shadow:4px 0 24px #0006}.sidebar.sidebar--open .nav-label,.sidebar.sidebar--open .sidebar-title,.sidebar.sidebar--open .nav-group-label,.sidebar.sidebar--open .company-selector,.sidebar.sidebar--open .user-info-text{opacity:1;width:auto}.sidebar.sidebar--open .nav-item{justify-content:flex-start;padding:10px 12px}.sidebar.sidebar--open .sidebar-header{justify-content:flex-start;padding:16px}.sidebar.sidebar--open .sidebar-footer{padding:12px}.sidebar.sidebar--open .user-info{justify-content:flex-start;padding:8px 12px}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.main-content{margin-left:0}.page-content{padding:16px}.header{padding:0 16px}}.permissions-grid{border:1px solid var(--border);border-radius:8px;overflow:hidden}.permissions-header{display:grid;grid-template-columns:1fr 100px 100px 100px;background:var(--card-secondary, rgba(255,255,255,.05));font-weight:600;font-size:12px;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px}.permissions-header>div{padding:10px 12px;text-align:center}.permissions-header .permissions-item-label{text-align:left}.permissions-row{display:grid;grid-template-columns:1fr 100px 100px 100px;border-top:1px solid var(--border);transition:background .15s}.permissions-row:hover{background:#ffffff08}.permissions-item-label{padding:10px 12px;font-size:14px;color:var(--text-primary);display:flex;align-items:center}.permissions-cell{padding:10px 12px;display:flex;align-items:center;justify-content:center}.permissions-cell input[type=checkbox]{width:18px;height:18px;accent-color:var(--brand-green, #90c73e);cursor:pointer}.permissions-cell input[type=checkbox]:disabled{opacity:.4;cursor:not-allowed}.permissions-role-header{font-size:11px}@media (max-width: 600px){.permissions-header,.permissions-row{grid-template-columns:1fr 70px 70px 70px}.permissions-role-header{font-size:10px}}
