.sidebar{width:240px;background-color:var(--color-bg-elevated);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0;position:relative}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-border),transparent)}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.sidebar-logo{display:flex;align-items:baseline;gap:var(--spacing-xs)}.sidebar-logo__mark{font-size:var(--font-size-xl);font-weight:900;background:linear-gradient(135deg,var(--color-accent),var(--color-purple),var(--color-emerald));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.sidebar-logo__studio{font-size:var(--font-size-sm);font-weight:300;color:var(--color-text-secondary);letter-spacing:.04em}.sidebar-nav{flex:1;padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;overflow-y:auto;scrollbar-width:thin;scrollbar-color:transparent transparent}.sidebar-nav:hover{scrollbar-color:var(--color-bg-surface) transparent}.sidebar-group-label{font-size:.6875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;padding:var(--spacing-md) var(--spacing-md) var(--spacing-xs);margin-top:var(--spacing-sm)}.sidebar-group:first-child .sidebar-group-label{margin-top:0}.sidebar-group-label:empty{display:none}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary);text-decoration:none;transition:transform var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast);min-height:44px}.sidebar-link:hover{transform:translate(2px);background-color:var(--color-bg-surface);color:var(--color-text-primary);text-decoration:none}.sidebar-link--active{background-color:#3b82f614;color:var(--color-accent);border-left:3px solid var(--color-accent);padding-left:calc(var(--spacing-md) - 3px)}.sidebar-link--active:hover{transform:none;background-color:#3b82f61f;color:var(--color-accent)}.sidebar-link-icon{width:18px;height:18px;flex-shrink:0}.sidebar-link-label{font-size:.875rem;font-weight:500}.sidebar-theme-toggle{display:flex;gap:2px;padding:2px;background-color:var(--color-bg-surface);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.sidebar-theme-btn{display:flex;align-items:center;justify-content:center;gap:4px;flex:1;padding:6px;min-height:32px;min-width:auto;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.6875rem;cursor:pointer;transition:all var(--transition-fast)}.sidebar-theme-btn:hover{color:var(--color-text-primary);background:none}.sidebar-theme-btn--active{background-color:var(--color-bg-elevated);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.sidebar-theme-btn--active:hover{background-color:var(--color-bg-elevated)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border)}.sidebar-cost{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-surface);border-radius:var(--radius-md);text-decoration:none;min-height:44px}.sidebar-cost:hover{text-decoration:none;background-color:var(--color-border)}.sidebar-cost-label{font-size:.75rem;color:var(--color-text-secondary)}.sidebar-cost-value{font-size:.875rem;font-weight:600;color:var(--color-success)}.sidebar-cost-progress{width:100%;height:3px;background-color:var(--color-bg-surface);border-radius:2px;margin-top:var(--spacing-xs);overflow:hidden}.sidebar-cost-progress-fill{height:100%;background:var(--color-success);border-radius:2px;transition:width var(--transition-normal)}.sidebar-cost-progress-fill--warning{background:var(--color-warning)}.sidebar-cost-progress-fill--danger{background:var(--color-error)}@media(max-width:1024px){.sidebar{width:200px}}@media(max-width:768px){.sidebar{width:60px;overflow:hidden}.sidebar-logo__studio{display:none}.sidebar-logo__mark{font-size:var(--font-size-lg)}.sidebar-header-title,.sidebar-link-label,.sidebar-group-label,.sidebar-cost-label,.sidebar-cost-value{display:none}.sidebar-link{justify-content:center;padding:var(--spacing-sm)}.sidebar-link--active{border-left:none;padding-left:var(--spacing-sm);border-bottom:2px solid var(--color-accent)}.sidebar-link-icon{width:20px;height:20px}.sidebar-cost{justify-content:center;padding:var(--spacing-sm)}.sidebar-cost-progress,.sidebar-reset-btn .sidebar-link-label{display:none}.sidebar-theme-toggle{flex-direction:column}.sidebar-theme-btn .sidebar-link-label{display:none}}.sidebar-reset-btn{display:flex;align-items:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-xs) var(--spacing-md);margin-top:var(--spacing-sm);background:none;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.75rem;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.sidebar-reset-btn:hover{color:var(--color-error);border-color:var(--color-error)}.sidebar-reset-confirm{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--color-bg-surface);border:1px solid var(--color-error);border-radius:var(--radius-sm);text-align:center}.sidebar-reset-confirm p{font-size:.75rem;color:var(--color-error);margin-bottom:var(--spacing-xs)}.sidebar-reset-actions{display:flex;gap:var(--spacing-xs);justify-content:center}.sidebar-reset-yes{padding:4px 12px;background-color:var(--color-error);color:var(--color-text-on-accent, #fff);border:none;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer}.sidebar-reset-no{padding:4px 12px;background-color:var(--color-bg-elevated);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer}.sidebar-project-name{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-project-dot{width:6px;height:6px;border-radius:50%;background:var(--color-success);flex-shrink:0}.sidebar-logout-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-tertiary, var(--color-text-secondary));cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast);margin-top:var(--spacing-xs)}.sidebar-logout-btn:hover{color:var(--color-error)}.toast-container{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);z-index:1100;display:flex;flex-direction:column-reverse;gap:var(--spacing-sm);pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0006;min-width:280px;max-width:400px;animation:toast-enter .25s ease-out}@keyframes toast-enter{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-exit{animation:toast-exit .2s ease-in forwards}@keyframes toast-exit{to{opacity:0;transform:translate(100%)}}.toast--success{border-left:3px solid var(--color-success)}.toast--error{border-left:3px solid var(--color-error)}.toast--warning{border-left:3px solid var(--color-warning)}.toast--info{border-left:3px solid var(--color-accent)}.toast__icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;border-radius:50%}.toast__icon--success{color:var(--color-success)}.toast__icon--error{color:var(--color-error)}.toast__icon--warning{color:var(--color-warning)}.toast__icon--info{color:var(--color-accent)}.toast__message{flex:1;font-size:.875rem;line-height:1.5;color:var(--color-text-primary)}.toast__close{flex-shrink:0;min-height:28px;min-width:28px;padding:0;background:transparent;color:var(--color-text-secondary);font-size:16px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.toast__close:hover{color:var(--color-text-primary);background-color:var(--color-bg-surface)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background-color:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:modal-fade-in var(--transition-normal) forwards}.modal-container{position:relative;background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:min(90vw,520px);max-height:85vh;overflow-y:auto;padding:var(--spacing-lg);animation:modal-slide-up var(--transition-normal) forwards}.modal-container-sm{width:min(90vw,400px)}.modal-container-lg{width:min(90vw,720px)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.modal-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-height:44px;min-width:44px;padding:0;background:transparent;color:var(--color-text-secondary);font-size:1.25rem;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.modal-close:hover{color:var(--color-text-primary);background-color:var(--color-bg-surface)}.modal-body{color:var(--color-text-secondary);line-height:1.7}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);margin-top:var(--spacing-md)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.gcf-message{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.7;word-break:keep-all;margin-bottom:var(--spacing-md)}.gcf-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.layout{display:flex;min-height:100vh}@keyframes content-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.layout-main{flex:1;padding:var(--spacing-lg);overflow-y:auto;animation:content-enter .3s cubic-bezier(.34,1.56,.64,1)}@media(max-width:1024px){.layout-main{padding:var(--spacing-md)}}@media(max-width:768px){.layout-main{padding:var(--spacing-sm)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg);position:relative;overflow:hidden}.login-bg-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.15;pointer-events:none}.login-bg-orb--1{width:600px;height:600px;background:var(--color-accent);top:-200px;right:-100px}.login-bg-orb--2{width:400px;height:400px;background:var(--color-purple);bottom:-150px;left:-100px}.login-bg-orb--3{width:300px;height:300px;background:var(--color-emerald);top:50%;left:50%;transform:translate(-50%,-50%)}.login-container{display:grid;grid-template-columns:1fr 1fr;max-width:960px;width:90vw;min-height:560px;background:var(--color-surface, var(--color-bg-elevated));border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;position:relative;z-index:1}@media(max-width:768px){.login-container{grid-template-columns:1fr;max-width:420px}.login-brand{display:none}}.login-brand{display:flex;flex-direction:column;justify-content:space-between;padding:var(--spacing-xl);background:linear-gradient(135deg,var(--color-primary-bg, rgba(59, 130, 246, .08)),var(--color-purple-bg, rgba(147, 51, 234, .08)));border-right:1px solid var(--color-border)}.login-brand__top{display:flex;flex-direction:column;gap:var(--spacing-sm)}.login-logo{display:flex;align-items:baseline;gap:var(--spacing-sm)}.login-logo__mark{display:flex;gap:1px}.login-logo__letter{font-size:var(--font-size-3xl);font-weight:900;letter-spacing:-.04em;line-height:1}.login-logo__letter--a{color:var(--color-accent)}.login-logo__letter--c{color:var(--color-purple)}.login-logo__letter--p{color:var(--color-emerald)}.login-logo__text{font-size:var(--font-size-xl);font-weight:300;color:var(--color-text-secondary);letter-spacing:.05em}.login-tagline{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500;letter-spacing:.02em}.login-acp-meaning{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.login-acp-meaning strong{color:var(--color-accent);font-weight:700}.login-acp-dot{color:var(--color-text-tertiary, var(--color-text-secondary));opacity:.5}.login-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.7;word-break:keep-all;margin-top:var(--spacing-xs)}.login-features{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.login-feature{display:flex;align-items:flex-start;gap:var(--spacing-xs);padding:var(--spacing-sm);border-radius:var(--radius-md);background:var(--color-surface-hover, rgba(255, 255, 255, .03))}.login-feature__icon{font-size:var(--font-size-lg);flex-shrink:0}.login-feature__title{display:block;font-size:var(--font-size-xs);font-weight:700;color:var(--color-text, var(--color-text-primary))}.login-feature__desc{display:block;font-size:var(--font-size-2xs);color:var(--color-text-tertiary, var(--color-text-secondary))}.login-version{font-size:var(--font-size-2xs);color:var(--color-text-tertiary, var(--color-text-secondary));text-align:center;margin-top:var(--spacing-md)}.login-form-area{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.login-form{width:100%;max-width:320px;display:flex;flex-direction:column;gap:var(--spacing-lg)}.login-form--shake{animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.login-form__header h2{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text, var(--color-text-primary));margin-bottom:var(--spacing-xs)}.login-form__header p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.login-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.login-field label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text, var(--color-text-primary))}.login-field input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text, var(--color-text-primary));font-size:var(--font-size-base);min-height:44px;transition:border-color var(--transition-fast)}.login-field input:focus{border-color:var(--color-accent);outline:2px solid var(--color-accent);outline-offset:1px}.login-field input::placeholder{color:var(--color-text-tertiary, var(--color-text-secondary))}.login-error{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-error-bg, rgba(239, 68, 68, .1));border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm)}.login-submit{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-sm) var(--spacing-md);min-height:44px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:700;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.login-submit:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px)}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-success{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-success-bg, rgba(34, 197, 94, .1));border:1px solid var(--color-success);border-radius:var(--radius-md);color:var(--color-success);font-size:var(--font-size-sm)}.login-switch{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.login-switch__btn{color:var(--color-accent);font-weight:700;font-size:var(--font-size-sm);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.login-switch__btn:hover{color:var(--color-accent-hover)}.login-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-loading .btn-loading-spinner{width:32px;height:32px;border-width:3px;color:var(--color-accent)}.project-guard-banner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:3rem 2rem;text-align:center;max-width:500px;margin:4rem auto}.project-guard-banner p{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.7;word-break:keep-all}.project-guard-banner strong{color:var(--color-primary)}.project-guard-btn{padding:.625rem 1.25rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer}.project-guard-btn:hover{background:var(--color-primary-hover)}.project-guard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:4rem 2rem;color:var(--color-text-secondary);font-size:var(--font-size-sm)}/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:"Pretendard", "Noto Sans KR", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-amber-50:oklch(98.7% .022 95.277);--color-amber-500:oklch(76.9% .188 70.08);--color-amber-600:oklch(66.6% .179 58.318);--color-emerald-50:oklch(97.9% .021 166.113);--color-emerald-500:oklch(69.6% .17 162.48);--color-emerald-600:oklch(59.6% .145 163.225);--color-blue-50:oklch(97% .014 254.604);--color-blue-600:oklch(54.6% .245 262.881);--color-blue-700:oklch(48.8% .243 264.376);--color-blue-800:oklch(42.4% .199 265.638);--color-violet-100:oklch(94.3% .029 294.588);--color-violet-600:oklch(54.1% .281 293.009);--color-violet-700:oklch(49.1% .27 292.581);--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg:#0f0f0f;--color-bg-elevated:#1a1a1a;--color-bg-surface:#242424;--color-border:#333;--color-text-primary:#fafafa;--color-text-secondary:#b0b0b0;--color-accent:#3b82f6;--color-accent-hover:#2563eb;--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--color-orange:#f97316;--color-purple:#8b5cf6;--color-pink:#ec4899;--color-teal:#06b6d4;--color-emerald:#10b981}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.row-1{grid-row:1}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);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,)}.sepia{--tw-sepia:sepia(100%);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,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-bg-surface) 25%,var(--color-shimmer,#ffffff0f) 50%,var(--color-bg-surface) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{border-radius:var(--radius-sm);height:1em;margin-bottom:.5em}.skeleton-text:last-child{width:60%}.skeleton-rect{border-radius:var(--radius-md);width:100%}.skeleton-circle{border-radius:50%}.empty-state{padding:var(--spacing-xl) var(--spacing-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:200px;display:flex}.empty-state-icon{margin-bottom:var(--spacing-md);opacity:.4;font-size:3rem}.empty-state-title{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1.125rem;font-weight:600}.empty-state-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);max-width:320px;font-size:.875rem;line-height:1.7}.form-field{gap:var(--spacing-xs);flex-direction:column;display:flex}.form-field-label{color:var(--color-text-secondary);align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-weight:500;display:flex}.form-field-required{color:var(--color-error);font-weight:600}.form-field-error input,.form-field-error textarea,.form-field-error select{border-color:var(--color-error)!important}.form-field-error-message{color:var(--color-error);align-items:center;gap:4px;font-size:.75rem;display:flex}.form-field-hint{color:var(--color-text-secondary);font-size:.75rem}.form-field-char-count{color:var(--color-text-secondary);text-align:right;font-size:.75rem}.form-field-char-count--warning{color:var(--color-warning)}.form-field-char-count--error{color:var(--color-error)}.section-card{background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg)}.section-card:hover{border-color:var(--color-border-hover,#ffffff1a)}.progress-bar{background-color:var(--color-bg-surface);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover));height:100%;transition:width var(--transition-normal);border-radius:3px}@keyframes reveal-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.reveal-enter{animation:reveal-up var(--transition-normal) ease-out forwards}.reveal-stagger>*{opacity:0;animation:reveal-up var(--transition-normal) ease-out forwards}.reveal-stagger>:first-child{animation-delay:0s}.reveal-stagger>:nth-child(2){animation-delay:60ms}.reveal-stagger>:nth-child(3){animation-delay:.12s}.reveal-stagger>:nth-child(4){animation-delay:.18s}.reveal-stagger>:nth-child(5){animation-delay:.24s}.reveal-stagger>:nth-child(6){animation-delay:.3s}@keyframes ripple{to{opacity:0;transform:scale(2.5)}}.btn-ripple{position:relative;overflow:hidden}.btn-ripple:after{content:"";opacity:1;background:radial-gradient(circle,#fff3,#0000 70%);position:absolute;top:0;right:0;bottom:0;left:0;transform:scale(0)}.btn-ripple:active:after{animation:.4s ease-out ripple}:root{--color-bg:#0f0f0f;--color-bg-elevated:#1a1a1a;--color-bg-surface:#242424;--color-border:#333;--color-text-primary:#fafafa;--color-text-secondary:#b0b0b0;--color-accent:#3b82f6;--color-accent-hover:#2563eb;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-bg:#3b82f614;--color-success-bg:#22c55e1a;--color-error-bg:#ef44441a;--color-warning-bg:#f59e0b1a;--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--font-sans:"Pretendard", "Noto Sans KR", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--font-size-2xs:.625rem;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.875rem;--font-size-lg:1rem;--font-size-xl:1.125rem;--font-size-2xl:1.25rem;--font-size-3xl:1.5rem;--spacing-2xs:2px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--bp-sm:640px;--bp-md:768px;--bp-lg:1024px;--bp-xl:1280px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-xl:0 16px 48px #0009, 0 0 0 1px #ffffff0d;--transition-fast:.15s ease;--transition-normal:.25s ease;--color-orange:#f97316;--color-orange-hover:#ea580c;--color-orange-bg:#f973161a;--color-purple:#8b5cf6;--color-purple-hover:#7c3aed;--color-purple-bg:#8b5cf61a;--color-pink:#ec4899;--color-pink-bg:#ec48991a;--color-teal:#06b6d4;--color-teal-bg:#06b6d41a;--color-emerald:#10b981;--color-emerald-bg:#10b9811a;--color-surface:var(--color-bg-elevated);--color-surface-raised:#222;--color-surface-sunken:#111;--color-surface-hover:#2a2a2a;--color-text:var(--color-text-primary);--color-text-tertiary:#666;--color-primary-alpha:#3b82f614;--color-purple-subtle:#8b5cf61f;--color-cyan:#06b6d4;--color-cyan-subtle:#06b6d41f;--color-yellow-subtle:#f59e0b1f;--color-yellow-text:#eab308;--color-success-subtle:#22c55e1f;--shadow-glow-accent:0 0 20px #3b82f626;--shadow-glow-success:0 0 20px #22c55e26;--transition-slow:.4s ease;--transition-spring:.3s cubic-bezier(.34, 1.56, .64, 1)}[data-theme=light]{--color-bg:#fafafa;--color-bg-elevated:#fff;--color-bg-surface:#f1f5f9;--color-border:#e2e8f0;--color-text-primary:#0f172a;--color-text-secondary:#64748b;--color-accent:#2563eb;--color-accent-hover:#1d4ed8;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-bg:#2563eb0f;--color-success-bg:#16a34a14;--color-error-bg:#dc26260f;--color-warning-bg:#d9770614;--color-success:#16a34a;--color-warning:#d97706;--color-error:#dc2626;--color-orange:#ea580c;--color-orange-hover:#c2410c;--color-orange-bg:#ea580c14;--color-purple:#7c3aed;--color-purple-hover:#6d28d9;--color-purple-bg:#7c3aed14;--color-pink:#db2777;--color-pink-bg:#db277714;--color-teal:#0891b2;--color-teal-bg:#0891b214;--color-emerald:#059669;--color-emerald-bg:#05966914;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001a;--shadow-xl:0 16px 48px #0000001f;--shadow-glow-accent:0 0 20px #2563eb1a;--shadow-glow-success:0 0 20px #16a34a1a;--color-surface:var(--color-bg-elevated);--color-surface-raised:#f8fafc;--color-surface-sunken:#e2e8f0;--color-surface-hover:#f1f5f9;--color-text:var(--color-text-primary);--color-text-tertiary:#94a3b8;--color-primary-alpha:#2563eb0f;--color-purple-subtle:#7c3aed14;--color-cyan:#0891b2;--color-cyan-subtle:#0891b214;--color-yellow-subtle:#d9770614;--color-yellow-text:#a16207;--color-success-subtle:#16a34a14;--color-shimmer:#0000000a;--color-border-hover:#0000001a;--color-text-on-accent:#fff}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text-primary);letter-spacing:-.02em;word-break:keep-all;line-height:1.7}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-weight:600;line-height:1.3}button{cursor:pointer;color:inherit;font-family:inherit;font-size:inherit;transition:background-color var(--transition-fast),color var(--transition-fast);background:0 0;border:none;padding:0}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);background:var(--color-accent);color:#fff;min-height:36px;font-size:var(--font-size-sm);font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--color-accent-hover)}.btn-secondary{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface,var(--color-bg-elevated));min-height:36px;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;display:inline-flex}.btn-secondary:hover{border-color:var(--color-accent);color:var(--color-text,var(--color-text-primary))}.btn-ghost{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);min-height:36px;color:var(--color-text-secondary);font-size:var(--font-size-sm);background:0 0;font-weight:500;display:inline-flex}.btn-ghost:hover{background:var(--color-surface-hover,var(--color-bg-surface))}.btn-danger{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);background:var(--color-error);color:#fff;min-height:36px;font-size:var(--font-size-sm);font-weight:600;display:inline-flex}.btn-danger:hover{opacity:.9}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);min-height:28px;font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);min-height:44px;font-size:var(--font-size-base)}.btn-loading-spinner{border:2px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}.btn-loading-spinner--sm{width:12px;height:12px}@keyframes spin{to{transform:rotate(360deg)}}input,textarea,select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface);color:var(--color-text-primary);min-height:44px;font-family:inherit;font-size:1rem}input:focus,textarea:focus,select:focus{outline:2px solid var(--color-accent);outline-offset:2px}button:focus-visible,a:focus-visible,[role=tab]:focus-visible,[role=switch]:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}.loading-fallback{justify-content:center;align-items:center;min-height:200px;display:flex}.loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.module-header-row{align-items:center;gap:var(--spacing-md);display:flex}.module-reset-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;align-items:center;gap:4px;min-width:auto;min-height:32px;padding:6px 12px;font-size:.75rem;display:flex}.module-reset-btn:hover{border-color:var(--color-error);color:var(--color-error);background:var(--color-error-bg)}.module-reset-btn:disabled{opacity:.4;cursor:not-allowed}.module-reset-btn:disabled:hover{border-color:var(--color-border);color:var(--color-text-secondary);background:0 0}.history-panel{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-top:var(--spacing-md)}.history-panel-header{cursor:pointer;padding-bottom:var(--spacing-sm);justify-content:space-between;align-items:center;display:flex}.history-panel-title{color:var(--color-text-primary);font-size:.875rem;font-weight:600}.history-panel-count{color:var(--color-text-secondary);font-size:.75rem}.history-list{gap:var(--spacing-xs);flex-direction:column;max-height:300px;display:flex;overflow-y:auto}.history-item{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-surface);border-radius:var(--radius-sm);transition:border-color var(--transition-fast);border:1px solid #0000;justify-content:space-between;align-items:center;display:flex}.history-item:hover{border-color:var(--color-border)}.history-item--active{border-color:var(--color-accent)}.history-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.history-item-title{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;overflow:hidden}.history-item-meta{color:var(--color-text-secondary);font-size:.6875rem}.history-item-actions{gap:var(--spacing-xs);flex-shrink:0;display:flex}.history-item-load{background:var(--color-primary-bg);color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-sm);cursor:pointer;min-width:auto;min-height:auto;padding:4px 8px;font-size:.6875rem}.history-item-delete{color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #0000;min-width:auto;min-height:auto;padding:4px 6px;font-size:.6875rem}.history-item-delete:hover{color:var(--color-error);border-color:var(--color-error)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
