:root{--bg: #141416;--bg-2: #1c1c20;--surface: #1a1a1e;--surface-2: #222226;--border: #2c2c32;--border-soft: #242429;--ink: #ecebe5;--ink-2: #c9c7c0;--muted: #8a877f;--muted-2: #5f5d57;--accent: #e89071;--accent-soft: #3a2419;--accent-ink: #f5c3ad;--blue: #86a3e0;--blue-soft: #1f2838;--success: #8fb785;--danger: #e48989;--highlight: rgba(255, 220, 120, .3);--sans: "Geist", -apple-system, BlinkMacSystemFont, "SF Pro Display", system-ui, sans-serif;--serif: "Instrument Serif", "Iowan Old Style", Georgia, serif;--mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--radius-lg: 18px;--radius-md: 12px;--radius-sm: 8px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.25), 0 1px 3px rgba(0,0,0,.18);--shadow-md: 0 6px 18px rgba(0,0,0,.32), 0 2px 6px rgba(0,0,0,.18);--shadow-lg: 0 24px 60px rgba(0,0,0,.5), 0 10px 24px rgba(0,0,0,.3);--dur: .18s;--ease: cubic-bezier(.2, .8, .2, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv11"}::selection{background:var(--accent);color:var(--bg)}*{color-scheme:dark}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:var(--muted-2);background-clip:padding-box;border:2px solid transparent}*::-webkit-scrollbar-track{background:transparent}a{color:var(--ink);text-decoration:none}a:hover{color:var(--accent-ink)}button{font:inherit;font-family:var(--sans);font-weight:500;background:var(--surface);border:1px solid var(--border);color:var(--ink);border-radius:var(--radius-sm);padding:7px 12px;cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease),color var(--dur) var(--ease);letter-spacing:-.005em}button:hover{background:var(--bg-2);border-color:var(--muted-2)}button:active{transform:translateY(1px)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--ink);color:#141416;border-color:var(--ink)}button.primary:hover{background:#fafaf7;color:#141416;border-color:#fafaf7}button.danger{color:var(--danger)}button.danger:hover{background:#fde8e8;border-color:var(--danger)}button.ghost{background:transparent;border:none;padding:6px 10px;color:var(--muted);border-radius:var(--radius-sm)}button.ghost:hover{background:var(--bg-2);color:var(--ink)}input,select,textarea{font:inherit;font-family:var(--sans);padding:8px 12px;border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:var(--radius-sm);outline:none;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}input:focus,select:focus,textarea:focus{border-color:var(--ink);box-shadow:0 0 0 3px #1c1c1a0f}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 14px) 14px,calc(100% - 10px) 14px;background-size:4px 4px,4px 4px;background-repeat:no-repeat;padding-right:26px}code,.mono{font-family:var(--mono);font-size:.88em}.app{display:grid;grid-template-columns:260px 1fr;height:100vh;padding:14px;gap:14px;background:var(--bg)}.nav{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 14px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.nav-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px;border-bottom:1px solid var(--border-soft);margin-bottom:10px}.nav-brand-logo{width:100%;max-width:80px;height:auto;color:var(--ink);display:block;filter:brightness(0) invert(1)}.nav-brand-mark{width:32px;height:32px;border-radius:10px;background:var(--ink);color:var(--surface);display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:18px;font-weight:500}.nav-brand-name{font-weight:600;letter-spacing:-.01em;font-size:15px}.nav-brand-sub{font-size:11px;color:var(--muted);margin-top:1px}.nav-section-label{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;padding:14px 8px 6px;font-weight:500}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--ink-2);font-size:13.5px;font-weight:500;cursor:pointer;transition:background var(--dur) var(--ease);border:none;background:transparent;width:100%;text-align:left}.nav-item:hover{background:var(--bg-2)}.nav-item.active{background:var(--bg-2);color:var(--ink)}.nav-item .icon{width:16px;height:16px;flex:none;opacity:.7}.nav-item .count{margin-left:auto;font-size:11px;color:var(--muted);font-weight:400;font-family:var(--mono)}.nav-footer{margin-top:auto;padding-top:14px;border-top:1px solid var(--border-soft)}.main{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}.main-header{display:flex;align-items:center;gap:12px;padding:16px 22px;border-bottom:1px solid var(--border-soft);background:var(--surface)}.main-header h1{margin:0;font-size:18px;font-weight:600;letter-spacing:-.015em;flex:none}.main-header .spacer{flex:1}.search{flex:1;max-width:360px;position:relative}.search input{width:100%;background:var(--bg-2);border:1px solid transparent;border-radius:var(--radius-pill);padding:7px 14px 7px 34px;font-size:13px}.search input:focus{background:var(--surface);border-color:var(--border);box-shadow:0 0 0 3px #1c1c1a0a}.search:before{content:"";position:absolute;left:12px;top:50%;width:14px;height:14px;transform:translateY(-50%);background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23868379' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='7'/><path d='m20 20-3.5-3.5'/></svg>") no-repeat}.main-body{flex:1;overflow:auto;padding:24px 22px 32px}.page-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:0 0 4px}.page-title h2{margin:0;font-family:var(--serif);font-style:italic;font-weight:400;font-size:34px;letter-spacing:-.02em;line-height:1.1}.page-title .sub{color:var(--muted);font-size:13px}.page-title-actions{display:flex;gap:8px}.toolbar-row{display:flex;align-items:center;gap:8px;margin:20px 0 16px}.sort-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-2);border-radius:var(--radius-pill);font-size:12.5px;color:var(--ink-2);border:1px solid transparent;cursor:pointer}.sort-chip:hover{background:var(--surface);border-color:var(--border)}.err-banner{background:#fde8e8;color:var(--danger);border:1px solid #f5c7c7;padding:10px 14px;border-radius:var(--radius-md);font-size:13px;margin-bottom:16px}.empty{padding:80px 20px;text-align:center;color:var(--muted)}.empty .big{font-family:var(--serif);font-style:italic;font-size:28px;color:var(--ink-2);margin-bottom:8px}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.doc-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:0;cursor:pointer;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);display:flex;flex-direction:column;gap:0;min-height:260px;position:relative;overflow:hidden}.doc-card>.title{padding:12px 16px 0}.doc-card>.meta{padding:8px 16px 12px;margin-top:0}.doc-thumb{height:170px;background:var(--bg-2);border-bottom:1px solid var(--border-soft);overflow:hidden;display:flex;justify-content:center;align-items:flex-start;padding:14px 14px 0}.doc-thumb-page{width:100%;max-width:160px;aspect-ratio:8.5 / 11;background:var(--surface);color:var(--ink);border-radius:3px;box-shadow:0 2px 6px #00000073,0 0 0 1px var(--border-soft);padding:10px 12px;overflow:hidden;font-family:var(--sans);font-size:4.5px;line-height:1.45;text-overflow:ellipsis;position:relative}.doc-thumb-page p{margin:0 0 3px;white-space:normal;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.doc-thumb-page:after{content:"";position:absolute;left:0;right:0;bottom:0;height:30px;background:linear-gradient(to bottom,transparent,var(--surface));pointer-events:none}.doc-thumb-empty{color:var(--muted);font-style:italic;font-size:5.5px;text-align:center;padding-top:30%}.doc-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border)}.doc-card .preview{flex:1;min-height:54px;font-size:12px;color:var(--muted);overflow:hidden;line-height:1.45;mask-image:linear-gradient(to bottom,#000 50%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,#000 50%,transparent 100%)}.doc-card .title{font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--ink);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.doc-card .meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px;padding-top:10px;border-top:1px solid var(--border-soft);font-size:11.5px;color:var(--muted);font-family:var(--mono)}.doc-card .meta .row-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--dur) var(--ease)}.doc-card:hover .row-actions{opacity:1}.doc-card .meta .row-actions button{padding:2px 6px;font-size:11px;border:none;background:transparent;color:var(--muted);font-family:var(--sans)}.doc-card .meta .row-actions button:hover{background:var(--bg-2);color:var(--ink)}.doc-card .meta .row-actions button.danger:hover{color:var(--danger);background:#fde8e8}.doc-card-new{background:transparent;border:1.5px dashed var(--muted-2);display:grid;place-items:center;color:var(--muted);font-size:13.5px;gap:8px;min-height:260px;padding:16px;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease)}.doc-card-new:hover{border-color:var(--ink);background:var(--surface);color:var(--ink);transform:none;box-shadow:none}.doc-card-new .plus{width:36px;height:36px;border-radius:50%;background:var(--bg-2);display:grid;place-items:center;font-size:20px;font-weight:300}.share-pop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1c1a59;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:50;animation:fade-in .14s ease}.share-pop{background:var(--surface);border-radius:var(--radius-lg);padding:24px;width:440px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);animation:scale-in .18s var(--ease)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.share-pop h3{margin:0 0 4px;font-size:18px;font-weight:600;letter-spacing:-.015em;display:flex;align-items:center;justify-content:space-between}.share-pop .close{background:transparent;border:none;font-size:18px;color:var(--muted);padding:0;width:28px;height:28px;border-radius:50%;cursor:pointer}.share-pop .close:hover{background:var(--bg-2);color:var(--ink)}.share-pop .share-sub{color:var(--muted);font-size:13px;margin:0 0 16px}.share-pop .sp-create{display:flex;gap:8px;align-items:stretch;margin-bottom:16px}.share-pop .sp-create select{flex:1}.share-pop ul{list-style:none;padding:0;margin:0}.share-pop li{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:10px 0;border-top:1px solid var(--border-soft);font-size:13px}.share-pop li:first-child{border-top:none}.perm-badge{font-size:10.5px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;padding:3px 9px;border-radius:var(--radius-pill);background:var(--bg-2);color:var(--muted)}.perm-badge[data-perm=edit]{background:var(--ink);color:var(--surface)}.perm-badge[data-perm=comment]{background:var(--accent-soft);color:var(--accent-ink)}.perm-badge[data-perm=view]{background:var(--blue-soft);color:#2e4a85}.share-pop .link-code{font-family:var(--mono);font-size:11.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-link-banner{margin-top:4px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);display:flex;gap:8px;align-items:center;font-size:12px}.new-link-banner code{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink-2);background:transparent;padding:0}.search{position:relative;display:flex;align-items:center}.search .search-icon{position:absolute;left:10px;width:14px;height:14px;color:var(--muted);pointer-events:none}.search input{padding-left:30px;padding-right:28px}.search .search-clear{position:absolute;right:6px;width:20px;height:20px;border-radius:50%;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;display:grid;place-items:center}.search .search-clear:hover{background:var(--bg-2);color:var(--ink)}.doc-card-skeleton{cursor:default}.doc-card-skeleton:hover{transform:none;box-shadow:none;border-color:var(--border-soft)}.doc-card-skeleton .sk-line{background:linear-gradient(90deg,var(--bg-2) 0%,var(--surface-2) 50%,var(--bg-2) 100%);background-size:200% 100%;animation:sk-shimmer 1.2s linear infinite;border-radius:4px}.doc-card-skeleton .sk-title{height:14px;width:70%;margin-bottom:8px}.doc-card-skeleton .sk-meta{height:10px;width:40%;margin-top:auto}@keyframes sk-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}a.doc-card{text-decoration:none;color:inherit}a.doc-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.row-menu{position:relative;display:inline-block}.row-menu-pop{position:absolute;right:0;top:calc(100% + 4px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:20;min-width:140px;padding:4px;display:flex;flex-direction:column}.row-menu-pop button{text-align:left;padding:6px 10px;font-size:12.5px;border:none;background:transparent;color:var(--ink);border-radius:var(--radius-sm, 4px);cursor:pointer;font-family:var(--sans)}.row-menu-pop button:hover{background:var(--bg-2)}.row-menu-pop button.danger{color:var(--danger)}.row-menu-pop button.danger:hover{background:#fde8e8}.share-pop li .link-col{display:flex;flex-direction:column;gap:2px;min-width:0}.share-pop li .link-col .link-code.muted{color:var(--muted)}.share-pop li .link-col .link-hint{font-size:10.5px;color:var(--muted);font-style:italic}.share-pop li .link-actions{display:flex;gap:6px}.doc-layout{display:block;height:100vh;padding:0;background:var(--bg)}.doc-main{background:var(--bg);border:none;border-radius:0;box-shadow:none;overflow:hidden;display:flex;flex-direction:column;min-width:0;position:relative;height:100%}.doc-header{display:flex;align-items:center;gap:10px;padding:7px 14px;border-bottom:1px solid var(--border-soft);min-height:40px}.doc-header .back{color:var(--muted);font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--radius-sm);transition:background var(--dur) var(--ease)}.doc-header .back:hover{background:var(--bg-2);color:var(--ink)}.doc-header .title-wrap{flex:1;min-width:0}.doc-header .title{font-size:13px;font-weight:600;letter-spacing:-.005em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:380px;padding:3px 8px;border-radius:var(--radius-sm);border:1px solid transparent;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);display:inline-flex;align-items:center;gap:6px;user-select:none;-webkit-user-select:none}.doc-header .title.editable{cursor:text}.doc-header .title.editable:hover{background:var(--bg-2)}.doc-header .title.editable:after{content:"✎";font-size:11px;color:var(--muted-2);opacity:0;transition:opacity var(--dur) var(--ease)}.doc-header .title.editable:hover:after{opacity:1}.doc-header .title-input{font:inherit;font-size:13px;font-weight:600;letter-spacing:-.005em;color:var(--ink);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 8px;min-width:240px;max-width:380px;outline:none}.doc-header .title-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e8907126}.doc-header .perm{font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:var(--radius-pill);background:var(--bg-2);color:var(--muted)}.doc-header .status-dot{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 0 2px #7a9b6e38;transition:background var(--dur) var(--ease)}.doc-header .status-dot.offline{background:var(--danger);box-shadow:0 0 0 2px #c85c5c2e}.doc-header .presence-bar{padding:0;border:none;background:transparent;flex-direction:row;gap:6px;min-height:auto;align-items:center}.doc-header .presence-bar-label{font-size:10px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.doc-header .presence-chip{width:22px;height:22px;font-size:10px;box-shadow:0 0 0 2px var(--surface);margin-left:-4px}.menu-bar{display:flex;gap:1px;padding:2px 10px;border-bottom:1px solid var(--border-soft);background:var(--surface);font-size:12px}.menu{position:relative}.menu-trigger{font:inherit;padding:3px 8px;border:none;background:transparent;color:var(--ink-2);border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.menu-trigger:hover,.menu-trigger.open{background:var(--bg-2);color:var(--ink)}.menu-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.menu-pop{position:absolute;top:calc(100% + 4px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px;min-width:220px;overflow:visible;z-index:60;animation:scale-in .12s var(--ease)}.menu-sub-pop{top:-6px!important}.menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 12px;border:none;background:transparent;color:var(--ink);border-radius:6px;cursor:pointer;text-align:left;font-size:13px;gap:12px;min-height:30px}.menu-item:hover:not(:disabled){background:var(--bg-2)}.menu-item:disabled{opacity:.35;cursor:not-allowed}.menu-sub{position:relative}.menu-sub>.menu-sub-pop{position:absolute;top:0;left:100%;margin-left:4px;display:none;min-width:200px}.menu-sub:hover>.menu-sub-pop,.menu-sub:focus-within>.menu-sub-pop{display:block}.menu-shortcut{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.02em}.menu-divider{height:1px;background:var(--border-soft);margin:4px 2px}.ci-drawer{position:fixed;top:14px;right:14px;bottom:14px;width:360px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:60;display:flex;flex-direction:column;overflow:hidden;animation:slide-in-right .24s var(--ease)}@keyframes slide-in-right{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.ci-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-soft)}.ci-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--ink)}.ci-count{font-family:var(--mono);font-size:11px;color:var(--muted);background:var(--bg-2);padding:2px 8px;border-radius:var(--radius-pill);font-weight:500}.ci-head .icon-btn{background:transparent;border:none;color:var(--muted);width:28px;height:28px;border-radius:50%;display:grid;place-items:center;cursor:pointer}.ci-head .icon-btn:hover{background:var(--bg-2);color:var(--ink)}.ci-filters{display:flex;gap:4px;padding:10px 14px;border-bottom:1px solid var(--border-soft)}.ci-filter{font:inherit;font-size:12px;padding:4px 12px;border:1px solid transparent;background:transparent;color:var(--muted);border-radius:var(--radius-pill);cursor:pointer;font-weight:500}.ci-filter:hover{background:var(--bg-2);color:var(--ink)}.ci-filter.active{background:var(--accent-soft);color:var(--accent)}.ci-list{flex:1;overflow-y:auto;padding:8px}.ci-empty{padding:40px 20px;text-align:center;color:var(--muted);font-style:italic;font-size:13px}.ci-item{display:flex;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;text-align:left;border-radius:var(--radius-md);cursor:pointer;transition:background var(--dur) var(--ease);align-items:flex-start}.ci-item:hover{background:var(--bg-2)}.ci-item.resolved{opacity:.5}.ci-avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:10.5px;font-weight:600;flex:none;margin-top:2px}.ci-body{flex:1;min-width:0}.ci-meta{display:flex;align-items:center;gap:8px;font-size:11.5px;line-height:1.3}.ci-author{font-weight:600;color:var(--ink);font-size:12.5px}.ci-time{color:var(--muted-2);font-family:var(--mono);font-size:10.5px}.ci-resolved-tag{margin-left:auto;font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--success)}.ci-comment{margin-top:3px;font-size:13px;line-height:1.45;color:var(--ink-2);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.ci-replies{margin-top:4px;font-size:11.5px;color:var(--muted)}.ci-item{display:block;width:100%;padding:10px 12px;border-radius:var(--radius-md);transition:background var(--dur) var(--ease);cursor:pointer}.ci-item-main{display:flex;gap:10px;align-items:flex-start}.ci-avatar.sm{width:22px;height:22px;font-size:9.5px}.ci-replies-list{margin-top:10px;padding-top:10px;padding-left:38px;border-top:1px dashed var(--border-soft);display:flex;flex-direction:column;gap:8px}.ci-reply{display:flex;gap:8px}.ci-reply-body{flex:1;min-width:0}.ci-actions{display:flex;gap:4px;justify-content:flex-end;margin-top:10px;padding-top:8px;border-top:1px solid var(--border-soft)}.ci-action{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;font-size:12px;border:none;background:transparent;color:var(--muted);border-radius:var(--radius-sm);cursor:pointer;font-weight:500}.ci-action:hover{background:var(--bg-2);color:var(--ink)}.ci-action.danger:hover{background:#3a1d1d;color:var(--danger)}.ci-reply-box{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border-soft)}.ci-reply-box textarea{width:100%;min-height:56px;font-family:var(--sans);font-size:13px;padding:8px 10px;border:1px solid var(--border);background:var(--bg-2);border-radius:var(--radius-sm);color:var(--ink);resize:vertical}.ci-reply-box textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e8907124}.ci-reply-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:8px}.ci-reply-actions button{padding:5px 14px;font-size:12.5px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);background:var(--bg-2);color:var(--ink)}.ci-reply-actions button.ghost{background:transparent;border-color:transparent;color:var(--muted)}.ci-reply-actions button.ghost:hover{background:var(--bg-2);color:var(--ink)}.ci-reply-actions button.primary{background:var(--ink);color:#141416;border-color:var(--ink)}.ci-reply-actions button.primary:disabled{opacity:.35;cursor:not-allowed}.ProseMirror .comment-mark.flash-anchor{animation:flash-anchor 1.2s var(--ease)}@keyframes flash-anchor{0%{box-shadow:0 0 0 4px var(--accent);background:var(--accent-soft)}60%{box-shadow:0 0 0 4px var(--accent-soft)}to{box-shadow:0 0 0 0 transparent}}body.full-width .editor-grid{width:100%;max-width:100%}body.full-width .editor-page{width:100%;max-width:100%;padding:40px max(24px,2vw);min-height:calc(100vh - 180px);background:transparent;border:none;border-radius:0;box-shadow:none}body.full-width .editor-wrap{padding:0}body.full-width .comments-dock{display:none}.editor-page .ProseMirror{max-width:var(--text-max-width, none);margin-left:auto;margin-right:auto}.width-control{position:fixed;bottom:20px;right:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:6px 10px 6px 14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);z-index:40;font-size:12px}.wc-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}.width-control input[type=range]{width:130px;height:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:3px;outline:none;padding:0;border:none}.width-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer;border:2px solid var(--surface);box-shadow:0 1px 3px #0000004d}.width-control input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer;border:2px solid var(--surface)}.wc-value{font-family:var(--mono);font-size:11.5px;color:var(--ink);min-width:30px;text-align:right;font-weight:500}.wc-reset{background:transparent;border:none;color:var(--muted);width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:14px;line-height:1}.wc-reset:hover{background:var(--bg-2);color:var(--ink)}.gdoc-toolbar{position:relative;background:var(--surface);color:var(--ink);border-radius:0;padding:4px 14px;display:flex;gap:1px;align-items:center;flex-wrap:wrap;border-bottom:1px solid var(--border-soft);z-index:5;scrollbar-width:none}.gdoc-toolbar::-webkit-scrollbar{display:none}.gdoc-toolbar .tb-group{display:inline-flex;align-items:center;gap:1px;flex:none}.gdoc-toolbar .tb-sep{width:1px;height:18px;background:var(--border);margin:0 6px;flex:none}.gdoc-toolbar .tb-btn,.gdoc-toolbar button{font:inherit;min-width:26px;height:26px;padding:0 6px;border:none;background:transparent;color:var(--ink-2);border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);flex:none}.gdoc-toolbar .tb-btn.small{min-width:22px;height:22px;padding:0 5px}.gdoc-toolbar .tb-sep{height:16px;margin:0 4px}.gdoc-toolbar button:hover{background:var(--bg-2);color:var(--ink)}.gdoc-toolbar button:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.gdoc-toolbar button.active,.gdoc-toolbar .tb-btn.active{background:var(--accent-soft);color:var(--accent)}.gdoc-toolbar .tb-select-btn{font:inherit;height:26px;padding:0 6px 0 8px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--ink);cursor:pointer;font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:4px;min-width:100px;max-width:160px;text-align:left;justify-content:space-between}.gdoc-toolbar .tb-select-btn:hover{background:var(--bg-2)}.gdoc-toolbar .tb-select-btn>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gdoc-toolbar .tb-select-btn.tb-font{min-width:140px;max-width:200px}.tb-dropdown{position:relative}.tb-menu{position:absolute;top:calc(100% + 4px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:6px;min-width:220px;max-height:360px;overflow-y:auto;z-index:50;animation:scale-in .12s var(--ease)}.tb-menu-item{display:flex;align-items:center;width:100%;min-height:32px;padding:6px 10px;border:none;background:transparent;color:var(--ink);border-radius:6px;cursor:pointer;text-align:left;font-size:13px;gap:8px;transition:background var(--dur) var(--ease)}.tb-menu-item:hover{background:var(--bg-2)}.tb-menu-item.active{background:var(--accent-soft);color:var(--accent)}.tb-menu-label{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);padding:8px 10px 4px;font-weight:600}.tb-block-menu .tb-menu-item{padding:8px 12px;text-align:left;justify-content:flex-start}.tb-block-row{display:flex;align-items:stretch;gap:2px}.tb-block-row>.tb-menu-item{flex:1}.tb-block-row>.tb-block-edit{opacity:.55;min-width:28px;width:28px;height:auto;border:none;background:transparent;color:var(--muted);border-radius:6px;cursor:pointer;transition:opacity var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease);display:inline-flex;align-items:center;justify-content:center;margin-left:4px}.tb-block-row:hover>.tb-block-edit,.tb-block-row:focus-within>.tb-block-edit{opacity:1}.tb-block-row>.tb-block-edit:hover{background:var(--bg-2);color:var(--accent)}.tb-block-row .tb-active-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:0 0 auto;align-self:center;margin-left:2px}.tb-block-row .tb-menu-item.active{background:transparent;color:inherit}.single-style-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:grid;place-items:center;animation:fade-in .14s var(--ease)}.single-style{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:620px;max-width:calc(100vw - 40px);max-height:calc(100vh - 80px);overflow:auto;animation:scale-in .2s var(--ease);display:flex;flex-direction:column;z-index:10000}.single-style .ss-head{display:flex;justify-content:space-between;align-items:flex-start;padding:26px 28px 18px;border-bottom:1px solid var(--border-soft)}.single-style .ss-kicker{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);font-weight:600;margin-bottom:6px}.single-style .ss-title{line-height:1.1;color:var(--ink);font-size:28px;font-weight:600}.single-style .ss-head .icon-btn{font-size:26px;width:36px;height:36px;border-radius:50%;background:transparent;border:none;color:var(--muted);cursor:pointer;line-height:1}.single-style .ss-head .icon-btn:hover{background:var(--bg-2);color:var(--ink)}.single-style .ss-body{padding:22px 28px;display:flex;flex-direction:column;gap:18px}.single-style .se-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.single-style .se-row label{flex:0 0 84px;font-size:12.5px;color:var(--muted);font-weight:600}.single-style .se-row select,.single-style .se-row input{height:38px;padding:0 14px;background:var(--bg-2);border:1px solid var(--border);color:var(--ink);border-radius:8px;font-size:14px;font-family:var(--sans)}.single-style .se-row select:focus,.single-style .se-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e8907124;outline:none}.single-style .se-row .style-segment{background:var(--bg-2);border-radius:8px;padding:4px;display:inline-flex;gap:3px}.single-style .se-row .style-segment button{min-width:40px;height:32px;border:none;background:transparent;color:var(--ink-2);border-radius:6px;cursor:pointer;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;font-size:13px}.single-style .se-row .style-segment button:hover{background:var(--surface);color:var(--ink)}.single-style .se-row .style-segment button.active{background:var(--accent-soft);color:var(--accent)}.single-style .style-swatches{display:grid;grid-template-columns:repeat(10,30px);gap:8px}.single-style .style-swatches .tb-swatch{width:30px!important;height:30px!important;border-radius:8px!important;border:1px solid rgba(255,255,255,.1)!important;padding:0!important;cursor:pointer;transition:transform var(--dur) var(--ease)}.single-style .style-swatches .tb-swatch:hover{transform:scale(1.1)}.single-style .style-swatches .tb-swatch.sel{outline:2px solid var(--accent);outline-offset:2px}.single-style .ss-foot{display:flex;justify-content:flex-end;gap:10px;align-items:center;padding:18px 28px;border-top:1px solid var(--border-soft);background:var(--surface-2);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.single-style .ss-foot button{padding:10px 20px;font-size:13.5px;font-weight:500;border-radius:8px;border:1px solid var(--border);background:var(--bg-2);color:var(--ink);cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}.single-style .ss-foot button:hover{background:var(--surface);border-color:var(--muted-2)}.single-style .ss-foot button.ghost{background:transparent;border-color:transparent;color:var(--muted)}.single-style .ss-foot button.ghost:hover:not(:disabled){background:var(--bg-2);color:var(--ink);border-color:transparent}.single-style .ss-foot button.ghost.danger{color:var(--danger)}.single-style .ss-foot button.primary{background:var(--ink);color:#141416;border-color:var(--ink);padding:10px 24px}.single-style .ss-foot button.primary:hover{background:#2e2e2b;border-color:#2e2e2b}.single-style .ss-foot button:disabled{opacity:.35;cursor:not-allowed}.tb-font-menu{min-width:240px}.tb-font-menu .tb-font-label{font-size:15px}.tb-font-menu .tb-menu-item{padding:10px 12px}.tb-style-menu{min-width:300px;padding:10px;right:0;left:auto}.tb-style-menu .style-row{display:flex;align-items:center;gap:10px;padding:6px 2px}.tb-style-menu .style-row label{flex:0 0 68px;font-size:12px;color:var(--muted);font-weight:500}.tb-style-menu .style-row select{height:30px;padding:0 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-2);color:var(--ink);font-size:13px}.tb-style-menu .style-segment{display:inline-flex;gap:2px;background:var(--bg-2);border-radius:6px;padding:3px}.tb-style-menu .style-segment button{min-width:30px;height:26px;border:none;background:transparent;border-radius:4px;color:var(--ink-2);cursor:pointer;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.tb-style-menu .style-segment button:hover{background:var(--surface);color:var(--ink)}.tb-style-menu .style-segment button.active{background:var(--accent-soft);color:var(--accent)}.tb-style-menu .style-swatches{display:grid;grid-template-columns:repeat(9,22px);gap:4px;flex:1}.tb-style-menu .style-swatches .tb-swatch{width:22px!important;height:22px!important;border-radius:5px!important;border:1px solid rgba(255,255,255,.08)!important}.styles-editor-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;display:grid;place-items:center;animation:fade-in .16s var(--ease)}.styles-editor{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:540px;max-width:calc(100vw - 40px);max-height:calc(100vh - 80px);overflow:auto;padding:22px 22px 16px;animation:scale-in .2s var(--ease)}.styles-editor .se-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.styles-editor .se-head h3{font-size:18px;font-weight:600;margin:0}.styles-editor .se-head .icon-btn{font-size:22px;line-height:1;width:32px;height:32px;border-radius:50%;background:transparent;border:none;color:var(--muted);cursor:pointer}.styles-editor .se-head .icon-btn:hover{background:var(--bg-2);color:var(--ink)}.styles-editor .se-hint{font-size:13px;color:var(--muted);margin:4px 0 16px;line-height:1.5}.styles-editor .se-list{list-style:none;padding:0;margin:0}.styles-editor .se-item{padding:12px 0;border-top:1px solid var(--border-soft);display:grid;grid-template-columns:1fr auto;gap:6px 16px;align-items:center}.styles-editor .se-item:first-child{border-top:none}.styles-editor .se-preview{grid-column:1;line-height:1.15;color:var(--ink)}.styles-editor .se-meta{grid-column:1;font-size:11.5px;color:var(--muted-2);font-family:var(--mono);display:flex;align-items:center;gap:8px}.styles-editor .se-badge{font-size:10px;letter-spacing:.08em;text-transform:uppercase;background:var(--accent-soft);color:var(--accent);padding:1px 8px;border-radius:var(--radius-pill);font-family:var(--sans);font-weight:600}.styles-editor .se-actions{grid-column:2;grid-row:1 / span 2;display:flex;flex-direction:column;gap:6px;align-self:center}.styles-editor .se-actions button{font-size:12px;padding:6px 12px;white-space:nowrap;border:1px solid var(--border);background:var(--bg-2);color:var(--ink);border-radius:var(--radius-sm);cursor:pointer}.styles-editor .se-actions button:hover{background:var(--surface);border-color:var(--muted-2)}.styles-editor .se-actions button.ghost{background:transparent;border-color:transparent;color:var(--muted)}.styles-editor .se-actions button.ghost:hover:not(:disabled){background:var(--bg-2);color:var(--ink)}.styles-editor .se-actions button:disabled{opacity:.35;cursor:not-allowed}.styles-editor .se-actions button.danger{color:var(--danger)}.styles-editor .se-item.open{background:var(--bg-2);border-radius:var(--radius-md);padding:12px 14px;margin:6px -6px}.styles-editor .se-editor{grid-column:1 / -1;margin-top:10px;padding-top:12px;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:8px}.styles-editor .se-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.styles-editor .se-row label{flex:0 0 auto;min-width:60px;font-size:11.5px;color:var(--muted);font-weight:500}.styles-editor .se-row select,.styles-editor .se-row input{height:28px;padding:0 8px;background:var(--surface);border:1px solid var(--border);color:var(--ink);border-radius:6px;font-size:12.5px;font-family:var(--sans)}.styles-editor .se-row .se-sep{flex:0 0 10px}.styles-editor .se-row .style-segment{background:var(--surface)}.styles-editor .se-row .style-segment button{min-width:30px;height:26px;border:none;background:transparent;color:var(--ink-2);border-radius:4px;cursor:pointer;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.styles-editor .se-row .style-segment button:hover{background:var(--bg-2);color:var(--ink)}.styles-editor .se-row .style-segment button.active{background:var(--accent-soft);color:var(--accent)}.styles-editor .se-meta{flex-wrap:wrap}.styles-editor .se-foot{display:flex;justify-content:space-between;align-items:center;padding-top:14px;margin-top:10px;border-top:1px solid var(--border-soft)}.styles-editor .se-foot .primary{padding:7px 18px;font-size:13px}.tb-menu-sep{height:1px;background:var(--border-soft);margin:6px 0}.tb-style-menu .tb-case button{font-family:var(--sans);font-size:12.5px;font-weight:500;min-width:36px}.tb-style-menu .style-actions{display:flex;justify-content:flex-end;margin-top:10px;padding-top:8px;border-top:1px solid var(--border-soft)}.tb-style-menu .style-actions .primary{padding:6px 16px;font-size:13px}.gdoc-toolbar .tb-select{font:inherit;height:30px;padding:0 22px 0 10px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--ink);cursor:pointer;font-size:12.5px;font-weight:500;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 10px) 13px,calc(100% - 6px) 13px;background-size:4px 4px,4px 4px;background-repeat:no-repeat}.gdoc-toolbar .tb-select:hover{background-color:var(--bg-2)}.gdoc-toolbar .tb-font{min-width:110px}.gdoc-toolbar .tb-size-select{width:50px;height:24px;text-align:center;padding:0 14px 0 6px;border:1px solid var(--border);font-size:12px}.gdoc-toolbar .tb-size button{min-width:22px;height:22px;background:var(--bg-2);border:1px solid var(--border);padding:0;font-size:12px}.gdoc-toolbar option{background:var(--surface);color:var(--ink)}.gdoc-toolbar .tb-color{position:relative}.gdoc-toolbar .tb-color-btn{flex-direction:column;padding:3px 6px!important;line-height:1;gap:2px;min-width:30px}.gdoc-toolbar .tb-color-label{font-weight:700;font-size:12px}.gdoc-toolbar .tb-color-bar{display:block;width:16px;height:2.5px;border-radius:1px}.gdoc-toolbar .tb-color-pop{position:absolute;top:100%;left:0;margin-top:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px;display:grid;grid-template-columns:repeat(6,22px);gap:6px;box-shadow:var(--shadow-lg);z-index:40;animation:scale-in .12s var(--ease)}.gdoc-toolbar .tb-swatch{width:22px!important;height:22px!important;min-width:22px!important;padding:0!important;border:1px solid var(--border)!important;border-radius:6px!important;cursor:pointer}.gdoc-toolbar .tb-swatch:hover{transform:scale(1.12)}.gdoc-toolbar .tb-swatch.sel{outline:2px solid var(--accent);outline-offset:1px}.bubble-menu{background:#0f0f11;color:#fafaf7;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-pill);padding:4px 6px;display:flex;gap:2px;align-items:center;box-shadow:var(--shadow-lg);font-size:13px;max-width:min(94vw,560px);flex-wrap:nowrap}.bubble-menu button{flex:0 0 auto}.bubble-menu button{font:inherit;min-width:28px;height:28px;padding:0 9px;border:none;background:transparent;color:#ffffffe0;border-radius:var(--radius-pill);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-weight:500;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.bubble-menu button:hover{background:#ffffff1a;color:#fff}.bubble-menu button.active{background:var(--accent);color:#fff}.bubble-menu .bm-size{display:inline-flex;align-items:center;gap:2px;padding:0 2px}.bubble-menu .bm-size .bm-size-val{min-width:22px;text-align:center;font-variant-numeric:tabular-nums;font-size:12px;color:#ffffffd9}.bubble-menu .bm-size .bm-size-step{min-width:22px;height:22px;padding:0;font-size:13px}.bubble-menu.img-bubble{padding:6px 10px;gap:8px}.bubble-menu.img-bubble .ib-row{display:inline-flex;align-items:center;gap:8px}.bubble-menu.img-bubble .ib-label{font-size:11px;color:#fff9;text-transform:uppercase;letter-spacing:.06em}.bubble-menu.img-bubble input[type=range]{width:120px;accent-color:var(--accent);background:transparent;border:none;padding:0}.bubble-menu.img-bubble input[type=range]:focus{box-shadow:none}.bubble-menu.img-bubble .ib-val{min-width:34px;text-align:center;font-variant-numeric:tabular-nums;font-size:12px;color:#ffffffd9}.bubble-menu.img-bubble .ib-align button{min-width:26px;padding:0 6px;font-size:14px}.ProseMirror img{max-width:100%;height:auto;border-radius:4px}.ProseMirror img[data-float=left]{float:left;margin:4px 16px 8px 0}.ProseMirror img[data-float=right]{float:right;margin:4px 0 8px 16px}.ProseMirror img[data-float=center]{display:block;margin:12px auto;float:none}.ProseMirror img.ProseMirror-selectednode{outline:2px solid var(--accent);outline-offset:2px}.people-drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:90;animation:fade-in .14s var(--ease)}.people-drawer{position:fixed;top:0;right:0;bottom:0;width:340px;max-width:100vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:91;display:flex;flex-direction:column;animation:slide-in-right .22s var(--ease);overflow-y:auto}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}.pd-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-soft)}.pd-head h3{margin:0;font-family:var(--serif);font-style:italic;font-weight:400;font-size:22px}.pd-close{width:28px;height:28px;padding:0;border-radius:50%;background:transparent;border:none;color:var(--muted);font-size:18px}.pd-close:hover{background:var(--bg-2);color:var(--ink)}.pd-section{padding:16px 18px;border-bottom:1px solid var(--border-soft)}.pd-section:last-child{border-bottom:none}.pd-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px}.pd-hint{color:var(--muted);font-size:12.5px;margin:0 0 12px;line-height:1.5}.pd-empty{color:var(--muted);font-size:13px;font-style:italic}.pd-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.pd-list li{display:flex;align-items:center;gap:10px;padding:6px 0}.pd-chip{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0}.pd-name{flex:1;font-size:13.5px}.pd-you{color:var(--muted);font-size:12px}.pd-links li{gap:8px}.pd-token{font-family:var(--mono);font-size:11px;color:var(--muted);flex:1}.pd-links button.danger{padding:4px 10px;font-size:12px}.profile-page{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}.profile-card{width:460px;max-width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-md)}.profile-back{font-size:13px;color:var(--muted);display:inline-block;margin-bottom:14px}.profile-card h1{font-family:var(--serif);font-style:italic;font-weight:400;font-size:32px;margin:0 0 6px;letter-spacing:-.02em}.profile-sub{color:var(--muted);font-size:13.5px;margin:0 0 22px}.profile-label{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.profile-card input{width:100%;font-size:15px;padding:10px 14px}.profile-actions{margin-top:18px;display:flex;align-items:center;gap:14px}.profile-actions .primary{padding:10px 22px}.profile-saved{color:var(--success);font-size:13px}.themes-page{display:grid;grid-template-columns:380px 1fr;min-height:100vh;background:var(--bg);color:var(--ink)}.themes-side{padding:22px 22px 32px;border-right:1px solid var(--border);overflow-y:auto;background:var(--surface)}.themes-back{font-size:12px;color:var(--muted);display:inline-block;margin-bottom:14px}.themes-side h1{font-family:var(--serif);font-style:italic;font-weight:400;font-size:28px;margin:0 0 4px;letter-spacing:-.02em}.themes-sub{color:var(--muted);font-size:12.5px;margin:0 0 18px;line-height:1.5}.themes-section-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:20px 0 10px}.themes-presets{display:grid;grid-template-columns:1fr 1fr;gap:8px}.theme-preset{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:8px 10px;background:var(--bg-2);border:1px solid var(--border-soft);border-radius:var(--radius-md);cursor:pointer;text-align:left}.theme-preset:hover{border-color:var(--muted-2)}.theme-preset.active{border-color:var(--accent)}.tp-swatches{display:inline-flex;gap:3px}.tp-swatches span{width:14px;height:14px;border-radius:50%;display:inline-block;border:1px solid rgba(255,255,255,.08)}.tp-name{font-size:12px;color:var(--ink-2)}.themes-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.themes-row-label{font-size:12px;color:var(--ink-2);flex:1}.themes-row input[type=color]{width:32px;height:24px;padding:0;border:1px solid var(--border);background:transparent}.themes-row input[type=range]{flex:2;accent-color:var(--accent)}.themes-row select{flex:2;height:26px;padding:0 6px;font-size:12px}.themes-hex{width:80px;height:24px;padding:0 6px;font-size:11px;font-family:var(--mono)}.themes-color-row{gap:8px}.themes-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-soft)}.themes-saved{color:var(--success);font-size:12px;font-weight:500;margin-right:auto;animation:fade-in .2s var(--ease)}.themes-dirty{color:var(--muted);font-size:12px;font-style:italic;margin-right:auto}.themes-preview{padding:36px;overflow-y:auto;display:grid;place-items:start center}.theme-preview-card{width:100%;max-width:720px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);box-shadow:var(--shadow-md)}.tpc-chrome{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--bg-2);border-bottom:1px solid var(--border-soft)}.tpc-dot{width:10px;height:10px;border-radius:50%;background:var(--muted-2)}.tpc-title{margin-left:10px;font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.tpc-page{padding:40px 48px;background:var(--surface);color:var(--ink);font-family:var(--sans);line-height:1.6}.tpc-page h1{font-family:var(--serif);font-style:italic;font-weight:400;font-size:2.2em;margin:0 0 6px;letter-spacing:-.02em}.tpc-page h2{font-family:var(--sans);font-weight:600;font-size:1.3em;color:var(--muted);margin:0 0 20px}.tpc-page h3{font-weight:600;font-size:1.05em;margin:20px 0 8px}.tpc-page p{margin:0 0 12px}.tpc-page blockquote{margin:14px 0;padding:8px 16px;border-left:3px solid var(--accent);color:var(--muted);font-family:var(--serif);font-style:italic;font-size:1.05em}.tpc-page ul{padding-left:1.3em;margin:0 0 12px}.tpc-page code{font-family:var(--mono);font-size:.88em;background:var(--bg-2);padding:1px 6px;border-radius:4px;color:var(--accent-ink)}.tpc-page pre{background:#0f0f11;color:#e4e2dc;padding:14px 18px;border-radius:var(--radius-md);overflow-x:auto;font-family:var(--mono);font-size:.88em;border:1px solid var(--border)}.tpc-page pre code{background:transparent;color:inherit;padding:0}.tpc-page a{color:var(--accent-ink);border-bottom:1px solid rgba(217,119,87,.4)}.tpc-byline{color:var(--muted);font-style:italic;font-family:var(--serif);margin-top:20px;font-size:.92em}@media (max-width: 900px){.themes-page{grid-template-columns:1fr}.themes-side{border-right:none;border-bottom:1px solid var(--border)}}.rev-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.rev-item{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:2px 10px;padding:10px 0;border-bottom:1px solid var(--border-soft)}.rev-when{font-size:13px;font-weight:600;color:var(--ink)}.rev-authors{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:4px}.rev-author{font-size:11px;padding:2px 8px;background:var(--accent-soft);color:var(--accent);border-radius:999px}.rev-anon{font-size:11px;color:var(--muted);font-style:italic}.rev-meta{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}.rev-restore{grid-row:1;grid-column:2;padding:4px 12px;font-size:12px;background:var(--ink);color:#141416;border-color:var(--ink)}.rev-restore:hover:not(:disabled){background:#fafaf7;color:#141416;border-color:#fafaf7}.rev-group-head{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:14px 0 6px}.rev-named{margin-bottom:14px}.rev-session{border-bottom:1px solid var(--border-soft)}.rev-session-head{width:100%;display:flex;align-items:center;gap:8px;padding:10px 0;background:transparent;border:none;color:var(--ink);text-align:left;cursor:pointer}.rev-session-head:hover{color:var(--accent)}.rev-caret{width:12px;color:var(--muted);font-size:10px}.rev-session-head .rev-when{flex:0 0 auto}.rev-session-head .rev-authors{flex:1 1 auto;grid-column:auto}.rev-session-head .rev-count{font-size:11px;color:var(--muted);padding:2px 8px;background:var(--surface-2, rgba(255,255,255,.04));border-radius:999px}.rev-list-nested{padding-left:18px;border-left:2px solid var(--border-soft);margin-left:4px}.rev-main{grid-row:1;grid-column:1;background:transparent;border:none;padding:0;text-align:left;cursor:pointer;color:inherit;display:block}.rev-main:hover .rev-when{color:var(--accent)}.rev-label{font-size:12px;font-weight:600;color:var(--accent);margin-top:2px}.rev-actions{grid-row:1;grid-column:2;display:flex;gap:4px}.rev-actions button{padding:3px 8px;font-size:11px;border-radius:4px}.rev-label-edit{grid-column:1 / -1;display:flex;gap:4px;margin-top:6px}.rev-label-edit input{flex:1;padding:4px 8px;font-size:12px;background:var(--surface);border:1px solid var(--border);color:var(--ink);border-radius:4px}.rev-label-edit button{padding:4px 10px;font-size:11px}.diff-preview{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:90;display:flex;flex-direction:column;overflow:auto}.diff-banner{position:sticky;top:0;z-index:2;display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 2px 8px #00000026}.diff-banner-title{font-size:13px;font-weight:600;color:var(--ink)}.diff-banner-controls{margin-left:auto;display:flex;align-items:center;gap:8px}.diff-banner-controls button{padding:5px 12px;font-size:12px}.diff-banner-controls .diff-restore{background:var(--accent);color:#141416;border-color:var(--accent)}.diff-base-toggle{font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}.diff-base-toggle select{padding:4px 8px;font-size:12px;background:var(--surface);color:var(--ink);border:1px solid var(--border);border-radius:4px}.diff-legend{display:flex;flex-wrap:wrap;gap:12px;padding:8px 20px;background:var(--surface);border-bottom:1px solid var(--border-soft);font-size:11px;color:var(--muted)}.diff-legend-item{display:inline-flex;align-items:center;gap:6px}.diff-legend-dot{width:10px;height:10px;border-radius:2px;display:inline-block}.diff-page{flex:1;padding:32px 20px;display:flex;justify-content:center}.diff-page .editor-page{width:100%;max-width:816px;min-height:400px}.diff-preview ins.diff-ins{text-decoration:none;background:color-mix(in srgb,var(--diff-color, #4aa3ff) 12%,transparent);border-bottom:2px solid var(--diff-color, #4aa3ff);padding-bottom:1px}.diff-preview del.diff-del{text-decoration:line-through;color:color-mix(in srgb,var(--diff-color, #888) 70%,var(--muted));opacity:.75}.focus-toggle{font-size:11px;font-weight:600;letter-spacing:.04em;padding:4px 10px;border-radius:var(--radius-pill);background:transparent;border:1px solid var(--border);color:var(--muted)}.focus-toggle:hover{color:var(--ink);border-color:var(--muted-2)}.focus-toggle.active{background:var(--accent);color:#141416;border-color:var(--accent)}body.focus-mode .doc-header,body.focus-mode .menu-bar,body.focus-mode .gdoc-toolbar,body.focus-mode .comments-dock-header,body.focus-mode .comments-rail,body.focus-mode .width-control,body.focus-mode .comments-dock{display:none!important}body.focus-mode .doc-main{background:var(--bg)}body.focus-mode .editor-wrap{padding:0;background:var(--bg)}body.focus-mode .editor-page{padding:80px max(24px,6vw);background:var(--bg)!important;border:none!important;border-radius:0!important;box-shadow:none!important;max-width:100%!important;width:100%!important}body.focus-mode .editor-page .ProseMirror{zoom:1.8;max-width:900px;margin:0 auto}.focus-exit{position:fixed;top:14px;right:16px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);z-index:60;cursor:pointer;opacity:1;transition:opacity 1.2s var(--ease)}.focus-exit.faded{opacity:.08}.focus-exit.faded:hover{opacity:1}.focus-exit:hover{background:var(--bg-2);color:var(--ink)}.bubble-menu .sep{width:1px;height:16px;background:#ffffff1f;margin:0 3px}.bm-style{position:relative}.bm-style-trigger{font:inherit;height:28px;padding:0 10px!important;display:inline-flex!important;align-items:center;gap:6px;font-size:12.5px;color:#ffffffe6;border:none;background:transparent;border-radius:999px;cursor:pointer;min-width:auto!important}.bm-style-trigger:hover{background:#ffffff1a}.bm-style-menu{position:absolute;top:calc(100% + 6px);left:0;background:#0f0f11;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:6px;min-width:180px;box-shadow:var(--shadow-lg);z-index:50;animation:scale-in .12s var(--ease)}.bm-style-item{display:flex!important;align-items:center;justify-content:space-between;width:100%;padding:7px 10px!important;border:none;background:transparent;color:#ffffffe6;border-radius:6px;cursor:pointer;text-align:left;min-width:auto!important;height:auto!important}.bm-style-item:hover{background:#ffffff14;color:#fff}.bm-style-item .tb-active-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);margin-left:10px}.editor-wrap{flex:1;overflow:auto;padding:0 24px 80px;background:var(--surface-2);position:relative}.editor-grid{position:relative;width:816px;max-width:100%;margin:0 auto;padding-right:0}.editor-page{position:relative;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:96px;width:816px;min-height:1056px;max-width:100%;box-shadow:var(--shadow-sm)}.comments-dock{position:absolute;top:0;left:calc(100% + 20px);width:320px;height:100%;min-height:100%;pointer-events:none}.comments-dock>*{pointer-events:auto}.comments-dock-header{position:absolute;top:-28px;left:calc(100% + 20px);width:320px;padding:0 8px 6px;display:flex;justify-content:space-between;align-items:center;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);font-weight:600}.comments-dock-header button{background:transparent;border:none;color:var(--muted);font-size:18px;width:24px;height:24px;border-radius:50%;padding:0;cursor:pointer;line-height:1}.comments-dock-header button:hover{background:var(--bg-2);color:var(--ink)}.comments-dock .cc-err{color:var(--danger);font-size:12px;padding:8px 12px;background:#3a1d1d;border-radius:var(--radius-sm)}.comments-dock .comment-card{max-width:100%;transition:top .32s cubic-bezier(.25,1,.32,1),box-shadow var(--dur) var(--ease);will-change:top}.comments-dock .comment-card.active{border-color:var(--accent);box-shadow:0 0 0 3px #e890712e,var(--shadow-md);z-index:5}.comment-actions{margin-left:auto;display:flex;gap:2px;align-items:center}.icon-btn{background:transparent;border:none;padding:4px;border-radius:6px;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.icon-btn:hover{background:var(--bg-2);color:var(--ink)}.icon-btn.danger:hover{background:#3a1d1d;color:var(--danger)}.comments-column .cc-head{display:flex;align-items:center;justify-content:space-between;padding:6px 2px 4px}.comments-column .cc-head .label{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.comments-column .cc-head button{padding:3px 8px;font-size:11.5px;background:transparent;border:none;color:var(--muted);border-radius:var(--radius-sm)}.comments-column .cc-head button:hover{background:var(--bg-2);color:var(--ink)}.comments-column .cc-empty{color:var(--muted);font-size:12.5px;padding:18px 4px;font-style:italic;font-family:var(--serif)}.comments-rail{position:fixed;right:26px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:8px;z-index:6}.comments-rail .tab{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:8px 10px;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2);cursor:pointer;box-shadow:var(--shadow-sm);transition:transform var(--dur) var(--ease)}.comments-rail .tab:hover{transform:translate(-3px);color:var(--ink)}.comments-rail .tab .count{font-family:var(--mono);background:var(--accent);color:#fff;font-size:10px;padding:1px 7px;border-radius:var(--radius-pill);font-weight:600}.ProseMirror{outline:none;min-height:100%;font-family:var(--sans);font-size:var(--editor-base-size, 15px);line-height:1.65;color:var(--ink);text-align:left;font-synthesis:style weight;-webkit-font-synthesis:style weight}.ProseMirror h1,.ProseMirror h2,.ProseMirror h3,.ProseMirror p{text-align:left}.ProseMirror em,.ProseMirror i{font-style:italic}.ProseMirror h1{font-family:var(--sans);font-style:normal;font-weight:700;font-size:32px;letter-spacing:-.02em;margin:28px 0 10px;line-height:1.2}.ProseMirror h2{font-family:var(--sans);font-weight:600;font-size:22px;letter-spacing:-.015em;margin:22px 0 8px;line-height:1.25}.ProseMirror h3{font-family:var(--sans);font-weight:600;font-size:17px;letter-spacing:-.01em;margin:18px 0 6px;line-height:1.3}.ProseMirror strong,.ProseMirror b{font-weight:700}.ProseMirror p{margin:0 0 10px}.ProseMirror blockquote{border-left:3px solid var(--accent);margin:14px 0;padding:2px 0 2px 16px;color:var(--ink-2);font-family:var(--serif);font-style:italic;font-size:17px}.ProseMirror code{font-family:var(--mono);font-size:.88em;background:var(--bg-2);padding:1.5px 6px;border-radius:4px;color:var(--accent-ink)}.ProseMirror pre{background:#0f0f11;color:#e4e2dc;padding:14px 18px;border-radius:var(--radius-md);overflow-x:auto;font-family:var(--mono);font-size:.88em;margin:14px 0;border:1px solid var(--border)}.ProseMirror pre code{background:transparent;color:inherit;padding:0}.ProseMirror a{color:var(--accent-ink);border-bottom:1px solid rgba(217,119,87,.4)}.ProseMirror a:hover{border-bottom-color:var(--accent-ink)}.ProseMirror ul,.ProseMirror ol{padding-left:1.5em;margin:0 0 10px}.ProseMirror hr{border:none;border-top:1px solid var(--border);margin:1.5em 0}.ProseMirror ul[data-type=taskList]{list-style:none;padding-left:0}.ProseMirror ul[data-type=taskList] li{display:flex;align-items:flex-start;gap:8px;padding:2px 0}.ProseMirror ul[data-type=taskList] li>label{flex:0 0 auto;padding-top:3px}.ProseMirror ul[data-type=taskList] li>div{flex:1}.ProseMirror ul[data-type=taskList] input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--accent)}.ProseMirror ul[data-type=taskList] li[data-checked=true]>div{color:var(--muted);text-decoration:line-through}.ProseMirror sup{font-size:.72em;vertical-align:super;line-height:0}.ProseMirror sub{font-size:.72em;vertical-align:sub;line-height:0}.ProseMirror .comment-mark{cursor:pointer}.ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--muted-2);float:left;height:0;pointer-events:none}.ProseMirror .comment-mark{background:var(--highlight);border-radius:2px;padding:0 1px;cursor:pointer;transition:background var(--dur) var(--ease)}.ProseMirror .comment-mark:hover{background:#ffe872}.ProseMirror img{max-width:100%;height:auto;border-radius:var(--radius-sm)}.collaboration-cursor__caret{border-left:1.5px solid currentColor;border-right:1.5px solid currentColor;margin-left:-1px;margin-right:-1px;pointer-events:none;position:relative;word-break:normal}.collaboration-cursor__label{font-family:var(--sans);font-size:10.5px;font-weight:500;color:#fff;padding:2px 7px;border-radius:var(--radius-pill);position:absolute;top:-1.7em;left:-2px;white-space:nowrap}.sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;min-width:0}.presence-bar{padding:14px 18px;border-bottom:1px solid var(--border-soft);display:flex;flex-direction:column;gap:8px;background:var(--surface)}.presence-bar-label{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.presence-chips{display:flex;gap:-6px;flex-wrap:wrap;align-items:center}.presence-chip{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:12px;box-shadow:0 0 0 2px var(--surface);margin-left:-6px;transition:transform var(--dur) var(--ease)}.presence-chips .presence-chip:first-child{margin-left:0}.presence-chip:hover{transform:translateY(-2px);z-index:1}.comments-panel{position:relative;min-height:60vh}.add-comment-fab{position:sticky;top:8px;z-index:2;width:100%;background:var(--accent);color:#fff;border:none;padding:8px 12px;border-radius:var(--radius-pill);font-weight:600;font-size:12.5px;box-shadow:var(--shadow-md);margin-bottom:10px;cursor:pointer}.add-comment-fab:hover{background:#d27e60}.comment-card{position:absolute;left:0;width:100%;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:12px 14px 10px;box-shadow:var(--shadow-sm);transition:top .22s var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);font-size:13px}.comment-card:hover{border-color:var(--border);box-shadow:var(--shadow-md)}.comment-card.thread.resolved{opacity:.55}.comment-card.comment-composer{border-color:var(--accent);box-shadow:0 0 0 3px #e890711f,var(--shadow-md)}.cc-quote{font-size:11.5px;color:var(--muted);font-style:italic;border-left:2px solid var(--accent);padding:2px 0 2px 8px;margin-bottom:10px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.comment-head{display:flex;align-items:center;gap:9px;margin-bottom:6px}.comment-head .avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600;font-size:11px;font-family:var(--sans);letter-spacing:.02em;flex:none;box-shadow:inset 0 0 0 1px #ffffff14}.comment-head>div{flex:1;min-width:0;line-height:1.15}.comment-head .author{font-size:12.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.comment-head .timestamp{font-size:11px;color:var(--muted-2)}.comment-head .thread-resolve{background:transparent;border:1px solid var(--border);border-radius:50%;width:24px;height:24px;padding:0;color:var(--muted);font-size:13px;cursor:pointer;display:grid;place-items:center;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease)}.comment-head .thread-resolve:hover{background:var(--success);border-color:var(--success);color:#fff}.comment{font-size:13px;line-height:1.5}.comment.reply{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-soft)}.comment .body{white-space:pre-wrap;color:var(--ink-2);padding-left:37px;word-wrap:break-word}.comment-composer textarea,.thread .reply-box textarea{width:100%;min-height:56px;font-size:13px;padding:8px 10px;resize:vertical;font-family:var(--sans);border:1px solid var(--border);background:var(--bg-2);border-radius:var(--radius-sm);color:var(--ink)}.comment-composer textarea:focus,.thread .reply-box textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e8907124;background:var(--bg)}.thread-footer{margin-top:10px;padding-top:8px;border-top:1px solid var(--border-soft)}.reply-trigger{width:100%;text-align:left;padding:7px 12px;background:var(--bg-2);border:1px solid transparent;border-radius:var(--radius-pill);color:var(--muted);font-size:12px;cursor:pointer;font-style:italic}.reply-trigger:hover{background:var(--surface-2);border-color:var(--border);color:var(--ink-2)}.reply-box{display:flex;flex-direction:column;gap:8px}.cc-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:8px}.cc-actions button{padding:5px 14px;font-size:12.5px;font-weight:500}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1c1a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:100;animation:fade-in .16s var(--ease)}.modal{background:var(--surface);border-radius:var(--radius-lg);padding:28px;width:420px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);animation:scale-in .2s var(--ease)}.modal h2{font-family:var(--serif);font-style:italic;font-weight:400;font-size:28px;letter-spacing:-.02em;margin:0 0 6px}.modal p{color:var(--muted);font-size:13.5px;margin:0 0 18px}.modal input{width:100%;font-size:15px}.modal form button{margin-top:12px;width:100%;padding:10px}.modal .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.modal .modal-actions button{width:auto;margin:0;padding:8px 18px;min-width:92px}.modal button.danger-solid{background:var(--danger, #d14343);color:#fff;border-color:transparent}.modal button.danger-solid:hover{filter:brightness(1.08)}.state{padding:3rem;text-align:center;color:var(--muted);font-style:italic;font-family:var(--serif);font-size:18px}@media (max-width: 900px){.app{grid-template-columns:1fr;padding:10px;gap:10px}.nav{display:none}.doc-layout{grid-template-columns:1fr}.sidebar{display:none}.editor-page{padding:32px 24px}.gdoc-toolbar{left:14px;right:14px;transform:none;max-width:calc(100% - 28px)}}.doc-thumb-page .tb-h1{font-size:6px;font-weight:700;line-height:1.15;margin:0 0 2px;color:var(--ink)}.doc-thumb-page .tb-h2{font-size:5.2px;font-weight:600;line-height:1.2;margin:2px 0 1px;color:var(--ink)}.doc-thumb-page .tb-h3{font-size:4.8px;font-weight:600;line-height:1.2;margin:2px 0 1px;color:var(--ink-2, var(--ink))}.doc-thumb-page .tb-li{font-size:4.4px;line-height:1.3;margin:0 0 1px;padding-left:2px;color:var(--ink-2, var(--ink))}.doc-thumb-page .tb-q{font-size:4.4px;line-height:1.3;margin:2px 0;padding-left:3px;border-left:1px solid var(--border);font-style:italic;color:var(--muted)}.doc-thumb-page .tb-code{font-family:var(--mono);font-size:4px;background:var(--bg-2);padding:1px 2px;border-radius:2px;margin:1px 0;color:var(--ink-2, var(--ink));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-card-new.compact{min-height:0;aspect-ratio:auto;padding:18px;align-items:center;justify-content:center;display:flex;flex-direction:column}.doc-card-new.compact .plus{font-size:28px}.name-modal .name-modal-context{padding:12px 14px;background:var(--bg-2);border-radius:var(--radius-sm);margin-bottom:18px;display:flex;flex-direction:column;gap:4px}.name-modal .name-modal-eyebrow{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:500}.name-modal .name-modal-title{font-size:17px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.name-modal .name-modal-context .perm-badge{align-self:flex-start;margin-top:2px}.name-modal .modal-actions .ghost{text-decoration:none;display:inline-flex;align-items:center;padding:8px 18px}.doc-error-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.doc-error-card{max-width:480px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 30px;box-shadow:var(--shadow-sm)}.doc-error-card h1{margin:0 0 6px;font-size:22px;letter-spacing:-.01em}.doc-error-card p{color:var(--muted);margin:0 0 14px}.doc-error-card .doc-error-detail{font-family:var(--mono);font-size:12px;background:var(--bg-2);padding:8px 10px;border-radius:var(--radius-sm);color:var(--muted);word-break:break-word}.doc-error-actions{margin-top:20px}.doc-error-actions .primary{text-decoration:none;display:inline-block;padding:9px 18px}.settings-card{max-width:560px;background:var(--bg-2);border:1px solid var(--border-soft);border-radius:var(--radius-lg);padding:24px 26px;margin-top:8px}.settings-title{margin:0 0 6px;font-size:18px;font-weight:600;letter-spacing:-.01em}.settings-sub{margin:0 0 18px;color:var(--muted);font-size:13.5px}.profile-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px;font-weight:500}.profile-hint{font-size:12px;color:var(--muted);margin-top:6px}.profile-err{font-size:12px;color:var(--danger, #d24b4b);margin-top:6px}.profile-actions{display:flex;align-items:center;gap:12px;margin-top:16px}.profile-saved{font-size:13px;color:var(--muted);min-width:70px}.themes-main .themes-body{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:24px;align-items:start}.themes-controls{display:flex;flex-direction:column;gap:4px}.themes-hex.invalid{border-color:var(--danger, #d24b4b)}.themes-hex-err{font-size:11px;color:var(--danger, #d24b4b);grid-column:2 / -1}.row-menu button,.search-clear{min-width:28px;min-height:28px;display:inline-flex;align-items:center;justify-content:center}@media (max-width: 860px){.app{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:auto;min-height:100vh;padding:10px;gap:10px}.nav{padding:10px 12px;flex-direction:row;flex-wrap:wrap;gap:8px;align-items:center}.nav-brand{padding:0;border-bottom:none;margin:0 8px 0 0}.nav-brand-logo{max-width:80px}.nav-section-label{display:none}.nav-item{width:auto;flex:0 0 auto;padding:6px 10px;font-size:12.5px}.nav-item .count{margin-left:6px}.nav-footer{width:100%;margin-top:0;padding-top:8px;border-top:1px solid var(--border-soft);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.nav-footer .nav-section-label{display:none}.nav-footer .primary{margin:0 0 0 auto!important;width:auto!important;padding:8px 14px}.main{min-width:0}.main-header{flex-wrap:wrap;padding:12px 14px;gap:8px}.main-header h1{font-size:16px}.search{max-width:none;flex:1 1 100%;order:10}.main-body{padding:14px 14px 24px}.page-title{flex-direction:column;align-items:stretch}.page-title-actions{display:flex}.page-title-actions .primary{width:100%;padding:10px}.doc-grid{grid-template-columns:1fr;gap:12px}.doc-card{min-height:auto}.themes-main .themes-body{grid-template-columns:1fr}.themes-preview{order:-1}.name-modal,.modal{max-width:calc(100vw - 28px)}.row-menu button,.search-clear,.row-actions button{min-width:36px;min-height:36px}}.admin-page{max-width:1080px;margin:0 auto;padding:32px 24px 64px;color:var(--text, #e6e6ea)}.admin-page h1{font-size:22px;font-weight:600;margin:0 0 18px}.admin-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border, #2a2a32);margin-bottom:18px}.admin-tabs button{background:transparent;border:none;color:var(--muted, #9a9aa3);padding:8px 14px;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.admin-tabs button.active{color:var(--text, #e6e6ea);border-bottom-color:var(--accent, #6c8cff)}.admin-tabs button:hover{color:var(--text, #e6e6ea)}.admin-create{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap;color:var(--muted, #9a9aa3);font-size:13px}.admin-create input{background:var(--surface-2, #1a1a22);border:1px solid var(--border, #2a2a32);color:var(--text, #e6e6ea);border-radius:6px;padding:7px 10px;font-size:13px}.admin-create input[type=number]{width:72px}.admin-create .primary{background:var(--accent, #6c8cff);color:#fff;border:none;border-radius:6px;padding:7px 14px;font-size:13px;cursor:pointer}.admin-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface, #131319);border:1px solid var(--border, #2a2a32);border-radius:8px;overflow:hidden}.admin-table th,.admin-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border, #2a2a32);vertical-align:middle}.admin-table th{background:var(--surface-2, #1a1a22);font-weight:500;color:var(--muted, #9a9aa3);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.admin-table tr:last-child td{border-bottom:none}.admin-table button{background:var(--surface-2, #1a1a22);color:var(--text, #e6e6ea);border:1px solid var(--border, #2a2a32);border-radius:5px;padding:5px 10px;font-size:12px;cursor:pointer}.admin-table button:hover{background:var(--surface-3, #22222c)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px;background:var(--bg)}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border-soft);border-radius:16px;padding:32px 28px 28px;box-shadow:0 12px 40px #00000059;display:flex;flex-direction:column;gap:14px}.auth-brand{display:flex;justify-content:center;margin:4px 0 8px}.auth-brand img{width:56px;height:auto;filter:brightness(0) invert(1);opacity:.92}.auth-card h1{margin:0;font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--ink);text-align:center}.auth-sub{margin:-4px 0 8px;text-align:center;font-size:13.5px;color:var(--muted)}.auth-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.auth-field>span{display:flex;justify-content:space-between;align-items:baseline}.auth-field>span em{font-style:normal;font-size:11.5px;color:var(--muted);opacity:.7}.auth-field input{background:var(--bg);color:var(--ink);border:1px solid var(--border-soft);border-radius:10px;padding:10px 12px;font-size:14px;outline:none;transition:border-color .12s ease,box-shadow .12s ease}.auth-field input:focus{border-color:var(--accent, #f7a072);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent, #f7a072) 22%,transparent)}.auth-field input:disabled{opacity:.6;cursor:not-allowed}.auth-err{background:color-mix(in srgb,#ef4444 16%,transparent);color:#ffb4b4;border:1px solid color-mix(in srgb,#ef4444 34%,transparent);border-radius:8px;padding:8px 12px;font-size:13px}.auth-submit{margin-top:6px;padding:11px 16px;font-size:14.5px;font-weight:600;border-radius:10px}.auth-link{display:inline-block;margin-top:6px;text-align:center;color:var(--accent, #f7a072);text-decoration:none;font-size:13.5px}.auth-link:hover{text-decoration:underline}.wc-modal{max-width:360px}.wc-modal h2{margin-bottom:4px}.wc-scope{margin:0 0 14px;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.wc-grid{display:grid;grid-template-columns:1fr;gap:8px;margin:0 0 16px}.wc-grid>div{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--border-soft);padding:8px 2px}.wc-grid>div:last-child{border-bottom:none}.wc-grid dt{font-size:13px;color:var(--muted);margin:0;display:flex;gap:6px;align-items:baseline}.wc-grid dt em{font-style:normal;font-size:11px;opacity:.6}.wc-grid dd{margin:0;font-size:18px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
