@import"https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=DM+Sans:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500;700&display=swap";@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css";:root{--navy-900: #081B33;--navy-800: #0F2847;--navy-700: #163560;--navy-600: #1E4579;--navy-500: #2A5A9A;--ice-100: #EDF2F9;--ice-200: #D4E0F0;--ice-300: #A8BFE0;--ice-400: #7A9ED0;--accent-600: #2563EB;--accent-500: #3B82F6;--accent-400: #60A5FA;--neutral-50: #FAFBFC;--neutral-100: #F1F3F5;--neutral-200: #E2E5E9;--neutral-300: #C8CDD3;--neutral-400: #9BA3AE;--neutral-500: #6B7583;--neutral-600: #4A5362;--neutral-700: #343B47;--neutral-800: #1F242D;--neutral-900: #111419;--success: #10B981;--warning: #F59E0B;--error: #EF4444;--info: #3B82F6;--success-strong: #047857;--warning-strong: #b45309;--error-strong: #DC2626;--info-strong: #1D4ED8;--success-surface: rgba(16,185,129,.08);--warning-surface: rgba(245,158,11,.1);--error-surface: rgba(239,68,68,.08);--info-surface: rgba(59,130,246,.08);--glass-bg: rgba(255,255,255,.85);--glass-bg-dark: rgba(17,20,25,.75);--c-qr-bg: #ffffff;--c-qr-fg: #000000;--font-display: "Sora", sans-serif;--font-body: "DM Sans", sans-serif;--font-ko: "Pretendard Variable", "Pretendard", sans-serif;--font-jp: "Zen Kaku Gothic New", sans-serif;--font-mono: ui-monospace, "SF Mono", "Fira Code", "JetBrains Mono", Consolas, monospace;--font-display-en: "Sora", sans-serif;--font-display-ko: "Sora", "Pretendard Variable", sans-serif;--font-display-jp: "Sora", "Zen Kaku Gothic New", sans-serif;--font-body-en: "DM Sans", sans-serif;--font-body-ko: "Pretendard Variable", "DM Sans", sans-serif;--font-body-jp: "Zen Kaku Gothic New", "DM Sans", sans-serif;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--space-32: 128px;--grid-card-sm: 80px;--grid-card-md: 160px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(15,40,71,.04);--shadow-sm: 0 2px 4px rgba(15,40,71,.05), 0 1px 2px rgba(15,40,71,.04);--shadow-md: 0 4px 12px rgba(15,40,71,.06), 0 2px 4px rgba(15,40,71,.04);--shadow-lg: 0 12px 32px rgba(15,40,71,.08), 0 4px 8px rgba(15,40,71,.04);--shadow-xl: 0 24px 48px rgba(15,40,71,.1), 0 8px 16px rgba(15,40,71,.06);--shadow-pill-active: 0 4px 12px rgba(15,40,71,.18);--focus-ring: 0 0 0 3px rgba(59,130,246,.35);--ease-standard: cubic-bezier(.2, 0, 0, 1);--ease-emphasis: cubic-bezier(.3, 0, 0, 1);--duration-fast: .12s;--duration-base: .2s;--duration-slow: .32s;--width-prose: 640px;--width-content: 960px;--width-app: 1200px;--width-wide: 1440px;--bp-sm: 640px;--bp-md: 768px;--bp-lg: 1024px;--bp-xl: 1280px;--fs-xs: 12px;--fs-sm: 14px;--fs-base: 16px;--fs-md: 17px;--fs-lg: 20px;--fs-xl: 24px;--fs-2xl: 28px;--fs-3xl: 34px;--c-bg: var(--neutral-50);--c-surface: #ffffff;--c-surface-2: var(--ice-100);--c-fg: var(--neutral-800);--c-muted: var(--neutral-500);--c-border: var(--neutral-200);--c-border-strong: var(--neutral-300);--c-primary: var(--navy-800);--c-primary-fg: #ffffff;--c-accent: var(--accent-600);--c-danger: var(--error);--c-danger-fg: #ffffff;--c-success: var(--success);--c-success-fg: #047857;--c-warning: var(--warning);--c-warning-fg: #b45309;--c-warning-bg: var(--warning-surface);--c-info: var(--info);--c-info-bg: var(--info-surface);--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--touch-min: 44px;--touch-comfy: 48px;--header-h: 56px;--header-h-desktop: 64px;--gutter: 20px;--gutter-desktop: 32px;--b500: var(--navy-500);--b600: var(--navy-600);--b700: var(--navy-800);--b800: var(--navy-900);--g100: var(--neutral-100);--g200: var(--neutral-200);--g300: var(--neutral-300);--g400: var(--neutral-400);--g500: var(--neutral-500);--g600: var(--neutral-600);--g700: var(--neutral-700);--g800: var(--neutral-800);--blu: var(--accent-600);--blu1: var(--info-surface);--red: var(--error);--red1: var(--error-surface);--grn: var(--success);--grn1: var(--success-surface);--org: var(--warning);--org1: var(--warning-surface);--pur: #8b5cf6;--pur1: rgba(139, 92, 246, .1);--surface: var(--neutral-50);--surface-elevated: #ffffff;--overlay-backdrop: rgba(8, 27, 51, .45);--overlay-dark: rgba(8, 27, 51, .65);--r: var(--radius-lg);--shl: var(--shadow-lg);--c-eaten: var(--success);--c-eaten-bg: var(--success-surface);--c-eaten-fg: var(--success-strong);--c-not-eaten: var(--error);--c-not-eaten-bg: var(--error-surface);--c-not-eaten-fg: var(--c-fg);--c-cat-empty-bg: var(--c-surface);--c-cat-empty-fg: var(--c-muted);--c-cat-empty-bd: var(--c-border);--c-cat-none-bg: var(--error-surface);--c-cat-none-fg: var(--error-strong);--c-cat-none-bd: var(--error);--c-cat-partial-bg: var(--warning-surface);--c-cat-partial-fg: var(--warning-strong);--c-cat-partial-bd: var(--warning);--c-cat-all-bg: var(--success-surface);--c-cat-all-fg: var(--success-strong);--c-cat-all-bd: var(--success);--color-group-blue: #2563EB;--color-group-blue-bg: var(--ice-200);--color-group-blue-fg: var(--navy-700);--color-group-purple: #8B5CF6;--color-group-purple-bg: var(--pur1);--color-group-purple-fg: #6D28D9;--color-group-teal: #14B8A6;--color-group-teal-bg: #CCFBF1;--color-group-teal-fg: #115E59;--color-group-pink: #EC4899;--color-group-pink-bg: #FCE7F3;--color-group-pink-fg: #9D174D;--color-group-brown: #92400E;--color-group-brown-bg: #FAE8D7;--color-group-brown-fg: #7C2D12;--color-group-gray: #6B7280;--color-group-gray-bg: var(--neutral-200);--color-group-gray-fg: var(--neutral-700);--color-group-butter: #FACC15;--color-group-butter-bg: #FEF9C3;--color-group-butter-fg: #854D0E;--c-dept-blue-bg: var(--color-group-blue-bg);--c-dept-blue-fg: var(--color-group-blue-fg);--c-dept-yellow-bg: var(--color-group-butter-bg);--c-dept-yellow-fg: var(--color-group-butter-fg);--c-dept-butter-bg: var(--color-group-butter-bg);--c-dept-butter-fg: var(--color-group-butter-fg);--c-dept-teal-bg: var(--color-group-teal-bg);--c-dept-teal-fg: var(--color-group-teal-fg);--c-dept-purple-bg: var(--color-group-purple-bg);--c-dept-purple-fg: var(--color-group-purple-fg);--c-dept-pink-bg: var(--color-group-pink-bg);--c-dept-pink-fg: var(--color-group-pink-fg);--c-dept-brown-bg: var(--color-group-brown-bg);--c-dept-brown-fg: var(--color-group-brown-fg);--c-dept-gray-bg: var(--color-group-gray-bg);--c-dept-gray-fg: var(--color-group-gray-fg);--reserved-color-not-eaten: var(--c-not-eaten);--reserved-color-eaten: var(--c-eaten);--reserved-color-partial: var(--c-cat-partial-bd);--tier-free-bg: var(--neutral-100);--tier-free-fg: var(--neutral-700);--tier-standard-bg: var(--info-surface);--tier-standard-fg: var(--accent-600);--tier-pro-bg: var(--pur1);--tier-pro-fg: var(--pur)}@media(min-width:768px){:root{--fs-xl: 28px;--fs-2xl: 32px;--fs-3xl: 40px;--gutter: var(--gutter-desktop);--header-h: var(--header-h-desktop)}}@media(max-width:600px){:root{--fs-xs: 14px;--fs-sm: 16px;--fs-base: 18px;--fs-md: 20px;--fs-lg: 23px;--fs-xl: 27px;--fs-2xl: 32px;--fs-3xl: 38px}}@media(max-width:600px)and (max-resolution:1.6dppx){:root{--fs-xs: 16px;--fs-sm: 18px;--fs-base: 22px;--fs-md: 25px;--fs-lg: 29px;--fs-xl: 34px;--fs-2xl: 40px;--fs-3xl: 48px}}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--c-bg);color:var(--c-fg);font-family:var(--font-body);font-size:var(--fs-base);line-height:1.65;min-height:100dvh;padding-left:var(--safe-left);padding-right:var(--safe-right);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}:lang(en) body,body[lang=en]{font-family:var(--font-body-en)}:lang(ko) body,body[lang=ko]{font-family:var(--font-body-ko)}:lang(ja) body,body[lang=ja]{font-family:var(--font-body-jp);font-feature-settings:"palt" 1}:lang(ja) .text-display,:lang(ja) .text-h1,:lang(ja) h1{font-weight:500}a{color:var(--c-accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;-webkit-tap-highlight-color:transparent;font-family:inherit;border:none;background:transparent;color:inherit}input[type=text],input[type=email],input[type=number],input[type=tel],input[type=search],input[type=password],textarea,select{width:100%;padding:12px 14px;border:1px solid var(--c-border);border-radius:var(--radius-md);font-size:var(--fs-base);font-family:inherit;background:var(--c-surface);color:var(--c-fg);min-height:var(--touch-min);transition:border-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-500);box-shadow:var(--focus-ring)}textarea{resize:vertical;min-height:96px;line-height:1.6}label{display:block;font-size:var(--fs-sm);font-weight:500;color:var(--neutral-600);margin:14px 0 6px}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--c-primary);margin:0;line-height:1.25;letter-spacing:-.3px}hr{border:none;border-top:1px solid var(--c-border);margin:var(--space-8) 0}.safe-top{padding-top:var(--safe-top)}.safe-bottom{padding-bottom:var(--safe-bottom)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 18px;min-height:var(--touch-min);border-radius:var(--radius-md);font-size:var(--fs-base);font-weight:600;background:var(--c-accent);color:var(--c-primary-fg);border:1px solid var(--c-accent);transition:background var(--duration-fast) var(--ease-standard),transform var(--duration-fast)}.btn:hover:not(:disabled){background:var(--accent-500)}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.btn-secondary{background:var(--c-surface);color:var(--c-accent);border-color:var(--c-accent)}.btn-secondary:hover:not(:disabled){background:var(--ice-100)}.btn-danger{background:var(--c-danger);border-color:var(--c-danger);color:var(--c-danger-fg)}.btn-danger:hover:not(:disabled){background:var(--error-strong)}.btn-ghost{background:transparent;color:var(--c-fg);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--neutral-100)}.btn-lg{padding:14px 28px;font-size:var(--fs-md);width:100%}.btn-sm{padding:6px 12px;font-size:var(--fs-sm);min-height:32px}.staff-chip{background:var(--c-surface);border:1.5px solid var(--c-border-strong);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-2);text-align:center;cursor:pointer;position:relative;min-height:var(--touch-comfy);transition:transform var(--duration-fast) var(--ease-standard),border-color var(--duration-fast),background var(--duration-fast),color var(--duration-fast);font-size:var(--fs-sm);font-weight:600;color:var(--c-fg)}.staff-chip:hover{transform:scale(1.03)}.staff-chip:focus-visible{box-shadow:var(--focus-ring);outline:none}.staff-chip.eaten{background:var(--c-eaten-bg);border-color:var(--c-eaten);color:var(--c-eaten-fg);font-weight:600}.staff-chip.stale{background:var(--c-not-eaten-bg);border:2px solid var(--c-not-eaten);color:var(--c-not-eaten-fg);font-weight:700}.staff-chip.stale:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:inherit;border:2px solid var(--c-not-eaten);opacity:0;pointer-events:none;animation:stalePulse 2s ease-in-out infinite}@keyframes stalePulse{0%,to{opacity:0;transform:scale(1)}50%{opacity:.6;transform:scale(1.02)}}@media(prefers-reduced-motion:reduce){.staff-chip.stale:after{animation:none;opacity:.4}}.staff-type{display:inline-block;font-size:9px;line-height:1;padding:2px 4px;background:var(--c-dept-gray-bg);color:var(--c-dept-gray-fg);border-radius:var(--radius-xs);font-family:var(--font-display);font-weight:700;margin-right:3px;vertical-align:1px;letter-spacing:0}.staff-type[data-dept=blue]{background:var(--color-group-blue-bg);color:var(--color-group-blue-fg)}.staff-type[data-dept=butter],.staff-type[data-dept=yellow]{background:var(--color-group-butter-bg);color:var(--color-group-butter-fg)}.staff-type[data-dept=teal]{background:var(--color-group-teal-bg);color:var(--color-group-teal-fg)}.staff-type[data-dept=purple]{background:var(--color-group-purple-bg);color:var(--color-group-purple-fg)}.staff-type[data-dept=pink]{background:var(--color-group-pink-bg);color:var(--color-group-pink-fg)}.staff-type[data-dept=brown]{background:var(--color-group-brown-bg);color:var(--color-group-brown-fg)}.staff-type[data-dept=gray]{background:var(--color-group-gray-bg);color:var(--color-group-gray-fg)}.staff-type.trainee{background:var(--c-dept-blue-bg);color:var(--c-dept-blue-fg)}.staff-type.dispatch{background:var(--c-dept-gray-bg);color:var(--c-dept-gray-fg)}.staff-chip-zone,.edit-zone{position:relative}.staff-chip-zone>.x-btn,.edit-zone>.x-btn{position:absolute;top:-6px;right:-6px}.staff-chip:after{content:"未";position:absolute;top:-7px;right:-7px;min-width:22px;height:22px;padding:0 5px;background:var(--c-not-eaten);color:var(--c-primary-fg);border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:var(--font-display);border:1.5px solid var(--c-surface);line-height:1}.staff-chip.eaten:after{content:"済";background:var(--c-eaten)}.staff-chip .check-badge{display:none}.cat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-2);box-shadow:var(--shadow-xs)}.cat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2);font-weight:600}.cat-status{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:700;border:1px solid;font-family:var(--font-mono)}.cat-status.empty{background:var(--c-cat-empty-bg);color:var(--c-cat-empty-fg);border-color:var(--c-cat-empty-bd)}.cat-status.none{background:var(--c-cat-none-bg);color:var(--c-cat-none-fg);border-color:var(--c-cat-none-bd)}.cat-status.partial{background:var(--c-cat-partial-bg);color:var(--c-cat-partial-fg);border-color:var(--c-cat-partial-bd)}.cat-status.all{background:var(--c-cat-all-bg);color:var(--c-cat-all-fg);border-color:var(--c-cat-all-bd)}.cat-pill-row{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-2) var(--gutter);background:var(--c-surface);border-bottom:1px solid var(--c-border);scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.cat-pill-row::-webkit-scrollbar{height:4px}.cat-pill-row::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:2px}.cat-pill-status{flex-shrink:0;scroll-snap-align:start;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;padding:6px 12px;border-radius:var(--radius-md);border:1.5px solid;cursor:pointer;transition:transform var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast);min-width:auto;font-family:var(--font-display);text-align:center;white-space:nowrap}.cat-pill-status:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.cat-pill-status.active{background:var(--c-primary);color:var(--c-primary-fg);border-color:var(--c-primary);transform:translateY(-1px);box-shadow:var(--shadow-pill-active)}.cat-pill-status.active .pill-count{color:var(--c-primary-fg)}.cat-pill-status .pill-name{font-weight:700;font-size:var(--fs-sm);white-space:nowrap}.cat-pill-status .pill-count{font-family:var(--font-mono);font-weight:700;font-size:var(--fs-xs);white-space:nowrap}.cat-pill-status.empty{background:var(--c-cat-empty-bg);color:var(--c-cat-empty-fg);border-color:var(--c-cat-empty-bd)}.cat-pill-status.none{background:var(--c-cat-none-bg);color:var(--c-cat-none-fg);border-color:var(--c-cat-none-bd)}.cat-pill-status.partial{background:var(--c-cat-partial-bg);color:var(--c-cat-partial-fg);border-color:var(--c-cat-partial-bd)}.cat-pill-status.all{background:var(--c-cat-all-bg);color:var(--c-cat-all-fg);border-color:var(--c-cat-all-bd)}.cat-pill-status[data-dept=blue]{background:var(--color-group-blue-bg);color:var(--color-group-blue-fg);border-color:var(--color-group-blue-fg)}.cat-pill-status[data-dept=butter],.cat-pill-status[data-dept=yellow]{background:var(--color-group-butter-bg);color:var(--color-group-butter-fg);border-color:var(--color-group-butter-fg)}.cat-pill-status[data-dept=teal]{background:var(--color-group-teal-bg);color:var(--color-group-teal-fg);border-color:var(--color-group-teal-fg)}.cat-pill-status[data-dept=purple]{background:var(--color-group-purple-bg);color:var(--color-group-purple-fg);border-color:var(--color-group-purple-fg)}.cat-pill-status[data-dept=pink]{background:var(--color-group-pink-bg);color:var(--color-group-pink-fg);border-color:var(--color-group-pink-fg)}.cat-pill-status[data-dept=brown]{background:var(--color-group-brown-bg);color:var(--color-group-brown-fg);border-color:var(--color-group-brown-fg)}.cat-pill-status[data-dept=gray]{background:var(--color-group-gray-bg);color:var(--color-group-gray-fg);border-color:var(--color-group-gray-fg)}.cat-pill-status .pill-count .unfed{color:var(--c-not-eaten);font-weight:800}.dept-pill-row{background:var(--c-bg);padding:var(--space-2) var(--gutter);border-bottom:1px solid var(--c-border)}.dept-pill-row .cat-pill-status{padding:7px 14px}.cat-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-2);border-radius:var(--radius-md);border:1.5px solid var(--c-border);background:var(--c-surface)}.cat-section.temporary .cat-section-head{border-style:dashed;border-color:var(--c-accent);background:var(--ice-100)}.cat-temp-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:var(--radius-xs);background:var(--ice-200);color:var(--navy-700);font-size:var(--fs-xs);font-weight:600;font-family:var(--font-display);margin-left:4px}.cat-temp-badge.expiring{background:var(--warning-surface);color:var(--c-warning-fg)}.edit-zone{position:relative}.edit-mode .edit-zone{outline:1px dashed var(--c-accent);outline-offset:2px;border-radius:var(--radius-sm)}.edit-action{display:none}.edit-mode .edit-action{display:inline-flex}.add-ghost-chip{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:var(--space-2);border:1.5px dashed var(--c-border);border-radius:var(--radius-lg);color:var(--c-muted);font-size:var(--fs-sm);font-weight:500;cursor:pointer;min-height:var(--touch-comfy);background:transparent;font-family:inherit;transition:border-color var(--duration-fast),color var(--duration-fast)}.add-ghost-chip:hover{border-color:var(--c-accent);color:var(--c-accent);border-style:solid}.add-ghost-chip.sm{font-size:10px;padding:2px 8px;min-height:22px}.inline-input{display:inline-flex;align-items:center;border:1.5px solid var(--c-accent);border-radius:var(--radius-lg);background:var(--c-surface);padding:2px 6px;min-height:var(--touch-comfy)}.inline-input input{border:none;outline:none;background:transparent;font-size:var(--fs-base);font-family:inherit;color:var(--c-fg);width:100%;padding:4px;min-height:auto}.inline-input input::placeholder{color:var(--c-muted);font-weight:400}.x-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:var(--radius-full);background:var(--c-surface);color:var(--c-muted);border:1px solid var(--c-border);font-size:11px;font-weight:700;cursor:pointer;margin-left:4px;flex-shrink:0;font-family:inherit;transition:background var(--duration-fast),color var(--duration-fast)}.x-btn:hover{background:var(--error-surface);color:var(--c-danger);border-color:var(--c-danger)}.mode-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-sm);background:var(--c-surface);border:1px solid var(--c-border);font-size:var(--fs-xs);font-weight:600;color:var(--c-fg);cursor:pointer;font-family:inherit}.mode-toggle.active{background:var(--c-accent);color:var(--c-primary-fg);border-color:var(--c-accent)}.mode-toggle:hover:not(.active){background:var(--c-surface-2)}.dept-subtype-row{display:flex;gap:var(--space-2);align-items:stretch}.dept-subtype-row select{flex:1;padding:8px 10px;border:1px solid var(--c-border);border-radius:var(--radius-sm);font-size:var(--fs-base);background:var(--c-surface);font-family:inherit;color:var(--c-fg)}.dept-subtype-row .dept-color-preview{display:inline-flex;align-items:center;justify-content:center;width:38px;border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:700;font-size:var(--fs-base)}.color-picker{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}.color-swatch{width:28px;height:28px;border-radius:var(--radius-sm);border:1.5px solid transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:11px;transition:transform var(--duration-fast),box-shadow var(--duration-fast);position:relative}.color-swatch:hover:not([disabled]){transform:scale(1.1)}.color-swatch[data-color=blue]{background:var(--color-group-blue-bg);color:var(--color-group-blue-fg)}.color-swatch[data-color=butter],.color-swatch[data-color=yellow]{background:var(--color-group-butter-bg);color:var(--color-group-butter-fg)}.color-swatch[data-color=teal]{background:var(--color-group-teal-bg);color:var(--color-group-teal-fg)}.color-swatch[data-color=purple]{background:var(--color-group-purple-bg);color:var(--color-group-purple-fg)}.color-swatch[data-color=pink]{background:var(--color-group-pink-bg);color:var(--color-group-pink-fg)}.color-swatch[data-color=brown]{background:var(--color-group-brown-bg);color:var(--color-group-brown-fg)}.color-swatch[data-color=gray]{background:var(--color-group-gray-bg);color:var(--color-group-gray-fg)}.color-swatch.selected{border-color:var(--c-primary);box-shadow:0 0 0 2px var(--c-surface),0 0 0 4px var(--c-primary)}.color-swatch[data-reserved]{cursor:not-allowed;opacity:.4;background:var(--neutral-100);color:var(--c-muted);position:relative;overflow:hidden}.color-swatch[data-reserved]:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(45deg,transparent calc(50% - 1px),var(--c-danger) calc(50% - 1px),var(--c-danger) calc(50% + 1px),transparent calc(50% + 1px))}.subtype-edit-row{display:flex;gap:var(--space-2);align-items:center;padding:6px 0}.subtype-edit-row .badge-char-input{width:38px;text-align:center;font-family:var(--font-display);font-weight:700;font-size:var(--fs-base);padding:6px 0;border:1.5px solid var(--c-border);border-radius:var(--radius-sm);background:var(--c-surface);flex-shrink:0}.subtype-edit-row .badge-char-input::placeholder{color:var(--c-muted);font-weight:400}.subtype-edit-row .subtype-name-input{flex:1;padding:6px 10px;border:1px solid var(--c-border);border-radius:var(--radius-sm);font-size:var(--fs-base);background:var(--c-surface);font-family:inherit}.dept-edit-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-3);box-shadow:var(--shadow-xs)}.dept-edit-card .dept-card-head{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.dept-edit-card .dept-name-input{flex:1;padding:8px 12px;border:1.5px solid var(--c-border);border-radius:var(--radius-md);font-size:var(--fs-base);font-family:var(--font-display);font-weight:700;background:var(--c-surface)}.dept-edit-card .dept-field-label{font-size:var(--fs-xs);font-weight:600;color:var(--c-muted);text-transform:uppercase;letter-spacing:.3px;margin:var(--space-3) 0 6px}.dept-edit-card .dept-field-label:first-child{margin-top:0}.dup-name-alert{background:var(--error-surface);border:1.5px solid var(--c-danger);border-radius:var(--radius-md);padding:var(--space-3);margin-top:var(--space-3);font-size:var(--fs-sm);line-height:1.5;color:var(--c-fg)}.dup-name-alert .alert-title{display:flex;align-items:center;gap:6px;font-weight:700;color:var(--c-danger);margin-bottom:4px}.dup-name-alert .alert-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.filter-dropdown{position:relative;display:inline-flex;flex-direction:column}.filter-dropdown-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--c-border);border-radius:var(--radius-sm);background:var(--c-surface);font-size:var(--fs-xs);font-weight:600;color:var(--c-fg);cursor:pointer;font-family:inherit;min-height:28px;white-space:nowrap}.filter-dropdown-btn:after{content:"▼";font-size:8px;margin-left:4px;opacity:.6}.filter-dropdown-btn .label-key{color:var(--c-muted)}.filter-dropdown-btn .label-val{color:var(--c-accent)}.filter-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:50;padding:6px 0;max-height:260px;overflow-y:auto}.filter-dropdown-menu .item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;font-size:var(--fs-xs);color:var(--c-fg)}.filter-dropdown-menu .item:hover{background:var(--c-surface-2)}.filter-dropdown-menu .item input[type=checkbox]{width:14px;height:14px}.filter-dropdown-menu .item .count{color:var(--c-muted);margin-left:auto;font-family:var(--font-mono)}.filter-dropdown-menu .item.muted{color:var(--c-muted);opacity:.6}.filter-dropdown-menu .divider{height:1px;background:var(--c-border);margin:4px 0}.filter-dropdown-menu .quick-actions{display:flex;gap:4px;padding:4px 10px 6px;border-bottom:1px solid var(--c-border);margin-bottom:4px}.filter-dropdown-menu .quick-actions button{font-size:10px;padding:2px 6px;border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-muted);border-radius:var(--radius-xs);cursor:pointer;font-family:inherit}.autosave-indicator{font-size:var(--fs-xs);color:var(--c-muted);display:inline-flex;align-items:center;gap:4px}.autosave-indicator.saving{color:var(--c-warning-fg)}.autosave-indicator.saved{color:var(--c-success-fg)}.autosave-indicator:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);background:currentColor;display:inline-block}.role-badge{display:inline-flex;align-items:baseline;gap:0;padding:0;border:none;background:transparent;font-size:var(--fs-xs);line-height:1.4;color:var(--c-fg);white-space:nowrap;margin-right:10px}.role-badge:last-child{margin-right:0}.role-badge .role-label{font-weight:600;color:var(--c-fg)}.role-badge .role-person{color:var(--c-muted);font-weight:500}.role-list{display:flex;flex-wrap:wrap;gap:0;margin-top:var(--space-1);font-size:var(--fs-xs);line-height:1.5}.scope-label,.dept-name{font-family:var(--font-display);font-weight:700;color:var(--c-primary);font-size:var(--fs-sm);margin-right:var(--space-3);flex-shrink:0}.global-role-section{display:flex;align-items:center;gap:var(--space-2);padding:6px var(--space-4);background:var(--c-surface-2);border-bottom:1px solid var(--c-border);overflow-x:auto;white-space:nowrap}.global-role-section.scope-institution{background:var(--c-surface);border-top:2px solid var(--c-primary);border-left:4px solid var(--c-primary);padding-left:var(--space-4)}.global-role-section.scope-institution .gr-title{color:var(--c-primary);font-weight:700}.global-role-section.scope-dept{border-left:4px dashed var(--neutral-400);padding-left:var(--space-4)}.global-role-section .gr-title{font-size:var(--fs-xs);font-weight:700;color:var(--c-muted);letter-spacing:.3px;margin:0;flex-shrink:0;display:inline-flex;align-items:center;gap:4px}.global-role-section .gr-list{display:inline-flex;flex-wrap:nowrap;gap:4px;flex:1;overflow-x:auto}.global-role-section .gr-list::-webkit-scrollbar{height:3px}.global-role-section .gr-list::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:2px}.view-toggle{display:inline-flex;background:var(--neutral-100);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:2px;gap:0}.view-toggle button{background:transparent;border:none;padding:4px 10px;font-size:var(--fs-xs);font-weight:500;color:var(--c-muted);cursor:pointer;border-radius:calc(var(--radius-md) - 2px);transition:background var(--duration-fast),color var(--duration-fast);font-family:inherit}.view-toggle button.active{background:var(--c-surface);color:var(--c-primary);font-weight:600;box-shadow:var(--shadow-xs)}.view-toggle button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--gutter);padding-bottom:max(var(--gutter),var(--safe-bottom))}.modal{background:var(--c-surface);border-radius:var(--radius-xl);width:100%;max-width:420px;max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 40px);overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--c-border);display:flex;justify-content:space-between;align-items:center;font-weight:600}.modal-body{padding:var(--space-5)}.modal-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--c-border);display:flex;justify-content:flex-end;gap:var(--space-2)}.otp-row{display:flex;gap:var(--space-2);justify-content:center}.otp-cell{width:40px;height:48px;border:2px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface);font-size:var(--fs-xl);font-weight:700;font-family:var(--font-mono);text-align:center;color:var(--c-fg)}.otp-cell:focus,.otp-cell.filled{border-color:var(--c-accent);color:var(--c-accent);outline:none;box-shadow:var(--focus-ring)}.tier-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-xs);font-size:var(--fs-xs);font-weight:600}.tier-badge.free{background:var(--tier-free-bg);color:var(--tier-free-fg)}.tier-badge.standard{background:var(--tier-standard-bg);color:var(--tier-standard-fg)}.tier-badge.pro{background:var(--tier-pro-bg);color:var(--tier-pro-fg)}.notice{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--fs-sm);line-height:1.6;border:1px solid transparent}.notice-info{background:var(--info-surface);color:var(--info);border-color:#3b82f633}.notice-success{background:var(--success-surface);color:var(--success);border-color:#10b98133}.notice-warning{background:var(--warning-surface);color:var(--warning);border-color:#f59e0b33}.notice-error{background:var(--error-surface);color:var(--error);border-color:#ef444433}.grid-cards-sm{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--grid-card-sm),1fr));gap:var(--space-2)}.grid-cards-md{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--grid-card-md),1fr));gap:var(--space-2)}.dept-nav-row{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-2) 0;border-bottom:1px solid var(--c-border);margin-bottom:var(--space-3)}.dept-nav-row>button{flex-shrink:0;padding:var(--space-2) var(--space-4);border:1px solid var(--c-border);border-radius:var(--radius-full);background:var(--c-surface);color:var(--c-muted);font-size:var(--fs-xs);font-weight:600;white-space:nowrap;cursor:pointer}.dept-nav-row>button[aria-selected=true]{background:var(--c-primary);color:var(--c-primary-fg);border-color:var(--c-primary)}.downgrade-warning-row{display:flex;align-items:flex-start;gap:var(--space-3)}.downgrade-warning-icon{flex-shrink:0;width:28px;height:28px;color:var(--c-warning-fg)}.downgrade-warning-text{flex:1;min-width:0}.downgrade-warning-body{font-size:var(--fs-md);font-weight:500;color:var(--c-fg);line-height:1.5;margin:0 0 var(--space-2)}.downgrade-warning-detail{font-size:var(--fs-xs);color:var(--c-muted);margin:0}.al{display:flex;flex-direction:column;min-height:100dvh;background:var(--surface)}.tb{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:calc(var(--space-2) + var(--safe-top)) var(--gutter) var(--space-2);min-height:calc(var(--header-h) + var(--safe-top));background:var(--glass-bg);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:20;backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px)}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){.tb{background:var(--surface-elevated)}}.tbl{display:flex;align-items:center;gap:var(--space-2);min-width:0;flex:1 1 auto}.tbr{display:flex;align-items:center;gap:2px;flex-shrink:0}.tbt{font-family:var(--font-display);font-size:var(--fs-md);font-weight:700;color:var(--b700);letter-spacing:-.3px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.ib{display:inline-flex;align-items:center;justify-content:center;width:var(--touch-min);height:var(--touch-min);border-radius:var(--radius-md);color:var(--c-fg);transition:background var(--duration-fast)}.ib:hover{background:var(--neutral-100)}.pc{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:max(var(--space-4),var(--safe-bottom))}.pc-inner{max-width:720px;margin:0 auto;padding:var(--space-5) var(--gutter)}.container{max-width:480px;margin:0 auto;padding:var(--gutter)}.container-content{max-width:var(--width-content);margin:0 auto;padding:0 var(--gutter)}.container-app{max-width:var(--width-app);margin:0 auto;padding:0 var(--gutter)}.container-prose{max-width:var(--width-prose);margin:0 auto;padding:0 var(--gutter)}.text-display{font-family:var(--font-display);font-size:var(--fs-3xl);font-weight:700;line-height:1.15;letter-spacing:-1.5px;color:var(--c-primary)}.text-h1{font-family:var(--font-display);font-size:var(--fs-2xl);font-weight:700;line-height:1.25;letter-spacing:-1px;color:var(--c-primary)}.text-h2{font-family:var(--font-display);font-size:var(--fs-xl);font-weight:600;line-height:1.3;letter-spacing:-.5px;color:var(--c-primary)}.text-h3{font-family:var(--font-display);font-size:var(--fs-lg);font-weight:600;line-height:1.35;color:var(--c-primary)}.text-h4{font-family:var(--font-display);font-size:var(--fs-md);font-weight:600;line-height:1.4;color:var(--c-primary)}.text-body-l{font-family:var(--font-body);font-size:var(--fs-lg);font-weight:400;line-height:1.65;color:var(--c-fg)}.text-body{font-family:var(--font-body);font-size:var(--fs-base);font-weight:400;line-height:1.65;color:var(--c-fg)}.text-body-s{font-family:var(--font-body);font-size:var(--fs-sm);font-weight:400;line-height:1.65;color:var(--c-muted)}.text-caption{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:500;letter-spacing:.2px;line-height:1.5;color:var(--c-muted)}.text-mono{font-family:var(--font-mono)}.lang-ja,[lang=ja]{font-family:var(--font-body-jp)}.lang-ko,[lang=ko]{font-family:var(--font-body-ko)}.lang-en,[lang=en]{font-family:var(--font-body-en)}.text-muted{color:var(--c-muted)}.text-accent{color:var(--c-accent)}.text-danger{color:var(--c-danger)}.text-success{color:var(--c-success)}.text-warning{color:var(--c-warning)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}
