@import"https://fonts.googleapis.com/css2?family=Fraunces:wght@600;700&family=Manrope:wght@400;500;600;700;800&display=swap";:root{--bg: #fff3e6;--surface: #ffffff;--surface-muted: #fff8f1;--text: #1f2937;--muted: #6b7280;--border: #f7d6bf;--accent: #f97316;--accent-strong: #ea580c;--accent-soft: #ffedd5;--shadow: 0 24px 60px rgba(248, 113, 113, .15)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Manrope,Noto Sans TC,PingFang TC,Microsoft JhengHei,sans-serif;color:var(--text);background:radial-gradient(700px 350px at 15% 0%,rgba(255,178,120,.35),transparent 70%),radial-gradient(700px 350px at 85% 15%,rgba(255,201,152,.4),transparent 75%),var(--bg)}button,input,textarea{font-family:inherit}.app{min-height:100vh;display:flex;justify-content:center;padding:32px 16px 48px}.app-shell{width:min(440px,100%);background:var(--surface);border-radius:28px;border:1px solid var(--border);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.app-shell.is-locked{pointer-events:none;-webkit-user-select:none;user-select:none}.app-shell.is-muted{filter:blur(1px) saturate(.9)}.app-shell.shake{animation:shake-hard .35s ease-in-out}.app-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:22px 24px;border-bottom:1px solid #f2f2f2;background:linear-gradient(180deg,#fffffff2,#ffffffbf);position:sticky;top:0;z-index:5}.brand{display:flex;gap:12px;align-items:center}.brand-icon{width:40px;height:40px;border-radius:14px;background:var(--accent);color:#fff;display:grid;place-items:center;box-shadow:0 10px 20px #f9731659}.brand-title{margin:0;font-family:Fraunces,"Noto Serif TC",serif;font-size:18px}.brand-sub{margin:2px 0 0;font-size:12px;color:var(--muted)}.badge{font-size:11px;padding:6px 10px;border-radius:999px;background:#f3f4f6;color:#6b7280;font-weight:600}.app-main{flex:1;padding:24px;overflow-y:auto}.view{display:flex;flex-direction:column;gap:20px}.view.center{align-items:center;justify-content:center;text-align:center;min-height:300px}.view-head h2{margin:0;font-size:22px;font-weight:800}.view-head p{margin:6px 0 0;color:var(--muted);font-size:14px}.input-stack{display:grid;gap:10px}.textarea{width:100%;min-height:180px;padding:16px;border-radius:16px;border:2px solid #fde3cc;background:#fff;color:var(--text);font-size:14px;resize:none;transition:border .2s ease,box-shadow .2s ease}.textarea::placeholder{color:#c4b5a5}.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #f9731626}.file-chip{font-size:12px;color:var(--muted);padding:8px 12px;border-radius:999px;background:var(--surface-muted)}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid-one{display:grid;grid-template-columns:1fr;gap:12px}.btn{border:none;padding:12px 14px;border-radius:16px;font-size:14px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.btn.full{width:100%;padding:16px;font-size:16px}.btn.primary{background:var(--accent);color:#fff;box-shadow:0 14px 28px #f9731659}.btn.primary:hover{background:var(--accent-strong)}.btn.ghost{background:#f3f4f6;color:#4b5563}.btn.ghost:hover{background:#e5e7eb}.btn.dark{background:#1f2937;color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.alert{display:inline-flex;align-items:center;gap:8px;padding:12px 14px;border-radius:14px;background:#ffe5e5;color:#b91c1c;font-size:13px}.alert.center{justify-content:center}.spinner-wrap{position:relative;width:70px;height:70px}.spinner{position:absolute;inset:0;border-radius:999px;border:4px solid #fde3cc;border-top-color:var(--accent);animation:spin 1s linear infinite}.spinner-icon{position:absolute;inset:0;margin:auto;color:var(--accent)}.ocr-progress{width:min(320px,100%);padding:16px;border-radius:16px;border:1px solid #f3f4f6;background:#fff;box-shadow:0 12px 24px #0f172a0f}.ocr-progress-header{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:var(--muted)}.ocr-progress-track{height:8px;background:#f3f4f6;border-radius:999px;overflow:hidden;margin-top:10px}.ocr-progress-bar{height:100%;background:var(--accent);transition:width .4s ease}.ocr-progress-steps{margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));font-size:11px;color:#9ca3af;text-align:center;gap:6px}.ocr-progress-steps span.active{color:var(--accent-strong);font-weight:700}.direction-list{display:grid;gap:14px}.direction-card{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:16px;border-radius:20px;border:2px solid #f3f4f6;background:#fff;text-align:left;cursor:pointer;transition:border .2s ease,box-shadow .2s ease,transform .2s ease}.direction-card:hover{border-color:var(--accent);box-shadow:0 12px 24px #f9731626;transform:translateY(-2px)}.direction-icon{width:48px;height:48px;border-radius:999px;display:grid;place-items:center;background:#fff7ed}.direction-info h3{margin:0;font-size:16px;font-weight:800}.direction-info p{margin:4px 0 0;font-size:13px;color:var(--muted)}.arrow{color:#d1d5db;transition:transform .2s ease,color .2s ease}.direction-card:hover .arrow{color:var(--accent);transform:translate(4px)}.link-btn{border:none;background:none;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer}.budget-card{padding:18px;border-radius:22px;border:1px solid #f2f2f2;background:#fff;box-shadow:0 16px 24px #0f172a0f}.budget-input{position:relative;display:flex;align-items:center;gap:10px;background:#f9fafb;border-radius:16px;padding:14px 16px}.budget-input input{border:none;background:transparent;font-size:22px;font-weight:800;width:100%;color:var(--text);outline:none}.quick-budgets{display:flex;gap:8px;margin-top:14px;overflow-x:auto;padding-bottom:2px}.pill{border:none;padding:8px 14px;border-radius:999px;background:#f3f4f6;color:#4b5563;font-weight:600;cursor:pointer;white-space:nowrap}.pill:hover{background:#ffedd5;color:var(--accent-strong)}.result-hero{display:flex;gap:16px;padding:20px;border-radius:24px;background:linear-gradient(135deg,#fb923c,#f97316);color:#fff;position:relative;overflow:hidden}.hero-icon{opacity:.2;position:absolute;right:10px;top:10px}.hero-content{position:relative;z-index:1}.hero-tag{display:inline-flex;padding:6px 12px;border-radius:999px;font-size:11px;background:#fff3}.result-hero h2{margin:8px 0 4px;font-size:24px}.result-hero p{margin:0;font-size:13px;color:#ffffffe6}.result-stack{display:grid;gap:12px}.result-card{border-radius:18px;border:1px solid #fde3cc;padding:14px 16px;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;background:#fff}.result-card.accent{border-color:#bfdbfe;position:relative;overflow:hidden}.result-card.accent:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#60a5fa}.result-label{width:40px;height:40px;border-radius:999px;display:grid;place-items:center;font-weight:800;background:#ffedd5;color:var(--accent)}.result-label.accent{background:#dbeafe;color:#2563eb}.result-info h3{margin:0;font-size:16px;font-weight:800}.result-info p{margin:2px 0 0;color:var(--muted);font-size:12px}.result-price{font-size:18px;font-weight:800}.result-divider{border-top:2px dashed #e5e7eb;margin:8px 0}.result-total{display:flex;justify-content:space-between;align-items:flex-end;color:var(--muted);font-weight:600}.result-total>span{font-size:13px}.result-total strong{font-size:28px;color:var(--accent);margin-right:6px}.result-total div span{font-size:12px}.result-empty{text-align:center;padding:24px;border-radius:18px;background:#f3f4f6;color:var(--muted)}.result-empty h3{margin:8px 0 4px;color:#374151}.result-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.btn.wide{grid-column:1 / -1}.progress-wrap{padding:0 24px 20px;background:#fff}.progress-track{height:6px;width:100%;background:#f3f4f6;border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:var(--accent);transition:width .4s ease}.busy-overlay{position:fixed;inset:0;background:#0f172aa6;display:grid;place-items:center;z-index:200;-webkit-backdrop-filter:blur(6px) saturate(1.1);backdrop-filter:blur(6px) saturate(1.1);transition:background .2s ease}.busy-overlay.warning{background:#dc2626b3}.busy-card{width:min(360px,85vw);padding:24px;border-radius:22px;background:#fff7ed;border:3px solid #fb923c;box-shadow:0 20px 60px #ea580c59;text-align:center;display:grid;gap:12px;animation:floaty 1.6s ease-in-out infinite}.busy-card.warning{border-color:#dc2626;background:#fee2e2;animation:alarm .4s ease-in-out infinite}.busy-spinner{width:54px;height:54px;border-radius:50%;border:5px solid rgba(251,146,60,.35);border-top-color:#f97316;margin:0 auto;animation:spin .8s linear infinite}.busy-text h3{margin:0;font-size:18px;font-weight:800;color:#9a3412}.busy-text p{margin:4px 0 0;font-size:13px;color:#7c2d12}.busy-warning{font-size:15px;font-weight:900;color:#b91c1c;letter-spacing:1px;text-transform:uppercase;text-shadow:0 2px 10px rgba(185,28,28,.4)}.icon{width:20px;height:20px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:28px;height:28px}.icon-xl{width:56px;height:56px}.fade-in{animation:fade-in .35s ease both}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shake-hard{0%{transform:translate(0) rotate(0)}15%{transform:translate(-8px,6px) rotate(-1deg)}30%{transform:translate(8px,-6px) rotate(1deg)}45%{transform:translate(-6px,-4px) rotate(-1deg)}60%{transform:translate(6px,4px) rotate(1deg)}75%{transform:translate(-4px,6px) rotate(-.5deg)}90%{transform:translate(4px,-4px) rotate(.5deg)}to{transform:translate(0) rotate(0)}}@keyframes alarm{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@media(max-width:480px){.app{padding:18px 12px 32px}.app-header,.app-main{padding:18px}.grid-two,.result-actions{grid-template-columns:1fr}}
