@charset "UTF-8";.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-top:1px solid #aeaeae;border-radius:0;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-top:1px solid #aeaeae;border-radius:0 0 .3rem .3rem}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__year-select,.react-datepicker__month-year-select{background-color:transparent;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__year-select:focus-visible,.react-datepicker__month-year-select:focus-visible{outline:auto 1px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:5em;margin:2px}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:5em;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.375em;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + 1.0625em);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.625em;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__children-container{width:17.25em;margin:.5em;padding-right:.25em;padding-left:.25em;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.react-datepicker-popper-offset{margin-top:-.7em}:root{--bg-start: #fff7ea;--bg-end: #f6d4b9;--panel: rgba(255, 252, 247, .88);--dialog-surface: #fff6ee;--text: #1e1c1a;--muted: #5f5a53;--primary: #14675a;--accent: #ef7d47;--ok: #0a965f;--bad: #c93434;--line: #debaa0;--line-strong: #cd9f7f;--surface-2: #fff6ee;--ring: rgba(20, 103, 90, .3);--shadow-soft: 0 16px 40px rgba(77, 45, 20, .12)}[data-theme=dark]{--bg-start: #0e1f2f;--bg-end: #151a26;--panel: rgba(20, 27, 39, .84);--dialog-surface: #1b2534;--text: #edf1f7;--muted: #aeb7c5;--primary: #20a088;--accent: #ff8f56;--ok: #40cc8f;--bad: #ff7171;--line: rgba(161, 185, 216, .28);--line-strong: rgba(162, 204, 219, .44);--surface-2: rgba(27, 37, 52, .85);--ring: rgba(32, 160, 136, .45);--shadow-soft: 0 22px 52px rgba(5, 10, 20, .4)}*{box-sizing:border-box}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}body{overscroll-behavior-x:none}img,video,canvas,svg{max-width:100%;height:auto}body{margin:0;min-height:100vh;font-family:Manrope,sans-serif;color:var(--text);background:radial-gradient(circle at 15% 20%,rgba(255,182,140,.2),transparent 35%),radial-gradient(circle at 80% 15%,rgba(20,103,90,.2),transparent 25%),radial-gradient(circle at 80% 70%,rgba(30,143,122,.14),transparent 32%),linear-gradient(135deg,var(--bg-start),var(--bg-end));background-attachment:fixed;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.16),transparent 22%),radial-gradient(circle at 78% 70%,rgba(32,160,136,.14),transparent 20%);animation:drift 16s ease-in-out infinite alternate}.layout{max-width:none;margin:0;padding:18px;display:grid;grid-template-columns:minmax(255px,300px) minmax(0,1fr);grid-auto-rows:1fr;align-items:start;gap:18px;position:relative;width:100%;max-width:100vw;min-height:100vh;overflow-x:hidden;box-sizing:border-box}.material-symbols-rounded{font-family:Material Symbols Rounded;font-style:normal;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;flex-shrink:0;line-height:1;-webkit-user-select:none;user-select:none}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-splash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:grid;place-items:center;background:var(--bg-start);background:linear-gradient(135deg,var(--bg-start) 0%,var(--bg-end) 100%);transition:opacity .6s ease-out,visibility .6s ease-out}.auth-splash-fading{opacity:0;visibility:hidden;pointer-events:none}.auth-splash-content{display:flex;flex-direction:column;align-items:center;justify-content:center;animation:authSplashEnter 1s cubic-bezier(.2,.8,.2,1) forwards}@keyframes authSplashEnter{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-splash-logo-wrap{position:relative;width:100px;height:100px;margin-bottom:24px;animation:authLogoFloat 3s ease-in-out infinite alternate}.auth-splash-logo{width:100%;height:100%;object-fit:contain;border-radius:50%;position:relative;z-index:2;box-shadow:0 8px 32px rgba(var(--primary-rgb, 18, 91, 80),.2)}@keyframes authLogoFloat{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.auth-splash-ring{position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;border-radius:50%;border:2px dashed color-mix(in srgb,var(--primary) 30%,transparent);animation:authSpinRing 15s linear infinite;z-index:1}@keyframes authSpinRing{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-splash-brand{font-size:2.5rem;font-weight:800;color:var(--primary);margin:0;letter-spacing:-.03em;background:linear-gradient(135deg,var(--primary),var(--accent));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-splash-tagline{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);margin:8px 0 20px}.auth-splash-dots{display:flex;gap:8px;margin-top:20px}.auth-splash-dots span{width:8px;height:8px;border-radius:50%;background:var(--primary);opacity:.4;animation:authDots 1.4s infinite ease-in-out both}.auth-splash-dots span:nth-child(1){animation-delay:-.32s}.auth-splash-dots span:nth-child(2){animation-delay:-.16s}@keyframes authDots{0%,80%,to{transform:scale(0);opacity:.2}40%{transform:scale(1);opacity:.8}}.auth-role-screen{width:min(960px,100%);display:grid;gap:44px;animation:rise .5s ease-out}.auth-role-header{text-align:center}.sidebar-head h1{font-family:inherit;font-size:1.5rem;letter-spacing:-.02em;margin:0 0 6px}.brand-badge{font-size:.42em;padding:2px 7px;border-radius:999px;font-weight:700;letter-spacing:.02em;white-space:nowrap;background:color-mix(in srgb,var(--badge-color) 15%,transparent);color:var(--badge-color);border:1px solid color-mix(in srgb,var(--badge-color) 30%,transparent);margin-top:3px}.auth-brand{font-family:Sora,sans-serif;font-size:3.4rem;font-weight:800;letter-spacing:-.04em;margin:0 0 8px;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-brand-sub{margin:0 0 40px;color:var(--muted);font-size:.85rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;opacity:.8}.auth-role-title{margin:0 0 8px;font-size:1.45rem;font-weight:600;letter-spacing:-.01em;color:var(--text)}.auth-role-subtitle{margin:0;color:var(--muted);font-size:1rem}.auth-role-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}.auth-role-cards--admin-types{grid-template-columns:repeat(2,1fr)}.auth-role-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:16px;padding:32px 28px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(160deg,#fffdf9f7,#fff4e8e6);color:var(--text);text-align:left;cursor:pointer;box-shadow:0 8px 24px #533a190f;transition:transform .26s cubic-bezier(.22,.68,0,1.2),box-shadow .26s ease,border-color .26s ease;overflow:hidden;--btn-shadow-rgb: 83, 58, 25}.auth-role-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);transform:translate(-150%);transition:transform .6s ease;pointer-events:none}.auth-role-card:hover:after{transform:translate(150%)}.auth-role-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 22px 44px #533a1921;border-color:var(--role-color, var(--accent))}.auth-role-card:focus-visible{outline:2px solid var(--ring);outline-offset:3px}.auth-role-card-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:18px;background:var(--role-bg, rgba(20,103,90,.1));flex-shrink:0}.auth-role-card-label{font-size:1.4rem;font-weight:700;letter-spacing:-.01em;line-height:1.1;text-wrap:balance}.auth-role-card-desc{font-size:1rem;color:var(--muted);line-height:1.5;flex:1}.auth-role-card-badge{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.03em;padding:3px 9px;border-radius:999px;border:1px solid var(--role-color, var(--accent));color:var(--role-color, var(--accent));background:var(--role-bg, rgba(239,125,71,.08))}.auth-role-card-arrow{margin-top:4px;color:var(--role-color, var(--accent));display:flex;opacity:0;transform:translate(-6px);transition:opacity .22s ease,transform .22s ease}.auth-role-card:hover .auth-role-card-arrow{opacity:1;transform:translate(0)}.auth-form-card{width:min(480px,100%);background:var(--panel);border:1px solid var(--line);border-radius:24px;padding:28px 32px 32px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-soft);display:grid;gap:0;animation:rise .45s ease-out}.auth-form-card--wide{width:min(820px,100%)}.auth-form-topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:24px}.auth-back-btn{display:inline-flex;align-items:center;gap:5px;background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:10px;padding:6px 12px;font-size:.84rem;font-weight:600;box-shadow:none;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.auth-back-btn:hover:not(:disabled){color:var(--text);border-color:var(--line-strong);background:color-mix(in srgb,var(--surface-2) 70%,transparent);transform:none;filter:none;box-shadow:none}.auth-form-role-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px 5px 8px;border:1px solid color-mix(in srgb,var(--role-color, var(--line)) 30%,var(--line));border-radius:999px;font-size:.82rem;font-weight:700;background:var(--role-bg, rgba(255,253,249,.9));color:var(--text)}.auth-form-heading{display:flex;flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:24px}.auth-form-avatar{display:flex;align-items:center;justify-content:center;width:68px;height:68px;border-radius:20px}.auth-form-title{margin:0;font-size:1.55rem;font-weight:800;letter-spacing:-.025em;line-height:1.1}.auth-form-subtitle{margin:0;color:var(--muted);font-size:.88rem;line-height:1.45}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:14px;background:color-mix(in srgb,var(--surface-2) 70%,transparent);padding:4px;margin-bottom:24px}.auth-tab{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 14px;border-radius:10px;border:none;background:transparent;color:var(--muted);font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:none;transition:background .2s,color .2s,box-shadow .2s}.auth-tab:hover:not(:disabled):not(.active){color:var(--text);background:color-mix(in srgb,var(--surface-2) 90%,transparent);transform:none;filter:none;box-shadow:none}.auth-tab.active{background:var(--panel);color:var(--primary);box-shadow:0 2px 10px #533a1914}.auth-form-body{display:grid;gap:16px;min-width:0}.flt-wrapper{display:flex;flex-direction:column;gap:4px}.flt-field{position:relative;display:grid}.flt-field input{width:100%;padding:20px 48px 8px 42px;border:1px solid var(--line);border-radius:12px;background:color-mix(in srgb,var(--surface-2) 80%,transparent);color:var(--text);font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;outline:none}.flt-field input:focus{border-color:var(--primary);background:var(--panel);box-shadow:0 0 0 3px var(--ring)}.flt-field label{position:absolute;left:42px;top:50%;transform:translateY(-50%);font-size:.95rem;color:var(--muted);pointer-events:none;transition:top .18s ease,font-size .18s ease,color .18s ease}.flt-field.raised label,.flt-field input:not(:placeholder-shown)+label{top:10px;font-size:.72rem;font-weight:600;letter-spacing:.02em}.flt-field.focused label{color:var(--primary)}.flt-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:18px!important;color:var(--muted);pointer-events:none;transition:color .18s}.flt-field.focused .flt-icon{color:var(--primary)}.flt-hint{padding-left:42px;font-size:.75rem;color:var(--muted);line-height:1.3}.flt-pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:none;padding:4px;color:var(--muted);cursor:pointer;box-shadow:none;border-radius:6px;display:flex;align-items:center;justify-content:center;line-height:1}.flt-pw-toggle:hover:not(:disabled){color:var(--text);transform:translateY(-50%);filter:none;box-shadow:none}.auth-feedback{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-radius:10px;font-size:.88rem;line-height:1.45;font-weight:500;animation:slide-in-down .4s cubic-bezier(.175,.885,.32,1.275) both}.auth-feedback--error{background:color-mix(in srgb,var(--bad) 12%,transparent);border:1px solid color-mix(in srgb,var(--bad) 30%,transparent);color:var(--bad)}.auth-feedback--success{background:color-mix(in srgb,var(--ok) 12%,transparent);border:1px solid color-mix(in srgb,var(--ok) 30%,transparent);color:var(--ok)}.auth-submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;border-radius:12px;font-size:1rem;font-weight:700;letter-spacing:.01em;margin-top:4px}.auth-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.session-loader-shell{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;animation:rise .5s ease-out;background:radial-gradient(circle at 15% 20%,rgba(255,182,140,.2),transparent 35%),radial-gradient(circle at 80% 15%,rgba(20,103,90,.2),transparent 25%),radial-gradient(circle at 80% 70%,rgba(30,143,122,.14),transparent 32%),linear-gradient(135deg,var(--bg-start),var(--bg-end))}.session-loader-spinner-wrap{position:relative;width:72px;height:72px;display:flex;align-items:center;justify-content:center}.session-loader-spinner{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:4px solid color-mix(in srgb,var(--primary) 15%,transparent);border-top-color:var(--primary);border-radius:50%;animation:spin .8s cubic-bezier(.4,0,.2,1) infinite}.session-loader-logo{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;position:relative;z-index:1}.session-loader-text{text-align:center}.session-loader-brand{font-family:Sora,sans-serif;font-size:1.6rem;font-weight:800;margin:0 0 6px;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.03em}.session-loader-muted{color:var(--muted);font-size:.95rem;margin:0;animation:pulse-op 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse-op{0%,to{opacity:1}50%{opacity:.4}}.auth-panel{width:min(520px,100%);display:grid;gap:12px}.auth-mode-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.auth-mode-toggle .ghost.active{border-color:var(--line-strong);background:color-mix(in srgb,var(--surface-2) 80%,transparent)}.auth-note{margin:4px 0 0}.auth-form-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.auth-form-role-icon{display:flex;align-items:center;color:var(--primary);width:22px;height:22px}@media (max-width: 680px){.auth-role-cards{grid-template-columns:1fr}.auth-role-card{flex-direction:row;align-items:center;gap:16px;padding:18px}.auth-role-card-icon{width:52px;height:52px;flex-shrink:0}.auth-role-card-desc,.auth-role-card-badge{display:none}.auth-role-card-arrow{margin-top:0;margin-left:auto;opacity:1;transform:translate(0)}.auth-form-card{padding:20px 18px 24px;border-radius:20px}.auth-form-card--wide{width:min(100%,560px)}}.sidebar{position:sticky;top:16px;align-self:stretch;height:auto;animation:slide-in-left .5s ease-out}.sidebar-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.sidebar-head>div{min-width:0;flex:1}.sidebar h1{margin:0;font-family:Sora,sans-serif;letter-spacing:-.02em}.mobile-navbar{display:none}.mobile-navbar-right{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%}.mobile-navbar-brand-block{display:flex;flex-direction:column;min-width:0;flex:1}.mobile-navbar-brand{font-family:Sora,sans-serif;font-size:1rem;font-weight:700;letter-spacing:-.01em;color:var(--text)}.mobile-navbar-subtitle{color:var(--muted);font-size:.76rem;line-height:1.2;margin-top:2px}.nav-toggle{border:1px solid var(--line);border-radius:10px;background:var(--surface-2);color:var(--text);box-shadow:none;width:40px;height:34px;min-width:40px;padding:0;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.nav-toggle:hover:not(:disabled){border-color:var(--line-strong)}.nav-toggle-line{width:18px;height:2px;border-radius:999px;background:currentColor;transition:transform .22s ease,opacity .22s ease}.nav-toggle.open .nav-toggle-line:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav-toggle.open .nav-toggle-line:nth-child(2){opacity:0}.nav-toggle.open .nav-toggle-line:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.theme-switch{width:58px;height:32px;border-radius:999px;border:1px solid transparent;padding:2px;cursor:pointer;background:transparent;transition:all .28s ease;box-shadow:none;overflow:hidden;margin-left:auto;flex:0 0 auto}.theme-switch.is-dark{background:#101927;border-color:#1f2c3b}.theme-switch.is-light{background:#fff;border-color:var(--line)}.theme-switch-track{width:100%;height:100%;position:relative;display:block;overflow:hidden;border-radius:999px}.theme-switch-thumb{width:26px;height:26px;border-radius:999px;position:absolute;top:0;left:0;display:inline-flex;align-items:center;justify-content:center;transition:transform .28s ease,background .28s ease,color .28s ease}.theme-switch.is-dark .theme-switch-thumb{transform:translate(28px);background:#1d2a3d;color:#f5f7fb}.theme-switch.is-light .theme-switch-thumb{transform:translate(0);background:#eceff4;color:#334155}.theme-switch:hover:not(:disabled){transform:none;filter:none;box-shadow:none}.theme-switch:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.nav-toggle{display:none}.side-nav{display:grid;gap:8px;margin:14px 0}.side-nav .side-link{animation:pop-in .35s ease both}.side-nav .side-link:nth-child(1){animation-delay:.03s}.side-nav .side-link:nth-child(2){animation-delay:.07s}.side-nav .side-link:nth-child(3){animation-delay:.11s}.side-nav .side-link:nth-child(4){animation-delay:.15s}.side-nav .side-link:nth-child(5){animation-delay:.19s}.side-nav .side-link:nth-child(6){animation-delay:.23s}.side-link{text-decoration:none;border:1px solid var(--line);border-radius:12px;padding:10px;color:var(--text);background:var(--surface-2);transition:transform .22s ease,background .22s ease,color .22s ease,box-shadow .22s ease}.side-link:hover{transform:translate(4px);box-shadow:0 12px 28px #533a1914}.side-link.active{background:var(--primary);color:#fff;box-shadow:0 12px 28px #125b5038}.side-link.disabled{opacity:.48;pointer-events:none;-webkit-user-select:none;user-select:none;cursor:not-allowed}.scope-pill{border:1px solid var(--line);padding:8px;border-radius:10px;background:linear-gradient(135deg,#fff8efe0,#fff0ddc7);font-weight:700;box-shadow:inset 0 1px #fff9}.side-actions{display:grid;gap:10px;margin-top:8px}.main-content{min-width:0;width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.topbar{animation:rise .45s ease-out}.topbar h1{margin:0;font-size:2rem}.topbar p{margin-top:6px;color:var(--muted)}.nav-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin:14px 0 18px}.nav-chip{text-decoration:none;background:#ffffffb3;border:1px solid var(--line);border-radius:999px;padding:10px 14px;text-align:center;color:var(--text);transition:transform .2s ease,background .2s ease}.nav-chip:hover{transform:translateY(-2px)}.nav-chip.active{background:var(--primary);color:#fff}.page-wrap{display:grid;gap:14px;width:100%;min-width:0}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;min-width:0}.dashboard-card{display:block;text-decoration:none;border:1px solid var(--line);border-radius:14px;padding:14px;background:linear-gradient(180deg,#fffdf9f2,#fff6eee6);color:var(--text);transition:transform .26s ease,box-shadow .26s ease,border-color .26s ease;box-shadow:0 10px 24px #533a190f}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 18px 34px #533a191f;border-color:#dcb28f}.panel{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:rise .45s ease-out;box-shadow:var(--shadow-soft);width:100%;min-width:0;overflow-x:hidden;overflow-y:visible;box-sizing:border-box}.page-wrap>*{animation:rise .5s ease-out}form{display:grid;gap:10px;min-width:0}input,textarea,select,button{font:inherit;max-width:100%}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px;background:var(--surface-2);color:var(--text);transition:transform .25s cubic-bezier(.2,.8,.2,1),border-color .25s ease,box-shadow .25s ease}input::placeholder,textarea::placeholder{color:color-mix(in srgb,var(--text) 55%,transparent);opacity:1}textarea{resize:vertical;min-height:96px}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:40px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232b2b2b' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px}select::-ms-expand{display:none}input:focus,textarea:focus,select:focus,button:focus-visible{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring);transform:scale(1.01)}button{--btn-shadow-rgb: 18, 91, 80;border:none;border-radius:999px;background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 80%,#0a3d35));color:#fff;padding:10px 22px;font-size:.88rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:transform .18s cubic-bezier(.2,.8,.2,1),filter .18s ease,opacity .18s ease,box-shadow .18s ease;box-shadow:0 4px 14px rgba(var(--btn-shadow-rgb),.22),0 1px 3px rgba(var(--btn-shadow-rgb),.12)}button:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 8px 22px rgba(var(--btn-shadow-rgb),.28),0 2px 6px rgba(var(--btn-shadow-rgb),.14)}button:active:not(:disabled){transform:translateY(0);filter:brightness(.97);box-shadow:0 2px 8px rgba(var(--btn-shadow-rgb),.18)}button:disabled{cursor:not-allowed;opacity:.55;box-shadow:none}button.alt{background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 85%,#c0501a));--btn-shadow-rgb: 200, 100, 50}button.ghost{background:transparent;color:var(--text);border:1.5px solid var(--line);box-shadow:none;font-weight:500}button.ghost:hover:not(:disabled){background:color-mix(in srgb,var(--primary) 6%,transparent);border-color:var(--primary);color:var(--primary);box-shadow:none}button.ghost.danger{background:transparent;color:#e74c3c;border:1.5px solid color-mix(in srgb,#e74c3c 45%,transparent);box-shadow:none}button.ghost.danger:hover:not(:disabled){background:linear-gradient(135deg,#c0392b,#e74c3c);border-color:transparent;color:#fff;box-shadow:0 6px 18px #e74c3c59}.selector-shell{display:grid;gap:14px;min-width:0;width:100%}.selector-stage{padding:14px;border:1px solid rgba(232,200,173,.9);border-radius:16px;background:linear-gradient(180deg,#fffcf7f2,#fff5ebd9);box-shadow:0 14px 30px #533a190f;transition:transform .24s ease,box-shadow .24s ease,opacity .24s ease;min-width:0;overflow:hidden}.selector-stage:hover{transform:translateY(-2px);box-shadow:0 18px 36px #533a191a}.selector-stage.is-disabled{opacity:.52}.selector-stage-header{margin-bottom:10px}.selector-stage-header h3{margin:0;font-size:1rem}.selector-stage-header p{margin:4px 0 0;color:var(--muted);font-size:.92rem}.choice-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;min-width:0;width:100%}.choice-grid.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.choice-grid.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-grid.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width: 420px){.choice-grid.grid-cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}}.choice-button{--btn-shadow-rgb: 83, 58, 25;min-height:58px;display:flex;align-items:center;justify-content:center;padding:12px 14px;border-radius:16px;background:linear-gradient(180deg,#fffefb,#fff3e7);color:var(--text);border:1px solid #edd3bd;box-shadow:0 10px 22px #533a1914;font-weight:700;position:relative;overflow:hidden;text-align:center}.choice-label-full{display:inline}.choice-label-short{display:none}@media (max-width: 1080px){.choice-label-full{display:none}.choice-label-short{display:inline;font-size:.85rem;font-weight:800;letter-spacing:.03em}}.choice-button:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.55) 48%,transparent 100%);transform:translate(-140%);transition:transform .5s ease}.choice-button:hover:after{transform:translate(140%)}.choice-button.active{background:linear-gradient(135deg,#125b50,#1d7a68);color:#fff;border-color:#125b50;box-shadow:0 16px 32px #125b503d}.detail-category-row{margin:4px 0 10px}.detail-category-title{margin:0 0 8px;font-weight:700;font-size:.94rem}.compact-choice-grid{gap:8px}.compact-choice-button{min-height:44px;border-radius:12px;padding:8px 10px;font-size:.98rem;box-shadow:0 6px 14px #533a1914}.student-row-action{min-height:38px;padding:8px 12px;border-radius:12px}.details-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.details-header-row h3{margin:0}.student-row-selected{background:color-mix(in srgb,var(--primary) 10%,transparent)}.table-wrap table tbody tr{cursor:pointer}.table-editor-card{max-width:900px}.table-editor-list{display:grid;gap:10px;margin-top:8px}.table-editor-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:color-mix(in srgb,var(--surface-2) 84%,transparent)}.table-editor-meta{display:grid;gap:2px}.table-editor-key{color:var(--muted);font-size:.83rem}.table-editor-actions{display:flex;gap:8px;flex-wrap:wrap}.table-editor-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.05em;border:1px solid var(--line)}.table-editor-badge.academic{color:#0f6a85;background:color-mix(in srgb,#0f6a85 12%,transparent);border-color:color-mix(in srgb,#0f6a85 35%,var(--line))}.table-editor-badge.general{color:#9a5a16;background:color-mix(in srgb,#c78235 12%,transparent);border-color:color-mix(in srgb,#c78235 35%,var(--line))}.student-edit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100000;display:grid;place-items:center;padding:20px;background:#1412106b;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fade-in .3s ease-out}.student-edit-modal{width:min(980px,100%);max-height:min(90vh,920px);overflow:auto;border:1px solid var(--line);border-radius:24px;background:var(--panel);box-shadow:0 28px 70px #1412103d;padding:22px;position:relative;z-index:100001;animation:spring-in .4s cubic-bezier(.175,.885,.32,1.275) both}.student-edit-modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.student-edit-modal-eyebrow{margin:0 0 4px;font-size:.82rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}.student-edit-modal-header h3{margin:0;font-size:1.45rem;word-break:break-word;overflow-wrap:anywhere;line-height:1.25}.student-edit-modal-form{display:grid;gap:16px}.student-edit-modal-section{display:grid;gap:12px;padding:16px;border:1px solid var(--line);border-radius:18px;background:color-mix(in srgb,var(--surface-2) 84%,transparent)}.student-edit-modal-section h4{margin:0;font-size:1rem}.student-edit-modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.student-edit-modal-grid textarea,.student-edit-modal-grid input,.student-edit-modal-section textarea{width:100%}.locked-field:disabled{cursor:not-allowed;pointer-events:auto}.locked-field:disabled:hover{cursor:not-allowed}.student-edit-modal-actions{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}.student-edit-modal-actions-left,.student-edit-modal-actions-right{display:flex;gap:10px;flex-wrap:wrap}.student-edit-modal-actions-right{justify-content:flex-end}.student-edit-modal-close{min-height:40px}.delete-confirm-global-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100002;display:grid;place-items:center;padding:20px;background:#0d0b0a47;animation:fade-in .3s ease-out}.delete-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;display:grid;place-items:center;padding:20px;border-radius:24px;background:#0d0b0a61;animation:fade-in .2s ease-out}.delete-confirm-card{width:min(620px,100%);border:1px solid var(--line);border-radius:20px;background:var(--dialog-surface);box-shadow:var(--shadow-soft);padding:18px;display:grid;gap:10px;animation:spring-in .4s cubic-bezier(.175,.885,.32,1.275) both}.delete-confirm-eyebrow{margin:0;font-size:.78rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--bad)}.delete-confirm-card h4{margin:0;color:var(--bad);font-size:1.15rem}.delete-confirm-card p{margin:0;color:var(--text);font-size:.95rem;line-height:1.45}.table-tool-popup-card{width:min(560px,100%)}.table-tool-popup-input{width:100%}.table-tool-popup-error{margin:0}.delete-confirm-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}button.danger{background:linear-gradient(135deg,#c0392b,#e74c3c);color:#fff;border:none;--btn-shadow-rgb: 192, 57, 43}button.danger:hover:not(:disabled){filter:brightness(1.05);box-shadow:0 8px 22px rgba(var(--btn-shadow-rgb),.3)}@media (max-width: 760px){.student-edit-modal-grid{grid-template-columns:1fr}.student-edit-modal-header{flex-direction:column}.student-edit-modal-actions{justify-content:stretch}.student-edit-modal-actions button{flex:1}.table-editor-row{grid-template-columns:1fr}}@media (max-width: 640px){.student-edit-modal{padding:16px;border-radius:18px}.student-edit-modal-eyebrow{font-size:.68rem}.student-edit-modal-header h3{font-size:1rem}.student-edit-modal-section{padding:12px;border-radius:14px;gap:10px}.student-edit-modal-section h4{font-size:.88rem}.student-edit-modal-grid{gap:8px}.student-edit-modal-form{gap:12px}.student-edit-modal-actions button{font-size:.82rem;padding:8px 12px}}.subject-builder{display:grid;gap:10px;padding:14px;border-radius:16px;border:1px dashed #d9b08b;background:color-mix(in srgb,var(--surface-2) 86%,transparent);animation:rise .35s ease-out}.subject-builder-actions{display:flex;gap:10px;flex-wrap:wrap}.selector-summary{display:flex;flex-wrap:wrap;gap:10px}.selector-summary-pill{padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:color-mix(in srgb,var(--surface-2) 95%,transparent);font-weight:700;box-shadow:inset 0 1px #ffffffb3}.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--line);max-width:100%;-webkit-overflow-scrolling:touch}.panel>.table-wrap{margin-top:12px}table{width:100%;border-collapse:collapse;min-width:0}th,td{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:middle}th+th,td+td{border-left:1px solid var(--line)}thead th{background:color-mix(in srgb,var(--surface-2) 94%,transparent);position:sticky;top:0;z-index:1;white-space:nowrap}.students-table{table-layout:fixed}.students-col-enroll{word-break:break-all}.student-attendance-table{min-width:560px;table-layout:fixed}.student-attendance-table th:nth-child(1),.student-attendance-table td:nth-child(1){width:58%}.student-attendance-table th:nth-child(2),.student-attendance-table td:nth-child(2),.student-attendance-table th:nth-child(3),.student-attendance-table td:nth-child(3),.student-attendance-table th:nth-child(4),.student-attendance-table td:nth-child(4){width:14%;white-space:nowrap}.student-attendance-subject{white-space:normal;word-break:normal;overflow-wrap:anywhere}.subject-name-short,.attendance-head-short{display:none}.attendance-matrix-table thead th{position:static;top:auto;z-index:auto;text-align:center;vertical-align:middle}.attendance-matrix-table th,.attendance-matrix-table td{border:1px solid var(--line)}.attendance-matrix-table thead th[rowspan]{text-align:left;min-width:88px}.attendance-matrix-table thead tr:nth-child(3) th{white-space:nowrap;font-weight:700}.attendance-matrix-table th+th,.attendance-matrix-table td+td{border-left:none}.attendance-edit-cell{cursor:pointer;-webkit-user-select:none;user-select:none;transition:filter .15s ease,box-shadow .15s ease}.attendance-edit-cell:hover{filter:brightness(1.05);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--primary) 32%,transparent)}.attendance-cell-popup{width:min(520px,100%)}.lecture-present-control{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.lecture-select{min-width:240px;max-width:100%}.lecture-present-count{font-weight:800}.lecture-wise-label .label-short,.lecture-present-hint .label-short{display:none}.overview-metrics-table{min-width:320px;table-layout:fixed}.overview-metrics-table th{width:44%;white-space:normal;overflow-wrap:normal;word-break:keep-all}.overview-metrics-table td{white-space:nowrap}.overview-student-table{min-width:620px}.overview-student-table th,.overview-student-table td{white-space:nowrap;overflow-wrap:normal;word-break:normal}.matrix-subject-select-wrap{display:grid;gap:6px;margin-top:8px;max-width:420px}.matrix-calendar-controls{display:grid;grid-template-columns:repeat(2,minmax(220px,420px));gap:12px;margin-top:10px}.student-attendance-matrix-table{min-width:760px}.student-attendance-matrix-table th,.student-attendance-matrix-table td{white-space:nowrap}.student-attendance-timetable-table{min-width:980px}.student-attendance-timetable-table th,.student-attendance-timetable-table td{min-width:180px;vertical-align:top}.student-attendance-timetable-table th:first-child,.student-attendance-timetable-table td:first-child{font-weight:700}.student-attendance-day-table{min-width:900px}.student-attendance-day-table tbody tr{background:transparent}.student-attendance-day-table td{height:100%}.student-timetable-day-header{display:grid;gap:2px;text-align:center}.student-timetable-day-header span{color:var(--muted);font-size:.8rem;font-weight:600}.student-timetable-cell{vertical-align:top;padding:10px}.student-timetable-cell-inner{display:grid;gap:5px}.student-timetable-day-cell{min-height:210px}.student-timetable-lecture-block{display:grid;gap:5px;padding:10px 8px;border-radius:12px;border:1px solid color-mix(in srgb,var(--line) 82%,transparent);background:color-mix(in srgb,var(--surface-2) 82%,transparent)}.student-timetable-lecture-block+.student-timetable-lecture-block{margin-top:8px}.student-timetable-subject{font-weight:800;letter-spacing:.01em}.student-timetable-time{font-size:.82rem;color:var(--muted)}.student-timetable-empty{color:var(--muted);text-align:center;font-weight:600}@media (max-width: 900px){.matrix-calendar-controls{grid-template-columns:1fr}}.skeleton{position:relative;overflow:hidden;border-radius:10px;background:linear-gradient(110deg,#debaa061,#e8cdb752 40%,#d0ac9447);animation:skeleton-pulse 2.2s ease-in-out infinite}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 0%,rgba(255,255,255,0) 25%,rgba(255,255,255,.55) 50%,rgba(255,255,255,0) 75%,transparent 100%);background-size:400px 100%;background-repeat:no-repeat;animation:skeleton-shimmer 1.4s cubic-bezier(.4,0,.2,1) infinite}.skeleton:nth-child(1):after{animation-delay:0s}.skeleton:nth-child(2):after{animation-delay:.1s}.skeleton:nth-child(3):after{animation-delay:.2s}.skeleton:nth-child(4):after{animation-delay:.3s}.skeleton:nth-child(5):after{animation-delay:.4s}.skeleton:nth-child(6):after{animation-delay:.5s}tr:nth-child(1) .skeleton:after{animation-delay:0s}tr:nth-child(2) .skeleton:after{animation-delay:.12s}tr:nth-child(3) .skeleton:after{animation-delay:.24s}tr:nth-child(4) .skeleton:after{animation-delay:.36s}tr:nth-child(5) .skeleton:after{animation-delay:.48s}tr:nth-child(6) .skeleton:after{animation-delay:.6s}.skeleton-line{height:14px;margin:8px 0;border-radius:7px}.skeleton-line.sm{height:10px;border-radius:5px}.skeleton-line.lg{height:20px;border-radius:10px}.skeleton-pill{height:36px;border-radius:999px}.skeleton-card{height:112px;border-radius:14px}.skeleton-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0}.skeleton-table-cell{height:16px;border-radius:6px;margin:6px 0}.skeleton-table-wrap{display:grid;gap:10px}.skeleton-table-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.skeleton-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}[data-theme=dark] .skeleton{background:linear-gradient(110deg,#48628261,#58769b52 40%,#3c557347)}[data-theme=dark] .skeleton:after{background:linear-gradient(105deg,transparent 0%,rgba(255,255,255,0) 25%,rgba(255,255,255,.1) 50%,rgba(255,255,255,0) 75%,transparent 100%);background-size:400px 100%}@media (prefers-reduced-motion: reduce){.skeleton:after{display:none}.skeleton{animation:skeleton-pulse 2s ease-in-out infinite}}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:calc(100% + 400px) 0}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.6}}.present-thumb{width:54px;height:54px;object-fit:cover;border-radius:10px;border:1px solid var(--line);display:block}.muted{color:var(--muted);font-size:.9rem}.status-present{color:var(--ok);font-weight:700;animation:fade-in-scale .3s ease-out both}.status-absent,.status-unknown{color:var(--bad);font-weight:700;animation:fade-in-scale .3s ease-out both}.leave-page-shell{display:grid;gap:16px;animation:rise .45s ease-out both}.leave-page-header{animation:fade-in-up .4s ease-out both;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.leave-page-header-actions{display:flex;align-items:center;gap:8px}.leave-history-btn{width:42px;height:42px;min-width:42px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);color:var(--text);display:inline-flex;align-items:center;justify-content:center;box-shadow:none;padding:0}.leave-history-btn .material-symbols-rounded{font-size:20px}.leave-history-btn.active{background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 82%,#0a3d35));color:#fff;border-color:var(--primary)}.leave-filter-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,220px);gap:12px}.leave-tab-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.leave-tab{border:1px solid var(--line);border-radius:16px;background:var(--surface-2);color:var(--text);min-height:50px;box-shadow:none}.leave-tab.active{background:linear-gradient(135deg,var(--primary),color-mix(in srgb,var(--primary) 82%,#0a3d35));color:#fff;border-color:var(--primary)}.leave-form{display:grid;gap:16px;animation:fade-in-up .45s ease-out both}.leave-form>*{animation:fade-in-up .4s ease-out both}.leave-form>*:nth-child(1){animation-delay:.05s}.leave-form>*:nth-child(2){animation-delay:.1s}.leave-form>*:nth-child(3){animation-delay:.15s}.leave-form>*:nth-child(4){animation-delay:.2s}.leave-form>*:nth-child(5){animation-delay:.25s}.leave-detail-card,.leave-application-card{border:1px solid var(--line);border-radius:16px;background:color-mix(in srgb,var(--surface-2) 92%,transparent);padding:14px;display:grid;gap:10px;animation:fade-in-up .4s ease-out both;transition:transform .22s ease,box-shadow .22s ease,border-color .2s ease}.leave-application-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);border-color:color-mix(in srgb,var(--primary) 25%,var(--line))}.leave-application-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.leave-form-fields{display:grid;gap:12px}.leave-form-fields label{display:grid;gap:6px;color:var(--text);font-weight:600}.leave-proof-preview-grid,.leave-proof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}.leave-proof-preview-card{margin:0;display:grid;gap:6px}.leave-proof-preview-card img,.leave-proof-grid img{width:100%;height:96px;object-fit:cover;border-radius:12px;border:1px solid var(--line);background:var(--surface-2)}.leave-proof-preview-card figcaption{font-size:.8rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leave-form-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.leave-application-list{display:grid;gap:12px}.leave-application-card h3,.leave-application-card p{margin:0}.leave-application-meta{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:.88rem}.leave-status-pill{display:inline-flex;align-items:center;justify-content:center;padding:5px 12px;border-radius:999px;font-size:.75rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.leave-status-pill.pending{background:color-mix(in srgb,var(--accent) 18%,transparent);color:color-mix(in srgb,var(--accent) 65%,var(--text));border-color:color-mix(in srgb,var(--accent) 35%,transparent)}.leave-status-pill.approved{background:color-mix(in srgb,var(--ok) 16%,transparent);color:color-mix(in srgb,var(--ok) 70%,var(--text));border-color:color-mix(in srgb,var(--ok) 35%,transparent)}.leave-status-pill.rejected{background:color-mix(in srgb,var(--bad) 16%,transparent);color:color-mix(in srgb,var(--bad) 70%,var(--text));border-color:color-mix(in srgb,var(--bad) 35%,transparent)}.manual-status-toggle{display:inline-flex;gap:8px;align-items:center;flex-wrap:wrap}.manual-status-btn{min-width:96px;padding:8px 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);color:var(--text);box-shadow:none}.manual-label-short,.manual-roll-short{display:none}.manual-status-btn.present.active{background:#0a8f5a;border-color:#0a8f5a;color:#fff}.manual-status-btn.absent.active{background:#c62828;border-color:#c62828;color:#fff}.manual-attendance-table th:last-child,.manual-attendance-table td:last-child{min-width:140px}.picker-input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px;background:var(--surface-2);font:inherit;color:var(--text)}input[type=file]{width:100%;min-width:0}.react-datepicker-popper{max-width:calc(100vw - 20px)!important;z-index:9999!important}.react-datepicker__month-container,.react-datepicker__time-container{max-width:100%}.react-datepicker{z-index:51}.time-range-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.time-range-field{display:grid;gap:4px}.time-range-label{font-size:.78rem;color:var(--muted);font-weight:700;letter-spacing:.02em}.react-datepicker{border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 18px 38px #533a1929;font-family:Manrope,sans-serif}.react-datepicker__header{background:linear-gradient(180deg,#fff7ee,#ffe9d4);border-bottom:1px solid var(--line)}.react-datepicker__current-month{font-weight:800;letter-spacing:.01em;padding:2px 38px 8px}.react-datepicker__navigation{top:8px;width:28px;height:28px;border:none;border-radius:8px;background:transparent;box-shadow:none;color:var(--text);min-width:28px;padding:0}.react-datepicker__navigation:hover:not(:disabled){background:#14675a1f;box-shadow:none;transform:none}.react-datepicker__navigation:focus,.react-datepicker__navigation:focus-visible,.react-datepicker__navigation:active{background:transparent!important;box-shadow:none!important;outline:none!important;transform:none!important}.react-datepicker__navigation--previous{left:8px}.react-datepicker__navigation--next{right:8px}.react-datepicker__navigation-icon:before{border-color:var(--muted);border-width:2px 2px 0 0;top:9px}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected,.react-datepicker__time-list-item--selected{background:var(--primary)!important;color:#fff!important}.react-datepicker__day:hover,.react-datepicker__time-list-item:hover{background:#125b5024!important}.react-datepicker__triangle{display:none}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{scrollbar-width:none;-ms-overflow-style:none}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list::-webkit-scrollbar{width:0;height:0;display:none}[data-theme=dark] .react-datepicker{background:#192233;color:#edf1f7}[data-theme=dark] .react-datepicker__header{background:#1d2a3f;border-bottom-color:var(--line)}[data-theme=dark] .react-datepicker__navigation:hover:not(:disabled){background:#60aa962e}[data-theme=dark] .react-datepicker__navigation:focus,[data-theme=dark] .react-datepicker__navigation:focus-visible,[data-theme=dark] .react-datepicker__navigation:active{background:transparent!important}[data-theme=dark] .react-datepicker__navigation-icon:before{border-color:#d5deea}[data-theme=dark] .react-datepicker__current-month,[data-theme=dark] .react-datepicker-time__header,[data-theme=dark] .react-datepicker__day-name,[data-theme=dark] .react-datepicker__time-name,[data-theme=dark] .react-datepicker__day,[data-theme=dark] .react-datepicker__time-list-item{color:#edf1f7}[data-theme=dark] .scope-pill{background:linear-gradient(135deg,#232e40f5,#171f2deb);box-shadow:inset 0 1px #ffffff0f}[data-theme=dark] .dashboard-card{background:linear-gradient(180deg,#1f2838fa,#151d29f0);border-color:var(--line-strong);box-shadow:0 16px 30px #050a1447}[data-theme=dark] .dashboard-card:hover{border-color:#7ab4c994;box-shadow:0 22px 38px #050a145c}[data-theme=dark] .selector-stage{border-color:#7b9aba57;background:linear-gradient(180deg,#1e2839f5,#151d29eb);box-shadow:0 18px 34px #050a143d}[data-theme=dark] .selector-stage:hover{box-shadow:0 22px 40px #050a1452}[data-theme=dark] .choice-button{--btn-shadow-rgb: 5, 10, 20;background:linear-gradient(180deg,#253144fa,#192231f5);border-color:#7b9aba52;box-shadow:0 12px 24px #050a143d}[data-theme=dark] .choice-button.active{background:linear-gradient(135deg,#19856f,#14675a);color:#fff;border-color:#1f9a81;box-shadow:0 16px 32px #0938306b}[data-theme=dark] .choice-button:after{background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.08) 48%,transparent 100%)}[data-theme=dark] .subject-builder{border-color:#7ab4c957;background:color-mix(in srgb,var(--surface-2) 92%,rgba(8,14,24,.3))}[data-theme=dark] .selector-summary-pill{box-shadow:inset 0 1px #ffffff0f}[data-theme=dark] .activity-loading{border-color:#ff9f578f;background:linear-gradient(100deg,#583518ad,#3e27147a)}[data-theme=dark] .activity-loading:after{background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%)}[data-theme=dark] .activity-success{border-color:#40cc8f70;background:#1244309e}[data-theme=dark] .activity-error{border-color:#ff71716b;background:#581c249e}[data-theme=dark] .unknown-card.state-success{border-color:#40cc8f70;background:#1244309e;box-shadow:0 10px 20px #0a191238}[data-theme=dark] .unknown-card.state-error{border-color:#ff71716b;background:#581c249e}.unknown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;align-items:stretch}.unknown-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;padding:10px;background:var(--surface-2);transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease}.unknown-card.state-loading{border-color:#d07f3b;box-shadow:0 10px 22px #d07f3b33;animation:pulse-card 1.1s ease-in-out infinite}.unknown-card.state-success{border-color:#2f9f74;background:#eefbf4;box-shadow:0 10px 20px #0a8f5a2e;animation:success-pop .45s ease}.unknown-card.state-error{border-color:#c62828;background:#fff1ef}.unknown-card.state-ignored{opacity:.75}.unknown-card img{width:100%;aspect-ratio:1 / 1;object-fit:cover;object-position:center;border-radius:8px;margin-bottom:6px}.unknown-card select{width:100%}.card-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:auto;padding-top:10px}.card-status{margin:10px 2px 0;font-size:.92rem;color:var(--muted);animation:rise .3s ease-out}.activity-banner{margin-top:12px;padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);animation:rise .3s ease-out}.activity-loading{border-color:#d6a981;background:linear-gradient(100deg,#fff7ef,#ffeada);position:relative;overflow:hidden}.activity-loading:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:shimmer 1.1s linear infinite}.activity-success{border-color:#73c7a0;background:#effaf4}.activity-error{border-color:#e4a6a6;background:#fff0f0}.activity-idle{border-color:var(--line)}.progress-wrap{margin-top:14px;padding:10px;border:1px solid var(--line);border-radius:10px;background:var(--surface-2)}.progress-label{display:flex;justify-content:space-between;margin-bottom:6px;font-weight:700}.progress-track{width:100%;height:12px;border-radius:999px;background:#99807252;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#1c8d78,#125b50);transition:width .35s ease}.progress-fill-running{background:linear-gradient(90deg,#1c8d78,#2aa793 35%,#8bd5ca,#2aa793 65%,#1c8d78);background-size:220% 100%;animation:progress-loading-wave 1.1s linear infinite}.face-images-form{gap:12px;margin-bottom:12px}.face-images-actions{display:grid;gap:10px;margin-bottom:12px}.face-images-actions button{width:100%}@keyframes shimmer{0%{transform:translate(-120%)}to{transform:translate(120%)}}@keyframes progress-loading-wave{0%{background-position:220% 0}to{background-position:-120% 0}}@keyframes drift{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(0,-10px,0) scale(1.03)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-card{0%{transform:translateY(0)}50%{transform:translateY(-2px)}to{transform:translateY(0)}}@keyframes success-pop{0%{transform:scale(.98)}70%{transform:scale(1.01)}to{transform:scale(1)}}@keyframes pop-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1080px){.layout{grid-template-columns:1fr;padding:10px;gap:12px;width:100%;max-width:100vw;overflow-x:hidden}.mobile-navbar{display:block;position:fixed;top:0;left:0;right:0;z-index:41;height:60px;padding:10px 14px;background:color-mix(in srgb,var(--panel) 88%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}.nav-toggle{display:inline-flex}.sidebar{display:none;position:fixed;top:60px;right:0;height:calc(100vh - 60px);width:min(84vw,320px);max-width:320px;overflow-y:auto;border-radius:18px 0 0 18px!important;z-index:32}.sidebar h1{display:none}.sidebar.open{display:block;animation:slide-in-right .22s ease-out}.layout.nav-open:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#060b1373;z-index:30}.main-content{padding-top:64px}.dashboard-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 780px){.layout{padding:8px}.sidebar{width:min(90vw,360px)}.sidebar-brand-text,.sidebar-brand-tagline{display:none}.topbar h1{font-size:1.5rem}.dashboard-cards,.time-range-row{grid-template-columns:1fr}.manual-status-toggle{width:100%;justify-content:stretch}.manual-status-btn{min-width:62px;padding:10px 12px;flex:1}.manual-label-full{display:none}.manual-label-short{display:inline;font-weight:700}.manual-roll-full{display:none}.manual-roll-short{display:inline}.manual-attendance-table th:last-child,.manual-attendance-table td:last-child{min-width:156px}.react-datepicker{max-width:calc(100vw - 28px)}.card-actions{grid-template-columns:1fr}.skeleton-line{height:12px;margin:7px 0}.skeleton-line.lg{height:18px}.skeleton-card{height:96px}.skeleton-table-row,.skeleton-grid-2{grid-template-columns:1fr;gap:8px}.recognition-results-table .recognition-col-face,.recognition-results-table .recognition-col-confidence{display:none}.table-wrap>table{min-width:640px}.table-wrap>.student-attendance-table,.table-wrap>.snapshot-table{min-width:0;width:100%}.student-attendance-table{min-width:100%;width:100%;table-layout:fixed}.student-attendance-table th:nth-child(1),.student-attendance-table td:nth-child(1){width:30%}.student-attendance-table th:nth-child(2),.student-attendance-table td:nth-child(2),.student-attendance-table th:nth-child(3),.student-attendance-table td:nth-child(3),.student-attendance-table th:nth-child(4),.student-attendance-table td:nth-child(4){width:23.33%}.student-attendance-table th,.student-attendance-table td{font-size:.9rem}th,td{padding:8px;font-size:.92rem}.lecture-present-control{flex-direction:column;align-items:stretch}.lecture-select{min-width:0;width:100%}}@media (max-width: 500px){.choice-grid,.choice-grid.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.panel{padding:13px}.scope-pill{font-size:.9rem}.selector-summary{flex-wrap:wrap;gap:6px;overflow:hidden}.selector-summary-pill{width:auto;flex:1 1 0;min-width:0;text-align:center;font-size:.78rem;line-height:1.2;padding:7px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-content{padding-top:64px}.panel{border-radius:14px}.table-wrap{margin-left:-2px;margin-right:-2px}.table-wrap>table{min-width:560px}.table-wrap>.student-attendance-table,.table-wrap>.snapshot-table{min-width:0;width:100%}.student-attendance-table{min-width:100%;width:100%;table-layout:fixed}.student-attendance-table th:nth-child(1),.student-attendance-table td:nth-child(1){width:30%}.student-attendance-table th:nth-child(2),.student-attendance-table td:nth-child(2),.student-attendance-table th:nth-child(3),.student-attendance-table td:nth-child(3),.student-attendance-table th:nth-child(4),.student-attendance-table td:nth-child(4){width:23.33%;white-space:nowrap}.student-attendance-table th,.student-attendance-table td{padding:6px;font-size:.84rem}.attendance-head-full{display:none}.attendance-head-short{display:inline;font-weight:700}.subject-name-full{display:none}.subject-name-short{display:inline;font-weight:700;letter-spacing:.02em}th,td{font-size:.88rem;white-space:normal;word-break:normal;overflow-wrap:anywhere}.overview-metrics-table th,.overview-metrics-table td,.overview-student-table th,.overview-student-table td{word-break:normal;overflow-wrap:normal}.overview-metrics-table td,.overview-student-table th,.overview-student-table td{white-space:nowrap}.overview-metrics-table th{white-space:normal}.overview-metrics-table{min-width:0;width:100%}.overview-metrics-table td{min-width:0}.lecture-wise-label{font-size:.95rem;line-height:1.2}.lecture-present-control{display:block;width:100%}.lecture-select{font-size:.84rem;min-height:34px;padding:7px 26px 7px 10px;border-radius:10px;width:100%;max-width:100%;min-width:0;background-position:right 10px center;background-size:14px}.lecture-present-count{font-size:.83rem;font-weight:700}.lecture-wise-label .label-full,.lecture-present-hint .label-full{display:none}.lecture-wise-label .label-short,.lecture-present-hint .label-short{display:inline}.lecture-present-hint{display:none}thead th{white-space:nowrap;overflow-wrap:normal}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.progress-fill-running{animation:progress-loading-wave 1.1s linear infinite!important}}.ob-root{--ob-bg-start: #fff7ea;--ob-bg-end: #f6d4b9;--ob-surface: #fff6ee;--ob-text: #1e1c1a;--ob-muted: #5f5a53;--ob-primary: #14675a;--ob-accent: #ef7d47;--ob-line: #debaa0;--ob-line-strong: #cd9f7f;--ob-shadow-soft: 0 16px 40px rgba(77, 45, 20, .12);position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:radial-gradient(circle at 14% 18%,rgba(255,182,140,.2),transparent 30%),radial-gradient(circle at 84% 14%,rgba(20,103,90,.18),transparent 24%),radial-gradient(circle at 78% 76%,rgba(30,143,122,.14),transparent 30%),linear-gradient(135deg,var(--ob-bg-start),var(--ob-bg-end));display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(16px,3vw,28px);overflow:hidden;font-family:Manrope,sans-serif}.ob-pill{position:absolute;border-radius:999px;pointer-events:none}.ob-pill-1{width:480px;height:80px;background:linear-gradient(135deg,#14675a3d,#20a0881f);top:7%;left:-8%;transform:rotate(-28deg);filter:blur(1px);animation:ob-float 9s ease-in-out infinite alternate}.ob-pill-2{width:360px;height:64px;background:linear-gradient(120deg,#ef7d4742,#ffb78c24);top:12%;right:-4%;transform:rotate(22deg);filter:blur(2px);animation:ob-float 12s ease-in-out infinite alternate-reverse}.ob-pill-3{width:540px;height:72px;background:linear-gradient(100deg,#14675a2e,#20a08814);bottom:14%;left:-12%;transform:rotate(18deg);filter:blur(2px);animation:ob-float 10s ease-in-out infinite alternate;animation-delay:-3s}.ob-pill-4{width:300px;height:52px;background:linear-gradient(100deg,#ef7d4742,#ffb78c1a);bottom:20%;right:2%;transform:rotate(-16deg);filter:blur(1.5px);animation:ob-float 14s ease-in-out infinite alternate-reverse;animation-delay:-5s}@keyframes ob-float{0%{transform:rotate(var(--r, -28deg)) translateY(0)}to{transform:rotate(var(--r, -28deg)) translateY(-18px)}}.ob-pill-1{--r: -28deg}.ob-pill-2{--r: 22deg}.ob-pill-3{--r: 18deg}.ob-pill-4{--r: -16deg}.ob-slide{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 20px;max-width:min(680px,calc(100vw - 32px));width:100%;will-change:transform,opacity}.ob-slide-in-right,.ob-slide-in-left{animation:ob-slide-from-bottom .92s cubic-bezier(.22,.61,.36,1) both}@keyframes ob-slide-from-bottom{0%{opacity:0;transform:translate3d(0,24px,0);filter:blur(1.8px)}65%{opacity:.88;transform:translate3d(0,4px,0);filter:blur(.2px)}to{opacity:1;transform:translateZ(0);filter:blur(0)}}.ob-eyebrow{margin:0 0 14px;font-size:.96rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ob-muted)}.ob-headline{margin:0 0 18px;font-family:Sora,sans-serif;font-size:clamp(2.45rem,8.6vw,4.7rem);font-weight:700;color:var(--ob-text);line-height:1.1;letter-spacing:-.02em}.ob-gradient-text{background:linear-gradient(135deg,var(--ob-primary) 0%,#1f8875 45%,var(--ob-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ob-sub{margin:0;font-size:clamp(1.12rem,2.7vw,1.38rem);color:var(--ob-muted);line-height:1.65;max-width:480px}.ob-controls{position:absolute;bottom:clamp(36px,6vh,68px);left:0;right:0;z-index:3;display:flex;align-items:center;justify-content:center;gap:18px;padding:0 24px}.ob-dots{display:flex;align-items:center;gap:8px}.ob-dot{width:8px;height:8px;border-radius:999px;background:#14675a3d;border:none;padding:0;cursor:pointer;transition:width .32s cubic-bezier(.22,1,.36,1),background .28s ease;box-shadow:none}.ob-dot:hover:not(:disabled){background:#14675a6b;transform:none;filter:none}.ob-dot-active{width:28px;background:var(--ob-primary)}.ob-btn-back{width:44px;height:44px;border-radius:999px;border:1.5px solid var(--ob-line);background:var(--ob-surface);color:var(--ob-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .22s ease,border-color .22s ease,opacity .22s ease;flex-shrink:0;box-shadow:none}.ob-btn-back:hover:not(:disabled){background:#fff;border-color:var(--ob-line-strong);color:var(--ob-text);transform:none;filter:none}.ob-btn-back:disabled{opacity:.45;cursor:default}.ob-btn-next{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:999px;border:1px solid var(--ob-line);background:#fff;color:var(--ob-text);font-weight:700;font-size:.95rem;cursor:pointer;box-shadow:0 8px 20px #533a1924;transition:transform .22s ease,box-shadow .22s ease,background .22s ease;flex-shrink:0}.ob-btn-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 28px #533a192e;filter:none}.ob-btn-start{border:1px solid transparent;background:linear-gradient(135deg,#1f8875,var(--ob-primary));color:#fff;box-shadow:0 10px 26px #14675a47}.ob-btn-start:hover:not(:disabled){box-shadow:0 14px 30px #14675a5c}@media (max-width: 1024px){.ob-pill-1{width:380px;height:66px;left:-11%}.ob-pill-2{width:300px;height:54px;right:-7%}.ob-pill-3{width:420px;height:60px;left:-14%}.ob-pill-4{width:260px;height:46px;right:-2%}.ob-slide{padding:30px;border-radius:20px}.ob-controls{bottom:clamp(24px,4.5vh,40px)}}@media (max-width: 768px){.ob-root{padding:16px 14px calc(16px + env(safe-area-inset-bottom))}.ob-pill-1{width:260px;height:46px;top:8%;left:-18%}.ob-pill-2{width:210px;height:38px;top:10%;right:-16%}.ob-pill-3{width:300px;height:44px;bottom:18%;left:-22%}.ob-pill-4{width:190px;height:36px;bottom:22%;right:-10%}.ob-slide{padding:24px 18px;border-radius:18px}.ob-eyebrow{font-size:.88rem;margin-bottom:10px}.ob-headline{font-size:clamp(2.28rem,10.6vw,3.38rem);margin-bottom:14px}.ob-sub{font-size:clamp(1.06rem,4.1vw,1.2rem);line-height:1.55;max-width:100%}.ob-controls{bottom:calc(12px + env(safe-area-inset-bottom));gap:10px;padding:0 8px}.ob-btn-back{width:40px;height:40px}.ob-dot{width:7px;height:7px}.ob-dot-active{width:24px}.ob-btn-next{padding:10px 18px;font-size:.88rem;gap:6px}}@media (max-height: 720px){.ob-root{justify-content:center;padding-top:14px;padding-bottom:calc(84px + env(safe-area-inset-bottom))}.ob-slide{margin-top:0}.ob-controls{position:absolute;bottom:calc(10px + env(safe-area-inset-bottom));margin-top:0}}@media (max-width: 480px){.ob-pill-2,.ob-pill-4{opacity:.65}.ob-slide{padding:22px 14px;max-width:calc(100% - 12px)}.ob-controls{gap:8px;width:100%}.ob-btn-next{padding:10px 16px;font-size:.84rem}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-scale{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes rise{0%{opacity:0;transform:translateY(18px)}60%{opacity:.9;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}@keyframes drift{0%{opacity:.7;transform:translate(0) scale(1)}33%{opacity:.85;transform:translate(12px,-8px) scale(1.04)}66%{opacity:.75;transform:translate(-8px,14px) scale(.97)}to{opacity:.7;transform:translate(6px,-4px) scale(1.02)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes spring-in{0%{opacity:0;transform:scale(.9) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slide-in-down{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes success-pop{0%{transform:scale(.96)}55%{transform:scale(1.03)}to{transform:scale(1)}}@keyframes pulse-card{0%,to{box-shadow:0 10px 22px #d07f3b33}50%{box-shadow:0 14px 30px #d07f3b61}}.panel{animation:fade-in-up .5s cubic-bezier(.2,.8,.2,1) both}.dashboard-grid>*,.table-wrap,.stat-group>*,.choice-grid>*{animation:fade-in-up .5s cubic-bezier(.2,.8,.2,1) both}.dashboard-grid>*:nth-child(1),.choice-grid>*:nth-child(1){animation-delay:.05s}.dashboard-grid>*:nth-child(2),.choice-grid>*:nth-child(2){animation-delay:.1s}.dashboard-grid>*:nth-child(3),.choice-grid>*:nth-child(3){animation-delay:.15s}.dashboard-grid>*:nth-child(4),.choice-grid>*:nth-child(4){animation-delay:.2s}.dashboard-grid>*:nth-child(5),.choice-grid>*:nth-child(5){animation-delay:.25s}.dashboard-grid>*:nth-child(6),.choice-grid>*:nth-child(6){animation-delay:.3s}.dashboard-card{transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s cubic-bezier(.2,.8,.2,1)}.dashboard-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 18px 42px #14675a29}[data-theme=dark] .dashboard-card:hover{box-shadow:0 18px 42px #0009}tbody tr{animation:fade-in-up .4s ease-out both;transition:background-color .2s ease,transform .2s ease}tbody tr:nth-child(1){animation-delay:.05s}tbody tr:nth-child(2){animation-delay:.1s}tbody tr:nth-child(3){animation-delay:.15s}tbody tr:nth-child(4){animation-delay:.2s}tbody tr:nth-child(5){animation-delay:.25s}tbody tr:nth-child(6){animation-delay:.3s}tbody tr:nth-child(7){animation-delay:.35s}tbody tr:nth-child(8){animation-delay:.4s}tbody tr:nth-child(9){animation-delay:.45s}tbody tr:nth-child(10){animation-delay:.5s}tbody tr:hover{background-color:color-mix(in srgb,var(--primary) 5%,transparent)}.side-link{transition:all .2s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}.side-link:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:color-mix(in srgb,var(--primary) 10%,transparent);transition:width .3s cubic-bezier(.4,0,.2,1);z-index:-1;border-radius:inherit}.side-link:hover:before{width:100%}.side-link:hover:not(.active){transform:translate(4px)}.side-link.active{transform:translate(6px);box-shadow:0 4px 12px #14675a26}button{transition:all .2s cubic-bezier(.2,.8,.2,1)}button:active:not(:disabled){transform:scale(.96)}input,select{transition:border-color .25s ease,box-shadow .25s ease,transform .25s ease}input:focus:not([type=checkbox]),select:focus{transform:scale(1.01)}.stat-pill{transition:transform .2s ease,box-shadow .2s ease}.stat-pill:hover{transform:scale(1.05);box-shadow:0 4px 12px #14675a1f}@media (max-width: 480px){.mobile-hide{display:none!important}}.react-datepicker-wrapper{display:block;width:100%}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.leave-modal-dialog{flex-direction:column!important;height:90vh!important}.leave-modal-img-pane{flex:0 0 35%!important;width:100%!important}.leave-modal-details-pane{flex:1 1 65%!important;width:100%!important;border-left:none!important;border-top:1px solid var(--line)}}.leave-modal-header{padding:22px 26px 18px}.leave-modal-body{padding:20px 26px}.leave-modal-eyebrow{font-size:.62rem}.leave-modal-title{font-size:1.25rem}.leave-modal-student-name{font-size:1rem}@media (max-width: 768px){.leave-modal-header{padding:14px 16px 12px!important}.leave-modal-body{padding:14px 16px!important;gap:14px!important}.leave-modal-eyebrow{font-size:.55rem!important}.leave-modal-title{font-size:1.05rem!important}.leave-modal-student-name{font-size:.9rem!important}.leave-modal-student-name span{font-size:.72rem!important;opacity:.7}.leave-modal-student-meta,.leave-modal-submitted,.leave-modal-submitted b{font-size:.75rem!important}.leave-modal-internship-title{font-size:.7rem!important}.leave-modal-internship div{font-size:.75rem!important}.leave-modal-review-card{padding:12px 14px!important;gap:8px!important}.leave-modal-review-card p{font-size:.58rem!important}.leave-modal-review-card div{font-size:.75rem!important}.leave-modal-footer{padding:12px 16px!important;gap:10px!important}.leave-modal-footer button{padding:9px 0!important;font-size:.8rem!important}.leave-modal-footer button .material-symbols-rounded{font-size:16px!important}}.leave-list-card{padding:20px;gap:14px}.leave-list-type{font-size:1.05rem}.leave-list-meta{font-size:.85rem}.leave-list-meta-icon{font-size:15px;flex-shrink:0}.leave-list-class{font-size:.75rem}.leave-list-status{font-size:.7rem;padding:4px 10px}.leave-list-timestamp{font-size:.75rem;padding:7px 11px}.leave-list-desc{font-size:.88rem}.leave-list-thumb-img{width:52px;height:52px}.leave-list-thumb-more{width:52px;height:52px;font-size:.75rem}.leave-list-actions{padding-top:14px}.leave-list-btn{padding:8px;font-size:.875rem}.leave-list-reviewed{font-size:.75rem}@media (max-width: 640px){.leave-list-card{padding:14px;gap:10px;border-radius:12px}.leave-list-type{font-size:.9rem}.leave-list-meta{font-size:.78rem}.leave-list-meta-icon{font-size:13px}.leave-list-class{font-size:.68rem}.leave-list-status{font-size:.62rem;padding:3px 8px}.leave-list-timestamp{font-size:.7rem;padding:6px 9px}.leave-list-desc{font-size:.8rem}.leave-list-thumb-img{width:40px;height:40px}.leave-list-thumb-more{width:40px;height:40px;font-size:.68rem}.leave-list-thumbs{gap:5px}.leave-list-actions{padding-top:10px}.leave-list-btn{padding:7px;font-size:.8rem}.leave-list-reviewed{font-size:.68rem}}@media (max-width: 640px){.student-filter-grid{grid-template-columns:1fr 1fr!important;gap:.65rem!important}.student-filter-grid select{font-size:.82rem;padding-left:10px;padding-right:10px}}.promote-student-list-wrap{margin:20px 0 4px;display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden}.promote-select-all-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:color-mix(in srgb,var(--primary) 8%,var(--surface-2));border-bottom:1px solid var(--line);-webkit-user-select:none;user-select:none}.promote-selection-count{font-size:.8rem;font-weight:600;white-space:nowrap}.promote-student-list{list-style:none;margin:0;padding:0;max-height:420px;overflow-y:auto;overscroll-behavior:contain}.promote-student-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .15s ease}.promote-student-row:last-child{border-bottom:none}.promote-student-row:hover{background:color-mix(in srgb,var(--primary) 6%,transparent)}.promote-student-row.selected{background:color-mix(in srgb,var(--primary) 10%,var(--surface-2))}.promote-checkbox-label{display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.9rem;font-weight:600;color:var(--text)}.promote-checkbox{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.promote-checkbox-custom{flex-shrink:0;width:18px;height:18px;border:2px solid var(--line-strong);border-radius:5px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;transition:border-color .18s,background .18s,box-shadow .18s;position:relative}.promote-checkbox-custom:after{content:"";display:block;width:5px;height:9px;border:2px solid white;border-top:none;border-left:none;transform:rotate(45deg) translate(-1px,-1px);opacity:0;transition:opacity .15s ease}.promote-checkbox:checked+.promote-checkbox-custom{background:var(--primary);border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.promote-checkbox:checked+.promote-checkbox-custom:after{opacity:1}.promote-checkbox:indeterminate+.promote-checkbox-custom{background:var(--primary);border-color:var(--primary)}.promote-checkbox:indeterminate+.promote-checkbox-custom:after{width:8px;height:0;border-top:2px solid white;border-right:none;border-left:none;transform:rotate(0) translateY(2px);opacity:1}.promote-select-all-text{font-size:.88rem;font-weight:700;color:var(--primary)}.promote-student-info{display:flex;flex-direction:column;gap:2px;min-width:0}.promote-student-name{font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.promote-student-meta{font-size:.76rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.promote-student-list::-webkit-scrollbar{width:5px}.promote-student-list::-webkit-scrollbar-track{background:transparent}.promote-student-list::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px}@media (max-width: 640px){.promote-select-all-bar{flex-wrap:wrap;gap:6px}.promote-student-list{max-height:320px}}@media (max-width: 768px){.choice-grid,.choice-grid.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.choice-grid.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-grid.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.choice-button{padding:8px 6px;font-size:.78rem;min-height:44px;word-break:break-word;line-height:1.2}.selector-stage:hover{transform:none;box-shadow:0 14px 30px #533a190f}.auth-splash-tagline{font-size:.7rem;letter-spacing:.1em}.auth-splash-brand{font-size:2rem}.auth-role-cards{grid-template-columns:1fr;gap:16px}.auth-role-card{padding:20px;gap:12px}.auth-role-card-icon{width:52px;height:52px}.auth-role-card-icon .material-symbols-rounded{font-size:28px!important}.auth-role-card-label{font-size:1.25rem}.dashboard-cards{display:grid;grid-template-columns:1fr;gap:12px}.dashboard-card{padding:16px;gap:8px;min-height:auto}.dashboard-card h3{font-size:.95rem}article.dashboard-card p{font-size:1.8rem}a.dashboard-card p{font-size:.9rem;line-height:1.4;color:var(--muted)}}@media (max-width: 400px){.choice-grid.grid-cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-grid.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.choice-button{font-size:.72rem;padding:6px 4px}}@media (max-width: 1080px){.panel,.page-wrap,.selector-shell,.selector-stage,.choice-grid{max-width:100%;box-sizing:border-box}.panel{width:100%;overflow-x:hidden}section.panel>form{max-width:100%;width:100%;overflow:hidden}}
