:root{--navy:#173b5c;--navy-dark:#102a42;--amber:#f2a33c;--ink:#1c2430;--ink-soft:#5a6675;--line:#d7dde4;--bg:#f2f4f6;--card:#fff;--good:#1e7d46;--bad:#b3261e;--pend:#8a5a00;--radius:10px}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px}.shell{flex-direction:column;min-height:100%;display:flex}.topbar{z-index:10;background:var(--navy);color:#fff;padding:calc(env(safe-area-inset-top) + 10px) 12px 10px;align-items:center;gap:8px;display:flex;position:sticky;top:0}.topbar h1{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;margin:0;font-size:17px;font-weight:600;overflow:hidden}.topbar .back{color:#fff;cursor:pointer;background:0 0;border:none;min-width:44px;min-height:44px;padding:0;font-size:22px}.net-dot{background:var(--bad);border-radius:50%;flex:none;width:10px;height:10px}.net-dot.online{background:#3fbf72}.queue-chip{color:#fff;cursor:pointer;background:#ffffff24;border:none;border-radius:999px;align-items:center;gap:6px;min-height:40px;padding:8px 12px;font-size:14px;display:inline-flex}.queue-chip .count{background:var(--amber);color:var(--navy-dark);border-radius:999px;padding:1px 8px;font-weight:700}.queue-chip .count.failed{color:#fff;background:#ff6b61}main{padding:14px 14px calc(env(safe-area-inset-bottom) + 24px);flex:1;width:100%;max-width:680px;margin:0 auto}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;padding:14px}.muted{color:var(--ink-soft);font-size:14px}.error-box{color:var(--bad);border-radius:var(--radius);background:#fdeceb;border:1px solid #f3c2bf;margin-bottom:12px;padding:12px;font-size:15px}.notice-box{color:var(--pend);border-radius:var(--radius);background:#fff7e8;border:1px solid #ecd9ae;margin-bottom:12px;padding:12px;font-size:14px}button.primary,button.secondary{border-radius:var(--radius);cursor:pointer;width:100%;min-height:52px;font-size:17px;font-weight:600;display:block}button.primary{background:var(--navy);color:#fff;border:none}button.primary:disabled{background:#9fb0c0}button.secondary{color:var(--navy);border:2px solid var(--navy);background:#fff}button.linkish{color:var(--navy);cursor:pointer;background:0 0;border:none;min-height:44px;padding:0 8px;font-size:15px;text-decoration:underline}label.field{margin-bottom:14px;display:block}label.field>span{margin-bottom:6px;font-size:14px;font-weight:600;display:block}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=search],textarea{border:1px solid var(--line);border-radius:var(--radius);width:100%;min-height:48px;color:var(--ink);background:#fff;padding:10px 12px;font-size:16px}textarea{resize:vertical;min-height:120px;line-height:1.45}.row-list{margin:0;padding:0;list-style:none}.row-list li{margin:0 0 10px}.row-btn{text-align:left;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;width:100%;font:inherit;color:inherit;padding:14px;display:block}.row-btn:active{background:#eef2f6}.row-top{justify-content:space-between;align-items:baseline;gap:10px;display:flex}.row-code{color:var(--navy);font-size:15px;font-weight:700}.row-name{margin-top:2px;font-size:15px}.row-sub{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.chip{border-radius:999px;padding:3px 10px;font-size:12.5px;font-weight:600;display:inline-block}.chip.not_started{color:var(--ink-soft);background:#e8ecf1}.chip.in_progress{color:#15538f;background:#e1ecfa}.chip.complete{color:var(--good);background:#e2f3e8}.chip.queued{color:var(--pend);background:#fff1d6}.chip.submitted{color:#15538f;background:#e1ecfa}.chip.approved{color:var(--good);background:#e2f3e8}.chip.failed{color:var(--bad);background:#fdeceb}.chip.milestone{color:#5b3787;background:#efe7f7}.pct{font-size:16px;font-weight:700}.wbs-head{color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;margin:18px 0 8px;font-size:13.5px;font-weight:700}.pct-display{text-align:center;color:var(--navy);margin:4px 0 2px;font-size:56px;font-weight:800}.pct-display .unit{color:var(--ink-soft);font-size:28px;font-weight:600}input[type=range].pct-slider{width:100%;height:44px;accent-color:var(--navy)}.pct-quick{grid-template-columns:repeat(5,1fr);gap:8px;margin:8px 0 4px;display:grid}.pct-quick button{border-radius:var(--radius);border:1px solid var(--line);min-height:48px;color:var(--navy);cursor:pointer;background:#fff;font-size:15px;font-weight:700}.pct-quick button.active{background:var(--navy);color:#fff;border-color:var(--navy)}.two-col{grid-template-columns:1fr 1fr;gap:10px;display:grid}.photo-strip{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.photo-thumb{width:96px;height:96px;position:relative}.photo-thumb img{object-fit:cover;border:1px solid var(--line);border-radius:8px;width:100%;height:100%}.photo-thumb button{background:var(--ink);color:#fff;cursor:pointer;border:none;border-radius:50%;width:28px;height:28px;font-size:15px;line-height:1;position:absolute;top:-8px;right:-8px}.details-toggle{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;width:100%;padding:6px 0 12px;font-size:13px;font-weight:600;display:flex}.details-toggle:hover{color:var(--navy)}.details-toggle-arrow{font-size:10px}.details-panel{padding-top:4px}.add-photo{border:2px dashed var(--line);width:96px;height:96px;color:var(--ink-soft);cursor:pointer;background:#fff;border-radius:8px;justify-content:center;align-items:center;font-size:30px;display:inline-flex}.video-strip{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.video-thumb{width:140px;height:96px;position:relative}.video-thumb video{object-fit:cover;border:1px solid var(--line);border-radius:8px;width:100%;height:100%;display:block}.video-thumb button{background:var(--ink);color:#fff;cursor:pointer;border:none;border-radius:50%;width:28px;height:28px;font-size:15px;line-height:1;position:absolute;top:-8px;right:-8px}.toast{left:50%;bottom:calc(env(safe-area-inset-bottom) + 18px);background:var(--ink);color:#fff;z-index:50;white-space:nowrap;border-radius:999px;padding:12px 18px;font-size:15px;position:fixed;transform:translate(-50%);box-shadow:0 4px 14px #00000040}.signin-wrap{max-width:380px;margin:8vh auto 0;padding:0 16px}.signin-logo{text-align:center;margin-bottom:22px}.signin-logo .mark{color:var(--navy);letter-spacing:-.5px;font-size:30px;font-weight:800}.signin-logo .sub{color:var(--ink-soft);margin-top:4px;font-size:14.5px}.spinner{border:3px solid var(--line);border-top-color:var(--navy);border-radius:50%;width:26px;height:26px;margin:30px auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}
