:root{--bg:#0a0a0a;--surface:#111;--surface-elevated:#161616;--surface-hover:#1a1a1a;--surface-active:#1f1f1f;--border:#1e1e1e;--border-subtle:#181818;--border-hover:#2a2a2a;--border-focus:#3a3a3a;--text-primary:#fafafa;--text-secondary:#a3a3a3;--text-muted:#6b6b6b;--text-disabled:#454545;--accent:#f97316;--accent-hover:#fb923c;--accent-muted:rgba(249,115,22,.12);--accent-subtle:rgba(249,115,22,.06);--accent-glow:rgba(249,115,22,.15);--success:#22c55e;--success-muted:rgba(34,197,94,.15);--success-subtle:rgba(34,197,94,.08);--error:#ef4444;--error-muted:rgba(239,68,68,.15);--error-subtle:rgba(239,68,68,.08);--warning:#f59e0b;--warning-muted:rgba(245,158,11,.15);--font-sans:var(--font-inter),-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:var(--font-jetbrains),"SF Mono",Monaco,"Cascadia Code",monospace;--text-display:clamp(2rem,5vw,2.75rem);--text-h1:clamp(1.5rem,3vw,1.875rem);--text-h2:clamp(1.125rem,2vw,1.375rem);--text-h3:1rem;--text-body:0.9375rem;--text-small:0.8125rem;--text-tiny:0.75rem;--text-micro:0.6875rem;--leading-tight:1.2;--leading-snug:1.35;--leading-normal:1.5;--leading-relaxed:1.65;--tracking-tight:-0.025em;--tracking-normal:0;--tracking-wide:0.025em;--tracking-wider:0.05em;--space-px:1px;--space-0:0;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--space-24:96px;--radius-sm:4px;--radius-md:6px;--radius-lg:10px;--radius-xl:14px;--radius-2xl:20px;--radius-full:9999px;--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-in-out:cubic-bezier(0.65,0,0.35,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--transition-fast:120ms var(--ease-out);--transition-base:200ms var(--ease-out);--transition-slow:300ms var(--ease-out);--transition-slower:400ms var(--ease-out);--shadow-sm:0 1px 2px rgba(0,0,0,.4),0 1px 3px rgba(0,0,0,.2);--shadow-md:0 4px 6px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2);--shadow-lg:0 10px 25px rgba(0,0,0,.4),0 4px 10px rgba(0,0,0,.3);--shadow-xl:0 20px 50px rgba(0,0,0,.5),0 10px 20px rgba(0,0,0,.3);--shadow-glow:0 0 20px var(--accent-glow);--shadow-inner:inset 0 1px 2px rgba(0,0,0,.3);--container-xs:480px;--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1200px;--container-2xl:1400px;--z-dropdown:50;--z-sticky:100;--z-overlay:200;--z-modal:300;--z-toast:400}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-body);line-height:var(--leading-relaxed);color:var(--text-secondary);background:var(--bg);min-height:100vh;overflow-x:hidden}::selection{background:var(--accent-muted);color:var(--text-primary)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;letter-spacing:var(--tracking-tight);line-height:var(--leading-snug)}h1{font-size:var(--text-h1);font-weight:700}h2{font-size:var(--text-h2)}h3{font-size:var(--text-h3)}p{margin-bottom:var(--space-4)}p:last-child{margin-bottom:0}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}b,strong{font-weight:600;color:var(--text-primary)}code{font-size:.875em;background:var(--surface-elevated);padding:.15em .4em;border-radius:var(--radius-sm);color:var(--accent)}code,pre{font-family:var(--font-mono)}pre{font-size:var(--text-small);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);overflow-x:auto;line-height:var(--leading-relaxed)}pre code{background:none;padding:0;color:inherit}main{max-width:var(--container-xl);margin:0 auto;padding:var(--space-12) var(--space-6);min-height:calc(100vh - 64px)}.header{position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-sticky);background:var(--bg);border-bottom:1px solid transparent;transition:border-color var(--transition-base),box-shadow var(--transition-base),background var(--transition-base)}.header-scrolled{border-bottom-color:var(--border);background:hsla(0,0%,4%,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.header-inner{justify-content:space-between;max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6);height:64px}.header-inner,.logo{display:flex;align-items:center}.logo{gap:var(--space-2);font-size:var(--text-h2);font-weight:700;text-decoration:none;letter-spacing:var(--tracking-tight);transition:opacity var(--transition-fast)}.logo,.logo:hover{color:var(--text-primary)}.logo:hover{opacity:.9}.logo-icon{color:var(--accent);font-size:1.25em;line-height:1}.logo-text{position:relative}.nav-desktop{gap:var(--space-1)}.nav-desktop,.nav-link{display:flex;align-items:center}.nav-link{gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--text-muted);font-size:var(--text-small);font-weight:500;border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast)}.nav-link:hover{color:var(--text-primary);background:var(--surface-hover)}.nav-link-external svg{opacity:.7}.nav-divider{width:1px;height:24px;background:var(--border);margin:0 var(--space-3)}.nav-skeleton{width:100px;height:32px;background:var(--surface);border-radius:var(--radius-md);animation:pulse 1.5s ease-in-out infinite}.user-menu{gap:var(--space-3)}.user-menu,.user-menu-trigger{display:flex;align-items:center}.user-menu-trigger{gap:var(--space-2);padding:var(--space-1) var(--space-3) var(--space-1) var(--space-1);color:var(--text-secondary);font-size:var(--text-small);font-weight:500;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface);transition:all var(--transition-fast)}.user-menu-trigger:hover{border-color:var(--border-hover);color:var(--text-primary)}.user-menu-avatar{width:26px;height:26px;border-radius:var(--radius-full);object-fit:cover}.user-menu-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-sign-in{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--surface);border:1px solid var(--border);color:var(--text-primary);font-size:var(--text-small);font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-sign-in:hover{background:var(--surface-hover);border-color:var(--border-hover)}.btn-sign-in svg{opacity:.8}.btn-sign-out{padding:var(--space-2) var(--space-3);background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:var(--text-small);font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-sign-out:hover{border-color:var(--error);color:var(--error)}.mobile-menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:10px;background:transparent;border:none;cursor:pointer;z-index:calc(var(--z-overlay) + 10)}.hamburger-line{display:block;width:20px;height:2px;background:var(--text-secondary);border-radius:2px;transition:all var(--transition-base);transform-origin:center}.mobile-menu-btn.active .hamburger-line:first-child{transform:translateY(7px) rotate(45deg)}.mobile-menu-btn.active .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}.mobile-menu-btn.active .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;z-index:var(--z-overlay);transition:opacity var(--transition-base),visibility var(--transition-base)}.mobile-menu-overlay.active{opacity:1;visibility:visible}.mobile-menu{position:fixed;top:0;right:0;width:min(320px,85vw);height:100vh;background:var(--surface);border-left:1px solid var(--border);z-index:calc(var(--z-overlay) + 5);transform:translateX(100%);transition:transform var(--transition-slow);overflow-y:auto}.mobile-menu.active{transform:translateX(0)}.mobile-menu-content{padding:calc(64px + var(--space-6)) var(--space-5) var(--space-8);display:flex;flex-direction:column;gap:var(--space-2)}.mobile-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--text-secondary);font-size:var(--text-body);font-weight:500;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.mobile-nav-link:active,.mobile-nav-link:hover{background:var(--surface-hover);color:var(--text-primary)}.mobile-nav-link svg{opacity:.7}.mobile-menu-divider{height:1px;background:var(--border);margin:var(--space-4) 0}.mobile-user-link{color:var(--accent)}.mobile-user-avatar{width:28px;height:28px;border-radius:var(--radius-full)}.mobile-sign-in,.mobile-sign-out{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-body);font-weight:500;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.mobile-sign-in{background:var(--accent);border:none;color:#fff}.mobile-sign-in:hover{background:var(--accent-hover)}.mobile-sign-out{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.mobile-sign-out:hover{border-color:var(--error);color:var(--error)}.mobile-nav-skeleton{height:44px;background:var(--surface-hover);border-radius:var(--radius-lg);animation:pulse 1.5s ease-in-out infinite}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:inherit;font-size:var(--text-small);font-weight:500;line-height:1.4;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;outline:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px rgba(0,0,0,.2)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-glow)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){border-color:var(--border-hover);color:var(--text-primary);background:var(--surface-hover)}.btn-ghost{background:transparent;color:var(--text-muted);padding:var(--space-2)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:var(--surface-hover)}.badge{display:inline-flex;align-items:center;padding:3px var(--space-2);background:var(--surface-elevated);color:var(--text-muted);font-size:var(--text-tiny);font-weight:500;border-radius:var(--radius-sm);white-space:nowrap;letter-spacing:var(--tracking-wide)}.badge-accent{background:var(--accent-muted);color:var(--accent)}.badge-success{background:var(--success-muted);color:var(--success)}.badge-error{background:var(--error-muted);color:var(--error)}input[type=email],input[type=password],input[type=search],input[type=text],select,textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-family:inherit;font-size:var(--text-body);line-height:var(--leading-normal);transition:all var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}input::placeholder,textarea::placeholder{color:var(--text-disabled)}textarea{resize:vertical;min-height:100px}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right var(--space-3) center;padding-right:var(--space-10)}.search-input,select{background-repeat:no-repeat}.search-input{width:240px;padding-left:var(--space-10);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-position:var(--space-3) center}.filter-select{width:auto;min-width:140px}.code-input{font-family:var(--font-mono);font-size:var(--text-h1);text-align:center;letter-spacing:.2em;padding:var(--space-5);border-width:2px}.gallery-filters{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-10)}.gallery-search{position:relative;display:flex;align-items:center}.gallery-search-icon{position:absolute;left:var(--space-4);color:var(--text-muted);pointer-events:none}.gallery-search-input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) var(--space-10);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-body);transition:all var(--transition-fast)}.gallery-search-input::placeholder{color:var(--text-muted)}.gallery-search-input:focus{outline:none;border-color:var(--border-hover);background:var(--surface)}.gallery-search-clear{position:absolute;right:var(--space-3);display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--surface-hover);border:none;border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.gallery-search-clear:hover{background:var(--surface-active);color:var(--text-primary)}.gallery-sort-tabs{display:flex;gap:var(--space-1);padding:0;background:transparent;border:none;border-radius:0;width:-moz-fit-content;width:fit-content}.gallery-sort-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--text-small);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.gallery-sort-tab.active,.gallery-sort-tab:hover{color:var(--text-primary)}.gallery-sort-tab.active{background:var(--surface)}.gallery-sort-tab svg{opacity:.7}.gallery-sort-tab.active svg{opacity:1}.gallery-filter-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.gallery-filter-pills{display:flex;gap:var(--space-2)}.gallery-filter-group{position:relative;display:flex;align-items:center}.gallery-filter-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:var(--space-2) var(--space-8) var(--space-2) var(--space-3);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--text-small);font-weight:500;cursor:pointer;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.gallery-filter-select:hover{color:var(--text-secondary);border-color:var(--border-hover)}.gallery-filter-select:focus{outline:none;border-color:var(--border-hover)}.gallery-filter-clear{position:absolute;right:calc(var(--space-6) + 4px);display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:var(--text-muted);border:none;border-radius:var(--radius-full);color:var(--bg);cursor:pointer;transition:all var(--transition-fast)}.gallery-filter-clear:hover{background:var(--accent)}.gallery-clear-all{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);color:var(--text-muted);font-size:var(--text-small);font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.gallery-clear-all:hover{color:var(--error);background:var(--error-subtle)}.filters{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center;padding:0;margin-bottom:var(--space-8);background:transparent;border:none;border-radius:0}.filters .filter-select,.filters .search-input{background:var(--surface);border-color:var(--border-subtle)}.clear-btn{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);color:var(--text-muted);font-size:var(--text-small);font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.clear-btn:hover{color:var(--error);background:var(--error-subtle)}.welcome-banner{position:relative;padding:var(--space-12) var(--space-8);margin-bottom:var(--space-12);text-align:center;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.welcome-banner:before{display:none}.banner-close{position:absolute;top:var(--space-4);right:var(--space-4);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--surface-hover);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-muted);font-size:1.25rem;cursor:pointer;transition:all var(--transition-fast);z-index:1}.banner-close:hover{background:var(--surface-active);color:var(--text-primary);border-color:var(--border-hover)}.welcome-banner h1{position:relative;font-size:var(--text-display);font-weight:700;margin-bottom:var(--space-4);color:var(--text-primary)}.welcome-banner p{position:relative;color:var(--text-muted);font-size:var(--text-body);max-width:540px;margin:0 auto;line-height:var(--leading-relaxed)}.gallery-page{max-width:900px;margin:0 auto}.gallery-header{margin-bottom:var(--space-10)}.gallery-header-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.gallery-title{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-h1);font-weight:600;margin:0}.gallery-title svg{color:var(--text-muted);opacity:.5}.gallery-subtitle{font-size:var(--text-small);color:var(--text-muted);margin:0}.gallery-empty{flex-direction:column;text-align:center;padding:var(--space-16) var(--space-8);background:transparent;border:none;border-radius:0}.gallery-empty,.gallery-empty-icon{display:flex;align-items:center;justify-content:center}.gallery-empty-icon{width:100px;height:100px;margin-bottom:var(--space-6);background:var(--surface-elevated);border-radius:var(--radius-full);color:var(--text-muted)}.gallery-empty h3{font-size:var(--text-h2);margin-bottom:var(--space-2)}.gallery-empty p{color:var(--text-muted);max-width:400px;margin-bottom:var(--space-6)}.gallery-empty-cta{padding:var(--space-4) var(--space-6);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg)}.gallery-empty-cta code{font-size:var(--text-small);background:transparent;padding:0;color:var(--accent)}.gallery-empty-clear{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--accent);color:#fff;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.gallery-empty-clear:hover{background:var(--accent-hover);color:#fff}.shots-list{display:flex;flex-direction:column;gap:var(--space-4)}.shot-card-v2{display:grid;grid-template-columns:auto 120px 1fr;grid-gap:var(--space-5);gap:var(--space-5);align-items:center;padding:var(--space-5) var(--space-4);background:transparent;border:none;border-bottom:1px solid var(--border-subtle);border-radius:0;transition:all var(--transition-base)}.shot-card-v2:hover{background:var(--surface)}.shot-card-upvote{display:flex;justify-content:center}.upvote-button-sm{padding:var(--space-2) var(--space-3);min-width:48px}.upvote-button-sm .upvote-count{font-size:var(--text-small)}.shot-card-thumbnail{display:block;position:relative;width:120px;height:75px;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-elevated);flex-shrink:0}.shot-card-thumbnail img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform var(--transition-base)}.shot-card-v2:hover .shot-card-thumbnail img{transform:scale(1.05)}.shot-card-thumbnail-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--surface-elevated),var(--surface));color:var(--text-disabled)}.shot-card-type-feature{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309}.shot-card-type-fix{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c}.shot-card-type-refactor{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4338ca}.shot-card-type-ui{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#7e22ce}.shot-card-type-test{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.shot-card-type-docs{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0369a1}.shot-card-type-other{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#4b5563}.shot-card-content{display:flex;flex-direction:column;gap:var(--space-2);min-width:0}.shot-card-main{display:flex;flex-direction:column;gap:var(--space-1)}.shot-card-title{text-decoration:none}.shot-card-title h3{font-size:var(--text-body);font-weight:600;margin:0;line-height:var(--leading-snug);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color var(--transition-fast)}.shot-card-title h3,.shot-card-v2:hover .shot-card-title h3{color:var(--text-primary)}.shot-card-tagline{font-size:var(--text-small);color:var(--text-muted);margin:0}.shot-card-stats-inline{display:inline-flex;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-tiny)}.shot-card-stats-inline .stat-add{color:var(--success)}.shot-card-stats-inline .stat-remove{color:var(--error)}.shot-card-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-tiny);color:var(--text-muted);flex-wrap:wrap}.shot-card-author{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--text-secondary);font-weight:500;text-decoration:none;transition:color var(--transition-fast)}.shot-card-author:hover{color:var(--accent)}.shot-card-avatar{width:18px;height:18px;border-radius:var(--radius-full);border:1px solid var(--border)}.shot-card-author-anon{font-style:italic}.shot-card-author-anon,.shot-card-sep{color:var(--text-disabled)}.shot-card-time{color:var(--text-muted)}.shot-card-pills{display:flex;gap:var(--space-1);margin-left:auto}.shot-card-pill{padding:0;background:transparent;border-radius:0;font-size:var(--text-tiny);font-weight:500;text-transform:lowercase;color:var(--text-muted)}.shot-card-pill-harness{color:var(--text-secondary)}.shot-card-pill-type{color:var(--text-muted)}.shot-card-pills:before{content:"";display:none}.shot-card-comments{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);color:var(--text-muted);text-decoration:none;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.shot-card-comments:hover{color:var(--accent);background:var(--accent-subtle)}.shots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));grid-gap:var(--space-6);gap:var(--space-6)}.shot-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base)}.shot-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.shot-card a{color:inherit;text-decoration:none}.shot-thumbnail-link{display:block;position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--surface-elevated)}.shot-thumbnail-link:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.4));opacity:0;transition:opacity var(--transition-base)}.shot-card:hover .shot-thumbnail-link:after{opacity:1}.shot-thumbnail{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform var(--transition-slow)}.shot-card:hover .shot-thumbnail{transform:scale(1.03)}.shot-thumbnail-placeholder{display:flex;align-items:center;justify-content:center;aspect-ratio:16/10;background:linear-gradient(135deg,var(--surface-elevated) 0,var(--surface) 100%);color:var(--text-disabled)}.shot-thumbnail-placeholder.shot-type-feature{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309}.shot-thumbnail-placeholder.shot-type-fix{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c}.shot-thumbnail-placeholder.shot-type-refactor{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4338ca}.shot-thumbnail-placeholder.shot-type-ui{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#7e22ce}.shot-thumbnail-placeholder.shot-type-test{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.shot-thumbnail-placeholder.shot-type-docs{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0369a1}.shot-thumbnail-placeholder.shot-type-other{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#4b5563}.shot-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:var(--text-small);color:var(--text-muted)}.author-link{color:var(--text-secondary);font-weight:500;transition:color var(--transition-fast)}.author-link:hover{color:var(--accent)}.author-with-avatar{display:inline-flex;align-items:center;gap:6px}.author-avatar{width:22px;height:22px;border-radius:var(--radius-full);border:1px solid var(--border)}.anonymous-author{color:var(--text-disabled);font-style:italic}.shot-date{color:var(--text-muted);font-size:var(--text-tiny)}.shot-meta>:not(:last-child):after{content:"";display:inline-block;width:3px;height:3px;margin-left:var(--space-2);background:var(--text-disabled);border-radius:var(--radius-full);vertical-align:middle}.shot-meta .badge:after,.shot-meta .stats:after{display:none}.stats{gap:var(--space-3);margin-left:auto;font-size:var(--text-tiny);font-weight:500;color:var(--text-muted)}.stats,.stats span{display:flex;align-items:center}.stats span{gap:4px}.diff-preview-link{display:block;padding:0 var(--space-5) var(--space-5)}.diff-preview{background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-3);font-family:var(--font-mono);font-size:var(--text-tiny);line-height:var(--leading-relaxed);overflow:hidden;white-space:pre;max-height:140px;mask-image:linear-gradient(180deg,#000 60%,transparent);-webkit-mask-image:linear-gradient(180deg,#000 60%,transparent)}.diff-add{color:var(--success);background:var(--success-subtle)}.diff-add,.diff-remove{display:block;margin:0 calc(var(--space-3) * -1);padding:0 var(--space-3)}.diff-remove{color:var(--error);background:var(--error-subtle)}.empty-state{text-align:center;padding:var(--space-16) var(--space-6);color:var(--text-muted)}.empty-state p{font-size:var(--text-h3);margin-bottom:var(--space-4)}.empty-state code{color:var(--accent)}.shot-detail-page{max-width:900px;padding-bottom:100px;margin:0 auto}.shot-hero{margin:0;margin-bottom:var(--space-10)}@media (min-width:768px){.shot-hero{margin:0;margin-bottom:var(--space-12)}}.shot-hero-images{display:grid;grid-template-columns:1fr;grid-gap:var(--space-4);gap:var(--space-4)}@media (min-width:768px){.shot-hero-images{grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.shot-hero-images:has(.shot-hero-before):has(.shot-hero-after){grid-template-columns:repeat(2,1fr)}.shot-hero-images:not(:has(.shot-hero-before)){grid-template-columns:1fr;max-width:800px;margin:0 auto}}.shot-hero-image{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);border:1px solid var(--border-subtle)}.shot-hero-image img{width:100%;display:block;transition:transform var(--transition-base)}.shot-hero-image a:hover img{transform:scale(1.02)}.shot-hero-badge{position:absolute;top:var(--space-3);left:var(--space-3);padding:var(--space-1) var(--space-3);background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-sm);font-size:var(--text-micro);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--text-secondary)}.shot-hero-after .shot-hero-badge{background:rgba(249,115,22,.9);color:#fff}.shot-title-bar{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}@media (min-width:768px){.shot-title-bar{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:var(--space-8);margin-bottom:var(--space-10)}}.shot-title-content{flex:1 1;min-width:0}.shot-title-content h1{font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;line-height:var(--leading-tight);margin:0 0 var(--space-3) 0;letter-spacing:var(--tracking-tight)}.shot-byline{gap:var(--space-3);flex-wrap:wrap}.shot-author,.shot-byline{display:flex;align-items:center}.shot-author{gap:var(--space-2);color:var(--text-secondary);font-weight:500;transition:color var(--transition-fast)}.shot-author:hover{color:var(--accent)}.shot-author-avatar{width:28px;height:28px;border-radius:var(--radius-full);border:2px solid var(--border)}.shot-author-name{font-size:var(--text-body)}.shot-author-anon{color:var(--text-muted)}.shot-byline-sep{color:var(--text-disabled)}.shot-timestamp{color:var(--text-muted);font-size:var(--text-small)}.shot-title-actions{display:none;gap:var(--space-3);flex-shrink:0}@media (min-width:768px){.shot-title-actions{display:flex}}.shot-tech-stack{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-8);color:var(--text-muted)}.shot-pill,.shot-tech-stack{align-items:center;font-size:var(--text-small)}.shot-pill{display:inline-flex;gap:var(--space-2);padding:0;border-radius:0;font-weight:500;border:none;background:transparent;transition:color var(--transition-fast)}.shot-pill svg{opacity:.5;width:14px;height:14px}.shot-pill-harness{color:var(--accent)}.shot-pill-model{color:var(--text-secondary)}.shot-pill-model code{background:transparent;padding:0;font-size:inherit;color:inherit}.shot-pill-type{color:var(--text-muted);text-transform:lowercase}.shot-tech-stack>:not(:last-child):after{content:"·";margin-left:var(--space-3);color:var(--text-disabled)}.shot-pill-tag{background:var(--surface);border:1px solid var(--border);color:var(--text-muted)}.shot-pill-tag:before{content:"#";opacity:.5}.shot-stats-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-6);padding:var(--space-5) 0;background:transparent;border:none;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);border-radius:0;margin-bottom:var(--space-8)}@media (min-width:768px){.shot-stats-row{gap:var(--space-8);padding:var(--space-6) 0;margin-bottom:var(--space-10)}}.shot-stat{display:flex;align-items:center;gap:var(--space-2);color:var(--text-muted)}.shot-stat svg{opacity:.4;width:16px;height:16px}.shot-stat-value{font-size:var(--text-body);font-weight:600;font-family:var(--font-mono);color:var(--text-primary)}.shot-stat-label{font-size:var(--text-small);text-transform:lowercase;letter-spacing:0;color:var(--text-muted)}.shot-stat-add .shot-stat-value,.shot-stat-add svg{color:var(--success)}.shot-stat-add svg{opacity:.7}.shot-stat-remove .shot-stat-value{color:var(--error)}.shot-stat-remove svg{color:var(--error);opacity:.7}.shot-links-card{margin-bottom:var(--space-10)}.shot-links-grid{display:flex;flex-direction:column;gap:var(--space-2)}@media (min-width:768px){.shot-links-grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--space-4)}}.shot-link-item{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;background:transparent;border:none;border-radius:0;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.shot-link-item:hover{color:var(--accent)}.shot-link-item svg{flex-shrink:0;opacity:.5;width:16px;height:16px}.shot-link-item:hover svg{opacity:.8}.shot-link-text{flex:1 1;font-weight:500;font-size:var(--text-small);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shot-link-arrow{font-size:var(--text-small);opacity:.3;transition:all var(--transition-fast)}.shot-link-item:hover .shot-link-arrow{opacity:.7}.shot-commit-hashes{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-tiny)}.shot-commit-hashes code{padding:2px 6px;background:var(--surface-elevated);border-radius:var(--radius-sm);font-family:var(--font-mono)}.shot-commit-hashes span{color:var(--text-disabled)}.shot-link-diff{flex-wrap:wrap}.shot-link-preview{cursor:default}.shot-preview-links{display:flex;gap:var(--space-3);margin-left:auto}.shot-preview-links a{color:var(--success);font-size:var(--text-small);font-weight:500;padding:var(--space-1) var(--space-3);background:var(--success-subtle);border-radius:var(--radius-md);transition:all var(--transition-fast)}.shot-preview-links a:hover{background:var(--success-muted)}.shot-mobile-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-4);position:fixed;bottom:0;left:0;right:0;padding:var(--space-4);background:hsla(0,0%,4%,.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);z-index:50}@media (min-width:768px){.shot-mobile-actions{display:none}.shot-detail-page{padding-bottom:0}}.shot-detail{max-width:var(--container-lg)}.shot-detail h3{margin-top:var(--space-10);margin-bottom:var(--space-5);font-size:var(--text-h2);padding-bottom:var(--space-3);border-bottom:1px solid var(--border)}.recipe-panel{background:transparent;border:none;border-top:1px solid var(--border-subtle);border-radius:0;padding:var(--space-10) 0 0 0;margin-top:var(--space-10)}.recipe-panel-header{margin-bottom:var(--space-8)}.recipe-panel-header h3{margin:0 0 var(--space-2) 0;padding:0;border:none;font-size:var(--text-h1);display:flex;align-items:center;gap:var(--space-3);color:var(--text-primary)}.recipe-panel-header h3 svg{color:var(--text-muted);opacity:.6}.recipe-panel-subtitle{color:var(--text-muted);font-size:var(--text-body);margin:0}.recipe-info-grid{display:flex;flex-wrap:wrap;gap:var(--space-8);margin-bottom:var(--space-8)}.recipe-info-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1);padding:0;background:transparent;border:none;border-radius:0;text-align:left}.recipe-info-icon{display:none}.recipe-info-label{font-size:var(--text-tiny);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wider);font-weight:600}.recipe-info-value{font-size:var(--text-body);color:var(--text-primary);font-weight:500}.recipe-info-value code{font-size:var(--text-small);background:transparent;padding:0;color:var(--text-secondary)}.recipe-section{padding:var(--space-6) 0;background:transparent;border:none;border-bottom:1px solid var(--border-subtle);border-radius:0;margin-bottom:0}.recipe-section:last-of-type{border-bottom:none}.recipe-section-prompt{background:transparent;border-bottom-color:var(--border-subtle)}.recipe-section-raw{background:transparent}.recipe-header{justify-content:space-between;margin-bottom:var(--space-4)}.recipe-header,.recipe-label{display:flex;align-items:center}.recipe-label{gap:var(--space-2);color:var(--text-secondary);font-size:var(--text-tiny);text-transform:uppercase;letter-spacing:var(--tracking-wider);font-weight:600}.recipe-label svg{color:var(--text-muted);opacity:.6}.recipe-tokens{display:flex;flex-wrap:wrap;gap:var(--space-6)}.recipe-token-stat{display:flex;flex-direction:column;gap:var(--space-1);padding:0;background:transparent;border-radius:0;min-width:60px}.recipe-token-label{font-size:var(--text-tiny);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.recipe-token-value{font-size:var(--text-body);font-weight:600;font-family:var(--font-mono)}.recipe-token-total .recipe-token-value,.recipe-token-value{color:var(--text-primary)}.recipe-token-cache .recipe-token-value{color:var(--success)}.recipe-tool-total{font-size:var(--text-tiny);color:var(--text-muted);font-weight:500}.recipe-tool-calls{display:flex;flex-wrap:wrap;gap:var(--space-2)}.recipe-tool-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background:var(--surface);border-radius:var(--radius-sm)}.recipe-tool-item code{font-size:var(--text-tiny);background:transparent;padding:0;color:var(--text-primary)}.recipe-tool-count{font-size:var(--text-tiny);color:var(--text-muted);font-weight:500}.recipe-params{display:flex;flex-wrap:wrap;gap:var(--space-2)}.recipe-param{padding:var(--space-1) var(--space-2);background:var(--surface);border-radius:var(--radius-sm)}.recipe-param code{font-size:var(--text-tiny);background:transparent;padding:0}.recipe-plugins{display:flex;flex-wrap:wrap;gap:var(--space-2)}.recipe-plugin-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--surface);border:none;border-radius:var(--radius-sm);font-size:var(--text-tiny);font-weight:500;color:var(--text-secondary)}.recipe-mcp-list{display:flex;flex-direction:column;gap:var(--space-2)}.recipe-mcp-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface);border-radius:var(--radius-md)}.recipe-mcp-item code{font-size:var(--text-small);background:transparent;padding:0;color:var(--text-primary)}.recipe-mcp-command{font-size:var(--text-tiny);color:var(--text-muted);font-family:var(--font-mono)}.recipe-configs{display:flex;flex-direction:column;gap:var(--space-3)}.recipe-config-item{flex-wrap:wrap}.recipe-config-item,.recipe-config-toggle{display:flex;align-items:center;gap:var(--space-2)}.recipe-config-toggle{padding:var(--space-2) var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-small);cursor:pointer;transition:all var(--transition-fast)}.recipe-config-toggle:hover{border-color:var(--accent);color:var(--accent)}.recipe-config-toggle svg{color:var(--text-muted)}.recipe-config-toggle code{background:transparent;padding:0;font-size:var(--text-small)}.recipe-config-content{width:100%;margin-top:var(--space-2);padding:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);max-height:300px;overflow:auto}.recipe-config-content pre{margin:0;padding:0;background:transparent;border:none;white-space:pre-wrap;font-size:var(--text-small)}.recipe-toggle-btn{padding:var(--space-1) var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);font-size:var(--text-tiny);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.recipe-toggle-btn:hover{border-color:var(--accent);color:var(--accent)}.recipe-value{font-size:var(--text-body);color:var(--text-secondary);line-height:var(--leading-relaxed)}.prompt-box,.recipe-value code{font-size:var(--text-small)}.prompt-box{border:none;border-radius:var(--radius-md);padding:var(--space-4);font-family:var(--font-mono);line-height:var(--leading-relaxed);white-space:pre-wrap;word-break:break-word;color:var(--text-primary);max-height:400px;overflow-y:auto}.copy-btn,.prompt-box{background:var(--surface)}.copy-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--text-tiny);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.copy-btn:hover{border-color:var(--accent);color:var(--accent)}.copy-btn.copied{border-color:var(--success);color:var(--success);background:var(--success-subtle)}.toggle-btn{background:none;border:none;color:var(--accent);font-size:var(--text-small);font-weight:500;cursor:pointer;padding:0;transition:color var(--transition-fast)}.toggle-btn:hover{color:var(--accent-hover)}.raw-session{position:relative;margin-top:var(--space-3)}.raw-session .copy-btn{position:absolute;top:var(--space-3);right:var(--space-3)}.raw-session pre{padding-top:var(--space-10);max-height:300px;overflow-y:auto}.prompt-box-compact{max-height:200px;overflow:auto}.recipe-tip{display:flex;align-items:flex-start;gap:var(--space-3);margin-top:var(--space-8);padding:var(--space-5);background:var(--surface);border:none;border-radius:var(--radius-md);font-size:var(--text-small);color:var(--text-muted);line-height:var(--leading-relaxed)}.recipe-tip svg{flex-shrink:0;color:var(--text-muted);margin-top:2px;opacity:.6}.recipe-tip strong{color:var(--accent);font-weight:600}.recipe-tip em{color:var(--text-secondary);font-style:italic}.shot-actions{display:flex;align-items:flex-start;gap:var(--space-3);flex-shrink:0}.upvote-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3) var(--space-4);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:var(--text-body);cursor:pointer;transition:all var(--transition-fast);min-width:60px}.upvote-button:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-2px)}.upvote-button.upvoted{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.upvote-button:disabled{opacity:.5;cursor:not-allowed}.upvote-arrow{transition:transform var(--transition-fast)}.upvote-button:hover:not(:disabled) .upvote-arrow{transform:translateY(-2px)}.upvote-button.upvoted .upvote-arrow{animation:upvote-bounce .4s var(--ease-spring)}@keyframes upvote-bounce{0%{transform:translateY(0)}40%{transform:translateY(-6px)}to{transform:translateY(0)}}.upvote-count{font-size:var(--text-small);font-weight:700;margin-top:var(--space-1)}.share-button-container{position:relative}.share-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-small);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.share-button:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--surface-hover)}.share-menu{position:absolute;top:calc(100% + var(--space-2));right:0;background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-2);min-width:180px;z-index:100;box-shadow:0 8px 30px rgba(0,0,0,.4);animation:menu-appear .15s var(--ease-out)}@keyframes menu-appear{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.share-menu-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-small);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.share-menu-item:hover{background:var(--surface-hover);color:var(--text-primary)}.share-menu-item svg{flex-shrink:0}.diff-stats-panel{display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-8);padding:var(--space-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl)}.diff-stats{display:flex;flex-wrap:wrap;gap:var(--space-6)}.diff-stat{display:flex;flex-direction:column;gap:var(--space-1)}.diff-stat-value{font-size:var(--text-h2);font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}.diff-stat-add .diff-stat-value{color:var(--success)}.diff-stat-remove .diff-stat-value{color:var(--error)}.diff-stat-label{font-size:var(--text-tiny);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.view-diff-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-small);font-weight:500;text-decoration:none;transition:all var(--transition-fast);width:-moz-fit-content;width:fit-content}.view-diff-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.star-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:var(--text-body);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.star-button.starred,.star-button:hover:not(:disabled){border-color:var(--warning);color:var(--warning);background:var(--warning-muted)}.star-button:disabled{opacity:.5;cursor:not-allowed}.star-icon{font-size:1.125rem;transition:transform var(--transition-fast)}.star-button:hover:not(:disabled) .star-icon{transform:scale(1.1)}.star-button.starred .star-icon{animation:star-pop .3s var(--ease-spring)}@keyframes star-pop{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.star-count{font-size:var(--text-small);font-weight:600}.comments-section{margin-top:var(--space-12);padding-top:var(--space-10);border-top:1px solid var(--border-subtle)}.comments-section h3{margin:0 0 var(--space-6) 0;padding:0;border:none;font-size:var(--text-h1);font-weight:600}.comment-form{margin-bottom:var(--space-8)}.comment-form textarea{min-height:100px;margin-bottom:var(--space-3)}.comment-form button{padding:var(--space-3) var(--space-5)}.sign-in-prompt{padding:var(--space-5);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:var(--text-small);text-align:center;margin-bottom:var(--space-8)}.sign-in-prompt a{font-weight:500}.loading,.no-comments{color:var(--text-muted);font-size:var(--text-small);text-align:center;padding:var(--space-8)}.comments-list{display:flex;flex-direction:column;gap:var(--space-4)}.comment{padding:var(--space-5);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:border-color var(--transition-fast)}.comment:hover{border-color:var(--border-hover)}.comment-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.comment-avatar{width:32px;height:32px;border-radius:var(--radius-full);border:1px solid var(--border)}.comment-meta{display:flex;flex-direction:column;gap:2px}.comment-author{color:var(--text-primary);font-weight:500;font-size:var(--text-small)}.comment-author:hover{color:var(--accent)}.comment-date{color:var(--text-muted);font-size:var(--text-tiny)}.comment-content{color:var(--text-secondary);line-height:var(--leading-relaxed);white-space:pre-wrap;font-size:var(--text-body)}.user-header{display:flex;align-items:center;gap:var(--space-6);margin-bottom:var(--space-8);padding-bottom:var(--space-8);border-bottom:1px solid var(--border)}.avatar{width:96px;height:96px;border-radius:var(--radius-full);border:3px solid var(--border);box-shadow:var(--shadow-md)}.user-info{flex:1 1}.user-info h1{margin-bottom:var(--space-2)}.user-bio{color:var(--text-muted);margin-bottom:var(--space-3)}.user-links{display:flex;gap:var(--space-4)}.user-links a{display:flex;align-items:center;gap:var(--space-2);color:var(--text-muted);font-size:var(--text-small);font-weight:500}.user-links a:hover{color:var(--accent)}.user-stats{display:flex;gap:var(--space-6);margin-top:var(--space-4)}.user-stat{text-align:center}.user-stat-value{display:block;font-size:var(--text-h2);font-weight:700;color:var(--text-primary)}.user-stat-label{font-size:var(--text-tiny);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wider)}.submit-page{max-width:var(--container-lg)}.submit-page .intro{font-size:var(--text-h3);color:var(--text-muted);margin-bottom:var(--space-10);max-width:600px}.submit-page h2{margin-top:var(--space-12);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border)}.steps{display:flex;flex-direction:column;gap:var(--space-4)}.step{display:flex;gap:var(--space-5);padding:var(--space-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--transition-base)}.step:hover{border-color:var(--border-hover);transform:translateX(4px)}.step-number{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--accent);color:#fff;border-radius:var(--radius-full);font-weight:700;font-size:var(--text-small);flex-shrink:0}.step-content{flex:1 1;min-width:0}.step-content h3{margin:0 0 var(--space-2) 0;font-size:var(--text-h3);border:none;padding:0}.step-content p{margin:0;color:var(--text-muted)}.step-content ul{margin:var(--space-3) 0 0 0;padding-left:var(--space-5);color:var(--text-secondary)}.step-content li{margin-bottom:var(--space-1)}.step-content pre{margin:var(--space-4) 0 0 0}.step-content code{color:var(--success)}.step-content .note{font-size:var(--text-small);margin-top:var(--space-3);font-style:italic;color:var(--text-muted)}.submit-page .shot-types ul,.submit-page .verification ul{padding-left:var(--space-5);color:var(--text-secondary)}.submit-page .shot-types li,.submit-page .verification li{margin-bottom:var(--space-2)}.submit-page .cli-options pre{background:var(--surface);border:1px solid var(--border)}.warning-panel{padding:var(--space-5);background:var(--warning-muted);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-lg);margin-top:var(--space-4)}.warning-panel strong{color:var(--warning)}.device-auth{max-width:420px;margin:var(--space-16) auto;text-align:center;padding:var(--space-8);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl)}.device-auth h1{margin-bottom:var(--space-3)}.device-auth p{color:var(--text-muted);margin-bottom:var(--space-6)}.device-form{display:flex;flex-direction:column;gap:var(--space-4)}.success-message{color:var(--success);font-size:var(--text-h3);font-weight:500}.error-message{color:var(--error);margin-top:var(--space-4);font-size:var(--text-small)}.signed-in-as{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border);font-size:var(--text-small);color:var(--text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--surface-elevated) 25%,var(--surface-hover) 50%,var(--surface-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-text:last-child{width:60%}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-full)}.skeleton-card{height:300px;border-radius:var(--radius-xl)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full);border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}*{scrollbar-width:thin;scrollbar-color:var(--border) var(--bg)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (max-width:1024px){main{padding:var(--space-6) var(--space-5)}.shots-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-5)}}@media (max-width:768px){main{padding:var(--space-5) var(--space-4)}.header-inner{padding:0 var(--space-4)}.nav-desktop{display:none}.mobile-menu-btn{display:flex}.gallery-page{max-width:100%}.gallery-header-content{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.gallery-title{font-size:var(--text-h2)}.gallery-filters{gap:var(--space-3)}.gallery-sort-tabs{width:100%;justify-content:space-around}.gallery-sort-tab{flex:1 1;justify-content:center;padding:var(--space-2) var(--space-2)}.gallery-sort-tab span{display:none}.gallery-filter-row{flex-direction:column;gap:var(--space-3)}.gallery-filter-pills{width:100%;flex-direction:column;gap:var(--space-2)}.gallery-filter-select{width:100%}.gallery-clear-all{align-self:flex-start}.shot-card-v2{grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:var(--space-3);padding:var(--space-3)}.shot-card-upvote{grid-row:1/3}.shot-card-thumbnail{display:none}.shot-card-content{grid-column:2;padding:0}.shot-card-title h3{font-size:var(--text-small)}.shot-card-tagline{font-size:var(--text-tiny)}.shot-card-meta{font-size:var(--text-micro)}.shot-card-pills{display:none}.shot-card-comments{margin-left:auto}.gallery-empty{padding:var(--space-10) var(--space-5)}.gallery-empty-icon{width:80px;height:80px}.gallery-empty-icon svg{width:40px;height:40px}.gallery-empty h3{font-size:var(--text-h3)}.gallery-empty-cta{padding:var(--space-3) var(--space-4)}.gallery-empty-cta code{font-size:var(--text-tiny);word-break:break-all}.shots-grid{grid-template-columns:1fr;gap:var(--space-4)}.shot-card{border-radius:var(--radius-lg)}.diff-preview-link{padding:0 var(--space-4) var(--space-4)}.filters{flex-direction:column;align-items:stretch;padding:var(--space-3);gap:var(--space-2)}.filter-select,.search-input{width:100%}.welcome-banner{padding:var(--space-8) var(--space-5);margin-bottom:var(--space-6)}.welcome-banner h1{font-size:var(--text-h1)}.welcome-banner p{font-size:var(--text-body)}.shot-header{flex-direction:column;gap:var(--space-4)}.shot-info{padding:var(--space-4)}.shot-info-row{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.shot-info-label{min-width:auto}.commit-links{flex-direction:column;align-items:flex-start}.screenshot-container{grid-template-columns:1fr}.full-diff{padding:var(--space-4);font-size:var(--text-tiny)}.recipe-panel{padding:var(--space-4);margin-top:var(--space-6)}.recipe-panel-header h3{font-size:var(--text-h3)}.recipe-info-grid{grid-template-columns:1fr;gap:var(--space-3)}.recipe-info-card{padding:var(--space-4);flex-direction:row;justify-content:flex-start;text-align:left;gap:var(--space-3)}.recipe-info-icon{width:36px;height:36px}.recipe-section{padding:var(--space-3)}.recipe-tokens{gap:var(--space-2)}.recipe-token-stat{padding:var(--space-2);min-width:70px}.recipe-tip{flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-4)}.recipe-tip svg{display:none}.user-header{flex-direction:column;text-align:center;gap:var(--space-4)}.avatar{width:80px;height:80px}.user-links,.user-stats{justify-content:center}.step{flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.step-number{width:32px;height:32px}.device-auth{margin:var(--space-8) var(--space-4);padding:var(--space-6)}.code-input{font-size:var(--text-h2)}.code-input,.comment{padding:var(--space-4)}.comment-avatar{width:28px;height:28px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media print{.comment-form,.filters,.header,.mobile-menu,.mobile-menu-overlay,.star-button{display:none!important}body{background:#fff;color:#000}.comment,.recipe-panel,.shot-card{border-color:#ddd;background:#fff}}.requests-page{padding:var(--space-8) var(--space-4);max-width:1000px;margin:0 auto}.requests-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.requests-header h1{font-size:var(--text-h1);font-weight:700;letter-spacing:var(--tracking-tight);color:var(--text-primary)}.requests-header p{color:var(--text-secondary);font-size:var(--text-body);line-height:var(--leading-relaxed);max-width:600px}.requests-header-actions{display:flex;align-items:center;gap:var(--space-4)}.requests-header-actions .btn-new-request{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--accent);color:#fff;font-size:var(--text-small);font-weight:600;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.requests-header-actions .btn-new-request:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.request-filters{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.request-search{position:relative;display:flex;align-items:center}.request-search-icon{position:absolute;left:var(--space-4);color:var(--text-muted);pointer-events:none}.request-search-input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) var(--space-12);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-body);transition:all var(--transition-fast)}.request-search-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-subtle)}.request-search-input::placeholder{color:var(--text-muted)}.request-search-clear{position:absolute;right:var(--space-3);padding:var(--space-1);background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.request-search-clear:hover{color:var(--text-primary);background:var(--surface-hover)}.request-sort-tabs{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--surface);border-radius:var(--radius-lg);width:-moz-fit-content;width:fit-content}.request-sort-tab{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);background:none;border:none;color:var(--text-secondary);font-size:var(--text-small);font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.request-sort-tab:hover{color:var(--text-primary);background:var(--surface-hover)}.request-sort-tab.active{color:var(--text-primary);background:var(--surface-elevated);box-shadow:var(--shadow-sm)}.request-filter-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.request-filter-pills{display:flex;gap:var(--space-2);flex-wrap:wrap}.request-filter-group{display:flex;align-items:center;gap:var(--space-1)}.request-filter-select{padding:var(--space-2) var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-small);cursor:pointer;transition:all var(--transition-fast)}.request-filter-select:hover{border-color:var(--border-hover)}.request-filter-select:focus{outline:none;border-color:var(--border-focus)}.request-filter-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:var(--surface-hover);border:none;border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.request-filter-clear:hover{background:var(--error-muted);color:var(--error)}.request-clear-all{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);color:var(--text-muted);font-size:var(--text-small);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast)}.request-clear-all:hover{color:var(--error);background:var(--error-subtle)}.requests-list{display:flex;flex-direction:column;gap:var(--space-3)}.request-card{display:grid;grid-template-columns:auto 1fr;grid-gap:var(--space-4);gap:var(--space-4);padding:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--transition-base);text-decoration:none}.request-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.request-card-upvote{display:flex;align-items:flex-start;padding-top:var(--space-1)}.request-card-content{display:flex;flex-direction:column;gap:var(--space-2);min-width:0}.request-card-badges{display:flex;gap:var(--space-2);flex-wrap:wrap}.request-type-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-micro);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wider);border-radius:var(--radius-sm)}.request-type-model{background:rgba(251,191,36,.15);color:#fbbf24}.request-type-harness{background:rgba(168,85,247,.15);color:#a855f7}.request-type-hosting{background:rgba(59,130,246,.15);color:#3b82f6}.request-type-plugin{background:rgba(34,197,94,.15);color:#22c55e}.request-type-other{background:hsla(240,4%,46%,.15);color:#71717a}.request-status-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-micro);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wider);border-radius:var(--radius-sm)}.request-status-open{background:rgba(59,130,246,.15);color:#3b82f6}.request-status-planned{background:rgba(251,191,36,.15);color:#fbbf24}.request-status-completed{background:rgba(34,197,94,.15);color:#22c55e}.request-status-declined{background:rgba(239,68,68,.15);color:#ef4444}.request-card-title{font-size:var(--text-body);font-weight:600;color:var(--text-primary);line-height:var(--leading-snug)}.request-card-desc{font-size:var(--text-small);color:var(--text-secondary);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.request-card-meta{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;font-size:var(--text-tiny);color:var(--text-muted)}.request-card-author{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.request-card-author:hover{color:var(--accent)}.request-card-author img{width:18px;height:18px;border-radius:var(--radius-full);object-fit:cover}.request-card-stats{display:flex;align-items:center;gap:var(--space-1)}.request-card-stats svg{width:14px;height:14px}.request-upvote-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3) var(--space-3);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:var(--text-small);font-weight:600;cursor:pointer;transition:all var(--transition-fast);min-width:52px}.request-upvote-button:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);transform:translateY(-2px)}.request-upvote-button.upvoted{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.request-upvote-button:disabled{opacity:.5;cursor:not-allowed}.request-upvote-button svg{margin-bottom:var(--space-1);transition:transform var(--transition-fast)}.request-upvote-button:hover:not(:disabled) svg{transform:translateY(-2px)}.request-upvote-button.upvoted svg{animation:upvote-bounce .4s var(--ease-spring)}.requests-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-4);text-align:center}.requests-empty svg{width:64px;height:64px;color:var(--text-disabled);margin-bottom:var(--space-4)}.requests-empty h3{font-size:var(--text-h3);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.requests-empty p{color:var(--text-muted);font-size:var(--text-body);margin-bottom:var(--space-6)}.requests-empty a{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--accent);color:#fff;font-size:var(--text-small);font-weight:600;border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-fast)}.requests-empty a:hover{background:var(--accent-hover);transform:translateY(-1px)}.new-request-page{padding:var(--space-8) var(--space-4);max-width:700px;margin:0 auto}.new-request-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.new-request-back{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--text-small);text-decoration:none;transition:color var(--transition-fast);width:-moz-fit-content;width:fit-content}.new-request-back:hover{color:var(--accent)}.new-request-header h1{font-size:var(--text-h1);font-weight:700;letter-spacing:var(--tracking-tight);color:var(--text-primary)}.new-request-header p{color:var(--text-secondary);font-size:var(--text-body);line-height:var(--leading-relaxed)}.request-form{display:flex;flex-direction:column;gap:var(--space-6)}.request-form-section{display:flex;flex-direction:column;gap:var(--space-2)}.request-form-label{font-size:var(--text-small);font-weight:600;color:var(--text-primary)}.request-form-required{color:var(--error);margin-left:var(--space-1)}.request-form-optional{color:var(--text-muted);font-weight:400;margin-left:var(--space-2)}.request-type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:var(--space-3);gap:var(--space-3)}.request-type-option{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.request-type-option:hover{border-color:var(--border-hover);background:var(--surface-hover)}.request-type-option.selected{border-color:var(--accent);background:var(--accent-subtle)}.request-type-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--surface-elevated);border-radius:var(--radius-md);color:var(--text-secondary);flex-shrink:0;transition:all var(--transition-fast)}.request-type-option.selected .request-type-icon{background:var(--accent-muted);color:var(--accent)}.request-type-info{display:flex;flex-direction:column;gap:var(--space-1)}.request-type-label{font-size:var(--text-body);font-weight:600;color:var(--text-primary)}.request-type-desc{font-size:var(--text-tiny);color:var(--text-muted);line-height:var(--leading-relaxed)}.request-form-input,.request-form-textarea{padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-body);font-family:inherit;transition:all var(--transition-fast);width:100%}.request-form-textarea{resize:vertical;min-height:120px;line-height:var(--leading-relaxed)}.request-form-input:focus,.request-form-textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-subtle)}.request-form-input::placeholder,.request-form-textarea::placeholder{color:var(--text-muted)}.request-form-hint{font-size:var(--text-tiny);color:var(--text-muted)}.request-form-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--error-subtle);border:1px solid var(--error-muted);border-radius:var(--radius-lg);color:var(--error);font-size:var(--text-small)}.request-form-actions{display:flex;justify-content:flex-end;padding-top:var(--space-4)}.request-form-submit{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--accent);color:#fff;font-size:var(--text-body);font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.request-form-submit:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.request-form-submit:disabled{opacity:.6;cursor:not-allowed}.request-form-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.request-detail-page{padding:var(--space-8) var(--space-4);max-width:800px;margin:0 auto}.request-detail-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.request-detail-back{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--text-small);text-decoration:none;transition:color var(--transition-fast);width:-moz-fit-content;width:fit-content}.request-detail-back:hover{color:var(--accent)}.request-detail-badges{display:flex;gap:var(--space-2)}.request-detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.request-detail-title{font-size:var(--text-h1);font-weight:700;letter-spacing:var(--tracking-tight);color:var(--text-primary);line-height:var(--leading-tight)}.request-detail-actions{flex-shrink:0}.request-detail-meta{font-size:var(--text-small);color:var(--text-muted);margin-bottom:var(--space-6)}.request-detail-author,.request-detail-meta{display:flex;align-items:center;gap:var(--space-2)}.request-detail-author{color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.request-detail-author:hover{color:var(--accent)}.request-detail-avatar{width:24px;height:24px;border-radius:var(--radius-full);object-fit:cover}.request-detail-author-anon{color:var(--text-muted)}.request-detail-sep{color:var(--text-disabled)}.request-detail-description{margin-bottom:var(--space-6)}.request-detail-description p{font-size:var(--text-body);color:var(--text-secondary);line-height:var(--leading-relaxed);white-space:pre-wrap}.request-detail-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-8)}.request-detail-link svg{color:var(--text-muted);flex-shrink:0}.request-detail-link a{color:var(--accent);font-size:var(--text-small);text-decoration:none;word-break:break-all}.request-detail-link a:hover{text-decoration:underline}.request-detail-comments{border-top:1px solid var(--border);padding-top:var(--space-8)}.request-detail-comments h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-h3);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-6)}.request-detail-comments h2 svg{color:var(--text-muted)}.request-comments{display:flex;flex-direction:column;gap:var(--space-6)}.request-comments-loading{display:flex;align-items:center;gap:var(--space-2);color:var(--text-muted);font-size:var(--text-small);padding:var(--space-4)}.request-comments-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:var(--radius-full);animation:spin .8s linear infinite}.request-comment-form{display:flex;gap:var(--space-3)}.request-comment-form-avatar{width:36px;height:36px;border-radius:var(--radius-full);object-fit:cover;flex-shrink:0}.request-comment-form-input-wrapper{flex:1 1;display:flex;flex-direction:column;gap:var(--space-2)}.request-comment-form-textarea{padding:var(--space-3) var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-body);font-family:inherit;resize:vertical;min-height:80px;transition:all var(--transition-fast)}.request-comment-form-textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-subtle)}.request-comment-form-textarea::placeholder{color:var(--text-muted)}.request-comment-form-actions{display:flex;align-items:center;justify-content:space-between}.request-comment-form-hint{font-size:var(--text-tiny);color:var(--text-muted)}.request-comment-form-submit{padding:var(--space-2) var(--space-4);background:var(--accent);color:#fff;font-size:var(--text-small);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.request-comment-form-submit:hover:not(:disabled){background:var(--accent-hover)}.request-comment-form-submit:disabled{opacity:.5;cursor:not-allowed}.request-comments-signin{padding:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;font-size:var(--text-small);color:var(--text-muted)}.request-comments-signin a{color:var(--accent);text-decoration:none;font-weight:500}.request-comments-signin a:hover{text-decoration:underline}.request-comments-empty{padding:var(--space-6);text-align:center;color:var(--text-muted);font-size:var(--text-small)}.request-comments-list{display:flex;flex-direction:column;gap:var(--space-4)}.request-comment{display:flex;gap:var(--space-3)}.request-comment-avatar{object-fit:cover}.request-comment-avatar,.request-comment-avatar-placeholder{width:32px;height:32px;border-radius:var(--radius-full);flex-shrink:0}.request-comment-avatar-placeholder{background:var(--surface-elevated)}.request-comment-content{flex:1 1;min-width:0}.request-comment-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.request-comment-author{font-size:var(--text-small);font-weight:600;color:var(--text-primary);text-decoration:none}.request-comment-author:hover{color:var(--accent)}.request-comment-author-anon{font-size:var(--text-small);color:var(--text-muted)}.request-comment-time{font-size:var(--text-tiny);color:var(--text-muted)}.request-comment-text{font-size:var(--text-body);color:var(--text-secondary);line-height:var(--leading-relaxed);white-space:pre-wrap;word-break:break-word}@media (max-width:768px){.new-request-page,.request-detail-page,.requests-page{padding:var(--space-6) var(--space-4)}.requests-header{gap:var(--space-3)}.request-sort-tabs{width:100%}.request-sort-tab{flex:1 1;justify-content:center}.request-filter-row{gap:var(--space-2)}.request-card{grid-template-columns:auto 1fr;gap:var(--space-3);padding:var(--space-3)}.request-type-grid{grid-template-columns:1fr}.request-detail-title-row{flex-direction:column;gap:var(--space-3)}.request-detail-actions{align-self:flex-start}.request-comment-form{flex-direction:column;gap:var(--space-3)}.request-comment-form-avatar{display:none}}