.projector-view{padding:48px;background:#f8fafc;min-height:100vh}.center-box{display:flex;flex-direction:column;align-items:center;justify-content:center}.join-code-large{font-size:8rem;font-weight:800;color:var(--brand);text-shadow:0 8px 0 rgba(0,0,0,.1);margin:24px 0}.q-options-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}.q-option-card{padding:32px;border-radius:20px;background:#fff;border:3px solid var(--text);font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:16px;box-shadow:0 12px #0000001a}.q-option-card span{width:44px;height:44px;background:var(--text);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.q-option-card.opt-a{background:#fef2f2;border-color:#ef4444}.q-option-card.opt-b{background:#eff6ff;border-color:#3b82f6}.q-option-card.opt-c{background:#f0fdf4;border-color:#22c55e}.q-option-card.opt-d{background:#fffbeb;border-color:#f59e0b}.q-btn{display:flex;flex-direction:column;align-items:center;padding:24px!important;text-align:center;transition:transform .1s ease}.q-btn:active{transform:scale(.95)}.q-btn.dimmed{opacity:.4}.q-btn.selected{border:4px solid var(--text);outline:4px solid var(--brand2)}.q-grid-mobile{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dist-bars{display:flex;justify-content:space-around;align-items:flex-end;height:250px;margin-top:32px}.dist-bar-item{display:flex;flex-direction:column;align-items:center;width:80px}.bar-track{width:60px;height:200px;background:#e2e8f0;border-radius:8px;display:flex;flex-direction:column;justify-content:flex-end}.bar-fill{width:100%;background:var(--muted);border-radius:0 0 8px 8px;transition:height 1s ease-out}.dist-bar-item.correct .bar-fill{background:#22c55e}.lb-table{background:#fff;border:2px solid var(--text);border-radius:20px;overflow:hidden}.lb-row{display:grid;grid-template-columns:60px 1fr 120px;padding:16px 24px;border-bottom:1px dashed var(--border);font-size:1.2rem}.lb-rank{font-weight:800;color:var(--muted)}.lb-name{font-weight:600}.lb-points{text-align:right;color:var(--brand);font-weight:700}.result-feedback{border-width:4px;border-style:solid}.result-feedback.success{border-color:#22c55e}.result-feedback.wrong{border-color:#ef4444}.pulse-circle{width:80px;height:80px;background:var(--brand);border-radius:50%;animation:quiz-pulse 2s infinite}@keyframes quiz-pulse{0%{transform:scale(.95);box-shadow:0 0 #0b1f4db3}70%{transform:scale(1);box-shadow:0 0 0 40px #0b1f4d00}to{transform:scale(.95);box-shadow:0 0 #0b1f4d00}}@media(max-width:600px){.q-grid-mobile{grid-template-columns:1fr}.lb-row{font-size:1rem;padding:12px 16px}}.auth-card{max-width:520px;margin:0 auto}.form-group{margin-top:12px}.active-link{border-style:solid}.profile-card{max-width:820px;margin-top:16px}.profile-row{align-items:flex-start}.user-profile-header{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;transition:opacity .2s}.user-profile-header:hover{opacity:.8}.user-avatar-small{width:36px;height:36px;background:var(--brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.user-info-header{display:flex;flex-direction:column;line-height:1.2}.user-name-header{font-weight:600;font-size:14px;color:var(--text)}.user-role-header{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:8px 16px 24px;justify-content:space-around;align-items:center;z-index:100;box-shadow:0 -4px 12px #0000000d}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;text-decoration:none;color:var(--muted);font-size:11px;font-weight:500;padding:8px;flex:1}.mobile-nav-item.active{color:var(--brand)}.mobile-nav-icon{width:24px;height:24px}.profile-fields{flex:1;min-width:260px}.journey-map-card{margin-top:16px;border-radius:24px;border:2px dashed var(--border);background:#fffdf8;padding:0;overflow:hidden;position:relative}.journey-map{position:relative;height:900px;width:100%}.journey-grass-bg{position:absolute;inset:0;background-color:#d1fae5;background-image:radial-gradient(circle at 100% 50%,transparent 20%,rgba(255,255,255,.3) 21%,rgba(255,255,255,.3) 34%,transparent 35%,transparent),radial-gradient(circle at 0% 50%,transparent 20%,rgba(255,255,255,.3) 21%,rgba(255,255,255,.3) 34%,transparent 35%,transparent),linear-gradient(0deg,rgba(0,0,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:20px 20px;z-index:0;opacity:.6}.journey-grass-bg:before{content:none}.journey-tree{position:absolute;width:32px;height:32px;border-radius:50%;background:#22c55e66;z-index:1}.journey-tree-small{position:absolute;width:24px;height:24px;border-radius:50%;background:#22c55e4d;z-index:1}@media(min-width:641px){.journey-tree{width:48px;height:48px;transform:scale(1.4)}.journey-tree-small{width:32px;height:32px;transform:scale(1.4)}}@media(max-width:640px){.navbar,.nav-links{display:none}.mobile-nav{display:flex}.page{padding-bottom:80px;margin-top:0}.navbar-inner{padding:0 16px}}.journey-svg{width:100%;height:100%;position:relative;z-index:2}.journey-road-shadow{fill:none;stroke:#0000000f;stroke-width:68;stroke-linecap:round;stroke-linejoin:round;transform:translate(3px,6px)}.journey-road-edge,.journey-road-core{fill:none;stroke:#4a4a4a;stroke-width:60;stroke-linecap:round;stroke-linejoin:round}.journey-road-edge-highlight{fill:none;stroke:#f5f5f5;stroke-width:62;stroke-linecap:round;stroke-linejoin:round;mix-blend-mode:overlay;opacity:.1}.journey-road-center{fill:none;stroke:#fbbf24;stroke-width:3;stroke-dasharray:20 14;stroke-linecap:round;stroke-linejoin:round}.journey-sidewalk{fill:none;stroke:#d1d5db;stroke-width:24;stroke-linecap:round;stroke-linejoin:round;opacity:.6}.journey-car image{transform-origin:center}.journey-markers{position:absolute;inset:0;pointer-events:auto;z-index:3}.journey-marker{position:absolute;display:flex;align-items:center;gap:8px;pointer-events:auto;border:none;background:transparent;cursor:pointer;padding:0}.journey-marker.marker-left{transform:translateY(-50%);flex-direction:row}.journey-marker.marker-right{transform:translate(-100%,-50%);flex-direction:row-reverse}.journey-marker .marker-dot{width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--brand);box-shadow:0 4px #0b1f4d29}.journey-marker.active .marker-dot{box-shadow:0 0 0 6px #ffffffd9,0 8px #0b1f4d33}.marker-label{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:8px 12px;border-radius:14px;background:#fff;border:2px dashed var(--border);box-shadow:var(--sketch-shadow);white-space:nowrap}.marker-date{font-weight:700;font-size:13px;color:var(--brand)}.marker-meta{font-size:12px;color:var(--muted)}.marker-tooltip{position:absolute;left:50%;bottom:calc(100% + 12px);transform:translate(-50%);background:#fff;color:var(--text);padding:10px 12px;border-radius:12px;box-shadow:0 8px 18px #0b1f4d2e;font-size:12px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;display:flex;flex-direction:column;gap:4px;z-index:4}.journey-marker:hover .marker-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.journey-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:24px;margin-bottom:24px}.stat-card{background:#fff;border:2px dashed var(--border);border-radius:20px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 12px #0b1f4d0a}.stat-icon{width:48px;height:48px;border-radius:12px;background:#0b1f4d0d;display:flex;align-items:center;justify-content:center;color:var(--brand)}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:20px;font-weight:700;line-height:1.2}.stat-label{font-size:13px;color:var(--muted)}.journey-marker{transition:transform .2s cubic-bezier(.34,1.56,.64,1);z-index:5}.journey-marker:hover{transform:scale(1.05) translateY(-2px);z-index:20}.journey-marker.marker-left{transform:translateY(-90%)}.journey-marker.marker-right{transform:translate(-100%,-90%)}.journey-marker.marker-left:hover{transform:translateY(-90%) scale(1.05) translateY(-2px)}.journey-marker.marker-right:hover{transform:translate(-100%,-90%) scale(1.05) translateY(-2px)}.signpost-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.signpost-board{position:relative;background:#a05a2c;border:2px solid #783d16;border-radius:4px;padding:6px 10px;box-shadow:0 4px 6px -1px #0000004d,inset 0 1px #fff3,inset 0 0 20px #0000001a;display:flex;flex-direction:column;min-width:110px;text-align:center;color:#fff9f0;z-index:2}.signpost-board:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(0,0,0,.03) 0px,rgba(0,0,0,.03) 2px,transparent 2px,transparent 8px);pointer-events:none;opacity:.5}.journey-marker.active .signpost-board{background:#c27a4b;border-color:#f59e0b;box-shadow:0 0 0 2px #fef3c7,0 8px 16px -4px #0006}.signpost-posts{position:absolute;top:100%;left:0;width:100%;height:24px;display:flex;justify-content:space-between;padding:0 15%;margin-top:-4px;z-index:1}.post-leg{width:6px;height:100%;background:#5d3514;border-radius:0 0 2px 2px;box-shadow:inset 1px 0 2px #0000004d}.signpost-date{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#ffffffbf;font-weight:700;margin-bottom:2px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.signpost-title{font-size:13px;font-weight:700;color:#fff;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.3)}.signpost-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#16a34a;color:#fff;font-size:9px;font-weight:800;padding:2px 6px;border-radius:4px;border:1px solid #14532d;box-shadow:0 2px 4px #0003}.quiz-timer{background:var(--brand);color:#fff;padding:8px 16px;border-radius:99px;font-weight:800;font-family:monospace;font-size:1.25rem;box-shadow:0 4px 12px #0b1f4d33;min-width:80px;text-align:center}.quiz-timer.danger{background:#ff4d4f!important;color:#fff!important;animation:pulse-red 1s infinite}@keyframes pulse-red{0%{transform:scale(1);box-shadow:0 0 #ff4d4fb3}70%{transform:scale(1.05);box-shadow:0 0 0 10px #ff4d4f00}to{transform:scale(1);box-shadow:0 0 #ff4d4f00}}.ans-count-badge{background:#0b1f4d0d;border:1px solid var(--border);padding:6px 16px;border-radius:99px;font-weight:700;font-size:.9rem;color:var(--brand)}.fullscreen-mode{position:fixed;inset:0;background:#fff;z-index:9999;padding:48px;display:flex;flex-direction:column}.fullscreen-exit-hint{position:fixed;top:16px;left:50%;transform:translate(-50%);background:#0000001a;padding:4px 12px;border-radius:99px;font-size:11px;color:var(--muted);cursor:pointer;z-index:10000;opacity:.5;transition:opacity .2s}.fullscreen-exit-hint:hover{opacity:1;background:#0003}.joined-names-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:800px;margin-top:32px}.joined-name-tag{background:#fff;border:2px solid var(--border);padding:10px 20px;border-radius:12px;font-weight:600;color:var(--brand);box-shadow:4px 4px 0 var(--border)}.pulse-in{animation:pulse-in .5s cubic-bezier(.34,1.56,.64,1)}@keyframes pulse-in{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.projector-view h1{font-size:2.5rem;margin-bottom:8px}.projector-body .join-hero{text-align:center;padding:48px}.join-code-large{font-size:6rem;font-weight:900;letter-spacing:.2em;color:var(--brand);text-shadow:6px 6px 0 var(--border)}.q-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px}.q-option-card{background:#fff;border:3px solid var(--border);padding:32px;border-radius:24px;font-size:1.5rem;font-weight:700;display:flex;align-items:center;gap:24px;box-shadow:8px 8px 0 var(--border)}.q-option-card span{background:var(--brand);color:#fff;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0}.bottom-sheet-backdrop{position:fixed;inset:0;background:#0b1f4d4d;z-index:80;display:flex;justify-content:center;align-items:flex-end}.bottom-sheet{background:#fff;width:100%;max-width:520px;border-radius:18px 18px 0 0;padding:12px 16px 24px;box-shadow:0 -8px 24px #0b1f4d33}.bottom-sheet-handle{width:42px;height:5px;border-radius:999px;background:#0b1f4d33;margin:0 auto 12px}.bottom-sheet-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.bottom-sheet-body{margin-top:16px}.sheet-badge{display:inline-block;padding:6px 10px;border-radius:999px;background:#0b1f4d14;color:var(--brand);font-weight:600;margin-bottom:12px}.sheet-entries{display:grid;gap:12px}.sheet-entry{border:1px dashed var(--border);border-radius:14px;padding:10px 12px;background:#fffdf8}.trainee-quiz-view{padding-bottom:40px}.trainee-quiz-view .quiz-header{margin:-16px -16px 16px;padding:16px;border-radius:0;border-bottom:1px solid var(--border);background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media(min-width:641px){.trainee-quiz-view .quiz-header{margin:0 0 24px;border-radius:12px;border:1px solid var(--border)}}.trainee-quiz-view .q-options-grid{gap:12px;margin-top:24px}.trainee-quiz-view .q-option-card{padding:20px;font-size:1.1rem}@media(max-width:640px){.journey-map{height:760px}.marker-label{padding:6px 8px}.marker-meta{display:none}}
