:root{--bg: #0c0b0a;--bg-2: #131110;--surface: #1a1714;--ink: #f3ede1;--ink-soft: #b6ab97;--ink-faint: #7d7464;--line: #2a2620;--gold: #c8a86d;--gold-dark: #a98a52;--entrata: #4f7a5b;--entrata-dark: #3c6147;--uscita: #b06a4f;--uscita-dark: #92543c;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);font-family:Helvetica Neue,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--ink);background:var(--bg)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;height:100%;min-height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overscroll-behavior:none;-webkit-user-select:none;user-select:none}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}.kiosk{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;padding:calc(28px + var(--safe-top)) 28px calc(28px + var(--safe-bottom));transition:background .4s ease;background:var(--bg);overflow:hidden}.kiosk-brand{text-align:center;flex:0 0 auto}.kiosk-logo{display:block;width:min(74vw,380px);height:auto;margin:0 auto}.kiosk-rule{width:64px;height:1px;background:var(--gold);margin:16px auto 8px;opacity:.8}.kiosk-tagline{font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);opacity:.85;margin:0}.kiosk-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px}.kiosk-clock{font-size:clamp(64px,22vw,132px);font-weight:200;letter-spacing:.02em;font-variant-numeric:tabular-nums;line-height:1;color:var(--ink)}.kiosk-date{font-size:clamp(14px,3.5vw,18px);letter-spacing:.12em;text-transform:capitalize;color:var(--ink-soft);margin-top:6px}.kiosk-actions{display:grid;grid-template-columns:1fr 1fr;gap:16px;flex:0 0 auto;width:100%;max-width:640px;margin:0 auto}.kbtn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:30px 16px;border-radius:18px;color:#fff;font-size:clamp(20px,5vw,28px);font-weight:500;letter-spacing:.16em;text-transform:uppercase;box-shadow:0 12px 34px #00000073;transition:transform .12s ease,box-shadow .12s ease}.kbtn:active{transform:translateY(2px) scale(.99);box-shadow:0 4px 14px #00000080}.kbtn .kbtn-icon{font-size:34px;line-height:1}.kbtn-entrata{background:linear-gradient(160deg,var(--entrata) 0%,var(--entrata-dark) 100%)}.kbtn-uscita{background:linear-gradient(160deg,var(--uscita) 0%,var(--uscita-dark) 100%)}.kiosk.scanning{background:linear-gradient(180deg,#15120f,#0a0908)}.kiosk.ok-entrata{background:linear-gradient(170deg,#2f5740,#14241a)}.kiosk.ok-uscita{background:linear-gradient(170deg,#7a4634,#2c1a13)}.kiosk.error{background:linear-gradient(170deg,#6e2f22,#1f0f0b)}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px;gap:12px;color:var(--ink)}.overlay.on-tint{color:#fff}.overlay-icon{font-size:clamp(72px,20vw,120px);line-height:1}.overlay-title{font-size:clamp(30px,8vw,56px);font-weight:600;margin:0}.overlay-sub{font-size:clamp(16px,4.5vw,26px);opacity:.92;margin:0;letter-spacing:.04em}.overlay-time{font-size:clamp(22px,6vw,40px);font-variant-numeric:tabular-nums;font-weight:600;margin-top:6px}.tag-pulse{width:130px;height:130px;border-radius:50%;border:2px solid var(--gold);display:grid;place-items:center;position:relative}.tag-pulse:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:50%;border:2px solid var(--gold);animation:pulse 1.6s ease-out infinite}@keyframes pulse{0%{transform:scale(1);opacity:.7}to{transform:scale(1.5);opacity:0}}.link-btn{margin-top:18px;padding:12px 26px;border-radius:999px;border:1px solid currentColor;font-size:15px;letter-spacing:.08em;opacity:.85;color:var(--ink-soft)}.gear{position:absolute;top:calc(14px + var(--safe-top));right:16px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:var(--gold);opacity:.6;font-size:18px;z-index:5}.kiosk.ok-entrata .gear,.kiosk.ok-uscita .gear,.kiosk.error .gear{color:#ffffff8c}.spin{width:34px;height:34px;border:3px solid rgba(255,255,255,.25);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.settings{max-width:560px;margin:0 auto;padding:calc(20px + var(--safe-top)) 18px calc(28px + var(--safe-bottom))}.settings h1{font-size:20px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--ink)}.card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:14px}.card h2{margin:0 0 12px;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}label{display:block;font-size:13px;color:var(--ink-soft);margin-bottom:6px}input,select{font:inherit;width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:var(--bg-2);color:var(--ink);min-height:48px}.field{margin-bottom:14px}.btn{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:50px;border-radius:12px;background:var(--gold);color:#1a1410;font-weight:700;letter-spacing:.06em}.btn.ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--line)}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:#2a2218;color:var(--gold)}.badge.ok{background:#1d2e22;color:#9fd6ad}.badge.err{background:#3a201a;color:#e7a48f}.muted{color:var(--ink-soft)}.row{display:flex;align-items:center;gap:10px}
