:root{color-scheme:light;--bg: #f7f8fb;--surface: #ffffff;--text: #1a1d25;--subtext: #5d6473;--accent: #2c61ff;--accent-hover: #1f4de3;--border: #d5dae4;--hero-bg: #e3f4ff;--shadow: 0 10px 30px rgba(18, 24, 40, .08);--shadow-soft: 0 4px 16px rgba(18, 24, 40, .05);--radius-xl: 28px;--radius-lg: 20px;--radius-md: 14px;font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--text)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);line-height:1.65}img{object-fit:contain}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}h1,h2,h3{font-family:Space Grotesk,Manrope,Inter,sans-serif;letter-spacing:-.02em}.serif{font-family:Playfair Display,Georgia,serif}button{font-family:inherit;cursor:pointer}.app-shell{min-height:100vh;display:flex;flex-direction:column}.site-header{position:sticky;top:0;z-index:20;background:#ffffffd1;-webkit-backdrop-filter:blur(12px) saturate(115%);backdrop-filter:blur(12px) saturate(115%);border-bottom:1px solid var(--border)}.site-header-inner{max-width:1100px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:18px}.brand{font-family:Space Grotesk,Manrope,Inter,sans-serif;font-weight:700;font-size:1.5rem;color:var(--text);letter-spacing:-.03em}.nav{display:flex;gap:18px;align-items:center;margin-left:auto;flex-wrap:wrap}.nav a{color:var(--subtext);font-weight:500}.nav a:hover{color:var(--text)}.nav a.active{color:var(--accent)}.nav a.btn,.nav a.btn:hover{color:#fff}.nav a.btn-soft{color:var(--text)}.container{max-width:1100px;margin:0 auto;padding:36px 22px 90px;width:100%}.container-narrow{max-width:760px}.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--accent);background:var(--accent);color:#fff;padding:10px 20px;border-radius:999px;font-weight:600;font-size:.97rem;transition:background .18s ease,transform .18s ease}.btn:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff;transform:translateY(-1px)}.btn:active{color:#fff;transform:translateY(0)}.btn-ghost{background:transparent;color:var(--accent)}.btn-soft{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-soft:hover{background:var(--surface);border-color:#bac2d2;color:var(--text)}.btn-danger{background:transparent;border-color:#d8b4ab;color:#b04a3a}.btn-danger:hover{background:#fbeae6;border-color:#b04a3a;color:#b04a3a}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:6px 14px;font-size:.86rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:24px 26px}.work-card{margin-bottom:16px;border:1px solid var(--border);transition:box-shadow .18s ease,transform .18s ease}.work-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.work-card .work-title{font-size:1.45rem;margin:4px 0 6px}.work-title a{color:var(--text)}.work-title a:hover{color:var(--accent)}.work-meta{color:var(--subtext);font-size:.92rem;display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.work-excerpt{white-space:pre-wrap;font-size:1.06rem;line-height:1.8;color:#2a2f3a;display:-webkit-box;-webkit-line-clamp:7;line-clamp:7;-webkit-box-orient:vertical;overflow:hidden}.work-body{font-size:1.18rem;line-height:1.6;color:#20242e}.work-cover{width:auto;max-width:100%;max-height:460px;object-fit:contain;border-radius:var(--radius-md);margin:10px auto 18px;display:block}.tag{display:inline-block;background:#eef2fb;color:var(--subtext);border-radius:999px;padding:3px 12px;font-size:.82rem;margin:0 6px 6px 0}a.tag:hover{background:#e1e8fa;color:var(--accent)}.genre-badge{text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:700;color:var(--accent)}.like-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);color:var(--subtext);border-radius:999px;padding:6px 15px;font-weight:600}.like-btn.liked{color:var(--accent);border-color:var(--accent);background:#eef2fb}.form{display:flex;flex-direction:column;gap:16px}label{font-weight:600;font-size:.9rem;color:var(--subtext);display:block;margin-bottom:6px}input,textarea,select{width:100%;font-family:inherit;font-size:1rem;padding:12px 15px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text)}textarea{min-height:220px;resize:vertical;line-height:1.8}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2c61ff1f}.page-title{font-size:clamp(1.9rem,4vw,2.4rem);margin:0 0 8px}.page-subtitle{color:var(--subtext);font-size:1.05rem;margin:0 0 30px}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:26px}.toolbar input,.toolbar select{width:auto;flex:1 1 200px}.error{background:#fbeae6;border:1px solid #e3b3a8;color:#963322;padding:11px 15px;border-radius:var(--radius-md)}.muted{color:var(--subtext)}.center{text-align:center}.avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;background:#e6ebf5;display:inline-block}.avatar-sm{width:26px;height:26px}.avatar-lg{width:72px;height:72px}.user-menu{position:relative}.user-menu-trigger{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);background:var(--surface);border-radius:999px;padding:4px 12px 4px 4px;color:var(--text);font-weight:600;font-size:.95rem}.user-menu-trigger:hover{border-color:#bac2d2}.user-menu-trigger .caret{color:var(--subtext);font-size:.8rem}.user-menu-dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:210px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:6px;z-index:30;display:flex;flex-direction:column}.user-menu-head{display:flex;flex-direction:column;padding:8px 10px 10px;border-bottom:1px solid var(--border);margin-bottom:6px}.user-menu-dropdown button{text-align:left;background:transparent;border:0;padding:9px 10px;border-radius:8px;font-size:.95rem;color:var(--text);font-weight:500}.user-menu-dropdown button:hover{background:#eef2fb;color:var(--accent)}.user-menu-dropdown button.danger{color:#b04a3a}.user-menu-dropdown button.danger:hover{background:#fbeae6;color:#b04a3a}.user-menu-divider{height:1px;background:var(--border);margin:6px 0}.profile-bio{margin:0 0 30px;padding:6px 0 6px 16px;border-left:3px solid var(--border);color:var(--subtext);font-style:italic;white-space:pre-wrap}.image-upload{display:flex;gap:14px;align-items:center}.image-upload-preview{width:96px;height:96px;flex:0 0 auto;border:1px dashed var(--border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;overflow:hidden;background:#f1f4fa;font-size:.82rem}.image-upload-preview.is-circle{border-radius:50%;width:84px;height:84px}.image-upload-preview img{width:100%;height:100%;object-fit:cover}.image-upload-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.collection-card{display:flex;flex-direction:column;overflow:hidden;padding:0}.collection-card .collection-cover{width:100%;height:180px;object-fit:contain;padding:12px;background:var(--hero-bg)}.collection-card .collection-body{padding:18px 20px}.collection-card h3{margin:0 0 6px;font-size:1.25rem;color:var(--text)}.landing{min-height:100vh;display:flex;flex-direction:column}.landing-top{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.3rem}.landing-logo{height:56px;width:auto;object-fit:contain}.search-shell{width:min(92vw,720px);margin:15vh auto auto;padding:.2rem 1rem 2rem}.landing-brand{text-align:center;font-family:Space Grotesk,Manrope,Inter,sans-serif;font-size:clamp(2.4rem,8vw,4.6rem);margin:0 0 1.4rem;letter-spacing:-.04em;font-weight:700}.search-form{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:.55rem;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;box-shadow:var(--shadow)}.search-form .search-input{min-width:0;flex:1 1 320px;border:0;font-size:clamp(1rem,2.6vw,1.2rem);padding:.95rem 1rem;border-radius:var(--radius-lg);outline:none;background:transparent;box-shadow:none}.search-form .search-input:focus{box-shadow:none}.search-submit{flex:0 0 auto;border:0;background:var(--accent);color:#fff;border-radius:999px;padding:.9rem 1.5rem;font-weight:600;font-size:1rem;transition:background .2s ease}.search-submit:hover{background:var(--accent-hover)}.landing-links{display:flex;justify-content:center;align-items:center;gap:1.4rem;margin-top:1.6rem;flex-wrap:wrap}.landing-links a{display:inline-flex;align-items:center;color:var(--subtext);font-weight:600;line-height:1}.landing-links a:hover{color:var(--accent)}.landing-links .landing-link-feed{color:var(--accent);padding:.45rem 1.05rem;border-radius:999px;background:#eef2fb;border:1px solid #d9e2fb}.landing-links .landing-link-feed:hover{background:#e1e8fa}.fab-write{position:fixed;right:24px;bottom:24px;z-index:40;width:58px;height:58px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:2rem;line-height:1;font-weight:400;color:#fff;background:var(--accent);border:0;box-shadow:var(--shadow);transition:background .18s ease,transform .18s ease}.fab-write:hover{background:var(--accent-hover);color:#fff;transform:translateY(-2px)}.fab-write span{margin-top:-3px}.work-body img,.work-md img{display:block;width:auto;max-width:100%;max-height:460px;object-fit:contain;border-radius:var(--radius-md);margin:18px auto}.work-body p,.work-md p{margin:0 0 1em}.work-body h1,.work-body h2,.work-body h3,.work-md h1,.work-md h2,.work-md h3{line-height:1.3}.work-body blockquote,.work-md blockquote{margin:0 0 1em;padding-left:1rem;border-left:3px solid var(--border);color:var(--subtext)}.work-body a,.work-md a{color:var(--accent)}.editor-md-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.editor-hint{color:var(--subtext);font-size:.85rem;margin:6px 0 0}.input-prefix{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);overflow:hidden}.input-prefix:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #2c61ff1f}.input-prefix span{padding:0 4px 0 14px;color:var(--subtext);font-weight:600}.input-prefix input{border:0;border-radius:0;padding-left:4px}.input-prefix input:focus{box-shadow:none}.handle{color:var(--subtext);font-weight:500}.section-hero{background:var(--hero-bg);text-align:center;padding:3rem 1.2rem 3.4rem;border-radius:var(--radius-xl);margin-bottom:2.4rem}.section-hero .hero-title{margin:0 0 1.2rem;font-family:Playfair Display,Georgia,serif;font-size:clamp(2.2rem,6vw,4rem);font-weight:700;letter-spacing:-.03em}.section-hero .hero-desc{color:var(--subtext);font-size:1.1rem;max-width:620px;margin:0 auto 1rem}.section-hero .hero-curator{color:var(--subtext);font-size:.98rem;margin:0 auto 1.6rem}.hero-image{width:auto;max-width:100%;max-height:min(56vh,560px);height:auto;object-fit:contain;border-radius:18px;margin:0 auto;display:block}.piece{border-bottom:1px solid var(--border);padding:2rem .4rem;display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,260px);gap:1.4rem;align-items:start}.piece:last-child{border-bottom:0}.piece-main{min-width:0}.piece-title{margin:0 0 .6rem;font-size:clamp(1.4rem,3vw,1.9rem)}.piece-title a{color:var(--text)}.piece-title a:hover{color:var(--accent)}.piece-text{margin:0;white-space:pre-wrap;color:var(--text);font-size:clamp(1.05rem,2vw,1.22rem);line-height:1.9}.piece-cover{width:auto;max-width:100%;max-height:320px;object-fit:contain;border-radius:var(--radius-md);margin-top:1rem;display:block}.piece-body{font-size:clamp(1.05rem,2vw,1.22rem);line-height:1.7;color:var(--text)}.piece-side{text-align:right;display:grid;gap:.3rem;justify-items:end}.piece-side-author{font-family:Manrope,Inter,sans-serif;font-size:clamp(1.1rem,2.2vw,1.4rem);font-weight:700;color:var(--text)}.piece-side-meta{color:var(--subtext);font-size:.92rem;display:flex;gap:10px;align-items:center}.comment{border-top:1px solid var(--border);padding:16px 0}.comment-meta{font-size:.88rem;color:var(--subtext);display:flex;gap:8px;align-items:center}.profile-head{display:flex;gap:20px;align-items:center;margin-bottom:30px}.profile-head .avatar{width:76px;height:76px}.admin-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--border);flex-wrap:wrap}.status-pill{font-size:.75rem;font-weight:700;padding:2px 10px;border-radius:999px}.status-pill.published,.status-pill.visible{background:#e3f0e1;color:#2f6b3a}.status-pill.hidden{background:#f3e0dd;color:#97362a}.tabs{display:flex;gap:8px;margin-bottom:22px;flex-wrap:wrap}.tabs button{border:1px solid var(--border);background:var(--surface);padding:8px 18px;border-radius:999px;font-weight:600;color:var(--subtext)}.tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}@media (max-width: 640px){.piece{grid-template-columns:1fr;gap:.8rem;padding:1.5rem .2rem}.piece-side{text-align:left;justify-items:start;order:-1}.search-shell{margin-top:10vh;width:min(95vw,720px)}}
