*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-size-adjust:100%}body{min-height:100vh;line-height:1.5}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}button{cursor:pointer;border:none;background:none}a{text-decoration:none;color:inherit}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{font-weight:inherit;font-size:inherit}:root{--color-bg: #fafafa;--color-surface: #ffffff;--color-surface-muted: #f5f5f5;--color-border: #eaeaea;--color-border-strong: #dadada;--color-text-main: #1f1f1f;--color-text-secondary: #3b3b3b;--color-text-muted: #6d6d6d;--color-text-inverse: #ffffff;--color-primary: #2f7d4b;--color-primary-hover: #3fa15f;--color-primary-soft: #eaf7f0;--color-primary-softer: #f5fbf8;--color-success: #2f7d4b;--color-success-soft: #eaf7f0;--color-error: #c62828;--color-error-soft: #fdecec;--color-warning: #e68619;--color-warning-soft: #fff4e1;--color-info: #5142df;--color-info-soft: #f3f1ff;--color-neutral: #3b3b3b;--color-neutral-soft: #f5f5f5;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-soft: 0 8px 16px rgba(15, 23, 42, .08);--shadow-md: 0 4px 12px rgba(15, 23, 42, .1);--shadow-sm: 0 2px 8px rgba(15, 23, 42, .06);--shadow-focus: 0 0 0 3px var(--color-primary-soft);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--font-family-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}[data-theme=dark]{--color-bg: #050816;--color-surface: #0b1120;--color-surface-muted: #020617;--color-border: #1e293b;--color-border-strong: #334155;--color-neutral-soft: #020617;--color-text-main: #e5e7eb;--color-text-secondary: #d1d5db;--color-text-muted: #9ca3af;--color-text-inverse: #050816;--color-primary: #3fa15f;--color-primary-hover: #4bb973;--color-primary-soft: #1a3828;--color-primary-softer: #0f2318;--color-success: #3fa15f;--color-success-soft: #1a3828;--color-error: #ef4444;--color-error-soft: #3f1515;--color-warning: #f59e0b;--color-warning-soft: #3f2a0b;--color-info: #6366f1;--color-info-soft: #1e1b3f;--shadow-soft: 0 8px 16px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-focus: 0 0 0 3px var(--color-primary-soft)}html{transition:background-color var(--transition-base),color var(--transition-base)}body{font-family:var(--font-family-sans);font-size:var(--font-size-sm);line-height:1.6;color:var(--color-text-main);background-color:var(--color-bg)}h1,.h1{font-size:var(--font-size-3xl);font-weight:600;line-height:1.2;color:var(--color-text-main);margin-bottom:var(--spacing-md)}h2,.h2{font-size:var(--font-size-2xl);font-weight:600;line-height:1.3;color:var(--color-text-main);margin-bottom:var(--spacing-md)}h3,.h3{font-size:var(--font-size-xl);font-weight:600;line-height:1.4;color:var(--color-text-main);margin-bottom:var(--spacing-sm)}h4,.h4{font-size:var(--font-size-lg);font-weight:600;line-height:1.4;color:var(--color-text-main);margin-bottom:var(--spacing-sm)}h5,.h5{font-size:var(--font-size-base);font-weight:600;line-height:1.5;color:var(--color-text-main);margin-bottom:var(--spacing-sm)}h6,.h6{font-size:var(--font-size-sm);font-weight:600;line-height:1.5;color:var(--color-text-main);margin-bottom:var(--spacing-sm)}p{margin-bottom:var(--spacing-md)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-normal{font-weight:400}.text-medium{font-weight:500}.text-semibold{font-weight:600}.text-bold{font-weight:700}.text-main{color:var(--color-text-main)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-inverse{color:var(--color-text-inverse)}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-uppercase{text-transform:uppercase}.text-lowercase{text-transform:lowercase}.text-capitalize{text-transform:capitalize}.text-underline{text-decoration:underline}.text-no-underline{text-decoration:none}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--color-primary-hover)}code{font-family:Fira Code,Courier New,monospace;font-size:.9em;background-color:var(--color-surface-muted);padding:2px 6px;border-radius:var(--radius-xs);color:var(--color-text-main)}pre{background-color:var(--color-surface-muted);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto;margin-bottom:var(--spacing-md)}pre code{background:none;padding:0}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--spacing-md)}@media (min-width: 1024px){.container{padding:0 var(--spacing-lg)}}.container--narrow{max-width:960px}.container--wide{max-width:1536px}.page{min-height:100vh;padding:var(--spacing-lg)}@media (min-width: 768px){.page{padding:var(--spacing-xl)}}.app-shell{display:flex;height:100vh;background-color:var(--color-bg)}.app-shell__sidebar{width:250px;height:100vh;background-color:var(--color-surface);border-right:1px solid var(--color-border);flex-shrink:0;transition:transform .3s ease;overflow-y:auto}.app-shell__sidebar::-webkit-scrollbar{width:8px;height:8px}.app-shell__sidebar::-webkit-scrollbar-track{background:var(--color-surface-muted);border-radius:var(--radius-sm)}.app-shell__sidebar::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm)}.app-shell__sidebar::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media (max-width: 768px){.app-shell__sidebar{position:fixed;top:0;left:0;bottom:0;z-index:1000;transform:translate(-100%);box-shadow:var(--shadow-lg)}.app-shell__sidebar.app-shell__sidebar--open{transform:translate(0)}}.app-shell__sidebar-overlay{display:none}@media (max-width: 768px){.app-shell__sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999;animation:fadeIn .3s ease}}.app-shell__main{flex:1;display:flex;flex-direction:column;overflow:hidden}.app-shell__topbar{display:none!important;height:64px;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg)}@media (max-width: 768px){.app-shell__topbar{display:flex!important}}.app-shell__burger{display:none}@media (max-width: 768px){.app-shell__burger{display:flex}}.app-shell__content{flex:1;overflow-y:auto;padding:var(--spacing-lg);background-color:var(--color-primary-softer)}.app-shell__content::-webkit-scrollbar{width:8px;height:8px}.app-shell__content::-webkit-scrollbar-track{background:var(--color-surface-muted);border-radius:var(--radius-sm)}.app-shell__content::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm)}.app-shell__content::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media (min-width: 768px){.app-shell__content{padding:var(--spacing-xl)}}.grid{display:grid;gap:var(--spacing-md)}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}.grid--auto-fit{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid--auto-fill{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.flex{display:flex}.flex--center{display:flex;align-items:center;justify-content:center}.flex--between{display:flex;align-items:center;justify-content:space-between}.flex--start{display:flex;align-items:center;justify-content:flex-start}.flex--end{display:flex;align-items:center;justify-content:flex-end}.flex--column{flex-direction:column}.flex--wrap{flex-wrap:wrap}.flex--1{flex:1}.flex--auto{flex:auto}.flex--none{flex:none}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.m-0{margin:0}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.m-auto{margin:auto}.mt-0{margin-top:0}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-0{margin-bottom:0}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-0{padding:0}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.pt-0{padding-top:0}.pt-xs{padding-top:var(--spacing-xs)}.pt-sm{padding-top:var(--spacing-sm)}.pt-md{padding-top:var(--spacing-md)}.pt-lg{padding-top:var(--spacing-lg)}.pt-xl{padding-top:var(--spacing-xl)}.pb-0{padding-bottom:0}.pb-xs{padding-bottom:var(--spacing-xs)}.pb-sm{padding-bottom:var(--spacing-sm)}.pb-md{padding-bottom:var(--spacing-md)}.pb-lg{padding-bottom:var(--spacing-lg)}.pb-xl{padding-bottom:var(--spacing-xl)}.w-full{width:100%}.w-auto{width:auto}.w-fit{width:fit-content}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.info-list{display:flex;flex-direction:column;gap:var(--spacing-md);background-color:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.info-list__item{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md)}.info-list__item:not(:last-child){padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.info-list__label{font-size:var(--font-size-sm);color:var(--color-text-muted);flex-shrink:0}.info-list__value{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-main);text-align:right}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:10px 20px;font-size:var(--font-size-sm);font-weight:500;line-height:1.5;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base),transform var(--transition-base);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-color:var(--color-primary)}.btn--sm{padding:6px 12px;font-size:var(--font-size-xs)}.btn--lg{padding:12px 24px;font-size:var(--font-size-base)}.btn--primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.btn--primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn--primary:active:not(:disabled){transform:scale(.98)}.btn--secondary{background-color:var(--color-surface);color:var(--color-text-main);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background-color:var(--color-surface-muted);border-color:var(--color-border-strong)}.btn--ghost{background-color:transparent;color:var(--color-text-main)}.btn--ghost:hover:not(:disabled){background-color:var(--color-surface-muted)}.btn--danger{background-color:var(--color-error);color:var(--color-text-inverse)}.btn--danger:hover:not(:disabled){background-color:#b71c1c}.btn--success{background-color:var(--color-success);color:var(--color-text-inverse)}.btn--success:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn--warning{background-color:var(--color-warning);color:var(--color-text-inverse)}.btn--warning:hover:not(:disabled){background-color:#d97a12}.btn--info{background-color:var(--color-info);color:var(--color-text-inverse)}.btn--info:hover:not(:disabled){background-color:#4235c9}.btn--neutral{background-color:var(--color-neutral);color:var(--color-text-inverse)}.btn--neutral:hover:not(:disabled){background-color:#2a2a2a}.btn--danger-soft{background-color:var(--color-error-soft);color:var(--color-error);border-color:var(--color-error-soft)}.btn--danger-soft:hover:not(:disabled){background-color:var(--color-error);color:var(--color-text-inverse);border-color:var(--color-error)}.btn--warning-soft{background-color:var(--color-warning-soft);color:var(--color-warning);border-color:var(--color-warning-soft)}.btn--warning-soft:hover:not(:disabled){background-color:var(--color-warning);color:var(--color-text-inverse);border-color:var(--color-warning)}.btn--success-soft{background-color:var(--color-success-soft);color:var(--color-success);border-color:var(--color-success-soft)}.btn--success-soft:hover:not(:disabled){background-color:var(--color-success);color:var(--color-text-inverse);border-color:var(--color-success)}.btn--info-soft{background-color:var(--color-info-soft);color:var(--color-info);border-color:var(--color-info-soft)}.btn--info-soft:hover:not(:disabled){background-color:var(--color-info);color:var(--color-text-inverse);border-color:var(--color-info)}.btn--neutral-soft{background-color:var(--color-neutral-soft);color:var(--color-neutral);border-color:var(--color-neutral-soft)}.btn--neutral-soft:hover:not(:disabled){background-color:var(--color-neutral);color:var(--color-text-inverse);border-color:var(--color-neutral)}.btn__badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;margin-left:var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:999px;line-height:1}.btn__badge--primary{background-color:var(--color-primary-soft);color:var(--color-primary)}.btn__badge--secondary,.btn__badge--ghost{background-color:var(--color-surface-muted);color:var(--color-text-main)}.btn__badge--danger{background-color:var(--color-error-soft);color:var(--color-error)}.btn__badge--success{background-color:var(--color-success-soft);color:var(--color-success)}.btn__badge--warning{background-color:var(--color-warning-soft);color:var(--color-warning)}.btn__badge--info{background-color:var(--color-info-soft);color:var(--color-info)}.btn__badge--neutral{background-color:var(--color-neutral-soft);color:var(--color-neutral)}.btn__badge--danger-soft{background-color:var(--color-surface);color:var(--color-error)}.btn__badge--warning-soft{background-color:var(--color-surface);color:var(--color-warning)}.btn__badge--success-soft{background-color:var(--color-surface);color:var(--color-success)}.btn__badge--info-soft{background-color:var(--color-surface);color:var(--color-info)}.btn__badge--neutral-soft{background-color:var(--color-surface);color:var(--color-neutral)}.input,.select,.textarea{width:100%;padding:10px 12px;font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-main);background-color:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-base),background-color var(--transition-base),box-shadow var(--transition-base)}.input::placeholder,.select::placeholder,.textarea::placeholder{color:var(--color-text-muted)}.input:hover:not(:disabled),.select:hover:not(:disabled),.textarea:hover:not(:disabled){border-color:var(--color-border-strong)}.input:focus,.select:focus,.textarea:focus{outline:none;background-color:var(--color-neutral-soft);border-color:var(--color-neutral);box-shadow:var(--shadow-focus)}.input:disabled,.select:disabled,.textarea:disabled{opacity:.5;cursor:not-allowed}.input--error,.select--error,.textarea--error{border-color:var(--color-error);background-color:var(--color-error-soft)}.input--error:focus,.select--error:focus,.textarea--error:focus{box-shadow:0 0 0 3px #c628281a}.input--success,.select--success,.textarea--success{border-color:var(--color-success);background-color:var(--color-success-soft)}.select{-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='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer;text-align:left}.select::-ms-expand{display:none}button.select{display:flex;align-items:center;justify-content:space-between;width:100%}.select-searchable{position:relative;width:100%}.select-searchable button.select{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between}.select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);z-index:1000;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.select-search{padding:8px;border-bottom:1px solid var(--color-border)}.select-search .input,.select-search .input-group{margin-bottom:0}.select-options{overflow-y:auto;max-height:250px}.select-options::-webkit-scrollbar{width:8px;height:8px}.select-options::-webkit-scrollbar-track{background:var(--color-surface-muted);border-radius:var(--radius-sm)}.select-options::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm)}.select-options::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.select-option{padding:10px 12px;cursor:pointer;transition:background-color var(--transition-base),color var(--transition-base);color:var(--color-text-main)}.select-option:hover{background-color:var(--color-surface-muted)}.select-option.selected{background-color:var(--color-primary-soft);color:var(--color-primary);font-weight:500}.select-option--checkbox{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 12px}.select-option--checkbox .checkbox__input{margin:0}.select-option--checkbox .checkbox__label{margin:0;cursor:pointer;flex:1}.select-no-results,.select-loading{padding:12px;text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.select-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.select-multiple-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.select-multiple-tag{display:inline-flex;align-items:center;gap:var(--spacing-xxs);padding:4px 8px;background-color:var(--color-primary-soft);color:var(--color-primary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;transition:background-color var(--transition-base)}.select-multiple-tag:hover{background-color:var(--color-primary-soft-hover)}.select-multiple-tag-remove{display:inline-flex;align-items:center;justify-content:center;padding:0;background:none;border:none;cursor:pointer;color:var(--color-primary);transition:color var(--transition-base)}.select-multiple-tag-remove:hover{color:var(--color-primary-dark)}.textarea{min-height:100px;resize:vertical}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.input-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-main)}.input-group .helper-text{font-size:var(--font-size-xs);color:var(--color-text-muted)}.input-group .error-text{font-size:var(--font-size-xs);color:var(--color-error)}.form-row{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.form-row>*{flex:1 1 calc(50% - var(--spacing-md) / 2);min-width:200px}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon--left .input{padding-left:40px}.input-with-icon--right .input{padding-right:40px}.input-icon{position:absolute;color:var(--color-text-muted);pointer-events:none}.input-icon--left{left:12px}.input-icon--right{right:12px}.input-icon-button{position:absolute;right:8px;padding:4px;background:none;border:none;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color var(--transition-base),background-color var(--transition-base)}.input-icon-button:hover{color:var(--color-text-main);background-color:var(--color-surface-muted)}.input-icon-button:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-color:var(--color-primary)}.input--with-left-icon{padding-left:40px}.input--with-right-icon{padding-right:40px}.upload-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.upload-field__label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-main)}.upload-field__required{color:var(--color-error)}.upload-dropzone{position:relative;border:2px dashed var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-surface-muted);padding:var(--spacing-xl);text-align:center;cursor:pointer;transition:border-color var(--transition-base),background-color var(--transition-base),box-shadow var(--transition-base),color var(--transition-base)}.upload-dropzone__input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.upload-dropzone__content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);pointer-events:none;color:var(--color-text-main)}.upload-dropzone__icon{width:48px;height:48px;color:var(--color-text-muted)}.upload-dropzone__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-main)}.upload-dropzone__subtitle{font-size:var(--font-size-xs);color:var(--color-text-muted)}.upload-dropzone__file{display:inline-flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-main)}.upload-dropzone__file-icon{width:18px;height:18px;color:var(--color-primary)}.upload-dropzone:hover:not(.is-disabled){border-color:var(--color-primary);background-color:var(--color-primary-softer)}.upload-dropzone:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-focus);background-color:var(--color-primary-softer)}.upload-dropzone.has-file .upload-dropzone__icon{color:var(--color-primary)}.upload-dropzone.is-disabled{opacity:.6;cursor:not-allowed}.password-validations{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.password-validations__item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);transition:color var(--transition-base)}.password-validations__item--valid{color:var(--color-success)}.info-box{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid;transition:all var(--transition-base)}.info-box__icon{flex-shrink:0;margin-top:2px}.info-box__content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-box__title{font-weight:600;font-size:var(--font-size-sm);margin:0}.info-box__text{font-size:var(--font-size-sm);margin:0;line-height:1.5}.info-box--primary{background-color:var(--color-primary-soft);border-color:var(--color-primary);color:var(--color-primary)}.info-box--success{background-color:var(--color-success-soft);border-color:var(--color-success);color:var(--color-success)}.info-box--warning{background-color:var(--color-warning-soft);border-color:var(--color-warning);color:var(--color-warning)}.info-box--error{background-color:var(--color-error-soft);border-color:var(--color-error);color:var(--color-error)}.info-box--info{background-color:var(--color-info-soft);border-color:var(--color-info);color:var(--color-info)}.checkbox-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.checkbox{display:inline-flex;align-items:flex-start;gap:var(--spacing-sm);cursor:pointer}.checkbox__input{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:var(--color-primary);border-radius:var(--radius-sm);flex-shrink:0}.checkbox__input:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-color:var(--color-primary)}.checkbox__input:disabled{opacity:.5;cursor:not-allowed}.checkbox__input--error{accent-color:var(--color-error)}.checkbox__label{font-size:var(--font-size-sm);color:var(--color-text-main);cursor:pointer;-webkit-user-select:none;user-select:none;line-height:1.5}.checkbox__label:has(+input:disabled){opacity:.5;cursor:not-allowed}.checkbox__helper-text{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-left:26px}.checkbox__error-text{font-size:var(--font-size-xs);color:var(--color-error);margin-left:26px}.radio{display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.radio input{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.card--elevated{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.card--hover{transition:transform var(--transition-base),box-shadow var(--transition-base)}.card--hover:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.card--hover{cursor:pointer}.card__header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.card__header .card__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-main);margin:0}.card__header .card__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.card__body{color:var(--color-text-main)}.card__footer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-full);white-space:nowrap}.badge--primary{background-color:var(--color-primary-soft);color:var(--color-primary)}.badge--success{background-color:var(--color-success-soft);color:var(--color-success)}.badge--error,.badge--danger{background-color:var(--color-error-soft);color:var(--color-error)}.badge--warning{background-color:var(--color-warning-soft);color:var(--color-warning)}.badge--info{background-color:var(--color-info-soft);color:var(--color-info)}.badge--neutral{background-color:var(--color-surface-muted);color:var(--color-text-main)}.sidebar-menu-item__badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;margin-left:var(--spacing-xs);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:999px;line-height:1;background-color:var(--color-primary-soft);color:var(--color-primary)}.segmented-control{display:inline-flex;gap:var(--spacing-xs);padding:var(--spacing-xs);background-color:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md)}@media (max-width: 640px){.segmented-control{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.segmented-control::-webkit-scrollbar{height:6px}.segmented-control::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:999px}}.segmented-control--full-width{display:flex;width:100%;border-radius:0;border-left:none;border-right:none;border-top:none}.segmented-control--full-width .segmented-control__option{flex:1;justify-content:center}@media (max-width: 640px){.segmented-control--full-width .segmented-control__option{flex:0 0 auto}}.segmented-control__option{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 16px;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);background-color:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-base),color var(--transition-base),box-shadow var(--transition-base);white-space:nowrap}.segmented-control__option:hover:not(.segmented-control__option--active){color:var(--color-text-main)}.segmented-control__option--active{background-color:var(--color-surface);color:var(--color-text-main);box-shadow:var(--shadow-sm)}.table-container{width:100%;overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-surface)}.table-container::-webkit-scrollbar{width:8px;height:8px}.table-container::-webkit-scrollbar-track{background:var(--color-surface-muted);border-radius:var(--radius-sm)}.table-container::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm)}.table-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table thead{background-color:var(--color-surface-muted);border-bottom:1px solid var(--color-border)}.table thead th{padding:12px 16px;text-align:left;font-weight:600;color:var(--color-text-main);white-space:nowrap}.table thead th:first-child{border-top-left-radius:var(--radius-lg)}.table thead th:last-child{border-top-right-radius:var(--radius-lg)}.table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color var(--transition-base)}.table tbody tr:hover{background-color:var(--color-surface-muted)}.table tbody tr:last-child{border-bottom:none}.table tbody td{padding:12px 16px;color:var(--color-text-main);vertical-align:middle}.table tbody td.table-cell--numeric{text-align:right;font-variant-numeric:tabular-nums}.table tbody td.table-cell--center{text-align:center}.table--striped tbody tr:nth-child(2n){background-color:var(--color-surface-muted)}.table--striped tbody tr:nth-child(2n):hover{background-color:var(--color-border)}.table--compact{font-size:var(--font-size-xs)}.table--compact thead th,.table--compact tbody td{padding:8px 12px}.alert{display:flex;align-items:flex-start;padding:var(--spacing-md);border-radius:var(--radius-md);border-left:4px solid;gap:var(--spacing-sm)}.alert__icon{flex-shrink:0}.alert__content{flex:1}.alert__title{font-weight:600;margin-bottom:var(--spacing-xs)}.alert__message{font-size:var(--font-size-sm)}.alert__message p,.alert__message ul,.alert__message ol,.alert__message div{margin:0}.alert__message p+p,.alert__message p+ul,.alert__message p+ol{margin-top:var(--spacing-xs)}.alert--success{background-color:var(--color-success-soft);border-left-color:var(--color-success);color:var(--color-success)}.alert--error{background-color:var(--color-error-soft);border-left-color:var(--color-error);color:var(--color-error)}.alert--warning{background-color:var(--color-warning-soft);border-left-color:var(--color-warning);color:var(--color-warning)}.alert--info{background-color:var(--color-info-soft);border-left-color:var(--color-info);color:var(--color-info)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-base)}.modal{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);max-width:600px;width:90%;max-height:90vh;overflow-y:auto;z-index:var(--z-modal);animation:slideUp var(--transition-base)}.modal::-webkit-scrollbar{width:8px;height:8px}.modal::-webkit-scrollbar-track{background:var(--color-surface-muted);border-radius:var(--radius-sm)}.modal::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm)}.modal::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.modal__header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-main);margin:0}.modal__close{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs);background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-base),background-color var(--transition-base)}.modal__close:hover{color:var(--color-text-main);background-color:var(--color-surface-muted)}.modal__close:active{background-color:var(--color-border)}.modal__body{padding:var(--spacing-lg)}.modal__body p:first-child,.modal__body ul:first-child,.modal__body ol:first-child,.modal__body div:first-child{margin-top:0}.modal__body p:last-child,.modal__body ul:last-child,.modal__body ol:last-child,.modal__body div:last-child{margin-bottom:0}.modal__footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm)}.modal--sm{max-width:400px}.modal--md{max-width:600px}.modal--lg{max-width:800px}.modal--xl{max-width:1200px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.spinner{display:inline-block;width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner--sm{width:16px;height:16px;border-width:2px}.spinner--lg{width:32px;height:32px;border-width:4px}.divider{height:1px;background-color:var(--color-border);margin:var(--spacing-md) 0}.divider--vertical{width:1px;height:auto;margin:0 var(--spacing-md)}.slide-over__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:var(--z-modal-backdrop);animation:fadeIn .5s ease-in-out}.slide-over__backdrop[data-state=closed]{animation:fadeOut .3s ease-in-out}.slide-over__panel{position:fixed;top:0;right:0;bottom:0;background-color:var(--color-surface);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;z-index:var(--z-modal);max-width:90vw;overflow:hidden;animation:slideInRight .5s cubic-bezier(.16,1,.3,1)}.slide-over__panel[data-state=closed]{animation:slideOutRight .3s cubic-bezier(.16,1,.3,1)}.slide-over__panel:focus{outline:none}.slide-over__panel--sm{width:400px}.slide-over__panel--md{width:600px}.slide-over__panel--lg{width:800px}.slide-over__panel--xl{width:1000px}.slide-over__header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.slide-over__header h2{margin:0}.slide-over__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background-color:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-base),color var(--transition-base)}.slide-over__close:hover{background-color:var(--color-surface-muted);color:var(--color-text-main)}.slide-over__close:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-color:var(--color-primary)}.slide-over__content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.slide-over__content::-webkit-scrollbar{width:8px;height:8px}.slide-over__content::-webkit-scrollbar-track{background:var(--color-surface-muted);border-radius:var(--radius-sm)}.slide-over__content::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm)}.slide-over__content::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.page-header{display:flex;flex-direction:column;gap:var(--spacing-sm)}.page-header__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-main);margin:0;line-height:1.5}.page-header__subtitle{font-size:var(--font-size-base);font-weight:var(--font-weight-regular);color:var(--color-text-secondary);margin:0;line-height:1.5}.tooltip{position:relative;display:inline-block}.tooltip__content{position:absolute;width:max-content;min-width:120px;max-width:360px;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-text-main);color:var(--color-text-inverse);font-size:var(--font-size-sm);line-height:1.4;border-radius:var(--radius-md);opacity:0;visibility:hidden;pointer-events:none;z-index:var(--z-tooltip);white-space:normal;transition:opacity var(--transition-base),visibility var(--transition-base)}.tooltip__content--top{bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--spacing-sm)}.tooltip__content--bottom{top:100%;left:50%;transform:translate(-50%);margin-top:var(--spacing-sm)}.tooltip__content--left{right:100%;top:50%;transform:translateY(-50%);margin-right:var(--spacing-sm)}.tooltip__content--right{left:100%;top:50%;transform:translateY(-50%);margin-left:var(--spacing-sm)}.tooltip:hover .tooltip__content{opacity:1;visibility:visible}.switch{position:relative;display:inline-block;width:48px;height:24px;flex-shrink:0}.switch__input{opacity:0;width:0;height:0;position:absolute}.switch__slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-border);border-radius:999px;transition:background-color var(--transition-base)}.switch__slider:before{content:"";position:absolute;height:16px;width:16px;left:4px;top:4px;background-color:var(--color-surface);border-radius:50%;transition:transform var(--transition-base)}.switch__input:checked+.switch__slider{background-color:var(--color-success)}.switch__input:checked+.switch__slider:before{transform:translate(24px)}.switch__input:disabled+.switch__slider{opacity:.5;cursor:not-allowed}.switch__input:focus-visible+.switch__slider{outline:none;box-shadow:var(--shadow-focus);border-color:var(--color-primary)}.switch--disabled{opacity:.5;cursor:not-allowed}.playground-section{padding:var(--spacing-lg);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.playground-section .section-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text-main);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-border)}.datepicker{position:relative}.datepicker__label{display:block;margin-bottom:var(--spacing-xs);font-weight:600;font-size:14px}.datepicker__trigger{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px;background:var(--color-surface);color:var(--color-text-main);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.datepicker__trigger:hover{border-color:var(--color-primary);box-shadow:0 8px 24px #0000000a}.datepicker__value{display:inline-flex;align-items:center;gap:8px;font-size:14px}.datepicker__clear{border:none;background:transparent;cursor:pointer;color:var(--color-text-muted);padding:4px;display:inline-flex;align-items:center;justify-content:center}.datepicker__clear:hover{color:var(--color-text-main)}.datepicker__popover{position:absolute;top:calc(100% + 8px);left:0;z-index:20;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 12px 32px #00000014;border-radius:var(--radius-lg);padding:12px;width:320px}.datepicker__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.datepicker__month{font-weight:700;font-size:14px}.datepicker__nav{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,border-color .15s ease}.datepicker__nav:hover{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-text-secondary)}.datepicker__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px;color:var(--color-text-muted);font-size:12px;text-align:center}.datepicker__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.datepicker__day{width:100%;padding:8px 0;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.datepicker__day--empty{visibility:hidden}.datepicker__day:hover{border-color:var(--color-border);background:var(--color-primary-soft);color:var(--color-text-secondary)}.datepicker__day--today{border-color:var(--color-border)}.datepicker__day--selected{background:var(--color-primary);color:var(--color-text-secondary);border-color:var(--color-primary)}.datepicker__day--inrange{background:var(--color-primary-soft);color:var(--color-text-secondary)}.datepicker__day--start,.datepicker__day--end{font-weight:700}.toast-container{position:fixed;top:var(--spacing-lg);right:var(--spacing-lg);z-index:var(--z-tooltip);display:flex;flex-direction:column;gap:var(--spacing-sm);max-width:420px;pointer-events:none}.toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-surface);border-radius:var(--radius-lg);border-left:4px solid;box-shadow:var(--shadow-md);pointer-events:auto;animation:toast-slide-in .3s ease}.toast__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.toast__message{flex:1;margin:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-main)}.toast__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.toast__close:hover{background-color:var(--color-surface-muted);color:var(--color-text-main)}.toast__close:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.toast--success{border-left-color:var(--color-success)}.toast--success .toast__icon{color:var(--color-success)}.toast--error{border-left-color:var(--color-error)}.toast--error .toast__icon{color:var(--color-error)}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.register-onboarding{min-height:100vh;background:linear-gradient(135deg,#22c55e08,#22c55e14,#22c55e08);display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}@media (max-width: 768px){.register-onboarding{padding:var(--spacing-md);align-items:flex-start}}.register-onboarding__container{width:100%;max-width:750px}.register-onboarding__header{text-align:center;margin-bottom:var(--spacing-3xl)}@media (max-width: 768px){.register-onboarding__header{margin-bottom:var(--spacing-xl)}}.register-onboarding__logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}@media (max-width: 768px){.register-onboarding__logo{margin-bottom:var(--spacing-md)}}.register-onboarding__logo-icon{width:56px;height:56px;background:linear-gradient(135deg,#dc2626,#ea580c);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-text-inverse);box-shadow:var(--shadow-lg)}@media (max-width: 768px){.register-onboarding__logo-icon{width:48px;height:48px}}.register-onboarding__logo-text{text-align:left}.register-onboarding__logo-text h1{margin:0;line-height:1.2}@media (max-width: 768px){.register-onboarding__logo-text h1{font-size:var(--font-size-xl)}}.register-onboarding__logo-text p{margin:0}@media (max-width: 768px){.register-onboarding__logo-text p{font-size:var(--font-size-xs)}}.register-onboarding__tagline{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}@media (max-width: 768px){.register-onboarding__tagline{font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}}.register-onboarding__card{background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid var(--color-border);overflow:hidden;margin-top:var(--spacing-xl)}@media (max-width: 768px){.register-onboarding__card{border-radius:var(--radius-lg);margin-top:var(--spacing-md)}}.register-onboarding__footer{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-lg)}.register-onboarding__link{color:var(--color-primary);font-weight:500;background:none;border:none;cursor:pointer;text-decoration:none;transition:color var(--transition-base)}.register-onboarding__link:hover{text-decoration:underline}.stepper{margin-bottom:var(--spacing-2xl)}.stepper__track{display:flex;align-items:center;justify-content:space-between;max-width:600px;margin:0 auto}.stepper__item-wrapper{display:flex;align-items:center;flex:1}.stepper__item-wrapper:last-child{flex:0}.stepper__item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.stepper__circle{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;box-shadow:0 2px 4px #0000001a;transition:all var(--transition-base)}@media (max-width: 640px){.stepper__circle{width:32px;height:32px}}.stepper__circle--completed{background-color:var(--color-success);color:var(--color-text-inverse);box-shadow:0 2px 8px #22c55e4d}.stepper__circle--current{background-color:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 4px 12px #3b82f666;transform:scale(1.1)}@media (max-width: 640px){.stepper__circle--current{transform:scale(1.05)}}.stepper__circle--pending{background-color:var(--color-surface-muted);color:var(--color-text-muted)}.stepper__check-icon{width:20px;height:20px}@media (max-width: 640px){.stepper__check-icon{width:16px;height:16px}}.stepper__number{font-size:var(--font-size-base)}@media (max-width: 640px){.stepper__number{font-size:var(--font-size-sm)}}.stepper__label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500;text-align:center}@media (max-width: 640px){.stepper__label{font-size:.625rem;max-width:60px;line-height:1.2}}.stepper__line{flex:1;height:4px;margin:0 var(--spacing-sm);border-radius:var(--radius-full);align-self:center;margin-top:-24px;transition:background-color var(--transition-base)}@media (max-width: 640px){.stepper__line{height:2px;margin:0 var(--spacing-xs);margin-top:-20px}}.stepper__line--completed{background-color:var(--color-success)}.stepper__line--pending{background-color:var(--color-border)}.register-step__header{padding:var(--spacing-md) var(--spacing-xl);background-color:var(--color-success);color:var(--color-text-inverse);border-bottom:1px solid var(--color-border)}.register-step__header-content{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xs)}.register-step__header-content h2{margin:0;color:var(--color-text-inverse)}.register-step__icon{width:24px;height:24px;color:var(--color-text-inverse)}.register-step__subtitle{margin:0;color:var(--color-text-inverse);opacity:.9;font-size:var(--font-size-sm)}.register-step__content{padding:var(--spacing-xl)}.register-step__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.register-step__button{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.register-step__button--success{background:linear-gradient(135deg,#16a34a,#059669);box-shadow:var(--shadow-lg)}.register-step__button--success:hover:not(:disabled){background:linear-gradient(135deg,#15803d,#047857)}.register-step__skip-button{width:100%}.password-validation__icon{width:16px;height:16px;border-radius:50%;background-color:var(--color-surface-muted);display:flex;align-items:center;justify-content:center}.equipment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md)}.equipment-card{position:relative;padding:var(--spacing-md);border-radius:var(--radius-lg);border:2px solid var(--color-border);background-color:var(--color-surface);cursor:pointer;text-align:left;transition:all var(--transition-base)}.equipment-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-sm)}.equipment-card--selected{border-color:var(--color-primary);background-color:var(--color-primary-soft);box-shadow:var(--shadow-md)}.equipment-card__check{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:24px;height:24px;background-color:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-inverse)}.equipment-card__content{display:flex;align-items:center;gap:var(--spacing-md)}.equipment-card__icon-wrapper{width:48px;height:48px;border-radius:var(--radius-md);background-color:var(--color-surface-muted);display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-base)}.equipment-card__icon-wrapper--selected{background-color:var(--color-primary-soft)}.equipment-card__icon{color:var(--color-text-muted);transition:color var(--transition-base)}.equipment-card--selected .equipment-card__icon{color:var(--color-primary)}.equipment-card__label{font-weight:500;color:var(--color-text-main);transition:color var(--transition-base)}.equipment-card--selected .equipment-card__label{color:var(--color-primary)}.email-input-group{display:flex;align-items:stretch}.email-input-group__input{flex-shrink:1;min-width:0;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-main);background-color:var(--color-surface);transition:border-color var(--transition-base)}.email-input-group__input:focus{outline:none;border-color:var(--color-primary);z-index:1;box-shadow:0 0 0 3px #3b82f61a}.email-input-group__domain{flex-grow:1;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--color-text-main);font-family:Courier New,monospace;font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-option-card{background:linear-gradient(135deg,#a855f70d,#a855f71a);border:2px solid rgba(168,85,247,.2);border-radius:var(--radius-lg);padding:var(--spacing-md)}.ai-option-card__content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.ai-option-card__header{display:flex;align-items:center;gap:var(--spacing-sm)}.ai-option-card__icon{color:#a855f7}.ai-option-card__title{font-weight:600;color:var(--color-text-main)}.ai-option-card__description{font-size:var(--font-size-sm);color:var(--color-text-main);margin:0}.ai-option-card__badge{font-size:var(--font-size-xs);font-weight:500;color:#a855f7;margin:0}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-in-out}.loading-overlay__content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xl)}.loading-overlay__spinner{position:relative;width:80px;height:80px}.loading-overlay__spinner-track{position:absolute;top:0;right:0;bottom:0;left:0;border:4px solid var(--color-primary-soft);border-radius:50%}.loading-overlay__spinner-fill{position:absolute;top:0;right:0;bottom:0;left:0;border:4px solid var(--color-primary);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.loading-overlay__text{height:32px;display:flex;align-items:center}.loading-overlay__phrase{font-size:var(--font-size-lg);font-weight:500;color:var(--color-text-main);animation:fadeInUp .3s ease-in-out}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.success-screen{min-height:100vh;background:linear-gradient(135deg,#22c55e08,#22c55e14,#22c55e08);display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.success-screen__content{max-width:800px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xl);animation:fadeInUp .7s ease-in-out}.success-screen__icon-wrapper{display:flex;justify-content:center}.success-screen__icon{width:96px;height:96px;background:linear-gradient(135deg,#22c55e,#10b981);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-inverse);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:zoomIn .5s ease-in-out}.success-screen__text{display:flex;flex-direction:column;gap:var(--spacing-sm)}.success-screen__title{font-size:2.25rem;font-weight:700;color:var(--color-text-main);margin:0}.success-screen__subtitle{font-size:1.25rem;color:var(--color-text-secondary);margin:0}.success-screen__cards{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-xl);border:1px solid var(--color-border);display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-lg);width:100%}.success-screen__note{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.success-card{text-align:center}.success-card__icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-sm)}.success-card__icon--primary{background-color:var(--color-primary-soft);color:var(--color-primary)}.success-card__icon--purple{background-color:#a855f71a;color:#a855f7}.success-card__icon--success{background-color:var(--color-success-soft);color:var(--color-success)}.success-card__title{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-main);margin:0 0 var(--spacing-xs) 0}.success-card__subtitle{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}@keyframes zoomIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.stepper{margin-bottom:var(--spacing-lg)}.register-step__header{padding:var(--spacing-sm) var(--spacing-md)}.register-step__header-content h2{font-size:var(--font-size-xl)}.register-step__content{padding:var(--spacing-md)}.register-step__form{gap:var(--spacing-sm)}.equipment-card{padding:var(--spacing-sm)}.equipment-card__label{font-size:var(--font-size-xs)}.success-screen{padding:var(--spacing-md)}.success-screen__content{gap:var(--spacing-lg)}.success-screen__icon{width:80px;height:80px}.success-screen__title{font-size:1.75rem}.success-screen__subtitle{font-size:1rem}.success-screen__cards{padding:var(--spacing-md);gap:var(--spacing-md)}.success-card__icon{width:40px;height:40px}}.login-page{--color-bg: #fafafa;--color-surface: #ffffff;--color-surface-muted: #f5f5f5;--color-border: #eaeaea;--color-border-strong: #dadada;--color-text-main: #1f1f1f;--color-text-secondary: #3b3b3b;--color-text-muted: #6d6d6d;--color-text-inverse: #ffffff;--color-primary: #2f7d4b;--color-primary-hover: #3fa15f;--color-primary-soft: #eaf7f0;display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background-color:var(--color-surface)}@media (max-width: 768px){.login-page{grid-template-columns:1fr}}.login-hero{position:relative;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xxl);background:linear-gradient(135deg,#2f7d4bf2,#3fa15ff2),url(/hero-background.jpg) center/cover;background-color:var(--color-primary);color:var(--color-text-inverse)}@media (max-width: 768px){.login-hero{display:none}}.login-hero .hero-content{max-width:480px;width:100%}.login-hero .hero-logo{margin-bottom:var(--spacing-xxl)}.login-hero .hero-logo img{height:48px;width:auto;filter:brightness(0) invert(1)}.login-hero .hero-text{margin-bottom:var(--spacing-xxl)}.login-hero .hero-text h1{font-size:var(--font-size-3xl);font-weight:700;line-height:1.2;margin:0 0 var(--spacing-md) 0;color:var(--color-text-inverse)}.login-hero .hero-text .hero-subtitle{font-size:var(--font-size-lg);line-height:1.6;margin:0;opacity:.95;color:var(--color-text-inverse)}.login-hero .hero-features{list-style:none;padding:0;margin:0}.login-hero .hero-features li{display:flex;align-items:center;justify-content:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-inverse)}.login-hero .hero-features li .feature-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:#fff3;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:700;flex-shrink:0}.login-form-container{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xxl) var(--spacing-xl);background-color:var(--color-surface)}@media (max-width: 480px){.login-form-container{padding:var(--spacing-xl) var(--spacing-lg)}}.login-form-container .login-form-wrapper{width:100%;max-width:420px}.login-form-container .login-header{margin-bottom:var(--spacing-xl)}.login-form-container .login-header h2{font-size:var(--font-size-3xl);font-weight:700;margin:0 0 var(--spacing-sm) 0;color:var(--color-text-main)}.login-form-container .login-header p{font-size:var(--font-size-base);margin:0;color:var(--color-text-secondary)}.login-form-container .login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-form-container .login-form .forgot-password-link{margin-top:calc(-1 * var(--spacing-sm));text-align:right}.login-form-container .login-form .forgot-password-link a{font-size:var(--font-size-sm);color:var(--color-primary);text-decoration:none;font-weight:500;transition:color var(--transition-base)}.login-form-container .login-form .forgot-password-link a:hover{color:var(--color-primary-hover);text-decoration:underline}.login-form-container .login-form button[type=submit]{margin-top:var(--spacing-sm)}.login-form-container .signup-link{margin-top:var(--spacing-xl);text-align:center;padding-top:var(--spacing-xl);border-top:1px solid var(--color-border)}.login-form-container .signup-link p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.login-form-container .signup-link p a{color:var(--color-primary);text-decoration:none;font-weight:600;transition:color var(--transition-base)}.login-form-container .signup-link p a:hover{color:var(--color-primary-hover);text-decoration:underline}
