:root{--bg: #fff6f3;--surface: #ffffff;--surface-2: #fff0ec;--surface-3: #ffe7e0;--line: #fbddd4;--line-soft: #fdeae4;--ink: #34232a;--muted: #9c8389;--faint: #c6acb2;--rose: #ff4d6d;--rose-deep: #e23362;--peach: #ff9166;--accent: var(--rose);--accent-ink: #ffffff;--grad: linear-gradient(135deg, #ff5e7e 0%, #ff9166 100%);--ok: #1f9d57;--warn: #d98324;--danger: #e5484d;--radius: 18px;--radius-sm: 12px;--shadow: 0 16px 38px -18px rgba(255, 77, 109, .45);--shadow-soft: 0 8px 24px -14px rgba(120, 60, 80, .25);--mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--glow-1: rgba(255, 145, 102, .22);--glow-2: rgba(255, 94, 126, .16);--sig-canvas: #ffffff;--sig-hint: #e7c9cf;--sig-baseline: #f0d2d8}[data-mode=roast]{--bg: #0c0c0e;--surface: #161518;--surface-2: #1e1d21;--surface-3: #27252b;--line: #322f37;--line-soft: #232128;--ink: #f3efec;--muted: #8a847f;--faint: #5c5650;--rose: #ff4d2e;--rose-deep: #ff7a1f;--peach: #ff9a1f;--accent: var(--rose);--accent-ink: #0c0c0e;--grad: linear-gradient(135deg, #ff4d2e 0%, #ff9a1f 100%);--ok: #3fae6b;--warn: #e0962f;--danger: #ff5a5a;--radius: 6px;--radius-sm: 4px;--shadow: 0 14px 30px -18px rgba(0, 0, 0, .85);--shadow-soft: 0 6px 18px -12px rgba(0, 0, 0, .7);--glow-1: rgba(255, 100, 30, .2);--glow-2: rgba(255, 60, 0, .12);--sig-canvas: #ffffff;--sig-hint: #c9c4c0;--sig-baseline: #d8d3cf}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{min-height:100%}body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);background-image:radial-gradient(820px 460px at 88% -6%,var(--glow-1),transparent 62%),radial-gradient(720px 420px at 6% 2%,var(--glow-2),transparent 58%);background-attachment:fixed;-webkit-font-smoothing:antialiased}a{color:var(--rose-deep);text-decoration:none}.nav{position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fff6f3d1;border-bottom:1px solid var(--line-soft)}.nav-inner{max-width:680px;margin:0 auto;padding:14px 18px;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--ink)}.brand .mark{width:34px;height:34px;border-radius:11px;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:17px;box-shadow:var(--shadow)}.nav .tag{font-size:13px;color:var(--muted);font-weight:600}.mode-toggle{display:inline-flex;gap:3px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:3px}.mode-toggle button{border:none;background:none;cursor:pointer;font-family:inherit;font-size:12px;font-weight:700;color:var(--muted);padding:6px 11px;border-radius:999px;line-height:1;white-space:nowrap;transition:background .15s,color .15s}.mode-toggle button.active{background:var(--grad);color:#fff;box-shadow:var(--shadow-soft)}@media (max-width: 380px){.mode-toggle button{padding:6px 8px;font-size:11px}}.app{max-width:680px;margin:0 auto;padding:22px 18px 80px}h1{font-size:31px;line-height:1.1;letter-spacing:-.03em;margin:0 0 11px;font-weight:800}h2{font-size:17px;letter-spacing:-.01em;margin:0 0 16px;font-weight:800}.eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:800;color:var(--rose-deep);margin-bottom:13px}p.lead{color:var(--muted);margin:0 0 22px;line-height:1.6;font-size:15.5px}.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px;margin-bottom:16px;box-shadow:var(--shadow-soft)}.card.hero{background:linear-gradient(180deg,#fff,#fff8f5)}label.field{display:block;margin-bottom:16px}label.field>span{display:block;font-size:12.5px;font-weight:700;color:var(--ink);margin-bottom:8px}input[type=text],input[type=password],textarea,select{width:100%;padding:14px 15px;font-size:16px;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--ink);font-family:inherit;transition:border-color .15s,box-shadow .15s,background .15s}input::placeholder,textarea::placeholder{color:var(--faint)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--rose);background:#fff;box-shadow:0 0 0 4px #ff4d6d24}textarea{min-height:82px;resize:vertical}select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23ff4d6d' d='M6 8 0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:38px}.file-drop{border:2px dashed var(--line);border-radius:var(--radius-sm);padding:26px 18px;text-align:center;color:var(--muted);background:var(--surface-2);cursor:pointer;transition:border-color .15s,color .15s,background .15s;font-size:14px}.file-drop:hover{border-color:var(--rose);color:var(--ink)}.file-drop.has-file{border-style:solid;border-color:var(--rose);color:var(--ink);background:#fff4f0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px 18px;font-size:15.5px;font-weight:800;border:none;border-radius:14px;cursor:pointer;font-family:inherit;background:var(--grad);color:#fff;box-shadow:0 12px 26px -10px #ff4d6d99;transition:transform .08s,filter .15s,opacity .15s,box-shadow .15s}.btn:hover{filter:brightness(1.04)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;filter:none}.btn.secondary{background:#fff;color:var(--rose-deep);border:1.5px solid var(--line);box-shadow:none}.btn.secondary:hover{border-color:var(--rose);background:#fff7f4}.btn.danger{background:#fff;color:var(--danger);border:1.5px solid #f6cfcf;box-shadow:none}.btn.danger:hover{background:#fdf0f0}.btn.small{width:auto;padding:10px 15px;font-size:13px;border-radius:10px;box-shadow:none}.btn.small:not(.secondary):not(.danger){box-shadow:0 8px 18px -8px #ff4d6d99}.row{display:flex;gap:12px}.row>*{flex:1}.tabs{display:flex;gap:5px;background:var(--surface);border:1px solid var(--line-soft);padding:5px;border-radius:14px;margin-bottom:20px;box-shadow:var(--shadow-soft)}.tabs button{flex:1;border:none;background:none;padding:11px;border-radius:10px;font-weight:800;font-size:14px;color:var(--muted);cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.tabs button.active{background:var(--grad);color:#fff}.item{display:flex;align-items:center;gap:13px;padding:15px 0;border-bottom:1px solid var(--line-soft)}.item:last-child{border-bottom:none}.item .grow{flex:1;min-width:0}.item .title{font-weight:800;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item .sub{font-size:13px;color:var(--muted);margin-top:3px}.badge{font-size:11px;font-weight:800;letter-spacing:.02em;padding:6px 10px;border-radius:999px;white-space:nowrap}.badge.pending{background:#fff1e2;color:var(--warn)}.badge.completed{background:#e6f6ec;color:var(--ok)}.badge.doc{background:var(--surface-3);color:var(--rose-deep)}.chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:7px 12px;border-radius:999px;background:var(--surface-2);color:var(--muted);margin:4px 5px 0 0}.chip.done{background:#e6f6ec;color:var(--ok)}.steps{counter-reset:step}.step{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-soft);align-items:center}.step:last-child{border-bottom:none}.step .n{counter-increment:step;flex-shrink:0;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:14px;background:var(--surface-3);color:var(--rose-deep)}.step .n:before{content:counter(step)}.step .t{font-weight:800;font-size:14.5px}.step .d{font-size:13px;color:var(--muted);margin-top:2px}.link-box{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px;margin-top:11px}.link-box .label{font-size:12px;letter-spacing:.02em;font-weight:800;color:var(--rose-deep);margin-bottom:8px}.link-box .url{font-family:var(--mono);font-size:12px;word-break:break-all;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:8px;padding:9px 11px}.empty{text-align:center;color:var(--faint);padding:34px 10px;font-size:14px}.alert{padding:13px 15px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px;font-weight:600}.alert.error{background:#fdeaea;color:var(--danger)}.alert.ok{background:#e6f6ec;color:var(--ok)}.sig-wrap{position:relative;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:var(--sig-canvas);overflow:hidden}.sig-wrap canvas{display:block;width:100%;height:210px;touch-action:none;cursor:crosshair}.sig-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--sig-hint);font-size:15px;pointer-events:none;font-weight:700}.sig-baseline{position:absolute;left:20px;right:20px;bottom:46px;border-bottom:1.5px dashed var(--sig-baseline);pointer-events:none}.sig-x{position:absolute;left:20px;bottom:48px;color:var(--sig-hint);font-size:18px;font-weight:700;pointer-events:none}.sig-actions{display:flex;justify-content:flex-end;margin-top:14px}.sig-clear{background:none;border:none;color:var(--muted);font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;padding:8px 2px;text-decoration:underline;text-underline-offset:3px}.sig-clear:hover{color:var(--rose-deep)}.doc-view{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px;max-height:50vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.doc-view canvas,.doc-view img{width:100%;height:auto;display:block;border-radius:8px;margin-bottom:10px;background:#fff;box-shadow:var(--shadow-soft)}.doc-view img:last-child,.doc-view canvas:last-child{margin-bottom:0}.checkbox{display:flex;align-items:flex-start;gap:12px;padding:15px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;line-height:1.5;color:var(--ink)}.checkbox input{width:22px;height:22px;margin:0;accent-color:var(--rose);flex-shrink:0}.muted-note{font-size:12px;color:var(--faint);text-align:center;margin-top:16px;line-height:1.6}.center-screen{min-height:65vh;display:grid;place-items:center}.spinner{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--rose);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.icon-tile{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;font-size:27px;margin-bottom:18px}.icon-tile.accent{background:var(--grad);color:#fff;box-shadow:var(--shadow)}.icon-tile.ok{background:#e6f6ec;color:var(--ok)}.icon-tile.danger{background:#fdeaea;color:var(--danger)}.divider{height:1px;background:var(--line-soft);margin:18px 0;border:none}[data-mode=roast] .card.hero{background:linear-gradient(180deg,var(--surface-2) 0%,var(--surface) 100%)}[data-mode=roast] input:focus,[data-mode=roast] textarea:focus,[data-mode=roast] select:focus{background:var(--surface);box-shadow:0 0 0 4px #ff4d2e33}[data-mode=roast] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23ff7a1f' d='M6 8 0 0h12z'/%3E%3C/svg%3E")}[data-mode=roast] .file-drop.has-file{background:#ff4d2e14}[data-mode=roast] .btn.secondary{background:var(--surface-3)}[data-mode=roast] .btn.secondary:hover{background:var(--surface-2)}[data-mode=roast] .btn.danger{background:transparent;border-color:#ff5a5a66}[data-mode=roast] .btn.danger:hover{background:#ff5a5a1f}[data-mode=roast] .badge.pending{background:#e0962f29}[data-mode=roast] .badge.completed,[data-mode=roast] .chip.done{background:#3fae6b29}[data-mode=roast] .link-box .url{background:var(--bg)}[data-mode=roast] .icon-tile.ok{background:#3fae6b29}[data-mode=roast] .icon-tile.danger{background:#ff5a5a29}
