@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}.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 randPulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}@keyframes randReveal{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes randSlotScroll{0%{transform:translateY(0)}to{transform:translateY(-100%)}}.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 option{background:#1e293b;color:#e2e8f0}.rand-class-select:hover{border-color:#10b98166;background:#10b9811f}.rand-main{flex:1 1 0;display:flex;align-items:center;justify-content:center;padding:24px}.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-content{display:flex;flex-direction:column;align-items:center;gap:40px;width:100%;max-width:500px}.rand-display{width:100%;min-height:160px;border-radius:24px;border:2px solid rgba(16,185,129,.15);background:#ffffff08;display:flex;align-items:center;justify-content:center;padding:32px;transition:all .3s ease;overflow:hidden}.rand-display--spinning{border-color:#10b98166;background:#10b9810d;animation:randPulse .6s ease infinite}.rand-display--picked{border-color:#10b98180;background:#10b98114;box-shadow:0 0 40px #10b9811f}.rand-slot{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center}.rand-slot-name{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:600;color:#10b98180;padding:4px 12px;border-radius:8px;background:#10b9810f;transition:all .08s ease}.rand-placeholder{font-family:Poppins,sans-serif;font-size:1.15rem;font-weight:600;color:#fff3;letter-spacing:-.01em}.rand-picked-name{font-family:Poppins,sans-serif;font-size:clamp(2rem,6vw,3.5rem);font-weight:800;color:#6ee7b7;letter-spacing:-.03em;text-shadow:0 0 30px rgba(16,185,129,.3);animation:randReveal .5s cubic-bezier(.34,1.56,.64,1);text-align:center;word-break:break-word}.rand-spin-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 40px;border-radius:16px;border:none;background:linear-gradient(135deg,#059669,#10b981);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 #10b98140}.rand-spin-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #10b98159}.rand-spin-btn:active:not(:disabled){transform:translateY(0)}.rand-spin-btn:disabled{opacity:.5;cursor:not-allowed}
