  :root {
    --navy: #1B2B4B; --navy2: #0d0820; --navy3: #080614;
    --gold: #C9A84C; --gold2: #E8C97A; --gold3: #f5e4a8;
    --gold-rgb: 201,168,76; --gold2-rgb: 232,201,122;
    --bg: #060408; --green: #34D399;
    --error: #f87171; --error-rgb: 248,113,113;
    --success: #4ADE80; --success-rgb: 74,222,128;
    --blue: #60A5FA; --blue-rgb: 96,165,250;
  }
  /* Nasconde elementi non rilevanti per personal mode (staff/reparti) */
  body[data-mode="personal"] .hide-in-personal { display: none !important; }
  /* ── Temi colore ── */
  body.theme-emerald { --gold:#34D399;--gold2:#6EE7B7;--gold3:#A7F3D0;--gold-rgb:52,211,153;--gold2-rgb:110,231,183;--bg:#040E0A; }
  body.theme-emerald::before { background:radial-gradient(ellipse at 28% 0%,rgba(16,90,60,.18) 0%,transparent 52%),radial-gradient(ellipse at 80% 18%,rgba(8,60,40,.12) 0%,transparent 44%),radial-gradient(ellipse at 50% 100%,rgba(10,40,30,.1) 0%,transparent 60%); }
  body.theme-rose { --gold:#F472B6;--gold2:#F9A8D4;--gold3:#FBCFE8;--gold-rgb:244,114,182;--gold2-rgb:249,168,212;--bg:#0A0408; }
  body.theme-rose::before { background:radial-gradient(ellipse at 28% 0%,rgba(110,18,60,.18) 0%,transparent 52%),radial-gradient(ellipse at 80% 18%,rgba(80,10,40,.12) 0%,transparent 44%),radial-gradient(ellipse at 50% 100%,rgba(60,8,30,.1) 0%,transparent 60%); }
  body.theme-ocean { --gold:#60A5FA;--gold2:#93C5FD;--gold3:#BFDBFE;--gold-rgb:96,165,250;--gold2-rgb:147,197,253;--bg:#040610; }
  body.theme-ocean::before { background:radial-gradient(ellipse at 28% 0%,rgba(18,40,110,.18) 0%,transparent 52%),radial-gradient(ellipse at 80% 18%,rgba(10,20,80,.12) 0%,transparent 44%),radial-gradient(ellipse at 50% 100%,rgba(8,15,50,.1) 0%,transparent 60%); }
  body.theme-sunset { --gold:#FB923C;--gold2:#FDBA74;--gold3:#FED7AA;--gold-rgb:251,146,60;--gold2-rgb:253,186,116;--bg:#0A0604; }
  body.theme-sunset::before { background:radial-gradient(ellipse at 28% 0%,rgba(110,50,18,.18) 0%,transparent 52%),radial-gradient(ellipse at 80% 18%,rgba(80,30,8,.12) 0%,transparent 44%),radial-gradient(ellipse at 50% 100%,rgba(50,25,8,.1) 0%,transparent 60%); }
  body.theme-luxury { --gold:#C9A84C;--gold2:#E8C97A;--gold3:#f5e4a8;--gold-rgb:201,168,76;--gold2-rgb:232,201,122;--bg:#060408; }

  * { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
  @media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
  }
  body { min-height: 100vh; background: #060408; display: flex; align-items: center; justify-content: center; font-family: 'DM Sans', sans-serif; padding: 0; }
  body::before { content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
    background: radial-gradient(ellipse at 28% 0%, rgba(55,18,110,.18) 0%, transparent 52%),
                radial-gradient(ellipse at 80% 18%, rgba(25,8,75,.12) 0%, transparent 44%),
                radial-gradient(ellipse at 50% 100%, rgba(205,112,0,.12) 0%, transparent 60%); }
  .phone { width: 100%; max-width: 420px; min-height: 100vh; background: #060408; position: relative; overflow: hidden; z-index:1; }
  .phone::before { content:''; position:absolute; top:0; left:0; right:0; height:55%; pointer-events:none; z-index:0;
    background: radial-gradient(ellipse at 35% 0%, rgba(55,18,110,.38) 0%, transparent 60%),
                radial-gradient(ellipse at 82% 22%, rgba(42,10,88,.24) 0%, transparent 48%);
    animation:aurora-shift 6s ease-in-out infinite; }
  .phone::after { content:''; position:absolute; bottom:0; left:0; right:0; height:42%; pointer-events:none; z-index:0;
    background: radial-gradient(ellipse at 50% 100%, rgba(205,112,0,.20) 0%, transparent 65%); }
  @media(min-width:480px){ body{padding:20px;} .phone{min-height:780px;max-height:1000px;border-radius:40px;box-shadow:0 40px 120px rgba(0,0,0,0.98),0 0 90px rgba(180,100,0,.07),0 0 120px rgba(40,10,90,.09),inset 0 1px 0 rgba(255,200,58,.06);border:1px solid rgba(200,140,20,.14);}
  @media(max-width:430px){.phone{min-height:100dvh;max-height:none;border-radius:0;box-shadow:none;border:none;}} }
  .statusbar{height:44px;background:rgba(0,0,0,0.3);display:flex;align-items:center;justify-content:space-between;padding:0 24px;font-size:12px;color:rgba(255,255,255,0.5);position:relative;z-index:1;}
  .screen{padding:0 24px 40px;padding-bottom:max(40px,env(safe-area-inset-bottom));overflow-y:auto;max-height:calc(100vh - 44px);-webkit-overflow-scrolling:touch;position:relative;z-index:1;}
  @media(min-width:480px){.screen{max-height:calc(1000px - 44px);}}
  .screen.hidden{display:none;}
  .logo-wrap{text-align:center;padding:28px 0 24px;position:relative;display:block;}
  .logo-ring-wrap{ width:72px; height:72px; margin:0 auto 12px; position:relative; }
  .logo-ring{ position:absolute; inset:-4px; border-radius:26px;
    background:conic-gradient(from 0deg,
      rgba(var(--gold-rgb),0) 0%, rgba(var(--gold-rgb),.58) 17%,
      rgba(var(--gold-rgb),0) 34%, rgba(var(--gold2-rgb),.20) 52%,
      rgba(var(--gold-rgb),0) 68%, rgba(var(--gold-rgb),.42) 84%,
      rgba(var(--gold-rgb),0) 100%);
    box-shadow:0 0 40px rgba(var(--gold-rgb),0.22),0 0 80px rgba(var(--gold-rgb),0.08);
    animation:spin 5s linear infinite; }
  @keyframes spin{ to{ transform:rotate(360deg); } }
  .logo-inner{ position:relative; z-index:1; width:72px; height:72px;
    border-radius:22px; background:linear-gradient(145deg,#0f0b1c,#08060e);
    border:1px solid rgba(var(--gold-rgb),0.22); display:flex;
    align-items:center; justify-content:center; font-size:30px;
    box-shadow:inset 0 1px 0 rgba(var(--gold-rgb),0.12),0 12px 32px rgba(0,0,0,0.55);
    cursor:pointer; user-select:none; -webkit-touch-callout:none; -webkit-user-select:none; }
  .logo-inner img{width:100%;height:100%;border-radius:22px;object-fit:cover;}

  .logo-title{font-size:30px;font-weight:800;background:linear-gradient(135deg,var(--gold),var(--gold2),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-0.5px;font-family:'Syne',sans-serif;text-shadow:0 0 30px rgba(var(--gold-rgb),0.15);}
  .logo-sub{color:rgba(var(--gold-rgb),.50);font-size:14px;margin-top:6px;font-family:'DM Sans',sans-serif;}
  .section-label{color:rgba(var(--gold-rgb),.58);font-size:13px;margin-bottom:14px;}
  .cat-btn{width:100%;min-height:64px;background:rgba(var(--gold-rgb),.035);border:1px solid rgba(var(--gold-rgb),.10);border-radius:16px;padding:16px 20px;cursor:pointer;display:flex;align-items:center;gap:14px;margin-bottom:12px;transition:transform 0.22s cubic-bezier(0.22,1,0.36,1),box-shadow 0.22s,background 0.2s,border-color 0.2s;text-align:left;min-height:60px;-webkit-tap-highlight-color:transparent;overflow:hidden;position:relative;}
  .cat-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,0.05) 50%,transparent 60%);transform:translateX(-100%);pointer-events:none;transition:none;}
  .cat-btn:hover::after{transform:translateX(200%);transition:transform 0.5s ease;}
  #cat-btn-general:hover{background:rgba(59,130,246,0.1);border-color:rgba(59,130,246,0.5);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,0.35),0 0 0 1px rgba(59,130,246,0.12);}
  #cat-btn-person:hover{background:rgba(139,92,246,0.1);border-color:rgba(139,92,246,0.5);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,0.35),0 0 0 1px rgba(139,92,246,0.12);}
  .cat-btn:active{transform:scale(0.97) !important;box-shadow:none !important;transition:transform 0.08s,box-shadow 0.08s !important;}
  .cat-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
  .cat-label{color:#FFF0D0;font-weight:600;font-size:15px;display:block;font-family:'Syne',sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .cat-sub{color:rgba(238,198,78,.50);font-size:13px;display:block;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .cat-arrow{margin-left:auto;color:rgba(255,255,255,0.45);font-size:20px;}
  .footer{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.06);display:flex;justify-content:center;gap:24px;}
  .footer a{color:rgba(255,255,255,0.35);font-size:12px;cursor:pointer;text-decoration:none;transition:color 0.2s;} .footer a:hover{color:var(--gold);} .footer a.inactive{opacity:0.3;cursor:default;}
  .back-btn{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:12px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;font-size:22px;margin:16px 0 8px;}
  .staff-btn{width:100%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:18px;padding:16px 20px;cursor:pointer;display:flex;align-items:center;gap:14px;margin-bottom:12px;transition:transform 0.22s cubic-bezier(0.22,1,0.36,1),box-shadow 0.22s,background 0.2s,border-color 0.2s;text-align:left;position:relative;overflow:hidden;}
  .staff-btn::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:2px;border-radius:2px;background:linear-gradient(180deg,transparent,rgba(27,80,180,0.7),transparent);}
  .staff-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,0.04) 50%,transparent 60%);transform:translateX(-100%);pointer-events:none;transition:none;}
  .staff-btn:hover::after{transform:translateX(200%);transition:transform 0.5s ease;}
  .staff-btn:active{transform:scale(0.97) !important;box-shadow:none !important;transition:transform 0.08s,box-shadow 0.08s !important;}
  .staff-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#0d0820,#080614);border:1px solid rgba(198,148,28,.32);box-shadow:0 0 20px rgba(198,118,0,.16);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;overflow:hidden;}
  .staff-avatar img,.admin-staff-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
  .menu-pub-btn{display:none;width:100%;margin:16px 0 4px;padding:14px 20px;border-radius:16px;background:rgba(var(--gold-rgb),0.1);border:1px solid rgba(var(--gold-rgb),0.3);color:var(--gold);font-family:'Syne',sans-serif;font-size:16px;font-weight:700;letter-spacing:0.03em;cursor:pointer;text-align:center;transition:background 0.2s}
  .menu-pub-btn:hover{background:rgba(var(--gold-rgb),0.2)}
  .upload-btn{display:inline-block;padding:8px 14px;border-radius:10px;background:rgba(var(--gold-rgb),0.12);border:1px dashed rgba(var(--gold-rgb),0.4);color:var(--gold);font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;margin-bottom:10px;text-align:center;width:100%;}
  .upload-input{display:none;}
  .upload-btn:hover{background:rgba(var(--gold-rgb),0.2);}
  .staff-name{color:#fff;font-weight:700;font-size:16px;font-family:'Syne',sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .staff-role{color:rgba(255,255,255,0.58);font-size:13px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .staff-rating{color:var(--gold);font-weight:700;font-size:15px;text-align:right;}
  .staff-happy{color:rgba(255,255,255,0.55);font-size:12px;text-align:right;margin-top:2px;}
  .tip-hero{text-align:center;margin-bottom:24px;}
  .tip-icon{width:64px;height:64px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px;}
  .tip-name{color:#fff;font-size:20px;font-weight:700;overflow-wrap:break-word;word-break:break-word;}
  .tip-rating{color:var(--gold);font-size:13px;margin-top:4px;}
  .tip-badge{display:inline-block;margin-top:10px;padding:6px 14px;border-radius:20px;color:rgba(255,255,255,0.5);font-size:12px;}
  .amounts-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:12px;}
  .amount-btn{padding:18px 8px;border-radius:13px;border:1px solid rgba(198,128,0,.08);color:#FFF0D0;font-weight:700;font-size:14px;cursor:pointer;transition:all 0.2s;font-family:'DM Mono',monospace;background:rgba(10,6,20,0.6);}
  .custom-input{width:100%;padding:13px 16px;border-radius:14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:#fff;font-size:15px;outline:none;margin-bottom:22px;font-family:'DM Mono',monospace;}
  .custom-input::placeholder{color:rgba(255,255,255,0.25);}
  .stars{display:flex;gap:6px;margin-bottom:18px;}
  .star-btn{background:none;border:none;cursor:pointer;font-size:28px;transition:transform 0.15s;padding:0;filter:grayscale(1) opacity(0.35);}
  .star-btn.active{filter:none;transform:scale(1.2);}
  .comment-input{width:100%;padding:13px 16px;border-radius:14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:#fff;font-size:14px;resize:none;margin-bottom:18px;outline:none;font-family:'DM Sans',sans-serif;min-height:80px;}
  .fb-btn{flex:1;padding:12px 4px;border-radius:12px;border:1px solid rgba(255,255,255,0.07);background:rgba(27,43,75,0.3);font-size:11px;cursor:pointer;transition:all 0.2s;color:rgba(255,255,255,0.6);min-height:44px;display:flex;align-items:center;justify-content:center;}
  .dept-btn-active{border-color:rgba(var(--gold-rgb),0.5)!important;background:rgba(var(--gold-rgb),0.15)!important;color:var(--gold)!important;}
  .fb-btn.sel-top{border-color:rgba(255,215,0,0.5);background:rgba(255,215,0,0.1);color:#FFD700;}
  .fb-btn.sel-ok{border-color:rgba(52,211,153,0.4);background:rgba(52,211,153,0.08);color:#34D399;}
  .fb-btn.sel-mid{border-color:rgba(var(--gold-rgb),0.3);background:rgba(var(--gold-rgb),0.08);color:var(--gold2);}
  .fb-btn.sel-good{border-color:rgba(96,165,250,0.4);background:rgba(96,165,250,0.08);color:#60A5FA;}
  .fb-btn.sel-bad{border-color:rgba(239,68,68,0.35);background:rgba(239,68,68,0.07);color:var(--error);}
  .comment-input::placeholder{color:rgba(255,255,255,0.25);}
  .custom-input:focus-visible,.comment-input:focus-visible,.modal-input:focus-visible,.pwd-input:focus-visible{border-color:var(--gold);box-shadow:0 0 0 2px rgba(var(--gold-rgb),0.18);}
  .hc-dot:focus-visible{box-shadow:0 0 0 2px rgba(var(--gold-rgb),0.4);}
  .btn-primary:focus-visible,.cat-btn:focus-visible,.amount-btn:focus-visible,.star-btn:focus-visible,.pay-tab:focus-visible,.fb-btn:focus-visible,.back-btn:focus-visible{outline:2px solid rgba(var(--gold-rgb),0.75);outline-offset:2px;}
  .btn-primary{width:100%;padding:17px 20px;min-height:44px;border:none;border-radius:16px;color:#0a1020;font-weight:800;font-size:15px;cursor:pointer;font-family:'Syne',sans-serif;letter-spacing:0.04em;background:linear-gradient(90deg,var(--gold) 0%,var(--gold2) 40%,var(--gold3) 60%,var(--gold) 100%);background-size:220% auto;animation:shimmer 3s linear infinite;box-shadow:0 8px 28px rgba(var(--gold-rgb),0.25),inset 0 1px 0 rgba(255,255,255,0.15);}
  .btn-primary{transition:transform 0.18s cubic-bezier(0.22,1,0.36,1),box-shadow 0.18s,background-position 0s;}
  .btn-primary:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(var(--gold-rgb),0.38),inset 0 1px 0 rgba(255,255,255,0.15);}
  .btn-primary:not(:disabled):active{transform:scale(0.97) !important;box-shadow:0 4px 12px rgba(var(--gold-rgb),0.2) !important;transition:transform 0.08s,box-shadow 0.08s !important;}
  .btn-primary:disabled{background:rgba(255,255,255,0.1)!important;color:rgba(255,255,255,0.3)!important;cursor:not-allowed;box-shadow:none!important;}
  .btn-secondary{width:100%;padding:14px;border-radius:16px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);font-weight:500;font-size:15px;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:12px;}
  .pay-amount{font-size:52px;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:block;text-align:center;}
  .pay-for{color:rgba(255,255,255,0.4);font-size:14px;text-align:center;margin-top:4px;margin-bottom:32px;}
  .pay-method{width:100%;padding:18px 20px;border-radius:16px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:#fff;display:flex;align-items:center;gap:12px;cursor:pointer;font-size:15px;font-weight:500;margin-bottom:10px;font-family:'DM Sans',sans-serif;transition:all 0.2s;min-height:56px;-webkit-tap-highlight-color:transparent;overflow:hidden;}
  .pay-method.pm-sel{background:rgba(var(--gold-rgb),0.18);border-color:var(--gold);box-shadow:0 0 0 2px rgba(var(--gold-rgb),0.35);}
  .pay-method:not(.pm-sel):hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,0.3);border-color:rgba(255,255,255,0.2);}
  .pay-method:active{transform:scale(0.98) !important;transition:transform 0.08s !important;}
  #pm-error{color:#ff6b6b;font-size:13px;text-align:center;margin-top:8px;display:none;}
  .confirm-wrap{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;}
  .confirm-personal{color:#F5D060;font-size:18px;font-weight:700;margin-bottom:8px;display:block;}
  .confirm-text{color:rgba(255,255,255,0.5);font-size:15px;margin-bottom:24px;line-height:1.5;}
  @keyframes coin-in{
    0%{transform:translateY(-80px) scale(0.5) rotateY(0deg);opacity:0;}
    25%{transform:translateY(8px) scale(1.1) rotateY(140deg);opacity:1;}
    40%{transform:translateY(-16px) scale(1.05) rotateY(240deg);opacity:1;}
    55%{transform:translateY(4px) scale(1) rotateY(320deg);opacity:1;}
    70%{transform:translateY(-4px) scale(1) rotateY(350deg);opacity:1;}
    100%{transform:translateY(0) scale(1) rotateY(360deg);opacity:1;}
  }
  @keyframes coin-burst{0%,65%{transform:scale(1);opacity:1;}80%{transform:scale(1.8);opacity:.6;}100%{transform:scale(0);opacity:0;}}
  @keyframes particle-fly{0%{transform:translate(0,0) scale(1);opacity:1;}100%{transform:translate(var(--tx),var(--ty)) scale(0);opacity:0;}}
  @keyframes heart-in{0%,60%{transform:scale(0);opacity:0;}75%{transform:scale(1.2);opacity:1;}85%{transform:scale(.92);opacity:1;}95%{transform:scale(1.08);}100%{transform:scale(1);opacity:1;}}
  @keyframes heart-beat{0%,100%{transform:scale(1);}14%{transform:scale(1.13);}28%{transform:scale(1);}42%{transform:scale(1.08);}70%{transform:scale(1);}}
  @keyframes wave-out{0%{transform:scale(.8);opacity:.55;}100%{transform:scale(2.6);opacity:0;}}
  .wave-ring{position:absolute;width:110px;height:110px;border-radius:50%;border:1px solid rgba(var(--gold-rgb),.35);display:none;}
  .confirm-amount{color:var(--gold);}
  .hearts-container{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:100;overflow:hidden;}
  .heart{position:absolute;animation:floatUp 2s ease-out forwards;opacity:0;}
  @keyframes floatUp{0%{opacity:1;transform:translateY(0) scale(1);}100%{opacity:0;transform:translateY(-350px) scale(0.4);}}
  @keyframes ember-float{0%{transform:translateY(0) translateX(0);opacity:0;}12%{opacity:.75;}80%{opacity:.4;}100%{transform:translateY(-350px) translateX(var(--ex,8px));opacity:0;}}
  @keyframes aurora-shift{0%,100%{opacity:.9;}50%{opacity:1;}}
  .phone-embers{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:2;}
  .ember{position:absolute;border-radius:50%;animation:ember-float var(--dur,4.5s) ease-in-out var(--del,0s) infinite;}
  /* ADMIN */
  .admin-big-tabs{display:flex;gap:8px;margin-bottom:20px;}
  .admin-big-tab{flex:1;padding:12px 8px;border-radius:14px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.5);font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s;}
  .admin-big-tab.active{background:rgba(var(--gold-rgb),0.18);border-color:var(--gold);color:var(--gold);}
  .admin-panel{display:block;}.admin-panel.hidden{display:none;}
  .persona-badge{display:inline-block;background:rgba(var(--gold-rgb),0.15);border:1px solid rgba(var(--gold-rgb),0.3);border-radius:8px;padding:2px 8px;font-size:11px;color:var(--gold);margin-left:6px;}
  .edit-staff-btn{background:rgba(var(--gold-rgb),0.12);border:1px solid rgba(var(--gold-rgb),0.3);border-radius:8px;color:var(--gold);font-size:22px;padding:8px 12px;cursor:pointer;font-family:'DM Sans',sans-serif;margin-left:6px;transition:all 0.2s ease;}
  .edit-staff-btn.active{background:rgba(var(--gold-rgb),0.35);border-color:var(--gold);box-shadow:0 0 8px rgba(var(--gold-rgb),0.3);}
  button.active{box-shadow:0 0 8px rgba(var(--gold-rgb),0.25);filter:brightness(1.3);}
  .inline-edit-box{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:12px;margin-top:10px;}
  .inline-edit-box .field-input{margin-bottom:8px;}
  .admin-header{display:flex;align-items:center;gap:12px;padding:20px 24px 16px;position:sticky;top:0;background:#060408;z-index:10;border-bottom:1px solid rgba(var(--gold-rgb),0.2);margin:0 -24px 20px;}
  .admin-title{font-size:22px;font-weight:700;color:var(--gold);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .admin-badge{background:rgba(var(--gold-rgb),0.15);border:1px solid rgba(var(--gold-rgb),0.3);border-radius:8px;padding:4px 10px;font-size:11px;color:var(--gold);font-weight:700;}
  .admin-logout{margin-left:auto;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:10px;color:rgba(255,255,255,0.5);font-size:12px;padding:6px 12px;cursor:pointer;font-family:'DM Sans',sans-serif;}
  .admin-section{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);border-radius:20px;padding:20px;margin-bottom:16px;}
  .admin-section-title{color:#fff;font-size:15px;font-weight:700;margin-bottom:16px;}
  .stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  .stat-card{background:rgba(var(--gold-rgb),0.08);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:14px;padding:16px;text-align:center;min-width:0;overflow:hidden;}
  .stat-val{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;overflow-wrap:break-word;word-break:break-word;}
  .stat-label{color:rgba(255,255,255,0.4);font-size:12px;margin-top:4px;overflow-wrap:break-word;word-break:break-word;line-height:1.2;}
  .field-label{color:rgba(255,255,255,0.6);font-size:13px;font-weight:700;margin-bottom:6px;display:block;}
  .field-input{width:100%;padding:12px 14px;border-radius:12px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:#fff;font-size:16px;outline:none;font-family:'DM Mono',monospace;margin-bottom:10px;}
  .field-input::placeholder{color:rgba(255,255,255,0.25);}
  select.field-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:rgba(255,255,255,0.06) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath stroke='%23ffffff80' stroke-width='1.5' fill='none' d='M1 1l5 5 5-5'/%3E%3C/svg%3E") no-repeat right 12px center;padding-right:36px;}
  select.field-input option{background:#1c1206;color:#fff;}
  select option{background:#1c1206;color:#E8E0D0;}
  .field-input:focus{border-color:var(--gold);}
  .eye-wrap{position:relative;width:100%;margin-bottom:10px;}
  .eye-wrap .field-input,.eye-wrap .pwd-input{margin-bottom:0;padding-right:44px;width:100%;}
  .eye-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:rgba(255,255,255,0.35);font-size:19px;padding:4px;line-height:1;transition:color 0.15s;}
  .eye-btn:hover{color:rgba(255,255,255,0.7);}
  .save-btn{background:linear-gradient(135deg,var(--gold),var(--gold2));border:none;border-radius:12px;color:#000;font-weight:700;font-size:14px;padding:12px 20px;cursor:pointer;font-family:'DM Sans',sans-serif;}
  .saved-msg{color:var(--success);font-size:13px;margin-left:10px;display:none;}
  .admin-staff-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:16px;margin-bottom:12px;}
  .admin-staff-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;overflow:hidden;}
  .admin-staff-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#8B5CF6,#C084FC);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;overflow:hidden;}
  .admin-staff-name{color:#fff;font-weight:700;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .admin-staff-role{color:rgba(255,255,255,0.4);font-size:12px;}
  .remove-staff-btn{margin-left:auto;background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);border-radius:8px;color:var(--error);font-size:12px;padding:5px 10px;cursor:pointer;font-family:'DM Sans',sans-serif;}
  .payment-tabs{display:flex;gap:6px;margin-bottom:12px;}
  .pay-tab{flex:1;padding:8px;border-radius:10px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.5);font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;text-align:center;transition:all 0.2s;}
  .pay-tab.active{background:rgba(var(--gold-rgb),0.15);border-color:rgba(var(--gold-rgb),0.4);color:var(--gold);font-weight:700;}
  .add-staff-btn{width:100%;padding:14px;border-radius:14px;border:1px dashed rgba(var(--gold-rgb),0.3);background:rgba(var(--gold-rgb),0.05);color:var(--gold);font-size:14px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:4px;}
  .modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:50;display:flex;align-items:flex-start;justify-content:center;padding:20px;padding-top:max(20px,env(safe-area-inset-top));overflow-y:auto;}
  .modal-overlay.hidden{display:none;}
  .modal{background:#1e1b2e;border-radius:24px;padding:28px 24px;width:100%;max-width:340px;border:1px solid rgba(255,255,255,0.1);}
  .modal h3{color:#fff;font-size:18px;margin-bottom:20px;}
  .modal-input{width:100%;padding:12px 16px;border-radius:12px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);color:#fff;font-size:15px;outline:none;margin-bottom:12px;font-family:'DM Mono',monospace;}
  .modal-input::placeholder{color:rgba(255,255,255,0.25);}
  .modal-btns{display:flex;gap:10px;margin-top:8px;}
  .modal-btn-cancel{flex:1;padding:12px;border-radius:12px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;}
  .modal-btn-add{flex:1;padding:12px;border-radius:12px;background:linear-gradient(135deg,var(--gold),var(--gold2));border:none;color:#000;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;}
  .pwd-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;text-align:center;}
  .pwd-icon{font-size:48px;margin-bottom:16px;}
  .pwd-title{color:#fff;font-size:20px;font-weight:700;margin-bottom:8px;}
  .pwd-sub{color:rgba(255,255,255,0.4);font-size:14px;margin-bottom:28px;}
  .pwd-input{width:100%;padding:14px 18px;border-radius:14px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.15);color:#fff;font-size:18px;outline:none;text-align:center;letter-spacing:3px;font-family:'DM Mono',monospace;margin-bottom:14px;}
  .pwd-input::placeholder{letter-spacing:0;color:rgba(255,255,255,0.25);font-size:14px;}
  .pwd-error{color:var(--error);font-size:13px;margin-bottom:12px;min-height:20px;}
  /* ACCORDION */
  .acc-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;padding:2px 0;}
  .acc-header:active{opacity:0.8;}
  .acc-arrow{color:var(--gold);font-size:18px;transition:transform 0.3s;flex-shrink:0;}
  .acc-header.open .acc-arrow{transform:rotate(180deg);}
  .acc-body{max-height:0;overflow:hidden;transition:max-height 0.35s ease, padding 0.3s;}
  .acc-body.open{max-height:3000px;padding-top:16px;overflow:visible;}
  @keyframes pop{0%{transform:scale(0.5);opacity:0;}100%{transform:scale(1);opacity:1;}}
  h2{color:#fff;font-size:22px;font-weight:700;margin-bottom:4px;}
  .subtitle{color:rgba(255,255,255,0.4);font-size:13px;margin-bottom:22px;}
  input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;}

  /* LANG BAR */
  .lang-bar{display:flex;gap:3px;padding:0;background:none;}
  .lang-btn{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:6px;padding:2px 5px;font-size:13px;cursor:pointer;transition:all 0.2s;line-height:1.3;}
  .admin-lang-bar{display:none;}
  .lang-btn.active{background:rgba(var(--gold-rgb),0.25);border-color:rgba(var(--gold-rgb),0.6);}
  /* ── RTL (Arabic) ── */
  [dir=rtl] .cat-arrow{margin-left:0;margin-right:auto;}
  [dir=rtl] .admin-logout{margin-left:0;margin-right:auto;}
  [dir=rtl] .cat-btn,[dir=rtl] .staff-btn{text-align:right;}
  [dir=rtl] .staff-rating,[dir=rtl] .staff-happy{text-align:left;}
  [dir=rtl] .saved-msg{margin-left:0;margin-right:10px;}
  [dir=rtl] .remove-staff-btn,[dir=rtl] .cat-manage-del{margin-left:0;margin-right:auto;}
  [dir=rtl] .edit-staff-btn,[dir=rtl] .persona-badge,[dir=rtl] .staff-mode-badge{margin-left:0;margin-right:6px;}
  [dir=rtl] .storico-nums{margin-left:0;margin-right:auto;text-align:left;}
  [dir=rtl] select.field-input{background-position:left 12px center;padding-right:12px;padding-left:36px;}
  [dir=rtl] .eye-wrap .field-input,[dir=rtl] .eye-wrap .pwd-input{padding-right:12px;padding-left:44px;}
  [dir=rtl] .eye-btn{right:auto;left:12px;}
  [dir=rtl] .gt-input-wrap .gt-clear-btn{right:auto;left:10px;}
  [dir=rtl] .gt-input-wrap .modal-input{padding-right:12px !important;padding-left:34px !important;}

  /* ── RTL — modali, pagamento, conferma, profilo ── */
  [dir=rtl] .modal{text-align:right;}
  [dir=rtl] .modal h3{text-align:right;}
  [dir=rtl] .modal-input{text-align:right;}
  [dir=rtl] .pay-method{text-align:right;flex-direction:row-reverse;}
  [dir=rtl] .pay-for{text-align:center;}
  [dir=rtl] .confirm-staff-card{flex-direction:row-reverse;text-align:right;}
  [dir=rtl] .confirm-text{text-align:right;}
  [dir=rtl] .back-btn{margin-left:auto;margin-right:0;}
  [dir=rtl] .staff-btn::before{left:auto;right:0;}
  [dir=rtl] .sp-edit-section{text-align:right;}
  [dir=rtl] .sp-field-lbl{text-align:right;}
  [dir=rtl] .sp-comment{text-align:right;}
  [dir=rtl] .pwa-banner{flex-direction:row-reverse;}
  [dir=rtl] .pwa-banner-text{text-align:right;}
  [dir=rtl] .admin-staff-header{flex-direction:row-reverse;}
  [dir=rtl] .admin-staff-name,[dir=rtl] .admin-staff-role{text-align:right;}
  [dir=rtl] .admin-section-title{text-align:right;}
  [dir=rtl] .field-label{text-align:right;}
  [dir=rtl] .field-input{text-align:right;}
  [dir=rtl] .pwd-input{text-align:center;}
  [dir=rtl] .comment-input{text-align:right;}
  [dir=rtl] .custom-input{text-align:right;}
  [dir=rtl] .cat-manage-card{flex-direction:row-reverse;text-align:right;}
  [dir=rtl] .cat-manage-del{margin-left:0;margin-right:auto;}
  [dir=rtl] .ob-staff-item{flex-direction:row-reverse;text-align:right;}
  [dir=rtl] .trust-strip{direction:rtl;}
  [dir=rtl] .fb-btn{text-align:center;}
  [dir=rtl] .tip-toast{direction:rtl;}
  [dir=rtl] .gt-toast{direction:rtl;}

  /* CATEGORY MANAGEMENT */
  .cat-manage-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
    border-radius:14px;padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;gap:12px;overflow:hidden;}
  .cat-manage-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;
    justify-content:center;font-size:20px;flex-shrink:0;}
  .cat-manage-name{color:#fff;font-weight:700;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;}
  .cat-manage-sub{color:rgba(255,255,255,0.4);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .cat-manage-del{margin-left:auto;background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);
    border-radius:8px;color:var(--error);font-size:12px;padding:5px 10px;cursor:pointer;font-family:'DM Sans',sans-serif;flex-shrink:0;}
  .cat-add-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;}
  .cat-color-row{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap;}
  .color-dot{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all 0.2s;flex-shrink:0;}
  .color-dot.selected{border-color:#fff;transform:scale(1.2);}
  /* Dynamic home category container */
  #dynamic-cats{}
  #dynamic-cats.hc-slide-forward{ animation:screenSlideForward 0.28s cubic-bezier(0.22,1,0.36,1) both; }
  #dynamic-cats.hc-slide-back{ animation:screenSlideBack 0.28s cubic-bezier(0.22,1,0.36,1) both; }

  .hc-dot{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;padding:0;outline:none;-webkit-appearance:none;appearance:none;transition:all 0.2s;flex-shrink:0;}
  .hc-dot.hc-sel{border-color:#fff;transform:scale(1.2);}

  /* BRANDING PREVIEW */
  .brand-preview{background:rgba(var(--gold-rgb),0.08);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:14px;padding:16px;margin-bottom:14px;text-align:center;}
  .brand-preview-name{font-size:18px;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;overflow-wrap:break-word;word-break:break-word;}
  .brand-preview-sub{font-size:12px;color:rgba(255,255,255,0.35);font-style:italic;margin-top:4px;}
  /* CONFIRM IMPROVED */
  .confirm-staff-card{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:16px;padding:14px 18px;margin:0 auto 20px;max-width:280px;}
  .confirm-staff-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#8B5CF6,#C084FC);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;}
  .confirm-staff-name{color:#fff;font-weight:700;font-size:16px;overflow-wrap:break-word;word-break:break-word;}
  .confirm-staff-role{color:rgba(255,255,255,0.45);font-size:13px;margin-top:2px;}

  /* STAFF STATS */
  .staff-stats-bar{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:12px;margin-bottom:4px;}
  .staff-stat-box{background:rgba(var(--gold-rgb),0.07);border:1px solid rgba(var(--gold-rgb),0.15);border-radius:10px;padding:10px 8px;text-align:center;}
  .staff-stat-val{font-size:17px;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:block;line-height:1.2;}
  .staff-stat-lbl{font-size:10px;color:rgba(255,255,255,0.35);margin-top:3px;display:block;line-height:1.3;}
  /* STORICO STAFF section */
  .storico-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);border-radius:16px;padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:14px;overflow:hidden;}
  .storico-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#8B5CF6,#C084FC);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
  .storico-name{color:#fff;font-weight:700;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .storico-role{color:rgba(255,255,255,0.58);font-size:12px;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .storico-nums{margin-left:auto;text-align:right;}
  .storico-amt{font-size:18px;font-weight:700;color:var(--gold);white-space:nowrap;}
  .storico-count{font-size:11px;color:rgba(255,255,255,0.35);margin-top:2px;}
  .storico-net{font-size:11px;color:var(--success);margin-top:1px;}

  /* ── ONBOARDING ── */
  .ob-step{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,0.08);border:2px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.4);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.3s;}
  .ob-step.active{background:rgba(var(--gold-rgb),0.2);border-color:var(--gold);color:var(--gold);}
  .ob-step.done{background:rgba(34,197,94,0.2);border-color:#22C55E;color:#22C55E;}
  .ob-line{flex:1;height:2px;background:rgba(255,255,255,0.1);margin:0 6px;transition:background 0.3s;}
  .ob-line.done{background:#22C55E;}
  .ob-staff-item{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:10px 14px;margin-bottom:8px;}
  .ob-staff-emoji{font-size:22px;width:36px;text-align:center;}
  .ob-staff-name{color:#fff;font-size:14px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .ob-staff-role{color:rgba(255,255,255,0.58);font-size:12px;}
  .ob-remove{background:none;border:none;color:rgba(255,255,255,0.3);cursor:pointer;font-size:16px;padding:2px 6px;}

  /* ── Safe area iPhone ── */
  @supports (padding-top: env(safe-area-inset-top)) {
    .statusbar { padding-top: env(safe-area-inset-top); height: calc(44px + env(safe-area-inset-top)); }
    .screen { max-height: calc(100vh - 44px - env(safe-area-inset-top)); padding-bottom: calc(40px + env(safe-area-inset-bottom)); }
  }
  /* ── Media query mobile reale ── */
  @media (max-width: 480px) {
    body { padding: 0; }
    .phone { border-radius: 0; min-height: 100vh; max-height: none; box-shadow: none; border: none; }
    .screen { padding: 0 16px 40px; }
    .admin-header { padding:20px 16px 16px; margin:0 -16px 20px; }
    .admin-big-tab .abt-label { font-size: 10px; }
    .stat-card { padding: 12px 8px; }
    .stat-val { font-size: 22px; }
  }
  @keyframes shimmer{ 0%{background-position:0% center;} 100%{background-position:220% center;} }
  #easter-coin:hover,#easter-coin:focus-visible{opacity:1 !important;transform:scale(1.15);}
  body.admin-open #easter-coin{display:none !important;}
  @keyframes easter-in{0%{opacity:0;transform:translateY(22px) scale(0.55);}60%{transform:translateY(-4px) scale(1.1);}100%{opacity:1;transform:translateY(0) scale(1);}}
  @keyframes easter-rot{0%{transform:rotate(0deg);}100%{transform:rotate(360deg);}}
  @keyframes easter-glow{0%,100%{filter:drop-shadow(0 0 3px rgba(var(--gold-rgb),0.2));}50%{filter:drop-shadow(0 0 10px rgba(var(--gold-rgb),0.75));}}
  @keyframes easter-bounce{0%,100%{transform:scale(1);}45%{transform:scale(1.18);}55%{transform:scale(1.12);}}
  /* ── Progresso flusso mancia ── */
  .tip-progress{display:flex;justify-content:center;align-items:center;gap:7px;padding:6px 0 18px;}
  .tp-dot{height:7px;width:7px;border-radius:4px;background:rgba(255,255,255,0.12);transition:all 0.3s ease;}
  .tp-dot.tp-done{background:rgba(var(--gold-rgb),0.45);}
  .tp-dot.tp-active{width:22px;background:var(--gold);box-shadow:0 0 8px rgba(var(--gold-rgb),0.55);}
  @keyframes popUp{
    0%{ opacity:0; transform:translateY(20px) scale(0.95); }
    60%{ opacity:1; }
    100%{ opacity:1; transform:translateY(0) scale(1); }
  }
  .pop{ animation:popUp 0.45s cubic-bezier(0.22,1,0.36,1) both; }
  .pop1{animation-delay:0s;} .pop2{animation-delay:0.08s;} .pop3{animation-delay:0.16s;} .pop4{animation-delay:0.24s;} .pop5{animation-delay:0.32s;} .pop6{animation-delay:0.40s;} .pop7{animation-delay:0.48s;} .pop8{animation-delay:0.56s;}
  @keyframes floatHeart{
    0%{ opacity:0.9; transform:translateY(0) scale(1); }
    100%{ opacity:0; transform:translateY(-90px) scale(0.6); }
  }
  .fheart{ position:absolute; font-size:14px; pointer-events:none;
    animation:floatHeart var(--dur,2s) ease-in var(--del,0s) infinite; }

  /* ── Trust strip — visitor onboarding ── */
  .trust-strip{
    display:flex;align-items:center;justify-content:center;gap:6px;
    margin:0 auto 16px;padding:8px 16px;border-radius:20px;
    background:rgba(34,197,94,0.06);border:1px solid rgba(34,197,94,0.15);
    color:rgba(34,197,94,0.92);font-size:12px;font-weight:500;
    letter-spacing:0.02em;width:fit-content;
    animation:screenFadeIn 0.5s 0.3s cubic-bezier(0.22,1,0.36,1) both;
  }
  .trust-icon{font-size:13px;line-height:1;}
  body.admin-open .trust-strip{display:none;}

  /* ── Mobile Polish — screen transitions ── */
  @keyframes screenFadeIn{
    0%{ opacity:0; transform:translateY(12px); }
    100%{ opacity:1; transform:translateY(0); }
  }
  .screen:not(.hidden){ animation:screenFadeIn 0.32s cubic-bezier(0.22,1,0.36,1) both; }
  /* Directional slide transitions */
  @keyframes screenSlideForward{
    0%{ opacity:0; transform:translateX(28px); }
    100%{ opacity:1; transform:translateX(0); }
  }
  @keyframes screenSlideBack{
    0%{ opacity:0; transform:translateX(-28px); }
    100%{ opacity:1; transform:translateX(0); }
  }
  .screen.slide-forward:not(.hidden){ animation:screenSlideForward 0.30s cubic-bezier(0.22,1,0.36,1) both; }
  .screen.slide-back:not(.hidden){ animation:screenSlideBack 0.30s cubic-bezier(0.22,1,0.36,1) both; }
  /* Disable animation on first load */
  .screen.no-anim:not(.hidden){ animation:none; }

  /* ── Mobile Polish — amount button selection ── */
  @keyframes amtPop{
    0%{ transform:scale(1); }
    40%{ transform:scale(1.08); }
    100%{ transform:scale(1); }
  }
  .amount-btn{ transition:all 0.2s cubic-bezier(0.22,1,0.36,1); }
  .amount-btn.amt-pop{ animation:amtPop 0.3s cubic-bezier(0.22,1,0.36,1); }

  /* ── Cat button glow pulse on load ── */
  @keyframes catGlow{
    0%{ box-shadow:0 0 0 0 rgba(var(--gold-rgb),0); }
    40%{ box-shadow:0 0 16px 2px rgba(var(--gold-rgb),0.13); }
    100%{ box-shadow:0 0 0 0 rgba(var(--gold-rgb),0); }
  }
  .cat-btn.pop{ animation:popUp 0.45s cubic-bezier(0.22,1,0.36,1) both, catGlow 1.6s ease-in-out 0.5s; }

  /* ── Mobile Polish — star bounce ── */
  @keyframes starBounce{
    0%{ transform:scale(1); }
    30%{ transform:scale(1.35); }
    60%{ transform:scale(0.9); }
    100%{ transform:scale(1.2); }
  }
  .star-btn.active{ animation:starBounce 0.35s cubic-bezier(0.22,1,0.36,1); }

  /* ── Mobile Polish — skeleton loading ── */
  @keyframes skeletonPulse{
    0%{ opacity:0.06; }
    50%{ opacity:0.12; }
    100%{ opacity:0.06; }
  }
  .skel-card{
    width:100%;min-height:64px;border-radius:16px;
    background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);
    margin-bottom:12px;animation:skeletonPulse 1.5s ease-in-out infinite;
  }
  .skel-row{ display:flex; gap:14px; align-items:center; padding:16px 20px; }
  .skel-circle{ width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,0.06);flex-shrink:0; }
  .skel-lines{ flex:1; }
  .skel-line{ height:12px;border-radius:6px;background:rgba(255,255,255,0.06);margin-bottom:6px; }
  .skel-line:last-child{ width:60%;margin-bottom:0; }

  /* ── Mobile Polish — feedback button tap ── */
  .fb-btn{ transition:all 0.18s cubic-bezier(0.22,1,0.36,1); }
  .fb-btn:active{ transform:scale(0.93); }

  /* ── Mobile Polish — pay method selection ── */
  @keyframes pmPop{
    0%{ transform:scale(1); }
    35%{ transform:scale(1.02) translateY(-2px); }
    100%{ transform:scale(1); }
  }
  .pay-method.pm-sel{ animation:pmPop 0.28s cubic-bezier(0.22,1,0.36,1); }

  /* ── Mobile Polish — smooth scroll ── */
  .screen{ scroll-behavior:smooth; }

  /* ── Mobile Polish — back button hover ── */
  .back-btn{ transition:all 0.2s cubic-bezier(0.22,1,0.36,1); }
  .back-btn:active{ transform:scale(0.88); background:rgba(255,255,255,0.12); }

  /* ── Tiny phones (≤360px) ── */
  @media (max-width: 360px) {
    .screen { padding: 0 14px 40px; }
    .modal-overlay { padding: 10px; padding-top: 10px; }
    .modal { padding: 20px 16px; }
    .amount-btn { font-size: 13px; padding: 14px 6px; }
    .cat-btn { padding: 12px 14px; gap: 10px; }
    .stat-val { font-size: 22px; }
    .admin-section { padding: 14px; }
    .admin-big-tab .abt-label { font-size: 9px; }
    .staff-stats-bar { gap: 4px; }
    .cat-add-grid { grid-template-columns: 1fr; }
  }
  /* ── Prevent horizontal overflow on all mobile ── */
  @media (max-width: 480px) {
    body { overflow-x: hidden; }
    .phone { overflow-x: hidden; }
    .payment-tabs { flex-wrap: wrap; }
    .confirm-staff-card { max-width: 100%; }
  }
  /* ── Admin Landscape Mobile ── */
  @media (orientation: landscape) and (max-height: 500px) {
    body.admin-open .phone { border-radius: 0; max-width: 100%; min-height: 100vh; box-shadow: none; border: none; }
    body.admin-open #screen-admin { max-height: 100vh; overflow-y: auto; padding: 0 16px 20px; }
    body.admin-open .admin-header { padding: 10px 16px; margin-bottom: 8px; }
    body.admin-open .admin-title { font-size: 16px; }
    body.admin-open .admin-big-tabs { gap: 6px; margin-bottom: 12px; }
    body.admin-open .admin-big-tab { padding: 8px 14px; font-size: 12px; flex: 1; }
    body.admin-open #apanel-config:not(.hidden) {
      display: block !important;
      max-width: 640px;
    }
    body.admin-open #apanel-config:not(.hidden) .admin-section {
      margin-bottom: 12px;
    }
    body.admin-open #apanel-team:not(.hidden) {
      display: grid !important;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      align-items: start;
    }
    body.admin-open #apanel-stats:not(.hidden) { display: block !important; }
    body.admin-open .stats-grid { grid-template-columns: repeat(4, 1fr) !important; }
    body.admin-open .admin-section { padding: 12px; }
    body.admin-open .admin-section-title { font-size: 13px; margin-bottom: 10px; }
  }
  /* ── Admin Sidebar — mobile (default): transparent wrappers ── */
  .admin-layout { display: block; }
  .admin-sidebar { display: block; }
  .admin-main { display: block; }
  .abt-label { pointer-events: none; }
  /* Config nav: hidden on mobile, base style for buttons */
  .config-nav { display: none; }
  .config-nav-btn { background:none;border:none;color:rgba(255,255,255,0.5);font-size:13px;font-family:'DM Sans',sans-serif;cursor:pointer;padding:8px 12px;border-radius:8px; }
  .config-nav-btn.active { color:var(--gold);font-weight:600; }
  .config-content { display: block; }
  .config-sec { display: block; }

  /* ── Tablet Breakpoint ── */
  @media (min-width: 600px) and (max-width: 899px) {
    .phone { max-width: 580px; }
    .stats-grid { grid-template-columns: 1fr 1fr 1fr; }
    .amounts-grid { grid-template-columns: 1fr 1fr 1fr 1fr; }
  }

  /* ── Admin Desktop Layout — Sidebar ── */
  @media (min-width: 900px) {
    body.admin-open {
      padding: 0;
      align-items: stretch;
      background: #060410;
    }
    body.admin-open .phone {
      max-width: 100%;
      min-height: 100vh;
      border-radius: 0;
      box-shadow: none;
      border: none;
    }
    body.admin-open .statusbar { display: none; }
    body.admin-open .admin-lang-bar{display:flex;gap:4px;justify-content:center;padding:12px 14px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,0.06);}
    body.admin-open #screen-admin {
      max-height: 100vh;
      padding: 0;
      overflow: hidden;
    }
    /* Layout flex: sidebar + main */
    body.admin-open .admin-layout {
      display: flex;
      height: 100vh;
      overflow: hidden;
    }
    /* ── Sidebar ── */
    body.admin-open .admin-sidebar {
      width: 260px;
      flex-shrink: 0;
      display: flex;
      flex-direction: column;
      background: linear-gradient(180deg, #0a0718 0%, #060410 100%);
      border-right: 1px solid rgba(var(--gold-rgb),0.12);
      overflow-y: auto;
      scrollbar-width: thin;
      scrollbar-color: rgba(var(--gold-rgb),0.2) transparent;
    }
    body.admin-open .admin-sidebar .admin-header {
      flex-direction: column;
      align-items: center;
      gap: 6px;
      padding: 28px 20px 20px;
      position: relative;
      border-bottom: 1px solid rgba(255,255,255,0.06);
      margin-bottom: 0;
      background: transparent;
    }
    body.admin-open .admin-sidebar .admin-title {
      font-size: 22px;
      text-align: center;
    }
    body.admin-open .admin-sidebar .admin-badge {
      margin-top: 2px;
    }
    body.admin-open .admin-sidebar .admin-logout {
      margin-left: 0;
      margin-top: 12px;
      width: 100%;
      text-align: center;
      padding: 8px 14px;
      border-radius: 10px;
    }
    body.admin-open .admin-sidebar #admin-help-btn,
    body.admin-open .admin-sidebar #admin-fs-btn {
      display: none;
    }
    /* ── Sidebar Nav (vertical tabs) ── */
    body.admin-open .admin-sidebar .admin-big-tabs {
      flex-direction: column;
      gap: 6px;
      padding: 20px 14px;
      margin-bottom: 0;
    }
    body.admin-open .admin-sidebar .admin-big-tab {
      flex: unset;
      text-align: left;
      padding: 14px 18px;
      border-radius: 12px;
      font-size: 15px;
      font-weight: 600;
      display: flex;
      align-items: center;
      gap: 10px;
      transition: all 0.2s ease;
    }
    body.admin-open .admin-sidebar .admin-big-tab:hover {
      background: rgba(var(--gold-rgb),0.08);
      border-color: rgba(var(--gold-rgb),0.2);
    }
    body.admin-open .admin-sidebar .admin-big-tab.active {
      background: rgba(var(--gold-rgb),0.15);
      border-color: rgba(var(--gold-rgb),0.5);
      color: var(--gold);
      box-shadow: 0 0 20px rgba(var(--gold-rgb),0.08);
    }
    /* ── Main Content Area ── */
    body.admin-open .admin-main {
      flex: 1;
      overflow-y: auto;
      padding: 32px 40px 40px;
      scrollbar-width: thin;
      scrollbar-color: rgba(var(--gold-rgb),0.15) transparent;
    }
    /* Stats: 4-column grid */
    body.admin-open .stats-grid {
      grid-template-columns: repeat(4, 1fr) !important;
    }
    /* Stats: storico + feedback side by side */
    body.admin-open .stats-bottom-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
      align-items: start;
    }
    /* Config: split layout — nav left, content right */
    body.admin-open #apanel-config:not(.hidden) {
      display: flex !important;
      max-width: none;
      gap: 0;
    }
    body.admin-open .config-nav {
      display: flex;
      flex-direction: column;
      width: 220px;
      flex-shrink: 0;
      padding: 8px 0;
      border-right: 1px solid rgba(255,255,255,0.06);
      position: sticky;
      top: 0;
      align-self: flex-start;
    }
    body.admin-open .config-nav-btn {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 14px 20px;
      background: none;
      border: none;
      color: rgba(255,255,255,0.55);
      font-size: 14px;
      font-family: 'DM Sans', sans-serif;
      cursor: pointer;
      text-align: left;
      width: 100%;
      transition: all 0.2s ease;
      border-left: 3px solid transparent;
    }
    body.admin-open .config-nav-btn:hover {
      background: rgba(var(--gold-rgb),0.06);
      color: rgba(255,255,255,0.8);
    }
    body.admin-open .config-nav-btn.active {
      background: rgba(var(--gold-rgb),0.1);
      color: var(--gold);
      border-left-color: var(--gold);
      font-weight: 600;
    }
    body.admin-open .config-content {
      flex: 1;
      min-width: 0;
      max-width: 600px;
      padding: 8px 0 8px 28px;
    }
    body.admin-open .config-sec { display: none !important; }
    body.admin-open .config-sec.cfg-active { display: block !important; }
    body.admin-open .config-sec.cfg-active .acc-body { display: block !important; max-height: none !important; overflow: visible !important; padding-top: 16px !important; }
    body.admin-open .config-sec.cfg-active .acc-header { display: none; }
    body.admin-open #apanel-config:not(.hidden) .admin-section {
      margin-bottom: 20px;
    }
    /* Team: 2-column grid */
    body.admin-open #apanel-team:not(.hidden) {
      display: grid !important;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
      align-items: start;
    }
    body.admin-open #apanel-stats:not(.hidden) {
      display: block !important;
    }
    /* Wider sections on desktop */
    body.admin-open .admin-section {
      border-radius: 20px;
      padding: 24px;
    }
    body.admin-open .admin-section-title {
      font-size: 16px;
      margin-bottom: 18px;
    }
    /* Stats cards hover effect */
    body.admin-open .stat-card {
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }
    body.admin-open .stat-card:hover {
      transform: translateY(-2px);
      box-shadow: 0 8px 24px rgba(var(--gold-rgb),0.12);
    }
    body.admin-open .stat-val {
      font-size: 32px;
    }
    /* RTL desktop */
    [dir=rtl] body.admin-open .admin-sidebar { border-right:none;border-left:1px solid rgba(var(--gold-rgb),0.12); }
    [dir=rtl] body.admin-open .config-nav { border-right:none;border-left:1px solid rgba(255,255,255,0.06); }
    [dir=rtl] body.admin-open .config-nav-btn { border-left:none;border-right:3px solid transparent;text-align:right; }
    [dir=rtl] body.admin-open .config-nav-btn.active { border-left-color:transparent;border-right-color:var(--gold); }
    [dir=rtl] body.admin-open .config-content { padding:8px 28px 8px 0; }
    [dir=rtl] body.admin-open .admin-sidebar .admin-big-tab { text-align:right; }
  }

  /* ── Extra-wide desktop (≥1400px) ── */
  @media (min-width: 1400px) {
    body.admin-open .admin-sidebar { width: 280px; }
    body.admin-open .admin-main { padding: 36px 48px 48px; }
    body.admin-open #apanel-team:not(.hidden) {
      grid-template-columns: 1fr 1fr 1fr !important;
    }
  }
  /* ── Stats Bar Chart ── */
  .stats-chart{display:flex;align-items:flex-end;gap:8px;height:80px;padding:4px 0 0;background:none;border:none;border-radius:0;margin-bottom:0;position:relative;}
  .stats-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0;}
  .stats-chart-bar{width:100%;min-height:6px;border-radius:6px 6px 2px 2px;background:linear-gradient(180deg,var(--gold2),var(--gold));transition:height 0.5s ease;position:relative;box-shadow:0 0 8px rgba(var(--gold-rgb),0.2);}
  .stats-chart-bar:hover{filter:brightness(1.3);box-shadow:0 0 16px rgba(var(--gold-rgb),0.45);}
  .stats-chart-val{font-size:11px;color:rgba(255,255,255,0.7);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
  .stats-chart-lbl{font-size:10px;color:rgba(255,255,255,0.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
  @media (min-width: 900px) {
    .stats-chart{height:110px;padding:4px 0 0;gap:10px;}
    .stats-chart-val{font-size:12px;}
    .stats-chart-lbl{font-size:11px;}
  }
  /* ── Hotel Home Tabs ── */
  .hotel-home-tabs{display:flex;gap:8px;margin-bottom:16px;}
  .hotel-home-tab{flex:1;padding:11px 8px;border-radius:14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.5);font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.2s;text-align:center;}
  .hotel-home-tab.active{background:rgba(var(--gold-rgb),0.18);border-color:var(--gold);color:var(--gold);}
  /* ── Staff mode badge ── */
  .staff-mode-badge{display:inline-block;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:700;margin-left:6px;flex-shrink:0;}
  .staff-mode-struttura{background:rgba(59,130,246,0.15);border:1px solid rgba(59,130,246,0.3);color:#60A5FA;}
  .staff-mode-privato{background:rgba(52,211,153,0.12);border:1px solid rgba(52,211,153,0.3);color:#34D399;}
  /* ── Staff profile page (Fase D) ── */
  .sp-hero{text-align:center;padding:20px 0 16px}
  .sp-avatar{width:90px;height:90px;border-radius:50%;overflow:hidden;margin:0 auto 12px;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;font-size:38px;border:2px solid rgba(255,255,255,0.12)}
  .sp-avatar img{width:100%;height:100%;object-fit:cover}
  .sp-name{font-size:22px;font-weight:800;color:#E8E0D0;margin-bottom:4px;overflow-wrap:break-word;word-break:break-word}
  .sp-role{font-size:14px;color:rgba(255,255,255,0.5);margin-bottom:4px}
  .sp-subtitle{font-size:13px;color:rgba(255,255,255,0.4);font-style:italic;margin-bottom:8px}
  .sp-dept{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:rgba(var(--gold-rgb),0.8);background:rgba(var(--gold-rgb),0.08);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:20px;padding:3px 10px;margin-bottom:12px}
  .sp-stats{display:flex;gap:8px;justify-content:center;margin-bottom:16px}
  .sp-stat{text-align:center;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:10px 14px;flex:1}
  .sp-stat-val{display:block;font-size:18px;font-weight:700;background:linear-gradient(135deg,var(--gold),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
  .sp-stat-lbl{display:block;font-size:10px;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:0.5px;margin-top:2px}
  .sp-tip-btn{width:100%;padding:15px;border-radius:14px;background:linear-gradient(135deg,var(--gold),var(--gold2));border:none;color:#1a1228;font-size:16px;font-weight:800;cursor:pointer;font-family:'DM Sans',sans-serif;margin-bottom:14px}
  .sp-edit-section{background:rgba(255,255,255,0.03);border:1px solid rgba(var(--gold-rgb),0.2);border-radius:16px;padding:16px;margin-bottom:14px}
  .sp-edit-title{font-size:12px;font-weight:700;color:rgba(var(--gold-rgb),0.8);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:12px}
  .sp-field-lbl{font-size:11px;color:rgba(255,255,255,0.4);font-weight:600;margin-bottom:4px;text-transform:uppercase;letter-spacing:0.4px}
  .sp-field{width:100%;padding:10px 12px;border-radius:9px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:#E8E0D0;font-size:14px;outline:none;font-family:'DM Sans',sans-serif;box-sizing:border-box;margin-bottom:8px}
  .sp-field:focus{border-color:rgba(var(--gold-rgb),0.45)}
  .sp-save-btn{width:100%;padding:12px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold2));border:none;color:#1a1228;font-size:14px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif}
  .sp-comment{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.07);border-radius:12px;padding:10px 12px;margin-bottom:8px}
  .sp-comment-text{font-size:13px;color:rgba(232,224,208,0.75);margin-bottom:4px}
  .sp-comment-meta{font-size:11px;color:rgba(255,255,255,0.3)}

  /* Clear-input (✕) wrapper */
  .gt-input-wrap{position:relative;display:block;}
  .gt-input-wrap .field-input,
  .gt-input-wrap .modal-input{padding-right:34px !important;}
  .gt-clear-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,0.3);font-size:16px;cursor:pointer;padding:2px 4px;line-height:1;display:none;transition:color 0.15s;}
  .gt-clear-btn:hover,.gt-clear-btn:active{color:rgba(255,255,255,0.7);}

  /* ═══════════════════════════════════════════════════════
     LIGHT THEME — visitatori
     ═══════════════════════════════════════════════════════ */
  body.light-theme { background: #F5F0E8; }
  body.light-theme::before { opacity: 0.15; }
  body.light-theme .phone { background: #F5F0E8; }
  body.light-theme .phone::before,
  body.light-theme .phone::after { opacity: 0.08; }
  body.light-theme .statusbar { background: rgba(0,0,0,0.04); color: rgba(0,0,0,0.45); }
  body.light-theme .screen { color: #2C2416; }
  body.light-theme .embers { opacity: 0.15; }

  /* Logo & heading */
  body.light-theme .logo-title { background: linear-gradient(135deg,#8B6914,#A67C1A,#8B6914); -webkit-background-clip:text; }
  body.light-theme .logo-sub { color: rgba(140,110,40,0.4); }
  body.light-theme .logo-inner { background: linear-gradient(145deg,#EDE6D4,#F5F0E8); border-color: rgba(180,150,60,0.25); box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 8px 24px rgba(0,0,0,0.08); }
  body.light-theme .logo-ring { opacity: 0.5; }
  body.light-theme .section-label { color: rgba(140,110,40,0.5); }

  /* Category buttons */
  body.light-theme .cat-btn { background: rgba(180,150,60,0.06); border-color: rgba(180,150,60,0.15); }
  body.light-theme .cat-btn:hover { background: rgba(180,150,60,0.1); border-color: rgba(180,150,60,0.25); }
  body.light-theme .cat-label { color: #2C2416; }
  body.light-theme .cat-sub { color: rgba(140,110,40,0.45); }
  body.light-theme .cat-arrow { color: rgba(0,0,0,0.2); }
  body.light-theme .cat-counter { color: rgba(0,0,0,0.35); }

  /* Staff buttons */
  body.light-theme .staff-btn { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); }
  body.light-theme .staff-btn::before { background: linear-gradient(180deg,transparent,rgba(27,80,180,0.4),transparent); }
  body.light-theme .staff-btn:hover { background: rgba(0,0,0,0.05); }

  /* Form fields */
  body.light-theme .field-input { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #2C2416; }
  body.light-theme .field-input::placeholder { color: rgba(0,0,0,0.3); }
  body.light-theme .field-input:focus { border-color: #B8941E; }
  body.light-theme select.field-input { background-color: rgba(0,0,0,0.04); }
  body.light-theme select.field-input option { background: #F5F0E8; color: #2C2416; }

  /* Pay method */
  body.light-theme .pay-method { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); color: #2C2416; }
  body.light-theme .pay-method.pm-sel { background: rgba(var(--gold-rgb),0.12); border-color: #B8941E; }
  body.light-theme .pay-method:not(.pm-sel):hover { box-shadow: 0 4px 12px rgba(0,0,0,0.06); border-color: rgba(0,0,0,0.15); }

  /* Back button */
  body.light-theme .back-btn { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.1); color: #2C2416; }

  /* Footer */
  body.light-theme .footer { border-top-color: rgba(0,0,0,0.08); }
  body.light-theme .footer a { color: rgba(0,0,0,0.4); }
  body.light-theme .footer a:hover { color: #B8941E; }

  /* Lang bar */
  body.light-theme .lang-bar { background: none; }
  body.light-theme .lang-btn { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); }
  body.light-theme .lang-btn.active { background: rgba(var(--gold-rgb),0.12); border-color: #B8941E; }

  /* Hotel tabs */
  body.light-theme .hotel-home-tab { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); color: rgba(0,0,0,0.45); }
  body.light-theme .hotel-home-tab.active { background: rgba(var(--gold-rgb),0.12); border-color: #B8941E; color: #8B6914; }

  /* Feedback options */
  body.light-theme .fb-opt { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); }

  /* Misc text overrides */
  body.light-theme #tip-name,
  body.light-theme #pay-amount { color: #2C2416; }
  body.light-theme #tip-rating,
  body.light-theme #star-label,
  body.light-theme #pay-for { color: rgba(0,0,0,0.5); }

  /* Clear input btn */
  body.light-theme .gt-clear-btn { color: rgba(0,0,0,0.3); }
  body.light-theme .gt-clear-btn:hover { color: rgba(0,0,0,0.6); }

  /* Amounts & tip */
  body.light-theme .amount-btn { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); color: #2C2416; }
  body.light-theme .amount-btn.amt-pop { background: rgba(var(--gold-rgb),0.12); border-color: var(--gold); }
  body.light-theme .custom-input { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #2C2416; }
  body.light-theme .custom-input::placeholder { color: rgba(0,0,0,0.3); }
  body.light-theme .tip-badge { color: rgba(0,0,0,0.4); }
  body.light-theme .tip-name { color: #2C2416; }
  body.light-theme .staff-name { color: #2C2416; }
  body.light-theme .staff-role { color: rgba(0,0,0,0.4); }
  body.light-theme .staff-happy { color: rgba(0,0,0,0.35); }
  body.light-theme .staff-avatar { background: linear-gradient(135deg,#EDE6D4,#F5F0E8); border-color: rgba(180,150,60,0.25); box-shadow: 0 0 12px rgba(0,0,0,0.06); }

  /* Stars & feedback */
  body.light-theme .star-btn { filter: grayscale(1) opacity(0.25); }
  body.light-theme .star-btn.active { filter: none; }
  body.light-theme .comment-input { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #2C2416; }
  body.light-theme .comment-input::placeholder { color: rgba(0,0,0,0.3); }
  body.light-theme .fb-btn { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); color: rgba(0,0,0,0.55); }

  /* Buttons */
  body.light-theme .btn-secondary { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: rgba(0,0,0,0.55); }
  body.light-theme .btn-primary:disabled { background: rgba(0,0,0,0.06) !important; color: rgba(0,0,0,0.25) !important; }

  /* Confirm screen */
  body.light-theme .confirm-text { color: rgba(0,0,0,0.5); }
  body.light-theme .confirm-personal { color: var(--gold); }
  body.light-theme .confirm-staff-card { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); }
  body.light-theme .confirm-staff-name { color: #2C2416; }
  body.light-theme .confirm-staff-role { color: rgba(0,0,0,0.4); }
  body.light-theme .confirm-staff-avatar { background: linear-gradient(135deg,#EDE6D4,#F5F0E8); }

  /* Modal */
  body.light-theme .modal-overlay { background: rgba(0,0,0,0.4); }
  body.light-theme .modal { background: #FAF6EE; border-color: rgba(0,0,0,0.1); }
  body.light-theme .modal h3 { color: #2C2416; }
  body.light-theme .modal-input { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #2C2416; }
  body.light-theme .modal-input::placeholder { color: rgba(0,0,0,0.3); }
  body.light-theme .modal-btn-cancel { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: rgba(0,0,0,0.55); }

  /* Password screen */
  body.light-theme .pwd-title { color: #2C2416; }
  body.light-theme .pwd-sub { color: rgba(0,0,0,0.4); }
  body.light-theme .pwd-input { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #2C2416; }
  body.light-theme .pwd-input::placeholder { color: rgba(0,0,0,0.3); }
  body.light-theme .eye-btn { color: rgba(0,0,0,0.3); }
  body.light-theme .eye-btn:hover { color: rgba(0,0,0,0.6); }

  /* H2 & subtitle */
  body.light-theme h2 { color: #2C2416; }
  body.light-theme .subtitle { color: rgba(0,0,0,0.4); }

  /* Pay method extras */
  body.light-theme .pay-tab { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); color: rgba(0,0,0,0.45); }
  body.light-theme .pay-tab.active { background: rgba(var(--gold-rgb),0.12); border-color: rgba(var(--gold-rgb),0.4); color: var(--gold); }
  body.light-theme #pm-error { color: #dc2626; }
  body.light-theme .pay-for { color: rgba(0,0,0,0.45); }

  /* Skeleton loading */
  body.light-theme .skel-card { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.06); }
  body.light-theme .skel-circle { background: rgba(0,0,0,0.06); }
  body.light-theme .skel-line { background: rgba(0,0,0,0.06); }

  /* Trust strip */
  body.light-theme .trust-strip { background: rgba(34,197,94,0.06); border-color: rgba(34,197,94,0.15); }

  /* Staff profile page */
  body.light-theme .sp-name { color: #2C2416; }
  body.light-theme .sp-role { color: rgba(0,0,0,0.45); }
  body.light-theme .sp-subtitle { color: rgba(0,0,0,0.4); }
  body.light-theme .sp-stat { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); }
  body.light-theme .sp-stat-lbl { color: rgba(0,0,0,0.35); }
  body.light-theme .sp-avatar { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.1); }
  body.light-theme .sp-field-lbl { color: rgba(0,0,0,0.45); }
  body.light-theme .sp-field { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #2C2416; }
  body.light-theme .sp-comment { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.06); }
  body.light-theme .sp-comment-text { color: rgba(0,0,0,0.65); }
  body.light-theme .sp-comment-meta { color: rgba(0,0,0,0.3); }

  /* Branding preview */
  body.light-theme .brand-preview-sub { color: rgba(0,0,0,0.35); }

  /* Onboarding */
  body.light-theme .ob-step { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.12); color: rgba(0,0,0,0.35); }
  body.light-theme .ob-line { background: rgba(0,0,0,0.1); }
  body.light-theme .ob-staff-item { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); }
  body.light-theme .ob-staff-name { color: #2C2416; }
  body.light-theme .ob-staff-role { color: rgba(0,0,0,0.4); }
  body.light-theme .ob-remove { color: rgba(0,0,0,0.3); }

  /* Registration stepper */
  body.light-theme .reg-step-dot { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.12); color: rgba(0,0,0,0.3); }
  body.light-theme .reg-step-line { background: rgba(0,0,0,0.1); }

  /* Menu button */
  body.light-theme .menu-pub-btn { background: rgba(var(--gold-rgb),0.08); border-color: rgba(var(--gold-rgb),0.25); }

  /* PWA banner */
  body.light-theme .pwa-banner { background: linear-gradient(135deg,#FAF6EE,#F5F0E8); border-top-color: rgba(0,0,0,0.08); box-shadow: 0 -8px 32px rgba(0,0,0,0.08); }
  body.light-theme .pwa-banner-title { color: #2C2416; }
  body.light-theme .pwa-banner-sub { color: rgba(0,0,0,0.45); }
  body.light-theme .pwa-banner-later { color: rgba(0,0,0,0.35); }

  /* ── Admin stays dark — reset light overrides ── */
  body.light-theme.admin-open { background: #060408; }
  body.light-theme.admin-open::before { opacity: 1; }
  body.light-theme.admin-open .phone { background: #060408; }
  body.light-theme.admin-open .phone::before,
  body.light-theme.admin-open .phone::after { opacity: 1; }
  body.light-theme.admin-open .statusbar { background: rgba(0,0,0,0.3); color: rgba(255,255,255,0.5); }
  body.light-theme.admin-open .screen { color: inherit; }
  body.admin-open #theme-toggle { display: none; }

  /* ── Toast notifica mancia real-time ── */
  .tip-toast {
    position: fixed; top: 24px; left: 50%; transform: translateX(-50%) translateY(-120px);
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border: 1px solid var(--gold); border-radius: 14px;
    padding: 14px 22px; z-index: 130;
    display: flex; align-items: center; gap: 12px;
    box-shadow: 0 8px 32px rgba(var(--gold-rgb),0.25);
    animation: toastIn 0.4s ease forwards;
    max-width: 90vw; cursor: pointer;
  }
  .tip-toast.out { animation: toastOut 0.4s ease forwards; }
  .tip-toast-icon { font-size: 28px; flex-shrink: 0; }
  .tip-toast-text { color: #fff; font-size: 14px; line-height: 1.4; }
  .tip-toast-amount { color: var(--gold); font-weight: 700; font-size: 16px; }
  @keyframes toastIn { to { transform: translateX(-50%) translateY(0); } }
  @keyframes toastOut { from { transform: translateX(-50%) translateY(0); } to { transform: translateX(-50%) translateY(-120px); opacity: 0; } }

  /* ── Global Toast (replaces alert()) ── */
  .gt-toast-wrap {
    position: fixed; top: 0; left: 50%; transform: translateX(-50%);
    z-index: 140; display: flex; flex-direction: column; align-items: center;
    gap: 8px; padding: 16px 0; pointer-events: none; width: 100%; max-width: 420px;
  }
  .gt-toast {
    pointer-events: auto;
    display: flex; align-items: center; gap: 10px;
    padding: 13px 18px; border-radius: 14px; max-width: 90%;
    font-size: 14px; line-height: 1.4; font-family: 'DM Sans', sans-serif;
    box-shadow: 0 8px 28px rgba(0,0,0,0.35);
    animation: gtToastIn 0.35s cubic-bezier(0.22,1,0.36,1) forwards;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  }
  .gt-toast.out { animation: gtToastOut 0.3s ease forwards; }
  .gt-toast-icon { font-size: 20px; flex-shrink: 0; }
  .gt-toast-msg { flex: 1; min-width: 0; }
  .gt-toast-close { background: none; border: none; color: inherit; opacity: 0.5;
    font-size: 18px; cursor: pointer; padding: 0 0 0 6px; flex-shrink: 0; line-height: 1; }
  .gt-toast-close:hover { opacity: 1; }

  .gt-toast.gt-error {
    background: rgba(220,38,38,0.92); color: #fff; border: 1px solid rgba(255,100,100,0.3);
  }
  .gt-toast.gt-success {
    background: rgba(22,163,74,0.92); color: #fff; border: 1px solid rgba(74,222,128,0.3);
  }
  .gt-toast.gt-info {
    background: rgba(30,64,120,0.94); color: #E8E0D0; border: 1px solid rgba(var(--gold-rgb),0.3);
  }
  .gt-toast.gt-warning {
    background: rgba(180,120,10,0.92); color: #fff; border: 1px solid rgba(250,204,21,0.35);
  }
  @keyframes gtToastIn {
    from { opacity: 0; transform: translateY(-18px) scale(0.95); }
    to { opacity: 1; transform: translateY(0) scale(1); }
  }
  @keyframes gtToastOut {
    from { opacity: 1; transform: translateY(0) scale(1); }
    to { opacity: 0; transform: translateY(-14px) scale(0.95); }
  }
  @media (prefers-reduced-motion: reduce) {
    .gt-toast, .gt-toast.out { animation-duration: 0.01s; }
  }

  /* ── Button Loading Spinner ── */
  .gt-btn-loading { position: relative; pointer-events: none; opacity: 0.7; }
  .gt-btn-loading::after {
    content: ''; display: inline-block; width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,0.3); border-top-color: #fff;
    border-radius: 50%; animation: gtSpin 0.6s linear infinite;
    margin-left: 8px; vertical-align: middle;
  }
  @keyframes gtSpin { to { transform: rotate(360deg); } }
  @media (prefers-reduced-motion: reduce) {
    .gt-btn-loading::after { animation-duration: 0.01s; }
  }

  /* ── Registration Stepper ── */
  .reg-stepper { display: flex; align-items: center; justify-content: center; gap: 0; margin-bottom: 8px; padding: 0 20px; }
  .reg-step-dot {
    width: 28px; height: 28px; border-radius: 50%;
    background: rgba(255,255,255,0.08); border: 2px solid rgba(255,255,255,0.15);
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700; color: rgba(255,255,255,0.35);
    transition: all 0.3s ease; flex-shrink: 0;
  }
  .reg-step-dot.active {
    background: rgba(var(--gold-rgb),0.2); border-color: var(--gold); color: var(--gold);
  }
  .reg-step-dot.done {
    background: rgba(var(--gold-rgb),0.3); border-color: var(--gold); color: var(--gold);
  }
  .reg-step-line {
    flex: 1; height: 2px; background: rgba(255,255,255,0.1);
    transition: background 0.3s ease; min-width: 20px;
  }
  .reg-step-line.done { background: var(--gold); }

  /* ── Form Validation ── */
  .gt-valid { border-color: rgba(74,222,128,0.5) !important; }
  .gt-invalid { border-color: rgba(248,113,113,0.5) !important; }
  .gt-validate-msg { font-size: 11px; margin-top: -4px; margin-bottom: 6px; min-height: 14px; }
  .gt-validate-msg.err { color: #f87171; }
  .gt-validate-msg.ok { color: #4ADE80; }

  /* ── Offline Banner ── */
  .gt-offline-bar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 150;
    background: rgba(220,38,38,0.95); color: #fff;
    text-align: center; padding: 10px 16px;
    font-size: 13px; font-weight: 600; font-family: 'DM Sans', sans-serif;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    animation: gtOfflineIn 0.35s ease forwards;
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  }
  .gt-offline-bar.out { animation: gtOfflineOut 0.35s ease forwards; }
  @keyframes gtOfflineIn { from { transform: translateY(-100%); } to { transform: translateY(0); } }
  @keyframes gtOfflineOut { from { transform: translateY(0); } to { transform: translateY(-100%); } }

  /* ── PWA Install Banner ── */
  .pwa-banner{position:fixed;bottom:0;left:0;right:0;z-index:110;background:linear-gradient(135deg,#0f0a1e,#1a1228);border-top:1px solid rgba(var(--gold-rgb),0.3);padding:16px 20px;padding-bottom:max(16px,env(safe-area-inset-bottom));display:flex;align-items:center;gap:14px;animation:pwaSlide 0.4s cubic-bezier(0.22,1,0.36,1);box-shadow:0 -8px 32px rgba(0,0,0,0.5);}
  .pwa-banner-icon{width:48px;height:48px;border-radius:12px;flex-shrink:0;background:rgba(var(--gold-rgb),0.15);display:flex;align-items:center;justify-content:center;font-size:24px;}
  .pwa-banner-icon img{width:48px;height:48px;border-radius:12px;}
  .pwa-banner-text{flex:1;min-width:0;}
  .pwa-banner-title{color:#fff;font-size:15px;font-weight:700;margin-bottom:2px;}
  .pwa-banner-sub{color:rgba(255,255,255,0.5);font-size:12px;}
  .pwa-banner-actions{display:flex;gap:8px;flex-shrink:0;}
  .pwa-banner-install{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;border:none;border-radius:10px;padding:10px 18px;font-size:13px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;transition:transform 0.15s,box-shadow 0.15s;}
  .pwa-banner-install:active{transform:scale(0.96);}
  .pwa-banner-later{background:none;border:none;color:rgba(255,255,255,0.4);font-size:12px;cursor:pointer;padding:8px;font-family:'DM Sans',sans-serif;}
  @keyframes pwaSlide{from{transform:translateY(100%);}to{transform:translateY(0);}}

  /* ── Welcome Landing Screen ── */
  .welcome-wrap {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    min-height: 100vh; padding: 40px 24px; text-align: center;
    position: relative; overflow: hidden;
  }
  .welcome-wrap::before {
    content: ''; position: absolute; inset: 0; z-index: 0;
    background:
      radial-gradient(ellipse at 50% 20%, rgba(var(--gold-rgb),0.12) 0%, transparent 60%),
      radial-gradient(ellipse at 30% 80%, rgba(139,92,246,0.08) 0%, transparent 50%),
      radial-gradient(ellipse at 80% 60%, rgba(var(--gold-rgb),0.06) 0%, transparent 40%);
    animation: welcomeAmbient 8s ease-in-out infinite alternate;
  }
  .welcome-wrap > * { position: relative; z-index: 1; }
  .welcome-logo-ring {
    width: 140px; height: 140px; border-radius: 50%;
    background: conic-gradient(from 0deg, var(--gold), var(--gold3), var(--gold), var(--gold2), var(--gold));
    padding: 3.5px; margin-bottom: 28px;
    animation: welcomeRingSpin 8s linear infinite, welcomeFloat 3s ease-in-out infinite;
    box-shadow: 0 0 60px rgba(var(--gold-rgb),0.3), 0 0 120px rgba(var(--gold-rgb),0.1);
    opacity: 0; animation: welcomeRingSpin 8s linear infinite, welcomeFloat 3s ease-in-out infinite, welcomeLogoIn 1s ease-out 0.2s forwards;
  }
  .welcome-logo {
    width: 100%; height: 100%; border-radius: 50%;
    background: var(--bg) center/cover no-repeat;
    display: flex; align-items: center; justify-content: center;
    font-size: 52px;
  }
  .welcome-name {
    font-size: 32px; font-weight: 800; color: #fff;
    letter-spacing: -0.02em; margin-bottom: 6px;
    opacity: 0; animation: welcomeTextIn 0.8s ease-out 0.5s forwards;
    text-shadow: 0 2px 20px rgba(0,0,0,0.3);
  }
  .welcome-msg {
    font-size: 15px; color: rgba(255,255,255,0.55);
    max-width: 300px; line-height: 1.6; margin-bottom: 36px;
    opacity: 0; animation: welcomeTextIn 0.8s ease-out 0.7s forwards;
  }
  .welcome-divider {
    width: 60px; height: 2px; border-radius: 1px; margin-bottom: 36px;
    background: linear-gradient(90deg, transparent, var(--gold), var(--gold2), var(--gold), transparent);
    opacity: 0; animation: welcomeDividerIn 1s ease-out 0.9s forwards;
    box-shadow: 0 0 12px rgba(var(--gold-rgb),0.4);
  }
  .welcome-btn {
    background: linear-gradient(135deg, var(--gold) 0%, #D4B44E 50%, var(--gold2) 100%);
    background-size: 200% 100%;
    color: #0a0812; font-size: 17px; font-weight: 700;
    padding: 18px 52px; border: none; border-radius: 50px;
    cursor: pointer; letter-spacing: 0.03em;
    box-shadow: 0 6px 30px rgba(var(--gold-rgb),0.4), 0 0 0 0 rgba(var(--gold-rgb),0.3);
    transition: transform 0.2s, box-shadow 0.2s;
    font-family: 'DM Sans', sans-serif;
    animation: welcomeBtnIn 0.8s ease-out 1.1s forwards, welcomeShimmer 3s ease-in-out 2s infinite;
    opacity: 0;
    position: relative; overflow: hidden;
  }
  .welcome-btn::after {
    content: ''; position: absolute; top: -50%; left: -60%; width: 40%; height: 200%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.25), transparent);
    transform: skewX(-20deg);
    animation: welcomeBtnShine 4s ease-in-out 2.5s infinite;
  }
  .welcome-btn:hover { transform: translateY(-3px); box-shadow: 0 10px 40px rgba(var(--gold-rgb),0.5); }
  .welcome-btn:active { transform: scale(0.96); }
  .welcome-powered {
    margin-top: 48px; font-size: 11px; color: rgba(255,255,255,0.18);
    letter-spacing: 0.08em; text-transform: uppercase;
    opacity: 0; animation: welcomeTextIn 0.6s ease-out 1.4s forwards;
  }
  .welcome-powered strong { color: rgba(var(--gold-rgb),0.45); font-weight: 700; }

  @keyframes welcomeLogoIn {
    from { opacity: 0; transform: scale(0.7); }
    to { opacity: 1; transform: scale(1); }
  }
  @keyframes welcomeTextIn {
    from { opacity: 0; transform: translateY(16px); }
    to { opacity: 1; transform: translateY(0); }
  }
  @keyframes welcomeDividerIn {
    from { opacity: 0; width: 0; }
    to { opacity: 1; width: 60px; }
  }
  @keyframes welcomeBtnIn {
    from { opacity: 0; transform: translateY(20px) scale(0.95); }
    to { opacity: 1; transform: translateY(0) scale(1); }
  }
  @keyframes welcomeRingSpin { to { transform: rotate(360deg); } }
  @keyframes welcomeFloat {
    0%, 100% { translate: 0 0; }
    50% { translate: 0 -6px; }
  }
  @keyframes welcomeAmbient {
    from { opacity: 0.8; transform: scale(1); }
    to { opacity: 1; transform: scale(1.05); }
  }
  @keyframes welcomeShimmer {
    0%, 100% { background-position: 0% center; }
    50% { background-position: 100% center; }
  }
  @keyframes welcomeBtnShine {
    0%, 75%, 100% { left: -60%; }
    25% { left: 120%; }
  }

  .welcome-wrap.fade-out {
    opacity: 0; transform: scale(0.96);
    transition: opacity 0.45s ease, transform 0.45s ease;
    pointer-events: none;
  }

  /* Light theme welcome */
  body.light-theme .welcome-wrap::before {
    background:
      radial-gradient(ellipse at 50% 20%, rgba(var(--gold-rgb),0.1) 0%, transparent 60%),
      radial-gradient(ellipse at 30% 80%, rgba(139,92,246,0.06) 0%, transparent 50%);
  }
  body.light-theme .welcome-name { color: #1a1a2e; text-shadow: none; }
  body.light-theme .welcome-msg { color: rgba(26,26,46,0.5); }
  body.light-theme .welcome-powered { color: rgba(26,26,46,0.18); }
  body.light-theme .welcome-logo { background-color: #F5F0E8; }
  body.light-theme .welcome-divider { box-shadow: 0 0 8px rgba(var(--gold-rgb),0.25); }
  body.light-theme .welcome-btn { box-shadow: 0 6px 24px rgba(var(--gold-rgb),0.3), 0 2px 8px rgba(0,0,0,0.08); }
