@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700&family=Poppins:wght@600;800&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.fixed{position:fixed}.table{display:table}.grid{display:grid}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.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)}@keyframes floatUp{0%{opacity:1;transform:translateY(0) scale(1)}60%{opacity:.9;transform:translateY(-40px) scale(1.1)}to{opacity:0;transform:translateY(-80px) scale(.9)}}@keyframes piggyBounce{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.04) rotate(-1deg)}75%{transform:scale(1.04) rotate(1deg)}}@keyframes coinSpin{0%{transform:rotateY(0) scale(1.1)}to{transform:rotateY(360deg) scale(1)}}@keyframes headerShimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes totalPop{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100svw;height:100svh;overflow:hidden;font-family:Inter,system-ui,sans-serif}.app-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% 30%,#fff8ee,#fff0dc 40%,#ffe8cc);overflow:hidden;position:relative}.app-header{flex:0 0 auto;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(245,158,11,.15);box-shadow:0 2px 20px #00000012;z-index:10}.header-content{max-width:100%;padding:0 2rem;height:68px;display:flex;align-items:center;justify-content:space-between}.header-right{display:flex;align-items:center;gap:1rem}.app-title{font-family:Poppins,sans-serif;font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,#d97706,#f59e0b,#fbbf24);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:headerShimmer 4s linear infinite;letter-spacing:-.02em}.total-display{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.total-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af}.total-amount{font-family:Poppins,sans-serif;font-size:1.7rem;font-weight:800;color:#1f2937;letter-spacing:-.03em;transition:all .3s ease}.app-main{flex:1 1 0;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.piggy-drop-zone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;width:min(520px,90vw);height:min(400px,70vh);cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none}.piggy-drop-zone--active{cursor:copy}.piggy-image-wrapper{position:relative;z-index:2;width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;filter:drop-shadow(0 0 0px transparent)}.piggy-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center bottom;object-position:center bottom;transition:transform .25s cubic-bezier(.34,1.56,.64,1),filter .25s ease;filter:drop-shadow(0 12px 30px rgba(255,150,130,.35));pointer-events:none}.piggy-image--hover{transform:scale(1.035);filter:drop-shadow(0 18px 40px rgba(255,150,130,.55)) brightness(1.05)}.piggy-image--dropped{animation:piggyBounce .5s ease}.piggy-total{position:absolute;bottom:22%;left:50%;transform:translate(-50%);font-family:Poppins,sans-serif;font-size:clamp(1rem,2.5vw,1.5rem);font-weight:800;color:#fffffff2;text-shadow:0 2px 8px rgba(180,60,40,.5),0 1px 3px rgba(0,0,0,.3);white-space:nowrap;pointer-events:none;transition:transform .2s ease;letter-spacing:-.02em}.piggy-total--pop{animation:totalPop .35s cubic-bezier(.34,1.56,.64,1)}.piggy-overlay,.piggy-overlay--drag-over,.piggy-overlay--dropped{display:none}.floating-amount{position:absolute;z-index:10;font-family:Poppins,sans-serif;font-size:1.4rem;font-weight:800;color:#059669;text-shadow:0 2px 8px rgba(0,0,0,.2),0 0 20px rgba(5,150,105,.4);pointer-events:none;animation:floatUp 1.2s ease-out forwards;transform:translate(-50%);white-space:nowrap}.app-footer{flex:0 0 auto;z-index:10}.money-tray{background:#ffffffe0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(245,158,11,.18);box-shadow:0 -4px 24px #00000014;padding:10px 0 12px}.tray-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#9ca3af;text-align:center;margin-bottom:8px}.tray-scroll-area{display:flex;align-items:center;justify-content:center;overflow-x:auto;overflow-y:hidden;padding:0 1.5rem;gap:0;scrollbar-width:thin;scrollbar-color:rgba(245,158,11,.3) transparent}.tray-scroll-area::-webkit-scrollbar{height:3px}.tray-scroll-area::-webkit-scrollbar-track{background:transparent}.tray-scroll-area::-webkit-scrollbar-thumb{background:#f59e0b66;border-radius:2px}.tray-section{display:flex;flex-direction:column;gap:5px;flex-shrink:0}.tray-section-label{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:#d1d5db;text-align:center}.tray-row{display:flex;align-items:center;gap:10px}.tray-divider{width:1px;height:64px;background:linear-gradient(to bottom,transparent,rgba(245,158,11,.25),transparent);margin:16px 18px 0;flex-shrink:0;align-self:center}.coin-item{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:grab;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s ease;flex-shrink:0;position:relative}.coin-item:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;border:1px solid rgba(255,255,255,.25);pointer-events:none}.coin-item:hover{transform:scale(1.14) translateY(-3px);cursor:grabbing}.coin-item:active{transform:scale(.95);cursor:grabbing}.coin-label{font-family:Poppins,sans-serif;font-size:.58rem;font-weight:700;color:#ffffffe6;text-shadow:0 1px 3px rgba(0,0,0,.5);letter-spacing:-.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bill-item{width:100px;height:54px;border-radius:6px;display:flex;align-items:center;justify-content:space-between;cursor:grab;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s ease;flex-shrink:0;position:relative;overflow:hidden}.bill-item:hover{transform:scale(1.08) translateY(-4px) rotate(-1deg);cursor:grabbing}.bill-item:active{transform:scale(.96);cursor:grabbing}.bill-watermark{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 60% 40%,rgba(255,255,255,.12) 0%,transparent 65%);pointer-events:none}.bill-left-stripe,.bill-right-stripe{width:8px;height:100%;flex-shrink:0;opacity:.7;filter:brightness(.7)}.bill-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bill-eu-symbol{font-family:Poppins,sans-serif;font-size:.6rem;font-weight:600;color:#ffffffbf;line-height:1}.bill-value{font-family:Poppins,sans-serif;font-size:1.25rem;font-weight:800;color:#fffffff7;text-shadow:0 1px 4px rgba(0,0,0,.35);line-height:1;letter-spacing:-.03em}.touch-drag-ghost{position:fixed;z-index:9999;pointer-events:none;transform:translate(-50%,-50%) scale(1.15);opacity:.9;transition:opacity .1s ease}.touch-ghost-coin{animation:coinSpin .4s ease-out}.touch-ghost-bill{transform:rotate(-3deg)}.header-history-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid rgba(245,158,11,.2);background:#f59e0b14;color:#d97706;cursor:pointer;transition:all .2s ease}.header-history-btn:hover{background:#f59e0b26;border-color:#f59e0b59;transform:scale(1.05)}.header-history-btn:active{transform:scale(.95)}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes drawerSlideOut{0%{transform:translate(0)}to{transform:translate(100%)}}.history-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000;pointer-events:none;transition:background .3s ease}.history-backdrop--open{background:#00000059;pointer-events:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.history-drawer{position:fixed;top:0;right:0;bottom:0;width:min(400px,90vw);z-index:101;background:#fefefe;box-shadow:-8px 0 40px #0000001f;display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}.history-drawer--open{transform:translate(0)}.history-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.06)}.history-header-left{display:flex;align-items:center;gap:10px}.history-header-icon{color:#d97706}.history-title{font-family:Poppins,sans-serif;font-size:1.15rem;font-weight:700;color:#1f2937;letter-spacing:-.02em}.history-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease}.history-close:hover{background:#00000014;color:#1f2937}.history-summary{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:2px;padding:20px 24px;background:linear-gradient(135deg,#f59e0b0f,#d977060a);border-bottom:1px solid rgba(0,0,0,.05)}.history-summary-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#9ca3af}.history-summary-amount{font-family:Poppins,sans-serif;font-size:1.6rem;font-weight:800;color:#1f2937;letter-spacing:-.03em}.history-summary-count{font-size:.75rem;color:#9ca3af}.history-list{flex:1 1 0;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:rgba(245,158,11,.2) transparent}.history-list::-webkit-scrollbar{width:4px}.history-list::-webkit-scrollbar-track{background:transparent}.history-list::-webkit-scrollbar-thumb{background:#f59e0b40;border-radius:2px}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:60px 24px;color:#9ca3af;text-align:center}.history-empty-icon{color:#d1d5db;margin-bottom:4px}.history-empty-sub{font-size:.8rem;color:#d1d5db}.history-group{margin-bottom:4px}.history-date-header{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af;padding:12px 24px 6px;position:sticky;top:0;background:#fefefe;z-index:1}.history-row{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;transition:background .15s ease}.history-row:hover{background:#00000005}.history-row-left{display:flex;align-items:center;gap:12px}.history-row-dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);flex-shrink:0;box-shadow:0 0 0 3px #f59e0b1f}.history-row-info{display:flex;flex-direction:column;gap:1px}.history-row-desc{font-size:.88rem;font-weight:500;color:#374151}.history-row-time{font-size:.72rem;color:#9ca3af}.history-row-right{display:flex;align-items:center;gap:8px}.history-row-amount{font-family:Poppins,sans-serif;font-size:.92rem;font-weight:700;color:#059669;letter-spacing:-.02em;white-space:nowrap}.history-row-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:#ef444414;color:#dc2626;cursor:pointer;transition:all .15s ease;opacity:0;transform:scale(.9)}.history-row:hover .history-row-delete{opacity:1;transform:scale(1)}.history-row-delete:hover{background:#ef444426;color:#b91c1c}.history-row-delete:disabled{opacity:.5;cursor:not-allowed}.history-row--deleting{opacity:.5;pointer-events:none}.history-confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:102;background:#0006;display:flex;align-items:flex-end;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.history-confirm-modal{width:100%;max-width:380px;margin:auto;background:#fefefe;border-radius:16px;box-shadow:0 20px 60px #00000040;overflow:hidden;animation:slideUp .3s cubic-bezier(.32,.72,0,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.history-confirm-header{padding:20px 24px 12px;border-bottom:1px solid rgba(0,0,0,.05)}.history-confirm-header h3{font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;color:#1f2937;margin:0;letter-spacing:-.02em}.history-confirm-body{padding:16px 24px;color:#6b7280;font-size:.9rem;line-height:1.5}.history-confirm-body strong{color:#1f2937;font-weight:600}.history-confirm-actions{display:flex;gap:12px;padding:12px 24px 20px;justify-content:flex-end}.history-confirm-cancel,.history-confirm-delete{padding:8px 20px;border-radius:8px;border:none;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s ease}.history-confirm-cancel{background:#0000000d;color:#6b7280}.history-confirm-cancel:hover:not(:disabled){background:#0000001a;color:#1f2937}.history-confirm-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.history-confirm-delete:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.history-confirm-delete:disabled,.history-confirm-cancel:disabled{opacity:.6;cursor:not-allowed}.dashboard-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);overflow:hidden}.dashboard-header{padding:24px 20px 16px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);border-bottom:1px solid rgba(0,0,0,.06);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dashboard-title{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:800;color:#1f2937;text-align:center;letter-spacing:-.03em}.dashboard-main{flex:1;padding:32px 20px;overflow-y:auto;display:flex;justify-content:center;align-items:flex-start}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:24px;width:100%;max-width:100%}.dashboard-card{position:relative;aspect-ratio:1;border:none;border-radius:20px;background:#fff;box-shadow:0 8px 24px #0000001f;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden;padding:0}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000002e}.dashboard-card:active{transform:translateY(-2px);transition-duration:.1s}.dashboard-card-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#fef3c7,#fde68a)}.dashboard-icon-img{width:70%;height:70%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.dashboard-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(180deg,#0000,#000000b3);display:flex;justify-content:center;align-items:center}.dashboard-card-label{font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;color:#fff;letter-spacing:-.01em;text-shadow:0 1px 3px rgba(0,0,0,.4)}.dashboard-card-icon--space{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}@keyframes sfPulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes sfEntryIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes sfNewEntry{0%{background:#22c55e26}to{background:transparent}}.sf-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(160deg,#0a0f1e,#0d1b2a 40%,#091628);overflow:hidden}.sf-header{background:#0a0f1eeb!important;border-bottom:1px solid rgba(56,189,248,.15)!important;box-shadow:0 2px 20px #0000004d!important}.sf-header .app-title{background:linear-gradient(135deg,#38bdf8,#7dd3fc,#bae6fd)!important;background-size:200% auto!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}.sf-header-left{display:flex;align-items:center;gap:12px}.sf-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(56,189,248,.2);background:#38bdf814;color:#7dd3fc;cursor:pointer;transition:all .2s ease;flex-shrink:0}.sf-back-btn:hover{background:#38bdf826;border-color:#38bdf866;transform:scale(1.05)}.sf-add-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;border:1px solid rgba(56,189,248,.3);background:#38bdf81a;color:#7dd3fc;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s ease}.sf-add-btn:hover{background:#38bdf833;border-color:#38bdf880;transform:translateY(-1px);box-shadow:0 4px 12px #38bdf826}.sf-main{flex:1 1 0;overflow-y:auto;padding:24px 16px;scrollbar-width:thin;scrollbar-color:rgba(56,189,248,.2) transparent}.sf-main::-webkit-scrollbar{width:4px}.sf-main::-webkit-scrollbar-thumb{background:#38bdf833;border-radius:2px}.sf-content{max-width:600px;margin:0 auto}.sf-loading{display:flex;justify-content:center;align-items:center;padding:80px 0}.sf-spinner{width:36px;height:36px;border:3px solid rgba(56,189,248,.15);border-top-color:#38bdf8;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sf-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 24px;text-align:center}.sf-empty-icon{color:#38bdf84d;margin-bottom:4px}.sf-empty-title{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:700;color:#ffffffb3;letter-spacing:-.02em}.sf-empty-sub{font-size:.88rem;color:#ffffff59}.sf-empty-btn{display:flex;align-items:center;gap:6px;margin-top:8px;padding:10px 20px;border-radius:10px;border:1px solid rgba(56,189,248,.3);background:#38bdf81a;color:#7dd3fc;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s ease}.sf-empty-btn:hover{background:#38bdf833;transform:translateY(-1px)}.sf-leaderboard{display:flex;flex-direction:column;gap:8px}.sf-entry{display:flex;align-items:center;gap:16px;padding:14px 18px;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);transition:all .2s ease;animation:sfEntryIn .3s ease}.sf-entry:hover{background:#ffffff12;border-color:#38bdf826}.sf-entry--new{animation:sfNewEntry 2s ease forwards}.sf-rank{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:Poppins,sans-serif;font-size:.85rem;font-weight:700;flex-shrink:0;background:#ffffff0f;color:#fff6}.sf-rank--gold{background:linear-gradient(135deg,#fbbf2433,#f59e0b1a);border:1px solid rgba(251,191,36,.35);color:#fcd34d}.sf-rank--silver{background:linear-gradient(135deg,#94a3b833,#64748b1a);border:1px solid rgba(148,163,184,.35);color:#cbd5e1}.sf-rank--bronze{background:linear-gradient(135deg,#b4530940,#92400e1a);border:1px solid rgba(180,83,9,.4);color:#fdba74}.sf-entry-info{flex:1;min-width:0}.sf-entry-name{font-family:Poppins,sans-serif;font-size:1rem;font-weight:600;color:#ffffffe6;letter-spacing:-.01em;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-entry-score{display:flex;flex-direction:column;align-items:flex-end;gap:1px;flex-shrink:0}.sf-score-value{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:800;color:#38bdf8;letter-spacing:-.03em;line-height:1}.sf-score-label{font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:#38bdf873}.sf-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;padding:16px;animation:fadeIn .2s ease}.sf-modal{width:100%;max-width:460px;background:#0f172a;border:1px solid rgba(56,189,248,.15);border-radius:20px;box-shadow:0 24px 60px #00000080,0 0 0 1px #38bdf80d;overflow:hidden;animation:slideUp .3s cubic-bezier(.32,.72,0,1);margin-bottom:env(safe-area-inset-bottom,0)}.sf-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.sf-modal-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:#ffffffe6;letter-spacing:-.02em}.sf-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:none;background:#ffffff0f;color:#ffffff80;cursor:pointer;transition:all .15s ease}.sf-modal-close:hover{background:#ffffff1a;color:#fffc}.sf-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:20px}.sf-form-group{display:flex;flex-direction:column;gap:8px}.sf-form-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#38bdf8b3}.sf-form-input{padding:12px 16px;border-radius:10px;border:1px solid rgba(56,189,248,.2);background:#ffffff0d;color:#ffffffe6;font-size:1rem;font-family:Inter,system-ui,sans-serif;outline:none;transition:all .2s ease}.sf-form-input::-moz-placeholder{color:#ffffff40}.sf-form-input::placeholder{color:#ffffff40}.sf-form-input:focus{border-color:#38bdf880;background:#38bdf80f;box-shadow:0 0 0 3px #38bdf814}.sf-score-options{display:flex;gap:8px;flex-wrap:wrap}.sf-score-option{flex:1;min-width:60px;padding:10px 8px;border-radius:10px;border:1px solid rgba(56,189,248,.15);background:#ffffff0a;color:#ffffff8c;font-family:Poppins,sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s ease;text-align:center}.sf-score-option:hover{background:#38bdf814;border-color:#38bdf84d;color:#fffc}.sf-score-option--selected{background:#38bdf826;border-color:#38bdf880;color:#7dd3fc;box-shadow:0 0 0 2px #38bdf81a}.sf-form-error{font-size:.82rem;color:#f87171;padding:8px 12px;border-radius:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.sf-form-submit{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#0ea5e9,#38bdf8);color:#0a0f1e;font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:-.01em}.sf-form-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #0ea5e959}.sf-form-submit:active:not(:disabled){transform:translateY(0)}.sf-form-submit:disabled{opacity:.6;cursor:not-allowed}.dashboard-settings-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:#0000000a;color:#6b7280;cursor:pointer;transition:all .2s ease}.dashboard-settings-btn:hover{background:#00000014;color:#374151;transform:rotate(30deg)}.dashboard-settings-btn:active{transform:rotate(30deg) scale(.95)}.dashboard-card-icon--randomizer{background:linear-gradient(135deg,#ecfdf5,#d1fae5,#a7f3d0)}.dashboard-card--randomizer .dashboard-icon-img{width:60%;height:60%}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000;pointer-events:none;transition:background .3s ease}.settings-backdrop--open{background:#00000059;pointer-events:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.settings-drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,92vw);z-index:101;background:#fefefe;box-shadow:-8px 0 40px #0000001f;display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}.settings-drawer--open{transform:translate(0)}.settings-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.06)}.settings-header-left{display:flex;align-items:center;gap:10px}.settings-header-icon{color:#d97706}.settings-title{font-family:Poppins,sans-serif;font-size:1.15rem;font-weight:700;color:#1f2937;letter-spacing:-.02em}.settings-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease}.settings-close:hover{background:#00000014;color:#1f2937}.settings-body{flex:1 1 0;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:28px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.1) transparent}.settings-section{display:flex;flex-direction:column;gap:12px}.settings-section-header{display:flex;align-items:center;gap:8px;font-family:Poppins,sans-serif;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280}.settings-add-row{display:flex;gap:8px}.settings-input{flex:1;padding:10px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.1);background:#00000005;color:#1f2937;font-size:.92rem;font-family:Inter,system-ui,sans-serif;outline:none;transition:all .2s ease}.settings-input::-moz-placeholder{color:#9ca3af}.settings-input::placeholder{color:#9ca3af}.settings-input:focus{border-color:#d97706;background:#fffbf0;box-shadow:0 0 0 3px #d9770614}.settings-add-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.settings-add-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.settings-add-btn:disabled{opacity:.4;cursor:not-allowed}.settings-class-list{display:flex;flex-direction:column;gap:4px}.settings-class-item{display:flex;align-items:center;border-radius:10px;transition:all .15s ease;overflow:hidden}.settings-class-item--active{background:#f59e0b14}.settings-class-name{flex:1;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:none;background:none;color:#374151;font-size:.92rem;font-weight:500;cursor:pointer;text-align:left;transition:color .15s ease}.settings-class-item--active .settings-class-name{color:#d97706;font-weight:600}.settings-class-count{font-size:.75rem;font-weight:600;color:#9ca3af;background:#0000000d;padding:2px 8px;border-radius:10px}.settings-class-item--active .settings-class-count{background:#d977061f;color:#d97706}.settings-class-delete{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:#d1d5db;cursor:pointer;transition:all .15s ease;margin-right:6px}.settings-class-delete:hover{background:#ef44441a;color:#dc2626}.settings-pupil-list{display:flex;flex-direction:column;gap:2px}.settings-pupil-item{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-radius:8px;transition:background .15s ease}.settings-pupil-item:hover{background:#00000005}.settings-pupil-name{font-size:.92rem;color:#374151;font-weight:500}.settings-pupil-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#d1d5db;cursor:pointer;transition:all .15s ease;opacity:0}.settings-pupil-item:hover .settings-pupil-delete{opacity:1}.settings-pupil-delete:hover{background:#ef44441a;color:#dc2626}.settings-empty{font-size:.85rem;color:#9ca3af;text-align:center;padding:20px 0}.settings-confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000080;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .2s ease}.settings-confirm-modal{width:100%;max-width:380px;background:#fefefe;border-radius:16px;box-shadow:0 20px 60px #00000040;padding:24px;animation:slideUp .3s cubic-bezier(.32,.72,0,1)}.settings-confirm-title{font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;color:#1f2937;margin:0 0 8px}.settings-confirm-text{font-size:.9rem;color:#6b7280;line-height:1.5;margin:0 0 20px}.settings-confirm-actions{display:flex;gap:12px;justify-content:flex-end}.settings-confirm-cancel,.settings-confirm-delete{padding:8px 20px;border-radius:8px;border:none;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s ease}.settings-confirm-cancel{background:#0000000d;color:#6b7280}.settings-confirm-cancel:hover{background:#0000001a;color:#1f2937}.settings-confirm-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.settings-confirm-delete:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}@keyframes randReveal{0%{opacity:0;transform:scale(.6) translateY(10px)}60%{transform:scale(1.08) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes randGlow{0%,to{box-shadow:0 0 20px #10b9814d,0 0 60px #10b9811a}50%{box-shadow:0 0 40px #10b98180,0 0 80px #10b98133}}.rand-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(160deg,#0f172a,#1e293b 40%,#334155);overflow:hidden}.rand-header{background:#0f172aeb!important;border-bottom:1px solid rgba(16,185,129,.15)!important;box-shadow:0 2px 20px #0000004d!important}.rand-header .app-title{background:linear-gradient(135deg,#10b981,#34d399,#6ee7b7)!important;background-size:200% auto!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}.rand-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(16,185,129,.2);background:#10b98114;color:#6ee7b7;cursor:pointer;transition:all .2s ease;flex-shrink:0}.rand-back-btn:hover{background:#10b98126;border-color:#10b98166;transform:scale(1.05)}.rand-class-select{padding:8px 14px;border-radius:10px;border:1px solid rgba(16,185,129,.2);background:#10b98114;color:#6ee7b7;font-size:.88rem;font-weight:600;font-family:Inter,system-ui,sans-serif;outline:none;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.rand-class-select:disabled{opacity:.5;cursor:not-allowed}.rand-class-select option{background:#1e293b;color:#e2e8f0}.rand-class-select:hover:not(:disabled){border-color:#10b98166;background:#10b9811f}.rand-main{flex:1 1 0;display:flex;align-items:center;justify-content:center;padding:16px 24px 24px;overflow:hidden}.rand-empty{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:40px}.rand-empty-icon{color:#10b98140;margin-bottom:4px}.rand-empty-title{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:700;color:#ffffffb3}.rand-empty-sub{font-size:.88rem;color:#ffffff59;max-width:300px}.rand-center-layout{display:flex;flex-direction:column;align-items:center;gap:28px}.rand-wheel-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.wheel-wrapper{position:relative;display:inline-flex;align-items:center;justify-content:center;filter:drop-shadow(0 8px 32px rgba(0,0,0,.5))}.wheel-canvas{width:min(400px,84vw);height:min(400px,84vw);border-radius:50%;display:block}.wheel-pointer{position:absolute;top:-2px;left:50%;transform:translate(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-top:28px solid #F59E0B;filter:drop-shadow(0 2px 6px rgba(245,158,11,.6));z-index:10}.rand-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:randReveal .45s cubic-bezier(.34,1.56,.64,1);pointer-events:none;z-index:20;gap:4px;padding:24px}.rand-overlay-label{font-family:Poppins,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#34d399}.rand-overlay-name{font-family:Poppins,sans-serif;font-size:clamp(1.8rem,7vw,3rem);font-weight:800;color:#fff;letter-spacing:-.03em;text-shadow:0 0 30px rgba(16,185,129,.7),0 2px 8px rgba(0,0,0,.5);text-align:center;word-break:break-word;line-height:1.1}.rand-spin-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:15px 40px;border-radius:16px;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:-.01em;box-shadow:0 4px 20px #f59e0b59;white-space:nowrap}.rand-spin-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #f59e0b80}.rand-spin-btn:active:not(:disabled){transform:translateY(0)}.rand-spin-btn:disabled{opacity:.5;cursor:not-allowed}.dashboard-card-icon--weektaak{background:linear-gradient(135deg,#fff8ee,#fff0dc,#ffe8cc);display:flex;align-items:center;justify-content:center}@keyframes wt-check-pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.wt-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(160deg,#f0f7ff,#ebf4ff,#e6f0ff);overflow:hidden}.wt-header-left{display:flex;align-items:center;gap:12px}.wt-header-title-block{display:flex;align-items:center;gap:10px}.wt-class-badge{font-size:.78rem;font-weight:600;color:#2563eb;background:#2563eb1a;border:1px solid rgba(37,99,235,.2);padding:2px 10px;border-radius:20px}.wt-header-right{display:flex;align-items:center;gap:10px}.wt-class-selector{display:flex;gap:6px}.wt-class-tab{padding:5px 14px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:transparent;font-size:.82rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s ease}.wt-class-tab--active{background:#2563eb1a;border-color:#2563eb4d;color:#2563eb;font-weight:600}.wt-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease;flex-shrink:0}.wt-back-btn:hover{background:#00000014;color:#374151}.wt-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease}.wt-icon-btn:hover{background:#2563eb14;color:#2563eb;border-color:#2563eb33;transform:rotate(20deg)}.wt-main{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:20px;gap:16px}.wt-loading,.wt-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#6b7280;text-align:center}.wt-empty-icon{color:#93c5fd}.wt-empty h2{font-family:Poppins,sans-serif;font-size:1.3rem;font-weight:700;color:#1d4ed8}.wt-empty p{color:#6b7280;font-size:.9rem;max-width:280px}.wt-content{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:14px}.wt-week-nav{display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;padding:10px 16px;box-shadow:0 2px 12px #0000000f;border:1px solid rgba(0,0,0,.06);flex-shrink:0}.wt-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:#00000008;color:#374151;cursor:pointer;transition:all .15s ease}.wt-nav-btn:hover:not(:disabled){background:#2563eb14;border-color:#2563eb33;color:#2563eb}.wt-nav-btn:disabled{opacity:.3;cursor:not-allowed}.wt-week-info{flex:1;display:flex;align-items:center;gap:10px}.wt-week-label{font-family:Poppins,sans-serif;font-weight:700;font-size:1rem;color:#1d4ed8}.wt-week-dates{font-size:.85rem;color:#6b7280;font-weight:500}.wt-new-week-btn{flex-shrink:0}.wt-table-scroll{flex:1;overflow:auto;border-radius:14px;box-shadow:0 2px 16px #00000012;border:1px solid rgba(0,0,0,.07);background:#fff}.wt-table{width:100%;border-collapse:collapse;font-size:.88rem;min-width:400px}.wt-th-name{text-align:left;padding:12px 16px;font-family:Poppins,sans-serif;font-weight:700;font-size:.82rem;color:#1d4ed8;background:#eff6ff;border-bottom:2px solid #DBEAFE;min-width:150px;position:sticky;left:0;z-index:2}.wt-th-task{padding:8px 6px;text-align:center;background:#eff6ff;border-bottom:2px solid #DBEAFE;border-left:1px solid #DBEAFE;min-width:80px;max-width:110px;vertical-align:bottom}.wt-th-task-inner{display:flex;flex-direction:column;align-items:center;gap:4px;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);padding:6px 2px;max-height:120px}.wt-th-task-name{font-weight:700;font-size:.8rem;color:#1e40af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.wt-th-empty-col{padding:12px;text-align:center;background:#eff6ff;border-bottom:2px solid #DBEAFE;border-left:1px solid #DBEAFE}.wt-th-empty-hint{font-size:.75rem;color:#93c5fd;font-style:italic}.wt-row{transition:background .2s ease}.wt-row:hover{background:#f8fbff}.wt-row--done .wt-td-name{background:linear-gradient(90deg,#f0fdf4,#dcfce7)}.wt-row--done .wt-pupil-name{color:#16a34a}.wt-td-name{padding:10px 16px;font-weight:600;color:#1f2937;border-bottom:1px solid #F1F5F9;background:#fafbff;position:sticky;left:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:background .2s ease}.wt-pupil-name{font-size:.88rem;font-weight:600}.wt-progress-badge{font-size:.7rem;font-weight:600;color:#6b7280;background:#f3f4f6;border-radius:20px;padding:1px 7px;flex-shrink:0}.wt-row--done .wt-progress-badge{background:#d1fae5;color:#059669}.wt-td-check{text-align:center;vertical-align:middle;border-bottom:1px solid #F1F5F9;border-left:1px solid #F1F5F9;cursor:pointer;transition:background .15s ease;height:44px;width:80px}.wt-td-check:hover{background:#eff6ff}.wt-td-check--done{background:#f0fdf4}.wt-td-check--done:hover{background:#dcfce7}.wt-td-empty{border-bottom:1px solid #F1F5F9;border-left:1px solid #F1F5F9}.wt-check-mark{display:flex;align-items:center;justify-content:center;color:#16a34a;animation:wt-check-pop .25s ease forwards}.wt-legend{background:#fff;border-radius:12px;padding:12px 16px;display:flex;flex-wrap:wrap;gap:8px 24px;box-shadow:0 2px 10px #0000000d;border:1px solid rgba(0,0,0,.06);flex-shrink:0}.wt-legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#374151}.wt-legend-name{font-weight:700;color:#1d4ed8}.wt-legend-desc{color:#6b7280}.wt-legend-link{color:#2563eb;font-size:.75rem;text-decoration:underline;cursor:pointer}.wt-empty-pupils{padding:16px;text-align:center;color:#9ca3af;font-size:.85rem;background:#fff;border-radius:12px;border:1px dashed #D1D5DB}.wt-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:10px;border:none;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;font-family:Poppins,sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 3px 12px #2563eb4d}.wt-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66}.wt-btn-primary:disabled{opacity:.55;cursor:not-allowed}.wt-btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;border:1px solid rgba(0,0,0,.12);background:#00000008;color:#374151;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease}.wt-btn-secondary:hover{background:#00000012}.wt-btn-danger{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;border:none;background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 3px 10px #dc262640}.wt-btn-danger:hover{transform:translateY(-1px);box-shadow:0 6px 18px #dc262659}.wt-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.wt-modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px #0003;width:100%;max-width:420px;overflow:hidden}.wt-settings-modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px #0003;width:100%;max-width:520px;max-height:90svh;overflow:hidden;display:flex;flex-direction:column;position:relative}.wt-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #F1F5F9}.wt-modal-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:#1e40af}.wt-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:transparent;color:#6b7280;cursor:pointer;transition:all .15s ease}.wt-modal-close:hover{background:#fef2f2;color:#ef4444;border-color:#ef444433}.wt-modal-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px}.wt-field-row{display:flex;gap:12px}.wt-field{flex:1;display:flex;flex-direction:column;gap:5px}.wt-label{font-size:.78rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.04em}.wt-required{color:#ef4444}.wt-input{padding:9px 12px;border-radius:10px;border:1.5px solid #E5E7EB;font-size:.88rem;color:#1f2937;background:#fff;transition:border-color .15s ease;outline:none;width:100%}.wt-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.wt-week-preview{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#eff6ff;border-radius:10px;border:1px solid #DBEAFE;font-size:.82rem;color:#374151;flex-wrap:wrap}.wt-week-preview-label{font-weight:700;color:#1d4ed8}.wt-week-preview-sep{color:#9ca3af}.wt-error{font-size:.82rem;color:#dc2626;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:8px 12px}.wt-modal-actions{display:flex;gap:10px;justify-content:flex-end}.wt-settings-tabs{display:flex;gap:0;border-bottom:1px solid #F1F5F9;padding:0 24px;flex-shrink:0}.wt-settings-tab{display:flex;align-items:center;gap:6px;padding:12px 16px;border:none;background:transparent;font-size:.83rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease;margin-bottom:-1px}.wt-settings-tab:hover{color:#2563eb}.wt-settings-tab--active{color:#2563eb;font-weight:700;border-bottom-color:#2563eb}.wt-settings-body{flex:1;overflow-y:auto;padding:0}.wt-settings-section{padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px}.wt-settings-hint{font-size:.82rem;color:#6b7280;line-height:1.5;background:#f8faff;border-radius:8px;padding:10px 12px;border:1px solid #E0EAFF}.wt-task-list{display:flex;flex-direction:column;gap:6px}.wt-empty-list{font-size:.82rem;color:#9ca3af;text-align:center;padding:12px;font-style:italic}.wt-task-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#f8faff;border-radius:10px;border:1px solid #E0EAFF}.wt-task-item--default{background:#fffbeb;border-color:#fde68a}.wt-task-item-icon{color:#f59e0b;flex-shrink:0;margin-top:2px}.wt-task-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.wt-task-item-name{font-weight:600;font-size:.85rem;color:#1f2937}.wt-task-item-desc{font-size:.78rem;color:#6b7280}.wt-task-item-link{font-size:.75rem;color:#3b82f6;word-break:break-all}.wt-delete-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;border:none;background:transparent;color:#9ca3af;cursor:pointer;transition:all .15s ease;flex-shrink:0}.wt-delete-btn:hover{background:#fef2f2;color:#ef4444}.wt-add-task-form{display:flex;flex-direction:column;gap:12px;padding:16px;background:#f8faff;border-radius:12px;border:1px solid #E0EAFF}.wt-form-title{font-family:Poppins,sans-serif;font-size:.88rem;font-weight:700;color:#1e40af;margin-bottom:2px}.wt-add-btn{align-self:flex-start}.wt-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffeb;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;border-radius:18px;z-index:10}.wt-confirm-box{background:#fff;border-radius:14px;padding:24px;box-shadow:0 8px 30px #0000001f;border:1px solid #E5E7EB;display:flex;flex-direction:column;gap:16px;max-width:320px;width:100%}.wt-confirm-text{font-size:.9rem;color:#374151;text-align:center;line-height:1.5}.wt-confirm-actions{display:flex;gap:10px;justify-content:center}.wt-day-picker{display:flex;gap:6px;flex-wrap:wrap}.wt-day-btn{padding:8px 14px;border-radius:10px;border:1.5px solid #E5E7EB;background:#fff;font-size:.83rem;font-weight:500;color:#374151;cursor:pointer;transition:all .15s ease}.wt-day-btn:hover:not(:disabled){border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}.wt-day-btn--active{background:linear-gradient(135deg,#2563eb,#3b82f6);border-color:transparent;color:#fff;font-weight:700;box-shadow:0 3px 10px #2563eb4d}.wt-day-btn--active:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff}.wt-day-btn:disabled{opacity:.5;cursor:not-allowed}.wt-start-day-info{font-size:.82rem;color:#374151;background:#f0f9ff;border:1px solid #BAE6FD;border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:6px}.wt-start-day-hint{color:#9ca3af;font-size:.75rem}.wt-tooltip-wrap{position:relative;display:inline-flex;writing-mode:horizontal-tb}.wt-tooltip-trigger{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1.5px solid #93C5FD;background:#eff6ff;color:#2563eb;font-size:.65rem;font-weight:800;cursor:pointer;transition:all .15s ease}.wt-tooltip-trigger:hover{background:#dbeafe}.wt-tooltip-box{background:#1e293b;color:#fff;border-radius:10px;padding:10px 12px;font-size:.78rem;min-width:160px;max-width:220px;box-shadow:0 8px 24px #0003;writing-mode:horizontal-tb}.wt-tooltip-desc{line-height:1.5;color:#e2e8f0;margin-bottom:6px}.wt-tooltip-link{display:inline-flex;align-items:center;gap:4px;color:#60a5fa;text-decoration:underline;font-size:.75rem;cursor:pointer}.wt-copy-section{margin-top:16px}.wt-copy-divider{height:1px;background:#e5e7eb;margin-bottom:16px}.wt-copy-title{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:#374151;margin:0 0 6px}.wt-copy-hint{font-size:.78rem;color:#6b7280;margin:0 0 8px}.wt-copy-success{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;color:#16a34a;font-weight:600;margin-top:8px}.wt-class-picker{margin-bottom:10px}.wt-class-picker-label{font-size:.78rem;color:#6b7280;font-weight:500;margin:0 0 6px}.wt-class-picker-options{display:flex;flex-wrap:wrap;gap:6px}.wt-class-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:20px;border:1.5px solid #E5E7EB;background:#fff;font-size:.8rem;font-weight:500;color:#374151;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.wt-class-chip:hover{border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}.wt-class-chip--active{background:#eff6ff;border-color:#2563eb;color:#1d4ed8;font-weight:600}.wt-btn-copy{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#f0fdf4;border:1.5px solid #86EFAC;border-radius:10px;color:#16a34a;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .15s ease;margin-top:4px}.wt-btn-copy:hover:not(:disabled){background:#dcfce7;border-color:#4ade80}.wt-btn-copy:disabled{opacity:.5;cursor:not-allowed}
