*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:#0d0d0d;margin:0}#root{width:100%;margin:0 auto}.qr-modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:100;background:#0f172ad9;justify-content:center;align-items:center;padding:16px;animation:.2s qr-fade;display:flex;position:fixed;inset:0}@keyframes qr-fade{0%{opacity:0}to{opacity:1}}.qr-modal{background:#fff;border-radius:24px;flex-direction:column;width:100%;max-width:440px;max-height:90vh;padding:20px 20px 24px;animation:.25s cubic-bezier(.16,1,.3,1) qr-pop;display:flex;box-shadow:0 32px 80px #00000080}@keyframes qr-pop{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.qr-modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.qr-modal-title{color:#1f2937;margin:0;font-size:1.2rem;font-weight:800}.qr-modal-close{color:#6b7280;cursor:pointer;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:background .2s;display:flex}.qr-modal-close:hover{color:#1f2937;background:#e5e7eb}.qr-modal-viewport{aspect-ratio:1;background:#000;border-radius:16px;width:100%;margin-bottom:16px;position:relative;overflow:hidden}.qr-modal-scanner{width:100%;height:100%}.qr-modal-scanner>video{object-fit:cover;width:100%!important;height:100%!important}.qr-modal-status{color:#fff;text-align:center;background:#0f172ad9;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex;position:absolute;inset:0}.qr-modal-status p{margin:0;font-size:.95rem;line-height:1.5}.qr-modal-status.error p{font-size:1rem;font-weight:600}.qr-modal-hint{color:#ffffffbf;font-size:.85rem!important;font-weight:400!important}.qr-modal-spinner{border:4px solid #fff3;border-top-color:#fff;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite qr-spin}@keyframes qr-spin{to{transform:rotate(360deg)}}.qr-modal-foot{color:#6b7280;text-align:center;margin:0;font-size:.85rem}@font-face{font-family:NanumSquareNeo;src:url(/fonts/NanumSquareNeo-dEb.ttf)format("truetype");font-weight:800;font-style:normal;font-display:swap}:root{--bg:#0a0707;--bg-elev:#14090b;--ticket-bg:#15090c;--ticket-bg-2:#1c0d10;--stub-bg:#100507;--deep-red:#b91c2a;--burgundy:#5c0a12;--cream:#f5e8c7;--gold:#c9a24a;--gold-dim:#8b7339;--text:#e8dcc0;--text-dim:#9a8a6e;--plus:#4ade80;--minus:#f87171}*{box-sizing:border-box}html,body,#root{background:var(--bg);min-height:100%;margin:0;padding:0}body{color:var(--text);background:radial-gradient(ellipse at top, #5c0a122e, transparent 55%), var(--bg);font-family:NanumSquareNeo,Noto Sans KR,system-ui,sans-serif}.app-root{flex-direction:column;gap:clamp(14px,3.6vw,20px);width:100%;max-width:480px;min-height:100vh;margin:0 auto;padding:clamp(16px,4.5vw,22px) clamp(14px,4vw,20px) clamp(24px,7vw,36px);display:flex;position:relative}.app-header{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:14px;padding:4px 2px 8px;display:grid}.user-section{align-items:center;gap:10px;min-width:0;display:flex}.avatar{object-fit:cover;border:1px solid var(--gold-dim);background:var(--bg-elev);border-radius:50%;flex-shrink:0;width:36px;height:36px;box-shadow:0 0 0 2px #c9a24a14}.avatar-fallback{background:var(--burgundy);width:36px;height:36px;color:var(--cream);border:1px solid var(--gold-dim);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:800;display:flex;box-shadow:0 0 0 2px #c9a24a14}.username{color:var(--text);white-space:nowrap;text-overflow:ellipsis;letter-spacing:.01em;font-size:.86rem;font-weight:800;overflow:hidden}.app-title{color:var(--cream);letter-spacing:.22em;text-align:center;text-shadow:0 0 14px #b91c2a66;white-space:nowrap;margin:0;padding:0 4px;font-family:Cinzel,serif;font-size:1rem;font-weight:900}.btn-refresh{appearance:none;border:1px solid var(--gold-dim);color:var(--gold);cursor:pointer;letter-spacing:.04em;background:0 0;border-radius:999px;justify-self:end;align-items:center;gap:4px;padding:7px 12px;font-family:inherit;font-size:.72rem;font-weight:800;transition:background .15s,border-color .15s;display:inline-flex}.btn-refresh:hover{border-color:var(--gold);background:#c9a24a1a}.btn-refresh:disabled{opacity:.45;cursor:not-allowed}.ticket-card{aspect-ratio:933/2157;background:url(/ticket-art.webp) 50%/cover no-repeat;border-radius:14px;width:100%;position:relative;overflow:hidden;box-shadow:0 0 0 1px #0006,0 22px 50px #000000a6,0 0 80px #b91c2a1a}.ticket-life-overlay{text-align:center;z-index:2;width:80%;position:absolute;top:54%;left:50%;transform:translate(-50%)}.life-label{letter-spacing:.34em;color:var(--cream);text-transform:uppercase;text-shadow:0 1px 4px #000000b3;justify-content:center;align-items:center;gap:clamp(8px,2.5vw,12px);margin-bottom:clamp(6px,1.6vw,9px);font-family:Cinzel,serif;font-size:clamp(.6rem,2vw,.72rem);display:flex}.life-label:before,.life-label:after{content:"";background:linear-gradient(90deg,#0000,#f5e8c7bf);width:clamp(20px,6.5vw,30px);height:1px;display:inline-block}.life-label:after{background:linear-gradient(90deg,#f5e8c7bf,#0000)}.life-row{justify-content:center;align-items:baseline;gap:clamp(6px,1.8vw,10px);display:flex}.life-value{color:var(--cream);font-variant-numeric:tabular-nums;letter-spacing:-.01em;text-shadow:0 2px 6px #000000e6,0 0 28px #140507a6;font-size:clamp(2rem,9vw,2.7rem);font-weight:800;line-height:1}.life-max{color:#f5e8c7c7;font-variant-numeric:tabular-nums;text-shadow:0 1px 3px #000000bf;font-size:clamp(.72rem,2.8vw,.92rem);font-weight:800}.ticket-qr-overlay{z-index:2;flex-direction:column;align-items:center;gap:clamp(8px,2.4vw,12px);width:clamp(150px,46vw,230px);display:flex;position:absolute;top:66%;left:50%;transform:translate(-50%)}.qr-frame{aspect-ratio:1;background:var(--cream);border:1px solid #0000008c;border-radius:clamp(4px,1.4vw,7px);justify-content:center;align-items:center;width:100%;padding:clamp(7px,2.4vw,12px);display:flex;position:relative;box-shadow:0 0 0 3px #f5e8c74d,0 0 0 4px #00000080,0 6px 18px #0009}.qr-frame>svg{width:100%;height:100%;display:block}.qr-frame:before,.qr-frame:after{content:"";border-style:solid;border-color:#f5e8c7f2;width:clamp(10px,3.4vw,16px);height:clamp(10px,3.4vw,16px);position:absolute}.qr-frame:before{border-width:1px 0 0 1px;top:-7px;left:-7px}.qr-frame:after{border-width:0 1px 1px 0;bottom:-7px;right:-7px}.qr-label{letter-spacing:.36em;color:var(--cream);text-shadow:0 1px 3px #000000e6;align-items:center;gap:clamp(6px,1.8vw,10px);font-family:Cinzel,serif;font-size:clamp(.55rem,1.9vw,.68rem);font-weight:700;display:flex}.qr-label:before,.qr-label:after{content:"";background:#f5e8c7b3;width:clamp(10px,3.4vw,16px);height:1px;display:inline-block}.details-card{background:var(--bg-elev);border:1px solid #c9a24a2e;border-radius:14px;overflow:hidden}.details-header{appearance:none;cursor:pointer;width:100%;color:inherit;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:14px 18px;font-family:inherit;transition:background .15s;display:flex}.details-header:hover{background:#c9a24a0d}.details-card.is-open .details-header{border-bottom:1px solid #c9a24a1f}.details-title{color:var(--cream);letter-spacing:.02em;align-items:center;gap:8px;margin:0;font-size:.95rem;font-weight:800;display:flex}.details-title .icon{color:var(--gold);font-size:1rem}.details-chevron{color:var(--gold-dim);font-size:.72rem;transition:color .15s}.details-header:hover .details-chevron{color:var(--gold)}.details-body{flex-direction:column;gap:12px;padding:8px 18px 16px;animation:.18s recordsFadeIn;display:flex}.detail-row{border-bottom:1px dashed #c9a24a1f;grid-template-columns:90px 1fr;align-items:baseline;gap:10px;padding-bottom:9px;display:grid}.detail-row:last-child{border-bottom:none;padding-bottom:0}.detail-label{letter-spacing:.18em;color:var(--gold-dim);text-transform:uppercase;font-family:Cinzel,serif;font-size:.66rem;font-weight:700}.detail-value{color:var(--cream);letter-spacing:.01em;word-break:break-all;font-size:.92rem;font-weight:800}.detail-value.serial{letter-spacing:.08em;color:var(--gold);text-shadow:0 0 8px #c9a24a40;font-family:Cinzel,serif;font-size:.9rem}.ticket-hint{text-align:center;color:var(--text-dim);justify-content:center;align-items:center;gap:6px;margin:0;font-size:.78rem;display:flex}.ticket-hint .icon{color:var(--gold)}.records-card{background:var(--bg-elev);border:1px solid #c9a24a2e;border-radius:14px;overflow:hidden}.records-header{appearance:none;cursor:pointer;width:100%;color:inherit;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;font-family:inherit;transition:background .15s;display:flex}.records-header:hover{background:#c9a24a0d}.records-card.is-open .records-header{border-bottom:1px solid #c9a24a1f}.records-header-left{flex:1;min-width:0}.records-title{color:var(--cream);letter-spacing:.02em;align-items:center;gap:8px;margin:0;font-size:.95rem;font-weight:800;display:flex}.records-title .icon{color:var(--gold);font-size:1rem}.records-count{height:20px;color:var(--gold);background:#c9a24a26;border-radius:999px;justify-content:center;align-items:center;margin-left:4px;padding:0 8px;font-size:.7rem;font-weight:800;display:inline-flex}.records-preview{color:var(--text-dim);align-items:center;gap:8px;min-width:0;margin:6px 0 0;font-size:.78rem;display:flex}.records-preview .delta-mini{font-variant-numeric:tabular-nums;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;min-width:36px;padding:2px 6px;font-size:.72rem;font-weight:800;display:inline-flex}.records-preview .delta-mini.plus{color:var(--plus);background:#4ade8021}.records-preview .delta-mini.minus{color:var(--minus);background:#f8717121}.records-preview .preview-reason{color:var(--text);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-weight:800;overflow:hidden}.records-preview .preview-time{color:var(--text-dim);white-space:nowrap;flex-shrink:0;margin-left:auto;font-size:.72rem}.records-chevron{color:var(--gold-dim);font-size:.72rem;transition:color .15s}.records-header:hover .records-chevron{color:var(--gold)}.records-body{padding:4px 18px 14px;animation:.18s recordsFadeIn}@keyframes recordsFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.records-list{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.records-empty{color:var(--text-dim);text-align:center;margin:0;padding:8px 0;font-size:.85rem}.record-item{border-bottom:1px dashed #c9a24a1f;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:9px 0;font-size:.85rem;display:grid}.record-item:last-child{border-bottom:none}.delta{text-align:center;font-variant-numeric:tabular-nums;border-radius:4px;min-width:42px;padding:3px 8px;font-size:.8rem;font-weight:800;display:inline-block}.delta.plus{color:var(--plus);background:#4ade8021;border:1px solid #4ade804d}.delta.minus{color:var(--minus);background:#f8717121;border:1px solid #f871714d}.reason{color:var(--text)}.time{color:var(--text-dim);font-size:.75rem}.btn-logout{appearance:none;color:var(--text);cursor:pointer;letter-spacing:.02em;background:#14090b99;border:1px solid #c9a24a66;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:13px;font-family:inherit;font-size:.88rem;font-weight:800;transition:all .18s;display:inline-flex}.btn-logout .icon{color:var(--gold);font-size:.92rem;transition:color .18s}.btn-logout:hover{border-color:var(--deep-red);color:var(--cream);background:#b91c2a1f}.btn-logout:hover .icon{color:var(--deep-red)}.qr-scan-guide{background:var(--bg-elev);text-align:center;border:1px solid #c9a24a47;border-radius:14px;flex-direction:column;align-items:center;gap:12px;margin:18px;padding:28px 22px;display:flex}.qr-scan-guide-icon{color:#c9a24ad9;font-size:56px;line-height:1}.qr-scan-guide h3{color:#f5e8c7f2;margin:0;font-size:1.15rem}.qr-scan-guide p{color:#f5e8c7bf;margin:0;font-size:.92rem;line-height:1.5}.qr-scan-guide ul{color:#f5e8c7b3;text-align:left;margin:8px 0 0;padding:0;font-size:.85rem;line-height:1.7;list-style:none}.qr-scan-guide li{padding-left:14px;position:relative}.qr-scan-guide li:before{content:"·";color:#c9a24ad9;font-size:1.2rem;position:absolute;top:-2px;left:4px}.center-state{background:var(--bg-elev);text-align:center;border:1px solid #c9a24a33;border-radius:14px;flex-direction:column;align-items:center;gap:14px;padding:28px 22px;display:flex}.center-state h2{color:var(--cream);letter-spacing:.12em;margin:0;font-family:Cinzel,serif;font-size:1.2rem;font-weight:700}.center-state p{color:var(--text-dim);margin:0;font-size:.88rem;line-height:1.55}.center-state .hint{color:var(--gold-dim);font-size:.75rem}.btn-cta{appearance:none;border:1px solid var(--deep-red);background:var(--deep-red);color:var(--cream);cursor:pointer;letter-spacing:.04em;border-radius:8px;padding:12px 24px;font-family:inherit;font-size:.95rem;font-weight:800}.btn-cta:hover{background:#991319}.btn-cta:disabled{opacity:.5;cursor:not-allowed}.btn-cta.kakao{color:#191919;background:#fee500;border-color:#fee500}.btn-cta.kakao:hover{filter:brightness(.95)}.loading-state{text-align:center;color:var(--text-dim);padding:40px 20px;font-size:.9rem}.btn-scan{appearance:none;border:1px solid var(--gold-dim);background:linear-gradient(180deg, #c9a24a2e 0%, #c9a24a0f 100%), var(--bg-elev);width:100%;color:var(--cream);letter-spacing:.04em;cursor:pointer;border-radius:14px;justify-content:center;align-items:center;gap:12px;padding:18px 24px;font-family:inherit;font-size:1rem;font-weight:800;transition:transform .1s,box-shadow .2s,border-color .2s,background .2s;display:flex;box-shadow:0 8px 24px #00000059,inset 0 1px #f5e8c70a}.btn-scan:hover{border-color:var(--gold);background:linear-gradient(180deg, #c9a24a47 0%, #c9a24a1a 100%), var(--bg-elev);box-shadow:0 12px 32px #00000073,0 0 0 1px #c9a24a33}.btn-scan:active{transform:scale(.99)}.btn-scan:disabled{opacity:.55;cursor:not-allowed}.btn-scan-icon{background:var(--gold);width:28px;height:28px;color:var(--bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:900;display:inline-flex}.btn-scan-text{text-align:left;flex:1}.toast{z-index:200;text-align:center;letter-spacing:.02em;border-radius:12px;max-width:calc(100vw - 32px);padding:14px 22px;font-size:.95rem;font-weight:700;animation:.3s cubic-bezier(.16,1,.3,1) toast-in;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 16px 40px #0009}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,24px)}to{opacity:1;transform:translate(-50%)}}.toast-success{color:#fff;background:linear-gradient(135deg,#16a34a 0%,#15803d 100%);border:1px solid #4ade8066}.toast-error{color:#fff;background:linear-gradient(135deg,#b91c1c 0%,#7f1d1d 100%);border:1px solid #f8717166}.toast-info{color:var(--cream);background:linear-gradient(135deg,#1f2937 0%,#111827 100%);border:1px solid #c9a24a66}.info-modal-backdrop{-webkit-backdrop-filter:blur(6px);z-index:150;background:#000000bf;justify-content:center;align-items:center;padding:16px;animation:.2s backdrop-in;display:flex;position:fixed;inset:0}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.info-modal{background:var(--bg-elev);border:1px solid var(--gold-dim);text-align:center;border-radius:16px;width:100%;max-width:360px;padding:28px 24px;animation:.25s cubic-bezier(.16,1,.3,1) modal-in;box-shadow:0 32px 80px #000000b3}@keyframes modal-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.info-modal-title{color:var(--cream);letter-spacing:.02em;margin:0 0 14px;font-size:1.1rem;font-weight:800}.info-modal-body{color:var(--text-dim);margin:0 0 22px;font-size:.9rem;line-height:1.6}.info-modal-body strong{color:var(--gold);font-weight:800}.info-modal .btn-cta{width:100%;margin-bottom:8px}.btn-text{appearance:none;color:var(--text-dim);cursor:pointer;background:0 0;border:none;width:100%;padding:8px 12px;font-family:inherit;font-size:.85rem}.btn-text:hover{color:var(--cream)}@media (width>=600px){.app-root{padding:28px 24px 40px}}
