@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;--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-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{.fixed{position:fixed}.relative{position:relative}.z-10{z-index:10}.mx-4{margin-inline:calc(var(--spacing)*4)}.mx-auto{margin-inline:auto}.mt-3{margin-top:calc(var(--spacing)*3)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.flex{display:flex}.grid{display:grid}.table{display:table}.h-3{height:calc(var(--spacing)*3)}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-3{width:calc(var(--spacing)*3)}.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)}.table-auto{table-layout:auto}.border-collapse{border-collapse:collapse}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.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}.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-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-8{padding-inline:calc(var(--spacing)*8)}.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)}.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)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.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,)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.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))}}@media (min-width:48rem){.md\:mb-6{margin-bottom:calc(var(--spacing)*6)}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:p-6{padding:calc(var(--spacing)*6)}.md\:p-8{padding:calc(var(--spacing)*8)}}}: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%,#94c5ff1f,#0000 45%),radial-gradient(circle at 88% 0,#a3cdff1f,#0000 40%),linear-gradient(160deg,#3f5f8f 0%,#3b6dbb 55%,#385b8e 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 20px 46px #02061747}@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}.pelanggaran-hero{place-items:center;margin-bottom:22px;display:grid}.pelanggaran-accordion__title{color:#0f172a;font-size:.95rem;font-weight:800}.pelanggaran-accordion__desc{color:#64748b;font-size:.72rem}.pelanggaran-toggle{background:#fff;border:1px solid #94a3b840;border-radius:18px;justify-content:space-between;align-items:center;gap:12px;width:min(560px,92vw);margin-bottom:12px;padding:14px 16px;display:flex;box-shadow:0 16px 32px #0f172a1f}.pelanggaran-card{background:linear-gradient(#fff 0%,#f1f5ff 100%);border:1px solid #94a3b838;border-radius:22px;width:min(560px,92vw);padding:18px;box-shadow:0 20px 40px #0f172a29}.pelanggaran-card__head{justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px;display:flex}.pelanggaran-card__title{color:#0f172a;margin-bottom:4px;font-size:1.05rem;font-weight:800}.pelanggaran-card__desc{color:#64748b;font-size:.75rem}.pelanggaran-card__badge{color:#dc2626;text-transform:uppercase;background:#ef44441f;border-radius:999px;padding:4px 10px;font-size:.62rem;font-weight:700}.pelanggaran-alert{color:#991b1b;background:#ef44441f;border:1px solid #ef444440;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;padding:10px 12px;font-size:.75rem;font-weight:600;display:flex}.pelanggaran-alert__btn{color:#fff;background:#ef4444;border:none;border-radius:999px;padding:6px 10px;font-size:.7rem;font-weight:700}.pelanggaran-form{gap:12px;display:grid}.pelanggaran-scan{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 14px;font-size:.78rem;font-weight:700;display:inline-flex;box-shadow:0 12px 22px #2563eb47}.pelanggaran-scan__icon{background:#fff3;border-radius:8px;place-items:center;width:20px;height:20px;font-size:.72rem;font-weight:800;display:grid}.pelanggaran-field{gap:6px;display:grid}.pelanggaran-label{color:#1f2937;font-size:.72rem;font-weight:700}.pelanggaran-input{color:#0f172a;background:#f8fafc;border:1px solid #94a3b84d;border-radius:12px;width:100%;padding:10px 36px;font-weight:600}.pelanggaran-input-wrap{align-items:center;display:flex;position:relative}.pelanggaran-input__icon{opacity:.7;font-size:.9rem;position:absolute;left:10px}.pelanggaran-input__caret{color:#94a3b8;font-size:.72rem;position:absolute;right:10px}.pelanggaran-submit{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:999px;padding:10px 14px;font-size:.78rem;font-weight:700;box-shadow:0 12px 22px #ef444447}.pelanggaran-card+.card{border-radius:20px;box-shadow:0 18px 36px #0f172a1f}.pelanggaran-list-card{background:linear-gradient(#f8fafc,#eef2ff);border:1px solid #94a3b840;border-radius:18px;box-shadow:0 18px 36px #0f172a29}.pelanggaran-list-head{align-items:center}.pelanggaran-list{gap:10px;display:grid}.pelanggaran-item{background:#fff;border:1px solid #94a3b833;border-radius:14px;justify-content:space-between;align-items:center;padding:12px 14px;display:flex;box-shadow:0 8px 16px #0f172a0f}.pelanggaran-item__title{color:#1f2937;margin-bottom:2px;font-size:.9rem;font-weight:700}.pelanggaran-item__meta{color:#94a3b8;font-size:.7rem;font-weight:600}.pelanggaran-item__actions{align-items:center;gap:8px;display:flex}.pelanggaran-item__chip{color:#ef4444;background:#fee2e2;border-radius:999px;padding:4px 10px;font-size:.7rem;font-weight:800}.pelanggaran-item__trash{color:#ef4444;background:#fee2e2;border:1px solid #ef444433;border-radius:999px;place-items:center;width:30px;height:30px;font-size:.8rem;display:grid}.pelanggaran-item__trash.is-confirm{color:#fff;background:#ef4444}.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}.mobile-dock,.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-panel{background:linear-gradient(135deg,#2563eb2e,#3b82f614);border-radius:20px;padding:14px;box-shadow:0 18px 36px #0f172a2e}.siswa-card--compact.card{background:#fff;border:1px solid #94a3b840;border-radius:18px}.siswa-card--compact .card__head{background:#f8fafc;border-bottom:1px solid #94a3b833;border-top-left-radius:24px;border-top-right-radius:24px;gap:12px 16px;padding:16px 20px 12px}.siswa-toolbar .btn--primary{border-radius:12px;height:36px;padding:0 14px;box-shadow:0 10px 18px #2563eb33}.siswa-toolbar .input{border-radius:999px;height:36px}.siswa-actions .btn{min-height:34px}.siswa-actions .btn--ghost{border-radius:10px;padding:6px 12px;font-size:.72rem}.siswa-filters{border-top:1px dashed #94a3b859;align-items:center;gap:12px;width:100%;padding:10px 0 0;display:flex}.siswa-filters__label{color:#0f172a;font-size:.78rem;font-weight:700}.siswa-filters__chips{flex-wrap:wrap;gap:8px;display:flex}.siswa-card--compact .segmented__btn{color:#1e3a8a;box-shadow:none;background:#eef2ff;border:1px solid #3b82f633;border-radius:999px;padding:6px 12px;font-size:.72rem;font-weight:700}.siswa-card--compact .segmented__btn.is-active{color:#fff;background:#2563eb;border-color:#2563eb80}.siswa-card--compact .table thead th{color:#64748b;letter-spacing:.03em;text-transform:uppercase;background:#f8fafc;font-size:.7rem}.siswa-card--compact .table tbody tr{background:#fff}.siswa-card--compact .table--cards tr{border-radius:16px;box-shadow:0 8px 16px #0f172a0f}.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}.bank-header{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;padding:4px 2px;display:flex}.bank-title{color:#fff;font-size:1.4rem;font-weight:800}.bank-subtitle{color:#fffffff2;flex-wrap:wrap;align-items:center;gap:8px;font-size:.78rem;font-weight:600;display:flex}.bank-date{color:#fff;background:#ffffff26;border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:700}.bank-time{color:#fff;letter-spacing:.06em;background:#ffffff2e;border-radius:999px;padding:4px 10px;font-size:.7rem;font-weight:700}.bank-refresh{color:#0f172a;background:#fff;border:1px solid #94a3b880;border-radius:999px;min-width:140px;padding:10px 18px;font-weight:700;transition:transform .2s,box-shadow .2s;box-shadow:0 10px 18px #0f172a0f}.bank-refresh:hover{transform:translateY(-2px);box-shadow:0 16px 26px #0f172a1f}.bank-wallet{color:#fff;background:linear-gradient(160deg,#3d7fdb 0%,#2c66c9 60%,#2456b2 100%);border-radius:22px;gap:16px;margin-bottom:18px;padding:18px;display:grid;box-shadow:0 14px 26px #1e40af38}.bank-wallet__label{opacity:.85;font-size:.78rem;font-weight:600}.bank-wallet__value{letter-spacing:.4px;font-size:2.2rem;font-weight:800}.bank-wallet__meta{background:#ffffff29;border-radius:16px;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:12px;display:grid}.bank-wallet__meta-label{text-transform:uppercase;letter-spacing:.08em;opacity:.85;font-size:.62rem;font-weight:700}.bank-wallet__meta-value{font-size:1rem;font-weight:800}.bank-chips{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:18px;display:grid}.bank-chip{text-align:left;background:#fff;border:1px solid #94a3b840;border-radius:16px;gap:6px;padding:12px 14px;display:grid;box-shadow:0 10px 18px #0f172a0f}.bank-chip span{color:#64748b;font-size:.72rem;font-weight:600}.bank-chip strong{color:#0f172a;font-size:1.3rem;font-weight:800}.bank-promo{color:#fff;background:linear-gradient(135deg,#25408f 0%,#2b57c9 55%,#2c66d4 100%);border:1px solid #bfdbfe4d;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;padding:14px 16px;display:flex;box-shadow:0 10px 20px #1e40af38}.bank-promo__title{color:#fff;font-size:.95rem;font-weight:800}.bank-promo__desc{color:#ffffffc7;font-size:.75rem}.bank-promo__badge{color:#fff;text-transform:uppercase;letter-spacing:.06em;background:#fff3;border:1px solid #ffffff59;border-radius:999px;padding:6px 12px;font-size:.65rem;font-weight:700}.bank-actions{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:20px;display:grid}.bank-action{color:#0f172a;background:#fff;border:1px solid #94a3b838;border-radius:16px;place-items:center;gap:6px;padding:12px 8px;font-size:.68rem;font-weight:700;text-decoration:none;transition:transform .2s,box-shadow .2s;display:grid;box-shadow:0 10px 18px #0f172a0f}.bank-action:hover{transform:translateY(-2px);box-shadow:0 18px 32px #0f172a1f}.bank-action__icon{background:#3b82f61f;border-radius:12px;place-items:center;width:38px;height:38px;font-size:1.05rem;display:grid}.bank-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:18px;display:grid}.bank-card{grid-column:span 6}.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-title{color:#0f172a;font-size:2rem}.dashboard-subtitle{color:#0f172a;font-size:.9rem}.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:10px;display:flex}.pagination__page{color:#0f172a;font-weight:700}.pagination__btn{color:#0f172a;background:#fff;border:2px solid #94a3b880;border-radius:12px;min-width:52px;padding:8px 14px;font-weight:700;box-shadow:0 6px 14px #0f172a14}.pagination__btn:disabled{opacity:.5;cursor:not-allowed}.pagination__btn--active{color:#1d4ed8;background:#e0f2fe;border-color:#2563eb73}.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}@media (max-width:640px){.pagination{flex-direction:column;align-items:stretch;gap:10px}.pagination__info{color:#475569;font-size:.85rem}.pagination__controls{justify-content:space-between;gap:8px}.pagination__btn{min-width:0;padding:6px 10px;font-size:.72rem}.pagination__page{text-align:center;min-width:72px}.pagination__size{justify-content:space-between;width:100%}.pagination__select{min-width:110px}}.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-search-results{border:1px solid var(--admin-border);color:#0f172a;opacity:1;background:#f8fafc;border-radius:12px;gap:8px;max-height:280px;margin-top:10px;padding:10px;display:grid;overflow:auto}.qr-search-item{text-align:left;color:#0f172a;opacity:1;cursor:pointer;background:#fff;border:1px solid #0000;border-radius:10px;gap:4px;padding:10px 12px;transition:border-color .2s,box-shadow .2s,transform .2s;display:grid}.qr-search-item:hover{border-color:#3b82f666;transform:translateY(-1px);box-shadow:0 8px 20px #0f172a14}.qr-search-item.is-active{border-color:#10b98180;box-shadow:0 12px 24px #10b9811f}.qr-search-name{color:#0f172a;opacity:1;font-weight:700}.qr-search-meta{color:#334155;opacity:.9;font-size:.8rem;font-weight:600}.qr-search-empty{color:var(--admin-muted);font-size:.85rem}.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}}@media (min-width:1024px){.qr-toolbar{grid-template-columns:minmax(320px,1.4fr) minmax(220px,.6fr);align-items:start}.qr-field{max-width:none}.qr-actions{text-align:right;justify-items:end}}.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{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}.dashboard-card--metric{border-radius:16px;grid-column:span 1;padding:14px}.dashboard-card--metric .card__head{gap:6px}.dashboard-card--metric .card__title{font-size:.78rem}.dashboard-card--metric .card__desc{color:#475569;font-size:.68rem}.dashboard-metric{font-size:1.6rem}.dashboard-card--wide{grid-column:span 2}.dashboard-card--wide .card__title{font-size:.95rem}.dashboard-card--wide .card__desc{color:#475569;font-size:.78rem}.dashboard-hero{padding:16px}.dashboard-title{font-size:1.4rem}.dashboard-subtitle{font-size:.78rem}.dashboard-hero__actions .btn{justify-content:center;width:100%}.combo-chart{gap:6px;height:140px}.sparkline{height:64px}.chart{height:150px}.bank-header{flex-direction:column;align-items:flex-start;gap:10px}.bank-refresh{text-align:center;justify-content:center;width:100%}.bank-wallet{padding:16px}.bank-wallet__value{font-size:2rem}.bank-wallet__meta{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.bank-wallet__meta-value{font-size:.95rem}.bank-chips{grid-template-columns:repeat(2,minmax(0,1fr))}.bank-actions{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.bank-action{padding:10px 6px;font-size:.64rem}.bank-action__icon{width:34px;height:34px}.bank-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.bank-card{grid-column:span 2}}@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}.bank-actions{grid-template-columns:repeat(4,minmax(0,1fr))}.bank-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{display:none}.admin-main{padding-bottom:calc(86px + env(safe-area-inset-bottom))}.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}.mobile-dock{width:min(94vw,520px);padding:6px 12px calc(6px + env(safe-area-inset-bottom));z-index:55;background:#f2f4f7;border:1px solid #94a3b833;border-radius:18px;grid-template-columns:repeat(5,minmax(0,1fr));align-items:center;gap:4px;display:grid;position:fixed;bottom:8px;left:50%;transform:translate(-50%);box-shadow:0 12px 24px #0f172a1f}.mobile-dock__item{color:#9aa3ad;letter-spacing:.02em;border-radius:12px;place-items:center;gap:4px;padding:6px 4px;font-size:.52rem;font-weight:700;text-decoration:none;transition:color .2s,transform .2s;display:grid}.mobile-dock__icon{background:0 0;border-radius:8px;place-items:center;width:24px;height:24px;display:grid}.mobile-dock__icon svg{color:currentColor;width:17px;height:17px}.mobile-dock__item.is-active{color:#1d4ed8}.mobile-dock__fab{color:#fff;background:#1d4ed8;border:5px solid #f2f4f7;border-radius:999px;place-items:center;width:56px;height:56px;margin-top:-24px;text-decoration:none;display:grid;box-shadow:0 10px 22px #1d4ed866}.mobile-dock__fab-icon svg{color:#fff;width:23px;height:23px}.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-page{gap:18px;display:grid}.leaderboard-header{background:#fff;border:1px solid #94a3b840;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex;box-shadow:0 16px 34px #0f172a14}.leaderboard-header__title{align-items:center;gap:14px;display:flex}.leaderboard-header__icon{background:linear-gradient(135deg,#fde68a,#fbbf24);border-radius:12px;place-items:center;width:40px;height:40px;font-size:1.1rem;display:grid;box-shadow:0 8px 14px #f59e0b47}.leaderboard-header__heading{color:#0f172a;margin:0 0 4px;font-size:1.25rem;font-weight:800}.leaderboard-header__sub{color:#64748b;font-size:.78rem;font-weight:600}.leaderboard-header__action{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:10px;align-items:center;gap:8px;padding:8px 16px;font-weight:700;text-decoration:none;display:inline-flex;box-shadow:0 10px 20px #2563eb4d}.leaderboard-filter{background:#f1f5f9;border:1px solid #94a3b82e;border-radius:18px;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;display:flex;box-shadow:inset 0 1px #ffffffb3}.leaderboard-filter__label{color:#0f172a;font-size:.75rem;font-weight:700}.leaderboard-filter__chips{flex-wrap:wrap;gap:10px;display:flex}.leaderboard-filter__btn{color:#475569;background:#fff;border:1px solid #94a3b833;border-radius:999px;padding:6px 12px;font-size:.7rem;font-weight:700;transition:all .2s}.leaderboard-filter__btn.is-active{color:#fff;background:#2563eb;border-color:#2563eb66;box-shadow:0 8px 16px #2563eb40}.leaderboard-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.leaderboard-summary{grid-template-columns:minmax(0,1.1fr) minmax(0,.8fr);align-items:stretch;gap:16px;display:grid}.leaderboard-top3{border-radius:16px;gap:12px;padding:16px;display:grid}.leaderboard-top3__title{color:#0f172a;font-size:.9rem;font-weight:800}.leaderboard-top3__avatars{gap:8px;display:flex}.leaderboard-top3__avatar{color:#fff;border-radius:50%;place-items:center;width:36px;height:36px;font-weight:800;display:grid}.leaderboard-top3__avatar.avatar-1{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.leaderboard-top3__avatar.avatar-2{color:#1f2937;background:linear-gradient(135deg,#cbd5f5,#94a3b8)}.leaderboard-top3__avatar.avatar-3{background:linear-gradient(135deg,#fdba74,#fb923c)}.leaderboard-top3__list{gap:8px;display:grid}.leaderboard-top3__row{color:#1f2937;grid-template-columns:18px 1fr auto;align-items:center;gap:8px;font-size:.78rem;font-weight:600;display:grid}.leaderboard-top3__rank{color:#1d4ed8;font-weight:800}.leaderboard-top3__score{color:#2563eb;font-weight:800}.leaderboard-table{border-radius:18px;gap:6px;padding:12px 16px;display:grid}.leaderboard-table__head{color:#94a3b8;grid-template-columns:80px 1.4fr .6fr .4fr;gap:8px;padding:6px 10px;font-size:.7rem;font-weight:700;display:grid}.leaderboard-table__row{border-radius:12px;grid-template-columns:80px 1.4fr .6fr .4fr;align-items:center;gap:8px;padding:10px;transition:background .2s;display:grid}.leaderboard-table__row:hover{background:#2563eb14}.leaderboard-table__row.is-top{background:#fef3c7cc}.leaderboard-table__cell{color:#0f172a;font-size:.82rem}.leaderboard-table__rank{color:#1f2937;background:#e2e8f0;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-weight:800;display:inline-flex}.leaderboard-table__rank.is-gold{color:#7c2d12;background:linear-gradient(135deg,#fcd34d,#f59e0b)}.leaderboard-table__rank.is-silver{color:#1f2937;background:linear-gradient(135deg,#e2e8f0,#94a3b8)}.leaderboard-table__rank.is-bronze{color:#7c2d12;background:linear-gradient(135deg,#fdba74,#fb923c)}.leaderboard-table__name{color:#0f172a;font-weight:700}.leaderboard-table__pill{color:#1d4ed8;background:#e0e7ff;border-radius:999px;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-flex}.leaderboard-table__score{color:#fff;background:#2563eb;border-radius:999px;justify-content:center;align-items:center;padding:6px 12px;font-size:.82rem;font-weight:800;display:inline-flex}.leaderboard-table__empty{text-align:center;color:#94a3b8;padding:18px;font-weight:600}.leaderboard-stat{background:#fff;border:1px solid #94a3b833;border-radius:16px;justify-content:space-between;align-items:center;padding:16px 18px;display:flex;box-shadow:0 12px 24px #0f172a0f}.leaderboard-stat__label{color:#64748b;margin-bottom:6px;font-size:.78rem;font-weight:700}.leaderboard-stat__value{color:#2563eb;font-size:1.6rem;font-weight:800}.leaderboard-stat__icon{opacity:.3;font-size:1.6rem}.leaderboard-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.leaderboard-card{background:#fff;border:1px solid #94a3b833;border-radius:18px;padding:16px 18px}.leaderboard-card--podium{box-shadow:0 14px 28px #0f172a14}.leaderboard-see-all{color:#fff;background:#2563eb;border:none;border-radius:999px;justify-content:center;align-items:center;margin:6px auto 0;padding:10px 18px;font-weight:700;display:inline-flex;box-shadow:0 10px 20px #2563eb40}.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}.leaderboard-header{flex-direction:column;align-items:flex-start}.leaderboard-grid,.leaderboard-stats,.leaderboard-summary{grid-template-columns:1fr}.leaderboard-table__head,.leaderboard-table__row{grid-template-columns:60px 1fr .6fr .5fr}.pagination{gap:12px}.pagination__controls{flex-wrap:wrap;justify-content:flex-end;width:100%}.pagination__page{order:-1}.pagination__size{justify-content:flex-end;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}.notif-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#070a128c}.notif-modal{text-align:center;background:linear-gradient(#fff,#f1f5ff);border:1px solid #94a3b840;border-radius:18px;gap:12px;width:min(88vw,360px);padding:18px 20px 20px;animation:.25s notifPop;display:grid;box-shadow:0 20px 44px #0f172a59}.notif-icon{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:14px;place-items:center;width:52px;height:52px;margin:0 auto;font-size:1.4rem;font-weight:900;display:grid;box-shadow:0 12px 22px #22c55e59}.notif-text{color:#0f172a;font-size:.95rem;font-weight:700;line-height:1.4}.notif-name{font-size:1rem;font-weight:800}.notif-kelas{color:#64748b;font-size:.78rem;font-weight:700}.notif-message{color:#1f2937;margin-top:6px;font-size:.88rem;font-weight:600}.scan-overlay{background:#060a14e0;justify-content:stretch;align-items:stretch;padding:0}.scan-screen{color:#e2e8f0;background:radial-gradient(circle at 20% 10%,#3b82f640,#0000 45%),linear-gradient(165deg,#080c16fa,#05070efa);grid-template-rows:auto 1fr auto;width:100%;height:100%;padding:24px 18px 28px;display:grid;position:relative;overflow:hidden}.scan-header{grid-template-columns:44px 1fr 44px;align-items:center;gap:10px;margin-bottom:20px;display:grid}.scan-icon{color:#fff;background:#0f172a99;border:1px solid #fff3;border-radius:14px;place-items:center;width:40px;height:40px;font-size:1.1rem;display:grid}.scan-header__text{text-align:center}.scan-title{letter-spacing:.1em;font-size:.95rem;font-weight:800}.scan-subtitle{color:#e2e8f0b3;font-size:.78rem}.scan-view{place-items:center;padding-bottom:140px;display:grid}.scan-frame{aspect-ratio:1/1.02;background:#0b1220;border:1px solid #ffffff1f;border-radius:18px;width:min(70vw,280px);position:relative;overflow:hidden;box-shadow:0 14px 24px #0f172a59}.scan-frame video{object-fit:cover;width:100%;height:100%;display:block}.scan-line{background:linear-gradient(90deg,#0000,#34d399,#0000);width:100%;height:3px;animation:2s linear infinite scan;position:absolute;left:0;box-shadow:0 0 10px #34d399e6}.scan-corner{border:3px solid #fff;width:30px;height:30px;position:absolute}.scan-corner--tl{border-bottom:none;border-right:none;top:12px;left:12px}.scan-corner--tr{border-bottom:none;border-left:none;top:12px;right:12px}.scan-corner--bl{border-top:none;border-right:none;bottom:12px;left:12px}.scan-corner--br{border-top:none;border-left:none;bottom:12px;right:12px}.scan-stripes{opacity:.25;pointer-events:none;background:repeating-linear-gradient(90deg,#ffffff1f 0 2px,#fff0 2px 6px);width:55%;height:100%;position:absolute;top:0;right:-12px;transform:skew(-14deg)}.scan-bottom{color:#0f172a;background:#fff;border-top-left-radius:22px;border-top-right-radius:22px;padding:12px 14px 18px;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -12px 28px #0f172a33}.scan-bottom__bar{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:12px;margin-bottom:10px;padding:10px 12px;font-size:.78rem;font-weight:700}.scan-tabs{background:#f1f5f9;border-radius:12px;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:6px;display:grid}.scan-tab{color:#0f172a;background:#fff;border:1px solid #0f172a26;border-radius:10px;padding:10px 12px;font-size:.78rem;font-weight:700}.scan-tab.is-active{color:#1d4ed8;background:#fff;border-color:#2563eb80;box-shadow:0 6px 12px #2563eb2e}@media (min-width:768px){.scan-screen{padding:32px 28px 36px}}.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}.rekap-modal{width:min(92vw,320px)}.modal-overlay .rekap-card{background:linear-gradient(#3b82f6 0%,#2563eb 100%);border-radius:20px;padding:12px;box-shadow:0 18px 40px #0f172a59}.rekap-head{color:#fff;background:linear-gradient(#fff3,#ffffff14);border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.rekap-head__left{align-items:center;gap:10px;display:flex}.rekap-head__icon{background:#fff3;border-radius:12px;place-items:center;width:34px;height:34px;display:grid}.rekap-head__title{letter-spacing:.08em;font-size:.72rem;font-weight:800}.rekap-head__subtitle{opacity:.9;font-size:.7rem}.rekap-close{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:10px;width:28px;height:28px;font-size:1.1rem;font-weight:700}.rekap-body{background:#fff;border-radius:16px;gap:12px;margin-top:10px;padding:14px;display:grid}.rekap-name{text-align:center;color:#1d4ed8;font-size:1rem;font-weight:800}.rekap-badges{justify-content:center;gap:8px;display:flex}.rekap-badge{border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:.7rem;font-weight:700;display:inline-flex}.rekap-badge--gold{color:#7c2d12;background:#fde68a}.rekap-badge--green{color:#15803d;background:#dcfce7}.rekap-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.rekap-stat{background:#f8fafc;border:1px solid #94a3b833;border-radius:12px;gap:4px;padding:8px 10px;display:grid}.rekap-stat span{color:#64748b;font-size:.7rem;font-weight:700}.rekap-stat strong{color:#2563eb;font-size:1rem}.rekap-stat--wide{grid-column:span 2}.rekap-stat .is-danger{color:#ef4444}.rekap-back{color:#fff;background:#2563eb;border:none;border-radius:999px;width:100%;padding:8px 12px;font-size:.8rem;font-weight:700}.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}}@keyframes notifPop{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@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}
