*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f0f2f5;color:#1a1a1a;font-size:14px}#app{max-width:1100px;margin:0 auto;padding:24px 16px}header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:8px}h1{font-size:1.4rem;font-weight:700}.meta{font-size:13px;color:#666;display:flex;align-items:center;gap:12px}button{padding:5px 14px;border:1px solid #ccc;border-radius:6px;background:#fff;cursor:pointer;font-size:13px}button:hover{background:#f0f0f0}.kpi-row{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.kpi-card{flex:1;min-width:120px;background:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:12px 14px}.kpi-card.kpi-critical{border-color:#fca5a5;background:#fff5f5}.kpi-card.kpi-ok{border-color:#86efac;background:#f0fdf4}.kpi-card.kpi-warn{border-color:#fde68a;background:#fffbeb}.kpi-card.kpi-inbound{border-color:#93c5fd;background:#eff6ff}.kpi-val{font-size:2rem;font-weight:700;line-height:1;margin-bottom:4px;color:#1a1a1a}.kpi-val-sm{font-size:1rem;padding-top:6px}.kpi-lbl{font-size:12px;color:#666}.kpi-lbl small{display:block;color:#aaa;font-size:11px;margin-top:2px}.role-section{background:#fff;border:1px solid #e5e5e5;border-radius:12px;margin-bottom:20px;overflow:hidden}.role-header{display:flex;align-items:center;gap:10px;padding:12px 20px;border-bottom:1px solid #f0f0f0}.role-fba{background:#eff6ff;border-bottom-color:#bfdbfe}.role-mfg{background:#fefce8;border-bottom-color:#fde68a}.role-badge{font-size:14px;font-weight:700;color:#1a1a1a}.role-hint{font-size:12px;color:#888}.subsection{padding:18px 20px;border-bottom:1px solid #f5f5f5}.subsection:last-child{border-bottom:none}.subsection-title{font-size:13px;font-weight:600;color:#444;margin-bottom:12px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.section-note{font-size:13px;color:#666;margin-bottom:10px}.count-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;background:#e0f2fe;color:#075985}.count-critical{background:#fee2e2;color:#991b1b}.ing-alert{font-size:13px;color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:6px;padding:8px 12px;margin-bottom:12px}.overdue{color:#dc2626;font-weight:600}.ing-status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px}.ing-out{background:#fee2e2;color:#991b1b}.ing-expected-only{background:#ede9fe;color:#5b21b6}.ing-ok{background:#dcfce7;color:#15803d}.weeks-container{display:flex;flex-direction:column;gap:10px}.week-panel{border:1px solid #e5e5e5;border-radius:10px;overflow:hidden}.week-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fafafa;flex-wrap:wrap}.week-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.week-dot-ok{background:#86efac}.week-dot-urgent{background:#fde68a}.week-dot-critical{background:#fca5a5}.week-label{font-weight:700;font-size:13px;min-width:72px}.week-dates{font-size:12px;color:#555;display:flex;align-items:center;gap:6px;flex:1;flex-wrap:wrap}.week-arrow{color:#aaa}.week-days{color:#999;font-size:11px;background:#f0f0f0;padding:1px 6px;border-radius:99px}.week-body{padding:12px 14px}.week-body table{margin:0}.seasonal-cards{display:flex;flex-direction:column;gap:12px}.seasonal-card{border:1px solid #e5e5e5;border-radius:10px;padding:14px 16px;background:#fafafa}.seasonal-card.seasonal-watch,.seasonal-card.seasonal-prepare{border-color:#bae6fd;background:#f0f9ff}.seasonal-card.seasonal-urgent{border-color:#fde68a;background:#fffbeb}.seasonal-card.seasonal-critical{border-color:#fca5a5;background:#fff5f5}.seasonal-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.seasonal-name{font-weight:700;font-size:14px}.seasonal-meta{font-size:13px;color:#555;margin-bottom:6px}.seasonal-countdown{font-weight:600;color:#7c3aed;margin-left:8px;font-size:12px;background:#ede9fe;padding:1px 7px;border-radius:99px}.seasonal-action{font-size:13px;margin-bottom:8px}.seasonal-stock{font-size:13px;color:#555;margin-bottom:10px}.seasonal-bottles{background:transparent}.seasonal-bottles th{background:transparent;font-size:11px;padding:5px 8px}.seasonal-bottles td{padding:5px 8px;font-size:13px;border-bottom-color:#f0f0f0}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:9px 12px;border-bottom:1px solid #f0f0f0}th{background:#fafafa;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#666}tr:last-child td{border-bottom:none}small{color:#888;font-size:12px}.doc{font-weight:700}.doc.critical{color:#dc2626}.doc.warning{color:#d97706}.doc.ok{color:#16a34a}.inbound-units{font-weight:700;font-size:15px;color:#2563eb}.shipment-id{font-family:monospace;font-size:12px;color:#555;background:#f5f5f5;padding:2px 6px;border-radius:4px}.eta-badge{font-size:12px;color:#555;background:#f0f9ff;border:1px solid #bae6fd;padding:2px 8px;border-radius:99px}.status-transit{font-size:12px;font-weight:600;color:#2563eb;background:#dbeafe;padding:2px 8px;border-radius:99px}.badge{display:inline-block;padding:2px 10px;border-radius:99px;font-size:12px;font-weight:500}.badge-ok{background:#dcfce7;color:#15803d}.badge-warn{background:#fef3c7;color:#92400e}.ai-summary{font-size:14px;color:#1e1b4b;margin-bottom:12px;line-height:1.6}.ai-dates{font-size:13px;color:#555;margin-bottom:16px}.ai-notes{font-size:13px;color:#666;margin-top:12px;padding:10px 14px;background:#fffbeb;border-radius:6px;border-left:3px solid #fbbf24}.ai-generated{font-size:11px;color:#aaa;margin-top:10px}.urgency{display:inline-block;padding:2px 10px;border-radius:99px;font-size:12px;font-weight:600}.urgency-critical{background:#fee2e2;color:#991b1b}.urgency-urgent{background:#fef3c7;color:#92400e}.urgency-monitor{background:#e0f2fe;color:#075985}.size-tag{font-size:11px;color:#888;font-weight:400}.reasoning{font-size:12px;color:#555;max-width:260px}.inbound-tag{font-size:11px;color:#2563eb;font-weight:500}.expected-tag{font-size:11px;color:#7c3aed;font-weight:500}.stock-in{font-size:12px;color:#555}.stock-sep{font-size:11px;color:#ccc}.shortfall-qty{color:#dc2626;font-weight:600}.no-shortfall{color:#16a34a;padding:4px 0;font-size:13px}.chart-sub{font-size:12px;font-weight:400;color:#aaa}.chart-legend{display:flex;gap:14px;margin-top:10px;flex-wrap:wrap}.leg-item{display:flex;align-items:center;gap:5px;font-size:12px;color:#555}.leg-sw{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid transparent;flex-shrink:0}.tip{border-bottom:1px dashed #aaa;cursor:help;position:relative}.tip:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#1a1a1a;color:#fff;font-size:12px;font-weight:400;text-transform:none;letter-spacing:0;white-space:normal;width:220px;padding:7px 10px;border-radius:6px;line-height:1.5;pointer-events:none;opacity:0;transition:opacity .15s;z-index:10}.tip:hover:after{opacity:1}.week-header-toggle{cursor:pointer;-webkit-user-select:none;user-select:none}.week-header-toggle:hover{background:#f5f5f5}.week-chips{display:flex;flex-wrap:wrap;gap:6px;padding:2px 0}.week-chip{font-size:12px;font-weight:600;padding:4px 10px;border-radius:99px;cursor:default}.week-chip small{font-weight:400;opacity:.85}.loading{padding:40px;text-align:center;color:#888}.error-banner{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:20px}
