@import "https://fonts.googleapis.com/css2?family=Kanit:wght@300;400;500;600;700&family=Sarabun:wght@300;400;500;600&display=swap";:root{--blue:#398df4;--blue-d:#1a6fd4;--blue-l:#e8f3fe;--blue-m:#c2ddfb;--blue-p:#f0f7ff;--text:#1a2540;--muted:#6b85a8;--border:#d4e5f9;--success:#14b87a;--warn:#f59e0b;--danger:#e8453c;--r:14px;--sh:0 2px 20px #398df41a;--sh2:0 8px 32px #398df42e;--glass:#ffffffb3;--glass-border:#ffffff80}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--blue-p);color:var(--text);min-height:100vh;font-family:IBM Plex Sans Thai,sans-serif;overflow-x:hidden}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes float-slow{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-18px)rotate(3deg)}}@keyframes float-reverse{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(12px)rotate(-2deg)}}@keyframes fly-left{0%{transform:translate(-50%)}to{transform:translate(0)}}@keyframes animStar{0%{transform:translateY(0)}to{transform:translateY(-2000px)}}header.navbar-container{z-index:9000;pointer-events:none;flex-direction:column;align-items:center;width:100%;display:flex;position:fixed;top:0;left:0}nav.navbar{pointer-events:auto;-webkit-backdrop-filter:blur(8px);background:#0000001a;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;width:100%;padding:12px 24px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex}nav.navbar.scrolled{background:#00000040;border:1px solid #fff3;border-radius:9999px;width:90%;margin-top:16px;box-shadow:0 8px 32px #0003}.nav-logo img{width:auto;height:32px}@media (width>=768px){.nav-logo img{height:40px}nav.navbar{padding:16px 40px}}.hero{color:#fff;text-align:center;background:linear-gradient(140deg,#4ae3e9 0%,#398df4 44% 100%);flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:120px 20px 60px;display:flex;position:relative;overflow:hidden}.hero-content{z-index:100;flex-direction:column;align-items:center;max-width:1200px;display:flex;position:relative}.hero-presented{align-items:center;gap:16px;margin-bottom:8px;display:flex}.hero-presented img{opacity:.9;height:24px}.hero-presented .divider{background:#fff3;width:1px;height:24px}.hero-subtitle{color:#ffffffe6;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;font-family:Kanit,sans-serif;font-size:14px}.hero-logo-group{justify-content:center;align-items:flex-end;gap:0;margin-bottom:0;display:flex;transform:scale(.75)}@media (width>=768px){.hero-logo-group{margin-bottom:10px;transform:scale(.9)}.hero-presented img,.hero-presented .divider{height:28px}}.j-logo{width:150px;height:auto;margin-right:-48px}.hero-title{text-transform:uppercase;text-align:right;flex-direction:column;font-family:Kanit,sans-serif;font-weight:900;line-height:.85;display:flex}.hero-title .junior{font-size:40px;font-weight:900}.hero-title .webmaster{font-size:24px;font-weight:500}.hero-title .camp{font-size:30px;font-weight:900}.stamp-14{width:150px;height:auto;margin-bottom:-12px;margin-left:8px;transition:transform .3s}.stamp-14:hover{transform:rotate(-3deg)}.hero-tagline{color:#fff;text-shadow:0 2px 10px #0000001a;margin:20px 0;font-family:Kanit,sans-serif;font-size:24px;font-weight:400}.hero-cta{color:var(--blue);z-index:200;background:#fff;border:2px solid #0000;border-radius:9999px;padding:14px 44px;font-family:Kanit,sans-serif;font-size:18px;font-weight:700;text-decoration:none;transition:all .3s;box-shadow:0 4px 20px #00000026}.hero-cta:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 10px 25px #0003}.deco-asset{pointer-events:none;z-index:5;position:absolute}.hashtag{width:80px;animation:4s ease-in-out infinite float;bottom:32%;right:32%}.slash{opacity:.8;width:180px;animation:5s ease-in-out infinite float-slow;top:20%;right:24%}.curly{opacity:.8;width:160px;animation:4.5s ease-in-out infinite float-reverse;top:28%;left:22%}.clouds-container{z-index:50;pointer-events:none;gap:0;width:200%;animation:40s linear infinite fly-left;display:flex;position:absolute;bottom:-80px;left:0}.long-cloud{width:100%;max-height:35vh;animation:10s ease-in-out infinite float-reverse}.cloud-bottom{z-index:40;opacity:1;width:55%;position:absolute;bottom:-10px}.cloud-left{left:-5%}.cloud-right{right:-5%;transform:scaleX(-1)}.cloud-small{z-index:60;width:400px;bottom:-40px;right:-120px}.hero-boy{z-index:30;filter:drop-shadow(0 10px 30px #0000001a);width:500px;max-width:85vw;animation:4s ease-in-out infinite float-reverse;position:absolute;bottom:2vh;right:-2%}@media (width<=768px){.hero{min-height:65vh;padding-top:100px}.deco-asset{display:none}.hero-boy{width:280px;bottom:1vh;right:-8%}.hero-logo-group{transform:scale(.65)}}.stars-container{pointer-events:none;z-index:1;position:absolute;inset:0;overflow:hidden}.stars-small,.stars-medium,.stars-big{background:0 0;border-radius:50%;position:absolute;top:0;left:0}.stars-small{width:1px;height:1px;animation:50s linear infinite animStar}.stars-medium{width:2px;height:2px;animation:100s linear infinite animStar}.stars-big{width:3px;height:3px;animation:150s linear infinite animStar}.hero-waves{z-index:2;pointer-events:none;position:absolute;bottom:-1px;left:0;right:0}.lock{z-index:400;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f0f7fff5;flex-direction:column;justify-content:center;align-items:center;gap:14px;transition:opacity .35s;display:flex;position:fixed;inset:0}.lock.hide{opacity:0;pointer-events:none}.lock-ring{border:4px solid var(--blue-m);border-top-color:var(--blue);border-radius:50%;width:54px;height:54px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.lock-title{color:var(--blue);font-family:Kanit,sans-serif;font-size:16px;font-weight:600}.lock-sub{color:var(--muted);text-align:center;max-width:280px;font-size:12px;line-height:1.7}.page{display:none}.page.active{animation:.4s ease-out fadeIn;display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.wrap{max-width:780px;margin:0 auto;padding-bottom:3rem}.login-card{background:var(--glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--sh2);text-align:center;z-index:5;border-radius:20px;margin:-3rem 1.5rem 2rem;padding:3rem 2rem;position:relative}.login-icon{background:linear-gradient(135deg, var(--blue-l), var(--blue-m));border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.25rem;font-size:32px;display:flex;box-shadow:inset 0 2px 4px #fffc}.login-card h2{color:var(--text);margin-bottom:8px;font-family:Kanit,sans-serif;font-size:24px;font-weight:600}.login-card p{color:var(--muted);margin-bottom:2rem;font-size:14px;line-height:1.7}.google-btn{border:1.5px solid var(--border);color:var(--text);cursor:pointer;background:#fff;border-radius:14px;align-items:center;gap:12px;padding:14px 28px;font-family:Sarabun,sans-serif;font-size:15px;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 12px #0000000d}.google-btn:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 8px 24px #398df433}.google-btn svg{flex-shrink:0;width:20px;height:20px}.step-header{align-items:center;gap:12px;padding:1.75rem 1.75rem .5rem;display:flex}.user-pill{border:1px solid var(--border);color:var(--muted);box-shadow:var(--sh);background:#fff;border-radius:20px;align-items:center;gap:8px;padding:5px 14px 5px 6px;font-size:12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--blue), #7dc0ff);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-family:Kanit,sans-serif;font-size:11px;font-weight:600;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.step-back{cursor:pointer;color:var(--muted);background:0 0;border:none;align-items:center;gap:4px;margin-left:auto;font-family:Sarabun,sans-serif;font-size:13px;transition:color .15s;display:flex}.step-back:hover{color:var(--blue)}.branch-grid{grid-template-columns:repeat(2,1fr);gap:16px;padding:1.5rem;display:grid}.branch-card{border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;box-shadow:var(--sh);text-align:left;background:#fff;padding:1.75rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.branch-card:before{content:"";border-radius:var(--r) var(--r) 0 0;background:var(--bc,var(--blue));height:5px;position:absolute;top:0;left:0;right:0}.branch-card:hover{border-color:var(--bc,var(--blue));box-shadow:var(--sh2);transform:translateY(-5px)}.branch-card.selected{border-color:var(--bc,var(--blue));background:var(--blue-p);box-shadow:0 0 0 3px #398df426, var(--sh2)}.branch-icon{margin-bottom:12px;font-size:32px;display:block}.branch-name{color:var(--text);margin-bottom:4px;font-family:Kanit,sans-serif;font-size:19px;font-weight:600}.branch-desc{color:var(--muted);font-size:12px;line-height:1.5}.branch-seats{background:var(--blue-l);color:var(--blue);border-radius:8px;align-items:center;gap:5px;margin-top:12px;padding:4px 10px;font-family:Kanit,sans-serif;font-size:11px;font-weight:600;display:inline-flex}.confirm-branch-btn{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:calc(100% - 3rem);margin:0 1.5rem 1.75rem;padding:15px;font-family:Sarabun,sans-serif;font-size:16px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 14px #398df459}.confirm-branch-btn:hover:not(:disabled){background:var(--blue-d);transform:translateY(-2px);box-shadow:0 8px 24px #398df473}.confirm-branch-btn:disabled{background:var(--blue-m);box-shadow:none;cursor:not-allowed;opacity:.7}.status-bar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#fff;justify-content:space-between;align-items:center;padding:.75rem 1.75rem;display:flex}.status-left{color:var(--muted);align-items:center;gap:8px;font-size:13px;display:flex}.sdot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sdot.ok{background:var(--success);animation:3s infinite pulse}.sdot.syncing{background:var(--warn);animation:1s infinite pulse}.sdot.err{background:var(--danger)}.sync-btn{border:1.5px solid var(--blue-m);color:var(--blue);cursor:pointer;background:0 0;border-radius:10px;padding:6px 16px;font-family:Sarabun,sans-serif;font-size:13px;font-weight:600;transition:all .2s}.sync-btn:hover{background:var(--blue-l);border-color:var(--blue)}.sync-btn:disabled{opacity:.35;pointer-events:none}.stat-strip{border-bottom:1px solid var(--border);background:#fff;display:flex}.stat-chip{border-right:1px solid var(--border);flex:1;align-items:center;gap:12px;padding:1rem 1.5rem;display:flex}.stat-chip:last-child{border-right:none}.chip-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;display:flex}.ci-open{color:var(--success);background:#e8f8f1}.ci-full{color:var(--danger);background:#fdecea}.ci-br{background:var(--blue-l);color:var(--blue)}.chip-val{font-family:Kanit,sans-serif;font-size:22px;font-weight:600;line-height:1.1}.chip-lbl{color:var(--muted);font-size:12px}.legend-bar{border-bottom:1px solid var(--border);background:#fff;flex-wrap:wrap;gap:20px;padding:.75rem 1.75rem;display:flex}.leg{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:flex}.leg-box{border-radius:3px;flex-shrink:0;width:16px;height:10px}.grid-wrap{padding:1.5rem}.sec-hdr{align-items:center;gap:12px;margin-bottom:16px;display:flex}.sec-line{background:var(--border);flex:1;height:1px}.sec-lbl{color:var(--muted);letter-spacing:.5px;white-space:nowrap;text-transform:uppercase;font-family:Kanit,sans-serif;font-size:13px;font-weight:600}.slots-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:32px;display:grid}.slot{border:1.5px solid var(--border);border-radius:var(--r);text-align:center;cursor:pointer;box-shadow:var(--sh);background:#fff;padding:18px 12px 15px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.slot:after{content:"";border-radius:var(--r) var(--r) 0 0;background:var(--blue-m);height:5px;position:absolute;top:0;left:0;right:0}.slot.available:after{background:var(--blue)}.slot.almost:after{background:var(--warn)}.slot.full:after,.slot.break-time:after{background:#d0dde8}.slot.available:hover{border-color:var(--blue);box-shadow:var(--sh2);transform:translateY(-4px)}.slot.almost:hover{border-color:var(--warn);transform:translateY(-4px);box-shadow:0 8px 24px #f59e0b2e}.slot.full{cursor:not-allowed;box-shadow:none;background:#f7fafc;border-color:#e0ecf7}.slot.break-time{cursor:default;box-shadow:none;background:#f4f8fc;border-color:#d8e8f5}.slot.locked{cursor:not-allowed;pointer-events:none;opacity:.55}.slot-time{margin-bottom:4px;font-family:Kanit,sans-serif;font-size:17px;font-weight:600}.slot.full .slot-time,.slot.break-time .slot-time{color:var(--muted)}.slot-count{font-size:12px;font-weight:500}.slot.available .slot-count{color:var(--blue)}.slot.almost .slot-count{color:var(--warn)}.slot.full .slot-count{color:var(--danger)}.slot.break-time .slot-count{color:#9bb5cc;font-size:11px}.seat-bar{justify-content:center;gap:3px;margin-top:10px;display:flex}.seat{border-radius:2px;width:9px;height:6px}.seat.taken{background:#c8d8e8}.seat.open{background:var(--blue);opacity:.45}.seat.open-warn{background:var(--warn);opacity:.5}.modal-ov{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#14234680;justify-content:center;align-items:center;padding:1rem;transition:all .3s;display:none;position:fixed;inset:0}.modal-ov.show{display:flex}.modal{background:#fff;border-radius:24px;width:100%;max-width:420px;padding:2.5rem 2rem;animation:.4s cubic-bezier(.175,.885,.32,1.1) modalPop;position:relative;box-shadow:0 32px 80px #398df440}@keyframes modalPop{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-bar{background:linear-gradient(90deg, var(--blue), #80c0ff);border-radius:24px 24px 0 0;height:6px;position:absolute;top:0;left:0;right:0}.modal h2{color:var(--text);margin-top:.2rem;margin-bottom:8px;font-family:Kanit,sans-serif;font-size:22px;font-weight:700}.modal-meta{flex-wrap:wrap;gap:8px;margin-bottom:2rem;display:flex}.meta-pill{background:var(--blue-l);border:1px solid var(--blue-m);color:var(--blue);border-radius:20px;align-items:center;gap:6px;padding:5px 14px;font-size:12px;font-weight:600;display:inline-flex}.branch-pill{color:#059669;background:#f0fdf8;border-color:#a7f3d0}.code-field{margin-bottom:12px}.code-field label{color:var(--muted);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.code-inputs{justify-content:center;gap:12px;display:flex}.code-char{border:2px solid var(--border);width:58px;height:68px;color:var(--text);text-align:center;text-transform:uppercase;background:#f8fbff;border-radius:16px;outline:none;font-family:Kanit,sans-serif;font-size:28px;font-weight:700;transition:all .2s}.code-char:focus{border-color:var(--blue);background:#fff;transform:translateY(-2px);box-shadow:0 0 0 4px #398df426}.code-char::placeholder{color:var(--border);opacity:.5}.code-inputs.err .code-char{border-color:var(--danger);background:snow}.code-inputs.valid .code-char{border-color:var(--success);background:#f0fdf4}.code-hint{color:var(--muted);text-align:center;margin-top:12px;font-size:12px}.code-err{color:var(--danger);text-align:center;min-height:20px;margin-top:8px;font-size:13px;font-weight:500}.modal-actions{gap:12px;margin-top:1.5rem;display:flex}.btn{cursor:pointer;border:none;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-family:Sarabun,sans-serif;font-size:15px;font-weight:600;transition:all .2s;display:flex}.btn-cancel{color:var(--muted);background:#f0f4fa}.btn-cancel:hover{color:var(--text);background:#e4ecf7}.btn-ok{background:var(--blue);color:#fff;box-shadow:0 4px 14px #398df459}.btn-ok:hover:not(:disabled){background:var(--blue-d);transform:translateY(-2px);box-shadow:0 8px 24px #398df473}.btn-ok:disabled{background:var(--blue-m);box-shadow:none;cursor:not-allowed}.spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;display:none}.spinner.show{display:block}.close-btn{cursor:pointer;width:32px;height:32px;color:var(--muted);background:#f0f4fa;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex;position:absolute;top:18px;right:18px}.close-btn:hover{color:var(--text);background:#e0ecf9;transform:rotate(90deg)}.success-view{text-align:center;padding:.5rem 0}.check-circle{width:72px;height:72px;color:var(--success);background:linear-gradient(135deg,#e8f8f1,#c8f0e0);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.25rem;font-size:32px;display:flex;box-shadow:0 8px 24px #14b87a33}.success-view h3{color:var(--text);margin-bottom:6px;font-family:Kanit,sans-serif;font-size:22px;font-weight:700}.success-view .sub{color:var(--muted);margin-bottom:.5rem;font-size:14px}.success-view .email-note{color:var(--success);justify-content:center;align-items:center;gap:5px;margin-top:6px;margin-bottom:1.25rem;font-size:12px;font-weight:500;display:flex}.sdetail{border:1px solid var(--border);text-align:left;background:#f8fbff;border-radius:16px;margin:1.5rem 0;padding:16px}.srow{border-bottom:1px solid var(--border);justify-content:space-between;padding:8px 0;font-size:13px;display:flex}.srow:last-child{border-bottom:none}.srow span:first-child{color:var(--muted)}.srow span:last-child{color:var(--text);font-weight:600}.footer{text-align:center;color:var(--muted);border-top:1px solid var(--border);background:#fff;padding:2rem;font-size:12px}@media (width<=600px){.hero-inner{padding:3rem 1.5rem 7rem}.j-letter{font-size:64px}.bw{font-size:16px}.num-stamp{width:50px;height:50px;font-size:28px}.branch-grid{grid-template-columns:1fr;gap:12px}.slots-grid{grid-template-columns:repeat(2,1fr)}.login-card{margin-top:-2.5rem}.code-char{border-radius:12px;width:48px;height:58px;font-size:22px}}
