@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:"Segoe UI", "Noto Sans Thai", sans-serif;--font-mono:"Cascadia Code", monospace;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"Segoe UI", "Noto Sans Thai", sans-serif;--default-mono-font-family:"Cascadia Code", monospace;--color-background:var(--background);--color-foreground:var(--foreground)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.grid{display:grid}.inline{display:inline}.table{display:table}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--background:#f5efe7;--foreground:#1d160f;--muted:#6b5b4d;--surface:#fffaf4e0;--surface-strong:#fff7ef;--border:#674a2d24;--brand:#8b4513;--brand-strong:#6f3410;--brand-soft:#f3d6bf;--success:#166534;--danger:#b91c1c;--warning:#b45309}*{box-sizing:border-box}html{min-height:100%}body{background:var(--background);min-height:100vh;color:var(--foreground);font-family:var(--font-sans);background-image:radial-gradient(circle at 0 0,#ffd7b5cc,#0000 32%),radial-gradient(circle at 100% 0,#c48b592e,#0000 26%),linear-gradient(#fff8f2 0%,#f5efe7 100%);margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh}.page{width:min(1180px,100% - 32px);margin:0 auto;padding:32px 0 56px}.hero{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.hero-title{margin:0;font-size:clamp(2rem,4vw,3.4rem);line-height:1}.hero-subtitle{color:var(--muted);margin:8px 0 0}.badge-row,.action-row{flex-wrap:wrap;gap:10px;display:flex}.badge{border:1px solid var(--border);color:var(--muted);background:#ffffffbd;border-radius:999px;align-items:center;gap:6px;padding:8px 12px;display:inline-flex}.panel{background:var(--surface);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:24px;padding:20px;box-shadow:0 16px 44px #5e432714}.panel+.panel{margin-top:16px}.panel-title{margin:0 0 4px;font-size:1.1rem}.panel-subtitle{color:var(--muted);margin:0}.grid{gap:16px;display:grid}.grid.stats{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));margin-bottom:20px}.stat-card{border:1px solid var(--border);background:linear-gradient(#fffffff2,#fff8f0e0);border-radius:22px;padding:20px}.stat-label{color:var(--muted);margin:0 0 10px;font-size:.95rem}.stat-value{margin:0;font-size:2rem;font-weight:700}.btn{cursor:pointer;border:0;border-radius:14px;min-height:48px;padding:13px 18px;font-weight:600;transition:transform .15s,opacity .15s,background .15s;position:relative}.notification-badge{color:#fff;background:#dc2626;border:2px solid #fff;border-radius:999px;justify-content:center;align-items:center;min-width:24px;min-height:24px;padding:0 8px;font-size:.8rem;font-weight:700;display:inline-flex;position:absolute;top:-8px;right:-8px;box-shadow:0 10px 24px #dc262640}.btn:hover{transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-strong)}.btn-secondary{color:var(--foreground);border:1px solid var(--border);background:#fff}.btn-danger{color:var(--danger);background:#fff1f2;border:1px solid #b91c1c24}.btn-ghost{color:var(--muted);border:1px dashed var(--border);background:0 0}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.weekday-picker{flex-wrap:wrap;gap:8px;display:flex}.weekday-option{border:1px solid var(--border);color:var(--foreground);cursor:pointer;background:#ffffffe6;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:.88rem;font-weight:700;display:inline-flex}.weekday-option input{width:14px;height:14px;accent-color:var(--brand)}.employee-register-actions{margin-top:18px}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:74px}.password-visibility-btn{color:#7a4a16;background:#fff;border:1px solid #7a4a1629;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700;line-height:1;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-visibility-btn:hover{background:#f8f1e8}.field{flex-direction:column;gap:8px;display:flex}.field label{color:var(--muted);font-size:.92rem}.field input,.field select,.field textarea{border:1px solid var(--border);background:#ffffffeb;border-radius:14px;width:100%;min-height:48px;padding:10px 12px}.message{border-radius:14px;margin-top:14px;padding:12px 14px}.message-success{color:var(--success);background:#16653417}.message-error{color:var(--danger);background:#b91c1c14}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:14px 12px}.data-table th{color:var(--muted);font-size:.92rem;font-weight:600}.table-meta{color:var(--muted);font-size:.85rem}.pre-wrap{white-space:pre-wrap;word-break:break-word;font-family:var(--font-mono);margin:0;font-size:.78rem}.photo-preview{border:1px solid var(--border);object-fit:cover;border-radius:18px;width:100%;max-width:280px;margin-top:10px}.attendance-photo-thumb{border:1px solid var(--border);object-fit:cover;background:#ffffffe6;border-radius:16px;width:60px;height:60px;display:block}.camera-box{border:1px dashed var(--border);background:#ffffffb8;border-radius:24px;width:100%;padding:12px}.camera-preview{object-fit:cover;background:#120c08;border-radius:18px;width:100%;max-height:420px;display:block}.camera-placeholder{min-height:220px;color:var(--muted);text-align:center;background:radial-gradient(circle at top,#f3d6bff2,#ffffffb3);border-radius:18px;place-items:center;padding:24px;line-height:1.7;display:grid}.map-picker{border:1px solid var(--border);background:#ffffffb3;border-radius:24px;width:100%;min-height:360px;overflow:hidden}.record-card{border:1px solid var(--border);background:#ffffffe0;border-radius:22px;padding:16px}.record-card+.record-card{margin-top:12px}.record-card-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.record-card-body{gap:10px;display:grid}.record-line{justify-content:space-between;align-items:center;gap:12px;font-size:.95rem;display:flex}.record-line span{color:var(--muted)}.mobile-only{display:none}.desktop-only{display:block}.status-pill{background:var(--brand-soft);color:var(--brand-strong);border-radius:999px;align-items:center;padding:6px 10px;font-size:.85rem;display:inline-flex}.status-pill.success{color:var(--success);background:#1665341a}.status-pill.warning{color:var(--warning);background:#b453091f}.status-pill.danger{color:var(--danger);background:#b91c1c1f}.empty-state{text-align:center;color:var(--muted);padding:24px}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{width:min(460px,100%);padding:28px}.login-card h1{margin:0;font-size:2.3rem}.login-card p{color:var(--muted)}.login-action-row{margin-top:18px}.shop-lookup-field{position:relative}.shop-lookup-list{z-index:20;border:1px solid var(--border);background:#fffaf4fa;border-radius:16px;padding:8px;position:absolute;top:calc(100% + 8px);left:0;right:0;box-shadow:0 16px 44px #5e432724}.shop-lookup-option{cursor:pointer;text-align:left;width:100%;color:var(--foreground);background:0 0;border:0;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.shop-lookup-option span{color:var(--muted);font-size:.82rem}.shop-lookup-option:hover:not(:disabled){background:#f3d6bf73}.shop-lookup-option:disabled{cursor:default;color:var(--muted)}.language-switcher{z-index:60;border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffaf4e0;border-radius:999px;padding:6px;display:inline-flex;position:fixed;top:16px;right:16px;box-shadow:0 10px 28px #5e43271f}.language-switch-btn{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:999px;padding:8px 14px;font-size:.9rem;font-weight:700}.language-switch-btn.active{background:var(--brand);color:#fff}.support-footer{justify-content:center;padding:0 16px 24px;display:flex}.support-link{color:var(--muted);text-underline-offset:4px;font-size:.82rem;text-decoration:underline}.support-link:hover{color:var(--brand-strong)}@media (max-width:640px){.page{width:min(100% - 20px,1180px);padding:20px 0 36px}.hero{align-items:flex-start}.panel,.stat-card{padding:16px}.map-picker{min-height:300px}.action-row{grid-template-columns:repeat(2,minmax(0,1fr));width:100%;display:grid}.action-row .btn{width:100%}.hero-title{font-size:2rem}.stat-value{font-size:1.7rem}.field input,.field select,.field textarea{font-size:16px}.desktop-only{display:none}.mobile-only{display:block}}@media (min-width:641px){.mobile-only{display:none}.desktop-only{display:block}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
