:root{--bg: #F0F2F7;--sidebar-bg: #1B3A6B;--sidebar-hover: #264E8F;--sidebar-active: #3369BE;--sidebar-text: rgba(255, 255, 255, .75);--sidebar-w: 220px;--sidebar-w-collapsed: 56px;--card-bg: #FFFFFF;--text-primary: #111827;--text-secondary: #6B7280;--text-muted: #9CA3AF;--border: #E5E7EB;--accent: #2563EB;--accent-light: rgba(37, 99, 235, .08);--accent-hover: #1D4ED8;--success: #059669;--success-bg: #ECFDF5;--success-border: #A7F3D0;--success-text: #065F46;--warning: #D97706;--warning-bg: #FFFBEB;--warning-border: #FCD34D;--warning-text: #92400E;--error: #EF4444;--error-bg: #FEF2F2;--error-border: #FECACA;--error-text: #991B1B;--info-bg: #EFF6FF;--info-border: #BFDBFE;--info-text: #1E40AF;--shadow: 0 1px 3px rgba(0, 0, 0, .05), 0 4px 16px rgba(0, 0, 0, .06);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--bottom-nav-h: 72px }[data-theme=dark]{--bg: #0B1120;--sidebar-bg: #0F172A;--sidebar-hover: #1E293B;--sidebar-active: #1E3A5F;--sidebar-text: rgba(255, 255, 255, .85);--card-bg: rgba(30,41,59,.75);--text-primary: #E2E8F0;--text-secondary: #94A3B8;--text-muted: #64748B;--border: rgba(148,163,184,.15);--accent-light: rgba(37,99,235,.15);--accent-hover: #3B82F6;--shadow: 0 1px 2px rgba(0,0,0,.2),0 4px 16px rgba(0,0,0,.18);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--success-bg: rgba(5,150,105,.12);--success-border: rgba(5,150,105,.25);--success-text: #6EE7B7;--warning-bg: rgba(217,119,6,.12);--warning-border: rgba(217,119,6,.25);--warning-text: #FCD34D;--error-bg: rgba(239,68,68,.12);--error-border: rgba(239,68,68,.25);--error-text: #FCA5A5;--info-bg: rgba(37,99,235,.12);--info-border: rgba(37,99,235,.25);--info-text: #93C5FD }*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}.app-shell{display:flex;width:100%;min-height:100vh}.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-brand{padding:20px 16px 18px;border-bottom:1px solid rgba(255,255,255,.1);min-height:70px;display:flex;align-items:center;overflow:hidden;white-space:nowrap;background:linear-gradient(135deg,rgba(96,165,250,.08) 0%,transparent 60%)}.sidebar-brand-inner{display:flex;align-items:center;gap:10px;width:100%}.sidebar-brand-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#60a5fa26;border-radius:10px;color:#60a5fa;transition:transform .3s ease}.sidebar-brand-text{overflow:hidden;opacity:1;transition:opacity .2s ease .1s}.sidebar.collapsed .sidebar-brand-text{opacity:0;transition:opacity .15s ease}.sidebar.collapsed .sidebar-brand{padding:20px 0 18px;justify-content:center}.sidebar.collapsed .sidebar-brand-icon{width:30px;height:30px}.sidebar-brand h1{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.3px;line-height:1.3}.sidebar-brand p{font-size:10px;color:#ffffff73;margin-top:3px}.sidebar-toggle{position:absolute;top:24px;right:8px;width:22px;height:22px;border-radius:6px;border:none;background:#ffffff14;color:#ffffff80;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,transform .3s ease;z-index:10;padding:0}.sidebar-toggle:hover{background:#ffffff26;color:#ffffffe6}.sidebar.collapsed .sidebar-toggle{right:50%;transform:translate(50%) rotate(180deg)}.sidebar-nav{flex:1;padding:10px 0;overflow:hidden;white-space:nowrap}.sidebar-section-label{padding:10px 16px 4px;font-size:10px;font-weight:700;color:#ffffff59;letter-spacing:.8px;text-transform:uppercase}.sidebar.collapsed .sidebar-section-label{display:none}.sidebar-badge{margin-left:auto;font-size:10px;font-weight:600;padding:1px 7px;border-radius:6px;background:#ffffff14;color:#ffffff80;flex-shrink:0}.sidebar.collapsed .sidebar-badge{display:none}.sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;font-family:inherit;font-size:13px;font-weight:500;color:var(--sidebar-text);position:relative;transition:background .15s,color .15s;white-space:nowrap}.sidebar-item:hover{background:var(--sidebar-hover);color:#fff}.sidebar-item.active{background:var(--sidebar-active);color:#fff}.sidebar-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:#60a5fa;border-radius:0 3px 3px 0}.sidebar-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease}.sidebar-item:hover .sidebar-icon{transform:scale(1.1)}.sidebar-label{overflow:hidden;opacity:1;transition:opacity .2s ease .1s}.sidebar.collapsed .sidebar-label{opacity:0;transition:opacity .15s ease}.sidebar.collapsed .sidebar-item{padding:12px 0;justify-content:center}.sidebar.collapsed .sidebar-item:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--card-bg);color:var(--text-primary);font-size:12px;font-weight:500;padding:6px 12px;border-radius:8px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s ease;box-shadow:0 2px 12px #0000001f;border:1px solid var(--border);z-index:200}.sidebar.collapsed .sidebar-item:hover:after{opacity:1}.sidebar-footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;color:#ffffff47;overflow:hidden;white-space:nowrap}.sidebar-footer-inner{display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar-admin-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:inherit;cursor:pointer;padding:2px 4px;border-radius:4px;font-size:11px;font-family:inherit;transition:background .15s}.sidebar-admin-btn:hover{background:#ffffff14}.sidebar.collapsed .sidebar-admin-label{display:none}.sidebar.collapsed .sidebar-footer{padding:14px 0;text-align:center}.sidebar.collapsed .sidebar-footer-inner{flex-direction:column;align-items:center;gap:6px}.sidebar.collapsed .sync-status-label{font-size:0;width:6px;height:6px;border-radius:50%;background:#ffffff4d;display:inline-block;cursor:pointer}.theme-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#ffffff14;border-radius:8px;cursor:pointer;color:#ffffff80;transition:background .15s,color .15s;padding:0}.theme-toggle:hover{background:#ffffff26;color:#fff}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;min-width:0;overflow-x:hidden;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.main-inner{min-width:0;overflow-x:hidden}.app-shell.sidebar-collapsed .main-content{margin-left:var(--sidebar-w-collapsed)}.mobile-topbar{display:none;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#1b3a6b,#1e4a8e);color:#fff}.mobile-topbar-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}.mobile-topbar-title svg{width:18px;height:18px;opacity:.7}.mobile-topbar-ver{font-size:11px;color:#fff6;font-weight:500;background:none;border:none;cursor:pointer;font-family:inherit;padding:4px 8px;border-radius:6px;transition:background .15s,color .15s}.mobile-topbar-ver:hover{background:#ffffff1a;color:#fff9}.mobile-topbar-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.mobile-topbar-btn{width:34px;height:34px;border:none;background:#ffffff14;color:#fff9;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;padding:0}.mobile-topbar-btn:hover{background:#ffffff26;color:#fff}.mobile-topbar-btn.admin-active{background:#05966940;color:#6ee7b7}.mobile-footer{display:none;text-align:center;font-size:11px;color:#c4c9d4;padding:12px 16px calc(var(--bottom-nav-h) + 12px);background:var(--bg)}.dock-nav{display:none;position:fixed;bottom:8px;left:12px;right:12px;height:58px;background:#ffffffa6;backdrop-filter:blur(28px) saturate(1.6);-webkit-backdrop-filter:blur(28px) saturate(1.6);border-radius:22px;border:1px solid rgba(255,255,255,.45);z-index:200;box-shadow:0 2px 16px #0000000f;padding-bottom:env(safe-area-inset-bottom,0)}.dock-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:none;background:transparent;cursor:pointer;font-family:inherit;color:var(--text-muted);transition:color .2s ease;min-width:0;padding:6px 4px 4px;position:relative;-webkit-tap-highlight-color:transparent}.dock-item.active{color:var(--text-primary)}.dock-item:active{opacity:.6}.dock-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.dock-item.active .dock-icon{transform:translateY(-1px)}.dock-label{font-size:9.5px;font-weight:500;letter-spacing:.3px;white-space:nowrap;transition:color .2s ease}.dock-item.active .dock-label{color:var(--text-primary)}.dock-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);position:absolute;bottom:3px;left:50%;transform:translate(-50%) scale(0);transition:transform .35s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 #2563eb00}.dock-item.active .dock-dot{transform:translate(-50%) scale(1);box-shadow:0 0 6px 1px #2563eb59}@media(max-width:900px){.sidebar{width:var(--sidebar-w-collapsed)}.sidebar-brand h1,.sidebar-brand p,.sidebar-section-label,.sidebar-badge,.changelog-btn,.sidebar-label,.sidebar-brand-text{display:none}.sidebar-brand{padding:20px 0 18px;justify-content:center}.sidebar-item{padding:12px 0;justify-content:center}.sidebar-item:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--card-bg);color:var(--text-primary);font-size:12px;font-weight:500;padding:6px 12px;border-radius:8px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s ease;box-shadow:0 2px 12px #0000001f;border:1px solid var(--border);z-index:200}.sidebar-item:hover:after{opacity:1}.sidebar-footer{padding:14px 0;text-align:center}.sidebar-footer-inner{flex-direction:column;align-items:center;gap:6px}.sidebar-toggle{display:none}.main-content{margin-left:var(--sidebar-w-collapsed)}}@media(max-width:640px){.sidebar{display:none!important}.hamburger,#overlay{display:none}.app-shell.sidebar-collapsed .main-content{margin-left:0!important}.mobile-topbar{display:flex}.mobile-footer{display:block}.dock-nav{display:flex}.main-inner{padding-bottom:calc(var(--bottom-nav-h) + 20px)}.mobile-topbar{padding:14px}.mobile-topbar-title{font-size:16px}.mobile-topbar-btn{width:38px;height:38px}.mobile-topbar-ver{font-size:12px;padding:5px 10px}.dock-nav{height:62px;bottom:6px;left:8px;right:8px;border-radius:20px}.dock-icon{width:24px;height:24px}.dock-label{font-size:10px}.dock-item{padding:6px 4px 4px;gap:2px}}[data-theme=dark] .dock-nav{background:#0b1120ad;border-color:#94a3b81a;box-shadow:0 2px 16px #0003}[data-theme=dark] .dock-item.active{color:var(--text-primary)}[data-theme=dark] .dock-item.active .dock-dot{box-shadow:0 0 6px 1px #60a5fa66}.tool-container{display:none;animation:fadeUp .25s ease-out}.tool-container.active{display:block}.tool-header{background:var(--card-bg);border-bottom:1px solid var(--border);padding:18px 24px;display:flex;align-items:center;gap:12px}.tool-header-icon{font-size:22px}.tool-header-text h2{font-size:16px;font-weight:700;color:var(--text-primary)}.tool-header-text p{font-size:12px;color:var(--text-secondary);margin-top:2px}.card{background:var(--card-bg);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);margin:16px}.card-title{font-size:13.5px;font-weight:600;color:var(--text-primary);margin-bottom:16px;display:flex;align-items:center;gap:8px}.card-title:before{content:"";width:4px;height:16px;background:var(--accent);border-radius:2px;flex-shrink:0}.input-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}.input-grid .input-full{grid-column:1 / -1}.input-group{display:flex;flex-direction:column;gap:5px}.input-label{font-size:12px;font-weight:500;color:var(--text-secondary)}.input-wrap{position:relative;display:flex;align-items:center}.input-field{width:100%;height:42px;padding:0 38px 0 12px;font-size:14px;font-family:inherit;font-variant-numeric:tabular-nums;color:var(--text-primary);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:var(--accent);background:var(--card-bg);box-shadow:0 0 0 3px var(--accent-light)}.input-field.has-error{border-color:var(--error)}.input-suffix{position:absolute;right:12px;font-size:12px;color:var(--text-secondary);pointer-events:none;font-weight:500}select.input-field{padding-right:32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer}.btn{height:42px;padding:0 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--card-bg);color:var(--accent);border:1.5px solid var(--accent)}.btn-secondary:hover{background:var(--accent-light)}.btn-ghost{background:var(--card-bg);color:var(--text-secondary);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--bg);color:var(--text-primary)}.btn-row{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.result-box{background:var(--success-bg);border:1.5px solid var(--success-border);border-radius:var(--radius-md);padding:14px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:14px}.result-label{font-size:14px;color:var(--success-text);font-weight:600}.result-value{font-size:28px;font-weight:800;color:var(--success);font-variant-numeric:tabular-nums}.result-value.bump{animation:bump .25s ease-out}@keyframes bump{0%{transform:scale(1)}50%{transform:scale(1.06)}to{transform:scale(1)}}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;margin-bottom:12px;flex-wrap:wrap}.alert-ok{background:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.alert-warn{background:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.alert-error{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.detail-item{background:var(--bg);border-radius:var(--radius-sm);padding:10px 14px}.detail-item .label{font-size:11px;color:var(--text-secondary);margin-bottom:4px}.detail-item .value{font-size:15px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.card{margin:12px;border-radius:var(--radius-md)}.btn-row{flex-direction:column}.btn{width:100%;justify-content:center}.detail-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column}.modal-footer button{width:100%}.input-field{font-size:16px;height:46px}.tool-header{padding:14px 16px}.tool-header-text h2{font-size:17px}.tool-header-text p{font-size:13px}.card{padding:16px}.card-title{font-size:15px;margin-bottom:14px}.input-label{font-size:13px}.btn{height:46px;font-size:14px}.result-value{font-size:26px}.result-label{font-size:14px}.detail-item .label{font-size:12px}.detail-item .value{font-size:16px}.period-input{font-size:16px;height:42px}}@keyframes toastIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalFadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes modalSlideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.sp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.sp-overlay.sp-open{opacity:1;visibility:visible}.sp-overlay.sp-closed{opacity:0;visibility:hidden}.sp-card{width:90%;max-width:480px;background:var(--card-bg);border-radius:12px;box-shadow:0 20px 60px #0003;overflow:hidden;transform:translateY(8px) scale(.98);transition:transform .2s ease}.sp-overlay.sp-open .sp-card{transform:translateY(0) scale(1)}.sp-overlay.sp-closed .sp-card{transform:translateY(8px) scale(.98)}.sp-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.sp-search-icon{flex-shrink:0;color:var(--text-muted);display:flex;align-items:center}.sp-input{flex:1;border:none;outline:none;font-size:16px;font-family:inherit;color:var(--text-primary);background:transparent}.sp-input::placeholder{color:var(--text-muted)}.sp-kbd{flex-shrink:0;font-size:11px;font-family:inherit;padding:2px 6px;border-radius:4px;background:var(--bg);color:var(--text-muted);border:1px solid var(--border);line-height:1.4}.sp-list{max-height:320px;overflow-y:auto;padding:6px}.sp-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .12s ease}.sp-item:hover,.sp-item.active{background:var(--accent-light)}.sp-item-icon{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--bg);color:var(--accent)}.sp-item-body{flex:1;min-width:0}.sp-item-label{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3}.sp-item-desc{font-size:12px;color:var(--text-secondary);line-height:1.4;margin-top:1px}.sp-highlight{color:var(--accent);font-weight:700;background:var(--accent-light);border-radius:2px;padding:0 1px}.sp-empty{padding:24px 16px;text-align:center;font-size:13px;color:var(--text-muted)}@media(max-width:640px){.sp-overlay{padding-top:8vh}.sp-card{width:95%;border-radius:10px}.sp-list{max-height:50vh}}.contract-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:16px;padding:16px}.contract-total-card,.contract-period-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column}.both-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.periods-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.period-input{width:100%;height:38px;padding:0 36px 0 10px;font-size:13px;font-family:inherit;font-variant-numeric:tabular-nums;color:var(--text-primary);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s,box-shadow .15s,background .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.period-input:focus{border-color:var(--accent);background:var(--card-bg);box-shadow:0 0 0 3px var(--accent-light)}.period-pct-suffix{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--text-secondary);pointer-events:none}.period-input-wrap{position:relative;flex:1}.summary-box{background:var(--bg);border-radius:var(--radius-sm);padding:14px 16px;margin-top:12px}.summary-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.summary-row+.summary-row{margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}.summary-label{font-size:12px;color:var(--text-secondary)}.summary-value{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums}.period-copy-btn{opacity:0;transition:opacity .15s}.period-item:hover .period-copy-btn{opacity:1}.copy-sm{width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;opacity:0;transition:opacity .15s}.summary-row:hover .copy-sm{opacity:1}.copy-sm:hover{background:var(--accent-light);color:var(--accent)}@media(max-width:640px){.contract-layout{grid-template-columns:1fr;padding:12px;gap:12px;padding-bottom:calc(var(--bottom-nav-h) + 20px)}.input-grid{grid-template-columns:1fr}.input-grid .input-full{grid-column:1}.result-box{flex-direction:column;align-items:flex-start}.result-value{font-size:26px}.both-grid{grid-template-columns:1fr}}.supply-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:16px;padding:16px}.supply-input-card,.supply-result-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column}.supply-tabs{display:flex;gap:6px;margin-bottom:18px;background:var(--bg);padding:4px;border-radius:10px;border:1px solid var(--border)}.supply-tab-btn{flex:1;padding:8px 12px;border:none;background:transparent;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;color:var(--text-secondary);border-radius:7px;transition:all .2s;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:6px}.tab-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.supply-tab-btn.active{background:var(--card-bg);color:var(--text-primary);box-shadow:0 1px 3px #00000014}.supply-tab-btn:hover:not(.active){color:var(--text-primary);background:var(--card-bg)}.supply-form-header{margin-bottom:12px}.supply-form-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600}.supply-both-form{display:grid;grid-template-columns:1fr 1fr;gap:16px}.supply-form-col{padding:12px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.supply-checkbox{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;color:var(--text-secondary);cursor:pointer}.supply-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.supply-table{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.supply-table-head{display:grid;grid-template-columns:1fr auto auto;gap:16px;padding:10px 16px;background:var(--bg);font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1.5px solid var(--border)}.supply-table-head span:nth-child(2),.supply-table-head span:nth-child(3){text-align:right}.supply-table-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:11px 16px;border-bottom:1px solid var(--border);position:relative;transition:background .12s;cursor:pointer}.supply-table-row:last-child{border-bottom:none}.supply-table-row:hover{background:var(--accent-light)}.supply-formula-toggle{display:inline-block;margin-left:6px;font-size:10px;color:var(--text-muted);transition:transform .15s}.supply-table-row--expanded .supply-formula-toggle{transform:rotate(90deg)}.supply-formula-line{grid-column:1 / -1;display:none;font-size:12px;color:var(--text-secondary);padding:6px 0 2px 11px;border-top:1px dashed var(--border);margin-top:4px}.supply-table-row--expanded .supply-formula-line{display:block}.supply-table-bar{position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 2px 2px 0}.supply-table-bar--blood{background:var(--accent)}.supply-table-bar--other{background:var(--success)}.supply-table-name{font-size:13.5px;font-weight:500;color:var(--text-primary);padding-left:8px}.supply-table-value{font-size:24px;font-weight:800;color:var(--text-primary);font-variant-numeric:tabular-nums;text-align:right;min-width:60px}.supply-table-unit{font-size:12px;color:var(--text-secondary);min-width:24px;text-align:left}.supply-empty{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.supply-both-layout{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.supply-both-col{background:var(--bg);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border)}.supply-both-total{background:var(--success-bg);border:1.5px solid var(--success-border);border-radius:var(--radius-md);padding:14px 16px}.supply-both-header{font-size:13px;font-weight:600;color:var(--text-primary);padding-left:10px;margin-bottom:10px}.supply-both-total .supply-both-header{color:var(--success-text)}.supply-both-col .supply-table,.supply-both-total .supply-table{border:none;border-radius:0}.supply-both-col .supply-table-head{display:none}.supply-both-col .supply-table-row,.supply-both-total .supply-table-row{padding:6px 8px;border-bottom-color:var(--border)}.supply-both-col .supply-table-row:last-child,.supply-both-total .supply-table-row:last-child{border-bottom:none}.supply-both-col .supply-table-value,.supply-both-total .supply-table-value{font-size:18px}.supply-both-col .supply-table-name,.supply-both-total .supply-table-name{font-size:12.5px}@media(max-width:640px){.supply-layout{grid-template-columns:1fr;padding:12px;gap:12px;padding-bottom:calc(var(--bottom-nav-h) + 20px)}.supply-both-form,.supply-both-layout,.input-grid{grid-template-columns:1fr}.supply-table-value{font-size:20px}}.ws-page{min-height:100vh;background:var(--bg);overflow-x:hidden;max-width:100%}.ws-hero{position:relative;padding:36px 28px 32px;background:linear-gradient(135deg,#1b3a6b,#1e4a8e,#2563eb);overflow:hidden}.ws-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 500px 350px at 75% 25%,rgba(96,165,250,.12),transparent);pointer-events:none}.ws-hero-inner{position:relative;z-index:1;max-width:720px;margin:0 auto}.ws-hero-title{font-size:24px;font-weight:800;color:#fff;letter-spacing:-.3px;margin-bottom:4px}.ws-hero-subtitle{font-size:12.5px;color:#ffffff8c;margin-bottom:20px;line-height:1.5}.ws-hero-stats{display:flex;gap:20px;margin-bottom:20px}.ws-hero-stat{display:flex;flex-direction:column;gap:1px}.ws-hero-stat-num{font-size:20px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums}.ws-hero-stat-label{font-size:10px;color:#fff6;font-weight:500;letter-spacing:.3px}.ws-search-wrap{position:relative}.ws-search-input{width:100%;height:44px;padding:0 40px;font-size:13.5px;font-family:inherit;color:var(--text-primary);background:#ffffffeb;border:none;border-radius:12px;outline:none;transition:box-shadow .2s;box-shadow:0 2px 12px #00000014}.ws-search-input::placeholder{color:var(--text-muted)}.ws-search-input:focus{box-shadow:0 2px 12px #00000014,0 0 0 3px #60a5fa40}.ws-search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;display:flex}.ws-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;border:none;background:var(--bg);color:var(--text-secondary);cursor:pointer;display:none;align-items:center;justify-content:center;transition:background .15s}.ws-search-clear:hover{background:var(--border)}.ws-toolbar{display:flex;align-items:center;gap:8px;padding:14px 20px 0;flex-wrap:wrap}.ws-mode-toggle{display:flex;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--card-bg)}.ws-mode-btn{padding:6px 14px;font-size:12px;font-weight:600;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:background .15s,color .15s;white-space:nowrap}.ws-mode-btn.active{background:var(--accent);color:#fff}.ws-mode-btn:not(.active):hover{background:var(--bg);color:var(--text-primary)}.ws-edit-actions{display:flex;align-items:center;gap:6px;margin-left:auto}.ws-cats-bar{padding:10px 20px;display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.ws-cats-bar::-webkit-scrollbar{display:none}.ws-cat-pill{padding:5px 14px;font-size:12px;font-weight:600;border:1.5px solid var(--border);border-radius:20px;background:var(--card-bg);color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap;flex-shrink:0}.ws-cat-pill:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.ws-cat-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.ws-body{padding:0 20px 32px}.ws-featured{margin-bottom:24px}.ws-featured-title{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:12px;display:flex;align-items:center;gap:4px}.ws-featured-title:before{content:"";width:3px;height:14px;background:#f59e0b;border-radius:2px;flex-shrink:0}.ws-featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;min-width:0}.ws-category{margin-bottom:24px;animation:wsFadeUp .4s ease-out both}.ws-category:nth-child(2){animation-delay:.05s}.ws-category:nth-child(3){animation-delay:.1s}.ws-category:nth-child(4){animation-delay:.15s}.ws-category:nth-child(5){animation-delay:.2s}.ws-category:nth-child(6){animation-delay:.25s}.ws-category-head{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:12px;display:flex;align-items:center;gap:8px}.ws-category-head:before{content:"";width:3px;height:14px;background:var(--accent);border-radius:2px;display:inline-block;flex-shrink:0}.ws-category-count{font-size:11px;font-weight:500;color:var(--text-muted);background:var(--bg);padding:1px 8px;border-radius:10px}.ws-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;min-width:0}.website-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:12px;transition:border-color .2s,box-shadow .2s,transform .2s;position:relative;cursor:pointer;display:flex;flex-direction:column;gap:8px}.website-card:hover{border-color:var(--accent);box-shadow:0 4px 16px #2563eb0f;transform:translateY(-1px)}.website-card:active{transform:translateY(0);transition-duration:.1s}.website-card-editable{border-style:dashed}.website-card-editable:hover{transform:none}.website-card-custom-tag{position:absolute;top:6px;right:6px;font-size:9px;background:var(--warning-bg);color:var(--warning-text);padding:1px 6px;border-radius:4px;font-weight:700}.website-card-top{display:flex;align-items:center;gap:10px}.website-card-avatar{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;position:relative;overflow:hidden}.website-card-avatar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent);pointer-events:none}.website-card-info{min-width:0;flex:1}.website-card-name{font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.website-card-desc{font-size:11px;color:var(--text-secondary);margin-top:1px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.website-card-tags{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.website-card-tag{font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;background:var(--accent-light);color:var(--accent)}.website-card-tag-hot{background:#ef44440f;color:#ef4444}.website-card-arrow{margin-left:auto;font-size:12px;color:var(--text-muted);transition:transform .2s,color .2s;flex-shrink:0}.website-card:hover .website-card-arrow{transform:translate(2px);color:var(--accent)}.ws-card-actions{display:none;gap:6px;padding-top:8px;border-top:1px solid var(--border)}.website-card-editable:hover .ws-card-actions{display:flex}.ws-card-btn{padding:4px 10px;font-size:11px;border:none;border-radius:6px;cursor:pointer;font-family:inherit;font-weight:600;transition:opacity .15s}.ws-card-btn:hover{opacity:.85}.ws-card-btn-edit{background:var(--accent-light);color:var(--accent)}.ws-card-btn-del{background:var(--error-bg);color:var(--error)}.ws-card-btn-link{background:var(--success-bg);color:var(--success);text-decoration:none}.ws-empty{text-align:center;padding:48px 20px;color:var(--text-muted)}.ws-empty-icon{margin-bottom:10px;opacity:.35;display:flex;justify-content:center}.ws-empty-text{font-size:14px;font-weight:500}.ws-empty-hint{font-size:12px;color:var(--text-muted);margin-top:4px}@keyframes wsFadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes wsCardIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.website-card{animation:wsCardIn .3s ease-out both}.ws-card-grid .website-card:nth-child(1){animation-delay:.02s}.ws-card-grid .website-card:nth-child(2){animation-delay:.04s}.ws-card-grid .website-card:nth-child(3){animation-delay:.06s}.ws-card-grid .website-card:nth-child(4){animation-delay:.08s}.ws-card-grid .website-card:nth-child(5){animation-delay:.1s}.ws-card-grid .website-card:nth-child(6){animation-delay:.12s}.ws-card-grid .website-card:nth-child(7){animation-delay:.14s}.ws-card-grid .website-card:nth-child(8){animation-delay:.16s}.ws-featured-grid .website-card:nth-child(1){animation-delay:.02s}.ws-featured-grid .website-card:nth-child(2){animation-delay:.04s}.ws-featured-grid .website-card:nth-child(3){animation-delay:.06s}.ws-featured-grid .website-card:nth-child(4){animation-delay:.08s}.ws-featured-grid .website-card:nth-child(5){animation-delay:.1s}.ws-featured-grid .website-card:nth-child(6){animation-delay:.12s}@media(min-width:1024px){.ws-hero{padding:48px 36px 40px}.ws-hero-title{font-size:28px}.ws-hero-subtitle{font-size:13px}.ws-hero-stat-num{font-size:24px}.ws-search-input{height:48px;font-size:14px;border-radius:14px;padding:0 44px 0 42px}.ws-card-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.ws-featured-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.website-card{padding:16px;border-radius:12px}.website-card-avatar{width:40px;height:40px;border-radius:10px;font-size:13px}.website-card-name{font-size:13.5px}.website-card-desc{font-size:11.5px}.ws-body{padding:0 28px 40px}.ws-cats-bar{padding:12px 28px}.ws-toolbar{padding:16px 28px 0}}@media(max-width:640px){.ws-hero{padding:20px 16px 18px}.ws-hero-title{font-size:18px}.ws-hero-subtitle{font-size:11px;margin-bottom:12px}.ws-hero-stats{gap:16px;margin-bottom:14px}.ws-hero-stat-num{font-size:16px}.ws-hero-stat-label{font-size:9px}.ws-search-input{height:40px;font-size:13px;border-radius:10px;padding:0 36px}.ws-search-icon{left:11px}.ws-toolbar{padding:10px 14px 0;gap:6px}.ws-mode-btn{padding:5px 10px;font-size:11px}.ws-cats-bar{padding:8px 14px;gap:5px}.ws-cat-pill{padding:4px 10px;font-size:11px}.ws-body{padding:0 14px calc(var(--bottom-nav-h) + 20px)}.ws-card-grid,.ws-featured-grid{grid-template-columns:1fr 1fr;gap:8px}.website-card{padding:10px;border-radius:8px;gap:6px;min-width:0;overflow:hidden}.website-card:hover{transform:none;box-shadow:none}.website-card-avatar{width:30px;height:30px;border-radius:7px;font-size:10px}.website-card-name{font-size:11.5px}.website-card-desc{font-size:10px;margin-top:1px}.website-card-top{gap:8px}.website-card-tag{font-size:9px;padding:1px 5px}.website-card-arrow{font-size:11px}.ws-category-head,.ws-featured-title{font-size:12px;margin-bottom:8px}.ws-category,.ws-featured{margin-bottom:16px}}@media(max-width:380px){.ws-card-grid,.ws-featured-grid{grid-template-columns:1fr}}[data-theme=dark] .ws-hero{background:linear-gradient(135deg,#0f172a,#1e293b,#1e3a5f)}[data-theme=dark] .ws-hero:before{background:radial-gradient(ellipse 500px 350px at 75% 25%,rgba(96,165,250,.08),transparent)}[data-theme=dark] .ws-search-input{background:#1e293bd9;color:var(--text-primary);box-shadow:0 2px 12px #0003}[data-theme=dark] .ws-search-input:focus{box-shadow:0 2px 12px #0003,0 0 0 3px #60a5fa33}[data-theme=dark] .ws-search-input::placeholder{color:var(--text-muted)}[data-theme=dark] .website-card:hover{box-shadow:0 4px 16px #2563eb1a}[data-theme=dark] .website-card-tag-hot{background:#ef44441a;color:#fca5a5}.sync-status-text{font-size:12px;color:var(--text-muted)}.sync-section-divider{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.sync-danger-btn{background:var(--error-bg)!important;color:var(--error)!important;border-color:var(--error-border)!important;width:100%;justify-content:center}.be-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:16px;padding:16px}.be-input-card,.be-result-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column}.be-tabs{display:flex;gap:6px;margin-bottom:18px;background:var(--bg);padding:4px;border-radius:10px;border:1px solid var(--border)}.be-tab-btn{flex:1;padding:8px 12px;border:none;background:transparent;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;color:var(--text-secondary);border-radius:7px;transition:all .2s;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:6px}.be-tab-btn.active{background:var(--card-bg);color:var(--text-primary);box-shadow:0 1px 3px #00000014}.be-tab-btn:hover:not(.active){color:var(--text-primary);background:var(--card-bg)}.be-form-area{display:flex;flex-direction:column;gap:4px}.be-result-area{display:flex;flex-direction:column;gap:12px}.be-warning{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.be-warning--orange{background:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.be-approach-info{background:var(--info-bg);border:1px solid var(--info-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:12.5px;color:var(--info-text);display:flex;align-items:center;gap:8px}.be-result-highlight{background:var(--success-bg);border:1.5px solid var(--success-border);border-radius:var(--radius-md);padding:18px 20px;text-align:center}.be-result-highlight .highlight-value{font-size:36px;font-weight:800;color:var(--success);font-variant-numeric:tabular-nums;line-height:1.2}.be-result-highlight .highlight-label{font-size:13px;color:var(--success-text);font-weight:600;margin-top:4px}.be-detail-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:8px 0}.be-detail-row+.be-detail-row{border-top:1px solid var(--border)}.be-detail-row .detail-label{font-size:12px;color:var(--text-secondary)}.be-detail-row .detail-value{font-size:15px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.be-param-hint{font-size:11px;color:var(--text-muted);margin-top:2px;line-height:1.4}@media(max-width:640px){.be-layout{grid-template-columns:1fr;padding:12px;gap:12px;padding-bottom:calc(var(--bottom-nav-h) + 20px)}.input-grid{grid-template-columns:1fr}.be-result-highlight .highlight-value{font-size:30px}}.mp-tabs{display:flex;gap:0;margin:0 16px;background:var(--bg-secondary);padding:5px;border-radius:12px;border:1.5px solid var(--border)}.mp-tab{flex:1;padding:11px 16px;border:none;background:transparent;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;color:var(--text-muted);border-radius:9px;transition:all .2s;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:6px;letter-spacing:.3px}.mp-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #00000026}.mp-tab:hover:not(.active){color:var(--text-primary);background:var(--card-bg)}.mp-foods-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px}.mp-foods-header-btns{display:flex;gap:8px}.mp-foods-title{font-size:15px;font-weight:700;color:var(--text-primary)}.mp-manage-cat-btn{padding:7px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text-secondary);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.mp-manage-cat-btn:hover{border-color:var(--accent);color:var(--accent)}.mp-cat-filters{display:flex;gap:6px;padding:0 16px 12px;flex-wrap:wrap}.mp-cat-filter{padding:5px 14px;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.mp-cat-filter.active{background:var(--accent);color:#fff;border-color:var(--accent)}.mp-cat-filter:hover:not(.active){border-color:var(--accent);color:var(--accent)}.mp-cat-tag{display:inline-block;padding:2px 8px;border-radius:10px;background:var(--accent-light);color:var(--accent);font-size:11px;font-weight:600;white-space:nowrap}.mp-cat-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;max-height:200px;overflow-y:auto}.mp-cat-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg)}.mp-cat-item-name{font-size:14px;font-weight:500;color:var(--text-primary)}.mp-cat-del-btn{width:24px;height:24px;border:none;border-radius:50%;background:transparent;color:var(--text-muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.mp-cat-del-btn:hover{background:var(--error-bg);color:var(--error)}.mp-cat-add-row{display:flex;gap:8px}.mp-cat-add-row .input-field{flex:1}.mp-cat-add-btn{padding:8px 16px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.mp-cat-add-btn:hover{background:var(--accent-hover)}.mp-add-food-btn{padding:7px 16px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.mp-add-food-btn:hover{background:var(--accent-hover)}.mp-foods-table-wrap{padding:0 16px 16px;overflow-x:auto}.mp-foods-table{width:100%;border-collapse:collapse;font-size:13px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.mp-foods-table thead{background:var(--bg)}.mp-foods-table th{padding:10px 14px;text-align:left;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1.5px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none}.mp-foods-table .mp-sortable{cursor:pointer;transition:color .15s}.mp-foods-table .mp-sortable:hover,.mp-foods-table .mp-sortable.mp-sort-active{color:var(--accent)}.mp-sort-arrow{font-size:10px;margin-left:2px;opacity:.5}.mp-sort-active .mp-sort-arrow{opacity:1}.mp-foods-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-primary);font-variant-numeric:tabular-nums}.mp-foods-table tbody tr:last-child td{border-bottom:none}.mp-foods-table tbody tr:hover{background:var(--accent-light)}.mp-foods-table .mp-food-name{font-weight:500;white-space:nowrap}.mp-foods-table .mp-food-actions{white-space:nowrap;display:flex;gap:6px}.mp-empty-cell{text-align:center;padding:32px 16px!important;color:var(--text-muted);font-size:14px}.mp-btn-edit,.mp-btn-delete,.mp-btn-delete-meal{padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:var(--card-bg);color:var(--text-secondary);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.mp-btn-edit:hover{border-color:var(--accent);color:var(--accent)}.mp-btn-delete:hover,.mp-btn-delete-meal:hover{border-color:var(--danger, var(--error));color:var(--danger, var(--error));background:var(--error-bg)}.mp-modal-form{display:flex;flex-direction:column;gap:12px}.mp-meal-header{padding:16px 16px 12px;display:flex;align-items:center;justify-content:space-between}.mp-meal-title{font-size:15px;font-weight:700;color:var(--text-primary)}.mp-current-plan-label{font-size:13px;font-weight:500;color:var(--accent);background:#0000000a;padding:3px 10px;border-radius:12px;margin-left:8px}.mp-new-plan-btn{padding:7px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,color .15s}.mp-new-plan-btn:hover{background:var(--bg);color:var(--text-primary)}.mp-cell-warn{background:#ffe0e0!important;color:#d32f2f!important;font-weight:800!important;border:2px solid #d32f2f!important;border-radius:4px;position:relative;cursor:help}.mp-cell-warn:after{content:" !";font-weight:800;color:#d32f2f}[data-theme=dark] .mp-cell-warn{background:#4a1a1a!important;color:#ff6b6b!important;border-color:#ff6b6b!important}[data-theme=dark] .mp-cell-warn:after{color:#ff6b6b}.mp-warning{margin-bottom:12px;border-radius:var(--radius-md);padding:12px 16px;font-size:13px;line-height:1.6}.mp-warning-pass{background:var(--success-bg, #e8f5e9);border:1.5px solid var(--success, #4caf50);color:var(--success-text, #2e7d32);display:flex;align-items:center;gap:8px}.mp-warning-pass .mp-warning-icon{font-size:18px;font-weight:700}.mp-warning-fail{background:var(--error-bg, #fff3e0);border:2px solid var(--error, #f44336);color:var(--text-primary)}.mp-warning-title{font-weight:700;font-size:14px;color:var(--error, #f44336);margin-bottom:8px}.mp-warning-item{display:flex;align-items:center;gap:6px;padding:4px 0}.mp-warning-item .mp-warning-icon{font-size:14px;font-weight:700;flex-shrink:0}.mp-warning-error .mp-warning-icon{color:var(--error, #f44336)}.mp-warning-warning .mp-warning-icon{color:var(--warning, #ff9800)}.mp-warning-text strong{color:var(--error, #f44336)}.mp-warning-warning .mp-warning-text strong{color:var(--warning, #ff9800)}.mp-meal-table-wrap{padding:0 16px 16px;overflow-x:auto}.mp-meal-table{width:100%;border-collapse:collapse;font-size:15px;border:1.5px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.mp-meal-table thead{background:var(--bg)}.mp-meal-table th{padding:10px;text-align:left;font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);white-space:nowrap}.mp-meal-table td{padding:9px 10px;border-bottom:1.5px solid var(--border);color:var(--text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.mp-meal-table tbody tr:hover{background:var(--accent-light)}.mp-cell-idx{color:var(--text-muted);font-size:13px;width:36px;text-align:center}.mp-computed{color:var(--text-secondary);font-size:14px;background:var(--bg-secondary);font-variant-numeric:tabular-nums}.mp-cell-cal{font-weight:700;color:var(--accent)!important;font-size:15px}.mp-meal-table .mp-food-actions{white-space:nowrap}.mp-region-title td{text-align:center;font-weight:700;font-size:12px;color:#fff;background:var(--accent);padding:6px;border-bottom:2px solid var(--accent);letter-spacing:1px}.mp-region-header th{background:var(--bg);padding:6px 10px;text-align:left;font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border);white-space:nowrap}.mp-region-upper td,.mp-region-lower td{padding:6px 10px;font-size:13px;color:var(--text-secondary)}.mp-summary-label{font-weight:700;font-size:13px;letter-spacing:.3px}.mp-summary-val{font-weight:700;font-variant-numeric:tabular-nums}.mp-summary-row-qty td{background:var(--bg-secondary)}.mp-summary-row-qty .mp-summary-val{color:var(--text-primary)}.mp-summary-row-cal td{background:var(--accent-light)}.mp-summary-row-cal .mp-summary-val{color:var(--accent);font-size:15px}.mp-summary-row-pct td{background:var(--bg-secondary)}.mp-summary-row-pct .mp-summary-val{color:var(--success);font-size:15px}.mp-region-upper .mp-summary-row-qty td,.mp-region-lower .mp-summary-row-qty td,.mp-region-upper .mp-summary-row-cal td,.mp-region-lower .mp-summary-row-cal td,.mp-region-upper .mp-summary-row-pct td,.mp-region-lower .mp-summary-row-pct td{padding:4px 10px;font-size:11.5px}.mp-editable{cursor:pointer;position:relative;border-left:2px solid transparent;transition:background .15s,border-color .15s}.mp-editable:after{content:"✎";position:absolute;top:2px;right:3px;font-size:9px;color:var(--accent);opacity:0;transition:opacity .15s;pointer-events:none}.mp-editable:hover{background:var(--accent-light);border-left-color:var(--accent)}.mp-editable:hover:after{opacity:.6}.mp-edit-tol-upper,.mp-edit-tol-lower{text-align:center;font-weight:600;min-width:52px}.mp-edit-tol-upper{color:#e65100}.mp-edit-tol-lower{color:#1565c0}[data-theme=dark] .mp-edit-tol-upper{color:#ffb74d}[data-theme=dark] .mp-edit-tol-lower{color:#64b5f6}.mp-inline-select{width:100%;padding:4px 6px;border:1.5px solid var(--accent);border-radius:4px;font-size:15px;font-family:inherit;background:var(--card-bg);color:var(--text-primary);outline:none;box-sizing:border-box}.mp-inline-input{width:70px;padding:4px 6px;border:1.5px solid var(--accent);border-radius:4px;font-size:15px;font-family:inherit;background:var(--card-bg);color:var(--text-primary);outline:none;box-sizing:border-box}.mp-tol-input{width:50px;text-align:center}.mp-tol-ok{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin-left:3px;border-radius:4px;background:var(--accent);color:#fff;font-size:13px;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none;vertical-align:middle;transition:background .15s}.mp-tol-ok:hover{background:var(--accent-hover)}.mp-note-input{width:90px}.mp-meal-actions{padding:12px 16px 24px;display:flex;gap:10px}.mp-add-meal-row-btn{padding:9px 20px;border:2px dashed var(--accent);border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s;width:100%}.mp-add-meal-row-btn:hover{background:var(--accent);color:#fff;border-style:solid}.mp-meal-header-btns{display:flex;gap:8px;align-items:center}.mp-export-btn{padding:9px 24px;border:1.5px solid var(--accent);border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.mp-export-btn:hover{background:var(--accent);color:#fff}.mp-save-plan-btn,.mp-saved-plans-btn{padding:9px 20px;border:1.5px solid var(--accent);border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.mp-save-plan-btn:hover,.mp-saved-plans-btn:hover,.mp-save-plan-btn{background:var(--accent);color:#fff}.mp-save-plan-btn:hover{opacity:.85}.mp-foods-search{margin:0 16px 8px}.mp-foods-search-input{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s;box-sizing:border-box}.mp-foods-search-input:focus{border-color:var(--accent)}.mp-saved-plans-section{margin:16px 16px 0;padding-top:16px;border-top:1.5px solid var(--border)}.mp-saved-plans-title{font-size:15px;font-weight:700;margin:0 0 10px;color:var(--text-primary)}.mp-saved-plans-list{display:flex;flex-direction:column;gap:8px}.mp-saved-plan-card{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius-md);gap:12px}.mp-saved-plan-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.mp-saved-plan-name{font-weight:600;font-size:14px;color:var(--text-primary)}.mp-saved-plan-meta{display:flex;gap:8px;font-size:12px;color:var(--text-secondary);flex-wrap:wrap}.mp-plan-badge{padding:1px 6px;border-radius:4px;font-size:11px;font-weight:600}.mp-badge-ok{background:#e6f9ed;color:#1a7f37}.mp-badge-warn{background:#fff8e1;color:#b8860b}.mp-saved-plan-items{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-saved-plan-actions{display:flex;gap:6px;flex-shrink:0}.mp-plan-load-btn,.mp-plan-delete-btn{padding:5px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:transparent;font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s}.mp-plan-delete-btn{color:var(--error-text);border-color:var(--error-text)}.mp-plan-delete-btn:hover{background:var(--error-text);color:#fff}.mp-food-updated{font-size:12px;color:var(--text-muted);white-space:nowrap}.mp-hover-card-updated{font-size:11px;color:var(--text-muted);margin-top:4px}.mp-cell-muted{color:var(--text-muted);font-size:12px}.mp-save-status{margin-top:12px;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;line-height:1.5}.mp-save-ok{background:#e8f5e9;color:#2e7d32}.mp-save-warn{background:#fff3e0;color:#e65100}.mp-save-icon{font-weight:800;margin-right:4px}[data-theme=dark] .mp-save-ok{background:#1b3a1b;color:#81c784}[data-theme=dark] .mp-save-warn{background:#3e2723;color:#ffb74d}.mp-plan-list{max-height:400px;overflow-y:auto}.mp-plans-empty{text-align:center;color:var(--text-muted);padding:32px 0;font-size:14px}.mp-plan-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.mp-plan-item:last-child{border-bottom:none}.mp-plan-info{flex:1;min-width:0}.mp-plan-name{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.mp-plan-meta{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--text-muted);flex-wrap:wrap}.mp-plan-cal{color:var(--accent);font-weight:600}.mp-plan-fat{font-weight:500}.mp-plan-badge{padding:1px 8px;border-radius:10px;font-size:11px;font-weight:700}.mp-badge-ok{background:#e8f5e9;color:#2e7d32}.mp-badge-warn{background:#ffe0e0;color:#d32f2f}[data-theme=dark] .mp-badge-ok{background:#1b3a1b;color:#81c784}[data-theme=dark] .mp-badge-warn{background:#4a1a1a;color:#ff6b6b}.mp-plan-date{font-size:11px}.mp-plan-actions{display:flex;gap:6px;flex-shrink:0;margin-left:12px}.mp-plan-load-btn,.mp-plan-delete-btn{padding:5px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.mp-plan-load-btn{color:var(--accent);border-color:var(--accent)}.mp-plan-load-btn:hover{background:var(--accent);color:#fff}.mp-plan-delete-btn{color:var(--text-muted);border-color:var(--border)}.mp-plan-delete-btn:hover{background:#d32f2f;color:#fff;border-color:#d32f2f}[data-theme=dark] .mp-foods-table tbody tr:hover,[data-theme=dark] .mp-meal-table tbody tr:hover{background:var(--accent-light)}[data-theme=dark] .mp-btn-edit:hover{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .mp-btn-delete:hover,[data-theme=dark] .mp-btn-delete-meal:hover{border-color:var(--error);color:var(--error);background:var(--error-bg)}[data-theme=dark] .mp-summary-row-cal td:nth-child(n+2){color:var(--accent-hover)}[data-theme=dark] .mp-summary-row-pct td:nth-child(n+2){color:var(--success-text)}[data-theme=dark] .mp-inline-select,[data-theme=dark] .mp-inline-input{background:var(--bg);border-color:var(--accent)}.mp-food-photo-cell{padding:6px 8px!important;width:52px;min-width:52px;text-align:center}.mp-food-photo{width:40px;height:40px;border-radius:6px;object-fit:cover;background:var(--bg-secondary);display:block;margin:0 auto;cursor:pointer;transition:transform .15s,box-shadow .15s}.mp-food-photo:hover{transform:scale(1.15);box-shadow:0 0 0 2px var(--accent)}.mp-photo-viewer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;animation:mp-viewer-fade-in .2s ease}@keyframes mp-viewer-fade-in{0%{opacity:0}to{opacity:1}}.mp-photo-viewer-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3}.mp-photo-viewer-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;animation:mp-viewer-scale-in .2s ease}@keyframes mp-viewer-scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.mp-photo-viewer-close{position:absolute;top:-40px;right:-8px;width:32px;height:32px;border:none;border-radius:50%;background:#ffffff26;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:1}.mp-photo-viewer-close:hover{background:#ffffff4d}.mp-photo-viewer-img{max-width:80vw;max-height:70vh;border-radius:12px;object-fit:contain;box-shadow:0 8px 32px #0006}.mp-photo-viewer-info{display:flex;align-items:center;gap:16px;margin-top:16px}.mp-photo-viewer-name{color:#fff;font-size:15px;font-weight:600}.mp-photo-viewer-download{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);background:#ffffff1a;color:#fff;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.mp-photo-viewer-download:hover{background:var(--accent);border-color:var(--accent)}.mp-hover-card{position:fixed;z-index:1000;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000026;padding:16px;min-width:220px;max-width:280px;pointer-events:auto;animation:mp-hover-fade-in .15s ease}@keyframes mp-hover-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.mp-hover-card-img{width:100%;max-width:200px;max-height:200px;border-radius:8px;object-fit:cover;margin-bottom:12px;display:block}.mp-hover-card-name{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.mp-hover-card-cat{display:inline-block;padding:2px 8px;border-radius:10px;background:var(--accent-light);color:var(--accent);font-size:11px;font-weight:600;margin-bottom:10px}.mp-hover-card-nutrition{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}.mp-hover-card-nut-item{text-align:center}.mp-hover-card-nut-value{font-size:16px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.mp-hover-card-nut-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.mp-hover-card-buy{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border:1px solid var(--accent);border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;text-decoration:none;transition:all .15s;pointer-events:auto}.mp-hover-card-buy:hover{background:var(--accent);color:#fff}.mp-photo-upload{display:flex;align-items:center;gap:12px}.mp-photo-preview{width:64px;height:64px;border-radius:8px;border:1.5px dashed var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.mp-photo-preview img{width:100%;height:100%;object-fit:cover;border-radius:6px}.mp-photo-actions{display:flex;flex-direction:column;gap:6px}.mp-photo-btn{display:inline-block;padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text-secondary);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.mp-photo-btn:hover{border-color:var(--accent);color:var(--accent)}.mp-photo-remove-btn{padding:4px 10px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--error);font-size:11px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s}.mp-photo-remove-btn:hover{background:var(--error-bg)}[data-theme=dark] .mp-hover-card{background:var(--card-bg);border-color:var(--border);box-shadow:0 8px 24px #0006}[data-theme=dark] .mp-food-photo{background:var(--bg)}[data-theme=dark] .mp-photo-preview{border-color:var(--border);background:var(--bg)}[data-theme=dark] .mp-ocr-entry{background:rgba(var(--accent-rgb, 59,130,246),.1)}[data-theme=dark] .mp-ocr-spinner{border-color:var(--border);border-top-color:var(--accent)}.mp-ocr-entry{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--accent-light);border-radius:var(--radius-sm);margin-bottom:4px}.mp-ocr-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid var(--accent);border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.mp-ocr-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.mp-ocr-divider{color:var(--text-muted);font-size:12px}.mp-ocr-hint{color:var(--text-secondary);font-size:12px}.mp-ocr-status{padding:16px;text-align:center}.mp-ocr-loading{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:13px}.mp-ocr-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:mp-spin .6s linear infinite}@keyframes mp-spin{to{transform:rotate(360deg)}}@media(max-width:768px){.mp-tabs{margin:0 12px}.mp-foods-header{padding:12px 12px 10px}.mp-foods-table-wrap{padding:0 12px 12px}.mp-foods-table th,.mp-foods-table td{padding:8px 10px;font-size:12px}.mp-meal-header{padding:12px 12px 8px}.mp-meal-table-wrap{padding:0 12px 12px}.mp-meal-table th,.mp-meal-table td{padding:7px 8px;font-size:12px}.mp-inline-input{width:55px}.mp-tol-input{width:40px}.mp-note-input{width:60px}.mp-food-photo-cell{padding:4px 6px!important;width:44px;min-width:44px}.mp-food-photo{width:32px;height:32px;border-radius:4px}.mp-hover-card{min-width:180px;max-width:240px;padding:12px}.mp-hover-card-img{max-width:150px;max-height:150px}.mp-photo-preview{width:48px;height:48px}.mp-meal-actions{padding:0 12px 24px}.mp-ocr-entry{padding:10px 12px;gap:8px}.mp-ocr-btn{padding:6px 12px;font-size:12px}}
