*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--gold: #c8a97e;--gold-dark: #8b5e3c;--gold-light: #f0d9b5;--cream: #fdf6e3;--cream-dark: #f5ecd4;--dark: #1a1208;--dark-mid: #2d2010;--text: #3d2b1a;--text-light: #7a6040;--white: #ffffff;--red: #c0392b;--green: #27ae60;--blue: #2980b9;--shadow: 0 2px 12px rgba(139,94,60,.12);--shadow-lg: 0 8px 32px rgba(139,94,60,.16);--radius: 10px;--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif}html{font-size:16px}body{font-family:var(--font-body);background:var(--cream);color:var(--text);min-height:100vh;overflow-x:hidden}h1,h2,h3,.display{font-family:var(--font-display)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--cream-dark)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s;text-decoration:none;min-height:36px;white-space:nowrap}.btn-primary{background:var(--gold);color:var(--dark)}.btn-primary:hover{background:var(--gold-dark);color:var(--white)}.btn-outline{background:transparent;border:1.5px solid var(--gold);color:var(--gold-dark)}.btn-outline:hover{background:var(--gold-light)}.btn-danger{background:var(--red);color:#fff}.btn-sm{padding:5px 11px;font-size:12px}.btn-ghost{background:transparent;color:var(--text-light)}.btn-ghost:hover{background:var(--cream-dark)}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:#fff;border-radius:var(--radius);border:1px solid var(--gold-light);box-shadow:var(--shadow);padding:20px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}.form-input{width:100%;padding:9px 12px;border:1.5px solid var(--gold-light);border-radius:8px;font-family:var(--font-body);font-size:14px;color:var(--text);background:#fff;transition:border-color .2s;outline:none}.form-input:focus{border-color:var(--gold)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b5e3c' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600}.badge-green{background:#d4edda;color:#155724}.badge-red{background:#f8d7da;color:#721c24}.badge-gold{background:var(--gold-light);color:var(--gold-dark)}.badge-blue{background:#cce5ff;color:#004085}.badge-gray{background:#f0f0f0;color:#666}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:14px}thead{background:var(--cream-dark)}th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light)}td{padding:11px 14px;border-bottom:1px solid var(--gold-light)}tr:hover td{background:var(--cream)}.stat-card{background:#fff;border-radius:var(--radius);border:1px solid var(--gold-light);padding:20px;display:flex;flex-direction:column;gap:6px}.stat-value{font-size:32px;font-weight:700;font-family:var(--font-display);color:var(--gold-dark)}.stat-label{font-size:12px;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.seat-grid{display:flex;flex-direction:column;gap:4px;min-width:max-content}.seat-row{display:flex;align-items:center;gap:4px}.seat-row-label{width:28px;text-align:right;font-size:11px;font-weight:700;color:var(--text-light);flex-shrink:0}.seat{width:68px;height:42px;border-radius:6px 6px 3px 3px;cursor:pointer;font-size:11px;font-weight:700;border:1.5px solid transparent;transition:all .15s;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.seat:hover{transform:scale(1.15);z-index:10}.seat.available{background:#e8f5e9;border-color:#81c784;color:#2e7d32}.seat.occupied{background:var(--gold);border-color:var(--gold-dark);color:var(--dark)}.seat.blocked{background:#f5f5f5;border-color:#ccc;color:#aaa;cursor:not-allowed}.seat.selected{background:var(--dark);border-color:var(--gold);color:var(--gold);transform:scale(1.15)}.seat.checked-in{background:var(--green);border-color:#1e8449;color:#fff}.seat-content{display:flex;min-width:0;width:100%;flex-direction:column;align-items:center;gap:2px}.seat-number{font-size:10px;line-height:1;opacity:.9;font-weight:900}.seat-guest-name{display:block;width:100%;padding:0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;line-height:1.15;font-size:10px;font-weight:800}.stage{background:linear-gradient(135deg,var(--dark),var(--dark-mid));color:var(--gold);text-align:center;padding:8px;border-radius:6px;font-size:12px;letter-spacing:2px;margin-bottom:16px;font-family:var(--font-display)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:14px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{padding:20px 24px;border-bottom:1px solid var(--gold-light);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--gold-light);display:flex;justify-content:flex-end;gap:10px}.layout{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--dark);flex-shrink:0;display:flex;flex-direction:column}.sidebar-brand{padding:24px 20px 16px;border-bottom:1px solid rgba(200,169,126,.2)}.main-content{flex:1;overflow-y:auto}.page{padding:28px;max-width:1200px;margin:0 auto}.seat-map-page.has-guest-panel{padding-right:320px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{font-size:26px;color:var(--dark)}.mobile-topbar,.mobile-nav{display:none}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 900px){.grid-4,.grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.text-center{text-align:center}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-muted{color:var(--text-light)}.font-bold{font-weight:700}.hall-guest-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.hall-guest-list{display:flex;flex-direction:column;gap:10px}.hall-guest-item{display:grid;grid-template-columns:92px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;background:var(--cream);border:1px solid var(--gold-light);border-radius:8px}.hall-seat-chip{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;border-radius:7px;background:#fff;color:var(--gold-dark);font-weight:800;border:1px solid var(--gold-light)}.hall-guest-main{min-width:0}.hall-guest-name{font-size:16px;font-weight:800;color:var(--dark);overflow-wrap:anywhere}.hall-guest-meta{display:flex;align-items:center;gap:5px;margin-top:3px;color:var(--text-light);font-size:13px}.hall-guest-status{justify-self:end}.checkin-card{margin-bottom:24px;text-align:center;padding:32px}.checkin-mode-tabs{display:inline-flex;gap:8px;padding:4px;margin-bottom:18px;background:var(--cream);border:1px solid var(--gold-light);border-radius:10px}.qr-scanner-box{position:relative;width:min(100%,360px);aspect-ratio:1;margin:0 auto 18px;overflow:hidden;border-radius:12px;background:var(--dark);border:1px solid var(--gold-light)}.qr-scanner-video{width:100%;height:100%;object-fit:cover}.qr-scanner-frame{position:absolute;top:16%;right:16%;bottom:16%;left:16%;border:3px solid var(--gold);border-radius:14px;box-shadow:0 0 0 999px #00000047;pointer-events:none}.qr-scanner-status{position:absolute;left:12px;right:12px;bottom:12px;padding:8px 10px;border-radius:8px;background:#1a1208c7;color:var(--gold);font-size:13px;font-weight:700}.checkin-manual-form{display:flex;gap:10px;max-width:420px;margin:0 auto}.guest-seat-picker{margin:4px 0 16px;padding:12px;background:var(--cream);border:1px solid var(--gold-light);border-radius:8px}.guest-seat-picker-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.guest-seat-picker-scroll{overflow:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.guest-seat-picker-grid{display:flex;flex-direction:column;gap:4px;min-width:max-content}.guest-seat-picker-row{display:flex;align-items:center;gap:4px}.guest-seat-picker-label{width:24px;flex-shrink:0;text-align:right;font-size:11px;font-weight:800;color:var(--text-light)}.guest-seat-picker-seat{width:30px;height:30px;border-radius:5px;border:1px solid transparent;font-size:11px;font-weight:800;cursor:pointer}.guest-seat-picker-seat.available{background:#e8f5e9;border-color:#81c784;color:#2e7d32}.guest-seat-picker-seat.selected{background:var(--dark);border-color:var(--gold);color:var(--gold)}.guest-seat-picker-seat.occupied{background:var(--gold);border-color:var(--gold-dark);color:var(--dark);cursor:not-allowed;opacity:.68}.guest-seat-picker-seat.blocked{background:#f5f5f5;border-color:#ccc;color:#999;cursor:not-allowed}.ticket-save-notice{padding:12px 14px;background:var(--cream);border:1px solid var(--gold-light);border-radius:8px;color:var(--text-light);font-size:13px;font-weight:600}@media (max-width: 900px){body{padding-bottom:70px}.layout{display:block;min-height:100vh}.sidebar{display:none}.main-content{min-height:100vh;overflow:visible}.mobile-topbar{position:sticky;top:0;z-index:90;display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 14px;background:var(--dark);border-bottom:1px solid rgba(200,169,126,.24)}.mobile-topbar .btn-ghost{color:#ffffffb8}.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:900;display:grid;grid-template-columns:repeat(6,1fr);background:var(--dark);border-top:1px solid rgba(200,169,126,.24);padding:6px 4px calc(6px + env(safe-area-inset-bottom));box-shadow:0 -8px 24px #1a12083d}.mobile-nav-link{min-width:0;display:flex;flex-direction:column;align-items:center;gap:3px;color:#ffffff94;text-decoration:none;font-size:10px;font-weight:600;padding:4px 2px;border-radius:8px}.mobile-nav-link span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav-link.active{color:var(--gold);background:#c8a97e1f}.page{width:100%;padding:18px 14px;max-width:none}.seat-map-page.has-guest-panel{padding-right:14px}.page-header{align-items:flex-start;flex-direction:column;gap:12px;margin-bottom:18px}.page-header>.btn,.page-header>a.btn,.page-header>button.btn{width:100%;justify-content:center}.page-title{font-size:24px;line-height:1.15}.card{padding:16px;border-radius:8px}.checkin-card{padding:22px 16px}.stat-card{padding:16px}.stat-value{font-size:28px}.table-wrapper{margin:0 -1px}table{min-width:720px;font-size:13px}th,td{padding:10px 11px}.modal-overlay{align-items:flex-end;padding:12px}.modal{max-height:calc(100vh - 24px);border-radius:12px}.modal-header{padding:16px 18px}.modal-body{padding:18px}.modal-footer{padding:14px 18px;flex-direction:column-reverse}.modal-footer .btn{width:100%;justify-content:center}.seat-grid{gap:5px;padding:2px 0 8px}.seat-row{gap:5px}.seat-row-label{width:24px}.seat{width:64px;height:40px;font-size:10px}.seat:hover{transform:none}.stage{min-width:max-content;padding:9px 18px}.guest-info-panel{left:10px!important;right:10px!important;top:auto!important;bottom:82px!important;width:auto!important;max-height:55vh;overflow-y:auto;border-radius:12px!important}.hall-guest-item{grid-template-columns:82px minmax(0,1fr)}.hall-guest-status{grid-column:2;justify-self:start}.checkin-manual-form{flex-direction:column}.checkin-manual-form .btn{justify-content:center;width:100%}.guest-seat-picker-header{flex-direction:column}}@media (max-width: 600px){html{font-size:15px}.page{padding:14px 10px}.page-title{font-size:22px}.grid-4,.grid-3,.grid-2{gap:12px}.card{padding:14px}.btn{width:auto;min-height:40px}.form-input{min-height:40px;font-size:16px}.form-label{letter-spacing:0}.mobile-nav-link{font-size:9px}.stat-card{padding:14px}.stat-value{font-size:25px}.stat-label{letter-spacing:0}.badge{white-space:nowrap}.checkin-mode-tabs{display:grid;grid-template-columns:1fr 1fr;width:100%}.checkin-mode-tabs .btn{justify-content:center;width:100%}.qr-scanner-box{width:100%}.hall-guest-header{flex-direction:column}.hall-guest-item{grid-template-columns:1fr}.hall-seat-chip,.hall-guest-status{justify-self:start}.hall-guest-status{grid-column:auto}.modal-overlay{padding:0}.modal{max-height:92vh;border-radius:14px 14px 0 0}.seat{width:62px;height:40px}}@media (max-width: 420px){.mobile-nav{grid-template-columns:repeat(3,1fr);row-gap:4px}body{padding-bottom:116px}.guest-info-panel{bottom:126px!important}}
