*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--orange: #F26522;--orange-dark: #d4531a;--orange-light: #fff4ef;--dark: #1a1a2e;--dark2: #16213e;--text: #2d2d2d;--muted: #777;--border: #e0e0e0;--radius: 10px;--shadow: 0 2px 16px rgba(0,0,0,.08);--font: "Inter", system-ui, sans-serif}html,body{height:100%;font-family:var(--font);color:var(--text);background:#f9f9f9}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3{font-weight:700}a{color:var(--orange);text-decoration:none}a:hover{text-decoration:underline}.muted{color:var(--muted);font-size:.9rem}.loading-state,.empty-state{text-align:center;padding:4rem 1rem;color:var(--muted);font-size:1.1rem}button,.btn{cursor:pointer;border:none;border-radius:var(--radius);font-size:.95rem;font-family:var(--font);transition:background .2s,opacity .2s}.btn-primary{background:var(--orange);color:#fff;padding:.65rem 1.4rem;font-weight:600}.btn-primary:hover{background:var(--orange-dark)}.btn-full{width:100%;padding:.75rem;font-size:1rem;font-weight:700;background:var(--orange);color:#fff;border-radius:var(--radius)}.btn-full:hover{background:var(--orange-dark)}.btn-dark{background:var(--dark);color:#fff;padding:.65rem 1.4rem;font-weight:600}.btn-dark:hover{background:var(--dark2)}.btn-sm{padding:.4rem .9rem;font-size:.85rem;background:var(--orange);color:#fff}.btn-ghost{background:transparent;color:var(--orange);border:1.5px solid var(--orange);padding:.6rem 1.2rem;font-weight:600}.btn-ghost:hover{background:var(--orange-light)}.link-btn{background:none;border:none;color:var(--orange);cursor:pointer;font-size:.9rem;text-decoration:underline;padding:0}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.form-group label{font-weight:600;font-size:.92rem}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);border-radius:8px;padding:.6rem .8rem;font-size:.95rem;font-family:var(--font);width:100%;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--orange)}.form-group textarea{resize:vertical;min-height:90px}.form-hint{font-size:.82rem;color:var(--muted);margin-top:.2rem}.checkbox-label{display:flex;align-items:center;gap:.6rem;cursor:pointer;font-size:.92rem}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--orange)}.radio-group{display:flex;flex-direction:column;gap:.55rem}.radio-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.93rem;padding:.75rem 1rem;border:2px solid var(--border);border-radius:10px;background:#fff;transition:border-color .15s,background .15s,box-shadow .15s;-webkit-user-select:none;user-select:none}.radio-label:hover{border-color:#bbb;background:#f9f9f9}.radio-label:has(input[type=radio]:checked){border-color:var(--orange);background:var(--orange-light);font-weight:600}.radio-label input[type=radio]{accent-color:var(--orange);width:16px;height:16px;flex-shrink:0;cursor:pointer}.error-banner{background:#ffeef0;border:1px solid #faa;color:#c00;border-radius:8px;padding:.65rem .9rem;font-size:.9rem;margin-bottom:1rem}.navbar{display:flex;align-items:center;justify-content:space-between;background:var(--dark);color:#fff;padding:0 2rem;height:56px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000004d}.navbar-brand{font-weight:800;font-size:1.15rem;color:var(--orange);letter-spacing:.5px}.navbar-right{display:flex;align-items:center;gap:1rem}.navbar-user{font-size:.9rem;color:#ccc}.role-badge{display:inline-block;padding:.2rem .55rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.role-badge.reporter{background:var(--orange);color:#fff}.role-badge.hr{background:#2563eb;color:#fff}.role-badge.ed{background:#7c3aed;color:#fff}.navbar .btn-sm{background:transparent;border:1px solid #555;color:#ccc}.navbar .btn-sm:hover{border-color:var(--orange);color:var(--orange)}.navbar-pwd-btn{font-size:.8rem!important}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-box{background:#fff;border-radius:16px;box-shadow:0 8px 48px #00000038;width:100%;max-width:420px;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.1rem}.modal-close{background:none;border:none;font-size:1rem;color:var(--muted);cursor:pointer;padding:.2rem .4rem;border-radius:6px}.modal-close:hover{background:#f0f0f0;color:var(--text)}.modal-body{padding:1.5rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.modal-success{padding:2rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.modal-success-icon{font-size:2.5rem}.modal-success p{color:var(--muted);font-size:.95rem}.login-page{min-height:calc(100vh - 56px);display:flex}.login-hero{flex:1;background:linear-gradient(145deg,var(--dark) 0%,#0f3460 100%);color:#fff;display:flex;flex-direction:column;justify-content:center;padding:3rem;min-width:0}.login-hero h1{font-size:2rem;margin-bottom:.75rem}.login-hero h1 span{color:var(--orange)}.login-hero p{color:#aab;line-height:1.7;font-size:1rem;max-width:380px}.hero-features{list-style:none;margin-top:1.5rem;display:flex;flex-direction:column;gap:.6rem}.hero-features li{display:flex;align-items:center;gap:.6rem;color:#ccd;font-size:.9rem}.hero-features li:before{content:"✔";color:var(--orange);font-weight:700}.login-grid{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1.5rem;gap:1.5rem;background:#f9f9f9}.login-card,.admin-login-card{width:100%;max-width:420px;background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:2rem}.login-card h2{margin-bottom:1.2rem;font-size:1.25rem}.admin-login-card{border-top:3px solid #7c3aed}.admin-login-card h2{margin-bottom:.5rem}.admin-hint{font-size:.85rem;color:var(--muted);margin-bottom:1rem}.login-card-desc{font-size:.88rem;color:var(--muted);margin-bottom:1.2rem}.error-msg{background:#ffeef0;border:1px solid #faa;color:#c00;border-radius:8px;padding:.55rem .8rem;font-size:.88rem;margin-bottom:.8rem}.hero-back-btn{margin-top:2rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;cursor:pointer;width:fit-content;transition:background .2s}.hero-back-btn:hover{background:#fff3}.login-hero--admin{background:linear-gradient(145deg,#1e1b4b,#312e81)}.choose-grid{justify-content:center;gap:1rem}.choose-label{font-weight:700;font-size:1rem;color:var(--muted);text-align:center;margin-bottom:.25rem}.choose-card{width:100%;max-width:420px;display:flex;align-items:center;gap:1rem;background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:1.4rem 1.6rem;border:2px solid transparent;cursor:pointer;text-align:left;transition:border-color .2s,box-shadow .2s,transform .15s}.choose-card:hover{border-color:var(--orange);box-shadow:0 4px 24px #0000001f;transform:translateY(-2px)}.choose-card--admin:hover{border-color:#7c3aed}.choose-icon{font-size:2rem;flex-shrink:0}.choose-card strong{display:block;font-size:1.05rem;margin-bottom:.2rem}.choose-card p{font-size:.88rem;color:var(--muted);margin:0}.choose-arrow{margin-left:auto;font-size:1.2rem;color:var(--muted);flex-shrink:0}.single-grid{justify-content:center}.single-grid .login-card{max-width:460px}.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:1.25rem}.tab{background:none;border:none;padding:.6rem 1rem;font-weight:600;font-size:.93rem;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.tab.active{color:var(--orange);border-bottom-color:var(--orange)}.report-page{max-width:760px;margin:0 auto;padding:2rem 1rem}.report-page>h1{font-size:1.5rem;margin-bottom:.3rem}.report-page>p{color:var(--muted);margin-bottom:1.5rem}.step-progress{display:flex;align-items:center;margin-bottom:2rem}.step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;background:#e0e0e0;color:#999;flex-shrink:0;transition:background .2s,color .2s}.step-dot.done{background:var(--orange);color:#fff}.step-dot.active{background:var(--orange);color:#fff;box-shadow:0 0 0 4px #fddcc8}.step-line{flex:1;height:2px;background:#e0e0e0}.step-line.done{background:var(--orange)}.step-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);overflow:hidden}.step-card-head{background:var(--orange-light);border-bottom:1px solid #f5d8cc;padding:1.1rem 1.5rem}.step-card-head h2{font-size:1.1rem;color:var(--dark)}.step-card-head p{font-size:.85rem;color:var(--muted);margin-top:.2rem}.step-body{padding:1.5rem}.category-list{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.category-item{border:2px solid var(--border);border-radius:8px;padding:.7rem .9rem;cursor:pointer;font-size:.9rem;transition:border-color .15s,background .15s;background:#fff}.category-item.selected{border-color:var(--orange);background:var(--orange-light);font-weight:600}.category-item:hover:not(.selected){border-color:#ccc;background:#f9f9f9}.declaration-box{background:#f0f0f0;border-radius:8px;padding:1rem 1.2rem;font-size:.87rem;color:#444;line-height:1.6;margin-bottom:1.2rem}.step-nav{display:flex;justify-content:space-between;padding:1rem 1.5rem;border-top:1px solid var(--border);background:#fafafa}.admin-page{max-width:1100px;margin:0 auto;padding:2rem 1rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.admin-header h1{font-size:1.5rem}.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.report-card{background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:1.2rem;text-decoration:none;color:var(--text);transition:box-shadow .2s,transform .15s;display:flex;flex-direction:column;gap:.5rem;border-left:4px solid var(--orange)}.report-card:hover{box-shadow:0 4px 24px #0000001f;transform:translateY(-2px);text-decoration:none}.report-card-top{display:flex;justify-content:space-between;align-items:flex-start}.case-id-label{font-family:monospace;font-size:.82rem;color:var(--muted)}.report-card h3{font-size:.98rem;margin-top:.2rem}.report-excerpt{font-size:.87rem;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.report-meta{font-size:.82rem;color:var(--muted)}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.status-badge.status-open,.status-open{background:#dcfce7;color:#166534}.status-badge.status-under_review,.status-under_review{background:#fef9c3;color:#713f12}.status-badge.status-closed,.status-closed{background:#f1f5f9;color:#475569}.status-badge.status-rejected,.status-rejected{background:#fee2e2;color:#991b1b}.status-badge.status-cancelled,.status-cancelled{background:#fef3c7;color:#92400e}.case-action-bar{display:flex;align-items:center;flex-wrap:wrap;gap:.6rem;background:#fff;border:1px solid var(--border);border-radius:12px;padding:.85rem 1.2rem;margin-bottom:1.25rem;box-shadow:0 1px 6px #0000000f}.action-bar-label{font-size:.85rem;font-weight:700;color:var(--muted);margin-right:.25rem}.action-bar-error{font-size:.85rem;color:#c00;margin-left:auto}.btn-action{padding:.5rem 1.1rem;font-size:.88rem;font-weight:700;border-radius:8px;border:none;cursor:pointer;transition:background .15s,opacity .15s}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-review{background:#eff6ff;color:#1d4ed8;border:1.5px solid #bfdbfe}.btn-review:hover:not(:disabled){background:#dbeafe}.btn-close-case{background:#f0fdf4;color:#166534;border:1.5px solid #bbf7d0}.btn-close-case:hover:not(:disabled){background:#dcfce7}.btn-reject{background:#fff1f2;color:#be123c;border:1.5px solid #fecdd3}.btn-reject:hover:not(:disabled){background:#ffe4e6}.btn-danger{background:#dc2626;color:#fff;padding:.6rem 1.2rem;font-weight:700;border-radius:var(--radius);border:none;cursor:pointer;font-size:.9rem;transition:background .15s}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.cancellation-notice{background:#fef3c7;border:1px solid #fcd34d;border-radius:10px;padding:.85rem 1.1rem;margin:1rem 0;font-size:.9rem;color:#78350f}.cancellation-notice strong{display:block;margin-bottom:.3rem}.cancellation-notice p{margin:0;line-height:1.5}.case-page{max-width:1200px;margin:0 auto;padding:1.5rem 1rem}.case-breadcrumb{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.back-link{color:var(--muted);font-size:.92rem}.back-link:hover{color:var(--text)}.case-id{font-family:monospace;font-size:.95rem;font-weight:700}.case-date{color:var(--muted);font-size:.9rem;margin-bottom:1.2rem}.case-layout{display:grid;grid-template-columns:1fr 380px;gap:1.5rem;align-items:start}@media (max-width: 860px){.case-layout{grid-template-columns:1fr}}.case-detail-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:2rem}.case-detail-card h2{font-size:1.2rem;margin-bottom:.3rem}.detail-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.detail-section h3{font-size:.97rem;font-weight:700;margin-bottom:.75rem;color:#333}.detail-section dl{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;gap:.75rem;font-size:.9rem}.info-row dt{font-weight:600;min-width:140px;color:#444;flex-shrink:0}.info-row dd{color:var(--text)}.incident-narrative{background:#f9f9f9;border-left:3px solid var(--orange);padding:.8rem 1rem;border-radius:0 8px 8px 0;font-size:.93rem;line-height:1.7;color:var(--text);margin-top:.75rem}.safety-alert{background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;padding:1rem 1.2rem;margin-top:1.2rem}.safety-alert h3{color:#9a3412}.anon-notice{display:flex;align-items:center;gap:.5rem;background:#f1f5f9;border-radius:8px;padding:.7rem 1rem;font-size:.88rem;color:var(--muted);margin-top:1.2rem}.chat-panel{background:#fff;border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;height:540px;overflow:hidden;position:sticky;top:72px}.chat-header{padding:.9rem 1.1rem;border-bottom:1px solid var(--border);font-weight:700;font-size:.95rem;background:var(--orange-light);display:flex;align-items:center;gap:.5rem}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.7rem}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.9rem;text-align:center;padding:1rem}.chat-bubble-wrap{display:flex;flex-direction:column;max-width:80%}.chat-bubble-wrap.me{align-self:flex-end;align-items:flex-end}.chat-bubble-wrap.other{align-self:flex-start;align-items:flex-start}.chat-bubble{padding:.6rem .9rem;border-radius:14px;font-size:.9rem;line-height:1.5;word-break:break-word}.chat-bubble-wrap.me .chat-bubble{background:var(--orange);color:#fff;border-bottom-right-radius:4px}.chat-bubble-wrap.other .chat-bubble{background:#f1f1f1;color:var(--text);border-bottom-left-radius:4px}.chat-meta{font-size:.75rem;color:var(--muted);margin-top:.25rem;display:flex;align-items:center;gap:.4rem}.badge-anon{background:#e2e8f0;color:#475569;border-radius:10px;padding:.1rem .45rem;font-size:.7rem;font-weight:600}.chat-anon-notice{font-size:.82rem;color:#475569;background:#f1f5f9;border-radius:8px;padding:.5rem .8rem;margin-bottom:.6rem;display:flex;align-items:center;gap:.4rem}.chat-input-area{border-top:1px solid var(--border);padding:.75rem;background:#fafafa}.chat-visibility-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;flex-wrap:wrap}.chat-visibility-label{font-size:.8rem;color:var(--muted);font-weight:600;flex-shrink:0}.chat-vis-btn{flex:1;padding:.45rem .7rem;font-size:.82rem;border-radius:8px;border:2px solid var(--border);background:#fff;color:var(--muted);font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,color .15s;white-space:nowrap}.chat-vis-btn:hover{border-color:#bbb;color:var(--text)}.chat-vis-btn.active{border-color:var(--orange);background:var(--orange-light);color:var(--orange)}.chat-input-row{display:flex;gap:.5rem}.chat-input-row textarea{flex:1;border:1.5px solid var(--border);border-radius:8px;padding:.5rem .7rem;font-size:.9rem;resize:none;height:60px;font-family:var(--font)}.chat-input-row textarea:focus{outline:none;border-color:var(--orange)}.chat-send-btn{background:var(--orange);color:#fff;border:none;border-radius:8px;padding:0 1rem;font-size:1.2rem;cursor:pointer;align-self:stretch}.chat-send-btn:hover{background:var(--orange-dark)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.reporter-dash{max-width:1100px;margin:0 auto;padding:2rem 1rem}.rdash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem;flex-wrap:wrap}.rdash-header h1{font-size:1.6rem}.rdash-sub{color:var(--muted);font-size:.93rem;margin-top:.3rem}.rdash-new-btn{padding:.7rem 1.4rem;font-size:.97rem;font-weight:700;white-space:nowrap}.rdash-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.75rem}.rdash-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border-radius:999px;border:1.5px solid var(--border);background:#fff;color:var(--muted);font-size:.88rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.rdash-pill:hover{border-color:#bbb;color:var(--text)}.rdash-pill.active{background:var(--dark);color:#fff;border-color:var(--dark)}.rdash-pill.active.pill-active{background:var(--orange);border-color:var(--orange)}.rdash-pill.active.pill-open{background:#166534;border-color:#166534}.rdash-pill.active.pill-under_review{background:#92400e;border-color:#92400e}.rdash-pill.active.pill-closed{background:#334155;border-color:#334155}.rdash-pill.active.pill-rejected{background:#9f1239;border-color:#9f1239}.rdash-pill.active.pill-cancelled{background:#78350f;border-color:#78350f}.pill-count{background:#0000001f;color:inherit;border-radius:999px;padding:.05rem .45rem;font-size:.78rem;font-weight:700;min-width:20px;text-align:center}.rdash-pill.active .pill-count{background:#ffffff40}.rdash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.1rem}.rcase-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:1.25rem 1.3rem;text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:.5rem;border-left:4px solid var(--orange);transition:box-shadow .2s,transform .15s}.rcase-card:hover{box-shadow:0 6px 28px #00000021;transform:translateY(-3px);text-decoration:none}.rcase-card-top{display:flex;align-items:center;justify-content:space-between}.rcase-time{font-size:.78rem;color:var(--muted)}.rcase-id{font-family:monospace;font-size:.8rem;color:var(--muted)}.rcase-category{font-size:1rem;font-weight:700;margin:0}.rcase-excerpt{font-size:.87rem;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.rcase-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem;font-size:.82rem}.rcase-location{color:var(--muted)}.rcase-cta{color:var(--orange);font-weight:700}.rdash-empty{text-align:center;padding:4rem 1rem;max-width:440px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.75rem}.rdash-empty-icon{font-size:3rem}.rdash-empty h2{font-size:1.3rem}.rdash-empty p{color:var(--muted);line-height:1.7}.success-screen{max-width:520px;margin:4rem auto;text-align:center;padding:1rem}.success-screen .icon{font-size:3.5rem;margin-bottom:1rem}.success-screen h2{font-size:1.6rem;margin-bottom:.75rem}.success-screen p{color:var(--muted);line-height:1.7;margin-bottom:1.5rem}.success-screen code{background:#f1f5f9;padding:.2rem .5rem;border-radius:6px;font-size:.9rem;font-family:monospace}
