/* ============================================================
   ZORBLINS — Apply page
   ============================================================ */
.apply{position:relative;max-width:1120px;margin:0 auto;padding:150px 5vw 100px;overflow:visible}
.apply__glow{position:absolute;width:800px;height:800px;left:50%;top:6%;transform:translateX(-50%);background:radial-gradient(circle,rgba(182,255,0,.12),transparent 60%);filter:blur(30px);pointer-events:none;animation:pulseGlow 7s ease-in-out infinite}
.apply__goblin{position:fixed;width:150px;border-radius:16px;opacity:.42;z-index:-1;box-shadow:0 0 0 3px rgba(182,255,0,.22)}
.apply__goblin--1{left:2.5%;top:34%;transform:rotate(-7deg)}
.apply__goblin--2{right:2.5%;bottom:12%;transform:rotate(7deg)}
@media (max-width:1250px){.apply__goblin{display:none}}

.apply__head{text-align:center;margin-bottom:44px;position:relative}
.apply__head p{color:var(--text-dim);max-width:560px;margin:14px auto 0;font-size:1.08rem}
.apply__main[hidden]{display:none}

/* ---- LAYOUT ---- */
.apply__layout{display:grid;grid-template-columns:1fr 330px;gap:26px;align-items:start}
@media (max-width:880px){.apply__layout{grid-template-columns:1fr}}

/* ---- FORM ---- */
.aform{position:relative;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:24px;padding:36px;display:grid;gap:30px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.aform[hidden]{display:none}
@media (max-width:560px){.aform{padding:24px 18px;gap:26px}}
.aform__row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media (max-width:560px){.aform__row{grid-template-columns:1fr}}

/* ---- STEPS ---- */
.step{display:grid;gap:20px}
.step__head{display:flex;align-items:flex-start;gap:14px}
.step__no{flex:none;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-family:var(--font-disp);font-size:1.3rem;color:var(--ink);background:var(--tox);box-shadow:var(--glow)}
.step__head h2{font-family:var(--font-disp);font-weight:400;font-size:1.55rem;letter-spacing:1px;color:#fff;line-height:1.1}
.step__head p{font-size:.9rem;color:var(--text-dim);margin-top:2px}

/* ---- FIELDS ---- */
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--font-body);font-weight:600;font-size:.92rem;color:var(--text);letter-spacing:.3px}
.field label span{color:var(--blood)}
.field input,.field textarea{
  font-family:var(--font-body);font-size:1rem;color:var(--text);
  background:rgba(6,10,2,.6);border:1.5px solid var(--line);border-radius:12px;
  padding:14px 16px;transition:border-color .3s,box-shadow .3s,background .3s;cursor:none;resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{color:#5d7048}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--tox);box-shadow:0 0 0 3px rgba(182,255,0,.13);background:rgba(10,16,4,.85)}
.field.invalid input,.field.invalid textarea{border-color:var(--blood);box-shadow:0 0 0 4px rgba(239,59,59,.12)}
.field__prefix{display:flex;align-items:center;background:rgba(6,10,2,.6);border:1.5px solid var(--line);border-radius:12px;transition:border-color .3s,box-shadow .3s}
.field__prefix:focus-within{border-color:var(--tox);box-shadow:0 0 0 3px rgba(182,255,0,.13)}
.field__prefix span{padding:0 4px 0 16px;color:var(--tox);font-weight:700;font-size:1.05rem}
.field__prefix input{border:none;box-shadow:none!important;background:transparent;flex:1}
.field.invalid .field__prefix{border-color:var(--blood)}
.err{color:var(--blood);font-size:.82rem;opacity:0;transition:opacity .25s;font-weight:500}
.field.invalid .err,.mission.invalid .err{opacity:1}
.hint{color:var(--text-dim);font-size:.84rem;opacity:.85}

/* ---- MISSIONS ---- */
.missions{list-style:none;display:grid;gap:14px}
.mission{position:relative;display:flex;align-items:center;gap:16px;padding:18px;border:1.5px solid var(--line);border-radius:16px;background:rgba(6,10,2,.5);transition:border-color .3s var(--ease),transform .3s var(--ease),box-shadow .3s,background .3s}
.mission--col{flex-direction:column;align-items:stretch}
.mission:hover{border-color:rgba(182,255,0,.4);transform:translateY(-2px)}
.mission.invalid{border-color:var(--blood);box-shadow:0 0 0 4px rgba(239,59,59,.1)}
.mission.is-done{border-color:rgba(182,255,0,.55);background:rgba(182,255,0,.045)}
.mission__check{position:absolute;top:-11px;right:-9px;width:28px;height:28px;border-radius:50%;background:var(--tox);color:var(--ink);display:grid;place-items:center;font-size:.9rem;font-weight:800;box-shadow:var(--glow);transform:scale(0) rotate(-30deg);transition:transform .35s var(--ease);z-index:3}
.mission.is-done .mission__check{transform:scale(1) rotate(0)}
.mission__top{display:flex;align-items:center;gap:16px}
.mission__icon{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:1.4rem;background:rgba(182,255,0,.08);border:1px solid var(--line);transition:.3s}
.mission.is-done .mission__icon{background:rgba(182,255,0,.16);border-color:var(--tox)}
.mission__body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.mission__body b{font-family:var(--font-body);font-weight:700;font-size:1.02rem;color:var(--text)}
.mission__body span{font-size:.85rem;color:var(--text-dim)}
.mission__go{flex:none;font-family:var(--font-disp);letter-spacing:1px;font-size:.85rem;color:var(--tox);border:1px solid var(--line);border-radius:9px;padding:9px 15px;background:rgba(182,255,0,.05);transition:.25s;cursor:none;white-space:nowrap}
.mission__go:hover{background:var(--tox);color:var(--ink);border-color:var(--tox);box-shadow:var(--glow);transform:translateY(-1px)}
.mission__inputs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:520px){.mission__inputs{grid-template-columns:1fr}}
.qt-field{display:flex;flex-direction:column;gap:8px}
.qt-field input{width:100%;font-family:var(--font-body);font-size:.98rem;color:var(--text);background:rgba(6,10,2,.6);border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;transition:border-color .3s,box-shadow .3s;cursor:none}
.qt-field input:focus{outline:none;border-color:var(--tox);box-shadow:0 0 0 3px rgba(182,255,0,.13)}
.mission.invalid .qt-field input{border-color:var(--blood)}
.mission.is-done .qt-field input{border-color:var(--tox)}

/* custom toggle for like+rt */
.tick-toggle{flex:none;cursor:none}
.tick-toggle input{position:absolute;opacity:0;width:0;height:0}
.tick-toggle__box{display:grid;place-items:center;width:32px;height:32px;border:1.5px solid var(--line);border-radius:10px;background:rgba(6,10,2,.6);transition:.25s}
.tick-toggle__box::after{content:"";width:7px;height:13px;border:solid var(--ink);border-width:0 3px 3px 0;transform:rotate(45deg) scale(0);transition:transform .25s var(--ease);margin-top:-2px}
.tick-toggle input:checked+.tick-toggle__box{background:var(--tox);border-color:var(--tox);box-shadow:var(--glow)}
.tick-toggle input:checked+.tick-toggle__box::after{transform:rotate(45deg) scale(1)}

/* ---- CHECKBOX ---- */
.check{display:flex;align-items:flex-start;gap:13px;cursor:none;font-size:.92rem;color:var(--text-dim);line-height:1.5}
.check input{position:absolute;opacity:0;width:0;height:0}
.check__box{flex:none;width:24px;height:24px;border:1.5px solid var(--line);border-radius:7px;background:rgba(6,10,2,.6);position:relative;transition:.25s;margin-top:1px}
.check input:checked+.check__box{background:var(--tox);border-color:var(--tox);box-shadow:var(--glow)}
.check__box::after{content:"";position:absolute;left:8px;top:3px;width:6px;height:12px;border:solid var(--ink);border-width:0 3px 3px 0;transform:rotate(45deg) scale(0);transition:transform .25s var(--ease)}
.check input:checked+.check__box::after{transform:rotate(45deg) scale(1)}
.check a{color:var(--tox);text-decoration:underline}
.check.invalid .check__box{border-color:var(--blood);box-shadow:0 0 0 4px rgba(239,59,59,.12)}

/* ---- FORM ERROR ---- */
.aform__error{background:rgba(239,59,59,.1);border:1.5px solid rgba(239,59,59,.5);color:#ff9b9b;border-radius:12px;padding:13px 16px;font-size:.92rem;font-weight:500;text-align:center}
.aform__error[hidden]{display:none}

/* ---- SUBMIT ---- */
.aform__submit{width:100%;margin-top:4px}
.aform__submit.loading{pointer-events:none;opacity:.85}
.aform__submit.loading .aform__submit-txt{visibility:hidden}
.aform__submit.loading::before{content:"";position:absolute;width:24px;height:24px;border:3px solid rgba(6,10,2,.3);border-top-color:var(--ink);border-radius:50%;animation:spin .7s linear infinite}

/* ---- ASIDE / PASS CARD ---- */
.apply__aside{position:sticky;top:96px}
@media (max-width:880px){.apply__aside{position:static}}
.aside__card{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1.5px solid var(--line);border-radius:22px;padding:20px;display:grid;gap:18px;box-shadow:0 22px 60px rgba(0,0,0,.45)}
.aside__art{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.aside__art img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.aside__pass{position:absolute;bottom:10px;left:10px;font-family:var(--font-disp);letter-spacing:1px;font-size:.82rem;color:var(--tox);background:rgba(6,10,2,.82);border:1px solid var(--line);padding:6px 12px;border-radius:9px;backdrop-filter:blur(4px)}

.aside__prog-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.aside__prog-top span{font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}
.aside__prog-top b{font-family:var(--font-disp);color:var(--tox);font-size:1.25rem}
.aside__bar{height:10px;background:rgba(182,255,0,.1);border-radius:20px;overflow:hidden;border:1px solid var(--line)}
.aside__bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--tox-deep),var(--tox-soft));transition:width .55s var(--ease);border-radius:20px}

.aside__list{list-style:none;display:grid;gap:4px}
.aside__list li{display:flex;align-items:center;gap:11px;padding:9px 0;color:var(--text-dim);font-size:.92rem;font-weight:500;transition:color .3s;border-bottom:1px dashed var(--line-soft)}
.aside__list li:last-child{border-bottom:none}
.aside__list li i{flex:none;width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);position:relative;transition:.3s}
.aside__list li.is-done{color:var(--text)}
.aside__list li.is-done i{background:var(--tox);border-color:var(--tox)}
.aside__list li.is-done i::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid var(--ink);border-width:0 2px 2px 0;transform:rotate(45deg)}

.aside__stats{display:flex;justify-content:space-between;gap:8px;text-align:center;padding-top:16px;border-top:1px solid var(--line-soft)}
.aside__stats b{display:block;font-family:var(--font-disp);color:var(--tox);font-size:1.4rem;letter-spacing:1px;line-height:1}
.aside__stats span{font-size:.7rem;letter-spacing:1px;color:var(--text-dim);text-transform:uppercase}
.aside__note{font-size:.8rem;color:var(--text-dim);text-align:center;opacity:.85;line-height:1.5}

/* ---- SUCCESS ---- */
.success{position:relative;padding:30px 5vw 40px;text-align:center;animation:fadeUp .6s var(--ease)}
.success__card{position:relative;max-width:580px;margin:0 auto;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1.5px solid rgba(182,255,0,.38);border-radius:26px;padding:54px 40px 40px;box-shadow:0 30px 80px rgba(0,0,0,.5);overflow:hidden}
.success__spore{position:absolute;color:var(--tox);opacity:.5;pointer-events:none;filter:drop-shadow(0 0 10px rgba(182,255,0,.6))}
.success__spore--1{top:18px;left:24px;font-size:1.4rem;animation:floaty 5s ease-in-out infinite}
.success__spore--2{top:40px;right:30px;font-size:1.1rem;color:var(--brain);animation:floaty 6.5s ease-in-out infinite}
.success__spore--3{bottom:24px;left:36px;font-size:1.2rem;animation:floaty 7s ease-in-out infinite}
.success__emoji{font-size:4.5rem;animation:bob 2.4s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(182,255,0,.7))}
.success__card h2{font-family:var(--font-disp);font-weight:400;font-size:2.6rem;letter-spacing:1px;color:#fff;margin:12px 0 12px}
.success__card p{color:var(--text-dim);font-size:1.05rem;margin-bottom:26px;max-width:440px;margin-left:auto;margin-right:auto}
.success__card a{color:var(--tox)}
.success__ref{text-align:left;background:rgba(6,10,2,.6);border:1px solid var(--line);border-radius:14px;padding:6px 18px;margin:0 auto 28px;max-width:420px}
.success__ref-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 0;border-bottom:1px dashed var(--line-soft)}
.success__ref-row:last-child{border-bottom:none}
.success__ref-row span{font-size:.78rem;letter-spacing:1.5px;color:var(--text-dim)}
.success__ref-row b{font-family:var(--font-disp);letter-spacing:.5px;color:var(--tox);font-size:1.05rem;word-break:break-all;text-align:right}
.success__status{color:#ffd84d!important}
.success__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.success__cta a{color:inherit}
.success__home{display:inline-block;margin-top:20px;color:var(--text-dim)!important;font-size:.9rem;font-weight:500;transition:color .25s;cursor:none}
.success__home:hover{color:var(--tox)!important}

/* shake animation for invalid submit */
@keyframes shake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-7px)}40%,60%{transform:translateX(7px)}}
.aform.shake{animation:shake .5s}
