.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;background:var(--bg-panel);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:20}.header__left{display:flex;align-items:center;gap:14px;min-width:0}.header__brand{display:flex;align-items:center;gap:12px;min-width:0}.header__logo{font-size:26px;line-height:1}.header__title{margin:0;font-size:19px;font-weight:700;letter-spacing:-.01em}.header__subtitle{margin:2px 0 0;font-size:12.5px;color:var(--text-muted)}.header__menu{display:none;flex-direction:column;gap:4px;width:40px;height:40px;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm)}.header__menu span{display:block;width:18px;height:2px;background:var(--text-soft);border-radius:2px}.theme-toggle{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--bg-elevated);display:grid;place-items:center;font-size:18px;transition:transform .2s ease,background .2s ease,border-color .2s ease}.theme-toggle:hover{transform:translateY(-1px) rotate(-8deg);border-color:var(--accent)}.layout{flex:1;display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:0}.sidebar{display:flex;flex-direction:column;background:var(--bg-sidebar);border-right:1px solid var(--border);min-height:0}.sidebar__search{position:relative;padding:16px 16px 12px}.sidebar__search input{width:100%;padding:11px 36px 11px 38px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-panel);color:var(--text);font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.sidebar__search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.sidebar__search-icon{position:absolute;left:28px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.6;pointer-events:none}.sidebar__search-clear{position:absolute;right:26px;top:50%;transform:translateY(-50%);border:none;background:var(--bg-hover);color:var(--text-soft);width:22px;height:22px;border-radius:50%;font-size:11px;display:grid;place-items:center}.sidebar__list{flex:1;overflow-y:auto;padding:4px 12px 16px}.sidebar__group{margin-bottom:18px}.sidebar__group-head{display:flex;align-items:baseline;gap:8px;padding:8px 8px 6px;position:sticky;top:0;background:linear-gradient(var(--bg-sidebar) 70%,transparent);z-index:1}.sidebar__group-day{font-size:13px;font-weight:600;color:var(--text)}.sidebar__group-date{font-size:12px;font-weight:600;color:var(--accent);background:var(--accent-soft);padding:1px 8px;border-radius:999px}.sidebar-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:11px 12px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text);transition:background .18s ease,border-color .18s ease,transform .18s ease}.sidebar-item+.sidebar-item{margin-top:2px}.sidebar-item:hover{background:var(--bg-hover)}.sidebar-item.is-active{background:var(--bg-active);border-color:var(--accent)}.sidebar-item.is-active .sidebar-item__title{color:var(--accent-strong)}.sidebar-item__body{display:flex;flex-direction:column;min-width:0}.sidebar-item__title{font-size:14px;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.sidebar-item__author{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-item__tags{display:flex;margin-top:6px}.sidebar-item__tag{font-size:10.5px;font-weight:600;color:var(--text-soft);background:var(--bg-hover);padding:2px 8px;border-radius:999px}.sidebar-item.is-active .sidebar-item__tag{background:var(--accent-soft);color:var(--accent-strong)}.sidebar__tags{display:flex;flex-wrap:wrap;gap:6px;padding:0 16px 12px;border-bottom:1px solid var(--border-soft);margin-bottom:6px}.tag-chip{font-size:12px;font-weight:600;color:var(--text-soft);background:var(--bg-panel);border:1px solid var(--border);padding:5px 11px;border-radius:999px;transition:all .16s ease}.tag-chip:hover{border-color:var(--accent);color:var(--accent-strong)}.tag-chip.is-active{background:var(--accent);border-color:var(--accent);color:var(--accent-contrast)}.sidebar__empty{padding:24px 12px;color:var(--text-muted);font-size:14px;text-align:center}.sidebar__foot{padding:12px 20px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--border-soft)}.sidebar__scrim{display:none}.main{overflow-y:auto;min-height:0;background:var(--bg)}.detail{animation:fadeUp .4s ease}.detail__inner{max-width:calc(var(--maxread) + 8rem);margin:0 auto;padding:48px 56px 96px}.detail__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;color:var(--text-muted)}.detail__chip{font-weight:600;color:var(--accent-strong);background:var(--accent-soft);padding:3px 12px;border-radius:999px}.detail__date{color:var(--text-soft)}.detail__dot{opacity:.5}.cover{position:relative;flex-shrink:0;display:flex;align-items:flex-start;overflow:hidden;border-radius:5px;box-shadow:var(--shadow-sm);color:#fff}.cover__spine{position:absolute;top:0;left:0;bottom:0;width:4px;background:rgba(0,0,0,.22);box-shadow:inset -1px 0 1px #ffffff26}.cover__text{display:flex;flex-direction:column;height:100%}.cover__title{font-family:var(--font-serif);font-weight:600;line-height:1.2;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical}.cover__author{margin-top:auto;opacity:.85;font-weight:500;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.cover__quote{font-family:var(--font-serif);margin:auto;opacity:.9}.cover--sm{width:40px;height:54px;border-radius:4px}.cover--sm .cover__text{padding:6px 5px 5px 8px}.cover--sm .cover__title{font-size:8.5px;-webkit-line-clamp:4}.cover--sm .cover__author{display:none}.cover--sm .cover__quote{font-size:26px}.cover--lg{width:132px;height:188px;border-radius:7px;box-shadow:var(--shadow-md)}.cover--lg .cover__text{padding:18px 16px 16px 20px}.cover--lg .cover__title{font-size:17px;-webkit-line-clamp:6}.cover--lg .cover__author{font-size:11px}.cover--lg .cover__quote{font-size:76px}.detail__head{display:flex;gap:26px;align-items:flex-start;margin-top:22px}.detail__head-text{min-width:0;flex:1}.detail__head .detail__kicker{margin-top:2px}.detail__tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}.detail__tag{font-size:12px;font-weight:600;color:var(--accent-strong);background:var(--accent-soft);padding:4px 12px;border-radius:999px}.detail__kicker{margin:22px 0 6px;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.detail__title{margin:0;font-family:var(--font-serif);font-size:38px;line-height:1.15;letter-spacing:-.015em;color:var(--text)}.detail__author{margin:12px 0 0;font-size:15px;color:var(--text-soft);font-weight:500}.detail__author--muted{color:var(--text-muted);font-style:italic;font-weight:400}.detail__summary{margin:22px 0 0;font-family:var(--font-serif);font-style:italic;font-size:19px;line-height:1.6;color:var(--text-soft);padding-left:18px;border-left:3px solid var(--accent)}.detail__rule{margin:32px 0;border:none;border-top:1px solid var(--border)}.review-body{max-width:var(--maxread)}.review-body__paragraph{margin:0 0 20px;font-size:17px;line-height:1.85;color:var(--text)}.review-body__heading{margin:36px 0 14px;font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.01em}.review-body__heading:before{content:"";display:inline-block;width:8px;height:8px;margin-right:10px;border-radius:2px;background:var(--accent);vertical-align:middle}.review-body__list{margin:0 0 22px;padding:0;list-style:none}.review-body__list li{position:relative;padding:10px 0 10px 34px;font-size:17px;line-height:1.7;border-bottom:1px dashed var(--border-soft)}.review-body__list li:last-child{border-bottom:none}.review-body__list li:before{content:"✓";position:absolute;left:0;top:10px;width:22px;height:22px;display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--accent-contrast);background:var(--accent);border-radius:50%}.review-body__message{margin:32px 0 0;padding:24px 26px;background:var(--quote-bg);border:1px solid var(--quote-border);border-radius:var(--radius);position:relative}.review-body__message-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--quote-accent);margin-bottom:8px}.review-body__message p{margin:0;font-family:var(--font-serif);font-size:19px;line-height:1.65;font-style:italic;color:var(--text)}.detail--empty{display:grid;place-items:center;height:100%}.detail__empty-card{text-align:center;color:var(--text-muted)}.detail__empty-card span{font-size:48px;display:block;margin-bottom:12px}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 860px){.header__menu{display:flex}.layout{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(86vw,var(--sidebar-w));z-index:40;transform:translate(-100%);transition:transform .28s ease;box-shadow:var(--shadow-lg)}.sidebar.is-open{transform:translate(0)}.sidebar__scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .28s ease;z-index:35}.sidebar__scrim.is-open{opacity:1;pointer-events:auto}.detail__inner{padding:28px 22px 72px}.detail__head{gap:18px}.cover--lg{width:92px;height:132px}.cover--lg .cover__text{padding:12px 11px 11px 14px}.cover--lg .cover__title{font-size:13px}.cover--lg .cover__quote{font-size:52px}.detail__title{font-size:26px}.review-body__paragraph,.review-body__list li{font-size:16px}}
