.ticket-card.apple-wallet-style{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-radius:24px;padding:32px 24px;box-shadow:0 10px 30px -5px #2563eb66;position:relative;overflow:hidden;margin-bottom:32px;border:none}.ticket-card.apple-wallet-style:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:radial-gradient(circle at top right,rgba(255,255,255,.2) 0%,transparent 60%);pointer-events:none}.ticket-card.apple-wallet-style .ticket-label{opacity:.8;font-size:13px;text-transform:uppercase;letter-spacing:1px;margin-top:8px}.ticket-card.apple-wallet-style .ticket-count{font-size:64px;font-weight:800;line-height:1;letter-spacing:-2px;text-shadow:0 2px 10px rgba(0,0,0,.2)}.slide-checkin-container{margin-top:24px;margin-bottom:24px;padding:4px;background:#00000008;border-radius:100px}.slide-checkin-track{background:#fff;box-shadow:0 2px 4px #0000000d;border:1px solid #e2e8f0}.slide-checkin-thumb{background:#2563eb;box-shadow:0 4px 12px #2563eb66}.slide-checkin-thumb.completing{background:#10b981}.slide-checkin-thumb span{color:#fff}.my-ticket-container{padding-bottom:40px;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}.stat-card-large{background:#fff;border-radius:20px;padding:20px;text-align:center;box-shadow:0 4px 6px -1px #00000005;border:1px solid #f1f5f9}.stat-value-large,.stat-value-date{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:4px}.stat-label{font-size:12px;color:#94a3b8;font-weight:500}:root{--primary-dark: #1D4E89;--primary-color: #1E90B8;--primary-teal: #3BBFAD;--primary-green: #3AA655;--accent-color: #3BBFAD;--accent-light: rgba(59, 191, 173, .1);--success-color: #3AA655;--warning-color: #F5A623;--danger-color: #E74C3C;--bg-primary: #FFFFFF;--bg-secondary: #F4F7FA;--bg-card: #FFFFFF;--bg-card-hover: #F0F4F8;--text-primary: #1A2B3C;--text-secondary: #5A6A7A;--text-muted: #8A9AAA;--border-color: #E0E6ED;--shadow-soft: 0 2px 12px rgba(29, 78, 137, .08);--shadow-medium: 0 8px 24px rgba(29, 78, 137, .12);--shadow-glow: 0 4px 20px rgba(30, 144, 184, .25);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 28px;--radius-full: 9999px;font-family:Hiragino Kaku Gothic ProN,Noto Sans JP,-apple-system,BlinkMacSystemFont,sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);color:var(--text-primary);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{min-height:100%;display:flex;flex-direction:column;background:var(--bg-secondary)}.page-container{flex:1;padding:20px 16px;max-width:500px;margin:0 auto;width:100%}.header{background:#004094;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-medium);gap:8px;flex-wrap:nowrap}.header-logo{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:0}.header-logo-icon{font-size:24px;flex-shrink:0}.header-logo-text{font-size:16px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-menu-btn{background:transparent;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}.header-menu-btn:hover{background:#ffffff26}.header-user{display:flex;align-items:center;gap:6px;flex-shrink:0}.header-avatar{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.3);flex-shrink:0}.header-logout{background:#ffffff26;border:none;color:#fff;font-size:12px;cursor:pointer;padding:6px 10px;border-radius:var(--radius-full);transition:all .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap;flex-shrink:0}.header-logout:hover{background:#ffffff40}.card{background:var(--bg-card);border:none;border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-soft);transition:all .3s ease}.card:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.card-title{font-size:14px;font-weight:600;color:var(--text-muted);margin-bottom:10px}.ticket-card{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-color) 50%,var(--primary-teal) 100%);border:none;text-align:center;padding:40px 24px;color:#fff;box-shadow:var(--shadow-glow);position:relative;overflow:hidden}.ticket-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.ticket-count{font-size:80px;font-weight:800;line-height:1;margin-bottom:8px;text-shadow:0 4px 20px rgba(0,0,0,.2)}.ticket-label{font-size:18px;font-weight:600;opacity:.95;letter-spacing:1px}.ticket-sub{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.2);font-size:14px;opacity:.9}.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}.stat-card{background:var(--bg-card);border:none;border-radius:var(--radius-md);padding:20px 16px;text-align:center;box-shadow:var(--shadow-soft);transition:all .3s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.stat-card-large{padding:24px 16px}.stat-value{font-size:32px;font-weight:700;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-value-large{font-size:42px;font-weight:800;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1}.stat-value-date{font-size:18px;font-weight:700;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.3}.stat-label{font-size:13px;color:var(--text-muted);margin-top:8px;font-weight:500}.upcoming-date-badge{width:56px;text-align:center;flex-shrink:0;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-teal) 100%);border-radius:12px;padding:10px 6px}.upcoming-date-month{font-size:11px;color:#ffffffe6;font-weight:600}.upcoming-date-day{font-size:26px;font-weight:800;color:#fff;line-height:1.1}.upcoming-event-item{padding:14px 16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 28px;font-size:16px;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .3s ease;width:100%;min-height:56px}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-teal) 100%);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #1e90b859}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-success{background:linear-gradient(135deg,var(--primary-teal) 0%,var(--primary-green) 100%);color:#fff;box-shadow:0 4px 16px #3aa6554d}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #3aa65566}.btn-danger{background:var(--danger-color);color:#fff}.btn-outline{background:transparent;border:2px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:10px 18px;font-size:14px;min-height:40px}.btn-icon{font-size:20px}.history-section{margin-top:28px}.history-title{font-size:16px;font-weight:700;margin-bottom:14px;color:var(--text-primary)}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg-card);border:none;border-radius:var(--radius-md);transition:all .3s;box-shadow:var(--shadow-soft)}.history-item:hover{background:var(--bg-card-hover);transform:translate(4px)}.history-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-light) 0%,rgba(59,191,173,.15) 100%);color:var(--primary-teal);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.history-content{flex:1;min-width:0}.history-event{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-date{font-size:13px;color:var(--text-muted);margin-top:3px}.checkin-complete{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;text-align:center;padding:40px 20px}.checkin-icon{width:110px;height:110px;border-radius:50%;background:linear-gradient(135deg,var(--primary-teal) 0%,var(--primary-green) 100%);display:flex;align-items:center;justify-content:center;font-size:52px;margin-bottom:28px;color:#fff;box-shadow:0 8px 32px #3aa65559;animation:bounce .6s ease}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.checkin-title{font-size:26px;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.checkin-info{background:var(--bg-card);border:none;border-radius:var(--radius-lg);padding:24px;width:100%;max-width:320px;margin-bottom:28px;box-shadow:var(--shadow-medium)}.checkin-info-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-color)}.checkin-info-row:last-child{border-bottom:none}.checkin-info-label{color:var(--text-muted);font-size:14px}.checkin-info-value{font-weight:600;font-size:14px;color:var(--text-primary)}.fade-in{animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp .6s ease-out forwards}.slide-up.delay-1{animation-delay:.3s;opacity:0}.slide-up.delay-2{animation-delay:.5s;opacity:0}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:100}.confetti-piece{position:absolute;width:10px;height:10px;top:-10px;animation:confettiFall linear forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.ripple-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1}.ripple{position:absolute;border:2px solid var(--primary-teal);border-radius:50%;opacity:0;animation:rippleEffect 1.5s ease-out forwards}.ripple-1{width:100px;height:100px;top:-50px;left:-50px;animation-delay:0s}.ripple-2{width:160px;height:160px;top:-80px;left:-80px;animation-delay:.2s}.ripple-3{width:220px;height:220px;top:-110px;left:-110px;animation-delay:.4s}@keyframes rippleEffect{0%{transform:scale(.5);opacity:.8}to{transform:scale(2);opacity:0}}.checkin-icon-animated{width:110px;height:110px;margin-bottom:28px;position:relative;border-radius:50%;box-shadow:0 8px 32px #3aa65559}.checkmark-svg{width:110px;height:110px;border-radius:50%;display:block;stroke-width:3;stroke:#fff;stroke-miterlimit:10;background:linear-gradient(135deg,var(--primary-teal) 0%,var(--primary-green) 100%);animation:scaleIn .4s ease-out forwards}.checkmark-circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:3;stroke-miterlimit:10;stroke:#ffffff4d;fill:none;animation:strokeCircle .6s cubic-bezier(.65,0,.45,1) .2s forwards}.checkmark-check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;stroke-width:4;stroke-linecap:round;animation:strokeCheck .4s cubic-bezier(.65,0,.45,1) .6s forwards}@keyframes scaleIn{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes strokeCircle{to{stroke-dashoffset:0}}@keyframes strokeCheck{to{stroke-dashoffset:0}}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 24px;text-align:center;background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.auth-logo{font-size:64px;margin-bottom:20px}.auth-title{font-size:32px;font-weight:800;margin-bottom:12px;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:44px;max-width:280px;line-height:1.7}.google-btn{display:inline-flex;align-items:center;gap:14px;padding:16px 32px;background:#fff;color:var(--text-primary);font-size:16px;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-medium)}.google-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #1d4e8926}.google-icon{width:22px;height:22px}.mock-badge{position:fixed;bottom:20px;right:20px;background:var(--warning-color);color:#fff;font-size:12px;font-weight:600;padding:8px 16px;border-radius:var(--radius-full);box-shadow:var(--shadow-medium)}.admin-section{margin-bottom:28px}.admin-section-title{font-size:17px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:10px;color:var(--text-primary)}.admin-section-title .icon{font-size:20px}.admin-summary-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:14px}.admin-summary-card{background:var(--bg-card);border:none;border-radius:var(--radius-md);padding:20px 16px;text-align:center;box-shadow:var(--shadow-soft)}.admin-summary-value{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-summary-label{font-size:12px;color:var(--text-muted);margin-top:6px}.table-container{overflow-x:auto;margin:-16px;padding:16px}.data-table{width:100%;min-width:520px;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{padding:14px 12px;text-align:left;border-bottom:1px solid var(--border-color)}.data-table th{font-weight:600;color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px;background:var(--bg-secondary)}.data-table tr:hover td{background:var(--bg-secondary)}.data-table .user-cell{display:flex;align-items:center;gap:12px}.data-table .user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--border-color)}.data-table .actions{display:flex;gap:8px}.input-group{display:flex;align-items:center;gap:10px}.input{padding:12px 16px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:15px;width:90px;text-align:center;transition:all .2s}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #1e90b826}.modal-overlay{position:fixed;inset:0;background:#1d4e8966;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000}.modal{background:var(--bg-primary);border-radius:var(--radius-xl);padding:28px;max-width:380px;width:100%;animation:modalIn .3s ease;box-shadow:var(--shadow-medium)}@keyframes modalIn{0%{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-size:20px;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.modal-actions{display:flex;gap:12px;margin-top:24px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;background:var(--bg-secondary)}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:14px}.error-message{background:#fff5f5;border:2px solid #FFDDDD;color:var(--danger-color);padding:16px;border-radius:var(--radius-md);margin-bottom:20px;text-align:center;font-size:14px;font-weight:500}.empty-state{text-align:center;padding:40px 24px;color:var(--text-muted)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state-text{font-size:14px}@media(max-width:480px){.page-container{padding:16px 12px}.ticket-count{font-size:64px}.ticket-label{font-size:16px}.admin-summary-grid{grid-template-columns:1fr}.stat-value{font-size:28px}}.slide-checkin-container{margin:20px 0}.slide-checkin-track{position:relative;height:64px;background:linear-gradient(135deg,var(--primary-teal) 0%,var(--primary-green) 100%);border-radius:var(--radius-full);box-shadow:0 4px 20px #3aa6554d;cursor:pointer;-webkit-user-select:none;user-select:none;overflow:hidden}.slide-checkin-track:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.slide-checkin-thumb{position:absolute;left:4px;top:4px;width:56px;height:56px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--primary-green);box-shadow:0 2px 10px #00000026;transition:transform .15s ease-out,box-shadow .2s;z-index:2}.slide-checkin-thumb:hover{box-shadow:0 4px 16px #0003}.slide-checkin-thumb.completing{background:var(--primary-green);color:#fff;box-shadow:0 0 20px #3aa65580}.slide-checkin-text{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);text-align:center;color:#fff;font-size:16px;font-weight:600;pointer-events:none;z-index:1;text-shadow:0 1px 2px rgba(0,0,0,.1)}
