*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Pretendard,-apple-system,BlinkMacSystemFont,PingFang SC,Noto Sans KR,Segoe UI,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--glass-radius)}.glass-strong{background:var(--glass-bg-strong);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--glass-radius)}.press{transition:transform .15s ease,opacity .15s ease}.press:active{transform:scale(.97)}.btn{transition:transform .15s ease,opacity .15s ease}.btn:active{transform:scale(.97)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;border-radius:14px;padding:.625rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:600}.btn-primary{background:var(--color-primary);color:#fff}.btn-danger{background:var(--color-danger);color:#fff}.btn-ghost{background:#7878801f;color:#3a3a3c}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.-bottom-1\.5{bottom:-.375rem}.-top-1\.5{top:-.375rem}.bottom-0{bottom:0}.left-0{left:0}.right-0{right:0}.right-0\.5{right:.125rem}.top-0\.5{top:.125rem}.z-10{z-index:10}.z-50{z-index:50}.z-\[9999\]{z-index:9999}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.-ml-1{margin-left:-.25rem}.-mr-1{margin-right:-.25rem}.-mt-0\.5{margin-top:-.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-12{height:3rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-6{width:1.5rem}.w-\[92\%\]{width:92%}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[30px\]{min-width:30px}.min-w-\[44px\]{min-width:44px}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-grab{cursor:grab}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-x-2\.5{-moz-column-gap:.625rem;column-gap:.625rem}.gap-x-3{-moz-column-gap:.75rem;column-gap:.75rem}.gap-y-1{row-gap:.25rem}.self-start{align-self:flex-start}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-\[12px\]{border-radius:12px}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-none{border-radius:0}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-0{border-width:0px}.border-x-0{border-left-width:0px;border-right-width:0px}.border-b-0{border-bottom-width:0px}.border-t{border-top-width:1px}.border-black\/5{border-color:#0000000d}.border-white\/40{border-color:#fff6}.bg-black\/10{background-color:#0000001a}.bg-black\/15{background-color:#00000026}.bg-black\/30{background-color:#0000004d}.bg-black\/5{background-color:#0000000d}.bg-danger\/10{background-color:#ff3b301a}.bg-danger\/15{background-color:#ff3b3026}.bg-primary\/15{background-color:#34c75926}.bg-white\/50{background-color:#ffffff80}.bg-white\/60{background-color:#fff9}.bg-white\/70{background-color:#ffffffb3}.bg-white\/80{background-color:#fffc}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-7{padding:1.75rem}.p-8{padding:2rem}.px-0\.5{padding-left:.125rem;padding-right:.125rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-6{padding-bottom:1.5rem}.pt-1{padding-top:.25rem}.pt-10{padding-top:2.5rem}.pt-16{padding-top:4rem}.pt-2\.5{padding-top:.625rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-\[0\.3em\]{letter-spacing:.3em}.tracking-\[0\.4em\]{letter-spacing:.4em}.tracking-\[0\.5em\]{letter-spacing:.5em}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-danger{--tw-text-opacity: 1;color:rgb(255 59 48 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.opacity-80{opacity:.8}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}html{font-size:14px!important;-webkit-text-size-adjust:100%!important;-moz-text-size-adjust:100%!important;text-size-adjust:100%!important}button,input,select,textarea{font-family:inherit;font-size:inherit}:root{--glass-bg: rgba(255, 255, 255, .55);--glass-bg-strong: rgba(255, 255, 255, .75);--glass-blur: blur(20px);--glass-border: 1px solid rgba(255, 255, 255, .6);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .08), 0 1px 4px rgba(0, 0, 0, .04);--glass-radius: 20px;--glass-radius-sm: 14px;--color-primary: #34c759;--color-warning: #ff9500;--color-danger: #ff3b30;--color-late: #ff9500;--color-early-leave: #ff6b6b;--color-present: #34c759;--color-absent: #8e8e93;--color-leave: #5ac8fa;--color-half-leave: #af52de;--tab-bar-height: 60px}*{-webkit-tap-highlight-color:transparent;box-sizing:border-box;font-family:Pretendard,-apple-system,BlinkMacSystemFont,PingFang SC,Noto Sans KR,Segoe UI,sans-serif}html,body{height:100%;margin:0;overflow:hidden}input,select,textarea{font-size:max(16px,1em)}body{font-size:14px;font-family:-apple-system,PingFang SC,Helvetica Neue,Pretendard,Noto Sans KR,Noto Sans SC,Microsoft YaHei,sans-serif;font-feature-settings:"tnum" 1;color:#1c1c1e;background:radial-gradient(ellipse at top left,rgba(180,220,255,.45) 0%,transparent 50%),radial-gradient(ellipse at top right,rgba(255,200,220,.35) 0%,transparent 50%),radial-gradient(ellipse at bottom left,rgba(200,255,220,.4) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(220,200,255,.35) 0%,transparent 50%),linear-gradient(145deg,#e8f0e9,#f0f0f5,#e6eef6);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#root{height:100%;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);box-sizing:border-box}.app-content{flex:1;width:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:24px 16px calc(var(--tab-bar-height) + env(safe-area-inset-bottom) + 16px)}.scroll-container{overflow-y:auto;-webkit-overflow-scrolling:touch}.tab-bar{padding-bottom:max(env(safe-area-inset-bottom),8px)}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.employee-dropdown{-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:rgba(52,199,89,.5) rgba(0,0,0,.05)}.employee-dropdown::-webkit-scrollbar{width:6px;display:block}.employee-dropdown::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.employee-dropdown::-webkit-scrollbar-thumb{background:#34c75999;border-radius:3px;border:1px solid rgba(255,255,255,.3)}.employee-dropdown::-webkit-scrollbar-thumb:active{background:#34c759d9}.employee-item{cursor:pointer;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.calendar-table-scroll{overflow:auto;max-height:calc(100vh - 300px);scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.3) transparent}.calendar-table-scroll::-webkit-scrollbar{width:8px;height:8px}.calendar-table-scroll::-webkit-scrollbar-thumb{background:#00000040;border-radius:4px}.calendar-table-scroll::-webkit-scrollbar-track{background:transparent}@media (max-width: 640px){.calendar-table-scroll{scrollbar-width:none;max-height:none}.calendar-table-scroll::-webkit-scrollbar{display:none}}.touch-scroll{-webkit-overflow-scrolling:touch}.leave-badge{display:inline-flex;align-items:center;white-space:nowrap;-webkit-white-space:nowrap;overflow:visible;text-overflow:clip;max-width:none;width:auto;border-radius:20px;padding:4px 14px;font-size:12px;font-weight:700}.leave-badge,[class*=leave-badge]{white-space:nowrap!important;-webkit-white-space:nowrap!important}.skeleton-cell{height:20px;border-radius:4px;background:linear-gradient(90deg,#0000000f 25%,#0000001f,#0000000f 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.personal-pin-card{background:#fff9;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1.5px solid rgba(255,255,255,.72);border-radius:20px;padding:24px 20px;margin-top:16px;box-shadow:0 4px 20px #0000000f,inset 0 1px #ffffffd9;text-align:center}.ppc-icon{font-size:36px;margin-bottom:12px}.ppc-title{font-size:16px;font-weight:700;margin-bottom:4px}.ppc-title .cn{color:#1f1a14;font-size:16px}.ppc-title .ko{color:#6b7480;font-size:13px;font-weight:500;margin-top:2px;display:block}.ppc-subtitle{font-size:11px;color:#889;margin-bottom:14px;line-height:1.5}.ppc-subtitle .ko{display:block;margin-top:2px}.ppc-who{font-size:12px;font-weight:700;color:#1b5e20;background:#4caf501a;border-radius:8px;padding:6px 10px;margin-bottom:14px;display:inline-block}.ppc-form{display:flex;flex-direction:column;gap:12px;text-align:left;margin-bottom:14px}.ppc-field label{display:block;font-size:11px;font-weight:600;color:#455160;margin-bottom:4px}.ppc-field label .cn{display:inline}.ppc-field label .ko{display:block;font-size:10px;color:#889;font-weight:500;margin-top:1px}.ppc-input{width:100%;padding:12px 14px;background:#fffc;border:1.5px solid rgba(0,0,0,.1);border-radius:10px;font-size:18px;font-weight:700;letter-spacing:6px;text-align:center;font-family:Courier New,monospace}.ppc-input:focus{outline:none;border-color:#4caf5080;box-shadow:0 0 0 3px #4caf5026}.ppc-validation-error{font-size:11px;color:#c62828;margin-top:4px;text-align:center}.ppc-validation-error .ko{display:block;font-size:10px}.ppc-message{padding:12px;border-radius:10px;margin:12px 0;font-size:12px;font-weight:600;text-align:center}.ppc-message.success{background:#4caf501f;border:1.5px solid rgba(76,175,80,.4);color:#1b5e20}.ppc-message.error{background:#f443361a;border:1.5px solid rgba(244,67,54,.35);color:#c62828}.ppc-message .msg-sub{font-size:10.5px;font-weight:400;margin-top:4px;opacity:.8}.ppc-submit-btn{width:100%;padding:14px;background:#4caf50d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1.5px solid rgba(76,175,80,.6);border-radius:12px;color:#fff;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #4caf5040;transition:all .2s ease}.ppc-submit-btn:disabled{background:#c8c8c880;border-color:#c8c8c899;color:#999;cursor:not-allowed;box-shadow:none}.ppc-submit-btn:not(:disabled):active{background:#4caf50;transform:scale(.98)}.pin-current-hint{margin-top:6px;padding:8px 10px;background:#4caf5014;border-radius:8px;font-size:11px;color:#455160}.pin-current-hint .cn{display:block}.pin-current-hint .ko{display:block;font-size:10px;color:#889;margin-top:2px}.pin-current-hint strong{font-family:Courier New,monospace;font-size:14px;letter-spacing:2px;color:#1b5e20;font-weight:800}.gps-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border-radius:16px;font-weight:700;font-size:15px;transition:transform .15s ease,opacity .15s ease}.gps-btn:active{transform:scale(.97)}.gps-btn:disabled{opacity:.7}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.animate-sheet{animation:sheet-up .28s cubic-bezier(.32,.72,0,1)}.animate-fade{animation:fade-in .2s ease}.safe-bottom{padding-bottom:env(safe-area-inset-bottom,0px)}.safe-top{padding-top:env(safe-area-inset-top,0px)}.btn-checkin-active{background:#34c7592e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(52,199,89,.45);border-radius:16px;box-shadow:0 2px 12px #34c7591f,inset 0 1px #fffc;color:#1a7a36;font-weight:600;transition:all .2s ease}.btn-checkin-active:active:not(:disabled){background:#34c7594d;transform:scale(.97)}.btn-checkout-active{background:#ff95002e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(255,149,0,.45);border-radius:16px;box-shadow:0 2px 12px #ff95001f,inset 0 1px #fffc;color:#b56b00;font-weight:600;transition:all .2s ease}.btn-checkout-active:active:not(:disabled){background:#ff95004d;transform:scale(.97)}.btn-field-work{background:#0a84ff26;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(10,132,255,.38);border-radius:16px;box-shadow:0 2px 12px #0a84ff1a,inset 0 1px #ffffffbf;color:#05c;font-weight:600;transition:all .2s ease}.btn-field-work:active:not(:disabled){background:#0a84ff42;transform:scale(.97)}.btn-annual-leave{background:#5ac8fa2e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(90,200,250,.42);border-radius:16px;box-shadow:0 2px 12px #5ac8fa1a,inset 0 1px #fffc;color:#0071a4;font-weight:600;transition:all .2s ease}.btn-annual-leave:active:not(:disabled){background:#5ac8fa4d;transform:scale(.97)}.btn-sick-leave{background:#ff6b9d26;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(255,107,157,.38);border-radius:16px;box-shadow:0 2px 12px #ff6b9d1a,inset 0 1px #ffffffbf;color:#c0185a;font-weight:600;transition:all .2s ease}.btn-sick-leave:active:not(:disabled){background:#ff6b9d42;transform:scale(.97)}.wifi-status-checking{background:#c8c8c840;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid rgba(255,255,255,.55);border-radius:16px;box-shadow:0 2px 12px #0000000d,inset 0 1px #ffffffbf;padding:10px 14px;text-align:center;color:#666;font-size:13px}.wifi-status-connected{background:#34c7592e;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid rgba(52,199,89,.45);border-radius:16px;box-shadow:0 2px 12px #34c7591f,inset 0 1px #ffffffd9;padding:10px 14px;text-align:center;color:#1a7a36;font-weight:600;font-size:14px}.wifi-status-disconnected{background:#ff9f432e;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid rgba(255,159,67,.45);border-radius:16px;box-shadow:0 2px 12px #ff9f431f,inset 0 1px #ffffffd9;padding:12px 16px;text-align:center}.wifi-status-disconnected .wifi-title{color:#c2410c;font-weight:600;font-size:14px;margin-bottom:4px}.wifi-status-disconnected .wifi-subtitle{font-size:12px;color:#8b5a2b;margin-bottom:10px}.wifi-retry-btn{background:#ff9f4340;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1.5px solid rgba(255,159,67,.5);border-radius:10px;color:#c2410c;font-size:13px;font-weight:600;padding:6px 14px;cursor:pointer;transition:all .2s ease}.wifi-retry-btn:active{background:#ff9f4366;transform:scale(.95)}.btn-qr-scan-active{background:#9575cd33;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1.5px solid rgba(149,117,205,.48);border-radius:16px;box-shadow:0 2px 14px #9575cd2e,inset 0 1px #fffc;color:#5e35b1;font-weight:600;padding:16px;width:100%;cursor:pointer;transition:all .2s ease;font-size:15px}.btn-qr-scan-active:active{background:#9575cd52;transform:scale(.97)}.btn-qr-scan-disabled{background:#c8c8c826;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(200,200,200,.35);border-radius:16px;box-shadow:0 1px 8px #0000000a,inset 0 1px #ffffffa6;color:#999;padding:16px;width:100%;cursor:not-allowed;opacity:.6;font-size:15px;font-weight:600}.stats-segment-container{background:#ffffff59;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1.5px solid rgba(255,255,255,.65);border-radius:18px;padding:4px;box-shadow:0 2px 12px #0000000f,inset 0 1px #ffffffd9}.stats-segment-btn{background:transparent;border:none;border-radius:14px;color:#666;font-weight:500;transition:all .2s ease;cursor:pointer}.stats-segment-btn.active{background:#34c759d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(52,199,89,.5);border-radius:14px;color:#fff;font-weight:700;box-shadow:0 2px 8px #34c75940,inset 0 1px #ffffff4d}.month-navigator{background:#ffffff80;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid rgba(255,255,255,.72);border-radius:18px;box-shadow:0 3px 16px #0000000f,inset 0 1px #ffffffe6;padding:10px 14px}.month-nav-btn{background:#ffffff73;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);border-radius:10px;box-shadow:0 1px 6px #00000012;transition:all .15s ease;cursor:pointer;padding:6px;display:inline-flex;align-items:center;justify-content:center}.month-nav-btn:active{background:#ffffffa6;transform:scale(.94)}.team-select-dropdown{background:#ffffff8c;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:14px;box-shadow:0 2px 12px #0000000f,inset 0 1px #ffffffd9;color:#333;font-weight:500;padding:10px 14px;width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;font-size:max(16px,.875rem);outline:none;border:1.5px solid rgba(255,255,255,.7)}.team-select-dropdown:focus{border-color:#34c75980;box-shadow:0 0 0 3px #34c7591f,inset 0 1px #ffffffd9;outline:none}.btn-html-download{background:#5ac8fa33;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(90,200,250,.48);border-radius:16px;box-shadow:0 2px 12px #5ac8fa1f,inset 0 1px #fffc;color:#0071a4;font-weight:600;transition:all .2s ease;cursor:pointer}.btn-html-download:active{background:#5ac8fa52;transform:scale(.97)}.btn-excel-download{background:#34a05a2e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1.5px solid rgba(52,160,90,.42);border-radius:16px;box-shadow:0 2px 12px #34a05a1f,inset 0 1px #ffffffbf;color:#1a5c30;font-weight:600;transition:all .2s ease;cursor:pointer}.btn-excel-download:active{background:#34a05a47;transform:scale(.97)}.calendar-table-card{background:#ffffff85;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1.5px solid rgba(255,255,255,.72);border-radius:20px;box-shadow:0 4px 24px #00000012,inset 0 1px #ffffffe6;overflow:hidden}.admin-mode-badge{background:#34c75926;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(52,199,89,.35);border-radius:20px;box-shadow:0 1px 6px #34c7591a,inset 0 1px #ffffffb3;color:#1a7a36;font-weight:600;padding:4px 12px}.btn-checkin-active,.btn-checkout-active,.btn-field-work,.btn-annual-leave,.btn-sick-leave{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:clamp(11px,3.2vw,14px)!important;letter-spacing:-.2px;min-width:0;padding:14px 10px;text-align:center;line-height:1.3;word-break:keep-all}.action-buttons-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.action-buttons-grid>*{min-width:0;width:100%}.wifi-status-connected,.wifi-status-disconnected,.wifi-status-checking{word-break:keep-all;overflow-wrap:break-word}.wifi-status-connected>div,.wifi-status-disconnected>div{font-size:clamp(12px,3.4vw,14px);line-height:1.4}.wifi-label{font-size:clamp(10px,3vw,12px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.btn-qr-scan-active,.btn-qr-scan-disabled{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:clamp(13px,3.6vw,15px)!important;word-break:keep-all;min-width:0}.calendar-legend{width:100%;margin-top:10px;padding:10px 0;overflow:hidden;background:#ffffff59;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.55);border-radius:12px;box-shadow:inset 0 1px #ffffffb3}.calendar-legend-scroll{display:flex;flex-wrap:nowrap;gap:14px;overflow-x:auto;overflow-y:hidden;padding:0 12px;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.calendar-legend-scroll::-webkit-scrollbar{display:none}.legend-item{flex:0 0 auto;white-space:nowrap;font-size:clamp(10px,2.8vw,12px);color:#555;line-height:1.5;word-break:keep-all}.employee-card-name{font-size:clamp(18px,5.5vw,22px);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:keep-all}.employee-card-team,.employee-card-status{font-size:clamp(11px,3.2vw,13px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:keep-all}.hint-text{font-size:clamp(11px,3vw,13px);line-height:1.5;color:#666;text-align:center;word-break:keep-all;overflow-wrap:break-word;padding:0 8px}.btn-html-download,.btn-excel-download,.stats-segment-btn,.team-select-dropdown{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:clamp(12px,3.4vw,14px);word-break:keep-all;min-width:0;letter-spacing:-.2px}.app-container,.tab-content{max-width:100vw;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));padding-bottom:env(safe-area-inset-bottom);overflow-x:hidden}.glass-card,.calendar-table-card,.month-navigator,.stats-segment-container,.wifi-status-connected,.wifi-status-disconnected,.wifi-status-checking{max-width:100%;box-sizing:border-box}.bilingual-inline{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:keep-all;font-size:clamp(11px,3vw,13px)}.bilingual-stack{display:flex;flex-direction:column;gap:2px}.bilingual-stack .cn{font-size:clamp(11px,3vw,13px);color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:keep-all}.bilingual-stack .ko{font-size:clamp(10px,2.8vw,12px);color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:keep-all}.ip-help-box{font-size:clamp(11px,3vw,13px);padding:10px;background:#ffffff80;border-radius:8px;line-height:1.6}.ip-help-title{margin-bottom:6px;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ip-help-step{margin-bottom:6px}.ip-help-step .cn,.ip-help-step .ko{font-size:clamp(10px,2.8vw,12px);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:keep-all}.ip-help-step .cn{color:#333}.ip-help-step .ko{color:#666}.tips-box{border-radius:10px;padding:10px 12px;background:#78788014}.tip-row{margin-bottom:4px}.tip-row .cn,.tip-row .ko{font-size:clamp(10px,2.8vw,12px);line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;word-break:keep-all}.tip-row .cn{color:#444}.tip-row .ko{color:#888}.wifi-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .2s ease}.wifi-modal-content{background:#ffffffed;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1.5px solid rgba(255,255,255,.85);border-radius:20px;box-shadow:0 8px 32px #00000026,inset 0 1px #ffffffe6;width:100%;max-width:380px;max-height:85vh;overflow-y:auto;padding:20px;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.wifi-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(0,0,0,.08)}.wifi-modal-close{background:#0000000f;border:none;border-radius:50%;width:30px;height:30px;font-size:14px;color:#666;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wifi-modal-close:active{background:#00000026;transform:scale(.9)}.wifi-modal-loading{display:flex;flex-direction:column;align-items:center;padding:32px 0;gap:12px}.wifi-modal-section{margin-bottom:12px;padding:12px;background:#00000008;border-radius:12px}.wifi-modal-label{margin-bottom:6px}.wifi-modal-label .cn{font-size:12px;font-weight:600;color:#555}.wifi-modal-label .ko{font-size:11px;color:#888}.wifi-modal-ip-list{display:flex;flex-direction:column;gap:6px}.wifi-modal-ip-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#ffffffbf;border-radius:8px;flex-wrap:wrap}.wifi-modal-ip-item code{font-family:Courier New,monospace;font-size:12px;color:#444;word-break:break-all;flex:1;min-width:0}.wifi-modal-ip-item code.matched{color:#1b5e20;font-weight:700}.wifi-modal-ip-label{font-size:10px;background:#0000000f;padding:2px 7px;border-radius:4px;color:#666;flex-shrink:0}.wifi-modal-match-badge{font-size:14px;flex-shrink:0}.wifi-modal-empty{padding:10px;text-align:center}.wifi-modal-my-ip{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}.wifi-modal-my-ip code{flex:1;font-family:Courier New,monospace;font-size:13px;padding:10px 12px;background:#ffffffd9;border-radius:8px;word-break:break-all;min-width:0;font-weight:600;border:1.5px solid transparent}.wifi-modal-my-ip code.matched{color:#1b5e20;border-color:#4caf5073;background:#e8f5e9d9}.wifi-modal-my-ip code.unmatched{color:#c62828;border-color:#f4433666;background:#ffebeed9}.wifi-modal-copy-btn{padding:8px 12px;background:#1976d224;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1.5px solid rgba(25,118,210,.38);border-radius:8px;color:#0d47a1;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s ease;flex-shrink:0}.wifi-modal-copy-btn:active{background:#1976d247;transform:scale(.95)}.wifi-modal-ip-type{font-size:10px;color:#999;margin-top:6px;text-align:right}.wifi-modal-result{padding:14px;border-radius:12px;margin:12px 0;text-align:center}.wifi-modal-result.success{background:#4caf501c;border:1.5px solid rgba(76,175,80,.38)}.wifi-modal-result.fail{background:#f4433617;border:1.5px solid rgba(244,67,54,.32)}.wifi-modal-help{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(244,67,54,.3)}.wifi-modal-actions{display:flex;gap:8px;margin-top:14px}.wifi-modal-recheck-btn{flex:1;padding:12px;background:#ffffffa6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1.5px solid rgba(0,0,0,.1);border-radius:12px;color:#555;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.wifi-modal-recheck-btn:active{background:#ffffffe6;transform:scale(.97)}.wifi-modal-confirm-btn{flex:1;padding:12px;background:#34c759e0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1.5px solid rgba(52,199,89,.6);border-radius:12px;color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #34c75938;white-space:nowrap}.wifi-modal-confirm-btn:active{background:#34c759;transform:scale(.97)}.admin-calendar-wrapper{width:100%;max-width:100%;background:#ffffff85;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1.5px solid rgba(255,255,255,.72);border-radius:20px;box-shadow:0 4px 24px #00000012,inset 0 1px #ffffffe6;overflow:hidden;padding:0;margin-bottom:12px;max-height:calc(100vh - 260px);display:flex;flex-direction:column}.admin-calendar-scroll{width:100%;flex:1;overflow-x:auto!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.admin-calendar-scroll::-webkit-scrollbar{width:6px;height:6px}.admin-calendar-scroll::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.admin-calendar-scroll::-webkit-scrollbar-track{background:transparent}.tab-content .admin-calendar-scroll,.app-content .admin-calendar-scroll{overflow-x:auto!important}.admin-calendar-table{min-width:-moz-max-content;min-width:max-content;white-space:nowrap;border-collapse:separate}.admin-calendar-table th,.admin-calendar-table td{white-space:nowrap}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}
