:root{font-family:Segoe UI,Tahoma,sans-serif;color-scheme:light;--bg: #f8fafc;--bg-end: #eef2f7;--card: #ffffff;--card-secondary: #f8fafc;--card-soft: #f8fafc;--text: #111827;--text-muted: #6b7280;--text-soft: #334155;--muted: #6b7280;--border: #e5e7eb;--border-strong: #cfd6df;--table-row-border: var(--border);--primary: #2563eb;--on-primary: #ffffff;--primary-hover: #1d4ed8;--primary-active: #1e40af;--primary-soft: #edf4ff;--surface-muted: #f8fafc;--surface-raised: #ffffff;--button-bg: #ffffff;--button-hover: #f7f9fc;--input-bg: #ffffff;--shadow: 0 4px 12px rgba(0, 0, 0, .05);--shadow-strong: 0 10px 30px rgba(15, 23, 42, .22);--navbar-shadow: 0 4px 12px rgba(15, 23, 42, .06);--login-accent: linear-gradient(135deg, rgba(11, 102, 208, .05), rgba(148, 163, 184, .03));--input-inset-shadow: inset 2px 4px 6px rgba(0, 0, 0, .08), inset -2px -2px 6px rgba(255, 255, 255, .6);--input-focus-shadow: 0 0 0 2px rgba(30, 107, 214, .2), inset 1px 2px 4px rgba(0, 0, 0, .05);--primary-shadow: 0 8px 16px rgba(37, 99, 235, .22);--primary-shadow-active: 0 3px 8px rgba(37, 99, 235, .2);--backdrop: rgba(15, 23, 42, .45);--danger: #dc2626;--danger-hover: #b91c1c;--success: #127e42;--success-bg: #eaf8ef;--success-border: #bde7cb;--warning: #8b6a06;--warning-bg: #fff8e2;--warning-border: #f2dfaa;--danger-bg: #fdecec;--danger-border: #f0c5c2;--inactive-bg: #f3f4f6;--inactive-text: #4b5563;--inactive-border: #d5dae1;color:var(--text);background:var(--bg-end)}[data-theme=dark]{color-scheme:dark;--bg: #0a0a0a;--bg-end: #0a0a0a;--card: #181818;--card-secondary: #202020;--card-soft: #202020;--text: #e5e5e5;--text-muted: #9ca3af;--text-soft: #d1d5db;--muted: var(--text-muted);--border: #2a2a2a;--border-strong: #3a3a3a;--table-row-border: var(--border);--primary: #3b82f6;--on-primary: #ffffff;--primary-hover: #60a5fa;--primary-active: #2563eb;--primary-soft: rgba(148, 163, 184, .16);--surface-muted: var(--card-secondary);--surface-raised: var(--card);--button-bg: #181818;--button-hover: #202020;--input-bg: #121212;--shadow: 0 4px 12px rgba(0, 0, 0, .24);--shadow-strong: 0 10px 30px rgba(0, 0, 0, .45);--navbar-shadow: 0 4px 12px rgba(0, 0, 0, .28);--login-accent: linear-gradient(135deg, rgba(32, 32, 32, .7), rgba(10, 10, 10, 0));--input-inset-shadow: inset 2px 4px 6px rgba(0, 0, 0, .24);--input-focus-shadow: 0 0 0 2px rgba(59, 130, 246, .28);--primary-shadow: 0 8px 16px rgba(59, 130, 246, .18);--primary-shadow-active: 0 3px 8px rgba(59, 130, 246, .16);--backdrop: rgba(2, 6, 23, .68);--danger: #f87171;--danger-hover: #ef4444;--success: #4ade80;--success-bg: rgba(74, 222, 128, .12);--success-border: rgba(74, 222, 128, .34);--warning: #facc15;--warning-bg: rgba(250, 204, 21, .12);--warning-border: rgba(250, 204, 21, .34);--danger-bg: rgba(248, 113, 113, .12);--danger-border: rgba(248, 113, 113, .34);--inactive-bg: #202020;--inactive-text: #cbd5e1;--inactive-border: #2a2a2a}*{box-sizing:border-box}html,body{margin:0;width:100%;max-width:100%;overflow-x:visible;min-height:100vh;background:var(--bg);color:var(--text)}#root{width:100%;max-width:100%;overflow-x:visible}img{display:block;max-width:100%}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;padding:8px 10px;border:1px solid var(--border-strong);border-radius:8px;min-height:44px;color:var(--text)}input,select,textarea{min-height:40px;padding:8px 12px;border-radius:6px;border:1px solid var(--border);font-size:14px;width:100%;box-sizing:border-box;font-family:inherit;background:var(--input-bg);color:var(--text)}textarea{resize:vertical;line-height:1.5}input[type=date]{width:100%;max-width:100%;min-height:44px;height:auto;padding:8px 12px;font-size:16px;line-height:1.2}button{cursor:pointer;background:var(--button-bg);transition:background-color .15s ease,border-color .15s ease}button:hover{background:var(--button-hover)}.app-shell{width:100%;max-width:1400px;margin:0 auto;padding:18px 24px 32px;min-width:0;overflow:visible}.app-layout{min-height:100vh;width:100%;max-width:100%;min-width:0;overflow:visible}.navbar,.app-navbar{position:sticky;top:0;z-index:9999;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:var(--card);border-bottom:1px solid var(--border);box-shadow:var(--navbar-shadow)}[data-theme=dark] .app-navbar{background:#0a0a0ae6;border-bottom:1px solid #2a2a2a}.app-navbar-inner{width:100%;max-width:1400px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;min-width:0}.nav-left{display:flex;align-items:center;gap:28px;flex:1 1 auto;flex-wrap:wrap;min-width:0}.navbar-brand{display:flex;align-items:center;gap:10px;flex:0 1 auto;min-width:0}.brand-logo{width:40px;height:40px;margin-right:0;object-fit:contain;border-radius:6px;border:1px solid var(--border);background:var(--card)}.brand-text{display:flex;flex-direction:column;line-height:1.2;min-width:0}.brand-main{font-size:16px;font-weight:600;color:var(--text);white-space:normal;overflow-wrap:anywhere}.brand-sub{font-size:12px;color:var(--muted);white-space:normal;overflow-wrap:anywhere}.main-nav{display:flex;align-items:center;gap:24px;flex-wrap:wrap;min-width:0}.main-nav-link{color:var(--text-soft);font-size:14px;font-weight:500;text-decoration:none;border-bottom:2px solid transparent;padding-bottom:3px}.main-nav-link:hover{color:var(--primary);text-decoration:none}.main-nav-link-active{color:var(--primary);border-bottom-color:var(--primary);font-weight:500}.divider{width:1px;height:20px;background:var(--border)}.nav-right{display:flex;align-items:center;gap:12px;margin-left:auto;flex-wrap:wrap;min-width:0}.role-pill{display:inline-flex;align-items:center;justify-content:center;min-width:56px;border:1px solid var(--border);border-radius:999px;padding:3px 9px;background:var(--surface-muted);color:var(--muted);font-size:11px;font-weight:500}.nav-logout-btn,.theme-toggle-btn{min-height:40px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow)}.topbar nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.meta-row{display:flex;justify-content:space-between;margin:10px 0 16px;font-size:14px}.badge{border:1px solid var(--border-strong);border-radius:999px;padding:2px 10px;background:var(--card)}.content{width:100%;max-width:100%;min-width:0;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:var(--shadow)}.content>*{min-width:0}.centered-card{width:100%;max-width:380px;margin:80px auto;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:var(--shadow)}.card{background:var(--card);border-radius:12px;box-shadow:var(--shadow)}.section{border:1px solid var(--border)}.login-card{width:min(100%,420px)}.login-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;padding:32px 24px;background:var(--login-accent),linear-gradient(180deg,var(--bg) 0%,var(--bg-end) 100%)}.login-layout{width:100%;max-width:1040px;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,380px);border:1px solid var(--border);border-radius:18px;overflow:hidden;background:var(--card);box-shadow:var(--shadow)}.login-brand-panel{display:flex;align-items:center;min-width:0;justify-content:center;padding:24px 32px;background:linear-gradient(145deg,var(--surface-muted),var(--bg-end))}.login-brand-content{max-width:360px;display:grid;gap:10px}.login-brand-logo{width:56px;height:56px;object-fit:contain;border-radius:12px;background:var(--card);border:1px solid var(--border);padding:8px}.login-brand-title{margin:0;font-size:28px;font-weight:700;color:var(--text);letter-spacing:-.02em}.login-brand-subtitle{margin:0;font-size:15px;font-weight:600;color:var(--primary)}.login-brand-description{margin:4px 0 0;font-size:14px;line-height:1.6;color:var(--muted)}.login-form-panel{display:flex;align-items:center;justify-content:center;padding:24px;background:var(--card)}.login-wrapper{display:flex;align-items:center;justify-content:center;min-height:100%}.login-form-card{width:100%;max-width:360px;padding:24px;border-radius:12px;border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow)}.login-card{width:340px;max-width:100%;padding:24px}.login-form-header{display:grid;gap:0;margin-bottom:16px}.login-form-header h1{margin:0 0 8px;font-size:22px;color:var(--text)}.login-form-copy{margin:0 0 16px;font-size:14px;line-height:1.6;color:var(--muted)}.login-form-eyebrow{margin:0 0 6px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--primary)}.login-form-stack{display:grid;gap:0}.input-group{width:100%;margin-bottom:16px}.login-input-label{display:block;margin-bottom:4px;font-size:12px;color:var(--muted)}.input.login-input{width:100%;min-height:44px;height:44px;border:none;outline:none;border-radius:10px;padding:12px 14px;font-size:14px;background-color:var(--surface-muted);box-shadow:var(--input-inset-shadow);transition:background-color .2s ease,box-shadow .2s ease}.input.login-input:focus{background-color:var(--input-bg);box-shadow:var(--input-focus-shadow)}.password-toggle{display:inline-flex;align-items:center;gap:10px;margin:0 0 16px;font-size:13px;color:var(--muted);cursor:pointer}.password-toggle input{width:16px;height:16px;min-height:16px;margin:0}.login-form-error{margin:0 0 12px}.login-submit-btn{width:100%;height:44px;min-height:44px;margin-top:4px}.button-primary{width:100%;height:44px;min-height:44px;border-radius:8px;border:none;background:var(--primary);color:var(--on-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.button-primary:hover{background:var(--primary-hover)}.button-primary:active{transform:scale(.98)}.stack-form{display:grid;gap:12px}.stack-form label{display:grid;gap:6px}.inline-form{display:flex;gap:8px;margin-bottom:12px}.dashboard-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--card);width:100%;min-width:0}.dashboard-filters input,.dashboard-filters select{min-width:150px}.dashboard-filters>*{min-width:0}.dashboard-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--card);width:100%;min-width:0}.dashboard-toolbar select,.dashboard-toolbar input[type=date]{min-width:145px}.dashboard-toolbar input[type=date]{min-width:0;flex:1 1 180px}.date-input{width:100%;min-width:0;padding:12px;font-size:16px}.filter-bar{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto auto auto auto;gap:10px;align-items:end;margin-bottom:14px;padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--card);width:100%;min-width:0}.sticky-filter-bar{position:sticky;top:86px;z-index:40;box-shadow:var(--shadow)}.filter-input,.filter-select,.filter-date,.filter-bar button{height:40px;min-height:40px;border-radius:8px}.filter-input,.filter-select,.filter-date{width:100%;min-width:0}.filter-bar .filter-field{min-width:0}.dashboard-toolbar>*{min-width:0}.toolbar-search{min-width:220px;flex:1 1 260px}.toolbar-btn{height:38px;padding:0 14px;font-size:14px;display:inline-flex;align-items:center;justify-content:center}.toolbar-btn-primary{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}.toolbar-btn-primary:hover{background:var(--primary-hover)}.toolbar-btn-secondary{background:var(--surface-muted);color:var(--text-soft);border-color:var(--border)}.toolbar-btn-secondary:hover{background:var(--button-hover)}.filter-field{display:grid;gap:4px;color:var(--muted);font-size:12px;min-width:150px}.filter-field span{font-weight:600}.active-filter-chips{display:flex;flex-wrap:wrap;gap:8px;margin:-2px 0 14px}.filter-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface-muted);color:var(--text-soft);font-size:12px;font-weight:600}.filter-card{background:var(--surface-muted);border:1px solid var(--border);border-radius:10px;padding:16px;display:grid;gap:14px;width:100%;min-width:0}.filter-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.filter-card-header h3{margin:0;font-size:18px}.filter-group{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.filter-actions{display:flex;justify-content:flex-end;gap:10px}.pagination-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px}.pagination-actions{display:flex;align-items:center;gap:10px}.btn-secondary{background:var(--card);color:var(--text-soft);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--button-hover)}.max-width{max-width:640px}.btn-block{width:100%}.touch-btn{min-height:40px;padding:8px 12px}.btn{height:40px;min-height:40px;padding:0 16px;border-radius:8px;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:6px;text-decoration:none}.error{color:var(--danger);margin:0;padding:10px 12px;border-radius:10px;border:1px solid var(--danger-border);background:var(--danger-bg)}.success{color:var(--success);margin:0;padding:10px 12px;border-radius:10px;border:1px solid var(--success-border);background:var(--success-bg)}.muted{color:var(--text-muted);margin-top:0}.panel{background:var(--card);width:100%;min-width:0}.create-do-page{display:grid;gap:14px;width:100%;min-width:0}.do-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;width:100%;min-width:0}.form-group label{display:block;margin-bottom:6px;font-size:13px;color:var(--muted)}.form-group{width:100%;min-width:0}.create-upload-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));width:100%;min-width:0}.create-upload-dropzone{min-height:84px;display:grid;gap:4px;align-content:center}.upload-label{font-size:13px;font-weight:600;color:var(--text)}.upload-subtext{font-size:12px;color:var(--muted)}.field-hint{margin:6px 0 0;font-size:12px;color:var(--muted);display:block}.upload-ready{color:var(--success);font-weight:600;overflow-wrap:anywhere}.create-do-actions{display:flex;justify-content:flex-start}.action-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.btn-primary{background:var(--primary);color:var(--on-primary);border-color:var(--primary);transition:background-color .2s ease,box-shadow .2s ease,transform .2s ease}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 0 12px #3b82f699;transform:translateY(-1px)}.btn-danger{background:var(--danger);color:var(--on-primary);border-color:var(--danger)}.btn-danger:hover{background:var(--danger-hover)}.btn-logout{background:#ef4444;color:#fff;border-color:#ef4444}.btn-logout:hover{background:#dc2626;border-color:#dc2626}.btn-outline{background:var(--button-bg);color:var(--text);border-color:var(--border-strong)}.btn-outline:hover{background:var(--button-hover);text-decoration:none}table{width:100%;border-collapse:collapse;background:transparent}.table-wrapper,.users-table-wrap{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrapper table,.users-table-wrap table{width:100%;min-width:600px}tbody tr{transition:background-color .18s ease}tbody tr:hover{background:var(--surface-muted)}th,td{border:0;border-bottom:1px solid var(--table-row-border);padding:8px;text-align:left;font-size:14px;color:var(--text)}.date-short{display:none}.date-cell{white-space:nowrap}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;margin-bottom:16px;min-width:0}.row-between{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.photo-section{margin-bottom:24px;padding:16px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.photo-grid img{width:100%;height:140px;object-fit:cover;border:1px solid var(--border);border-radius:8px}.photo-card{display:flex;flex-direction:column;gap:6px;padding:8px;border:1px solid var(--border);border-radius:10px;background:var(--card)}.photo-meta{margin:0;font-size:12px;color:var(--muted)}.pdf-card,.pdf-tile{display:grid;place-items:center}.pdf-card{gap:8px;text-align:center}.pdf-card p{margin:0;max-width:100%;font-size:12px;color:var(--text-soft);overflow-wrap:anywhere}.pdf-tile{width:100%;min-height:90px;border:1px solid var(--border);border-radius:8px;background:var(--surface-muted);color:var(--danger);font-weight:800}.photo-card .pdf-tile{min-height:140px}.pdf-icon{border:2px solid currentColor;border-radius:6px;padding:8px 10px;font-size:13px;line-height:1}.pdf-download{justify-content:center;width:100%;font-size:12px}.attachment-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.attachment-actions .btn-link,.attachment-actions button{width:100%;min-height:36px;justify-content:center;font-size:12px}.do-detail-page{display:grid;gap:16px;width:100%;min-width:0}.do-detail-container{display:flex;align-items:flex-start;gap:28px;width:100%;min-width:0}.main-content{flex:1;min-width:0;display:grid;gap:16px}.sidebar{width:360px;min-width:340px;flex:0 0 360px;border-left:1px solid var(--border);padding-left:20px}.activity-sidebar{position:sticky;top:20px;height:fit-content}.do-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px;border:1px solid var(--border);border-radius:10px;background:var(--card);box-shadow:var(--shadow);min-width:0}.do-title{margin:0;font-size:30px;line-height:1.1}.do-subline{margin-top:8px;display:flex;flex-wrap:wrap;gap:14px;color:var(--muted);font-size:14px}.do-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize}.status-delivered{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.status-pending{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.status-issue{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.status-store-load{background:var(--primary-soft);color:var(--primary);border:1px solid rgba(59,130,246,.28)}.status-store-unload{background:var(--inactive-bg);color:var(--inactive-text);border:1px solid var(--inactive-border)}.status-active{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.status-inactive{background:var(--inactive-bg);color:var(--inactive-text);border:1px solid var(--inactive-border)}.btn-link{display:inline-flex;align-items:center;padding:8px 10px;border:1px solid var(--border-strong);border-radius:8px;background:var(--button-bg)}.btn.btn-link{padding:0 16px}.do-info-card{border:1px solid var(--border);border-radius:12px;background:var(--card);padding:20px 24px;box-shadow:var(--shadow);width:100%;min-width:0}.do-info-card h3{margin:0 0 12px}.do-info{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;gap:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.info-row:last-child{padding-bottom:0;border-bottom:0}.info-row>div{min-width:0;flex:1}.info-label{margin:0 0 4px;color:var(--muted);font-size:12px}.info-value{margin:0;font-size:15px;color:var(--text);font-weight:600;overflow-wrap:anywhere}.section-card{border:1px solid var(--border);border-radius:12px;background:var(--card);padding:20px 24px;box-shadow:var(--shadow);width:100%;min-width:0}.table-skeleton{display:grid;gap:10px}.skeleton-table-row{width:100%;height:56px;border-radius:12px}.empty-state-card{display:grid;gap:10px;justify-items:start;padding:28px 24px;border:1px dashed var(--border-strong);border-radius:14px;background:var(--surface-muted)}.empty-state-card h3,.empty-state-card p{margin:0}.notice-modal{max-width:440px}.notice-modal-message{line-height:1.6;color:var(--text-soft)}.workflow-card{display:grid;gap:16px}.workflow-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.workflow-card-copy{margin-bottom:0}.workflow-track{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.workflow-step{position:relative;display:grid;gap:12px;padding:14px 14px 16px;border:1px solid var(--border);border-radius:14px;background:var(--surface-muted);min-width:0}.workflow-step:after{content:"";position:absolute;top:23px;left:calc(100% + 6px);width:12px;height:2px;background:var(--border)}.workflow-step:last-child:after{display:none}.workflow-step-current{border-color:#2563eb59;background:linear-gradient(180deg,var(--card),var(--primary-soft));box-shadow:var(--shadow)}.workflow-step-done{border-color:var(--success-border);background:var(--success-bg)}.workflow-step-future{opacity:.78}.workflow-step-dot{width:16px;height:16px;border-radius:999px;border:3px solid var(--border-strong);background:var(--card)}.workflow-step-current .workflow-step-dot{border-color:var(--primary);background:var(--primary);box-shadow:0 0 0 5px var(--primary-soft)}.workflow-step-done .workflow-step-dot{border-color:var(--success);background:var(--success)}.workflow-step-label{margin:0 0 4px;font-size:13px;font-weight:700;color:var(--text)}.workflow-step-owner{margin:0;font-size:12px;color:var(--text-muted)}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.section-meta-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.section-owner-badge,.section-state-badge{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.01em}.section-owner-badge{border:1px solid var(--border);background:var(--surface-muted);color:var(--text-soft)}.section-state-badge-current{border:1px solid rgba(37,99,235,.35);background:var(--primary-soft);color:var(--primary)}.section-state-badge-done{border:1px solid var(--success-border);background:var(--success-bg);color:var(--success)}.section-state-badge-muted{border:1px solid var(--border);background:var(--surface-muted);color:var(--text-muted)}.photo-section-active{border-color:#2563eb57;box-shadow:0 0 0 1px #2563eb14,var(--shadow)}.photo-section-done{border-color:var(--success-border)}.photo-section-future{opacity:.88}.skeleton{display:block;border-radius:8px;background:linear-gradient(90deg,var(--surface-muted) 0%,var(--border) 48%,var(--surface-muted) 100%);background-size:200% 100%;animation:skeleton-pulse 1.2s ease-in-out infinite}.skeleton-title{width:min(320px,70vw);height:34px;margin-bottom:12px}.skeleton-row{display:flex;gap:14px;flex-wrap:wrap}.skeleton-text{width:180px;height:16px}.skeleton-block{width:100%;min-height:140px}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.section-title{margin:0 0 8px;font-size:18px}.section-row{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;width:100%;min-width:0}.section-left{flex:1;min-width:0;display:grid;gap:12px}.section-header{display:grid;gap:2px}.activity-section{display:flex;flex-direction:column;gap:14px}.remark-form{display:grid;grid-template-columns:1fr;gap:10px;align-items:start}.remark-form button{width:100%;min-width:0}.btn-modern{background:var(--primary);color:var(--on-primary);border:1px solid var(--primary);border-radius:10px;padding:10px 16px;font-weight:600;transition:all .2s ease}.btn-modern:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:var(--primary-shadow);transform:translateY(-1px)}.btn-modern:active:not(:disabled){background:var(--primary-active);border-color:var(--primary-active);box-shadow:var(--primary-shadow-active);transform:translateY(0)}.btn-modern:disabled{background:var(--border-strong);border-color:var(--border-strong);box-shadow:none;transform:none;cursor:not-allowed;opacity:1}.activity-timeline{display:grid;gap:12px}.logs{max-height:400px;overflow-y:auto;padding-right:4px}.activity-item{display:grid;grid-template-columns:16px minmax(0,1fr);gap:10px;margin-bottom:12px;min-width:0}.activity-marker{width:10px;height:10px;margin-top:6px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}.activity-body{min-width:0;border:1px solid var(--border);border-radius:8px;padding:12px 14px;background:var(--surface-muted)}.activity-meta{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:12px}.activity-action{margin:6px 0 0;color:var(--text);font-weight:700}.activity-remark{margin:6px 0 0;color:var(--text-soft);line-height:1.5;overflow-wrap:anywhere}.section-right{width:260px;flex:0 0 260px;display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--surface-muted)}.section-right button,.section-right .upload-dropzone{width:100%}.upload-dropzone{position:relative;min-width:0;width:100%;border:1px dashed var(--border-strong);border-radius:8px;padding:8px 12px;background:var(--surface-muted);color:var(--text-soft);font-size:13px;text-align:center;cursor:pointer}.compact-dropzone{border:1px dashed var(--border-strong);padding:10px;font-size:13px;color:var(--muted)}.compact-dropzone-text{display:block}.upload-dropzone input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.upload-dropzone-active{border-color:var(--primary);background:var(--primary-soft)}.upload-action-btn{width:100%;min-height:40px;height:40px;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.complete-action-btn{margin-top:2px}.complete-action-btn.complete-action-btn-done,.complete-action-btn.complete-action-btn-done:disabled{background:var(--success);border-color:var(--success);color:var(--on-primary)}.selected-grid{margin-top:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;min-width:0}.selected-card{border:1px solid var(--border);border-radius:8px;padding:8px;background:var(--card)}.selected-card img{width:100%;height:90px;object-fit:cover;border-radius:6px}.selected-card p{margin:6px 0 0;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted)}.users-page{display:grid;gap:16px;width:100%;min-width:0}.users-table-wrap{overflow-x:auto}.user-actions{display:flex;flex-wrap:wrap;gap:8px;min-width:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);display:flex;align-items:center;justify-content:center;padding:16px;z-index:1200}.confirm-modal{width:100%;max-width:420px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px;box-shadow:var(--shadow-strong);display:grid;gap:10px}.confirm-modal h3,.confirm-modal p{margin:0}.warning-text{color:var(--danger-hover);font-weight:600}.confirm-target{font-size:13px;color:var(--text-soft);background:var(--surface-muted);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.modal-actions{display:flex;justify-content:flex-end;gap:8px}@media (max-width: 768px){.date-full{display:none}.date-short{display:inline}.login-page{padding:0;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-end) 100%)}.login-layout{min-height:auto;grid-template-columns:1fr;border-radius:0;border:0;box-shadow:none}.login-brand-panel{padding:24px 20px 16px}.login-brand-content{gap:10px}.login-brand-logo{width:56px;height:56px}.login-brand-title{font-size:28px}.login-brand-subtitle{font-size:16px}.login-brand-description{font-size:14px;line-height:1.6;max-width:none}.login-form-panel{padding:16px 20px 24px;align-items:flex-start}.login-form-card{max-width:none;padding:20px}.login-card{width:100%;max-width:none;padding:20px}.app-shell{padding:12px}.content{padding:14px}.centered-card{margin:30px auto;width:100%}button,.btn-link,.nav-logout-btn{width:100%}.topbar{flex-direction:column;align-items:flex-start}.inline-form{flex-direction:column}.dashboard-toolbar{gap:10px;flex-direction:column;align-items:stretch}.filter-bar{grid-template-columns:1fr;align-items:stretch}.sticky-filter-bar{top:72px}.filter-bar button{width:100%}.filter-row{flex-direction:column}.toolbar-search{min-width:0;flex:1 1 100%}.dashboard-toolbar select,.dashboard-toolbar input[type=date]{width:100%;flex:1 1 auto;min-width:0}.dashboard-toolbar button{width:100%}.dashboard-filters{flex-direction:column}.dashboard-filters input,.dashboard-filters select,.dashboard-filters button,.filter-field{width:100%}.filter-card-header,.filter-actions{flex-direction:column;align-items:stretch}.filter-group{grid-template-columns:1fr}.pagination-row{align-items:stretch;flex-direction:column}.pagination-actions{width:100%}.pagination-actions button{flex:1}.action-row{width:100%;flex-wrap:wrap}.do-header,.do-detail-container{flex-direction:column}.sidebar{width:100%;min-width:0;flex:1 1 auto;border-left:0;padding-left:0}.info-row{flex-direction:column;gap:10px}.activity-sidebar{position:static}.logs{max-height:400px}.do-title{font-size:24px}.do-header-actions,.upload-dropzone{width:100%}.section-row{flex-direction:column}.workflow-card-header{flex-direction:column;align-items:flex-start}.workflow-track{grid-template-columns:1fr}.workflow-step:after{display:none}.section-right{width:100%;flex:1 1 auto}.remark-form{grid-template-columns:1fr}.remark-form button{width:100%}.touch-btn{min-height:44px;width:100%}.user-actions{flex-direction:column}.user-actions button{width:100%}.modal-actions{flex-direction:column}.modal-actions button{width:100%}.do-grid,.create-upload-grid{grid-template-columns:1fr}.nav-right{width:100%;justify-content:flex-start}.nav-right button,.nav-right .nav-logout-btn{width:auto}}@media (max-width: 900px){.app-navbar-inner{align-items:flex-start;padding:12px 16px}.nav-left{flex-wrap:wrap;gap:16px}.navbar-brand{flex:1 1 260px}.main-nav{justify-content:flex-start;flex-wrap:wrap;gap:18px;padding-top:0;margin-top:0;border-top:0}.brand-main{font-size:16px}.nav-right{width:auto;flex-direction:row;align-items:center}.role-pill{align-self:center}.do-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 901px) and (max-width: 1200px){.do-grid{grid-template-columns:repeat(3,1fr)}}.app-layout{--bg: #f4f7fb;--bg-end: #eaf0f7;--card: #ffffff;--card-secondary: #f7f9fc;--card-soft: #f3f6fb;--surface-muted: #f6f8fb;--surface-raised: #ffffff;--border: #dde5f0;--border-strong: #c8d3e2;--table-row-border: #e6edf5;--text: #111827;--text-soft: #263445;--text-muted: #667085;--muted: #667085;--primary: #1f6feb;--primary-hover: #1959c9;--primary-active: #164da9;--primary-soft: #eaf2ff;--shadow: 0 10px 24px rgba(31, 42, 68, .07);--navbar-shadow: 0 1px 0 rgba(15, 23, 42, .08), 0 12px 26px rgba(15, 23, 42, .06);background:linear-gradient(180deg,#1f6feb0f,#f4f7fb00 280px),var(--bg)}[data-theme=dark] .app-layout{--bg: #0d1117;--bg-end: #0d1117;--card: #151b23;--card-secondary: #111820;--card-soft: #101820;--surface-muted: #101820;--surface-raised: #151b23;--border: #263241;--border-strong: #334155;--table-row-border: #263241;--text: #e6edf3;--text-soft: #d1d9e0;--text-muted: #97a6b6;--muted: #97a6b6;--primary: #58a6ff;--primary-hover: #79b8ff;--primary-active: #388bfd;--primary-soft: rgba(88, 166, 255, .14);--shadow: 0 12px 30px rgba(0, 0, 0, .34);--navbar-shadow: 0 1px 0 rgba(255, 255, 255, .06), 0 16px 34px rgba(0, 0, 0, .28);background:linear-gradient(180deg,#58a6ff14,#0d111700 280px),var(--bg)}.app-navbar{background:#ffffffeb;border-bottom:1px solid rgba(203,213,225,.72);box-shadow:var(--navbar-shadow)}[data-theme=dark] .app-navbar{background:#0d1117eb;border-bottom-color:#334155cc}.app-navbar-inner{max-width:1480px;padding:10px 24px;gap:18px}.navbar-brand{gap:12px}.brand-logo{width:42px;height:42px;border-radius:8px;border-color:var(--border);box-shadow:0 6px 14px #0f172a14}.brand-main{font-size:15px;font-weight:700;letter-spacing:0}.brand-sub{font-size:12px;color:var(--text-muted)}.divider{height:30px;background:var(--border)}.main-nav{gap:4px;padding:4px;border:1px solid var(--border);border-radius:8px;background:var(--surface-muted)}.main-nav-link{min-height:34px;display:inline-flex;align-items:center;border:0;border-radius:6px;padding:0 12px;color:var(--text-soft);font-size:13px;font-weight:650}.main-nav-link:hover{background:var(--button-hover)}.main-nav-link-active{color:var(--primary);background:var(--card);box-shadow:0 1px 4px #0f172a14}.nav-right{gap:10px}.role-pill{min-height:32px;min-width:0;border-radius:8px;padding:0 10px;background:var(--primary-soft);color:var(--primary);font-weight:700}.theme-toggle-btn,.nav-logout-btn{min-height:36px;height:36px;border-radius:8px}.btn-logout{background:#dc2626;border-color:#dc2626}.btn-logout:hover{background:#b91c1c;border-color:#b91c1c}.app-shell{max-width:1480px;padding:22px 24px 40px}.content{padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.content h2,.do-title{letter-spacing:0}.content h2{margin:0 0 18px;font-size:28px;line-height:1.15;color:var(--text)}.dashboard-page,.create-do-page,.users-page,.do-detail-page{gap:18px}.section-card,.do-info-card,.filter-card,.do-header,.empty-state-card{border-radius:8px;border-color:var(--border);box-shadow:var(--shadow)}.section-card,.do-info-card{padding:22px}.section-title{margin-bottom:14px;font-size:17px;color:var(--text)}.filter-bar{grid-template-columns:minmax(240px,1.55fr) minmax(160px,.9fr) minmax(170px,.9fr) minmax(150px,.75fr) repeat(4,max-content);gap:10px;align-items:end;margin-bottom:18px;padding:12px;border-radius:8px;border-color:var(--border);background:#fffffff0;box-shadow:var(--shadow)}[data-theme=dark] .filter-bar{background:#151b23f0}.sticky-filter-bar{top:74px}.filter-field{gap:6px;color:var(--text-muted);font-size:12px}.filter-field span{font-weight:700}input,select,textarea{border-color:var(--border-strong);border-radius:8px;background:var(--input-bg);color:var(--text);transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:#1f6febb8;box-shadow:0 0 0 3px #1f6feb21}.toolbar-btn,.btn,.touch-btn,.btn-modern,.button-primary,.btn-primary,.btn-secondary,.btn-outline,.btn-danger,.btn-link{border-radius:8px;font-weight:650}.toolbar-btn{min-height:40px;height:40px}.toolbar-btn-primary,.btn-primary,.btn-modern{background:var(--primary);border-color:var(--primary);color:var(--on-primary);box-shadow:0 8px 18px #1f6feb29}.toolbar-btn-primary:hover,.btn-primary:hover,.btn-modern:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 10px 20px #1f6feb33;transform:translateY(-1px)}.toolbar-btn-secondary,.btn-secondary,.btn-outline,.btn-link{background:var(--surface-raised);color:var(--text-soft);border-color:var(--border)}.toolbar-btn-secondary:hover,.btn-secondary:hover,.btn-outline:hover,.btn-link:hover{background:var(--surface-muted)}.active-filter-chips{margin:0 0 16px}.filter-chip{border-radius:8px;background:var(--primary-soft);color:var(--primary);border-color:#1f6feb33}.table-wrapper,.users-table-wrap{border:1px solid var(--border);border-radius:8px;background:var(--card);box-shadow:var(--shadow)}table{border-collapse:separate;border-spacing:0}thead th{position:sticky;top:0;z-index:1;background:var(--surface-muted);color:var(--text-soft);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.02em}th,td{padding:13px 14px;vertical-align:middle}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--card-soft)}td a{font-weight:800}.status-badge{min-height:26px;border-radius:8px;padding:4px 9px;font-size:11px;letter-spacing:0;text-transform:none}.status-pending{background:#fff7db;color:#8a5f00;border-color:#edd38d}.status-issue{background:#ffecef;color:#a61b38;border-color:#f2b8c2}.status-store-load{background:#eaf5ff;color:#0f609b;border-color:#add8f4}.status-store-unload{background:#f0f3f7;color:#475467;border-color:#d7dee8}.status-delivered,.status-active{background:#eaf8ef;color:#087443;border-color:#addfc1}.status-inactive{background:#f1f3f6;color:#5f6b7a;border-color:#d9e0e8}[data-theme=dark] .status-pending{background:#facc151f;color:#facc15;border-color:#facc154d}[data-theme=dark] .status-issue{background:#f871711f;color:#fb7185;border-color:#f8717152}[data-theme=dark] .status-store-load{background:#38bdf81f;color:#7dd3fc;border-color:#38bdf852}[data-theme=dark] .status-store-unload,[data-theme=dark] .status-inactive{background:#94a3b81f;color:#cbd5e1;border-color:#94a3b847}[data-theme=dark] .status-delivered,[data-theme=dark] .status-active{background:#4ade801f;color:#86efac;border-color:#4ade8052}.pagination-row{margin-top:14px;padding:0 2px}.pagination-row .muted{margin:0;font-size:13px}.do-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.form-group label,.stack-form label{font-size:13px;font-weight:700;color:var(--text-soft)}.field-hint{color:var(--text-muted)}.create-upload-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.upload-dropzone{border-radius:8px;border-color:var(--border-strong);background:var(--surface-muted)}.create-upload-dropzone{min-height:112px;padding:18px 14px}.upload-label{font-size:14px}.upload-subtext,.compact-dropzone-text{color:var(--text-muted)}.upload-dropzone:hover,.upload-dropzone-active{border-color:#1f6febb8;background:var(--primary-soft)}.do-detail-container{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:22px}.sidebar{width:auto;min-width:0;flex:initial;border-left:0;padding-left:0}.activity-sidebar{top:96px}.do-header{align-items:center;padding:18px 20px}.do-title{font-size:32px}.do-subline{gap:18px}.workflow-track{gap:10px}.workflow-step{border-radius:8px;background:var(--surface-muted)}.photo-section{margin-bottom:0}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.photo-card,.selected-card,.activity-body,.section-right,.confirm-modal{border-radius:8px}.activity-body{background:var(--card)}.logs{max-height:520px}.users-page>.muted{margin-bottom:0}.users-page .section-card .max-width{max-width:none;grid-template-columns:minmax(160px,1.1fr) minmax(150px,1fr) minmax(150px,1fr) minmax(140px,.9fr) minmax(150px,1fr) minmax(150px,.7fr);align-items:end}.users-page .section-card .max-width button{align-self:end}.filter-card{background:var(--card)}.filter-card .stack-form{gap:12px}.user-actions{gap:6px}.user-actions button{min-height:36px;padding:7px 10px;font-size:12px}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal{padding:20px}@media (max-width: 1200px){.filter-bar{grid-template-columns:repeat(4,minmax(0,1fr))}.filter-input{grid-column:span 4}.filter-bar button{width:100%}.do-grid,.users-page .section-card .max-width,.create-upload-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.do-detail-container{grid-template-columns:1fr}.activity-sidebar{position:static}}@media (max-width: 900px){.app-navbar-inner{padding:10px 16px;gap:12px}.nav-left{width:100%;gap:12px}.divider{display:none}.main-nav{order:3;width:100%;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}.main-nav::-webkit-scrollbar{display:none}.main-nav-link{flex:1 0 auto;justify-content:center}.nav-right{width:100%;justify-content:space-between}.nav-right button,.nav-right .nav-logout-btn{width:auto;flex:1 1 0}.role-pill{flex:0 0 auto}.sticky-filter-bar{position:static}}@media (max-width: 768px){.app-shell{padding:14px 12px 28px}.content h2{margin-bottom:14px;font-size:25px}.section-card,.do-info-card,.filter-card,.do-header{padding:16px}.filter-bar{grid-template-columns:1fr;gap:10px;padding:10px}.filter-input{grid-column:auto}.filter-input,.filter-select,.filter-date,.filter-bar button{height:42px}.active-filter-chips{margin-bottom:12px}.table-wrapper,.users-table-wrap{border:0;background:transparent;box-shadow:none;overflow:visible}.table-wrapper table,.users-table-wrap table{min-width:0}.table-wrapper table,.table-wrapper thead,.table-wrapper tbody,.table-wrapper th,.table-wrapper td,.table-wrapper tr,.users-table-wrap table,.users-table-wrap thead,.users-table-wrap tbody,.users-table-wrap th,.users-table-wrap td,.users-table-wrap tr{display:block;width:100%}.table-wrapper thead,.users-table-wrap thead{display:none}.table-wrapper tbody,.users-table-wrap tbody{display:grid;gap:10px}.table-wrapper tbody tr,.users-table-wrap tbody tr{display:grid;gap:0;border:1px solid var(--border);border-radius:8px;background:var(--card);box-shadow:var(--shadow);overflow:hidden}.table-wrapper td,.users-table-wrap td{display:grid;grid-template-columns:104px minmax(0,1fr);gap:12px;align-items:center;min-height:42px;border-bottom:1px solid var(--table-row-border);padding:10px 12px;overflow-wrap:anywhere}.table-wrapper td:last-child,.users-table-wrap td:last-child{border-bottom:0}.table-wrapper td:before,.users-table-wrap td:before{content:attr(data-label);color:var(--text-muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.02em}.table-wrapper td:first-child{grid-template-columns:1fr;background:var(--surface-muted)}.table-wrapper td:first-child:before{display:none}.table-wrapper td:first-child a{font-size:17px}.date-full{display:inline}.date-short{display:none}.pagination-actions{display:grid;grid-template-columns:1fr 1fr}.do-grid,.users-page .section-card .max-width,.filter-group,.create-upload-grid{grid-template-columns:1fr}.create-do-actions,.create-do-actions button{width:100%}.do-header{align-items:stretch}.do-header-actions{display:grid;grid-template-columns:1fr 1fr}.do-header-actions .status-badge{grid-column:1 / -1;justify-self:start}.workflow-track{grid-template-columns:1fr}.workflow-step{grid-template-columns:18px minmax(0,1fr);align-items:start}.section-row{gap:14px}.photo-grid,.selected-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.users-table-wrap td[data-label=Actions]{grid-template-columns:1fr}.users-table-wrap td[data-label=Actions]:before{margin-bottom:2px}.user-actions{display:grid;grid-template-columns:1fr}}@media (max-width: 480px){.app-navbar-inner{padding:10px 12px}.brand-logo{width:38px;height:38px}.brand-main{font-size:14px}.brand-sub{font-size:11px}.role-pill{width:100%}.nav-right{display:grid;grid-template-columns:1fr 1fr}.nav-right .role-pill{grid-column:1 / -1}.photo-grid,.selected-grid{grid-template-columns:1fr}}@media (max-width: 768px){.app-navbar{position:sticky;top:0}.app-navbar-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px 12px;padding:10px 14px}.nav-left{display:contents}.nav-right{grid-column:2;grid-row:1;display:flex;width:auto;gap:8px;justify-content:flex-end}.navbar-brand{grid-column:1;min-width:0}.brand-logo{width:36px;height:36px}.brand-main{font-size:14px}.brand-sub{font-size:11px}.role-pill{display:none}.theme-toggle-btn{display:inline-flex;width:auto;min-width:66px;height:36px;min-height:36px;padding:0 12px}.nav-logout-btn{width:auto;min-width:84px;height:36px;min-height:36px;padding:0 14px}.main-nav{grid-column:1 / -1;grid-row:2;width:100%;padding:3px;gap:3px}.main-nav-link{min-height:36px;padding:0 8px;font-size:12px}.app-shell{padding-top:16px}}@media (max-width: 420px){.app-navbar-inner{padding:9px 12px}.nav-logout-btn{min-width:76px;padding:0 12px}.theme-toggle-btn{min-width:58px;padding:0 10px}}.mobile-menu-toggle{display:none}@media (max-width: 768px){.app-navbar-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 14px}.app-navbar .nav-left{display:contents}.app-navbar .navbar-brand{grid-column:1;grid-row:1}.mobile-menu-toggle{grid-column:2;grid-row:1;width:42px;height:38px;min-height:38px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--surface-raised)}.mobile-menu-toggle span{width:18px;height:2px;border-radius:999px;background:var(--text);transition:transform .18s ease,opacity .18s ease}.app-navbar-menu-open .mobile-menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}.app-navbar-menu-open .mobile-menu-toggle span:nth-child(2){opacity:0}.app-navbar-menu-open .mobile-menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.app-navbar .divider,.app-navbar .main-nav,.app-navbar .nav-right{display:none}.app-navbar-menu-open .main-nav{grid-column:1 / -1;grid-row:2;width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;margin:0;padding:4px}.app-navbar-menu-open .main-nav-link{justify-content:center;min-height:38px;padding:0 8px}.app-navbar-menu-open .nav-right{grid-column:1 / -1;grid-row:3;width:100%;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.app-navbar-menu-open .role-pill,.app-navbar-menu-open .theme-toggle-btn,.app-navbar-menu-open .nav-logout-btn{width:100%;min-width:0;min-height:38px;height:38px}.app-navbar-menu-open .role-pill,.app-navbar-menu-open .theme-toggle-btn,.app-navbar-menu-open .nav-logout-btn{display:inline-flex}.app-shell{padding-top:16px}}@media (max-width: 420px){.app-navbar-menu-open .nav-right{grid-template-columns:1fr 1fr}.app-navbar-menu-open .role-pill{grid-column:1 / -1}}.main-nav-links{display:flex;align-items:center;gap:4px}.mobile-menu-heading,.mobile-menu-close,.mobile-menu-backdrop{display:none}@media (max-width: 768px){.app-navbar .main-nav,.app-navbar .nav-right{display:none}.mobile-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;display:block;width:100%;min-height:100vh;padding:0;border:0;border-radius:0;background:#02061794;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.app-navbar-menu-open .mobile-menu-toggle{visibility:hidden}.app-navbar-menu-open .main-nav{position:fixed;top:0;right:0;z-index:10000;width:min(84vw,330px);height:100vh;display:flex;flex-direction:column;align-items:stretch;gap:16px;margin:0;padding:18px 18px 138px;overflow-y:auto;border:0;border-left:1px solid var(--border);border-radius:0;background:var(--card);box-shadow:-20px 0 44px #02061757}.mobile-menu-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border);color:var(--text);font-size:18px;font-weight:800}.mobile-menu-close{width:38px;height:38px;min-height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:8px;background:var(--surface-muted);color:transparent;font-size:0}.mobile-menu-close:before{content:"X";color:var(--text);font-size:16px;font-weight:800;line-height:1}.app-navbar-menu-open .main-nav-links{display:grid;gap:8px}.app-navbar-menu-open .main-nav-link{min-height:46px;justify-content:flex-start;padding:0 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface-muted)}.app-navbar-menu-open .main-nav-link-active{background:var(--primary-soft);color:var(--primary);border-color:#1f6feb47}.app-navbar-menu-open .nav-right{position:fixed;right:0;bottom:0;z-index:10001;width:min(84vw,330px);display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:16px 18px 18px;border-left:1px solid var(--border);background:var(--card);box-shadow:-20px -8px 34px #0206172e}.app-navbar-menu-open .role-pill,.app-navbar-menu-open .theme-toggle-btn,.app-navbar-menu-open .nav-logout-btn{width:100%;min-width:0;min-height:40px;height:40px}.app-navbar-menu-open .role-pill{grid-column:1 / -1;display:inline-flex}.app-navbar-menu-open .theme-toggle-btn,.app-navbar-menu-open .nav-logout-btn{display:inline-flex}}.mobile-menu-actions{display:none}@keyframes mobileDrawerIn{0%{opacity:.9;transform:translate(22px)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.app-navbar-menu-open .app-navbar-inner>.nav-right{display:none}.app-navbar-menu-open .main-nav{position:fixed;inset:0 0 0 auto;z-index:10000;width:min(86vw,340px);height:100dvh;display:flex;flex-direction:column;align-items:stretch;gap:16px;margin:0;padding:18px;overflow-y:auto;border:0;border-left:1px solid var(--border);border-radius:0;background:var(--card);box-shadow:-24px 0 46px #02061757;animation:mobileDrawerIn .18s ease-out}.app-navbar-menu-open .main-nav-links{display:grid;grid-template-columns:1fr;gap:10px}.app-navbar-menu-open .mobile-menu-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:auto;padding-top:16px;border-top:1px solid var(--border)}.app-navbar-menu-open .mobile-menu-actions .role-pill{grid-column:1 / -1;width:100%;min-height:40px;justify-content:center}.app-navbar-menu-open .mobile-menu-actions .theme-toggle-btn,.app-navbar-menu-open .mobile-menu-actions .nav-logout-btn{width:100%;min-width:0;min-height:42px;height:42px}}[data-theme=dark] .app-layout{--bg: #050505;--bg-end: #050505;--card: #171717;--card-secondary: #111111;--card-soft: #141414;--surface-muted: #101010;--surface-raised: #1b1b1b;--border: #2b2b2b;--border-strong: #3a3a3a;--table-row-border: #2b2b2b;--text: #f5f5f5;--text-soft: #d9d9d9;--text-muted: #a6a6a6;--muted: #a6a6a6;--primary: #2f81f7;--primary-hover: #4c94ff;--primary-active: #1f6feb;--primary-soft: rgba(47, 129, 247, .18);--button-hover: #202020;--input-bg: #0d0d0d;--shadow: none;--navbar-shadow: none;background:var(--bg)}[data-theme=dark] .app-navbar{background:#050505f5;border-bottom-color:#272727;box-shadow:none}[data-theme=dark] .page-card,[data-theme=dark] .summary-card,[data-theme=dark] .form-section,[data-theme=dark] .images-section,[data-theme=dark] .detail-card,[data-theme=dark] .user-management-card,[data-theme=dark] .dashboard-page .filters-card,[data-theme=dark] .users-page .filters-card,[data-theme=dark] .table-wrapper,[data-theme=dark] .users-table-wrap{background:var(--card);border-color:var(--border)}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--input-bg);border-color:#303030}[data-theme=dark] .main-nav,[data-theme=dark] .dropzone,[data-theme=dark] .activity-body,[data-theme=dark] .mobile-menu-close{background:var(--surface-muted);border-color:var(--border)}.mobile-menu-close:before{content:none}@media (max-width: 768px){.mobile-menu-close{color:var(--text);font-size:16px;font-weight:800}}.do-detail-page{--detail-accent: rgba(31, 111, 235, .12)}.do-detail-container{grid-template-columns:minmax(0,1fr) minmax(340px,420px);align-items:start;gap:24px}.do-header{position:relative;align-items:stretch;overflow:hidden;padding:24px 26px;border:1px solid rgba(31,111,235,.16);background:linear-gradient(135deg,#1f6feb1a,#fff0 42%),var(--card)}.do-header:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:var(--primary)}.do-header-main{display:grid;gap:8px;min-width:0}.do-eyebrow{margin:0;color:var(--primary);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.do-title{font-size:clamp(30px,4vw,44px);line-height:.95}.do-subline{margin-top:2px;gap:10px}.do-subline span{display:inline-flex;align-items:center;min-height:30px;padding:4px 10px;border:1px solid var(--border);border-radius:8px;background:#ffffffa8;color:var(--text-soft)}.do-subline strong{margin-right:4px}[data-theme=dark] .do-subline span{background:#ffffff0a}.do-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:12px}.do-summary-item{display:grid;gap:4px;min-width:0;padding:12px;border:1px solid var(--border);border-radius:8px;background:#ffffffbd}[data-theme=dark] .do-summary-item{background:#ffffff0a}.do-summary-item span{color:var(--text-muted);font-size:11px;font-weight:800;letter-spacing:.03em;text-transform:uppercase}.do-summary-item strong{min-width:0;color:var(--text);font-size:16px;line-height:1.2;overflow-wrap:anywhere}.do-header-actions{align-content:start;justify-content:flex-end;flex-wrap:nowrap;min-width:420px}.do-header-actions .btn,.do-header-actions .btn-link{flex:0 0 auto}.card-heading-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.card-heading-row h3,.card-heading-row .section-title{margin-bottom:4px}.card-heading-row .muted{margin:0}.do-info-card,.workflow-card,.photo-section,.activity-section{border-radius:10px;border-color:#cbd5e1e6;background:#fffffff5}[data-theme=dark] .do-info-card,[data-theme=dark] .workflow-card,[data-theme=dark] .photo-section,[data-theme=dark] .activity-section{background:var(--card);border-color:var(--border)}.do-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.info-tile{min-width:0;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--surface-muted)}.info-tile .info-label{margin-bottom:8px;font-weight:800;letter-spacing:.02em;text-transform:uppercase}.info-tile .info-value{font-size:16px}.workflow-track{grid-template-columns:repeat(5,minmax(128px,1fr))}.workflow-step{gap:14px;padding:16px;border-color:var(--border);background:linear-gradient(180deg,var(--surface-muted),var(--card))}.workflow-step:after{top:30px}.workflow-step-dot{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-width:2px;color:var(--text-muted);font-size:12px;font-weight:900}.workflow-step-current{background:linear-gradient(180deg,var(--card),var(--primary-soft))}.workflow-step-current .workflow-step-dot,.workflow-step-done .workflow-step-dot{color:var(--on-primary)}.workflow-step-label{font-size:14px}.photo-section{padding:22px 24px}.photo-section-active{background:linear-gradient(90deg,#1f6feb14,#1f6feb00 36%),var(--card)}.photo-section-future{opacity:1}.photo-section-future .section-left{opacity:.68}.photo-empty-state{display:grid;gap:4px;padding:18px;border:1px dashed var(--border-strong);border-radius:8px;background:var(--surface-muted)}.photo-empty-state p{margin:0;color:var(--text);font-weight:800}.photo-empty-state .muted{margin:0}.photo-card{overflow:hidden;padding:10px}.photo-card img,.photo-card .pdf-tile{border-radius:8px}.section-right{width:290px;flex-basis:290px;padding:14px;background:linear-gradient(180deg,var(--surface-muted),var(--card))}.compact-dropzone{min-height:76px;display:grid;place-items:center;border-radius:8px;background:transparent}.activity-sidebar{top:86px}.activity-section{max-height:calc(100vh - 112px);overflow:hidden}.activity-heading-row{align-items:center;margin-bottom:8px}.activity-count{min-width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-weight:900}.activity-timeline{position:relative;gap:0;padding-left:4px}.activity-timeline:before{content:"";position:absolute;top:10px;bottom:10px;left:8px;width:2px;background:var(--border)}.logs{max-height:min(52vh,560px)}.activity-item{position:relative;grid-template-columns:18px minmax(0,1fr);gap:14px;margin-bottom:14px}.activity-marker{position:relative;z-index:1;width:12px;height:12px;margin-top:18px;border:2px solid var(--card)}.activity-body{padding:14px 16px;background:var(--card)}.activity-action{font-size:15px}.remark-form{padding-top:14px;border-top:1px solid var(--border)}.remark-form textarea{min-height:94px}@media (max-width: 1280px){.do-detail-container{grid-template-columns:minmax(0,1fr)}.activity-sidebar{position:static}.activity-section{max-height:none}.logs{max-height:420px}}@media (max-width: 900px){.do-header{padding:20px}.do-header-actions{justify-content:flex-start;min-width:0;width:100%}.do-summary-grid,.do-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.workflow-track{grid-template-columns:1fr}.workflow-step:after{display:none}.section-row{display:grid}.section-right{width:100%;flex-basis:auto}}@media (max-width: 560px){.do-summary-grid,.do-info-grid{grid-template-columns:1fr}.card-heading-row{display:grid}}.do-detail-page{--detail-line: color-mix(in srgb, var(--border) 78%, transparent)}.do-detail-container{grid-template-columns:minmax(0,1fr) 380px;gap:18px}.main-content{gap:12px}.do-header,.do-info-card,.workflow-card,.photo-section,.activity-section{border-radius:8px;border:1px solid var(--detail-line);box-shadow:none;background:var(--card)}.do-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;padding:22px 24px;overflow:visible;background:var(--card)}.do-header:before{display:none}.do-header-main{gap:10px}.do-eyebrow{color:var(--text-muted);font-size:11px;letter-spacing:.1em}.do-title{font-size:40px;line-height:1}.do-subline{gap:18px;color:var(--text-soft)}.do-subline span{min-height:0;padding:0;border:0;background:transparent}.do-header-actions{min-width:0;align-self:start;display:flex;align-items:center;justify-content:flex-end;gap:10px}.do-info-card,.workflow-card,.photo-section{padding:20px 24px}.card-heading-row{margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--detail-line)}.card-heading-row h3,.section-title{font-size:18px}.do-info-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:0;border:1px solid var(--detail-line);border-radius:8px;overflow:hidden}.info-tile{padding:14px 16px;border:0;border-right:1px solid var(--detail-line);border-bottom:0;border-radius:0;background:transparent}.info-tile:last-child{border-bottom:0;border-right:0}.info-tile .info-label{margin-bottom:6px;color:var(--text-muted);font-size:11px}.info-tile .info-value{font-size:15px}.workflow-card{gap:14px}.workflow-card-header{align-items:center}.workflow-card-copy{display:none}.workflow-track{position:relative;grid-template-columns:repeat(5,minmax(0,1fr));gap:0;padding:8px 0 2px}.workflow-step{position:relative;display:grid;grid-template-columns:minmax(0,1fr);align-items:start;gap:10px;padding:0 14px 0 0;border:0;background:transparent;box-shadow:none;min-width:0}.workflow-step:after{top:13px;left:32px;width:calc(100% - 42px);height:3px;border-radius:999px;background:var(--detail-line)}.workflow-step-dot{position:relative;z-index:1;width:30px;height:30px;background:var(--card)}.workflow-step-current{background:transparent}.workflow-step-current .workflow-step-label{color:var(--primary)}.workflow-step-done:after{background:var(--success)}.workflow-step-current:after{background:linear-gradient(90deg,var(--primary),var(--detail-line))}.workflow-step-future{opacity:.6}.workflow-step-label{margin-top:0;max-width:112px;line-height:1.25;white-space:normal}.workflow-step-owner{margin-top:3px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.photo-section,.photo-section-active{background:var(--card)}.photo-section-future .section-left{opacity:1}.section-title-row{align-items:center}.section-meta-row{margin-top:2px}.section-owner-badge,.section-state-badge{border-radius:8px}.section-row{gap:18px}.photo-empty-state{padding:14px 16px;background:transparent}.photo-empty-state-compact{padding:10px 12px}.photo-empty-state-compact p,.photo-empty-state-compact .muted{font-size:13px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(132px,1fr))}.photo-card{padding:8px;border-color:var(--detail-line);box-shadow:none}.section-right{width:260px;flex-basis:260px;border-color:var(--detail-line);background:transparent}.compact-dropzone{min-height:64px}.activity-sidebar{top:88px}.activity-section{padding:20px}.activity-heading-row{padding-bottom:12px;border-bottom:1px solid var(--detail-line)}.activity-count{width:30px;min-width:30px;height:30px}.activity-timeline:before{left:6px;background:var(--detail-line)}.activity-item{grid-template-columns:14px minmax(0,1fr);gap:12px;margin-bottom:0;padding:12px 0}.activity-body{padding:0;border:0;background:transparent}.activity-meta{font-size:11px}.activity-action{margin-top:5px;font-size:14px}.activity-remark{font-size:14px}.remark-form{margin-top:6px}@media (max-width: 1280px){.do-detail-container{grid-template-columns:1fr}}@media (max-width: 900px){.do-header{grid-template-columns:1fr;padding:16px}.do-header-actions{justify-content:flex-start;gap:8px}.do-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.info-tile{border-right:1px solid var(--detail-line);border-bottom:1px solid var(--detail-line)}.info-tile:nth-child(2n){border-right:0}.info-tile:nth-last-child(-n+1){border-bottom:0}.workflow-track{display:flex;gap:0;overflow-x:auto;padding:8px 2px 6px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.workflow-step{flex:0 0 112px;padding-right:16px}.workflow-step:after{display:block;width:calc(100% - 38px)}.workflow-track::-webkit-scrollbar{display:none}.workflow-step-label{max-width:88px;font-size:12px}.workflow-step-owner{font-size:10px}.do-info-card,.workflow-card,.photo-section{padding:16px}.section-row{gap:12px}}@media (max-width: 560px){.do-title{font-size:34px}.do-detail-page,.main-content{gap:10px}.do-header,.do-info-card,.workflow-card,.photo-section,.activity-section{border-radius:0;border-left:0;border-right:0}.do-subline{gap:8px}.do-subline span{font-size:13px}.do-header-actions{display:grid;grid-template-columns:1fr 1fr}.do-header-actions .status-badge{grid-column:1 / -1;justify-self:start}.do-header-actions .btn,.do-header-actions .btn-link{width:100%}.do-info-grid{grid-template-columns:1fr}.info-tile,.info-tile:nth-child(2n),.info-tile:nth-last-child(-n+1){border-right:0;border-bottom:1px solid var(--detail-line)}.info-tile:last-child{border-bottom:0}.info-tile{padding:10px 0}.do-info-grid{border-left:0;border-right:0;border-radius:0}.workflow-card-header .status-badge{display:none}.workflow-step{flex-basis:94px;padding-right:12px}.workflow-step-dot{width:26px;height:26px;font-size:11px}.workflow-step:after{top:12px;left:30px}.section-title-row{align-items:flex-start}.section-state-badge,.section-owner-badge{padding:4px 8px;font-size:10px}.photo-empty-state{padding:12px}.photo-empty-state-compact{padding:10px 0;border:0}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.photo-grid img,.photo-card .pdf-tile{height:110px}.section-right{padding:10px}.compact-dropzone{min-height:48px}.upload-action-btn{height:38px;min-height:38px}.activity-section{padding:16px}.photo-section-locked-empty{display:none}}body.drawer-open{overflow:hidden}.app-navbar .mobile-menu-toggle{width:42px;height:42px;min-width:42px;min-height:42px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0;border:0;border-radius:999px;background:transparent}.app-navbar .mobile-menu-toggle:hover{background:var(--surface-muted)}.app-navbar .mobile-menu-toggle span{width:20px;height:2px;border-radius:999px;background:var(--text);transition:transform .18s ease,opacity .18s ease}.app-navbar-menu-open .mobile-menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}.app-navbar-menu-open .mobile-menu-toggle span:nth-child(2){opacity:0}.app-navbar-menu-open .mobile-menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.app-navbar .divider,.app-navbar .main-nav{display:none}.main-nav-links{display:grid;gap:6px}.mobile-menu-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 8px 16px;border-bottom:1px solid var(--border)}.drawer-brand{display:flex;align-items:center;gap:10px;min-width:0}.drawer-brand-logo{width:36px;height:36px;object-fit:contain;border-radius:8px;border:1px solid var(--border);background:var(--card)}.drawer-brand-main,.drawer-brand-sub{display:block;line-height:1.2}.drawer-brand-main{color:var(--text);font-size:15px;font-weight:800}.drawer-brand-sub{color:var(--text-muted);font-size:12px}.mobile-menu-close{width:38px;height:38px;min-width:38px;min-height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;border-radius:999px;background:transparent;color:var(--text);font-size:15px;font-weight:800}.mobile-menu-close:hover{background:var(--surface-muted)}.mobile-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;display:block;width:100%;min-height:100vh;padding:0;border:0;border-radius:0;background:#0206176b;backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px)}@keyframes drawerSlideIn{0%{transform:translate(-28px);opacity:.88}to{transform:translate(0);opacity:1}}.app-navbar-menu-open .main-nav{position:fixed;inset:0 auto 0 0;z-index:10000;width:min(86vw,340px);height:100dvh;display:flex;flex-direction:column;align-items:stretch;gap:18px;margin:0;padding:16px 14px;overflow-y:auto;border:0;border-right:1px solid var(--border);border-radius:0;background:var(--card);box-shadow:24px 0 46px #02061738;animation:drawerSlideIn .18s ease-out}.app-navbar-menu-open .main-nav-link{min-height:52px;display:flex;align-items:center;gap:18px;padding:0 16px;border:0;border-radius:8px;background:transparent;color:var(--text);font-size:15px;font-weight:700;text-decoration:none}.app-navbar-menu-open .main-nav-link:hover{background:var(--surface-muted)}.app-navbar-menu-open .main-nav-link-active{background:var(--primary-soft);color:var(--primary);box-shadow:none}.nav-link-icon{width:28px;min-width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;color:currentColor;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.app-navbar-menu-open .mobile-menu-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:auto;padding:16px 2px 2px;border-top:1px solid var(--border)}.app-navbar-menu-open .mobile-menu-actions .role-pill{grid-column:1 / -1;width:100%;min-height:40px}.app-navbar-menu-open .mobile-menu-actions .theme-toggle-btn,.app-navbar-menu-open .mobile-menu-actions .nav-logout-btn{width:100%;min-width:0;min-height:42px;height:42px}[data-theme=dark] .mobile-menu-backdrop{background:#0000009e}@media (max-width: 768px){.app-navbar-inner{display:flex;align-items:center;gap:10px}.app-navbar .nav-left{display:flex;align-items:center;gap:10px;width:auto;flex:1 1 auto}.app-navbar .navbar-brand{grid-column:auto;grid-row:auto}.app-navbar .nav-right{grid-column:auto;grid-row:auto;width:auto}.app-navbar-menu-open .mobile-menu-toggle{visibility:visible}}@media (max-width: 560px){.app-navbar .brand-sub{display:none}.app-navbar .nav-right{gap:6px}.app-navbar .theme-toggle-btn,.app-navbar .nav-logout-btn{min-width:0;padding:0 10px}}
