*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--pt-bg: #0a0a0f;--pt-surface: #141420;--pt-surface-light: #1e1e2e;--pt-text: #e8e8f0;--pt-text-muted: #8888a0;--pt-accent: #60a5fa;--pt-accent-glow: rgba(96, 165, 250, .3);--pt-font: "Inter", system-ui, -apple-system, sans-serif;--pt-font-display: "Sora", "Inter", sans-serif}html{scroll-behavior:smooth}body{font-family:var(--pt-font);background:var(--pt-bg);color:var(--pt-text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow:hidden;height:100vh}.pt-page{height:100vh;display:flex;flex-direction:column}.pt-header{padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.06);background:#0a0a0fcc;backdrop-filter:blur(12px);z-index:20;flex-shrink:0}.pt-logo-group{display:flex;align-items:center;gap:.6rem}.pt-logo-mark{width:28px;height:28px;flex-shrink:0}.pt-logo-text{display:flex;flex-direction:column;line-height:1;gap:1px}.pt-logo-name{font-family:var(--pt-font-display);font-size:.95rem;font-weight:700;letter-spacing:.04em;color:var(--pt-text);text-transform:uppercase}.pt-logo-tagline{font-size:.48rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--pt-text-muted)}.pt-header-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:100px;background:#60a5fa1a;border:1px solid rgba(96,165,250,.2);color:var(--pt-accent);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.pt-header-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--pt-accent);animation:ptPulse 2s ease-in-out infinite}@keyframes ptPulse{0%,to{opacity:1}50%{opacity:.3}}.pt-back-link{font-size:.78rem;color:var(--pt-text-muted);text-decoration:none;padding:.35rem .75rem;border-radius:6px;transition:all .2s}.pt-back-link:hover{color:var(--pt-text);background:var(--pt-surface-light)}.pt-player-section{flex:1;position:relative;overflow:hidden}.pt-wrapper{width:100%;height:100%;position:relative}.pt-canvas{width:100%;height:100%;background:var(--pt-bg)}.pt-canvas canvas{display:block}.pt-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--pt-bg);color:#ffffffb3;font-family:var(--pt-font);font-size:.9rem;letter-spacing:.05em;z-index:20}.pt-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--pt-accent);border-radius:50%;animation:pt-spin .8s linear infinite}@keyframes pt-spin{to{transform:rotate(360deg)}}.pt-hud{position:absolute;inset:0;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;z-index:10}.pt-hud-top{display:flex;justify-content:center;padding:1.25rem}.pt-stop-indicator{display:flex;gap:8px;padding:6px 14px;border-radius:100px;background:#0a0a0f99;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);pointer-events:auto}.pt-stop-dot{position:relative;width:10px;height:10px;border-radius:50%;border:none;padding:0;background:#fff3;cursor:pointer;transition:all .4s ease}.pt-stop-dot:hover{background:#ffffff80;transform:scale(1.3)}.pt-stop-dot--active{background:var(--pt-accent);box-shadow:0 0 10px var(--pt-accent-glow);transform:scale(1.3)}.pt-stop-dot--done{background:#60a5fa80}.pt-stop-dot-tooltip{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);white-space:nowrap;font-family:var(--pt-font);font-size:.75rem;font-weight:500;color:#fff;background:#0f172ae6;padding:4px 10px;border-radius:5px;backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000004d;pointer-events:none;opacity:0;transition:opacity .2s ease}.pt-stop-dot:hover .pt-stop-dot-tooltip{opacity:1}.pt-hud-bottom{background:linear-gradient(transparent,#0a0a0fd9 40%);padding:3rem 2rem 1.5rem;pointer-events:auto}.pt-info{margin-bottom:1rem}.pt-info-label{font-family:var(--pt-font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.3rem;text-shadow:0 2px 12px rgba(0,0,0,.5)}.pt-info-desc{font-size:.88rem;color:var(--pt-text-muted);max-width:100%;line-height:1.55;white-space:pre-line;text-shadow:0 1px 8px rgba(0,0,0,.5)}.pt-controls{display:flex;align-items:center;gap:.75rem}.pt-play-btn{width:40px;height:40px;border-radius:50%;border:none;background:#ffffff1a;backdrop-filter:blur(8px);color:var(--pt-text);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.pt-play-btn:hover{background:#fff3;transform:scale(1.05)}.pt-progress-bar{flex:1;height:4px;border-radius:2px;background:#ffffff1a;overflow:hidden}.pt-progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--pt-accent),#a78bfa);transition:width .15s linear}.pt-stop-count{font-size:.75rem;font-weight:600;color:var(--pt-text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:36px;text-align:right}.pt-footer{flex-shrink:0;text-align:center;padding:.6rem 1rem;border-top:1px solid rgba(255,255,255,.06);font-size:.7rem;color:var(--pt-text-muted);background:#0a0a0fe6;z-index:20}.pt-footer a{color:var(--pt-accent);text-decoration:none}.pt-footer a:hover{text-decoration:underline}.hs{position:absolute;left:0;top:0;width:50px;height:50px;border:none;background:transparent;cursor:pointer;z-index:15;display:flex;align-items:center;justify-content:center;padding:0;will-change:transform;transition:opacity .4s ease}.hs__pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:var(--c);opacity:.3;animation:hsPulse 2s ease-out infinite}@keyframes hsPulse{0%{transform:scale(1);opacity:.4}to{transform:scale(2.5);opacity:0}}.hs__icon{position:relative;width:36px;height:36px;background:linear-gradient(135deg,#60a5fa,#2563eb,#1e40af);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--pt-font);font-weight:700;font-size:1rem;color:#fff;box-shadow:0 0 20px color-mix(in srgb,var(--c) 50%,transparent);transition:transform .3s ease,box-shadow .3s ease}.hs__label{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;white-space:nowrap;font-family:var(--pt-font);font-size:.8rem;font-weight:500;color:#fff;background:#0f172ae0;padding:4px 12px;border-radius:6px;backdrop-filter:blur(8px);box-shadow:0 2px 8px #00000040;pointer-events:none}.pth-modal-overlay{position:absolute;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#000000bf;backdrop-filter:blur(8px);animation:pthFadeIn .25s ease}@keyframes pthFadeIn{0%{opacity:0}to{opacity:1}}.pth-modal{position:relative;background:var(--pt-surface);border:1px solid rgba(255,255,255,.08);border-radius:16px;width:min(92vw,860px);max-height:88vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:pthSlideUp .3s ease}@keyframes pthSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.pth-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;border:none;background:#ffffff1a;color:var(--pt-text);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:all .2s}.pth-modal-close:hover{background:#fff3}.pth-modal-header{padding:1.25rem 1.5rem .5rem;display:flex;align-items:center;gap:.6rem}.pth-modal-badge{width:10px;height:10px;border-radius:50%;background:var(--pt-accent);flex-shrink:0}.pth-modal-title{font-family:var(--pt-font-display);font-size:1.2rem;font-weight:700;color:var(--pt-text)}.pth-modal-description{padding:.25rem 2rem .75rem;margin:0;color:#ffffffb3;font-size:.9rem;line-height:1.6}.pth-modal-media{padding:.75rem 1.5rem 1.5rem;flex:1;min-height:0}.pth-modal-video{width:100%;aspect-ratio:16 / 9;border-radius:10px;background:#000;display:block;max-height:70vh}.pth-modal-3d{width:100%;height:440px;border-radius:10px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);overflow:hidden}.pth-modal-3d model-viewer{--poster-color: transparent}.pth-modal-3d .mv-hotspot{background:none;border:none;padding:0;margin:0;position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer;z-index:10;pointer-events:auto}.pth-modal-3d .mv-hotspot-dot{position:relative;width:20px;height:20px;border-radius:50%;background:radial-gradient(circle,#60a5fa,#2563eb 70%);border:2.5px solid #fff;box-shadow:0 0 0 3px #2563eb59,0 2px 8px #0000004d;transition:transform .2s ease,box-shadow .2s ease}.pth-modal-3d .mv-hotspot-dot:before{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,99,235,.5);animation:mvRipple 2s ease-out infinite}@keyframes mvRipple{0%{transform:scale(1);opacity:.6}to{transform:scale(2.2);opacity:0}}.pth-modal-3d .mv-hotspot:hover .mv-hotspot-dot{transform:scale(1.3);box-shadow:0 0 0 4px #2563eb80,0 4px 16px #00000059}.pth-modal-3d .mv-hotspot:hover .mv-hotspot-dot:before{animation:none;opacity:0}.pth-modal-3d .mv-hotspot-label{display:none}.pth-modal-3d .mv-hotspot[data-visibility-attribute]:not([data-visible]){opacity:.15;pointer-events:none;transition:opacity .3s ease}.pth-modal-3d .mv-hotspot[data-visible]{opacity:1;transition:opacity .3s ease}.pth-modal-3d .mv-hotspot-tooltip{position:absolute;top:calc(100% + 14px);left:50%;width:210px;padding:10px 14px;border-radius:10px;background:#0f172af0;backdrop-filter:blur(10px);color:#f1f5f9;font-family:var(--pt-font);font-size:.78rem;line-height:1.5;text-align:left;box-shadow:0 8px 24px #0006;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;transform:translate(-50%) translateY(-4px)}.pth-modal-3d .mv-hotspot-tooltip strong{display:block;font-size:.82rem;font-weight:600;color:#fff;margin-bottom:3px}.pth-modal-3d .mv-hotspot-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#0f172af0}.pth-modal-3d .mv-hotspot:hover .mv-hotspot-tooltip{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}@media(max-width:768px){.pt-header{padding:.6rem 1rem}.pt-header-badge{display:none}.pt-hud-bottom{padding:2rem 1rem 1rem}.pt-info-label{font-size:1.15rem}.pt-info-desc{font-size:.8rem}.pt-play-btn{width:36px;height:36px}.pth-modal-description{padding:.25rem 1.25rem .5rem;font-size:.82rem}}
