*{box-sizing:border-box;margin:0;padding:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{background-color:#f5f7fb;color:#1f2933;height:100vh}#app{position:relative;width:100%;height:100vh;overflow:hidden}.game-topbar{position:absolute;top:10px;left:50%;transform:translate(-50%);display:inline-flex;flex-direction:column;align-items:center;gap:12px;padding:12px 24px;border-radius:24px;background-color:#0f172ab3;color:#f9fafb;font-size:18px;z-index:1;pointer-events:none;max-width:90vw}max-width: 90vw; } .game-topbar-title{font-size:24px;font-weight:700;white-space:nowrap}.game-topbar-stats{display:inline-flex;align-items:center;gap:16px}.game-topbar-stat{display:inline-flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;border-radius:9999px;background-color:#0f172a73}.game-topbar-top{display:flex;align-items:center;gap:6px}.game-topbar-icon{font-size:20px}.game-topbar-label{opacity:.8;font-size:12px;text-align:center;white-space:nowrap}.game-topbar-value{font-weight:800;font-size:20px}.game-topbar-description{font-size:14px;color:#d1d5db;text-align:center;line-height:1.4;max-width:600px;opacity:.9}.babylon-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;touch-action:none}.main-scenario-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 24px 24px;position:relative;z-index:1}.main-scenario-heading{font-size:24px;font-weight:700}.main-scenario-subtitle{font-size:14px;color:#6b7280}.main-scenario-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;max-width:960px;position:relative}.main-scenario-grid.overlapping-layout{display:block;width:100%;height:400px;max-width:400px;margin:0 auto;position:relative}.overlapping-layout .main-scenario-card{position:absolute!important;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #0f172a26}.overlapping-layout .main-scenario-card:hover{transform:translateY(-10px) scale(1.05)!important;box-shadow:0 15px 35px #0f172a4d;border-color:#3b82f6}@media(max-width:768px){.main-scenario-grid.overlapping-layout{max-width:300px;height:350px}}@media(max-width:480px){.main-scenario-grid.overlapping-layout{max-width:250px;height:300px}.overlapping-layout .main-scenario-card{width:220px}}.hand-card-counter{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none}.hand-card-counter.hidden{display:none}.model-loading-indicator{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;color:#fff;padding:20px 30px;border-radius:12px;display:none;flex-direction:column;align-items:center;gap:15px;z-index:2000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:16px;font-weight:500}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.main-scenario-card{width:260px;max-width:90vw;border-radius:12px;background-color:#fff;border:1px solid #e5e7eb;box-shadow:0 4px 10px #0f172a1f;overflow:hidden;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.main-scenario-card:hover,.main-scenario-card:focus-visible{transform:translateY(-4px);border-color:#3b82f6;box-shadow:0 10px 25px #0f172a40}.main-scenario-image-wrapper{width:100%;height:220px;background:linear-gradient(135deg,#e5e7eb,#f3f4f6);display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:8px 8px 0 0}.main-scenario-image{width:100%;height:100%;object-fit:cover;object-position:center}.main-scenario-card-body{padding:10px 12px 12px}.main-scenario-card-title{font-size:15px;font-weight:600;margin-bottom:4px}.main-scenario-card-description{font-size:13px;color:#4b5563;max-height:3.2em;overflow:hidden}.exit-button{position:absolute;top:16px;left:16px;width:48px;height:48px;background-color:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;font-weight:700;font-size:24px;box-shadow:0 4px 12px #ef444466;z-index:250;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease}.exit-button:hover{background-color:#dc2626;box-shadow:0 6px 16px #ef444499;transform:scale(1.05)}.exit-button:active{transform:scale(.95)}.settings-button{position:absolute;top:16px;right:16px;padding:8px 16px;background-color:#bfdbfe;border:none;border-radius:4px;color:#1e3a8a;cursor:pointer;font-weight:600;box-shadow:0 1px 3px #0f172a33;z-index:2}.settings-button:hover{background-color:#93c5fd}.deal-button{position:absolute;background-color:#10b981;border:none;border-radius:50%;color:#fff;cursor:pointer;font-weight:700;box-shadow:0 4px 12px #10b98166;z-index:2;opacity:0;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease,opacity .3s ease;display:flex;align-items:center;justify-content:center}.deal-button.center-large{top:50%;left:50%;transform:translate(-50%,-50%);width:160px;height:160px;font-size:32px;opacity:1;transition:all 2s cubic-bezier(.4,0,.2,1),opacity .3s ease}.deal-button.corner-small{top:calc(100% - 104px);left:24px;transform:none;width:80px;height:80px;font-size:16px;opacity:1;transition:all 2s cubic-bezier(.4,0,.2,1),transform .15s ease,box-shadow .15s ease,background-color .15s ease}.deal-button:hover{background-color:#059669;box-shadow:0 6px 16px #10b98180}.deal-button.corner-small:hover{transform:scale(1.05)}.deal-button:active,.deal-button.corner-small:active{transform:scale(.95)}.deal-button.cooldown{cursor:default;opacity:.75}.deal-button-label{position:relative;z-index:2}.deal-cooldown-ring{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg);pointer-events:none;opacity:0}.deal-cooldown-ring-bg{fill:none;stroke:#fff3;stroke-width:3}.deal-cooldown-ring-fg{fill:none;stroke:#f97316;stroke-width:3;stroke-linecap:round;stroke-dasharray:100;stroke-dashoffset:100}.deal-button.cooldown .deal-cooldown-ring{opacity:1}.deal-button.cooldown .deal-cooldown-ring-fg{animation:dealCooldownStroke var(--deal-cooldown-duration, 5s) linear forwards}@keyframes dealCooldownStroke{0%{stroke-dashoffset:0}to{stroke-dashoffset:100}}.pause-button{position:absolute;top:calc(100% - 104px);right:24px;background-color:#6b7280;border:none;border-radius:50%;width:80px;height:80px;color:#fff;cursor:pointer;font-weight:700;font-size:32px;box-shadow:0 4px 12px #6b728066;z-index:2;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease;display:flex;align-items:center;justify-content:center}.commentary-button{position:absolute;top:calc(100% - 104px);right:124px;width:60px;height:60px;border-radius:50%;border:none;background-color:#2563eb;color:#fff;cursor:pointer;font-size:24px;box-shadow:0 4px 12px #2563eb80;z-index:2;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease,opacity .15s ease}.commentary-button:hover{background-color:#1d4ed8;box-shadow:0 6px 16px #2563eb99;transform:scale(1.05)}.commentary-button:active{transform:scale(.95)}.commentary-button.off{background-color:#4b5563}.pause-button:hover{background-color:#4b5563;box-shadow:0 6px 16px #6b728080;transform:scale(1.05)}.pause-button:active{transform:scale(.95)}.selection-triangle{position:absolute;width:0;height:0;border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:25px solid #10b981;z-index:3;pointer-events:auto;cursor:pointer;opacity:0;transition:opacity .2s ease;transform:translate(-50%);animation:triangleBounce 1.5s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(16,185,129,.6)) drop-shadow(0 0 16px rgba(16,185,129,.4));animation:triangleBounce 1.5s ease-in-out infinite,triangleGlow 2s ease-in-out infinite}.selection-triangle:not(.hidden){opacity:1}.selection-triangle:hover{filter:drop-shadow(0 0 12px rgba(16,185,129,.8)) drop-shadow(0 0 24px rgba(16,185,129,.6))}@keyframes triangleBounce{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,-8px)}}@keyframes triangleGlow{0%,to{filter:drop-shadow(0 0 8px rgba(16,185,129,.6)) drop-shadow(0 0 16px rgba(16,185,129,.4))}50%{filter:drop-shadow(0 0 16px rgba(16,185,129,.9)) drop-shadow(0 0 32px rgba(16,185,129,.6))}}.timeline{position:absolute;top:120px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:1;pointer-events:none}.timeline-bar{width:400px;height:8px;background-color:#0f172a66;border-radius:9999px;overflow:hidden}.timeline-progress{height:100%;background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:9999px;width:0%;transition:width .3s linear}.timeline-year{font-size:28px;font-weight:800;color:#f9fafb;text-shadow:0 2px 8px rgba(0,0,0,.5)}@media(max-width:768px){.timeline{top:140px}.timeline-bar{width:300px}.timeline-year{font-size:24px}}@media(max-width:480px){.timeline{top:160px}.timeline-bar{width:250px}.timeline-year{font-size:20px}}.commentary-header-status{font-size:11px;color:#6b7280;min-width:40px;text-align:left}.year-input{width:80px;padding:4px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;text-align:center;background-color:#f9fafb}.year-input:focus{outline:none;border-color:#3b82f6}.event-display{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;transition:opacity .5s ease;cursor:pointer}.event-display:not(.hidden){opacity:1}.event-content{background-color:#fff;border-radius:16px;max-width:800px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #00000080;transform:scale(.8);transition:transform .5s cubic-bezier(.34,1.56,.64,1)}.event-display:not(.hidden) .event-content{transform:scale(1)}.event-image-wrapper{width:100%;height:400px;overflow:hidden;background:linear-gradient(135deg,#e5e7eb,#f3f4f6)}.event-image{width:100%;height:100%;object-fit:cover;object-position:center}.event-info{padding:32px}.event-title{font-size:32px;font-weight:700;color:#111827;margin-bottom:16px}.event-description{font-size:18px;color:#4b5563;line-height:1.6;margin-bottom:24px}.event-hint{font-size:14px;color:#9ca3af;text-align:center;font-style:italic;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.city-model-progress{margin-top:6px;width:180px;height:4px;border-radius:9999px;background:#e5e7eb;overflow:hidden}.city-model-progress-bar{width:40%;height:100%;border-radius:9999px;background:linear-gradient(90deg,#3b82f6,#10b981);animation:cityModelProgressIndeterminate 1s infinite ease-in-out}.city-model-progress-bar.is-determinate{animation:none;transform:none}@keyframes cityModelProgressIndeterminate{0%{transform:translate(-100%)}50%{transform:translate(50%)}to{transform:translate(200%)}}.global-overlay{position:fixed;inset:0;background:#0f172aa6;display:flex;align-items:center;justify-content:center;z-index:200}.global-overlay-dialog{min-width:280px;max-width:420px;padding:20px 24px 18px;border-radius:12px;background:#fff;box-shadow:0 20px 60px #00000073;display:flex;flex-direction:column;gap:10px}.global-overlay-message{font-weight:600;font-size:15px}.global-overlay-subtext{font-size:13px;color:#6b7280}.global-overlay-progress{width:100%;height:5px;border-radius:9999px;background:#e5e7eb;overflow:hidden}.global-overlay-progress-bar{width:35%;height:100%;border-radius:9999px;background:linear-gradient(90deg,#3b82f6,#10b981);animation:globalOverlayIndeterminate 1s infinite ease-in-out}@keyframes globalOverlayIndeterminate{0%{transform:translate(-100%)}50%{transform:translate(40%)}to{transform:translate(200%)}}.global-overlay-actions{display:flex;justify-content:flex-end;margin-top:6px}.event-display.minimizing{opacity:0}.event-display.minimizing .event-content{transform:scale(.3) translate(100vw);transition:transform .8s cubic-bezier(.68,-.55,.27,1.55),opacity .8s ease}.effect-lines{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.effect-line{fill:none;opacity:.6;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.active-effects{position:fixed;bottom:120px;display:flex;flex-direction:column-reverse;gap:12px;z-index:2;pointer-events:auto}.active-effects-left{left:24px}.active-effects-right{right:24px}.active-effect-card{width:80px;height:100px;border:2px solid rgba(0,0,0,.2);border-radius:8px;padding:8px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:0 4px 12px #00000026;transition:all .5s cubic-bezier(.4,0,.2,1);animation:slideInFromBottom .5s cubic-bezier(.4,0,.2,1)}.active-effect-card.animating{opacity:0;pointer-events:none}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.active-effect-card:hover{transform:scale(1.05)}.active-effect-image{width:100%;height:50px;object-fit:cover;border-radius:4px;background:#ffffffe6}.active-effect-title{font-size:9px;font-weight:700;color:#fff;text-align:center;line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-shadow:0 1px 2px rgba(0,0,0,.3)}.active-effect-timer{font-size:10px;color:#ffffffe6;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.effect-preview{position:fixed;bottom:120px;width:200px;background-color:#fffffffa;border:3px solid #3b82f6;border-radius:12px;padding:16px;box-shadow:0 8px 24px #0000004d;z-index:10;pointer-events:none;transition:opacity .2s ease,transform .2s ease,left .2s ease,right .2s ease}.effect-preview.preview-left{left:120px;right:auto}.effect-preview.preview-right{right:120px;left:auto}.effect-preview.hidden{opacity:0;transform:scale(.9)}.effect-preview-image{width:100%;height:120px;object-fit:cover;border-radius:8px;margin-bottom:12px;background:linear-gradient(135deg,#e5e7eb,#f3f4f6)}.effect-preview-title{font-size:14px;font-weight:700;color:#111827;margin-bottom:8px;text-align:center}.effect-preview-effects{display:flex;flex-direction:column;gap:6px}.effect-preview-effect{display:flex;align-items:center;gap:6px;font-size:12px;color:#374151}.effect-preview-icon{font-size:14px}.effect-preview-value{font-weight:600}.effect-preview-value.positive{color:#10b981}.effect-preview-value.negative{color:#ef4444}.flying-icon{position:fixed;font-size:24px;z-index:200;pointer-events:none;opacity:1;text-shadow:0 2px 4px rgba(15,23,42,.6)}.admin-panel{position:relative;width:100%;height:100vh;background:radial-gradient(circle at top left,rgba(56,189,248,.18),transparent 55%),radial-gradient(circle at bottom right,rgba(52,211,153,.18),transparent 55%),linear-gradient(135deg,#f9fafb,#e5f0ff);padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px;overflow:hidden}.hidden{display:none!important}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding:8px 12px;border-radius:10px;background:#0f172ae6;color:#e5f0ff;box-shadow:0 10px 30px #0f172a59}.admin-header-actions{display:flex;align-items:center;gap:8px}.admin-header h1{font-size:18px;font-weight:700;letter-spacing:.03em}.close-button{border:none;background:transparent;font-size:18px;cursor:pointer;color:inherit;opacity:.8;transition:opacity .15s ease,transform .15s ease}.close-button:hover{opacity:1;transform:scale(1.05)}.section{border-top:1px solid rgba(148,163,184,.35);padding-top:12px}.section h2{font-size:15px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em;color:#0f172a}.scenarios-list{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 210px);overflow-y:auto;padding-right:6px}.scenario-card{border-radius:12px;padding:10px 12px;background:#f9fafbf2;border:1px solid rgba(148,163,184,.4);box-shadow:0 8px 18px #0f172a14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.scenario-card:hover{transform:translateY(-2px);border-color:#22c55e;box-shadow:0 14px 30px #0f172a29}.scenario-body.collapsed{display:none}.scenario-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.scenario-meta{display:flex;flex-direction:column;gap:12px;margin:6px 0 10px}.scenario-impacts{display:flex;flex-wrap:wrap;gap:6px;width:100%}.scenario-impact-chip{padding-right:8px}.scenario-image-container{display:flex;flex-direction:column;gap:4px;width:100%;max-width:200px}.scenario-description-container{width:100%;margin:8px 0}.scenario-description-input{width:100%;min-height:80px;padding:8px 10px;border-radius:4px;border:1px solid #d1d5db;font-size:13px;line-height:1.5;resize:vertical;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;font-family:inherit}.scenario-header h3.scenario-title{flex:1;font-size:15px;font-weight:600}.scenario-title-input{flex:1;padding:4px 6px;border-radius:4px;border:1px solid #d1d5db}.section-label{font-size:14px;font-weight:700;text-transform:none;color:#111827}.section-header-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px;margin-bottom:2px}.section-header-left{display:flex;align-items:center;gap:8px}.section-collapse-toggle{padding:0;font-size:24px;line-height:1}.scenario-section{margin-bottom:6px}.massnahmen-list{display:flex;flex-direction:column;gap:4px;margin-top:4px}.massnahme-item{display:flex;flex-direction:row;gap:8px;align-items:flex-start;border-radius:10px;padding:6px 8px;background-color:#fff;border:1px solid rgba(148,163,184,.45);box-shadow:0 3px 8px #0f172a0f}.massnahme-item--measure{border-left:4px solid #22c55e}.massnahme-item--event{border-left:4px solid #3b82f6}.massnahme-item.collapsed .massnahme-image-container,.massnahme-item.collapsed .massnahme-fields textarea,.massnahme-item.collapsed .massnahme-impacts-summary-row,.massnahme-item.collapsed .massnahme-impacts,.massnahme-item.collapsed .massnahme-footer{display:none}.massnahme-image-container{display:flex;flex-direction:column;gap:4px;min-width:140px}.massnahme-image-preview{width:128px;height:128px;border-radius:6px;background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}.massnahme-image-preview img.massnahme-image{width:100%;height:100%;object-fit:cover}.massnahme-image-input{display:none}.image-delete-btn{background:#fee2e2;border:1px solid #fca5a5;border-radius:4px;color:#dc2626;cursor:pointer;font-size:12px;padding:2px 8px;align-self:center;transition:background-color .2s}.image-delete-btn:hover{background:#fecaca}.image-hover-overlay{position:fixed;z-index:3000;pointer-events:none}.image-hover-card{background:radial-gradient(circle at top left,rgba(52,211,153,.08),transparent 55%),#fdfcf7;border-radius:14px;border:2px solid #e5e7eb;box-shadow:0 12px 30px #0f172a73;padding:12px 14px;width:320px;max-width:90vw;font-size:13px}.image-hover-title{font-size:15px;font-weight:700;text-align:center;margin-bottom:8px;color:#0f172a}.image-hover-image-wrapper{width:100%;height:180px;border-radius:8px;overflow:hidden;background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.image-hover-image-wrapper img{width:100%;height:100%;object-fit:cover}.image-hover-impacts-summary-row{display:flex;justify-content:center;margin-bottom:8px}.image-hover-impacts-summary{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.image-hover-description{margin-top:4px;font-size:12px;line-height:1.3;color:#374151}.massnahme-fields{display:flex;flex-direction:column;gap:6px;flex:1}.massnahme-impacts-summary-row{display:flex;align-items:center;justify-content:space-between;margin-top:2px}.massnahme-impacts-summary{display:flex;flex-wrap:wrap;gap:6px}.impact-summary-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:9999px;background-color:#f3f4f6;font-size:11px}.impact-summary-icon{font-size:12px}.impact-summary-value{font-variant-numeric:tabular-nums;min-width:16px;text-align:right;font-weight:600}.impact-summary-pos{color:#16a34a}.impact-summary-neg{color:#dc2626}.impact-summary-years{color:#2563eb}.massnahme-impacts{margin-top:4px;border-top:1px dashed #e5e7eb;padding-top:4px;display:flex;flex-direction:column;gap:4px}.impact-row{display:grid;grid-template-columns:1.2fr 1.2fr 1.2fr;align-items:center;column-gap:12px}.impact-row-extended{display:grid;grid-template-columns:1fr 1.5fr 2.5fr 1.5fr;align-items:center;column-gap:8px;padding:8px 0;border-bottom:1px solid #e5e7eb}.impact-value-control{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}.impact-control-label{font-size:10px;font-weight:600;color:#6b7280;text-transform:uppercase}.impact-years-inline{font-size:10px;color:#6b7280;margin:0 2px}.impact-label-cell{font-size:12px;font-weight:500;color:#374151}.impact-value-cell,.impact-years-cell{display:inline-flex;align-items:center;gap:6px}.impact-value,.impact-years-value{min-width:24px;text-align:center;font-variant-numeric:tabular-nums;font-size:12px}.impact-years-label{font-size:11px;color:#6b7280}.impact-btn{border:none;background:transparent;cursor:pointer;padding:0}.impact-btn-circle{width:20px;height:20px;border-radius:9999px;border:1px solid #d1d5db;display:inline-flex;align-items:center;justify-content:center;font-size:12px;background-color:#f9fafb}.impact-btn-circle:hover{background-color:#e5e7eb}.massnahme-title-row{display:flex;align-items:center;gap:4px}.massnahme-title{flex:1;font-size:16px;font-weight:600}.massnahme-title-input{flex:1;padding:4px 6px;border-radius:4px;border:1px solid #d1d5db;font-size:12px}.massnahme-fields textarea{width:100%;padding:4px 6px;border-radius:6px;border:1px solid #d1d5db;font-size:12px;background-color:#f9fafb}.massnahme-footer{display:flex;justify-content:flex-end;margin-top:4px}.icon-button{border:none;background:transparent;cursor:pointer;font-size:14px;padding:2px 4px}.massnahme-collapse-toggle{font-size:18px}.primary-button{margin-top:8px;padding:6px 12px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-radius:9999px;border:none;cursor:pointer;font-size:13px;font-weight:600;box-shadow:0 6px 18px #16a34a73;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.primary-button:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 10px 24px #16a34a99}.small-button{padding:4px 10px;font-size:11px;border-radius:9999px;border:1px solid #d1d5db;background-color:#f3f4f6;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:4px}.small-button:hover{background-color:#e5e7eb}.categories-container{margin:16px 0;padding:12px;background:#f8fafccc;border:1px solid rgba(148,163,184,.3);border-radius:8px}.categories-list{display:flex;flex-direction:column;gap:8px;margin:12px 0}.category-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#fff;border:1px solid rgba(148,163,184,.2);border-radius:6px;transition:border-color .15s ease}.category-item:hover{border-color:#94a3b866}.color-preview{width:20px;height:20px;border-radius:4px;border:1px solid rgba(0,0,0,.1);flex-shrink:0}.category-name{flex-grow:1;font-weight:500;color:#374151}.add-category-btn{padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .15s ease}.add-category-btn:hover{background:#2563eb}.actors-container{margin:16px 0;padding:12px;background:#f8fafccc;border:1px solid rgba(148,163,184,.3);border-radius:8px}.actors-list{display:flex;flex-direction:column;gap:16px;margin:12px 0}.actor-card{background:#fff;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:16px;display:flex;gap:16px;transition:border-color .15s ease}.actor-card:hover{border-color:#94a3b866}.actor-model-section{flex-shrink:0;width:120px}.actor-model-preview{width:100%;height:100px;border:2px dashed rgba(16,185,129,.3);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;background:#10b9810d}.actor-model-preview:hover{border-color:#10b98199;background:#10b9811a}.actor-model-preview .no-model{text-align:center;font-size:12px;color:#6b7280;line-height:1.3}.actor-model-preview .model-viewer{font-size:24px;margin-bottom:4px}.actor-model-preview .model-name{font-size:10px;color:#374151;text-align:center;word-break:break-all;max-width:100%}.actor-fields{flex-grow:1;display:flex;flex-direction:column;gap:12px}.actor-field-row{display:flex;flex-direction:column;gap:4px}.actor-field-label{font-size:12px;font-weight:500;color:#374151;margin-bottom:2px}.actor-field-input,.actor-field-textarea{padding:8px 12px;border:1px solid rgba(148,163,184,.3);border-radius:6px;font-size:14px;background:#fff;transition:border-color .15s ease;font-family:inherit}.actor-field-input:focus,.actor-field-textarea:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.actor-field-textarea{resize:vertical;min-height:60px}.delete-actor-btn{align-self:flex-start;padding:6px 12px;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .15s ease;flex-shrink:0}.delete-actor-btn:hover{background:#dc2626}.add-actor-btn{padding:8px 16px;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .15s ease}.add-actor-btn:hover{background:#059669}.upload-progress{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px}.upload-icon{font-size:20px}.upload-text{font-size:12px;font-weight:500;color:#374151}.progress-bar{width:80px;height:4px;background:#3b82f633;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:#3b82f6;width:0%;transition:width .3s ease}.upload-percent{font-size:10px;color:#6b7280;font-weight:500}.upload-success{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:4px}.success-icon{font-size:24px}.success-text{font-size:12px;font-weight:500;color:#059669}.model-3d-container{width:100%;height:80px;border-radius:4px;overflow:hidden;transition:transform .15s ease}.model-3d-container:hover{transform:scale(1.05)}.model-preview-container{width:100%;height:80px;border-radius:4px;overflow:hidden;transition:transform .15s ease}.model-preview-container:hover{transform:scale(1.05)}.model-preview-image{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#10b9811a,#3b82f61a);border:1px solid rgba(16,185,129,.3);border-radius:4px;cursor:pointer;transition:all .15s ease}.model-preview-image:hover{background:linear-gradient(135deg,#10b98133,#3b82f633);border-color:#10b98180}.preview-icon{font-size:20px;margin-bottom:2px}.preview-text{font-size:10px;color:#374151;font-weight:500}.model-3d-canvas{width:100%;height:100%;display:block;border-radius:4px;cursor:grab}.model-3d-canvas:active{cursor:grabbing}.model-fallback{width:100%;height:80px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#6b7280;background:#3b82f61a;border-radius:4px}.model-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffffe6;border-radius:4px;gap:4px;z-index:10}.loading-spinner{font-size:16px;animation:spin 1s linear infinite}.loading-text{font-size:10px;color:#6b7280;font-weight:500}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.large-model-preview-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.large-model-preview-container{position:relative;background:#fff;border-radius:12px;padding:20px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040}.large-model-preview-header{font-size:18px;font-weight:600;color:#374151;margin-bottom:16px;text-align:center}.large-model-preview-canvas{display:block;border-radius:8px;border:1px solid rgba(148,163,184,.2);cursor:grab}.large-model-preview-canvas:active{cursor:grabbing}.large-model-preview-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border:none;background:#ef44441a;color:#ef4444;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease}.large-model-preview-close:hover{background:#ef444433}.large-model-preview-upload{position:absolute;top:12px;left:12px;background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s ease;box-shadow:0 2px 4px #3b82f626}.large-model-preview-upload:hover{background:#2563eb;box-shadow:0 4px 8px #3b82f640;transform:translateY(-1px)}.large-model-preview-delete{position:absolute;top:12px;left:170px;background:#ef4444;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s ease;box-shadow:0 2px 4px #ef444426}.large-model-preview-delete:hover{background:#dc2626;box-shadow:0 4px 8px #ef444440;transform:translateY(-1px)}.large-model-preview-save-camera{position:absolute;top:52px;left:12px;background:#10b981;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .15s ease;box-shadow:0 2px 4px #10b98126}.large-model-preview-save-camera:hover{background:#059669;box-shadow:0 4px 8px #10b98140;transform:translateY(-1px)}.animations-container{margin-top:16px;padding:12px;background:#f8fafccc;border-radius:8px;border:1px solid rgba(148,163,184,.2)}.animations-loading,.animations-error,.no-animations{text-align:center;color:#6b7280;font-size:14px;padding:8px}.animations-error{color:#ef4444}.animations-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.animations-header{font-size:16px;font-weight:600;color:#374151;margin:0}.animation-upload-btn{background:#10b981;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .15s ease}.animation-upload-btn:hover{background:#059669;transform:translateY(-1px)}.large-preview-upload-status{margin-top:12px;padding:12px;background:#f8fafcf2;border-radius:8px;border:1px solid rgba(148,163,184,.3)}.no-model-large{text-align:center;color:#6b7280;font-size:16px;padding:40px 20px;line-height:1.6}.animation-controls{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.animation-button{padding:8px 12px;background:#f3f4f6;border:1px solid rgba(148,163,184,.3);border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;color:#374151}.animation-button:hover{background:#e5e7eb;border-color:#94a3b880}.animation-button.playing{background:#10b981;color:#fff;border-color:#059669}.animation-button.stop-all-btn{background:#ef4444;color:#fff;border-color:#dc2626}.animation-button.stop-all-btn:hover{background:#dc2626}.animation-indicator{font-size:10px;color:#6b7280;margin-top:2px}.animation-indicator.has-animations{color:#10b981;font-weight:500}.measure-category-row{display:flex;align-items:center;gap:12px;margin:8px 0;padding:8px 0;border-top:1px solid rgba(148,163,184,.2)}.measure-field-label{font-size:12px;font-weight:500;color:#374151;min-width:70px}.measure-category-select,.measure-level-select{padding:4px 8px;border:1px solid rgba(148,163,184,.3);border-radius:4px;font-size:12px;background:#fff;cursor:pointer}.measure-category-select{flex-grow:1;max-width:150px}.measure-level-select{width:60px}.measure-category-select:focus,.measure-level-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.level-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:18px;padding:2px 6px;background:#8b5cf6;color:#fff;border-radius:9px;font-size:10px;font-weight:600;margin-left:8px;flex-shrink:0}.save-all-button{padding:4px 12px;font-size:11px;border-radius:9999px;border:none;background:linear-gradient(135deg,#0ea5e9,#3b82f6);color:#fff;cursor:pointer;font-weight:500;box-shadow:0 4px 14px #2563eb80;transition:filter .15s ease,box-shadow .15s ease,transform .15s ease}.save-all-button:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 7px 18px #2563ebb3}.save-all-button.hidden{display:none}.settings-overlay{position:fixed;inset:0;background-color:#0f172a66;display:flex;align-items:center;justify-content:center;z-index:2000}.settings-dialog{width:720px;max-width:95vw;max-height:75vh;background:radial-gradient(circle at top left,rgba(56,189,248,.18),transparent 55%),#fff;border-radius:16px;box-shadow:0 18px 45px #0f172a73;padding:18px 22px;display:flex;flex-direction:column;gap:12px}.settings-dialog-header{display:flex;align-items:center;justify-content:space-between}.settings-dialog-body{flex:1 1 auto;margin-top:8px;overflow-y:auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);column-gap:16px;row-gap:10px;padding-right:4px}.settings-dialog-body hr,.settings-dialog-body .form-field.full-width{grid-column:1 / -1}.settings-dialog-footer{display:flex;justify-content:flex-end;margin-top:8px}.form-field{display:flex;flex-direction:column;gap:4px}.form-field label{font-size:13px;font-weight:500}.form-field input[type=password],.form-field input[type=text],.form-field select,.form-field textarea{padding:6px 9px;border-radius:6px;border:1px solid #d1d5db;font-size:13px;background-color:#f9fafb}.form-field small{font-size:11px;color:#6b7280}.commentary-container{margin-top:4px;padding:6px 8px;border-radius:8px;background:linear-gradient(135deg,#eff6ffe6,#ecfdf5f2);border:1px dashed rgba(148,163,184,.7);display:flex;flex-direction:column;gap:4px}.commentary-header-row{display:flex;align-items:center;justify-content:space-between;gap:4px;cursor:pointer}.commentary-header-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#111827}.commentary-toggle{font-size:14px}.commentary-container textarea{background-color:#ffffffd9}.commentary-status-row{font-size:10px;color:#4b5563}.commentary-buttons-row{display:flex;justify-content:flex-end;gap:6px}.loading-shimmer{position:relative;color:transparent!important;overflow:hidden}.loading-shimmer::placeholder{color:transparent!important}.loading-shimmer:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#fff0,#94a3b84d,#fff0);transform:translate(-100%);animation:loadingShimmer 1.2s infinite}@keyframes loadingShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.bundles-container{margin-top:16px;padding-top:12px;border-top:1px solid #e5e7eb}.bundles-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.bundle-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.bundle-name-input{flex:0 0 140px;padding:6px 10px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;font-weight:500}.bundle-name-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.bundle-measures-preview{display:flex;align-items:center;gap:6px;flex:1}.bundle-mini-card{position:relative;width:48px;height:64px;border-radius:4px;background:#e5e7eb;border:1px solid #d1d5db;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#6b7280;overflow:hidden}.bundle-mini-card img{width:100%;height:100%;object-fit:cover}.bundle-mini-remove{position:absolute;top:2px;right:2px;width:16px;height:16px;background:#ef4444e6;color:#fff;border:none;border-radius:50%;font-size:12px;line-height:1;cursor:pointer;display:none}.bundle-mini-card:hover .bundle-mini-remove{display:block}.bundle-add-measure{width:48px;height:64px;border:2px dashed #d1d5db;border-radius:4px;background:transparent;color:#9ca3af;font-size:20px;cursor:pointer;transition:all .15s}.bundle-add-measure:hover{border-color:#3b82f6;color:#3b82f6;background:#3b82f60d}.bundle-delete{opacity:.6;transition:opacity .15s}.bundle-delete:hover{opacity:1}.add-bundle-btn{margin-top:8px;padding:8px 16px;background:#f0fdf4;border:1px dashed #86efac;border-radius:6px;color:#16a34a;font-weight:500;cursor:pointer;transition:all .15s}.add-bundle-btn:hover{background:#dcfce7;border-color:#4ade80}.bundle-measure-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px -5px #00000026;max-height:200px;overflow-y:auto;min-width:200px}.bundle-measure-option{padding:10px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid #f3f4f6}.bundle-measure-option:last-child{border-bottom:none}.bundle-measure-option:hover{background:#f0f9ff;color:#0369a1}.measure-bundle-tags{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;background:#fafafa;border-top:1px solid #f3f4f6}.bundle-tag{display:inline-block;padding:3px 10px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:11px;font-weight:600;border-radius:12px;letter-spacing:.02em}.event-bundle-row{display:flex;align-items:center;gap:10px;padding:8px 0;margin-top:8px;border-top:1px solid #f3f4f6}.bundle-label{font-size:12px;font-weight:500;color:#6b7280}.event-bundle-select{flex:1;padding:6px 10px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;background:#fff}.event-bundle-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.bundle-measure-overlay{position:fixed;top:0;height:100vh;z-index:200;pointer-events:auto}.bundle-actor-canvas{width:100%;height:100%}.bundle-skip-button{position:fixed;bottom:60px;left:50%;transform:translate(-50%);width:80px;height:80px;background-color:#ef4444;border:none;border-radius:50%;color:#fff;font-size:40px;font-weight:700;cursor:pointer;z-index:210;box-shadow:0 4px 20px #ef444480;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease;display:flex;align-items:center;justify-content:center}.bundle-skip-button:hover{background-color:#dc2626;transform:translate(-50%) scale(1.1);box-shadow:0 6px 24px #ef4444b3}.bundle-skip-button:active{transform:translate(-50%) scale(.95)}
