*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}button{padding:10px 20px;border:none;border-radius:4px;background-color:#007bff;color:#fff;cursor:pointer;font-size:16px;transition:background-color .2s}button:hover{background-color:#0056b3}button:disabled{background-color:#ccc;cursor:not-allowed}button.secondary{background-color:#6c757d}button.secondary:hover{background-color:#545b62}button.danger{background-color:#dc3545}button.danger:hover{background-color:#c82333}input,textarea,select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:16px;width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:#007bff}label{display:block;margin-bottom:4px;font-weight:500}.card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.debug-panel{position:fixed;bottom:20px;right:20px;width:400px;max-height:500px;background:#2d2d2d;color:#f8f8f2;border-radius:8px;padding:16px;font-family:Courier New,monospace;font-size:12px;overflow-y:auto;box-shadow:0 4px 12px #0000004d;z-index:1000}.debug-panel h3{color:#f8f8f2;margin-bottom:12px;font-size:14px}.debug-panel pre{margin:0;white-space:pre-wrap;word-wrap:break-word}.debug-panel .toggle-btn{position:absolute;top:8px;right:8px;padding:4px 8px;font-size:12px;background:#555;border:none;border-radius:4px;color:#fff;cursor:pointer;z-index:1001}.debug-panel .toggle-btn:hover{background:#777}.debug-toggle-btn{position:fixed;bottom:20px;right:20px;padding:8px 16px;font-size:12px;background:#2d2d2d;color:#f8f8f2;border:1px solid #555;border-radius:8px;cursor:pointer;z-index:1000;font-family:Courier New,monospace;box-shadow:0 4px 12px #0000004d}.debug-toggle-btn:hover{background:#3d3d3d;border-color:#777}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700}.status-pending{background-color:#ffc107;color:#000}.status-activated{background-color:#17a2b8;color:#fff}.status-accessed{background-color:#007bff;color:#fff}.status-partially-used{background-color:#ff9800;color:#fff}.status-fully-used{background-color:#28a745;color:#fff}.status-revoked{background-color:#dc3545;color:#fff}.status-entered{background-color:#28a745;color:#fff}.status-not-activated,.status-expired{background-color:#6c757d;color:#fff}.message{padding:12px;border-radius:4px;margin-bottom:16px}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.message.warning{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.message.info{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.container{max-width:1200px;margin:0 auto;padding:20px}.header{background:#fff;padding:16px 20px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.header h1{font-size:24px;margin:0}.header-nav{margin-top:12px;display:flex;gap:12px}.header-nav a{color:#007bff;text-decoration:none;padding:4px 8px;border-radius:4px}.header-nav a:hover{background-color:#f0f0f0}.header-nav a.active{background-color:#007bff;color:#fff}.form-group{margin-bottom:16px}.form-actions{margin-top:24px;display:flex;gap:12px}.list-item{padding:12px;border-bottom:1px solid #eee}.list-item:last-child{border-bottom:none}.list-item:hover{background-color:#f8f8f8}.dark-mode,.dark-mode body,.dark-mode .container{background-color:#1a1a1a;color:#e0e0e0}.dark-mode .header{background:#2d2d2d;color:#e0e0e0;box-shadow:0 2px 4px #0000004d}.dark-mode .header h1{color:#e0e0e0}.dark-mode .header-nav a{color:#64b5f6}.dark-mode .header-nav a:hover{background-color:#3d3d3d;color:#90caf9}.dark-mode .header-nav a.active{background-color:#1976d2;color:#fff}.dark-mode .card{background:#2d2d2d;color:#e0e0e0;box-shadow:0 2px 4px #0000004d}.dark-mode input,.dark-mode textarea,.dark-mode select{background-color:#3d3d3d;color:#e0e0e0;border-color:#555}.dark-mode input:focus,.dark-mode textarea:focus,.dark-mode select:focus{border-color:#64b5f6}.dark-mode label{color:#e0e0e0}.dark-mode .list-item{border-bottom-color:#444}.dark-mode .list-item:hover{background-color:#3d3d3d}.dark-mode .message.success{background-color:#2e7d32;color:#e8f5e9;border-color:#4caf50}.dark-mode .message.error{background-color:#c62828;color:#ffebee;border-color:#ef5350}.dark-mode .message.warning{background-color:#f57c00;color:#fff3e0;border-color:#ff9800}.dark-mode .message.info{background-color:#0277bd;color:#e1f5fe;border-color:#03a9f4}.guest-header{background:#fff}.guest-header h1{color:#333}.guest-header h1 span{color:#666}.guest-header h1 span span{color:#007bff}.guest-qr-container{min-height:100vh;background:#fff;padding:0;margin:0;max-width:100%}.guest-qr-loading,.guest-qr-error{padding:40px 20px;text-align:center;font-size:18px}.guest-qr-header{padding:16px 20px;border-bottom:1px solid #eee;text-align:center}.guest-qr-header h1{font-size:18px;font-weight:500;letter-spacing:1px;color:#333;margin:0;text-transform:uppercase}.guest-qr-content{padding:24px 20px;max-width:600px;margin:0 auto}.guest-qr-event-name{font-size:32px;font-weight:700;letter-spacing:2px;color:#333;margin:0 0 8px;text-transform:uppercase}.qr-code-frame{position:relative;background:#fff;padding:24px;margin:0 auto;max-width:320px}.qr-code-corner{position:absolute;width:24px;height:24px;border:3px solid #000}.qr-code-corner-tl{top:0;left:0;border-right:none;border-bottom:none}.qr-code-corner-tr{top:0;right:0;border-left:none;border-bottom:none}.qr-code-corner-bl{bottom:0;left:0;border-right:none;border-top:none}.qr-code-corner-br{bottom:0;right:0;border-left:none;border-top:none}.qr-code-top-line{position:absolute;top:3px;left:24px;right:24px;height:3px;background:#ff69b4}.qr-code-content{padding:40px 20px 20px;display:flex;justify-content:center;align-items:center;min-height:240px}.qr-code-image{max-width:100%;height:auto}.qr-code-placeholder{width:120px;height:120px;display:flex;align-items:center;justify-content:center}.qr-code-placeholder-icon{width:80px;height:80px;background:#f0f0f0;border-radius:8px;position:relative}.qr-code-placeholder-icon:before{content:"";position:absolute;top:10px;left:10px;width:24px;height:24px;background:#ccc;border-radius:2px}.qr-code-placeholder-icon:after{content:"";position:absolute;bottom:10px;right:10px;width:16px;height:16px;background:#ccc;border-radius:2px}.refresh-dot{width:8px;height:8px;background:#4caf50;border-radius:50%}.guest-initial{width:32px;height:32px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-weight:600;color:#666;font-size:14px}.guest-qr-invited-by strong{color:#333;font-weight:600}.guest-container{min-height:100vh;background:#f5f5f5;padding:0;margin:0;max-width:100%}.guest-loading,.guest-error{padding:40px 20px;text-align:center;font-size:18px}.guest-header{background:#fff;padding:16px 20px;border-bottom:1px solid #eee;text-align:center;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000d}.guest-header h1{font-size:18px;font-weight:500;letter-spacing:1px;color:#333;margin:0;text-transform:uppercase}.guest-tabs{display:flex;background:#fff;border-bottom:1px solid #eee;overflow-x:auto;-webkit-overflow-scrolling:touch;position:sticky;top:57px;z-index:99}.guest-tab{flex:1;min-width:80px;padding:12px 8px;border:none;background:transparent;color:#666;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.guest-tab:hover:not(:disabled){background:#f8f9fa;color:#007bff}.guest-tab.active{color:#007bff;border-bottom-color:#007bff;font-weight:600}.guest-tab:disabled{opacity:.5;cursor:not-allowed}.guest-tab-badge{display:inline-block;margin-left:4px;color:#28a745;font-weight:700}.guest-content{padding:16px;max-width:600px;margin:0 auto}.guest-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;margin-bottom:16px}.guest-section-title{font-size:20px;font-weight:600;color:#333;margin:0 0 20px}.guest-subtitle{font-size:16px;font-weight:600;color:#333;margin:0 0 16px}.guest-description{font-size:14px;color:#666;margin-bottom:20px;line-height:1.6}.guest-info-grid{display:grid;grid-template-columns:1fr;gap:16px}.guest-info-item{display:flex;flex-direction:column;gap:4px}.guest-info-label{font-size:12px;color:#999;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.guest-info-value{font-size:16px;color:#333;font-weight:500}.guest-form-group{margin-bottom:20px}.guest-form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:#333}.guest-input{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:16px;transition:border-color .2s;-webkit-appearance:none;appearance:none}.guest-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.guest-form-actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}.guest-button{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;flex:1;min-width:120px}.guest-button.primary{background:#007bff;color:#fff}.guest-button.primary:hover:not(:disabled){background:#0056b3}.guest-button.secondary{background:#6c757d;color:#fff}.guest-button.secondary:hover:not(:disabled){background:#545b62}.guest-button.danger{background:#dc3545;color:#fff}.guest-button.danger:hover:not(:disabled){background:#c82333}.guest-button.small{padding:6px 12px;font-size:14px;min-width:auto}.guest-button:disabled{opacity:.5;cursor:not-allowed}.guest-button.active{background:#0056b3;box-shadow:0 2px 8px #007bff4d}.guest-entry-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.guest-entry-form{margin-top:24px;padding-top:24px;border-top:1px solid #eee}.guest-info-box{padding:12px;background:#f0f8ff;border-radius:8px;margin-bottom:20px;font-size:14px}.guest-warning-box{padding:12px;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;margin-bottom:20px;font-size:14px}.guest-warning-box strong{color:#856404;display:block;margin-bottom:4px}.guest-warning-box p{margin:4px 0 0;font-size:13px;color:#856404}.guest-success-box{margin-top:16px;padding:16px;background:#e8f5e9;border-radius:8px;font-size:14px}.guest-success-title{color:#2e7d32;font-weight:700;margin-bottom:8px}.guest-url-display{font-size:12px;color:#666;word-break:break-all;font-family:monospace;margin-bottom:8px}.guest-url-hint{font-size:12px;color:#666}.guest-verified-box{display:flex;flex-direction:column;align-items:center;padding:32px 20px;text-align:center}.guest-verified-icon{width:64px;height:64px;border-radius:50%;background:#28a745;color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin-bottom:20px}.guest-verified-message h3{font-size:20px;font-weight:600;color:#28a745;margin:0 0 8px}.guest-verified-message p{font-size:14px;color:#666;margin:0;line-height:1.6}.guest-children-list{margin-top:20px}.guest-children-list h4{font-size:14px;font-weight:600;margin-bottom:12px;color:#333}.guest-children-list ul{list-style:none;padding:0;margin:0}.guest-children-list li{padding:12px;background:#f8f9fa;margin-bottom:8px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;font-size:14px}.guest-qr-list{margin-top:32px;padding-top:24px;border-top:1px solid #eee}.guest-qr-item{padding:16px;border:1px solid #ddd;border-radius:8px;margin-bottom:12px;background:#f9f9f9}.guest-qr-item-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.guest-qr-item-header h4{margin:0;font-size:16px;font-weight:600}.guest-qr-item-info{font-size:14px;color:#666}.guest-qr-event-info{text-align:center;margin-bottom:32px}.guest-qr-event-name{font-size:28px;font-weight:700;letter-spacing:2px;color:#333;margin:0 0 8px;text-transform:uppercase}.guest-qr-event-date{font-size:14px;color:#999;margin:0}.guest-qr-code-area{margin:32px 0}.guest-qr-refresh{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#f5f5f5;border-radius:8px;margin:24px auto;max-width:200px;font-size:14px;color:#666}.guest-qr-footer{display:flex;justify-content:space-between;align-items:center;margin-top:40px;padding-top:24px;border-top:1px solid #eee}.guest-qr-invited-by{display:flex;align-items:center;gap:12px;font-size:14px;color:#666}.guest-qr-price{font-size:18px;font-weight:700;color:#333}@media(max-width:768px){.container{padding:12px}.debug-panel{width:calc(100% - 40px);max-height:300px}.guest-header{padding:12px 16px}.guest-header h1{font-size:16px}.guest-tabs{top:49px}.guest-tab{padding:10px 6px;font-size:12px;min-width:70px}.guest-content{padding:12px}.guest-card{padding:16px;border-radius:8px}.guest-section-title{font-size:18px;margin-bottom:16px}.guest-subtitle{font-size:15px}.guest-info-grid{gap:12px}.guest-info-value{font-size:15px}.guest-input{padding:10px 14px;font-size:16px}.guest-button{padding:10px 20px;font-size:15px}.guest-entry-buttons{grid-template-columns:1fr}.guest-form-actions{flex-direction:column}.guest-form-actions .guest-button{width:100%}.guest-qr-event-name{font-size:24px}.qr-code-frame{max-width:280px;padding:20px}.guest-qr-footer{flex-direction:column;gap:16px;align-items:flex-start}.guest-children-list li{flex-direction:column;align-items:flex-start;gap:8px}.guest-qr-item-header{flex-direction:column;gap:12px;align-items:flex-start}.guest-qr-item-header .guest-button{width:100%}}@media(max-width:480px){.guest-header h1{font-size:14px}.guest-tab{padding:8px 4px;font-size:11px;min-width:60px}.guest-content{padding:8px}.guest-card{padding:12px}.guest-section-title{font-size:16px}.guest-qr-event-name{font-size:20px}.qr-code-frame{max-width:240px;padding:16px}}
