*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f9fc;--surface:#fff;--surface-2:#f1f3f8;--border:#e2e6ef;--border-strong:#c8cfe0;--primary:#4f6ef7;--primary-dark:#3a57e8;--primary-light:#eef1fe;--success:#22c55e;--success-light:#f0fdf4;--warning:#f59e0b;--warning-light:#fffbeb;--danger:#ef4444;--danger-light:#fef2f2;--text:#1a1d2e;--text-2:#4b5068;--text-3:#8b91a8;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 8px 24px #0000001a, 0 4px 8px #0000000f;--t:.18s ease}[data-theme=dark]{--bg:#0f1117;--surface:#1a1d27;--surface-2:#22263a;--border:#2a2f45;--border-strong:#3a4060;--primary:#6b8aff;--primary-dark:#4f6ef7;--primary-light:#1a2140;--success:#34d399;--success-light:#0a2a1a;--warning:#fbbf24;--warning-light:#2a1f0a;--danger:#f87171;--danger-light:#2a0f0f;--text:#e8eaf6;--text-2:#9aa0c0;--text-3:#555d80;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;transition:background var(--t), color var(--t);font-family:Inter,Noto Sans JP,system-ui,sans-serif;font-size:15px;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.page{flex:1;width:100%;max-width:680px;margin:0 auto;padding:24px 16px 48px}.page--wide{max-width:960px}.nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;height:56px;box-shadow:var(--shadow-sm);transition:background var(--t), border-color var(--t);justify-content:space-between;align-items:center;padding:0 20px;display:flex;position:sticky;top:0}.nav__logo{color:var(--primary);letter-spacing:-.3px;font-size:17px;font-weight:700}.nav__links{align-items:center;gap:8px;display:flex}.nav__link{border-radius:var(--radius-sm);color:var(--text-2);transition:background var(--t), color var(--t);padding:6px 14px;font-size:14px;font-weight:500}.nav__link:hover{background:var(--surface-2);color:var(--text);text-decoration:none}.nav__link--active{background:var(--primary-light);color:var(--primary)}.theme-toggle{border:1px solid var(--border);background:var(--surface-2);cursor:pointer;width:36px;height:36px;transition:background var(--t);border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex}.theme-toggle:hover{background:var(--border)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:background var(--t), border-color var(--t);padding:24px}.card+.card{margin-top:16px}.card__title{color:var(--text);margin-bottom:4px;font-size:16px;font-weight:700}.card__subtitle{color:var(--text-3);margin-bottom:16px;font-size:13px}.badge{border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge--primary{background:var(--primary-light);color:var(--primary)}.badge--success{background:var(--success-light);color:var(--success)}.badge--warning{background:var(--warning-light);color:var(--warning)}.badge--danger{background:var(--danger-light);color:var(--danger)}.badge--neutral{background:var(--surface-2);color:var(--text-3)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--t), box-shadow var(--t), transform var(--t);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.975)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn--primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4f6ef747}.btn--primary:hover:not(:disabled){background:var(--primary-dark)}.btn--success{background:var(--success);color:#fff}.btn--success:hover:not(:disabled){filter:brightness(1.1)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){filter:brightness(1.1)}.btn--ghost{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn--outline-danger{color:var(--danger);border:1px solid var(--danger);background:0 0}.btn--outline-danger:hover:not(:disabled){background:var(--danger-light)}.btn--sm{padding:6px 14px;font-size:13px}.btn--lg{padding:13px 28px;font-size:16px}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-group:last-of-type{margin-bottom:0}label{color:var(--text-2);font-size:13px;font-weight:600}input[type=text],input[type=email],input[type=password],input[type=number],input[type=datetime-local],textarea,select{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--surface);transition:border-color var(--t), box-shadow var(--t), background var(--t);appearance:none;outline:none;padding:10px 14px;font-family:inherit;font-size:15px}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f6ef71f}input::placeholder,textarea::placeholder{color:var(--text-3)}textarea{resize:vertical;min-height:80px}.form-hint{color:var(--text-3);margin-top:2px;font-size:12px}.form-error{color:var(--danger);margin-top:2px;font-size:12px}.alert{border-radius:var(--radius-sm);border:1px solid #0000;align-items:flex-start;gap:10px;padding:12px 16px;font-size:14px;display:flex}.alert--success{background:var(--success-light);border-color:var(--success);color:var(--success)}.alert--danger{background:var(--danger-light);border-color:var(--danger);color:var(--danger)}.alert--info{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-3);margin-bottom:12px;font-size:13px;font-weight:700}.divider{background:var(--border);height:1px;margin:20px 0}.ticket-number{letter-spacing:-3px;color:var(--primary);text-align:center;font-size:72px;font-weight:900;line-height:1}.ticket-number--calling{color:var(--success)}.qr-wrapper{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;align-items:center;gap:12px;padding:24px;display:flex}.spinner{border:2.5px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;width:22px;height:22px;margin:24px auto;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--text-3);padding:48px 24px}.empty__icon{margin-bottom:12px;font-size:40px}.empty__text{font-size:15px;font-weight:500}.overlay{z-index:200;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:28px}.modal__title{margin-bottom:8px;font-size:18px;font-weight:700}.modal__body{color:var(--text-2);margin-bottom:24px;font-size:14px;line-height:1.7}.modal__actions{justify-content:flex-end;gap:10px;display:flex}.tabs{background:var(--surface-2);border-radius:var(--radius-md);gap:4px;margin-bottom:20px;padding:4px;display:flex}.tab{border-radius:var(--radius-sm);color:var(--text-3);cursor:pointer;transition:background var(--t), color var(--t);background:0 0;border:none;flex:1;padding:8px;font-family:inherit;font-size:14px;font-weight:600}.tab--active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.url-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);word-break:break-all;padding:10px 14px;font-family:monospace;font-size:12px}@media (width<=480px){.page{padding:16px 12px 40px}.card{padding:18px}.modal{padding:22px}.ticket-number{font-size:56px}}[data-theme=dark] input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert()}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:invert()}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes numberPop{0%{opacity:0;transform:scale(.6)}70%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes callPulse{0%,to{box-shadow:0 0 #22c55e73}50%{box-shadow:0 0 0 20px #22c55e00}}.anim-fade-up{animation:.4s both fadeInUp}.anim-fade-up--1{animation-delay:60ms}.anim-fade-up--2{animation-delay:.12s}.anim-fade-up--3{animation-delay:.18s}.anim-fade-up--4{animation-delay:.24s}.anim-number{animation:.55s cubic-bezier(.34,1.56,.64,1) both numberPop}.anim-call{animation:2s ease-in-out infinite callPulse}.event-card{cursor:pointer;transition:border-color var(--t), transform var(--t), box-shadow var(--t)}.event-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.stat-box{background:var(--surface-2);border-radius:var(--radius-md);text-align:center;border:1px solid var(--border);padding:18px}.stat-box__label{color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-size:11px;font-weight:700}.stat-box__value{font-size:34px;font-weight:900;line-height:1}.staff-hero{text-align:center;border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--surface);transition:background var(--t), border-color var(--t);margin-bottom:16px;padding:36px 24px}.staff-hero__label{color:var(--text-3);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:11px;font-weight:700}.staff-hero__number{letter-spacing:-4px;color:var(--success);font-size:110px;font-weight:900;line-height:1}.staff-hero__unit{color:var(--text-3);margin-top:4px;font-size:16px;font-weight:600}.ticket-hero{text-align:center;padding:32px 24px}.ticket-hero__label{color:var(--text-3);letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-weight:700}.ticket-hero__number{letter-spacing:-3px;color:var(--primary);font-size:100px;font-weight:900;line-height:1}.ticket-hero__unit{color:var(--text-3);margin-top:6px;font-size:15px}.btn--next{border-radius:var(--radius-xl);cursor:pointer;border:none;width:100%;padding:28px 0;font-family:inherit;font-size:22px;font-weight:900;transition:all .2s}.btn--next--active{background:var(--success);color:#fff}.btn--next--active:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 8px 24px #22c55e59}.btn--next--inactive{background:var(--surface-2);color:var(--text-3);cursor:not-allowed}.waiting-card{text-align:center;padding:28px 24px}.waiting-card__count{letter-spacing:-2px;font-size:72px;font-weight:900;line-height:1}.waiting-card__unit{color:var(--text-3);margin-top:4px;font-size:16px}.auth-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-icon{text-align:center;margin-bottom:12px;font-size:44px}.auth-title{text-align:center;margin-bottom:4px;font-size:22px;font-weight:800}.auth-subtitle{color:var(--text-3);text-align:center;margin-bottom:28px;font-size:14px}.btn--ticket{border-radius:var(--radius-xl);cursor:pointer;border:none;width:100%;padding:22px 0;font-family:inherit;font-size:20px;font-weight:800;transition:all .2s}.btn--ticket--open{background:var(--primary);color:#fff;box-shadow:0 6px 20px #4f6ef759}.btn--ticket--open:hover{background:var(--primary-dark);transform:translateY(-2px)}.btn--ticket--closed{background:var(--surface-2);color:var(--text-3);cursor:not-allowed}.page-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.page-header__title{letter-spacing:-.5px;font-size:24px;font-weight:800}.page-header__sub{color:var(--text-3);margin-top:2px;font-size:13px}.qr-box{border-radius:var(--radius-lg);background:#fff;margin-top:8px;padding:16px;display:inline-flex}@media (width<=480px){.staff-hero__number{font-size:88px}.ticket-hero__number{font-size:80px}.waiting-card__count{font-size:60px}}html{transition:background .2s,color .2s}@media (width<=600px){.nav{padding:0 14px}.staff-hero__number{letter-spacing:-3px;font-size:80px}.ticket-hero__number{letter-spacing:-2px;font-size:76px}.btn--next{padding:22px 0;font-size:18px}.btn--ticket{padding:18px 0;font-size:18px}.stat-box__value{font-size:28px}}body{background-image:radial-gradient(at 15% 40%,#4f6ef70f 0%,#0000 55%),radial-gradient(at 85% 15%,#4f6ef70a 0%,#0000 50%)}[data-theme=dark] body{background-image:radial-gradient(at 15% 40%,#6b8aff14 0%,#0000 55%),radial-gradient(at 85% 15%,#6b8aff0d 0%,#0000 50%)}.auth-screen{background:var(--bg)!important;background-image:radial-gradient(at 50% 30%,#4f6ef714 0%,#0000 60%)!important}.landing{overflow:hidden}.landing-container{max-width:1100px;margin:0 auto;padding:0 2rem}.landing-container--narrow{max-width:720px}.landing-hero{text-align:center;background:var(--bg);padding:6rem 0 5rem}.landing-hero__title{margin-bottom:1.25rem;font-size:clamp(2rem,5vw,3.4rem);font-weight:800;line-height:1.3}.landing-hero__subtitle{color:var(--text-2);margin-bottom:2.5rem;font-size:1.05rem;line-height:1.8}.landing-hero__cta{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.landing-section{padding:5rem 0}.landing-section--alt{background:var(--surface-2)}.landing-section__title{text-align:center;margin-bottom:3rem;font-size:1.8rem;font-weight:700}.landing-section__cta{text-align:center;margin-top:3rem}.landing-features{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;display:grid}.landing-feature-card{text-align:center;padding:2.5rem 1.5rem!important}.landing-feature-card__icon{margin-bottom:1rem;font-size:2.8rem;display:block}.landing-feature-card__title{margin-bottom:.5rem;font-size:1rem;font-weight:700}.landing-feature-card__desc{color:var(--text-2);font-size:.88rem;line-height:1.7}.landing-steps{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:.5rem;display:flex}.landing-step-wrapper{flex:1;align-items:center;min-width:160px;max-width:220px;display:flex}.landing-step-card{text-align:center;flex:1;padding:2rem 1rem!important}.landing-step-card__num{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:2.8rem;height:2.8rem;margin-bottom:.8rem;font-size:1.1rem;font-weight:800;display:inline-flex}.landing-step-card__title{margin-bottom:.4rem;font-size:.95rem;font-weight:700}.landing-step-card__desc{color:var(--text-2);font-size:.82rem;line-height:1.6}.landing-step-arrow{color:var(--border-strong);flex-shrink:0;padding:0 .25rem;font-size:1.8rem}.landing-faq{flex-direction:column;gap:.75rem;display:flex}.landing-faq__item{cursor:pointer;-webkit-user-select:none;user-select:none;padding:1.25rem 1.5rem!important}.landing-faq__item.is-open{border-color:var(--primary)!important}.landing-faq__question{justify-content:space-between;align-items:center;gap:1rem;font-size:.95rem;font-weight:600;display:flex}.landing-faq__toggle{color:var(--text-3);flex-shrink:0;font-size:.65rem}.landing-faq__answer{border-top:1px solid var(--border);color:var(--text-2);margin-top:.9rem;padding-top:.9rem;font-size:.88rem;line-height:1.75}.landing-contact{text-align:center}.landing-contact__text{color:var(--text-2);margin-bottom:1.75rem}.btn--lg{border-radius:var(--radius-md)!important;padding:.9rem 2.2rem!important;font-size:1.05rem!important}.btn--full{width:100%}.btn--outline{border:2px solid var(--primary)!important;color:var(--primary)!important;background:0 0!important}.btn--outline:hover{background:var(--primary)!important;color:#fff!important}.site-header{z-index:100;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0}.site-header__inner{justify-content:space-between;align-items:center;max-width:1100px;height:3.5rem;margin:0 auto;padding:0 1.5rem;display:flex}.site-header__logo{color:var(--text);font-size:1rem;font-weight:700;text-decoration:none}.site-header__right{align-items:center;gap:.5rem;display:flex}.site-header__link{border-radius:var(--radius-sm);color:var(--text-2);transition:background var(--t), color var(--t);padding:6px 12px;font-size:14px;font-weight:500;text-decoration:none}.site-header__link:hover{background:var(--surface-2);color:var(--text);text-decoration:none}.site-header__link--btn{cursor:pointer;background:0 0;border:none}.site-header__theme-btn{border:1px solid var(--border);background:var(--surface-2);cursor:pointer;width:36px;height:36px;transition:background var(--t);border-radius:50%;font-size:16px}.site-header__theme-btn:hover{background:var(--border)}.auth-wrap{justify-content:center;align-items:center;min-height:calc(100vh - 3.5rem);padding:2rem 1rem;display:flex}.auth-card{width:100%;max-width:420px}.auth-card__header{text-align:center;margin-bottom:2rem}.auth-card__icon{margin-bottom:.75rem;font-size:2.5rem;display:block}.auth-card__title{margin-bottom:.25rem;font-size:1.4rem;font-weight:700}.auth-card__subtitle{color:var(--text-2);font-size:.9rem}.auth-card__switch{text-align:center;color:var(--text-2);margin-top:1.25rem;font-size:.88rem}.auth-card__switch-link{color:var(--primary);cursor:pointer;margin-left:.25rem}.auth-card__switch-link:hover{text-decoration:underline}.alert{border-radius:var(--radius-sm);margin-bottom:1rem;padding:10px 14px;font-size:14px}.alert--error{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger)}.alert--success{background:var(--success-light);color:var(--success);border:1px solid var(--success)}.form-group{margin-bottom:1rem}.form-label{color:var(--text-2);margin-bottom:.35rem;font-size:13px;display:block}.form-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:border-color var(--t);padding:10px 12px;font-size:15px}.form-input:focus{border-color:var(--primary);outline:none}@media (width<=640px){.landing-section{padding:3.5rem 0}.landing-hero{padding:3.5rem 0 2.5rem}.landing-step-arrow,.site-header__link--desktop{display:none}}.settings-profile{align-items:center;gap:14px;margin-top:4px;display:flex}.settings-avatar{background:var(--primary-light);width:52px;height:52px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex}.settings-profile__name{margin-bottom:2px;font-size:15px;font-weight:700}.settings-profile__meta{color:var(--text-3);margin-bottom:6px;font-size:12px}.card--danger{border-color:var(--danger)!important}.card__title--danger{color:var(--danger)}.auth-card>.btn{margin-top:1.25rem}.site-header__hamburger{cursor:pointer;color:var(--text);border-radius:var(--radius-sm);background:0 0;border:none;padding:6px 10px;font-size:20px;line-height:1;display:none}.mobile-menu{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;padding:8px 0;display:none}.mobile-menu__item{color:var(--text);cursor:pointer;text-align:left;width:100%;transition:background var(--t);background:0 0;border:none;padding:14px 24px;font-size:15px;font-weight:500;text-decoration:none;display:block}.mobile-menu__item:hover{background:var(--surface-2)}.mobile-menu__item--danger{color:var(--danger)}@media (width<=640px){.site-header__hamburger{align-items:center;display:flex}.mobile-menu{display:flex}}.card .form-group+.btn,.card .form-group+button{margin-top:1rem}
