*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--white: oklch(.99 .003 240);--off-white: oklch(.97 .004 240);--line: oklch(.88 .008 240);--muted: oklch(.72 .012 240);--text: oklch(.22 .015 240);--text-light: oklch(.52 .015 240);--accent: oklch(.62 .16 220);--accent-glow: oklch(.72 .18 220);--accent-dim: oklch(.62 .16 220 / .12);--danger: oklch(.62 .18 25)}html,body{width:100%;height:100%;overflow:hidden;background:var(--white)}body{font-family:Space Grotesk,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased}#root{width:100%;height:100%;display:flex;flex-direction:column}button,input,textarea,select{font:inherit}.overlay{position:fixed;inset:0;background:var(--overlay-bg, oklch(.1 .02 240 / .45));-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;display:flex;align-items:flex-end;justify-content:center;padding-bottom:16px;animation:fadeIn .18s ease}@media(min-height:600px){.overlay{align-items:center;padding-bottom:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes centeredSlideUp{0%{transform:translate(-50%,24px);opacity:0}to{transform:translate(-50%);opacity:1}}.intro-splash{position:fixed;inset:0;z-index:300;display:grid;place-items:center;background:radial-gradient(circle at 50% 42%,var(--accent-dim),transparent 42%),var(--white);animation:introFadeOut 2.6s ease forwards;pointer-events:none}.intro-stage{width:min(360px,82vw);color:var(--accent);text-align:center}.intro-svg{width:100%;height:auto;overflow:visible}.intro-thread-line{fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-dasharray:360;stroke-dashoffset:360;filter:drop-shadow(0 0 10px color-mix(in oklab,var(--accent) 45%,transparent));animation:introDrawLine 2.1s cubic-bezier(.22,1,.36,1) .35s forwards}.intro-yarn-ball{fill:color-mix(in oklab,var(--accent) 12%,var(--white));stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;transform-origin:94px 82px;animation:introUnwind 2.25s cubic-bezier(.22,1,.36,1) forwards}.intro-yarn-ball path{fill:none;opacity:.9}.intro-end-dot{fill:currentColor;opacity:0;animation:introDot .45s ease 1.85s forwards}.intro-title{margin-top:6px;color:var(--text);font-size:15px;font-weight:600;letter-spacing:0;animation:introTitle 2.1s ease forwards}.upload-overlay{position:fixed;inset:0;z-index:220;display:grid;place-items:center;background:var(--overlay-bg, oklch(.1 .02 240 / .45));-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);animation:fadeIn .15s ease}.upload-card{min-width:148px;min-height:96px;padding:18px 20px;border-radius:18px;background:var(--modal-bg);border:1px solid var(--line);color:var(--text);display:grid;place-items:center;gap:10px;box-shadow:0 24px 70px #0004083d;font-size:15px;font-weight:600}.upload-spinner{width:26px;height:26px;border-radius:50%;border:3px solid var(--accent-dim);border-top-color:var(--accent);animation:uploadSpin .8s linear infinite}@keyframes introDrawLine{to{stroke-dashoffset:0}}@keyframes introUnwind{0%{transform:translate(72px) rotate(0) scale(1);opacity:1}62%{transform:translate(16px) rotate(-210deg) scale(.74);opacity:.92}to{transform:translate(-78px) rotate(-420deg) scale(.18);opacity:0}}@keyframes introDot{to{opacity:1}}@keyframes introTitle{0%,18%{opacity:0;transform:translateY(8px)}45%,82%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}@keyframes introFadeOut{0%,78%{opacity:1}to{opacity:0;visibility:hidden}}@keyframes uploadSpin{to{transform:rotate(360deg)}}.modal{background:var(--modal-bg, var(--white));border-radius:20px;width:min(480px,94vw);max-height:88vh;overflow-y:auto;padding:28px;box-shadow:0 24px 80px #00040833;animation:slideUp .22s cubic-bezier(.22,1,.36,1);margin-bottom:env(keyboard-inset-height,0px)}.modal-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:4px;letter-spacing:-.3px}.modal-sub{font-family:DM Mono,monospace;font-size:11px;color:var(--accent);letter-spacing:.04em;margin-bottom:20px}label{font-size:12px;font-weight:500;color:var(--text-light);display:block;margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}input[type=text],input[type=datetime-local],textarea,select{width:100%;padding:10px 14px;border-radius:10px;border:1.5px solid var(--line);background:var(--off-white);font-family:Space Grotesk,sans-serif;font-size:14px;color:var(--text);outline:none;transition:border-color .15s;resize:none}input[type=text]:focus,input[type=datetime-local]:focus,textarea:focus,select:focus{border-color:var(--accent)}.form-row{margin-bottom:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:10px;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.12)}.btn-ghost{background:transparent;color:var(--text-light);border:1.5px solid var(--line)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:#f9f4f3;color:var(--danger);border:1.5px solid oklch(.9 .04 25)}.btn-danger:hover{background:var(--danger);color:#fff;border-color:transparent}.btn:disabled{opacity:.45;cursor:not-allowed;filter:none}.btn-row{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}.upload-zone{border:1.5px dashed var(--line);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .15s;background:var(--off-white);color:var(--text-light);font-size:13px}.upload-zone:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.recording-panel{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:12px;border:1.5px solid var(--line);background:var(--off-white)}.record-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);box-shadow:0 0 #de4e4b7a;animation:recordPulse 1.15s ease-out infinite}@keyframes recordPulse{0%{box-shadow:0 0 #de4e4b7a}to{box-shadow:0 0 0 10px #de4e4b00}}.color-swatches{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:all .15s;flex-shrink:0}.color-swatch.active{border-color:var(--text);transform:scale(1.15)}.geo-status{margin-top:8px;padding:8px 10px;border-radius:10px;background:var(--off-white);border:1px solid var(--line);color:var(--text-light);font-size:12px;line-height:1.5}.geo-status.ok{color:var(--accent);border-color:color-mix(in oklab,var(--accent) 35%,var(--line));background:var(--accent-dim)}.geo-candidates{display:flex;flex-direction:column;gap:7px;margin-top:8px;max-height:220px;overflow-y:auto}.geo-candidate{width:100%;padding:9px 10px;border-radius:10px;border:1px solid var(--line);background:var(--off-white);color:var(--text);cursor:pointer;text-align:left}.geo-candidate:hover{border-color:var(--accent);background:var(--accent-dim)}.geo-candidate b{display:block;font-size:12px;font-weight:500;line-height:1.45}.geo-candidate small{display:block;margin-top:4px;color:var(--accent);font-family:DM Mono,monospace;font-size:10px}.map-picker{margin-top:10px}.map-picker-hint,.map-empty-note{margin-top:8px;color:var(--text-light);font-size:11px;line-height:1.45}.topbar{position:fixed;top:0;left:0;right:0;min-height:56px;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 20px;background:var(--topbar-bg, oklch(.99 .003 240 / .85));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--topbar-border, oklch(.9 .006 240 / .6))}.topbar-title{font-size:15px;font-weight:600;letter-spacing:-.3px;white-space:nowrap;flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}.topbar-title{color:var(--topbar-title, var(--text));text-shadow:var(--topbar-title-shadow, none)}.topbar-time{font-family:DM Mono,monospace;font-size:11px;color:var(--accent);letter-spacing:.06em;white-space:nowrap}.topbar-tools{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex:1 1 auto;min-width:0}.topbar-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--off-white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;color:var(--text);flex-shrink:0}.topbar-btn:hover{background:var(--accent-dim);color:var(--accent)}.topbar-btn.active{background:var(--accent);color:#fff}.search-panel{position:fixed;top:66px;right:16px;z-index:60;width:min(360px,calc(100vw - 32px));padding:12px;border-radius:14px;background:var(--topbar-bg);border:1px solid var(--topbar-border);box-shadow:0 18px 50px #0004082e;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.jump-panel{position:fixed;top:66px;right:16px;z-index:60;width:min(340px,calc(100vw - 32px));padding:12px;border-radius:14px;background:var(--topbar-bg);border:1px solid var(--topbar-border);box-shadow:0 18px 50px #0004082e;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.quick-jumps{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}.search-panel input{height:38px}.filter-row{display:flex;gap:6px;margin-top:8px}.filter-chip{flex:1;height:28px;border-radius:999px;border:1px solid var(--line);background:var(--off-white);color:var(--text-light);font-size:12px;cursor:pointer}.filter-chip.active{background:var(--accent);border-color:transparent;color:#fff}.view-pill{font-family:DM Mono,monospace;font-size:11px;letter-spacing:.08em;padding:4px 10px;border-radius:20px;-webkit-user-select:none;user-select:none;cursor:pointer;white-space:nowrap;appearance:none}.timeline-wrap{flex:1;overflow:hidden;position:relative;touch-action:none;cursor:ns-resize}.history-view{position:relative;flex:1;min-height:100%;overflow:hidden;background:radial-gradient(ellipse 90% 70% at 50% 30%,#fdf3e8,#f3e5d7);color:#371c0d}.history-stage{position:absolute;top:var(--history-top, 56px);left:0;right:0;bottom:0;overflow:hidden}.history-intro{position:absolute;top:8%;left:50%;z-index:2;width:min(620px,calc(100vw - 40px));text-align:center;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity .5s,transform .5s}.history-intro-title{font-size:clamp(24px,5vw,36px);font-weight:300;letter-spacing:0;line-height:1.15}.history-intro-mono{margin-top:8px;color:#c36032;font-family:DM Mono,monospace;font-size:11px;letter-spacing:.18em}.history-intro-hint{margin-top:14px;color:#7b5b49;font-size:12px;letter-spacing:.04em}.history-yarns-carousel-wrap{position:absolute;left:0;right:0;bottom:calc(40px + env(safe-area-inset-bottom,0px));z-index:4;-webkit-user-select:none;user-select:none;padding-bottom:24px}.history-yarns-carousel{width:100%;overflow:hidden;cursor:grab;touch-action:none;padding:90px 0 32px;-webkit-mask-image:linear-gradient(to right,transparent 0%,black 14%,black 86%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 14%,black 86%,transparent 100%)}.history-yarns-carousel.dragging{cursor:grabbing}.history-yarns-carousel.pulling-up .history-yarn-slot.is-center .history-yarn-svg-wrap{transform:translateY(-18px) scale(1.05)}.history-yarns-track{display:flex;align-items:flex-end;padding:0 calc(50% - 85px);will-change:transform}.history-yarns-track.snap{transition:transform .55s cubic-bezier(.22,1,.36,1)}.history-yarn-slot{flex:0 0 170px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:10px;border:0;background:transparent;color:#371c0d;cursor:pointer;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .4s ease,filter .4s ease;will-change:transform,opacity}.history-yarns-carousel-wrap.picker-active .history-yarn-slot:not(.is-center){opacity:.12!important;pointer-events:none}.history-yarn-svg-wrap{position:relative;pointer-events:none;transition:transform .4s cubic-bezier(.22,1,.36,1)}.history-yarn-slot.is-center .history-yarn-svg-wrap{animation:historyCenterBob 3.6s ease-in-out infinite}.history-yarn-slot.launching{z-index:10;opacity:1!important;pointer-events:none}.history-yarn-slot.launching .history-yarn-svg-wrap{animation:historyYarnLaunch 1.18s cubic-bezier(.18,.84,.26,1) forwards}.history-yarn-slot.launching .history-yarn-svg-wrap:after{content:"";position:absolute;left:50%;bottom:58%;width:3px;height:0;border-radius:999px;background:linear-gradient(to top,#c36032,#c3603200);box-shadow:0 0 16px #c360326b;transform:translate(-50%);animation:historyYarnThreadPull 1.18s cubic-bezier(.18,.84,.26,1) forwards}.history-yarn-slot.launching .history-yarn-svg-wrap svg{animation:historyYarnTighten 1.18s cubic-bezier(.18,.84,.26,1) forwards}.history-yarn-slot.launching .history-yarn-label,.history-yarn-slot.launching .history-yarn-meta{opacity:0;transition:opacity .18s ease}@keyframes historyCenterBob{0%,to{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-6px) rotate(1.5deg)}}@keyframes historyYarnLaunch{0%{transform:translateY(-6px) scale(1.04) rotate(0);filter:brightness(1);opacity:1}32%{transform:translateY(-54px) scale(1.08) rotate(-2deg);filter:brightness(1.08);opacity:1}72%{transform:translateY(-136px) scale(.92) rotate(2deg);filter:brightness(1.1);opacity:.86}to{transform:translateY(-260px) scale(.62) rotate(5deg);filter:brightness(1.12);opacity:0}}@keyframes historyYarnTighten{0%{transform:scale(1);opacity:1;filter:drop-shadow(0 12px 18px oklch(.3 .06 50 / .18))}38%{transform:scale(.82,1.08);opacity:.95}72%{transform:scale(.24,1.78);opacity:.72}to{transform:scale(.06,2.45);opacity:.18;filter:drop-shadow(0 0 14px oklch(.6 .14 44 / .5))}}@keyframes historyYarnThreadPull{0%{height:0;opacity:0;transform:translate(-50%) translateY(0)}24%{height:90px;opacity:.88}70%{height:230px;opacity:.98;transform:translate(-50%) translateY(-86px)}to{height:340px;opacity:0;transform:translate(-50%) translateY(-210px)}}.history-yarn-svg-wrap svg{display:block;filter:drop-shadow(0 12px 18px oklch(.3 .06 50 / .18))}.history-yarn-shadow{position:absolute;left:50%;bottom:-14px;width:80%;height:14px;border-radius:50%;background:radial-gradient(ellipse,oklch(.3 .06 50 / .28) 0%,transparent 70%);filter:blur(1px);transform:translate(-50%)}.history-yarn-label{padding:3px 10px;border:1px solid oklch(.84 .03 65);border-radius:20px;background:#fdf3e8d9;color:#371c0d;font-family:DM Mono,monospace;font-size:13px;letter-spacing:.08em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.history-yarn-meta{color:#7b5b49;font-family:DM Mono,monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;opacity:.7}.history-center-marker{position:absolute;left:50%;bottom:0;display:grid;place-items:center;opacity:.75;pointer-events:none;transform:translate(-50%)}.history-center-marker-arrow{width:22px;height:22px;border-top:2px solid oklch(.6 .14 44);border-left:2px solid oklch(.6 .14 44);transform:rotate(45deg);filter:drop-shadow(0 0 10px oklch(.6 .14 44 / .35));animation:historyArrowPulse 1.6s ease-in-out infinite}@keyframes historyArrowPulse{0%,to{translate:0 4px;opacity:.55}50%{translate:0 -2px;opacity:1}}.history-carousel-arrow{position:absolute;top:50%;z-index:5;width:36px;height:36px;border:1px solid oklch(.84 .03 65);border-radius:50%;display:grid;place-items:center;background:#fdf3e8d9;color:#7b5b49;cursor:pointer;transform:translateY(-50%);transition:transform .15s,border-color .15s,color .15s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.history-carousel-arrow:hover{border-color:#c36032;color:#c36032;transform:translateY(-50%) scale(1.06)}.history-carousel-arrow:disabled{opacity:.25;pointer-events:none}.history-carousel-arrow.left{left:14px}.history-carousel-arrow.right{right:14px}.history-thread-unwind{position:absolute;left:50%;bottom:0;width:2.5px;height:0;background:linear-gradient(to top,#c36032,#c3603200);opacity:0;pointer-events:none;transform:translate(-50%);transition:height .7s cubic-bezier(.22,1,.36,1),opacity .35s}.history-thread-unwind.show{height:50vh;opacity:1}.history-picker-overlay{position:absolute;inset:0;z-index:6;display:flex;justify-content:center;align-items:flex-start;padding-top:12vh;pointer-events:none}.history-picker-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 28px 22px;border:1px solid oklch(.84 .03 65);border-radius:24px;background:#fdf3e8db;box-shadow:0 24px 60px #45240f2e;pointer-events:auto;animation:historyPickerIn .5s cubic-bezier(.22,1,.36,1);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}@keyframes historyPickerIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.history-picker-prompt{color:#c36032;font-family:DM Mono,monospace;font-size:10px;letter-spacing:.18em}.history-year-wheel{width:240px;height:166px;overflow-y:auto;padding:62px 0;scroll-snap-type:y mandatory;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 25%,black 75%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,black 25%,black 75%,transparent 100%);scrollbar-width:none}.history-year-wheel::-webkit-scrollbar{width:0}.history-year-item{width:100%;height:42px;border:0;display:flex;align-items:center;justify-content:center;background:transparent;color:#7b5b49;font-family:DM Mono,monospace;font-size:32px;font-weight:300;letter-spacing:.04em;cursor:pointer;scroll-snap-align:center;scroll-snap-stop:always;transition:color .2s,transform .2s}.history-year-item.active{color:#c36032;font-weight:500;transform:scale(1.08)}.history-year-summary{width:100%;padding-top:10px;border-top:1px solid oklch(.84 .03 65);display:flex;justify-content:center;gap:18px;color:#7b5b49;font-family:DM Mono,monospace;font-size:10px;letter-spacing:.08em}.history-year-summary b{color:#c36032;font-size:13px;font-weight:500}.history-picker-actions{display:flex;gap:10px;margin-top:6px}.history-picker-btn{min-height:38px;padding:0 20px;border-radius:24px;border:0;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:transform .15s,filter .15s,border-color .15s,color .15s}.history-picker-btn.primary{background:#c36032;color:#fff;box-shadow:0 4px 14px #c3603259}.history-picker-btn.primary:hover{filter:brightness(1.08);transform:translateY(-1px)}.history-picker-btn.ghost{border:1.5px solid oklch(.84 .03 65);background:transparent;color:#7b5b49}.history-picker-btn.ghost:hover{border-color:#c36032;color:#c36032}.showcase-view{position:relative;flex:1;min-height:100%;overflow:hidden;background:radial-gradient(ellipse 80% 60% at 50% 35%,var(--white) 0%,var(--off-white) 100%);color:var(--text)}.showcase-stage{position:absolute;left:0;right:0;top:var(--showcase-top, 56px);bottom:80px;perspective:var(--showcase-persp, 1200px);perspective-origin:50% 45%;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab}.showcase-stage.grabbing{cursor:grabbing}.showcase-stage:before,.showcase-stage:after{content:"";position:absolute;left:0;right:0;height:120px;z-index:5;pointer-events:none}.showcase-stage:before{top:0;background:linear-gradient(to bottom,var(--white) 0%,transparent 100%)}.showcase-stage:after{bottom:0;background:linear-gradient(to top,var(--white) 0%,transparent 100%)}.showcase-scene{position:absolute;left:50%;top:0;width:0;height:100%;transform-style:preserve-3d}.showcase-lane{position:absolute;left:0;top:0;width:240px;height:100%;margin-left:-120px;transform-style:preserve-3d;will-change:transform,opacity;transition:opacity .4s ease,transform .5s cubic-bezier(.22,1,.36,1)}.showcase-lane-axis{position:absolute;left:50%;top:0;bottom:0;width:1.5px;transform:translate(-50%);background:linear-gradient(to bottom,transparent 0%,var(--lane-color) 18%,var(--lane-color) 82%,transparent 100%);box-shadow:0 0 14px color-mix(in oklab,var(--lane-color) 60%,transparent)}.showcase-now-dot{position:absolute;left:50%;width:14px;height:14px;border-radius:50%;transform:translate(-50%,-50%);background:var(--lane-color);box-shadow:0 0 16px var(--lane-color),0 0 0 2px var(--white)}.showcase-now-dot:after{content:"NOW";position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--lane-color);font-family:DM Mono,monospace;font-size:9px;font-weight:500;letter-spacing:.1em}.showcase-tick{position:absolute;left:50%;height:1px;transform:translate(-50%,-50%);color:var(--text-light);opacity:.25}.showcase-tick.major{opacity:.62}.showcase-tick-label{position:absolute;left:calc(50% - 22px);transform:translate(-50%,calc(-50% - 8px));color:var(--text-light);font-family:DM Mono,monospace;font-size:9px;letter-spacing:.06em;opacity:.55;pointer-events:none;white-space:nowrap}.showcase-lane-stamp{position:absolute;left:50%;display:flex;align-items:center;gap:8px;border:0;background:transparent;color:var(--text);cursor:pointer;transform:translateY(-50%)}.showcase-lane-stamp.left{transform:translate(-100%,-50%);flex-direction:row-reverse}.showcase-stamp-axis-tick{position:absolute;left:50%;top:50%;width:12px;height:1.5px;background:var(--stamp-color);transform:translateY(-50%)}.showcase-lane-stamp.left .showcase-stamp-axis-tick{transform:translateY(-50%) translate(-100%)}.showcase-stamp-thumb{width:44px;height:44px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;border:2px solid var(--stamp-color);background-color:color-mix(in oklab,var(--stamp-color) 18%,var(--white));background-size:cover;background-position:center;box-shadow:0 2px 14px color-mix(in oklab,var(--stamp-color) 45%,transparent);color:var(--stamp-color);font-size:16px;font-weight:600;transition:transform .18s}.showcase-lane-stamp:hover .showcase-stamp-thumb{transform:scale(1.1)}.showcase-stamp-card{max-width:160px;padding:5px 10px;border:1px solid color-mix(in oklab,var(--stamp-color) 35%,transparent);border-radius:8px;background:color-mix(in oklab,var(--white) 86%,transparent);box-shadow:0 2px 12px #0e171e14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.showcase-stamp-time{display:block;color:var(--stamp-color);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.05em}.showcase-stamp-note{display:block;max-width:140px;overflow:hidden;color:var(--text);font-size:11px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.showcase-lane-header{position:absolute;left:50%;top:18px;z-index:6;display:flex;flex-direction:column;align-items:center;gap:6px;border:0;background:transparent;transform:translate(-50%);cursor:pointer}.showcase-lane-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:15px;font-weight:600;letter-spacing:.02em;box-shadow:0 4px 16px #0e171e2e,inset 0 0 0 2px #fff6}.showcase-lane-name{padding:3px 10px;border:1px solid var(--line);border-radius:999px;background:color-mix(in oklab,var(--white) 82%,transparent);color:var(--text);font-size:13px;font-weight:500;white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.showcase-lane-meta{color:var(--text-light);font-family:DM Mono,monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase}.showcase-lane-footer{position:absolute;left:50%;bottom:18px;display:flex;align-items:center;gap:6px;transform:translate(-50%);color:var(--text-light);font-family:DM Mono,monospace;font-size:9px;letter-spacing:.08em}.showcase-pulse-dot{width:6px;height:6px;border-radius:50%;animation:showcasePulse 2s infinite}@keyframes showcasePulse{0%{box-shadow:0 0 0 0 currentColor}70%{box-shadow:0 0 0 8px transparent}to{box-shadow:0 0 0 0 transparent}}.showcase-room{position:absolute;left:50%;top:50%;width:0;height:0;transform:translate(-50%,-50%);transform-style:preserve-3d;pointer-events:none}.showcase-room-floor,.showcase-room-ceiling{position:absolute;left:-2400px;top:0;width:4800px;height:1500px;background-image:linear-gradient(to right,color-mix(in oklab,var(--accent) 12%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in oklab,var(--accent) 12%,transparent) 1px,transparent 1px);background-size:80px 80px;transform-origin:50% 0}.showcase-room-floor{transform:rotateX(90deg) translateY(0) translateZ(-700px);mask-image:radial-gradient(ellipse 60% 80% at 50% 0%,black 0%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 60% 80% at 50% 0%,black 0%,transparent 100%)}.showcase-room-ceiling{transform:rotateX(-90deg) translateY(0) translateZ(700px);mask-image:radial-gradient(ellipse 60% 80% at 50% 0%,black 0%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 60% 80% at 50% 0%,black 0%,transparent 100%)}.showcase-focus-flag{position:absolute;left:50%;top:8px;z-index:50;display:flex;align-items:center;gap:8px;padding:6px 14px 6px 6px;border:1px solid var(--line);border-radius:999px;background:color-mix(in oklab,var(--white) 90%,transparent);box-shadow:0 4px 16px #0e171e14;transform:translate(-50%);pointer-events:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.showcase-focus-flag>span{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:600}.showcase-focus-flag b{color:var(--text);font-size:12px}.showcase-focus-flag small{color:var(--text-light);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.06em}.showcase-tray{position:absolute;left:0;right:0;bottom:0;z-index:55;height:80px;display:flex;align-items:center;justify-content:center;gap:10px;overflow-x:auto;padding:0 20px;border-top:1px solid color-mix(in oklab,var(--line) 50%,transparent);background:color-mix(in oklab,var(--white) 80%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.showcase-tray::-webkit-scrollbar{height:0}.showcase-tray-label{margin-right:8px;color:var(--text-light);font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;white-space:nowrap}.showcase-tray-chip{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;border:0;background:transparent;cursor:pointer;opacity:.55;transition:transform .18s,opacity .18s}.showcase-tray-chip:hover,.showcase-tray-chip.active{opacity:1;transform:translateY(-2px)}.showcase-tray-chip>span{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:600}.showcase-tray-chip.active>span{box-shadow:0 0 0 2px var(--white),0 0 0 4px var(--accent),0 4px 14px #0e171e33}.showcase-tray-chip small{color:var(--text-light);font-size:9.5px;letter-spacing:.02em;white-space:nowrap}.showcase-tray-chip.active small{color:var(--text);font-weight:500}.showcase-scroll-date{position:fixed;left:50%;top:50%;z-index:50;margin-top:-60px;transform:translate(-50%);pointer-events:none;text-align:center;transition:opacity .25s ease}.showcase-scroll-date.hidden{opacity:0}.showcase-scroll-date.visible{opacity:1}.showcase-scroll-day{color:var(--accent);font-family:DM Mono,monospace;font-size:48px;font-weight:500;line-height:1;text-shadow:0 0 30px color-mix(in oklab,var(--accent) 40%,transparent)}.showcase-scroll-meta{margin-top:6px;color:var(--text-light);font-family:DM Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase}.atmosphere-effects{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}.timeline-svg{z-index:1}.entry-layer{position:absolute;inset:0;z-index:2;pointer-events:none}.entry-layer>*{pointer-events:auto}.effects-deep-space .stars{position:absolute;inset:-20%;opacity:.9;background-image:radial-gradient(circle at 12% 18%,oklch(.9 .08 210 / .86) 0 1px,transparent 1.6px),radial-gradient(circle at 28% 42%,oklch(.82 .14 220 / .7) 0 1px,transparent 1.7px),radial-gradient(circle at 68% 22%,oklch(.92 .04 230 / .72) 0 1px,transparent 1.5px),radial-gradient(circle at 82% 64%,oklch(.75 .18 200 / .72) 0 1px,transparent 1.6px);background-size:180px 180px,260px 260px,220px 220px,320px 320px;animation:starDrift 70s linear infinite}.effects-deep-space .shooting-star{position:absolute;width:150px;height:1px;right:-190px;top:-40px;background:linear-gradient(90deg,transparent,oklch(.86 .2 205 / .95) 28%,transparent);filter:drop-shadow(0 0 8px oklch(.72 .22 200));transform:rotate(-45deg);animation:shootingStar 7s ease-in-out infinite}.effects-deep-space .shooting-star.two{top:22%;animation-delay:3.6s;animation-duration:9s;opacity:.72}.effects-daylight .solar-lines{position:absolute;inset:0;opacity:.36;background-image:linear-gradient(100deg,transparent 0 38%,oklch(.72 .18 220 / .16) 39%,transparent 43%),linear-gradient(180deg,transparent 0 92%,oklch(.62 .16 220 / .12) 93%,transparent 100%);background-size:520px 100%,100% 86px;animation:daylightSweep 18s ease-in-out infinite}.effects-daylight .data-sparkles{position:absolute;inset:0;opacity:.34;background-image:radial-gradient(circle at 16% 30%,oklch(.72 .18 220 / .7) 0 1px,transparent 1.6px),radial-gradient(circle at 74% 58%,oklch(.52 .12 190 / .42) 0 1px,transparent 1.5px);background-size:140px 140px,210px 210px;animation:particleRise 34s linear infinite}.effects-amber .dust{position:absolute;inset:-10%;opacity:.42;background-image:radial-gradient(circle at 18% 72%,oklch(.73 .14 58 / .72) 0 1.2px,transparent 2px),radial-gradient(circle at 54% 26%,oklch(.65 .12 42 / .42) 0 1px,transparent 1.8px),radial-gradient(circle at 82% 48%,oklch(.82 .1 78 / .5) 0 1px,transparent 1.8px);background-size:170px 170px,240px 240px,300px 300px;animation:amberFloat 42s linear infinite}.effects-amber .heat-lines{position:absolute;inset:0;opacity:.26;background-image:repeating-linear-gradient(96deg,transparent 0 74px,oklch(.6 .14 44 / .12) 75px 76px,transparent 77px 160px);animation:heatShift 16s ease-in-out infinite}@keyframes starDrift{0%{transform:translateZ(0)}to{transform:translate3d(90px,120px,0)}}@keyframes shootingStar{0%,58%,to{transform:translateZ(0) rotate(-45deg);opacity:0}62%{opacity:1}76%{transform:translate3d(calc(-100vw - 300px),calc(100vw + 300px),0) rotate(-45deg);opacity:0}}@keyframes daylightSweep{0%,to{background-position:-220px 0,0 0}50%{background-position:calc(100vw + 220px) 0,0 40px}}@keyframes particleRise{0%{transform:translate3d(0,70px,0)}to{transform:translate3d(24px,-90px,0)}}@keyframes amberFloat{0%{transform:translate3d(0,50px,0)}to{transform:translate3d(-70px,-80px,0)}}@keyframes heatShift{0%,to{transform:translate(-16px) skew(-4deg)}50%{transform:translate(18px) skew(4deg)}}@media(prefers-reduced-motion:reduce){.atmosphere-effects *,.intro-splash,.intro-thread-line,.intro-yarn-ball,.intro-end-dot,.intro-title,.upload-spinner,.history-yarn-slot.is-center .history-yarn-svg-wrap{animation:none!important}.intro-splash{display:none}}.fab{position:fixed;bottom:calc(28px + env(safe-area-inset-bottom,0px));right:24px;z-index:50;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0095b566;box-shadow:0 4px 20px oklch(.62 .16 220 / .4);transition:all .2s;font-size:22px}.fab:hover{transform:scale(1.08);box-shadow:0 6px 28px #0095b58c;box-shadow:0 6px 28px oklch(.62 .16 220 / .55)}.detail-media{width:100%;border-radius:12px;overflow:hidden;background:var(--off-white);margin-bottom:16px;max-height:280px;display:flex;align-items:center;justify-content:center}.detail-media img{width:100%;height:100%;object-fit:cover}.detail-audio{width:100%;padding:16px;background:var(--off-white);border-radius:12px;margin-bottom:16px;display:flex;align-items:center;gap:12px}.detail-audio audio{flex:1;height:36px}.tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:500;letter-spacing:.04em;background:var(--off-white);color:var(--text-light)}.tile-map{position:relative;width:100%;min-height:220px;overflow:hidden;border-radius:14px;border:1px solid var(--line);background:var(--off-white);touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none}.tile-map:active{cursor:grabbing}.tile-layer{position:absolute;inset:0}.tile-layer img{position:absolute;width:256px;height:256px;max-width:none;pointer-events:none}.tile-map-crosshair{position:absolute;left:50%;top:50%;width:18px;height:18px;border-radius:50%;border:1px solid oklch(.1 .02 240 / .36);transform:translate(-50%,-50%);pointer-events:none}.tile-map-crosshair:before,.tile-map-crosshair:after{content:"";position:absolute;background:#0004085c}.tile-map-crosshair:before{left:50%;top:-7px;width:1px;height:32px}.tile-map-crosshair:after{left:-7px;top:50%;width:32px;height:1px}.tile-map-marker,.tile-map-point{position:absolute;z-index:2;width:22px;height:22px;border-radius:50% 50% 50% 4px;border:2px solid white;box-shadow:0 4px 14px #00040852;transform:translate(-50%,-100%) rotate(-45deg);cursor:pointer}.tile-map-marker:after,.tile-map-point:after{content:"";position:absolute;inset:5px;border-radius:50%;background:#fff}.tile-map-point{width:18px;height:18px}.tile-map-tools{position:absolute;right:10px;top:10px;z-index:3;display:flex;flex-direction:column;gap:6px}.tile-map-tools button{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--modal-bg);color:var(--text);cursor:pointer;font-size:18px;box-shadow:0 8px 18px #00040829}.tile-map-credit{position:absolute;left:8px;bottom:7px;z-index:3;padding:3px 6px;border-radius:7px;background:#ffffffc7;color:#2a343c;font-size:10px}.map-canvas{position:relative;height:280px;border-radius:14px;overflow:hidden;margin-bottom:14px;background:linear-gradient(90deg,var(--line) 1px,transparent 1px),linear-gradient(180deg,var(--line) 1px,transparent 1px),radial-gradient(circle at 50% 50%,var(--accent-dim),transparent 62%),var(--off-white);background-size:34px 34px,34px 34px,100% 100%,100% 100%;border:1px solid var(--line)}.map-point{position:absolute;width:18px;height:18px;border-radius:50%;border:2px solid var(--white);box-shadow:0 0 0 4px color-mix(in oklab,currentColor 18%,transparent),0 6px 16px #00040838;transform:translate(-50%,-50%);cursor:pointer}.map-empty{position:absolute;inset:0;display:grid;place-items:center;color:var(--text-light);font-family:DM Mono,monospace;font-size:12px;letter-spacing:.08em}.map-list{display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto}.map-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;border:1px solid var(--line);background:var(--off-white);color:var(--text);text-align:left;cursor:pointer}.map-row>span{width:10px;height:10px;border-radius:50%;flex-shrink:0}.map-row b{display:block;font-family:DM Mono,monospace;font-size:11px;color:var(--accent);margin-bottom:2px}.map-row small{display:block;color:var(--text-light);font-size:12px}.pending-list{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto}.pending-empty,.pending-note{color:var(--text-light);font-size:13px;line-height:1.55}.pending-note{margin-top:12px}.pending-item{padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:var(--off-white)}.pending-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.pending-head span{color:var(--danger);font-size:12px;font-weight:600;letter-spacing:.06em}.pending-head small{color:var(--accent);font-family:DM Mono,monospace;font-size:10px;white-space:nowrap}.pending-meta{color:var(--text);font-size:13px;line-height:1.45;overflow-wrap:anywhere}.pending-error{margin-top:7px;color:var(--text-light);font-family:DM Mono,monospace;font-size:10px;line-height:1.45;overflow-wrap:anywhere}.pending-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:10px;flex-wrap:wrap}.mini-action{min-height:28px;padding:0 10px;border-radius:8px;border:1px solid var(--line);background:var(--modal-bg);color:var(--accent);font-size:12px;cursor:pointer}.mini-action.danger{color:var(--danger)}.mini-action:disabled{opacity:.45;cursor:not-allowed}.scroll-date{position:fixed;left:50%;transform:translate(-50%);top:50%;margin-top:-60px;z-index:48;pointer-events:none;text-align:center;transition:opacity .25s ease,transform .25s ease}.scroll-date.visible{opacity:1;transform:translate(-50%) scale(1)}.scroll-date.hidden{opacity:0;transform:translate(-50%) scale(.92)}.scroll-date-day{font-family:DM Mono,monospace;font-size:56px;font-weight:500;letter-spacing:0;line-height:1;color:var(--accent);text-shadow:0 0 40px oklch(.62 .16 220 / .25)}.scroll-date-meta{font-family:DM Mono,monospace;font-size:13px;letter-spacing:.1em;color:var(--text-light);margin-top:6px;text-transform:uppercase}.zoom-hint{position:fixed;left:50%;transform:translate(-50%);bottom:40px;z-index:49;background:#141c21bf;color:#fff;font-family:DM Mono,monospace;font-size:11px;padding:5px 12px;border-radius:20px;pointer-events:none;opacity:0;transition:opacity .3s;letter-spacing:.06em}.zoom-hint.show{opacity:1}.update-toast{position:fixed;left:50%;bottom:calc(104px + env(safe-area-inset-bottom,0px));z-index:80;display:flex;align-items:center;gap:10px;padding:9px 10px 9px 14px;border-radius:999px;background:var(--topbar-bg);border:1px solid var(--topbar-border);color:var(--text);box-shadow:0 14px 40px #00040838;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transform:translate(-50%);animation:centeredSlideUp .22s cubic-bezier(.22,1,.36,1);font-size:13px}.twk-panel{position:fixed;right:16px;top:64px;z-index:2147483646;width:280px;max-height:min(520px,calc(100vh - 76px));display:flex;flex-direction:column;background:#faf9f7c7;color:#29261b;-webkit-backdrop-filter:blur(24px) saturate(160%);backdrop-filter:blur(24px) saturate(160%);border:.5px solid rgba(255,255,255,.6);border-radius:14px;box-shadow:0 1px #ffffff80 inset,0 12px 40px #0000002e;font:11.5px/1.4 ui-sans-serif,system-ui,-apple-system,sans-serif;overflow:hidden}.twk-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 8px 10px 14px;-webkit-user-select:none;user-select:none}.twk-hd b{font-size:12px;font-weight:600;letter-spacing:.01em}.twk-x{appearance:none;border:0;background:transparent;color:#29261b8c;width:22px;height:22px;border-radius:6px;cursor:pointer;font-size:13px;line-height:1}.twk-body{padding:2px 14px 14px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0}.twk-sect{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#29261b73;padding:10px 0 0;display:flex;flex-direction:column;gap:5px}.twk-sect:first-child{padding-top:0}.twk-field{appearance:none;width:100%;height:26px;padding:0 8px;border:.5px solid rgba(0,0,0,.1);border-radius:7px;background:#fff9;color:inherit;font:inherit;outline:none}.twk-seg{position:relative;display:flex;padding:2px;border-radius:8px;background:#0000000f;-webkit-user-select:none;user-select:none;gap:2px}.twk-seg button{appearance:none;position:relative;z-index:1;flex:1;border:0;background:transparent;color:inherit;font:inherit;font-weight:500;min-height:22px;border-radius:6px;cursor:pointer;padding:4px 6px;line-height:1.2;overflow-wrap:anywhere}.twk-seg button.active{background:#ffffffe6;box-shadow:0 1px 2px #0000001f}::-webkit-scrollbar{width:0}@media(max-width:520px){.topbar{min-height:92px;padding:8px 10px 9px;gap:7px;flex-direction:column;align-items:stretch;justify-content:center}.topbar-title{font-size:13px;max-width:none;width:100%;text-align:left}.topbar-time{display:none}.topbar-tools{overflow-x:auto;scrollbar-width:none;justify-content:flex-start;gap:6px;width:100%;padding-bottom:1px}.topbar-btn{width:34px;height:34px}.topbar-tools::-webkit-scrollbar{display:none}.view-pill{flex-shrink:0}.search-panel,.jump-panel{top:102px}.twk-panel{top:auto;right:10px;left:10px;bottom:calc(12px + env(safe-area-inset-bottom,0px));width:auto;max-height:min(70vh,520px);max-height:min(70dvh,520px)}.modal{padding:22px}.history-intro{top:7%}.history-intro-title{font-size:24px}.history-intro-hint{max-width:260px;margin-inline:auto;line-height:1.45}.history-yarns-carousel-wrap{bottom:calc(26px + env(safe-area-inset-bottom,0px))}.history-yarns-carousel{padding:76px 0 30px}.history-yarn-label{font-size:12px}.history-carousel-arrow{display:none}.history-picker-overlay{padding-top:13vh}.history-picker-card{width:min(328px,calc(100vw - 28px));padding:16px 18px 18px}.history-year-summary{gap:12px}.history-picker-actions{width:100%}.history-picker-btn{flex:1;padding-inline:12px}.showcase-stage{bottom:72px}.showcase-lane{width:210px;margin-left:-105px}.showcase-lane-header{top:12px}.showcase-lane-name,.showcase-lane-meta,.showcase-focus-flag small{display:none}.showcase-stamp-card{max-width:108px;padding:4px 8px}.showcase-stamp-note{max-width:92px}.showcase-stamp-thumb{width:38px;height:38px;border-radius:9px}.showcase-tray{height:72px;justify-content:flex-start;padding:0 12px max(0px,env(safe-area-inset-bottom,0px))}.showcase-tray-label{display:none}.showcase-focus-flag{top:6px;padding:5px 10px 5px 5px}.showcase-scroll-day{font-size:42px}}
