@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Noto+Serif+SC:wght@500;600;700&display=swap";:root{--bg-canvas: #f3f0ea;--bg-surface: #fcfaf6;--bg-panel: #fffdf9;--bg-soft: #f2eee6;--ink-strong: #23201d;--ink-body: #4d4842;--ink-muted: #7b756d;--line: #d8d1c5;--line-strong: #bdb4a7;--accent: #75624f;--accent-strong: #5f4d3b;--shadow: 0 18px 44px rgb(44 36 29 / 10%);color:var(--ink-strong);background:var(--bg-canvas);font-family:Manrope,Avenir Next,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{overflow-x:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at 8% 6%,rgb(255 255 255 / 52%) 0%,transparent 46%),radial-gradient(circle at 90% 10%,rgb(200 182 156 / 18%) 0%,transparent 43%),linear-gradient(160deg,#f4f0e9,#f6f3ee 40%,#efebe3)}button,input,textarea,select{font:inherit}button,summary,a{-webkit-tap-highlight-color:rgb(117 98 79 / 14%)}img,canvas{max-width:100%}.app-shell{min-height:100vh;padding:46px 22px}.workspace{width:min(1140px,100%);min-width:0;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:30px;padding:20px 22px;background:color-mix(in oklab,var(--bg-surface) 90%,white);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow)}.eyebrow{margin:0 0 6px;color:var(--ink-muted);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}h1{margin:0;font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:36px;font-weight:600;line-height:1.2}.nav-actions,.row-actions{display:flex;flex-wrap:wrap;gap:8px}.panel{padding:20px;background:var(--bg-panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}.form-grid{display:grid;gap:14px}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.admin-layout{display:grid;gap:16px}.collapsible-section{overflow:hidden;background:color-mix(in oklab,var(--bg-surface) 88%,white);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}.collapsible-summary{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;min-height:56px;padding:14px 18px;color:var(--ink-strong);font-weight:800;cursor:pointer;list-style:none}.collapsible-summary::-webkit-details-marker{display:none}.collapsible-summary:before{content:"›";grid-column:1;width:18px;color:var(--accent);font-size:24px;line-height:1;transform:rotate(0);transition:transform .18s ease}.collapsible-summary span{grid-column:2;min-width:0}.collapsible-summary small{grid-column:3;color:var(--ink-muted);font-size:13px;font-weight:700;white-space:nowrap}.collapsible-section[open] .collapsible-summary{border-bottom:1px solid var(--line)}.collapsible-section[open] .collapsible-summary:before{transform:rotate(90deg)}.collapsible-body{display:grid;gap:16px;padding:16px}.admin-action-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(220px,1fr);gap:16px;align-items:start}.admin-quick-actions{display:grid;gap:12px}.quick-import-panel{display:grid;gap:16px}.quick-user-strip{display:flex;gap:10px;min-width:0;padding:4px 2px 10px;overflow-x:auto;scrollbar-width:thin}.quick-user-card{display:grid;flex:0 0 104px;gap:8px;justify-items:center;min-height:122px;padding:10px 8px;color:var(--ink-body);text-align:center;background:var(--bg-surface);border-color:var(--line)}.quick-user-card:hover{color:var(--ink-strong);background:var(--bg-soft);border-color:var(--line-strong)}.quick-user-card.is-selected{color:#fffef9;background:var(--accent);border-color:var(--accent)}.quick-user-card .avatar{width:58px;height:58px;font-size:18px;box-shadow:none}.quick-user-card span{width:100%;overflow:hidden;font-size:13px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.quick-import-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}.file-picker{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.file-picker input{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.quick-preview-strip{display:flex;gap:10px;min-width:0;padding:4px 2px 10px;overflow-x:auto;scrollbar-width:thin}.quick-preview-card{position:relative;display:grid;flex:0 0 112px;gap:6px;margin:0;padding:8px;background:var(--bg-surface);border:1px solid var(--line);border-radius:8px}.quick-preview-card img{width:96px;height:72px;object-fit:cover;background:var(--bg-soft);border:1px solid var(--line);border-radius:6px}.quick-preview-remove{position:absolute;top:4px;right:4px;display:grid;width:24px;min-height:24px;padding:0;place-items:center;color:#fffef9;font-size:18px;line-height:1;background:#2c241db8;border-color:#fffdf96b;border-radius:999px}.quick-preview-remove:hover{background:#8c2642;border-color:#8c2642}.quick-preview-card figcaption{overflow:hidden;color:var(--ink-muted);font-size:12px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.single-preview-strip{padding-bottom:0;overflow:visible}.single-preview-card{flex-basis:138px}.single-preview-card img{width:122px;height:92px}.date-picker{position:relative}.date-picker-popover{position:absolute;top:calc(100% + 8px);left:0;z-index:20;width:292px;padding:12px;background:var(--bg-panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.date-picker-header{display:grid;grid-template-columns:38px 1fr 38px;gap:8px;align-items:center;margin-bottom:10px;text-align:center}.date-picker-header strong{font-size:15px}.date-picker-nav{min-height:36px;padding:4px;font-size:22px;line-height:1}.date-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.date-picker-weekday{display:grid;min-height:28px;place-items:center;color:var(--ink-muted);font-size:12px;font-weight:800}.date-picker-day{min-height:34px;padding:4px;color:var(--ink-body);background:var(--bg-surface);border-color:transparent}.date-picker-day:hover{color:var(--ink-strong);background:var(--bg-soft);border-color:var(--line)}.date-picker-day.is-muted{color:var(--ink-muted);background:transparent}.date-picker-day.is-selected{color:#fffef9;background:var(--accent);border-color:var(--accent)}.admin-artwork-filter{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr)) auto auto;gap:12px;align-items:end}.admin-user-filter{display:grid;grid-template-columns:minmax(180px,1fr) auto auto;gap:12px;align-items:end}.filter-count{align-self:center;color:var(--ink-muted);font-size:14px;white-space:nowrap}.section-note,.empty-state{color:var(--ink-muted)}label{display:grid;gap:6px;color:var(--ink-body);font-size:14px;font-weight:700}input,textarea,select{width:100%;min-height:42px;padding:8px 10px;color:var(--ink-strong);background:var(--bg-surface);border:1px solid var(--line);border-radius:6px;outline:none}textarea{min-height:110px;resize:vertical}input:disabled{color:var(--ink-muted);background:var(--bg-soft)}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #75624f33}button{min-height:42px;padding:8px 14px;color:#fffef9;background:var(--accent);border:1px solid var(--accent);border-radius:6px;cursor:pointer;transition:.18s ease}button,summary,input,textarea,select{touch-action:manipulation}button:hover{background:var(--accent-strong);border-color:var(--accent-strong);transform:translateY(-1px)}button:focus-visible,summary:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid rgb(117 98 79 / 28%);outline-offset:2px}button:focus:not(:focus-visible),summary:focus:not(:focus-visible){outline:none}.secondary-button{color:var(--ink-body);background:var(--bg-surface);border-color:var(--line)}.secondary-button:hover{background:var(--bg-soft)}.error-message,.success-message{padding:12px 14px;margin:0 0 14px;border-radius:8px}.error-message{color:#8c2642;background:#fef3f5;border:1px solid #f3c7d2}.success-message{color:#2f5f3f;background:#f4fbf6;border:1px solid #cde9d4;word-break:break-all}.pwa-install-prompt{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));z-index:120;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;width:min(520px,calc(100vw - 28px));padding:14px;color:var(--ink-strong);background:color-mix(in oklab,var(--bg-panel) 92%,white);border:1px solid var(--line);border-radius:10px;box-shadow:0 18px 44px #2c241d2e}.pwa-install-prompt strong{display:block;margin-bottom:4px;font-size:15px}.pwa-install-prompt p{margin:0;color:var(--ink-body);font-size:13px;line-height:1.55}.pwa-install-actions{display:flex;gap:8px}.pwa-install-actions button{min-height:38px;white-space:nowrap}.install-help-page{display:grid;gap:14px;padding:2px 0 18px}.install-help-page h2,.install-help-page h3,.install-help-page p{margin:0}.install-help-page h2{font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:22px;font-weight:600}.install-help-page header{display:grid;gap:6px}.install-help-page header p,.install-help-block p,.install-help-block li,.install-debug-panel dd{color:var(--ink-body);font-size:13px;line-height:1.62}.install-help-block{display:grid;gap:8px;padding:12px;background:#fcfaf69e;border:1px solid rgb(216 209 197 / 52%);border-radius:8px}.install-help-block h3{color:var(--ink-strong);font-size:14px}.install-help-block ol{display:grid;gap:5px;padding-left:20px;margin:0}.install-help-inline-button{min-height:0;padding:0 3px;color:var(--accent);font-size:inherit;font-weight:800;background:transparent;border:0;border-radius:0}.install-debug-panel dl{display:grid;grid-template-columns:auto minmax(0,1fr);gap:6px 10px;margin:0}.install-debug-panel dt{color:var(--ink-muted);font-size:12px;font-weight:800}.install-debug-panel dd{min-width:0;margin:0;overflow-wrap:anywhere}.user-list{display:grid;gap:10px;padding:0;margin:0;list-style:none}.user-list li{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:14px 16px;background:var(--bg-panel);border:1px solid var(--line);border-radius:10px}.user-list li>div:first-child{display:grid;gap:4px}.user-list span{color:var(--ink-muted)}.manage-artwork-side{display:flex;align-items:center;gap:12px}.manage-artwork-thumb{flex:0 0 auto;width:86px;height:58px;object-fit:contain;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px}.artwork-pagination{display:grid;gap:12px}.pagination-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;color:var(--ink-muted);background:var(--bg-panel);border:1px solid var(--line);border-radius:10px}.gallery-user-list{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:20px;padding:0;margin:0;list-style:none}.gallery-user-list li{width:clamp(168px,20vw,224px)}.gallery-user-card{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;gap:12px;min-height:252px;padding:14px 12px 12px;color:var(--ink-strong);text-align:center;background:radial-gradient(circle at 50% 16%,rgb(255 255 255 / 36%) 0%,transparent 62%),linear-gradient(180deg,#ffffff70,#ffffff29 56%,#ffffff14),var(--bg-panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 16px 32px #2c241d1c;transition:.18s ease}.gallery-user-card:hover{background:radial-gradient(circle at 50% 16%,rgb(255 255 255 / 48%) 0%,transparent 62%),linear-gradient(180deg,#ffffff8a,#ffffff38 56%,#ffffff1a),#fffefb;border-color:var(--line-strong);box-shadow:0 22px 40px #2c241d29;transform:translateY(-3px)}.gallery-user-card span{max-width:100%;overflow:hidden;font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:18px;font-weight:600;line-height:1.4;text-overflow:ellipsis;white-space:nowrap}.avatar{display:inline-grid;flex:0 0 auto;width:156px;height:156px;place-items:center;overflow:hidden;color:#fffdf8;font-size:42px;font-weight:800;text-transform:uppercase;background:linear-gradient(140deg,#8f7a63,#675544);border:1px solid #c8bda9;border-radius:999px;object-fit:cover;box-shadow:0 10px 24px #3e32263d}.avatar-fallback{padding:0 6px;color:#fffdf8;background:linear-gradient(145deg,#75624ff5,#483a2dfa);border-color:#fffdf875;text-shadow:0 1px 2px rgb(0 0 0 / 34%)}.artwork-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.gallery-feed{display:grid;gap:16px}.gallery-feed-meta{display:flex;justify-content:flex-end;color:var(--ink-muted);font-size:14px;font-weight:700}.gallery-feed-sentinel{min-height:42px;padding:12px;color:var(--ink-muted);text-align:center}.home-card-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;justify-items:center}.home-card{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,3fr);align-items:stretch;width:100%;max-width:560px;min-height:320px;height:320px;overflow:hidden;background:var(--bg-panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:0;color:var(--ink-strong);text-align:left;transition:.18s ease}.home-card:hover{color:var(--ink-strong);background:var(--bg-panel);border-color:var(--line-strong);box-shadow:0 22px 48px #2c241d24;transform:translateY(-2px)}.home-card:hover .home-card-image img{transform:scale(1.015)}.home-card-image{display:block;width:100%;min-height:100%;padding:0;overflow:hidden;background:transparent;border:none;border-right:1px solid var(--line);border-radius:0;cursor:pointer}.home-card-image:hover{transform:none}.home-card-image img{display:block;width:100%;height:100%;object-fit:cover;transition:.22s ease}.home-card-body{display:grid;grid-template-rows:minmax(0,1fr) auto;gap:12px;min-width:0;min-height:0;padding:20px 18px}.home-card-copy{display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;min-width:0;min-height:0;padding:0;color:var(--ink-strong);text-align:left;background:transparent;border:0;border-radius:0}.home-card-copy:hover{color:var(--ink-strong);background:transparent;border-color:transparent;transform:none}.home-card-meta{display:grid;gap:6px}.home-card-meta strong{font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:19px;font-weight:600;line-height:1.35}.home-card-meta span{color:var(--ink-muted);font-size:13px}.like-count{display:inline-flex;flex:0 0 auto;align-items:center;gap:4px}.like-count.is-flashing{color:#b02e53;animation:like-pulse .76s ease-in-out 1}.home-card-note{--note-lines: 4;align-self:start;max-height:calc(var(--note-lines) * 1.72em);margin:0;overflow:hidden;color:var(--ink-body);line-height:1.72;min-height:0;white-space:pre-wrap;display:-webkit-box;-webkit-line-clamp:var(--note-lines);-webkit-box-orient:vertical}.home-card-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;align-self:end}.reaction-button{width:max-content;color:var(--ink-muted);font-size:12px;line-height:1.2;padding:5px 10px;border:1px solid var(--line);border-radius:999px;background:var(--bg-surface)}.reaction-button:hover{color:var(--ink-strong);background:var(--bg-soft);border-color:var(--line-strong)}.reaction-button{color:#8c2642;border-color:#e8c5c8}.reaction-button.featured{color:#7a5418;border-color:#e4cf9b;background:#fff8dc}@keyframes like-pulse{0%{transform:scale(1);text-shadow:none}18%{transform:scale(1.18);text-shadow:0 0 14px rgb(208 69 101 / 46%)}36%{transform:scale(.96)}54%{transform:scale(1.14)}to{transform:scale(1);text-shadow:none}}@keyframes mobile-like-bump{0%{transform:translateY(0) scale(1)}28%{transform:translateY(-4px) scale(1.14)}56%{transform:translateY(1px) scale(.96)}to{transform:translateY(0) scale(1)}}.timeline-owner{display:flex;align-items:center;gap:12px;margin-bottom:24px}.timeline-share-button{margin-left:auto}.share-shell{min-height:100vh;min-height:100dvh;overflow-x:hidden;background:radial-gradient(circle at 50% 45%,rgb(35 88 122 / 34%) 0%,transparent 36%),linear-gradient(180deg,#101827,#15243a 42%,#e6dfd2)}.share-tunnel{--scene-count: 1;--tunnel-center-y: 45vh;position:relative;min-height:calc((var(--scene-count) + 1) * 100vh);cursor:pointer;overflow-x:hidden;overscroll-behavior-y:contain;touch-action:pan-y pinch-zoom}.time-tunnel-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.share-entrance{position:fixed;top:calc(var(--tunnel-center-y) - min(36vh,300px));left:50%;z-index:30;display:grid;grid-template-columns:auto minmax(0,max-content);align-items:center;justify-content:center;gap:16px;width:min(520px,calc(100% - 32px));transform:translate(-50%);transition:opacity .52s ease,transform .52s ease}.share-tunnel.is-running .share-entrance{opacity:0;pointer-events:none;transform:translate(-50%) translateY(-18px)}.share-entrance strong{font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:56px;font-weight:600;line-height:1.08;color:#f9fbff;text-shadow:0 0 34px rgb(142 211 255 / 38%)}.share-entrance p{margin:8px 0;color:#d7e8f4;font-size:20px}.share-entrance span,.share-entrance small{color:#b8cfdf}.share-entrance small{grid-column:1 / -1;justify-self:center;align-self:end;margin-bottom:56px;letter-spacing:.08em}.tunnel-stage{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;min-height:100dvh;place-items:center;overflow:hidden;perspective:1200px;opacity:0;z-index:2;transition:opacity .52s ease}.share-tunnel.is-running .tunnel-stage{opacity:1}.tunnel-depth{position:relative;display:grid;width:min(1180px,calc(100% - 32px));height:min(780px,86vh);place-items:center;transform-style:preserve-3d;transform:translateY(calc(var(--tunnel-center-y) - 50vh))}.tunnel-current,.tunnel-next,.tunnel-memory{position:absolute;top:50%;left:50%}.tunnel-current{z-index:10;width:min(860px,92vw,calc(62vh * 4 / 3));aspect-ratio:4 / 3;height:auto;opacity:var(--scene-opacity);transform-origin:50% 50%;transform:translate(-50%,-50%) translateZ(var(--scene-z)) scale(var(--scene-scale));transition:opacity .16s ease-out}.share-tunnel.is-complete .tunnel-current:not(.tunnel-future-scene){transform:translate(-50%,-50%) translateZ(70px) scale(1);opacity:1}.tunnel-current-image{display:block;width:100%;height:100%;object-fit:cover;object-position:center;clip-path:ellipse(49% 43% at 50% 50%);background:var(--bg-panel);border:1px solid var(--line);border-radius:50%;box-shadow:0 0 36px #94daff3d,0 28px 80px #040c1861}.tunnel-current-image.is-landscape{object-fit:contain}.tunnel-current-image.is-portrait{object-fit:cover}.tunnel-copy{position:absolute;top:calc(100% + 14px);left:50%;width:min(760px,100%);margin-top:0;text-align:center;opacity:min(1,calc(var(--scene-progress) * 1.6));transform:translate(-50%) translateY(calc((1 - var(--scene-progress)) * 16px));color:#f8fbff;text-shadow:0 1px 18px rgb(0 0 0 / 42%)}.tunnel-copy strong{font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:18px}.tunnel-copy p{margin:10px 0 0;color:#eef6fb;line-height:1.72;white-space:pre-wrap}.tunnel-play-toggle{position:fixed;right:22px;bottom:22px;bottom:calc(22px + env(safe-area-inset-bottom));z-index:40;min-width:82px;color:#eef8ff;background:#0e253dbd;border-color:#a6dcff70;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tunnel-future-scene{top:calc(50% + min(15vh,140px));display:grid;place-items:center}.tunnel-future-text{color:#d9f3ff;font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:32px;font-weight:500;line-height:1.35;letter-spacing:0;text-align:center;text-shadow:0 0 18px rgb(142 211 255 / 46%),0 0 42px rgb(73 155 214 / 34%),0 1px 18px rgb(0 0 0 / 42%)}.tunnel-next{z-index:2;width:min(520px,62vw);transform:translate(-50%,-50%) translateZ(-420px) scale(.72);filter:blur(1.5px) saturate(.82)}.tunnel-next img{width:100%;max-height:52vh;aspect-ratio:1.55 / 1;object-fit:cover;clip-path:ellipse(49% 43% at 50% 50%);border-radius:50%;box-shadow:0 14px 42px #2c241d1f}.tunnel-memory{--memory-index: 1;z-index:1;width:min(260px,32vw);opacity:max(.08,calc(.34 - var(--memory-index) * .05));transform:translate(-50%,-50%) translate(calc((var(--memory-index) - 3) * -54px)) translateY(calc(var(--memory-index) * 18px)) translateZ(calc(var(--memory-index) * -120px)) rotateY(-10deg) scale(.72);filter:saturate(.62)}.tunnel-memory img{width:100%;max-height:220px;aspect-ratio:1.55 / 1;object-fit:cover;clip-path:ellipse(49% 43% at 50% 50%);background:var(--bg-panel);border:1px solid var(--line);border-radius:50%}@media (prefers-reduced-motion: reduce){.tunnel-current,.tunnel-copy,.share-entrance,.tunnel-stage{transition:none}.tunnel-current{transform:scale(1)}}.timeline-owner>div,.detail-owner{display:grid;gap:4px}.timeline-owner span{color:var(--ink-muted)}.timeline-list{display:grid;gap:36px;position:relative;padding:10px 0}.timeline-list:before{position:absolute;top:0;bottom:0;left:50%;width:2px;content:"";background:linear-gradient(#d4ccbe,#998875,#d4ccbe)}.timeline-item{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:52px;align-items:center;position:relative}.timeline-item:before{position:absolute;top:50%;left:50%;width:12px;height:12px;content:"";background:#8a745d;border:4px solid #f4f0e9;border-radius:999px;box-shadow:0 0 0 1px #c9bfaf;transform:translate(-50%,-50%)}.timeline-item:nth-child(2n) .timeline-image{grid-column:2}.timeline-item:nth-child(2n) .timeline-copy{grid-column:1;grid-row:1;text-align:right}.timeline-image{display:block;min-height:0;padding:0;overflow:hidden;background:var(--bg-panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);transition:.2s ease}.timeline-image:hover{background:#fffefb;border-color:var(--line-strong);transform:translateY(-2px)}.timeline-image img{display:block;width:100%;aspect-ratio:4 / 3;object-fit:cover}.timeline-copy{display:grid;gap:8px;padding:18px;background:var(--bg-panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}.timeline-copy p{margin:0;color:var(--ink-body);line-height:1.65;white-space:pre-wrap}.timeline-index{width:max-content;padding:4px 8px;color:#6b5843;font-size:13px;font-weight:800;background:#f3ece1;border-radius:999px}.timeline-item:nth-child(2n) .timeline-index{justify-self:end}.artwork-note{margin:0;color:var(--ink-body);line-height:1.65;white-space:pre-wrap}.artwork-card{display:grid;gap:8px;min-height:0;padding:0;overflow:hidden;color:var(--ink-strong);text-align:left;background:var(--bg-panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}.artwork-card:hover{background:#fffefb;border-color:var(--line-strong)}.artwork-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;background:#ddd5c8}.artwork-card span{padding:0 12px 12px}.detail-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:16px;align-items:start}.detail-layout img{width:100%;max-height:72vh;object-fit:contain;background:var(--bg-panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}.detail-owner{grid-template-columns:auto minmax(0,1fr);align-items:center}.original-view-button{justify-self:start;color:#fffdf8;font-weight:700;background:linear-gradient(180deg,#ffffff1f,#fff0),var(--accent);border-color:color-mix(in oklab,var(--accent),#fff 18%);box-shadow:0 12px 26px #2c241d29}.original-view-button:hover{background:linear-gradient(180deg,#ffffff29,#fff0),var(--accent-strong)}.original-viewer{--viewer-scale: 1;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;overflow:hidden;background:radial-gradient(circle at 50% 46%,rgb(200 182 156 / 12%) 0%,transparent 44%),#12100ef0;overscroll-behavior:contain;touch-action:none;-webkit-user-select:none;user-select:none}.original-viewer-actions{position:fixed;top:18px;right:18px;z-index:101;display:flex;gap:8px}.original-viewer-action{color:#fffdf8;font-weight:800;background:#5e4e3de0;border-color:#fffdf86b;box-shadow:0 8px 22px #00000042;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.original-viewer-action:hover{color:#fffdf8;background:#75624ff0;border-color:#fffdf88f}.original-viewer-image{position:absolute;top:50%;left:50%;width:100vw;height:100dvh;max-width:none;max-height:none;object-fit:contain;object-position:center;background:transparent;border:0;border-radius:0;box-shadow:none;transform:translate(-50%,-50%) scale(var(--viewer-scale));transform-origin:50% 50%;will-change:transform}.original-viewer-image.is-rotated{width:100dvh;height:100vw;object-fit:contain;transform:translate(-50%,-50%) rotate(90deg) scale(var(--viewer-scale));transform-origin:50% 50%}.mobile-shell{height:100dvh;min-height:100dvh;padding:calc(8px + env(safe-area-inset-top)) 10px calc(48px + env(safe-area-inset-bottom));overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;scroll-padding-top:calc(8px + env(safe-area-inset-top));scroll-snap-type:y proximity;background:linear-gradient(180deg,#f8f5ef 0%,var(--bg-canvas) 48%,#eee9df 100%);-webkit-overflow-scrolling:touch}.mobile-shell-home,.mobile-shell-featured{scroll-behavior:smooth;scroll-padding-top:calc(18px + env(safe-area-inset-top));scroll-snap-type:none}.mobile-topbar{position:sticky;top:0;z-index:40;display:flex;gap:10px;align-items:center;justify-content:space-between;min-height:52px;padding:8px 0 10px;background:linear-gradient(180deg,#f8f5ef,#f8f5efeb 78%,#f8f5ef00);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-brand{display:grid;min-height:42px;padding:0;color:var(--ink-strong);text-align:left;background:transparent;border:0;border-radius:0}.mobile-brand:hover,.mobile-text-button:hover{color:var(--ink-strong);background:transparent;border-color:transparent;transform:none}.mobile-brand span{color:var(--ink-muted);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.mobile-brand strong{font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:23px;font-weight:600;line-height:1.2}.mobile-account-actions{display:flex;flex:0 0 auto;gap:6px}.mobile-text-button{min-height:36px;padding:6px 8px;color:var(--ink-body);font-size:13px;font-weight:800;background:transparent;border:0}.mobile-content{display:grid;gap:10px}.mobile-message{margin:6px 0 10px}.mobile-tabbar{position:fixed;right:0;bottom:0;left:0;z-index:60;display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:0;min-height:calc(44px + env(safe-area-inset-bottom));padding:3px 10px calc(3px + env(safe-area-inset-bottom));background:#fcfaf6e0;border-top:1px solid rgb(216 209 197 / 58%);border-right:0;border-bottom:0;border-left:0;border-radius:0;box-shadow:none;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transform:translateZ(0);will-change:transform}.mobile-tabbar button{position:relative;min-height:36px;padding:6px 4px;color:var(--ink-muted);font-size:11.5px;font-weight:700;background:transparent;border:0;border-radius:0;-webkit-tap-highlight-color:transparent}.mobile-tabbar button:after{position:absolute;right:calc(50% - 7px);bottom:3px;left:calc(50% - 7px);height:2px;content:"";background:transparent;border-radius:999px}.mobile-tabbar button.is-active{color:var(--accent-strong);font-weight:800;background:transparent}.mobile-tabbar button.is-active:after{background:#75624f94}.mobile-tabbar button:active{color:var(--ink-strong);background:#75624f1f;transform:none}.mobile-tabbar button.is-active:active{color:var(--accent-strong);background:#75624f14}.mobile-shell-detail{padding-bottom:calc(12px + env(safe-area-inset-bottom))}.mobile-shell-detail .mobile-tabbar{transform:translateY(100%);pointer-events:none}.mobile-feed{gap:10px}.mobile-feed .gallery-feed-meta{display:none}.mobile-artwork-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 10px;align-items:start}.mobile-artwork-list .home-card{position:relative;display:grid;grid-template-rows:auto 54px;max-width:none;height:auto;min-height:0;overflow:hidden;background:#fcfaf694;border:1px solid rgb(216 209 197 / 54%);border-radius:8px;box-shadow:none;scroll-margin-top:calc(18px + env(safe-area-inset-top));scroll-snap-align:start;transition:border-color .18s ease,background-color .18s ease,transform .18s ease}.mobile-shell-home .mobile-artwork-list .home-card,.mobile-shell-featured .mobile-artwork-list .home-card{scroll-snap-align:none}.mobile-artwork-list .home-card-visual{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;background:#eee7dc;border-bottom:1px solid rgb(216 209 197 / 62%)}.mobile-artwork-list .home-card-image{position:absolute;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;min-height:0;padding:0;overflow:hidden;background:transparent;border:0;border-radius:0}.mobile-artwork-list .home-card-image img{display:block;width:100%;height:100%;aspect-ratio:auto;object-fit:cover;object-position:center}.mobile-artwork-list .home-card-image img.is-landscape{object-fit:fill}.mobile-artwork-list .home-card-image img.is-portrait{object-fit:cover}.mobile-artwork-list .home-card-body{display:grid;grid-template-rows:1fr;min-height:0;padding:6px 7px}.mobile-artwork-list .home-card-copy{display:grid;grid-template-rows:auto auto;min-height:0;gap:3px}.mobile-artwork-list .home-card-meta{grid-template-columns:1fr;gap:2px;align-items:center}.mobile-artwork-list .home-card-meta strong{overflow:hidden;color:var(--ink-body);font-size:12px;font-weight:700;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.mobile-artwork-list .home-card-meta span{overflow:hidden;font-size:11px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.mobile-artwork-list .home-card-meta span:not(.like-count){display:none}.mobile-artwork-list .like-count{display:none}.mobile-artwork-list .home-card-note{--note-lines: 1;display:block;overflow:hidden;color:var(--ink-muted);font-size:12px;line-height:1.45;white-space:nowrap;text-overflow:ellipsis}.mobile-artwork-list .home-card-image-badges{position:absolute;bottom:6px;left:6px;z-index:2;display:flex;max-width:calc(100% - 12px);gap:5px;align-items:center}.mobile-artwork-list .home-card-image-badges .reaction-button,.mobile-artwork-list .home-card-image-badges .reaction-badge{display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;width:auto;min-width:24px;min-height:22px;padding:2px 6px;color:#fffdf8e0;font-size:10px;font-weight:800;text-shadow:0 1px 2px rgb(0 0 0 / 55%);background:#18141161;border:1px solid rgb(255 255 255 / 24%);border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:none;white-space:nowrap}.mobile-artwork-list .home-card-image-badges .reaction-button.is-liked{color:#fff8fb;background:#de0018d1;border-color:#ffbebe9e}.mobile-artwork-list .home-card-image-badges .reaction-button.is-bumping{animation:mobile-like-bump .42s ease-out 1}.mobile-artwork-list .home-card-image-badges .reaction-button.featured,.mobile-artwork-list .home-card-image-badges .reaction-badge.is-featured{color:#f0c05a;background:#422b08c7;border-color:#bf891cb3}.mobile-artwork-list .home-card-actions{display:flex;gap:5px;align-self:end}.mobile-artwork-list .reaction-button{flex:1 1 0;min-width:0;min-height:30px;padding:4px 6px;color:#fffdf8;font-size:11px;font-weight:800;text-shadow:none;background:var(--accent);border-color:var(--accent);border-radius:6px;pointer-events:auto}.mobile-artwork-list .reaction-button.featured{color:#fff8db;background:#7a5418;border-color:#7a5418}.mobile-featured-list{grid-template-columns:1fr;gap:28px;padding:2px 2px 18px}.mobile-featured-list .home-card{grid-template-rows:auto auto;overflow:visible;background:transparent;border:0;border-radius:0}.mobile-featured-list .home-card-visual{aspect-ratio:4 / 3;background:#f8f4ed;border:1px solid rgb(216 209 197 / 52%);border-radius:8px;box-shadow:0 14px 32px #2c241d1a}.mobile-featured-list .home-card-image{border-radius:8px;box-shadow:none}.mobile-featured-list .home-card-image img{aspect-ratio:auto;object-fit:contain;background:#f9f6f0}.mobile-featured-list .home-card-image img.is-landscape,.mobile-featured-list .home-card-image img.is-portrait{object-fit:contain}.mobile-featured-list .home-card-image img.is-landscape{object-fit:fill}.mobile-featured-list .home-card-body{padding:10px 2px 0}.mobile-featured-list .home-card-meta{grid-template-columns:1fr}.mobile-featured-list .home-card-meta strong{color:var(--ink-strong);font-size:13px;font-weight:700}.mobile-featured-list .home-card-note{display:block;color:var(--ink-body);font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:14px;line-height:1.62;white-space:normal}.mobile-featured-list .home-card-image-badges{bottom:8px;left:8px}.mobile-featured-list .home-card-image-badges .reaction-button,.mobile-featured-list .home-card-image-badges .reaction-badge{background:#1814114d;border-color:#fff3}.mobile-users-page{display:grid;gap:12px;padding:2px 0 16px}.mobile-users-intro{display:grid;gap:3px;padding:4px 2px 2px}.mobile-users-intro h2{margin:0;font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:22px;font-weight:600;line-height:1.25}.mobile-users-intro p,.mobile-users-note{margin:0;color:var(--ink-muted);font-size:13px;line-height:1.55}.mobile-user-list{display:grid;grid-template-columns:1fr;gap:8px;padding:0;margin:0}.mobile-user-list li{width:auto}.mobile-user-list .gallery-user-card{display:grid;grid-template-columns:28px 48px minmax(0,1fr) auto;grid-template-rows:auto auto;min-height:82px;gap:3px 10px;align-items:center;justify-items:start;width:100%;padding:10px 12px 10px 10px;color:var(--ink-strong);text-align:left;background:#fcfaf6b8;border:1px solid rgb(216 209 197 / 58%);border-radius:8px;box-shadow:none}.mobile-user-list .gallery-user-card:after{content:none;color:var(--ink-muted);font-size:24px;line-height:1}.mobile-user-list .mobile-user-index{grid-column:1;grid-row:1 / 3;align-self:center;color:#7b756d94;font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:14px;font-weight:600}.mobile-user-list .gallery-user-card .avatar{grid-column:2;grid-row:1 / 3;width:48px;height:48px;font-size:16px;box-shadow:none}.mobile-user-list .mobile-user-name{grid-column:3;align-self:end;max-width:100%;font-family:inherit;font-size:15px;font-weight:800;line-height:1.3}.mobile-user-list .mobile-user-meta{grid-column:3;color:var(--ink-muted);font-size:12px;font-weight:700;line-height:1.45}.mobile-user-list .gallery-user-card:before{grid-column:4;grid-row:1 / 3;align-self:center;color:#75624fa3;content:"›";font-size:24px;line-height:1}.mobile-timeline-owner{display:grid;grid-template-columns:54px minmax(0,1fr);gap:11px;align-items:center;margin:4px 0 20px;padding:6px 2px 2px}.mobile-timeline-owner .avatar{width:54px;height:54px;font-size:17px;box-shadow:none}.mobile-timeline-owner strong{font-size:17px;font-weight:700}.mobile-timeline-owner .timeline-share-button{grid-column:1 / -1;justify-self:start;min-height:34px;padding:6px 12px;color:var(--accent);font-size:13px;background:#fcfaf6b3;border-color:#b0895c61;box-shadow:none}.mobile-timeline-share-link{grid-column:1 / -1;justify-self:start;min-height:0;padding:0;color:#75624fc7;font-size:12.5px;font-weight:800;background:transparent;border:0;border-radius:0}.mobile-timeline-share-link:hover{color:var(--accent-strong);background:transparent;border-color:transparent;transform:none}.mobile-growth-intro{margin:-2px 0 18px;color:var(--ink-muted);font-size:13px;line-height:1.6}.mobile-growth-card{position:relative;display:grid;gap:11px;padding:0 0 42px 22px}.mobile-growth-card:before{position:absolute;top:20px;bottom:14px;left:7px;width:1px;content:"";background:linear-gradient(180deg,#b9ad9d29,#b9ad9d00)}.mobile-growth-index{position:absolute;top:0;left:0;z-index:1;display:grid;width:16px;min-height:18px;place-items:center;color:#75624f75;font-size:11px;font-weight:800;background:var(--bg-canvas)}.mobile-growth-image{display:block;width:100%;aspect-ratio:4 / 3;min-height:0;padding:0;overflow:hidden;background:#f9f6f0;border:1px solid rgb(216 209 197 / 50%);border-radius:8px;box-shadow:none}.mobile-growth-image img{display:block;width:100%;height:100%;object-fit:cover;object-position:center;background:#f9f6f0}.mobile-growth-image img.is-landscape{object-fit:fill}.mobile-growth-image img.is-portrait{object-fit:cover}.mobile-growth-copy{display:grid;gap:6px;padding:0 2px}.mobile-growth-copy time{color:var(--ink-muted);font-size:11.5px;font-weight:700}.mobile-growth-note{display:grid;gap:4px}.mobile-growth-note p{margin:0;color:var(--ink-strong);font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:14px;line-height:1.65;white-space:pre-wrap}.mobile-growth-note p.is-collapsed{display:-webkit-box;max-height:4.95em;overflow:hidden;-webkit-line-clamp:3;-webkit-box-orient:vertical}.mobile-growth-expand{justify-self:start;min-height:0;padding:0;color:var(--ink-muted);font-size:12px;font-weight:800;background:transparent;border:0;border-radius:0}.mobile-growth-expand:hover{color:var(--accent);background:transparent;border-color:transparent;transform:none}.mobile-growth-detail-link{justify-self:start;min-height:0;padding:2px 0 0;color:#75624fd1;font-size:12.5px;font-weight:700;background:transparent;border:0;border-radius:0}.mobile-growth-detail-link:hover{color:var(--accent-strong);background:transparent;border-color:transparent;transform:none}.mobile-growth-list{display:grid;gap:4px;padding:0 0 22px}.mobile-growth-list:before,.mobile-growth-list .timeline-item:before{display:none}.mobile-growth-list .timeline-item,.mobile-growth-list .timeline-item:nth-child(2n) .timeline-copy,.mobile-growth-list .timeline-item:nth-child(2n) .timeline-image{display:grid;grid-template-columns:1fr;gap:8px;grid-column:auto;grid-row:auto;text-align:left}.mobile-growth-list .timeline-image{border-radius:8px;box-shadow:none}.mobile-growth-list .timeline-image img{aspect-ratio:4 / 5;object-fit:cover}.mobile-growth-list .timeline-copy{grid-template-columns:auto minmax(0,1fr) auto;gap:4px 8px;padding:0 2px 2px;background:transparent;border:0;border-radius:0;box-shadow:none}.mobile-growth-list .timeline-copy strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-growth-list .timeline-copy span:not(.timeline-index),.mobile-growth-list .timeline-copy p{grid-column:2 / -1;color:var(--ink-muted);font-size:12px}.mobile-growth-list .timeline-copy button{grid-column:1 / -1;min-height:36px;margin-top:4px}.mobile-detail-layout{display:grid;grid-template-columns:1fr;gap:10px}.mobile-detail-layout .detail-image{max-height:none;border-radius:6px;box-shadow:none}.mobile-detail-panel{display:grid;gap:10px;padding:2px 2px 12px}.mobile-detail-panel .detail-owner{grid-template-columns:42px minmax(0,1fr)}.mobile-detail-panel .avatar{width:42px;height:42px;font-size:15px;box-shadow:none}.mobile-detail-stats{display:flex;flex-wrap:wrap;gap:8px;color:var(--ink-muted);font-size:12px}.mobile-detail-panel .original-view-button{justify-self:stretch;min-height:42px}.mobile-artwork-detail{display:grid;gap:12px;padding-bottom:10px}.mobile-artwork-detail .detail-image{width:100%;max-height:68dvh;object-fit:contain;background:#f9f6f0;border:1px solid rgb(216 209 197 / 58%);border-radius:6px;box-shadow:none}.mobile-artwork-detail-copy{display:grid;gap:7px;padding:0 2px}.mobile-artwork-caption{margin:0;color:var(--ink-strong);font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:15px;line-height:1.7;white-space:pre-wrap}.mobile-artwork-meta,.mobile-artwork-like{margin:0;color:var(--ink-muted);font-size:12px;line-height:1.6}.mobile-artwork-links{display:flex;flex-wrap:wrap;gap:8px 14px;padding-top:2px}.mobile-original-link{min-height:0;padding:0;color:var(--accent);font-size:13px;font-weight:800;background:transparent;border:0;border-radius:0}.mobile-original-link:hover{color:var(--accent-strong);background:transparent;border-color:transparent;transform:none}.tunnel-control-dock{position:fixed;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));left:16px;z-index:30;display:grid;gap:8px;padding:10px;color:#f6fbff;background:#09131fb3;border:1px solid rgb(220 240 255 / 18%);border-radius:14px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.tunnel-progress-track{height:4px;overflow:hidden;background:#ffffff2e;border-radius:999px}.tunnel-progress-track span{display:block;height:100%;background:#d9f0ff;border-radius:inherit}.tunnel-progress-text{color:#f6fbffc2;font-size:12px;font-weight:800}.tunnel-control-actions{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.tunnel-control-actions button,.tunnel-control-actions .tunnel-play-toggle{position:static;min-height:40px;padding:6px 8px;color:#f6fbff;font-size:13px;background:#ffffff1a;border-color:#fff3;border-radius:10px;box-shadow:none}.tunnel-control-actions .tunnel-play-toggle{color:#14202a;background:#d9f0ff;border-color:#d9f0ff}.tunnel-share-button{grid-column:1 / -1;justify-self:center;min-height:32px;padding:5px 12px;color:#f6fbffc7;font-size:13px;font-weight:800;background:#09131f3d;border:1px solid rgb(246 251 255 / 16%);border-radius:999px;box-shadow:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tunnel-share-button:hover{color:#f6fbff;background:#09131f61;transform:none}.tunnel-mobile-actions{position:fixed;top:calc(12px + env(safe-area-inset-top));right:12px;z-index:35;display:flex;gap:6px}.tunnel-mobile-action-button{min-height:34px;padding:6px 12px;color:#f6fbffc7;font-size:13px;font-weight:800;background:#09131f57;border:1px solid rgb(246 251 255 / 16%);border-radius:999px;box-shadow:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tunnel-mobile-action-button:hover{color:#f6fbff;background:#09131f7a;transform:none}@media (max-width: 1080px){.app-shell{padding:32px 18px}.page-header{align-items:flex-start}.home-card-list{grid-template-columns:1fr}.home-card{max-width:760px}.timeline-list{gap:28px}.timeline-item{gap:34px}.admin-artwork-filter{grid-template-columns:repeat(2,minmax(160px,1fr)) auto auto}}@media (max-width: 760px){.app-shell{padding:18px 12px}.page-header{gap:14px;padding:16px}h1{font-size:28px;overflow-wrap:anywhere}.nav-actions,.row-actions{width:100%}.nav-actions button,.row-actions button{flex:1 1 96px;min-height:44px}.panel{padding:16px}.page-header,.grid-two,.admin-action-grid,.detail-layout,.home-card,.admin-user-filter,.admin-artwork-filter,.timeline-item,.user-list li,.home-card-list{grid-template-columns:1fr}.home-card{max-width:620px;min-height:0;height:auto}.home-card-image{border-right:none;border-bottom:1px solid var(--line)}.home-card-image img{min-height:0;aspect-ratio:4 / 3}.home-card-body{padding:16px}.home-card-meta strong{font-size:18px}.home-card-note{--note-lines: 3}.home-card-actions{align-items:stretch}.home-card-actions button{flex:1 1 120px}.collapsible-summary{grid-template-columns:auto minmax(0,1fr)}.collapsible-summary small{grid-column:2;white-space:normal}.date-picker-popover{width:min(292px,calc(100vw - 56px))}.detail-layout{gap:12px}.detail-layout>.detail-image{max-height:58dvh}.gallery-user-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.gallery-user-list li{width:auto}.gallery-user-card{min-height:188px;padding:12px 10px;border-radius:10px}.gallery-user-card .avatar{width:96px;height:96px;font-size:28px}.timeline-owner{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px}.timeline-share-button{grid-column:1 / -1;width:100%;margin-left:0}.timeline-list{gap:18px}.timeline-copy{padding:14px}.timeline-copy button{width:100%}.timeline-index{justify-self:start}.detail-owner .avatar{width:72px;height:72px;font-size:22px}.original-view-button{justify-self:stretch}.original-viewer-actions{top:12px;right:12px;left:12px;justify-content:flex-end}.original-viewer-action{min-width:72px}.timeline-list:before,.timeline-item:before{display:none}.timeline-item,.timeline-item:nth-child(2n) .timeline-copy,.timeline-item:nth-child(2n) .timeline-image{grid-column:auto;grid-row:auto;text-align:left}.page-header{display:grid;align-items:stretch}.pagination-bar{display:grid}.pwa-install-prompt{right:10px;bottom:calc(10px + env(safe-area-inset-bottom));left:10px;grid-template-columns:1fr;width:auto}.pwa-install-actions{justify-content:stretch}.pwa-install-actions button{flex:1 1 0;min-height:44px}.share-entrance{grid-template-columns:1fr;justify-items:center;text-align:center;top:max(24px,calc(var(--tunnel-center-y) - 220px));width:min(420px,calc(100% - 28px));gap:12px}.share-entrance strong{font-size:clamp(28px,9vw,38px)}.share-entrance p{margin:6px 0;font-size:17px}.share-entrance small{margin-bottom:26px}.share-entrance .avatar{width:96px;height:96px;font-size:28px}.tunnel-depth{width:100vw;height:100dvh}.tunnel-future-text{font-size:24px;padding:0 18px}.tunnel-memory{display:none}.tunnel-current{width:min(82vw,480px,64dvh);aspect-ratio:4 / 3;height:auto}.tunnel-current-image{height:100%}.tunnel-copy{top:calc(100% + 10px);width:min(82vw,440px);padding:0 8px}.tunnel-copy p{display:-webkit-box;max-height:5.1em;overflow:hidden;-webkit-line-clamp:3;-webkit-box-orient:vertical}.tunnel-play-toggle{right:14px;min-height:44px}.user-list li,.manage-artwork-side,.pagination-bar,.quick-import-actions,.file-picker{align-items:stretch}.manage-artwork-side{display:grid;grid-template-columns:86px minmax(0,1fr)}.manage-artwork-side .row-actions{min-width:0}.filter-count{white-space:normal;overflow-wrap:anywhere}}@media (max-width: 760px) and (orientation: landscape){.app-shell{padding:12px}.page-header{align-items:flex-start}.detail-layout{grid-template-columns:minmax(0,1.35fr) minmax(240px,.65fr)}.detail-layout>.detail-image{max-height:calc(100dvh - 24px)}.detail-layout>.panel{max-height:calc(100dvh - 24px);overflow:auto}.share-tunnel{--tunnel-center-y: 50vh}.share-entrance{grid-template-columns:auto minmax(0,max-content);top:18px;text-align:left}.share-entrance .avatar{width:70px;height:70px;font-size:22px}.share-entrance strong{font-size:28px}.share-entrance p{font-size:15px}.share-entrance small{grid-column:1 / -1;margin-bottom:0}.tunnel-current{width:min(82vw,480px,72dvh);aspect-ratio:4 / 3;height:auto}.tunnel-copy{top:calc(100% + 6px)}.tunnel-copy p{-webkit-line-clamp:2}}@media (max-width: 420px){.app-shell{padding:12px 10px}.page-header{padding:14px}h1{font-size:25px}button{padding-inline:10px}.gallery-user-list{grid-template-columns:1fr}.gallery-user-card{min-height:156px}.gallery-user-card .avatar{width:82px;height:82px}.home-card-image img,.timeline-image img,.artwork-card img{aspect-ratio:1 / 1}.manage-artwork-side{grid-template-columns:1fr}.manage-artwork-thumb{width:100%;height:auto;max-height:160px;object-fit:contain}}@media (hover: none) and (pointer: coarse){button:hover,.home-card:hover,.home-card:hover .home-card-image img,.gallery-user-card:hover,.timeline-image:hover,.artwork-card:hover,.reaction-button:hover,.quick-user-card:hover,.original-view-button:hover{transform:none}}.home-card-list.mobile-artwork-list,.gallery-user-list.mobile-user-list.mobile-artwork-grid-legacy{grid-template-columns:repeat(2,minmax(0,1fr))}.gallery-user-list.mobile-user-list{grid-template-columns:1fr}.mobile-profile-page{display:grid;gap:12px;padding-bottom:16px}.mobile-profile-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:2px 0 0}.mobile-profile-header h2{margin:0;font-family:"Noto Serif SC",Songti SC,STSong,serif;font-size:22px;font-weight:600;line-height:1.25}.mobile-profile-header p,.mobile-manage-summary{margin:0;color:var(--ink-muted);font-size:13px;line-height:1.5}.mobile-logout-button{flex:0 0 auto;min-height:34px;padding:5px 10px;color:var(--ink-body);font-size:12px;font-weight:800;background:#fcfaf6b8;border-color:#d8d1c5b3}.mobile-profile-tabs{position:sticky;top:calc(4px + env(safe-area-inset-top));z-index:12;display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;background:#fcfaf6f0;border:1px solid rgb(216 209 197 / 68%);border-radius:8px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-admin-tabs{grid-template-columns:repeat(4,1fr)}.mobile-admin-page .quick-user-strip{padding-bottom:4px}.mobile-admin-page .quick-user-card{flex-basis:86px;min-height:104px;border-radius:8px}.mobile-admin-page .quick-user-card .avatar{width:46px;height:46px;font-size:15px}.mobile-admin-import-block{display:grid;gap:11px}.mobile-admin-filter{padding:10px}.mobile-admin-filter-section summary{gap:8px}.mobile-admin-filter-section summary span{flex:1 1 auto;min-width:0}.mobile-admin-filter-section summary small{flex:0 0 auto;color:var(--ink-muted);font-size:12px;font-weight:700;white-space:nowrap}.mobile-admin-user-list{gap:8px}.mobile-admin-user-list li{display:grid;grid-template-columns:1fr;gap:10px;padding:10px;background:#fcfaf6b8;border:1px solid rgb(216 209 197 / 58%);border-radius:8px}.mobile-admin-user-main{display:grid;grid-template-columns:44px minmax(0,1fr);gap:9px;align-items:center}.mobile-admin-user-main .avatar{width:44px;height:44px;font-size:15px;box-shadow:none}.mobile-admin-user-main>div{display:grid;min-width:0;gap:2px}.mobile-admin-user-main strong,.mobile-admin-user-main span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-admin-user-main strong{font-size:14px}.mobile-admin-user-main span{color:var(--ink-muted);font-size:12px}.mobile-admin-user-list .row-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.mobile-admin-user-list .row-actions button{min-height:34px;padding:4px 6px;font-size:12px}.mobile-profile-tabs button{min-height:36px;padding:5px 6px;color:var(--ink-muted);font-size:13px;font-weight:800;background:transparent;border:0;border-radius:6px}.mobile-profile-tabs button.is-active{color:#fffef9;background:var(--accent)}.mobile-profile-panel{display:grid;gap:10px}.mobile-tool-section{overflow:hidden;background:#fcfaf6b3;border:1px solid rgb(216 209 197 / 60%);border-radius:8px}.mobile-tool-section summary{display:flex;align-items:center;justify-content:space-between;min-height:42px;padding:0 12px;color:var(--ink-strong);font-size:14px;font-weight:800;cursor:pointer;list-style:none}.mobile-tool-section summary::-webkit-details-marker{display:none}.mobile-tool-section summary:after{color:var(--ink-muted);content:"展开";font-size:12px;font-weight:700}.mobile-tool-section[open] summary{border-bottom:1px solid rgb(216 209 197 / 52%)}.mobile-tool-section[open] summary:after{content:"收起"}.mobile-tool-form{display:grid;gap:9px;padding:10px;background:#fcfaf6b3;border:1px solid rgb(216 209 197 / 46%);border-radius:8px}.mobile-tool-section .mobile-tool-form{background:transparent;border:0;border-radius:0}.mobile-tool-form .avatar{width:56px;height:56px;font-size:18px;box-shadow:none}.mobile-tool-form button[type=submit]{min-height:40px}.mobile-tool-form textarea{min-height:96px}.mobile-manage-list{gap:10px}.mobile-artwork-manage-list{gap:8px}.mobile-artwork-manage-list li{display:grid;grid-template-columns:minmax(0,1fr);gap:8px;padding:10px;background:#fcfaf6b8;border:1px solid rgb(216 209 197 / 58%);border-radius:8px}.mobile-artwork-manage-list li>div:first-child{display:grid;gap:3px}.mobile-artwork-manage-list strong{font-size:14px;line-height:1.35}.mobile-artwork-manage-list span{color:var(--ink-muted);font-size:12px;line-height:1.45}.mobile-artwork-manage-list .manage-artwork-side{display:grid;grid-template-columns:64px minmax(0,1fr);gap:10px;align-items:center}.mobile-artwork-manage-list .manage-artwork-thumb{width:64px;height:48px;object-fit:cover;border-radius:6px}.mobile-artwork-manage-list .row-actions{display:flex;flex-wrap:wrap;gap:6px;width:auto}.mobile-artwork-manage-list .row-actions button{flex:0 1 auto;min-height:32px;padding:4px 8px;font-size:12px}.mobile-artwork-manage-list .danger-text-button{color:#b42335;background:#fff8f8;border-color:#efc2c8}.mobile-manage-list .pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:8px;font-size:12px;border-radius:8px}.mobile-manage-list .pagination-bar .row-actions{display:flex;flex:0 0 auto;width:auto;gap:6px}.mobile-manage-list .pagination-bar .row-actions button{flex:0 0 auto;min-height:32px;padding:4px 8px;font-size:12px}
