*{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:#f7f7f7;color:#1a1a1a;font-weight:300}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}button{padding:10px 20px;border:1px solid hsl(0,0%,70%);border-radius:0;background-color:#f2f2f2;color:#1a1a1a;cursor:pointer;font-size:16px;font-weight:400;transition:background-color .2s,border-color .2s}button:hover:not(:disabled){background-color:#d9d9d9;border-color:#999}button:disabled{background-color:#e6e6e6;color:#999;cursor:not-allowed;border-color:#d9d9d9}button.secondary{background-color:#e6e6e6;border-color:#bfbfbf}button.secondary:hover:not(:disabled){background-color:#ccc;border-color:#a6a6a6}button.danger{background-color:#ef4343;color:#fff;border-color:#eb1414}button.danger:hover:not(:disabled){background-color:#ed2c2c;border-color:#d31212}input,textarea,select{padding:8px 12px;border:1px solid hsl(0,0%,85%);border-radius:0;font-size:16px;font-weight:300;width:100%;background-color:#fff;color:#1a1a1a}input:focus,textarea:focus,select:focus{outline:none;border-color:#999}label{display:block;margin-bottom:4px;font-weight:400;color:#1a1a1a}.card{background:#fff;border:1px solid hsl(0,0%,85%);border-radius:4px;padding:20px;box-shadow:0 1px 2px #0000000d;margin-bottom:20px}.debug-panel{position:fixed;bottom:20px;right:20px;width:400px;max-height:500px;background:#262626;color:#e6e6e6;border:1px solid hsl(0,0%,30%);border-radius:4px;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:#e6e6e6;margin-bottom:12px;font-size:14px;font-weight:400}.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:#404040;border:1px solid hsl(0,0%,35%);border-radius:0;color:#e6e6e6;cursor:pointer;z-index:1001;font-weight:400}.debug-panel .toggle-btn:hover{background:#595959;border-color:#737373}.debug-toggle-btn{position:fixed;bottom:20px;right:20px;padding:8px 16px;font-size:12px;background:#262626;color:#e6e6e6;border:1px solid hsl(0,0%,35%);border-radius:4px;cursor:pointer;z-index:1000;font-family:Courier New,monospace;font-weight:400;box-shadow:0 4px 12px #0000004d}.debug-toggle-btn:hover{background:#404040;border-color:#737373}.status-badge{display:inline-block;padding:4px 8px;border-radius:0;font-size:12px;font-weight:400;border:1px solid hsl(0,0%,70%)}.status-pending{background-color:#f2f2f2;color:#4d4d4d;border-color:#ccc}.status-activated{background-color:#e6e6e6;color:#333;border-color:#bfbfbf}.status-accessed{background-color:#d9d9d9;color:#1a1a1a;border-color:#b3b3b3}.status-partially-used{background-color:#ef4343;color:#fff;border-color:#eb1414}.status-fully-used{background-color:#333;color:#f2f2f2;border-color:#262626}.status-revoked{background-color:#ef4343;color:#fff;border-color:#eb1414}.status-entered{background-color:#4d4d4d;color:#f2f2f2;border-color:#404040}.status-not-activated,.status-expired{background-color:#e6e6e6;color:#666;border-color:#ccc}.message{padding:12px;border-radius:0;margin-bottom:16px;border:1px solid;font-weight:400}.message.success{background-color:#fafafa;color:#333;border-color:#d9d9d9}.message.error{background-color:#fef6f6;color:#bc1010;border-color:#ef4343}.message.warning{background-color:#f5f5f5;color:#4d4d4d;border-color:#ccc}.message.info{background-color:#f7f7f7;color:#404040;border-color:#d9d9d9}.container{max-width:1200px;margin:0 auto;padding:20px;background-color:#f7f7f7;color:#1a1a1a}.header{background:#fff;border-bottom:1px solid hsl(0,0%,85%);padding:16px 20px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.header h1{font-size:24px;font-weight:500;margin:0;color:#1a1a1a}.header-nav{margin-top:12px;display:flex;gap:12px}.header-nav a{color:#4d4d4d;text-decoration:none;padding:4px 8px;border-radius:0;font-weight:400;border-bottom:1px solid transparent;transition:color .2s,border-color .2s}.header-nav a:hover{color:#1a1a1a;border-bottom-color:#b3b3b3}.header-nav a.active{color:#1a1a1a;border-bottom-color:#1a1a1a;font-weight:500}.form-group{margin-bottom:16px}.form-actions{margin-top:24px;display:flex;gap:12px}.list-item{padding:12px;border-bottom:1px solid hsl(0,0%,85%)}.list-item:last-child{border-bottom:none}.list-item:hover{background-color:#f5f5f5}.dark-mode,.dark-mode body,.dark-mode .container{background-color:#1a1a1a;color:#e6e6e6}.dark-mode .header{background:#262626;border-bottom-color:#4d4d4d;color:#e6e6e6}.dark-mode .header h1{color:#e6e6e6}.dark-mode .header-nav a{color:#b3b3b3}.dark-mode .header-nav a:hover{color:#e6e6e6;border-bottom-color:gray}.dark-mode .header-nav a.active{color:#e6e6e6;border-bottom-color:#e6e6e6}.dark-mode .card{background:#262626;border-color:#4d4d4d;color:#e6e6e6;box-shadow:0 1px 2px #0000004d}.dark-mode input,.dark-mode textarea,.dark-mode select{background-color:#262626;color:#e6e6e6;border-color:#595959}.dark-mode input:focus,.dark-mode textarea:focus,.dark-mode select:focus{border-color:gray}.dark-mode label{color:#d9d9d9}.dark-mode .list-item{border-bottom-color:#4d4d4d}.dark-mode .list-item:hover{background-color:#2e2e2e}.dark-mode .message.success{background-color:#262626;color:#d9d9d9;border-color:#595959}.dark-mode .message.error{background-color:#5e0808;color:#f9b9b9;border-color:#ef4343}.dark-mode .message.warning{background-color:#2e2e2e;color:#ccc;border-color:#666}.dark-mode .message.info{background-color:#292929;color:#d9d9d9;border-color:#595959}.dark-mode-toggle{width:40px;height:20px;cursor:pointer;appearance:none;background-color:#ccc;border:1px solid hsl(0,0%,70%);border-radius:0;position:relative;transition:background-color .2s;flex-shrink:0}.dark-mode-toggle:checked{background-color:#ef4343;border-color:#eb1414}.dark-mode-toggle:before{content:"";position:absolute;width:16px;height:16px;top:1px;left:1px;background-color:#fff;border:1px solid hsl(0,0%,70%);transition:transform .2s}.dark-mode-toggle:checked:before{transform:translate(20px)}.dark-mode .dark-mode-toggle{background-color:#666;border-color:gray}.dark-mode .dark-mode-toggle:checked{background-color:#ef4343;border-color:#eb1414}.guest-header{background:#fff}.guest-header h1{color:#333}.guest-header h1 span{color:#666}.guest-header h1 span span{color:#4d4d4d}.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:#f5f5f5;color:#1a1a1a}.guest-tab.active{color:#1a1a1a;border-bottom-color:#1a1a1a;font-weight:500}.guest-tab:disabled{opacity:.5;cursor:not-allowed}.guest-tab-badge{display:inline-block;margin-left:4px;color:#4d4d4d;font-weight:400}.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:#999;box-shadow:0 0 0 3px #0000000d}.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:#333;color:#f2f2f2;border:1px solid hsl(0,0%,30%)}.guest-button.primary:hover:not(:disabled){background:#4d4d4d;border-color:#666}.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:#4d4d4d;border-color:#666;box-shadow:0 2px 8px #0000001a}.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:#333;color:#f2f2f2;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:500;margin-bottom:20px;border:1px solid hsl(0,0%,30%)}.guest-verified-message h3{font-size:20px;font-weight:500;color:#1a1a1a;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;background-color:#fff;color:#333}.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}}
