: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}:where(button,a,input,select,textarea,[tabindex]):focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 42%,transparent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.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{display:none;opacity:0;transition:opacity .15s ease}.sidebar.collapsed .sidebar-brand{padding:20px 0 18px;justify-content:center}.sidebar.collapsed .sidebar-brand-inner{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-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[data-page=contract],.dock-item[data-page=contract],.sidebar-item[data-page=home],.dock-item[data-page=home]{--module-color: #60A5FA;--module-bg: rgba(96, 165, 250, .2) }.sidebar-brand{cursor:pointer}.sidebar-item[data-page=supply],.dock-item[data-page=supply]{--module-color: #2DD4BF;--module-bg: rgba(45, 212, 191, .18) }.sidebar-item[data-page=beEstimate],.dock-item[data-page=beEstimate]{--module-color: #A78BFA;--module-bg: rgba(167, 139, 250, .2) }.sidebar-item[data-page=mealPlan],.dock-item[data-page=mealPlan]{--module-color: #FB923C;--module-bg: rgba(251, 146, 60, .2) }.sidebar-item[data-page=websites],.dock-item[data-page=websites]{--module-color: #34D399;--module-bg: rgba(52, 211, 153, .18) }.sidebar-item[data-page=sync],.dock-item[data-page=sync]{--module-color: #F472B6;--module-bg: rgba(244, 114, 182, .18) }.sidebar-item .sidebar-icon{color:#ffffff8c}.sidebar-item:hover{background:var(--sidebar-hover);color:#fff}.sidebar-item.active{background:var(--module-bg, var(--sidebar-active));color:#fff}.sidebar-item.active .sidebar-icon{color:#fff;background:var(--module-color, #60a5fa);box-shadow:0 3px 10px color-mix(in srgb,var(--module-color, #60a5fa) 38%,transparent)}.sidebar-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--module-color, #60a5fa);border-radius:0 3px 3px 0}.sidebar-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:8px;transition:transform .2s ease,color .15s,background .15s,box-shadow .15s}.sidebar-item:hover .sidebar-icon{color:#fff;transform:scale(1.08)}.sidebar-label{overflow:hidden;opacity:1;transition:opacity .2s ease .1s}.sidebar.collapsed .sidebar-label{display:none;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(--module-color, var(--text-primary));background:var(--module-bg, var(--accent-light));border-radius:16px;margin:4px 2px}.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{color:#fff;background:var(--module-color, var(--accent));border-radius:10px;transform:translateY(-1px);box-shadow:0 3px 10px color-mix(in srgb,var(--module-color, var(--accent)) 35%,transparent)}.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(--module-color, var(--text-primary));font-weight:700}.dock-dot{width:5px;height:5px;border-radius:50%;background:var(--module-color, 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 var(--module-color, rgba(37,99,235,.35))}@media(min-width:641px)and (max-width:900px){.sidebar.collapsed:not(.peek-closed):hover{width:var(--sidebar-w);box-shadow:12px 0 28px #0f172a2e}.sidebar.collapsed:not(.peek-closed):hover .sidebar-brand{padding:20px 16px 18px;justify-content:flex-start}.sidebar.collapsed:not(.peek-closed):hover .sidebar-brand-inner{justify-content:flex-start}.sidebar.collapsed:not(.peek-closed):hover .sidebar-brand-icon{width:34px;height:34px}.sidebar.collapsed:not(.peek-closed):hover .sidebar-brand-text,.sidebar.collapsed:not(.peek-closed):hover .sidebar-label{display:block;opacity:1}.sidebar.collapsed:not(.peek-closed):hover .sidebar-section-label{display:block}.sidebar.collapsed:not(.peek-closed):hover .sidebar-badge{display:inline-flex}.sidebar.collapsed:not(.peek-closed):hover .sidebar-item{padding:10px 14px;justify-content:flex-start}.sidebar.collapsed:not(.peek-closed):hover .sidebar-item:after{display:none}.sidebar.collapsed:not(.peek-closed):hover .sidebar-footer{padding:14px 16px;text-align:left}.sidebar.collapsed:not(.peek-closed):hover .sidebar-footer-inner{flex-direction:row;align-items:center;gap:8px}.sidebar.collapsed:not(.peek-closed):hover .sidebar-admin-label{display:inline}.sidebar.collapsed:not(.peek-closed):hover .sync-status-label{display:inline;width:auto;height:auto;border-radius:0;background:transparent;font-size:11px}}@media(max-width:640px){.sidebar{display:none!important}.hamburger,#overlay{display:none}.main-content,.app-shell.sidebar-collapsed .main-content{margin-left:0!important;width:100%}.mobile-topbar{display:flex;position:sticky;top:0;z-index:150;padding-top:calc(14px + env(safe-area-inset-top))}.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:calc(6px + env(safe-area-inset-bottom));left:calc(8px + env(safe-area-inset-left));right:calc(8px + env(safe-area-inset-right));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(--module-color, var(--text-primary))}[data-theme=dark] .dock-item.active .dock-dot{box-shadow:0 0 6px 1px var(--module-color, rgba(96,165,250,.4))}.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}.tax-rate-options{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.custom-tax-wrap{width:112px;height:36px;display:flex;align-items:center;border:1.5px solid var(--border);border-radius:20px;background:var(--card-bg);color:var(--text-secondary);transition:border-color .15s,box-shadow .15s,background .15s}.custom-tax-wrap:focus-within,.custom-tax-wrap.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.custom-tax-input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--text-primary);font:inherit;font-size:12.5px;text-align:center;padding:0 2px 0 10px;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.custom-tax-input::-webkit-inner-spin-button,.custom-tax-input::-webkit-outer-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0}.custom-tax-input::placeholder{color:var(--text-muted)}.custom-tax-input.has-error{color:var(--error)}.custom-tax-wrap>span{padding-right:10px;font-size:12px;font-weight:600}.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{width:32px;height:32px;border:1px solid var(--accent);border-radius:8px;background:var(--accent-light);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:1;transition:background .15s,color .15s,transform .15s,box-shadow .15s;box-shadow:0 1px 2px #2563eb1f}.result-value-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.result-copy-btn{height:34px;padding:0 11px;border:0;border-radius:8px;background:var(--success);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:5px;font:inherit;font-size:12px;font-weight:600;cursor:pointer;flex-shrink:0;transition:filter .15s,transform .15s}.result-copy-btn:hover{filter:brightness(.92);transform:translateY(-1px)}.result-copy-btn:active{transform:translateY(0)}.period-copy-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px);box-shadow:0 3px 8px #2563eb3d}.period-copy-btn:active{transform:translateY(0)}.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-actions{width:100%;justify-content:space-between}.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}}.home-editorial{--home-ink: #071a38;--home-blue: #165dff;--home-line: #dce4ef;width:min(1180px,calc(100% - 64px));margin:0 auto;padding:44px 0 36px}[data-theme=dark] .home-editorial{--home-ink: #e8eef8;--home-line: rgba(148, 163, 184, .22) }.editorial-hero{min-height:430px;display:grid;grid-template-columns:.86fr 1.14fr;align-items:center;gap:28px;border-bottom:1px solid var(--home-line)}.editorial-copy{padding:20px 0 54px 30px}.editorial-copy h1{margin:0;max-width:530px;color:var(--home-ink);font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:clamp(58px,7vw,88px);font-weight:700;line-height:1.03;letter-spacing:-.075em}.editorial-copy p{margin-top:26px;color:var(--text-secondary);font-size:18px;letter-spacing:.03em}.editorial-cta{margin-top:54px;padding:0;border:0;background:transparent;color:var(--home-blue);font:inherit;font-size:16px;font-weight:650;letter-spacing:.02em;cursor:pointer}.editorial-cta span{display:inline-block;margin-left:12px;font-size:23px;transition:transform .18s}.editorial-cta:hover span{transform:translate(5px)}.science-graphic{min-width:0;color:var(--home-blue);display:flex;align-items:center;justify-content:center}.science-graphic svg{width:100%;max-width:640px;height:auto;display:block}.editorial-tools{padding-top:38px}.editorial-section-title{display:flex;align-items:center;justify-content:space-between;padding:0 0 16px}.editorial-section-title h2{color:var(--home-ink);font-size:13px;font-weight:650;letter-spacing:.16em}.editorial-search,.editorial-footer-search{padding:0;border:0;background:transparent;color:var(--text-secondary);font:inherit;font-size:12px;cursor:pointer}.editorial-search:hover,.editorial-footer-search:hover{color:var(--home-blue)}.editorial-tool-list{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--home-line);border-bottom:1px solid var(--home-line)}.editorial-tool{min-width:0;min-height:112px;display:grid;grid-template-columns:54px 44px 1fr 24px;align-items:center;gap:14px;padding:18px 22px 18px 8px;border:0;border-bottom:1px solid var(--home-line);background:transparent;color:var(--home-ink);text-align:left;font:inherit;cursor:pointer;transition:background .18s,padding .18s}.editorial-tool:nth-child(odd){border-right:1px solid var(--home-line)}.editorial-tool:nth-last-child(-n+2){border-bottom:0}.editorial-tool:hover{padding-left:16px;background:color-mix(in srgb,var(--home-blue) 4.5%,transparent)}.editorial-number{color:var(--home-blue);font-size:24px;font-weight:450;letter-spacing:-.04em;font-variant-numeric:tabular-nums}.editorial-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--home-ink)}.editorial-tool-copy{min-width:0;display:flex;flex-direction:column;gap:7px}.editorial-tool-copy strong{color:var(--home-ink);font-size:15px;font-weight:680}.editorial-tool-copy small{color:var(--text-secondary);font-size:12px;line-height:1.45}.editorial-arrow{color:var(--text-muted);font-size:18px;opacity:0;transform:translate(-5px,5px);transition:opacity .18s,transform .18s,color .18s}.editorial-tool:hover .editorial-arrow{color:var(--home-blue);opacity:1;transform:translate(0)}.editorial-footer{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px;color:var(--text-secondary);font-size:12px}.editorial-footer-search span{margin-right:8px;color:var(--home-ink);font-size:18px}.editorial-footer p{margin:0}.footer-cloud{margin-right:7px;color:var(--home-blue)}@media(max-width:980px){.home-editorial{width:min(100% - 40px,880px)}.editorial-hero{grid-template-columns:.9fr 1.1fr;min-height:390px}.editorial-copy{padding-left:8px}.editorial-copy h1{font-size:clamp(50px,7vw,70px)}.editorial-tool{grid-template-columns:44px 38px 1fr 18px;gap:10px;padding-right:12px}}@media(max-width:720px){.home-editorial{width:calc(100% - 32px);padding-top:14px;padding-bottom:calc(var(--bottom-nav-h) + 28px)}.editorial-hero{grid-template-columns:1fr;gap:0;min-height:0;padding-top:30px}.editorial-copy{padding:0}.editorial-copy h1{font-size:clamp(48px,14vw,68px)}.editorial-copy p{margin-top:18px;font-size:15px}.editorial-cta{margin-top:30px}.science-graphic{margin-top:-6px}.editorial-tools{padding-top:28px}.editorial-search{display:none}.editorial-tool-list{grid-template-columns:1fr}.editorial-tool,.editorial-tool:nth-child(odd),.editorial-tool:nth-last-child(-n+2){border-right:0;border-bottom:1px solid var(--home-line)}.editorial-tool:last-child{border-bottom:0}.editorial-tool{min-height:92px;grid-template-columns:42px 36px 1fr 18px;padding:14px 4px}.editorial-number{font-size:20px}.editorial-icon{width:36px;height:36px}.editorial-icon svg{width:24px;height:24px}.editorial-arrow{opacity:1;transform:none}.editorial-footer{align-items:flex-start;flex-direction:column;justify-content:center;padding:20px 0}}:root{--bg: #f2eee6;--card-bg: #fbf8f1;--text-primary: #242321;--text-secondary: #6f6a62;--text-muted: #9a9388;--border: #d8d0c3;--accent: #cf5c3f;--accent-hover: #b94d34;--accent-light: rgba(207, 92, 63, .1);--sidebar-bg: #f8f4ec;--sidebar-text: #59544d;--sidebar-hover: rgba(207, 92, 63, .08);--sidebar-active: rgba(207, 92, 63, .12);--sidebar-w: 224px;--sidebar-w-collapsed: 72px;--shadow: 0 1px 0 rgba(66, 55, 41, .06), 0 12px 36px rgba(66, 55, 41, .045);--shadow-sm: 0 1px 2px rgba(66, 55, 41, .07);--radius-sm: 7px;--radius-md: 10px;--radius-lg: 14px;--success: #56705a;--success-bg: #edf2e8;--success-border: #bdc9b6;--success-text: #405a45;--warning: #aa712e;--warning-bg: #f7eddb;--warning-border: #ddc797;--warning-text: #77501e;--info-bg: #eee9df;--info-border: #d3c8b8;--info-text: #534d45 }[data-theme=dark]{--bg: #252421;--card-bg: #2d2b27;--text-primary: #f0eae0;--text-secondary: #b8afa3;--text-muted: #8e867c;--border: #4a453e;--accent: #e07a5f;--accent-hover: #eb8d72;--accent-light: rgba(224, 122, 95, .14);--sidebar-bg: #1f1e1b;--sidebar-text: #c8beb2;--sidebar-hover: rgba(224, 122, 95, .1);--sidebar-active: rgba(224, 122, 95, .14) }html{background:var(--bg)}body{background-color:var(--bg);background-image:radial-gradient(circle at 18% 12%,rgba(207,92,63,.028) 0 1px,transparent 1.5px),radial-gradient(circle at 72% 54%,rgba(74,65,52,.024) 0 1px,transparent 1.5px);background-size:19px 19px,27px 27px;font-family:Times New Roman,Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif;letter-spacing:.005em}button,input,select,textarea{font-family:inherit}.sidebar{border-right:1px solid var(--border);box-shadow:none;color:var(--sidebar-text)}.sidebar-brand{min-height:82px;padding:22px 18px;border-bottom-color:var(--border);background:transparent}.sidebar-brand-icon{width:42px;height:42px;border:1px solid #b9543c;border-radius:13px 11px 14px 10px;background:#cf674b;color:#fff7ed;box-shadow:0 6px 15px #9348322b;transform:rotate(-2deg);transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .25s}.brand-mark{display:block;transform-origin:center;transition:transform .45s cubic-bezier(.34,1.56,.64,1)}.sidebar-brand:hover .sidebar-brand-icon{transform:rotate(2deg) translateY(-1px);box-shadow:0 9px 21px #93483238}.sidebar-brand:hover .brand-mark{transform:rotate(30deg) scale(1.04)}.sidebar-brand h1{color:var(--text-primary);font-family:Times New Roman,"Noto Serif SC",Songti SC,STSong,serif;font-size:16px;font-weight:650}.sidebar-brand p,.sidebar-section-label,.sidebar-badge{color:var(--text-muted)}.sidebar.collapsed .sidebar-brand{padding:22px 0;border-bottom-color:var(--border)}.sidebar.collapsed .sidebar-brand-icon{width:42px;height:42px}.sidebar-nav{padding:14px 0}.sidebar-section-label{padding:13px 18px 5px;font-size:9px;letter-spacing:.18em}.sidebar-item{min-height:54px;gap:12px;margin:2px 8px;width:calc(100% - 16px);padding:8px 10px;border-radius:10px;color:var(--sidebar-text)}.sidebar.collapsed .sidebar-item{width:52px;margin:3px 10px;padding:8px;justify-content:center}.sidebar-icon{width:36px;height:36px;border:1px solid transparent;border-radius:12px 10px 13px 9px;color:var(--module-color, var(--text-secondary));transition:transform .22s cubic-bezier(.34,1.56,.64,1),color .18s,background .18s,border-color .18s}.sidebar-item .sidebar-icon{color:var(--module-color, var(--text-secondary));opacity:.88}.sidebar-icon svg,.dock-icon svg,.editorial-icon svg{stroke-width:1.8}.sidebar-item:hover{background:var(--module-bg, var(--sidebar-hover));color:var(--text-primary)}.sidebar-item:hover .sidebar-icon{color:var(--module-color, var(--accent));opacity:1;transform:translateY(-1px) rotate(-3deg);border-color:color-mix(in srgb,var(--module-color, var(--accent)) 28%,transparent)}.sidebar-item.active{background:var(--module-bg, var(--sidebar-active));color:var(--text-primary)}.sidebar-item.active .sidebar-icon{color:var(--module-color, var(--accent));opacity:1;background:color-mix(in srgb,var(--module-color, var(--accent)) 12%,var(--card-bg));border-color:color-mix(in srgb,var(--module-color, var(--accent)) 38%,var(--border));box-shadow:none;transform:rotate(-2deg)}.sidebar-item.active:before{display:none}.sidebar-item[data-page=home],.dock-item[data-page=home],.sidebar-item[data-page=contract],.dock-item[data-page=contract]{--module-color: #cf5c3f;--module-bg: rgba(207, 92, 63, .1) }.sidebar-item[data-page=supply],.dock-item[data-page=supply]{--module-color: #6f8058;--module-bg: rgba(111, 128, 88, .11) }.sidebar-item[data-page=beEstimate],.dock-item[data-page=beEstimate]{--module-color: #b07b2e;--module-bg: rgba(176, 123, 46, .11) }.sidebar-item[data-page=mealPlan],.dock-item[data-page=mealPlan]{--module-color: #b65e43;--module-bg: rgba(182, 94, 67, .1) }.sidebar-item[data-page=websites],.dock-item[data-page=websites]{--module-color: #66837f;--module-bg: rgba(102, 131, 127, .11) }.sidebar-item[data-page=sync],.dock-item[data-page=sync]{--module-color: #8b6d8f;--module-bg: rgba(139, 109, 143, .11) }.sidebar-footer{border-top-color:var(--border);background:transparent;position:relative;overflow:visible}.sidebar-account-menu,.mobile-account-menu{padding:6px;border:1px solid var(--border);border-radius:12px 10px 13px 9px;background:var(--card-bg);box-shadow:0 14px 36px #32281e29;z-index:260}.sidebar-account-menu[hidden],.mobile-account-menu[hidden]{display:none}.sidebar-account-menu{position:absolute;left:8px;right:8px;bottom:calc(100% + 8px)}.account-menu-item,.mobile-account-item{width:100%;min-height:40px;padding:8px 10px;display:flex;align-items:center;gap:9px;border:0;border-radius:8px;background:transparent;color:var(--text-primary);font:inherit;font-size:12px;text-align:left;cursor:pointer}.account-menu-item:hover,.mobile-account-item:hover{background:var(--accent-light);color:var(--accent)}.mobile-topbar-actions{position:relative}.mobile-account-menu{position:absolute;top:calc(100% + 10px);right:44px;width:190px}.mobile-account-item{justify-content:flex-start}.mobile-auth-btn{justify-content:space-between}.sidebar-admin-btn,.theme-toggle,.sync-status-label{color:var(--text-muted)}.theme-toggle{background:color-mix(in srgb,var(--text-primary) 5%,transparent)}@media(min-width:641px){.sidebar.collapsed:not(.peek-closed):hover{width:var(--sidebar-w);box-shadow:14px 0 32px #362d231a}.sidebar.collapsed:not(.peek-closed):hover .sidebar-brand{padding:22px 18px;justify-content:flex-start}.sidebar.collapsed:not(.peek-closed):hover .sidebar-brand-inner{justify-content:flex-start}.sidebar.collapsed:not(.peek-closed):hover .sidebar-brand-text,.sidebar.collapsed:not(.peek-closed):hover .sidebar-label,.sidebar.collapsed:not(.peek-closed):hover .sidebar-section-label{display:block;opacity:1}.sidebar.collapsed:not(.peek-closed):hover .sidebar-badge{display:inline-flex}.sidebar.collapsed:not(.peek-closed):hover .sidebar-item{width:calc(100% - 16px);margin:2px 8px;padding:8px 10px;justify-content:flex-start}.sidebar.collapsed:not(.peek-closed):hover .sidebar-item:after{display:none}.sidebar.collapsed:not(.peek-closed):hover .sidebar-footer{padding:14px 16px;text-align:left}.sidebar.collapsed:not(.peek-closed):hover .sidebar-footer-inner{flex-direction:row;align-items:center;gap:8px}.sidebar.collapsed:not(.peek-closed):hover .sidebar-admin-label,.sidebar.collapsed:not(.peek-closed):hover .sync-status-label{display:inline}}.tool-header{min-height:112px;padding:28px clamp(24px,4vw,58px);border-bottom-color:var(--border);background:color-mix(in srgb,var(--card-bg) 76%,transparent)}.tool-header-icon{width:42px;height:42px;display:grid;place-items:center;border:1px solid color-mix(in srgb,var(--accent) 36%,var(--border));border-radius:50% 44% 48% 42%;color:var(--accent);transform:rotate(-2deg)}.tool-header-text h2{font-family:Times New Roman,"Noto Serif SC",Songti SC,STSong,serif;font-size:clamp(24px,2.4vw,34px);font-weight:650;letter-spacing:-.035em}.tool-header-text p{margin-top:5px;font-size:13px}.card,.contract-total-card,.contract-period-card,.supply-card,.be-card{border:1px solid var(--border);box-shadow:var(--shadow);background:color-mix(in srgb,var(--card-bg) 94%,transparent)}.card-title,.ct-section-title,.section-title{font-family:Times New Roman,"Noto Serif SC",Songti SC,STSong,serif;font-weight:650;letter-spacing:.01em}.card-title:before{width:18px;height:2px;border-radius:2px;background:var(--accent)}.input-field,input[type=number],input[type=text],textarea,select{background-color:#fffdf8;border-color:var(--border);border-width:1px;border-radius:var(--radius-sm)}[data-theme=dark] .input-field,[data-theme=dark] input[type=number],[data-theme=dark] input[type=text],[data-theme=dark] textarea,[data-theme=dark] select{background-color:#34312c}.input-field:focus,input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.btn{border-radius:7px;font-weight:600;letter-spacing:.025em;box-shadow:none}.btn-primary{background:var(--accent)}.btn-secondary{color:var(--accent);border-color:var(--accent);background:transparent}.btn-ghost{background:transparent}.result-box{border-radius:9px;box-shadow:none;display:grid;grid-template-columns:minmax(0,1fr);align-items:stretch}.result-box>div:first-child{min-width:0;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.result-box .chinese-upper{min-width:0;word-break:normal;line-height:1.55}.result-box .result-value-actions{width:100%;min-width:0;justify-content:space-between}.result-value{font-family:Times New Roman,"Noto Serif SC",serif;font-weight:600;letter-spacing:-.035em}.contract-total-card .input-label,.contract-period-card .input-label{font-size:16px;font-weight:600}.contract-total-card .input-field{height:52px;padding-left:16px;padding-right:58px;font-size:20px;font-weight:600}.contract-total-card .input-suffix{font-size:15px;font-weight:600}.contract-total-card .tax-chip,.contract-total-card .custom-tax-input{font-size:15px!important;font-weight:600}.contract-total-card .custom-tax-wrap>span{font-size:14px}.contract-total-card .result-label{font-size:16px}.contract-total-card .result-value{font-size:clamp(32px,3vw,42px);line-height:1.08}.contract-total-card .chinese-upper,.contract-total-card .ct-base-upper,.contract-total-card .ct-tax-upper{font-size:14px!important;line-height:1.5}.contract-total-card .summary-label{font-size:15px}.contract-total-card .summary-value{display:block;margin-top:4px;font-family:Times New Roman,"Noto Serif SC",serif;font-size:21px;line-height:1.2}.contract-period-card .period-item>div:first-child>span:first-child{min-width:42px!important;font-size:16px!important}.contract-period-card .period-input{height:50px;padding-left:14px;font-size:20px;font-weight:600}.contract-period-card .period-pct-suffix{font-size:15px;font-weight:600}.contract-period-card .period-amount{min-width:126px!important;font-family:Times New Roman,"Noto Serif SC",serif;font-size:20px!important;line-height:1.15}.contract-period-card .period-upper{padding-left:50px!important;font-size:14px!important;line-height:1.45}.contract-period-card .ct-ratio-bar{font-size:16px}.be-tabs .be-tab-btn.active{background:var(--accent);color:#fff;box-shadow:0 5px 14px #8b432c2e;font-weight:700;transform:translateY(-1px)}.be-tabs .be-tab-btn:hover:not(.active){color:var(--accent);background:var(--accent-light)}.home-editorial{--home-ink: var(--text-primary);--home-blue: var(--accent);--home-line: var(--border);width:min(1180px,calc(100% - 80px));padding-top:26px}.home-editorial .editorial-hero{min-height:340px;grid-template-columns:1fr;place-items:center;padding-bottom:0;border-bottom:0;position:relative;overflow:hidden;text-align:center;background-image:linear-gradient(rgba(176,123,46,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(176,123,46,.045) 1px,transparent 1px);background-size:30px 30px;background-position:center}.editorial-hero:before,.editorial-hero:after{content:"";position:absolute;left:50%;top:53%;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none}.editorial-hero:before{width:380px;height:380px;border:1px solid rgba(176,123,46,.11)}.editorial-hero:after{display:none}.editorial-copy{padding:0;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}.editorial-copy h1{font-size:clamp(50px,6vw,92px);font-weight:600;letter-spacing:-.065em;white-space:nowrap;word-break:keep-all}.editorial-hero-mark{width:128px;height:128px;display:grid;place-items:center;color:#bd644e;background:transparent;transform:none;transition:transform .32s ease,color .32s ease}.editorial-hero-mark .brand-mark{width:112px;height:112px;transform-origin:50% 50%}.editorial-hero-mark:hover{color:#d35f43;transform:translateY(-4px) scale(1.04)}.editorial-hero-mark:hover .brand-mark{animation:editorial-brand-spin 1.8s linear infinite}@keyframes editorial-brand-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.editorial-hero-mark,.editorial-hero-mark .brand-mark{animation:none;transition:none}}.science-graphic{display:none}.home-search-stage{padding:18px 0 6px}.home-global-search{width:min(760px,calc(100% - 36px));min-height:76px;margin:0 auto;padding:10px 12px 10px 22px;display:grid;grid-template-columns:28px minmax(0,1fr) auto 52px;align-items:center;gap:12px;border:1px solid color-mix(in srgb,var(--accent) 38%,var(--border));border-radius:18px 16px 20px 15px;background:color-mix(in srgb,var(--card-bg) 94%,transparent);box-shadow:0 16px 46px #4b3a2717,0 2px 7px #4b3a270f;transition:border-color .18s,box-shadow .18s,transform .18s}.home-global-search:focus-within{border-color:var(--accent);box-shadow:0 18px 54px #6d422a21,0 0 0 4px var(--accent-light);transform:translateY(-1px)}.home-search-icon{display:grid;place-items:center;color:var(--accent)}.home-search-input{width:100%;min-width:0;height:52px;padding:0;border:0!important;outline:0;background:transparent!important;box-shadow:none!important;color:var(--text-primary);font-size:clamp(17px,2vw,22px)}.home-search-input::placeholder{color:var(--text-muted)}.home-search-shortcut{padding:5px 8px;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:11px;white-space:nowrap}.home-search-submit{width:48px;height:48px;display:grid;place-items:center;border:0;border-radius:14px 12px 15px 11px;background:var(--accent);color:#fff;font-size:24px;cursor:pointer;transition:background .18s,transform .18s}.home-search-submit:hover{background:var(--accent-hover);transform:translate(2px)}.home-search-hint{margin:9px auto 0;color:var(--text-muted);font-size:11px;text-align:center}.editorial-tools{padding-top:24px}.editorial-section-title{padding-bottom:11px}.editorial-footer{min-height:44px;justify-content:flex-end}.editorial-section-title h2{font-family:Times New Roman,"Noto Serif SC",Songti SC,STSong,serif;font-size:20px;letter-spacing:.08em}.editorial-tool-list{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;border:0}.editorial-tool:nth-child(odd),.editorial-tool:nth-last-child(-n+2){border:1px solid var(--border)}.editorial-tool:last-child{border:1px solid var(--border)}.editorial-tool{position:relative;min-height:106px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:14px 10px;border:1px solid var(--border);border-radius:12px 10px 13px 9px;background:color-mix(in srgb,var(--card-bg) 68%,transparent);transition:background .18s,border-color .18s,transform .18s}.editorial-tool:hover{padding-left:10px;background:#cf5c3f0e;border-color:color-mix(in srgb,var(--accent) 42%,var(--border));transform:translateY(-2px)}.editorial-number{position:absolute;top:8px;right:9px;font-size:12px}.editorial-icon{align-self:center;width:38px;height:38px}.editorial-tool-copy{align-self:center;padding:0;text-align:center}.editorial-tool-copy strong{font-size:13px;white-space:nowrap}.editorial-tool-copy small,.editorial-arrow{display:none}.editorial-tool:hover{background:#cf5c3f0e}.editorial-number{color:var(--accent);font-family:Times New Roman,serif}.editorial-icon{width:42px;height:42px;border:1px solid color-mix(in srgb,var(--accent) 28%,var(--border));border-radius:50% 43% 48% 40%;color:var(--text-primary);transform:rotate(-2deg)}.editorial-tool:nth-child(2) .editorial-number,.editorial-tool:nth-child(2) .editorial-icon{color:#6f8058}.editorial-tool:nth-child(3) .editorial-number,.editorial-tool:nth-child(3) .editorial-icon{color:#b07b2e}.editorial-tool:nth-child(4) .editorial-number,.editorial-tool:nth-child(4) .editorial-icon{color:#b65e43}.editorial-tool:nth-child(5) .editorial-number,.editorial-tool:nth-child(5) .editorial-icon{color:#66837f}.editorial-tool:nth-child(6) .editorial-number,.editorial-tool:nth-child(6) .editorial-icon{color:#8b6d8f}.editorial-tool-copy strong{font-family:Times New Roman,"Noto Serif SC",Songti SC,STSong,serif;font-size:13px;font-weight:650}.mobile-topbar{background:var(--sidebar-bg);color:var(--text-primary);border-bottom:1px solid var(--border)}.mobile-topbar-title{font-family:Times New Roman,"Noto Serif SC",Songti SC,STSong,serif}.mobile-topbar-title .brand-mark{color:var(--accent)}.mobile-topbar-btn,.mobile-topbar-ver{color:var(--text-secondary);background:transparent}.dock-nav{background:#fbf8f1eb;border-color:var(--border);border-radius:16px;box-shadow:0 8px 28px #4237291f}.dock-item.active{background:transparent}.dock-item.active .dock-icon{color:var(--module-color, var(--accent));background:var(--module-bg, var(--accent-light));border:1px solid color-mix(in srgb,var(--module-color, var(--accent)) 35%,var(--border));border-radius:10px 9px 12px 8px;box-shadow:none;transform:translateY(-1px) rotate(-2deg)}@media(max-width:720px){.home-editorial{width:calc(100% - 36px)}.home-editorial .editorial-hero{min-height:260px;padding:18px 0 0}.editorial-hero:before{width:310px;height:310px}.editorial-hero:after{width:210px;height:210px}.editorial-tool-list{grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:minmax(142px,44vw);gap:10px;overflow-x:auto;overscroll-behavior-inline:contain;scroll-snap-type:inline mandatory;padding-bottom:7px}.editorial-tool,.editorial-tool:nth-child(odd),.editorial-tool:nth-last-child(-n+2),.editorial-tool:last-child{min-height:104px;padding:14px 10px;border:1px solid var(--border)}.editorial-tool:hover{padding-left:10px}.editorial-tool{scroll-snap-align:start}.home-search-stage{padding-top:18px}.home-global-search{width:100%;min-height:66px;grid-template-columns:24px minmax(0,1fr) 44px;padding:8px 9px 8px 16px;border-radius:15px}.home-search-input{height:46px;font-size:16px}.home-search-shortcut{display:none}.home-search-submit{width:42px;height:42px;border-radius:12px}.editorial-copy h1{font-size:clamp(42px,12vw,64px)}.editorial-hero-mark{width:96px;height:96px}.editorial-hero-mark .brand-mark{width:82px;height:82px}.contract-total-card .input-field,.contract-period-card .period-input{font-size:18px}.contract-total-card .result-value{font-size:clamp(30px,9vw,38px)}.contract-period-card .period-amount{min-width:94px!important;font-size:18px!important}.science-graphic{margin-top:8px}.tool-header{min-height:98px;padding:20px 22px}}
