:root{--red: #e60012;--red-dark: #c00010;--red-tint: #fdecec;--red-tint-2: #fbe3e3;--ink: #17181a;--ink-2: #3d4148;--gray: #6b7280;--gray-2: #969ba3;--line: #ededf0;--line-2: #e3e4e8;--bg: #f3f4f6;--surface: #ffffff;--ok: #1f9d57;--ok-tint: #e6f6ec;--amber: #d98300;--amber-tint: #fdf1dd;--radius: 16px;--radius-sm: 12px;--shadow: 0 1px 2px rgba(20, 22, 26, .04), 0 6px 16px rgba(20, 22, 26, .06);--shadow-lg: 0 10px 34px rgba(20, 22, 26, .16);--maxw: 600px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;min-height:100%}body{font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Noto Sans KR,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5;letter-spacing:-.01em}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:30;background:var(--surface);border-bottom:1px solid var(--line);height:58px;display:flex;align-items:center;gap:12px;padding:0 18px;max-width:var(--maxw);margin:0 auto}.topbar.wide{max-width:980px}.kcar-logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:20px;color:var(--red);letter-spacing:-.04em}.kcar-mark{display:grid;grid-template-columns:1fr 1fr;gap:2.5px;width:26px;height:26px}.kcar-mark i{border-radius:4px;display:block}.kcar-mark i:nth-child(1){background:var(--red)}.kcar-mark i:nth-child(2){background:#b9bdc4}.kcar-mark i:nth-child(3){background:#b9bdc4}.kcar-mark i:nth-child(4){background:var(--red)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}.user-chip{text-align:right;line-height:1.25}.user-chip .name{font-weight:700;font-size:14px}.user-chip .sub{font-size:13px;color:var(--gray-2)}.icon-btn{background:var(--bg);border:none;width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:var(--ink-2);position:relative}.icon-btn svg{width:22px;height:22px}.content{max-width:var(--maxw);margin:0 auto;padding:20px 18px calc(86px + env(safe-area-inset-bottom,0px))}.content.wide{max-width:980px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:40;background:#fffffff5;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);border-top:1px solid var(--line);display:flex;justify-content:space-around;padding:8px 8px calc(8px + env(safe-area-inset-bottom,0px));max-width:var(--maxw);margin:0 auto}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 0;color:var(--gray-2);font-size:12px;font-weight:700;border:none;background:none}.nav-tab svg{width:24px;height:24px}.nav-tab.active{color:var(--red)}.nav-tab .tab-badge{position:absolute;transform:translate(14px,-6px);background:var(--red);color:#fff;border-radius:999px;font-size:11px;min-width:17px;height:17px;padding:0 4px;display:grid;place-items:center;font-weight:800}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:18px}.page-title{font-size:26px;font-weight:800;letter-spacing:-.035em;margin:0}.page-sub{color:var(--gray);font-size:15px;margin:5px 0 0}.muted{color:var(--gray)}.row{display:flex;gap:10px;align-items:center}.spread{justify-content:space-between}.wrap{flex-wrap:wrap}.stack{display:flex;flex-direction:column;gap:12px}.grow{flex:1;min-width:0}.section-label{font-size:14px;font-weight:800;color:var(--gray-2);margin:18px 4px 8px;letter-spacing:.01em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:12px;padding:12px 18px;min-height:48px;font-weight:800;font-size:15px;background:#eef0f3;color:var(--ink);transition:filter .15s,background .15s,transform .05s}.btn:active{transform:scale(.99)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--red);color:#fff}.btn-primary:hover{background:var(--red-dark)}.btn-ghost{background:transparent;border-color:var(--line-2);color:var(--ink-2)}.btn-danger{background:var(--red-tint);color:var(--red-dark)}.btn-success{background:var(--ok);color:#fff}.btn-block{width:100%}.btn-lg{padding:15px 22px;min-height:54px;font-size:16px}.btn-sm{padding:8px 12px;min-height:38px;font-size:14px;border-radius:10px;font-weight:700}.action-bar{position:sticky;bottom:calc(78px + env(safe-area-inset-bottom,0px));display:flex;gap:10px;margin-top:18px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:18px}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}.field label{font-weight:700;font-size:14px;color:var(--ink-2)}.input,.select,.textarea{width:100%;border:1.5px solid var(--line-2);border-radius:12px;padding:13px 14px;min-height:50px;background:#fff;outline:none;font-size:16px;transition:border-color .15s,box-shadow .15s}.textarea{min-height:auto}.input:focus,.select:focus,.textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-tint)}.input-affix{position:relative;display:flex;align-items:center}.input-affix .unit{position:absolute;right:14px;color:var(--gray-2);font-size:14px;font-weight:700}.search{position:relative}.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--gray-2)}.search input{padding-left:42px}.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;font-size:14px;font-weight:800}.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor}.badge.gray{background:#eef0f3;color:#565d68}.badge.red{background:var(--red-tint);color:var(--red-dark)}.badge.green{background:var(--ok-tint);color:#157a43}.badge.amber{background:var(--amber-tint);color:#a96400}.list{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.list-row{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:none;border:none;padding:16px 18px;border-bottom:1px solid var(--line);font-size:16px}.list-row:last-child{border-bottom:none}.list-row:active{background:#f7f8fa}.list-row .lead{width:40px;height:40px;border-radius:50%;background:var(--bg);display:grid;place-items:center;font-weight:800;color:var(--ink-2);flex-shrink:0;font-size:15px}.list-row .lead.red{background:var(--red-tint);color:var(--red)}.list-row .ltitle{font-weight:700;font-size:16px}.list-row .lsub{font-size:14px;color:var(--gray);margin-top:2px}.list-row .chevron{margin-left:auto;color:var(--gray-2);display:grid;place-items:center}.list-row .chevron svg{width:20px;height:20px}.list-row.selected{background:var(--red-tint)}.tile-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.tile{position:relative;border:1.5px solid var(--line-2);background:#fff;border-radius:var(--radius);padding:18px 16px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .05s;text-align:left}.tile:active{transform:scale(.99)}.tile:hover{border-color:#c9ccd2}.tile .tile-name{font-weight:800;font-size:16px}.tile .tile-desc{color:var(--gray);font-size:14px;margin-top:4px;line-height:1.4}.tile.selected{border-color:var(--red);background:var(--red-tint)}.tile .order-badge{position:absolute;top:12px;right:12px;background:var(--red);color:#fff;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:800}.tile .tag{display:inline-block;margin-top:10px;font-size:13px;font-weight:800;color:var(--red);background:var(--red-tint);padding:3px 9px;border-radius:999px}.steps-indicator{display:flex;align-items:center;gap:6px;margin-bottom:20px}.step-pill{display:flex;align-items:center;gap:7px;font-weight:800;font-size:14px;color:var(--gray-2)}.step-pill .num{width:24px;height:24px;border-radius:50%;background:#e6e8ec;color:var(--gray);display:grid;place-items:center;font-size:13px}.step-pill.active{color:var(--red)}.step-pill.active .num{background:var(--red);color:#fff}.step-pill.done .num{background:var(--ok);color:#fff}.step-sep{flex:1;height:2px;background:var(--line-2);border-radius:2px;min-width:10px}.queue{display:flex;flex-direction:column;gap:8px}.queue-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--line);border-radius:14px;background:#fff}.queue-item .seq{width:28px;height:28px;border-radius:9px;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px;flex-shrink:0}.crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:14px;font-size:14px;font-weight:700}.crumbs .crumb{color:var(--red)}.crumbs .crumb.plain,.crumbs .sep{color:var(--gray-2)}.diagram-wrap{display:flex;justify-content:center;background:#f7f8fa;border:1px solid var(--line);border-radius:var(--radius);padding:14px}.diagram-wrap svg{max-height:440px;width:auto}.zone{fill:#d2d6dc;stroke:#aab0b8;stroke-width:2;cursor:pointer;transition:fill .12s}.zone:hover{fill:#bcc2ca}.zone.selected{fill:var(--red);stroke:var(--red-dark)}.zone-label{font-size:14px;font-weight:800;fill:#565d68;pointer-events:none;text-anchor:middle}.zone-label.selected{fill:var(--red-dark)}.timeline{display:flex;flex-direction:column}.tl-item{display:flex;gap:14px}.tl-rail{display:flex;flex-direction:column;align-items:center}.tl-node{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:15px;background:#e6e8ec;color:var(--gray);font-weight:800;flex-shrink:0}.tl-node.done{background:var(--ok);color:#fff}.tl-node.active{background:var(--red);color:#fff}.tl-line{width:2px;flex:1;background:var(--line-2);min-height:16px}.tl-body{padding-bottom:20px;flex:1;min-width:0}.tl-card{border:1px solid var(--line);border-radius:14px;padding:15px 16px;background:#fff}.photo-grid{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.photo-grid img{width:92px;height:92px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}.notif-panel{position:absolute;top:50px;right:0;width:340px;max-width:90vw;max-height:70vh;overflow:auto;background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);border:1px solid var(--line);z-index:50}.notif-item{padding:14px 16px;border-bottom:1px solid var(--line)}.notif-item.unread{background:var(--red-tint)}.notif-item .t{font-weight:800;font-size:14px}.notif-item .b{color:var(--gray);font-size:14px;margin-top:3px}.notif-item .ts{color:var(--gray-2);font-size:13px;margin-top:5px}.table{width:100%;border-collapse:collapse;background:#fff}.table th,.table td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);font-size:15px;vertical-align:middle}.table th{color:var(--gray);font-size:14px;font-weight:800;background:#fafbfc}.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:20px}.login-card{width:100%;max-width:400px;background:#fff;border-radius:22px;padding:34px 26px;box-shadow:var(--shadow);border:1px solid var(--line)}.login-card h1{margin:18px 0 4px;font-size:24px;font-weight:800}.demo-accounts{margin-top:18px;border-top:1px dashed var(--line-2);padding-top:16px;font-size:14px;color:var(--gray)}.demo-accounts button{background:#fff;border:1.5px solid var(--line-2);border-radius:10px;padding:9px 12px;font-size:14px;margin:6px 6px 0 0;font-weight:700;color:var(--ink-2)}.demo-accounts button:active{background:var(--red-tint)}.console-shell{max-width:460px;margin:0 auto;min-height:100vh;background:#b2c7da}.console-top{background:#f7d40e;color:#3c1e1e;padding:18px 18px 16px}.console-top .kakao{display:inline-flex;align-items:center;gap:6px;background:#3c1e1e;color:#f7d40e;font-weight:800;font-size:13px;padding:4px 11px;border-radius:999px}.console-note{padding:10px 16px;font-size:14px;color:#4a5a6a}.kakao-msg{background:#fff;border-radius:4px 16px 16px;padding:16px;margin:12px 16px;box-shadow:0 1px 2px #0000001f}.kakao-msg .title{font-weight:800;margin-bottom:9px;font-size:16px}.kakao-msg .body{white-space:pre-wrap;font-size:15px;line-height:1.6;color:#2b2f36}.kakao-msg .kakao-btn{margin-top:14px;width:100%;border:none;border-radius:12px;padding:14px;font-weight:800;font-size:16px;min-height:52px}.msg-done-tag{font-size:13px;color:var(--gray-2);margin-top:10px;font-weight:700}.camera-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f121699;display:grid;place-items:center;z-index:100;padding:16px}.camera-card{background:#fff;border-radius:18px;width:100%;max-width:440px;padding:22px;max-height:90vh;overflow:auto}.dropzone{border:2px dashed #cdd2da;border-radius:14px;padding:28px;text-align:center;color:var(--gray);cursor:pointer;background:#fafbfc;font-size:15px;font-weight:600}.dropzone:active{border-color:var(--red)}.center-screen{min-height:60vh;display:grid;place-items:center;color:var(--gray)}.spinner{width:30px;height:30px;border:3px solid var(--line-2);border-top-color:var(--red);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{border-radius:12px;padding:13px 15px;font-size:15px;font-weight:600;margin-bottom:14px}.alert-error{background:var(--red-tint);color:var(--red-dark)}.alert-info{background:#eef2f6;color:#43536a}.empty{text-align:center;padding:48px 20px;color:var(--gray);font-size:15px}.empty .big{font-size:38px;margin-bottom:10px}@media (min-width: 720px){.tile-grid{grid-template-columns:1fr 1fr 1fr}}
