.typography{margin:0;font-family:var(--font-family-base);letter-spacing:var(--letter-spacing-base);line-height:var(--line-height-base);color:inherit}.typography--size-xs{font-size:var(--font-size-xs)}.typography--size-sm{font-size:var(--font-size-sm)}.typography--size-md{font-size:var(--font-size-md)}.typography--size-lg{font-size:var(--font-size-lg)}.typography--size-xl{font-size:var(--font-size-xl)}.typography--size-xxl{font-size:var(--font-size-xxl)}.typography--size-3xl{font-size:var(--font-size-3xl)}.typography--size-display{font-size:var(--font-size-display)}.typography--weight-regular{font-weight:var(--font-weight-regular)}.typography--weight-medium{font-weight:var(--font-weight-medium)}.typography--weight-semibold{font-weight:var(--font-weight-semibold)}.typography--weight-bold{font-weight:var(--font-weight-bold)}.typography--color-primary{color:var(--text-primary)}.typography--color-secondary{color:var(--text-secondary)}.typography--color-tertiary{color:var(--text-tertiary)}.typography--color-error{color:var(--text-error)}.typography--color-inverse{color:var(--text-inverse)}.typography--color-brand{color:var(--color-primary)}.typography--align-left{text-align:left}.typography--align-center{text-align:center}.typography--align-right{text-align:right}.typography--ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ds-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);border-radius:var(--radius-xl);font-weight:var(--font-weight-semibold);transition:var(--transition-base);border:none;font-family:var(--font-family-base);cursor:pointer;white-space:nowrap}.ds-button:disabled,.ds-button.is-loading{cursor:not-allowed;opacity:.6}.ds-button--full-width{width:100%}.ds-button--primary{background-color:var(--color-primary);color:var(--text-inverse)}.ds-button--primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.ds-button--secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.ds-button--outline{background-color:transparent;border:1px solid var(--border-default);color:var(--text-primary)}.ds-button--ghost{background-color:transparent;color:var(--text-secondary)}.ds-button--ghost:hover:not(:disabled){background-color:var(--bg-secondary)}.ds-button--danger{background-color:var(--color-error);color:var(--text-inverse)}.ds-button--sm{height:32px;padding:0 var(--spacing-md);font-size:var(--font-size-sm);border-radius:var(--radius-base)}.ds-button--md{height:40px;padding:0 var(--spacing-lg);font-size:var(--font-size-sm);border-radius:var(--radius-base)}.ds-button--lg{height:48px;padding:0 var(--spacing-xl);font-size:var(--font-size-md);border-radius:var(--radius-lg)}.ds-button--xl{height:56px;padding:0 var(--spacing-2xl);font-size:var(--font-size-lg);border-radius:var(--radius-xl)}.ds-button-spinner{margin-right:var(--spacing-xs);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ds-selection-button.ds-button{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-base);border:1px solid var(--border-default);background-color:var(--bg-primary);cursor:pointer;transition:var(--transition-base);min-height:46px}.ds-selection-button--full-width{width:100%}.ds-selection-button--selected.ds-button{border-color:var(--color-primary);box-shadow:var(--shadow-purple)}.ds-selection-button.ds-button:disabled{background-color:var(--bg-secondary);border-color:var(--border-default);color:var(--text-tertiary);opacity:.5}.ds-calendar{width:100%;padding:var(--spacing-lg) 0}.ds-calendar-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:0 var(--spacing-xl)}.ds-calendar-nav-btn{background:none;border:none;cursor:pointer;width:40px;height:40px;color:var(--text-primary);display:flex;align-items:center;justify-content:center}.ds-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center}.ds-calendar-weekday{display:flex;align-items:center;justify-content:center;width:40px;height:40px;font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:var(--font-weight-medium)}.ds-calendar-weekday.sunday{color:var(--palette-bittersweet)}.ds-calendar-weekday.saturday{color:var(--color-accent)}.ds-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);row-gap:var(--spacing-sm)}.ds-calendar-day{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;font-size:var(--font-size-md);color:var(--text-secondary);border-radius:var(--radius-base);cursor:pointer}.ds-calendar-day:hover:not(.disabled):not(.selected):not(.other-month){background-color:var(--bg-secondary)}.ds-calendar-day.selected{background-color:var(--color-primary);color:var(--text-inverse);font-weight:var(--font-weight-semibold)}.ds-calendar-day.other-month{color:var(--palette-gray-300);cursor:default}.ds-calendar-day.disabled{color:var(--palette-gray-300);cursor:not-allowed;opacity:.4}.ds-calendar-day.disabled:hover{background-color:transparent}.fab-container{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);width:100%;max-width:var(--max-layout-width);display:flex;justify-content:flex-end;pointer-events:none;z-index:101}.fab-button{pointer-events:auto;margin-right:var(--spacing-lg);background-color:var(--color-primary);color:var(--text-inverse);border:none;border-radius:var(--radius-full);padding:var(--spacing-xs) var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-2xs);box-shadow:var(--shadow-purple);cursor:pointer;font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);line-height:var(--line-height-relaxed);transition:all .2s cubic-bezier(.16,1,.3,1);min-height:40px}.fab-button:active{transform:scale(.95)}.fab-main-icon-wrapper{display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.fab-button.open{background-color:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-md);padding:0;width:40px;height:40px;justify-content:center;border-radius:50%}.fab-button.open .fab-label{display:none}.fab-button.open .fab-main-icon-wrapper{transform:rotate(45deg);color:var(--text-secondary)}.fab-overlay{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--max-layout-width);bottom:0;background-color:var(--bg-overlay);z-index:100;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-end;padding:var(--spacing-lg);padding-bottom:calc(140px + env(safe-area-inset-bottom));animation:fadeIn .2s ease}.fab-menu-container{display:flex;flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);margin-right:0;background-color:var(--color-primary);padding:var(--spacing-md) 0;border-radius:var(--radius-xl);min-width:138px;box-shadow:var(--shadow-md);animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.fab-menu-item{display:flex;align-items:center;gap:var(--spacing-xs);background:none;border:none;cursor:pointer;padding:var(--spacing-2xs) var(--spacing-lg);width:100%;transition:background-color .2s}.fab-menu-item:hover{background-color:#ffffff1a}.fab-menu-label{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:var(--line-height-relaxed);color:var(--text-inverse)}.fab-menu-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--text-inverse);transition:transform .2s ease}.fab-menu-item:hover .fab-menu-icon{transform:scale(1.1)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ds-card{background-color:var(--bg-primary);border-radius:var(--radius-xl);overflow:hidden;transition:var(--transition-base);cursor:default}.ds-card.interactive{cursor:pointer}.ds-card.interactive:active{transform:scale(.98)}.ds-card.elevated{box-shadow:var(--shadow-sm);border:none}.ds-card.outlined{border:1px solid var(--border-default);box-shadow:none}.ds-card.flat{background-color:var(--bg-secondary);border:none;box-shadow:none}.ds-card.padding-none{padding:0}.ds-card.padding-sm{padding:var(--spacing-sm)}.ds-card.padding-md{padding:var(--spacing-md)}.ds-card.padding-lg{padding:var(--spacing-lg)}.ds-card.padding-xl{padding:var(--spacing-xl)}.empty-state-container{width:100%;min-height:108px;padding:0 var(--spacing-lg);background-color:transparent}.empty-state-text{color:var(--palette-gray-300);line-height:var(--line-height-relaxed);text-align:center}.empty-state-icon{color:var(--palette-gray-300);display:flex;align-items:center;justify-content:center}.text-field-container{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%}.text-field-input{width:100%;padding:var(--spacing-md);border:2px solid var(--border-default);border-radius:var(--radius-lg);background-color:var(--bg-input);font-family:var(--font-family-base);font-size:var(--font-size-md);color:var(--text-primary);resize:none;outline:none;transition:var(--transition-base)}.text-field-input:focus{border-color:var(--color-primary)}.text-field-input::placeholder{color:var(--text-placeholder)}.input-container{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%}.input-wrapper{position:relative;display:flex;align-items:center;width:100%}.input-field{width:100%;padding:12px var(--spacing-md);border-radius:var(--radius-lg);border:2px solid var(--border-default);background-color:var(--bg-input);font-size:var(--font-size-md);color:var(--text-primary);transition:var(--transition-base);outline:none}.input-field[type=date],.input-field[type=time]{cursor:pointer}.input-field:focus{border-color:var(--color-primary)}.input-field::placeholder{color:var(--text-placeholder)}.input-field:disabled{background-color:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.input-field--error{border-color:var(--color-error)}.input-field--error:focus{border-color:var(--color-error)}.input-field--with-left-icon{padding-left:48px}.input-field--with-right-icon{padding-right:48px}.input-left-element{position:absolute;left:var(--spacing-md);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);z-index:1}.input-right-element{position:absolute;right:var(--spacing-md);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);cursor:pointer}.input-error-message{color:var(--color-error);font-size:var(--font-size-xs);margin-top:2px}.form-label{display:block;margin-bottom:var(--spacing-2xs)}.divider{width:100%;border:none;margin:0}.divider--thin{height:1px;height:2px}.divider--thick{height:5px}.ds-loading-container{display:flex;justify-content:center;align-items:center;width:100%;height:100%;min-height:200px}.ds-loading-container--fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#fffc;z-index:9999}.ds-loading-spinner{animation:ds-spin 1s linear infinite;color:var(--color-primary)}@keyframes ds-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ds-accordion{padding:0;width:100%}.ds-accordion.default{padding:var(--spacing-sm) 0}.ds-accordion.default:not(:last-child){border-bottom:5px solid var(--border-light)}.accordion-header{cursor:pointer;padding:var(--spacing-sm) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center}.ds-accordion .accordion-content .accordion-header{border-bottom:1px solid var(--border-light)}.ds-accordion.nested .accordion-header{border-bottom:none}.accordion-title-wrapper{display:flex;justify-content:space-between;align-items:center;width:100%}.accordion-title-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary)}.accordion-icon{display:flex;justify-content:center;align-items:center;width:40px;height:40px;color:var(--text-tertiary)}.accordion-content{display:flex;flex-direction:column;padding:var(--spacing-sm) var(--spacing-lg);gap:var(--spacing-sm)}.animate-slide-down{animation:slideDown .3s ease-out forwards}.toggle-container{position:relative;display:inline-block;width:43px;height:24px}.toggle-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:1;margin:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-tertiary);transition:.4s;border-radius:31px}.toggle-slider:before{position:absolute;content:"";height:19px;width:19px;left:2.5px;right:2.5px;bottom:2.5px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 3px 8px #00000026,0 3px 1px #0000000f}.toggle-input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-input:focus+.toggle-slider{box-shadow:0 0 1px var(--color-primary)}.toggle-input:checked+.toggle-slider:before{transform:translate(19px)}.toggle-container.disabled .toggle-slider{cursor:not-allowed;opacity:.6}.ds-tabs-container{display:flex;align-items:center;width:100%;border-bottom:1px solid var(--border-light);position:relative}.ds-tabs{display:flex;flex:1;padding:0 var(--spacing-lg);overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.ds-tabs-container:not(.has-overflow) .ds-tab-item{flex:1}.ds-tabs-container.has-overflow .ds-tab-item{flex:0 0 auto}.ds-tabs::-webkit-scrollbar{display:none}.ds-tabs{-ms-overflow-style:none;scrollbar-width:none}.ds-tab-item{flex:0 0 auto;background:none;border:none;padding:var(--spacing-md) var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-tertiary);cursor:pointer;position:relative;transition:color .2s;text-align:center}.ds-tab-item.active{color:var(--text-secondary);font-weight:var(--font-weight-semibold)}.ds-tab-item.active:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:2px;background-color:var(--text-secondary)}.ds-tabs-more-btn{display:flex;align-items:center;justify-content:center;height:100%;padding:0 var(--spacing-md);background:transparent;border:none;border-left:1px solid var(--border-light);color:var(--text-tertiary);cursor:pointer;z-index:1}.ds-tabs-more-btn:active{background-color:var(--bg-secondary)}.ds-tabs-modal-content{padding:var(--spacing-md) 0}.ds-tabs-modal-search{margin-bottom:var(--spacing-lg)}.ds-tabs-modal-list{display:flex;flex-direction:column;max-height:60vh;overflow-y:auto;gap:var(--spacing-xs)}.ds-tabs-modal-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);text-align:left;cursor:pointer;transition:all .2s}.ds-tabs-modal-item:active{background-color:var(--bg-secondary)}.ds-tabs-modal-item.active{border-color:var(--color-primary);background-color:rgba(var(--color-primary-rgb),.05)}.ds-tabs-modal-item.active .ds-tabs-modal-label{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.ds-tabs-modal-label{font-size:var(--font-size-md);color:var(--text-primary);line-height:1.4;flex:1;margin-right:var(--spacing-md)}.ds-tabs-modal-chevron{color:var(--palette-gray-400);flex-shrink:0}.ds-segmented-control-container{padding:var(--spacing-sm) var(--spacing-lg);background-color:transparent}.ds-segmented-control{display:flex;background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:2px;background-color:var(--palette-gray-100)}.ds-segmented-tab{flex:1;padding:6px 0;font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--text-tertiary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.ds-segmented-tab.active{background-color:var(--bg-primary);color:var(--text-secondary);box-shadow:var(--shadow-sm);font-weight:var(--font-weight-semibold)}.ds-autocomplete-container{position:relative;width:100%}.suggestion-dropdown{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-md);max-height:200px;overflow-y:auto;z-index:1000;margin-top:4px}.suggestion-item{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-md);color:var(--text-primary);cursor:pointer;border-bottom:1px solid var(--border-light);transition:background-color .2s ease}.ds-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--bg-overlay);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--spacing-xl);animation:fadeIn .2s ease-in-out}.ds-modal-container{background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:min(320px,95vw);max-height:90vh;position:relative;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--spacing-lg);animation:slideUp .3s cubic-bezier(.16,1,.3,1);text-align:left}.ds-modal-container.ds-modal-container--large{max-width:min(640px,95vw);min-height:500px}.ds-modal-close-button{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:background-color .2s ease;z-index:10}.ds-modal-close-button:hover{background-color:var(--bg-tertiary);color:var(--text-secondary)}.ds-modal-header{text-align:left;display:flex;flex-direction:column;gap:var(--spacing-xs);padding-right:var(--spacing-xl);flex-shrink:0}.ds-modal-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);line-height:var(--line-height-heading);white-space:pre-wrap}.ds-modal-description{color:var(--text-secondary);font-size:var(--font-size-md);font-weight:var(--font-weight-regular);line-height:var(--line-height-base);white-space:pre-wrap}.ds-modal-content{color:var(--text-primary);flex:1;overflow-y:auto;min-height:0;padding-right:var(--spacing-md)}.ds-modal-actions{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%;flex-shrink:0;padding-top:var(--spacing-md)}.ds-modal-actions>*{width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.select-container{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%}.required-mark{color:var(--color-error);margin-left:2px}.select-wrapper{position:relative;display:flex;align-items:center;width:100%}.select-field{width:100%;height:48px;padding:10px var(--spacing-md);padding-right:40px;border-radius:var(--radius-lg);border:2px solid var(--border-default);background-color:var(--bg-input);font-size:var(--font-size-md);color:var(--text-primary);transition:var(--transition-base);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.select-field:focus{border-color:var(--color-primary)}.select-field--error{border-color:var(--color-error)}.select-arrow{position:absolute;right:var(--spacing-md);color:var(--text-tertiary);pointer-events:none}.select-error-message{color:var(--color-error);font-size:var(--font-size-xs);margin-top:2px}.fixed-bottom-cta-container{position:fixed;bottom:0;left:0;right:0;padding:var(--spacing-sm) var(--spacing-lg) calc(var(--spacing-xl) + env(safe-area-inset-bottom));background-color:var(--bg-primary);z-index:10}.step-progress-container{width:100%;height:4px;background-color:var(--palette-gray-100);position:relative;overflow:hidden}.step-progress-bar{position:absolute;top:0;left:0;width:100%;height:100%;background-color:var(--color-primary);transform-origin:left;transform:scaleX(var(--progress, 0));transition:transform .6s cubic-bezier(.34,1.56,.64,1);z-index:1}.step-progress-segments{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;z-index:2;pointer-events:none}.step-progress-segment{flex:1;height:100%;position:relative}.step-progress-segment:after{content:"";position:absolute;right:0;top:0;width:2px;height:100%;background-color:#fff;z-index:3}.step-progress-segment:last-child:after{display:none}.ds-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;line-height:1.2;white-space:nowrap}.ds-badge--primary{background-color:var(--color-primary);color:#fff}.ds-badge--secondary{background-color:var(--color-secondary);color:#fff}.ds-badge--success{background-color:var(--color-success-bg, #e8f5e9);color:var(--color-success, #2e7d32)}.ds-badge--danger{background-color:var(--color-error-bg, #ffebee);color:var(--color-error, #c62828)}.ds-badge--warning{background-color:var(--color-warning-bg, #fff3e0);color:var(--color-warning, #ef6c00)}.ds-badge--neutral{background-color:var(--color-neutral-bg, #f5f5f5);color:var(--color-neutral, #616161)}.ds-badge--outline{background-color:transparent;border:1px solid var(--border-color, #e0e0e0);color:var(--text-secondary, #757575)}.skeleton{background-color:var(--palette-gray-200);border-radius:var(--radius-md);animation:skeleton-pulse 1.5s ease-in-out infinite;display:block}@keyframes skeleton-pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.month-year-picker-container{background-color:var(--bg-primary-weak);padding:var(--spacing-lg);width:100%;margin-bottom:var(--spacing-lg);animation:slideDown .9s cubic-bezier(.16,1,.3,1)}.picker-header{margin-bottom:var(--spacing-xl);display:flex;justify-content:center;align-items:center;gap:var(--spacing-md)}.current-year{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);min-width:60px;text-align:center}.nav-button{background:none;border:none;cursor:pointer;color:var(--text-primary);padding:var(--spacing-2xs);display:flex;align-items:center;justify-content:center;transition:opacity .2s ease}.nav-button:hover{opacity:.6}.months-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-xs);margin:var(--spacing-sm) 0}.month-button{background-color:var(--bg-primary);border:1px solid transparent;border-radius:var(--radius-md);height:48px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-md);color:var(--text-tertiary);border:1px solid var(--border-default);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.month-button:hover{color:var(--text-primary);transform:translateY(-1px)}.month-button.selected{background-color:var(--bg-primary);border-color:var(--color-primary);color:var(--color-primary);font-weight:var(--font-weight-bold);box-shadow:var(--shadow-purple)}.picker-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0 var(--spacing-2xs)}.reset-button{background:none;border:none;border-bottom:1px solid var(--text-tertiary);padding:0;color:var(--text-tertiary);font-size:var(--font-size-sm);cursor:pointer;line-height:1.2}.confirm-button{background-color:var(--color-primary);color:var(--text-inverse);border:none;border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-xl);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color .2s ease}.confirm-button:active{background-color:var(--color-primary-hover)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px);max-height:0}to{opacity:1;transform:translateY(0);max-height:400px}}.sub-header{position:sticky;top:0;z-index:100;background-color:transparent;height:var(--header-height-total);padding-top:env(safe-area-inset-top);transition:background-color .3s ease,backdrop-filter .3s ease,border-bottom .3s ease}.sub-header.scrolled{background-color:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.sub-header-content{height:100%;padding:0 var(--spacing-md);position:relative}.sub-header-back-button{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;position:absolute;left:var(--spacing-md);color:var(--text-primary)}.sub-header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%;text-align:center}.success-display-container{min-width:276px}.success-display-header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.success-display-icon-wrapper{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background-color:var(--color-primary);color:var(--text-inverse);margin-bottom:8px}.success-display-subtitle-container{padding:var(--spacing-md) var(--spacing-lg)}.success-display-subtitle{line-height:var(--line-height-relaxed);white-space:pre-wrap;font-weight:var(--font-weight-medium)}.success-display-subtitle .highlight{color:var(--color-primary);font-weight:var(--font-weight-medium)}.success-state-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);width:100%}.success-state-content{width:100%}.info-list{display:flex;flex-direction:column}.info-list.gap-sm{gap:var(--spacing-sm)}.info-list.gap-md{gap:var(--spacing-md)}.info-list.gap-lg{gap:var(--spacing-lg)}.info-row{display:flex;justify-content:space-between;align-items:center}.detail-card{border-radius:var(--radius-xl)}.detail-card-title{margin-bottom:var(--spacing-xl)}.action-card{position:relative;display:flex;justify-content:center;flex-direction:column}.action-card-row{display:flex;justify-content:space-between;align-items:center;width:100%}.action-card-main{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.action-card-icon{display:flex;align-items:center;justify-content:center}.action-card-content{display:flex;flex-direction:column;gap:var(--spacing-2xs);flex:1}.action-card-sublabel{line-height:var(--line-height-base)}.action-card-right{display:flex;align-items:center;gap:var(--spacing-sm)}.action-card-sublabel-right{color:var(--palette-gray-800)}.home-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px;height:var(--header-height-total);padding-top:env(safe-area-inset-top);background-color:transparent;position:sticky;top:0;z-index:100;transition:box-shadow .2s ease-in-out}.home-header.scrolled{background-color:var(--bg-primary);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 3px #0000000d}.home-header-left{display:flex;align-items:center}.home-header-logo{height:24px;width:auto}.home-header-right{display:flex;align-items:center;gap:16px}.home-header-icon-button{background:none;border:none;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative}.notification-badge{position:absolute;top:4px;right:6px;width:5px;height:5px;background-color:#ff3b30;border-radius:50%}.success-page-container{min-height:100vh;background-color:var(--bg-primary);display:flex;flex-direction:column;justify-content:center;align-items:center;padding-bottom:100px}.success-page-content{width:100%;padding:0 var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xl)}.success-page-bottom-actions{position:fixed;bottom:0;left:0;right:0;padding:var(--spacing-sm) var(--spacing-lg) var(--spacing-xl);background-color:var(--bg-primary);z-index:10}.success-page-highlight{color:var(--color-primary);font-weight:var(--font-weight-medium)}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:10000;pointer-events:none}.toast{min-width:320px;max-width:90vw;padding:12px 16px;border-radius:8px;background-color:var(--bg-primary);box-shadow:0 4px 12px #00000026;display:flex;align-items:flex-start;gap:12px;animation:slideUp .3s ease-out;pointer-events:auto;border:1px solid var(--border-color)}.toast.success{border-left:4px solid var(--color-success)}.toast.error{border-left:4px solid var(--color-error)}.toast.warning{border-left:4px solid var(--color-warning)}.toast.info{border-left:4px solid var(--color-primary)}.toast-content{flex:1}.toast-message{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.4}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ds-error-page-container{min-height:100vh;text-align:center;padding:var(--spacing-lg);background-color:var(--bg-secondary);color:var(--text-primary)}.ds-error-page-alert-icon{margin-bottom:var(--spacing-md)}.ds-error-page-heading{margin-bottom:var(--spacing-sm)}.ds-error-page-text{margin-bottom:var(--spacing-2xl)}.ds-error-page-details{margin:var(--spacing-xs) 0 var(--spacing-2xl);text-align:left;width:80%;max-width:600px;background-color:var(--bg-primary);padding:var(--spacing-md);border-radius:var(--radius-base);box-shadow:var(--shadow-sm);color:var(--text-secondary);max-height:200px;overflow-y:auto}.ds-error-page-details-summary{cursor:pointer;font-weight:var(--font-weight-semibold);color:var(--text-secondary)}.ds-error-page-details-message,.ds-error-page-details-stack{margin-top:var(--spacing-xs);font-family:var(--font-family-base);white-space:pre-wrap;word-break:break-all;font-size:.9em}.ds-error-page-button-group{min-width:220px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%}body{line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;background:none;border:none;outline:none}a{text-decoration:none;color:inherit}ul,ol{list-style:none}button{cursor:pointer}:root{--palette-primary-50: rgba(104, 69, 245, .05);--palette-primary-500: #6845f5;--palette-primary-600: rgba(104, 69, 245, .9);--palette-green-500: #43c465;--palette-emerald: var(--palette-green-500);--palette-orange-500: #ff9500;--palette-sunglow: #fecf33;--palette-red-500: #ff3b30;--palette-red-400: #ff6b6b;--palette-bittersweet: var(--palette-red-400);--palette-white: #ffffff;--palette-black: #000000;--palette-gray-50: #fcfcfc;--palette-gray-100: #f2f2f7;--palette-gray-200: #e5e5ea;--palette-gray-300: #d2d2d7;--palette-gray-400: #c7c7cc;--palette-gray-500: #aeaeb2;--palette-gray-600: #8e8e93;--palette-gray-700: #515154;--palette-gray-800: #3a3a3c;--palette-gray-900: #1d1d1f;--color-primary: var(--palette-primary-500);--color-primary-light: rgba(170, 150, 252, .15);--color-primary-hover: var(--palette-primary-600);--color-accent: #0075ff;--color-success: var(--palette-green-500);--color-attendance-present: var(--palette-emerald);--color-attendance-present-bg: rgba(67, 196, 101, .1);--color-attendance-makeup: var(--palette-sunglow);--color-attendance-makeup-bg: rgba(254, 207, 51, .1);--color-attendance-absent: var(--palette-bittersweet);--color-attendance-absent-bg: rgba(255, 107, 107, .1);--color-warning: var(--palette-orange-500);--color-error: var(--palette-red-400);--text-primary: var( --palette-gray-900 );--text-secondary: var(--palette-gray-700);--text-tertiary: var( --palette-gray-600 );--text-placeholder: var(--palette-gray-300);--text-inverse: var(--palette-white);--text-error: var(--color-error);--bg-primary: var(--palette-white);--bg-secondary: var(--palette-gray-50);--bg-tertiary: var(--palette-gray-100);--bg-input: var(--palette-white);--bg-overlay: rgba(0, 0, 0, .4);--bg-primary-weak: var(--palette-primary-50);--border-light: var(--palette-gray-100);--border-default: var(--palette-gray-300);--border-focus: var(--color-primary);--border-error: var(--color-error);--font-family-base: "Pretendard Variable", "Pretendard", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-xxl: 24px;--font-size-3xl: 32px;--font-size-display: 28px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1;--line-height-heading: 1.2;--line-height-subheading: 1.4;--line-height-base: 1.5;--line-height-relaxed: 1.6;--letter-spacing-tighter: -.5px;--letter-spacing-tight: -.3px;--letter-spacing-base: -.2px;--letter-spacing-normal: 0;--spacing-2xs: 4px;--spacing-xs: 8px;--spacing-sm: 12px;--spacing-md: 16px;--spacing-lg: 20px;--spacing-xl: 24px;--spacing-2xl: 32px;--spacing-3xl: 40px;--spacing-4xl: 80px;--border-width-thin: 1px;--border-width-medium: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-base: 10px;--radius-lg: 14px;--radius-xl: 16px;--radius-full: 9999px;--max-layout-width: 1000px;--shadow-sm: 0 0 14px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-purple: 0 4px 12px 0 rgba(104, 69, 245, .24);--transition-base: all .2s ease-in-out;--transition-fast: all .1s ease-in-out;--header-height-base: 48px;--header-height-total: calc( var(--header-height-base) + env(safe-area-inset-top) )}body{font-family:var(--font-family-base);background-color:var(--bg-secondary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}input,textarea{-webkit-user-select:auto;user-select:auto}.container{width:100%;max-width:var(--max-layout-width);margin:0 auto;padding:0 var(--spacing-lg)}.flex-center{display:flex;align-items:center;justify-content:center}.flex-col{display:flex;flex-direction:column}.text-center{text-align:center}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-xl);font-weight:var(--font-weight-semibold);transition:var(--transition-base);cursor:pointer}.btn-primary{background-color:var(--color-primary);color:var(--color-white)}.btn-primary:hover{opacity:.9}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-base{width:100%;padding:10px var(--spacing-md);border-radius:var(--radius-lg);border:var(--border-width-medium) solid var(--color-gray-300);font-size:var(--font-size-md);color:var(--color-gray-900);transition:var(--transition-base);background-color:var(--color-white)}.input-base:focus{border-color:var(--color-primary);outline:none}.input-base.error{border-color:var(--color-error)}.error-text{color:var(--color-error);font-size:var(--font-size-xs);margin-top:var(--spacing-2xs)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.animate-slide-down{animation:slideDown .3s ease-out}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:var(--palette-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:var(--palette-gray-400)}.container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:100vh;padding:0 var(--spacing-lg);background-color:var(--bg-primary)}.login-content-wrapper{display:flex;flex-direction:column;align-items:center;width:100%;max-width:335px}.login-logo-section{margin-bottom:var(--spacing-4xl)}.login-logo{width:170px;height:auto}.login-form{display:flex;flex-direction:column;width:100%;gap:var(--spacing-2xl)}.login-inputs-block-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2xs);width:100%}.login-inputs-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);width:100%}.login-input-group-margin{display:flex;flex-direction:column;width:100%}.login-input-container{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%;margin-bottom:var(--spacing-xs)}.login-label{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:var(--font-weight-regular);line-height:1.6}.login-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.login-input{width:100%;height:46px;padding:10px var(--spacing-md);background-color:var(--bg-input);border:var(--border-width-medium) solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--font-size-md);line-height:1.4;font-family:inherit;transition:border-color .2s ease}.login-input::placeholder{color:var(--text-placeholder)}.login-input:focus{border-color:var(--border-focus)}.login-input.error{border-color:var(--border-error)}.login-input-error-message{font-size:var(--font-size-xs);color:var(--text-error);font-weight:var(--font-weight-regular);line-height:1.4}.login-input-password{padding-right:44px}.login-eye-icon{position:absolute;right:var(--spacing-md);display:flex;align-items:center;justify-content:center;cursor:pointer}.login-auto-login-container{display:flex;align-items:center;gap:7px;cursor:pointer}.login-checkbox{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border:1px solid var(--border-default);border-radius:2.5px;background-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.login-checkbox.checked{background-color:var(--color-primary);border-color:var(--color-primary)}.login-auto-login-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);line-height:1.4}.login-button{margin-top:var(--spacing-sm)}.login-error{margin-bottom:var(--spacing-sm);color:var(--text-error);font-size:var(--font-size-sm);text-align:center}.login-signup-link{margin-top:var(--spacing-xl);font-size:var(--font-size-sm);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.signup-link-button{background:none;border:none;padding:0;color:var(--color-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;text-decoration:underline}.signup-link-button:hover{opacity:.8}.login-privacy-link{margin-top:var(--spacing-xl);display:flex;justify-content:center}.login-privacy-link a{font-size:var(--font-size-xs);color:var(--text-tertiary);text-decoration:underline}.login-privacy-link a:hover{color:var(--text-secondary)}.signup-container{padding:var(--spacing-xl) var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-2xl);min-height:100vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background-color:var(--bg-primary)}.signup-header{display:flex;align-items:center;gap:var(--spacing-md)}.signup-segmented-control{padding:0}.back-button{background:none;border:none;padding:var(--spacing-xs);margin-left:calc(var(--spacing-xs) * -1);cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center}.signup-form{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.signup-section{display:flex;flex-direction:column}.signup-fields{display:flex;flex-direction:column;gap:var(--spacing-lg)}.eye-button{background:none;border:none;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.signup-submit-button{margin-top:var(--spacing-xs)}.signup-agreement{text-align:center;margin-top:calc(var(--spacing-md) * -1)}.privacy-link{color:var(--color-primary);text-decoration:underline;font-weight:var(--font-weight-medium)}.privacy-link:hover{opacity:.8}.bottom-navigation{position:fixed;bottom:0;left:50%;transform:translate(-50%);right:0;background-color:var(--bg-secondary);max-width:var(--max-layout-width);width:100%;height:calc(56px + env(safe-area-inset-bottom));display:flex;justify-content:space-between;align-items:center;padding:0 var(--spacing-lg) env(safe-area-inset-bottom);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--border-light);box-shadow:var(--shadow-md);z-index:90}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;background:none;border:none;padding:0;min-width:60px;cursor:pointer;transition:all .2s ease}.bottom-nav-label{font-family:var(--font-family-base);font-weight:600;font-size:var(--font-size-xs);line-height:var(--line-height-relaxed);margin-top:2px}.bottom-nav-item.active .bottom-nav-icon{color:var(--color-primary);stroke-width:2.5}.bottom-nav-item.active .bottom-nav-label{color:var(--color-primary)}.bottom-nav-item .bottom-nav-icon{color:var(--text-tertiary);stroke-width:2}.bottom-nav-item .bottom-nav-label{color:var(--text-tertiary)}.app-layout{margin:0 auto;min-height:100vh;max-width:var(--max-layout-width);background-color:var(--bg-secondary);position:relative}.app-layout-main{padding-bottom:20px}.app-layout-main.with-bottom-nav{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.sticky-below-header{position:sticky;top:var(--header-height-total);z-index:10}.information-detail-page{min-height:100vh;background-color:var(--bg-secondary)}.information-detail-content{margin:var(--spacing-3xl) 0 var(--spacing-4xl)}.information-detail-card{background-color:var(--bg-primary)}.information-detail-title{margin-bottom:var(--spacing-xl);display:block}.information-detail-list{width:100%}.detail-section{display:flex;flex-direction:column}.detail-section:not(:last-child){margin-bottom:var(--spacing-xl)}.detail-section-divider{margin:var(--spacing-xl) 0}.detail-section-header{margin-bottom:var(--spacing-sm)}.detail-section-content{line-height:1.6}:root{--swiper-theme-color: #007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function, initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,#00000080,#0000)}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color, var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color: #fff}.swiper-lazy-preloader-black{--swiper-preloader-color: #000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.swiper-virtual .swiper-slide{-webkit-backface-visibility:hidden;transform:translateZ(0)}.swiper-virtual.swiper-css-mode .swiper-wrapper:after{content:"";position:absolute;left:0;top:0;pointer-events:none}.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper:after{height:1px;width:var(--swiper-virtual-size)}.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper:after{width:1px;height:var(--swiper-virtual-size)}:root{--swiper-navigation-size: 44px}.swiper-button-prev,.swiper-button-next{position:absolute;width:var(--swiper-navigation-size);height:var(--swiper-navigation-size);z-index:10;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--swiper-navigation-color, var(--swiper-theme-color))}.swiper-button-prev.swiper-button-disabled,.swiper-button-next.swiper-button-disabled{opacity:.35;cursor:auto;pointer-events:none}.swiper-button-prev.swiper-button-hidden,.swiper-button-next.swiper-button-hidden{opacity:0;cursor:auto;pointer-events:none}.swiper-navigation-disabled .swiper-button-prev,.swiper-navigation-disabled .swiper-button-next{display:none!important}.swiper-button-prev svg,.swiper-button-next svg{width:100%;height:100%;object-fit:contain;transform-origin:center;fill:currentColor;pointer-events:none}.swiper-button-lock{display:none}.swiper-button-prev,.swiper-button-next{top:var(--swiper-navigation-top-offset, 50%);margin-top:calc(0px - (var(--swiper-navigation-size) / 2))}.swiper-button-prev{left:var(--swiper-navigation-sides-offset, 4px);right:auto}.swiper-button-prev .swiper-navigation-icon{transform:rotate(180deg)}.swiper-button-next{right:var(--swiper-navigation-sides-offset, 4px);left:auto}.swiper-horizontal .swiper-button-prev,.swiper-horizontal .swiper-button-next,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal~.swiper-button-next{top:var(--swiper-navigation-top-offset, 50%);margin-top:calc(0px - (var(--swiper-navigation-size) / 2));margin-left:0}.swiper-horizontal .swiper-button-prev,.swiper-horizontal~.swiper-button-prev,.swiper-horizontal.swiper-rtl .swiper-button-next,.swiper-horizontal.swiper-rtl~.swiper-button-next{left:var(--swiper-navigation-sides-offset, 4px);right:auto}.swiper-horizontal .swiper-button-next,.swiper-horizontal~.swiper-button-next,.swiper-horizontal.swiper-rtl .swiper-button-prev,.swiper-horizontal.swiper-rtl~.swiper-button-prev{right:var(--swiper-navigation-sides-offset, 4px);left:auto}.swiper-horizontal .swiper-button-prev .swiper-navigation-icon,.swiper-horizontal~.swiper-button-prev .swiper-navigation-icon,.swiper-horizontal.swiper-rtl .swiper-button-next .swiper-navigation-icon,.swiper-horizontal.swiper-rtl~.swiper-button-next .swiper-navigation-icon{transform:rotate(180deg)}.swiper-horizontal.swiper-rtl .swiper-button-prev .swiper-navigation-icon,.swiper-horizontal.swiper-rtl~.swiper-button-prev .swiper-navigation-icon{transform:rotate(0)}.swiper-vertical .swiper-button-prev,.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-prev,.swiper-vertical~.swiper-button-next{left:var(--swiper-navigation-top-offset, 50%);right:auto;margin-left:calc(0px - (var(--swiper-navigation-size) / 2));margin-top:0}.swiper-vertical .swiper-button-prev,.swiper-vertical~.swiper-button-prev{top:var(--swiper-navigation-sides-offset, 4px);bottom:auto}.swiper-vertical .swiper-button-prev .swiper-navigation-icon,.swiper-vertical~.swiper-button-prev .swiper-navigation-icon{transform:rotate(-90deg)}.swiper-vertical .swiper-button-next,.swiper-vertical~.swiper-button-next{bottom:var(--swiper-navigation-sides-offset, 4px);top:auto}.swiper-vertical .swiper-button-next .swiper-navigation-icon,.swiper-vertical~.swiper-button-next .swiper-navigation-icon{transform:rotate(90deg)}.swiper-pagination{position:absolute;text-align:center;transition:.3s opacity;transform:translateZ(0);z-index:10}.swiper-pagination.swiper-pagination-hidden{opacity:0}.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled{display:none!important}.swiper-pagination-fraction,.swiper-pagination-custom,.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal{bottom:var(--swiper-pagination-bottom, 8px);top:var(--swiper-pagination-top, auto);left:0;width:100%}.swiper-pagination-bullets-dynamic{overflow:hidden;font-size:0}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transform:scale(.33);position:relative}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main{transform:scale(1)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev{transform:scale(.33)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next{transform:scale(.33)}.swiper-pagination-bullet{width:var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));height:var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));display:inline-block;border-radius:var(--swiper-pagination-bullet-border-radius, 50%);background:var(--swiper-pagination-bullet-inactive-color, #000);opacity:var(--swiper-pagination-bullet-inactive-opacity, .2)}button.swiper-pagination-bullet{border:none;margin:0;padding:0;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.swiper-pagination-clickable .swiper-pagination-bullet{cursor:pointer}.swiper-pagination-bullet:only-child{display:none!important}.swiper-pagination-bullet-active{opacity:var(--swiper-pagination-bullet-opacity, 1);background:var(--swiper-pagination-color, var(--swiper-theme-color))}.swiper-vertical>.swiper-pagination-bullets,.swiper-pagination-vertical.swiper-pagination-bullets{right:var(--swiper-pagination-right, 8px);left:var(--swiper-pagination-left, auto);top:50%;transform:translate3d(0,-50%,0)}.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet{margin:var(--swiper-pagination-bullet-vertical-gap, 6px) 0;display:block}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{top:50%;transform:translateY(-50%);width:8px}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{display:inline-block;transition:.2s transform,.2s top}.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet{margin:0 var(--swiper-pagination-bullet-horizontal-gap, 4px)}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{left:50%;transform:translate(-50%);white-space:nowrap}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s left}.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s right}.swiper-pagination-fraction{color:var(--swiper-pagination-fraction-color, inherit)}.swiper-pagination-progressbar{background:var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, .25));position:absolute}.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{background:var(--swiper-pagination-color, var(--swiper-theme-color));position:absolute;left:0;top:0;width:100%;height:100%;transform:scale(0);transform-origin:left top}.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill{transform-origin:right top}.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite{width:100%;height:var(--swiper-pagination-progressbar-size, 4px);left:0;top:0}.swiper-vertical>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite{width:var(--swiper-pagination-progressbar-size, 4px);height:100%;left:0;top:0}.swiper-pagination-lock{display:none}.swiper-scrollbar{border-radius:var(--swiper-scrollbar-border-radius, 10px);position:relative;touch-action:none;background:var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, .1))}.swiper-scrollbar-disabled>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-disabled{display:none!important}.swiper-horizontal>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-horizontal{position:absolute;left:var(--swiper-scrollbar-sides-offset, 1%);bottom:var(--swiper-scrollbar-bottom, 4px);top:var(--swiper-scrollbar-top, auto);z-index:50;height:var(--swiper-scrollbar-size, 4px);width:calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%))}.swiper-vertical>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-vertical{position:absolute;left:var(--swiper-scrollbar-left, auto);right:var(--swiper-scrollbar-right, 4px);top:var(--swiper-scrollbar-sides-offset, 1%);z-index:50;width:var(--swiper-scrollbar-size, 4px);height:calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%))}.swiper-scrollbar-drag{height:100%;width:100%;position:relative;background:var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, .5));border-radius:var(--swiper-scrollbar-border-radius, 10px);left:0;top:0}.swiper-scrollbar-cursor-drag{cursor:move}.swiper-scrollbar-lock{display:none}.swiper-zoom-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center;text-align:center}.swiper-zoom-container>img,.swiper-zoom-container>svg,.swiper-zoom-container>canvas{max-width:100%;max-height:100%;object-fit:contain}.swiper-slide-zoomed{cursor:move;touch-action:none}.swiper .swiper-notification{position:absolute;left:0;top:0;pointer-events:none;opacity:0;z-index:-1000}.swiper-free-mode>.swiper-wrapper{transition-timing-function:ease-out;margin:0 auto}.swiper-grid>.swiper-wrapper{flex-wrap:wrap}.swiper-grid-column>.swiper-wrapper{flex-wrap:wrap;flex-direction:column}.swiper-fade.swiper-free-mode .swiper-slide{transition-timing-function:ease-out}.swiper-fade .swiper-slide{pointer-events:none;transition-property:opacity}.swiper-fade .swiper-slide .swiper-slide{pointer-events:none}.swiper-fade .swiper-slide-active,.swiper-fade .swiper-slide-active .swiper-slide-active{pointer-events:auto}.swiper.swiper-cube{overflow:visible}.swiper-cube .swiper-slide{pointer-events:none;backface-visibility:hidden;z-index:1;visibility:hidden;transform-origin:0 0;width:100%;height:100%}.swiper-cube .swiper-slide .swiper-slide{pointer-events:none}.swiper-cube.swiper-rtl .swiper-slide{transform-origin:100% 0}.swiper-cube .swiper-slide-active,.swiper-cube .swiper-slide-active .swiper-slide-active{pointer-events:auto}.swiper-cube .swiper-slide-active,.swiper-cube .swiper-slide-next,.swiper-cube .swiper-slide-prev{pointer-events:auto;visibility:visible}.swiper-cube .swiper-cube-shadow{position:absolute;left:0;bottom:0;width:100%;height:100%;opacity:.6;z-index:0}.swiper-cube .swiper-cube-shadow:before{content:"";background:#000;position:absolute;left:0;top:0;bottom:0;right:0;filter:blur(50px)}.swiper-cube .swiper-slide-next+.swiper-slide{pointer-events:auto;visibility:visible}.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top,.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom,.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left,.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right{z-index:0;backface-visibility:hidden}.swiper.swiper-flip{overflow:visible}.swiper-flip .swiper-slide{pointer-events:none;backface-visibility:hidden;z-index:1}.swiper-flip .swiper-slide .swiper-slide{pointer-events:none}.swiper-flip .swiper-slide-active,.swiper-flip .swiper-slide-active .swiper-slide-active{pointer-events:auto}.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top,.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom,.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left,.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right{z-index:0;backface-visibility:hidden}.swiper-creative .swiper-slide{backface-visibility:hidden;overflow:hidden;transition-property:transform,opacity,height}.swiper.swiper-cards{overflow:visible}.swiper-cards .swiper-slide{transform-origin:center bottom;backface-visibility:hidden;overflow:hidden}.main-banner-container{width:100%;height:300px;padding:0 var(--spacing-lg);margin-bottom:var(--spacing-sm);box-sizing:border-box}.main-banner-wrapper{width:100%;height:100%;border-radius:var(--radius-lg);overflow:hidden;position:relative;background-color:#d9d9d9}.main-banner-swiper{width:100%;height:100%}.main-banner-image{width:100%;height:100%;object-fit:cover}.main-banner-indicator{padding:var(--spacing-2xs) 10px;position:absolute;bottom:var(--spacing-lg);right:var(--spacing-lg);background-color:#0009;z-index:10;border-radius:var(--radius-full)}.section-title{padding:var(--spacing-sm) var(--spacing-lg)}.section-title .honorific{font-size:var(--font-size-md);color:var(--text-tertiary);font-weight:var(--font-weight-medium)}.typography.heading-3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-base);color:var(--text-primary)}.typography.heading-4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-base);color:var(--text-secondary)}.attendance-stat-card{min-height:100px;box-shadow:var(--shadow-sm);width:100%;flex:1;background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:0}.attendance-stat-card .attendance-stat-count{color:var(--text-primary);font-size:var(--font-size-xxl);font-weight:var(--font-weight-bold);line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-tighter);margin-bottom:0}.attendance-stat-card .attendance-stat-label{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-base)}.attendance-stats-wrapper{padding:4px 20px}.attendance-stats-wrapper.has-progress{margin-bottom:var(--spacing-md)}.attendance-progress-container{padding:0 20px}.attendance-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.attendance-progress-label{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.attendance-progress-value{font-size:var(--font-size-xxl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.attendance-progress-bar-bg{width:100%;height:8px;background-color:var(--bg-tertiary, #f1f3f5);border-radius:4px;overflow:hidden}.attendance-progress-bar-fill{height:100%;background-color:var(--color-primary, #6c5ce7);border-radius:4px;transition:width .3s ease}.clinic-card-link{text-decoration:none;color:inherit;display:block}.clinic-card-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:218px;width:100%;flex-shrink:0;cursor:pointer}.clinic-card-date-header{display:flex;align-items:center;gap:var(--spacing-xs)}.clinic-card-indicator{width:3px;height:var(--spacing-md);border-radius:var(--radius-sm);background-color:var(--color-primary);flex-shrink:0}.clinic-card-link.completed .clinic-card-indicator{background-color:var(--palette-gray-300)}.clinic-card-date-info{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--text-secondary);line-height:var(--line-height-subheading);letter-spacing:var(--letter-spacing-base);white-space:nowrap}.clinic-card-link.completed .clinic-card-date-info{color:var(--text-tertiary)}.clinic-card-dot{width:3px;height:3px;border-radius:50%;background-color:var(--text-secondary);opacity:.5}.clinic-card-link.completed .clinic-card-dot{background-color:var(--text-tertiary)}.clinic-card-content{display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-md);box-shadow:var(--shadow-sm);width:100%;box-sizing:border-box;transition:background-color .2s ease,box-shadow .2s ease}.clinic-card-info{display:flex;flex-direction:column;gap:var(--spacing-2xs);flex:1;min-width:0}.clinic-card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:var(--line-height-subheading);letter-spacing:var(--letter-spacing-tight);color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.clinic-card-link.completed .clinic-card-title{color:var(--text-tertiary)}.clinic-card-detail{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap;color:var(--text-tertiary);line-height:var(--line-height-subheading);letter-spacing:var(--letter-spacing-base)}.clinic-card-detail.location{white-space:nowrap}.clinic-card-arrow{flex-shrink:0;margin-left:var(--spacing-xs)}.upcoming-clinics-wrapper{margin-top:var(--spacing-sm)}.upcoming-clinics-scroll-area{display:flex;gap:var(--spacing-md);padding:0 var(--spacing-lg);overflow-x:auto;padding-bottom:var(--spacing-xs);scrollbar-width:none;-ms-overflow-style:none}.student-clinics-page{min-height:100%;background-color:var(--bg-secondary);padding-bottom:80px}.clinics-section{display:flex;flex-direction:column}.completed-section{margin-top:0}.upcoming-clinics-scroll-area{display:flex;gap:var(--spacing-md);padding:0 var(--spacing-lg) var(--spacing-md);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.upcoming-clinics-scroll-area::-webkit-scrollbar{display:none}.divider-wrapper{margin:var(--spacing-sm) 0}.date-picker-trigger{padding:4px 8px;height:auto;gap:4px;color:var(--text-tertiary);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.filter-scroll-area{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.filter-scroll-area::-webkit-scrollbar{display:none}.filter-container{padding:var(--spacing-2xs) var(--spacing-lg)}.completed-list{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-4xl)}.clinic-info-section{display:flex;flex-direction:column}.clinic-info-divider{margin:16px 0}.step4-complete-container{padding-top:var(--spacing-4xl)}.step4-success-header{margin-bottom:var(--spacing-lg)}.step4-success-icon-wrapper{width:40px;height:40px;border-radius:50%;background-color:var(--color-primary);display:flex;align-items:center;justify-content:center;color:var(--text-inverse)}.step4-success-title{font-size:22px!important;font-weight:var(--font-weight-bold)!important;color:var(--text-primary)!important}.student-clinic-reservation-page{min-height:100vh;background-color:var(--bg-primary)}.reservation-divider{height:var(--spacing-sm);background-color:var(--bg-secondary);border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}.reservation-calendar-wrapper{background-color:var(--bg-primary)}.reservation-section{margin-top:var(--spacing-xs)}.reservation-group{margin-bottom:var(--spacing-sm)}.reservation-container-no-padding{padding-top:0!important;padding-bottom:0!important}.reservation-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xs)}.reservation-empty-state{grid-column:1 / -1;padding:1rem;text-align:center;color:var(--text-tertiary)}.section-title{padding:var(--spacing-sm) var(--spacing-lg) var(--spacing-sm)}.video-detail-page{background-color:var(--bg-secondary);min-height:100vh}.video-player-container{width:100%;aspect-ratio:16 / 9;background-color:#000}.video-list-section{padding:20px 16px;background-color:var(--bg-primary);position:relative;z-index:11}.video-subject-accordion.ds-accordion{padding:0;background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:none;overflow:hidden}.video-subject-accordion .accordion-header{padding:var(--spacing-xs) var(--spacing-md)}.video-subject-accordion .accordion-title-text{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.video-subject-accordion .accordion-content{padding:0;gap:0}.video-list-container{margin-bottom:var(--spacing-sm)}.video-item{padding:var(--spacing-sm) var(--spacing-lg);cursor:pointer;display:flex;align-items:center}.video-item:hover,.video-item.active{background-color:var(--bg-tertiary)}.video-item.active .video-title{color:var(--primary-color);font-weight:600}.active-text{color:var(--primary-color)}.video-icon{margin-right:var(--spacing-sm);fill:var(--color-primary);stroke:var(--text-inverse);flex-shrink:0}.video-title{color:var(--text-primary);font-weight:var(--font-weight-medium)}.student-review-video-page{padding-top:var(--spacing-2xs);padding-bottom:var(--spacing-4xl);min-height:100%}.video-subject-list{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-lg)}.status-badge{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:6px var(--spacing-xs);border-radius:var(--radius-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);min-width:43px;text-align:center;line-height:1}.status-badge.status-success{background-color:var(--color-attendance-present-bg);color:var(--color-attendance-present)}.status-badge.status-failure{background-color:var(--color-attendance-absent-bg);color:var(--color-attendance-absent)}.status-badge.status-present{background-color:var(--color-attendance-present-bg);color:var(--color-attendance-present)}.status-badge.status-makeup{background-color:var(--color-attendance-makeup-bg);color:var(--color-attendance-makeup)}.status-badge.status-absent{background-color:var(--color-attendance-absent-bg);color:var(--color-attendance-absent)}.status-badge.status-excused{background-color:var(--color-attendance-makeup-bg);color:var(--color-attendance-makeup)}.daily-attendance-status-container{padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.daily-attendance-status-row{width:100%}.date-indicator-bar{width:3px;height:16px;background-color:var(--color-primary)}.date-text{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary)}.attendance-detail-info{margin-top:var(--spacing-sm)}.attendance-actions{margin-left:var(--spacing-xs)}.action-button{padding:4px!important;min-width:auto!important;height:auto!important;color:var(--text-secondary)!important}.action-button:hover{background-color:var(--bg-secondary)!important}.action-button.edit:hover{color:var(--color-primary)!important}.action-button.delete:hover{color:var(--color-error)!important}.attendance-form{width:100%}.attendance-form-submit{margin-top:var(--spacing-md);height:48px;border-radius:var(--radius-lg)}.attendance-add-modal-content{padding-top:var(--spacing-md)}.ds-modal-container{max-width:335px!important}.ds-modal-header{border-bottom:none!important;padding-bottom:0!important}.ds-modal-title{font-size:var(--font-size-lg)!important;font-weight:var(--font-weight-bold)!important}.weakness-card .weakness-card-header{margin-bottom:var(--spacing-xs)}.weakness-card .weakness-title{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weakness-card .weakness-title-prefix{font-weight:var(--font-weight-bold);font-size:var(--font-size-md);color:var(--text-secondary)}.weakness-card .weakness-title-text{font-size:var(--font-size-md);color:var(--text-primary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weakness-card .rate-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xs)}.weakness-card .rate-label{font-size:var(--font-size-sm);color:var(--text-tertiary)}.weakness-card .rate-values{min-width:127px;font-size:var(--font-size-sm);text-align:right;color:var(--text-tertiary)}.weakness-card .my-rate{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary)}.weakness-card .my-rate.success{color:var(--color-success)}.weakness-card .my-rate.failure{color:var(--color-error)}.weakness-card .progress-bar-bg{width:100%;height:6px;background-color:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.weakness-card .progress-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.weakness-card .progress-bar-fill.success{background-color:var(--color-success)}.weakness-card .progress-bar-fill.failure{background-color:var(--color-error)}.weakness-card .weakness-clinic-button-wrapper{margin-top:var(--spacing-lg)}.unit-analysis-list{border-radius:var(--radius-xl);background-color:var(--bg-primary);box-shadow:var(--shadow-sm);overflow:hidden}.unit-item-accordion.ds-accordion{padding:0}.unit-item-accordion.ds-accordion:not(:last-child){border-bottom:none}.unit-item-accordion .accordion-header{padding:var(--spacing-xs) var(--spacing-md)}.unit-item-accordion .accordion-title-text{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:var(--line-height-relaxed)}.unit-item-accordion .accordion-content{padding:0;gap:0}.sub-unit-accordion.ds-accordion{padding:0;border-bottom:none;border-top:1px solid var(--border-light)}.sub-unit-accordion:first-child.ds-accordion{border-top:none}.sub-unit-accordion .accordion-header{padding:var(--spacing-xs) var(--spacing-md)}.sub-unit-accordion .accordion-title-text{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin-left:var(--spacing-sm)}.theme-list{display:flex;flex-direction:column;gap:var(--spacing-xs);background-color:var(--bg-tertiary);padding:var(--spacing-sm) var(--spacing-md) var(--spacing-xl)}.theme-item{padding:var(--spacing-xs) 0 var(--spacing-xs) var(--spacing-xl);font-size:var(--font-size-md);line-height:var(--line-height-relaxed);color:var(--text-primary)}.theme-item-button{width:100%;text-align:left;background-color:transparent;border:none;cursor:pointer;padding:0;margin:0}.theme-item+.theme-weakness-card{margin:var(--spacing-xs) 0 var(--spacing-xs) var(--spacing-xl)}.theme-item-button.is-active .theme-item{color:var(--color-primary);font-weight:var(--font-weight-bold)}.theme-item-button .theme-weakness-card{display:none}.theme-item-button.is-active .theme-weakness-card{display:block}.chart-container-radar{width:100%;height:260px;position:relative}.chart-container-trend{width:100%;height:280px;position:relative}.chart-no-data-wrapper{width:100%;height:250px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.collapse-selector{padding:var(--spacing-sm) var(--spacing-xl);background-color:var(--palette-gray-100);border-bottom:1px solid var(--border-light);cursor:pointer;transition:background-color .2s}.collapse-selector:active{background-color:var(--palette-gray-200)}.selector-icon-wrapper{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);background-color:var(--bg-primary);box-shadow:var(--shadow-sm);color:var(--color-primary)}.chevron-wrapper{transition:transform .3s ease;color:var(--text-tertiary)}.chevron-wrapper.up{transform:rotate(180deg)}.collapse-options-container{background-color:var(--bg-primary);border-bottom:1px solid var(--border-light);max-height:300px;overflow-y:auto}.option-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-2xl);border-bottom:1px solid var(--border-extra-light);cursor:pointer;transition:background-color .2s}.option-item:active{background-color:var(--palette-gray-50)}.option-item.is-selected{color:var(--color-primary);font-weight:var(--font-weight-bold)}.check-icon{color:var(--color-primary)}.result-card{flex:1}.result-card-title{margin-bottom:4px}.result-card-status-badge{position:absolute;right:0;top:50%;transform:translateY(-50%)}.student-attendance-page{min-height:100vh;background-color:var(--bg-secondary);padding-bottom:80px}.student-attendance-content-wrapper{padding:var(--spacing-sm) 0 var(--spacing-xl)}.calendar-section{background-color:var(--bg-primary)}.teacher-home-header{padding:var(--spacing-sm) 0}.teacher-stats-section{padding:var(--spacing-sm) var(--spacing-lg)}.teacher-stats-row{display:flex}.teacher-stats-row>*{flex:1}.teacher-home-content{padding:var(--spacing-lg) 0 var(--spacing-4xl)}.teacher-stats-card{display:flex;align-items:center}.teacher-stats-card.primary{background-color:var(--color-primary);box-shadow:var(--shadow-purple);border:none}.teacher-vertical-list{padding:0 var(--spacing-lg)}.teacher-list-item-wrapper{width:100%}.teacher-clinics-page{background-color:var(--bg-secondary);padding-bottom:var(--spacing-4xl)}.teacher-calendar-wrapper{background-color:var(--bg-primary)}.teacher-clinics-content{padding-top:var(--spacing-lg);background-color:var(--bg-secondary)}.clinics-filter{padding:var(--spacing-2xs) var(--spacing-lg)}.clinics-list{padding:var(--spacing-lg)}.dashboard-section{width:100%}.section-title-btn{background:none;border:none;padding:0;margin:0;width:100%;text-align:left;cursor:pointer;display:block}.section-title-btn:active{opacity:.7}.section-scroll-container{display:flex;overflow-x:auto;gap:var(--spacing-md);padding-bottom:var(--spacing-xs);padding-left:var(--spacing-lg);padding-right:var(--spacing-lg);-ms-overflow-style:none;scrollbar-width:none}.section-scroll-container::-webkit-scrollbar{display:none}.teacher-home-content{width:100%}.teacher-card-wrapper{min-width:218px;flex-shrink:0}.generic-list-page{padding-bottom:var(--spacing-4xl)}.teacher-tasks-container{padding:var(--spacing-2xs) 0 var(--spacing-4xl)}.task-section{padding:var(--spacing-xs) var(--spacing-lg)}.available-times-page{min-height:100vh;background-color:var(--background-secondary)}.available-day-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-primary)}.available-day-page .content-container{flex:1}.time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-bottom:100px}.teacher-exams-page{min-height:100%;background-color:var(--palette-gray-50);display:flex;flex-direction:column}.exam-list-container{flex:1}.teacher-exam-create-page{min-height:100%;background-color:#fff;display:flex;flex-direction:column}.question-types-container{flex:1;overflow-y:auto}.teacher-exam-types-page{min-height:100%;background-color:var(--palette-gray-50);display:flex;flex-direction:column}.teacher-exam-types-page .action-btn.ds-button{padding:0 var(--spacing-xs);min-width:auto}.teacher-exam-types-page .unit-item-accordion .accordion-title-content p{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary)}.teacher-exam-types-page .sub-unit-accordion .accordion-title-content p{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.teacher-exam-types-page .theme-item{padding-right:var(--spacing-sm)!important}.teacher-exam-types-page .theme-item-button:hover{background-color:#00000005}.teacher-exam-type-create-page{min-height:100%;background-color:#fff;display:flex;flex-direction:column}.suggestion-dropdown{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-md);max-height:200px;overflow-y:auto;z-index:100;margin-top:4px}.suggestion-item{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-md);color:var(--text-primary);cursor:pointer;border-bottom:1px solid var(--border-light)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item:active{background-color:var(--bg-secondary);color:var(--color-primary)}.teacher-exam-grade-create-page{min-height:100%;background-color:#fff;display:flex;flex-direction:column}.grade-results-container{flex:1;overflow-y:auto}.teacher-exam-grades-page{min-height:100vh;background-color:var(--palette-gray-50)}.grade-list-container{padding-bottom:80px}.grade-item-card{background-color:var(--palette-white);padding:16px;border-radius:12px;box-shadow:0 2px 8px #0000000d}.grade-item-card .lucide-clipboard-check{background-color:var(--palette-primary-50);padding:8px;border-radius:8px;width:40px;height:40px}.action-btn.ds-button{padding:0 var(--spacing-xs);min-width:auto}.teacher-students-page{background-color:var(--white);min-height:100vh;padding-bottom:80px}.student-list-container{padding:0 var(--spacing-lg) var(--spacing-xl)}.student-search-input{margin-bottom:var(--spacing-sm)}.teacher-student-detail-page{background-color:var(--white);min-height:100vh;padding-bottom:80px}.admin-layout{display:flex;flex-direction:column;height:100vh;background-color:var(--palette-background)}.admin-header{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background-color:#fff;border-bottom:1px solid var(--palette-gray-200);position:sticky;top:0;z-index:100}.menu-toggle-btn{background:none;border:none;cursor:pointer;display:none;padding:4px}.admin-title{font-size:18px;font-weight:600;color:var(--palette-gray-900);margin:0}.logout-btn{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;color:var(--palette-gray-600);font-size:14px}.logout-btn:hover{color:var(--palette-primary-main)}.admin-container{display:flex;flex:1;overflow:hidden;position:relative}.admin-sidebar{width:240px;background-color:#fff;border-right:1px solid var(--palette-gray-200);display:flex;flex-direction:column;height:100%;transition:transform .3s ease;z-index:90}.sidebar-header{display:none;padding:20px;border-bottom:1px solid var(--palette-gray-200);align-items:center;justify-content:space-between}.sidebar-header h2{margin:0;font-size:18px}.close-sidebar-btn{background:none;border:none;cursor:pointer}.admin-nav{padding:20px 0;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;background:none;border:none;cursor:pointer;width:100%;text-align:left;color:var(--palette-gray-600);font-size:15px;transition:background-color .2s}.nav-item:hover{background-color:var(--palette-gray-100);color:var(--palette-gray-900)}.nav-item.active{background-color:var(--palette-primary-light);color:var(--palette-primary-main);font-weight:500;border-right:3px solid var(--palette-primary-main)}.admin-content{flex:1;overflow-y:auto;padding:24px;background-color:var(--palette-gray-50)}.sidebar-overlay{display:none;position:absolute;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:80}@media(max-width:768px){.menu-toggle-btn{display:block}.admin-sidebar{position:absolute;top:0;left:0;bottom:0;transform:translate(-100%);box-shadow:2px 0 8px #0000001a}.admin-sidebar.open{transform:translate(0)}.sidebar-header{display:flex}.sidebar-overlay{display:block}.logout-text{display:none}.admin-content{padding:16px}}.admin-error-message{margin-top:var(--spacing-md);color:var(--palette-red-500);font-size:var(--font-size-sm);text-align:left;display:flex;align-items:center;gap:4px}.admin-error-message:before{content:"⚠"}.admin-page-container{padding:12px;max-width:1200px;margin:0 auto}.admin-section-title{font-size:28px;font-weight:700;color:var(--palette-gray-900);margin-bottom:32px}.admin-card{background-color:var(--palette-white);padding:32px;border-radius:12px;box-shadow:0 2px 8px #0000000d;text-decoration:none;transition:transform .2s,box-shadow .2s;color:inherit;border:none}.admin-card--hoverable:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.admin-card-title{margin:0 0 8px;font-size:20px;font-weight:600;color:var(--palette-gray-900)}.admin-card-description{margin:0;color:var(--palette-gray-600);font-size:14px;line-height:1.5}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.admin-auth-container{height:100vh;display:flex;justify-content:center;align-items:center;background-color:var(--palette-gray-50)}.admin-auth-card{width:100%;max-width:400px;background-color:var(--palette-white);padding:40px;border-radius:8px;box-shadow:0 4px 12px #0000001a}.admin-auth-title{text-align:center;margin-bottom:32px;font-size:24px;font-weight:700;color:var(--palette-gray-900)}.admin-error-message{color:var(--palette-red-400);font-size:14px;text-align:center;margin-top:12px}.admin-home-icon-wrapper{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var( --bg-primary-weak );color:var(--color-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.admin-page-layout{max-width:1200px;margin:0 auto;height:calc(100vh - 64px);display:flex;flex-direction:column;padding:12px;box-sizing:border-box;overflow-x:hidden}.admin-page-layout .admin-page-header{margin-bottom:32px;flex-shrink:0}.admin-page-layout .page-title{font-size:24px;font-weight:700;color:var(--palette-gray-900);margin:0}.admin-page-layout .simple-filter-bar{padding:0 0 20px;flex-shrink:0;display:flex;gap:12px;align-items:center}.admin-page-layout .search-type-select{width:140px}.admin-page-layout .search-action-group{display:flex;flex:1;gap:8px;align-items:center;min-width:0}.admin-page-layout .admin-search-input{width:100%;flex:1;max-width:400px}.admin-page-layout .page-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}@media(max-width:768px){.admin-page-layout{overflow-x:hidden}.admin-page-layout .simple-filter-bar{display:block;width:100%;padding-bottom:12px}.admin-page-layout .search-type-select{display:block;width:100%!important;margin-bottom:12px;box-sizing:border-box}.admin-page-layout .search-action-group{display:flex;width:100%;gap:8px;box-sizing:border-box}.admin-page-layout .admin-search-input{width:auto!important;flex:1;max-width:none;min-width:0;box-sizing:border-box}.admin-page-layout .search-button{flex-shrink:0;width:auto!important}}.admin-data-grid-container{flex:1;display:flex;flex-direction:column;min-height:0;width:100%}.admin-data-grid-container .grid-scroll-hint{padding-bottom:8px;-webkit-user-select:none;user-select:none}@media(max-width:768px){.admin-data-grid-container .grid-scroll-hint{display:none}}.admin-data-grid-container .admin-data-grid{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;flex:1;overflow:auto;position:relative;min-height:400px}.admin-data-grid-container .grid-pagination{padding:24px 0 8px;flex-shrink:0;display:flex;justify-content:center;align-items:center;background-color:transparent;border-top:1px solid var(--palette-gray-100);margin-top:8px}.admin-data-grid-container .pagination-ellipsis{color:var(--palette-gray-400);font-size:14px;padding:0 4px}.admin-data-grid-container .grid-header{display:grid;padding:12px 24px;background-color:var(--palette-gray-100);font-weight:600;color:var(--palette-gray-700);border-bottom:1px solid var(--palette-gray-200);position:sticky;top:0;z-index:10;box-shadow:0 2px 4px #0000000d;min-width:fit-content}.admin-data-grid-container .grid-body{min-width:fit-content}.admin-data-grid-container .grid-loading-container{flex:1;display:flex;align-items:center;justify-content:center;min-height:400px}.admin-data-grid-container .grid-row{display:grid;padding:12px 24px;align-items:center;border-bottom:1px solid var(--palette-gray-100);transition:background-color .2s;min-width:fit-content}.admin-data-grid-container .grid-row:last-child{border-bottom:none}.admin-data-grid-container .grid-row:hover{background-color:var(--palette-gray-50)}.admin-data-grid-container .grid-row--clickable{cursor:pointer}.admin-data-grid-container .grid-row--clickable:hover{background-color:var(--palette-gray-100)}.admin-data-grid-container .header-cell{position:relative;display:flex;align-items:center;height:100%;-webkit-user-select:none;user-select:none;border-right:1px solid var(--palette-gray-300);padding:0 8px}.admin-data-grid-container .header-cell:last-child{border-right:none}.admin-data-grid-container .grid-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:8px;border-right:1px solid var(--palette-gray-200);padding-left:8px}.admin-data-grid-container .grid-cell:last-child{border-right:none}.admin-data-grid-container .resizer{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:1}.admin-data-grid-container .resizer:hover{background-color:var(--color-primary)}@media(max-width:768px){.admin-data-grid-container .admin-data-grid{background-color:transparent;box-shadow:none;border-radius:0}.admin-data-grid-container .grid-header{display:none}.admin-data-grid-container .grid-body{display:flex;flex-direction:column;gap:16px;min-width:0}.admin-data-grid-container .grid-row{display:flex!important;flex-direction:column;gap:12px;padding:16px;background-color:#fff;border-radius:12px;border:1px solid var(--palette-gray-200);box-shadow:0 2px 8px #0000000d;min-width:0}.admin-data-grid-container .grid-cell{display:flex;justify-content:space-between;align-items:center;width:100%;padding:0 0 8px;border-right:none;border-bottom:1px solid var(--palette-gray-100);white-space:normal;font-size:14px;color:var(--text-primary)}.admin-data-grid-container .grid-cell:last-child{border-bottom:none;padding-bottom:0}.admin-data-grid-container .grid-cell[data-label=""]{display:none}.admin-data-grid-container .grid-cell[data-label=관리]{border-top:1px solid var(--palette-gray-100);border-bottom:none;margin-top:8px;padding-top:12px;justify-content:flex-end}.admin-data-grid-container .grid-cell[data-label=관리]:before{display:none}.admin-data-grid-container .banner-thumbnail-cell img{max-width:100px;height:auto;border-radius:4px}.admin-data-grid-container .grid-cell:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);margin-right:16px;min-width:80px;flex-shrink:0;text-align:left;display:inline-block}}.admin-icon-btn{padding:8px!important;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center}.admin-icon-btn:hover{background-color:var(--palette-gray-100)}.delete-btn:hover{background-color:var(--palette-red-50)}.class-grid-cols{grid-template-columns:2.5fr 1fr 2fr .8fr 100px}.data-grid{max-height:calc(100vh - 200px);overflow-y:auto;position:relative;overflow-x:auto}.grid-header{position:sticky;top:0;z-index:10;background-color:var(--palette-gray-100);box-shadow:0 2px 4px #0000000d;min-width:fit-content}.grid-row{min-width:fit-content}.header-cell{position:relative;display:flex;align-items:center;height:100%}.resizer{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;-webkit-user-select:none;user-select:none}.resizer:hover{background-color:var(--palette-primary-main)}.status-cell{display:flex;align-items:center}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:13px;font-weight:600;line-height:1.4}.status-badge.active{background-color:#e6fffa;color:var(--palette-status-success)}.status-badge.inactive{background-color:var(--palette-gray-200);color:var(--palette-gray-600)}.admin-select{width:100%;padding:12px;border-radius:8px;border:1px solid var(--palette-gray-300);font-size:16px;background-color:#fff}@media(max-width:768px){.class-grid-cols{display:flex;flex-direction:column}.grid-header{display:none}.data-grid{max-height:none;overflow-y:visible;overflow-x:hidden}.resizer{display:none}}.admin-class-detail-page{display:flex;flex-direction:column;height:100%}.admin-class-detail-header{background-color:var(--bg-primary);border-bottom:1px solid var(--border-light)}.admin-class-detail-header h2{margin:0;font-size:24px;font-weight:600;color:var(--text-primary)}.class-description{margin:0;font-size:14px;color:var(--text-secondary)}.class-teacher{margin:0;font-size:14px;color:var(--text-tertiary)}.admin-class-detail-content{flex:1;overflow-y:auto}.video-grid-cols{grid-template-columns:2fr 1fr .8fr 2fr 100px}.data-grid{max-height:calc(100vh - 200px);overflow-y:auto;position:relative}.grid-header{position:sticky;top:0;z-index:10;background-color:var(--palette-gray-100);box-shadow:0 2px 4px #0000000d}.text-ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}.icon-btn{padding:8px!important;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.video-grid-cols{display:flex;flex-direction:column}.grid-header{display:none}.data-grid{max-height:none;overflow-y:visible}}.banner-thumbnail-cell{width:100px;height:56px;border-radius:4px;overflow:hidden;background-color:var(--palette-gray-100);display:flex;align-items:center;justify-content:center;border:1px solid var(--palette-gray-200)}.banner-thumbnail-cell img{width:100%;height:100%;object-fit:cover}.empty-thumb{color:var(--palette-gray-400)}.banner-form-preview{width:100%;height:160px;border-radius:8px;overflow:hidden;background-color:var(--palette-gray-50);border:1px solid var(--palette-gray-200);display:flex;align-items:center;justify-content:center;margin-top:12px}.banner-form-preview img{width:100%;height:100%;object-fit:contain}.grid-row.draggable{cursor:grab}.grid-row.draggable:active{cursor:grabbing}.drag-cell{display:flex;align-items:center;justify-content:center}.drag-handle{color:var(--palette-gray-200);transition:all .2s}.drag-handle.active{color:var(--color-primary);cursor:grab}.mode-reorder .grid-row:hover{background-color:var(--palette-gray-50)}.grid-row.dragging{opacity:.5;background-color:var(--palette-primary-50);border:2px dashed var(--color-primary)}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:12px}.empty-state-placeholder{padding:40px;text-align:center;color:var(--palette-gray-500);background-color:#fff}.banner-upload-area{width:100%}.upload-mode-selector{display:flex;background-color:var(--palette-gray-100);padding:3px;border-radius:var(--radius-md);margin-bottom:16px;width:100%}.mode-tab{flex:1;padding:6px 12px;border:none;background:none;font-size:13px;font-weight:500;color:var(--palette-gray-600);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s}.mode-tab:hover{color:var(--palette-gray-900)}.mode-tab.active{background-color:var(--palette-white);color:var(--color-primary);box-shadow:0 1px 3px #0000001a}.banner-upload-placeholder{width:100%;min-height:120px;border:2px dashed var(--palette-gray-300);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;background-color:var(--palette-gray-50);cursor:pointer;transition:all .2s;color:var(--palette-gray-600)}.banner-upload-placeholder:hover{border-color:var(--color-primary);background-color:var(--palette-primary-50);color:var(--color-primary)}.banner-upload-hint{font-size:var(--font-size-xs);color:var(--palette-gray-500);margin-top:4px}.banner-upload-preview{width:100%;border:2px solid var(--palette-gray-200);border-radius:var(--radius-lg);overflow:hidden;background-color:var(--palette-gray-50);position:relative}.banner-upload-preview img{width:100%;height:auto;max-height:200px;object-fit:contain;display:block}.banner-upload-preview button{position:absolute;top:8px;right:8px}@media(max-width:768px){.hide-on-mobile{display:none!important}}.admin-student-empty-class{color:var(--palette-gray-400);font-size:14px}.admin-student-class-badge{display:inline-block;padding:4px 10px;background-color:var(--palette-gray-100);border:1px solid var(--palette-gray-200);border-radius:12px;font-size:12px;font-weight:500;color:var(--palette-gray-700);white-space:nowrap}.admin-student-class-more{display:inline-block;padding:4px 8px;background-color:var(--palette-gray-200);border:none;border-radius:12px;font-size:11px;font-weight:600;color:var(--palette-gray-600);cursor:pointer;transition:background-color .2s;font-family:inherit;line-height:inherit}.admin-student-class-more:hover{background-color:var(--palette-gray-300)}.admin-student-class-modal-item{padding:12px;background-color:var(--palette-gray-50);border-radius:8px;border:1px solid var(--palette-gray-200)}.admin-student-unenroll-btn{color:var(--palette-red-500)}.admin-student-unenroll-btn:hover{background-color:var(--palette-red-50)}.admin-student-enroll-btn{white-space:nowrap}.admin-student-enroll-modal{max-width:600px}.admin-student-modal-close{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--palette-gray-500);border-radius:4px;transition:background-color .2s}.admin-student-modal-close:hover{background-color:var(--palette-gray-100)}.admin-student-selected-info{padding:12px 16px;background-color:var(--palette-primary-light);border-radius:8px;border:1px solid var(--palette-primary-main)}.admin-student-class-list-container{padding:16px;background-color:var(--palette-gray-50);border-radius:8px;border:1px solid var(--palette-gray-200);max-height:400px;overflow-y:auto}.admin-student-empty-class-list{padding:32px;text-align:center}.admin-student-class-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background-color:var(--palette-white);border:2px solid var(--palette-gray-200);border-radius:8px;cursor:pointer;transition:all .2s}.admin-student-class-item:hover,.admin-student-class-item--selected{border-color:var(--palette-primary-main);background-color:var(--palette-primary-light)}.admin-student-class-checkbox{width:20px;height:20px;margin-top:2px;cursor:pointer;accent-color:var(--palette-primary-main)}.admin-student-enrolled-list-container{padding:16px;background-color:var(--palette-gray-50);border-radius:8px;border:1px solid var(--palette-gray-200)}.admin-student-class-item--removed{opacity:.6;border-color:var(--palette-gray-300)}.admin-student-class-item--removed:hover{border-color:var(--palette-red-400);background-color:var(--palette-red-50)}.admin-student-class-manage-btn{display:flex;align-items:center;justify-content:center;padding:4px;background:none;border:none;border-radius:4px;cursor:pointer;color:var(--palette-gray-500);transition:all .2s;flex-shrink:0}.admin-student-class-manage-btn:hover{background-color:var(--palette-gray-100);color:var(--palette-primary-main)}.admin-material-requests-status-select{width:120px}.admin-material-requests-status-select .select-field{height:36px;padding:0 32px 0 12px;font-size:14px}.admin-material-requests-status-select .select-arrow{right:8px}.admin-consultation-status-select{width:120px}.admin-consultation-status-select .select-field{height:36px;padding:0 32px 0 12px;font-size:14px}.admin-consultation-status-select .select-arrow{right:8px}.logout-button{text-decoration:underline;color:var(--text-tertiary);font-size:14px}.notification-container{display:flex;flex-direction:column;gap:12px;padding:20px}.notification-empty{display:flex;justify-content:center;align-items:center;height:100%}.notification-empty-text{color:var(--text-secondary);font-size:var(--font-size-md)}.notification-dot{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);width:6px;height:6px;border-radius:50%;background-color:var(--color-error);flex-shrink:0}.profile-edit-container{padding:var(--spacing-md);max-width:var(--max-width-md);margin:0 auto}.profile-edit-header{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.profile-edit-header .back-button{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.profile-edit-header h2{flex-grow:1;text-align:center;margin-left:-24px}.profile-edit-form,.profile-edit-fields{display:flex;flex-direction:column;gap:var(--spacing-md)}.general-error{text-align:center}.splash-container{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,#6b3aff,#b388ff);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999}.splash-container .splash-content{display:flex;flex-direction:column;align-items:center;transform:translateY(-30px)}.splash-container .splash-full-logo{width:200px;height:auto;filter:drop-shadow(0 4px 20px rgba(0,0,0,.15))}.splash-container .splash-footer{position:absolute;bottom:50px;width:85%;max-width:320px}.splash-container .progress-bar-bg{width:100%;height:4px;background:#ffffff40;border-radius:10px;overflow:hidden}.splash-container .progress-bar-fill{height:100%;background:#fff;width:0%;box-shadow:0 0 10px #fffc;transition:width .4s cubic-bezier(.1,.7,.1,1)}
