*{box-sizing:border-box}body{font-family:Arial,sans-serif;background:radial-gradient(circle at top,rgba(56,189,248,.16),transparent 32%),radial-gradient(circle at bottom right,rgba(59,130,246,.16),transparent 28%),#f4f4f9;color:#333;margin:0;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:clamp(10px,2.4vh,24px)}body.is-stream-step,body.is-video-result-step{display:block;padding:0;overflow:hidden;background:#000}.toast{position:fixed;top:18px;right:18px;z-index:1000;max-width:min(360px,100vw - 36px);padding:14px 16px;border-radius:14px;background:#0f172af0;color:#fff;box-shadow:0 18px 44px #0f172a47;opacity:0;pointer-events:none;transform:translateY(-10px);transition:opacity .2s ease,transform .2s ease}.toast--visible{opacity:1;transform:translateY(0)}#app{background:#fffffff0;padding:clamp(16px,2.8vh,28px);border-radius:24px;border:1px solid rgba(255,255,255,.65);box-shadow:0 18px 60px #0f172a2e;width:min(720px,100%);min-height:min(1280px,100dvh - clamp(20px,4.8vh,48px));text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}body.is-stream-step #app,body.is-video-result-step #app{width:100vw;min-height:100dvh;padding:0;border:0;border-radius:0;background:#000;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.step{display:none}.step.active{display:block}#step-1.active,#step-2.active{min-height:calc(min(1280px,100dvh) - clamp(52px,5.6vh,72px))}.eyebrow{margin:0 0 10px;color:#007bff;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}h1{margin:0 0 clamp(14px,2vh,24px);font-size:clamp(2rem,5vw,3.4rem)}.location-grid{display:grid;grid-template-columns:1fr;gap:clamp(10px,1.4vh,16px);max-height:min(68dvh,900px);overflow-y:auto;overscroll-behavior:contain;padding-right:4px;scroll-padding-block:4px;scroll-snap-type:y proximity;touch-action:pan-y;scrollbar-width:thin}.location-btn{scroll-snap-align:start;min-height:clamp(58px,6.2vh,82px);border-radius:14px;font-size:clamp(1rem,2.2vh,1.35rem);font-weight:700}button,input,select{font:inherit}button{padding:clamp(12px,1.7vh,18px);border:none;border-radius:8px;background-color:#007bff;color:#fff;cursor:pointer;font-size:1rem;transition:background .3s}button:hover:not(:disabled){background-color:#0062cc}button:disabled{cursor:not-allowed;opacity:.55}.secondary-btn{background-color:#6c757d}.secondary-btn:hover:not(:disabled){background-color:#545b62}.scenario-actions{display:grid;gap:clamp(12px,1.4vh,18px);max-height:100dvh;margin-bottom:0;overflow-y:auto;overscroll-behavior:contain;padding:2px 4px 2px 0;scroll-padding-block:2px;scroll-snap-type:y proximity;touch-action:pan-y;scrollbar-width:thin}.scenario-screen{display:flex;flex-direction:column;gap:clamp(12px,1.6vh,20px)}.scenario-main-panel,.scenario-list-panel{border:1px solid rgba(148,163,184,.22);border-radius:24px;padding:clamp(14px,2vh,24px);background:linear-gradient(180deg,#fffffff5,#f8fafceb);box-shadow:0 12px 28px #0f172a0f}.scenario-main-panel,.scenario-list-panel{min-height:0}.scenario-list-panel{display:grid;grid-template-rows:auto minmax(0,1fr)}.scenario-selection-header{display:grid;gap:clamp(10px,1.4vh,16px);align-items:stretch;margin-bottom:clamp(12px,1.6vh,18px);text-align:left}#back-to-step-1{align-self:start;padding:clamp(9px,1.1vh,12px) 16px;min-height:0}.section-description{margin:0;color:#6c757d;max-width:56ch}.selected-location-card{overflow:hidden;border-radius:22px;background:linear-gradient(180deg,#0f172a,#1e293b);color:#fff;box-shadow:0 16px 36px #0f172a29;min-height:0}.selected-location-card img{display:block;width:100%;aspect-ratio:16/9;max-height:min(31dvh,420px);object-fit:cover}.selected-location-card__content{display:grid;gap:clamp(6px,1vh,10px);padding:clamp(12px,1.6vh,18px)}.selected-location-card__label{margin:0;color:#93c5fd;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.selected-location-card h2{margin:0;font-size:1.35rem}.selected-location-card__description{margin:0;color:#e2e8f0d6;line-height:1.5}.scenario-grid-label{margin:0 0 clamp(10px,1.2vh,14px);color:#6c757d;font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.scenario-btn{display:grid;grid-template-columns:minmax(120px,38%) minmax(0,1fr);gap:0;padding:0;border:1px solid #dbe4ef;min-height:clamp(138px,15vh,188px);border-radius:20px;background:#fff;color:#0f172a;text-align:left;overflow:hidden;box-shadow:0 10px 24px #0f172a14;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;animation:scenarioCardIn .45s ease both;animation-delay:calc(var(--card-index, 0) * 90ms);scroll-snap-align:start}.scenario-btn:hover:not(:disabled){transform:translateY(-4px);border-color:#007bff6b;box-shadow:0 22px 40px #0f172a29;background-color:#fff}.scenario-btn--selected{border-color:#007bffcc;box-shadow:0 22px 42px #007bff29;transform:translateY(-2px)}.scenario-btn--featured{border-color:#f59e0b59;box-shadow:0 14px 28px #f59e0b1a}.scenario-btn__preview{width:100%;height:100%;min-height:100%;object-fit:cover;background:#0f172a}.scenario-btn__body{display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:clamp(8px,1.2vh,12px);padding:clamp(14px,1.8vh,20px)}.scenario-btn__title{font-size:clamp(1.05rem,2.2vh,1.35rem)}.scenario-btn__body strong{font-size:1.1rem}.scenario-btn__description{color:#0f172a;line-height:1.45;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.scenario-btn__cta{justify-self:stretch;margin-top:4px;border-radius:999px;padding:clamp(11px,1.5vh,16px) 18px;font-size:1rem;color:#fff;background:linear-gradient(135deg,#0ea5e9,#2563eb);font-weight:700;box-shadow:0 10px 20px #2563eb38;text-align:center}@keyframes scenarioCardIn{0%{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media (width <= 520px) and (orientation: portrait){body:not(.is-stream-step):not(.is-video-result-step){padding:8px}body:not(.is-stream-step):not(.is-video-result-step) #app{width:min(480px,100%);min-height:min(854px,100dvh - 16px);padding:14px;border-radius:18px}#step-1.active,#step-2.active{min-height:calc(min(854px,100dvh) - 44px)}h1{font-size:clamp(1.9rem,8vw,2.35rem)}.scenario-main-panel,.scenario-list-panel{padding:12px;border-radius:18px}.selected-location-card img{max-height:230px}.selected-location-card__description,.section-description{font-size:.92rem;line-height:1.35}.scenario-btn{grid-template-columns:120px minmax(0,1fr);min-height:136px;border-radius:16px}.scenario-btn__body{padding:12px}.scenario-btn__description{-webkit-line-clamp:2;font-size:.92rem}.scenario-btn__cta{padding:10px 12px}}@media (width >= 700px) and (orientation: portrait){body:not(.is-stream-step):not(.is-video-result-step) #app{width:min(720px,100%);min-height:min(1280px,100dvh - 32px)}.scenario-btn{grid-template-columns:210px minmax(0,1fr);min-height:190px}.scenario-btn__description{-webkit-line-clamp:4}}.step.stream-step{display:none}.step.stream-step.active{display:grid;place-items:center;min-height:100dvh;text-align:center}.stream-layout{display:grid;grid-template-columns:300px 1fr;gap:18px}.hidden{display:none!important}.controls{display:grid;gap:16px;align-content:start;padding:18px;border-radius:12px;background:#f8fafc}label{display:grid;gap:8px;color:#24415f;font-weight:700}input,select{width:100%;border:1px solid #d4dde7;border-radius:8px;padding:12px;color:#333;background:#fff}.checkbox{grid-template-columns:18px 1fr;align-items:center}.button-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stage{position:relative;width:min(100vw,56.25dvh);height:min(100dvh,177.7777777778vw);min-height:0;aspect-ratio:9/16;margin:0 auto;overflow:hidden;padding:0;border-radius:0;background:#000}video{width:100%;height:100%;min-height:0;display:block;object-fit:cover;border-radius:0;background:#000}.status{position:absolute;left:28px;bottom:28px;border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:8px 12px;color:#e0f2fe;background:#020617b8}.countdown{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(18px,4vh,36px);text-align:center;z-index:5;color:#fff;padding:max(24px,env(safe-area-inset-top)) 24px 24px;background:#0000002e;font-size:clamp(7rem,28vw,16rem);font-weight:800;letter-spacing:-.05em;text-shadow:0 12px 30px rgba(0,0,0,.45);pointer-events:none}.countdown__label{position:absolute;top:max(32px,env(safe-area-inset-top));left:50%;white-space:pre-line;width:min(92vw,720px);transform:translate(-50%);font-size:clamp(1.1rem,4vw,2.4rem);font-weight:800;letter-spacing:0;line-height:1.15}.countdown__number{display:inline-block;min-width:1ch;line-height:.9;font-variant-numeric:tabular-nums;transform:translateZ(0)}.record-actions{position:absolute;right:28px;bottom:28px;display:flex;gap:10px;flex-wrap:wrap}.stream-step .record-actions,.stream-step .status{display:none!important}.recording-panel{position:absolute;left:0;right:0;bottom:0;display:grid;gap:10px;padding:12px 16px 16px;border-radius:0;z-index:4;color:#e0f2fe;background:#020617d1}.recording-panel__header{display:flex;justify-content:space-between;gap:12px;align-items:center}.recording-panel p{margin:0;font-weight:700}.step.final-video-step,.step.qr-step{display:none}.step.final-video-step.active,.step.qr-step.active{text-align:left;position:relative;overflow:hidden;border-radius:18px;padding:1rem;background:radial-gradient(circle at top right,rgba(56,189,248,.12),transparent 35%),linear-gradient(180deg,#0f172a05,#0f172a0f)}body.is-video-result-step .final-video-step{display:grid;place-items:center;min-height:100dvh;padding:0;border-radius:0;background:#000}body.is-video-result-step .final-video-step:before{display:none}body.is-video-result-step .final-video-step>.eyebrow,body.is-video-result-step .final-video-step>h1{display:none}.final-video-step:before,.qr-step:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(135deg,rgba(255,255,255,.3),transparent 30%,transparent 70%,rgba(255,255,255,.18));mix-blend-mode:screen}.final-video-card{display:grid;gap:14px;border-radius:24px;padding:18px;background:linear-gradient(180deg,#0f172af5,#0f172ae0);box-shadow:0 18px 40px #0f172a3d;border:1px solid rgba(255,255,255,.08)}.final-video-player{display:none}body.is-video-result-step .final-video-card{width:min(100vw,56.25dvh);height:min(100dvh,177.7777777778vw);min-height:0;aspect-ratio:9/16;grid-template-rows:minmax(0,1fr) auto;gap:10px;margin:0 auto;padding:10px;border-radius:0;background:#000;box-shadow:none;position:relative}.final-video-card video{width:100%;min-height:460px;border-radius:18px;background:#000;box-shadow:inset 0 0 0 1px #ffffff14}body.is-video-result-step .final-video-card video{min-height:0;border-radius:0;object-fit:cover;box-shadow:none}.final-qr-panel{display:grid;grid-template-columns:1fr;gap:16px;align-items:center;border-radius:18px;padding:16px;color:#e2e8f0;background:#0f172ab8;text-align:center}.final-qr-panel__copy{display:grid;gap:4px}.final-qr-panel__copy strong{color:#f8fafc;font-size:1.05rem}.final-qr-panel__copy span{color:#cbd5e1}.final-qr-panel__qr{display:grid;place-items:center;justify-self:center;border-radius:14px;padding:10px;background:#fff}.final-qr-panel__qr img{width:140px;aspect-ratio:1;object-fit:contain}.final-qr-panel .download-link{display:inline-flex;justify-content:center;justify-self:stretch;white-space:nowrap;border-radius:12px;padding:12px 16px;color:#fff;background:#3b82f6b8;font-weight:700;text-decoration:none}body.is-video-result-step .final-qr-panel{position:absolute;top:50%;left:50%;display:grid;grid-template-columns:1fr;gap:10px;width:min(360px,100% - 20px);padding:12px;border-radius:16px;text-align:center;transform:translate(-50%,-50%);z-index:1}body.is-video-result-step .final-qr-panel__copy span{display:none}body.is-video-result-step .final-qr-panel__copy .final-qr-panel__countdown{display:block;color:#93c5fd;font-weight:700}body.is-video-result-step .final-qr-panel__qr{justify-self:center;padding:8px}body.is-video-result-step .final-qr-panel__qr img{width:min(42vw,160px)}.upload-panel{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;gap:14px;padding:24px;text-align:center;color:#f8fafc;background:#020617b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.upload-panel p{max-width:32rem;margin:0;font-size:clamp(1rem,3vw,1.35rem);font-weight:700;line-height:1.35}.upload-spinner{width:56px;height:56px;border:5px solid rgba(255,255,255,.18);border-top-color:#38bdf8;border-radius:50%;animation:spin .9s linear infinite}.upload-status{min-height:1.2em;color:#bfdbfe;font-size:.95rem}.recording-timer{color:#93c5fd;font-size:.95rem;font-weight:700}.progress-bar{overflow:hidden;height:12px;border-radius:999px;background:#ffffff1f}.progress-bar__fill{width:0;height:100%;border-radius:inherit;background:linear-gradient(90deg,#22c55e,#38bdf8);transition:width .2s linear}@keyframes spin{to{transform:rotate(360deg)}}.result-panel{position:absolute;top:28px;right:28px;display:grid;gap:10px;width:min(280px,100% - 56px);border-radius:16px;padding:14px;text-align:center;color:#f8fafc;background:#020617d1}.result-panel__header{display:flex;justify-content:space-between;gap:12px;align-items:center}.result-panel p{margin:0;font-weight:700}.result-panel img{width:100%;border-radius:10px;background:#fff}.result-panel .qr-link,.result-panel .download-link{color:#93c5fd;font-weight:700}.result-panel .qr-link{display:block}.result-page{display:grid;place-items:center;min-height:520px;padding:1rem;border-radius:24px;background:radial-gradient(circle at center,rgba(56,189,248,.18),transparent 32%),linear-gradient(180deg,#0f172a14,#0f172a2e)}.result-panel--page{position:static;width:min(420px,100%);padding:18px;border-radius:24px;box-shadow:0 20px 50px #0f172a47}.result-panel--page .qr-link{display:grid;place-items:center;padding:12px;border-radius:18px;background:#fffffff2}.result-panel--page .qr-link img{width:min(100%,280px);aspect-ratio:1;object-fit:contain}.result-panel--page .download-link{display:inline-flex;justify-content:center;padding:12px 16px;border-radius:12px;background:#3b82f629}.monitor{position:absolute;top:28px;right:28px;display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:8px;max-width:min(420px,100% - 56px);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:10px;color:#bfdbfe;background:#020617b8}.monitor span{display:grid;gap:2px;border-radius:12px;padding:8px 10px;background:#0f172ab8;font-size:.75rem}.monitor strong{color:#f8fafc;font-size:.95rem}@media (max-width: 850px){body{align-items:flex-start;padding:12px}#app{padding:1rem}.location-grid,.stream-layout,.button-row{grid-template-columns:1fr}.stage{min-height:320px}body.is-stream-step .stage{width:min(100vw,56.25dvh);height:min(100dvh,177.7777777778vw);min-height:0;aspect-ratio:9/16}video{min-height:292px}body.is-stream-step video{min-height:0}body.is-video-result-step .final-video-card{width:min(100vw,56.25dvh);height:min(100dvh,177.7777777778vw);min-height:0;aspect-ratio:9/16;margin-top:0}.monitor{position:static;grid-template-columns:1fr 1fr;max-width:none;margin-top:12px}.record-actions,.result-panel,.upload-panel,.result-panel--page{position:static;margin-top:12px}.result-page{min-height:0}.final-video-card video{min-height:260px}body.is-video-result-step .final-video-card video{min-height:0}.final-qr-panel{grid-template-columns:1fr;text-align:center}.final-qr-panel__qr{justify-self:center}.result-panel--page .qr-link img{width:min(100%,220px)}}.final-image{width:100%}
