:root{color:#e8e9ed;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(120% 80% at 50% 0,#1e293b 0%,#0f172a 45%);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.45}*{box-sizing:border-box}body{min-height:100svh;margin:0}#root{min-height:100svh}.cg-app{flex-direction:column;align-items:stretch;max-width:720px;min-height:100svh;margin:0 auto;padding:1.25rem 1rem 2rem;display:flex}.cg-header{text-align:center;margin-bottom:.75rem}.cg-title{letter-spacing:-.02em;color:#f8fafc;margin:0 0 .35rem;font-size:1.65rem;font-weight:600}.cg-sub{color:#94a3b8;margin:0;font-size:.9rem}.cg-perm-hint{color:#64748b;max-width:34rem;margin:.65rem auto 0;font-size:.78rem;line-height:1.4}.cg-banner-wrap{min-height:3rem;margin-bottom:.75rem;padding:0 .5rem;position:relative}.cg-banner{pointer-events:none;opacity:0;text-align:center;white-space:nowrap;border-radius:999px;max-width:100%;padding:.55rem 1.1rem;font-size:.9rem;font-weight:600;transition:opacity .35s,transform .35s;position:absolute;top:0;left:50%;transform:translate(-50%)translateY(-8px)}@media (width<=520px){.cg-banner{white-space:normal;padding-bottom:.65rem}}.cg-banner-visible{opacity:1;transform:translate(-50%)translateY(0)}.cg-banner-warn{color:#1c1917;background:#eab308eb;box-shadow:0 8px 24px #eab30840}.cg-banner-det{color:#f8fafc;background:#3b82f6f2;box-shadow:0 8px 24px #3b82f64d}.cg-stage{flex:1;justify-content:center;align-items:flex-start;width:100%;min-width:0;display:flex}.cg-stage--hud-only{flex:0 auto;align-items:center;padding-top:.3rem;padding-bottom:.7rem}.cg-video-wrap{aspect-ratio:9/16;border-radius:12px;width:100%;max-width:100%;transition:max-width .3s,max-height .3s,box-shadow .3s,aspect-ratio .3s,border-radius .3s;position:relative;overflow:hidden;box-shadow:0 20px 50px #00000073,0 0 0 1px #ffffff0f}.cg-video-wrap:not(.cg-video-wrap--hud-only){max-height:min(78svh,720px);margin-inline:auto}@media (width<=599px) and (orientation:portrait){.cg-video-wrap:not(.cg-video-wrap--hud-only){max-width:100%;max-height:min(68svh,620px)}}@media (orientation:landscape) and (height<=520px){.cg-video-wrap:not(.cg-video-wrap--hud-only){max-width:min(100%,36rem);max-height:min(72svh,420px)}}@media (width>=600px){.cg-video-wrap:not(.cg-video-wrap--hud-only){max-width:min(22rem,92vw);max-height:min(78svh,720px)}}.cg-video-wrap.cg-video-wrap--hud-only{aspect-ratio:auto;border-radius:10px;width:100%;max-width:19rem;min-height:18rem;box-shadow:0 10px 26px #0006,0 0 0 1px #ffffff0f}@media (width<=380px){.cg-video-wrap.cg-video-wrap--hud-only{max-width:100%;min-height:16rem}}.cg-video-inner{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.cg-video-feed{z-index:1;justify-content:center;align-items:center;transition:opacity .2s,visibility .2s;display:flex;position:absolute;inset:0}.cg-video-feed--hidden{opacity:0;visibility:hidden;pointer-events:none}.cg-video-off-hint{z-index:3;pointer-events:none;text-align:center;justify-content:center;align-items:center;padding:1rem;display:flex;position:absolute;inset:0}.cg-video-off-hint p{color:#94a3b8;margin:0;font-size:.88rem;font-weight:600;line-height:1.4}.cg-video-toggle-wrap{z-index:4;pointer-events:auto;position:absolute;bottom:.85rem;left:50%;transform:translate(-50%)}.cg-video-toggle{appearance:none;cursor:pointer;color:#e2e8f0;background:#0f172ae0;border:1px solid #94a3b873;border-radius:999px;padding:.4rem .95rem;font-family:inherit;font-size:.82rem;font-weight:600;transition:background .15s,border-color .15s,color .15s;box-shadow:0 4px 14px #00000059}.cg-video-toggle:hover{background:#1e293beb;border-color:#94a3b8a6}.cg-video-toggle--on{color:#6ee7b7;border-color:#34d39980}.cg-video{vertical-align:top;object-fit:contain;background:#020617;width:100%;max-width:100%;height:100%;max-height:100%;display:block}.cg-overlay-canvas{z-index:2;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.cg-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:.65rem;margin-top:1.25rem;display:flex}.cg-btn{appearance:none;color:#e2e8f0;cursor:pointer;background:#0f172aa6;border:1px solid #94a3b859;border-radius:8px;padding:.55rem 1.1rem;font-size:.95rem;font-weight:600;transition:background .15s,border-color .15s}.cg-btn:hover{background:#1e293bd9;border-color:#94a3b88c}.cg-btn-primary{color:#fff;background:linear-gradient(120deg,#3b82f6,#6366f1);border-color:#0000}.cg-btn-primary:hover{filter:brightness(1.06)}.cg-btn-active{color:#6ee7b7;border-color:#34d399a6}.cg-error{text-align:center;color:#fca5a5;flex-basis:100%;margin:0;font-size:.85rem}.cg-warning-flash{z-index:9998;pointer-events:none;mix-blend-mode:overlay;background:radial-gradient(110% 95% at 50% 42%,#ffa02880 0%,#ea580c52 42%,#b91c1c38 100%);animation:1.05s ease-in-out infinite cg-warning-flash;position:fixed;inset:0}@keyframes cg-warning-flash{0%{opacity:0}12%{opacity:.95}24%{opacity:.08}38%{opacity:.88}52%{opacity:.06}66%{opacity:.82}80%{opacity:.04}to{opacity:0}}@media (prefers-reduced-motion:reduce){.cg-warning-flash{opacity:.28;mix-blend-mode:normal;background:#ea580c33;animation:none}}.cg-app-behind-settings{pointer-events:none;-webkit-user-select:none;user-select:none}.cg-settings-overlay{z-index:10000;-webkit-overflow-scrolling:touch;background:radial-gradient(120% 80% at 50% 0,#1e293b 0%,#0f172a 45%);position:fixed;inset:0;overflow:auto}.cg-app-settings{max-width:36rem}.cg-settings-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.cg-settings-title{color:#f8fafc;margin:0;font-size:1.25rem;font-weight:600}.cg-settings-lead{color:#94a3b8;margin:0 0 1.25rem;font-size:.85rem;line-height:1.45}.cg-settings-section{border-bottom:1px solid #94a3b833;margin-bottom:1.35rem;padding-bottom:1rem}.cg-settings-section:last-of-type{border-bottom:none}.cg-settings-section-title{color:#cbd5e1;margin:0 0 .75rem;font-size:.95rem;font-weight:600}.cg-settings-row{flex-direction:column;gap:.35rem;margin-bottom:.85rem;display:flex}.cg-settings-label{color:#e2e8f0;flex-direction:column;gap:.15rem;font-size:.9rem;display:flex}.cg-settings-hint{color:#64748b;font-size:.72rem;font-weight:400}.cg-settings-control{align-items:center;gap:.65rem;display:flex}.cg-settings-control input[type=range]{accent-color:#6366f1;flex:1;min-width:0}.cg-settings-value{font-variant-numeric:tabular-nums;color:#94a3b8;text-align:right;min-width:5.5rem;font-size:.8rem}.cg-settings-desc{color:#94a3b8;margin:0 0 .75rem;font-size:.82rem;line-height:1.5}.cg-settings-desc--bilingual{flex-direction:column;gap:.45rem;display:flex}.cg-settings-desc-line{display:block}.cg-settings-control--row{flex-wrap:wrap}.cg-settings-control--language{max-width:22rem}.cg-settings-select{color:#e2e8f0;cursor:pointer;appearance:none;background-color:#0f172ad9;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right .65rem center;background-repeat:no-repeat;background-size:1rem 1rem;border:1px solid #94a3b873;border-radius:10px;width:100%;padding:.55rem 2.25rem .55rem .9rem;font-family:inherit;font-size:.9rem;font-weight:600;line-height:1.35;transition:border-color .15s,background-color .15s,box-shadow .15s}.cg-settings-select:hover{background-color:#1e293bbf;border-color:#94a3b8a6}.cg-settings-select:focus{border-color:#6366f18c;outline:none;box-shadow:0 0 0 2px #6366f147}.cg-settings-select option{color:#0f172a;background:#f1f5f9;font-weight:600}.cg-settings-pill{color:#c7d2fe;white-space:nowrap;background:#6366f133;border:1px solid #6366f159;border-radius:999px;padding:.35rem .75rem;font-size:.8rem;font-weight:600}.cg-settings-section--last{border-bottom:none;padding-bottom:0}.cg-settings-segment{flex-wrap:wrap;gap:.5rem;display:flex}.cg-settings-segment-btn{appearance:none;cursor:pointer;color:#cbd5e1;background:#0f172a99;border:1px solid #94a3b866;border-radius:10px;flex:1;min-width:8.5rem;padding:.6rem .85rem;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s,color .15s}.cg-settings-segment-btn:hover{background:#1e293bbf;border-color:#94a3b899}.cg-settings-segment-btn--on{color:#e0e7ff;background:#4f46e547;border-color:#6366f1a6}.cg-settings-footer{border-top:1px solid #94a3b838;flex-wrap:wrap;justify-content:flex-end;gap:.65rem;margin-top:1.35rem;padding-top:1.15rem;display:flex}
