@import "https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&display=swap";
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_fe8b9d92-module__LINzvG__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_fe8b9d92-module__LINzvG__variable{--font-inter:"Inter","Inter Fallback"}
@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-border-style:solid;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-gray-50:#f9fafb;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-xl:36rem;--container-7xl:80rem;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-black:900;--tracking-tight:-.025em;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-inter);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-gray-50:lab(98.2596% -.247031 -.706708)}}}@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{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.z-10{z-index:10}.col-span-full{grid-column:1/-1}.mx-4{margin-inline:calc(var(--spacing)*4)}.mx-auto{margin-inline:auto}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.table{display:table}.h-3{height:calc(var(--spacing)*3)}.h-16{height:calc(var(--spacing)*16)}.h-20{height:calc(var(--spacing)*20)}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-3{width:calc(var(--spacing)*3)}.w-16{width:calc(var(--spacing)*16)}.w-20{width:calc(var(--spacing)*20)}.w-full{width:100%}.max-w-7xl{max-width:var(--container-7xl)}.max-w-md{max-width:var(--container-md)}.max-w-xl{max-width:var(--container-xl)}.flex-1{flex:1}.table-auto{table-layout:auto}.border-collapse{border-collapse:collapse}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-full{border-radius:3.40282e38px}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-white{background-color:var(--color-white)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-5{padding:calc(var(--spacing)*5)}.p-6{padding:calc(var(--spacing)*6)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-8{padding-inline:calc(var(--spacing)*8)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-2\.5{padding-block:calc(var(--spacing)*2.5)}.py-4{padding-block:calc(var(--spacing)*4)}.py-16{padding-block:calc(var(--spacing)*16)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-black{--tw-font-weight:var(--font-weight-black);font-weight:var(--font-weight-black)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.uppercase{text-transform:uppercase}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.opacity-100{opacity:1}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-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,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.hover\:scale-\[1\.02\]:hover{scale:1.02}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}}@media (min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}}@media (min-width:48rem){.md\:mb-6{margin-bottom:calc(var(--spacing)*6)}.md\:mb-8{margin-bottom:calc(var(--spacing)*8)}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:justify-end{justify-content:flex-end}.md\:gap-4{gap:calc(var(--spacing)*4)}.md\:p-5{padding:calc(var(--spacing)*5)}.md\:p-6{padding:calc(var(--spacing)*6)}.md\:p-8{padding:calc(var(--spacing)*8)}.md\:py-24{padding-block:calc(var(--spacing)*24)}.md\:text-right{text-align:right}}@media (min-width:64rem){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}}:root{--background:#f8fafc;--foreground:#0f172a;--card:#fff;--card-border:#94a3b833;--shadow-soft:0 12px 30px #0f172a14;--shadow-strong:0 24px 60px #0f172a2e}@media (prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed}}body{color:var(--foreground);font-family:var(--font-inter),Arial,Helvetica,sans-serif;background:radial-gradient(circle at 16% 14%,#2563eb59,#0000 45%),radial-gradient(circle at 88% 0,#3b82f647,#0000 40%),linear-gradient(160deg,#0b1220 0%,#0f172a 55%,#0b1020 100%)}.admin-app{--admin-bg:#f8fafc;--admin-card:#fff;--admin-muted:#111827;--admin-border:#94a3b84d;background:radial-gradient(circle at 18% 12%,#7dd3fc38,#0000 45%),radial-gradient(circle at 88% 0,#60a5fa33,#0000 40%),linear-gradient(160deg,#1e4fa3 0%,#1f63cf 55%,#1e4fa3 100%);border:1px solid #94a3b840;border-radius:26px;grid-template-columns:minmax(220px,280px) 1fr;gap:24px;width:100%;min-height:calc(100vh - 24px);padding:22px;display:grid;box-shadow:0 28px 60px #02061759}@media (min-width:1024px){.admin-app-layout{align-items:flex-start;gap:32px;display:flex}}.absensi-shell{max-width:1100px;margin:0 auto;padding:16px 20px 32px;display:block}.absensi-shell>.glass-card,.absensi-shell>.card{margin-bottom:18px}.absensi-shell>.glass-card:last-child,.absensi-shell>.card:last-child{margin-bottom:0}.absensi-hero{background:linear-gradient(140deg,#fffffffa,#f1f5f9e6);border:1px solid #0f172a14}.absensi-hero p{color:#0f172a;opacity:1}.absensi-card{padding:22px}.admin-sidebar{color:#f8fafc;background:linear-gradient(#0b1220 0%,#0f172a 60%,#0b1220 100%);border:1px solid #94a3b833;border-radius:24px;flex-direction:column;gap:20px;height:auto;padding:20px;display:flex;box-shadow:0 28px 60px #02061780}@media (min-width:1024px){.admin-sidebar{height:auto;min-height:calc(100vh - 4rem);position:sticky;top:2rem}}.admin-sidebar .nav{max-height:none;overflow:visible}.brand{align-items:center;gap:12px;display:flex}.brand__logo{background:linear-gradient(135deg,#38bdf8,#2563eb);border-radius:16px;place-items:center;width:46px;height:46px;font-size:20px;display:grid;box-shadow:0 12px 26px #2563eb80}.brand__logo svg{color:#e2e8f0;width:22px;height:22px}.brand__title{font-size:1.05rem;font-weight:700}.brand__sub{opacity:.7;font-size:.75rem}.nav{gap:12px;display:grid}.nav__item{width:100%;color:inherit;text-align:left;background:#0f172a99;border:1px solid #94a3b838;border-radius:16px;align-items:center;gap:10px;padding:12px 16px;font-weight:600;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.nav__item--active{background:linear-gradient(135deg,#2563ebb3,#0ea5e980);border-color:#7dd3fce6;box-shadow:inset 0 0 0 1px #94a3b833,0 16px 30px #1e40af59}.nav__icon{background:#ffffff2e;border:1px solid #ffffff2e;border-radius:10px;place-items:center;width:30px;height:30px;display:grid}.nav__icon svg{color:#e2e8f0;width:18px;height:18px}.nav__item:hover{border-color:#94a3b873;transform:translateY(-1px);box-shadow:0 14px 26px #02061759}.sidebar__footer{gap:12px;margin-top:auto;display:grid}.admin-main{gap:20px;padding:4px 4px 20px;display:grid}.mobile-topbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(#0b1220f2,#0f172ae6);border:1px solid #1e40af59;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:none;box-shadow:0 12px 26px #02061773}.mobile-topbar__title{color:#e2e8f0;font-weight:800}.mobile-topbar__btn{background:#0f172a59;border:1px solid #bfdbfee6;border-radius:10px;place-items:center;width:36px;height:36px;font-weight:700;display:grid;box-shadow:inset 0 0 0 1px #ffffff26}.burger{gap:3px;width:18px;height:12px;display:grid}.burger span{background:#e2e8f0;border-radius:999px;height:2px;display:block}.sidebar-overlay{display:none}.topbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.page-title{color:var(--admin-text);font-size:clamp(1.6rem,2vw,2.1rem);font-weight:800}.page-subtitle{color:var(--admin-muted);font-size:.9rem}.topbar__right{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.search{border:1px solid var(--admin-border);background:#fffc;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;display:flex}.search__input{color:#000;background:0 0;border:none;outline:none;min-width:200px;font-weight:600}.search__input::placeholder{color:#000;opacity:.6}.admin-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:26px;display:grid}.report-grid{grid-template-columns:1fr;gap:24px}.card{border:1px solid var(--admin-border);background:linear-gradient(#fff,#f8fafc);border-radius:22px;grid-column:span 6;gap:20px;padding:22px;display:grid;box-shadow:0 16px 34px #0f172a1f}.siswa-card{gap:14px}.siswa-card--compact{gap:12px;padding:0;font-family:Sora,Segoe UI,sans-serif}.siswa-card--compact .card__head{background:linear-gradient(#2563eb14,#fff0);border-bottom:1px solid #94a3b833;border-top-left-radius:24px;border-top-right-radius:24px;gap:12px 16px;padding:16px 20px 12px}.siswa-card--compact .siswa-head__title{padding-top:0}.siswa-card--compact .card__title,.siswa-card--compact .card__desc{margin:0}.siswa-card--compact .card__desc{color:#475569;font-size:.88rem}.siswa-card--compact .siswa-toolbar{gap:10px}.siswa-card--compact .siswa-segmented{box-shadow:none;background:0 0;border:none;border-radius:0;margin-top:8px;padding:0}.siswa-card--compact .table-wrap{z-index:1;padding:0 16px 16px;position:relative}.siswa-card--compact .table--cards{border-spacing:0 12px}.card--full{grid-column:span 12}.dashboard-card{grid-column:span 6}.dashboard-grid .dashboard-card--metric{grid-column:span 3}.dashboard-grid .dashboard-card--wide{grid-column:span 6}.dashboard-grid{margin-top:18px}.dashboard-hero{background:linear-gradient(135deg,#3b82f614,#0ea5e914);border:1px solid #94a3b84d}.dashboard-hero__content{flex-direction:column;gap:16px;display:flex}.dashboard-hero__actions{flex-wrap:wrap;gap:12px;display:flex}.dashboard-alert{color:#991b1b;background:#fff5f5;border:1px solid #ef444433;font-weight:600}.dashboard-metric{color:#0f172a;font-size:2.6rem;font-weight:800}.dashboard-card--metric{background:linear-gradient(#fff,#f8fafc);border:1px solid #94a3b833}.dashboard-metric-row{align-items:flex-end;gap:16px;display:flex}.metric-label{color:#0f172a;text-transform:uppercase;font-size:.75rem;font-weight:700}.metric-value{color:#0f172a;font-size:1.6rem;font-weight:800}.combo-chart{grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:10px;height:190px;display:grid}.combo-chart__col{place-items:end center;gap:6px;display:grid}.combo-chart__bar{border-radius:10px;width:100%;min-height:6px}.combo-chart__bar--absen{background:linear-gradient(#2563ebe6,#3b82f64d);border:1px solid #2563eb66}.combo-chart__bar--pel{background:linear-gradient(#ef4444e6,#f871714d);border:1px solid #ef444466}.combo-chart__label{color:#0f172a;font-size:.7rem}.sparkline{background:#f8fafc;border:1px solid #94a3b84d;border-radius:16px;place-items:center;width:100%;height:80px;display:grid}.chart{grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:8px;height:180px;display:grid}.chart__col{justify-items:center;gap:6px;display:grid}.chart__bar{background:linear-gradient(#2563ebe6,#3b82f659);border:1px solid #2563eb66;border-radius:10px;width:100%}.chart__label{color:#0f172a;font-size:.7rem}@media (max-width:1024px){.dashboard-card,.dashboard-grid .dashboard-card--metric,.dashboard-grid .dashboard-card--wide{grid-column:span 12}.dashboard-hero__content{align-items:flex-start}}.card__head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.siswa-head{flex-wrap:wrap;align-items:center;gap:14px 18px}.siswa-head__title{flex:1;min-width:220px}.siswa-toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.siswa-actions{flex-wrap:wrap}.siswa-segmented{flex:100%;justify-content:flex-start}.card__head+.siswa-segmented{flex-wrap:nowrap;gap:8px;margin-top:-2px;padding:6px 2px 10px;display:flex;overflow-x:auto}.siswa-card--compact .siswa-segmented{background:#ffffffd9;border:1px solid #94a3b840;border-radius:14px;margin-top:12px;padding:8px 12px;box-shadow:0 10px 22px #0f172a0f}.card__head>.segmented,.card__head>.siswa-segmented{margin-top:4px}@media (max-width:900px){.siswa-card--compact .card__head{padding:14px 16px 10px}.siswa-card--compact .siswa-segmented{padding:0 16px 8px}.siswa-toolbar{justify-content:flex-start;width:100%}}.pagination{border-top:1px solid #94a3b84d;justify-content:space-between;align-items:center;gap:16px;padding-top:12px;display:flex}.pagination__controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.pagination__page{color:#0f172a;font-weight:700}.pagination__size{align-items:center;gap:8px;display:flex}.pagination__label{color:#0f172a;font-size:.8rem;font-weight:700}.pagination__select{min-width:90px;padding:6px 10px}.report-card .table-wrap{overflow-x:auto}.report-table{min-width:560px}.report-header{flex-wrap:wrap;align-items:center;gap:12px 18px}.report-filter-card{background:linear-gradient(#fff,#f5f7fb);border:1px solid #94a3b840;box-shadow:0 16px 36px #0f172a14}.report-filter-head{align-items:center;margin-bottom:12px}.report-filters{gap:14px;display:grid}.report-range{flex-wrap:wrap;gap:10px;display:flex}.report-fields{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.report-fields .field .input,.report-fields .field select{height:44px}.report-fields .search{height:44px;padding:0 14px}.badge{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.badge--success{color:#166534;background:#dcfce7;border-color:#16653433}.badge--warning{color:#92400e;background:#fef3c7;border-color:#92400e33}.badge--danger{color:#991b1b;background:#fee2e2;border-color:#991b1b33}.badge--muted{color:#475569;background:#e2e8f0;border-color:#47556933}.report-card{background:linear-gradient(#fff,#f5f7fb);border:1px solid #94a3b840;box-shadow:0 18px 40px #0f172a14}.report-card .card__title{font-size:1.1rem}.report-card .card__desc{color:#64748b}.report-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.report-actions .btn{white-space:nowrap;min-height:40px;padding:0 16px}.report-actions .btn--primary{min-width:120px}.report-actions .btn--ghost{min-width:160px}.report-nav{flex-wrap:wrap;gap:10px;display:flex}.report-nav .segmented__btn{padding:7px 14px;text-decoration:none}.report-nav .segmented__btn:hover{background:#2563eb14;border-color:#2563eb59}.report-filter-card .report-range{padding-bottom:4px}.report-filter-card .field .label{color:#1f2937;font-weight:700}.report-filter-card .btn--ghost{background:#fff;border-color:#94a3b899}.report-filter-card .btn--ghost:hover{background:#2563eb14;border-color:#2563eb59}.report-actions .btn{height:40px}.report-actions .btn--primary{box-shadow:0 10px 22px #2563eb33}.report-filter-card .segmented__btn{padding:7px 14px}.report-filter-card .segmented__btn.is-active{background:#1e293b;border-color:#0f172ae6;box-shadow:0 10px 18px #0f172a2e}.report-filter-card .card__desc{color:#64748b}.report-card .table{background:#fff;border:1px solid #94a3b833;border-radius:16px;overflow:hidden}.report-card .table thead th{color:#0f172a;letter-spacing:.02em;text-transform:uppercase;background:#f1f5f9;font-size:.75rem;font-weight:700}.report-card .table tbody tr{transition:background .2s}.report-card .table tbody tr:hover{background:#3b82f60f}.report-card .table td{color:#0f172a}.report-card .table-empty{color:#64748b;padding:24px}.report-pagination{white-space:nowrap;justify-content:flex-end;padding-top:12px;overflow-x:auto}.report-pagination::-webkit-scrollbar{height:6px}.report-pagination::-webkit-scrollbar-thumb{background:#94a3b880;border-radius:999px}.report-pagination .segmented__btn{flex:none}@media (max-width:900px){.report-card{padding:18px}.report-actions{width:100%}.report-actions .btn{flex:auto}.report-pagination{justify-content:flex-start}.report-fields{grid-template-columns:1fr}.report-actions .btn{flex:auto;width:auto}.report-nav .segmented__btn{text-align:center;width:100%}}.report-actions{gap:12px;margin-left:16px}.card__title{color:#0f172a;font-size:1.1rem;font-weight:700}.card__desc{color:#0f172a;font-size:.85rem}.badge{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:6px 12px;font-size:.7rem;font-weight:700}.badge--blue{color:#1d4ed8;background:#2563eb1f}.badge--green{color:#047857;background:#10b98124}.badge--red{color:#b91c1c;background:#ef444424}.badge--amber{color:#92400e;background:#f59e0b38}.form{gap:16px;display:grid}.field{gap:8px;display:grid}.label{color:#374151;font-size:.8rem;font-weight:700}.input{color:#111827;background:#fff;border:1px solid #94a3b859;border-radius:12px;outline:none;padding:10px 12px;font-weight:600}.input-prefix{align-items:center;gap:0;display:flex}.input-prefix__icon{color:#0f172a;background:#f8fafc;border:1px solid #94a3b859;border-right:none;border-radius:12px 0 0 12px;align-items:center;height:42px;padding:0 12px;font-weight:800;display:inline-flex}.input-prefix__field{border-left:none;border-radius:0 12px 12px 0}.input:focus{border-color:var(--admin-primary);box-shadow:0 0 0 3px #3b82f626}.actions{flex-wrap:wrap;gap:12px;display:flex}.btn{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-weight:700;transition:transform .2s,box-shadow .2s;display:inline-flex}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px #0f172a1f}.btn--primary{background:var(--admin-primary);color:#fff}.btn--ghost{color:#0f172a;background:#fff;border-color:#94a3b866}.btn--danger{color:#fff;background:#dc2626}.btn--success{color:#fff;background:#22c55e}.btn--info{color:#fff;background:#3b82f6}.btn--warning{color:#fff;background:#f59e0b}.btn--sm{border-radius:999px;padding:6px 12px;font-size:.75rem}.two-col{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.divider{background:#94a3b84d;height:1px}.list{gap:10px;display:grid}.list__row{border:1px solid var(--admin-border);background:#fff;border-radius:14px;justify-content:space-between;align-items:center;gap:18px;padding:12px 14px;display:flex}.list__title{color:#111827;font-weight:700}.list__meta{color:var(--admin-muted);font-size:.75rem}.table td .list__meta{margin-top:6px}.right{align-items:center;gap:14px;display:flex}.chip{border-radius:999px;margin-left:6px;padding:4px 8px;font-size:.75rem;font-weight:700}.table td[data-label=Saldo\ Poin] .chip{margin-top:4px;margin-left:0}.chip--green{color:#047857;background:#10b98133}.chip--red{color:#b91c1c;background:#ef444433}.chip--muted{color:var(--admin-muted);background:#94a3b833}.pill{color:#0f172a;background:#f1f5f9;border:1px solid #94a3b866;border-radius:4px;align-items:center;gap:8px;padding:6px 12px;font-size:.75rem;font-weight:700;display:inline-flex}.dot{background:#cbd5f5;border-radius:50%;width:8px;height:8px}.dot--ok{background:#22c55e}.dot--warn{background:#f59e0b}.dot--hadir{background:#22c55e}.dot--izin{background:#f59e0b}.dot--sakit{background:#3b82f6}.dot--alfa{background:#ef4444}.dot--belum{background:#94a3b8}.pill--hadir{background:#22c55e1f;border-color:#22c55e66}.pill--izin{background:#f59e0b26;border-color:#f59e0b66}.pill--sakit{background:#3b82f61f;border-color:#3b82f666}.pill--alfa{background:#ef44441f;border-color:#ef444466}.pill--belum{background:#94a3b82e;border-color:#94a3b873}.table-wrap{width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%;min-width:720px}.table--cards{border-collapse:separate;border-spacing:0 14px;min-width:720px}.table--cards thead th{color:#475569;text-transform:uppercase;letter-spacing:.04em;background:0 0;border-bottom:none;font-size:.7rem}.table--cards tbody tr{background:#fff;border:1px solid #94a3b84d;box-shadow:0 14px 30px #0f172a14}.table--cards tbody tr:hover{box-shadow:0 18px 36px #0f172a1f}.table--cards tbody td{border-bottom:none}.table--cards tbody td:first-child{border-top-left-radius:18px;border-bottom-left-radius:18px}.table--cards tbody td:last-child{border-top-right-radius:18px;border-bottom-right-radius:18px}.table--cards .table-panel td{box-shadow:none;border:1px solid #ef444433;border-radius:18px}.table th,.table td{text-align:left;color:#000;border-bottom:1px solid #94a3b84d;padding:18px 24px;font-size:.85rem}.table-compact th,.table-compact td{padding:12px 16px}.table td{font-weight:600}.table th{color:#0f172a;background:#94a3b82e;font-weight:700}.th-right,.td-right{text-align:right}.table-empty{text-align:center;color:var(--admin-muted)}.table-panel td{background:#ef44440a}.table-input{color:#0f172a;text-align:left;background:0 0;border:none;outline:none;width:100%;font-weight:700}.icon-btn{background:#94a3b833;border:none;border-radius:999px;padding:6px 8px;font-size:.9rem;transition:transform .2s}.icon-btn:hover{transform:translateY(-1px)}.list__row .icon-btn--danger:hover{transform:none}.list__row .icon-btn--danger{color:#dc2626;background:#ef44441f;border:1px solid #ef444433}.row-actions{grid-template-columns:repeat(4,max-content);justify-content:end;align-items:center;gap:8px;display:grid}.btn--icon{white-space:nowrap;align-items:center;gap:6px;height:34px;padding:6px 10px;line-height:1;display:inline-flex}.btn__icon{justify-content:center;align-items:center;display:inline-flex}.btn__icon svg{width:16px;height:16px}.icon-btn--danger{color:#dc2626;background:#ef44441f;border:1px solid #ef444433;border-radius:999px;place-items:center;width:36px;height:34px;display:grid}.icon-btn--danger svg{width:16px;height:16px}.icon-btn--danger.is-confirm{color:#fff;background:#dc2626;border-color:#dc2626;width:auto;padding:6px 10px}.icon-btn__label{font-size:.75rem;font-weight:700}@media (max-width:1024px){.row-actions{grid-template-columns:repeat(2,max-content);justify-content:flex-start}}.segmented{flex-wrap:wrap;gap:10px;display:flex}.segmented__btn{border:1px solid var(--admin-border);color:#0f172a;background:#fff;border-radius:999px;padding:8px 14px;font-size:.78rem;font-weight:700;box-shadow:0 6px 14px #0f172a14}.segmented__btn.is-active{color:#fff;background:#0f172a;border-color:#0f172ae6;box-shadow:0 10px 20px #0f172a33}.segmented__dots{color:#64748b;justify-content:center;align-items:center;padding:0 6px;font-weight:700;display:inline-flex}.manual{background:#94a3b81f;border-radius:16px;padding:12px}.violation-panel{background:#ef444414;border:1px solid #ef444433;border-radius:16px;gap:12px;padding:14px;display:grid}.panel-title{color:#991b1b;font-weight:700}.panel-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;display:grid}.panel-item{text-align:left;color:#0f172a;background:#fff;border:1px solid #ef444433;border-radius:12px;gap:8px;padding:8px 10px;font-weight:600;display:flex}.panel-item span:not(.panel-points){color:#0f172a}.panel-item:hover{background:#ef444414;border-color:#ef444466}.panel-points{color:#b91c1c;font-weight:800}.muted{color:var(--admin-muted);font-size:.8rem}.qr-toolbar{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));align-items:end;gap:16px;display:grid}.qr-field{max-width:320px}.qr-actions{justify-items:flex-start;gap:6px;display:grid}.qr-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.qr-group-list{gap:22px;display:grid}.qr-group{border-bottom:1px dashed #94a3b880;gap:12px;padding-bottom:8px;display:grid}.qr-group:last-child{border-bottom:none}.qr-group__title{color:#0f172a;font-size:1.05rem;font-weight:800}.qr-card{border:1px solid var(--admin-border);background:#fff;border-radius:16px;gap:12px;padding:16px;display:grid;box-shadow:0 12px 24px #0f172a14}.qr-code{background:#f8fafc;border:1px dashed #94a3b866;border-radius:12px;place-items:center;padding:12px;display:grid}.qr-code img{width:170px;height:170px}.qr-meta{gap:4px;display:grid}.qr-name{color:#0f172a;font-weight:700}.qr-sub{color:#475569;font-size:.85rem;font-weight:600}.qr-id{color:#0f172a;font-family:Courier New,Courier,monospace;font-size:.8rem}.qr-card-actions{justify-content:flex-start;display:flex}.qr-print-area{break-inside:avoid}@media print{body{background:#fff!important}.admin-sidebar,.mobile-topbar,.qr-hide-print{display:none!important}.admin-app,.admin-main,.absensi-shell{box-shadow:none!important;background:#fff!important;border:none!important;margin:0!important;padding:0!important}.qr-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.qr-group{break-after:page;page-break-after:always;border:none;padding-bottom:0}.qr-group:last-child{page-break-after:auto}.qr-card{box-shadow:none;page-break-inside:avoid;border:1px solid #e2e8f0}.qr-code img{width:140px;height:140px}}.w-full{width:100%}@media (max-width:768px){.siswa-card{gap:10px}.table-wrap{overflow-x:hidden}.table{min-width:0}.table thead{display:none}.table,.table tbody,.table tr,.table td{width:100%;display:block}.table tr{border:1px solid var(--admin-border);background:#fff;border-radius:0;margin-bottom:0;padding:0}.table--cards tr{border-radius:18px;margin-bottom:14px;box-shadow:0 14px 26px #0f172a14}.table td{text-align:left;color:#000;border-bottom:1px solid #94a3b81a;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 16px;line-height:1.2;display:flex}.table td:last-child{border-bottom:none}.table td:before{content:attr(data-label);text-transform:uppercase;color:var(--admin-muted);text-align:left;margin-bottom:12px;margin-right:0;font-size:.7rem;font-weight:700}.table-compact td{text-align:right;flex-direction:row;align-items:center;gap:8px;padding:10px 12px}.table-compact td:before{margin-bottom:8px;margin-right:10px}.table-no-stack,.table-no-stack thead,.table-no-stack tbody,.table-no-stack tr,.table-no-stack th,.table-no-stack td{display:table}.table-no-stack thead{display:table-header-group}.table-no-stack tbody{display:table-row-group}.table-no-stack tr{display:table-row}.table-no-stack th,.table-no-stack td{text-align:left;padding:12px 14px;display:table-cell}.table-no-stack td:before{content:none}.table-compact-right td{text-align:right}.table-compact-right td:first-child,.table-compact-right th:first-child{text-align:left}.report-header{flex-direction:column;align-items:flex-start;gap:12px}.report-actions{flex-wrap:wrap;justify-content:flex-start;width:100%;margin-left:0}.row-actions{grid-template-columns:repeat(2,max-content);justify-content:flex-start;gap:6px;width:100%}.row-actions .btn,.row-actions .icon-btn--danger{width:auto;height:30px;font-size:.7rem}.pill{background:#f1f5f9;border-radius:4px;padding:6px 10px;font-size:.78rem}.admin-grid{gap:26px}.dashboard-grid{margin-top:18px}}@media (max-width:1024px){.admin-app{grid-template-columns:1fr;padding:16px}.admin-sidebar{border-radius:16px;padding:16px;position:relative;top:0}.card{grid-column:span 12}}@media (max-width:768px){.gradient-bg{background:radial-gradient(circle at 16% 10%,#2563eb47,#0000 45%),radial-gradient(circle at 86% 0,#3b82f638,#0000 40%),linear-gradient(160deg,#0b1220 0%,#0f172a 55%,#0b1020 100%)!important}.admin-app{box-shadow:none;border:none;border-radius:0;flex-direction:column;gap:0;padding:0;display:flex;background:radial-gradient(circle at 16% 10%,#2563eb47,#0000 45%),radial-gradient(circle at 86% 0,#3b82f638,#0000 40%),linear-gradient(160deg,#0b1220 0%,#0f172a 55%,#0b1020 100%)!important}.admin-main{order:1;padding:0}.admin-sidebar{border-radius:0;order:2;gap:16px;height:auto;padding:12px}.absensi-shell{max-width:100%;margin:0;padding:24px 12px}.absensi-hero,.card{box-shadow:var(--shadow-soft);border-radius:16px;margin:0}.mobile-topbar{border-radius:0;display:flex}.admin-sidebar{z-index:50;border-radius:0 16px 16px 0;width:min(82vw,320px);height:100vh;transition:transform .25s;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-110%)}.admin-sidebar.is-open{transform:translate(0)}.sidebar-overlay{z-index:40;background:#0f172a73;display:block;position:fixed;inset:0}.admin-sidebar .nav{grid-template-columns:1fr;gap:8px;padding-bottom:0;display:grid;overflow:visible}.nav__item{white-space:nowrap;width:100%}.sidebar__footer{grid-template-columns:1fr}.row-actions{grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch}.row-actions .btn,.row-actions .icon-btn--danger{justify-content:center;width:100%}.row-actions .icon-btn--danger{height:36px}.card__head .btn{border-radius:10px;padding:8px 12px;font-size:.78rem}.card__head{flex-direction:column;align-items:flex-start;gap:6px}.siswa-head{align-items:stretch}.siswa-head__title{order:1}.siswa-head__title p{margin:0 0 2px}.siswa-segmented{margin-top:0;order:3!important}.siswa-toolbar{flex-direction:column;align-items:flex-start;gap:10px;width:100%;margin-top:2px;order:2!important}.siswa-toolbar .siswa-segmented{width:100%;margin-top:4px;padding-bottom:4px}.siswa-segmented{scrollbar-width:none;z-index:1;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:8px;width:100%;min-height:32px;margin-top:8px;padding-bottom:2px;position:relative;overflow-x:auto;visibility:visible!important;opacity:1!important;display:flex!important}.siswa-segmented::-webkit-scrollbar{display:none}.card__head>.segmented,.card__head>.siswa-segmented{margin-top:0}.siswa-toolbar .btn--primary{justify-content:center;width:100%}.siswa-toolbar .field{width:100%}.siswa-toolbar .field .input{width:100%;min-width:0}.siswa-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;display:grid}.siswa-actions .btn{justify-content:center;width:100%;padding:8px 10px;font-size:.72rem}.pagination{flex-direction:column;align-items:flex-start}.card__head .segmented{justify-content:flex-start;width:100%}.card{margin-bottom:0}.table td[data-label=Kelas]{color:#000;font-size:.9rem;font-weight:800}}.glass-card{border:1px solid var(--card-border);box-shadow:var(--shadow-soft);background:linear-gradient(#fffffffa,#fff);border-radius:20px;transition:transform .25s,box-shadow .25s,border-color .25s}.glass-card:hover{box-shadow:var(--shadow-strong);border-color:#2563eb59;transform:translateY(-4px)}.gradient-bg{background:radial-gradient(circle at 16% 10%,#2563eb59,#0000 45%),radial-gradient(circle at 86% 0,#3b82f647,#0000 40%),linear-gradient(160deg,#0b1220 0%,#0f172a 55%,#0b1020 100%);position:relative;overflow:hidden}.gradient-bg:before{content:none}.fade-in{animation:.7s cubic-bezier(.16,1,.3,1) fadeIn}.luxury-button{transition:transform .2s,box-shadow .2s,filter .2s;position:relative}.luxury-button:hover{transform:translateY(-2px)scale(1.01);box-shadow:0 18px 34px #0f172a33}.luxury-button:active{transform:translateY(0)scale(.99)}.admin-cta{border-radius:14px;align-self:flex-start;min-width:180px;padding:10px 18px;font-weight:700}@media (min-width:768px){.admin-cta{align-self:center;min-width:220px;padding:12px 22px}}.stat-card{border:1px solid var(--card-border);background:linear-gradient(#fffffffa,#fff);transition:transform .25s,box-shadow .25s,border-color .25s}.stat-card:hover{border-color:#2563eb59;transform:translateY(-4px);box-shadow:0 18px 36px #0f172a1f}.rank-badge{background:#f1f5f9;border:2px solid #e2e8f0}.premium-shadow{box-shadow:var(--shadow-soft)}.leaderboard-card{background:#fff;border:2px solid #2563ebbf;border-radius:18px;padding:18px 22px;box-shadow:0 12px 24px #0f172a14}.leaderboard-row{align-items:center;gap:18px;display:flex}.leaderboard-rank{flex:none}.leaderboard-medal{color:#1f2937;background:#fff;border:3px solid #e2e8f0;border-radius:50%;place-items:center;width:52px;height:52px;font-weight:800;display:grid;position:relative;box-shadow:0 10px 18px #0f172a1f}.leaderboard-medal:before,.leaderboard-medal:after{content:"";background:#3b82f6;border-radius:6px 6px 12px 12px;width:16px;height:18px;position:absolute;top:-12px;box-shadow:0 2px 6px #2563eb59}.leaderboard-medal:before{left:6px;transform:rotate(-14deg)}.leaderboard-medal:after{right:6px;transform:rotate(14deg)}.leaderboard-medal[data-rank="1"]{color:#7c2d12;background:radial-gradient(circle at 35% 30%,#ffe9a6 0%,#f2b80f 70%);border-color:#e0a000}.leaderboard-medal[data-rank="2"]{color:#334155;background:radial-gradient(circle at 35% 30%,#f2f4f7 0%,#b4bcc6 70%);border-color:#9aa3ad}.leaderboard-medal[data-rank="3"]{color:#7c2d12;background:radial-gradient(circle at 35% 30%,#ffddb8 0%,#c8823a 70%);border-color:#b5702f}.leaderboard-info{flex:auto;gap:10px;display:grid}.leaderboard-name{font-weight:700}.leaderboard-tags{flex-wrap:wrap;gap:10px;display:flex}.leaderboard-tag{border-radius:10px;align-items:center;gap:6px;padding:6px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.leaderboard-tag--kelas{color:#1d4ed8;background:#3b82f61a;border:1px solid #3b82f633}.leaderboard-tag--hadir{color:#15803d;background:#22c55e1f;border:1px solid #22c55e40}.leaderboard-score{color:#fff;border-radius:14px;flex:none;justify-content:center;align-items:center;gap:8px;min-width:110px;height:54px;font-weight:800;display:inline-flex;box-shadow:0 12px 22px #2563eb59}.leaderboard-score__value{font-size:1.05rem}.leaderboard-score__icon{font-size:1.1rem}@media (max-width:768px){.leaderboard-card{padding:16px 18px}.leaderboard-row{flex-direction:column;align-items:flex-start}.leaderboard-score{align-self:flex-end}.pagination{gap:12px}.pagination__controls{justify-content:space-between;width:100%}.pagination__page{order:-1}.pagination__size{justify-content:flex-start;width:100%}.pagination__select{min-width:120px}.segmented{gap:6px}.segmented__btn{color:#0f172a;background:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;min-width:0;height:26px;padding:4px 10px;font-size:.68rem;line-height:1.1;display:inline-flex;box-shadow:0 6px 12px #0f172a14}.segmented__btn.is-active{color:#fff;background:#0f172a;border-color:#0f172ae6}.pagination__info{color:#0f172a;font-weight:600}}.animated-border{border:2px solid #2563ebb3;animation:2.5s ease-in-out infinite borderPulse;box-shadow:0 8px 24px #2563eb33}.modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#000c;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-card{gap:22px;width:min(680px,94vw);padding:28px;display:grid}.modal-card .card__title{font-size:1.25rem}.modal-card .card__desc{color:var(--admin-muted);font-size:.95rem}.modal-card .input{padding:12px 14px;font-size:.95rem}.modal-card .btn{padding:10px 18px;font-size:.95rem}.fab-add{background:var(--admin-primary);color:#fff;z-index:60;border:none;border-radius:999px;place-items:center;width:54px;height:54px;font-size:28px;font-weight:700;transition:transform .2s,box-shadow .2s;display:grid;position:fixed;bottom:24px;right:24px;box-shadow:0 16px 34px #2563eb59}.fab-add:hover{transform:translateY(-2px);box-shadow:0 20px 40px #2563eb73}.fab-add:active{transform:translateY(0)}@media (max-width:768px){.fab-add{border-radius:16px;width:50px;height:50px;bottom:16px;right:16px}}.scanner-frame{aspect-ratio:4/3;background:radial-gradient(circle at 30% 20%,#38bdf833,#0000 55%),linear-gradient(160deg,#0f172a 0%,#111827 100%);border:3px solid #10b981;border-radius:20px;width:min(88vw,380px);max-width:380px;position:relative;overflow:hidden;box-shadow:0 0 30px #10b98180}.scanner-frame video{background:#0f172a;width:100%;height:100%;display:block}.scan-line{background:linear-gradient(90deg,#0000,#10b981,#0000);width:100%;height:3px;animation:2s linear infinite scan;position:absolute;box-shadow:0 0 10px #10b981}.corner-tl,.corner-tr,.corner-bl,.corner-br{border:4px solid #10b981;width:40px;height:40px;position:absolute}.corner-tl{border-bottom:none;border-right:none;top:10px;left:10px}.corner-tr{border-bottom:none;border-left:none;top:10px;right:10px}.corner-bl{border-top:none;border-right:none;bottom:10px;left:10px}.corner-br{border-top:none;border-left:none;bottom:10px;right:10px}@keyframes fadeIn{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes scan{0%{top:0%}to{top:100%}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes borderPulse{0%,to{box-shadow:0 8px 24px #2563eb33}50%{box-shadow:0 16px 40px #2563eb59}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
