:root{--font-family-base:-apple-system,BlinkMacSystemFont,"SF Pro Display","Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;--color-primary:#1a6b3a;--color-primary-hover:#155730;--color-primary-active:#0f4224;--color-primary-subtle:#e8f5ee;--color-primary-disabled:#b0bec5;--color-accent:#3aaa35;--color-accent-hover:#2d8a29;--gradient-brand:linear-gradient(135deg,#1a6b3a,#2d9e5f);--color-surface-page:#f5f5f7;--color-surface-card:#ffffff;--color-surface-inset:#f0f0f5;--color-surface-hover:#fafafa;--color-surface-overlay:rgba(0,0,0,0.35);--color-text-primary:#1d1d1f;--color-text-secondary:#86868b;--color-text-tertiary:#aeaeb2;--color-text-inverse:#ffffff;--color-text-disabled:#c7c7cc;--color-text-link:var(--color-primary);--color-border:#e5e5ea;--color-border-light:#f0f0f5;--color-border-strong:#d2d2d7;--color-border-focus:var(--color-primary);--color-success:#2d9e5f;--color-success-bg:#edfaf3;--color-success-border:#a3d9bc;--color-warning:#d97706;--color-warning-bg:#fffbeb;--color-warning-border:#fcd34d;--color-danger:#dc2626;--color-danger-bg:#fef2f2;--color-danger-border:#fca5a5;--color-info:#2563eb;--color-info-bg:#eff6ff;--color-info-border:#93c5fd;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-12:48px;--space-16:64px;--font-size-caption:12px;--font-size-caption-lg:13px;--font-size-body:14px;--font-size-body-lg:16px;--font-size-h2:18px;--font-size-h1:28px;--font-size-h1-lg:32px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--radius-sm:8px;--radius-md:12px;--radius-lg:14px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-xs:0 1px 3px rgba(0,0,0,0.03);--shadow-sm:0 1px 6px rgba(0,0,0,0.03);--shadow-md:0 2px 20px rgba(0,0,0,0.04);--shadow-lg:0 8px 40px rgba(0,0,0,0.06);--shadow-focus:0 0 0 4px rgba(26,107,58,0.08);--transition-fast:120ms cubic-bezier(0.4,0,0.2,1);--transition-normal:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:350ms cubic-bezier(0.4,0,0.2,1);--z-base:0;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-toast:400}[data-theme=dark]{--color-primary:#4ade80;--color-primary-hover:#6ee7a0;--color-primary-active:#22c55e;--color-primary-subtle:#052e16;--color-surface-hover:#22273200;--color-surface-primary:var(--color-surface-card);--color-surface-secondary:var(--color-surface-page);--color-surface-tertiary:var(--color-surface-inset);--color-border-light:#1f2430;--color-border-default:var(--color-border);--color-semantic-success-bg:var(--color-success-bg);--color-semantic-warning-bg:var(--color-warning-bg);--color-semantic-danger-bg:var(--color-danger-bg);--color-semantic-info-bg:var(--color-info-bg)}:root{--color-surface-primary:var(--color-surface-card);--color-surface-secondary:var(--color-surface-page);--color-surface-tertiary:var(--color-surface-inset);--color-border-default:var(--color-border);--color-primary-default:var(--color-primary);--color-semantic-success:var(--color-success);--color-semantic-success-bg:var(--color-success-bg);--color-semantic-warning:var(--color-warning);--color-semantic-warning-bg:var(--color-warning-bg);--color-semantic-danger:var(--color-danger);--color-semantic-danger-bg:var(--color-danger-bg);--color-semantic-info:var(--color-info);--color-semantic-info-bg:var(--color-info-bg)}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }

/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
 */*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Hiragino Sans,Hiragino Kaku Gothic ProN,Yu Gothic,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*,:after,:before{box-sizing:border-box}html{font-family:Inter,Noto Sans JP,system-ui,sans-serif;font-size:var(--font-size-body);color:var(--color-text-primary);background-color:var(--color-surface-page);-webkit-font-smoothing:antialiased}body{margin:0;min-height:100vh}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.sr-only{border:0}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-weight:var(--font-weight-medium);border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast),opacity var(--transition-fast);min-height:44px;min-width:44px;white-space:nowrap;text-decoration:none;position:relative;overflow:hidden}.btn:active:not(:disabled){transform:scale(.97)}.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn:disabled,.btn[aria-disabled=true]{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 1px 3px rgba(26,107,58,.25),0 1px 2px rgba(26,107,58,.15)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:0 4px 12px rgba(26,107,58,.3),0 1px 4px rgba(26,107,58,.2);transform:translateY(-1px)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-active);box-shadow:0 1px 2px rgba(26,107,58,.2);transform:translateY(0) scale(.97)}.btn-secondary{background-color:var(--color-surface-card);color:var(--color-text-primary);border-color:var(--color-border);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background-color:var(--color-surface-hover);border-color:var(--color-border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary:active:not(:disabled){background-color:var(--color-surface-inset);transform:translateY(0) scale(.97)}.btn-danger{background-color:var(--color-danger);color:var(--color-text-inverse);box-shadow:0 1px 3px rgba(220,38,38,.25)}.btn-danger:hover:not(:disabled){filter:brightness(.92);box-shadow:0 4px 12px rgba(220,38,38,.28);transform:translateY(-1px)}.btn-danger:active:not(:disabled){filter:brightness(.85);transform:translateY(0) scale(.97)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-surface-inset);color:var(--color-text-primary)}.btn-ghost:active:not(:disabled){background-color:var(--color-border);transform:scale(.97)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-caption);min-height:32px}.btn-md{padding:var(--space-2) var(--space-4);font-size:var(--font-size-body)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-body-lg)}.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid;border-top:2px solid transparent;border-radius:var(--radius-full);animation:spin .6s linear infinite}.field-wrapper{display:flex;flex-direction:column;gap:var(--space-1)}.field-label{font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);letter-spacing:.01em}.field-input,.field-textarea{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-body);color:var(--color-text-primary);background-color:var(--color-surface-card);border:1.5px solid var(--color-border-strong);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);min-height:44px}.field-input:hover:not(:disabled):not(:focus),.field-textarea:hover:not(:disabled):not(:focus){border-color:var(--color-border-strong);background-color:var(--color-surface-hover)}.field-input:focus-visible,.field-textarea:focus-visible{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-focus);background-color:var(--color-surface-card)}.field-input:disabled,.field-textarea:disabled{background-color:var(--color-surface-inset);color:var(--color-text-disabled);cursor:not-allowed;border-color:var(--color-border)}.field-input[aria-invalid=true],.field-textarea[aria-invalid=true]{border-color:var(--color-danger);box-shadow:0 0 0 3px rgba(220,38,38,.1)}[data-variant=success] .field-input,[data-variant=success] .field-textarea{border-color:var(--color-success);box-shadow:0 0 0 3px rgba(45,158,95,.1)}.field-textarea{min-height:96px;resize:vertical}.field-error{color:var(--color-danger)}.field-error,.field-helper{font-size:var(--font-size-caption);margin:0}.field-helper{color:var(--color-text-tertiary)}.card{background-color:var(--color-surface-card);border-radius:var(--radius-lg);overflow:hidden}[data-variant=default].card{box-shadow:var(--shadow-sm)}[data-variant=elevated].card{box-shadow:var(--shadow-md)}[data-variant=outlined].card{border:1px solid var(--color-border);box-shadow:none}.card-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);font-weight:var(--font-weight-semibold);font-size:var(--font-size-body-lg);color:var(--color-text-primary)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);background-color:var(--color-surface-page);display:flex;justify-content:flex-end;gap:var(--space-3)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-caption);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);transition:opacity var(--transition-fast)}[data-color=success].badge{background-color:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}[data-color=warning].badge{background-color:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}[data-color=danger].badge{background-color:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}[data-color=info].badge{background-color:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info-border)}[data-color=neutral].badge{background-color:var(--color-surface-inset);color:var(--color-text-secondary);border:1px solid var(--color-border)}.badge-remove{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0;width:16px;height:16px;border-radius:var(--radius-full);color:inherit;opacity:.6;transition:opacity var(--transition-fast),background-color var(--transition-fast)}.badge-remove:hover{opacity:1;background-color:rgba(0,0,0,.08)}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);flex-direction:column;z-index:var(--z-toast);max-width:400px;width:100%}.toast,.toast-container{display:flex;gap:var(--space-3)}.toast{align-items:flex-start;padding:var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:slideInRight var(--transition-normal) ease;border:1px solid transparent}[data-type=success].toast{background-color:var(--color-success-bg);border-color:var(--color-success-border)}[data-type=error].toast{background-color:var(--color-danger-bg);border-color:var(--color-danger-border)}[data-type=warning].toast{background-color:var(--color-warning-bg);border-color:var(--color-warning-border)}[data-type=info].toast{background-color:var(--color-info-bg);border-color:var(--color-info-border)}.toast-icon{font-size:var(--font-size-body-lg);flex-shrink:0}.toast-message{flex:1;font-size:var(--font-size-body);color:var(--color-text-primary);margin:0}.toast-close{background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);padding:0;font-size:var(--font-size-body-lg);line-height:1;flex-shrink:0;transition:color var(--transition-fast)}.toast-close:hover{color:var(--color-text-primary)}.progress-bar-wrapper{display:flex;align-items:center;gap:var(--space-3)}.progress-label{font-size:var(--font-size-caption);color:var(--color-text-secondary);white-space:nowrap}.progress-bar{flex:1;height:6px;background-color:var(--color-surface-inset);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background-color:var(--color-primary);border-radius:3px;transition:width var(--transition-normal)}.progress-value{font-size:var(--font-size-caption);color:var(--color-text-secondary);min-width:36px;text-align:right}.stepper{width:100%}.stepper-list{display:flex;list-style:none;margin:0;padding:0;gap:var(--space-2)}[data-orientation=horizontal] .stepper-list{flex-direction:row;align-items:flex-start}[data-orientation=vertical] .stepper-list{flex-direction:column}.stepper-step{display:flex;align-items:center;gap:var(--space-2);flex:1;position:relative}[data-orientation=horizontal] .stepper-step:after{content:"";flex:1;height:2px;background-color:var(--color-border);margin:0 var(--space-2);transition:background-color var(--transition-normal)}[data-orientation=horizontal] .stepper-step:last-child:after{display:none}[data-status=completed] .stepper-step:after{background-color:var(--color-primary)}.stepper-indicator{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);font-size:var(--font-size-caption);font-weight:var(--font-weight-semibold);flex-shrink:0;border:2px solid var(--color-border);background-color:var(--color-surface-card);color:var(--color-text-tertiary);transition:background-color var(--transition-normal),border-color var(--transition-normal),color var(--transition-normal)}[data-status=completed] .stepper-indicator{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}[data-status=current] .stepper-indicator{border-color:var(--color-primary);color:var(--color-primary);font-weight:var(--font-weight-bold);box-shadow:0 0 0 4px var(--color-primary-subtle)}.stepper-label{font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);white-space:nowrap}[data-status=current] .stepper-label{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}[data-status=completed] .stepper-label{color:var(--color-text-secondary)}.stepper-description{font-size:var(--font-size-caption);color:var(--color-text-tertiary)}.wizard{display:flex;flex-direction:column;gap:var(--space-8)}.wizard-content{background-color:var(--color-surface-card);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-sm);min-height:200px}.wizard-nav{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-4);border-top:1px solid var(--color-border)}.modal-dialog{border:none;border-radius:var(--radius-2xl);padding:0;box-shadow:var(--shadow-lg);background-color:var(--color-surface-card);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:fadeIn var(--transition-normal) ease}.modal-dialog::backdrop{background-color:var(--color-surface-overlay);backdrop-filter:blur(3px)}[data-size=sm].modal-dialog{width:min(400px,90vw)}[data-size=md].modal-dialog{width:min(560px,90vw)}[data-size=lg].modal-dialog{width:min(800px,90vw)}[data-size=fullscreen].modal-dialog{width:100vw;height:100vh;max-height:100vh;border-radius:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-close,.modal-title{font-size:var(--font-size-h2)}.modal-close{background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);line-height:1;padding:var(--space-1);border-radius:var(--radius-sm);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast),color var(--transition-fast)}.modal-close:hover{background-color:var(--color-surface-inset);color:var(--color-text-primary)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--space-3);flex-shrink:0;background-color:var(--color-surface-page)}.table-wrapper{width:100%;overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-body);color:var(--color-text-primary)}.table-th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-caption);color:var(--color-text-secondary);background-color:var(--color-surface-page);border-bottom:1px solid var(--color-border-light);white-space:nowrap;letter-spacing:.04em;text-transform:uppercase}.table-td-check,.table-th-check{width:44px;text-align:center}.table-sort-btn{background:none;border:none;cursor:pointer;font:inherit;color:inherit;font-weight:var(--font-weight-semibold);padding:0;display:flex;align-items:center;gap:var(--space-1);transition:color var(--transition-fast)}.table-sort-btn:hover{color:var(--color-text-primary)}.table-row{border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-fast)}.table-row:hover{background-color:var(--color-surface-hover)}.table-row[data-selected=true]{background-color:var(--color-info-bg)}.table-td{padding:var(--space-3) var(--space-4);color:var(--color-text-primary);vertical-align:middle}.table-empty{padding:var(--space-12) var(--space-4);text-align:center;color:var(--color-text-tertiary)}.table-empty,.table-pagination{font-size:var(--font-size-body)}.table-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-4);border-top:1px solid var(--color-border);color:var(--color-text-secondary)}.table-pagination button{background:var(--color-surface-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:var(--space-1) var(--space-3);min-width:44px;min-height:44px;font-size:var(--font-size-body-lg);color:var(--color-text-primary);transition:background-color var(--transition-fast),border-color var(--transition-fast)}.table-pagination button:hover:not(:disabled){background-color:var(--color-surface-hover);border-color:var(--color-border-strong)}.table-pagination button:disabled{opacity:.4;cursor:not-allowed}.datagrid-wrapper{width:100%}.datagrid-caption{font-size:var(--font-size-caption);color:var(--color-text-secondary);margin:0 0 var(--space-2);font-weight:var(--font-weight-medium)}.datagrid-scroll{border:1px solid var(--color-border-light);border-radius:var(--radius-sm);background-color:var(--color-surface-card)}.datagrid-header{display:flex;position:sticky;top:0;z-index:1;background-color:var(--color-surface-page);border-bottom:1px solid var(--color-border-light)}.datagrid-th{padding:var(--space-2) var(--space-3);font-size:var(--font-size-caption);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);white-space:nowrap;letter-spacing:.04em;text-transform:uppercase;text-align:left}.datagrid-row{display:flex;border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-fast)}.datagrid-row:hover{background-color:var(--color-surface-hover)}.datagrid-td{padding:var(--space-2) var(--space-3);font-size:var(--font-size-body);color:var(--color-text-primary);display:flex;align-items:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.datagrid-td[data-editable=true]{cursor:pointer}.datagrid-td[data-editable=true]:hover{background-color:var(--color-surface-inset)}.datagrid-td[data-sticky=true],.datagrid-th[data-sticky=true]{position:sticky;left:0;z-index:1;background-color:inherit}.datagrid-edit-input{width:100%;padding:var(--space-1) var(--space-2);font-size:var(--font-size-body);border:1.5px solid var(--color-border-focus);border-radius:var(--radius-sm);background-color:var(--color-surface-card);box-shadow:var(--shadow-focus);outline:none}.datagrid-count{font-size:var(--font-size-caption);color:var(--color-text-tertiary);padding:var(--space-2) var(--space-3);margin:0;text-align:right}.multiselect-wrapper,.select-wrapper{display:flex;flex-direction:column;gap:var(--space-1);position:relative}.select-input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-body);color:var(--color-text-primary);background-color:var(--color-surface-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);min-height:44px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.select-input:hover:not(:disabled){border-color:var(--color-border-strong)}.select-input:focus-visible{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-focus)}.select-input:disabled{background-color:var(--color-surface-inset);cursor:not-allowed}[data-error=true] .select-input{border-color:var(--color-danger)}.multiselect-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-body);color:var(--color-text-primary);background-color:var(--color-surface-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);min-height:44px;cursor:pointer;text-align:left;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.multiselect-trigger:hover{border-color:var(--color-border-strong)}.multiselect-trigger:focus-visible{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-focus)}.multiselect-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multiselect-dropdown{position:absolute;top:100%;left:0;right:0;background-color:var(--color-surface-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);margin-top:var(--space-1);overflow:hidden;animation:fadeIn var(--transition-fast) ease}.multiselect-search{width:100%;padding:var(--space-2) var(--space-3);border:none;border-bottom:1px solid var(--color-border);font-size:var(--font-size-body);background-color:var(--color-surface-page)}.multiselect-search:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.multiselect-list{list-style:none;margin:0;padding:var(--space-1) 0;max-height:240px;overflow-y:auto}.multiselect-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;font-size:var(--font-size-body);color:var(--color-text-primary);transition:background-color var(--transition-fast)}.multiselect-option:hover{background-color:var(--color-surface-hover)}.multiselect-option[aria-selected=true]{background-color:var(--color-info-bg)}.multiselect-option[aria-disabled=true]{opacity:.4;cursor:not-allowed}.multiselect-empty{padding:var(--space-4);text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-body)}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.app-header{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);background-color:var(--color-surface-card);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-xs);position:sticky;top:0;z-index:var(--z-sticky)}.app-sidebar{background-color:#ffffff;border-right:1px solid var(--color-border);padding:var(--space-5) 0;overflow-y:auto;position:sticky;top:0;height:100vh}.app-main{position:relative;padding:28px 32px;overflow-y:auto;background-color:#f5f5f7;animation:fadeIn .3s ease both}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-5);margin:1px var(--space-2);font-size:var(--font-size-body);color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-sm);transition:background-color var(--transition-fast),color var(--transition-fast),font-weight var(--transition-fast);min-height:40px}.nav-item:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.nav-item[aria-current=page]{background-color:#f0faf4;color:#1a6b3a;font-weight:600}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.page-title{font-size:24px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.section-card{background-color:var(--color-surface-card);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.section-title{font-size:var(--font-size-h2);font-weight:var(--font-weight-bold);color:var(--color-text-primary);border-left:4px solid var(--color-primary);padding-left:var(--space-3);margin:0}.kpi-card{background-color:var(--color-surface-card);border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--space-5);text-align:center;display:flex;flex-direction:column;gap:var(--space-2);transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-label{font-size:var(--font-size-caption);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium);letter-spacing:.04em;text-transform:uppercase}.kpi-value{font-size:var(--font-size-h1-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.skeleton{background:linear-gradient(90deg,var(--color-surface-inset) 25%,var(--color-surface-hover) 50%,var(--color-surface-inset) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-text{height:16px;width:100%}.skeleton-title{height:24px;width:60%}.skeleton-card{height:120px;width:100%}.skeleton-list{display:flex;flex-direction:column;gap:var(--space-3)}.auth-page{min-height:100vh;background-color:#fff}.auth-page,.auth-visual{display:flex;position:relative;overflow:hidden}.auth-visual{flex:1;background:linear-gradient(160deg,#0a3d1f,#1a6b3a 40%,#2d9e5f);flex-direction:column;justify-content:center;padding:64px;color:#fff}.auth-visual:after{right:-120px;bottom:-120px;width:400px;height:400px;background:rgba(255,255,255,.04)}.auth-visual:after,.auth-visual:before{content:"";position:absolute;border-radius:50%}.auth-visual:before{left:-80px;top:-80px;width:300px;height:300px;background:rgba(255,255,255,.03)}.auth-visual-tagline{font-size:14px;opacity:.5;letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--space-4)}.auth-visual-title{font-size:42px;font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:var(--space-4);color:#fff}.auth-visual-desc{font-size:18px;opacity:.8;line-height:1.6;max-width:400px}.auth-form-panel{width:480px;display:flex;align-items:center;justify-content:center;padding:48px;background:#fff;flex-shrink:0}.auth-card{background-color:transparent;border-radius:0;box-shadow:none;padding:0;width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--space-6);position:relative;overflow:visible}.auth-card:before{display:none}.auth-card-wide{max-width:400px}.auth-brand{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);text-align:left}.auth-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin:0;letter-spacing:-.02em}.auth-subtitle{font-size:15px;color:#86868b;margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-hint{font-size:var(--font-size-caption);color:#aeaeb2;text-align:center;margin:0}@media (max-width:767px){.auth-page{flex-direction:column}.auth-visual{display:none}.auth-form-panel{width:100%;min-height:100vh;padding:24px}}.onboarding-step-content{background-color:var(--color-surface-page);border-radius:var(--radius-md);padding:var(--space-6);min-height:200px;border:1px solid var(--color-border)}.onboarding-step-title{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-3)}.onboarding-step-desc{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0 0 var(--space-4)}.onboarding-feature-list{list-style:none;padding:0;margin:0 0 var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.onboarding-feature-list li{font-size:var(--font-size-body);color:var(--color-success);font-weight:var(--font-weight-medium)}.onboarding-nav{display:flex;justify-content:space-between;align-items:center}.onboarding-skip{display:flex;justify-content:center;margin-top:var(--space-4)}.onboarding-skip-link{background:none;border:none;padding:var(--space-2) var(--space-4);font-size:var(--font-size-body);color:var(--color-text-tertiary);cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:color var(--transition-fast);border-radius:var(--radius-sm)}.onboarding-skip-link:hover{color:var(--color-text-secondary)}.onboarding-skip-link:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.onboarding-skip-link:disabled{color:var(--color-text-disabled);cursor:not-allowed;text-decoration:none}.onboarding-complete{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);text-align:center;padding:var(--space-8) 0}.onboarding-complete-icon{font-size:64px;line-height:1}.passkey-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.passkey-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background-color:var(--color-surface-page);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.passkey-item:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-xs)}.passkey-info{display:flex;align-items:center;gap:var(--space-3)}.passkey-icon{font-size:24px}.passkey-name{font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin:0}.passkey-meta{font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin:var(--space-1) 0 0}.alert-banner{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-body);margin-bottom:var(--space-4);border:1px solid transparent}.alert-banner-danger{background-color:var(--color-danger-bg);border-color:var(--color-danger-border);color:var(--color-danger)}.alert-banner-warning{background-color:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning)}.alert-banner-success{background-color:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12) var(--space-6);text-align:center}.empty-state-icon{font-size:56px;line-height:1;color:var(--color-text-tertiary);opacity:.7}.empty-state p{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;max-width:320px;line-height:var(--line-height-relaxed)}.exam-shell{display:flex;flex-direction:column;min-height:100dvh;background-color:var(--color-surface-page)}.exam-header{position:sticky;top:0;z-index:var(--z-sticky);background-color:var(--color-surface-card);border-bottom:1px solid var(--color-border);padding:var(--space-3) var(--space-6);display:flex;align-items:center;gap:var(--space-6);box-shadow:var(--shadow-xs)}.exam-brand{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;font-size:var(--font-size-body-lg)}.exam-progress-wrap{flex:1}.exam-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-8) var(--space-4)}.exam-card{background-color:var(--color-surface-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);width:100%;gap:var(--space-6);animation:fadeIn var(--transition-normal) ease}.exam-card,.exam-loading{padding:var(--space-8);max-width:640px;display:flex;flex-direction:column}.exam-loading{gap:var(--space-4);margin:0 auto}.drum-shell{width:100%;overflow:hidden;position:relative;display:flex;flex-direction:column;align-items:center;background:#f5f5f7;touch-action:pan-x;-moz-user-select:none;user-select:none;-webkit-user-select:none;overscroll-behavior-y:none}.drum-shell:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0,rgba(255,255,255,.8),transparent),radial-gradient(ellipse at 80% 20%,rgba(219,234,254,.4),transparent 50%),radial-gradient(ellipse at 20% 80%,rgba(224,231,255,.4),transparent 50%);pointer-events:none;z-index:0}.drum-section-header{position:relative;z-index:20;width:100%;height:44px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:rgba(255,255,255,.8);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(226,232,240,.5);flex-shrink:0}.drum-section-label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.drum-roll-container{position:relative;width:100%;max-width:800px;flex:1;z-index:10;overflow:hidden}.drum-roll-track{position:absolute;top:0;width:100%;display:flex;flex-direction:column;align-items:center;will-change:transform;transition:transform .4s cubic-bezier(.25,1,.5,1)}.drum-item-wrapper{width:100%;display:flex;justify-content:center;padding:4px 16px;transition:height .35s cubic-bezier(.25,1,.5,1),opacity .3s ease,transform .35s cubic-bezier(.25,1,.5,1),filter .3s ease}.drum-item-card{width:100%;max-width:800px;text-align:center;border-radius:24px;transition:all .3s ease;padding:8px;background:transparent;border:1px solid transparent}.drum-item-card-active{background:rgba(255,255,255,.7);box-shadow:0 8px 30px rgba(0,0,0,.05);border-color:rgba(255,255,255,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:16px 24px}.drum-question-text{font-weight:500;line-height:1.6;transition:all .3s ease;font-size:13px;color:#94a3b8;margin:0}.drum-question-text-active{font-size:16px;color:#1e293b}.drum-question-number{display:block;font-size:10px;color:#94a3b8;margin-bottom:4px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.drum-options-container{width:100%;transition:height .3s ease,opacity .3s ease}.drum-options-grid{display:grid;gap:6px;width:100%;padding-top:12px}.drum-option-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 4px;border-radius:12px;border:1px solid rgba(255,255,255,.6);background:rgba(255,255,255,.5);color:#475569;cursor:pointer;transition:all .2s ease;min-height:44px;outline:none}.drum-option-btn:hover:not(:disabled){background:#ffffff;border-color:#e2e8f0;box-shadow:0 2px 8px rgba(0,0,0,.04)}.drum-option-btn-selected{background:#1e293b;border-color:#1e293b;color:#ffffff;box-shadow:0 4px 12px rgba(30,41,59,.2);transform:scale(1.05)}.drum-option-btn-selected:hover:not(:disabled){background:#334155;border-color:#334155}.drum-option-btn:disabled{cursor:not-allowed;opacity:.5}.drum-option-label{font-size:11px;font-weight:500;line-height:1.3;position:relative;z-index:1}.drum-nav-controls{bottom:max(3.5rem,calc(env(safe-area-inset-bottom) + 32px));display:flex;justify-content:center;align-items:center;gap:16px;padding:0 24px}.drum-nav-controls,.drum-save-status{position:absolute;left:0;right:0;z-index:20}.drum-save-status{bottom:max(1rem,env(safe-area-inset-bottom));text-align:center;font-size:12px;font-weight:500;color:#94a3b8;pointer-events:none}.drum-nav-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:9999px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;border:none;min-height:44px}.drum-nav-btn:active:not(:disabled){transform:scale(.95)}.drum-nav-btn:disabled{opacity:.3;pointer-events:none}.drum-nav-btn-prev{background:rgba(255,255,255,.8);backdrop-filter:blur(8px);color:#475569;box-shadow:0 2px 8px rgba(0,0,0,.04);border:1px solid rgba(226,232,240,.5)}.drum-nav-btn-prev:hover:not(:disabled){background:#ffffff;color:#1e293b}.drum-nav-btn-next{background:#1e293b;color:#ffffff;box-shadow:0 4px 12px rgba(30,41,59,.2)}.drum-nav-btn-next:hover:not(:disabled){background:#334155}.exam-main:has(.drum-shell){padding:0;display:block}.drum-complete-btn{display:inline-flex;align-items:center;justify-content:center;padding:16px 48px;border-radius:9999px;font-size:16px;font-weight:700;cursor:pointer;border:none;background:#1a6b3a;color:#ffffff;box-shadow:0 4px 16px rgba(26,107,58,.3);transition:all .2s ease;min-height:52px;min-width:240px}.drum-complete-btn:hover:not(:disabled){background:#155730;box-shadow:0 6px 20px rgba(26,107,58,.4);transform:translateY(-1px)}.drum-complete-btn:active:not(:disabled){transform:scale(.97)}.drum-complete-btn:disabled{opacity:.6;cursor:not-allowed}.messages-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--space-4);height:calc(100vh - 200px);min-height:400px}.messages-sidebar{background-color:var(--color-surface-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow-y:auto;display:flex;flex-direction:column;box-shadow:var(--shadow-xs)}.messages-sidebar-title{font-size:var(--font-size-caption);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:var(--space-4) var(--space-4) var(--space-2);margin:0}.thread-list{list-style:none;padding:0;margin:0}.thread-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;cursor:pointer;text-align:left;font-size:var(--font-size-body);color:var(--color-text-primary);transition:background-color var(--transition-fast);min-height:44px}.thread-item:hover{background-color:var(--color-surface-hover)}.thread-item[data-active=true]{background-color:var(--color-primary-subtle);color:var(--color-primary);font-weight:var(--font-weight-medium)}.thread-avatar{font-size:20px;flex-shrink:0}.thread-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.messages-pane{background-color:var(--color-surface-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xs)}.message-list{flex:1;overflow-y:auto;padding:var(--space-4);list-style:none;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.message-bubble-wrap{display:flex}.message-bubble-wrap[data-self=true]{justify-content:flex-end}.message-bubble{max-width:70%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background-color:var(--color-surface-inset);border:1px solid var(--color-border)}.message-bubble[data-self=true]{background-color:var(--color-primary);color:var(--color-text-inverse);border-color:transparent}.message-text{margin:0;font-size:var(--font-size-body);line-height:var(--line-height-relaxed)}.message-time{font-size:var(--font-size-caption);color:var(--color-text-tertiary);margin-top:var(--space-1);display:block}.message-bubble[data-self=true] .message-time{color:rgba(255,255,255,.65)}.message-compose{padding:var(--space-4);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-3);background-color:var(--color-surface-page)}.message-compose-body{display:flex;flex-direction:column;gap:var(--space-2)}.message-compose-actions{display:flex;align-items:center;gap:var(--space-2);justify-content:flex-end}.message-textarea{flex:1;resize:none;min-height:80px}.attachment-btn{font-size:var(--font-size-body-lg);min-width:44px;min-height:44px;padding:var(--space-2)}.attachment-preview-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-1)}.attachment-preview-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--color-surface-page);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-body)}.attachment-icon{flex-shrink:0;font-size:var(--font-size-body-lg)}.attachment-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-primary);font-size:var(--font-size-body)}.attachment-status{flex-shrink:0;display:inline-flex;align-items:center;font-size:var(--font-size-caption);font-weight:var(--font-weight-medium)}.attachment-status-uploading{color:var(--color-text-secondary)}.attachment-status-done{color:var(--color-success)}.attachment-status-error{color:var(--color-danger)}.attachment-remove{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);font-size:var(--font-size-body-lg);line-height:1;padding:0;min-width:24px;min-height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.attachment-remove:hover{color:var(--color-danger);background-color:var(--color-danger-bg)}.messages-empty{background-color:var(--color-surface-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);font-size:48px;color:var(--color-text-tertiary)}.messages-empty p{font-size:var(--font-size-body)}@media (max-width:768px){.messages-layout{grid-template-columns:1fr;height:auto}.result-score-display{flex-direction:column;text-align:center}}.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-12) var(--space-8);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast);text-align:center;background-color:var(--color-surface-card)}.drop-zone:focus-visible,.drop-zone:hover{border-color:var(--color-primary);background-color:var(--color-primary-subtle);box-shadow:var(--shadow-focus);outline:none}.drop-zone-icon{font-size:48px;line-height:1;opacity:.6}.drop-zone-title{font-size:var(--font-size-body-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin:0}.drop-zone-sub{font-size:var(--font-size-body);color:var(--color-text-tertiary);margin:0}@media (max-width:1024px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}.dept-progress-item{grid-template-columns:120px 1fr}}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr 1fr}}.filter-chip{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);border:1px solid var(--color-border);background-color:var(--color-surface-card);color:var(--color-text-secondary);font-size:var(--font-size-caption);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);min-height:32px}.filter-chip:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-strong);color:var(--color-text-primary)}.filter-chip-active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.filter-chip-active:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);color:var(--color-text-inverse)}.confidential-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-45deg);z-index:0;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap;font-size:3rem;font-weight:700;color:#0f172a;opacity:.08}.confidential-watermark:before{content:"CONFIDENTIAL 社外秘"}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.z-50{z-index:50}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.ml-2{margin-left:var(--space-2)}.ml-4{margin-left:var(--space-4)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.table-row{display:table-row}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-4{height:var(--space-4)}.h-6{height:var(--space-6)}.h-full{height:100%}.max-h-48{max-height:12rem}.min-h-64{min-height:16rem}.min-h-96{min-height:24rem}.w-4{width:var(--space-4)}.w-6{width:var(--space-6)}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content: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)}.gap-6{gap:var(--space-6)}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(var(--space-2) * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(var(--space-2) * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(var(--space-3) * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(var(--space-3) * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(var(--space-4) * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(var(--space-4) * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-sm{border-radius:var(--radius-sm)}.border{border-width:1px}.border-2{border-width:2px}.border-dashed{border-style:dashed}.border-\[var\(--border-default\)\]{border-color:var(--border-default)}.bg-\[var\(--surface-secondary\)\]{background-color:var(--surface-secondary)}.p-3{padding:var(--space-3)}.pt-4{padding-top:var(--space-4)}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.italic{font-style:italic}.text-\[var\(--color-danger\)\]{color:var(--color-danger)}.text-\[var\(--color-primary\)\]{color:var(--color-primary)}.text-\[var\(--text-primary\)\]{color:var(--text-primary)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-\[var\(--text-tertiary\)\]{color:var(--text-tertiary)}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}[data-theme=dark]{--color-primary:#6b8aff;--color-primary-hover:#8aa0ff;--color-primary-active:#4f6ef7;--color-primary-subtle:#1a2040;--color-surface-page:#111318;--color-surface-card:#1c1f27;--color-surface-inset:#252a35;--color-surface-hover:#1e2330;--color-surface-primary:#1c1f27;--color-surface-secondary:#111318;--color-surface-tertiary:#252a35;--color-text-primary:#e8eaf0;--color-text-secondary:#8a9ab0;--color-text-tertiary:#5a6880;--color-text-inverse:#111318;--color-text-disabled:#3a4455;--color-border:#2a2f3d;--color-border-strong:#3d4558;--color-border-default:#2a2f3d;--color-success-bg:#0a2318;--color-warning-bg:#1c1200;--color-danger-bg:#1c0808;--color-info-bg:#0a1530;--color-semantic-success-bg:#0a2318;--color-semantic-warning-bg:#1c1200;--color-semantic-danger-bg:#1c0808;--color-semantic-info-bg:#0a1530}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes slideInRight{0%{transform:translateX(calc(100% + var(--space-6)));opacity:0}to{transform:translateX(0);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width:767px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr}.app-sidebar{display:none;position:fixed;top:0;left:0;width:280px;height:100vh;z-index:300;box-shadow:var(--shadow-lg);animation:slideInLeft .25s ease}.app-sidebar[data-open=true]{display:flex;flex-direction:column}.mobile-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-surface-card);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:200;min-height:56px}.mobile-header-brand{display:flex;align-items:center;gap:var(--space-2);flex:1}.mobile-header-brand-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);background-color:#1a6b3a;color:#ffffff;font-size:12px;font-weight:700;flex-shrink:0}.mobile-header-brand-name{font-size:15px;font-weight:600;color:var(--color-text-primary)}.hamburger-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:24px;transition:background-color var(--transition-fast);flex-shrink:0}.hamburger-btn:hover{background-color:var(--color-surface-hover)}.sidebar-backdrop{display:block;position:fixed;inset:0;background-color:rgba(0,0,0,.4);z-index:299;animation:fadeIn .2s ease}.app-main{padding:var(--space-4);min-height:100dvh}.toast-container{left:var(--space-4);right:var(--space-4);bottom:var(--space-4)}}@media (min-width:768px){.mobile-header,.sidebar-backdrop{display:none}.drum-question-text{font-size:15px}.drum-question-text-active{font-size:18px}.drum-option-label{font-size:13px}.drum-item-card-active{padding:20px 32px}.drum-options-grid{gap:12px}.drum-section-label{font-size:13px}.drum-section-counter{font-size:14px}}@media (min-width:768px) and (max-width:1024px){.app-shell{grid-template-columns:64px 1fr}.app-sidebar{width:64px;padding:var(--space-3) 0;transition:width .2s ease;overflow:visible}.sidebar-brand{justify-content:center;padding:var(--space-2)}.sidebar-brand-name{display:none}.nav-item{justify-content:center;padding:var(--space-2);margin:1px var(--space-1)}.nav-item span{display:none}.app-sidebar:hover{width:240px;z-index:250;position:fixed;top:0;left:0;height:100vh;box-shadow:var(--shadow-lg)}.app-sidebar:hover .sidebar-brand-name{display:block}.app-sidebar:hover .nav-item,.app-sidebar:hover .sidebar-brand{justify-content:flex-start;padding:var(--space-2) var(--space-5)}.app-sidebar:hover .nav-item{margin:1px var(--space-2)}.app-sidebar:hover .nav-item span{display:inline}.app-main{padding:var(--space-5) var(--space-5)}}@keyframes slideInLeft{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@media print{.no-print,[data-sidebar],[data-testid=consent-no],[data-testid=consent-yes],aside,nav{display:none!important}body{background-color:white;color:black;font-size:12pt}.app-main{padding:0;max-width:100%}.card{border:1px solid #ccc;-moz-column-break-inside:avoid;break-inside:avoid;margin-bottom:16pt}.page-title{font-size:18pt;margin-bottom:12pt}.result-axis-fill,.result-score-circle{-webkit-print-color-adjust:exact;print-color-adjust:exact}}@media (min-width:320px){.exam-shell{min-height:100dvh}.exam-main{padding:var(--space-4) var(--space-3);align-items:stretch}.exam-main:has(.drum-shell){padding:0}.exam-card{padding:var(--space-5) var(--space-4);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.exam-option{min-height:52px;padding:var(--space-4) var(--space-4)}.examinee-main,.examinee-page .app-main,[data-page=examinee] .app-main{padding:var(--space-4) var(--space-3);min-height:100dvh}}@media (min-width:768px){.exam-main{padding:var(--space-8) var(--space-4);align-items:flex-start}.exam-card{padding:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.exam-option{min-height:44px}}@media (max-width:767px){[data-testid=horizontal-bar-chart]>div{grid-template-columns:1fr!important;gap:var(--space-2)!important}[data-testid=sub-scores]{grid-template-columns:1fr!important}[data-testid=contact-section],[data-testid=result-guide-section],[data-testid=result-overview-section],[data-testid^=result-detail-section-]{padding:var(--space-4)!important}[data-testid=result-page] a,[data-testid=result-page] button{min-height:44px;min-width:44px}[data-testid=result-page]{overflow-x:hidden;max-width:100vw}[data-testid=scale-legend]{flex-wrap:wrap;justify-content:center}}[data-testid=result-page]{font-size:max(12px,var(--font-size-body))}@media (max-width:767px){nav[aria-label="メインナビゲーション"] [role=list]{grid-template-columns:1fr!important}nav[aria-label="メインナビゲーション"]{padding:var(--space-4)!important}}@media (min-width:768px) and (max-width:1023px){nav[aria-label="メインナビゲーション"] [role=list]{grid-template-columns:repeat(2,1fr)!important}}@media (max-width:767px){header[role=banner][aria-label="アプリケーションヘッダー"]{padding:0 var(--space-3)!important}header[role=banner][aria-label="アプリケーションヘッダー"] .header-page-title{display:none}}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-\[var\(--color-primary\)\]:focus{--tw-ring-color:var(--color-primary)}@media (min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}