.join-shell{background:radial-gradient(circle at 15% 15%,#5874ea2e 0%,#0000 40%),radial-gradient(circle at 85% 80%,#009f6d24 0%,#0000 40%),#f5f7fa;background:radial-gradient(circle at 15% 15%,lab(51.5554% 17.9614 -64.0229/.18) 0%,#0000 40%),radial-gradient(circle at 85% 80%,lab(58.026% -55.2534 17.8626/.14) 0%,#0000 40%),lab(97.0731% .0266731 -1.89826);place-items:center;min-height:100dvh;padding:24px 16px;display:grid}[data-theme=dark] .join-shell{background:radial-gradient(circle at 15% 15%,#3245b738 0%,#0000 40%),radial-gradient(circle at 85% 80%,#00694129 0%,#0000 40%),#060911;background:radial-gradient(circle at 15% 15%,lab(33.6992% 24.2273 -63.7625/.22) 0%,#0000 40%),radial-gradient(circle at 85% 80%,lab(38.2841% -57.0956 18.1543/.16) 0%,#0000 40%),lab(2.40668% .431754 -4.19189)}.join-card{background:var(--white);border:1px solid var(--line);border-radius:22px;width:min(100%,460px);overflow:hidden;box-shadow:0 24px 72px #0203091f;box-shadow:0 24px 72px lab(.861393% .307038 -2.29472/.12)}.join-brand{color:var(--text);align-items:center;gap:8px;padding:18px 24px 0;font-size:.9rem;font-weight:900;display:flex}.join-brand-logo{background:var(--blue);color:#fff;border-radius:8px;place-items:center;width:28px;height:28px;font-size:.82rem;font-weight:900;display:grid}.join-form{flex-direction:column;gap:16px;padding:20px 24px 28px;display:flex}.join-event-badge{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.join-event-name{color:var(--text);font-size:.8rem;font-weight:900}.join-team-chip{color:#2f40c2;color:lab(33.1744% 30.0628 -70.8453);letter-spacing:.04em;background:#e6eeff;background:lab(93.8152% 1.35225 -22.2675);border-radius:999px;align-items:center;padding:3px 10px;font-size:.72rem;font-weight:900;display:inline-flex}[data-theme=dark] .join-team-chip{color:#8ea9ff;color:lab(69.7638% 8.63075 -50.4474);background:#1a2550;background:lab(15.5983% 7.5911 -28.4857)}.join-title{letter-spacing:-.03em;color:var(--text);margin:0;font-family:Sora,sans-serif;font-size:clamp(1.2rem,3vw,1.5rem);font-weight:800;line-height:1.15}.join-subtitle{color:var(--muted);margin:-8px 0 0;font-size:.84rem;font-weight:600;line-height:1.55}.join-error{color:#a40025;color:lab(34.0336% 64.3112 33.531);background:#fff1f1;background:lab(96.2185% 9.51859 4.03003);border:1px solid #ff9d9d;border:1px solid lab(75.3541% 44.702 19.7306);border-radius:10px;align-items:center;gap:8px;padding:11px 14px;font-size:.84rem;font-weight:800;display:flex}.join-field{flex-direction:column;gap:6px;display:flex}.join-label{letter-spacing:.03em;color:var(--text);align-items:center;gap:6px;font-size:.78rem;font-weight:900;display:flex}.join-optional{color:var(--muted);font-weight:600}.join-hint{color:var(--muted);font-size:.73rem;font-weight:700}.join-input{box-sizing:border-box;border:1.5px solid var(--line);background:var(--bg);width:100%;color:var(--text);border-radius:10px;outline:none;padding:11px 14px;font-size:.93rem;font-weight:700;transition:border-color .15s,box-shadow .15s;display:block}.join-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3480fc1a;box-shadow:0 0 0 3px lab(54.05% 11.0892 -69.9224/.1)}.join-dietary-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.join-dietary-btn{border:1.5px solid var(--line);background:var(--bg);color:var(--text);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-size:.82rem;font-weight:800;transition:border-color .14s,background .14s,color .14s;display:flex}.join-dietary-btn:hover{border-color:var(--blue);background:#eaf2ff;background:lab(95.2105% -1.69313 -14.7488)}.join-dietary-btn.is-selected{border-color:var(--blue);color:#004abd;color:lab(33.2066% 26.2347 -76.6836);background:#e3efff;background:lab(93.9533% -2.13489 -21.9539)}.join-gdpr{border:1.5px solid var(--line);background:var(--bg);cursor:pointer;color:var(--muted);border-radius:10px;grid-template-columns:auto 1fr;align-items:start;gap:10px;padding:14px;font-size:.78rem;font-weight:600;line-height:1.55;display:grid}.join-gdpr strong{color:var(--text)}.join-gdpr-checkbox{width:18px;height:18px;accent-color:var(--blue);cursor:pointer;flex-shrink:0;margin-top:1px}.join-submit-btn{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:50px;padding:0 20px;font-size:.95rem;font-weight:900;transition:background .14s,transform .11s,box-shadow .14s;display:flex;box-shadow:0 12px 30px #005de047;box-shadow:0 12px 30px lab(41.7201% 20.6278 -76.6452/.28)}.join-submit-btn:hover:not(:disabled){background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 16px 36px #005de057;box-shadow:0 16px 36px lab(41.7201% 20.6278 -76.6452/.34)}.join-submit-btn:disabled{opacity:.48;cursor:not-allowed}.join-loading,.join-invalid,.join-success{text-align:center;flex-direction:column;align-items:center;gap:14px;max-width:380px;padding:48px 24px;display:flex}.join-loading{color:var(--muted)}.join-invalid{color:#a40025;color:lab(34.0336% 64.3112 33.531)}.join-invalid h1,.join-success h1{margin:0;font-family:Sora,sans-serif;font-size:1.4rem;font-weight:800}.join-invalid p,.join-success p{color:var(--muted);margin:0;font-size:.88rem;font-weight:700;line-height:1.55}.join-success{color:#00895a;color:lab(50.1517% -63.5759 20.3218)}.join-spinner{border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.portal-shell{background:radial-gradient(circle at 20% 10%,#5874ea1f 0%,#0000 40%),#f5f7fa;background:radial-gradient(circle at 20% 10%,lab(51.5554% 17.9614 -64.0229/.12) 0%,#0000 40%),lab(97.0731% .0266731 -1.89826);place-items:start center;min-height:100dvh;padding:24px 16px 48px;display:grid}[data-theme=dark] .portal-shell{background:radial-gradient(circle at 20% 10%,#2735a62e 0%,#0000 40%),#05070f;background:radial-gradient(circle at 20% 10%,lab(27.6482% 27.4119 -63.765/.18) 0%,#0000 40%),lab(1.92084% .400029 -3.66425)}.portal-card{background:var(--white);border:1px solid var(--line);border-radius:24px;width:min(100%,420px);overflow:hidden;box-shadow:0 20px 60px #0203091a;box-shadow:0 20px 60px lab(.861393% .307038 -2.29472/.1)}.portal-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.portal-checkin-badge{color:#006843;color:lab(38.5338% -65.3765 20.5957);background:#cbfce3;background:lab(95.0075% -19.7331 6.53151);border:1px solid #a7e9c8;border:1px solid lab(87.1531% -26.4668 8.73582);border-radius:999px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:900;display:inline-flex}.portal-identity{align-items:center;gap:14px;padding:20px 20px 0;display:flex}.portal-avatar{color:#2d3acc;color:lab(32.5831% 36.5557 -78.0047);background:#dce7ff;background:lab(91.4937% 1.37699 -22.2575);border-radius:50%;flex-shrink:0;place-items:center;width:52px;height:52px;font-family:Sora,sans-serif;font-size:1.1rem;font-weight:900;display:grid}.portal-name{letter-spacing:-.02em;color:var(--text);font-family:Sora,sans-serif;font-size:1.1rem;font-weight:800}.portal-role{color:var(--muted);margin-top:2px;font-size:.8rem;font-weight:700}.portal-event-info{background:var(--bg);border:1px solid var(--line);border-radius:12px;margin:16px 20px 0;padding:14px 16px}.portal-event-title{color:var(--text);margin-bottom:4px;font-size:.9rem;font-weight:900}.portal-event-meta{color:var(--blue);font-size:.78rem;font-weight:700}.portal-event-venue{color:var(--muted);margin-top:3px;font-size:.76rem;font-weight:700}.portal-chips{flex-wrap:wrap;gap:6px;padding:14px 20px 0;display:flex}.portal-chip{letter-spacing:.02em;border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:900;display:inline-flex}.portal-chip.is-team{color:#282fc2;color:lab(28.863% 39.3156 -78.1153);background:#dce7ff;background:lab(91.4937% 1.37699 -22.2575);border:1px solid #c2d3ff;border:1px solid lab(84.3641% 2.50983 -29.4298)}.portal-chip.is-status{color:#006843;color:lab(38.5338% -65.3765 20.5957);background:#d1fae5;background:lab(94.8737% -16.4086 5.43673);border:1px solid #aee7ca;border:1px solid lab(87.0202% -23.1016 7.63398)}.portal-chip.is-dietary{color:#8e4900;color:lab(38.6384% 42.2284 98.2165);background:#ffeee1;background:lab(95.243% 8.91963 17.0156);border:1px solid #ffcca3;border:1px solid lab(85.8556% 14.9623 27.9469)}.portal-chip.is-warning{color:#974c00;color:lab(40.645% 51.0908 108.017);background:#ffeede;background:lab(95.212% 10.8459 20.5506);border:1px solid #ffca9d;border:1px solid lab(85.7729% 19.1822 35.5884)}.portal-qr-section{flex-direction:column;align-items:center;gap:10px;padding:24px 20px 20px;display:flex}.portal-qr-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:.72rem;font-weight:900}.portal-qr{border:1px solid var(--line);background:#fff;border-radius:16px;padding:16px;box-shadow:0 6px 20px #02030912;box-shadow:0 6px 20px lab(.861393% .307038 -2.29472/.07)}.portal-qr svg{width:220px;height:220px;display:block}.portal-qr-id{letter-spacing:.12em;color:var(--muted);font-family:Sora,monospace;font-size:.72rem;font-weight:900}.portal-qr-hint{color:var(--muted);text-align:center;max-width:300px;margin:0;font-size:.76rem;font-weight:600;line-height:1.55}.portal-footer{text-align:center;color:var(--muted);border-top:1px solid var(--line);padding:14px 20px 20px;font-size:.72rem;font-weight:700}.scanner-layout{grid-template-columns:1fr 360px;align-items:start;gap:20px;padding:20px 28px 40px;display:grid}@media (max-width:900px){.scanner-layout{grid-template-columns:1fr;padding:16px 0 40px}}.scanner-camera-wrap{aspect-ratio:4/3;background:#010105;background:lab(.432646% .24683 -1.55951);border-radius:16px;justify-content:center;align-items:center;min-height:260px;display:flex;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%;display:block}.scanner-idle{color:#999eab;color:lab(65.0842% .243634 -7.51679);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:20px;display:flex}.scanner-idle p{margin:0;font-size:.84rem;font-weight:700}.scanner-overlay{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:absolute;inset:0}.scanner-frame{border:2px solid #00ce8e;border:2px solid lab(73.374% -61.8287 20.0411);border-radius:16px;width:200px;height:200px;animation:2s ease-in-out infinite scanner-pulse;box-shadow:0 0 0 9999px #0101058c,inset 0 0 0 2px #00ce8e33;box-shadow:0 0 0 9999px lab(.432646% .24683 -1.55951/.55),inset 0 0 0 2px lab(73.374% -61.8287 20.0411/.2)}@keyframes scanner-pulse{0%,to{border-color:#00ac73;border-color:lab(61.7644% -62.5218 20.1541)}50%{border-color:#00e399;border-color:lab(79.6905% -76.3695 24.6254)}}.scanner-hint{color:#fff;text-shadow:0 1px 4px #000000b3;text-shadow:0 1px 4px lab(.112911% 0 0/.7);margin:0;font-size:.82rem;font-weight:800}.scanner-stop-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#010105b3;background:lab(.432646% .24683 -1.55951/.7);border:1px solid #ffffff40;border:1px solid lab(100% 0 0/.25);border-radius:8px;align-items:center;gap:6px;padding:7px 12px;font-size:.78rem;font-weight:900;transition:background .14s;display:flex;position:absolute;bottom:12px;right:12px}.scanner-stop-btn:hover{background:#010105e6;background:lab(.432646% .24683 -1.55951/.9)}.scanner-result-wrap{background:var(--white);border:1px solid var(--line);border-radius:16px;justify-content:center;align-items:center;min-height:300px;display:flex;box-shadow:0 6px 20px #0203090f;box-shadow:0 6px 20px lab(.861393% .307038 -2.29472/.06)}.scanner-placeholder{color:var(--muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:32px 24px;display:flex}.scanner-placeholder p{max-width:240px;margin:0;font-size:.84rem;font-weight:700;line-height:1.55}.scanner-pulse{background:#009f6e40;background:lab(58.281% -62.7892 20.1972/.25);border-radius:50%;width:36px;height:36px;animation:1.2s ease-in-out infinite scan-pulse}@keyframes scan-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}.scanner-spinner{border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}.scanner-result{text-align:center;flex-direction:column;align-items:center;gap:10px;width:100%;padding:28px 20px;display:flex}.scanner-result.is-success{color:#008052;color:lab(46.667% -64.0086 20.3891)}.scanner-result.is-error{color:#bc002d;color:lab(39.6187% 70.7365 36.7098)}.scanner-result.is-found{color:var(--text)}.scanner-result.is-blocked{color:#914600;color:lab(38.2976% 51.4395 103.799)}.scanner-avatar{color:#282fc2;color:lab(28.863% 39.3156 -78.1153);background:#dce7ff;background:lab(91.4937% 1.37699 -22.2575);border-radius:50%;place-items:center;width:60px;height:60px;font-family:Sora,sans-serif;font-size:1.2rem;font-weight:900;display:grid}.scanner-result-name{letter-spacing:-.02em;color:inherit;font-family:Sora,sans-serif;font-size:1.1rem;font-weight:800}.scanner-result-role{color:var(--muted);font-size:.8rem;font-weight:700}.scanner-chips{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.scanner-checkin-btn{color:#fff;cursor:pointer;background:#008052;background:lab(46.667% -64.0086 20.3891);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:48px;margin-top:8px;padding:0 24px;font-size:.95rem;font-weight:900;transition:background .14s,transform .11s;display:flex;box-shadow:0 10px 26px #0080524d;box-shadow:0 10px 26px lab(46.667% -64.0086 20.3891/.3)}.scanner-checkin-btn:hover{background:#006540;background:lab(37.3716% -65.6298 20.633);transform:translateY(-1px)}.scanner-online-badge{border-radius:999px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:900;display:inline-flex}.scanner-online-badge.is-online{color:#006843;color:lab(38.5338% -65.3765 20.5957);background:#d1fae5;background:lab(94.8737% -16.4086 5.43673);border:1px solid #aee7ca;border:1px solid lab(87.0202% -23.1016 7.63398)}.scanner-online-badge.is-offline{color:#8e4900;color:lab(38.6384% 42.2284 98.2165);background:#ffeee1;background:lab(95.243% 8.91963 17.0156);border:1px solid #ffcca3;border:1px solid lab(85.8556% 14.9623 27.9469)}.join-pending-screen{text-align:center;flex-direction:column;align-items:center;gap:16px;max-width:400px;padding:48px 28px 40px;display:flex}.join-pending-icon{color:#a74a00;color:lab(42.9907% 50.7581 111.553);background:#ffeee2;background:lab(95.1878% 10.1147 16.0933);border:2px solid #ffbc8b;border:2px solid lab(82.0739% 26.3276 41.2946);border-radius:50%;place-items:center;width:72px;height:72px;display:grid}.join-pending-screen h1{color:var(--text);margin:0;font-family:Sora,sans-serif;font-size:1.4rem;font-weight:800}.join-pending-screen p{color:var(--muted);margin:0;font-size:.88rem;font-weight:700;line-height:1.6}.join-pending-notice{color:var(--muted);text-align:left;background:#fff2ea;background:lab(96.4581% 3.91161 6.33183);border:1.5px solid #ffbd90;border:1.5px solid lab(82.1858% 21.5144 33.6821);border-radius:12px;gap:6px;width:100%;padding:14px 18px;font-size:.8rem;font-weight:700;line-height:1.5;display:grid}.join-pending-notice strong{color:#7a3800;color:lab(31.4584% 46.5132 81.4416);letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px;font-size:.72rem;font-weight:900;display:block}.portal-status-badge{border-radius:999px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:900;display:inline-flex}.portal-status-badge.is-pending{color:#7e3400;color:lab(31.243% 52.5902 87.8033);background:#ffeee2;background:lab(95.1878% 10.1147 16.0933);border:1px solid #ffbc8b;border:1px solid lab(82.0739% 26.3276 41.2946)}.portal-status-badge.is-rejected{color:#950021;color:lab(30.5419% 64.3472 34.8174);background:#fff1f1;background:lab(96.2185% 9.51859 4.03003);border:1px solid #ffb2b1;border:1px solid lab(80.4179% 31.8605 13.8045)}.portal-avatar.is-pending{color:#a34d00;color:lab(43.3634% 39.1429 81.1313);background:#fbdecc;background:lab(90.586% 8.01972 12.8131)}.portal-avatar.is-rejected{color:#ab4046;color:lab(42.8492% 44.8372 20.5997);background:#fce0e0;background:lab(91.5784% 9.51931 4.03152)}.portal-approval-box{text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:10px;margin:16px 20px;padding:20px;display:flex}.portal-approval-box.is-pending{background:#fff2e9;background:lab(96.4411% 4.91759 7.9348);border:1.5px solid #ffb888;border:1.5px solid lab(80.9119% 26.3632 41.3636)}.portal-approval-box.is-rejected{background:#fff6f5;background:lab(97.5297% 4.75529 2.00645);border:1.5px solid #ffb7b6;border:1.5px solid lab(81.5782% 31.8587 13.7979)}.portal-approval-icon{font-size:2rem;line-height:1}.portal-approval-title{color:var(--text);font-family:Sora,sans-serif;font-size:1rem;font-weight:800}.portal-approval-box.is-pending .portal-approval-title{color:#6d2d00;color:lab(26.7542% 47.2901 71.0243)}.portal-approval-box.is-rejected .portal-approval-title{color:#84001a;color:lab(25.8836% 64.3987 36.6252)}.portal-approval-text{color:var(--muted);margin:0;font-size:.84rem;font-weight:700;line-height:1.6}.portal-approval-hint{color:var(--muted);background:#fff9;background:lab(100% 0 0/.6);border:1px solid #d3ddf9;border:1px solid lab(88.157% .675976 -14.9422);border-radius:8px;width:100%;padding:10px 14px;font-size:.76rem;font-weight:700;line-height:1.5}[data-theme=dark] .portal-status-badge.is-pending{color:#ef852e;color:lab(66.6902% 37.2311 61.7785);background:#241104;background:lab(7.04215% 8.99325 9.16091);border-color:#5c2b00;border-color:lab(24.022% 24.1759 40.1679)}[data-theme=dark] .portal-status-badge.is-rejected{color:#e8777a;color:lab(63.7475% 44.741 19.9351);background:#1d0c0c;background:lab(5.03733% 7.82207 2.74258);border-color:#5b161c;border-color:lab(20.0613% 32.0638 15.0786)}[data-theme=dark] .portal-approval-box.is-pending{background:#180c05;background:lab(4.36331% 3.92379 4.42451);border-color:#532300;border-color:lab(20.5178% 24.5257 37.3699)}[data-theme=dark] .portal-approval-box.is-rejected{background:#150a0a;background:lab(3.57886% 4.03656 1.48092);border-color:#551018;border-color:lab(17.7374% 32.0804 15.2783)}[data-theme=dark] .portal-approval-box.is-pending .portal-approval-title{color:#ef852e;color:lab(66.6902% 37.2311 61.7785)}[data-theme=dark] .portal-approval-box.is-rejected .portal-approval-title{color:#e8777a;color:lab(63.7475% 44.741 19.9351)}[data-theme=dark] .portal-approval-hint{background:#ffffff0a;background:lab(100% 0 0/.04);border-color:#262d42;border-color:lab(18.4901% 1.77544 -14.5624)}[data-theme=dark] .join-pending-notice{background:#160d07;background:lab(4.3822% 3.02959 3.67208);border-color:#492100;border-color:lab(18.3516% 19.1326 28.9952)}[data-theme=dark] .join-pending-notice strong{color:#e1791b;color:lab(62.0302% 37.5445 63.6504)}@media (max-width:600px){.join-form{padding:16px 18px 24px}.join-dietary-grid{grid-template-columns:1fr 1fr}.portal-qr svg{width:180px;height:180px}.scanner-frame{width:160px;height:160px}.portal-approval-box{margin:14px;padding:16px}}
