:root{--bg: #f4f6f9;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #f2f6fb;--text: #122032;--muted: #5c6b7d;--line: #d8e0ea;--line-strong: #c5d2e1;--primary: #0f4d91;--primary-2: #1f5fab;--danger: #b43535;--ok: #207a48;--warn: #9f6a1d;--radius: 10px;--radius-sm: 8px;--radius-lg: 12px;--shadow-sm: 0 6px 18px rgba(12, 34, 58, .08);--shadow: 0 12px 28px rgba(16, 37, 63, .1);--transition: .18s ease}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;line-height:1.45;font-family:IBM Plex Sans,Segoe UI,Arial,sans-serif;color:var(--text);background:radial-gradient(circle at top left,#ecf2fb 0,#f7f9fc 48%,#f3f6fa)}body{text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.screen-center{min-height:100vh;display:flex;align-items:center;justify-content:center;gap:12px;color:var(--muted)}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:16px}.auth-card{width:min(460px,100%);background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:30px;display:grid;gap:18px}.auth-card h1{margin:0;font-size:28px}.auth-card p{margin:-8px 0 4px;color:var(--muted)}.password-field{display:grid;grid-template-columns:1fr auto;align-items:center;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;transition:border-color var(--transition),box-shadow var(--transition)}.password-field input{border:0;min-height:38px;outline:0}.password-field:focus-within{border-color:var(--primary-2);outline:2px solid rgba(31,95,171,.15)}.password-toggle-btn{width:34px;height:34px;margin-right:2px;border:0;background:transparent;color:#41556d;border-radius:7px;display:grid;place-items:center;cursor:pointer}.password-toggle-btn:hover{background:#eef3f8}label{display:grid;gap:8px;font-size:12px;letter-spacing:.02em;text-transform:uppercase;font-weight:600;color:#324459}.field-hint{margin-top:-4px;font-size:12px;font-weight:500;color:#5c6f83}input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:var(--radius-sm);min-height:40px;padding:8px 12px;font:inherit;color:var(--text);transition:border-color var(--transition),box-shadow var(--transition),background-color var(--transition)}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23455f7a' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:14px;padding-right:34px}select:hover{border-color:#b2c4d9;background-color:#fbfdff}input:focus,select:focus,textarea:focus{border-color:var(--primary-2);outline:2px solid rgba(31,95,171,.15);outline-offset:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:8px 13px;border-radius:var(--radius-sm);border:1px solid transparent;font-weight:600;font-size:13px;cursor:pointer;transition:border-color var(--transition),background-color var(--transition),color var(--transition),box-shadow var(--transition)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:focus-visible,.nav-btn:focus-visible,.icon-btn:focus-visible,.password-toggle-btn:focus-visible{outline:2px solid rgba(31,95,171,.2);outline-offset:1px}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 8px 18px #0f4d9138}.btn-primary:hover:not(:disabled){background:#0e447f}.btn-secondary{background:var(--surface);border-color:var(--line-strong);color:#284159}.btn-secondary:hover:not(:disabled){background:var(--surface-2)}.btn-danger{background:#fff;border-color:#e4bcbc;color:var(--danger)}.btn-danger:hover:not(:disabled){background:#fff6f6}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{background:linear-gradient(180deg,#0f2f53,#122a45);color:#e4eef7;padding:18px 14px;border-right:1px solid #27425f;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{display:flex;align-items:center;gap:9px;font-size:18px;font-weight:700;padding:8px 10px;margin-bottom:16px}.sidebar nav{display:grid;gap:7px}.nav-btn{display:flex;align-items:center;gap:8px;border:1px solid transparent;background:transparent;color:#deebf9;border-radius:10px;min-height:38px;padding:8px 11px;cursor:pointer;font-weight:600;transition:background-color var(--transition),border-color var(--transition),color var(--transition)}.nav-btn:hover{background:#ffffff14}.nav-btn.active{background:#ffffff24;border-color:#ffffff38}.main-area{display:grid;grid-template-rows:auto 1fr;min-width:0}.topbar{background:var(--surface);border-bottom:1px solid var(--line);padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;z-index:4}.topbar h2{margin:0;font-size:21px;letter-spacing:.01em}.topbar-right{display:flex;gap:10px;align-items:center}.user-pill{border:1px solid var(--line-strong);border-radius:8px;padding:7px 11px;background:#f8fbff;font-weight:600}.content{padding:18px;min-width:0}.stack{display:grid;gap:14px}.card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);padding:14px}.center{min-height:120px;display:grid;place-items:center}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap}.search-field{min-width:260px;max-width:560px;width:100%;display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;padding:0 11px;transition:border-color var(--transition),box-shadow var(--transition),background-color var(--transition)}.search-field input{border:0;outline:0;min-height:38px;padding:0}.search-field:focus-within{border-color:var(--primary-2);box-shadow:0 0 0 3px #1f5fab1f}.table-wrap{width:100%;overflow:auto;border:1px solid #e7edf5;border-radius:var(--radius-sm);background:#fff}.data-table{width:100%;border-collapse:collapse;min-width:740px}.data-table th,.data-table td{border-bottom:1px solid #e8edf4;text-align:left;padding:11px 10px;font-size:13px;white-space:nowrap;vertical-align:middle}.data-table th{color:#41556d;font-size:12px;text-transform:uppercase;letter-spacing:.04em;background:#f3f8ff;position:sticky;top:0;z-index:1;border-bottom-color:#dbe4f0}.data-table tbody tr:nth-child(2n){background:#fbfdff}.data-table tbody tr:hover{background:#f1f7ff}.actions-cell{display:flex;align-items:center;gap:8px}.badge{display:inline-flex;border-radius:999px;padding:4px 9px;border:1px solid #ccd8e6;color:#31475e;font-size:11px;letter-spacing:.02em;text-transform:uppercase;font-weight:600}.badge.ok{border-color:#abd6bd;color:var(--ok);background:#edf8f1}.badge.warn{border-color:#e6d4ad;color:var(--warn);background:#fff8e8}.pager{margin-top:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.empty-row{text-align:center;color:var(--muted);padding:26px!important}.error-banner{border:1px solid #e3b4b4;border-radius:var(--radius-sm);background:#fff3f3;color:#8f2f2f;padding:10px 12px}.notice{border-radius:var(--radius-sm);padding:10px 12px;border:1px solid var(--line)}.notice-ok{background:#eef9f2;border-color:#b9e0c6;color:#1f6d3f}.notice-error{background:#fff3f3;border-color:#e4bcbc;color:#8f2f2f}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a162680;display:grid;place-items:center;z-index:100;padding:18px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:min(1200px,100%);max-height:93vh;overflow:auto;border-radius:var(--radius-lg);border:1px solid var(--line);background:#fff;box-shadow:0 28px 55px #08182c3d;padding:14px}.modal-detail{width:min(1120px,100%)}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e8eef6;position:sticky;top:-14px;background:#fff;z-index:2}.modal-head h3{margin:0;font-size:18px}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border:1px solid var(--line-strong);border-radius:8px;background:#fff;cursor:pointer;transition:background-color var(--transition),border-color var(--transition)}.icon-btn:hover{background:#f3f8ff;border-color:#b7c8dc}.form-grid{display:grid;gap:11px}.form-grid .cols-2{display:grid;gap:11px;grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid input[type=file]{border:1px dashed #bcc9d9;background:#f9fcff;padding:10px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px;flex-wrap:wrap}.family-block{border:1px solid #dfe7f1;border-radius:var(--radius);background:#f8fbff;padding:11px;display:grid;gap:10px}.family-head{display:flex;justify-content:space-between;align-items:center}.family-head h4{margin:0}.family-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr 1fr 1fr auto;gap:9px}.lookup{position:relative;display:grid;gap:7px}.lookup-list{position:absolute;z-index:20;top:100%;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);max-height:260px;overflow:auto;margin-top:4px}.lookup-item{width:100%;text-align:left;border:0;border-bottom:1px solid #eef3f8;background:#fff;padding:9px 10px;display:grid;gap:3px;cursor:pointer}.lookup-item:hover{background:#f8fbff}.lookup-item span{color:var(--muted);font-size:12px}.selected-worker{display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:#fbfdff;padding:9px 11px}.selected-worker p{margin:3px 0 0;color:var(--muted);font-size:12px}.app-grid{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.form-card{display:grid;gap:11px;align-content:start}.form-card h3{margin:0;padding-bottom:9px;border-bottom:1px solid var(--line);font-size:18px}.checkbox-line{display:flex;gap:8px;align-items:center}.checkbox-line input{width:auto;min-height:auto}.family-select{display:grid;gap:6px;border:1px solid #dfe7f1;background:#f8fbff;border-radius:var(--radius-sm);padding:9px}.family-select .muted{margin:0}.chips-block{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.chip{border:1px solid #c8d5e4;background:#fff;border-radius:999px;min-height:30px;min-width:34px;padding:0 10px;cursor:pointer;transition:background-color var(--transition),border-color var(--transition),color var(--transition)}.chip-active{background:#dfedff;border-color:#82a8d6;color:#15477e}.split-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,38%);gap:14px}.detail-card{display:grid;gap:11px;align-content:start}.detail-card h3{margin:0}.detail-meta{display:flex;gap:8px 10px;flex-wrap:wrap;color:var(--muted);font-size:12px}.report-detail-stack{display:grid;gap:11px}.report-detail-section{border:1px solid var(--line);border-radius:10px;background:#fbfdff;padding:11px}.report-detail-section h4{margin:0 0 8px;font-size:14px}.report-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px 12px}.report-detail-item{min-width:0;display:grid;gap:3px}.report-detail-label{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#5f7387}.report-detail-value{font-size:13px;color:var(--text);word-break:break-word}.report-detail-link{color:var(--primary);font-size:13px;text-decoration:underline;text-underline-offset:2px;word-break:break-word}.report-family-table{min-width:680px}.preview-box{border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px;max-height:68vh;overflow:auto;background:#fcfdff}.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}.section-head h3{margin:0;font-size:18px}.section-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.table-total{margin-top:10px;text-align:right;font-weight:700}.list-toolbar{align-items:flex-start;gap:12px}.tab-inline{display:flex;gap:8px;flex-wrap:wrap}.tab-active{border-color:#8eb0db;background:#eaf2fe;color:#16467c}.right-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.list-search{min-width:280px;max-width:380px}.report-edit-form{max-width:720px}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition),background-color var(--transition)}.sortable-th-active{color:#184d82;background:#eaf2ff}.th-sort{margin-left:6px;color:#6b7f97;font-size:11px}.table-input{width:100%;min-width:96px}.dashboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stat-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm);padding:15px;display:grid;gap:8px}.stat-card span{color:var(--muted);font-size:12px}.stat-card strong{font-size:28px}.card-wide{grid-column:span 2}.muted{color:var(--muted)}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1300px){.app-shell{grid-template-columns:220px 1fr}.family-row{grid-template-columns:repeat(2,minmax(0,1fr))}.app-grid,.split-layout,.dashboard-grid{grid-template-columns:1fr}.card-wide{grid-column:span 1}}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid #26435f;position:sticky;top:0;z-index:5;height:auto;max-height:none}.sidebar nav{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.nav-btn{justify-content:center;min-height:40px;padding:8px}.nav-btn span{display:none}.topbar{flex-direction:column;align-items:flex-start;padding:12px 14px}.content{padding:12px}.toolbar{align-items:stretch}.search-field,.list-search{min-width:100%;max-width:100%}.table-wrap{border-radius:7px}.modal{max-height:96vh;padding:10px}.modal-head{top:-10px}.report-detail-grid{grid-template-columns:1fr}}
