:root,[data-theme=dark]{--bg: #0e0e0e;--card: #1a1a1a;--field: #141414;--fg: #f2f2f2;--muted: #9a9a9a;--border: #2c2c2c;--accent: #f2f2f2;--accent-fg: #0e0e0e;--danger: #c9c9c9;--danger-border: #6a6a6a}[data-theme=light]{--bg: #ffffff;--card: #f6f6f6;--field: #ffffff;--fg: #111111;--muted: #666666;--border: #dcdcdc;--accent: #111111;--accent-fg: #ffffff;--danger: #444444;--danger-border: #999999}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--fg);font:16px/1.5 system-ui,-apple-system,sans-serif}.app{max-width:680px;margin:0 auto;padding:0 16px 64px}.topbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;padding:16px 0;border-bottom:1px solid var(--border);margin-bottom:24px}.brand{font-weight:700;font-size:20px;color:var(--fg);text-decoration:none}nav{display:flex;gap:12px;align-items:center;flex-wrap:wrap}nav a{color:var(--fg);text-decoration:none}nav a:hover{text-decoration:underline}.subnav{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.subnav a{color:var(--muted);text-decoration:none;padding:10px 14px;min-height:44px;display:inline-flex;align-items:center;border-bottom:2px solid transparent;margin-bottom:-1px}.subnav a.active{color:var(--fg);border-bottom-color:var(--fg);font-weight:600}h1,h2{margin:0 0 8px}h3{margin:0}.muted{color:var(--muted)}.error{color:var(--fg);font-weight:600}.stack{display:flex;flex-direction:column;gap:16px}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.row.between{justify-content:space-between}.card,.block{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px}.block{position:relative}.block.editing{border-color:var(--muted)}.block-grid{display:grid;grid-template-columns:repeat(var(--cols, 12),minmax(0,1fr));grid-auto-rows:var(--row-h, 48px);grid-auto-flow:row;gap:12px}.grid-cell{position:relative;min-width:0;background:var(--card);border:1px solid var(--border);border-radius:10px}.grid-cell-image{overflow:hidden}.grid-cell-inner{min-width:0}.grid-cell .block{background:transparent;border:0;border-radius:0}.grid-cell .block-image{position:absolute;top:0;right:0;bottom:0;left:0;padding:0}.drag-handle{position:absolute;top:8px;left:8px;width:28px;height:28px;min-height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:var(--card);color:var(--muted);border:1px solid var(--border);border-radius:8px;cursor:grab;touch-action:none;opacity:0;transition:opacity .12s ease}.grid-cell:hover .drag-handle,.drag-handle:focus-visible{opacity:1}.drag-handle:active{cursor:grabbing}.resize-handle{position:absolute;top:0;right:0;width:18px;height:100%;cursor:ew-resize;touch-action:none;z-index:2}.resize-handle:after{content:"";position:absolute;top:50%;right:4px;width:6px;height:44px;max-height:55%;transform:translateY(-50%);border-radius:999px;background:var(--card);border:1px solid var(--border);box-shadow:0 1px 4px #00000059;opacity:0;transition:opacity .12s ease}.grid-cell:hover .resize-handle:after,.resize-handle:active:after{opacity:1}.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px}.block-head{display:flex;gap:8px;align-items:center}.block-actions{position:absolute;top:12px;right:12px}.badge{font-size:12px;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:1px 8px}.body{white-space:pre-wrap}.body.markdown{white-space:normal}.body.markdown>:first-child{margin-top:0}.body.markdown>:last-child{margin-bottom:0}.body.markdown pre,.body.markdown code{background:var(--field);border-radius:6px}.body.markdown pre{padding:10px 12px;overflow-x:auto}.body.markdown code{padding:1px 4px}.body.markdown pre code{padding:0}label{display:flex;flex-direction:column;gap:4px;font-size:14px;color:var(--muted)}input,textarea,select{background:var(--field);color:var(--fg);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font:inherit;width:100%}textarea{min-height:80px;resize:vertical}button{background:var(--accent);color:var(--accent-fg);border:none;border-radius:8px;padding:8px 14px;font:inherit;font-weight:600;cursor:pointer;white-space:nowrap;min-height:44px}button.link{background:none;color:var(--fg);padding:0;font-weight:500;min-height:auto}button.danger{background:transparent;color:var(--danger);border:1px solid var(--danger-border)}.icon-btn{background:transparent;color:var(--muted);border:none;border-radius:8px;padding:0;width:44px;height:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.icon-btn:hover{color:var(--fg);background:var(--field)}.add-block{width:100%;min-height:48px;background:transparent;color:var(--muted);border:1px dashed var(--border);border-radius:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.add-block:hover{color:var(--fg);border-color:var(--muted)}.image-frame{display:block;padding:0;width:100%;height:100%;background:var(--field);border:none;border-radius:0;overflow:hidden;cursor:zoom-in}.image-frame img{width:100%;height:100%;object-fit:cover;display:block}.block-image time{position:absolute;left:0;right:0;bottom:0;margin:0;padding:16px 12px 8px;font-size:12px;color:#fff;background:linear-gradient(transparent,#0009);pointer-events:none}.image-slot{display:flex;flex-direction:column;gap:6px;width:100%}.image-slot-img{width:100%;object-fit:cover;background:var(--field);border:1px solid var(--border);border-radius:8px}.lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#000000d9;cursor:zoom-out;border:none}.lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}.add-image{width:100%;aspect-ratio:3 / 2;min-height:0;background:transparent;color:var(--muted);border:1px dashed var(--border);border-radius:8px;font-weight:600}.add-image:hover{color:var(--fg);border-color:var(--muted)}.seg{flex-direction:row;align-items:center;gap:6px;color:var(--fg);cursor:pointer}.seg input{width:auto}@media (max-width: 480px){.app{padding:0 12px 48px}}
