@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,400&display=swap";:root{--success-color: #2a8a4a;--success-gradient: linear-gradient(135deg, #2a8a4a 0%, #1e7a3e 100%);--warning-color: #c48a20;--warning-gradient: linear-gradient(135deg, #c48a20 0%, #b07a18 100%);--danger-color: #c44040;--danger-gradient: linear-gradient(135deg, #c44040 0%, #b03636 100%);--font-body: "DM Sans", -apple-system, system-ui, sans-serif;--font-heading: "Poppins", -apple-system, system-ui, sans-serif;--fg: #1a1a2e;--fg-soft: #4a4a68;--fg-muted: #8888a4;--bg: #f8f7f4;--bg-raised: #ffffff;--bg-inset: #f0efeb;--bg-hover: #eae9e4;--border: #e2e1dc;--border-strong: #d0cfc8;--accent: #1a8a6e;--accent-hover: #157a60;--accent-soft: #e8f5f0;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 4px 20px rgba(0,0,0,.08);--shadow-card: 0 1px 3px rgba(0,0,0,.04), 0 0 0 1px var(--border);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--ease: cubic-bezier(.22,.61,.36,1);--duration: .18s;--pos-bg: #F4F1EC;--surface-alt: #F9F7F4;--ink: #1A1A18;--ink-soft: #6B6860;--ink-muted: #A5A09A;--cart-border: #E5E1DA;--cart-border-strong: #D0CBC3;--cart-radius-sm: 10px;--cart-radius-md: 14px;--cart-radius-lg: 20px;--shadow-cart-card: 0 1px 3px rgba(26,26,24,.04), 0 4px 12px rgba(26,26,24,.06);--gradient-primary: linear-gradient(135deg, #1a8a6e 0%, #157a60 100%);--gradient-secondary: linear-gradient(135deg, #1a8a6e 0%, #157a60 100%);--gradient-body: linear-gradient(180deg, #f8f7f4 0%, #f0efeb 100%);--z-element: 10;--z-sticky: 100;--z-mobile-info: 999;--z-modal: 9999;--z-modal-overlay: 10000;--z-modal-nested: 10001;--z-alert: 999999}.screen-hidden{display:none!important}body{font-family:var(--font-body);background:var(--bg);background-attachment:fixed;color:var(--fg);margin:0;padding:0;display:flex;justify-content:center;align-items:center;height:100vh;overflow:hidden;min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.5}*,*:before,*:after{font-family:inherit}input,button,select,textarea{font-family:var(--font-body)}[contenteditable]{color:#1a1a2e}h1,h2{font-family:var(--font-heading)}h2{background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--fg);background-clip:unset;text-align:left;font-size:clamp(22px,2.6vw,32px);margin:0;font-weight:600;letter-spacing:-.01em}h3{font-family:var(--font-heading);background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--fg);background-clip:unset;border-bottom:1px solid var(--border);padding-bottom:10px;margin-top:20px;font-weight:600}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:var(--bg-raised);padding:40px;border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-lg);width:90%;max-width:450px;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.login-logo{max-width:250px;height:auto;margin-bottom:20px;filter:none}.lock-icon{font-size:50px;margin-bottom:10px}.login-container h1{font-size:24px;margin-bottom:20px;background:none;-webkit-text-fill-color:var(--fg);color:var(--fg)}.login-container select,.login-container input,.login-container button{width:100%;padding:15px;font-size:18px;border-radius:var(--radius-md);margin-top:15px;box-sizing:border-box;font-family:var(--font-body);transition:all var(--duration) var(--ease)}.login-container select,.login-container input{border:1px solid #d0cfc8;background:#fff;color:#1a1a2e}.login-container select:focus,.login-container input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}.login-container button{background:var(--gradient-primary);color:#fff;border:none;cursor:pointer;font-weight:600;box-shadow:var(--shadow-md);transition:all var(--duration) var(--ease)}.login-container button:hover{background:linear-gradient(135deg,#157a60,#126e56);box-shadow:var(--shadow-lg)}.login-container button:active{transform:translateY(0)}.login-container label{font-weight:600;align-self:flex-start;margin:6px 0 2px;color:var(--fg-soft);font-size:14px}.login-container form{display:flex;flex-direction:column;align-items:center;width:100%}.login-container form label{align-self:flex-start}.restaurant-mode-login-toggle{display:flex;align-items:center;gap:10px;width:100%;margin:6px 0;padding:10px 14px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1.5px solid #93c5fd;border-radius:var(--radius-md, 10px);cursor:pointer;font-weight:400;text-align:left;box-sizing:border-box;font-family:var(--font, "DM Sans", sans-serif)}.restaurant-mode-login-toggle span{font-size:14px;font-weight:600;color:#1e40af}.restaurant-mode-login-toggle small{display:block;font-size:11px;color:var(--fg-soft, #666);margin-top:2px;font-weight:400}.restaurant-mode-login-toggle input[type=checkbox]{width:20px;height:20px;min-width:20px;cursor:pointer;accent-color:#3b82f6}#login-screen{text-align:center;background:var(--bg-raised);padding:40px;border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-lg)}.login-options{width:100%}#quick-login-btn{background:var(--success-gradient);box-shadow:var(--shadow-md)}#quick-login-btn:hover{box-shadow:var(--shadow-lg)}#start-login-btn{background:var(--gradient-primary);box-shadow:var(--shadow-md)}#start-login-btn:hover{box-shadow:var(--shadow-lg)}#pin-modal-buttons{display:flex;gap:15px;margin-top:20px}.secondary-action{background:linear-gradient(135deg,#8888a4,#6b6b84)!important;box-shadow:var(--shadow-md)!important}.secondary-action:hover{box-shadow:var(--shadow-lg)!important}.login-error{color:var(--danger-color);margin-top:15px;font-weight:600;padding:10px;background:#fdf0f0;border-radius:var(--radius-md);border:1px solid #f0c0c0;font-size:14px}.login-error:empty{display:none}.login-subtitle{margin:-6px 0 14px;color:var(--fg-soft);font-size:16px}#admin-user-select{width:100%;padding:12px;border:1px solid var(--border-strong);border-radius:var(--radius-md);font-size:16px;box-sizing:border-box;background:var(--bg-raised);transition:all var(--duration) var(--ease)}#admin-user-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}.switch-club-btn{background:none;border:none;color:var(--accent);text-decoration:none;cursor:pointer;font-size:14px;margin-top:6px;font-weight:600;transition:all var(--duration) var(--ease)}.switch-club-btn:hover{color:var(--accent-hover);text-decoration:underline}.login-version{position:absolute;bottom:8px;right:12px;font-size:11px;color:#ffffff40;font-family:monospace;pointer-events:none;-webkit-user-select:none;user-select:none}#tauri-titlebar{display:none}body.tauri-desktop #tauri-titlebar{display:flex;align-items:center;justify-content:space-between;height:32px;background:var(--accent-hover);color:#fff;padding:0 8px;user-select:none;-webkit-user-select:none;position:fixed;top:0;left:0;right:0;z-index:100000}body.tauri-desktop{padding-top:32px;height:calc(100vh - 32px);min-height:calc(100vh - 32px)}body.tauri-desktop #main-app{padding-bottom:4px}body.tauri-desktop .login-container{height:calc(100vh - 32px);min-height:calc(100vh - 32px)}body.tauri-desktop .modal,body.tauri-desktop .fsp-overlay,body.tauri-desktop .settings-modal-backdrop,body.tauri-desktop #custom-alert-modal,body.tauri-desktop #hv3-backdrop{top:32px!important;height:calc(100vh - 32px)!important;min-height:calc(100vh - 32px)!important}body.tauri-desktop.tauri-fullscreen #tauri-titlebar{display:none}body.tauri-desktop.tauri-fullscreen{padding-top:0;height:100vh;min-height:100vh}body.tauri-desktop.tauri-fullscreen .login-container{height:100vh;min-height:100vh}body.tauri-desktop.tauri-fullscreen .modal,body.tauri-desktop.tauri-fullscreen .fsp-overlay,body.tauri-desktop.tauri-fullscreen .settings-modal-backdrop,body.tauri-desktop.tauri-fullscreen #custom-alert-modal,body.tauri-desktop.tauri-fullscreen #hv3-backdrop{top:0!important;height:100vh!important;min-height:100vh!important}.titlebar-left{display:flex;align-items:center;gap:8px}.titlebar-icon{width:18px;height:18px}.titlebar-title{font-family:var(--font-heading);font-size:13px;font-weight:600;letter-spacing:.3px}.titlebar-controls{display:flex;gap:2px}.titlebar-btn{background:none;border:none;color:#ffffffd9;width:36px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.titlebar-btn:hover{background:#ffffff26}.titlebar-btn-close:hover{background:#c44040;color:#fff}.input{color:#1a1a2e;background:#fff;border-color:#d0cfc8}.input::placeholder{color:#8888a4;opacity:1}.input--on-dark{color:#e2e8f0;background:#ffffff14;border-color:#ffffff26}.input--on-dark::placeholder{color:#94a3b8;opacity:1}.select{color:#1a1a2e;background:#fff;border-color:#d0cfc8}.select option{background:#fff;color:#1a1a2e}#main-app{display:grid;grid-template-columns:1fr 460px;grid-template-rows:auto 1fr;grid-template-areas:"header     header" "products   sidebar";gap:8px 16px;width:100%;height:100%;padding:12px 16px 16px;box-sizing:border-box;position:relative;background:transparent}#products-area{grid-area:products;display:flex;flex-direction:column;gap:6px;height:100%;position:relative}.sidebar-main-header{grid-area:header}#sidebar{grid-area:sidebar}@media(max-width:800px){body{overflow:auto;height:auto}#main-app{grid-template-columns:1fr;grid-template-rows:auto auto auto;grid-template-areas:"header" "products" "sidebar";height:auto;padding:10px;gap:10px}#sidebar{min-height:400px}}.settings-button{padding:10px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:600;background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md);transition:all var(--duration) var(--ease)}.settings-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.top-bar-actions{display:flex;align-items:center;gap:8px}.toolbar-gear-btn{margin-left:8px}.toolbar-gear-menu{position:absolute;top:60px;right:20px;background:var(--bg-raised);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:8px 0;min-width:220px;z-index:9999;border:1px solid var(--border)}.toolbar-gear-menu button{width:100%;padding:10px 16px;border:none;background:transparent;text-align:left;cursor:pointer;font-size:14px;font-weight:500;color:var(--fg);transition:all var(--duration) var(--ease)}.toolbar-gear-menu button:hover{background:var(--accent-soft);color:var(--accent)}.settings-modal-backdrop{position:fixed;inset:0;background:#0f172a66;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9998}.settings-modal{background:linear-gradient(180deg,#fff8e8,#fef4e0);padding:20px 24px;border-radius:var(--radius-xl);max-width:420px;width:90%;box-shadow:var(--shadow-lg);border:1px solid var(--border);position:relative;overflow:hidden}.settings-modal:before{display:none}.settings-modal h2{margin-top:0;margin-bottom:16px;font-size:20px;text-align:center;font-family:var(--font-heading);color:#a78bfa;-webkit-text-fill-color:#a78bfa}.settings-modal-content{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.settings-modal-content .settings-item-btn{width:100%;padding:14px 16px;border-radius:var(--radius-lg);border:1px solid #e0ddf0;background:var(--bg-raised);text-align:left;cursor:pointer;font-weight:700;color:var(--fg);transition:all var(--duration) var(--ease)}.settings-modal-content .settings-item-btn:has(.settings-item-icon){display:flex;align-items:center;gap:14px}.settings-modal-content .settings-item-btn .settings-item-icon{width:44px;height:44px;flex-shrink:0;border-radius:10px;overflow:hidden;background:transparent}.settings-modal-content .settings-item-btn .settings-item-icon img{width:100%;height:100%;object-fit:contain}.settings-modal-content .settings-item-btn .settings-item-icon .settings-item-icon-emoji{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.6rem}.settings-modal-content .settings-item-btn .settings-item-text{flex:1;min-width:0}.settings-modal-content .settings-item-btn .settings-item-text .settings-item-desc{font-size:12px;margin-top:2px;font-weight:400;color:var(--fg-muted)}.settings-modal-content .settings-item-btn:hover{border-color:#a78bfa;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.settings-modal-content .settings-item-btn.highlight,.settings-modal-content .settings-item-btn[data-action=theme],.settings-modal-content .settings-item-btn:has(.settings-item-text .settings-item-title:is([data-i18n*=theme],[data-i18n*=appearance])){background:#f0ecf8;border-color:#c8b8e8}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:var(--radius-md);background:var(--bg-inset);border:1px solid var(--border)}.modal{display:none;position:fixed;z-index:var(--z-modal);left:0;top:0;width:100%;height:100%;background:#0f172a66;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);justify-content:center;align-items:center}.modal-overlay,#userModal{z-index:var(--z-modal)}.modal-content{background:var(--bg-raised);padding:24px;border-radius:var(--radius-xl);width:90%;max-width:600px;height:80%;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);border:1px solid var(--border);position:relative;overflow:hidden}.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);padding-bottom:15px;gap:15px}.modal-header h2{white-space:nowrap;flex-shrink:0}.close-btn{color:var(--fg-muted);font-size:38px;font-weight:700;cursor:pointer;flex-shrink:0;transition:all var(--duration) var(--ease)}.close-btn:hover{color:var(--accent)}.modal-controls{padding:12px 0;display:flex;flex-wrap:wrap;gap:10px}.modal-user-list,.modal-product-list{overflow-y:auto;flex-grow:1}.modal-entry{padding:14px 16px;border-bottom:1px solid var(--border);font-size:18px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;border-radius:var(--radius-md);margin:4px 0;transition:all var(--duration) var(--ease)}.modal-entry:hover{background:var(--accent-soft)}.modal-entry-info{flex-grow:1;font-weight:700;display:grid;grid-template-columns:2fr 1fr 1fr;gap:15px;align-items:center}.modal-entry-info.highlight{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-md);padding:8px;margin:-5px}.modal.admin-mode .modal-entry-info{grid-template-columns:2fr 1fr .7fr 1fr 1.2fr}.modal-product-list .action-icons{display:flex}.modal-product-list .modal-entry{flex-wrap:nowrap;gap:15px}.modal-product-list .modal-entry-info{display:flex;align-items:center;gap:12px;flex:1}.user-filter-buttons{display:flex;gap:8px;flex-shrink:0}.filter-btn{padding:8px 14px;font-size:13px;font-weight:600;border:1px solid var(--accent);background:var(--bg-raised);color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap}.filter-btn:hover{background:var(--gradient-primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.filter-btn:active{transform:translateY(0)}.filter-btn.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}#search-user-input,#admin-search-user-input,.modal-controls #search-history-input{flex-grow:1;font-size:18px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid #d0cfc8;background:#fff;color:#1a1a2e;font-family:var(--font-body);transition:all var(--duration) var(--ease)}#search-user-input:focus,#admin-search-user-input:focus,.modal-controls #search-history-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}.edit-user-modal{width:95%;max-width:520px}.edit-user-form{display:flex;flex-direction:column;gap:16px;padding:10px 0}.edit-user-form .form-group{display:flex;flex-direction:column;gap:6px}.edit-user-form label{font-size:14px;font-weight:700;color:var(--fg-soft)}.edit-user-form input,.edit-user-form select{padding:12px 14px;border-radius:var(--radius-md);border:1px solid #d0cfc8;font-size:16px;background:#fff;color:#1a1a2e;transition:all var(--duration) var(--ease)}.edit-user-form input:focus,.edit-user-form select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}.inline-input-row{display:flex;gap:10px;flex-wrap:wrap}.preset-buttons{display:flex;gap:8px;flex-wrap:wrap}.preset-btn{padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-raised);color:var(--text, #1e293b);cursor:pointer;font-weight:600;transition:all var(--duration) var(--ease)}.preset-btn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}.form-row{display:flex;gap:12px;flex-wrap:wrap}.form-row .half{flex:1;min-width:180px}.user-list-header{display:grid;grid-template-columns:2fr 1fr 1fr;gap:15px;padding:10px 15px;border-bottom:1px solid var(--border);margin:0 15px;background:var(--bg-inset);border-radius:var(--radius-md) var(--radius-md) 0 0}.modal.admin-mode .user-list-header{grid-template-columns:2fr 1fr .7fr 1fr 1.2fr}.sort-header{font-size:14px;font-weight:700;color:var(--fg-soft);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;padding:4px 0;position:relative;transition:color var(--duration) var(--ease)}.sort-header:hover{color:var(--accent)}.user-list-header>div:nth-child(2){text-align:center}.user-list-header>div:nth-child(3),.user-list-header>div.static-header{text-align:right}.static-header{font-size:14px;font-weight:700;color:var(--fg-soft);text-transform:uppercase;letter-spacing:.05em;padding:4px 0;display:none}.sort-header.active{color:var(--accent)}.sort-header.active:after{content:" ▼";font-size:.8em;position:absolute}.sort-btn.active{background:var(--gradient-primary);color:#fff;border-color:var(--accent)}.user-list-name{text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-list-number{text-align:center;color:var(--fg-soft);font-size:.9em}.user-list-balance{text-align:right;font-family:var(--font-body);font-weight:600}.user-list-balance.positive{color:var(--success-color)}.user-list-balance.negative{color:var(--danger-color)}.action-icons{display:flex;align-items:center;gap:10px;justify-content:flex-end;display:none}.badge-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:15px}.badge-category-list{display:flex;flex-direction:column;gap:12px;max-height:70vh;overflow-y:auto;padding-right:6px}.badge-section{border:1px solid var(--border);border-radius:var(--radius-lg);padding:8px 12px;background:var(--bg-raised)}.badge-section summary{font-weight:700;font-size:15px;cursor:pointer;list-style:none;color:var(--fg);transition:color var(--duration) var(--ease)}.badge-section[open] summary{color:var(--accent)}.badge-section summary::-webkit-details-marker{display:none}.badge-option{padding:12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-raised);cursor:pointer;font-weight:600;transition:all var(--duration) var(--ease)}.badge-option:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px);box-shadow:var(--shadow-md)}.badge-option.image-badge{padding:10px}.badge-option.image-badge img{width:90px;height:90px;object-fit:contain;display:block;margin:0 auto}.badge-panel{flex:0 0 320px;min-width:280px;background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px}.badge-panel h3{margin-bottom:12px;font-size:18px;text-align:center}.flango-status-layout{display:flex;gap:20px;align-items:flex-start;padding:0 10px;flex-wrap:wrap}.product-summary-line{font-size:14px;color:var(--fg-soft);margin:6px 0}.flango-stats-breakdown{width:100%;background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;margin-bottom:18px}.flango-stats-breakdown .stats-section{margin-bottom:12px}.flango-stats-breakdown h4{margin:0 0 4px;font-size:16px;color:var(--accent)}.flango-stats-breakdown ul{margin:0;padding-left:18px;font-size:14px;color:var(--fg)}.flango-stats-breakdown li{margin-bottom:4px}.badge-coverflow{display:flex;align-items:center;gap:10px}.coverflow-nav{width:40px;height:40px;border-radius:50%;border:none;background:var(--gradient-primary);font-size:18px;cursor:pointer;flex-shrink:0;box-shadow:var(--shadow-md);color:#fff;transition:all var(--duration) var(--ease)}.coverflow-nav:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}.coverflow-stage{flex:1;perspective:1100px;height:240px;position:relative;touch-action:pan-y;overflow:hidden}.coverflow-track{position:relative;width:100%;height:100%;transform-style:preserve-3d}.coverflow-slide{position:absolute;top:45%;left:50%;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.25,.46,.45,.94),opacity .45s ease,filter .45s ease;opacity:0;pointer-events:none}.coverflow-slide .badge-display-item{width:180px;max-width:180px}.coverflow-slide .badge-display-item img{width:94%;height:94%}.coverflow-slide.state-center{transform:translate(-50%,-50%) translateZ(90px);opacity:1;filter:blur(0);z-index:3;pointer-events:auto}.coverflow-slide.state-left{transform:translate(-115%,-50%) rotateY(28deg) translateZ(-55px);opacity:.65;filter:blur(1px);z-index:2}.coverflow-slide.state-right{transform:translate(15%,-50%) rotateY(-28deg) translateZ(-55px);opacity:.65;filter:blur(1px);z-index:2}.coverflow-slide.state-hidden{opacity:0;transform:translate(-50%,-50%) translateZ(-160px);filter:blur(4px);z-index:1}.badge-display-item{width:140px;max-width:140px;aspect-ratio:1/1;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background:transparent;margin:0 auto}.badge-display-item img{width:88%;height:88%;object-fit:contain}.badge-display-pill{font-size:14px;padding:6px;text-align:center}.badge-empty{opacity:.2;background:var(--bg-inset)}.status-text{flex:1;display:flex;gap:16px;align-items:center}.status-avatar{width:120px;height:auto;flex-shrink:0}.status-level-description{font-size:15px;color:var(--fg-soft);margin:4px 0 12px}.custom-icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-top:10px}.custom-icon-option{border:1px solid var(--border);border-radius:var(--radius-md);padding:10px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;background:var(--bg-raised);transition:all var(--duration) var(--ease)}.custom-icon-option img{width:48px;height:48px;object-fit:contain}.custom-icon-option:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px)}.custom-icon-option.selected{border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26;background:var(--accent-soft)}.allergen-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:8px 12px;margin:6px 0 12px}.allergen-option{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--fg)}.allergen-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}.refill-row{display:flex;align-items:center;gap:12px;margin:6px 0 12px;flex-wrap:wrap}.refill-option{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--fg)}.refill-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.refill-price-input{min-width:160px;flex:0 0 auto}.refill-fields{display:grid;gap:10px;margin:0 0 12px}.refill-fields.hidden{display:none}.refill-field{display:flex;flex-direction:column;gap:4px}.refill-field label{font-size:14px;color:var(--fg)}.refill-field input[type=number]{width:100%;box-sizing:border-box}.refill-help{font-size:12px;color:var(--fg-muted);min-height:16px}.balance-display{font-weight:700;font-size:15px;color:var(--fg)}.modal.admin-mode .static-header,.modal.admin-mode .action-icons{display:flex}.admin-action-column{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.admin-action-btn{font-size:14px;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-raised);cursor:pointer;font-family:inherit;font-weight:600;color:var(--fg);transition:all var(--duration) var(--ease)}.admin-action-btn:hover{transform:translateY(-1px)}.admin-action-btn[data-user-action=deposit]{color:var(--success-color);border-color:#2a8a4a66}.admin-action-btn[data-user-action=deposit]:hover{background:#2a8a4a14}.admin-action-btn[data-user-action=edit]{color:var(--accent);border-color:#1a8a6e66}.admin-action-btn[data-user-action=edit]:hover{background:var(--accent-soft)}.admin-action-btn[data-user-action=delete]{color:var(--danger-color);border-color:#c4404066}.admin-action-btn[data-user-action=delete]:hover{background:#c440400f}.action-icon{font-size:24px;cursor:pointer;padding:5px 10px;border-radius:var(--radius-sm);transition:all var(--duration) var(--ease)}.action-icon:hover{transform:scale(1.15)}.delete-icon{color:var(--danger-color)}.edit-icon{color:var(--accent)}.login-user-entry{padding:16px;border-bottom:1px solid var(--border);cursor:pointer;font-size:20px;text-align:center;font-weight:700;border-radius:var(--radius-md);margin:4px 0;transition:all var(--duration) var(--ease)}.login-user-entry:hover{background:var(--accent-soft)}#add-btn-modal{width:100%;background:var(--success-gradient);color:#fff;padding:16px;font-size:20px;font-family:var(--font-body);border:none;border-radius:var(--radius-md);cursor:pointer;margin:15px 0 5px;font-weight:700;box-shadow:var(--shadow-md);transition:all var(--duration) var(--ease)}#add-btn-modal:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.checkout-block-icon,.custom-alert-icon-circle{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 16px}.checkout-block-icon.danger,.custom-alert-icon-circle.danger{background:#fdf0f0}.checkout-block-icon.warning,.custom-alert-icon-circle.warning{background:#fdf8ec}.checkout-block-icon.allergen,.custom-alert-icon-circle.allergen{background:#fff3e0}.checkout-block-icon.diet,.custom-alert-icon-circle.diet{background:#f3e8ff}.checkout-block-message{text-align:center;font-size:16px;color:var(--fg-soft);line-height:1.6;padding:0 16px}.checkout-block-message strong{color:var(--fg)}.checkout-block-detail{margin-top:16px;padding:12px 16px;background:var(--bg-inset);border-radius:var(--radius-md);font-size:14px;color:var(--fg-soft);text-align:center}.allergen-products{display:flex;flex-direction:column;gap:8px;margin-top:16px}.allergen-product-row{display:flex;align-items:center;gap:12px;padding:12px;background:#fff8f0;border:1px solid #fde0c0;border-radius:var(--radius-md)}.allergen-product-row .ap-icon{font-size:1.3rem}.allergen-product-row .ap-name{font-weight:600;font-size:14px;flex:1}.allergen-product-row .ap-allergens{font-size:12px;color:#fb923c;font-weight:600}#custom-alert-modal{position:fixed;inset:0;background:#0f172a66;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;min-height:100vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg-inset);z-index:var(--z-alert)}#custom-alert-modal::-webkit-scrollbar{width:10px}#custom-alert-modal::-webkit-scrollbar-track{background:var(--bg-inset);border-radius:999px}#custom-alert-modal::-webkit-scrollbar-thumb{background:var(--gradient-primary);border-radius:999px}#custom-alert-content{background:var(--bg-raised);padding:32px;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:left;max-width:640px;width:min(95vw,640px);max-height:calc(100vh - 120px);overflow-y:auto;border:1px solid var(--border);position:relative;transform:translateY(-80px);opacity:0;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .45s ease}#custom-alert-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);border-radius:var(--radius-xl) var(--radius-xl) 0 0}#custom-alert-content::-webkit-scrollbar{width:8px}#custom-alert-content::-webkit-scrollbar-thumb{background:var(--gradient-primary);border-radius:999px}#custom-alert-content::-webkit-scrollbar-track{background:var(--bg-inset);border-radius:999px}#custom-alert-modal.dropdown-active #custom-alert-content{transform:translateY(0);opacity:1}#custom-alert-title{font-family:var(--font-heading);font-size:32px;color:var(--accent);-webkit-text-fill-color:var(--accent);background:none;-webkit-background-clip:unset;background-clip:unset;margin-bottom:15px}#custom-alert-body{font-family:var(--font-body);font-size:20px;line-height:1.6;margin-bottom:30px;color:var(--fg)}#custom-alert-body strong{color:var(--accent)}#custom-alert-buttons{display:flex;justify-content:center;gap:15px}#custom-alert-buttons button{min-width:120px;padding:14px 28px;font-size:18px;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--duration) var(--ease);font-family:var(--font-body);font-weight:700}#custom-alert-buttons button:hover{transform:translateY(-2px)}#custom-alert-ok{background:var(--success-gradient);color:#fff;box-shadow:var(--shadow-md)}#custom-alert-ok:hover{box-shadow:var(--shadow-lg)}#custom-alert-cancel{background:linear-gradient(135deg,#8888a4,#6b6b84);color:#fff;box-shadow:var(--shadow-md)}#custom-alert-cancel:hover{box-shadow:var(--shadow-lg)}#custom-alert-content:has(.confirm-modal-header) #custom-alert-title{display:none}.confirm-modal-header{text-align:center;margin-bottom:16px}.confirm-modal-header h3{font-family:var(--font-heading);font-size:24px;font-weight:600;color:var(--accent);margin:0 0 4px}.confirm-modal-header .confirm-customer-row{display:flex;align-items:center;justify-content:center;gap:10px}.confirm-modal-header .confirm-customer-avatar{width:40px;height:40px;min-width:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent, #1a8a6e) 0%,#0d6b56 100%);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;overflow:hidden;box-shadow:0 2px 8px #0000001f}.confirm-modal-header .confirm-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.confirm-modal-header .customer-highlight{color:var(--fg-soft);font-weight:700;font-size:18px}.confirm-modal-products{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.confirm-product-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-inset);border-radius:var(--radius-md);border:1px solid var(--border)}.confirm-product-row .cp-icon{font-size:1.8rem;width:44px;text-align:center;flex-shrink:0}.confirm-product-row .cp-icon img{width:44px;height:44px;object-fit:contain}.confirm-product-row .cp-info{flex:1;min-width:0}.confirm-product-row .cp-name{font-size:15px;font-weight:600;color:var(--fg)}.confirm-product-row .cp-qty{font-size:12px;color:var(--fg-soft)}.confirm-product-row .cp-price{font-size:15px;font-weight:700;color:var(--fg);text-align:right;white-space:nowrap}.confirm-discount-row{display:flex;align-items:center;gap:12px;padding:4px 12px;color:var(--fg-soft);font-size:13px}.confirm-modal-summary{margin-top:8px;padding-top:14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.confirm-summary-row{display:flex;justify-content:space-between;font-size:14px}.confirm-summary-row .label{color:var(--fg-soft)}.confirm-summary-row .value{color:var(--fg);font-weight:600}.confirm-summary-row.total{font-size:20px;font-weight:700}.confirm-summary-row .value.positive{color:var(--success-color, #10b981)}.confirm-summary-row .value.negative{color:var(--danger-color, #ef4444)}.confirm-negative-warning{background:linear-gradient(135deg,#ef44440f,#ef44441a);color:#991b1b;padding:10px;border-radius:var(--radius-md);margin-top:8px;border:1px solid rgba(239,68,68,.15);font-size:14px}.confirm-restaurant-section{margin-top:12px;padding-top:14px;border-top:1px solid var(--border, #e5e7eb)}.confirm-restaurant-label{font-size:13px;font-weight:700;color:var(--fg-soft, #6b7280);text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px;display:flex;align-items:center;gap:6px}.confirm-table-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.confirm-table-grid-compact{gap:6px}.confirm-table-btn{padding:14px 8px;border:2px solid var(--border, #e5e7eb);border-radius:var(--radius-md, 12px);background:var(--bg-inset, #f9fafb);font-size:18px;font-weight:700;color:var(--fg, #374151);cursor:pointer;transition:all .15s;text-align:center;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.confirm-table-btn:hover{border-color:#d1d5db;background:#f3f4f6}.confirm-table-btn:active{transform:scale(.95)}.confirm-table-btn.selected{border-color:#f59e0b;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;box-shadow:0 2px 8px #f59e0b40}.confirm-table-btn.compact{padding:10px 4px;font-size:15px;border-radius:10px;border-width:1.5px}.confirm-table-btn.compact.selected{border-width:2px}.confirm-kitchen-note{width:100%;padding:10px 12px;border:2px solid var(--border, #e5e7eb);border-radius:var(--radius-md, 10px);font-size:14px;resize:none;font-family:inherit;outline:none;transition:border-color .2s;box-sizing:border-box}.confirm-kitchen-note:focus{border-color:#f59e0b}.confirm-kitchen-note::placeholder{color:#9ca3af}#custom-alert-content:has(.confirm-modal-header) #custom-alert-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px}#custom-alert-content:has(.confirm-modal-header) #custom-alert-buttons button{width:100%;min-width:unset}#custom-alert-content:has(.confirm-modal-header) #custom-alert-cancel{order:-1}.admin-free-confirm-box{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#1a8a6e14,#1a8a6e26);padding:10px 16px;border-radius:var(--radius-md);font-weight:700;font-size:16px;color:var(--accent);margin-bottom:4px;border:1px solid rgba(26,138,110,.15)}.settings-section{margin-bottom:20px}.settings-section .item{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.settings-section label{flex-grow:1;font-size:16px;cursor:pointer}.play-sound-btn{cursor:pointer;font-size:20px;margin-left:15px}#assortment-list .item{cursor:grab}.sortable-ghost{opacity:.4;background:var(--accent-soft)}.sale-items-list{list-style:none;padding-left:20px;margin-top:8px;font-size:14px;color:var(--fg-soft);width:100%}.sale-items-list li{display:flex;justify-content:space-between}#sales-summary{padding:16px;background:var(--bg-inset);border-bottom:1px solid var(--border);text-align:center}.report-buttons{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding:12px;border-bottom:1px solid var(--border)}.history-scroll-container{overflow-y:auto;max-height:calc(80vh - 260px)}#sales-history-list{overflow:visible}.report-buttons .action-button{width:auto;padding:10px 14px;font-size:14px;margin-bottom:0;border-radius:var(--radius-sm)}.report-buttons .btn-all-balances{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.report-buttons .btn-all-balances:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.report-buttons .btn-filter{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.report-buttons .btn-filter:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.report-buttons .btn-undo-last-sale{background:var(--danger-gradient);color:#fff;box-shadow:var(--shadow-md)}.report-buttons .btn-undo-last-sale:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.history-filter-panel{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;margin:0 12px 10px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center}.history-filter-panel .filter-actions{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap;justify-content:center}.history-filter-panel .filter-actions .action-button{width:auto;padding:10px 14px;font-size:14px;margin-bottom:0}.history-filter-panel .filter-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 18px;width:100%;max-width:720px}.history-filter-panel .filter-column{display:flex;flex-direction:column;gap:8px}.history-filter-panel label{display:flex;align-items:center;gap:8px;font-size:14px}.date-filter{display:flex;gap:10px;justify-content:center;align-items:center;padding:12px;background:var(--bg-inset)}#product-form-fields{display:flex;flex-direction:column;gap:15px;padding:15px 0}#product-form-fields input{font-size:18px;padding:14px;border-radius:var(--radius-md);border:1px solid #d0cfc8;font-family:var(--font-body);background:#fff;color:#1a1a2e;transition:all var(--duration) var(--ease)}#product-form-fields input::placeholder{color:#8888a4}#product-form-fields input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}#product-form-fields .collapsible-header{color:var(--fg)!important}.icon-type-btn{color:var(--fg-soft)!important}.icon-type-btn.active{color:var(--fg)!important}#product-form-fields h4{margin:10px 0 0;font-family:var(--font-body);font-weight:700;color:var(--fg-soft);font-size:16px}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:10px;padding:12px 10px 16px;overflow-y:auto}.emoji-grid span{font-size:28px;cursor:pointer;text-align:center;padding:8px;border-radius:var(--radius-sm);transition:all var(--duration) var(--ease)}.emoji-grid span:hover{background:var(--accent-soft);transform:scale(1.1)}#user-form-fields{display:flex;flex-direction:column;gap:15px;padding:15px 0}#user-form-fields input,#user-form-fields select{font-size:18px;padding:14px;border-radius:var(--radius-md);border:1px solid var(--border-strong);font-family:var(--font-body);background:var(--bg-raised);transition:all var(--duration) var(--ease)}#user-form-fields input:focus,#user-form-fields select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}#balance-form-fields{display:flex;flex-direction:column;gap:15px;padding:15px 0}#balance-form-fields input{font-size:24px;padding:14px;border-radius:var(--radius-md);border:1px solid var(--border-strong);font-family:var(--font-body);text-align:center;background:var(--bg-raised);transition:all var(--duration) var(--ease)}#balance-form-fields input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}#balance-form-fields p{margin:0;padding:12px;background:var(--bg-inset);border-radius:var(--radius-md);border:1px solid var(--border)}#pin-display{background:var(--bg-inset);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:24px;font-size:32px;text-align:center;margin:20px 0;letter-spacing:12px;font-family:monospace;height:60px;box-sizing:border-box;color:var(--accent)}#pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.keypad-btn{padding:22px;font-size:28px;font-weight:700;border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--bg-raised);cursor:pointer;transition:all var(--duration) var(--ease);color:var(--fg)}.keypad-btn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px)}.keypad-btn:active{background:#1a8a6e26;transform:translateY(0)}.keypad-action{background:var(--bg-inset);font-size:24px}.feedback-section{padding:12px;text-align:center}.feedback-prompt{font-size:16px;line-height:1.5;color:var(--fg-soft);margin-bottom:15px;max-width:450px;margin-left:auto;margin-right:auto}.sticky-note{background:linear-gradient(145deg,#fef9ee,#fdf6e4);padding:24px;box-shadow:var(--shadow-lg);transform:none;transition:all var(--duration) var(--ease);margin:10px auto;max-width:360px;border-radius:var(--radius-md);border:1px solid var(--border)}.sticky-note:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0000001a}.sticky-note-textarea{width:100%;border:none;background:transparent;font-size:20px;line-height:1.4;margin-top:10px;resize:none;height:90px;outline:none;font-family:Caveat,cursive;color:#374151}.sticky-note-button{font-size:20px;padding:8px 18px;border:2px solid #374151;background:transparent;cursor:pointer;margin-top:10px;border-radius:var(--radius-sm);font-family:Caveat,cursive;transition:all var(--duration) var(--ease)}.sticky-note-button:hover{background:#374151;color:#fef9c3}.sticky-note-text{font-size:20px;margin-top:8px;color:#374151;font-family:Caveat,cursive}.simple-badge-row{display:flex;flex-wrap:nowrap;gap:10px;justify-content:flex-start;padding:12px 0;overflow-x:auto}.simple-badge-row.compact{flex-wrap:wrap;gap:8px;overflow-x:visible}.simple-badge-item{display:flex;flex-direction:column;align-items:center;min-width:120px}.badge-item-wrapper{position:relative;display:inline-flex}.badge-remove-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;border:none;background:var(--danger-gradient);color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #c4404066;transition:all var(--duration) var(--ease)}.badge-remove-btn:hover{transform:scale(1.1)}.simple-badge-item.compact{min-width:90px}.simple-badge-item .badge-display-item{width:110px;max-width:110px}.simple-badge-row.compact .simple-badge-item .badge-display-item{width:80px;max-width:80px}.badge-label{margin-top:6px;font-size:13px;font-weight:600;text-align:center;color:var(--fg)}.simple-badge-row.compact .badge-label{font-size:11px}.badge-remove-btn.compact{width:20px;height:20px;font-size:12px}.no-badges-message{font-size:14px;color:var(--fg-soft);padding:16px;background:var(--bg-inset);border-radius:var(--radius-md);text-align:center;border:1px solid var(--border)}.no-badges-message.small{font-size:12px;padding:10px}.admin-badge-row{margin-top:6px}.assign-badge-note{font-size:13px;color:var(--danger-color);margin:6px 0 0;text-align:left}.settings-modal-close-btn{color:var(--fg)!important;border-color:var(--border-strong)!important}.modal-content,.settings-modal{color:var(--fg)}.admin-role-toggle{display:flex;gap:0;margin-bottom:12px;border-radius:10px;overflow:hidden;border:1px solid rgba(0,0,0,.12);flex-shrink:0;min-height:42px}.admin-role-toggle-btn{flex:1;padding:12px 0;border:none;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s;background:#0000000d;color:#0006;min-height:42px;line-height:1}.admin-role-toggle-btn.active{background:var(--accent, #6366f1);color:#fff}#products{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;background:linear-gradient(180deg,#fef9ee,#fdf6e4);padding:20px;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-card);overflow-y:auto;height:100%;align-content:stretch;grid-auto-rows:1fr;flex:1;min-height:0;position:relative}.product-reorder-hint{font-size:13px;color:var(--fg-muted);margin-bottom:6px;text-align:left;display:none}.product-grid-controls{position:absolute;top:8px;right:8px;display:flex;flex-direction:row;align-items:center;gap:6px;z-index:5;pointer-events:auto}.product-grid-toggle{width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-raised);box-shadow:var(--shadow-sm);cursor:pointer;font-size:16px;transition:all var(--duration) var(--ease)}.product-grid-toggle:hover{background:var(--bg-hover);border-color:var(--border-strong)}.product-reorder-add-btn{display:none;padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-raised);cursor:pointer;font-size:13px;color:var(--fg-soft);transition:all var(--duration) var(--ease)}.product-reorder-add-btn:hover{background:var(--bg-hover)}.product-remove-overlay{position:absolute;left:50%;top:68%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:#ffffffbf;border:2px solid rgba(196,64,64,.35);display:none;align-items:center;justify-content:center;z-index:6;cursor:pointer;pointer-events:auto}.product-remove-x{font-size:28px;font-weight:700;color:#c44040bf}.reorder-mode .product-remove-overlay,.reorder-mode .product-btn.product-placeholder .product-remove-overlay{display:flex}.product-edit-pencil{position:absolute;right:6px;bottom:6px;width:36px;height:36px;border-radius:50%;background:#7c3aede6;display:none;align-items:center;justify-content:center;z-index:7;cursor:pointer;pointer-events:auto;box-shadow:0 2px 6px #0003;transition:transform .15s ease}.product-edit-pencil span{font-size:18px;line-height:1}.product-edit-pencil:active{transform:scale(.9)}body.reorder-mode .product-btn .product-edit-pencil{display:flex!important}body.reorder-mode .product-btn.product-placeholder .product-edit-pencil{display:none!important}.product-btn.product-placeholder{border-style:dashed;border-color:var(--border-strong);background:var(--bg-inset);cursor:default}.product-btn.product-placeholder .placeholder-actions{display:none;flex-direction:column;gap:6px;margin-top:8px}.reorder-mode .product-btn.product-placeholder .placeholder-actions{display:flex}.placeholder-action-btn{border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--bg-raised);padding:6px 10px;cursor:pointer;font-size:12px;color:var(--fg-soft);transition:all var(--duration) var(--ease)}.placeholder-action-btn:hover{background:var(--bg-hover)}body.reorder-mode .product-reorder-hint{display:flex;align-items:center;gap:8px}body.reorder-mode .product-reorder-add-btn{display:inline-flex}#products:has(>.product-btn:nth-child(1):last-child){grid-template-columns:1fr}#products:has(>.product-btn:nth-child(2):last-child){grid-template-columns:repeat(2,1fr)}#products:has(>.product-btn:nth-child(3):last-child){grid-template-columns:repeat(3,1fr)}#products:has(>.product-btn:nth-child(4):last-child){grid-template-columns:repeat(2,1fr)}#products:has(>.product-btn:nth-child(5):last-child){grid-template-columns:repeat(3,1fr)}#products:has(>.product-btn:nth-child(5):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(6):last-child){grid-template-columns:repeat(3,1fr)}#products:has(>.product-btn:nth-child(7):last-child){grid-template-columns:repeat(3,1fr)}#products:has(>.product-btn:nth-child(7):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(7):last-child)>.product-btn:last-child{grid-column:span 2}#products:has(>.product-btn:nth-child(8):last-child){grid-template-columns:repeat(3,1fr)}#products:has(>.product-btn:nth-child(8):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(9):last-child){grid-template-columns:repeat(3,1fr)}#products:has(>.product-btn:nth-child(10):last-child){grid-template-columns:repeat(3,1fr)}#products:has(>.product-btn:nth-child(10):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(10):last-child)>.product-btn:last-child{grid-column:span 2}.product-btn{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:16px;border-radius:var(--radius-lg);border:2px solid transparent;background:#fff4d4;box-shadow:var(--shadow-card);cursor:pointer;transition:all var(--duration) var(--ease);overflow:hidden;height:100%}.product-btn:nth-child(10n+1){background:#fff4d4;border-color:#dcc8784d}.product-btn:nth-child(10n+1):hover{border-color:#dcc87899;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+2){background:#d4f0ea;border-color:#78c8b44d}.product-btn:nth-child(10n+2):hover{border-color:#78c8b499;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+3){background:#d4e8f8;border-color:#78b4dc4d}.product-btn:nth-child(10n+3):hover{border-color:#78b4dc99;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+4){background:#fce4ec;border-color:#dca0b44d}.product-btn:nth-child(10n+4):hover{border-color:#dca0b499;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+5){background:#e8daf8;border-color:#b4a0dc4d}.product-btn:nth-child(10n+5):hover{border-color:#b4a0dc99;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+6){background:#ffe8d4;border-color:#dcb48c4d}.product-btn:nth-child(10n+6):hover{border-color:#dcb48c99;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+7){background:#d4f0ea;border-color:#78c8b44d}.product-btn:nth-child(10n+7):hover{border-color:#78c8b499;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+8){background:#e8daf8;border-color:#b4a0dc4d}.product-btn:nth-child(10n+8):hover{border-color:#b4a0dc99;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+9){background:#fff4d4;border-color:#dcc8784d}.product-btn:nth-child(10n+9):hover{border-color:#dcc87899;box-shadow:var(--shadow-lg)}.product-btn:nth-child(10n+10){background:#d4e8f8;border-color:#78b4dc4d}.product-btn:nth-child(10n+10):hover{border-color:#78b4dc99;box-shadow:var(--shadow-lg)}.product-btn:hover{transform:translateY(-2px)}.product-btn:active{transform:translateY(-1px)}.product-btn.product-refill{border-color:#2a8a4a4d;background:linear-gradient(145deg,#d4f0ea,#b8e6d8);box-shadow:var(--shadow-card)}.product-btn.product-refill:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:#2a8a4a80}.product-btn.product-refill:active{transform:translateY(-1px)}.product-btn.toast-product{position:relative;justify-content:flex-end;padding:5px}.product-btn .product-btn-inner{display:flex;flex-direction:column;gap:8px}.product-btn .avatar-lock-overlay{display:none}.product-btn.product-limit-reached{cursor:not-allowed;filter:saturate(.6)}.product-btn.product-limit-reached .product-btn-inner{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;gap:8px}.product-btn.product-limit-reached .product-icon{z-index:2}.product-btn.product-limit-reached .avatar-lock-overlay{display:flex;position:absolute;inset:0;background:#ffffff80;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-lg)}.product-btn.product-limit-reached .avatar-lock-overlay img{width:100%;height:100%;max-width:180px;max-height:180px;object-fit:contain;opacity:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}.product-btn.product-limit-reached:hover{transform:none}.product-btn.product-limit-reached .product-limit-counter{z-index:50}.product-limit-counter{position:absolute;top:6px;left:50%;transform:translate(-50%);display:none;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1.5px solid #7dd3fc;border-radius:var(--radius-full);padding:2px 10px;font-size:12px;font-weight:700;color:#0369a1;font-family:var(--font-body);z-index:50;pointer-events:auto;cursor:help;box-shadow:0 2px 6px #0ea5e933;white-space:nowrap}.product-limit-counter.visible{display:inline-flex!important;width:auto!important}.product-limit-counter.at-limit{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#f87171;color:#b91c1c;box-shadow:0 2px 6px #ef444440}.limit-tooltip{position:absolute;top:36px;left:50%;transform:translate(-50%);min-width:220px;max-width:280px;padding:12px 14px;background:linear-gradient(135deg,#1e293b,#334155);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000040,0 4px 8px #00000026;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease,transform .2s ease;pointer-events:none}.limit-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-bottom-color:#1e293b}.limit-tooltip.visible{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.limit-tooltip-block{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}.limit-tooltip-block:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.limit-tooltip-source{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:flex;align-items:center;gap:5px}.limit-tooltip-source.club{color:#60a5fa}.limit-tooltip-source.parent{color:#a78bfa}.limit-tooltip-source.sugar{color:#f472b6}.limit-tooltip-source.allergy{color:#fb923c}.limit-tooltip-source.refill{color:#34d399}.limit-tooltip-message{font-size:12px;font-weight:400;color:#f1f5f9;line-height:1.4}.limit-tooltip-message strong{font-weight:600;color:#fff}.limit-tooltip-icon{font-size:11px}.product-emoji{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10vw;z-index:0}.product-icon{width:40px;height:40px;display:block;object-fit:contain;margin:0 auto 6px}.product-btn .product-icon{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;border-radius:calc(var(--radius-lg) - 2px);opacity:1;z-index:0;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.product-icon-small{width:32px;height:32px;object-fit:contain}.product-name{margin-top:8px;font-weight:700;color:var(--fg)}.product-price{font-size:14px;color:var(--fg-soft);font-weight:600}.product-price.refill-price{color:var(--success-color);font-weight:700}.product-shortcut{position:absolute;top:8px;left:8px;width:22px;height:22px;background:var(--success-color);color:#fff;border-radius:var(--radius-sm);display:flex;justify-content:center;align-items:center;font-size:11px;font-weight:800;box-shadow:var(--shadow-sm);z-index:20;line-height:1}.product-quantity-badge{position:absolute;top:6px;right:6px;min-width:22px;height:22px;padding:0 6px;background:var(--danger-color);color:#fff;border-radius:var(--radius-full);display:none;justify-content:center;align-items:center;font-size:12px;font-weight:700;box-shadow:var(--shadow-sm);z-index:15;font-family:var(--font-body);border:2px solid white;gap:2px}.product-quantity-badge .cart-icon{font-size:10px}.product-quantity-badge .cart-qty{font-size:12px;font-weight:700}.product-quantity-badge.visible{display:flex}.product-info-box{display:flex;justify-content:flex-start;align-items:baseline;border-radius:var(--radius-md);z-index:1;position:absolute;gap:8px;min-width:0;background:#0000001f;color:var(--fg);font-weight:700;font-family:var(--font-body);line-height:1;font-size:clamp(12px,1.5vw,16px);padding:clamp(4px,.5vw,8px) clamp(10px,1.4vw,14px);bottom:clamp(6px,1.2vw,10px);left:clamp(6px,1.2vw,10px);right:clamp(6px,1.2vw,10px);box-shadow:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);letter-spacing:.03em;text-transform:uppercase}.product-info-box .product-price{font-size:inherit;font-weight:inherit;color:inherit;margin-left:auto}.product-info-box .product-name,.product-info-box .product-price{position:relative;top:-.2em}.product-info-box .product-name{text-transform:uppercase;letter-spacing:.05em;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.product-name-wrapper{display:inline-flex;align-items:center;gap:4px;flex:1 1 auto;min-width:0}.product-name-wrapper .product-name{flex:1 1 auto;min-width:0}.product-edit-price-wrap{flex:0 0 auto;min-width:0;white-space:nowrap}.reorder-mode .product-name-wrapper{flex:1 1 auto;min-width:0;display:inline-flex;align-items:center;gap:4px}.reorder-mode .product-edit-name{outline:1px dashed rgba(26,26,46,.25);border-radius:4px;padding:2px 4px;min-height:18px;cursor:text;flex:1 1 auto;min-width:0;pointer-events:auto;position:relative;z-index:10;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reorder-mode .product-edit-icon{font-size:.85em;opacity:.6;flex-shrink:0;pointer-events:none;-webkit-user-select:none;user-select:none}.reorder-mode .product-edit-price-wrap{display:inline-flex;align-items:center;gap:4px;flex:0 0 auto;white-space:nowrap}.reorder-mode .product-edit-price-input{width:64px;border:none;background:transparent;font:inherit;color:inherit;outline:1px dashed rgba(26,26,46,.25);border-radius:4px;padding:2px 4px;cursor:text;pointer-events:auto;position:relative;z-index:10}.refill-timer{position:absolute;top:38px;left:50%;transform:translate(-50%);z-index:45;font-size:14px;color:var(--success-color);font-weight:700;padding:4px 10px;background:#edf8f0;border-radius:var(--radius-md);display:flex;align-items:center;gap:5px;justify-content:center;border:1px solid rgba(42,138,74,.3);box-shadow:var(--shadow-sm);white-space:nowrap}.refill-timer .timer-value{font-family:Courier New,monospace;font-weight:800;letter-spacing:1px;font-size:14px}.cart-product-line{display:flex;align-items:center;gap:8px}.cart-product-icon{width:clamp(32px,6vw,48px);height:clamp(32px,6vw,48px);object-fit:contain}.cart-product-emoji{font-size:clamp(24px,5vw,40px)}.cart-remove-icon{width:24px;height:24px;display:inline-block;vertical-align:middle}.user-session-banner{background:transparent;border:none;border-radius:0;padding:0;margin-bottom:12px;display:flex;gap:14px;align-items:stretch;justify-content:center;box-shadow:none}.user-session-banner #logged-in-user{display:none}.session-sticky-note{flex:1;max-width:220px;padding:12px 16px;border-radius:12px;position:relative;text-align:left;font-family:var(--font-body);display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:3px;background:var(--bg-raised, #fff);border:2px solid var(--border, #e2e8f0);box-shadow:0 2px 8px #0000000f}.session-sticky-note:before,.session-sticky-note:after{display:none!important;content:none!important}.session-sticky-note.clerk-note{background:linear-gradient(145deg,#f0fdfa,#ccfbf1);border-color:#14b8a659;transform:none}.session-sticky-note.adult-note{background:linear-gradient(145deg,#faf5ff,#f3e8ff);border-color:#a855f74d;transform:none}.session-sticky-note .sticky-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap}.session-sticky-note.clerk-note .sticky-label{color:#0d9488}.session-sticky-note.adult-note .sticky-label{color:#9333ea}.session-sticky-note .sticky-name{font-size:17px;font-weight:800;color:var(--fg, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.session-cards{display:flex;gap:10px;align-items:stretch;margin-left:auto}.session-cards .session-sticky-note{max-width:200px;padding:8px 14px}#shift-timer-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-full);font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--fg-soft);box-shadow:none;margin:0 4px}#sidebar-logo{width:clamp(70px,8vw,100px);height:auto;display:block;margin:0;filter:none}#flango-logo-button img{object-fit:contain}.sidebar-header-icon{width:clamp(32px,5vw,48px);height:clamp(32px,5vw,48px);object-fit:contain}#selected-user-info{background:transparent;border:none;padding:0;overflow:visible;border-radius:0;margin-bottom:0;display:flex!important;flex-direction:column;gap:14px;text-align:left;position:relative;z-index:10;transform:none;box-shadow:none;font-family:var(--font-body)}#selected-user-info:before,#selected-user-info:after{display:none;content:none}.customer-card{background:#d4e8f8;border-radius:0;padding:6px 16px 6px 130px;margin:0 -20px;min-height:60px;display:flex;align-items:center;gap:10px;box-shadow:none;border:none;position:relative;overflow:visible;z-index:6}.customer-card:before{display:none}.customer-avatar-wrap{position:absolute;left:8px;top:calc(50% - 2px);transform:translateY(-50%);flex-shrink:0;z-index:2}.customer-avatar-ring{width:140px;height:140px;border-radius:50%;background:linear-gradient(145deg,#f7d59c,#f0b860);display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;color:#7a5c1f;border:3.5px solid #5b8cb8;box-shadow:none;-webkit-user-select:none;user-select:none;overflow:hidden}.customer-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.customer-number-badge{position:absolute;bottom:-8px;left:50%;transform:translate(-50%);background:#5b8cb8;color:#fff;font-size:13px;font-weight:700;padding:3px 12px;border-radius:var(--radius-full);border:2.5px solid var(--bg-raised);white-space:nowrap;letter-spacing:1.5px;font-variant-numeric:tabular-nums;box-shadow:0 2px 6px #00000026;font-family:var(--font-body)}.customer-info{flex:1;min-width:0;text-align:center;position:static}.customer-name{font-family:var(--font-body);font-size:14px;font-weight:700;color:#3d6d94;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px;overflow:visible;text-overflow:clip;position:absolute;top:calc(100% + 3px);left:130px;right:0;text-align:center;height:36px;display:flex;align-items:center;justify-content:center;z-index:10}.balance-row{display:flex;gap:5px;margin-top:3px;align-items:center;justify-content:center}.balance-arrow{flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#5b8cb8}.balance-arrow svg{width:18px;height:18px}.balance-col{flex:none;width:85px;text-align:center;padding:3px 4px;border-radius:var(--cart-radius-sm);background:var(--surface-alt);border:1px solid var(--cart-border)}.balance-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-muted);margin-bottom:2px;font-family:var(--font-body)}.balance-val{font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.3px}.balance-new .balance-val{color:var(--accent)}.balance-val.negative{color:var(--danger-color)}.deselect-user-btn{position:absolute!important;top:-10px!important;right:12px!important;left:auto!important;transform:none!important;background:var(--bg-raised)!important;color:var(--ink-muted)!important;border:1px solid var(--cart-border)!important;border-radius:50%!important;width:22px!important;height:22px!important;min-width:22px!important;font-size:13px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;cursor:pointer!important;z-index:15!important;box-shadow:0 1px 3px #0000001a!important}.deselect-user-btn:hover{background:#c440401a!important;color:var(--danger-color)!important}.customer-avatar-empty{opacity:.35;border-color:var(--ink-muted)!important;box-shadow:none;background:linear-gradient(145deg,#e0ddd7,#d5d2cc)!important;color:#999}.customer-name-empty{color:var(--ink-muted);font-style:italic;position:static;padding-bottom:0}#checkout-stack:has(.customer-empty) .customer-empty,#checkout-stack:has(.customer-empty) #total-price,#checkout-stack:has(.customer-empty) .checkout-total-divider,#checkout-stack:has(.customer-empty) #complete-purchase{display:none!important}#checkout-stack:has(.customer-empty){background:transparent;border-top:none;padding:12px 20px}#checkout-stack:has(.customer-empty) #select-customer-main-btn{padding:20px 16px;font-size:18px;border-radius:20px;background:#e3edf7;box-shadow:0 2px 8px #0000000f;border:1.5px solid rgba(43,90,140,.12)}#sidebar:has(.customer-empty) #current-order{border-radius:0 0 24px 24px;overflow:hidden}#selected-user-info.empty-state{padding:16px 18px}#selected-user-info.empty-state .info-box{display:flex;flex-direction:column;gap:4px;text-align:center;padding:12px}#selected-user-info.empty-state .info-box-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-muted)}#selected-user-info.empty-state .info-box-value{font-size:14px;font-weight:500;color:var(--ink-soft)}#user-selection-area{border-top:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}#select-customer-main-btn{background:#e3edf7;color:#2b5a8c;padding:16px 12px;font-size:15px;font-family:var(--font-body);border:1.5px solid transparent;border-radius:var(--cart-radius-md);cursor:pointer;margin-bottom:0;font-weight:700;box-shadow:none;transition:all .13s ease;flex:1;display:flex;align-items:center;justify-content:center;gap:8px}#select-customer-main-btn svg{width:18px;height:18px;flex-shrink:0}#select-customer-main-btn:active{background:#d1e2f0;transform:scale(.98)}#user-selection-actions{display:flex;gap:10px;align-items:stretch}#user-selection-actions button{flex:1}.avatar-carousel-container{display:flex;flex-direction:column;gap:25px;padding-bottom:15px}#avatar-picker-scroll-wrapper{overflow-y:auto;flex-grow:1;padding:15px 10px 0;margin:0 -10px}#avatar-picker-modal .modal-content{max-width:850px}.avatar-row{position:relative}.avatar-row-header{background:var(--accent-soft);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;margin-bottom:10px;box-shadow:var(--shadow-sm)}.avatar-row-title{font-family:var(--font-heading);font-size:18px;font-weight:700;margin:0 0 8px;display:flex;align-items:center;gap:6px;line-height:1.4;color:var(--accent);background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--accent);background-clip:unset}.avatar-row-description{font-size:14px;color:var(--fg-soft);font-weight:400;font-family:var(--font-body);margin:-4px 0 8px;padding-left:10px;max-width:560px}.avatar-row.locked .avatar-scroller{filter:grayscale(90%) brightness(.8)}.avatar-row-lock-overlay{position:absolute;inset:0;background:#fffc;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:3;border-radius:var(--radius-md);color:var(--fg-muted);text-align:center}.avatar-lock-overlay{display:none;position:absolute;inset:0;background:#fffc;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);align-items:center;justify-content:center;z-index:3}.avatar-row.locked .avatar-lock-overlay{display:flex}.avatar-lock-overlay img{width:40px;height:40px;opacity:.8}.avatar-lock-overlay.shake{animation:shake-animation .4s ease-in-out}.avatar-scroller{display:flex;gap:15px;overflow-x:auto;padding:10px;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none}.avatar-scroller::-webkit-scrollbar{display:none}.avatar-row-nav{position:absolute;top:50%;transform:translateY(50%);width:40px;height:40px;border-radius:50%;background:var(--bg-raised);border:1px solid var(--border);box-shadow:var(--shadow-md);font-size:24px;font-weight:700;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;color:var(--accent);transition:all var(--duration) var(--ease)}.avatar-row-nav:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(50%) scale(1.1)}.avatar-row-nav.left{left:15px}.avatar-row-nav.right{right:15px}.avatar-carousel-wrapper{display:flex;align-items:center;justify-content:center;gap:10px}.avatar-scroller-viewport{width:645px;overflow:hidden}.avatar-option{border-radius:var(--radius-lg);position:relative;background:var(--bg-raised);cursor:pointer;transition:all var(--duration) var(--ease);overflow:hidden;border:2px solid var(--border);flex-shrink:0;width:200px;height:200px}.avatar-option.selected{border-color:var(--accent);box-shadow:0 0 0 4px #1a8a6e33,var(--shadow-lg);transform:translateY(-4px);outline:3px solid rgba(26,138,110,.4)}.avatar-option.selected:after{content:"";position:absolute;top:10px;left:10px;width:32px;height:32px;border-radius:50%;background:var(--success-gradient);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2a8a4a66;z-index:3}.avatar-row.locked .avatar-option{cursor:not-allowed}.avatar-option:hover{transform:scale(1.05) translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}.avatar-option img{width:100%;height:100%;object-fit:cover}.avatar-preview-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-raised);font-size:16px;cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--duration) var(--ease);color:var(--fg-soft)}.avatar-preview-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.1)}.avatar-preview-full{width:100%;height:100%;object-fit:contain}.avatar-preview-modal{position:fixed;inset:0;z-index:var(--z-modal-overlay);display:flex;align-items:center;justify-content:center}.avatar-preview-backdrop{position:absolute;inset:0;background:#0f172ab3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.avatar-preview-content{position:relative;max-width:90vw;max-height:90vh}.avatar-preview-content .close-btn{position:absolute;top:-15px;right:-15px;width:40px;height:40px;border-radius:50%;background:var(--bg-raised);color:var(--fg);border:1px solid var(--border);font-size:28px;line-height:1;cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--duration) var(--ease)}.avatar-preview-content .close-btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.avatar-preview-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;border:1px solid var(--border);background:var(--bg-raised);font-size:32px;cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--duration) var(--ease);color:var(--fg-soft)}.avatar-preview-nav:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.avatar-preview-nav.prev{left:-60px}.avatar-preview-nav.next{right:-60px}#logged-in-user-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:none;transition:all var(--duration) var(--ease);box-shadow:none}.user-info-cluster:hover #logged-in-user-avatar{transform:translateY(-1px);box-shadow:var(--shadow-sm)}@keyframes lockFadeIn{0%{opacity:0;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}to{opacity:1;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}}h2{font-family:var(--font-heading);background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--fg);background-clip:unset;color:var(--fg);text-align:left;font-size:clamp(22px,2.6vw,32px);margin:0;font-weight:600;letter-spacing:-.01em}h3{font-family:var(--font-heading);background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--fg);background-clip:unset;color:var(--fg);border-bottom:1px solid var(--border);padding-bottom:10px;margin-top:20px;font-weight:600}#sidebar{background:var(--pos-bg);padding:0;border-radius:var(--cart-radius-lg);border:1px solid var(--cart-border);box-shadow:0 4px 16px #1a1a1814,0 12px 40px #1a1a181a;display:flex;flex-direction:column;position:relative;height:100%;min-height:0;overflow:hidden}#sidebar:after{display:none}.sidebar-main-header{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:#fef9ee;border-radius:var(--radius-md);border:1px solid var(--border);min-height:56px}#logged-in-user{display:none}.institution-info{display:flex;align-items:center;gap:12px;padding-right:20px;border-right:1px solid var(--border, #e2e8f0)}.institution-icon{font-size:28px}.institution-text{display:flex;flex-direction:column}.institution-name{font-family:var(--font-heading);font-weight:700;font-size:20px;color:var(--fg)}.institution-meta{font-size:12px;color:var(--accent, #1a8a6e);font-weight:600;text-transform:uppercase;letter-spacing:1px}.header-actions .shift-timer-pill,.header-actions #shift-timer-pill{margin:0;padding:4px 10px;font-size:12px;font-family:var(--font-body);border-radius:var(--radius-sm);gap:5px;border:1px solid var(--border);background:var(--bg);color:var(--fg-muted);box-shadow:none;height:40px;white-space:nowrap;cursor:pointer;transition:all var(--duration) var(--ease)}.header-actions .shift-timer-pill:hover,.header-actions #shift-timer-pill:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--fg);transform:translateY(-1px)}.user-session-banner{display:flex}.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:1}.header-action-btn{width:52px;height:52px;padding:8px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);cursor:pointer;transition:all var(--duration) var(--ease);box-shadow:none;display:flex;align-items:center;justify-content:center;color:var(--fg-soft)}.header-action-btn:hover{transform:translateY(-1px);background:var(--bg-hover);border-color:var(--border-strong);color:var(--fg)}.header-action-btn:active{transform:translateY(0)}.header-action-btn img{width:34px;height:34px;object-fit:contain}#logged-in-user-avatar-container{width:44px;height:44px;flex-shrink:0;border-radius:50%;background:var(--accent-soft);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:none;transition:all var(--duration) var(--ease);padding:0;order:1;margin-left:8px;overflow:hidden}#logged-in-user-avatar-container img{width:100%;height:100%;object-fit:cover;border-radius:50%}#logged-in-user-avatar-container:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--accent-hover)}#flango-logo-button{position:relative;overflow:visible}#flango-logo-button .beta-ribbon{position:absolute;display:block;top:-2px;right:-8px;background:linear-gradient(135deg,#ff9f43,#f7b731,#ff9f43);color:#5d4037;font-size:7px;font-weight:800;letter-spacing:.5px;padding:2px 12px;border-radius:2px;transform:rotate(35deg);box-shadow:0 1px 2px #00000040,inset 0 1px #fff6;z-index:999;pointer-events:none;text-transform:uppercase;border:1px solid rgba(255,255,255,.3);font-family:system-ui,-apple-system,sans-serif;white-space:nowrap;line-height:1}.login-container .beta-login-sticker{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;margin:-90px auto 10px;background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#5d4037;font-size:14px;font-weight:800;letter-spacing:.6px;border-radius:12px;box-shadow:0 4px 10px #0000001f,inset 0 1px #ffffff80;text-transform:uppercase;width:fit-content;transform:rotate(-2deg);border:1px solid rgba(255,255,255,.45);pointer-events:none}.sidebar-header{position:relative;background:#d4e8f8;padding:20px 22px 16px;margin:0;border-radius:0;border-bottom:1px solid rgba(0,0,0,.06);box-shadow:none;transform:none;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-header:before{display:none}.sidebar-header h2{font-family:var(--font-heading);background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--ink);background-clip:unset;color:var(--ink);font-size:22px;font-weight:700;text-align:left;margin:0;letter-spacing:-.3px;display:flex;align-items:center;gap:0}.sidebar-header-icon{display:none}.sidebar-header h2 .cart-count-badge,.cart-count-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--ink);color:#fff;-webkit-text-fill-color:#fff;background-clip:unset;-webkit-background-clip:unset;font-family:var(--font-body);font-size:13px;font-weight:600;width:24px;height:24px;border-radius:var(--radius-full);margin-left:8px;vertical-align:middle;position:relative;top:-1px;flex-shrink:0}.clear-cart-btn{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-full);border:1.5px solid var(--cart-border-strong);background:var(--bg-raised);color:var(--ink-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:var(--font-body);white-space:nowrap;-webkit-tap-highlight-color:transparent}.clear-cart-btn svg{width:15px;height:15px;flex-shrink:0}.clear-cart-btn:active{background:#0000000d;border-color:var(--ink-muted);transform:scale(.97)}.clear-cart-btn:hover{background:#00000008;color:var(--danger-color)}#current-order{flex:1;min-height:0;display:flex;flex-direction:column;margin:0;padding:0;overflow-y:auto;overflow-x:hidden;background:#fff4d4;border-radius:0;border:none;position:relative;transform:none;box-shadow:none;scrollbar-width:none}#current-order::-webkit-scrollbar{display:none}#current-order:before{display:none}#current-order:after{display:none}#current-order ul{list-style:none;padding:16px 18px;margin:0;display:flex;flex-direction:column;gap:6px}#toolbar-gear-menu{order:0}.sidebar-header{order:1}#current-order{order:2}#selected-user-info{display:none!important;order:99}#checkout-stack{order:3}#current-order li{padding:0;min-height:0;display:flex;border-bottom:none;border-radius:0;margin:0;font-family:var(--font-body);font-size:15px;color:var(--ink);line-height:1.4;list-style:none}.remove-item-btn{font-size:0;cursor:pointer;padding:0;background:transparent;border:none;line-height:1}.remove-item-btn:before{display:none}.remove-item-btn>*{display:none}.cart-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-muted);padding:0 4px;margin-bottom:2px}#current-order li.cart-item,.cart-item{display:flex;align-items:center;gap:14px;padding:14px 18px;background-color:#fff;background-image:none;border-radius:18px;border:none;box-shadow:0 2px 8px #0000000d;transition:all .15s ease;animation:cartSlideIn .25s ease-out backwards}@keyframes cartSlideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.cart-icon-box{width:48px;height:48px;border-radius:12px;background:var(--surface-alt);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;border:1px solid var(--cart-border)}.cart-icon-box .cart-icon-img{width:32px;height:32px;object-fit:contain}.cart-text{flex:1;min-width:0}.cart-item-name{font-size:16px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-unit{font-size:12px;color:var(--ink-muted);margin-top:1px}.cart-item-price{font-size:16px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;margin-right:4px}.cart-remove-btn{width:34px;height:34px;border-radius:var(--radius-full);border:1.5px solid var(--cart-border);background:var(--bg-raised);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent;padding:0;font-size:0}.cart-remove-btn:before{display:none}.cart-remove-btn svg{width:14px;height:14px;color:var(--ink-muted);display:block}.cart-remove-btn:active{background:#c4404014;border-color:var(--danger-color);transform:scale(.92)}.cart-remove-btn:active svg{color:var(--danger-color)}.cart-remove-btn:hover svg{color:var(--danger-color)}#order-list:has(.cart-empty){flex:1}.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:#9ca3af;opacity:.5}.cart-empty-icon{margin-bottom:12px}.cart-empty-icon svg{width:48px;height:48px}.cart-empty-text{font-weight:700;font-size:16px}.admin-free-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--accent-soft);border-radius:var(--cart-radius-md);border:1px solid rgba(26,138,110,.2);font-size:14px;font-weight:600;color:var(--accent)}.cart-discount{background:#fffbeb;border-color:#dcb4784d}#total-price{display:none!important}.checkout-total-divider{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;height:auto;box-sizing:border-box;margin:0 -20px;background:#d4e8f8;border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);position:relative;z-index:2}.checkout-total-spacer{background:#fff4d4;border-color:transparent;height:36px;padding:0;min-height:0;z-index:5}.checkout-total-spacer *{visibility:hidden}.checkout-total-icons{display:flex;align-items:center;gap:4px;flex-wrap:nowrap;flex:1;min-width:0;overflow:hidden}.checkout-total-mini-icon{width:44px;height:44px;border-radius:10px;background:var(--bg-raised);border:1px solid var(--cart-border);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:1;min-width:24px;min-height:24px}.checkout-total-mini-icon img{width:75%;height:75%;object-fit:contain}.checkout-total-plus,.checkout-total-equals{font-size:15px;font-weight:700;color:var(--ink-muted);-webkit-user-select:none;user-select:none}.checkout-total-equals{margin-left:4px}.checkout-total-amount{display:flex;align-items:center;gap:6px;flex-shrink:0}.checkout-total-val{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--ink);letter-spacing:-.5px;font-variant-numeric:tabular-nums;line-height:1;white-space:nowrap}.total-product-summary,.total-text{display:none}#checkout-stack{display:flex;flex-direction:column;gap:4px;margin-top:auto;padding:0 20px 6px;border-top:none;background:#fff4d4;position:relative;overflow:visible}#bottom-buttons{margin-top:0;padding-top:0;display:none}#user-selection-actions{display:flex;gap:10px}.action-button{width:100%;color:#fff;padding:16px 12px;font-size:15px;font-family:var(--font-body);border:none;border-radius:var(--cart-radius-md);cursor:pointer;margin-bottom:0;transition:all .13s ease;font-weight:700;box-shadow:none;display:flex;align-items:center;justify-content:center;gap:8px;-webkit-tap-highlight-color:transparent;letter-spacing:-.1px}.action-button svg{width:18px;height:18px;flex-shrink:0}.action-button:hover{transform:none;box-shadow:none}.action-button:active{transform:scale(.98)}.action-button:disabled{background:var(--cart-border-strong);color:var(--ink-muted);cursor:not-allowed;box-shadow:none;transform:none}#settings-btn{background:var(--gradient-secondary);box-shadow:0 4px 15px #1a8a6e33}#settings-btn:hover{box-shadow:0 6px 20px #1a8a6e4d}#undo-last-sale-btn{background:var(--warning-gradient);box-shadow:0 4px 15px #c48a2033}#undo-last-sale-btn:hover{box-shadow:0 6px 20px #c48a204d}#complete-purchase{background:var(--accent);color:#fff;padding:16px 12px;font-size:15px;margin-bottom:0;box-shadow:0 2px 6px #1a8a6e40;border-radius:var(--cart-radius-md);flex:1}#complete-purchase:active{background:var(--accent-hover);transform:scale(.98);box-shadow:0 1px 3px #1a8a6e4d}#complete-purchase:disabled{background:var(--cart-border-strong);color:var(--ink-muted);box-shadow:none}#admin-panel{margin-top:0;padding-top:0;border-top:none}.admin-btn{background:var(--gradient-primary);box-shadow:0 4px 15px #1a8a6e33}.admin-btn:hover{box-shadow:0 6px 20px #1a8a6e4d}.settings-section:has(#print-negative-balance-btn){display:block}.reorder-mode #products .product-btn{--shake-distance: 1px;animation:shake-animation .55s ease-in-out infinite;cursor:grab}.reorder-mode #products .product-btn:nth-child(3n){animation-duration:.6s;animation-delay:-.05s}.reorder-mode #products .product-btn:nth-child(3n+1){animation-duration:.56s;animation-delay:-.12s}.reorder-mode #products .product-btn:nth-child(3n+2){animation-duration:.62s;animation-delay:-.18s}.reorder-mode #products .product-btn:active{cursor:grabbing}.sound-global-controls{width:100%}.sound-control-section{background:var(--bg);padding:18px;border-radius:var(--radius-md);margin-bottom:16px;border:1px solid var(--border)}.sound-control-section h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--fg);-webkit-text-fill-color:var(--fg);background:none;border-bottom:none;padding-bottom:0}.sound-control-row{margin-bottom:12px}.sound-control-row:last-child{margin-bottom:0}.sound-control-row label{display:block;font-size:14px;font-weight:500;color:var(--fg);margin-bottom:6px}.sound-control-row input[type=checkbox]{margin-right:8px;width:18px;height:18px;cursor:pointer;vertical-align:middle;accent-color:var(--accent)}.sound-control-row input[type=range]{width:100%;height:8px;border-radius:4px;background:var(--bg-inset);outline:none;cursor:pointer}.sound-control-row input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:var(--gradient-primary);cursor:pointer;box-shadow:0 2px 8px #1a8a6e4d}.sound-control-row input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--gradient-primary);cursor:pointer;border:none}#master-volume-display{font-weight:600;color:var(--accent)}.sound-item-extended{border:1px solid var(--border);padding:14px;border-radius:var(--radius-md);margin-bottom:10px;background:var(--bg-raised)}.sound-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sound-item-header label{font-size:14px;font-weight:600;color:var(--fg);margin:0}.sound-item-controls{display:flex;gap:8px;align-items:center}.sound-volume-control{margin-top:8px}.sound-volume-control label{display:block;font-size:13px;font-weight:500;color:var(--fg-muted);margin-bottom:4px}.sound-volume-display{font-weight:600;color:var(--accent)}.sound-volume-slider{width:100%;height:6px;border-radius:3px;background:var(--bg-inset);outline:none;cursor:pointer}.sound-volume-slider::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:var(--success-gradient);cursor:pointer;box-shadow:0 2px 8px #2a8a4a4d}.sound-volume-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--success-gradient);cursor:pointer;border:none}.summary-view-selector{display:flex;gap:12px;margin-bottom:20px;padding:12px;background:var(--bg);border-radius:var(--radius-lg);flex-wrap:wrap;border:1px solid var(--border)}.summary-view-btn{flex:1;min-width:120px;padding:14px 22px;font-size:16px;font-weight:600;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-raised);color:var(--fg-muted);cursor:pointer;transition:all var(--duration) var(--ease);box-shadow:var(--shadow-sm)}.summary-view-btn:hover{background:var(--accent-soft);transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--fg)}.summary-view-btn.active{background:var(--gradient-primary);color:#fff;border-color:var(--accent);box-shadow:0 4px 15px #1a8a6e40}.summary-filters{display:flex;gap:15px;align-items:flex-end;margin-bottom:20px;padding:16px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-size:14px;font-weight:600;color:var(--fg-muted)}.date-input{padding:12px;font-size:16px;border:1px solid #e2e1dc;border-radius:var(--radius-md);background:#fff;transition:all var(--duration) var(--ease);color:#1a1a2e;font-family:var(--font-body)}.date-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a8a6e26}.summary-table-container{flex:1;overflow-y:auto;margin-bottom:20px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-raised);max-height:calc(90vh - 400px)}.summary-table{width:100%;border-collapse:collapse;font-size:15px;font-family:var(--font-body)}.summary-table thead{position:sticky;top:0;background:var(--gradient-primary);color:#fff;z-index:10}.summary-table th{padding:16px 14px;text-align:left;font-weight:700;border-bottom:2px solid var(--accent-hover);white-space:nowrap}.summary-table tbody tr{transition:all var(--duration) var(--ease);border-bottom:1px solid var(--border)}.summary-table tbody tr:hover{background:var(--accent-soft);cursor:pointer}.summary-table td{padding:14px;vertical-align:top;color:var(--fg)}.period-day:nth-child(odd){background:#fff4d459}.period-day:nth-child(2n){background:#fff4d42e}.period-week:nth-child(odd){background:#dbeafe59}.period-week:nth-child(2n){background:#dbeafe2e}.period-month:nth-child(odd){background:#e8f5f080}.period-month:nth-child(2n){background:#e8f5f040}.period-year:nth-child(odd){background:#ede9fe59}.period-year:nth-child(2n){background:#ede9fe2e}.week-separator{border-top:2px solid var(--accent)}.summary-table tfoot{position:sticky;bottom:0;background:var(--gradient-primary);color:#fff;font-weight:700;z-index:10}.summary-table tfoot td{padding:16px 14px;border-top:2px solid var(--accent-hover)}.summary-loading,.summary-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.summary-loading .spinner{border:4px solid var(--border);border-top:4px solid var(--accent);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.summary-loading p{font-size:18px;color:var(--fg-muted);font-weight:600}.summary-error{color:var(--danger-color)}.summary-error p:first-child{font-size:24px;font-weight:700;margin-bottom:10px}.summary-error p:last-child{font-size:16px;color:var(--fg-muted)}.summary-actions{display:flex;gap:12px;padding:16px;background:var(--bg);border-top:1px solid var(--border);border-radius:0 0 var(--radius-md) var(--radius-md);flex-wrap:wrap}.summary-actions .action-button{flex:1;min-width:150px}.secondary-action{background:linear-gradient(135deg,#8888a4,#6b6b84);box-shadow:var(--shadow-md)}.secondary-action:hover{box-shadow:var(--shadow-lg)}.summary-empty{padding:60px 20px;text-align:center;color:var(--fg-muted)}.summary-empty p{font-size:18px;margin-bottom:10px}.summary-empty p:first-child{font-size:48px;margin-bottom:20px}@media(max-width:768px){.summary-view-selector{flex-direction:column}.summary-view-btn{width:100%;min-width:unset}.summary-filters{flex-direction:column;align-items:stretch}.summary-table{font-size:13px}.summary-table th,.summary-table td{padding:10px}.summary-actions{flex-direction:column}}@media(max-width:800px){body{overflow:auto;height:auto}#main-app{grid-template-columns:1fr;grid-template-rows:auto auto;height:auto;padding:10px;gap:10px}#sidebar{min-height:400px}.institution-info,.user-session-banner{display:none}}.role-cluster{display:flex;align-items:center;gap:10px;margin-right:auto;margin-left:16px}.role-card{display:flex;flex-direction:column;background:linear-gradient(145deg,#f0fdfa,#ccfbf1);border:1px solid rgba(20,184,166,.3);padding:6px 14px;border-radius:var(--radius-sm, 8px)}.role-card.adult-role{background:linear-gradient(145deg,#faf5ff,#f3e8ff);border-color:#a855f74d}.role-label{font-size:10px;color:#0d9488;text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:2px}.adult-role .role-label{color:#9333ea}.role-name{font-size:15px;font-weight:700;color:var(--fg, #1e293b);display:flex;align-items:center;gap:6px}.role-stars{font-size:13px}.flango-update-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--success-gradient);color:#fff;border:none;border-radius:var(--radius-full);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--duration) var(--ease);box-shadow:0 4px 12px #2a8a4a40;animation:update-pulse 2s ease-in-out infinite}.flango-update-chip:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2a8a4a59}.flango-update-chip:active{transform:translateY(0)}.update-chip-icon{font-size:16px;animation:update-spin 3s linear infinite}@keyframes update-pulse{0%,to{box-shadow:0 4px 12px #2a8a4a40}50%{box-shadow:0 4px 20px #2a8a4a66}}@keyframes update-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.version-info-panel{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;margin-top:12px}.version-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.version-info-row:last-of-type{border-bottom:none}.version-label{font-size:14px;color:var(--fg-muted)}.version-value{font-size:14px;font-weight:600;color:var(--fg)}.version-value.status-ok{color:var(--success-color)}.version-value.status-update{color:var(--warning-color)}.version-value.status-warning{color:var(--danger-color)}.version-refresh-btn,.version-check-btn{width:100%;padding:14px 18px;margin-top:12px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--duration) var(--ease);font-family:var(--font-body)}.version-refresh-btn{background:var(--success-gradient);color:#fff;box-shadow:0 4px 12px #2a8a4a33}.version-refresh-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2a8a4a4d}.version-refresh-btn:disabled{background:linear-gradient(135deg,#cbd5e1,#94a3b8);cursor:not-allowed;transform:none;box-shadow:none}.version-check-btn{background:var(--bg);color:var(--fg-muted);border:1px solid var(--border)}.version-check-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--fg)}.version-check-btn:disabled{background:var(--bg);color:var(--fg-muted);cursor:not-allowed;opacity:.5}#cafe-event-strip{background:var(--bg-raised);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-card);padding:12px 16px;gap:12px}#cafe-event-strip .cafe-event-card{min-width:200px;max-width:280px;padding:14px 16px;border-radius:var(--radius-lg);font-family:var(--font-body);gap:6px}#cafe-event-strip .cafe-event-title{font-size:14px;font-weight:700;font-family:var(--font-body)}#cafe-event-strip .cafe-event-datetime,#cafe-event-strip .cafe-event-days{font-family:var(--font-body);font-size:12px}#cafe-event-strip .cafe-event-price{font-family:var(--font-body);font-size:13px;font-weight:700}#cafe-event-strip .cafe-event-capacity-text{font-family:var(--font-body);font-size:10px}#cafe-event-strip .cafe-event-badge{font-family:var(--font-body);border-radius:var(--radius-full);font-size:9px}#cafe-event-strip .cafe-event-progress{height:4px;border-radius:var(--radius-full);margin-top:8px}#cafe-event-strip .cafe-event-progress-bar{border-radius:var(--radius-full)}.kitchen-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-raised, var(--bg-raised, #ffffff));border-bottom:1px solid var(--border, var(--border, #e0ddd7));flex-shrink:0}.kitchen-panel-title{font-size:16px;font-weight:800;color:var(--fg, #1a1a2e);font-family:var(--font-body, "DM Sans", sans-serif)}.kitchen-panel-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border-radius:var(--radius-full, 14px);background:var(--accent, #1a8a6e);color:#fff;font-size:14px;font-weight:800}.kitchen-panel-orders{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.kitchen-panel-empty{text-align:center;padding:32px 16px;color:var(--fg-muted, #8888a4);font-size:14px}.kitchen-row-compact{display:flex;align-items:stretch;gap:8px;padding:6px 10px;background:var(--bg-raised, var(--bg-raised, #ffffff));border-radius:var(--radius-md, 8px);min-height:36px;box-shadow:var(--shadow-card, 0 1px 2px rgba(0, 0, 0, .06));transition:opacity .2s}.krc-column{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;justify-content:center}.krc-main{display:flex;align-items:center;gap:8px;min-width:0}.krc-note-text{font-size:11px;color:var(--fg-soft, #64748b);font-family:var(--font-body, "DM Sans", sans-serif);line-height:1.3;word-break:break-word;padding-right:4px}.kitchen-row-compact.served{opacity:.45}.krc-border{width:4px;align-self:stretch;border-radius:2px;flex-shrink:0}.krc-customer{font-size:13px;font-weight:700;color:var(--fg, #1a1a2e);font-family:var(--font-body, "DM Sans", sans-serif);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:70px;max-width:120px}.krc-items{display:flex;align-items:center;gap:4px;flex:1;min-width:0;overflow:hidden}.krc-item{display:inline-flex;align-items:center;gap:1px;font-size:12px;color:var(--fg-soft, #555);font-family:var(--font-body, "DM Sans", sans-serif);white-space:nowrap}.krc-item-icon{width:18px;height:18px;border-radius:3px;object-fit:cover}.krc-item-emoji{font-size:15px}.krc-table{display:inline-flex;align-items:center;padding:1px 6px;background:#1a8a6e1a;color:var(--accent, #1a8a6e);border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0}.krc-note{flex-shrink:0;font-size:13px;cursor:help}.krc-time{font-size:12px;font-weight:700;flex-shrink:0;min-width:40px;text-align:right}.krc-serve{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:2px solid var(--accent, #1a8a6e);background:transparent;color:var(--accent, #1a8a6e);font-size:14px;font-weight:800;cursor:pointer;flex-shrink:0;transition:all .15s;font-family:inherit;padding:0}.krc-serve:hover{background:var(--accent, #1a8a6e);color:#fff}.krc-served-check{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--fg-muted, #8888a4);font-size:14px;font-weight:800;flex-shrink:0}@keyframes shake-animation{0%,to{transform:translate(0)}20%,60%{transform:translate(calc(var(--shake-distance, 4px) * -1))}40%,80%{transform:translate(var(--shake-distance, 4px))}}body.kitchen-fullscreen-mode{overflow:hidden}.kitchen-fullscreen-overlay{position:fixed;inset:0;z-index:9999;background:#f1f5f9;display:flex;flex-direction:column;overflow:hidden;animation:kfsSlideIn .25s ease-out}@keyframes kfsSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.kfs-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;gap:10px;min-height:56px}.kfs-header-left{display:flex;align-items:center;gap:8px;min-width:0;flex-shrink:1}.kfs-logo{font-size:22px}.kfs-title{font-size:17px;font-weight:800;color:#1e293b;white-space:nowrap}.kfs-divider{color:#cbd5e1;font-size:16px}.kfs-inst-name{font-size:13px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.kfs-header-center{display:flex;align-items:center}.kfs-stat-group{display:flex;align-items:center;gap:4px}.kfs-stat{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:16px;font-weight:700;font-size:13px;white-space:nowrap}.kfs-stat-number{font-size:18px;font-weight:800}.kfs-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.kfs-stat-active{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.kfs-stat-total{background:#f1f5f9;color:#475569}.kfs-stat-revenue{background:#f0fdf4;color:#15803d}.kfs-stat-revenue .kfs-stat-number{font-size:15px}.kfs-header-right{display:flex;align-items:center;gap:5px;flex-shrink:0}.kfs-ctrl-btn{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;font-size:13px;font-family:inherit;font-weight:600;color:#475569;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s;touch-action:manipulation;min-height:40px;-webkit-tap-highlight-color:transparent}.kfs-ctrl-btn:hover{background:#e2e8f0;border-color:#cbd5e1}.kfs-ctrl-btn:active{transform:scale(.97)}.kfs-ctrl-back{color:#3b82f6;border-color:#bfdbfe}.kfs-ctrl-back:hover{background:#eff6ff;border-color:#93c5fd}.kfs-content{flex:1;min-height:0;overflow:hidden;display:flex}.kfs-content.layout-bottom{flex-direction:column}.kfs-content.layout-side{flex-direction:row}.kfs-content.layout-hidden,.kfs-content.layout-merged{flex-direction:column}.kfs-zone{display:flex;flex-direction:column;min-height:0;min-width:0}.kfs-content.layout-bottom .kfs-zone-active{flex:2}.kfs-content.layout-bottom .kfs-zone-served{flex:1;border-top:2px solid #e2e8f0}.kfs-content.layout-side .kfs-zone-active{flex:1}.kfs-content.layout-side .kfs-zone-served{flex:1;border-left:2px solid #e2e8f0}.kfs-content.layout-hidden .kfs-zone-active{flex:1}.kfs-content.layout-hidden .kfs-zone-served{display:none}.kfs-content.layout-merged .kfs-zone-active{flex:1}.kfs-content.layout-merged .kfs-zone-served{display:none}.kfs-zone-header{padding:8px 16px;border-bottom:1px solid #e2e8f0;background:#fff;flex-shrink:0}.kfs-zone-header h2{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.kfs-zone-served .kfs-zone-header h2{color:#10b981}.kfs-orders-container{flex:1;min-height:0;overflow:hidden;overflow-y:auto;padding:0;position:relative}.kitchen-fullscreen-overlay .kitchen-table{width:100%;border-collapse:collapse;table-layout:fixed;will-change:transform}.kitchen-fullscreen-overlay .kitchen-table thead th{background:#f8fafc;padding:6px 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;text-align:left;border-bottom:1px solid #e2e8f0;-webkit-user-select:none;user-select:none}.kitchen-fullscreen-overlay .kitchen-table thead th[data-sort-column]{cursor:pointer;transition:color .15s}.kitchen-fullscreen-overlay .kitchen-table thead th[data-sort-column]:hover{color:#f59e0b}.kitchen-fullscreen-overlay .kitchen-table thead th.sort-active{color:#d97706;font-weight:800}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(1),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(1){width:68px}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(2),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(2){width:120px}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(3),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(3){width:55px}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(5),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(5){width:75px}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(6),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(6){width:100px}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(7),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(7){width:140px}.kitchen-fullscreen-overlay .kitchen-row{border-bottom:1px solid #f1f5f9;border-left:4px solid transparent;transition:background .1s}.kitchen-fullscreen-overlay .kitchen-row:hover{background:#f8fafc}.kitchen-fullscreen-overlay .kitchen-row.served{opacity:.5;border-left-color:transparent}.kitchen-fullscreen-overlay .kitchen-row.served:hover{opacity:.7;background:#f0fdf4}.kitchen-fullscreen-overlay .kitchen-row td{padding:8px 10px;vertical-align:middle;font-size:13px}.kitchen-fullscreen-overlay .kitchen-time-relative{font-size:14px;font-weight:800}.kitchen-fullscreen-overlay .kitchen-time-clock{font-size:10px;color:#94a3b8}.kitchen-fullscreen-overlay .kitchen-col-time{white-space:nowrap}.kitchen-fullscreen-overlay .kitchen-col-customer{overflow:hidden}.kitchen-fullscreen-overlay .kitchen-customer-name{font-weight:700;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.kitchen-fullscreen-overlay .kitchen-col-table{font-weight:600;color:#3b82f6;text-align:center}.kitchen-fullscreen-overlay .kitchen-items-wrap{display:flex;flex-wrap:wrap;gap:4px}.kitchen-fullscreen-overlay .kitchen-item-inline{display:inline-flex;align-items:center;gap:3px;background:#f1f5f9;padding:2px 6px;border-radius:5px;font-size:12px;font-weight:500;white-space:nowrap}.kitchen-fullscreen-overlay .kitchen-item-icon{width:16px;height:16px;border-radius:3px;object-fit:cover;vertical-align:middle}.kitchen-fullscreen-overlay .kitchen-item-emoji{font-size:13px}.kitchen-fullscreen-overlay .kitchen-note-row{margin-top:3px;font-size:11px;color:#854d0e;background:#fefce8;padding:1px 5px;border-radius:4px;display:inline-flex;align-items:center;gap:3px;border:1px solid #fde68a}.kitchen-fullscreen-overlay .kitchen-note-text{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kitchen-fullscreen-overlay .kitchen-note-badge{cursor:help}.kitchen-fullscreen-overlay .kitchen-col-amount{font-weight:700;color:#1e293b;text-align:right;white-space:nowrap;font-size:13px}.kitchen-fullscreen-overlay .kitchen-col-server{font-size:12px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kitchen-fullscreen-overlay .kitchen-col-action{text-align:center;display:flex;align-items:center;justify-content:center;gap:10px}.kitchen-fullscreen-overlay .kitchen-serve-btn{padding:6px 10px;background:#f8fafc;color:#374151;border:2px solid #d1d5db;border-radius:8px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap;touch-action:manipulation;min-height:36px;-webkit-tap-highlight-color:transparent}.kitchen-fullscreen-overlay .kitchen-serve-btn:hover{background:#10b981;color:#fff;border-color:#10b981}.kitchen-fullscreen-overlay .kitchen-serve-btn:active{transform:scale(.96)}.kitchen-fullscreen-overlay .kitchen-served-label{color:#10b981;font-size:16px;font-weight:700}.kitchen-fullscreen-overlay .kitchen-delete-btn{display:none}.kitchen-fullscreen-overlay.show-delete-btn .kitchen-delete-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#fef2f2;color:#dc2626;border:2px solid #fecaca;border-radius:8px;font-size:15px;cursor:pointer;transition:all .15s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.kitchen-fullscreen-overlay.show-delete-btn .kitchen-delete-btn:hover{background:#fee2e2;border-color:#f87171}.kitchen-fullscreen-overlay.show-delete-btn .kitchen-delete-btn:active{transform:scale(.96)}.kitchen-fullscreen-overlay .kitchen-empty{text-align:center;padding:32px 16px;font-size:15px;color:#94a3b8;font-weight:500}.kitchen-fullscreen-overlay .kitchen-toast-container{position:absolute;top:70px;right:16px;z-index:100;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:360px;width:100%}.kitchen-fullscreen-overlay .kitchen-toast{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#fff;border-radius:14px;box-shadow:0 8px 30px #00000026,0 2px 8px #0000000f;border-left:4px solid #f59e0b;pointer-events:auto;cursor:pointer;animation:toastSlideIn .35s ease-out;transform-origin:right center}.kitchen-fullscreen-overlay .kitchen-toast-enter{opacity:0;transform:translate(100%)}.kitchen-fullscreen-overlay .kitchen-toast-exit{animation:toastFadeOut .4s ease-in forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastFadeOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(60px)}}.kitchen-fullscreen-overlay .kitchen-toast-icon{font-size:22px;flex-shrink:0;line-height:1}.kitchen-fullscreen-overlay .kitchen-toast-body{flex:1;min-width:0}.kitchen-fullscreen-overlay .kitchen-toast-title{font-size:13px;font-weight:800;color:#1e293b;margin-bottom:2px}.kitchen-fullscreen-overlay .kitchen-toast-subtitle{font-size:12px;font-weight:600;color:#64748b}.kitchen-fullscreen-overlay .kitchen-toast-items{font-size:11px;color:#94a3b8;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kitchen-fullscreen-overlay .kitchen-toast-close{background:none;border:none;font-size:14px;color:#94a3b8;cursor:pointer;padding:2px 4px;line-height:1;flex-shrink:0}.kitchen-fullscreen-overlay .kitchen-toast-close:hover{color:#475569}.kitchen-fullscreen-overlay .kitchen-settings-overlay{position:fixed;top:60px;right:16px;width:320px;max-width:calc(100vw - 32px);background:#fff;border-radius:14px;box-shadow:0 8px 32px #0000002e,0 2px 8px #00000014;z-index:200;overflow:hidden}.kitchen-fullscreen-overlay .kitchen-settings-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:14px;font-weight:700;color:#1e293b}.kitchen-fullscreen-overlay .kitchen-settings-close{background:none;border:none;font-size:16px;color:#94a3b8;cursor:pointer;padding:4px}.kitchen-fullscreen-overlay .kitchen-settings-close:hover{color:#475569}.kitchen-fullscreen-overlay .kitchen-settings-body{padding:16px;display:flex;flex-direction:column;gap:14px}.kitchen-fullscreen-overlay .kitchen-settings-row label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin-bottom:6px}.kitchen-fullscreen-overlay .kitchen-settings-select-row{display:flex;gap:6px}.kitchen-fullscreen-overlay .kitchen-settings-select-row select{flex:1;padding:10px 12px;border:2px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:inherit;background:#fff;outline:none;min-height:44px}.kitchen-fullscreen-overlay .kitchen-settings-select-row select:focus{border-color:#f59e0b}.kitchen-fullscreen-overlay .kitchen-settings-preview{padding:10px 14px;border:2px solid #e5e7eb;border-radius:10px;background:#f8fafc;font-size:14px;cursor:pointer;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;touch-action:manipulation}.kitchen-fullscreen-overlay .kitchen-settings-preview:hover{background:#e2e8f0;border-color:#cbd5e1}.kitchen-fullscreen-overlay .kitchen-settings-divider{height:1px;background:#e2e8f0;margin:2px 0}.kitchen-fullscreen-overlay .kitchen-settings-actions{display:flex;flex-direction:column;gap:8px}.kitchen-fullscreen-overlay .kitchen-settings-action-btn{width:100%;padding:10px 14px;border:2px solid #e5e7eb;border-radius:10px;background:#f8fafc;color:#1e293b;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;min-height:44px;transition:all .15s;touch-action:manipulation}.kitchen-fullscreen-overlay .kitchen-settings-action-btn:hover:not(:disabled){background:#e2e8f0;border-color:#cbd5e1}.kitchen-fullscreen-overlay .kitchen-settings-action-btn:active:not(:disabled){transform:scale(.97)}.kitchen-fullscreen-overlay .kitchen-settings-action-btn:disabled{opacity:.4;cursor:not-allowed}.kitchen-fullscreen-overlay .kitchen-settings-action-serve{color:#16a34a;border-color:#bbf7d0;background:#f0fdf4}.kitchen-fullscreen-overlay .kitchen-settings-action-serve:hover:not(:disabled){background:#dcfce7;border-color:#4ade80}.kitchen-fullscreen-overlay .kitchen-settings-action-clear{color:#d97706;border-color:#fde68a;background:#fffbeb}.kitchen-fullscreen-overlay .kitchen-settings-action-clear:hover:not(:disabled){background:#fef3c7;border-color:#fbbf24}.kitchen-fullscreen-overlay .kitchen-settings-action-reset{color:#dc2626;border-color:#fecaca;background:#fef2f2}.kitchen-fullscreen-overlay .kitchen-settings-action-reset:hover:not(:disabled){background:#fee2e2;border-color:#f87171}@media(max-width:1024px){.kfs-header{padding:8px 12px;gap:8px}.kfs-inst-name,.kfs-divider{display:none}.kfs-stat{padding:5px 10px}.kfs-stat-number{font-size:16px}.kfs-stat-revenue .kfs-stat-number{font-size:14px}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(6),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(6){display:none}}@media(max-width:768px){.kfs-header{flex-wrap:wrap;padding:6px 10px}.kfs-header-left{order:1}.kfs-header-center{order:3;width:100%;justify-content:center;margin-top:2px}.kfs-header-right{order:2;flex-wrap:wrap;gap:4px}.kfs-title{font-size:15px}.kfs-ctrl-btn{padding:6px 10px;font-size:12px;min-height:38px}.kfs-stat{padding:4px 8px}.kfs-stat-number{font-size:14px}.kfs-stat-label{font-size:10px}.kitchen-fullscreen-overlay .kitchen-table th:nth-child(3),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(3),.kitchen-fullscreen-overlay .kitchen-table th:nth-child(6),.kitchen-fullscreen-overlay .kitchen-table td:nth-child(6){display:none}.kitchen-fullscreen-overlay .kitchen-row td{padding:6px 8px;font-size:12px}.kitchen-fullscreen-overlay .kitchen-item-inline{font-size:11px;padding:1px 4px}}@media(min-width:1400px){.kitchen-fullscreen-overlay .kitchen-row td{padding:10px 14px;font-size:14px}.kitchen-fullscreen-overlay .kitchen-time-relative{font-size:16px}.kitchen-fullscreen-overlay .kitchen-serve-btn{padding:8px 14px;font-size:13px}.kfs-stat-number{font-size:22px}}.kfs-content.layout-side .kitchen-table th:nth-child(6),.kfs-content.layout-side .kitchen-table td:nth-child(6){display:none}@media(max-width:1200px){.kfs-content.layout-side .kitchen-table th:nth-child(3),.kfs-content.layout-side .kitchen-table td:nth-child(3){display:none}}.rv-tag{background:#1a8a6e1f;color:#1a8a6e}.rv-tag-remove{color:#1a8a6e}.rv-add-btn{background:var(--accent, #1a8a6e)}.confirm-variant-badge.selected{background:var(--accent, #1a8a6e);border-color:var(--accent, #1a8a6e);color:#fff}.kitchen-item-variant{background:#1a8a6e1f;color:#1a8a6e}.krc-item-variant{color:var(--accent, #1a8a6e)}.kitchen-fullscreen-overlay .kitchen-item-variant{background:#1a8a6e1f;color:#1a8a6e}body.calculator-mode #main-app{grid-template-columns:1fr 320px 380px;grid-template-areas:"header     header      header" "products   calculator  sidebar"}body.calculator-mode #calculator-panel{grid-area:calculator}body.calculator-mode.products-collapsed #main-app{grid-template-columns:1fr 380px;grid-template-areas:"header     header" "calculator sidebar"}body.calculator-mode.products-collapsed #products-area{display:none}.calculator-panel{display:none;flex-direction:column;gap:var(--sp-3, 12px);padding:var(--sp-4, 16px);background:var(--bg-raised, #ffffff);border-left:1px solid var(--border, #e0ddd7);border-right:1px solid var(--border, #e0ddd7);border-radius:var(--radius-lg, 16px);overflow-y:auto}body.calculator-mode .calculator-panel{display:flex}.calc-display{background:var(--bg-inset, #f0efeb);border:1px solid var(--border, #e0ddd7);border-radius:var(--radius-md, 10px);padding:var(--sp-3, 12px) var(--sp-4, 16px);min-height:64px;display:flex;flex-direction:column;justify-content:center;align-items:flex-end}.calc-expression{font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-xl, 22px);font-weight:700;color:var(--fg, #1a1a2e);line-height:1.2;word-break:break-all}.calc-result{font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-sm, 13px);color:var(--fg-muted, #8888a4);min-height:18px}.calc-product-name-section{display:flex;flex-direction:column;gap:var(--sp-1, 4px)}.calc-label{font-size:var(--text-xs, 12px);font-weight:600;color:var(--fg-muted, #8888a4);text-transform:uppercase;letter-spacing:.05em}.calc-name-row{display:flex;flex-wrap:wrap;gap:var(--sp-2, 8px);min-width:0}.calc-name-row>*{min-width:0}.calc-quick-select,.calc-custom-name{flex:1 1 80px;padding:var(--sp-2, 8px) var(--sp-3, 12px);border:1px solid var(--border, #e0ddd7);border-radius:var(--radius-sm, 6px);font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-sm, 13px);background:var(--bg, #f8f7f4);color:var(--fg, #1a1a2e)}.calc-quick-add-btn{width:36px;height:36px;border:1px solid var(--border, #e0ddd7);border-radius:var(--radius-sm, 6px);background:var(--accent-soft, #e8f5f0);color:var(--accent, #1a8a6e);font-weight:700;font-size:var(--text-lg, 18px);cursor:pointer;transition:all .15s ease;flex-shrink:0}.calc-quick-add-btn:hover{background:var(--accent, #1a8a6e);color:#fff}.calc-quick-products{display:flex;flex-wrap:wrap;gap:var(--sp-1, 4px)}.calc-quick-chip{display:inline-flex;align-items:center;gap:4px;padding:var(--sp-1, 4px) var(--sp-2, 8px) var(--sp-1, 4px) var(--sp-3, 12px);border-radius:999px;border:1px solid var(--border, #e0ddd7);background:var(--bg, #f8f7f4);font-size:var(--text-xs, 12px);font-weight:500;color:var(--fg-soft, #555);cursor:pointer;transition:all .15s ease}.calc-quick-chip:hover,.calc-quick-chip.selected{background:var(--accent-soft, #e8f5f0);border-color:var(--accent, #1a8a6e);color:var(--accent, #1a8a6e)}.calc-chip-label{display:inline-flex;align-items:center;gap:2px}.calc-chip-icon{width:16px;height:16px;object-fit:contain;vertical-align:middle;margin-right:2px}.calc-chip-delete{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:13px;line-height:1;color:var(--fg-muted, #999);border-radius:50%;transition:all .15s ease}.calc-chip-delete:hover{color:#e53e3e;background:#e53e3e1f}.calc-quick-create{display:flex;flex-direction:column;gap:var(--sp-2, 8px);padding:var(--sp-3, 12px);background:var(--bg-inset, #f0efeb);border-radius:var(--radius-md, 10px)}.calc-create-top-row{display:flex;gap:var(--sp-2, 8px);align-items:center}.calc-create-top-row input{flex:1;padding:var(--sp-2, 8px) var(--sp-3, 12px);border:1px solid var(--border, #e0ddd7);border-radius:var(--radius-sm, 6px);font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-sm, 13px);background:var(--bg, #f8f7f4);color:var(--fg, #1a1a2e)}.calc-create-selected-emoji{width:40px;height:40px;border:2px solid var(--accent, #1a8a6e);border-radius:var(--radius-sm, 6px);background:var(--bg, #f8f7f4);font-size:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:default;padding:0}.calc-create-selected-emoji img{width:28px;height:28px;object-fit:contain}.calc-emoji-picker{display:flex;flex-wrap:wrap;gap:4px;max-height:140px;overflow-y:auto;padding:var(--sp-1, 4px);background:var(--bg, #f8f7f4);border:1px solid var(--border, #e0ddd7);border-radius:var(--radius-sm, 6px)}.calc-emoji-option{width:34px;height:34px;border:1px solid transparent;border-radius:var(--radius-sm, 6px);background:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s ease;padding:0}.calc-emoji-option:hover{background:var(--bg-hover, #eae9e4);border-color:var(--border, #e0ddd7)}.calc-emoji-option.selected{background:var(--accent-soft, #e8f5f0);border-color:var(--accent, #1a8a6e);box-shadow:0 0 0 1px var(--accent, #1a8a6e)}.calc-icon-option img{width:24px;height:24px;object-fit:contain}.calc-emoji-separator{width:100%;height:1px;background:var(--border, #e0ddd7);margin:2px 0}.calc-create-actions{display:flex;gap:var(--sp-2, 8px);justify-content:flex-end}.calc-quick-save-btn{padding:var(--sp-2, 8px) var(--sp-4, 16px);border:none;border-radius:var(--radius-sm, 6px);background:var(--accent, #1a8a6e);color:#fff;font-weight:600;font-size:var(--text-sm, 13px);cursor:pointer}.calc-quick-cancel-btn{padding:var(--sp-2, 8px) var(--sp-4, 16px);border:1px solid var(--border, #e0ddd7);border-radius:var(--radius-sm, 6px);background:var(--bg, #f8f7f4);color:var(--fg-muted, #8888a4);font-weight:500;font-size:var(--text-sm, 13px);cursor:pointer}.calc-numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-2, 8px)}.calc-numpad-btn{min-height:52px;border:1px solid var(--border, #e0ddd7);border-radius:var(--radius-md, 10px);background:var(--bg, #f8f7f4);font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-lg, 18px);font-weight:600;color:var(--fg, #1a1a2e);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.calc-numpad-btn:hover{background:var(--bg-hover, #eae9e4)}.calc-numpad-btn:active{background:var(--bg-inset, #f0efeb);transform:scale(.94);transition:transform 60ms ease}.calc-numpad-btn.calc-op[data-value=C]{background:#c4404014;color:var(--danger, #c44040);border-color:#c4404033;font-weight:700}.calc-numpad-btn.calc-op[data-value="+"]{background:var(--accent-soft, #e8f5f0);color:var(--accent, #1a8a6e);border-color:#1a8a6e33;font-weight:700}.calc-add-btn{width:100%;padding:var(--sp-3, 12px) var(--sp-4, 16px);border:none;border-radius:var(--radius-md, 10px);background:var(--accent, #1a8a6e);color:#fff;font-family:var(--font-body, "DM Sans", sans-serif);font-size:var(--text-base, 15px);font-weight:700;cursor:pointer;transition:all .15s ease}.calc-add-btn:hover{background:var(--accent-hover, #157a60)}.calc-add-btn:active{transform:scale(.98)}.calc-add-btn:disabled{opacity:.5;cursor:not-allowed}.calc-recent{display:none;flex-direction:column;gap:var(--sp-1, 4px);padding-top:var(--sp-3, 12px);border-top:1px solid var(--border, #e0ddd7)}.calc-recent-label{font-size:var(--text-xs, 12px);font-weight:600;color:var(--fg-muted, #8888a4);text-transform:uppercase;letter-spacing:.05em}.calc-recent-item{font-size:var(--text-xs, 12px);color:var(--fg-soft, #555);padding:var(--sp-1, 4px) 0}body.kitchen-mode #main-app{grid-template-columns:1fr 400px 380px;grid-template-areas:"header     header      header" "products   kitchen     sidebar"}body.kitchen-mode #kitchen-panel{grid-area:kitchen}.kitchen-panel{display:none;flex-direction:column;background:var(--bg-raised, #ffffff);border-left:1px solid var(--border, #e0ddd7);border-right:1px solid var(--border, #e0ddd7);border-radius:var(--radius-lg, 16px);overflow:hidden}body.kitchen-mode .kitchen-panel{display:flex;animation:kitchenSlideIn .3s ease forwards}@keyframes kitchenSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}body.kitchen-mode #products{grid-template-columns:repeat(2,1fr);gap:var(--sp-2, 8px);align-content:start}body.kitchen-mode .product-btn{min-height:70px;aspect-ratio:unset;padding:var(--sp-2, 8px)}body.kitchen-mode .product-btn .pc-icon,body.kitchen-mode .product-btn .product-emoji{font-size:1.75rem}body.kitchen-mode .product-btn .pc-bar{padding:var(--sp-1, 4px) var(--sp-2, 8px);font-size:.65rem}body.kitchen-mode #cafe-event-strip,body.kitchen-mode .product-shortcut{display:none}.calculator-toggle.active{background:var(--accent, #1a8a6e);color:#fff;border-color:var(--accent, #1a8a6e);box-shadow:0 2px 8px #1a8a6e4d}#kitchen-btn.active{background:var(--accent, #1a8a6e);color:#fff;border-color:var(--accent, #1a8a6e);box-shadow:0 2px 8px #1a8a6e4d;border-radius:var(--radius-sm, 6px)}body.calculator-mode #products{grid-template-columns:repeat(2,1fr);gap:var(--sp-2, 8px);align-content:start}body.calculator-mode .product-btn{min-height:80px;aspect-ratio:unset;padding:var(--sp-2, 8px)}body.calculator-mode .product-btn .pc-icon,body.calculator-mode .product-btn .product-emoji{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.08))}body.calculator-mode .product-btn .pc-bar{padding:var(--sp-1, 4px) var(--sp-2, 8px);font-size:.65rem}body.calculator-mode #cafe-event-strip,body.calculator-mode .product-shortcut{display:none}.calculator-products-collapse{display:none;position:fixed;top:50%;transform:translateY(-50%);width:24px;height:60px;background:var(--bg-raised, #ffffff);border:1px solid var(--border, #e0ddd7);border-right:none;border-radius:var(--radius-sm, 6px) 0 0 var(--radius-sm, 6px);cursor:pointer;font-size:var(--text-sm, 13px);color:var(--fg-muted, #8888a4);z-index:10;transition:background .15s ease,color .15s ease,opacity 80ms ease;align-items:center;justify-content:center;padding:0}body.calculator-mode .calculator-products-collapse{display:flex}.calculator-products-collapse:hover{background:var(--bg-hover, #eae9e4);color:var(--fg, #1a1a2e)}.calculator-products-collapse:after{content:"«"}body.calculator-mode.products-collapsed .calculator-products-collapse:after{content:"»"}body.calculator-mode.products-collapsed .calculator-products-collapse{left:0;border-radius:0 var(--radius-sm, 6px) var(--radius-sm, 6px) 0;border:1px solid var(--border, #e0ddd7);border-left:none;height:80px;width:28px}body.calculator-mode.products-collapsed #calculator-panel{max-width:900px;margin:0 auto;gap:var(--sp-5, 20px);padding:var(--sp-6, 24px) var(--sp-8, 32px);justify-content:center}body.calculator-mode.products-collapsed .calc-display{padding:var(--sp-5, 20px) var(--sp-6, 24px);min-height:100px}body.calculator-mode.products-collapsed .calc-expression{font-size:36px}body.calculator-mode.products-collapsed .calc-result{font-size:16px}body.calculator-mode.products-collapsed .calc-numpad{gap:var(--sp-4, 16px)}body.calculator-mode.products-collapsed .calc-numpad-btn{min-height:90px;font-size:28px;border-radius:var(--radius-lg, 16px)}body.calculator-mode.products-collapsed .calc-add-btn{padding:var(--sp-5, 20px);font-size:var(--text-xl, 22px);border-radius:var(--radius-lg, 16px)}body.calculator-mode.products-collapsed .calc-product-name-section{gap:var(--sp-2, 8px)}body.calculator-mode.products-collapsed .calc-label{font-size:var(--text-sm, 13px)}body.calculator-mode.products-collapsed .calc-quick-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--sp-3, 12px)}body.calculator-mode.products-collapsed .calc-quick-chip{padding:var(--sp-3, 12px) var(--sp-5, 20px);font-size:var(--text-base, 15px)}body.calculator-mode.products-collapsed .calc-name-row{flex-wrap:nowrap}body.calculator-mode.products-collapsed .calc-quick-select,body.calculator-mode.products-collapsed .calc-custom-name{font-size:var(--text-lg, 18px);padding:var(--sp-3, 12px) var(--sp-4, 16px)}body.calculator-mode.products-collapsed .calc-quick-add-btn{width:44px;height:44px;font-size:var(--text-xl, 22px)}body.calculator-mode.products-collapsed .calc-recent{display:flex;font-size:var(--text-base, 15px)}body.calculator-mode.products-collapsed .calc-recent-label{font-size:var(--text-sm, 13px)}body.calculator-mode.products-collapsed .calc-recent-item{font-size:var(--text-base, 15px);padding:var(--sp-2, 8px) 0}.pos-body,#main-app{transition:grid-template-columns .3s ease}body.calculator-mode .calculator-panel{animation:calcSlideIn .3s ease forwards}@keyframes calcSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes calcAddSuccess{0%{background:var(--accent, #1a8a6e)}50%{background:var(--success, #2a8a4a);box-shadow:0 0 12px #2a8a4a4d}to{background:var(--accent, #1a8a6e)}}.calc-add-btn.success{animation:calcAddSuccess .4s ease}.calculator-cart-item .cart-item-icon{font-size:1.2rem}@media(max-width:1199px)and (min-width:768px){body.kitchen-mode #main-app{grid-template-columns:1fr 380px;grid-template-areas:"header     header" "products   sidebar"}body.kitchen-mode .kitchen-panel{position:fixed;top:76px;left:12px;bottom:12px;width:min(380px,calc(100vw - 420px));z-index:50;border-radius:var(--radius-lg, 16px);box-shadow:-4px 0 24px #00000026,0 0 0 1px var(--border, #e0ddd7)}}@media(max-width:1024px){body.calculator-mode #main-app{grid-template-columns:1fr 340px;grid-template-areas:"header     header" "calculator sidebar"}body.calculator-mode #products-area{display:none}}@media(max-width:767px){body.calculator-mode .calculator-panel{position:fixed;inset:0;z-index:100;border:none;padding:var(--sp-5, 20px);overflow-y:auto;border-radius:0}body.calculator-mode #products-area,body.calculator-mode #sidebar{display:none}body.kitchen-mode .kitchen-panel{position:fixed;inset:0;z-index:100;border:none;overflow-y:auto;border-radius:0}body.kitchen-mode #products-area,body.kitchen-mode #sidebar{display:none}}.event-admin-modal{max-width:720px;border-radius:16px;box-shadow:0 20px 60px #0000001f,0 0 0 1px #0000000a}.event-admin-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.event-admin-header .event-back-btn{flex-shrink:0;min-width:80px;margin-bottom:0;padding:6px 8px}.event-admin-header .event-back-btn.event-admin-back-hidden{visibility:hidden;pointer-events:none}.event-admin-header .event-admin-title{flex:1;text-align:center;margin:0;padding:0 8px}.event-admin-header .close-btn{flex-shrink:0}.event-view{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.event-back-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;padding:6px 0;margin-bottom:4px;text-align:left;width:fit-content;border-radius:8px;transition:background .15s,color .15s}.event-back-btn:hover{text-decoration:none;background:#4a90d914;color:var(--accent)}.event-filter-bar{display:flex;gap:8px;padding:10px 0 14px;flex-wrap:wrap;align-items:center}.event-filter-btn{padding:8px 16px;border-radius:20px;border:1px solid #e5e7eb;background:#f9fafb;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.event-filter-btn:hover{background:#f3f4f6;border-color:#d1d5db}.event-filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.event-create-btn{margin-left:auto;padding:8px 18px;border-radius:20px;border:none;background:var(--success-color, #27ae60);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:transform .12s,box-shadow .15s,opacity .15s}.event-create-btn:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 4px 12px #27ae6059}.event-list-container{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:4px 0}.event-list-empty{text-align:center;color:#999;padding:40px 20px;font-size:14px}.event-list-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:#fafafa;border:1px solid #f0f0f0;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.event-list-item:hover{background:#f0f4ff;border-color:#4a90d959;box-shadow:0 2px 8px #4a90d914}.event-list-item-info{flex:1;min-width:0}.event-list-item-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-list-item-meta{font-size:12px;color:#777;margin-top:2px}.event-list-item-stats{text-align:right;font-size:12px;color:#555;white-space:nowrap}.event-list-item-stats .event-reg-count{font-weight:600}.event-status-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.35px;-webkit-text-fill-color:initial;-webkit-background-clip:initial;background-clip:initial}.event-status-badge.upcoming{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border:1px solid rgba(5,150,105,.2)}.event-status-badge.cancelled{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border:1px solid rgba(185,28,28,.2)}.event-status-badge.past{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.event-detail-header{padding:8px 0 20px;border-bottom:1px solid rgba(0,0,0,.06);margin-bottom:16px}.event-detail-header .event-description{margin:0 0 10px;padding:10px 12px;font-size:13px;color:#555;line-height:1.5;background:#00000005;border-radius:10px;border-left:3px solid var(--accent)}.event-meta-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.event-meta-badge{display:inline-flex;flex-direction:column;align-items:flex-start;min-width:0;padding:8px 12px;background:linear-gradient(145deg,#f8f9fc,#f0f2f7);border:1px solid rgba(0,0,0,.06);border-radius:10px;box-shadow:0 1px 3px #0000000a}.event-meta-badge-label{font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:.3px;font-weight:600;margin-bottom:2px}.event-meta-badge-value{font-size:14px;font-weight:600;color:#111;line-height:1.3;word-break:break-word}.event-meta-badge:first-child .event-meta-badge-value{color:var(--accent)}.event-detail-summary{display:flex;gap:12px;padding:14px 0 18px;flex-wrap:wrap}.event-summary-card{flex:1;min-width:120px;background:linear-gradient(145deg,#f8f9fc,#f0f2f7);border-radius:12px;padding:14px 16px;text-align:center;border:1px solid rgba(0,0,0,.05);box-shadow:0 2px 8px #0000000a;transition:transform .15s,box-shadow .15s}.event-summary-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.event-summary-card .summary-label{font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:.4px;font-weight:600}.event-summary-card .summary-value{font-size:22px;font-weight:700;margin-top:4px;color:#111;letter-spacing:-.02em}.event-detail-actions{display:flex;gap:10px;padding:12px 0 18px;flex-wrap:wrap}.event-action-btn{padding:10px 18px;border-radius:10px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:transform .12s,box-shadow .15s,opacity .15s}.event-action-btn:hover{transform:translateY(-1px)}.event-action-btn:active{transform:translateY(0)}.event-action-btn.primary{background:var(--accent);color:#fff;box-shadow:0 4px 12px #4a90d959}.event-action-btn.primary:hover{opacity:.92;box-shadow:0 6px 16px #4a90d966}.event-action-btn.secondary{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.event-action-btn.secondary:hover{background:#e5e7eb;border-color:#d1d5db}.event-action-btn.danger{background:#dc2626;color:#fff;box-shadow:0 2px 8px #dc262640}.event-action-btn.danger:hover{opacity:.92;box-shadow:0 4px 12px #dc262659}.event-reg-list{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:0}.event-reg-list>p{padding:24px 16px;font-size:14px;color:#6b7280}.event-reg-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;table-layout:fixed;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000f}.event-reg-table thead{position:sticky;top:0;z-index:2}.event-reg-table th{padding:6px 8px;text-align:left;font-weight:600;font-size:10px;color:#6b7280;background:linear-gradient(180deg,#f9fafb,#f3f4f6);border-bottom:1px solid #e5e7eb;white-space:nowrap;text-transform:uppercase;letter-spacing:.35px}.event-reg-table th.event-reg-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.event-reg-table th.event-reg-sortable:hover{background:#e5e7eb}.event-reg-table .sort-indicator{font-size:10px;margin-left:2px;color:#9ca3af}.event-reg-table tbody tr{transition:background .12s}.event-reg-table tbody tr:nth-child(2n){background:#fafafa}.event-reg-table tbody tr:hover{background:#f0f4ff}.event-reg-table td{padding:5px 8px;vertical-align:middle;border-bottom:1px solid #f3f4f6;line-height:1.25}.event-reg-table .reg-name{font-size:12px;font-weight:600;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-reg-table .reg-number{font-size:11px;color:#6b7280;font-variant-numeric:tabular-nums}.event-reg-table .reg-grade{font-size:11px;text-align:center;color:#6b7280}.event-reg-table .reg-balance{font-size:11px;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.event-reg-table .reg-actions{white-space:normal;padding:4px 8px;vertical-align:middle}.event-reg-actions-inner{display:flex;flex-wrap:wrap;gap:4px;align-items:center;line-height:1}.event-reg-table .reg-unregister{text-align:right;padding:4px 8px;vertical-align:middle;width:7%}.event-reg-unregister-col{text-align:right}.event-reg-table tr.reg-cancelled{opacity:.55;background:#fef2f2}.event-reg-table tr.reg-cancelled:hover{background:#fee2e2}.event-reg-table .event-payment-badge,.event-reg-table .event-reg-status-badge{padding:2px 6px;border-radius:6px;font-size:10px;font-weight:600}.event-payment-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.2px}.event-payment-badge.paid{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border:1px solid rgba(5,150,105,.2)}.event-payment-badge.not_paid{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border:1px solid rgba(185,28,28,.2)}.event-payment-badge.not_required{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.event-payment-badge.refunded{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#3730a3;border:1px solid rgba(67,56,202,.2)}.event-reg-status-badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600}.event-reg-status-badge.registered{background:#e6f4ea;color:#1e7e34}.event-reg-status-badge.cancelled{background:#fde8e8;color:#c0392b}.event-reg-cancel-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border-radius:6px;border:1px solid #dc2626;background:transparent;color:#dc2626;font-size:16px;font-weight:700;line-height:1;cursor:pointer;transition:background .12s,color .12s}.event-reg-cancel-btn:hover{background:#dc2626;color:#fff}.event-reg-pay-btn{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;line-height:1.2;cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.event-reg-pay-btn.manual{border:1px solid #059669;background:transparent;color:#059669}.event-reg-pay-btn.manual:hover{background:#059669;color:#fff}.event-reg-pay-btn.balance{border:1px solid var(--accent);background:transparent;color:var(--accent)}.event-reg-pay-btn.balance:hover{background:var(--accent);color:#fff}.event-reg-pay-btn.disabled,.event-reg-pay-btn:disabled{opacity:.45;cursor:not-allowed;border-color:#d1d5db;background:#f3f4f6;color:#9ca3af}.event-reg-pay-btn.disabled:hover,.event-reg-pay-btn:disabled:hover{opacity:.45;border-color:#d1d5db;background:#f3f4f6;color:#9ca3af}.event-summary-card .summary-sub{font-size:12px;color:#6b7280;margin-top:4px;font-weight:500}.event-reg-list-header{font-size:14px;font-weight:600;color:#374151;margin:0 0 12px;letter-spacing:-.01em;padding-top:4px}.event-form{display:flex;flex-direction:column;gap:10px;padding:8px 0;overflow-y:auto;flex:1}.event-form input[type=text],.event-form input[type=number],.event-form input[type=datetime-local],.event-form textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;box-sizing:border-box;font-family:inherit}.event-form textarea{resize:vertical}.event-form input:focus,.event-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #4a90d926}.event-class-section{margin-top:4px}.event-class-checkboxes{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:6px}.event-class-checkbox{display:flex;align-items:center;gap:4px;font-size:13px;cursor:pointer}.event-class-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.event-form-actions{display:flex;gap:10px;padding-top:8px;justify-content:flex-end}.event-save-btn{padding:10px 24px;border-radius:8px;border:none;background:var(--success-color, #27ae60);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}.event-save-btn:hover{opacity:.85}.event-cancel-btn{padding:10px 24px;border-radius:8px;border:1px solid #ddd;background:#f5f5f5;color:#555;font-size:14px;cursor:pointer;transition:background .15s}.event-cancel-btn:hover{background:#e8e8e8}#cafe-event-strip{display:none;flex-direction:row;gap:10px;padding:8px 12px;background:var(--bg-raised);border-radius:12px;box-shadow:0 0 12px #0000000f;overflow-x:auto;overflow-y:hidden;flex-shrink:0;align-items:stretch;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}#cafe-event-strip::-webkit-scrollbar{height:4px}#cafe-event-strip::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}#cafe-event-strip.visible{display:flex}#products-area.event-strip-active #products{padding:12px;gap:10px}#products-area.event-strip-active #products .product-btn{padding:6px}#products-area.event-strip-active #products .product-name{font-size:12px}#products-area.event-strip-active #products .product-price{font-size:11px}.cafe-event-card{display:flex;flex-direction:column;justify-content:space-between;min-width:160px;max-width:220px;padding:8px 10px;border-radius:10px;background:linear-gradient(145deg,#f8f9fc,#eef1f7);border:1.5px solid #e0e4ec;cursor:pointer;transition:transform .12s,box-shadow .15s,border-color .15s;flex-shrink:0;gap:4px}.cafe-event-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014;border-color:var(--accent)}.cafe-event-card:active{transform:translateY(0)}.cafe-event-card.registered{background:linear-gradient(145deg,#dcfce7,#bbf7d0);border-color:#16a34a59;cursor:default}.cafe-event-card.registered:hover{transform:none;box-shadow:none;border-color:#16a34a59}.cafe-event-card.awaiting-payment{background:linear-gradient(145deg,#fff7ed,#fed7aa);border-color:#ea8a0066;cursor:pointer}.cafe-event-card.awaiting-payment:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ea8a0026;border-color:#ea8a0099}.cafe-event-card.awaiting-payment .cafe-event-title{color:#92400e}.cafe-event-card.awaiting-payment .cafe-event-datetime{color:#b45309}.cafe-event-card.awaiting-payment .cafe-event-price{color:#92400e}.cafe-event-card.awaiting-payment .cafe-event-capacity-text{color:#b45309}.cafe-event-badge.awaiting-payment{background:#ea8a00;color:#fff}.cafe-event-card.full{background:#f3f4f6;border-color:#e5e7eb;cursor:default;opacity:.7}.cafe-event-card.full:hover{transform:none;box-shadow:none;border-color:#e5e7eb}.cafe-event-card.disabled{pointer-events:none}.cafe-event-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:6px}.cafe-event-title{font-size:12px;font-weight:700;color:#1f2937;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.cafe-event-card.registered .cafe-event-title{color:#166534}.cafe-event-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:6px;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px}.cafe-event-badge.registered{background:#166534;color:#fff}.cafe-event-badge.full{background:#991b1b;color:#fff}.cafe-event-card-mid{display:flex;align-items:center;justify-content:space-between;gap:4px}.cafe-event-days{font-size:10px;color:#6b7280;white-space:nowrap}.cafe-event-card.registered .cafe-event-days{color:#15803d}.cafe-event-datetime{font-size:10px;color:#6b7280;white-space:nowrap}.cafe-event-card.registered .cafe-event-datetime{color:#15803d}.cafe-event-price{font-size:11px;font-weight:700;color:#374151;white-space:nowrap}.cafe-event-card.registered .cafe-event-price{color:#166534}.cafe-event-card-bottom{display:flex;align-items:center;gap:6px}.cafe-event-progress{flex:1;height:5px;background:#e5e7eb;border-radius:3px;overflow:hidden}.cafe-event-progress-bar{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.cafe-event-progress-bar.almost-full{background:#f59e0b}.cafe-event-progress-bar.full{background:#dc2626}.cafe-event-capacity-text{font-size:9px;color:#9ca3af;white-space:nowrap;font-variant-numeric:tabular-nums}.cafe-event-card.registered .cafe-event-capacity-text{color:#15803d}.order-event-item{color:var(--accent);font-style:italic}.cafe-event-settings-group{display:flex;flex-direction:column;gap:12px;padding:8px 0}.cafe-event-settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.cafe-event-settings-row label{font-size:14px;font-weight:500;color:#374151}.cafe-event-settings-row input[type=number]{width:70px;padding:6px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;text-align:center}:root{--hv3-bg: #faf8f5;--hv3-card: #ffffff;--hv3-card-border: #efe9e0;--hv3-card-shadow: 0 1px 3px rgba(0,0,0,.02), 0 6px 16px rgba(0,0,0,.02);--hv3-text: #1c1812;--hv3-text-muted: #917f6c;--hv3-text-light: #b8a998;--hv3-accent: #e67e22;--hv3-accent-light: #fef3e2;--hv3-accent-dark: #c96a12;--hv3-green: #16a34a;--hv3-green-bg: #dcfce7;--hv3-red: #dc2626;--hv3-red-bg: #fee2e2;--hv3-sidebar-bg: #1c1812;--hv3-sidebar-text: #b8a998;--hv3-sidebar-active: #e67e22;--hv3-radius: 14px;--hv3-radius-sm: 8px;--hv3-pill-bg: #f3ede5;--hv3-grid-line: #f0ebe4;--hv3-font: "Outfit", "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}.hv3-backdrop{position:fixed;inset:0;z-index:9999;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;animation:hv3FadeIn .2s ease}@keyframes hv3FadeIn{0%{opacity:0}to{opacity:1}}.hv3-layout{display:flex;width:100%;height:100%;font-family:var(--hv3-font);background:var(--hv3-bg);color:var(--hv3-text)}.hv3-sidebar{width:200px;background:var(--hv3-sidebar-bg);color:var(--hv3-sidebar-text);padding:24px 0;display:flex;flex-direction:column;flex-shrink:0;box-shadow:2px 0 20px #0000001a;overflow-y:auto}.hv3-sidebar-header{padding:0 20px;margin-bottom:32px}.hv3-sidebar-logo{display:flex;align-items:center;gap:8px}.hv3-sidebar-logo-icon{font-size:20px}.hv3-sidebar-logo-text{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.3px}.hv3-sidebar-subtitle{font-size:10px;color:var(--hv3-sidebar-text);margin-top:4px;opacity:.5}.hv3-sidebar-section{padding:16px 20px 6px;font-size:9px;font-weight:700;color:var(--hv3-sidebar-text);opacity:.4;text-transform:uppercase;letter-spacing:1.5px}.hv3-sidebar-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 20px;border:none;cursor:pointer;font-family:var(--hv3-font);font-size:13px;font-weight:500;text-align:left;background:transparent;color:var(--hv3-sidebar-text);border-left:3px solid transparent;transition:all .15s}.hv3-sidebar-btn:hover{background:#ffffff0a}.hv3-sidebar-btn.active{background:#e67e2226;color:var(--hv3-sidebar-active);font-weight:700;border-left-color:var(--hv3-sidebar-active)}.hv3-sidebar-btn-icon{font-size:16px}.hv3-sidebar-spacer{flex:1}.hv3-sidebar-footer{padding:0 20px;opacity:.3;font-size:10px;color:var(--hv3-sidebar-text)}.hv3-main{flex:1;padding:28px 36px;overflow-y:auto;max-height:100vh}.hv3-content{max-width:1000px;margin:0 auto}.hv3-content:has(.hv3-tx-bar){max-width:100%}.hv3-page-header{margin-bottom:24px;display:flex;justify-content:space-between;align-items:flex-start}.hv3-page-title{margin:0;font-size:22px;font-weight:800;color:var(--hv3-text);letter-spacing:-.3px}.hv3-page-subtitle{margin:4px 0 0;font-size:12px;color:var(--hv3-text-light)}.hv3-close-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--hv3-card-border);background:var(--hv3-card);color:var(--hv3-text-muted);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.hv3-close-btn:hover{background:var(--hv3-red-bg);color:var(--hv3-red);border-color:var(--hv3-red)}.hv3-card{background:var(--hv3-card);border-radius:var(--hv3-radius);border:1px solid var(--hv3-card-border);box-shadow:var(--hv3-card-shadow);padding:20px 22px}.hv3-stats-row{display:flex;gap:16px;flex-wrap:wrap}.hv3-stat{background:var(--hv3-card);border-radius:var(--hv3-radius);border:1px solid var(--hv3-card-border);box-shadow:var(--hv3-card-shadow);padding:20px 22px;flex:1;min-width:160px}.hv3-stat-top{display:flex;justify-content:space-between;align-items:flex-start}.hv3-stat-label{font-size:11px;font-weight:600;color:var(--hv3-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.hv3-stat-value{font-size:26px;font-weight:800;color:var(--hv3-text);letter-spacing:-.5px}.hv3-stat-icon{font-size:20px;opacity:.2}.hv3-stat-footer{display:flex;align-items:center;gap:6px;margin-top:8px}.hv3-stat-sub{font-size:11px;color:var(--hv3-text-light)}.hv3-badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;white-space:nowrap}.hv3-badge-green{color:var(--hv3-green);background:var(--hv3-green-bg)}.hv3-badge-red{color:var(--hv3-red);background:var(--hv3-red-bg)}.hv3-section-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.hv3-section-title h3{margin:0;font-size:15px;font-weight:700;color:var(--hv3-text)}.hv3-pills{display:flex;gap:4px;background:var(--hv3-pill-bg);border-radius:10px;padding:3px}.hv3-pill{padding:5px 16px;border-radius:8px;border:none;background:transparent;color:var(--hv3-text-muted);font-weight:600;font-size:12px;cursor:pointer;font-family:var(--hv3-font);transition:all .15s;white-space:nowrap}.hv3-pill.small{padding:4px 12px;font-size:11px}.hv3-pill.active{background:var(--hv3-accent);color:#fff}.hv3-tabs{display:flex;gap:8px}.hv3-tab-btn{display:flex;align-items:center;gap:6px;padding:8px 18px;border-radius:10px;border:1.5px solid var(--hv3-card-border);background:transparent;color:var(--hv3-text-muted);font-weight:600;font-size:13px;cursor:pointer;font-family:var(--hv3-font);transition:all .15s}.hv3-tab-btn.active{border:2px solid var(--hv3-text);background:var(--hv3-text);color:#fff}.hv3-tab-btn-icon{font-size:14px}.hv3-progress{flex:1;height:10px;background:var(--hv3-pill-bg);border-radius:99px;overflow:hidden}.hv3-progress-fill{height:100%;border-radius:99px;transition:width .6s ease}.hv3-table{width:100%;border-collapse:collapse;font-size:13px}.hv3-table thead tr{border-bottom:2px solid var(--hv3-card-border)}.hv3-table th{padding:8px 12px;text-align:left;font-size:10px;font-weight:700;color:var(--hv3-text-light);text-transform:uppercase;letter-spacing:.5px}.hv3-table tbody tr{border-bottom:1px solid var(--hv3-card-border)}.hv3-table td{padding:10px 12px}.hv3-table tfoot tr{background:var(--hv3-bg)}.hv3-table tfoot td{padding:10px 12px;font-weight:700;font-size:12px}.hv3-role-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px;display:inline-block}.hv3-role-voksen{background:var(--hv3-accent-light);color:var(--hv3-accent-dark)}.hv3-role-barn{background:#e8f5e9;color:#2e7d32}.hv3-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--hv3-text-muted);font-weight:500;-webkit-user-select:none;user-select:none}.hv3-toggle-track{width:36px;height:20px;border-radius:99px;position:relative;background:#d4cdc3;transition:background .2s}.hv3-toggle-track.on{background:var(--hv3-accent)}.hv3-toggle-thumb{width:16px;height:16px;border-radius:99px;background:#fff;position:absolute;top:2px;left:2px;transition:left .2s;box-shadow:0 1px 3px #00000026}.hv3-toggle-track.on .hv3-toggle-thumb{left:18px}.hv3-page{display:flex;flex-direction:column;gap:20px}.hv3-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.hv3-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.hv3-flex-between{display:flex;justify-content:space-between;align-items:center}.hv3-flex-wrap{display:flex;flex-wrap:wrap;gap:12px}.hv3-ranking{display:flex;flex-direction:column;gap:14px}.hv3-ranking-item{display:flex;align-items:center;gap:12px}.hv3-ranking-medal{font-size:15px;width:24px;text-align:center;flex-shrink:0}.hv3-ranking-number{font-size:13px;font-weight:700;color:var(--hv3-text-light)}.hv3-ranking-name{font-size:13px;font-weight:600;width:160px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hv3-ranking-bar{flex:1;height:12px;background:var(--hv3-pill-bg);border-radius:99px;overflow:hidden}.hv3-ranking-bar-fill{height:100%;border-radius:99px;transition:width .6s ease}.hv3-ranking-value{text-align:right;min-width:110px;flex-shrink:0}.hv3-ranking-value-main{font-size:13px;font-weight:700}.hv3-ranking-value-sub{font-size:11px;color:var(--hv3-text-light);margin-left:6px}.hv3-legend{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.hv3-legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--hv3-text-muted)}.hv3-legend-dot{width:8px;height:8px;border-radius:2px}.hv3-chart-container{position:relative;width:100%}.hv3-chart-container svg{display:block;width:100%}.hv3-chart-tooltip{position:absolute;pointer-events:none;background:#1a1a1a;color:#fff;padding:8px 14px;border-radius:10px;font-size:13px;font-weight:500;box-shadow:0 4px 20px #0000004d;z-index:100;white-space:nowrap;opacity:0;transition:opacity .15s;font-family:var(--hv3-font)}.hv3-chart-tooltip.visible{opacity:1}.hv3-chart-tooltip-label{opacity:.6;font-size:10px}.hv3-chart-tooltip-value{font-size:15px;font-weight:700}.hv3-chart-tooltip-sub{font-size:10px;color:#f97316;margin-top:2px}.hv3-report-card{border-radius:16px;padding:24px 22px;cursor:pointer;border:1.5px solid transparent;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;transform:translateY(0);box-shadow:0 1px 4px #00000008}.hv3-report-card:hover{transform:translateY(-3px)}.hv3-report-card-circle{position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;opacity:.06}.hv3-report-icon-box{width:44px;height:44px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}.hv3-report-title{margin:0 0 6px;font-size:15px;font-weight:700;color:var(--hv3-text)}.hv3-report-desc{margin:0 0 16px;font-size:12px;color:var(--hv3-text-muted);line-height:1.5}.hv3-report-footer{display:flex;justify-content:space-between;align-items:center}.hv3-report-tags{display:flex;gap:8px}.hv3-report-tag{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase}.hv3-report-dl-btn{width:32px;height:32px;border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 1px 3px #0000000f;border:1px solid var(--hv3-card-border);font-size:14px;cursor:pointer}.hv3-report-card:hover .hv3-report-dl-btn{border:none}.hv3-report-dl-btn.done{background:var(--hv3-green);border:none;color:#fff}.hv3-tip-card{padding:20px 24px;display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#1c1812,#2d261c);border-radius:var(--hv3-radius);border:none}.hv3-tip-icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;background:#e67e2226;display:flex;align-items:center;justify-content:center;font-size:20px}.hv3-tip-title{margin:0 0 4px;font-size:14px;font-weight:700;color:#fff}.hv3-tip-text{margin:0;font-size:12px;color:#b8a998;line-height:1.5}.hv3-hero{background:linear-gradient(135deg,#1c1812,#342a1e,#1c1812);border-radius:20px;padding:36px 36px 32px;position:relative;overflow:hidden}.hv3-hero-circle{position:absolute;border-radius:50%;background:var(--hv3-accent)}.hv3-hero-content{position:relative;z-index:1}.hv3-hero-label{font-size:12px;font-weight:600;color:var(--hv3-accent);text-transform:uppercase;letter-spacing:1.5px}.hv3-hero-value{font-size:56px;font-weight:800;color:#fff;letter-spacing:-2px;line-height:1}.hv3-hero-unit{font-size:22px;font-weight:600;color:var(--hv3-accent)}.hv3-hero-desc{margin:0 0 20px;font-size:15px;color:#b8a998;font-weight:400}.hv3-hero-ministats{display:flex;gap:12px;flex-wrap:wrap}.hv3-hero-ministat{background:#ffffff0f;border-radius:12px;padding:14px 20px;border:1px solid rgba(255,255,255,.06);min-width:150px;flex:1}.hv3-hero-ministat-label{font-size:11px;color:#8c7e6f;margin-bottom:4px}.hv3-hero-ministat-value{font-size:22px;font-weight:800;color:#fff}.hv3-hero-ministat-sub{font-size:10px;color:var(--hv3-accent);margin-top:2px}.hv3-breakdown-card{padding:22px 24px;border-radius:var(--hv3-radius)}.hv3-breakdown-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.hv3-breakdown-value{font-size:28px;font-weight:800;letter-spacing:-.5px}.hv3-breakdown-desc{margin:8px 0 0;font-size:12px;line-height:1.5}.hv3-econ-card{padding:24px 28px;background:linear-gradient(135deg,#fef3e2,#fde8c8,#fef9f0);border:1px solid #fed7aa;border-radius:var(--hv3-radius)}.hv3-econ-inner{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.hv3-econ-icon{width:64px;height:64px;border-radius:16px;flex-shrink:0;background:linear-gradient(135deg,#e67e22,#d35400);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 16px #e67e2240}.hv3-econ-permonth{text-align:center;padding:16px 24px;background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000a;border:1px solid var(--hv3-card-border)}.hv3-method-note{padding:16px 22px;background:#f8f4ef;border-radius:12px;border:1px solid var(--hv3-card-border);display:flex;align-items:flex-start;gap:12px}.hv3-method-note-text{font-size:12px;color:var(--hv3-text-muted);line-height:1.6}.hv3-status-tag{font-size:10px;font-weight:700;padding:3px 10px;border-radius:6px;display:inline-block}.hv3-upload-zone{padding:40px 24px;border-radius:14px;border:1.5px dashed var(--hv3-card-border);background:#fdfcfa;text-align:center;cursor:pointer;transition:all .2s}.hv3-upload-zone:hover,.hv3-upload-zone.drag-over{border:2px dashed var(--hv3-accent);background:var(--hv3-accent-light)}.hv3-gauge{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.hv3-gauge-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.hv3-gauge-pct{font-size:32px;font-weight:800;color:var(--hv3-text)}.hv3-gauge-label{font-size:10px;color:var(--hv3-text-muted);font-weight:600}.hv3-coming-soon{padding:14px 20px;background:linear-gradient(135deg,#fef3e2,#fde8c8);border:1px solid #fed7aa;border-radius:var(--hv3-radius-sm);display:flex;align-items:center;gap:10px;font-size:12px;color:var(--hv3-accent-dark);font-weight:600}.hv3-period-selector{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#f8f4ef;border-radius:10px;border:1px solid var(--hv3-card-border)}.hv3-period-date{font-size:13px;font-weight:600;color:var(--hv3-text)}.hv3-period-sep{font-size:11px;color:var(--hv3-text-light)}.hv3-loading{display:flex;align-items:center;justify-content:center;padding:60px 0;color:var(--hv3-text-light);font-size:14px;gap:10px}.hv3-spinner{width:20px;height:20px;border:2px solid var(--hv3-pill-bg);border-top-color:var(--hv3-accent);border-radius:50%;animation:hv3Spin .6s linear infinite}@keyframes hv3Spin{to{transform:rotate(360deg)}}.hv3-saldo-row{display:flex;align-items:center;gap:12px}.hv3-saldo-label{font-size:12px;font-weight:600;width:60px;text-align:right;flex-shrink:0}.hv3-saldo-bar{flex:1;height:14px;background:var(--hv3-pill-bg);border-radius:99px;overflow:hidden}.hv3-saldo-bar-fill{height:100%;border-radius:99px;transition:width .5s ease}.hv3-saldo-count{font-size:12px;font-weight:600;color:var(--hv3-text);width:55px;flex-shrink:0}.hv3-saldo-warning{margin-top:14px;padding:10px 14px;background:var(--hv3-red-bg);border-radius:var(--hv3-radius-sm);font-size:12px;color:var(--hv3-red);font-weight:500}.hv3-saldo-neg{color:var(--hv3-red);font-weight:600}.hv3-saldo-pos{color:var(--hv3-green);font-weight:600}.hv3-saldo-zero{color:var(--hv3-text-muted)}.hv3-level-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;background:var(--hv3-accent-light);color:var(--hv3-accent-dark);white-space:nowrap}.hv3-tx-search{padding:6px 14px;border-radius:var(--hv3-radius-sm);border:1.5px solid var(--hv3-card-border);background:var(--hv3-card);color:var(--hv3-text);font-family:var(--hv3-font);font-size:13px;font-weight:500;width:200px;outline:none;transition:border-color .15s}.hv3-tx-search::placeholder{color:var(--hv3-text-light)}.hv3-tx-search:focus{border-color:var(--hv3-accent)}.hv3-tx-dropdown{position:absolute;top:100%;left:0;right:0;max-height:280px;overflow-y:auto;background:var(--hv3-card-bg, #fff);border:1.5px solid var(--hv3-card-border);border-top:none;border-radius:0 0 var(--hv3-radius-sm) var(--hv3-radius-sm);box-shadow:0 8px 24px #0000001f;z-index:100}.hv3-tx-dropdown-item{padding:8px 14px;font-size:13px;cursor:pointer;transition:background .1s;color:var(--hv3-text, #1e293b)}.hv3-tx-dropdown-item:hover{background:var(--hv3-accent-subtle, rgba(99,102,241,.08))}.hv3-tx-dropdown-item[style*="display: none"]+.hv3-tx-dropdown-item:not([style*="display: none"]){border-top:none}.hv3-tx-count{font-size:12px;font-weight:600;color:var(--hv3-text-muted);white-space:nowrap}.hv3-tx-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--hv3-card);border:1px solid var(--hv3-card-border);border-radius:14px;margin-bottom:10px;flex-wrap:wrap;box-shadow:var(--hv3-card-shadow)}.hv3-tx-bar .hv3-pill{padding:7px 18px;font-size:13px;font-weight:700}.hv3-tx-bar .hv3-pills{gap:3px;padding:3px}.hv3-tx-bar-sep{width:1px;height:26px;background:var(--hv3-card-border);margin:0 2px;flex-shrink:0}.hv3-tx-bar-spacer{flex:1}.hv3-tx-datewrap{display:flex;align-items:stretch;border:1.5px solid var(--hv3-card-border);border-radius:10px;overflow:hidden;background:var(--hv3-card);transition:border-color .15s}.hv3-tx-datewrap:focus-within{border-color:var(--hv3-accent);box-shadow:0 0 0 3px var(--hv3-accent-light)}.hv3-tx-bar-date{width:120px;padding:8px 10px;border:none;background:transparent;color:var(--hv3-text);font-family:var(--hv3-font);font-size:14px;font-weight:700;outline:none;cursor:pointer}.hv3-tx-bar-date::-webkit-calendar-picker-indicator{display:none}.hv3-tx-date-btn{display:flex;align-items:center;justify-content:center;width:42px;border:none;border-left:1.5px solid var(--hv3-card-border);background:var(--hv3-pill-bg);color:var(--hv3-accent);cursor:pointer;font-size:16px;transition:background .15s,color .15s;flex-shrink:0}.hv3-tx-date-btn:hover{background:var(--hv3-accent-light);color:var(--hv3-accent-dark)}.hv3-tx-bar-datesep{font-size:12px;color:var(--hv3-text-muted);font-weight:500}.hv3-tx-bar-check{font-size:13px;color:var(--hv3-text-muted);font-weight:600;display:flex;align-items:center;gap:5px;cursor:pointer;white-space:nowrap}.hv3-tx-bar-check input[type=checkbox]{accent-color:var(--hv3-accent);width:15px;height:15px;cursor:pointer}.hv3-tx-card{border-radius:var(--hv3-radius)}.hv3-tx-card .hv3-table{font-size:15px}.hv3-tx-card .hv3-table th{font-size:13px;font-weight:800;padding:14px 16px;color:var(--hv3-text);text-transform:uppercase;letter-spacing:.3px;border-bottom:2.5px solid var(--hv3-text-muted)}.hv3-tx-card .hv3-table td{padding:14px 16px;font-size:15px}.hv3-tx-card .hv3-tx-tag{font-size:13px;padding:4px 12px;font-weight:700}.hv3-tx-tag{display:inline-flex;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:700;white-space:nowrap}.hv3-tx-tag-green{background:var(--hv3-green-bg);color:var(--hv3-green)}.hv3-tx-tag-blue{background:#dbeafe;color:#2563eb}.hv3-tx-tag-orange{background:var(--hv3-accent-light);color:var(--hv3-accent-dark)}.hv3-tx-tag-red{background:var(--hv3-red-bg);color:var(--hv3-red)}.hv3-tx-tag-purple{background:#f3e8ff;color:#7c3aed}.hv3-tx-tag-teal{background:#ccfbf1;color:#0d9488}.hv3-tx-tag-gray{background:var(--hv3-pill-bg);color:var(--hv3-text-muted)}.hv3-tx-row-sale td:first-child{border-left:3px solid var(--hv3-green)}.hv3-tx-row-deposit td:first-child{border-left:3px solid #2563eb}.hv3-tx-row-adjustment td:first-child{border-left:3px solid var(--hv3-accent)}.hv3-tx-row-undo td:first-child{border-left:3px solid var(--hv3-red)}.hv3-tx-row-undo td{text-decoration:line-through;opacity:.5}.hv3-tx-row-balance td:first-child{border-left:3px solid #7c3aed}.hv3-tx-row-event td:first-child{border-left:3px solid #0d9488}.hv3-tx-row:hover{background:#e67e220a}.hv3-tx-expand-row{display:none}.hv3-tx-expand-row.open{display:table-row}.hv3-tx-expand-cell{padding:0;border-top:none}.hv3-tx-expand-btn{background:transparent;border:1.5px solid var(--hv3-card-border);border-radius:6px;padding:2px 8px;font-size:14px;color:var(--hv3-text-muted);cursor:pointer;font-family:var(--hv3-font);transition:all .15s}.hv3-tx-expand-btn:hover{border-color:var(--hv3-accent);color:var(--hv3-accent)}.hv3-tx-product{display:inline-flex;align-items:center;gap:2px;font-size:12px;background:var(--hv3-pill-bg);border:1px solid var(--hv3-card-border);border-radius:6px;padding:1px 6px 1px 3px;margin:1px 2px;white-space:nowrap}.hv3-tx-product img{flex-shrink:0}.hv3-tx-product-name{max-width:80px;overflow:hidden;text-overflow:ellipsis;color:var(--hv3-text)}.hv3-tx-product-qty{color:var(--hv3-text-muted);margin-left:2px}.hv3-tx-adjust-panel{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:20px;background:var(--hv3-bg);border-top:1px solid var(--hv3-card-border)}.hv3-tx-adjust-details{padding-right:24px;border-right:1px solid var(--hv3-card-border)}.hv3-tx-adjust-controls{padding-left:24px}.hv3-tx-adjust-section-title{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--hv3-text);margin-bottom:14px}.hv3-tx-adjust-items{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.hv3-tx-adjust-item{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;font-size:15px}.hv3-tx-adjust-item-name{font-weight:600}.hv3-tx-adjust-item-qty{color:var(--hv3-text-muted);font-size:14px}.hv3-tx-adjust-item-price{font-weight:700;text-align:right;font-variant-numeric:tabular-nums;font-size:15px}.hv3-tx-adjust-total-line{border-top:1px solid var(--hv3-card-border);padding-top:8px;margin-top:4px}.hv3-tx-adjust-meta{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--hv3-text-muted)}.hv3-tx-adjust-qty-section{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.hv3-tx-adjust-qty-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center}.hv3-tx-adjust-qty-name{font-weight:600;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hv3-tx-adjust-qty-controls{display:flex;align-items:center;gap:6px}.hv3-tx-adjust-qty-delta{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;min-width:60px;text-align:right}.hv3-tx-qty-btn{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--hv3-card-border);background:var(--hv3-card);color:var(--hv3-text);font-weight:700;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:var(--hv3-font);transition:all .15s}.hv3-tx-qty-btn:hover{border-color:var(--hv3-accent);color:var(--hv3-accent-dark);background:var(--hv3-accent-light)}.hv3-tx-qty-btn:active{transform:scale(.92)}.hv3-tx-qty-diff{font-variant-numeric:tabular-nums;font-weight:700;font-size:16px;min-width:28px;text-align:center}.hv3-tx-adjust-manual{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding:10px 12px;background:var(--hv3-card);border-radius:var(--hv3-radius-sm);border:1px solid var(--hv3-card-border)}.hv3-tx-adjust-manual-label{font-size:14px;color:var(--hv3-text-muted);font-weight:600}.hv3-tx-manual-display{font-variant-numeric:tabular-nums;font-weight:700;font-size:16px;min-width:44px;text-align:center}.hv3-tx-adjust-summary{border-top:1px solid var(--hv3-card-border);padding-top:12px;margin-bottom:16px;display:flex;flex-direction:column;gap:6px}.hv3-tx-adjust-summary-row{display:flex;justify-content:space-between;font-size:14px;color:var(--hv3-text-muted)}.hv3-tx-adjust-summary-total{font-size:16px;font-weight:800;color:var(--hv3-text);padding-top:6px;border-top:1px solid var(--hv3-card-border)}.hv3-tx-adjust-actions{display:flex;gap:10px}.hv3-tx-adjust-save{flex:1;padding:12px 20px;border-radius:var(--hv3-radius-sm);border:none;background:var(--hv3-accent);color:#fff;font-weight:700;font-size:15px;cursor:pointer;font-family:var(--hv3-font);transition:all .15s}.hv3-tx-adjust-save:hover:not(:disabled){background:var(--hv3-accent-dark)}.hv3-tx-adjust-save:disabled{opacity:.4;cursor:not-allowed}.hv3-tx-adjust-undo{padding:12px 20px;border-radius:var(--hv3-radius-sm);border:1.5px solid var(--hv3-red);background:transparent;color:var(--hv3-red);font-weight:700;font-size:15px;cursor:pointer;font-family:var(--hv3-font);transition:all .15s}.hv3-tx-adjust-undo:hover{background:var(--hv3-red-bg)}.hv3-tx-table td{vertical-align:middle}@media(max-width:700px){.hv3-tx-adjust-panel{grid-template-columns:1fr}.hv3-tx-adjust-details{border-right:none;border-bottom:1px solid var(--hv3-card-border);padding-right:0;padding-bottom:16px;margin-bottom:16px}.hv3-tx-adjust-controls{padding-left:0}.hv3-tx-bar{flex-direction:column;align-items:stretch}.hv3-tx-bar-sep{display:none}.hv3-tx-search{width:100%}}@keyframes hv3DotPop{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.hv3-chart-dot{opacity:0;transform-box:fill-box;transform-origin:center;animation:hv3DotPop .25s ease forwards}@keyframes hv3SliceGrow{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}.hv3-donut-slice{opacity:0;animation:hv3SliceGrow .5s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes hv3LegendFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.hv3-legend-animated{opacity:0;animation:hv3LegendFade .4s ease forwards}@media(max-width:900px){.hv3-sidebar{width:56px;padding:16px 0}.hv3-sidebar-header,.hv3-sidebar-section,.hv3-sidebar-footer{display:none}.hv3-sidebar-btn{justify-content:center;padding:10px;gap:0;border-left-width:2px}.hv3-sidebar-btn span:last-child{display:none}.hv3-main{padding:20px 16px}.hv3-grid-2,.hv3-grid-3{grid-template-columns:1fr}.hv3-stats-row{flex-direction:column}.hv3-hero-value{font-size:40px}}.hv3-pp-user-picker{position:relative;max-width:420px}.hv3-pp-search{width:100%;padding:10px 14px;border-radius:10px;border:1.5px solid var(--hv3-border);background:var(--hv3-bg);color:var(--hv3-text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}.hv3-pp-search:focus{border-color:var(--hv3-accent);box-shadow:0 0 0 3px #f973161f}.hv3-pp-search::placeholder{color:var(--hv3-text-muted)}.hv3-pp-dropdown{position:absolute;top:calc(100% + 4px);left:0;width:100%;max-height:280px;overflow-y:auto;background:var(--hv3-card-bg);border-radius:10px;border:1px solid var(--hv3-border);box-shadow:0 12px 32px #00000026;z-index:50}.hv3-pp-dropdown-item{padding:10px 14px;cursor:pointer;font-size:13px;font-weight:500;color:var(--hv3-text);transition:background .15s}.hv3-pp-dropdown-item:hover{background:var(--hv3-hover-bg, rgba(249,115,22,.06))}.hv3-pp-dropdown-item+.hv3-pp-dropdown-item{border-top:1px solid var(--hv3-border)}.hv3-pp-selected-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--hv3-accent-light);color:var(--hv3-accent-dark);border-radius:10px;font-weight:600;font-size:14px}.hv3-pp-clear-btn{background:none;border:none;color:var(--hv3-accent-dark);font-size:16px;cursor:pointer;padding:0 2px;line-height:1;opacity:.7;transition:opacity .15s}.hv3-pp-clear-btn:hover{opacity:1}.hv3-pp-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.hv3-pp-summary{display:flex;gap:24px;flex-wrap:wrap}.hv3-pp-stat{font-size:13px;color:var(--hv3-text-muted)}.hv3-pp-stat strong{color:var(--hv3-text);font-weight:700}.hv3-pp-chart{display:flex;flex-direction:row;align-items:flex-end;justify-content:center;gap:20px;padding:40px 30px 24px;min-height:340px;overflow-x:auto;background:linear-gradient(180deg,#f9731605,#fff0)}.hv3-pp-bar-wrapper{display:flex;flex-direction:column;align-items:center;min-width:55px;max-width:80px;flex:1}.hv3-pp-bar{position:relative;width:44px;height:0;border-radius:22px 22px 6px 6px;transition:height .8s cubic-bezier(.34,1.56,.64,1);cursor:default}.hv3-pp-bar-cap{position:absolute;top:-8px;left:0;width:44px;height:16px;border-radius:50%;z-index:3}.hv3-pp-bar-value{font-size:13px;font-weight:800;color:var(--hv3-text);margin-bottom:8px;white-space:nowrap}.hv3-pp-bar-icon{margin-top:12px;width:36px;height:36px;background:var(--hv3-card-bg);border-radius:10px;display:flex;align-items:center;justify-content:center;border:1px solid var(--hv3-border);box-shadow:0 2px 6px #0000000f}.hv3-pp-bar-name{margin-top:6px;font-size:11px;font-weight:700;color:var(--hv3-text-muted);text-align:center;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hv3-pp-bar-tooltip{position:absolute;bottom:calc(100% + 20px);left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:12px 16px;border-radius:12px;font-size:13px;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;transition:all .2s ease;z-index:100;box-shadow:0 10px 25px #00000040}.hv3-pp-bar-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e293b}.hv3-pp-bar:hover .hv3-pp-bar-tooltip{opacity:1;visibility:visible}.hv3-pp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--hv3-text-muted)}@media(max-width:600px){.hv3-pp-chart{justify-content:flex-start;gap:14px;padding:30px 16px 20px}.hv3-pp-summary{flex-direction:column;gap:8px}}.hv3-cd-personnel-table tbody tr.hv3-cd-person-row{cursor:pointer;transition:background .15s}.hv3-cd-person-row:hover{background:var(--hv3-bg)}.hv3-cd-person-row.selected{background:var(--hv3-accent-light, #fef3e2)}.hv3-cd-stat-best{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.hv3-cd-stat-worst{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fecaca}.hv3-cd-sort-th{padding:10px 12px;text-align:left;font-size:10px;font-weight:700;color:var(--hv3-text-light);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:color .15s}.hv3-cd-sort-th:hover{color:var(--hv3-text-muted)}.hv3-cd-sort-th.active{color:var(--hv3-accent)}.hv3-cd-row-best{background:#f0fdf4}.hv3-cd-row-worst{background:#fef2f2}.hv3-cd-diff-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;white-space:nowrap}.hv3-cd-diff-badge.positive{background:#dcfce7;color:#16a34a}.hv3-cd-diff-badge.negative{background:#fee2e2;color:#dc2626}.hv3-kunde-row{background:transparent;transition:background .15s}.hv3-kunde-row:hover{background:#faf8f5}.hv3-kunde-row-neg{background:#fefafa}.hv3-kunde-row-neg:hover{background:#fef2f2}.hv3-kunde-search:focus{border-color:var(--hv3-accent)}.portal-v2{--flango: #F5960A;--flango-light: #FFF4E6;--flango-mid: #FFDAA6;--flango-dark: #C47200;--ink: #1C1917;--ink-soft: #57534E;--ink-muted: #A8A29E;--surface: #FAFAF9;--surface-raised: #FFFFFF;--surface-sunken: #F5F5F4;--surface-hover: #F0EFED;--border: #E7E5E4;--border-strong: #D6D3D1;--positive: #16A34A;--positive-light: #DCFCE7;--caution: #EA580C;--caution-light: #FFF7ED;--negative: #DC2626;--negative-light: #FEF2F2;--info: #2563EB;--info-light: #EFF6FF;--purple: #7C3AED;--purple-light: #F5F3FF;--s1: 4px;--s2: 8px;--s3: 12px;--s4: 16px;--s5: 20px;--s6: 24px;--s8: 32px;--s10: 40px;--s12: 48px;--s16: 64px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 24px;--r-full: 9999px;--font: "Plus Jakarta Sans", -apple-system, system-ui, sans-serif;--font-display: "Instrument Serif", Georgia, serif;--shadow-xs: 0 1px 2px rgba(28,25,23,.04);--shadow-sm: 0 1px 3px rgba(28,25,23,.06), 0 1px 2px rgba(28,25,23,.04);--shadow-md: 0 4px 12px rgba(28,25,23,.07);--shadow-lg: 0 8px 30px rgba(28,25,23,.09);--nav-h: 64px;--bottom-h: 80px;--max-w: 480px}.portal-v2 *,.portal-v2 *:before,.portal-v2 *:after{box-sizing:border-box;margin:0;padding:0}.portal-v2{-webkit-text-size-adjust:100%}.portal-v2{font-family:var(--font);color:var(--ink);background:var(--surface);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100dvh;overscroll-behavior-y:none}.portal-v2 button{font:inherit;cursor:pointer;border:none;background:none}.portal-v2 img{max-width:100%;display:block}.portal-v2 input,.portal-v2 select,.portal-v2 textarea{font:inherit}.portal-v2 a{color:inherit;text-decoration:none}.portal-v2 .app{min-height:100dvh;display:flex;flex-direction:column;background:var(--surface)}.portal-v2 .topnav{position:sticky;top:0;z-index:100;background:#fafaf9e0;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--border);height:var(--nav-h);display:flex;align-items:center;padding:0 var(--s4)}.portal-v2 .topnav-inner{width:100%;max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;justify-content:space-between}.portal-v2 .brand{display:flex;align-items:center;gap:var(--s2)}.portal-v2 .brand-logo{width:32px;height:32px;border-radius:var(--r-sm)}.portal-v2 .brand-name{font-weight:700;font-size:18px;letter-spacing:-.02em}.portal-v2 .brand-sub{font-size:11px;color:var(--ink-muted);font-weight:500;margin-top:-2px}.portal-v2 .nav-actions{display:flex;align-items:center;gap:var(--s2)}.portal-v2 .nav-btn{width:38px;height:38px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:background .15s,color .15s}.portal-v2 .nav-btn:hover{background:var(--surface-hover);color:var(--ink)}.portal-v2 .nav-btn svg{width:20px;height:20px}.portal-v2 .main{flex:1;width:100%;max-width:var(--max-w);margin:0 auto;padding:var(--s4) var(--s4) calc(var(--bottom-h) + var(--s4))}.portal-v2 .tab-view{display:none;flex-direction:column;gap:var(--s4)}.portal-v2 .tab-view.active{display:flex;animation:viewFadeIn .3s cubic-bezier(.22,.61,.36,1) both}@keyframes viewFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.portal-v2 .view-header{padding:var(--s2) 0 var(--s3)}.portal-v2 .view-title{font-size:22px;font-weight:800;letter-spacing:-.02em}.portal-v2 .view-subtitle{font-size:13px;color:var(--ink-muted);margin-top:2px}.portal-v2 .child-selector{display:flex;gap:var(--s2);overflow-x:auto;scrollbar-width:none;padding:var(--s1) 0;scroll-snap-type:x mandatory}.portal-v2 .child-selector::-webkit-scrollbar{display:none}.portal-v2 .child-chip{scroll-snap-align:start;flex-shrink:0;display:flex;align-items:center;gap:var(--s2);padding:var(--s2) var(--s3);border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface-raised);transition:all .2s;white-space:nowrap;font-weight:600;font-size:14px;color:var(--ink-soft)}.portal-v2 .child-chip.active{border-color:var(--flango);background:var(--flango-light);color:var(--flango-dark)}.portal-v2 .child-chip:hover:not(.active){border-color:var(--border-strong);background:var(--surface-sunken)}.portal-v2 .child-avatar{width:28px;height:28px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-size:15px;background:var(--flango-mid)}.portal-v2 .child-chip.active .child-avatar{background:var(--flango);color:#fff}.portal-v2 .child-chip .saldo-mini{font-size:12px;font-weight:700;color:var(--positive);margin-left:var(--s1)}.portal-v2 .child-chip.active .saldo-mini{color:var(--flango-dark)}.portal-v2 .add-child-chip{border-style:dashed;border-color:var(--border-strong);color:var(--ink-muted);gap:var(--s1)}.portal-v2 .add-child-chip:hover{border-color:var(--flango);color:var(--flango)}.portal-v2 .add-child-chip svg{width:16px;height:16px}.portal-v2 .balance-card{background:linear-gradient(135deg,#1c1917,#292524);border-radius:var(--r-xl);padding:var(--s6);color:#fff;position:relative;overflow:hidden}.portal-v2 .balance-card:before{content:"";position:absolute;top:-60px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(245,150,10,.25) 0%,transparent 70%);pointer-events:none}.portal-v2 .balance-card:after{content:"";position:absolute;bottom:-80px;left:-20px;width:160px;height:160px;background:radial-gradient(circle,rgba(245,150,10,.12) 0%,transparent 70%);pointer-events:none}.portal-v2 .balance-header{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1}.portal-v2 .balance-label{font-size:13px;font-weight:500;color:#fff9;letter-spacing:.03em;text-transform:uppercase}.portal-v2 .balance-amount{font-family:var(--font-display);font-size:48px;font-weight:400;line-height:1.1;margin-top:var(--s1);position:relative;z-index:1}.portal-v2 .balance-amount .currency{font-family:var(--font);font-size:20px;font-weight:600;color:#ffffff80;margin-left:4px}.portal-v2 .balance-child-name{font-size:14px;color:#ffffff80;margin-top:var(--s2);position:relative;z-index:1}.portal-v2 .balance-contact{font-size:13px;color:#ffffff73;text-decoration:none;margin-top:var(--s1);display:inline-block;position:relative;z-index:1;transition:color .15s}.portal-v2 .balance-contact:hover{color:#fffc}.portal-v2 .balance-status{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--r-full);font-size:12px;font-weight:600}.portal-v2 .status-ok{background:#16a34a33;color:#4ade80}.portal-v2 .status-low{background:#ea580c33;color:#fb923c}.portal-v2 .status-empty{background:#dc262633;color:#f87171}.portal-v2 .status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.portal-v2 .topup-row{display:flex;gap:var(--s2);margin-top:var(--s5);position:relative;z-index:1}.portal-v2 .topup-btn{flex:1;height:44px;border-radius:var(--r-md);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;gap:var(--s2);transition:transform .15s,opacity .15s}.portal-v2 .topup-btn:active{transform:scale(.97)}.portal-v2 .topup-primary{background:var(--flango);color:#fff}.portal-v2 .topup-primary:hover{opacity:.9}.portal-v2 .topup-secondary{background:#ffffff1a;color:#fffc;border:1px solid rgba(255,255,255,.15)}.portal-v2 .topup-secondary:hover{background:#ffffff26}.portal-v2 .quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s2)}.portal-v2 .qa-item{display:flex;flex-direction:column;align-items:center;gap:var(--s2);padding:var(--s3) var(--s2);border-radius:var(--r-lg);transition:background .15s;text-align:center}.portal-v2 .qa-item:hover{background:var(--surface-sunken)}.portal-v2 .qa-item:active{transform:scale(.96)}.portal-v2 .qa-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:20px}.portal-v2 .qa-icon.orange{background:var(--flango-light)}.portal-v2 .qa-icon.green{background:var(--positive-light)}.portal-v2 .qa-icon.blue{background:var(--info-light)}.portal-v2 .qa-icon.red{background:var(--negative-light)}.portal-v2 .qa-label{font-size:11px;font-weight:600;color:var(--ink-soft);line-height:1.3}.portal-v2 .section{background:var(--surface-raised);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;scroll-margin-top:calc(var(--nav-h) + var(--s4))}.portal-v2 .section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s4) var(--s4) var(--s3);cursor:pointer;user-select:none;-webkit-user-select:none;transition:background .1s}.portal-v2 .section-header:hover{background:var(--surface-sunken)}.portal-v2 .section-header:active{background:var(--surface-hover)}.portal-v2 .section-title-row{display:flex;align-items:center;gap:var(--s3)}.portal-v2 .section-icon{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.portal-v2 .section-title{font-weight:700;font-size:15px}.portal-v2 .section-subtitle{font-size:12px;color:var(--ink-muted);margin-top:1px}.portal-v2 .section-chevron{width:20px;height:20px;color:var(--ink-muted);transition:transform .25s ease;flex-shrink:0}.portal-v2 .section.open .section-chevron{transform:rotate(180deg)}.portal-v2 .section-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s cubic-bezier(.22,.61,.36,1)}.portal-v2 .section.open .section-body{grid-template-rows:1fr}.portal-v2 .section-body-inner{overflow:hidden}.portal-v2 .section-content{padding:0 var(--s4) var(--s4)}.portal-v2 .toggle{position:relative;width:48px;height:28px;flex-shrink:0}.portal-v2 .toggle input{opacity:0;width:0;height:0;position:absolute}.portal-v2 .toggle-track{position:absolute;inset:0;border-radius:var(--r-full);background:var(--border-strong);transition:background .2s;cursor:pointer}.portal-v2 .toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000026;transition:transform .2s}.portal-v2 .toggle input:checked+.toggle-track{background:var(--positive)}.portal-v2 .toggle input:checked+.toggle-track:after{transform:translate(20px)}.portal-v2 .setting-row{display:flex;align-items:center;justify-content:space-between;padding:var(--s3) 0;gap:var(--s4)}.portal-v2 .setting-row+.setting-row{border-top:1px solid var(--border)}.portal-v2 .setting-info{flex:1;min-width:0}.portal-v2 .setting-label{font-weight:600;font-size:14px}.portal-v2 .setting-desc{font-size:12px;color:var(--ink-muted);margin-top:2px}.portal-v2 .chip-group{display:flex;flex-wrap:wrap;gap:var(--s2);margin-top:var(--s3)}.portal-v2 .chip{padding:var(--s2) var(--s4);border-radius:var(--r-full);border:1.5px solid var(--border);font-weight:600;font-size:14px;color:var(--ink-soft);transition:all .15s}.portal-v2 .chip:hover{border-color:var(--border-strong)}.portal-v2 .chip.active{border-color:var(--flango);background:var(--flango-light);color:var(--flango-dark)}.portal-v2 .stepper{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.portal-v2 .stepper-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:18px;font-weight:700;transition:background .1s}.portal-v2 .stepper-btn:hover{background:var(--surface-hover)}.portal-v2 .stepper-val{width:40px;text-align:center;font-weight:700;font-size:13px;border-left:1px solid var(--border);border-right:1px solid var(--border);height:34px;line-height:34px}.portal-v2 .hint-box{display:flex;gap:var(--s3);padding:var(--s3);border-radius:var(--r-md);font-size:13px;line-height:1.4}.portal-v2 .hint-box.info{background:var(--info-light);color:var(--info)}.portal-v2 .hint-box.warn{background:var(--caution-light);color:var(--caution)}.portal-v2 .hint-box.green{background:var(--positive-light);color:var(--positive)}.portal-v2 .hint-box.purple{background:var(--purple-light);color:var(--purple)}.portal-v2 .hint-box.neutral{background:var(--surface-sunken);color:var(--ink-soft)}.portal-v2 .hint-icon{font-size:16px;flex-shrink:0;margin-top:1px}.portal-v2 .period-toggle{display:inline-flex;background:var(--surface-sunken);border-radius:var(--r-sm);padding:2px;gap:2px}.portal-v2 .period-btn{padding:var(--s1) var(--s3);border-radius:6px;font-size:12px;font-weight:600;color:var(--ink-muted);transition:all .15s}.portal-v2 .period-btn.active{background:var(--surface-raised);color:var(--ink);box-shadow:var(--shadow-xs)}.portal-v2 .disclaimer{font-size:11px;color:var(--ink-muted);line-height:1.5;font-style:italic;margin-top:var(--s3);padding-top:var(--s3);border-top:1px solid var(--border)}.portal-v2 .input-field{width:100%;height:44px;border:1.5px solid var(--border);border-radius:var(--r-md);padding:0 var(--s3);font-size:14px;transition:border-color .15s;background:var(--surface-raised)}.portal-v2 .input-field:focus{outline:none;border-color:var(--flango);box-shadow:0 0 0 3px #f5960a1f}.portal-v2 .save-btn{height:44px;padding:0 var(--s6);border-radius:var(--r-md);background:var(--flango);color:#fff;font-weight:700;font-size:14px;transition:opacity .15s,transform .15s;white-space:nowrap}.portal-v2 .save-btn:hover{opacity:.9}.portal-v2 .save-btn:active{transform:scale(.97)}.portal-v2 .save-btn.full{width:100%}.portal-v2 .chart-bar-group{display:flex;align-items:flex-end;gap:3px;height:100px;padding-top:var(--s2)}.portal-v2 .chart-bar{flex:1;border-radius:4px 4px 0 0;background:var(--flango);min-height:4px;opacity:.7;transition:opacity .15s,background .15s}.portal-v2 .chart-bar:hover{opacity:1}.portal-v2 .chart-bar.today{opacity:1;background:var(--flango-dark)}.portal-v2 .chart-label{font-size:10px;color:var(--ink-muted);font-weight:500}.portal-v2 .chart-summary{display:flex;gap:var(--s4);margin-top:var(--s3);padding-top:var(--s3);border-top:1px solid var(--border)}.portal-v2 .chart-stat{flex:1}.portal-v2 .chart-stat-value{font-size:20px;font-weight:700}.portal-v2 .chart-stat-label{font-size:11px;color:var(--ink-muted);font-weight:500}.portal-v2 .product-chart{margin-top:var(--s4);padding-top:var(--s4);border-top:1px solid var(--border)}.portal-v2 .product-chart-title{font-weight:700;font-size:14px;margin-bottom:var(--s3)}.portal-v2 .product-bar-row{display:flex;align-items:center;gap:var(--s3);margin-bottom:var(--s2)}.portal-v2 .product-bar-label{width:80px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:var(--s1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-v2 .product-bar-track{flex:1;height:24px;background:var(--surface-sunken);border-radius:4px;overflow:hidden;position:relative}.portal-v2 .product-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;display:flex;align-items:center;padding-left:var(--s2)}.portal-v2 .product-bar-value{font-size:11px;font-weight:700;color:#fff;white-space:nowrap}.portal-v2 .product-bar-fill.c1{background:#2dd4bf}.portal-v2 .product-bar-fill.c2{background:#60a5fa}.portal-v2 .product-bar-fill.c3{background:#f59e0b}.portal-v2 .product-bar-fill.c4{background:#f472b6}.portal-v2 .product-bar-fill.c5{background:#a78bfa}.portal-v2 .pill-chart-container{display:flex;align-items:flex-end;justify-content:center;gap:var(--s4);padding:var(--s4) 0;min-height:220px}.portal-v2 .pill-col{display:flex;flex-direction:column;align-items:center;gap:var(--s2);flex:1;max-width:72px}.portal-v2 .pill-bar-wrap{position:relative;width:52px;display:flex;flex-direction:column;align-items:center}.portal-v2 .pill-value{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:4px}.portal-v2 .pill-bar{width:100%;border-radius:26px;position:relative;min-height:24px;overflow:hidden}.portal-v2 .pill-bar:before{content:"";position:absolute;inset:0;border-radius:26px;background:linear-gradient(90deg,#ffffff26,#ffffff59 35%,#fff0 60%)}.portal-v2 .pill-bar:after{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:40px;height:16px;border-radius:50%;background:inherit;filter:brightness(1.3) saturate(.8)}.portal-v2 .pill-bar.c1{background:linear-gradient(180deg,#5eead4,#0d9488)}.portal-v2 .pill-bar.c2{background:linear-gradient(180deg,#93c5fd,#3b82f6)}.portal-v2 .pill-bar.c3{background:linear-gradient(180deg,#fcd34d,#f59e0b)}.portal-v2 .pill-bar.c4{background:linear-gradient(180deg,#f9a8d4,#db2777)}.portal-v2 .pill-bar.c5{background:linear-gradient(180deg,#c4b5fd,#7c3aed)}.portal-v2 .pill-icon{width:32px;height:32px;border-radius:var(--r-sm);background:var(--surface-sunken);display:flex;align-items:center;justify-content:center;font-size:16px;margin-top:var(--s1)}.portal-v2 .pill-name{font-size:11px;font-weight:600;color:var(--ink-soft);text-align:center;max-width:72px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-v2 .chart-view-toggle{display:inline-flex;background:var(--surface-sunken);border-radius:var(--r-sm);padding:2px;gap:2px}.portal-v2 .chart-view-btn{padding:var(--s1) var(--s3);border-radius:6px;font-size:12px;font-weight:600;color:var(--ink-muted);transition:all .15s}.portal-v2 .chart-view-btn.active{background:var(--surface-raised);color:var(--ink);box-shadow:var(--shadow-xs)}.portal-v2 .screentime-overview{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3);margin-bottom:var(--s4)}.portal-v2 .st-stat-card{background:var(--surface-sunken);border-radius:var(--r-md);padding:var(--s3);text-align:center}.portal-v2 .st-stat-value{font-size:24px;font-weight:800}.portal-v2 .st-stat-label{font-size:11px;color:var(--ink-muted);font-weight:500;margin-top:2px}.portal-v2 .st-stat-card.remaining .st-stat-value{color:var(--positive)}.portal-v2 .st-stat-card.used .st-stat-value{color:var(--flango)}.portal-v2 .st-chart-section{margin-top:var(--s4);padding-top:var(--s4);border-top:1px solid var(--border)}.portal-v2 .st-chart-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s3);flex-wrap:wrap;gap:var(--s2)}.portal-v2 .st-chart-total{font-size:13px;color:var(--ink-soft);margin-bottom:var(--s2)}.portal-v2 .st-chart-total strong{color:var(--ink)}.portal-v2 .game-row{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) 0}.portal-v2 .game-row+.game-row{border-top:1px solid var(--border)}.portal-v2 .game-icon{width:40px;height:40px;border-radius:var(--r-sm);background:var(--surface-sunken);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.portal-v2 .game-info{flex:1;min-width:0}.portal-v2 .game-name{font-weight:600;font-size:14px}.portal-v2 .game-platform{font-size:11px;color:var(--ink-muted);font-weight:500}.portal-v2 .game-blocked{font-size:11px;color:var(--negative);font-weight:600}.portal-v2 .tx-row{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) 0}.portal-v2 .tx-row+.tx-row{border-top:1px solid var(--border)}.portal-v2 .tx-icon{width:36px;height:36px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.portal-v2 .tx-icon.purchase{background:var(--flango-light)}.portal-v2 .tx-icon.topup{background:var(--positive-light)}.portal-v2 .tx-icon.adjust{background:var(--info-light)}.portal-v2 .tx-info{flex:1;min-width:0}.portal-v2 .tx-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-v2 .tx-date{font-size:12px;color:var(--ink-muted)}.portal-v2 .tx-amount{font-weight:700;font-size:14px;white-space:nowrap}.portal-v2 .tx-amount.negative{color:var(--ink)}.portal-v2 .tx-amount.positive{color:var(--positive)}.portal-v2 .event-card{border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s3) var(--s4);display:flex;align-items:center;gap:var(--s3)}.portal-v2 .event-card+.event-card{margin-top:var(--s2)}.portal-v2 .event-date-badge{width:44px;flex-shrink:0;text-align:center}.portal-v2 .event-month{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--flango);letter-spacing:.05em}.portal-v2 .event-day{font-size:22px;font-weight:800;line-height:1.1}.portal-v2 .event-info{flex:1;min-width:0}.portal-v2 .event-title{font-weight:700;font-size:14px}.portal-v2 .event-meta{font-size:12px;color:var(--ink-muted)}.portal-v2 .event-action-btn{padding:var(--s2) var(--s3);border-radius:var(--r-sm);font-weight:700;font-size:12px;background:var(--flango-light);color:var(--flango-dark);transition:background .15s;flex-shrink:0}.portal-v2 .event-action-btn:hover{background:var(--flango-mid)}.portal-v2 .event-action-btn.registered{background:var(--positive-light);color:var(--positive)}.portal-v2 .product-list-item{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) 0}.portal-v2 .product-list-item+.product-list-item{border-top:1px solid var(--border)}.portal-v2 .product-emoji{width:36px;height:36px;border-radius:var(--r-sm);background:var(--surface-sunken);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.portal-v2 .product-name{flex:1;font-weight:600;font-size:14px}.portal-v2 .product-price{font-weight:700;font-size:14px;color:var(--ink-soft)}.portal-v2 .allergen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s2);margin-top:var(--s3)}.portal-v2 .allergen-item{display:flex;flex-direction:column;align-items:center;gap:var(--s1);padding:var(--s3) var(--s2);border-radius:var(--r-md);border:1.5px solid var(--border);text-align:center;transition:all .15s;cursor:pointer}.portal-v2 .allergen-item:hover{border-color:var(--border-strong)}.portal-v2 .allergen-item.blocked{border-color:var(--negative);background:var(--negative-light)}.portal-v2 .allergen-item.warn{border-color:var(--caution);background:var(--caution-light)}.portal-v2 .allergen-emoji{font-size:24px}.portal-v2 .allergen-name{font-size:11px;font-weight:600;color:var(--ink-soft)}.portal-v2 .allergen-status{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.portal-v2 .allergen-item.blocked .allergen-status{color:var(--negative)}.portal-v2 .allergen-item.warn .allergen-status{color:var(--caution)}.portal-v2 .topup-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s3);margin-top:var(--s3)}.portal-v2 .topup-option{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--s5) var(--s4);border-radius:var(--r-lg);border:2px solid var(--border);background:var(--surface-raised);transition:all .15s;gap:var(--s1)}.portal-v2 .topup-option:hover{border-color:var(--border-strong);background:var(--surface-sunken)}.portal-v2 .topup-option:active{transform:scale(.97)}.portal-v2 .topup-option.selected{border-color:var(--flango);background:var(--flango-light)}.portal-v2 .topup-option-amount{font-size:24px;font-weight:800}.portal-v2 .topup-option.selected .topup-option-amount{color:var(--flango-dark)}.portal-v2 .topup-option-label{font-size:12px;color:var(--ink-muted);font-weight:500}.portal-v2 .topup-option.custom{border-style:dashed}.portal-v2 .topup-method-section{margin-top:var(--s6)}.portal-v2 .topup-method-title{font-weight:700;font-size:15px;margin-bottom:var(--s3)}.portal-v2 .topup-method-btn{width:100%;height:52px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;gap:var(--s3);font-weight:700;font-size:15px;transition:all .15s}.portal-v2 .topup-method-btn:active{transform:scale(.98)}.portal-v2 .topup-method-btn.stripe{background:var(--ink);color:#fff}.portal-v2 .topup-method-btn.stripe:hover{background:#292524}.portal-v2 .topup-method-btn.mobilepay{background:#5a78ff;color:#fff;margin-top:var(--s2)}.portal-v2 .topup-method-btn.mobilepay:hover{background:#4a66e6}.portal-v2 .topup-method-btn.cash{background:var(--surface-sunken);color:var(--ink-soft);border:1px solid var(--border);margin-top:var(--s2)}.portal-v2 .topup-method-btn.cash:hover{background:var(--surface-hover)}.portal-v2 .qr-section{margin-top:var(--s4);padding:var(--s4);background:var(--surface-sunken);border-radius:var(--r-md);text-align:center}.portal-v2 .qr-image{width:180px;height:180px;margin:0 auto var(--s3);border-radius:var(--r-md);background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:64px}.portal-v2 .qr-note{font-size:12px;color:var(--ink-muted);line-height:1.4}.portal-v2 .newsletter-box{display:flex;align-items:center;gap:var(--s3);padding:var(--s3);border-radius:var(--r-md);background:var(--surface-sunken);margin-top:var(--s3)}.portal-v2 .newsletter-text{flex:1}.portal-v2 .newsletter-title{font-weight:600;font-size:13px}.portal-v2 .newsletter-desc{font-size:11px;color:var(--ink-muted)}.portal-v2 .event-payment{border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s4);margin-top:var(--s2);background:var(--surface-sunken)}.portal-v2 .event-payment-title{font-weight:700;font-size:15px;margin-bottom:var(--s1)}.portal-v2 .event-pay-btn{width:100%;height:48px;border-radius:var(--r-md);display:flex;align-items:center;gap:var(--s3);padding:0 var(--s4);font-weight:600;font-size:14px;transition:all .15s;margin-bottom:var(--s2)}.portal-v2 .event-pay-btn:active{transform:scale(.98)}.portal-v2 .event-pay-btn.saldo{background:var(--positive-light);border:1.5px solid var(--positive);color:var(--positive)}.portal-v2 .event-pay-btn.saldo:hover{background:#bbf7d0}.portal-v2 .event-pay-btn.external{background:var(--surface-raised);border:1.5px solid var(--border);color:var(--ink-soft)}.portal-v2 .event-pay-btn.external:hover{border-color:var(--border-strong);background:var(--surface-hover)}.portal-v2 .event-cancel-btn{width:100%;height:36px;font-size:13px;color:var(--ink-muted);font-weight:600;border-radius:var(--r-sm)}.portal-v2 .event-cancel-btn:hover{color:var(--ink-soft);background:var(--surface-hover)}.portal-v2 .feedback-tabs{display:flex;gap:var(--s2);margin-bottom:var(--s4);border-bottom:1px solid var(--border);padding-bottom:var(--s3)}.portal-v2 .feedback-tab{padding:var(--s2) var(--s4);border-radius:var(--r-full);font-weight:600;font-size:13px;color:var(--ink-muted);transition:all .15s}.portal-v2 .feedback-tab:hover{color:var(--ink-soft);background:var(--surface-sunken)}.portal-v2 .feedback-tab.active{background:var(--flango-light);color:var(--flango-dark)}.portal-v2 .feedback-type-chips{display:flex;flex-wrap:wrap;gap:var(--s2);margin-bottom:var(--s3)}.portal-v2 .feedback-type-chips .chip{font-size:13px;padding:6px 12px}.portal-v2 .feedback-textarea{width:100%;border:1.5px solid var(--border);border-radius:var(--r-md);padding:var(--s3);font-size:14px;resize:vertical;min-height:80px;background:var(--surface-raised);transition:border-color .15s;margin-bottom:var(--s3);font-family:var(--font);line-height:1.5}.portal-v2 .feedback-textarea:focus{outline:none;border-color:var(--flango);box-shadow:0 0 0 3px #f5960a1f}.portal-v2 .admin-bar{z-index:200;background:linear-gradient(135deg,#1c1917,#292524);color:#fff;padding:var(--s3) var(--s5);display:flex;align-items:center;justify-content:space-between;gap:var(--s4);flex-wrap:nowrap;overflow:visible}.portal-v2 .admin-bar-left{display:flex;align-items:center;gap:var(--s3);flex-shrink:0}.portal-v2 .admin-bar-back-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.18);color:#fff;font-size:13px;font-weight:600;padding:6px 14px;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.portal-v2 .admin-bar-back-btn:hover{background:#ffffff38;border-color:#ffffff59}.portal-v2 .admin-bar-label{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#ffffff80}.portal-v2 .admin-bar-institution{font-weight:700;font-size:15px}.portal-v2 .admin-bar-right{display:flex;align-items:center;gap:var(--s4);flex-shrink:0}.portal-v2 .preview-toggle{display:flex;align-items:center;gap:var(--s2);background:#ffffff1a;border-radius:var(--r-full);padding:4px 4px 4px var(--s3);cursor:pointer;transition:background .15s}.portal-v2 .preview-toggle:hover{background:#ffffff26}.portal-v2 .preview-label{font-size:13px;font-weight:600;white-space:nowrap}.portal-v2 .preview-switch{position:relative;width:44px;height:24px;border-radius:var(--r-full);background:#fff3;transition:background .2s}.portal-v2 .preview-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.portal-v2 .preview-toggle.active .preview-switch{background:var(--flango)}.portal-v2 .preview-toggle.active .preview-switch:after{transform:translate(20px)}.portal-v2 .admin-save-bar{position:fixed;bottom:0;left:0;right:0;z-index:200;background:#1c1917f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--s3) var(--s5);display:flex;align-items:center;justify-content:flex-end;gap:var(--s3);border-top:1px solid rgba(255,255,255,.1);transform:translateY(100%);transition:transform .25s ease}.portal-v2 .admin-save-bar.visible{transform:translateY(0)}.portal-v2 .admin-save-bar .save-btn{background:var(--positive)}.portal-v2 .admin-save-bar .discard-btn{background:transparent;color:#fff9;font-weight:600;font-size:14px;padding:0 var(--s4);height:44px}.portal-v2 .admin-save-bar .discard-btn:hover{color:#fff}.portal-v2 .admin-unsaved{font-size:13px;color:#ffffff80;margin-right:auto}.portal-v2 .sidebar-check{width:16px;height:16px;flex-shrink:0;accent-color:var(--positive);cursor:pointer;border-radius:3px}.portal-v2 .sidebar-nav-item.feature-off{opacity:.45}.portal-v2 .sidebar-nav-item.feature-off svg{opacity:.5}.portal-v2.parent-preview .sidebar-check,.portal-v2.parent-preview .sidebar-nav-item.feature-off{display:none}.portal-v2 .section.disabled{opacity:.45;border-style:dashed;border-color:var(--border)}.portal-v2 .section.disabled .section-icon{filter:grayscale(1)}.portal-v2 .section.disabled .section-title,.portal-v2 .section.disabled .section-subtitle{color:var(--ink-muted)}.portal-v2 .sidebar-nav-item.superadmin-locked{position:relative}.portal-v2 .sidebar-nav-item.superadmin-locked .sidebar-check{pointer-events:none;opacity:.5}.portal-v2 .sa-lock{font-size:11px;margin-left:auto;flex-shrink:0}.portal-v2 .sa-lock-on{filter:hue-rotate(90deg)}.portal-v2 .sa-lock-off{filter:grayscale(1)}.portal-v2 .admin-field{margin-top:var(--s3);padding:var(--s3);border-radius:var(--r-md);background:linear-gradient(135deg,#1c191708,#1c19170f);border:1px dashed var(--border-strong)}.portal-v2 .admin-field-label{display:flex;align-items:center;gap:var(--s1);font-size:11px;font-weight:700;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--s2)}.portal-v2 .admin-field-label:before{content:"⚙️";font-size:12px}.portal-v2 .admin-field .input-field{background:var(--surface-raised)}.portal-v2 .admin-field textarea{width:100%;border:1.5px solid var(--border);border-radius:var(--r-md);padding:var(--s3);font-size:13px;resize:vertical;min-height:60px;background:var(--surface-raised);font-family:var(--font);line-height:1.5;transition:border-color .15s}.portal-v2 .admin-field textarea:focus{outline:none;border-color:var(--flango);box-shadow:0 0 0 3px #f5960a1f}.portal-v2 .admin-field .setting-row{padding:var(--s2) 0}.portal-v2 .admin-field .setting-label{font-size:13px}.portal-v2 .admin-field .setting-desc{font-size:11px}.portal-v2.parent-preview .admin-field,.portal-v2.parent-preview .section.disabled,.portal-v2.parent-preview .admin-save-bar{display:none!important}.portal-v2.parent-preview .admin-bar{background:var(--flango)}.portal-v2.parent-preview .admin-bar-label{color:#ffffffb3}@media(min-width:768px){.portal-v2 .admin-bar{position:fixed;top:0;left:240px;right:0;z-index:200}.portal-v2 .main{padding-top:calc(var(--s6) + 60px)}.portal-v2 .admin-save-bar{left:240px}.portal-v2.parent-preview .bottomnav{display:none}}@media(max-width:767px){.portal-v2 .main{padding-top:var(--s4)}.portal-v2 .admin-bar+.topnav{top:48px}.portal-v2 .admin-save-bar{padding-bottom:env(safe-area-inset-bottom,0px)}}.portal-v2 .bottomnav{position:fixed;bottom:0;left:0;right:0;z-index:100;height:var(--bottom-h);background:#fafaf9eb;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom,0px)}.portal-v2 .bnav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--s1) var(--s3);border-radius:var(--r-md);transition:color .15s;color:var(--ink-muted)}.portal-v2 .bnav-item.active{color:var(--flango)}.portal-v2 .bnav-item:hover{color:var(--ink-soft)}.portal-v2 .bnav-item svg{width:22px;height:22px}.portal-v2 .bnav-label{font-size:10px;font-weight:600}@media(min-width:768px){.portal-v2{--nav-h: 72px;--bottom-h: 0px}.portal-v2 .bottomnav{display:none}.portal-v2 .app{flex-direction:row}.portal-v2 .topnav{display:none}.portal-v2 .tab-view{display:flex;animation:none}.portal-v2 .child-selector,.portal-v2 .view-header.mobile-only{display:none}.portal-v2 .desktop-sidebar{display:flex;flex-direction:column;width:240px;min-width:240px;height:100dvh;position:fixed;top:0;left:0;background:var(--surface-raised);border-right:1px solid var(--border);padding-top:var(--s6);z-index:150}.portal-v2 .desktop-sidebar .brand{padding:0 var(--s5);margin-bottom:var(--s6)}.portal-v2 .desktop-sidebar .brand-name{font-size:20px}.portal-v2 .sidebar-child-section{padding:0 var(--s3);margin-bottom:var(--s4);max-height:200px;overflow-y:auto}.portal-v2 .sidebar-child-item{display:flex;align-items:center;gap:var(--s3);padding:var(--s2) var(--s3);border-radius:var(--r-md);cursor:pointer;transition:background .15s;margin-bottom:2px}.portal-v2 .sidebar-child-item:hover{background:var(--surface-sunken)}.portal-v2 .sidebar-child-item.active{background:var(--flango-light)}.portal-v2 .sidebar-child-avatar{width:32px;height:32px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-size:16px;background:var(--flango-mid)}.portal-v2 .sidebar-child-item.active .sidebar-child-avatar{background:var(--flango);color:#fff}.portal-v2 .sidebar-child-name{font-weight:600;font-size:14px}.portal-v2 .sidebar-child-saldo{font-size:12px;color:var(--ink-muted);font-weight:500}.portal-v2 .sidebar-add-child{display:flex;align-items:center;gap:var(--s2);padding:var(--s2) var(--s3);color:var(--ink-muted);font-size:13px;font-weight:600;cursor:pointer;border-radius:var(--r-md);transition:all .15s}.portal-v2 .sidebar-add-child:hover{background:var(--surface-sunken);color:var(--flango)}.portal-v2 .sidebar-add-child svg{width:16px;height:16px}.portal-v2 .sidebar-divider{height:1px;background:var(--border);margin:var(--s2) var(--s5)}.portal-v2 .sidebar-nav{flex:1;padding:0 var(--s3);overflow-y:auto}.portal-v2 .sidebar-nav-item{display:flex;align-items:center;gap:var(--s3);padding:var(--s2) var(--s3);border-radius:var(--r-md);cursor:pointer;transition:background .15s;margin-bottom:2px;font-size:14px;font-weight:500;color:var(--ink-soft)}.portal-v2 .sidebar-nav-item:hover{background:var(--surface-sunken);color:var(--ink)}.portal-v2 .sidebar-nav-item.active{background:var(--flango-light);color:var(--flango-dark);font-weight:600}.portal-v2 .sidebar-nav-item svg{width:18px;height:18px;flex-shrink:0}.portal-v2 .sidebar-nav-item .nav-badge{margin-left:auto;padding:1px 7px;border-radius:var(--r-full);font-size:11px;font-weight:700;background:var(--flango-light);color:var(--flango-dark)}.portal-v2 .sidebar-footer{padding:var(--s3) var(--s5);border-top:1px solid var(--border)}.portal-v2 .sidebar-footer-btn{display:flex;align-items:center;gap:var(--s2);font-size:13px;color:var(--ink-muted);font-weight:500;padding:var(--s2) 0;transition:color .15s;cursor:pointer}.portal-v2 .sidebar-footer-btn:hover{color:var(--ink)}.portal-v2 .sidebar-footer-btn svg{width:16px;height:16px}.portal-v2 .main{margin-left:240px;max-width:none;padding:calc(var(--s6) + 60px) var(--s8) var(--s6);scroll-behavior:smooth;display:flex;flex-direction:column;align-items:center;gap:var(--s4)}.portal-v2 .main>.tab-view{width:100%;max-width:680px;display:contents!important}.portal-v2 .main>.tab-view>*{width:100%;max-width:680px}.portal-v2 .allergen-grid{grid-template-columns:repeat(5,1fr)}}@media(max-width:767px){.portal-v2 .desktop-sidebar{display:none}}.portal-v2 .section.highlight-flash{animation:sectionFlash .8s ease}@keyframes sectionFlash{0%{box-shadow:0 0 #f5960a00}30%{box-shadow:0 0 0 3px #f5960a4d}to{box-shadow:0 0 #f5960a00}}.portal-v2 .admin-bar-center{display:flex;gap:var(--s1);flex:1;justify-content:center;min-width:0}.portal-v2 .admin-page-tab{padding:6px 16px;border-radius:var(--r-full);font-size:13px;font-weight:600;color:#ffffff80;transition:all .15s;white-space:nowrap}.portal-v2 .admin-page-tab:hover{color:#fffc;background:#ffffff14}.portal-v2 .admin-page-tab.active{color:#fff;background:#ffffff26}.portal-v2.parent-preview .admin-page-tab,.portal-v2 .admin-page{display:none}.portal-v2 .admin-page.active{display:block}.portal-v2.parent-preview .admin-page#page-insights,.portal-v2 .insights-sidebar,.portal-v2 .admin-page#page-insights.active .insights-sidebar{display:none!important}@media(min-width:768px){.portal-v2 .admin-page#page-insights.active .insights-sidebar{display:flex!important;width:240px;min-width:240px;height:calc(100dvh - 42px);position:fixed;top:42px;left:0;background:var(--surface-raised);border-right:1px solid var(--border);flex-direction:column;padding-top:var(--s6);z-index:100}}.portal-v2 .insights-page{padding:var(--s6);max-width:1100px;margin:0 auto}@media(min-width:768px){.portal-v2 .insights-page{margin-left:max(240px,calc(50% - 550px));padding-top:60px}}.portal-v2 .insights-page .page-header{margin-bottom:var(--s6)}.portal-v2 .insights-page .page-title{font-size:24px;font-weight:800;letter-spacing:-.02em}.portal-v2 .insights-page .page-subtitle{font-size:14px;color:var(--ink-muted);margin-top:2px}.portal-v2 .insight-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s4);margin-bottom:var(--s6)}.portal-v2 .insight-stat-grid-3{grid-template-columns:repeat(3,1fr)}.portal-v2 .insight-stat-card{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s5)}.portal-v2 .insight-stat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s3)}.portal-v2 .insight-stat-icon{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:18px}.portal-v2 .insight-stat-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--r-full)}.portal-v2 .insight-stat-badge.up{background:#dcfce7;color:#16a34a}.portal-v2 .insight-stat-badge.neutral{background:var(--surface-sunken);color:var(--ink-muted)}.portal-v2 .insight-stat-value{font-family:var(--font-display);font-size:36px;line-height:1.1}.portal-v2 .insight-stat-label{font-size:13px;color:var(--ink-muted);font-weight:500;margin-top:2px}.portal-v2 .insight-stat-detail{font-size:12px;color:var(--ink-soft);margin-top:var(--s2);padding-top:var(--s2);border-top:1px solid var(--border)}.portal-v2 .insight-stat-detail strong{color:var(--ink)}.portal-v2 .insight-section-title{font-size:16px;font-weight:700;margin-bottom:var(--s3)}.portal-v2 .alert-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s3);margin-bottom:var(--s6)}.portal-v2 .alert-card{display:flex;align-items:center;gap:var(--s3);background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s4);cursor:pointer;transition:all .15s}.portal-v2 .alert-card:hover{border-color:var(--flango);box-shadow:0 2px 8px #f5960a1a}.portal-v2 .alert-icon{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.portal-v2 .alert-icon.red{background:#fef2f2}.portal-v2 .alert-icon.orange{background:#fff7ed}.portal-v2 .alert-icon.blue{background:#eff6ff}.portal-v2 .alert-icon.purple{background:#f5f3ff}.portal-v2 .alert-info{flex:1}.portal-v2 .alert-count{font-family:var(--font-display);font-size:28px;line-height:1.1}.portal-v2 .alert-text{font-size:13px;color:var(--ink-muted)}.portal-v2 .alert-action{font-weight:700;color:var(--flango-dark);font-size:14px;white-space:nowrap}.portal-v2 .adoption-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3);margin-bottom:var(--s6)}.portal-v2 .adoption-card{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s4)}.portal-v2 .adoption-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s2)}.portal-v2 .adoption-name{font-size:14px;font-weight:600}.portal-v2 .adoption-pct{font-family:var(--font-display);font-size:24px}.portal-v2 .adoption-bar-track{height:8px;background:var(--surface-sunken);border-radius:var(--r-full);overflow:hidden;margin-bottom:var(--s1)}.portal-v2 .adoption-bar-fill{height:100%;border-radius:var(--r-full);transition:width .5s}.portal-v2 .adoption-detail{font-size:12px;color:var(--ink-muted)}.portal-v2 .parent-list-link{display:flex;align-items:center;justify-content:space-between;padding:var(--s5);background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all .15s;margin-bottom:var(--s6)}.portal-v2 .parent-list-link:hover{border-color:var(--flango);box-shadow:0 2px 8px #f5960a1a}.portal-v2 .charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4);margin-bottom:var(--s6)}.portal-v2 .chart-card{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s5)}.portal-v2 .chart-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s4)}.portal-v2 .chart-card-title{font-weight:700;font-size:15px}.portal-v2 .i-period-toggle{display:flex;gap:2px;background:var(--surface-sunken);border-radius:var(--r-sm);padding:2px}.portal-v2 .i-period-btn{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;color:var(--ink-muted);transition:all .15s}.portal-v2 .i-period-btn.active{background:var(--surface-raised);color:var(--ink);box-shadow:0 1px 3px #00000014}.portal-v2 .i-period-btn:hover{color:var(--ink)}.portal-v2 .chart-bars{display:flex;align-items:flex-end;gap:3px;height:120px}.portal-v2 .chart-bar{flex:1;border-radius:3px 3px 0 0;min-width:4px;transition:height .3s}.portal-v2 .chart-bar.primary{background:var(--flango);opacity:.7}.portal-v2 .chart-bar.primary:hover{opacity:1}.portal-v2 .chart-bar.accent{background:#7c3aed;opacity:.7}.portal-v2 .chart-bar.accent:hover{opacity:1}.portal-v2 .chart-labels{display:flex;justify-content:space-between;margin-top:var(--s1)}.portal-v2 .chart-label{font-size:11px;color:var(--ink-muted)}.portal-v2 .parent-list-overlay{position:fixed;inset:0;z-index:500;background:var(--surface);display:none;flex-direction:column;overflow:hidden}.portal-v2 .parent-list-overlay.open{display:flex}.portal-v2 .pl-page-toolbar{position:sticky;top:0;z-index:10;padding:var(--s3) var(--s5);background:var(--surface-raised);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap;flex-shrink:0}.portal-v2 .pl-topbar{position:sticky;top:0;z-index:10;background:linear-gradient(135deg,#1c1917,#292524);color:#fff;padding:var(--s3) var(--s5);display:flex;align-items:center;justify-content:space-between;gap:var(--s4)}.portal-v2 .pl-topbar-left{display:flex;align-items:center;gap:var(--s3)}.portal-v2 .pl-topbar-back{display:flex;align-items:center;gap:var(--s2);font-size:13px;font-weight:600;color:#fff9;padding:var(--s1) var(--s3);border-radius:var(--r-sm);transition:all .15s;cursor:pointer}.portal-v2 .pl-topbar-back:hover{color:#fff;background:#ffffff1a}.portal-v2 .pl-topbar-title{font-weight:700;font-size:15px}.portal-v2 .pl-toolbar{padding:var(--s4) var(--s5);background:var(--surface-raised);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap}.portal-v2 .pl-search{height:38px;width:280px;border:1.5px solid var(--border);border-radius:var(--r-md);padding:0 var(--s3) 0 36px;font-size:13px;background:var(--surface-raised) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23A8A29E' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat 12px center;transition:border-color .15s}.portal-v2 .pl-search:focus{outline:none;border-color:var(--flango);box-shadow:0 0 0 3px #f5960a1f}.portal-v2 .pl-filter-btn{height:36px;padding:0 var(--s3);border-radius:var(--r-md);border:1.5px solid var(--border);font-size:12px;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;gap:var(--s1);transition:all .15s;background:var(--surface-raised)}.portal-v2 .pl-filter-btn:hover{border-color:var(--border-strong)}.portal-v2 .pl-filter-btn.active{border-color:var(--flango);background:var(--flango-light);color:var(--flango-dark)}.portal-v2 .pl-sep{width:1px;height:24px;background:var(--border)}.portal-v2 .pl-count{font-size:12px;color:var(--ink-muted);font-weight:500;margin-left:auto}.portal-v2 .pl-table-wrap{flex:1;overflow:auto;min-height:0}.portal-v2 .pl-table{width:100%;border-collapse:collapse;background:var(--surface-raised)}.portal-v2 .pl-table thead{background:var(--surface-sunken);position:sticky;top:0;z-index:5}.portal-v2 .pl-table th{padding:var(--s2) var(--s3);text-align:left;font-size:11px;font-weight:700;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em;cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border-bottom:2px solid var(--border);background:var(--surface-sunken)}.portal-v2 .pl-table th:hover{color:var(--ink)}.portal-v2 .pl-table th.sorted{color:var(--flango-dark)}.portal-v2 .pl-table th.sorted:after{content:" ▲";font-size:9px}.portal-v2 .pl-table th.sorted.desc:after{content:" ▼"}.portal-v2 .pl-table td{padding:var(--s2) var(--s3);font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}.portal-v2 .pl-table tr:hover td{background:var(--surface-sunken);cursor:pointer}.portal-v2 .pl-summary{padding:var(--s3) var(--s5);background:var(--surface-sunken);border-top:1px solid var(--border);display:flex;gap:var(--s5);font-size:12px;color:var(--ink-soft);flex-wrap:wrap}.portal-v2 .pl-summary strong{color:var(--ink)}.portal-v2 .pl-tag{display:inline-block;padding:1px 8px;border-radius:var(--r-full);font-size:11px;font-weight:700}.portal-v2 .pl-tag.green{background:#dcfce7;color:#16a34a}.portal-v2 .pl-tag.orange{background:#fff7ed;color:#ea580c}.portal-v2 .pl-tag.red{background:#fef2f2;color:#dc2626}.portal-v2 .pl-tag.blue{background:#eff6ff;color:#2563eb}.portal-v2 .pl-tag.gray{background:var(--surface-sunken);color:var(--ink-muted)}.portal-v2 .pl-action-btn{padding:var(--s1) var(--s3);border-radius:var(--r-sm);font-size:12px;font-weight:700;border:1.5px solid var(--border);color:var(--ink-soft);transition:all .15s}.portal-v2 .pl-action-btn:hover{border-color:var(--flango);color:var(--flango-dark);background:var(--flango-light)}.portal-v2 .pl-child-avatar{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--r-full);background:var(--flango-light);font-size:12px;font-weight:700;color:var(--flango-dark);margin-right:var(--s2);vertical-align:middle}.portal-v2 .pl-no{color:var(--ink-muted)}.portal-v2 .pl-modal-overlay{position:fixed;inset:0;background:#1c191766;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:600;display:none;align-items:center;justify-content:center;padding:var(--s4)}.portal-v2 .pl-modal-overlay.open{display:flex}.portal-v2 .pl-modal{background:var(--surface-raised);border-radius:var(--r-xl);width:100%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.portal-v2 .pl-modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--s5);border-bottom:1px solid var(--border)}.portal-v2 .pl-modal-title{font-weight:800;font-size:18px}.portal-v2 .pl-modal-close{width:36px;height:36px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--ink-muted)}.portal-v2 .pl-modal-close:hover{background:var(--surface-sunken);color:var(--ink)}.portal-v2 .pl-modal-body{padding:var(--s5)}.portal-v2 .pl-modal-sec{margin-bottom:var(--s5)}.portal-v2 .pl-modal-sec:last-child{margin-bottom:0}.portal-v2 .pl-modal-sec-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);margin-bottom:var(--s3)}.portal-v2 .pl-modal-row{display:flex;align-items:center;justify-content:space-between;padding:var(--s2) 0;border-bottom:1px solid var(--border)}.portal-v2 .pl-modal-row:last-child{border-bottom:none}.portal-v2 .pl-modal-actions{display:flex;gap:var(--s2);padding:var(--s4) var(--s5);border-top:1px solid var(--border)}.portal-v2 .pl-modal-actions button{flex:1;height:40px;display:flex;align-items:center;justify-content:center;padding:0 var(--s3);border-radius:var(--r-sm);font-size:12px;font-weight:700;border:1.5px solid var(--border);color:var(--ink-soft);transition:all .15s}.portal-v2 .pl-modal-actions button:hover{border-color:var(--flango);color:var(--flango-dark);background:var(--flango-light)}.portal-v2 .pl-modal-actions .primary{background:var(--flango);color:#fff;border-color:var(--flango)}.portal-v2 .pl-modal-actions .primary:hover{opacity:.9;background:var(--flango);color:#fff}.pv2-code-popup-overlay{position:fixed;inset:0;z-index:10000;background:#00000073;display:flex;align-items:center;justify-content:center;animation:pv2FadeIn .15s ease}.pv2-code-popup{background:#fff;border-radius:16px;max-width:480px;width:90%;box-shadow:0 10px 30px #00000040;overflow:hidden}.pv2-code-popup-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border, #E7E5E4)}.pv2-code-popup-close{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:#a8a29e;cursor:pointer;border:none;background:none}.pv2-code-popup-close:hover{background:#f5f5f4;color:#1c1917}.pv2-code-popup-body{padding:20px}.pv2-code-display{font-size:28px;font-weight:800;letter-spacing:.15em;text-align:center;padding:14px 0;margin:8px 0 12px;background:#fff4e6;border-radius:10px;color:#c47200;font-family:SF Mono,Fira Code,monospace}.pv2-code-copy-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;border:1.5px solid #E7E5E4;background:#fff;color:#1c1917;cursor:pointer;transition:all .15s}.pv2-code-copy-btn:hover{border-color:#f5960a;color:#c47200;background:#fff4e6}.pv2-code-aula-section{background:#fafaf9;border-radius:10px;padding:14px;border:1px solid #E7E5E4}.pv2-code-aula-text{font-size:13px;line-height:1.6;color:#57534e;white-space:pre-wrap;max-height:200px;overflow-y:auto}@keyframes pv2FadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1100px){.portal-v2 .insight-stat-grid,.portal-v2 .insight-stat-grid-3{grid-template-columns:repeat(2,1fr)}.portal-v2 .alert-cards,.portal-v2 .charts-grid{grid-template-columns:1fr}.portal-v2 .adoption-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.portal-v2 .insights-page{padding-top:var(--s4);margin-left:0}.portal-v2 .insight-stat-grid{grid-template-columns:1fr 1fr}}.icon-mgmt-toolbar-wrap{flex-shrink:0;padding:12px 20px;display:flex;flex-direction:column;gap:10px}.icon-mgmt-toolbar-header{display:flex;align-items:center;justify-content:space-between}.icon-mgmt-back-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#94a3b8;font-size:14px;font-weight:600;padding:8px 16px;cursor:pointer;transition:all .15s;flex-shrink:0}.icon-mgmt-back-btn:hover{background:#ffffff24;color:#e2e8f0}.icon-mgmt-toolbar-title{display:flex;align-items:center;gap:16px}.icon-mgmt-toolbar-title h2{margin:0;font-size:16px;font-weight:700}.icon-mgmt-toolbar-title .icon-mgmt-counter{font-size:12px;font-weight:500;color:#94a3b8;white-space:nowrap}.icon-mgmt-toolbar-row{display:flex;gap:8px;align-items:center}.icon-mgmt-search{flex:1;max-width:280px;height:40px;border:1px solid #d1d5db;border-radius:10px;padding:0 12px;font-family:inherit;font-size:13px;background:#f8f9fa;color:#1e293b;outline:none;transition:border-color .15s,background .15s;box-sizing:border-box}.icon-mgmt-search:focus{border-color:#1a8a6e}.icon-mgmt-search::placeholder{color:#94a3b8}.icon-mgmt-toolbar-actions{display:flex;gap:8px;margin-left:auto}.icon-mgmt-action-btn{height:40px;padding:0 16px;border-radius:10px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;border:1px solid #d1d5db;background:#fff;color:#1e293b;display:flex;align-items:center;gap:6px;transition:all .15s;white-space:nowrap}.icon-mgmt-action-btn:hover{background:#f1f5f9;border-color:#94a3b8}.icon-mgmt-action-btn:active{transform:scale(.97)}.icon-mgmt-action-btn.active{background:#1a8a6e26;border-color:#1a8a6e;color:#1a8a6e}.icon-mgmt-create-btn{background:#1a8a6e;color:#fff;border-color:#1a8a6e}.icon-mgmt-create-btn:hover{background:#157a60;border-color:#157a60}.icon-mgmt-quota-bar{height:3px;background:#e2e8f0;flex-shrink:0}.icon-mgmt-quota-fill{height:100%;background:#1a8a6e;border-radius:0 2px 2px 0;transition:width .4s ease}.icon-mgmt-filters{display:flex;flex-wrap:wrap;gap:6px;padding:10px 20px;flex-shrink:0}.icon-mgmt-chip{height:36px;padding:0 14px;border-radius:9999px;font-size:12px;font-weight:500;border:1px solid #e2e8f0;background:#f8f9fa;color:#475569;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:5px;transition:all .15s;flex-shrink:0}.icon-mgmt-chip:hover{background:#e2e8f0;border-color:#cbd5e1}.icon-mgmt-chip.active{background:#1a8a6e26;color:#1a8a6e;border-color:#1a8a6e}.icon-mgmt-chip[data-filter="source:uploaded"].active{background:#2563eb26;color:#60a5fa;border-color:#3b82f6}.icon-mgmt-chip[data-filter="source:ai_generated"].active{background:#7c3aed26;color:#a78bfa;border-color:#7c3aed}.icon-mgmt-chip[data-filter="style:clay"].active{background:#d9770626;color:#fbbf24;border-color:#d97706}.icon-mgmt-chip[data-filter="style:pixar"].active{background:#05966926;color:#34d399;border-color:#059669}.icon-mgmt-chip[data-filter="mode:avatar"].active{background:#6366f126;color:#818cf8;border-color:#6366f1}.icon-mgmt-chip[data-filter="mode:portrait"].active{background:#db277726;color:#f472b6;border-color:#db2777}.icon-mgmt-chip[data-filter="prompt:custom"].active{background:#7c3aed26;color:#a78bfa;border-color:#7c3aed}.icon-mgmt-chip[data-filter="mode:reference"].active{background:#0284c726;color:#38bdf8;border-color:#0284c7}.icon-mgmt-chip[data-filter="mode:motiv"].active{background:#0891b226;color:#22d3ee;border-color:#0891b2}.icon-mgmt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:14px;padding:4px}.icon-mgmt-grid-wrap{flex:1;overflow-y:auto;padding:0 20px 20px}.icon-mgmt-empty{padding:40px;text-align:center;color:#94a3b8;font-size:15px}.icon-mgmt-card{position:relative;display:flex;flex-direction:column;align-items:center;padding:12px 8px 8px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;cursor:default;transition:all .15s;overflow:hidden;min-width:0}.icon-mgmt-card:hover{border-color:#94a3b8;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.icon-mgmt-card-img{width:72px;height:72px;object-fit:cover;border-radius:8px;flex-shrink:0}.icon-mgmt-card-name{font-size:12px;font-weight:500;color:#475569;margin-top:6px;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-mgmt-card-badge{position:absolute;top:5px;left:5px;font-size:10px;padding:2px 6px;border-radius:6px;font-weight:600;line-height:1.4;background:#ffffff14;color:#8888a4}.icon-mgmt-card-badge.source-uploaded{background:#2563eb26;color:#60a5fa}.icon-mgmt-card-badge.source-ai{background:#7c3aed26;color:#a78bfa}.icon-mgmt-hover-actions{position:absolute;top:5px;right:5px;display:flex;flex-direction:column;gap:4px;opacity:0;transition:opacity .15s}.icon-mgmt-card:hover .icon-mgmt-hover-actions{opacity:1}.icon-mgmt-hover-btn{width:28px;height:28px;border-radius:50%;background:#0000000f;border:1px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;color:#475569;box-shadow:0 1px 4px #00000014;transition:all .15s}.icon-mgmt-hover-btn:hover{background:#1a8a6e1f;color:#1a8a6e;border-color:#1a8a6e}.icon-mgmt-delete-btn,.icon-mgmt-settings-btn,.icon-mgmt-rename-input{display:none}.icon-mgmt-grid.edit-mode .icon-mgmt-delete-btn{display:flex;position:absolute;top:4px;right:4px;width:26px;height:26px;border-radius:50%;background:#ef4444;color:#fff;border:none;font-size:12px;cursor:pointer;align-items:center;justify-content:center;line-height:1;z-index:10;transition:background .15s}.icon-mgmt-grid.edit-mode .icon-mgmt-delete-btn:hover{background:#dc2626}.icon-mgmt-grid.edit-mode .icon-mgmt-settings-btn{display:flex;position:absolute;bottom:32px;right:4px;width:26px;height:26px;border-radius:50%;background:#f1f5f9;color:#64748b;border:1px solid #d1d5db;font-size:12px;cursor:pointer;align-items:center;justify-content:center;line-height:1;z-index:10;transition:all .15s}.icon-mgmt-grid.edit-mode .icon-mgmt-settings-btn:hover{border-color:#1a8a6e;color:#1a8a6e}.icon-mgmt-grid.edit-mode .icon-mgmt-card-name{display:none}.icon-mgmt-grid.edit-mode .icon-mgmt-rename-input{display:block;width:calc(100% - 8px);height:28px;margin:4px 4px 0;border:1px solid #1a8a6e;border-radius:6px;font-size:11px;font-family:inherit;text-align:center;padding:0 4px;outline:none;background:#f8f9fa;color:#1e293b;box-sizing:border-box}.icon-mgmt-grid.edit-mode .icon-mgmt-rename-input:focus{background:#fff}.icon-mgmt-grid.edit-mode .icon-mgmt-hover-actions{display:none}.icon-mgmt-grid.edit-mode .icon-mgmt-card{animation:icon-edit-wiggle .3s ease}@keyframes icon-edit-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-1deg)}75%{transform:rotate(1deg)}}.icon-create-modal-content{max-width:520px;width:95%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:iconModalIn .2s ease-out}@keyframes iconModalIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.icon-create-header{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.icon-create-header h2{font-size:16px;font-weight:700;margin:0}.icon-create-tabs{display:flex;flex-shrink:0;border-bottom:1px solid #e2e8f0}.icon-create-tab{flex:1;padding:10px 0;text-align:center;font-size:13px;font-weight:500;color:#94a3b8;cursor:pointer;border:none;border-bottom:2px solid transparent;background:transparent;transition:all .15s;font-family:inherit}.icon-create-tab:hover{color:#475569}.icon-create-tab.active{color:#1a8a6e;border-bottom-color:#1a8a6e}.icon-create-body{padding:20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:20px}.icon-create-tab-content{display:none}.icon-create-tab-content.active{display:flex;flex-direction:column;gap:20px}.icon-create-section-label{font-size:13px;font-weight:600;color:#1e293b;margin-bottom:2px}.icon-create-section-help{font-size:12px;color:#64748b;line-height:1.5;margin-bottom:10px}.icon-create-style-cards{display:flex;gap:10px}.icon-create-style-card{flex:1;padding:12px;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .15s;text-align:center;background:#fff;font-family:inherit;color:#1e293b}.icon-create-style-card:hover{border-color:#94a3b8}.icon-create-style-card.selected{border:2px solid #1a8a6e;background:#1a8a6e1a}.icon-create-style-card .style-card-emoji{font-size:22px;margin-bottom:6px}.icon-create-style-card .style-card-label{font-size:13px;font-weight:600;color:#1e293b}.icon-create-style-card .style-card-desc{font-size:11px;color:#64748b;margin-top:3px;line-height:1.4}.icon-create-name-input{width:100%;height:38px;border:1px solid #d1d5db;border-radius:8px;padding:0 12px;font-family:inherit;font-size:13px;outline:none;background:#f8f9fa;color:#1e293b;box-sizing:border-box;transition:border-color .15s}.icon-create-name-input:focus{border-color:#1a8a6e}.icon-create-photo-actions{display:flex;gap:10px}.icon-create-camera-action{flex:1;border-style:dashed}.icon-create-dropzone{border:2px dashed #d1d5db;border-radius:10px;padding:20px;text-align:center;cursor:pointer;transition:all .15s;color:#94a3b8;font-size:12px;background:#fafafa}.icon-create-dropzone:hover,.icon-create-dropzone.dragover{border-color:#1a8a6e;background:#f0fdf4}.icon-create-mode-btns{display:flex;gap:8px}.icon-create-mode-btn{flex:1;height:38px;border-radius:9999px;border:1px solid #d1d5db;background:#fff;font-size:12px;font-weight:500;color:#64748b;cursor:pointer;transition:all .15s;font-family:inherit}.icon-create-mode-btn:hover{border-color:#94a3b8}.icon-create-mode-btn.active,.icon-create-mode-btn.selected{background:#1a8a6e26;color:#1a8a6e;border-color:#1a8a6e}.icon-create-mode-desc{font-size:12px;color:#64748b;line-height:1.5;padding:8px 12px;background:#f8f9fa;border-radius:8px;margin-top:6px}.icon-create-style-selector{display:flex;gap:4px;background:#f1f5f9;border-radius:8px;padding:3px}.icon-create-style-btn,.icon-create-photo-mode-btn{flex:1;padding:7px 10px;border:none;border-radius:6px;background:transparent;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;color:#64748b}.icon-create-style-btn:hover,.icon-create-photo-mode-btn:hover{background:#e2e8f0}.icon-create-style-btn.active,.icon-create-photo-mode-btn.active{background:#fff;color:#1e293b;box-shadow:0 1px 3px #0000001a}.icon-create-adv-toggle{font-size:12px;color:#64748b;cursor:pointer;display:flex;align-items:center;gap:4px;font-weight:500;border:none;background:none;font-family:inherit;padding:0}.icon-create-adv-toggle:hover{color:#1a8a6e}.icon-create-prompt-area{width:100%;height:68px;border:1px solid #d1d5db;border-radius:8px;padding:8px;font-family:Courier New,monospace;font-size:12px;resize:vertical;outline:none;color:#1e293b;background:#f8f9fa;box-sizing:border-box}.icon-create-prompt-area:focus{border-color:#1a8a6e}.icon-create-gen-btn{width:100%;height:46px;border-radius:10px;background:#1a8a6e;color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.icon-create-gen-btn:hover{background:#157a60}.icon-create-gen-btn:active{transform:scale(.98)}.icon-create-preview-strip{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f9fa;border-radius:10px}.icon-create-preview-thumb{width:72px;height:72px;border-radius:8px;object-fit:cover;border:1px solid #e2e8f0;flex-shrink:0}.icon-create-preview-info{font-size:12px;color:#64748b;line-height:1.6}.icon-create-preview-info strong{color:#1e293b;font-weight:600}.icon-create-locked-ref{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f8f9fa;border-radius:10px;border:1px dashed #d1d5db}.icon-create-locked-ref .lock-icon{font-size:14px;color:#94a3b8}.icon-create-locked-ref .lock-text{font-size:12px;color:#64748b}.icon-create-photo-preview{margin-top:8px;display:flex;align-items:center;gap:10px}.icon-create-photo-preview img{width:64px;height:64px;border-radius:8px;object-fit:cover;border:1px solid #e2e8f0}.icon-create-photo-remove-btn{background:#ef4444;color:#fff;border:none;border-radius:6px;padding:4px 10px;font-size:11px;cursor:pointer;font-weight:500;transition:background .15s}.icon-create-photo-remove-btn:hover{background:#dc2626}.icon-create-ai-result{text-align:center;margin-top:12px}.icon-create-ai-result img{max-width:160px;max-height:160px;border-radius:12px;border:2px solid #7c3aed}.icon-create-ai-result-label{margin-top:6px;font-size:12px;color:#a78bfa;font-weight:600}.icon-create-upload-preview{text-align:center;margin-top:10px}.icon-create-upload-preview img{max-width:128px;max-height:128px;border-radius:12px;border:2px solid #e2e8f0}.icon-create-spinner{width:24px;height:24px;border:3px solid #e2e8f0;border-top-color:#1a8a6e;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 8px}@keyframes spin{to{transform:rotate(360deg)}}.icon-create-footer{padding:12px 20px;border-top:1px solid #e2e8f0;display:flex;align-items:center;gap:12px;flex-shrink:0}.icon-create-footer-name{flex:1;height:38px;border:1px solid #d1d5db;border-radius:8px;padding:0 12px;font-family:inherit;font-size:13px;outline:none;background:#f8f9fa;color:#1e293b;box-sizing:border-box}.icon-create-footer-name:focus{border-color:#1a8a6e;background:#fff}.icon-create-cancel-btn{height:40px;padding:0 20px;background:#f1f5f9;color:#475569;border:1px solid #d1d5db;border-radius:10px;cursor:pointer;font-weight:600;font-size:13px;font-family:inherit;transition:all .15s}.icon-create-cancel-btn:hover{background:#e2e8f0}.icon-create-save-btn{height:40px;padding:0 20px;background:#1a8a6e;color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:600;font-size:13px;font-family:inherit;transition:all .15s}.icon-create-save-btn:hover{background:#157a60}.icon-create-save-btn:disabled{opacity:.4;cursor:not-allowed}.icon-create-status{text-align:center;padding:12px}.icon-create-status-text{font-size:13px;color:#64748b}.icon-preview-modal{position:fixed;inset:0;z-index:var(--z-modal-nested);display:flex;align-items:center;justify-content:center}.icon-preview-backdrop{position:absolute;inset:0;background:#000000d1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.icon-preview-content{position:relative;z-index:1;text-align:center;padding:24px;max-width:90%}.icon-preview-img-wrap{width:480px;height:480px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto;overflow:hidden}.icon-preview-img-wrap img{width:100%;height:100%;object-fit:contain;border-radius:16px}.icon-preview-name{color:#fff;font-size:18px;font-weight:600;margin-top:16px}.icon-preview-meta{display:flex;gap:8px;justify-content:center;margin-top:8px;flex-wrap:wrap}.icon-preview-meta-chip{font-size:12px;color:#ffffffa6;padding:3px 10px;border:1px solid rgba(255,255,255,.2);border-radius:9999px}.icon-preview-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#ffffff1f;color:#fff;border:none;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.icon-preview-nav:hover{background:#ffffff38}.icon-preview-nav-prev{left:16px}.icon-preview-nav-next{right:16px}.icon-preview-close{position:absolute;top:12px;right:16px;width:40px;height:40px;border-radius:50%;background:#ffffff1f;color:#fff;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.icon-preview-close:hover{background:#ffffff38}.icon-preview-modal .avatar-preview-backdrop{position:absolute;inset:0;background:#000000d1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.icon-preview-modal .avatar-preview-content{position:relative;max-width:80vw;max-height:80vh}.icon-preview-modal .avatar-preview-full{width:100%;height:100%;object-fit:contain;border-radius:16px}.icon-preview-info{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);text-align:center;color:#fff;white-space:nowrap}.icon-preview-info-name{font-size:16px;font-weight:700}.icon-preview-info-meta{font-size:12px;opacity:.7;margin-top:2px}.icon-mgmt-categories{display:flex;gap:6px;padding:8px 20px 4px;flex-shrink:0}.icon-mgmt-cat-chip{padding:8px 16px;border:2px solid rgba(255,255,255,.08);border-radius:10px;background:#ffffff08;color:#94a3b8;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.icon-mgmt-cat-chip:hover{border-color:#fff3;background:#ffffff0f}.icon-mgmt-cat-chip.active{border-color:#7c3aed;background:#7c3aed26;color:#c4b5fd}.icon-mgmt-dark{background:#1a1a2e;color:#e2e8f0}.icon-mgmt-dark input,.icon-mgmt-dark textarea{color:#e2e8f0;background:#ffffff14;border-color:#ffffff1f}.icon-mgmt-dark input::placeholder{color:#64748b}.icon-mgmt-dark input:focus{outline:none;border-color:#7c3aed}.icon-mgmt-dark .close-btn{color:#94a3b8}.icon-mgmt-dark .icon-mgmt-action-btn{background:#ffffff14;color:#e2e8f0;border:1px solid rgba(255,255,255,.1)}.icon-mgmt-dark .icon-mgmt-action-btn:hover{background:#ffffff1f}.icon-mgmt-dark .icon-mgmt-create-btn{background:#7c3aed;color:#fff;border:none}.icon-mgmt-dark .icon-mgmt-chip{background:#ffffff0f;color:#94a3b8;border:1px solid rgba(255,255,255,.08)}.icon-mgmt-dark .icon-mgmt-chip.active{background:#7c3aed26;color:#c4b5fd;border-color:#7c3aed}.icon-mgmt-list{display:block}.icon-list-table{width:100%;border-collapse:collapse;font-size:13px}.icon-list-table thead th{text-align:left;padding:10px 14px;font-size:12px;font-weight:700;color:#94a3b8;border-bottom:2px solid rgba(255,255,255,.1);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.icon-list-table thead th:hover{color:#c4b5fd}.icon-list-table thead th.sorted-asc:after{content:" ▲";font-size:10px}.icon-list-table thead th.sorted-desc:after{content:" ▼";font-size:10px}.icon-list-table tbody tr{border-bottom:1px solid rgba(255,255,255,.06);transition:background .1s}.icon-list-table tbody tr:hover{background:#ffffff0a}.icon-list-table td{padding:8px 14px;vertical-align:middle}.icon-list-editable{background:none;border:1px solid transparent;border-radius:6px;padding:4px 8px;color:#e2e8f0;font-size:13px;width:100%;box-sizing:border-box;transition:border-color .15s,background .15s}.icon-list-editable:hover{border-color:#ffffff1f;background:#ffffff0a}.icon-list-editable:focus{outline:none;border-color:#7c3aed;background:#ffffff14}.icon-list-editable.tags-input{font-size:12px;color:#94a3b8}.icon-list-editable.tags-input:focus{color:#e2e8f0}.icon-tags-cell{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.icon-tag-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:#7c3aed;color:#fff;border-radius:6px;font-size:11px;font-weight:600;white-space:nowrap}.icon-tag-remove{background:none;border:none;color:#94a3b8;font-size:10px;cursor:pointer;padding:0 2px;line-height:1}.icon-tag-remove:hover{color:#ef4444}.icon-tag-input{border:none;background:none;color:#94a3b8;font-size:12px;padding:2px 4px;width:70px;min-width:50px}.icon-tag-input:focus{outline:none;color:#e2e8f0}.icon-tag-input::placeholder{color:#475569}.icon-list-delete-btn,.icon-list-table .icon-mgmt-download-btn{background:none;border:none;cursor:pointer;font-size:18px;padding:4px;transition:transform .15s}.icon-list-delete-btn:hover,.icon-list-table .icon-mgmt-download-btn:hover{transform:scale(1.2)}.pip-overlay{position:fixed;inset:0;z-index:var(--z-modal-overlay);display:flex;background:#000000b3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:pipOverlayIn .2s ease-out}.pip-fullscreen{width:100%;height:100%;display:flex;flex-direction:column;--bg-raised: rgba(255, 255, 255, .08);--bg-inset: rgba(255, 255, 255, .04);--bg-hover: rgba(255, 255, 255, .14);--fg: #e2e8f0;--fg-muted: #94a3b8;--border-strong: rgba(255, 255, 255, .15);--border: rgba(255, 255, 255, .08);--accent: #7c3aed;background:#1a1a2e;color:#e2e8f0;overflow:hidden;animation:pipModalIn .2s ease-out}@keyframes pipOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes pipModalIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.pip-header{flex-shrink:0;display:flex;align-items:stretch;gap:12px;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.pip-header h2{margin:0;font-size:18px;font-weight:700;flex:1;display:flex;align-items:center}.pip-back-btn{border:2px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff0d;color:#94a3b8;font-size:16px;font-weight:700;cursor:pointer;padding:18px 24px;transition:all .15s;white-space:nowrap;flex-shrink:0}.pip-back-btn:hover{color:#e2e8f0;background:#ffffff1a;border-color:#fff3}.pip-header-tab{flex:1;padding:18px 24px;border:2px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff08;cursor:pointer;text-align:center;font-size:17px;font-weight:700;color:#64748b;transition:all .15s}.pip-header-tab:hover{border-color:#fff3;background:#ffffff0f;color:#94a3b8}.pip-header-tab.active{border-color:#7c3aed;background:#7c3aed26;color:#c4b5fd}.pip-source-zone{flex-shrink:0;padding:16px 24px;border-bottom:1px solid rgba(255,255,255,.06)}.pip-search-row{margin:0 auto 14px;max-width:320px;position:relative}.pip-search-input{width:100%;padding:10px 16px;border:2px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff14;color:#e2e8f0;font-size:14px;box-sizing:border-box;transition:border-color .15s}.pip-search-input:focus{outline:none;border-color:#7c3aed}.pip-search-input::placeholder{color:#94a3b8}.pip-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;border:none;background:#ffffff0a;color:#94a3b8;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.pip-search-clear:hover{background:#ffffff24;color:#e2e8f0}.pip-subsource-row{display:flex;align-items:flex-start;gap:16px}.pip-source-cards{display:flex;flex-wrap:wrap;gap:10px;flex:1}.pip-source-card{flex:0 0 130px;min-height:90px;padding:14px 10px;border:2px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff08;cursor:pointer;text-align:center;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:4px}.pip-source-card:hover{border-color:#fff3;background:#ffffff0f;transform:translateY(-1px)}.pip-source-card.active{border-color:#7c3aed;background:#7c3aed1f}.pip-source-card .pip-source-emoji{font-size:32px;line-height:1.2}.pip-source-card .pip-source-label{font-size:13px;font-weight:700;color:#e2e8f0}.pip-source-card.active .pip-source-label{color:#c4b5fd}.pip-source-card .pip-source-desc{font-size:10px;color:#64748b;line-height:1.3;max-width:120px}.pip-source-card.active .pip-source-desc{color:#a78bfa}.pip-preview-box{flex-shrink:0;width:120px;height:120px;border-radius:14px;border:2px solid rgba(255,255,255,.1);background:#ffffff0a;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:visible;position:relative}.pip-preview-box img{border-radius:12px}.pip-preview-box img{width:100%;height:100%;object-fit:contain}.pip-preview-placeholder{font-size:36px;opacity:.3}.pip-preview-label{position:absolute;bottom:0;left:0;right:0;padding:4px;font-size:9px;color:#94a3b8;text-align:center;background:#00000080}.pip-preview-clear{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:#ef4444;color:#fff;border:2px solid #1a1a2e;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;z-index:5;transition:transform .15s}.pip-preview-clear:hover{transform:scale(1.1)}.pip-preview-box.generating{background:linear-gradient(90deg,#7c3aed0d 25%,#7c3aed26,#7c3aed0d 75%);background-size:200% 100%;animation:pipShimmer 1.5s infinite}@keyframes pipShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.pip-content-zone{flex:1;overflow-y:auto;padding:20px 24px}.pip-content-section{animation:pipContentIn .15s ease-out;max-width:800px;margin:0 auto}@keyframes pipContentIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pip-icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.pip-icon-option{display:flex;flex-direction:column;align-items:center;padding:12px 8px;border:2px solid rgba(255,255,255,.06);border-radius:12px;background:#ffffff08;cursor:pointer;transition:all .15s;text-align:center}.pip-icon-option:hover{border-color:#fff3;background:#ffffff0f;transform:translateY(-1px)}.pip-icon-option.selected{border-color:#7c3aed;background:#7c3aed1f}.pip-icon-option img{width:72px;height:72px;object-fit:contain;border-radius:8px}.pip-icon-option span{font-size:11px;color:#94a3b8;margin-top:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.pip-emoji-grid{display:flex;flex-wrap:wrap;gap:6px}.pip-emoji-grid span{font-size:28px;cursor:pointer;padding:6px;border-radius:8px;transition:background .15s}.pip-emoji-grid span:hover{background:#ffffff14}.pip-dropzone{border:2px dashed rgba(255,255,255,.15);border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s;background:#ffffff05;max-width:500px;margin:0 auto}.pip-dropzone:hover,.pip-dropzone.dragover{border-color:#7c3aed;background:#7c3aed0f}.pip-dropzone-icon{font-size:48px;margin-bottom:12px}.pip-dropzone-title{font-size:16px;font-weight:600;margin-bottom:6px}.pip-dropzone-desc{font-size:13px;color:#64748b}.pip-camera-trigger{border:2px dashed #60a5fa;border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s;background:#60a5fa0f;max-width:500px;margin:0 auto}.pip-camera-trigger:hover{border-color:#3b82f6;background:#60a5fa1f}.pip-camera-preview{text-align:center;max-width:500px;margin:0 auto}.pip-camera-preview img{width:160px;height:160px;object-fit:cover;border-radius:14px;border:3px solid #60a5fa}.pip-camera-actions{display:flex;gap:10px;margin-top:16px;justify-content:center}.pip-ai-step{margin-bottom:20px}.pip-ai-step-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.pip-step-badge{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pip-step-label{font-size:15px;font-weight:600;color:#e2e8f0}.pip-step-hint{font-size:12px;color:#64748b;margin-left:38px;margin-top:-6px;margin-bottom:10px}.pip-style-cards{display:flex;gap:10px;margin-left:38px}.pip-style-card{flex:1;padding:14px 10px;border:2px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff08;cursor:pointer;text-align:center;transition:all .15s}.pip-style-card:hover{border-color:#fff3;background:#ffffff0f}.pip-style-card.active{border-color:#7c3aed;background:#7c3aed1f}.pip-style-card .pip-card-emoji{font-size:28px}.pip-style-card .pip-card-label{font-size:13px;font-weight:700;margin-top:6px;color:#94a3b8}.pip-style-card.active .pip-card-label{color:#c4b5fd}.pip-style-card .pip-card-desc{font-size:10px;color:#64748b;margin-top:3px;line-height:1.3}.pip-photo-actions{display:flex;gap:10px;margin-left:38px}.pip-photo-btn{flex:1;padding:14px 12px;border:2px dashed rgba(255,255,255,.12);border-radius:12px;background:#ffffff05;cursor:pointer;text-align:center;transition:all .15s;font-size:13px;font-weight:600;color:#94a3b8}.pip-photo-btn:hover{border-color:#7c3aed;background:#7c3aed0f;color:#c4b5fd}.pip-photo-btn .pip-btn-icon{font-size:24px;display:block;margin-bottom:4px}.pip-photo-preview{display:flex;align-items:center;gap:12px;margin-left:38px;padding:10px;background:#ffffff08;border-radius:10px}.pip-photo-preview img{width:64px;height:64px;object-fit:cover;border-radius:8px;border:2px solid rgba(255,255,255,.1)}.pip-photo-remove-btn{padding:6px 14px;border:1px solid #ef4444;border-radius:8px;background:transparent;color:#ef4444;cursor:pointer;font-size:12px;font-weight:600;transition:all .15s}.pip-photo-remove-btn:hover{background:#ef44441a}.pip-mode-section{margin-left:38px;overflow:hidden;transition:max-height .25s ease-out,opacity .2s}.pip-mode-section.pip-disabled{opacity:.4;pointer-events:none}.pip-mode-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.pip-mode-card{padding:12px 10px;border:2px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff08;cursor:pointer;text-align:center;transition:all .15s}.pip-mode-card:hover{border-color:#fff3;background:#ffffff0f}.pip-mode-card.active{border-color:#7c3aed;background:#7c3aed1f}.pip-mode-card .pip-card-emoji{font-size:24px}.pip-mode-card .pip-card-label{font-size:12px;font-weight:700;margin-top:4px;color:#94a3b8}.pip-mode-card.active .pip-card-label{color:#c4b5fd}.pip-mode-card .pip-card-desc{font-size:10px;color:#64748b;margin-top:2px;line-height:1.2}.pip-mode-desc-text{font-size:11px;color:#64748b;font-style:italic;margin-top:8px;margin-left:38px}.pip-advanced-details{margin-left:38px;margin-top:12px}.pip-advanced-details summary{cursor:pointer;font-size:12px;color:#94a3b8;padding:6px 0;-webkit-user-select:none;user-select:none;list-style:none}.pip-advanced-details summary:before{content:"▶ ";display:inline-block;transition:transform .2s}.pip-advanced-details[open] summary:before{transform:rotate(90deg)}.pip-advanced-details .pip-prompt-area{width:100%;min-height:70px;padding:10px 12px;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:12px;font-family:inherit;resize:vertical;box-sizing:border-box;background:#ffffff0a;color:inherit;margin-top:8px}.pip-reset-prompt-btn{background:none;border:none;color:#1a8a6e;font-size:11px;cursor:pointer;padding:4px 0;margin-top:4px}.pip-generate-btn{width:100%;max-width:500px;margin:8px auto 0;display:block;padding:16px 24px;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:16px;cursor:pointer;transition:opacity .15s,transform .15s;touch-action:manipulation}.pip-generate-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.pip-generate-btn:disabled{opacity:.6;cursor:not-allowed}.pip-generate-loading{text-align:center;padding:30px;max-width:500px;margin:0 auto}.pip-loading-spinner{font-size:40px;animation:pipPulse 1.5s infinite}@keyframes pipPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}.pip-loading-message{font-size:14px;color:#a78bfa;margin-top:10px;font-weight:600}.pip-ai-result{text-align:center;max-width:500px;margin:0 auto;animation:pipResultIn .25s ease-out}@keyframes pipResultIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.pip-ai-result img{width:160px;height:160px;border-radius:16px;background:#ffffff0f;padding:8px;box-shadow:0 4px 20px #7c3aed33}.pip-result-label{font-size:12px;color:#a78bfa;margin-top:8px;font-weight:600}.pip-result-actions{display:flex;gap:10px;justify-content:center;margin-top:16px}.pip-footer{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:14px 24px;border-top:1px solid rgba(255,255,255,.08);position:relative;z-index:9999}.pip-name-input{flex:1;padding:10px 14px;border:2px solid rgba(255,255,255,.12);border-radius:10px;background:#ffffff14;color:#e2e8f0;font-size:14px}.pip-name-input::placeholder{color:#64748b}.pip-name-input:focus{outline:none;border-color:#7c3aed}.pip-footer-spacer{flex:1}.pip-manage-library-btn{margin-right:auto;padding:10px 20px;border:1px solid rgba(255,255,255,.2);border-radius:10px;background:#ffffff1a;color:#e2e8f0;cursor:pointer;font-size:14px;font-weight:600;transition:all .15s}.pip-manage-library-btn:hover{background:#ffffff29;color:#fff}.pip-cancel-btn{padding:10px 20px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:transparent;color:#94a3b8;cursor:pointer;font-size:14px;font-weight:600;transition:all .15s}.pip-cancel-btn:hover{background:#ffffff0f}.pip-save-btn{padding:10px 24px;border:none;border-radius:10px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;cursor:pointer;font-size:14px;font-weight:700;transition:all .15s}.pip-save-btn:disabled{opacity:.4;cursor:not-allowed}.pip-save-btn:not(:disabled):hover{opacity:.9;transform:translateY(-1px)}.pip-btn-primary{padding:12px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .15s}.pip-btn-secondary{padding:12px 24px;background:#ffffff0f;color:#94a3b8;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:all .15s}.pip-btn-ai-ref{padding:12px 24px;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .15s}.pip-edit-preview{text-align:center;padding:16px 0 8px}.pip-edit-preview img{width:100px;height:100px;object-fit:cover;border-radius:14px;border:2px solid rgba(255,255,255,.15);box-shadow:0 4px 16px #0003}.pip-edit-preview .pip-edit-name{font-size:13px;color:#94a3b8;margin-top:6px}.pip-separator{display:flex;align-items:center;gap:12px;margin:20px 0 16px;color:#64748b;font-size:13px;font-weight:600}.pip-separator:before,.pip-separator:after{content:"";flex:1;height:1px;background:#ffffff14}.pip-custom-prompt-section{margin-left:38px}.pip-custom-prompt-section textarea{width:100%;min-height:80px;padding:12px 14px;border:2px solid rgba(255,255,255,.1);border-radius:10px;font-size:14px;font-family:inherit;resize:vertical;box-sizing:border-box;background:#ffffff0a;color:inherit}.pip-custom-prompt-hint{font-size:11px;color:#64748b;margin-top:4px}.pip-empty-state{padding:30px;text-align:center;color:#64748b;font-size:14px;background:#ffffff08;border-radius:12px}.pip-bg-removal{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#ffffff08;border-radius:10px;cursor:pointer;-webkit-user-select:none;user-select:none;max-width:500px;margin:16px auto 0}.pip-bg-removal input[type=checkbox]{width:20px;height:20px;margin-top:2px;cursor:pointer}.pip-bg-removal-label{font-weight:600;font-size:14px}.pip-bg-removal-desc{font-size:12px;color:#94a3b8;margin-top:3px}.pip-upload-preview{text-align:center;max-width:500px;margin:16px auto 0}.pip-upload-preview img{width:140px;height:140px;object-fit:cover;border-radius:14px;border:2px solid rgba(255,255,255,.15)}@media(max-width:768px){.pip-source-zone{flex-direction:column;padding:12px 16px}.pip-source-cards{flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:8px}.pip-source-card{flex:0 0 110px;min-height:80px;scroll-snap-align:start}.pip-preview-box{width:80px;height:80px;align-self:center;margin-bottom:8px}.pip-content-zone{padding:16px}.pip-style-cards,.pip-photo-actions{flex-direction:column;margin-left:0}.pip-mode-cards{grid-template-columns:1fr;margin-left:0}.pip-step-hint,.pip-advanced-details,.pip-custom-prompt-section,.pip-mode-section,.pip-mode-desc-text,.pip-photo-preview{margin-left:0}.pip-header,.pip-footer{padding:12px 16px}}.modal-content.edit-user-modal{max-height:90vh;overflow-y:auto!important}#profile-pic-section{margin:10px 0;padding:12px 14px;background:#00000008;border-radius:8px;border:1px solid rgba(0,0,0,.06)}.profile-pic-detail-preview{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgba(0,0,0,.1);flex-shrink:0}.profile-pic-detail-placeholder{width:48px;height:48px;border-radius:50%;background:#e8e8e8;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.pp-detail-label{font-size:13px;font-weight:600;margin-bottom:2px}.pp-detail-sublabel{font-size:11px;color:#64748b}.profile-pic-opt-out-msg{font-size:12px;color:#94a3b8;font-style:italic;margin:0}.pp-detail-label{color:#e2e8f0}.pp-detail-sublabel{color:#94a3b8}#profile-pic-section{background:#ffffff0a;border-color:#ffffff14}.profile-pic-detail-placeholder{background:#ffffff1a}.profile-pic-detail-preview{border-color:#fff3}.pp-inline-thumb{width:26px;height:26px;border-radius:50%;object-fit:cover;vertical-align:middle;margin-right:6px;border:1.5px solid rgba(0,0,0,.12);box-shadow:0 1px 3px #0000001a;flex-shrink:0}.pp-inline-default{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:#e8e8e8;font-size:14px;line-height:1;vertical-align:middle;margin-right:6px;flex-shrink:0}.pp-inline-thumb{border-color:#ffffff40}.pp-inline-default{background:#ffffff1f}.user-list-thumbnail{width:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.profile-pic-thumb{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3);background:#ffffff1a}.profile-pic-placeholder{width:36px;height:36px;border-radius:50%;background:#ffffff14;border:2px dashed rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:14px;color:#ffffff4d}.customer-avatar .profile-pic-selected{width:100%;height:100%;border-radius:50%;object-fit:cover}.profile-pic-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-pic-modal{background:#1e1e2e;border-radius:16px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto;padding:24px;box-shadow:0 20px 60px #00000080;color:#e2e8f0}.profile-pic-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.profile-pic-modal-header h3{margin:0;font-size:18px;font-weight:700;color:#f8fafc!important;-webkit-text-fill-color:#f8fafc!important}.profile-pic-modal-close{background:none;border:none;color:#94a3b8;font-size:28px;cursor:pointer;padding:0 4px;line-height:1}.profile-pic-modal-close:hover{color:#f8fafc}.profile-pic-current{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding:16px;background:#ffffff0d;border-radius:12px}.profile-pic-current-img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.2);flex-shrink:0}.profile-pic-current-placeholder{width:80px;height:80px;border-radius:50%;background:#ffffff14;border:3px dashed rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:32px;color:#ffffff4d;flex-shrink:0}.profile-pic-current-info{flex:1;font-size:13px;color:#94a3b8;line-height:1.5}.profile-pic-current-info strong{color:#e2e8f0}.profile-pic-remove-btn{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:6px 12px;font-size:12px;cursor:pointer;margin-top:8px;transition:background .2s}.profile-pic-remove-btn:hover{background:#ef44444d}.profile-pic-divider{border:none;border-top:1px solid rgba(255,255,255,.1);margin:20px 0}.profile-pic-type-label{font-size:13px;color:#94a3b8;margin-bottom:12px;font-weight:600}.profile-pic-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.profile-pic-type-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 8px;min-height:80px;background:#ffffff0f;border:2px solid rgba(255,255,255,.1);border-radius:12px;color:#e2e8f0;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.profile-pic-type-btn:hover{background:#ffffff1a;border-color:#ffffff40}.profile-pic-type-btn:active{transform:scale(.96)}.profile-pic-type-btn .type-icon{font-size:28px}.profile-pic-type-btn.active{background:#6366f126;border-color:#6366f180;color:#a5b4fc}.profile-pic-type-btn.pp-type-disabled{opacity:.4;pointer-events:none;cursor:not-allowed}.pp-type-disabled-reason{font-size:9px;color:#ef4444;margin-top:2px;font-weight:600;line-height:1.2}.profile-pic-subview{background:#ffffff08;border-radius:12px;padding:16px;margin-bottom:16px;min-height:120px}.profile-pic-upload-area{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;border:2px dashed rgba(255,255,255,.15);border-radius:12px;cursor:pointer;transition:border-color .2s}.profile-pic-upload-area:hover{border-color:#6366f166}.profile-pic-upload-area .upload-icon{font-size:36px;color:#64748b}.profile-pic-upload-area .upload-text{font-size:13px;color:#94a3b8}.profile-pic-camera-container{position:relative;width:100%;aspect-ratio:1;max-width:300px;margin:0 auto;border-radius:50%;overflow:hidden;background:#000}.profile-pic-camera-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.profile-pic-camera-actions{display:flex;justify-content:center;gap:12px;margin-top:16px}.profile-pic-capture-btn{width:64px;height:64px;border-radius:50%;background:#ef4444;border:4px solid rgba(255,255,255,.3);cursor:pointer;transition:transform .15s,background .15s}.profile-pic-capture-btn:hover{transform:scale(1.05);background:#dc2626}.profile-pic-capture-btn:active{transform:scale(.95)}.profile-pic-preview-container{display:flex;flex-direction:column;align-items:center;gap:16px}.profile-pic-preview-img{width:200px;height:200px;border-radius:50%;object-fit:cover;border:4px solid rgba(99,102,241,.4)}.profile-pic-preview-actions{display:flex;gap:12px}.profile-pic-library-scroll{max-height:300px;overflow-y:auto}.profile-pic-library-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:4px}.profile-pic-library-item{aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;border:3px solid transparent;transition:border-color .2s,transform .15s;background:#ffffff0d}.profile-pic-library-item:hover{border-color:#6366f166;transform:scale(1.05)}.profile-pic-library-item.selected{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e40}.profile-pic-library-item img{width:100%;height:100%;object-fit:cover}.profile-pic-btn{padding:10px 20px;border-radius:10px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px;min-width:44px}.profile-pic-btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.profile-pic-btn-primary:hover{filter:brightness(1.1)}.profile-pic-btn-primary:disabled{opacity:.5;cursor:not-allowed}.profile-pic-btn-secondary{background:#ffffff14;color:#94a3b8;border:1px solid rgba(255,255,255,.1)}.profile-pic-btn-secondary:hover{background:#ffffff1f;color:#e2e8f0}.profile-pic-loading{display:flex;align-items:center;justify-content:center;gap:8px;color:#94a3b8;font-size:13px}.profile-pic-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.1);border-top-color:#6366f1;border-radius:50%;animation:pp-spin .6s linear infinite}@keyframes pp-spin{to{transform:rotate(360deg)}}.profile-pic-opt-out-msg{color:#f59e0b;font-size:12px;font-style:italic;padding:8px 12px;background:#f59e0b1a;border-radius:8px;border:1px solid rgba(245,158,11,.2)}.profile-pic-detail-row{display:flex;align-items:center;gap:12px}.profile-pic-detail-preview{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.2);flex-shrink:0}.profile-pic-detail-placeholder{width:48px;height:48px;border-radius:50%;background:#ffffff14;border:2px dashed rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:18px;color:#ffffff4d;flex-shrink:0}@media(max-width:500px){.profile-pic-modal{width:95%;padding:16px;max-height:95vh}.profile-pic-type-grid{gap:8px}.profile-pic-library-grid{grid-template-columns:repeat(3,1fr)}.profile-pic-camera-container{max-width:250px}}.edit-user-accordion{display:flex;flex-direction:column;gap:8px;padding:4px 0}.eu-section{border-radius:12px;overflow:hidden}.eu-section-header{background:#6366f10f;border:1px solid rgba(99,102,241,.15);border-radius:12px;padding:12px 14px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease;-webkit-user-select:none;user-select:none}.eu-section-header:hover{background:#6366f11a;border-color:#6366f140}.eu-section-header.active{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent;background:#6366f11a;border-color:#6366f140}.eu-section-title{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--text-primary, #1e293b);flex:1}.eu-section-icon{width:32px;height:32px;border-radius:50%;background:#6366f11a;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.eu-section-arrow{width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;color:var(--text-secondary, #64748b);font-size:12px}.eu-section-header.active .eu-section-arrow{transform:rotate(180deg)}.eu-section-content{background:#6366f108;border:1px solid rgba(99,102,241,.15);border-top:none;border-radius:0 0 12px 12px;padding:14px;display:none}.eu-section-content.active{display:block}.pp-carousel-track{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 4px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.pp-carousel-item{flex:0 0 auto;width:128px;text-align:center;cursor:pointer;scroll-snap-align:start}.pp-carousel-img{display:block;width:120px;height:120px;max-width:120px;max-height:120px;border-radius:50%;object-fit:cover;border:4px solid transparent;transition:border-color .2s;margin:0 auto}.pp-carousel-label{font-size:11px;color:var(--text-secondary, #64748b);margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pp-carousel-nav{position:absolute;top:50%;transform:translateY(-60%);z-index:5;width:32px;height:32px;border-radius:50%;border:1px solid rgba(99,102,241,.2);background:var(--bg-primary, rgba(255, 255, 255, .95));color:var(--text-primary, #1e293b);font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001f;transition:opacity .2s}.pp-carousel-nav:hover{background:var(--bg-secondary, rgba(240, 240, 255, .95))}.pp-carousel-left{left:-6px}.pp-carousel-right{right:-6px}.eu-section-subtitle{font-size:11px;color:var(--text-secondary, #64748b);font-weight:400;margin-top:1px}.uap-overlay{position:fixed;inset:0;z-index:900;background:var(--modal-backdrop, rgba(0,0,0,.7));display:flex;flex-direction:column;overflow:hidden}.uap-container{display:flex;flex-direction:column;height:100%;background:var(--modal-bg, #1a1a2e);color:var(--text-primary, #e2e8f0)}.uap-header{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;flex-wrap:wrap}.uap-back-btn{padding:8px 16px;background:#ffffff1a;color:inherit;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;white-space:nowrap}.uap-back-btn:hover{background:#ffffff26}.uap-portal-btn{padding:8px 16px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:13px;white-space:nowrap;transition:opacity .15s}.uap-portal-btn:hover{opacity:.85}.uap-title{font-size:18px;font-weight:700;margin:0;white-space:nowrap}.uap-tabs{display:flex;gap:4px;margin-left:auto;flex-shrink:0}.uap-tab{padding:8px 16px;background:transparent;color:var(--text-secondary, #94a3b8);border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;transition:color .15s,border-color .15s}.uap-tab:hover{color:var(--text-primary, #e2e8f0)}.uap-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.uap-toolbar{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;flex-wrap:wrap}.uap-search{width:260px;padding:8px 12px 8px 36px;border:1px solid rgba(255,255,255,.15)!important;border-radius:8px;background:#1e1e2e!important;color:#e2e8f0!important;font-size:14px;outline:none;-webkit-text-fill-color:#e2e8f0!important}.uap-search::placeholder{color:#64748b!important;-webkit-text-fill-color:#64748b!important}.uap-search:focus{border-color:var(--accent)}.uap-search-wrap{position:relative;z-index:10}.uap-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:15px;opacity:.5;pointer-events:none}.uap-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;font-size:18px;cursor:pointer;padding:2px 6px;line-height:1;border-radius:50%;transition:color .15s,background .15s}.uap-search-clear:hover{color:#e2e8f0;background:#ffffff1a}.uap-counter{font-size:12px;color:var(--text-secondary, #94a3b8);margin-left:auto}.uap-filters{display:flex;gap:6px;flex-wrap:wrap}.uap-chip{padding:5px 12px;border-radius:16px;background:#ffffff0f;color:var(--text-secondary, #94a3b8);border:1px solid rgba(255,255,255,.08);cursor:pointer;font-size:12px;font-weight:500;transition:all .15s;white-space:nowrap}.uap-chip:hover{background:#ffffff1a}.uap-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.uap-view-toggles{display:flex;gap:4px}.uap-view-btn{padding:6px 10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:6px;cursor:pointer;font-size:14px;color:var(--text-secondary, #94a3b8)}.uap-view-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.uap-content{flex:1;overflow-y:auto;padding:0}.uap-tab-content{display:none;height:100%}.uap-tab-content.active{display:flex;flex-direction:column}.uap-table-wrap{flex:1;overflow:auto;padding:0 12px 12px}.uap-table{width:100%;border-collapse:collapse;font-size:13px}.uap-table thead{position:sticky;top:0;z-index:2}.uap-table th{padding:10px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #94a3b8);background:var(--modal-bg, #1a1a2e);border-bottom:1px solid rgba(255,255,255,.08);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none}.uap-table th:hover{color:var(--text-primary, #e2e8f0)}.uap-table th.sorted{color:var(--accent)}.uap-table th .sort-arrow{margin-left:4px;font-size:10px}.uap-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.uap-table tr{transition:background .1s}.uap-table tbody tr:hover{background:#ffffff0a}.uap-thumb-link{cursor:pointer;display:inline-block}.uap-thumb-link:hover .uap-thumb,.uap-thumb-link:hover .uap-thumb-placeholder{box-shadow:0 0 0 2px var(--accent)}.uap-thumb{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.uap-thumb-placeholder{width:36px;height:36px;border-radius:50%;background:#6366f126;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--text-secondary, #94a3b8);flex-shrink:0}.uap-row-highlighted{background:#6366f11f!important;outline:2px solid var(--accent);outline-offset:-2px}.uap-deposit-custom-btn{padding:3px 10px;border:1px solid rgba(99,102,241,.3);border-radius:6px;background:#6366f11a;color:var(--accent);font-size:11px;font-weight:600;cursor:pointer;margin-left:4px;transition:all .15s}.uap-deposit-custom-btn:hover{background:#6366f140;border-color:var(--accent)}.uap-deposit-btn{padding:3px 8px;border:1px solid rgba(34,197,94,.3);border-radius:6px;background:#22c55e1a;color:#22c55e;font-size:11px;font-weight:600;cursor:pointer;margin-right:3px;transition:all .15s}.uap-deposit-btn:hover{background:#22c55e40;border-color:#22c55e}.uap-deposit-btn:disabled{opacity:.5;cursor:default}.uap-badge-add{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#6366f126;color:var(--accent);font-size:14px;font-weight:700;transition:background .15s}.uap-badge-add:hover{background:#6366f14d}.uap-cell-link{cursor:pointer;border-bottom:1px dashed rgba(255,255,255,.15);padding-bottom:1px;transition:border-color .15s,color .15s}.uap-cell-link:hover{border-bottom-color:var(--accent);color:var(--accent)}.uap-balance-pos{color:#22c55e;font-weight:600}.uap-balance-neg{color:#ef4444;font-weight:600}.uap-badge-pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500;background:#6366f126;color:var(--accent);margin:1px 2px}.uap-toggle{width:36px;height:20px;cursor:pointer;accent-color:var(--accent)}.uap-pp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px;padding:16px}.uap-pp-card{display:flex;flex-direction:column;align-items:center;padding:10px 6px 8px;border:2px solid rgba(255,255,255,.06);border-radius:12px;background:#ffffff08;cursor:pointer;transition:border-color .15s,transform .15s;position:relative}.uap-pp-card:hover{border-color:#ffffff26;transform:translateY(-1px)}.uap-pp-card.active-pic{border-color:#22c55e}.uap-pp-card-img{width:80px;height:80px;border-radius:50%;object-fit:cover}.uap-pp-card-name{font-size:11px;color:var(--text-secondary, #94a3b8);margin-top:6px;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uap-pp-type-badge{position:absolute;top:4px;left:4px;font-size:10px;padding:1px 5px;border-radius:8px;font-weight:600;line-height:1.4}.uap-lightbox{position:fixed;inset:0;z-index:var(--z-modal-overlay);background:#000000e6;display:flex;align-items:center;justify-content:center;gap:20px}.uap-lightbox-inner{background:var(--modal-bg, #1e1e2e);border-radius:20px;padding:32px 40px;max-width:620px;width:95%;text-align:center}.uap-lightbox-img{width:min(500px,70vw);height:min(500px,70vw);border-radius:50%;object-fit:cover;margin-bottom:20px;box-shadow:0 8px 40px #0006}.uap-lightbox-img-default{display:flex;align-items:center;justify-content:center;font-size:min(120px,18vw);font-weight:700;margin-left:auto;margin-right:auto;flex-shrink:0}.uap-lightbox-close{position:absolute;top:16px;right:20px;font-size:32px;color:#fff;cursor:pointer;background:none;border:none;opacity:.7;transition:opacity .15s}.uap-lightbox-close:hover{opacity:1}.uap-lb-nav{background:#ffffff1a;color:#fff;border:none;font-size:48px;width:64px;height:64px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,opacity .15s;line-height:1}.uap-lb-nav:hover:not(:disabled){background:#fff3}.uap-lb-nav:disabled{opacity:.15;cursor:default}.uap-lb-actions{display:flex;gap:6px;justify-content:center;margin-bottom:12px;flex-wrap:nowrap}.uap-lb-btn{padding:7px 14px;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:12px;cursor:pointer;white-space:nowrap;transition:opacity .15s}.uap-lb-btn:hover{opacity:.85}.uap-crop-container{width:300px;height:300px;margin:0 auto;position:relative;border-radius:50%;overflow:hidden;border:3px solid rgba(255,255,255,.2);background:#0000004d;cursor:grab;touch-action:none}.uap-crop-container:active{cursor:grabbing}.uap-crop-circle{width:100%;height:100%;position:relative;overflow:hidden}.uap-crop-img{position:absolute;top:0;left:0;transform-origin:0 0;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.uap-period-bar{display:flex;gap:6px;padding:0}.uap-consent-ok{color:#22c55e}.uap-consent-no{color:#ef4444}.uap-empty{text-align:center;padding:60px 20px;color:var(--text-secondary, #64748b);font-size:14px}.uap-loading{text-align:center;padding:40px 20px;color:var(--text-secondary, #64748b);font-size:13px}.fsp-overlay{--fsp-bg: #1a1520;--fsp-bg2: #211c28;--fsp-bg4: #362f40;--fsp-accent: #e8734a;--fsp-accent2: #f4a261;--fsp-accent-g: linear-gradient(135deg, #e8734a, #f4a261);--fsp-txt: #f0ece6;--fsp-txt2: #b0a8b8;--fsp-txt3: #7a7182;--fsp-card-h: #332b3d;--fsp-rad: 10px;--fsp-content-bg: #15111a;--fsp-tab-h: 62px;--bg-raised: #241e2d;--bg-inset: var(--fsp-bg);--bg-hover: var(--fsp-card-h);--fg: var(--fsp-txt);--fg-muted: var(--fsp-txt3);--border-strong: rgba(255, 255, 255, .1);--border: rgba(255, 255, 255, .06);--accent: var(--fsp-accent);position:fixed;inset:0;z-index:9000;display:flex;flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--fsp-bg);color:var(--fsp-txt);overflow:hidden}.fsp-overlay *,.fsp-overlay *:before,.fsp-overlay *:after{box-sizing:border-box;margin:0;padding:0}.fsp-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:linear-gradient(135deg,#2a1f30,#1e1828);border-bottom:1px solid rgba(232,115,74,.12);flex-shrink:0}.fsp-hdr-left{display:flex;align-items:center;gap:14px}.fsp-hdr-logo{width:40px;height:40px;border-radius:11px;overflow:hidden;display:flex;align-items:center;justify-content:center}.fsp-hdr-logo img{width:32px;height:32px;object-fit:contain}.fsp-hdr h1{font-size:19px;font-weight:600}.fsp-hdr-sub{font-size:11.5px;color:var(--fsp-txt3);margin-top:2px}.fsp-close-btn{width:36px;height:36px;border-radius:9px;border:none;background:#ffffff0f;color:var(--fsp-txt2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.fsp-close-btn:hover{background:#e8734a26;color:var(--fsp-accent)}.fsp-main{display:flex;flex:1;min-height:0}.fsp-side{width:270px;flex-shrink:0;background:var(--fsp-bg2);display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.06)}.fsp-side-hdr{height:var(--fsp-tab-h);flex-shrink:0;display:flex;align-items:center;gap:9px;padding:0 22px;border-bottom:1px solid rgba(255,255,255,.05)}.fsp-side-hdr-dot{width:9px;height:9px;border-radius:50%;background:var(--fsp-accent);flex-shrink:0}.fsp-side-hdr-text{font-size:14px;font-weight:600;color:var(--fsp-accent)}.fsp-side-items{flex:1;overflow-y:auto;padding:10px}.fsp-side-back{flex-shrink:0;padding:10px;border-top:1px solid rgba(255,255,255,.05)}.fsp-side-back button{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;border-radius:var(--fsp-rad);border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--fsp-txt2);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.fsp-side-back button:hover{background:#e8734a1a;border-color:#e8734a33;color:var(--fsp-txt)}.fsp-si{display:flex;align-items:center;gap:11px;padding:10px 14px;border-radius:var(--fsp-rad);cursor:pointer;transition:all .15s;border:1px solid transparent;margin-bottom:2px}.fsp-si .fsp-si-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fsp-si .fsp-si-text{font-size:14px;color:var(--fsp-txt2);line-height:1.3;flex:1}.fsp-si:hover{background:var(--fsp-card-h);border-color:#ffffff0a}.fsp-si:hover .fsp-si-text{color:var(--fsp-txt)}.fsp-si.active{background:#e8734a1a;border-color:#e8734a2e}.fsp-si.active .fsp-si-icon{color:#fff}.fsp-si.active .fsp-si-text{color:var(--fsp-txt);font-weight:500}.fsp-si:not(.active) .fsp-si-icon{color:var(--fsp-txt3)}.fsp-si-dot{width:8px;height:8px;border-radius:50%;background:#5dca7a;flex-shrink:0}.fsp-right{flex:1;display:flex;flex-direction:column;background:var(--fsp-content-bg);position:relative}.fsp-tabs{height:var(--fsp-tab-h);flex-shrink:0;display:flex;align-items:center;gap:8px;padding:0 24px;background:var(--fsp-bg2);border-bottom:1px solid rgba(255,255,255,.04);overflow-x:auto}.fsp-tab{padding:11px 22px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--fsp-txt3);font-size:14px;font-weight:500;cursor:pointer;border-radius:10px;transition:all .15s;display:flex;align-items:center;gap:9px;white-space:nowrap;font-family:inherit}.fsp-tab svg{opacity:.5;transition:opacity .15s}.fsp-tab:hover{color:var(--fsp-txt2);background:#ffffff0d;border-color:#ffffff1a}.fsp-tab:hover svg{opacity:.8}.fsp-tab.active{color:#fff;background:var(--fsp-accent);border-color:var(--fsp-accent)}.fsp-tab.active svg{opacity:1}.fsp-content{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;overflow-y:auto}.fsp-ph{text-align:center}.fsp-ph-ring{width:72px;height:72px;border-radius:18px;border:2px dashed var(--fsp-txt3);margin:0 auto 18px;display:flex;align-items:center;justify-content:center}.fsp-ph-title{font-size:16px;font-weight:600;margin-bottom:6px}.fsp-ph-desc{font-size:13px;color:var(--fsp-txt3)}.fsp-big-cards{display:flex;gap:32px;align-items:center;justify-content:center;width:100%;max-width:900px}.fsp-big-card{width:440px;height:440px;background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;text-align:center;position:relative}.fsp-big-card:hover{background:var(--fsp-card-h);border-color:#e8734a40;transform:translateY(-2px)}.fsp-big-card-icon{width:160px;height:160px;border-radius:36px;display:flex;align-items:center;justify-content:center}.fsp-big-card-label{position:absolute;top:48px;left:0;right:0;font-size:21px;font-weight:600;color:var(--fsp-txt)}.fsp-big-card-desc{position:absolute;bottom:48px;left:28px;right:28px;font-size:14px;color:var(--fsp-txt3);line-height:1.5}.fsp-toggle{width:44px;height:26px;border-radius:13px;background:var(--fsp-bg4);cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.fsp-toggle.on{background:var(--fsp-accent)}.fsp-toggle:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}.fsp-toggle.on:after{transform:translate(18px)}.fsp-radio{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.15);cursor:pointer;position:relative;flex-shrink:0}.fsp-radio.on{border-color:var(--fsp-accent)}.fsp-radio.on:after{content:"";position:absolute;top:3px;left:3px;width:10px;height:10px;border-radius:50%;background:var(--fsp-accent)}.fsp-page{width:100%;max-width:720px;align-self:flex-start;padding:40px 48px 60px}.fsp-page-title{font-size:22px;font-weight:600;color:var(--fsp-txt);margin-bottom:8px}.fsp-page-desc{font-size:14px;color:var(--fsp-txt3);line-height:1.6;margin-bottom:28px}.fsp-block{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px 22px}.fsp-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.fsp-row-title{font-size:14px;font-weight:500;color:var(--fsp-txt);margin-bottom:3px}.fsp-row-desc{font-size:12px;color:var(--fsp-txt3)}.fsp-section{margin-bottom:16px}.fsp-main-toggle{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.fsp-main-title{font-size:15px;font-weight:600;color:var(--fsp-txt);margin-bottom:4px}.fsp-main-desc{font-size:12px;color:var(--fsp-txt3)}.fsp-expand{overflow:hidden;max-height:0;opacity:0;transition:max-height .3s,opacity .3s}.fsp-expand.open{max-height:400px;opacity:1}.fsp-body{overflow:hidden;max-height:0;opacity:0;transition:max-height .4s,opacity .3s}.fsp-body.open{max-height:1200px;opacity:1}.fsp-collapse-btn{display:flex;align-items:center;gap:8px;padding:14px 18px;background:var(--fsp-bg2);border-radius:14px;cursor:pointer;transition:all .15s;width:100%;border:1px solid rgba(255,255,255,.06);font-family:inherit;color:inherit}.fsp-collapse-btn:hover{background:var(--fsp-card-h)}.fsp-collapse-btn svg{transition:transform .2s}.fsp-collapse-btn.open svg{transform:rotate(90deg)}.fsp-collapse-btn span{font-size:13px;font-weight:600;color:var(--fsp-txt2)}.fsp-collapse-body{overflow:hidden;max-height:0;opacity:0;transition:max-height .35s,opacity .3s}.fsp-collapse-body.open{max-height:600px;opacity:1;overflow:visible}.fsp-collapse-body-inner{padding:12px 0 0}.fsp-overlay input[type=number]::-webkit-inner-spin-button,.fsp-overlay input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.fsp-overlay input[type=number]{-moz-appearance:textfield}.fsp-overlay .fsp-num-wrap{display:flex;align-items:center;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:#1a1520;overflow:hidden}.fsp-overlay .fsp-num-wrap:focus-within{border-color:var(--fsp-accent)}.fsp-overlay .fsp-num-wrap input{flex:1;padding:11px 14px;border:none;background:transparent;color:#f0ece6;font-size:14px;outline:none;font-family:inherit;min-width:0}.fsp-overlay .fsp-num-wrap input::placeholder{color:var(--fsp-txt3)}.fsp-num-btns{display:flex;flex-direction:column;border-left:1px solid rgba(255,255,255,.06)}.fsp-num-btn{width:32px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--fsp-txt3);transition:all .12s;background:none;border:none;padding:0}.fsp-num-btn:hover{background:#e8734a1a;color:var(--fsp-accent)}.fsp-num-btns .fsp-num-btn:first-child{border-bottom:1px solid rgba(255,255,255,.06)}.fsp-btn{padding:11px 28px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;border:none;font-family:inherit}.fsp-btn-primary{background:var(--fsp-accent);color:#fff}.fsp-btn-primary:hover{background:#d4683f}.fsp-btn-ghost{background:none;border:1px solid rgba(255,255,255,.08);color:var(--fsp-txt2)}.fsp-btn-ghost:hover{background:#ffffff0a;color:var(--fsp-txt)}.fsp-save-row{display:flex;justify-content:flex-end;margin-top:28px}.fsp-sub{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:10px;margin-bottom:8px;cursor:pointer;transition:background .15s}.fsp-sub:hover{background:#ffffff0a}.fsp-sub-title{font-size:13px;font-weight:500;color:var(--fsp-txt)}.fsp-sub-hint{font-size:11px;color:var(--fsp-txt3);margin-top:2px}.fsp-role{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:10px;margin-bottom:6px}.fsp-role-left{display:flex;align-items:center;gap:10px;flex:1}.fsp-role-emoji{font-size:16px;flex-shrink:0}.fsp-role-name{font-size:13px;font-weight:500;color:var(--fsp-txt)}.fsp-off{opacity:.35;pointer-events:none;filter:grayscale(.6);transition:all .25s}.fsp-slide-overlay{position:absolute;inset:0;background:#00000080;opacity:0;pointer-events:none;transition:opacity .25s;z-index:10}.fsp-slide-overlay.open{opacity:1;pointer-events:all}.fsp-slide-panel{position:absolute;top:0;right:0;bottom:0;width:520px;background:var(--fsp-bg2);border-left:1px solid rgba(232,115,74,.12);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:11;display:flex;flex-direction:column}.fsp-slide-panel.open{transform:translate(0)}.fsp-slide-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 20px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.fsp-slide-hdr h2{font-size:18px;font-weight:600;color:var(--fsp-txt)}.fsp-slide-close{width:32px;height:32px;border-radius:8px;border:none;background:#ffffff0f;color:var(--fsp-txt2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.fsp-slide-close:hover{background:#e8734a26;color:var(--fsp-accent)}.fsp-slide-body{flex:1;overflow-y:auto;padding:24px 28px 32px}.fsp-slide-footer{flex-shrink:0;padding:16px 28px;border-top:1px solid rgba(255,255,255,.06);display:flex;gap:10px;justify-content:flex-end}.fsp-form-group{margin-bottom:22px}.fsp-form-label{font-size:12px;font-weight:600;color:var(--fsp-txt3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.fsp-overlay .fsp-input{width:100%;padding:11px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#1a1520;color:#f0ece6;font-size:14px;outline:none;font-family:inherit}.fsp-overlay .fsp-input:focus{border-color:var(--fsp-accent)}.fsp-overlay .fsp-input::placeholder{color:var(--fsp-txt3)}.fsp-overlay textarea.fsp-input{resize:vertical;min-height:72px;line-height:1.5}.fsp-dt-block{background:var(--fsp-bg);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px 16px}.fsp-dt-row{display:flex;gap:8px}.fsp-dt-field{flex:1;display:flex;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:#211c28;overflow:hidden;transition:border-color .15s}.fsp-dt-field:focus-within{border-color:var(--fsp-accent)}.fsp-dt-field input{flex:1;padding:10px 12px;border:none;background:transparent;color:#f0ece6;font-size:13px;outline:none;font-family:inherit;text-align:center;color-scheme:dark;-webkit-appearance:none;appearance:none;min-width:0}.fsp-dt-field input::-webkit-calendar-picker-indicator{display:none}.fsp-dt-picker-btn{width:42px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:none;border-left:1px solid rgba(255,255,255,.06);background:#ffffff08;color:var(--fsp-txt3);cursor:pointer;transition:all .15s;padding:0}.fsp-dt-picker-btn:hover{background:#e8734a1a;color:var(--fsp-accent)}.fsp-overlay select,.fsp-overlay input[type=date],.fsp-overlay input[type=time]{color-scheme:dark}.fsp-form-row{display:flex;gap:12px}.fsp-form-row .fsp-form-group{flex:1}.fsp-form-hint{font-size:11px;color:var(--fsp-txt3);margin-top:8px}.fsp-chip{padding:8px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:#ffffff05;color:var(--fsp-txt3);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.fsp-chip:hover{background:#ffffff0d;color:var(--fsp-txt2)}.fsp-chip.on{background:#e8734a1f;border-color:#e8734a4d;color:var(--fsp-accent)}.fsp-theme-card{cursor:pointer;border:2px solid transparent;border-radius:16px;padding:12px;transition:all .2s;background:var(--fsp-bg2)}.fsp-theme-card:hover{border-color:#ffffff1a;background:var(--fsp-card-h)}.fsp-theme-card.active{border-color:var(--fsp-accent);background:#e8734a0f}.fsp-theme-preview{height:100px;border-radius:10px;padding:16px;margin-bottom:12px}.fsp-theme-name{font-size:14px;font-weight:600;color:var(--fsp-txt);margin-bottom:2px}.fsp-theme-desc{font-size:12px;color:var(--fsp-txt3)}.fsp-overlay .fsp-help-search{width:100%;padding:12px 16px 12px 42px;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#211c28;color:#f0ece6;font-size:14px;outline:none;font-family:inherit;transition:border-color .15s}.fsp-help-search:focus{border-color:var(--fsp-accent)}.fsp-help-search::placeholder{color:var(--fsp-txt3)}.fsp-help-search-wrap{position:relative;margin-bottom:24px}.fsp-help-search-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none}.fsp-help-item{border:1px solid rgba(255,255,255,.06);border-radius:12px;margin-bottom:8px;overflow:hidden;background:var(--fsp-bg2);transition:border-color .15s}.fsp-help-item:hover{border-color:#ffffff1a}.fsp-help-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;gap:12px}.fsp-help-hdr-title{font-size:14px;font-weight:500;color:var(--fsp-txt)}.fsp-help-hdr svg{flex-shrink:0;transition:transform .2s;color:var(--fsp-txt3)}.fsp-help-item.open .fsp-help-hdr svg{transform:rotate(180deg)}.fsp-help-body{max-height:0;overflow:hidden;transition:max-height .3s ease}.fsp-help-item.open .fsp-help-body{max-height:600px}.fsp-help-body-inner{padding:0 20px 18px;font-size:13px;color:var(--fsp-txt2);line-height:1.7}.fsp-snd-slider-wrap{display:flex;align-items:center;gap:10px;flex:1}.fsp-snd-slider-wrap input[type=range]{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--fsp-bg4);border-radius:2px;outline:none}.fsp-snd-slider-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--fsp-accent);cursor:pointer}.fsp-snd-val{font-size:12px;font-weight:600;color:var(--fsp-accent);min-width:36px;text-align:right;font-family:monospace}.fsp-snd-select{padding:7px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:var(--fsp-bg);color:var(--fsp-txt);font-size:12px;outline:none;font-family:inherit;cursor:pointer;min-width:100px}.fsp-snd-select:focus{border-color:var(--fsp-accent)}.fsp-snd-play{width:30px;height:30px;border-radius:8px;border:none;background:#e8734a1a;color:var(--fsp-accent);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.fsp-snd-play:hover{background:#e8734a33}.fsp-snd-row{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:16px 20px;margin-bottom:8px}.fsp-snd-row-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}.fsp-snd-row-label{font-size:13px;font-weight:600;color:var(--fsp-txt);min-width:110px}.fsp-pm-badge{display:inline-flex;padding:3px 9px;border-radius:6px;font-size:10.5px;font-weight:600;letter-spacing:.2px;white-space:nowrap}.fsp-pm-badge-green{background:#5dca7a1f;color:#5dca7a}.fsp-pm-badge-blue{background:#5ba0d81f;color:#5ba0d8}.fsp-pm-badge-orange{background:#f4a2611f;color:#f4a261}.fsp-pm-badge-red{background:#e85a6f1f;color:#e85a6f}.fsp-pm-badge-gray{background:#ffffff0f;color:var(--fsp-txt3)}.fsp-pm-card{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;margin-bottom:12px;overflow:hidden;transition:border-color .15s}.fsp-pm-card:hover{border-color:#ffffff1a}.fsp-pm-card-hdr{padding:18px 22px;display:flex;align-items:flex-start;gap:14px;cursor:pointer}.fsp-pm-card-left{flex:1;min-width:0}.fsp-pm-card-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.fsp-pm-card-title{font-size:15px;font-weight:600;color:var(--fsp-txt)}.fsp-pm-card-desc{font-size:12px;color:var(--fsp-txt3);line-height:1.5}.fsp-pm-card-expand{overflow:hidden;max-height:0;opacity:0;transition:max-height .35s ease,opacity .25s ease}.fsp-pm-card-expand.open{max-height:2000px;opacity:1}.fsp-pm-card-body{padding:0 22px 20px;border-top:1px solid rgba(255,255,255,.04)}.fsp-pm-card-body-inner{padding-top:16px}.fsp-pm-detail{font-size:13px;color:var(--fsp-txt2);line-height:1.6;margin-bottom:14px}.fsp-pm-detail strong{color:var(--fsp-txt);font-weight:500}.fsp-tb-preview{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:16px 20px;margin-bottom:28px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.fsp-tb-preview-label{font-size:11px;font-weight:600;color:var(--fsp-txt3);text-transform:uppercase;letter-spacing:.6px;margin-right:4px}.fsp-tb-preview-icon{width:36px;height:36px;border-radius:9px;background:#e8734a1a;display:none;align-items:center;justify-content:center;font-size:16px;transition:all .2s}.fsp-tb-preview-icon.vis{display:flex}.fsp-tb-item{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:16px 20px;display:flex;align-items:center;gap:14px;margin-bottom:8px;transition:all .15s}.fsp-tb-item:hover{border-color:#ffffff1a}.fsp-tb-item-emoji{font-size:20px;flex-shrink:0;width:36px;text-align:center}.fsp-tb-item-info{flex:1}.fsp-tb-item-name{font-size:14px;font-weight:500;color:var(--fsp-txt);margin-bottom:2px}.fsp-tb-item-desc{font-size:12px;color:var(--fsp-txt3)}.fsp-tb-item-note{font-size:11px;color:var(--fsp-accent);margin-top:2px}.fsp-tb-item-drag{width:24px;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:grab;padding:8px 0;flex-shrink:0;opacity:.3;transition:opacity .15s}.fsp-tb-item:hover .fsp-tb-item-drag{opacity:.7}.fsp-tb-item-drag:active{cursor:grabbing;opacity:1}.fsp-tb-item-drag span{display:block;width:14px;height:2px;border-radius:1px;background:var(--fsp-txt2)}.fsp-tb-item.dragging{opacity:.4;border-style:dashed}.fsp-tb-item.drag-over{border-color:var(--fsp-accent);background:#e8734a0d}.fsp-arr-tabs{display:flex;gap:8px;margin-bottom:32px}.fsp-arr-tab{padding:10px 22px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--fsp-txt3);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px;font-family:inherit}.fsp-arr-tab:hover{background:#ffffff0d;color:var(--fsp-txt2)}.fsp-arr-tab.active{background:var(--fsp-accent);border-color:var(--fsp-accent);color:#fff}.fsp-arr-badge{font-size:11px;padding:2px 8px;border-radius:99px;font-weight:600}.fsp-arr-tab.active .fsp-arr-badge{background:#fff3;color:#fff}.fsp-arr-tab:not(.active) .fsp-arr-badge{background:#ffffff0f;color:var(--fsp-txt3)}.fsp-arr-create{padding:12px 24px;border-radius:10px;border:1px dashed rgba(232,115,74,.35);background:#e8734a0f;color:var(--fsp-accent);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px;margin-bottom:36px;font-family:inherit}.fsp-arr-create:hover{background:#e8734a1f;border-color:#e8734a80}.fsp-arr-section-title{font-size:12px;font-weight:600;color:var(--fsp-txt3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}.fsp-arr-card{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px 22px;display:flex;align-items:center;gap:16px;margin-bottom:8px;cursor:pointer;transition:all .15s}.fsp-arr-card:hover{border-color:#ffffff1f}.fsp-arr-card-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.fsp-arr-card-info{flex:1}.fsp-arr-card-name{font-size:14px;font-weight:500;color:var(--fsp-txt);margin-bottom:3px}.fsp-arr-card-meta{font-size:12px;color:var(--fsp-txt3)}.fsp-arr-card-count{font-size:13px;color:var(--fsp-txt2);font-weight:500;display:flex;align-items:center;gap:6px}.fsp-arr-setting{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:20px 24px}.fsp-arr-card.fsp-arr-card-open{border-color:#e8734a33;cursor:default}.fsp-arr-card-chevron{color:var(--fsp-txt3);transition:transform .2s;flex-shrink:0}.fsp-arr-card-open .fsp-arr-card-chevron{transform:rotate(90deg);color:var(--fsp-accent)}.fsp-arr-detail{max-height:0;overflow:hidden;transition:max-height .35s ease,opacity .25s ease;opacity:0;margin-bottom:8px}.fsp-arr-detail.open{max-height:2000px;opacity:1;overflow:visible}.fsp-arr-detail-inner{padding:0 22px 22px;border:1px solid rgba(255,255,255,.06);border-top:none;border-radius:0 0 14px 14px;background:var(--fsp-bg2);margin-top:-8px}.fsp-arr-detail-desc{font-size:13px;color:var(--fsp-txt3);line-height:1.5;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}.fsp-arr-meta-grid{display:flex;gap:8px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04);overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;-ms-overflow-style:none}.fsp-arr-meta-grid::-webkit-scrollbar{display:none}.fsp-arr-meta-pill{flex:1 1 0;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:2px;min-width:0}.fsp-arr-meta-pill-label{font-size:10px;font-weight:600;color:var(--fsp-txt3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.fsp-arr-meta-pill-val{font-size:13px;font-weight:600;color:var(--fsp-txt);white-space:nowrap}.fsp-arr-stats{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}.fsp-arr-stat{flex:1;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:14px 16px;text-align:center}.fsp-arr-stat-label{font-size:10px;font-weight:600;color:var(--fsp-txt3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.fsp-arr-stat-val{font-size:22px;font-weight:600;color:var(--fsp-txt)}.fsp-arr-stat-sub{font-size:11px;color:var(--fsp-txt3);margin-top:2px}.fsp-arr-actions{display:flex;gap:8px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}.fsp-arr-users-title{font-size:12px;font-weight:600;color:var(--fsp-txt3);text-transform:uppercase;letter-spacing:.5px;margin-top:16px;margin-bottom:8px}.fsp-arr-table{width:100%;font-size:12px;border-collapse:collapse;margin-top:14px;table-layout:auto}.fsp-arr-table th{text-align:left;padding:8px 10px;color:var(--fsp-txt3);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06);white-space:nowrap}.fsp-arr-table td{padding:10px;color:var(--fsp-txt2);border-bottom:1px solid rgba(255,255,255,.03);white-space:nowrap}.fsp-arr-table td:first-child{white-space:normal;min-width:80px}.fsp-arr-table tr:hover td{background:#ffffff05}.fsp-arr-pay-badge{display:inline-flex;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600}.fsp-arr-pay-badge.paid{background:#5dca7a1f;color:#5dca7a}.fsp-arr-pay-badge.unpaid{background:#ffffff0f;color:var(--fsp-txt3)}.fsp-arr-table-btn{padding:4px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.08);background:none;color:var(--fsp-txt3);font-size:11px;cursor:pointer;transition:all .12s;font-family:inherit;white-space:nowrap}.fsp-arr-table-btn:hover{background:#ffffff0d;color:var(--fsp-txt2)}.fsp-arr-table-btn.accent{border-color:#e8734a33;color:var(--fsp-accent)}.fsp-arr-table-btn.accent:hover{background:#e8734a14}.fsp-arr-table-rm{width:24px;height:24px;border-radius:6px;border:1px solid rgba(232,90,111,.2);background:none;color:#e85a6f;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .12s}.fsp-arr-table-rm:hover{background:#e85a6f1a}.fsp-up-overlay{position:absolute;inset:0;background:#00000080;opacity:0;pointer-events:none;transition:opacity .25s;z-index:20;display:flex;align-items:center;justify-content:center}.fsp-up-overlay.open{opacity:1;pointer-events:all}.fsp-up-modal{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.08);border-radius:18px;width:540px;max-height:80vh;display:flex;flex-direction:column;transform:scale(.95);transition:transform .25s;overflow:hidden;position:relative}.fsp-up-overlay.open .fsp-up-modal{transform:scale(1)}.fsp-up-hdr{padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.fsp-up-hdr-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.fsp-up-hdr h3{font-size:16px;font-weight:600;color:var(--fsp-txt)}.fsp-up-hdr-event{font-size:12px;color:var(--fsp-accent)}.fsp-up-close{width:28px;height:28px;border-radius:7px;border:none;background:#ffffff0f;color:var(--fsp-txt2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;font-size:14px;font-family:inherit}.fsp-up-close:hover{background:#e8734a26;color:var(--fsp-accent)}.fsp-up-filters{display:flex;gap:6px;padding:12px 24px;border-bottom:1px solid rgba(255,255,255,.04);flex-shrink:0;overflow-x:auto}.fsp-up-filter{padding:6px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--fsp-txt3);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap;flex-shrink:0;font-family:inherit}.fsp-up-filter:hover{background:#ffffff0d;color:var(--fsp-txt2)}.fsp-up-filter.active{background:var(--fsp-accent);border-color:var(--fsp-accent);color:#fff}.fsp-up-search{padding:12px 24px;border-bottom:1px solid rgba(255,255,255,.04);flex-shrink:0}.fsp-up-search-wrap{position:relative}.fsp-up-search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none}.fsp-up-search input{width:100%;padding:10px 14px 10px 36px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#1a1520;color:#f0ece6;font-size:13px;outline:none;font-family:inherit;-webkit-appearance:none;appearance:none}.fsp-up-search input:focus{border-color:var(--fsp-accent)}.fsp-up-search input::placeholder{color:#7a7182;opacity:1}.fsp-up-list{flex:1;overflow-y:auto;padding:6px 0}.fsp-up-user{display:flex;align-items:center;gap:12px;padding:10px 24px;cursor:pointer;transition:background .1s}.fsp-up-user:hover{background:#ffffff08}.fsp-up-user.fsp-up-user-highlight{background:#e8734a14;border-left:3px solid var(--fsp-accent)}.fsp-up-user.enrolled{opacity:.35;pointer-events:none}.fsp-up-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.fsp-up-user-info{flex:1;min-width:0}.fsp-up-user-name{font-size:13px;font-weight:500;color:var(--fsp-txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fsp-up-user-meta{font-size:11px;color:var(--fsp-txt3)}.fsp-up-user-saldo{font-size:13px;font-weight:600;min-width:70px;text-align:right}.fsp-up-user-saldo.pos{color:#5dca7a}.fsp-up-user-saldo.neg{color:#e85a6f}.fsp-up-enrolled-badge{font-size:10px;color:var(--fsp-accent);display:flex;align-items:center;gap:4px}.fsp-up-footer{padding:14px 24px;border-top:1px solid rgba(255,255,255,.05);flex-shrink:0;font-size:12px;color:var(--fsp-txt3);text-align:center}.fsp-up-warn{position:absolute;bottom:0;left:0;right:0;background:var(--fsp-bg2);border-top:1px solid rgba(244,162,97,.2);padding:18px 24px;transform:translateY(100%);transition:transform .25s;z-index:2;border-radius:0 0 18px 18px}.fsp-up-warn.open{transform:translateY(0)}.fsp-up-warn-text{font-size:13px;color:var(--fsp-txt2);line-height:1.5;margin-bottom:14px}.fsp-up-warn-text strong{color:#f4a261;font-weight:600}.fsp-up-warn-btns{display:flex;gap:8px;justify-content:flex-end}.fsp-pay-overlay{position:absolute;inset:0;background:#0000008c;opacity:0;pointer-events:none;transition:opacity .2s;z-index:25;display:flex;align-items:center;justify-content:center}.fsp-pay-overlay.open{opacity:1;pointer-events:all}.fsp-pay-modal{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:420px;padding:28px;transform:scale(.95);transition:transform .2s}.fsp-pay-overlay.open .fsp-pay-modal{transform:scale(1)}.fsp-pay-title{font-size:16px;font-weight:600;color:var(--fsp-txt);margin-bottom:16px;display:flex;align-items:center;gap:8px}.fsp-pay-detail{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:16px;margin-bottom:20px;font-size:13px;color:var(--fsp-txt2);line-height:1.7}.fsp-pay-detail strong{color:var(--fsp-txt);font-weight:600}.fsp-pay-detail .fsp-pay-result{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.04);color:var(--fsp-txt3)}.fsp-pay-detail .fsp-pay-result strong{color:#5dca7a}.fsp-pay-btns{display:flex;gap:8px;justify-content:flex-end}.fsp-reg-overlay{position:absolute;inset:0;background:#0000008c;opacity:0;pointer-events:none;transition:opacity .2s;z-index:25;display:flex;align-items:center;justify-content:center}.fsp-reg-overlay.open{opacity:1;pointer-events:all}.fsp-reg-modal{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:400px;padding:28px;transform:scale(.95);transition:transform .2s}.fsp-reg-overlay.open .fsp-reg-modal{transform:scale(1)}.fsp-rm-overlay{position:absolute;inset:0;background:#0000008c;opacity:0;pointer-events:none;transition:opacity .2s;z-index:25;display:flex;align-items:center;justify-content:center}.fsp-rm-overlay.open{opacity:1;pointer-events:all}.fsp-rm-modal{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:420px;padding:28px;transform:scale(.95);transition:transform .2s}.fsp-rm-overlay.open .fsp-rm-modal{transform:scale(1)}.fsp-tt-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1px solid rgba(255,255,255,.12);color:var(--fsp-txt3);font-size:9px;font-style:italic;font-weight:600;font-family:Georgia,serif;cursor:help;vertical-align:middle;position:relative}.fsp-tt{display:none;position:absolute;top:calc(100% + 8px);left:0;background:var(--fsp-bg);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 16px;font-size:12px;color:var(--fsp-txt2);line-height:1.5;z-index:50;pointer-events:none;min-width:280px}.fsp-tt-label{font-size:10px;font-weight:600;color:var(--fsp-txt3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.fsp-tt-icon:hover+.fsp-tt,.fsp-tt-icon:hover~.fsp-tt{display:block}.fsp-feedback-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.fsp-device-row{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px 22px;display:flex;align-items:center;gap:16px;margin-bottom:8px}.fsp-device-emoji{font-size:22px;flex-shrink:0}.fsp-device-left{flex:1}.fsp-device-title{font-size:14px;font-weight:500;color:var(--fsp-txt)}.fsp-device-meta{font-size:12px;color:var(--fsp-txt3);margin-top:2px}.fsp-rm-sound{background:var(--fsp-bg2);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px 22px}.fsp-rm-sound-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.fsp-rm-sound-title{font-size:14px;font-weight:500;color:var(--fsp-txt)}.fsp-rm-sound-desc{font-size:12px;color:var(--fsp-txt3);margin-bottom:12px}.fsp-rm-sound-chips{display:flex;flex-wrap:wrap;gap:6px}.fsp-rm-schip{padding:7px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--fsp-txt3);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.fsp-rm-schip:hover{background:#ffffff0d;color:var(--fsp-txt2)}.fsp-rm-schip.on{background:#e8734a1f;border-color:#e8734a4d;color:var(--fsp-accent)}.fsp-num-row{display:flex;align-items:center;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.04)}.fsp-num-row label{font-size:13px;font-weight:500;color:var(--fsp-txt2)}.fsp-save-btn{padding:12px 36px;border-radius:10px;font-size:14px;font-weight:600;cursor:default;transition:all .2s;border:none;font-family:inherit;background:var(--fsp-bg4);color:var(--fsp-txt3);pointer-events:none}.fsp-save-btn.dirty{background:var(--fsp-accent);color:#fff;cursor:pointer;pointer-events:all}.fsp-save-btn.dirty:hover{background:#d4683f}@media(min-width:768px){body:has(#screen-club-login:not(.screen-hidden)) #selected-user-info,body:has(#screen-admin-login:not(.screen-hidden)) #selected-user-info,#main-app.screen-hidden #selected-user-info{display:none!important}}@media(max-width:1024px)and (min-width:768px){#main-app{gap:12px;padding:12px}#products{grid-template-columns:repeat(3,1fr);gap:12px;padding:15px}#products:has(>.product-btn:nth-child(2):last-child){grid-template-columns:repeat(2,1fr)}#products:has(>.product-btn:nth-child(4):last-child){grid-template-columns:repeat(2,1fr)}#products:has(>.product-btn:nth-child(5):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(7):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(7):last-child)>.product-btn:last-child{grid-column:span 2}#products:has(>.product-btn:nth-child(8):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(10):last-child)>.product-btn:first-child{grid-column:span 2}#products:has(>.product-btn:nth-child(10):last-child)>.product-btn:last-child{grid-column:span 2}.product-btn{min-height:140px;padding:14px}.modal-content{max-width:90vw;max-height:90vh;margin:20px auto}}@media(max-width:767px){:root{--flango-mobile-header-h: 48px;--flango-mobile-banner-h: 52px;--flango-mobile-footer-h: 240px;--flango-safe-bottom: env(safe-area-inset-bottom, 0px)}html{overflow:hidden;width:100%;height:100%}body{overflow:hidden;width:100%;height:100%;min-height:100svh;padding:0;margin:0;position:relative;overscroll-behavior:none;-webkit-text-size-adjust:100%;background:var(--gradient-body)}@supports (height: 100dvh){body{min-height:100dvh}}#main-app{display:flex;flex-direction:column;grid-template-columns:1fr;grid-template-rows:auto auto 1fr auto;grid-template-areas:none;gap:0;padding:0;margin:0;height:100dvh;width:100%;overflow:hidden}.sidebar-main-header{position:relative;width:100%;background:var(--gradient-primary);border-bottom:1px solid rgba(26,138,110,.3);padding:6px 8px;margin:0;display:flex;flex-shrink:0;grid-area:unset}#main-app.screen-hidden .sidebar-main-header{display:none}.header-actions{display:flex;gap:4px;width:100%;justify-content:space-around}.header-action-btn{width:40px;height:40px;min-width:40px;min-height:40px;padding:4px;flex-shrink:0;background:#fff3;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-sm)}.header-action-btn img{width:30px;height:30px;filter:brightness(0) invert(1)}.user-session-banner,#logged-in-user,.institution-info,#main-app.screen-hidden .user-session-banner{display:none}#selected-user-info{position:fixed;left:8px;right:8px;bottom:calc(var(--flango-mobile-footer-h) + var(--flango-safe-bottom) + 5px);top:auto;z-index:999;display:grid!important;visibility:visible;opacity:1;grid-template-columns:repeat(3,1fr);gap:6px;padding:12px;margin:0;background:var(--bg-raised);backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:0 -4px 20px #00000014;height:auto;pointer-events:auto;min-height:48px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}#selected-user-info:active{transform:scale(.98)}#main-app.screen-hidden #selected-user-info{display:none!important}body:has(#screen-club-login:not(.screen-hidden)) #selected-user-info,body:has(#screen-admin-login:not(.screen-hidden)) #selected-user-info{display:none!important}#selected-user-info:empty:before{content:"VALGT BRUGER";display:block;font-size:12px;font-weight:700;color:var(--fg-muted);text-align:center;padding:10px 8px;opacity:.8;letter-spacing:.5px}#selected-user-info.hidden,#selected-user-info.is-hidden,#selected-user-info[hidden],#selected-user-info[aria-hidden=true]{display:grid!important;visibility:visible;opacity:1}#selected-user-info .info-box{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 2px;min-width:0}#selected-user-info .info-box-label{font-size:9px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.5px}#selected-user-info .info-box-value{font-size:13px;font-weight:700;color:var(--fg);text-shadow:none}#selected-user-info .info-box-value.negative{color:var(--danger-color);font-weight:800}#products-area{width:100%;margin:0;padding:0;flex:1 1 auto;background:var(--bg);grid-area:unset;display:flex;flex-direction:column;overflow:hidden;min-height:0}#products{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:auto;gap:8px;padding:10px;background:transparent;width:100%;margin:0;height:auto;min-height:0;max-height:none;align-content:start;align-items:start;justify-items:center;overflow-x:hidden;overflow-y:auto;scroll-snap-type:none;-webkit-overflow-scrolling:touch;scroll-behavior:auto;box-shadow:none;border-radius:0}#products:has(.product-page){display:flex;flex-direction:row;gap:0;padding:0;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;width:100%;height:auto;min-height:0}#products:has(.product-page)::-webkit-scrollbar{display:none;width:0;height:0}.product-page{flex:0 0 100%;scroll-snap-align:start;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,auto);gap:8px;padding:10px;width:100%;height:auto;box-sizing:border-box;align-content:start;justify-items:center;align-items:start;min-height:0}#products:has(.product-page)~#products-page-dots,#products-area:has(.product-page) #products-page-dots{display:flex}.product-btn{aspect-ratio:1 / 1;width:100%;height:auto;max-height:none;min-height:0;padding:10px 6px;font-size:11px;touch-action:manipulation;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-radius:var(--radius-lg);position:relative;overflow:visible;background:var(--bg-raised);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin:0}#products-page-dots{display:none;justify-content:center;align-items:center;gap:8px;padding:10px 0;margin:0;background:transparent;position:relative;z-index:5}.page-dot{width:8px;height:8px;border-radius:50%;background:#1a8a6e4d;transition:all .2s ease;cursor:pointer}.page-dot.active{width:10px;height:10px;background:var(--gradient-primary);box-shadow:0 2px 8px #1a8a6e66}.product-btn-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:3px;margin:0}.product-info-box{position:relative;display:flex;flex-direction:column;align-items:center;gap:1px;margin-top:0;background:transparent;padding:0}.product-name{font-size:9px;line-height:1.1;margin:0;text-align:center;color:var(--fg);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-family:var(--font-body)}.product-price{font-size:8px;font-weight:700;margin:0;color:var(--accent);line-height:1}.product-icon{position:relative;inset:auto;width:68px;height:68px;margin:0 auto;flex-shrink:0;display:block;object-fit:contain;object-position:center;opacity:1;border-radius:var(--radius-md);z-index:auto}.product-emoji{position:relative;inset:auto;font-size:56px;line-height:68px;width:68px;height:68px;margin:0 auto;flex-shrink:0;display:flex;align-items:center;justify-content:center;text-align:center;z-index:auto}.product-quantity-badge{position:absolute;top:4px;right:4px;background:var(--danger-gradient);color:#fff;border-radius:50%;width:22px;height:22px;font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center;z-index:20;pointer-events:none;box-shadow:0 2px 6px #c4404066;border:2px solid white}.product-quantity-badge.visible{display:flex}.product-badge,.product-shortcut{display:none}.product-btn,.product-btn-inner{overflow:visible}#sidebar{position:fixed;bottom:0;left:0;right:0;width:100%;background:var(--bg-raised);backdrop-filter:none;-webkit-backdrop-filter:none;border-top:1px solid var(--border);box-shadow:0 -4px 20px #00000014;padding:10px calc(10px + env(safe-area-inset-right,0px)) calc(10px + var(--flango-safe-bottom)) calc(10px + env(safe-area-inset-left,0px));margin:0;display:flex;flex-direction:column;gap:0;grid-area:unset;flex-shrink:0;overflow:visible;z-index:100;min-height:0;max-height:calc(var(--flango-mobile-footer-h) + var(--flango-safe-bottom));height:auto}#main-app.screen-hidden #sidebar,#sidebar .sidebar-header{display:none}#current-order{display:block;flex:0 0 auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:10px 10px 10px 14px;margin:0 4px 8px;background:linear-gradient(180deg,#fef9ee,#fdf6e4);backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:var(--radius-md);height:110px;min-height:110px;max-height:110px;border:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative;transform:none}#current-order:before{display:none}#order-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}#order-list li{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 4px 0;min-height:26px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:0;border:none;color:var(--fg);font-family:var(--font-body);font-size:14px;line-height:26px;position:relative;gap:6px}#order-list li:before{display:none}.cart-product-line{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.cart-product-icon{width:20px;height:20px;flex-shrink:0;border-radius:4px}.cart-product-emoji{font-size:16px;line-height:1;flex-shrink:0}.cart-product-line span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;color:var(--fg)}.remove-item-btn{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#c440401a;border-radius:50%;cursor:pointer;transition:all .15s ease;color:var(--danger-color)}.remove-item-btn:active{background:#c4404033;transform:scale(.95)}.cart-remove-icon{width:14px;height:14px;opacity:.9}#checkout-stack{display:flex;flex-direction:column;gap:0;padding:8px;background:var(--bg-inset);backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:none;overflow:hidden}#total-price{background:transparent;border-radius:0;padding:8px 12px;margin:0;color:var(--fg);font-size:18px;font-weight:800;display:flex!important;align-items:center;justify-content:flex-end;border:none;box-shadow:none;text-shadow:none;letter-spacing:.5px;-webkit-text-fill-color:var(--fg);background-clip:unset}#mini-receipt-chips,.order-chip,.order-chip-qty,.order-chip-remove,.order-chip-overflow{display:none}#total-price-value{display:block;width:100%;text-align:right}#user-selection-area{padding:0;margin:0;background:transparent}#user-selection-area>*:not(#user-selection-actions):not(#selected-user-info){display:none;height:0;margin:0;padding:0;border:0;background:transparent}#user-selection-actions{display:flex;gap:6px;margin:0;padding:0;background:transparent;border:0}#user-selection-actions button{flex:1;padding:14px 10px;font-size:14px;font-weight:700;min-height:48px;border-radius:var(--radius-md);border:1px solid var(--border);margin:6px 0 0;background:var(--bg-raised);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:var(--shadow-sm);color:var(--fg);text-shadow:none;letter-spacing:.3px;transition:all .15s ease}#user-selection-actions button:active{transform:scale(.98)}#select-customer-main-btn{padding:14px 10px;font-size:14px;font-weight:700;min-height:48px;background:var(--accent);color:#fff;border:none}#complete-order-btn,#complete-purchase{width:100%;padding:14px 12px;font-size:15px;font-weight:800;min-height:50px;margin:0;background:var(--success-gradient);border:none;box-shadow:var(--shadow-md);border-radius:var(--radius-md);color:#fff}#complete-order-btn:active,#complete-purchase:active{box-shadow:var(--shadow-sm);transform:scale(.97)}*,*:before,*:after{box-sizing:border-box}body{overflow-x:hidden}.modal{padding:0;background:#1a1a2e99;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);align-items:flex-start;overflow-y:auto;justify-content:flex-start}.modal-content{width:100%;max-width:100%;max-height:none;min-height:100vh;margin:0;border-radius:0;box-shadow:none;display:flex;flex-direction:column;height:auto;background:var(--bg-raised)}.modal-header{position:sticky;top:0;z-index:100;background:var(--bg-raised);border-bottom:1px solid var(--border);padding:16px 14px;margin:0;border-radius:0;display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:19px;margin:0;color:var(--fg);-webkit-text-fill-color:var(--fg)}.close-btn{width:40px;height:40px;font-size:30px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;color:var(--accent)}.modal-body{flex:1;padding:14px;overflow-y:auto}.modal-footer{position:sticky;bottom:0;background:var(--bg-raised);border-top:1px solid var(--border);padding:14px;margin:0}.modal-controls{padding:12px 14px;gap:10px;display:flex;flex-direction:column}.modal-controls input{width:100%;padding:14px;font-size:16px;min-height:48px;border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--bg-raised);color:var(--fg)}.modal-controls button{width:100%;padding:14px;font-size:16px;min-height:48px}button,.btn,.action-button{min-height:48px;min-width:44px;padding:12px 16px;font-size:15px;touch-action:manipulation}.primary-btn{font-size:16px;padding:14px 20px;min-height:52px}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select,textarea{min-height:48px;padding:12px 14px;font-size:16px}input[type=checkbox],input[type=radio]{min-width:22px;min-height:22px;cursor:pointer;accent-color:var(--accent)}}@media(max-width:480px){#products{grid-template-columns:repeat(3,1fr)}#sidebar{max-height:260px}.report-buttons button{flex:1 1 100%;min-width:auto}.avatar-option{width:130px;height:130px}.sidebar-header-icon{width:36px;height:36px;min-width:40px;min-height:40px}}@media(max-height:550px)and (orientation:landscape){.sidebar-main-header{padding:8px 12px}#sidebar-logo{width:50px}.user-session-banner{display:none}#main-app{margin-top:120px}body{padding-bottom:220px}#sidebar{max-height:200px}}@media(hover:none)and (pointer:coarse){.product-btn:hover{transform:none}.product-btn:active{transform:scale(.97);transition:transform .1s}button:active{opacity:.85}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms;animation-iteration-count:1;transition-duration:.01ms}}
