:root {
  --bg:#0a0a0a; --s1:#111; --s2:#181818; --s3:#1e1e1e;
  --b1:#252525; --b2:#303030;
  --gold:#b8973a; --gold-l:#d4af5a; --gold-d:#7a6030;
  --on-accent:var(--gold-l); --sel-bg:#1a1508;
  --text:#f0ede6; --text-em:var(--gold-l); --sub:#888278; --dim:#444240;
  --green:#3d9e6a; --gbg:#0d1f16; --gbr:#1a3828;
  --red:#c0392b; --rbg:#fff0ee; --rbr:#f5c0bb;
  --overlay:rgba(255,255,255,0.06); --overlay-b:rgba(255,255,255,0.12);
  --font-heading:'Cormorant Garamond',serif;
  --font-body:'Outfit',sans-serif;
  --font-size:15px;
  --radius:10px;
  --btn-radius:12px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{height:100%;overflow-x:hidden;}
body{
  background:var(--bg); color:var(--text); font-family:var(--font-body); font-size:var(--font-size);
  min-height:100dvh;
  padding-top:env(safe-area-inset-top);
  padding-bottom:env(safe-area-inset-bottom);
  padding-left:env(safe-area-inset-left);
  padding-right:env(safe-area-inset-right);
  -webkit-text-size-adjust:100%;
  overflow-x:hidden;
}
button,[onclick]{touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer;}
input,select,textarea{-webkit-appearance:none;border-radius:var(--radius);font-family:var(--font-body);}
/* Prevent iOS auto-zoom on input focus (requires ≥16px) */
input,select,textarea{font-size:16px;}

/* ── LAYOUT ── */
.page{max-width:480px;margin:0 auto;padding:0 20px 80px;}
body.embed-mode{background:transparent;}
body.embed-mode .page{padding-bottom:40px;}
body.transparent-embed{--bg:transparent;--s1:transparent;--s2:transparent;--s3:transparent;}

/* ── BANNER ── */
.banner-wrap{margin:0 -20px;margin-bottom:0;}
.banner-img{width:100%;max-height:200px;object-fit:cover;display:block;}

/* ── HEADER ── */
.header{text-align:center;padding:32px 0 24px;}
.header-logo{max-height:56px;max-width:200px;object-fit:contain;margin-bottom:10px;display:block;margin-left:auto;margin-right:auto;}
.header-brand{font-family:var(--font-heading);font-size:2rem;font-weight:600;color:var(--text-em);letter-spacing:.06em;}
.header-sub{font-size:.68rem;color:var(--sub);letter-spacing:.18em;text-transform:uppercase;margin-top:3px;}

/* ── PROGRESS ── */
.progress{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:32px;}
.prog-dot{width:8px;height:8px;border-radius:50%;background:var(--b2);transition:all .3s;}
.prog-dot.active{background:var(--gold);transform:scale(1.2);}
.prog-dot.done{background:var(--gold-d);}

/* ── STEP TITLE ── */
.step-title{font-family:var(--font-heading);font-size:1.55rem;font-weight:400;margin-bottom:6px;}
.step-hint{font-size:.78rem;color:var(--sub);margin-bottom:22px;line-height:1.5;}

/* ── CALENDAR ── */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.cal-month{font-family:var(--font-heading);font-size:1.15rem;font-weight:600;color:var(--text-em);}
.cal-arrow{background:none;border:1px solid var(--b2);color:var(--sub);width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:border-color .15s;}
.cal-arrow:hover{border-color:var(--gold-d);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cal-day-name{text-align:center;font-size:.68rem;color:var(--sub);letter-spacing:.05em;text-transform:uppercase;padding:4px 0;font-weight:600;}
.cal-day{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  border-radius:8px;font-size:.95rem;font-weight:400;border:1px solid transparent;
  transition:all .15s;
}
.cal-day.empty{cursor:default;}
.cal-day.disabled{color:var(--sub);cursor:not-allowed;background:var(--overlay);opacity:.6;position:relative;}
.cal-day.disabled[data-tip]:hover::after,.cal-day.disabled[data-tip]:focus::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--s2);color:var(--gold);font-size:.65rem;font-weight:600;letter-spacing:.04em;padding:4px 8px;border-radius:6px;border:1px solid var(--gold-d);pointer-events:none;z-index:10;opacity:1;}
.cal-day.disabled[data-tip]:first-child::after,.cal-day.disabled[data-tip]:nth-child(-n+9)::after{bottom:auto;top:calc(100% + 6px);}
.cal-day[data-tip]{-webkit-tap-highlight-color:transparent;}
.cal-day.available{color:var(--gold);cursor:pointer;font-weight:700;font-size:1rem;background:rgba(184,151,58,.07);}
.cal-day.available:hover{color:var(--gold-l);background:rgba(184,151,58,.16);}
.cal-day.selected{background:var(--gold);color:var(--on-accent);font-weight:700;}
.cal-day.today.available{box-shadow:inset 0 0 0 1.5px var(--gold-d);}
.cal-day.today.disabled{border-color:transparent;}

/* ── SHIFTS ── */
.arrival-chips{display:flex;flex-wrap:wrap;gap:8px;}
.arrival-chip{background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:11px 16px;font-size:.85rem;color:var(--text);cursor:pointer;transition:all .2s;font-family:var(--font-body);min-height:44px;display:inline-flex;align-items:center;}
.arrival-chip:hover{border-color:var(--gold-d);}
.arrival-chip.selected{border-color:var(--gold);background:var(--sel-bg);color:var(--on-accent);}
.loc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.loc-card{background:var(--s2);border:1.5px solid var(--b2);border-radius:var(--radius);padding:16px 10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:all .2s;color:var(--text);font-family:var(--font-body);min-height:72px;text-align:center;}
.loc-card:hover{border-color:var(--gold-d);}
.loc-card.selected{border-color:var(--gold);background:var(--sel-bg);}
.loc-icon{font-size:1.3rem;}
.loc-label{font-size:.8rem;color:var(--text);font-weight:500;}
.loc-card.selected .loc-label{color:var(--on-accent);}
.shift-list{display:flex;flex-direction:column;gap:10px;margin-bottom:0;}
.shift-card{
  background:var(--s2);border:1px solid var(--b1);border-radius:var(--radius);
  padding:16px;display:flex;align-items:center;justify-content:space-between;
  transition:all .2s;min-height:64px;
}
.shift-card.available{cursor:pointer;}
.shift-card.available:hover{border-color:var(--gold-d);}
.shift-card.selected{border-color:var(--gold);background:var(--sel-bg);}
.shift-card.selected .shift-time{color:var(--on-accent);}
.shift-card.selected .shift-label{color:var(--on-accent);opacity:.75;}
.shift-card.full{opacity:.5;cursor:not-allowed;}
.shift-card.request{cursor:pointer;border-color:#3a2810;opacity:.85;}
.shift-card.request:hover{border-color:var(--gold);}
.shift-card.request.selected{border-color:var(--gold);background:var(--sel-bg);}
.shift-time{font-family:var(--font-heading);font-size:1.2rem;font-weight:600;color:var(--text-em);}
.shift-label{font-size:.72rem;color:var(--sub);margin-top:1px;}
.shift-badge{font-size:.7rem;padding:3px 10px;border-radius:99px;font-weight:500;}
.shift-badge.free{background:var(--gbg);border:1px solid var(--gbr);color:var(--green);}
.shift-badge.low{background:#1f1408;border:1px solid #3a2810;color:#c47c2a;}
.shift-badge.full{background:var(--rbg);border:1px solid var(--rbr);color:var(--red);}
.shift-badge.request{background:#1f1408;border:1px solid #3a2810;color:#c47c2a;}

/* ── GUEST PICKER ── */
.guest-row{display:flex;align-items:center;justify-content:space-between;background:var(--s2);border:1px solid var(--b1);border-radius:var(--radius);padding:14px 16px;margin-bottom:20px;}
.guest-label{font-size:.85rem;color:var(--sub);}
.guest-ctrl{display:flex;align-items:center;gap:14px;}
.guest-btn{width:44px;height:44px;border-radius:8px;background:none;border:1px solid var(--b2);color:var(--text);font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.guest-btn:hover{border-color:var(--gold-d);}
.guest-btn:disabled{opacity:.3;cursor:not-allowed;}
.guest-count{font-size:1.25rem;font-weight:600;color:var(--text-em);min-width:24px;text-align:center;}

/* ── FIELD ── */
.field{margin-bottom:16px;}
.field label{display:block;font-size:.78rem;color:var(--text);font-weight:500;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;}
.field-optional{display:inline-block;font-size:.6rem;font-weight:500;color:var(--sub);background:var(--s3);border:1px solid var(--b1);border-radius:99px;padding:1px 7px;letter-spacing:.04em;vertical-align:middle;margin-left:6px;text-transform:none;}
.field input,.field textarea,.field select{
  width:100%;background:var(--s2);border:1px solid var(--b1);color:var(--text);
  padding:13px 14px;border-radius:var(--radius);font-size:16px;outline:none;
  transition:border-color .15s, box-shadow .15s;
  border-left-width:3px;
}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:var(--gold-d);
  border-left-color:var(--gold);
  box-shadow:inset 3px 0 0 0 rgba(184,151,58,.15);
}
.field input::placeholder,.field textarea::placeholder{color:var(--dim);}
.field textarea{resize:vertical;min-height:80px;line-height:1.5;}
.field select option{background:var(--s2);}

/* ── CHECKBOXES ── */
.check-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.check-item{display:flex;align-items:center;gap:12px;background:var(--s2);border:1px solid var(--b1);border-radius:var(--radius);padding:14px;cursor:pointer;transition:border-color .15s;min-height:52px;}
.check-item:hover{border-color:var(--b2);}
.check-item.checked{border-color:var(--gold-d);}
.check-box{width:18px;height:18px;border-radius:5px;border:1px solid var(--b2);background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.7rem;color:var(--gold);}
.check-item.checked .check-box{background:var(--gold-d);border-color:var(--gold);}
.check-text{font-size:.82rem;color:var(--text);}
.field-info-block{font-size:.82rem;color:var(--sub);line-height:1.6;padding:10px 14px;background:var(--s2);border-left:3px solid var(--gold-d);border-radius:0 8px 8px 0;margin-bottom:4px;white-space:pre-wrap;}

/* ── BUTTONS ── */
.btn-primary{
  width:100%;padding:16px 20px;border-radius:var(--btn-radius);border:none;
  background:var(--gold);color:var(--on-accent);font-family:var(--font-body);
  font-size:.95rem;font-weight:600;letter-spacing:.03em;
  transition:background .15s, box-shadow .15s;margin-top:8px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 2px 12px rgba(184,151,58,.25);
  min-height:52px;
}
.btn-primary:hover{background:var(--gold-l);box-shadow:0 4px 18px rgba(184,151,58,.35);}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;}
.btn-arrow{font-size:1rem;transition:transform .15s;}
.btn-primary:hover .btn-arrow{transform:translateX(3px);}
.btn-spin{display:inline-block;width:12px;height:12px;border:2px solid rgba(0,0,0,.25);border-top-color:#0a0a0a;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:6px;}
.btn-back{
  background:none;border:none;color:var(--sub);
  padding:12px 0;font-family:var(--font-body);
  font-size:.82rem;margin-bottom:12px;letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:5px;
  min-height:44px;
}
.btn-back:hover{color:var(--gold-l);}
.btn-outline{
  width:100%;padding:12px;border-radius:var(--btn-radius);border:1px solid var(--b2);
  background:none;color:var(--sub);font-family:var(--font-body);
  font-size:.85rem;transition:all .15s;margin-top:10px;
}
.btn-outline:hover{border-color:var(--gold-d);color:var(--gold-l);}

/* ── SUMMARY BOX ── */
.summary{
  background:var(--overlay);border:1px solid var(--overlay-b);border-radius:var(--radius);
  border-left:3px solid var(--gold-d);padding:16px 18px;margin-bottom:20px;
}
.sum-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:10px 0;}
.sum-row+.sum-row{border-top:1px solid var(--b1);}
.sum-key{font-size:.78rem;color:var(--sub);text-transform:uppercase;letter-spacing:.09em;flex-shrink:0;}
.sum-val{font-size:1.05rem;color:var(--text-em);font-weight:500;text-align:right;word-break:break-word;overflow-wrap:anywhere;min-width:0;}

/* ── LOADING ── */
.loading-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:14px;}
.spinner{width:28px;height:28px;border:2px solid var(--b2);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-text{font-size:.78rem;color:var(--sub);}

/* ── ERROR ── */
.err-banner{background:var(--rbg);border:1px solid var(--rbr);color:var(--red);padding:10px 14px;border-radius:10px;font-size:.78rem;margin-bottom:14px;display:none;}
.step-cap-hint{font-size:.85rem;font-weight:600;line-height:1.45;color:var(--dim);text-align:center;margin-bottom:10px;padding:10px 14px;background:var(--s2);border-radius:8px;}
.btn-hint{font-size:.72rem;color:var(--dim);text-align:center;margin-top:8px;}
.lr-info-banner{background:#1a1500;border:1px solid #4a3800;color:#d4a017;padding:11px 14px;border-radius:10px;font-size:.8rem;line-height:1.55;margin-bottom:12px;white-space:pre-wrap;}

/* ── CLOSED ── */
.closed-msg{background:var(--s2);border:1px solid var(--b1);border-radius:12px;padding:20px;text-align:center;margin-bottom:20px;}
.closed-msg .closed-icon{font-size:1.8rem;margin-bottom:8px;}
.closed-msg p{font-size:.82rem;color:var(--sub);line-height:1.5;}

/* ── LOADING SHIFTS ── */
.shift-skeleton{background:var(--s2);border:1px solid var(--b1);border-radius:12px;padding:14px 16px;height:64px;animation:pulse 1.2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.5;}}

/* ── HONEYPOT ── */
.hp-field{position:absolute;left:-9999px;top:-9999px;opacity:0;pointer-events:none;}

/* ── STEP VISIBILITY ── */
.step{display:none;}
.step.active{display:block;}

/* ── THANK YOU PAGE ── */
.thankyou-wrap{
  text-align:center;padding:48px 0 32px;
}
.thankyou-check-circle{
  width:76px;height:76px;border-radius:50%;
  background:var(--gbg);border:2px solid var(--green);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 22px;
  animation:popIn .45s cubic-bezier(.175,.885,.32,1.275) both;
}
@keyframes popIn{from{transform:scale(0);opacity:0;}to{transform:scale(1);opacity:1;}}
.thankyou-checkmark{color:var(--green);font-size:2.2rem;line-height:1;animation:fadeUp .3s .2s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}
.thankyou-title{font-family:var(--font-heading);font-size:1.9rem;font-weight:400;margin-bottom:10px;animation:fadeUp .3s .3s ease both;}
.thankyou-msg{font-size:.84rem;color:var(--sub);line-height:1.65;max-width:320px;margin:0 auto;animation:fadeUp .3s .35s ease both;}
.redirect-bar{
  margin-top:22px;padding:10px 16px;border-radius:10px;
  background:var(--s2);border:1px solid var(--b1);
  font-size:.75rem;color:var(--sub);
  animation:fadeUp .3s .4s ease both;
}
.redirect-progress{
  height:3px;background:var(--b2);border-radius:2px;margin-top:8px;overflow:hidden;
}
.redirect-progress-bar{
  height:100%;background:var(--gold);border-radius:2px;
  transition:width 1s linear;
}

/* ── SUCCESS LOGO ── */
#stepSuccess{position:relative;}
.success-logo{display:flex;justify-content:center;padding:8px 0 0;animation:fadeUp .35s .05s ease both;}
.success-logo img{max-height:64px;max-width:60%;object-fit:contain;border-radius:8px;}

/* ── SUCCESS ACTIONS ── */
.success-actions{display:flex;flex-direction:column;gap:14px;margin-top:6px;animation:fadeUp .4s .5s ease both;}
.cal-block{display:flex;flex-direction:column;gap:6px;}
.btn-cal{
  width:100%;background:var(--s2);border:1.5px solid var(--b1);color:var(--text);
  padding:12px 14px;border-radius:var(--btn-radius,10px);font-size:.88rem;font-weight:600;font-family:inherit;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;transition:all .15s;
}
.btn-cal:hover,.btn-cal:focus-visible{border-color:var(--gold-d);color:var(--gold-l);}
.btn-cal:active{background:var(--s3);}
.cal-hint{font-size:.7rem;color:var(--dim);line-height:1.45;text-align:center;}

/* ── CONFETTI ── */
/* Each particle is animated via Web Animations API in js/form.js — no CSS
   keyframes needed here (Safari/iOS WebKit had issues with var() inside
   @keyframes which silently broke the fall animation). */
.confetti-container{
  position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:9999;
}
@media (prefers-reduced-motion: reduce){
  /* User explicitly wants confetti on every booking, so it runs even with
     reduce-motion. Only suppress the non-essential entrance animations. */
  .thankyou-check-circle,.thankyou-checkmark,.thankyou-title,.thankyou-msg,
  .success-logo,.success-actions{animation:none !important;}
}

/* ── FOOTER LINKS ── */
.footer-links{
  display:flex;flex-direction:column;align-items:center;gap:0;
  padding:20px 0 4px;border-top:1px solid var(--b1);margin-top:32px;
}
.footer-links-grid{
  display:inline-grid;grid-template-columns:max-content max-content;
  column-gap:28px;row-gap:9px;justify-items:center;
}
.footer-link-span{grid-column:span 2;}
.footer-link{font-size:.7rem;color:var(--sub);text-decoration:none;letter-spacing:.03em;}
.footer-link:hover{color:var(--gold-l);}

/* ── LANGUAGE SWITCHER ── */
.lang-switcher{display:flex;gap:8px;justify-content:center;margin-top:14px;flex-wrap:wrap;}
.lang-btn{background:var(--s2);border:1.5px solid var(--b2);color:var(--text);padding:7px 18px;border-radius:99px;font-size:.78rem;font-weight:600;cursor:pointer;letter-spacing:.06em;transition:all .15s;font-family:'Outfit',sans-serif;opacity:.85;}
.lang-btn:hover{border-color:var(--gold-l);color:var(--gold-l);opacity:1;}
.lang-btn.active{background:var(--gold);border-color:var(--gold);color:#fff;opacity:1;box-shadow:0 2px 10px rgba(184,151,58,.35);}
.lang-btn{min-height:44px;}

/* ── TABLET (iPad) ── */
@media(min-width:600px){
  .page{padding:0 32px 80px;}
  .header{padding:40px 0 28px;}
  .cal-day{font-size:1rem;}
}

/* ── SMALL MOBILE (≤380px, z.B. iPhone SE) ── */
@media(max-width:380px){
  .page{padding:0 14px 70px;}
  .header{padding:24px 0 18px;}
  .header-brand{font-size:1.7rem;}
  .step-title{font-size:1.35rem;}
  .cal-day{font-size:.85rem;}
  .cal-day-name{font-size:.62rem;}
  .loc-cards{gap:7px;}
  .loc-card{padding:12px 6px;}
  .loc-label{font-size:.72rem;}
  .shift-time{font-size:1.1rem;}
  .shift-badge{font-size:.68rem;padding:3px 8px;}
  .guest-row{padding:12px 14px;}
  .summary{padding:14px;}
  .sum-val{font-size:.85rem;}
  .btn-primary{font-size:.88rem;padding:15px 16px;}
}
