@import"https://fonts.googleapis.com/css2?family=Prompt:wght@300;400;500;600;700;800&display=swap";:root{font-family:Prompt,Segoe UI,Tahoma,sans-serif;--kiosk-accent-default: #1f4f8c;--kiosk-surface: #ffffff;--kiosk-border: #d3dde9;--kiosk-text: #16253a;--kiosk-muted: #5a6b80;--kiosk-green: #22c55e;--kiosk-green-dark: #16a34a}*{box-sizing:border-box}button,input,select,textarea{font:inherit}html,body,#app{width:100%;min-height:100%;margin:0}body{background:#eef2f7}body.kiosk-mode{overflow:hidden;overscroll-behavior:none}body.kiosk-cursor-hidden,body.kiosk-cursor-hidden *{cursor:none!important}.kiosk-page{--kiosk-ui-font: "Prompt", "Segoe UI", Tahoma, sans-serif;--kiosk-accent: var(--kiosk-service-color, var(--kiosk-accent-default));--kiosk-accent-dark: color-mix(in srgb, var(--kiosk-accent) 70%, #1f2937);min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;position:relative;overflow:hidden;touch-action:manipulation;user-select:none;-webkit-user-select:none;background-color:#eef2f7;background-image:var(--kiosk-page-image, none),var(--kiosk-page-bg, linear-gradient(165deg, #f8fafc 0%, #eef2f7 52%, #e8eef5 100%));background-size:var(--kiosk-page-image-size, cover),cover;background-position:var(--kiosk-page-image-position, center),center;background-repeat:no-repeat,no-repeat;font-family:var(--kiosk-ui-font);color:var(--kiosk-text)}.kiosk-page button,.kiosk-page p,.kiosk-page span,.kiosk-page h2{font-family:var(--kiosk-ui-font)}.bg-shape{position:absolute;border-radius:50%;pointer-events:none;filter:blur(120px);opacity:.12}.bg-shape-1{width:55vmax;height:55vmax;background:linear-gradient(135deg,var(--kiosk-accent, #4ea542) 0%,#60a5fa 100%);top:-20%;right:-15%;animation:float-shape 20s ease-in-out infinite}.bg-shape-2{width:40vmax;height:40vmax;background:linear-gradient(135deg,#a78bfa,#c9d8ea);bottom:-12%;left:-12%;animation:float-shape 25s ease-in-out infinite reverse}.bg-shape-3{width:28vmax;height:28vmax;background:linear-gradient(135deg,#34d399,#dfe7f1);top:45%;left:60%;opacity:.08;animation:float-shape 18s ease-in-out infinite}@keyframes float-shape{0%,to{transform:translate(0) scale(1)}33%{transform:translate(3%,-4%) scale(1.05)}66%{transform:translate(-2%,3%) scale(.97)}}.kiosk-activate-btn{position:fixed;top:16px;right:16px;z-index:60;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:12px 20px;background:linear-gradient(135deg,#fffffff2,#f8fafce6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--kiosk-text);font-size:13px;font-weight:600;letter-spacing:.01em;display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #0f172a1a}.kiosk-settings-btn{position:fixed;top:16px;left:16px;z-index:60;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:12px 18px;background:linear-gradient(135deg,#fffffff2,#f8fafce6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--kiosk-text);font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #0f172a1a}.kiosk-settings-btn:active,.kiosk-activate-btn:active{transform:scale(.96);background:linear-gradient(135deg,#f8fafcfa,#f1f5f9f2)}.kiosk-settings-btn:hover,.kiosk-activate-btn:hover{border-color:#ffffff80;box-shadow:0 6px 20px #0f172a26;transform:translateY(-1px)}.kiosk-mode-error{position:fixed;top:64px;right:16px;margin:0;z-index:60;border-radius:14px;padding:10px 16px;background:linear-gradient(135deg,#ef4444e6,#b91c1ce6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:12px;font-weight:500;box-shadow:0 4px 16px #ef444459}.connect-overlay{position:fixed;inset:0;z-index:90;background:#0f172a8c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:16px}.connect-panel{width:min(720px,100%);max-height:90vh;overflow:auto;border-radius:20px;border:1px solid rgba(255,255,255,.2);background:linear-gradient(180deg,#fffffffa,#f8fafcf2);box-shadow:0 25px 50px #02061740,0 0 0 1px #ffffff1a inset;padding:24px}.connect-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.connect-header h3{margin:0;font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--kiosk-text) 0%,#3b5998 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.connect-close{border:1px solid var(--kiosk-border);background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#334155;width:36px;height:36px;border-radius:12px;cursor:pointer;transition:all .2s ease;font-size:16px}.connect-close:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);transform:rotate(90deg)}.connect-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.connect-field{display:flex;flex-direction:column;gap:6px}.connect-field span{font-size:12px;font-weight:600;color:#334155}.connect-field input,.connect-field select{width:100%;border:1px solid var(--kiosk-border);border-radius:12px;background:#fff;color:#0f172a;padding:12px 14px;font-size:14px;transition:all .2s ease}.connect-field input:focus,.connect-field select:focus{outline:none;border-color:var(--kiosk-accent-default);box-shadow:0 0 0 3px #1f4f8c1a}.connect-switch{grid-column:1 / -1;display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:#1e293b;margin-top:4px}.connect-message{margin:12px 0 0;font-size:13px;font-weight:500;padding:10px 14px;border-radius:10px}.connect-error{color:#b91c1c;background:#ef44441a}.connect-success{color:#166534;background:#22c55e1a}.connect-hint{margin:12px 0 0;font-size:12px;color:#64748b;padding:10px 14px;background:#64748b14;border-radius:10px}.connect-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.connect-btn{border:1px solid var(--kiosk-border);border-radius:12px;padding:11px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.connect-btn.secondary{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#334155}.connect-btn.secondary:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.connect-btn.primary{background:linear-gradient(135deg,var(--kiosk-accent-default) 0%,#153257 100%);border-color:var(--kiosk-accent-default);color:#fff;box-shadow:0 4px 12px #1f4f8c4d}.connect-btn.primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px #1f4f8c66}.kiosk-main{position:relative;z-index:1;width:100%;max-width:1280px;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding:32px 32px 20px}.kiosk-header{display:flex;flex-direction:column;align-items:center;text-align:center;padding-bottom:20px;flex-shrink:0}.brand-block{display:flex;align-items:center;justify-content:center;margin-bottom:16px}.brand-logo-image{max-width:80%;max-height:80px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(15,23,42,.15))}.brand-logo-text{display:flex;align-items:center;gap:4px}.brand-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:18px;background:linear-gradient(135deg,var(--kiosk-accent, #4ea542) 0%,color-mix(in srgb,var(--kiosk-accent, #4ea542) 60%,#1e3a5f) 100%);color:#fff;font-size:38px;font-weight:800;box-shadow:0 8px 24px #4ea54259}.brand-logo-name{font-size:40px;line-height:1;font-weight:700;background:linear-gradient(135deg,var(--kiosk-text) 0%,#3b5998 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.kiosk-welcome-block{margin-top:4px}.kiosk-welcome{margin:0;font-size:clamp(24px,5.5vw,32px);font-weight:700;color:#13243a;letter-spacing:.01em;text-shadow:0 2px 4px rgba(15,23,42,.08)}.kiosk-welcome-sub{margin:4px 0 0;font-size:clamp(14px,3vw,17px);font-weight:400;color:var(--kiosk-muted);opacity:.9}.services-block{display:grid;grid-template-columns:1fr;gap:16px;flex:1 1 auto;min-height:0;overflow-y:auto;padding:16px 8px;scrollbar-width:none;align-content:start}.services-block.services-grid-2col{grid-template-columns:repeat(2,minmax(0,1fr))}.services-block.services-grid-1col{grid-template-columns:1fr}.services-block.services-grid-auto{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.services-block::-webkit-scrollbar{display:none}.service-card{position:relative;width:100%;border:1px solid rgba(255,255,255,.5);border-radius:18px;background:linear-gradient(135deg,#fffffff2,#f8fafce6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#1f2937;padding:18px 18px 18px 20px;min-height:95px;display:flex;align-items:center;gap:16px;cursor:pointer;text-align:left;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #0f172a14,0 2px 8px #0f172a0a;animation:card-enter .4s ease both;animation-delay:var(--card-delay, 0ms);overflow:hidden}@keyframes card-enter{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.service-card:before{content:"";position:absolute;inset:0;border-radius:18px;background:linear-gradient(140deg,rgba(255,255,255,.4) 0%,transparent 50%);pointer-events:none}.service-card:after{content:"";position:absolute;top:0;left:0;width:5px;height:100%;background:linear-gradient(180deg,var(--kiosk-service-color, var(--kiosk-accent-default)) 0%,color-mix(in srgb,var(--kiosk-service-color, var(--kiosk-accent-default)) 70%,#1e3a5f) 100%);border-radius:18px 0 0 18px;opacity:0;transition:opacity .25s ease}.service-card:hover:not(:disabled){border-color:#ffffffb3;box-shadow:0 12px 32px #0f172a1f,0 4px 12px #0f172a0f;transform:translateY(-3px)}.service-card:hover:not(:disabled):after{opacity:1}.service-card:active:not(:disabled){transform:scale(.98) translateY(0);background:linear-gradient(135deg,#f8fafcfa,#f1f5f9f2);box-shadow:0 6px 16px #0f172a1a}.service-card:disabled{cursor:wait;opacity:.55}.service-card-badge{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--kiosk-service-color, var(--kiosk-accent-default)) 0%,color-mix(in srgb,var(--kiosk-service-color, var(--kiosk-accent-default)) 65%,#1e3a5f) 100%);color:#fff;display:grid;place-items:center;font-size:32px;font-weight:700;flex-shrink:0;box-shadow:0 6px 16px #1f4f8c40;transition:transform .25s ease,box-shadow .25s ease}.service-card:hover:not(:disabled) .service-card-badge{transform:scale(1.05);box-shadow:0 8px 20px #1f4f8c59}.service-card-copy{min-width:0;flex:1;display:flex;flex-direction:column;gap:4px}.service-card-title{font-size:clamp(21px,4.5vw,28px);line-height:1.2;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.service-card-subtitle{font-size:clamp(13px,2.6vw,16px);line-height:1.3;color:var(--kiosk-muted);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.service-card-subtitle:before{content:"⏱️";font-size:14px}.service-card-chevron{flex-shrink:0;width:40px;height:40px;border-radius:12px;background:#94a3b81f;color:#64748b;display:grid;place-items:center;transition:all .25s ease}.service-card:hover:not(:disabled) .service-card-chevron{background:var(--kiosk-service-color, var(--kiosk-accent-default));color:#fff;transform:translate(3px)}.spinner{display:inline-block;width:28px;height:28px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.service-empty{grid-column:1 / -1;border-radius:24px;border:2px dashed rgba(100,116,139,.3);background:linear-gradient(135deg,#fff9,#f8fafc66);color:#64748b;text-align:center;padding:40px 20px;font-size:17px;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:14px}.service-empty svg{opacity:.5}.service-error{margin:14px 0 0;padding:12px 16px;border-radius:14px;background:linear-gradient(135deg,#ef44441f,#dc262614);border:1px solid rgba(220,38,38,.25);color:#b91c1c;font-size:13px;line-height:1.5;display:flex;align-items:flex-start;gap:10px;flex-shrink:0}.service-error svg{flex-shrink:0;margin-top:2px}.kiosk-footer{margin-top:auto;padding-top:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;border-top:1px solid rgba(203,213,225,.4)}.status-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 16px;font-size:12px;font-weight:600;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .25s ease}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-pill.online{background:linear-gradient(135deg,#22c55e26,#16a34a1a);color:#15803d;border:1px solid rgba(34,197,94,.25)}.status-pill.online .status-dot{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 0 8px #22c55e99,0 0 16px #22c55e4d;animation:pulse-dot 2s ease-in-out infinite}.status-pill.offline{background:linear-gradient(135deg,#ef44441f,#b91c1c14);color:#b91c1c;border:1px solid rgba(239,68,68,.2)}.status-pill.offline .status-dot{background:linear-gradient(135deg,#ef4444,#b91c1c)}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}.status-site{color:#64748b;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:6px 14px;background:#64748b14;border-radius:999px}.ticket-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#000000a6,#0f172abf);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:grid;place-items:center;z-index:50;padding:24px;cursor:pointer}.ticket-card{width:min(92vw,420px);border-radius:24px;background:linear-gradient(170deg,#fff,#f8fafc);padding:36px 28px 32px;text-align:center;box-shadow:0 30px 60px #0000004d,0 0 0 1px #ffffff1a inset;cursor:default;position:relative;overflow:hidden}.ticket-card:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--kiosk-ticket-color, var(--kiosk-accent-default)) 0%,var(--kiosk-green) 50%,var(--kiosk-ticket-color, var(--kiosk-accent-default)) 100%)}.ticket-check-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--kiosk-green) 0%,var(--kiosk-green-dark) 100%);display:grid;place-items:center;margin:0 auto 20px;box-shadow:0 10px 30px #22c55e66,0 0 0 6px #22c55e26;animation:check-pop .5s cubic-bezier(.34,1.56,.64,1) both}@keyframes check-pop{0%{transform:scale(0) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.ticket-title{margin:0;font-size:24px;font-weight:700;color:#1e293b;letter-spacing:-.01em}.ticket-number-wrap{margin:14px 0;padding:16px 0;border-radius:20px;background:linear-gradient(135deg,#22c55e1a,#16a34a0f);border:1px solid rgba(34,197,94,.15)}.ticket-number{margin:0;font-size:clamp(68px,15vw,100px);line-height:1;font-weight:800;background:linear-gradient(135deg,var(--kiosk-green-dark) 0%,#0f766e 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.04em;text-shadow:none;animation:number-pulse 2s ease-in-out infinite}@keyframes number-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.ticket-service{margin:0;font-size:22px;color:#334155;font-weight:600}.ticket-time{margin:10px 0 0;font-size:15px;color:#64748b;display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#64748b14;border-radius:999px}.ticket-close-btn{margin-top:24px;width:100%;border:0;border-radius:16px;padding:16px;background:linear-gradient(135deg,var(--kiosk-green) 0%,var(--kiosk-green-dark) 100%);color:#fff;font-size:19px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 6px 20px #22c55e59}.ticket-close-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #22c55e73}.ticket-close-btn:active{transform:scale(.98) translateY(0)}.ticket-pop-enter-active{transition:opacity .3s ease}.ticket-pop-enter-active .ticket-card{animation:ticket-slide-up .4s cubic-bezier(.34,1.56,.64,1) both}.ticket-pop-leave-active{transition:opacity .25s ease}.ticket-pop-enter-from,.ticket-pop-leave-to{opacity:0}@keyframes ticket-slide-up{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:420px){.kiosk-main{padding:20px 16px 14px}.kiosk-activate-btn{top:10px;right:10px;padding:10px 14px;font-size:12px}.kiosk-settings-btn{top:10px;left:10px;padding:10px 14px;font-size:12px}.kiosk-mode-error{top:52px;right:10px;font-size:11px;padding:8px 12px}.service-card{min-height:85px;padding:16px 14px 16px 16px;border-radius:16px}.service-card-badge{width:54px;height:54px;border-radius:14px;font-size:28px}.service-card-chevron{width:36px;height:36px;border-radius:10px}.brand-logo-icon{width:52px;height:52px;font-size:32px;border-radius:16px}.brand-logo-name{font-size:32px}.ticket-card{padding:28px 20px 24px;border-radius:20px}.ticket-check-circle{width:68px;height:68px}.ticket-title{font-size:20px}.ticket-service{font-size:18px}}@media(min-height:800px){.services-block{gap:20px}.service-card{min-height:105px;padding:22px 18px 22px 22px}.service-card-badge{width:70px;height:70px;font-size:36px}}
