*{box-sizing:border-box}
:root{
  --pink:#c83f73;
  --pink-dark:#9f2758;
  --ink:#633247;
  --muted:#8d6375;
  --white:rgba(255,255,255,.78);
  --line:rgba(200,63,115,.16);
  --shadow:0 30px 90px rgba(155,39,88,.20);
  --radius:30px;
}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 12% 18%, rgba(255,170,205,.75), transparent 28%),
    radial-gradient(circle at 88% 10%, rgba(255,222,236,.95), transparent 26%),
    radial-gradient(circle at 70% 92%, rgba(255,197,219,.55), transparent 30%),
    linear-gradient(135deg,#fff 0%,#fff7fa 48%,#f9edf3 100%);
  overflow:hidden;
  -webkit-tap-highlight-color:transparent;
}
button,input{font:inherit}
button{touch-action:manipulation}
.bg-orbs span{
  position:fixed;width:36vmin;height:36vmin;border-radius:50%;
  filter:blur(34px);opacity:.35;pointer-events:none;
  animation:drift 9s ease-in-out infinite alternate;
}
.bg-orbs span:nth-child(1){left:-10vmin;top:15vmin;background:#ff9cc4}
.bg-orbs span:nth-child(2){right:-8vmin;top:10vmin;background:#ffd1df;animation-delay:-3s}
.bg-orbs span:nth-child(3){left:55%;bottom:-12vmin;background:#f3b0cc;animation-delay:-6s}
.app{position:relative;width:100vw;height:100dvh;display:grid;place-items:center;padding:24px}
.screen{
  position:absolute;inset:0;display:grid;place-items:center;
  padding:82px 24px 34px;opacity:0;transform:translateY(16px) scale(.985);
  pointer-events:none;transition:opacity .42s ease, transform .42s ease;
  overflow:auto;
}
.screen.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
h1,h2{
  font-family:"Playfair Display",Georgia,serif;color:var(--pink);
  text-align:center;margin:8px 0 20px;line-height:1.02;letter-spacing:-.035em;
  text-shadow:0 2px 0 rgba(255,255,255,.85);
}
h1{font-size:clamp(44px,8vw,86px)}
h2{font-size:clamp(34px,5.7vw,62px)}
p{margin:8px 0;text-align:center}
.sub{color:var(--muted);font-size:14px}
.eyebrow{
  color:var(--pink-dark);text-transform:uppercase;letter-spacing:.18em;
  font-size:12px;font-weight:900;margin-bottom:4px;
}
.progress{
  position:fixed;top:22px;left:50%;transform:translateX(-50%);
  z-index:40;display:flex;align-items:center;gap:10px;
  padding:10px 14px;border:1px solid var(--line);
  background:rgba(255,255,255,.48);backdrop-filter:blur(14px);
  border-radius:999px;box-shadow:0 15px 45px rgba(155,39,88,.10);
}
.progress span{filter:grayscale(1);opacity:.45;transform:scale(.92);transition:.2s}
.progress span.on{filter:none;opacity:1;transform:scale(1.1)}
.progress i{display:block;width:30px;height:2px;background:#e7b8ca;border-radius:99px}
.btn{
  border:0;border-radius:999px;padding:16px 28px;color:white;background:#333;
  font-weight:900;cursor:pointer;box-shadow:0 16px 34px rgba(200,63,115,.24);
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 20px 44px rgba(200,63,115,.30)}
.btn:active{transform:translateY(0) scale(.98)}
.btn:disabled{opacity:.43;cursor:not-allowed;transform:none}
.primary{background:linear-gradient(135deg,var(--pink-dark),#e26e9f)}
.ghost{background:#eadfe5;color:#6f5360;box-shadow:0 10px 25px rgba(80,40,60,.08)}
.big{font-size:16px;padding:18px 34px}
.wide{width:100%;margin-top:18px}
.hidden{opacity:0;pointer-events:none}
.hidden.ready{opacity:1;pointer-events:auto}
.intro-card,.glass-card{
  width:min(720px,92vw);background:var(--white);
  border:1px solid rgba(255,255,255,.85);backdrop-filter:blur(18px);
  border-radius:var(--radius);padding:38px;box-shadow:var(--shadow);
}
.loader-line{display:flex;justify-content:space-between;align-items:center;gap:18px;font-weight:900;color:var(--pink-dark)}
.loader-line em{font-style:normal;color:var(--muted)}
.bar{height:15px;background:#f3d7e3;border-radius:999px;overflow:hidden;margin:18px 0 26px}
.bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,#c83f73,#ff95bd);border-radius:inherit;transition:width .1s linear}
.mail-wrap{position:relative;height:118px;display:grid;place-items:center}
.mail{font-size:86px;filter:drop-shadow(0 20px 22px rgba(155,39,88,.20));animation:float 2.5s ease-in-out infinite}
.spark{position:absolute;font-size:22px;animation:twinkle 1.8s ease-in-out infinite}
.s1{left:calc(50% - 88px);top:30px}.s2{right:calc(50% - 98px);top:22px;animation-delay:-.6s}.s3{right:calc(50% - 65px);bottom:16px;animation-delay:-1s}
.ask-row{display:flex;gap:14px;align-items:center;justify-content:center;min-height:72px}
.no-btn{position:relative;z-index:45}
.no-btn.runaway-active{position:fixed}
.hint{font-size:12px;color:#9f7586;margin-top:18px}
.party{font-size:92px;animation:pop .5s ease both}
.panic-box{
  margin:22px auto 26px;padding:13px 18px;width:max-content;max-width:90vw;
  border-radius:999px;background:rgba(255,255,255,.62);border:1px solid var(--line);
  box-shadow:0 14px 34px rgba(155,39,88,.10);
}
.panic-box span{color:var(--muted);font-size:13px;margin-right:8px}
.panic-box b{color:var(--pink-dark)}
.label{display:block;margin:18px 0 10px;color:var(--ink);font-weight:900;font-size:13px}
.pill-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.pill-grid button,.choice-grid button{
  border:1px solid rgba(200,63,115,.14);background:rgba(255,255,255,.58);
  color:var(--ink);border-radius:18px;cursor:pointer;transition:.18s ease;
}
.pill-grid button{padding:14px 10px;font-weight:900}
.pill-grid button.selected,.choice-grid button.selected{
  background:#fff5f9;border-color:rgba(200,63,115,.55);
  box-shadow:0 16px 34px rgba(200,63,115,.16);transform:translateY(-3px);
}
.custom-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
input{
  width:100%;padding:14px 15px;border:1px solid rgba(200,63,115,.18);
  background:rgba(255,255,255,.68);border-radius:16px;outline:none;color:var(--ink);
}
input:focus{border-color:rgba(200,63,115,.72);box-shadow:0 0 0 4px rgba(200,63,115,.10)}
.choice-grid{
  width:min(980px,94vw);display:grid;grid-template-columns:repeat(4,1fr);
  gap:14px;margin:12px auto 92px;
}
.choice-grid button{
  min-height:132px;padding:16px 10px;display:grid;place-items:center;
  box-shadow:0 18px 50px rgba(155,39,88,.08);
}
.choice-grid span{font-size:40px}
.choice-grid b{font-size:15px}
.choice-grid small{color:var(--muted);font-weight:700;text-align:center}
.bottom-btn{
  position:fixed;left:50%;bottom:26px;transform:translateX(-50%);
  width:min(390px,86vw);z-index:55;
}
.bottom-btn:hover{transform:translateX(-50%) translateY(-2px)}
.bottom-btn:active{transform:translateX(-50%) scale(.98)}
.ticket-wrap{display:grid;gap:18px;place-items:center;width:min(760px,94vw)}
.ticket{
  width:100%;background:linear-gradient(180deg,#fff,#fff7fa);border-radius:30px;
  box-shadow:var(--shadow);overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.9);
}
.ticket:before,.ticket:after{
  content:"";position:absolute;top:105px;width:34px;height:34px;border-radius:50%;background:#fff4f8;z-index:2;
}
.ticket:before{left:-17px}.ticket:after{right:-17px}
.ticket-top,.ticket-bottom{
  display:flex;justify-content:space-between;gap:16px;padding:18px 24px;
  background:rgba(200,63,115,.09);color:var(--pink-dark);
  font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;
}
.ticket-main{padding:34px 28px 28px;text-align:center;position:relative}
.polaroid{
  position:absolute;right:22px;top:-12px;width:76px;height:92px;background:#f4fbfb;
  border:8px solid white;box-shadow:0 12px 28px rgba(0,0,0,.12);
  transform:rotate(4deg);display:grid;place-items:center;color:var(--pink);font-size:48px;
}
.note{font-size:12px;font-style:italic;color:var(--muted)}
.ticket-info{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px;text-align:left}
.ticket-info div{border:1px dashed rgba(200,63,115,.24);border-radius:18px;padding:15px;background:rgba(255,255,255,.62)}
.ticket-info small{display:block;color:var(--muted);font-weight:900;font-size:11px;margin-bottom:6px}
.ticket-info strong{display:block;color:var(--pink-dark);line-height:1.25}
.ticket-bottom .code{color:var(--pink)}
.final-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.toast{
  position:fixed;left:50%;bottom:22px;transform:translate(-50%,20px);
  background:#78304c;color:white;padding:14px 18px;border-radius:999px;
  opacity:0;z-index:100;box-shadow:0 16px 40px rgba(80,30,50,.2);transition:.25s ease;
}
.toast.show{opacity:1;transform:translate(-50%,0)}
.confetti,.mini-heart{position:fixed;top:-20px;z-index:90;pointer-events:none;animation:fall 1.8s linear forwards}
.mini-heart{top:auto;animation:rise 1.3s ease-out forwards}
.shake{animation:shake .36s ease}
@keyframes drift{to{transform:translate(4vmin,3vmin) scale(1.07)}}
@keyframes float{50%{transform:translateY(-10px) rotate(-2deg)}}
@keyframes twinkle{50%{transform:scale(1.3) rotate(12deg);opacity:.55}}
@keyframes pop{0%{transform:scale(.3);opacity:0}70%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
@keyframes fall{to{transform:translateY(110vh) rotate(520deg);opacity:0}}
@keyframes rise{to{transform:translateY(-95px) scale(1.8);opacity:0}}
@keyframes shake{20%{transform:translateX(-8px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(4px)}}
@media(max-width:900px){.choice-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){
  .app{padding:16px}.screen{padding:84px 16px 28px}.progress{top:14px;gap:8px;padding:9px 10px}.progress i{width:18px}
  h1{font-size:clamp(42px,13vw,64px)}h2{font-size:clamp(34px,10vw,52px)}
  .intro-card,.glass-card{padding:26px 18px;border-radius:24px}.ask-row{flex-direction:column}.no-btn.runaway-active{left:55%;top:64%}
  .pill-grid{grid-template-columns:repeat(2,1fr)}.choice-grid{grid-template-columns:repeat(2,1fr);gap:11px;margin-bottom:18px}
  .choice-grid button{min-height:124px}.custom-row{grid-template-columns:1fr}
  .bottom-btn{position:sticky;left:auto;bottom:14px;transform:none;width:min(390px,92vw);margin:10px auto 0;display:block}
  .bottom-btn:hover{transform:translateY(-2px)}
  .bottom-btn:active{transform:scale(.98)}
  .ticket-top,.ticket-bottom{font-size:10px;padding:15px 18px}.ticket-main{padding:34px 18px 22px}
  .polaroid{width:58px;height:72px;font-size:34px;right:12px}.ticket-info{grid-template-columns:1fr}
}


@media(max-width:380px){
  .choice-grid{
    grid-template-columns:1fr;
  }

  .choice-grid button{
    min-height:108px;
  }

  .bottom-btn{
    width:94vw;
  }
}


/* ===== FIX v2: mobile food screen button ===== */
/* Na ekranie wyboru jedzenia układ ma być normalną kolumną, zwłaszcza na telefonie. */
#food.screen{
  align-content:start;
}

/* Na telefonie przycisk "robimy bilet" jest normalnie pod kafelkami i jest klikalny. */
@media(max-width:760px){
  #food.screen{
    display:block;
    padding-top:84px;
    padding-bottom:28px;
  }

  #food .eyebrow,
  #food h2,
  #food .sub{
    width:100%;
  }

  #food .choice-grid{
    width:100%;
    margin:12px auto 18px;
  }

  #food .bottom-btn{
    position:relative !important;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    top:auto !important;
    transform:none !important;
    width:min(390px,92vw);
    margin:18px auto 8px;
    display:block;
    z-index:2;
  }

  #food .bottom-btn:hover{
    transform:none !important;
  }

  #food .bottom-btn:active{
    transform:scale(.98) !important;
  }
}


/* ===== FIX v3: przycisk "Nie" pod "Tak" + tekst mieści się w latającym buttonie ===== */
.ask-row{
  flex-direction:column;
  gap:12px;
}

.no-btn{
  position:relative;
  z-index:45;
  min-width:190px;
  max-width:88vw;
  width:auto;
  white-space:nowrap;
  text-align:center;
  padding-left:24px;
  padding-right:24px;
}

.no-btn.runaway-active{
  position:fixed;
  width:auto !important;
  min-width:190px;
  max-width:calc(100vw - 28px);
  white-space:nowrap;
}


/* ===== FIX v4: jedzenie tylko jedna opcja + przycisk zawsze klikalny ===== */
#food.screen{
  align-content:start;
}

#food .bottom-btn{
  pointer-events:auto;
}

@media(max-width:760px){
  #food.screen{
    display:block;
    padding-top:84px;
    padding-bottom:34px;
  }

  #food .choice-grid{
    width:100%;
    margin:12px auto 18px !important;
  }

  #food .bottom-btn{
    position:relative !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    bottom:auto !important;
    transform:none !important;
    width:min(390px,92vw) !important;
    min-height:56px;
    margin:18px auto 10px !important;
    display:block;
    z-index:20;
  }

  #food .bottom-btn:hover{
    transform:none !important;
  }

  #food .bottom-btn:active{
    transform:scale(.98) !important;
  }
}


/* ===== TOKEN VERSION MOBILE FIXES ===== */
.ask-row{
  flex-direction:column;
  gap:12px;
}

.no-btn{
  position:relative;
  z-index:45;
  min-width:190px;
  max-width:88vw;
  width:auto;
  white-space:nowrap;
  text-align:center;
  padding-left:24px;
  padding-right:24px;
}

.no-btn.runaway-active{
  position:fixed;
  width:auto !important;
  min-width:190px;
  max-width:calc(100vw - 28px);
  white-space:nowrap;
}

#food.screen{
  align-content:start;
}

#food .bottom-btn{
  pointer-events:auto;
}

.admin-card{
  width:min(560px,92vw);
  background:var(--white);
  border:1px solid rgba(255,255,255,.85);
  backdrop-filter:blur(18px);
  border-radius:var(--radius);
  padding:34px;
  box-shadow:var(--shadow);
}

.admin-card h1{
  font-size:clamp(34px,6vw,56px);
  margin-bottom:10px;
}

.admin-card p{
  color:var(--muted);
  line-height:1.5;
}

.admin-card label{
  display:block;
  margin:16px 0 8px;
  color:var(--ink);
  font-weight:900;
  font-size:13px;
}

.admin-card input{
  width:100%;
  padding:15px 16px;
  border:1px solid rgba(200,63,115,.18);
  background:rgba(255,255,255,.75);
  border-radius:16px;
  outline:none;
  color:var(--ink);
}

.admin-card input:focus{
  border-color:rgba(200,63,115,.72);
  box-shadow:0 0 0 4px rgba(200,63,115,.10);
}

.admin-message{
  margin-top:16px;
  padding:12px 14px;
  border-radius:16px;
  text-align:left;
}

.admin-message.ok{
  background:#f0fff3;
  color:#17602a;
}

.admin-message.err{
  background:#fff0f3;
  color:#8a1733;
}

.generated-link{
  margin-top:18px;
  padding:14px;
  border-radius:16px;
  background:rgba(255,255,255,.72);
  border:1px dashed rgba(200,63,115,.25);
  overflow-wrap:anywhere;
  font-weight:800;
  color:var(--pink-dark);
}

@media(max-width:760px){
  #food.screen{
    display:block;
    padding-top:84px;
    padding-bottom:34px;
  }

  #food .choice-grid{
    width:100%;
    margin:12px auto 18px !important;
  }

  #food .bottom-btn{
    position:relative !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    bottom:auto !important;
    transform:none !important;
    width:min(390px,92vw) !important;
    min-height:56px;
    margin:18px auto 10px !important;
    display:block;
    z-index:20;
  }

  #food .bottom-btn:hover{
    transform:none !important;
  }

  #food .bottom-btn:active{
    transform:scale(.98) !important;
  }
}

@media(max-width:380px){
  .choice-grid{
    grid-template-columns:1fr !important;
  }

  .choice-grid button{
    min-height:108px;
  }

  .bottom-btn{
    width:94vw !important;
  }
}


/* ===== LANG VERSION ADMIN SELECT ===== */
.admin-select{
  width:100%;
  padding:15px 16px;
  border:1px solid rgba(200,63,115,.18);
  background:rgba(255,255,255,.75);
  border-radius:16px;
  outline:none;
  color:var(--ink);
  font:inherit;
}

.admin-select:focus{
  border-color:rgba(200,63,115,.72);
  box-shadow:0 0 0 4px rgba(200,63,115,.10);
}

/* ===== TARGET SELECT ===== */
.target-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:8px 0 14px;
}
.target-option{
  margin:0 !important;
  cursor:pointer;
}
.target-option input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.target-option span{
  display:block;
  padding:14px 12px;
  border-radius:16px;
  text-align:center;
  font-weight:900;
  border:1px solid rgba(200,63,115,.18);
  background:rgba(255,255,255,.70);
  color:var(--ink);
  transition:.18s ease;
}
.target-option input:checked + span{
  background:#fff5f9;
  border-color:rgba(200,63,115,.55);
  box-shadow:0 14px 28px rgba(200,63,115,.13);
  transform:translateY(-1px);
}
@media(max-width:420px){
  .target-row{grid-template-columns:1fr}
}
