@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300&family=DM+Mono:wght@300;400;500&family=Noto+Sans+TC:wght@300;400;500;700&display=swap";:root{--bg-deep: #07050f;--bg-base: #0d0b1a;--bg-surface: #13102298;--bg-card: #16132680;--border: #2a2245;--rose: #d4956a;--rose-light: #e8b89a;--rose-dim: #d4956a44;--amethyst: #9b6dca;--amethyst-light: #c084fc;--amethyst-dim: #9b6dca33;--text-primary: #f0e8ff;--text-secondary: #9d8fba;--text-muted: #5c5075;--green: #4ade80;--green-dim: #4ade8020;--red: #ff4d6d;--red-dim: #ff4d6d20;--yellow: #fbbf24;--watsons: #00a0e3;--cosmed: #f47920;--poya: #16a34a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-deep);color:var(--text-primary);font-family:Noto Sans TC,sans-serif;font-weight:300;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.layout{display:grid;grid-template-columns:220px 1fr;grid-template-rows:auto 1fr;min-height:100vh;position:relative;z-index:1}.orb{position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0}.orb-1{width:600px;height:600px;background:radial-gradient(circle,#9b6dca18 0%,transparent 70%);top:-200px;left:-100px}.orb-2{width:500px;height:500px;background:radial-gradient(circle,#d4956a14 0%,transparent 70%);bottom:-100px;right:-100px}.orb-3{width:400px;height:400px;background:radial-gradient(circle,#ff4d6d0a 0%,transparent 70%);top:50%;left:60%}.sidebar{grid-row:1 / -1;background:linear-gradient(180deg,#0f0c1f,#0a0817);border-right:1px solid var(--border);padding:28px 0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-logo{padding:0 24px 28px;border-bottom:1px solid var(--border)}.logo-tag{font-family:DM Mono,monospace;font-size:9px;letter-spacing:.2em;color:var(--rose);text-transform:uppercase;margin-bottom:6px}.logo-name{font-family:Cormorant Garamond,serif;font-size:22px;font-weight:300;background:linear-gradient(135deg,var(--rose-light),var(--amethyst-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}.logo-sub{font-size:10px;color:var(--text-muted);letter-spacing:.1em;margin-top:2px}.nav{padding:20px 0;flex:1}.nav-section-title{font-family:DM Mono,monospace;font-size:9px;letter-spacing:.2em;color:var(--text-muted);text-transform:uppercase;padding:0 24px 8px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 24px;font-size:13px;font-weight:400;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-left:2px solid transparent}.nav-item:hover{color:var(--text-primary);background:var(--bg-surface)}.nav-item.active{color:var(--rose-light);border-left-color:var(--rose);background:var(--rose-dim)}.nav-item .icon{font-size:14px;width:18px;text-align:center}.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-family:DM Mono,monospace;font-size:10px;padding:1px 6px;border-radius:10px}.sidebar-status{padding:16px 24px;border-top:1px solid var(--border);font-size:11px}.status-row{display:flex;align-items:center;gap:8px;color:var(--text-muted);margin-bottom:6px}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse-dot 2s infinite}.status-dot.idle{background:var(--yellow);box-shadow:0 0 6px var(--yellow)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.status-next{font-family:DM Mono,monospace;font-size:10px;color:var(--text-muted)}.header{grid-column:2;display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid var(--border);background:linear-gradient(90deg,var(--bg-deep) 0%,#0d0b1a 100%)}.header-left h1{font-family:Cormorant Garamond,serif;font-size:26px;font-weight:300;letter-spacing:.03em}.header-left h1 em{font-style:italic;color:var(--rose-light)}.header-left p{font-size:12px;color:var(--text-muted);margin-top:2px}.header-right{display:flex;align-items:center;gap:16px}.last-update{font-family:DM Mono,monospace;font-size:11px;color:var(--text-muted);text-align:right}.last-update span{display:block;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;border:none;font-family:Noto Sans TC,sans-serif}.btn-primary{background:linear-gradient(135deg,var(--rose) 0%,var(--amethyst) 100%);color:#fff}.btn-primary:hover{opacity:.85;transform:translateY(-1px);box-shadow:0 4px 20px var(--amethyst-dim)}.btn-ghost{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary)}.btn-ghost:hover{border-color:var(--amethyst);color:var(--text-primary)}.btn.loading{opacity:.6;pointer-events:none}.btn.loading:after{content:"";display:inline-block;width:10px;height:10px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;margin-left:6px;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.main{grid-column:2;padding:28px 32px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;position:relative;overflow:hidden;transition:all .3s;animation:fadeUp .5s ease both}.kpi-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 60%,var(--accent,#9b6dca18) 100%)}.kpi-card:hover{border-color:var(--amethyst);transform:translateY(-2px);box-shadow:0 8px 30px var(--amethyst-dim)}.kpi-label{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.15em;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px}.kpi-value{font-family:Cormorant Garamond,serif;font-size:38px;font-weight:600;line-height:1}.kpi-value.rose{color:var(--rose-light)}.kpi-value.green{color:var(--green)}.kpi-value.red{color:var(--red)}.kpi-value.violet{color:var(--amethyst-light)}.kpi-sub{font-size:11px;color:var(--text-muted);margin-top:8px}.badge{display:inline-flex;align-items:center;gap:3px;font-family:DM Mono,monospace;font-size:10px;padding:2px 7px;border-radius:4px}.badge-green{background:var(--green-dim);color:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.log-strip{background:#050410;border:1px solid var(--border);border-radius:8px;padding:10px 16px;font-family:DM Mono,monospace;font-size:11px;color:var(--text-muted);display:flex;gap:16px;align-items:center;overflow-x:auto}.log-entry{display:flex;align-items:center;gap:6px;white-space:nowrap}.log-sep{color:#2a2245}.ts{color:var(--amethyst)}.ok{color:var(--green)}.err{color:var(--red)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-title{font-family:Cormorant Garamond,serif;font-size:18px;font-weight:400;letter-spacing:.04em;display:flex;align-items:center;gap:10px}.section-title:before{content:"";width:3px;height:18px;border-radius:2px;background:linear-gradient(180deg,var(--rose),var(--amethyst))}.section-actions{display:flex;gap:8px}.tab-bar{display:flex;border-radius:8px;overflow:hidden;border:1px solid var(--border);width:fit-content}.tab{padding:6px 14px;font-family:DM Mono,monospace;font-size:11px;letter-spacing:.05em;cursor:pointer;transition:all .2s;color:var(--text-muted);background:var(--bg-surface);border:none}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--amethyst);color:#fff}.select-styled{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);padding:6px 12px;border-radius:6px;font-family:Noto Sans TC,sans-serif;font-size:12px;cursor:pointer;outline:none}.select-styled:focus{border-color:var(--amethyst)}.input-styled{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary);padding:8px 12px;border-radius:6px;font-family:Noto Sans TC,sans-serif;font-size:13px;outline:none;transition:border-color .2s}.input-styled::placeholder{color:var(--text-muted)}.input-styled:focus{border-color:var(--amethyst);box-shadow:0 0 0 2px var(--amethyst-dim)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px}.btn-primary:disabled,.btn-ghost:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.price-table{width:100%;border-collapse:collapse}.price-table thead tr{background:#0f0d1f;border-bottom:1px solid var(--border)}.price-table th{padding:12px 16px;font-family:DM Mono,monospace;font-size:10px;letter-spacing:.12em;color:var(--text-muted);text-align:center;text-transform:uppercase}.price-table td{padding:14px 16px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle;text-align:center}.price-table tbody tr:last-child td{border-bottom:none}.price-table tbody tr{transition:background .2s}.price-table tbody tr:hover{background:var(--bg-surface)}.price-table td:first-child{text-align:left}.product-cell{display:flex;align-items:center;gap:12px}.product-img{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,var(--rose-dim),var(--amethyst-dim));display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.product-name{font-weight:400;font-size:13px;line-height:1.3}.product-brand{font-size:11px;color:var(--text-muted);margin-top:2px}.price-cell{text-align:center}.price-cell>*{text-align:center;margin-left:auto;margin-right:auto}.price-num{font-family:DM Mono,monospace;font-size:14px;font-weight:500;text-align:center}.price-num.lowest{color:var(--green)}.price-num.highest{color:var(--red)}.price-change{font-family:DM Mono,monospace;font-size:10px;margin-top:2px;text-align:center}.price-change.down{color:var(--green)}.price-change.up{color:var(--red)}.platform-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-family:DM Mono,monospace;font-size:10px}.pb-watsons{background:#00a0e315;color:var(--watsons);border:1px solid #00a0e330}.pb-cosmed{background:#f4792015;color:var(--cosmed);border:1px solid #f4792030}.pb-poya{background:#16a34a15;color:var(--poya);border:1px solid #16a34a30}.gift-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:4px;font-size:10px;background:var(--amethyst-dim);color:var(--amethyst-light);border:1px solid var(--amethyst-dim);margin:2px}.mid-grid{display:grid;grid-template-columns:1fr 380px;gap:20px}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:22px}.chart-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}.legend-item{display:flex;align-items:center;gap:6px;font-family:DM Mono,monospace;font-size:11px;color:var(--text-secondary)}.legend-dot{width:10px;height:3px;border-radius:2px}.chart-container{position:relative;height:220px}.alert-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:22px;display:flex;flex-direction:column}.alert-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:300px;flex:1}.alert-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:12px;display:flex;gap:10px;align-items:flex-start;transition:all .2s;position:relative}.alert-item:hover{border-color:var(--amethyst)}.alert-item.unread:after{content:"";position:absolute;top:10px;right:10px;width:6px;height:6px;border-radius:50%;background:var(--rose);box-shadow:0 0 6px var(--rose)}.alert-item.critical{border-color:var(--red-dim);background:#ff4d6d08;animation:pulse-alert 3s infinite}@keyframes pulse-alert{0%,to{border-color:#ff4d6d40}50%{border-color:#ff4d6d90;box-shadow:0 0 12px #ff4d6d20}}.alert-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.ai-red{background:var(--red-dim)}.ai-green{background:var(--green-dim)}.ai-violet{background:var(--amethyst-dim)}.ai-yellow{background:#fbbf2420}.alert-body{flex:1;min-width:0}.alert-title{font-size:12px;font-weight:500;line-height:1.3}.alert-meta{display:flex;align-items:center;gap:8px;margin-top:5px}.alert-time{font-family:DM Mono,monospace;font-size:10px;color:var(--text-muted);margin-left:auto}.alert-diff{font-family:DM Mono,monospace;font-size:11px;font-weight:500}.alert-diff.neg{color:var(--green)}.alert-diff.pos{color:var(--red)}.settings-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px}.settings-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-top:18px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase}.form-hint{font-size:10px;color:var(--text-muted);margin-top:2px}.form-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:9px 12px;color:var(--text-primary);font-family:DM Mono,monospace;font-size:12px;outline:none;transition:border-color .2s;width:100%}.form-input:focus{border-color:var(--amethyst);box-shadow:0 0 0 3px var(--amethyst-dim)}.form-input::placeholder{color:var(--text-muted)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:12px;color:var(--text-secondary)}.toggle{width:36px;height:20px;border-radius:10px;background:var(--border);cursor:pointer;position:relative;transition:background .3s;border:none}.toggle.on{background:var(--amethyst)}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .3s}.toggle.on:after{left:19px}.settings-actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}.line-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-family:DM Mono,monospace;font-size:11px}.line-status.connected{background:#06c75515;border:1px solid #06c75540;color:#06c755}.line-status.disconnected{background:#ff4d6d15;border:1px solid #ff4d6d40;color:#ff4d6d}.line-status .dot{width:6px;height:6px;border-radius:50%}.line-status.connected .dot{background:#06c755;box-shadow:0 0 5px #06c755}.line-status.disconnected .dot{background:#ff4d6d}.modal-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;background:#0008;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);align-items:center;justify-content:center}.modal-backdrop.open{display:flex}.modal{background:#13102a;border:1px solid var(--border);border-radius:16px;width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;padding:28px;animation:fadeUp .25s ease both}.modal-title{font-family:Cormorant Garamond,serif;font-size:22px;font-weight:300;margin-bottom:22px;display:flex;align-items:center;justify-content:space-between}.modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;line-height:1;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.modal-section{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.15em;color:var(--amethyst);text-transform:uppercase;margin:18px 0 10px}.modal-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.url-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.url-label{font-family:DM Mono,monospace;font-size:11px;width:52px;flex-shrink:0}.url-label.watsons{color:var(--watsons)}.url-label.cosmed{color:var(--cosmed)}.url-label.poya{color:var(--poya)}.emoji-picker{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.emoji-btn{width:36px;height:36px;border-radius:8px;background:var(--bg-surface);border:1px solid var(--border);font-size:18px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.emoji-btn:hover,.emoji-btn.selected{border-color:var(--amethyst);background:var(--amethyst-dim)}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:18px;border-top:1px solid var(--border)}#toast-container{position:fixed;bottom:28px;right:28px;display:flex;flex-direction:column;gap:10px;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;font-size:13px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid;pointer-events:auto;animation:toastIn .3s cubic-bezier(.2,.8,.4,1) both;max-width:360px}.toast.success{background:#0d1f14cc;border-color:#4ade8040;color:#4ade80}.toast.error{background:#1f0d10cc;border-color:#ff4d6d40;color:#ff4d6d}.toast.info{background:#10101fcc;border-color:#9b6dca40;color:#c084fc}.toast.removing{animation:toastOut .25s ease forwards}@keyframes toastIn{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translateY(8px) scale(.95)}}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:9000;background:linear-gradient(90deg,#1a0808,#2a0d0d);border-bottom:1px solid #ff4d6d40;padding:8px 24px;font-family:DM Mono,monospace;font-size:11px;color:var(--red);text-align:center;letter-spacing:.05em}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.kpi-card:nth-child(1){animation-delay:.05s}.kpi-card:nth-child(2){animation-delay:.1s}.kpi-card:nth-child(3){animation-delay:.15s}.kpi-card:nth-child(4){animation-delay:.2s}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--amethyst)}@media (max-width:1200px){.layout{grid-template-columns:200px 1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.mid-grid{grid-template-columns:1fr}.settings-grid{grid-template-columns:1fr 1fr}}
