*{margin:0;padding:0;box-sizing:border-box}:root{--apple-blue: #007AFF;--apple-blue-hover: #0056D6;--apple-blue-active: #004BB5;--apple-blue-light: rgba(0, 122, 255, .08);--apple-blue-medium: rgba(0, 122, 255, .12);--success: #34C759;--success-hover: #2DB14E;--success-bg: rgba(52, 199, 89, .1);--success-text: #1B7A36;--warning: #FF9500;--warning-hover: #E08600;--warning-bg: rgba(255, 149, 0, .1);--warning-text: #9A6700;--danger: #FF3B30;--danger-hover: #E0352B;--danger-bg: rgba(255, 59, 48, .1);--danger-text: #C62828;--purple: #AF52DE;--purple-bg: rgba(175, 82, 222, .12);--text: #1D1D1F;--text-secondary: #86868B;--text-tertiary: #AEAEB2;--text-on-fill: #FFFFFF;--bg: #F2F2F7;--bg-secondary: #F9F9FB;--sidebar-bg: rgba(245, 245, 247, .92);--sidebar-border: rgba(0, 0, 0, .08);--card-bg: #FFFFFF;--border: #D2D2D7;--border-light: #E8E8ED;--border-separator: rgba(0, 0, 0, .06);--separator-heavy: #475569;--separator-medium: #94a3b8;--fill-primary: rgba(120, 120, 128, .2);--fill-secondary: rgba(120, 120, 128, .16);--fill-tertiary: rgba(118, 118, 128, .12);--fill-quaternary: rgba(116, 116, 128, .08);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 2px 8px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08), 0 1px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12), 0 2px 8px rgba(0, 0, 0, .06);--radius-xs: 6px;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--space-9: 48px;--font-caption: 11px;--font-small: 12px;--font-body-sm: 13px;--font-body: 14px;--font-subtitle: 15px;--font-section: 17px;--font-heading: 20px;--font-display: 24px;--header-height: 56px;--z-sticky: 10;--z-sidebar: 100;--z-sidebar-backdrop: 150;--z-sidebar-toggle: 200;--z-detail: 300;--z-detail-panel: 310;--z-dialog: 400;--z-toast: 500;--z-login: 600;--transition-fast: .15s ease;--transition: .2s ease;--transition-slow: .3s ease;--ease-spring: cubic-bezier(.32, .72, 0, 1);--ease-standard: cubic-bezier(.4, 0, .2, 1);--focus-ring: 0 0 0 3px rgba(0, 122, 255, .35);--focus-ring-danger: 0 0 0 3px rgba(255, 59, 48, .2);--focus-ring-warning: 0 0 0 3px rgba(255, 149, 0, .2)}html{scroll-behavior:auto}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:var(--font-body);line-height:1.5;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#app{display:flex;min-height:100vh}input,textarea,select,pre,code,.selectable{user-select:text;-webkit-user-select:text}img,svg{-webkit-user-drag:none;user-drag:none}::selection{background:#007aff33}input[type=checkbox],input[type=radio]{accent-color:var(--apple-blue);cursor:pointer}button,[role=button],label[for],.toggle-label,.switch,.toggle,select,summary{cursor:pointer}a{color:var(--apple-blue);text-decoration:none;transition:color var(--transition-fast);cursor:pointer}a:hover{color:var(--apple-blue-hover);text-decoration:underline}a:active{color:var(--apple-blue-active)}:focus-visible{outline:none;box-shadow:var(--focus-ring)}button:focus-visible,a:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:var(--radius-sm)}:disabled,[disabled]{opacity:.5;cursor:not-allowed!important;pointer-events:none}*{scrollbar-width:thin;scrollbar-color:var(--fill-tertiary) transparent}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--fill-tertiary);border-radius:var(--radius-pill)}*::-webkit-scrollbar-thumb:hover{background:var(--fill-secondary)}.hidden{display:none!important}.flex-center{display:flex;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-end{display:flex;justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.table-wrapper{overflow-x:auto}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-tertiary);font-size:var(--font-small)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mr-2{margin-right:var(--space-2)}.ml-auto{margin-left:auto}.th-checkbox{width:40px}.th-sm{width:72px}.th-md,.th-stepper{width:120px}.th-action{width:100px}.table-empty{text-align:center;color:var(--text-tertiary);padding:var(--space-8) var(--space-5);font-size:var(--font-body)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-secondary);padding:var(--space-9) var(--space-5)}.empty-state-icon{margin-bottom:var(--space-3);opacity:.4;font-size:48px}.empty-state-title{font-size:var(--font-subtitle);font-weight:500;margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--font-body);color:var(--text-tertiary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-12px) scale(.95)}}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.sidebar{width:260px;background:var(--sidebar-bg);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-right:1px solid var(--sidebar-border);position:fixed;height:100vh;display:flex;flex-direction:column;z-index:var(--z-sidebar);overflow:hidden}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5);height:var(--header-height);border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-logo{width:30px;height:30px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--apple-blue) 0%,#5856D6 100%);color:var(--text-on-fill);display:flex;align-items:center;justify-content:center;font-size:var(--font-body);font-weight:700;flex-shrink:0;box-shadow:0 2px 8px #007aff40}.sidebar-app-name{font-size:var(--font-body);font-weight:700;color:var(--text);letter-spacing:-.2px;line-height:1.3}.sidebar-app-sub{font-size:var(--font-small);color:var(--text-tertiary);font-weight:400;line-height:1.3}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-2) var(--space-3)}.nav-group-label{padding:var(--space-4) var(--space-3) var(--space-1);font-size:var(--font-caption);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;list-style:none}.nav-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:7px var(--space-3);border:none;background:none;border-radius:var(--radius-sm);font-size:var(--font-body-sm);font-weight:500;color:var(--text);cursor:pointer;transition:all var(--transition-fast);text-align:left;font-family:inherit;margin-bottom:1px;line-height:1.4}.nav-item:hover{background:var(--fill-quaternary)}.nav-item.active{background:var(--apple-blue);color:var(--text-on-fill)}.nav-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.nav-icon{width:20px;height:20px;flex-shrink:0;opacity:.6}.nav-item:hover .nav-icon{opacity:.8}.nav-item.active .nav-icon{opacity:1}.nav-divider{height:1px;background:var(--sidebar-border);margin:var(--space-2) var(--space-3);list-style:none}.sidebar-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--apple-blue) 0%,#5856D6 100%);color:var(--text-on-fill);display:flex;align-items:center;justify-content:center;font-size:var(--font-body-sm);font-weight:600;flex-shrink:0}.sidebar-user-detail{flex:1;min-width:0}.sidebar-user-name{font-size:var(--font-body-sm);font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sidebar-user-email{font-size:var(--font-small);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sidebar-logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);border:1px solid var(--border-light);border-radius:var(--radius-sm);background:none;font-size:var(--font-small);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:inherit}.sidebar-logout-btn svg{width:15px;height:15px}.sidebar-logout-btn:hover{background:var(--fill-quaternary);color:var(--text);border-color:var(--border)}.sidebar-logout-btn:active{transform:scale(.98)}.sidebar-toggle{display:none;position:fixed;top:var(--space-3);left:var(--space-3);z-index:var(--z-sidebar-toggle);width:40px;height:40px;border-radius:var(--radius-sm);border:none;background:var(--card-bg);box-shadow:var(--shadow);cursor:pointer;align-items:center;justify-content:center;color:var(--text);transition:all var(--transition)}.sidebar-toggle:active{transform:scale(.92)}.sidebar-toggle svg{width:20px;height:20px}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-sidebar-backdrop)}.content{flex:1;margin-left:260px;padding:var(--space-9) var(--space-9);background:var(--card-bg);min-height:100vh}.content h1{font-size:var(--font-display);font-weight:700;letter-spacing:-.3px;color:var(--text);margin-bottom:var(--space-2)}.page-desc{color:var(--text-secondary);margin-bottom:var(--space-7);font-size:var(--font-body);font-weight:400;line-height:1.5}.page-header{margin:calc(-1 * var(--space-9)) calc(-1 * var(--space-9)) var(--space-5);padding:0 var(--space-9);height:var(--header-height);border-bottom:1px solid var(--sidebar-border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:var(--z-sticky);background:var(--card-bg)}.page-breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-body-sm)}.page-breadcrumb-parent{color:var(--apple-blue)}.page-breadcrumb-sep{color:var(--text-tertiary)}.page-breadcrumb-current{color:var(--text);font-weight:500}.page{display:none}.page.active{display:block}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,#f5f5fa,#e5e5ea,#d8d8de);z-index:var(--z-login);display:flex;flex-direction:column;align-items:center;justify-content:center}.login-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.6);border-radius:20px;padding:var(--space-9) 56px;text-align:center;box-shadow:0 0 0 1px #0000000a,0 8px 40px #00000014,0 2px 8px #0000000a;min-width:400px;max-width:440px;animation:slideUp .4s var(--ease-spring)}.login-logo{width:56px;height:56px;margin:0 auto var(--space-5);border-radius:var(--radius);background:linear-gradient(135deg,var(--apple-blue) 0%,#5856D6 100%);color:var(--text-on-fill);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;box-shadow:0 4px 16px #007aff4d,0 1px 4px #007aff26}.login-title{font-size:26px;font-weight:700;color:var(--text);letter-spacing:-.5px;margin-bottom:var(--space-1)}.login-subtitle{font-size:var(--font-body-sm);color:var(--text-tertiary);font-weight:400;letter-spacing:.5px;margin-bottom:0}.login-divider{width:32px;height:1px;background:var(--border);margin:var(--space-6) auto}.login-desc{font-size:var(--font-body);color:var(--text-secondary);margin-bottom:var(--space-5)}.btn-google{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-5);height:48px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);font-size:var(--font-subtitle);font-weight:500;cursor:pointer;transition:all var(--transition);color:var(--text);font-family:inherit;box-shadow:var(--shadow-sm)}.btn-google-icon{width:20px;height:20px;flex-shrink:0}.btn-google:hover{box-shadow:var(--shadow);border-color:var(--text-tertiary);transform:translateY(-1px)}.btn-google:active{transform:translateY(0)}.btn-google:focus-visible{outline:none;box-shadow:var(--focus-ring)}.login-error{margin-top:var(--space-5);padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid rgba(255,59,48,.12);border-radius:var(--radius-sm);color:var(--danger);font-size:var(--font-body-sm);font-weight:500;text-align:left;line-height:1.5;display:flex;align-items:flex-start;gap:var(--space-2)}.login-error-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.login-footer{margin-top:var(--space-7);font-size:var(--font-small);color:var(--text-tertiary);letter-spacing:.3px;animation:fadeIn .6s ease .3s both}@media(max-width:1200px){.content{padding:var(--space-7) var(--space-7)}.page-header{margin:calc(-1 * var(--space-7)) calc(-1 * var(--space-7)) var(--space-4);padding:0 var(--space-7)}}@media(max-width:768px){.page-header{margin:0 0 var(--space-3);padding:0;height:auto;border-bottom:none}.sidebar-toggle{display:flex}.sidebar-backdrop.open{display:block}.sidebar{width:280px;transform:translate(-100%);transition:transform .3s var(--ease-spring);box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.content{margin-left:0;padding:64px var(--space-5) var(--space-6)}.login-card{min-width:0;margin:0 var(--space-4);padding:var(--space-7) var(--space-6)}.login-logo{width:48px;height:48px;font-size:20px}}.btn{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-sm);font-size:var(--font-body);cursor:pointer;transition:all var(--transition);font-weight:500;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);line-height:1.4;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.97)}.btn:focus-visible{box-shadow:var(--focus-ring)}.btn-primary{background:var(--apple-blue);color:var(--text-on-fill)}.btn-primary:hover{background:var(--apple-blue-hover)}.btn-primary:focus-visible{box-shadow:var(--focus-ring)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-body-sm);border-radius:var(--radius-xs)}.btn-danger{background:var(--danger);color:var(--text-on-fill)}.btn-danger:hover{background:var(--danger-hover)}.btn-danger:focus-visible{box-shadow:var(--focus-ring-danger)}.btn-warning{background:var(--warning);color:var(--text-on-fill)}.btn-warning:hover{background:var(--warning-hover)}.btn-warning:focus-visible{box-shadow:var(--focus-ring-warning)}.btn-outline{background:var(--card-bg);border:1px solid var(--border);color:var(--text)}.btn-outline:hover{background:var(--fill-quaternary);border-color:var(--text-tertiary)}.badge{display:inline-block;padding:2px var(--space-2);border-radius:var(--radius-pill);font-size:var(--font-caption);font-weight:600;background:var(--fill-tertiary);color:var(--text-secondary)}table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--font-body-sm)}th,td{padding:10px var(--space-3);text-align:left;border-bottom:1px solid var(--border-light)}td{font-variant-numeric:tabular-nums}th{background:var(--bg);font-weight:600;color:var(--text-secondary);font-size:var(--font-caption);text-transform:uppercase;letter-spacing:.3px;position:sticky;top:0;z-index:var(--z-sticky);white-space:nowrap}th:first-child{border-radius:var(--radius-xs) 0 0 0}th:last-child{border-radius:0 var(--radius-xs) 0 0}tbody tr{transition:background-color var(--transition-fast)}tbody tr:nth-child(2n){background:var(--bg-secondary)}tbody tr:hover{background:var(--fill-quaternary)}tr:last-child td{border-bottom:none}tr.zero-row{opacity:.35}tr.special-row{background:var(--warning-bg)}tr.special-row:hover{background:#ff950026}.items-section{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius);padding:var(--space-6);box-shadow:var(--shadow-sm)}.items-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.items-header h3{font-size:var(--font-subtitle);font-weight:600}.toggle-label{font-size:var(--font-body-sm);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:var(--space-1)}.switch{position:relative;display:inline-block;width:42px;height:24px}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--fill-tertiary);border-radius:var(--radius-pill);transition:.25s var(--ease-standard)}.switch .slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:var(--text-on-fill);border-radius:50%;transition:.25s var(--ease-standard);box-shadow:0 1px 3px #00000026,0 0 1px #0000000f}.switch input:checked+.slider{background:var(--success)}.switch input:checked+.slider:before{transform:translate(18px)}.switch:focus-within .slider{box-shadow:var(--focus-ring)}.switch input:disabled+.slider{opacity:.35;cursor:default}.toggle{position:relative;width:44px;height:26px;background:var(--fill-tertiary);border-radius:var(--radius-pill);cursor:pointer;transition:background .25s var(--ease-standard);flex-shrink:0}.toggle.active{background:var(--success)}.toggle-handle{position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--text-on-fill);border-radius:50%;box-shadow:0 1px 3px #00000026,0 0 1px #0000000f;transition:transform .25s var(--ease-standard)}.toggle.active .toggle-handle{transform:translate(18px)}.box-size-select{padding:var(--space-1) var(--space-2);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:var(--font-body-sm);background:var(--card-bg);font-family:inherit;cursor:pointer;transition:border-color var(--transition)}.box-size-select:focus{outline:none;border-color:var(--apple-blue);box-shadow:var(--focus-ring)}td.group-label{vertical-align:middle;text-align:center;border-right:1px solid var(--border-light);font-weight:600;color:var(--text-secondary)}.toast-container{position:fixed;top:var(--space-5);right:var(--space-5);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2)}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius);font-size:var(--font-body-sm);font-weight:500;box-shadow:var(--shadow-md);animation:toastIn .3s var(--ease-spring);max-width:360px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;gap:var(--space-2)}.toast-success{background:#34c759f2;color:var(--text-on-fill)}.toast-error{background:#ff3b30f2;color:var(--text-on-fill)}.toast.leaving{animation:toastOut .25s ease forwards}.dialog-overlay,.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:var(--z-dialog);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.dialog,.confirm-dialog{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-6);min-width:380px;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp .25s var(--ease-spring)}.dialog h3,.confirm-dialog h3{margin-bottom:var(--space-2);font-size:var(--font-section);font-weight:600}.dialog p,.confirm-dialog p{color:var(--text-secondary);font-size:var(--font-body);margin-bottom:var(--space-5);line-height:1.6}.dialog-actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.confirm-dialog--wide{min-width:440px;max-width:560px}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:var(--z-detail)}.detail-panel{position:fixed;right:0;top:0;height:100vh;width:440px;max-width:90vw;background:var(--card-bg);box-shadow:var(--shadow-lg);z-index:var(--z-detail-panel);display:flex;flex-direction:column}.detail-enter-active{transition:opacity .25s ease}.detail-enter-active .detail-panel{transition:transform .3s var(--ease-spring)}.detail-leave-active{transition:opacity .2s ease}.detail-leave-active .detail-panel{transition:transform .2s ease}.detail-enter-from,.detail-leave-to{opacity:0}.detail-enter-from .detail-panel,.detail-leave-to .detail-panel{transform:translate(100%)}.detail-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-light);flex-shrink:0}.detail-panel-title{font-size:var(--font-subtitle);font-weight:600}.detail-close-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--fill-quaternary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-subtitle);transition:all var(--transition)}.detail-close-btn:hover{background:var(--fill-tertiary);color:var(--text)}.detail-panel-body{padding:var(--space-5) var(--space-6);overflow-y:auto;flex:1;font-size:var(--font-body)}.detail-section{margin-bottom:var(--space-5)}.detail-section h4{font-size:var(--font-body-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.3px}.detail-formula{background:var(--fill-quaternary);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--font-small);line-height:1.6;color:var(--text-secondary);white-space:pre-wrap}.detail-breakdown-table,.detail-breakdown{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--font-body-sm)}.detail-breakdown-table th,.detail-breakdown th{font-size:var(--font-caption);font-weight:600;color:var(--text-tertiary);text-align:left;padding:var(--space-2) var(--space-3)}.detail-breakdown-table td,.detail-breakdown td{padding:var(--space-2) var(--space-3)}.detail-breakdown-table td:last-child,.detail-breakdown td:last-child{text-align:right;font-variant-numeric:tabular-nums}.detail-total-row td{font-weight:700;border-top:2px solid var(--border);background:var(--bg-secondary)}.detail-value{text-align:right;font-variant-numeric:tabular-nums}.detail-source{background:var(--fill-quaternary);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--font-small);line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;font-family:SF Mono,Menlo,Consolas,monospace}.detail-btn{background:none;border:none;cursor:pointer;color:var(--apple-blue);font-size:var(--font-body-sm);padding:2px var(--space-1);border-radius:var(--radius-xs);transition:all var(--transition);display:inline-flex;align-items:center}.detail-btn:hover{background:var(--apple-blue-light)}.info-card{background:var(--apple-blue-light);border:1px solid var(--apple-blue-medium);border-radius:var(--radius);padding:var(--space-4) var(--space-5);margin-bottom:var(--space-5);font-size:var(--font-body)}.info-card strong{display:block;margin-bottom:var(--space-1);color:var(--text)}.info-card p{color:var(--text-secondary);font-size:var(--font-body-sm)}.setting-card{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius);padding:var(--space-5) var(--space-6);margin-bottom:var(--space-5);box-shadow:var(--shadow-sm);position:relative}.setting-card-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.setting-card-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--apple-blue-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.setting-card-icon svg{width:22px;height:22px;color:var(--apple-blue)}.setting-card-title{font-size:var(--font-subtitle);font-weight:600;color:var(--text);margin-bottom:2px}.setting-card-desc{font-size:var(--font-body-sm);color:var(--text-secondary)}.setting-card-required{position:absolute;top:var(--space-5);right:var(--space-6);font-size:var(--font-small);font-weight:600;color:var(--danger)}.radio-group{display:flex;gap:var(--space-5)}.radio-styled{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-body-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:color var(--transition)}.radio-styled:hover{color:var(--text)}.radio-styled input{position:absolute;opacity:0;width:0;height:0}.radio-dot{position:relative;width:18px;height:18px;border:2px solid var(--border);border-radius:50%;flex-shrink:0;transition:all var(--transition)}.radio-dot:after{content:"";position:absolute;top:3px;left:3px;width:8px;height:8px;border-radius:50%;background:var(--apple-blue);transform:scale(0);transition:transform .2s var(--ease-spring)}.radio-styled.active .radio-dot{border-color:var(--apple-blue)}.radio-styled.active .radio-dot:after{transform:scale(1)}.radio-styled.active{color:var(--text);font-weight:600}.radio-styled:focus-within .radio-dot{box-shadow:var(--focus-ring)}.help-btn{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--text-tertiary);background:none;color:var(--text-tertiary);font-size:var(--font-small);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0;line-height:1;padding:0}.help-btn:hover{border-color:var(--apple-blue);color:var(--apple-blue);background:var(--apple-blue-light)}.code-chip{display:inline-block;padding:2px var(--space-2);background:var(--fill-quaternary);border-radius:var(--radius-xs);font-size:var(--font-small);font-family:SF Mono,ui-monospace,monospace;letter-spacing:.3px;color:var(--text-secondary)}.section-divider{height:1px;background:var(--border-light);margin:var(--space-6) 0}.action-btn{background:none;border:none;cursor:pointer;font-size:var(--font-body);padding:var(--space-1) var(--space-2);border-radius:var(--radius-xs);transition:all var(--transition);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center}.action-btn:hover{background:var(--fill-tertiary);color:var(--text)}.role-badge{display:inline-block;padding:3px var(--space-2);border-radius:var(--radius-pill);font-size:var(--font-small);font-weight:500}.role-badge.admin{background:var(--purple-bg);color:var(--purple)}.status-badge{display:inline-block;padding:3px var(--space-2);border-radius:var(--radius-pill);font-size:var(--font-small);font-weight:500}.status-badge.enabled{background:var(--success-bg);color:var(--success-text)}.status-badge.disabled{background:var(--danger-bg);color:var(--danger)}.perm-chip{display:inline-block;padding:2px var(--space-2);border-radius:var(--radius-pill);font-size:var(--font-caption);font-weight:500;background:#007aff1a;color:var(--apple-blue);margin:1px 2px}.platform-chips{display:flex;flex-wrap:wrap;gap:var(--space-1)}.platform-chip{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--apple-blue-light);color:var(--apple-blue);border-radius:var(--radius-pill);font-size:var(--font-small);font-weight:500}.form-container{max-width:560px}.form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-5)}.wizard-vendor-tag{padding:2px var(--space-3);background:var(--fill-quaternary);color:var(--text-secondary);border-radius:var(--radius-pill);font-size:var(--font-small);font-weight:500}.wizard-stepper,.wizard-step{display:flex;align-items:center}.wizard-step-line-left,.wizard-step-line-right{width:12px;height:1.5px;background:var(--border);transition:background var(--transition)}.wizard-step:first-child .wizard-step-line-left,.wizard-step:last-child .wizard-step-line-right{display:none}.wizard-step.is-completed .wizard-step-line-left,.wizard-step.is-completed .wizard-step-line-right,.wizard-step.is-active .wizard-step-line-left{background:var(--apple-blue)}.wizard-step-circle{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-caption);font-weight:600;flex-shrink:0;transition:all var(--transition);cursor:default}.wizard-step.is-completed .wizard-step-circle{background:var(--apple-blue);color:var(--text-on-fill)}.wizard-step.is-active .wizard-step-circle{background:var(--apple-blue);color:var(--text-on-fill);box-shadow:0 0 0 3px #007aff26}.wizard-step.is-pending .wizard-step-circle{background:transparent;border:1.5px solid var(--border);color:var(--text-tertiary)}.wizard-check-icon{width:11px;height:11px}.wizard-body>*{animation:stepIn .25s ease}@keyframes stepIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.step-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);margin-top:var(--space-7);padding-top:var(--space-5);border-top:1px solid var(--border-light)}.vendor-section-desc{font-size:var(--font-body-sm);color:var(--text-secondary);margin-bottom:var(--space-5)}.vendor-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,240px));gap:var(--space-4);margin-bottom:var(--space-6)}.vendor-card{background:var(--card-bg);border:1.5px solid var(--border-light);border-radius:var(--radius);padding:var(--space-6) var(--space-5) var(--space-5);text-align:center;cursor:pointer;transition:all var(--transition);position:relative}.vendor-card:hover{border-color:var(--apple-blue);box-shadow:var(--shadow),0 0 0 1px #007aff1a;transform:translateY(-2px)}.vendor-card:active{transform:translateY(0);transition-duration:80ms}.vendor-card.selected{border-color:var(--apple-blue);background:var(--apple-blue-light);box-shadow:0 0 0 3px #007aff26}.vendor-avatar{width:48px;height:48px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--apple-blue) 0%,#5856D6 100%);display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-3);box-shadow:0 2px 8px #007aff33;transition:all var(--transition)}.vendor-card:hover .vendor-avatar{box-shadow:0 4px 12px #007aff4d;transform:scale(1.05)}.vendor-avatar-letter{font-size:var(--font-section);font-weight:700;color:var(--text-on-fill);line-height:1}.vendor-card-name{font-size:var(--font-body);font-weight:600;color:var(--text);margin-bottom:2px}.vendor-card-prefix{font-size:var(--font-small);color:var(--text-tertiary);font-weight:500;font-family:SF Mono,ui-monospace,monospace;letter-spacing:.5px}.vendor-card.selected .vendor-avatar{box-shadow:0 4px 16px #007aff59}.vendor-card.selected .vendor-card-name{color:var(--apple-blue-hover)}.vendor-dev-section{margin-top:var(--space-4)}.vendor-dev-divider{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.vendor-dev-divider:before,.vendor-dev-divider:after{content:"";flex:1;height:1px;background:var(--border-light)}.vendor-dev-divider span{font-size:var(--font-caption);color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.vendor-dev-actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.vendor-dev-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px dashed var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);font-size:var(--font-small);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:inherit}.vendor-dev-btn:hover{border-color:var(--apple-blue);border-style:solid;color:var(--apple-blue);background:var(--apple-blue-light)}.vendor-dev-btn:disabled{opacity:.5;cursor:not-allowed}.vendor-dev-btn svg{opacity:.6}.upload-progress{margin-bottom:var(--space-5)}.upload-progress-text{display:flex;align-items:baseline;gap:2px;font-size:var(--font-body-sm);color:var(--text-secondary);margin-bottom:var(--space-2)}.upload-progress-count{font-size:var(--font-subtitle);font-weight:700;color:var(--apple-blue);font-variant-numeric:tabular-nums}.upload-progress-sep{color:var(--text-tertiary);margin:0 1px}.upload-progress-bar{height:4px;background:var(--fill-quaternary);border-radius:var(--radius-pill);overflow:hidden}.upload-progress-fill{height:100%;background:var(--apple-blue);border-radius:var(--radius-pill);transition:width .4s var(--ease-spring)}.upload-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.upload-card{position:relative;border-radius:var(--radius);transition:transform var(--transition),box-shadow var(--transition);min-width:0}.upload-card:hover{transform:translateY(-2px)}.upload-card:active{transform:translateY(0);transition-duration:80ms}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:var(--space-6) var(--space-4);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--card-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:160px}.upload-card:not(.upload-done):not(.upload-loading):hover .upload-area,.upload-card.dragover .upload-area{border-color:var(--apple-blue);background:var(--apple-blue-light);box-shadow:0 0 0 3px #007aff14}.upload-card:not(.upload-done):not(.upload-loading):hover .upload-icon svg,.upload-card.dragover .upload-icon svg{color:var(--apple-blue);transform:translateY(-2px)}.upload-icon{margin-bottom:var(--space-3);display:flex;align-items:center;justify-content:center}.upload-icon svg{width:32px;height:32px;color:var(--text-tertiary);stroke-width:1.5;transition:all var(--transition)}.upload-label{font-size:var(--font-body-sm);font-weight:600;color:var(--text);line-height:1.3}.upload-desc{font-size:var(--font-small);color:var(--text-secondary);margin-top:var(--space-1)}.upload-hint{font-size:var(--font-caption);color:var(--text-tertiary);margin-top:var(--space-2);font-family:SF Mono,ui-monospace,monospace;letter-spacing:.3px}.upload-card.upload-loading{pointer-events:none}.upload-card.upload-loading .upload-area{border-color:var(--apple-blue);border-style:solid;background:var(--apple-blue-light)}.upload-state-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.upload-spinner{display:inline-block;width:28px;height:28px;border:2.5px solid rgba(0,122,255,.15);border-top-color:var(--apple-blue);border-radius:50%;animation:spin .8s linear infinite}.upload-loading-label{font-size:var(--font-body-sm);color:var(--apple-blue);font-weight:500}.upload-done .upload-area{border-color:var(--success);border-style:solid;background:var(--success-bg);cursor:default;position:relative}.upload-done:hover{transform:none}.upload-state-done{display:flex;align-items:center;gap:var(--space-3);width:100%}.upload-done-icon{width:32px;height:32px;border-radius:50%;background:var(--success);display:flex;align-items:center;justify-content:center;flex-shrink:0}.upload-done-icon svg{width:18px;height:18px;color:var(--text-on-fill);stroke-width:2.5}.upload-done-info{text-align:left;min-width:0}.upload-file-row{display:flex;align-items:baseline;gap:var(--space-2);margin-top:2px;min-width:0}.upload-filename{font-size:var(--font-small);color:var(--success-text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.upload-filesize{font-size:var(--font-small);color:var(--text-tertiary);font-weight:400;flex-shrink:0}.upload-reupload{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#ffffffe0;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);font-size:var(--font-small);font-weight:600;color:var(--apple-blue);cursor:pointer;opacity:0;pointer-events:none;transition:opacity var(--transition);font-family:inherit}.upload-reupload svg{width:20px;height:20px}.upload-done:hover .upload-area{border-color:var(--apple-blue)}.upload-done:hover .upload-reupload{opacity:1;pointer-events:auto}.price-config{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius);padding:var(--space-6);margin-bottom:var(--space-6);box-shadow:var(--shadow-sm)}.price-config h3{margin-bottom:var(--space-4);font-size:var(--font-subtitle);font-weight:600}.price-grid{display:flex;gap:var(--space-9);flex-wrap:wrap}.price-group h4{margin-bottom:var(--space-3);font-size:var(--font-body-sm);color:var(--text-secondary);font-weight:600}.price-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.price-row label{width:34px;font-weight:600;font-size:var(--font-body-sm);color:var(--text)}.price-row span{font-size:var(--font-small);color:var(--text-tertiary)}.stepper{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--card-bg);transition:border-color var(--transition)}.stepper:focus-within{border-color:var(--apple-blue);box-shadow:var(--focus-ring)}.stepper-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:var(--fill-quaternary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;padding:0}.stepper-btn:hover{background:var(--fill-tertiary);color:var(--text)}.stepper-btn:active{background:var(--fill-secondary)}.stepper-btn svg{width:14px;height:14px}.stepper-input{width:56px;height:28px;border:none;border-left:1px solid var(--border-light);border-right:1px solid var(--border-light);text-align:center;font-size:var(--font-body-sm);font-family:inherit;font-variant-numeric:tabular-nums;background:var(--card-bg);color:var(--text);outline:none;padding:0 var(--space-1)}.stepper-sm .stepper-btn{width:24px;height:24px}.stepper-sm .stepper-btn svg{width:12px;height:12px}.stepper-sm .stepper-input{width:48px;height:24px;font-size:var(--font-small)}.chip-toggle{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-pill);font-size:var(--font-small);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.chip-toggle:hover{border-color:var(--text-tertiary);color:var(--text)}.chip-toggle-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all var(--transition)}.chip-toggle.active{border-color:var(--apple-blue);color:var(--apple-blue);background:var(--apple-blue-light)}.chip-toggle.active .chip-toggle-dot{background:var(--apple-blue)}.result-tabs{display:flex;gap:0;background:var(--fill-tertiary);border-radius:var(--radius) var(--radius) 0 0;padding:var(--space-1)}.tab-btn{padding:var(--space-2) var(--space-4);border:none;background:transparent;font-size:var(--font-body-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);display:flex;align-items:center;gap:var(--space-2);flex:1;justify-content:center;font-family:inherit}.tab-btn:hover{color:var(--text)}.tab-btn.active{background:var(--card-bg);color:var(--text);font-weight:600;box-shadow:var(--shadow-sm)}.tab-subtotal{font-size:var(--font-caption);font-weight:600;color:var(--text-tertiary);background:var(--fill-tertiary);padding:1px var(--space-2);border-radius:var(--radius-pill)}.tab-btn.active .tab-subtotal{background:var(--apple-blue-light);color:var(--apple-blue)}.tab-panel{display:none}.tab-panel.active{display:block}.result-preview{background:var(--card-bg);border:1px solid var(--border-light);border-radius:0 0 var(--radius) var(--radius);padding:var(--space-5);overflow-x:auto;box-shadow:var(--shadow-sm)}.result-preview h3{margin-bottom:var(--space-3);font-size:var(--font-subtitle);font-weight:600;color:var(--text)}.total-row td{background:var(--bg);border-top:2px solid var(--text);font-weight:600}.section-header td{background:var(--bg);font-weight:700;font-size:var(--font-body);padding-top:var(--space-4)}.grand-total-section{background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius);margin-top:var(--space-4);box-shadow:var(--shadow-sm)}.grand-total-row td{padding:var(--space-5) var(--space-6);font-size:var(--font-heading);border:none;font-weight:700;letter-spacing:-.3px;font-variant-numeric:tabular-nums}.grand-total-row td:last-child{text-align:right}.scan-warnings{background:var(--warning-bg);border:1px solid rgba(255,149,0,.25);border-radius:var(--radius);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-5)}.scan-warnings h4{color:var(--warning-text);margin-bottom:var(--space-2);font-size:var(--font-body);font-weight:600}.scan-warnings ul{list-style:none;padding:0}.scan-warnings li{color:var(--warning-text);font-size:var(--font-body-sm);padding:2px 0}.warning-icon{vertical-align:-2px;margin-right:var(--space-1)}.shipping-table tr.row-zero td{color:var(--border)}.shipping-table tr.region-main td.group-label{background:#007aff0d}.shipping-table tr.region-island td.group-label{background:#ff95000f}.shipping-table tr.group-sep-carrier>td{border-top:3px solid var(--separator-heavy)}.shipping-table tr.group-sep-region>td{border-top:2px solid var(--separator-medium)}tr.platform-row-selected td{background:var(--success-bg)}tr.platform-row-selected:hover td{background:#34c75926}.platform-toolbar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.platform-toolbar .form-input{flex:1;max-width:280px}.platform-total{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-light);text-align:right;font-size:var(--font-subtitle);font-weight:600}.platform-total-value{color:var(--apple-blue);font-variant-numeric:tabular-nums}.required-hint{color:var(--danger);font-size:var(--font-body-sm);font-weight:600}.pe-adj-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--fill-tertiary);border:none;border-radius:var(--radius-xs);color:var(--text-secondary);font-size:var(--font-body);font-weight:700;line-height:1;cursor:pointer;margin-left:3px;vertical-align:middle;transition:all var(--transition)}.pe-adj-btn:hover{background:var(--apple-blue);color:var(--text-on-fill)}.pe-adj-btn:active{transform:scale(.9)}tr.manual-row td:last-child{color:var(--danger);font-weight:600}.detail-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:none;border:1.5px solid var(--text-tertiary);border-radius:50%;color:var(--text-secondary);font-size:var(--font-caption);font-weight:700;line-height:1;cursor:pointer;margin-left:var(--space-1);vertical-align:middle;flex-shrink:0;transition:all var(--transition)}.detail-btn:hover{background:var(--apple-blue);border-color:var(--apple-blue);color:var(--text-on-fill)}@media(max-width:1100px){.upload-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.wizard-stepper{display:none}.upload-grid{grid-template-columns:1fr}.price-grid{gap:var(--space-6)}.vendor-list{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}}.manage-toolbar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5)}.inline-form{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--apple-blue-light);border:1px solid var(--apple-blue-medium);border-radius:var(--radius);margin-bottom:var(--space-5);flex-wrap:wrap}.form-input{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:var(--font-body-sm);font-family:inherit;background:var(--card-bg);transition:border-color var(--transition)}.form-input:focus{outline:none;border-color:var(--apple-blue);box-shadow:var(--focus-ring)}.form-input-full{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:var(--font-body);font-family:inherit;background:var(--card-bg);transition:border-color var(--transition)}.form-input-full:focus{outline:none;border-color:var(--apple-blue);box-shadow:var(--focus-ring)}.form-input--wide{width:280px}.form-input--search{width:240px}.form-input--has-toggle{padding-right:var(--space-8)}.form-error{color:var(--danger);font-size:var(--font-small);font-weight:500}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-body-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-1)}.form-msg{margin-top:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);font-size:var(--font-body-sm);font-weight:500}.form-msg.success{background:var(--success-bg);color:var(--success-text);border:1px solid rgba(52,199,89,.2)}.form-msg.error{background:var(--danger-bg);color:var(--danger-text);border:1px solid rgba(255,59,48,.2)}.password-wrap{position:relative}.eye-toggle{position:absolute;right:var(--space-2);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:var(--space-1);color:var(--text-tertiary);transition:color var(--transition);display:flex;align-items:center;justify-content:center}.eye-toggle:hover{color:var(--text-secondary)}.eye-toggle svg{width:18px;height:18px}.inline-edit-input{padding:var(--space-1) var(--space-2);border:1px solid var(--apple-blue);border-radius:var(--radius-xs);font-size:var(--font-body-sm);font-family:inherit;width:200px;box-shadow:var(--focus-ring)}.sub-tabs{display:flex;gap:0;background:var(--fill-tertiary);border-radius:var(--radius-sm);padding:3px;margin-bottom:var(--space-5);width:fit-content}.sub-tab-btn{padding:var(--space-1) var(--space-4);border:none;background:transparent;font-size:var(--font-body-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-xs);transition:all var(--transition);font-family:inherit}.sub-tab-btn:hover{color:var(--text)}.sub-tab-btn.active{background:var(--card-bg);color:var(--text);font-weight:600;box-shadow:var(--shadow-sm)}.sub-tab-panel{display:none}.sub-tab-panel.active{display:block}.price-compare-table th,.price-compare-table td{text-align:center}.price-compare-table th:first-child,.price-compare-table td:first-child{text-align:left}.price-zone-header td{background:var(--bg);font-weight:700;font-size:var(--font-body-sm);padding-top:var(--space-3)}.vendor-block{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius);padding:var(--space-5);margin-bottom:var(--space-3);box-shadow:var(--shadow-sm)}.vendor-block h3{font-size:var(--font-body);font-weight:600;margin-bottom:var(--space-2)}.vendor-block .prefix{color:var(--text-tertiary);font-size:var(--font-small);margin-left:var(--space-2);font-weight:400}.perm-wildcard-label{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--fill-quaternary);border-radius:var(--radius-sm)}.perm-group{margin-bottom:var(--space-3)}.perm-group-title{font-weight:600;font-size:var(--font-body-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.perm-item-label{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);cursor:pointer}.perm-item-label:hover{background:var(--fill-quaternary)}.form-hint{margin-top:var(--space-1);font-size:var(--font-caption);color:var(--text-tertiary)}.vendor-edit-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:var(--z-detail)}.vendor-edit-panel{position:fixed;right:0;top:0;height:100vh;width:400px;max-width:90vw;background:var(--card-bg);box-shadow:var(--shadow-lg);z-index:var(--z-detail-panel);display:flex;flex-direction:column}.vendor-edit-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-light);flex-shrink:0}.vendor-edit-title{font-size:var(--font-subtitle);font-weight:600}.vendor-edit-body{padding:var(--space-6);flex:1;overflow-y:auto}.vendor-edit-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.vendor-edit-meta{font-size:var(--font-small);color:var(--text-tertiary)}tbody tr.vendor-row-active,tbody tr.vendor-row-active:hover{background:var(--apple-blue-light)}.vendor-edit-enter-active{transition:opacity .25s ease}.vendor-edit-enter-active .vendor-edit-panel{transition:transform .3s var(--ease-spring)}.vendor-edit-leave-active{transition:opacity .2s ease}.vendor-edit-leave-active .vendor-edit-panel{transition:transform .2s ease}.vendor-edit-enter-from,.vendor-edit-leave-to{opacity:0}.vendor-edit-enter-from .vendor-edit-panel,.vendor-edit-leave-to .vendor-edit-panel{transform:translate(100%)}.api-card+.api-card{margin-top:var(--space-5)}.api-card-header{margin-bottom:var(--space-5)}.api-card-name{font-size:var(--font-section);font-weight:600;color:var(--text);margin-bottom:var(--space-1)}.api-card-meta{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.api-card-desc{font-size:var(--font-body-sm);color:var(--text-secondary)}.api-card-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:var(--apple-blue-light);color:var(--apple-blue);border-radius:var(--radius-pill);font-size:var(--font-small);font-weight:500}.api-env-section{margin-bottom:var(--space-4)}.api-env-group-label{font-size:var(--font-body-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.api-env-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-xs);font-size:var(--font-body-sm)}.api-env-row:nth-child(2n){background:var(--fill-quaternary)}.api-env-name{font-family:SF Mono,SFMono-Regular,Menlo,monospace;font-size:var(--font-small);color:var(--text-secondary);min-width:200px;flex-shrink:0}.api-env-value{color:var(--text);word-break:break-all}.api-env-set{color:var(--success-text);font-weight:500}.api-env-missing{color:var(--danger);font-weight:500}.api-auth-status{padding:2px var(--space-2);border-radius:var(--radius-pill);font-size:var(--font-small);font-weight:500}.api-auth-status.configured{background:var(--success-bg);color:var(--success-text)}.api-auth-status.missing{background:var(--danger-bg);color:var(--danger)}.api-card-actions{margin-top:var(--space-4)}.api-hint{margin-top:var(--space-5);font-size:var(--font-body-sm);color:var(--text-tertiary)}.api-hint code{font-family:SF Mono,SFMono-Regular,Menlo,monospace;font-size:var(--font-small);background:var(--fill-quaternary);padding:2px var(--space-1);border-radius:4px}@media(max-width:768px){.inline-form{flex-direction:column;align-items:stretch}.manage-toolbar{flex-wrap:wrap}.sub-tabs{width:100%;overflow-x:auto}}.tool-container{max-width:640px;margin:0 auto}.tool-container h2{font-size:var(--font-subtitle);font-weight:600;color:var(--text);margin-bottom:var(--space-6)}.tool-step-indicator{display:flex;justify-content:center;gap:var(--space-8);margin-bottom:var(--space-8)}.tool-step-dot{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.tool-step-dot .dot-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-body-sm);font-weight:600;background:var(--border);color:var(--text-tertiary);transition:all var(--transition)}.tool-step-dot.active .dot-num{background:var(--apple-blue);color:var(--text-on-fill);box-shadow:0 0 0 4px var(--apple-blue-medium)}.tool-step-dot.done .dot-num{background:var(--success);color:var(--text-on-fill)}.tool-step-dot .dot-label{font-size:var(--font-caption);color:var(--text-tertiary)}.tool-step-dot.active .dot-label{color:var(--apple-blue);font-weight:500}.tool-step-section{animation:fadeIn .3s ease}.tool-step-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-8);padding-top:var(--space-5);border-top:1px solid var(--border-light)}.tool-field-label{display:block;font-size:var(--font-body-sm);font-weight:500;color:var(--text);margin-bottom:var(--space-1);margin-top:var(--space-5)}.tool-field-label.disabled{color:var(--text-tertiary)}.tool-form-input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-body);border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text);transition:border-color var(--transition);box-sizing:border-box;font-family:inherit}.tool-form-input:focus{outline:none;border-color:var(--apple-blue);box-shadow:var(--focus-ring)}.tool-form-input:disabled{opacity:.5;cursor:not-allowed}.searchable-select{position:relative}.searchable-select.disabled{opacity:.5;pointer-events:none}.searchable-select .search-input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-body);border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text);transition:border-color var(--transition);box-sizing:border-box;font-family:inherit}.searchable-select .search-input:focus{outline:none;border-color:var(--apple-blue);box-shadow:var(--focus-ring)}.searchable-select.open .search-input{border-bottom-left-radius:0;border-bottom-right-radius:0;border-color:var(--apple-blue)}.select-dropdown{position:absolute;top:100%;left:0;right:0;max-height:240px;overflow-y:auto;background:var(--card-bg);border:2px solid var(--apple-blue);border-top:none;border-bottom-left-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm);z-index:var(--z-dropdown, 100);box-shadow:var(--shadow-md)}.select-option{padding:var(--space-2) var(--space-3);font-size:var(--font-body-sm);cursor:pointer;transition:background var(--transition)}.select-option:hover{background:var(--apple-blue-light)}.select-empty{padding:var(--space-2) var(--space-3);font-size:var(--font-body-sm);color:var(--text-tertiary);text-align:center}.selected-tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);margin-top:var(--space-2);background:var(--apple-blue);color:var(--text-on-fill);border-radius:var(--radius-pill);font-size:var(--font-body-sm)}.tag-remove{cursor:pointer;font-size:var(--font-subtitle);line-height:1;opacity:.7;transition:opacity var(--transition);background:none;border:none;color:inherit;padding:0}.tag-remove:hover{opacity:1}.tool-loading-box{text-align:center;padding:var(--space-8) 0;color:var(--text-tertiary)}.tool-error-box{text-align:center;padding:var(--space-8) 0;color:var(--danger)}.tool-error-box .btn{margin-top:var(--space-3)}.tool-summary-card{background:var(--card-bg);border:1px solid var(--border-light);border-radius:var(--radius);padding:var(--space-5);margin-bottom:var(--space-5)}.tool-summary-row{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-2) 0;font-size:var(--font-body-sm);border-bottom:1px solid var(--border-light)}.tool-summary-row:last-child{border-bottom:none}.tool-summary-label{color:var(--text-tertiary);flex-shrink:0;margin-right:var(--space-3)}.tool-done-section{text-align:center;margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border-light)}.tool-done-msg{font-size:var(--font-body);font-weight:500;color:var(--success);margin-bottom:var(--space-3)}@media(max-width:768px){.tool-step-indicator{gap:var(--space-5)}.tool-step-dot .dot-label{font-size:10px}.tool-step-actions{flex-direction:column-reverse}.tool-step-actions .btn{width:100%}}
