:root{--bg: #f6efe2;--bg-grain: #ece2cd;--ink: #2a2017;--ink-soft: #6b5b46;--accent: #7a4a2b;--accent-soft: #b88a64;--card: #fbf5e8;--card-edge: #d8c9a8;--danger: #b53b1b;--success: #2c7a4c;--star: #d09a3c}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--ink);text-wrap:pretty}body{background:radial-gradient(1200px 600px at 20% -10%,#f8f0db 0%,transparent 60%),radial-gradient(1000px 500px at 110% 110%,#efe3c6 0%,transparent 55%),var(--bg);background-attachment:fixed}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;font:inherit}textarea{font-family:inherit}.app{max-width:1400px;margin:0 auto;padding:28px 28px 48px}.app__main{display:grid;grid-template-columns:minmax(280px,400px) 1fr;gap:28px;align-items:stretch}@media (max-width: 880px){.app__main{grid-template-columns:1fr;gap:20px}.app{padding:20px 16px 40px}}.app__left{display:flex;flex-direction:column;gap:18px;min-width:0}.app__header{padding:4px 4px 0}.app__title{font-family:Crimson Pro,Georgia,serif;font-weight:700;font-size:38px;letter-spacing:-.01em;margin:0 0 6px}.app__subtitle{color:var(--ink-soft);font-size:15px;margin:0;line-height:1.5}.panel{background:var(--card);border:1px solid var(--card-edge);border-radius:14px;padding:22px;box-shadow:0 6px 24px #3c1e0a0f}.panel__title{font-family:Crimson Pro,Georgia,serif;font-size:20px;margin:0 0 12px}.input__textarea{width:100%;min-height:220px;resize:vertical;padding:12px 14px;border-radius:10px;border:1px solid var(--card-edge);background:#fffaee;color:var(--ink);font-size:15px;line-height:1.5;outline:none;transition:border-color .16s ease,box-shadow .16s ease}.input__textarea:focus{border-color:var(--accent-soft);box-shadow:0 0 0 3px #b88a6438}.input__row{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:10px;flex-wrap:wrap}.input__count{color:var(--ink-soft);font-size:13px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:999px;font-weight:600;font-size:14px;letter-spacing:.01em;background:var(--accent);color:#fdf7e7;transition:transform .12s ease,background .16s ease,box-shadow .16s ease;box-shadow:0 2px #5c331a,0 8px 20px #7a4a2b40}.btn:hover{background:#8a5532}.btn:active{transform:translateY(1px);box-shadow:0 1px #5c331a,0 4px 12px #7a4a2b40}.btn:disabled{background:#cbb89a;box-shadow:none;cursor:not-allowed;color:#fdf7e7}.rejects{margin-top:12px;background:#fbeee5;color:#7a3b1c;border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.45}.board-panel{display:flex;flex-direction:column;gap:16px;min-height:0}@media (min-width: 881px){.board-panel{position:sticky;top:24px;height:calc(100vh - 56px)}}.board-stage{position:relative;background:repeating-linear-gradient(0deg,rgba(0,0,0,.012) 0 1px,transparent 1px 24px),repeating-linear-gradient(90deg,rgba(0,0,0,.012) 0 1px,transparent 1px 24px),linear-gradient(180deg,#fdf6e5,#f3e7c8);border-radius:14px;border:1px solid var(--card-edge);padding:16px;overflow:hidden;flex:1;display:flex;align-items:center;justify-content:center;min-height:360px}.board-stage__fill,.board-canvas-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.board-canvas{display:block;max-width:100%;height:auto}.board-empty{color:var(--ink-soft);text-align:center;font-size:15px;max-width:360px;line-height:1.55}.rotate-hint{position:absolute;bottom:10px;left:50%;transform:translate(-50%);background:#2a2017d1;color:#fdf6e5;font-size:12px;padding:6px 12px;border-radius:999px;pointer-events:none;letter-spacing:.02em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.controls{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.controls__center{display:flex;align-items:center;gap:10px}.controls__actions{display:flex;align-items:center;gap:8px}.controls__counter{font-variant-numeric:tabular-nums;font-size:14px;color:var(--ink-soft);min-width:130px;text-align:center}.icon-btn{width:40px;height:40px;border-radius:999px;background:var(--card);color:var(--ink);box-shadow:inset 0 0 0 1px var(--card-edge);display:inline-flex;align-items:center;justify-content:center;font-size:16px;transition:transform .12s ease,background .16s ease,color .16s ease}.icon-btn:hover{background:#f5ead2}.icon-btn:active{transform:scale(.96)}.icon-btn:disabled{color:var(--ink-soft);cursor:not-allowed;opacity:.5}.icon-btn--bookmark{font-size:22px;line-height:1;color:var(--ink-soft)}.icon-btn--bookmark.is-on{color:var(--star);background:#fff5dc;box-shadow:inset 0 0 0 1px #e9c97a}.icon-btn--bookmark.is-on:hover{background:#ffeec5}.bookmarks{border-top:1px dashed var(--card-edge);padding-top:14px;display:flex;flex-direction:column;gap:8px;min-height:0}.bookmarks__label{font-size:12px;color:var(--ink-soft);letter-spacing:.03em;text-transform:uppercase}.bookmarks__strip{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;padding:2px 2px 8px;scroll-snap-type:x proximity;scrollbar-width:thin}.bookmark{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 6px 4px;background:#fffaee;border-radius:8px;box-shadow:inset 0 0 0 1px var(--card-edge);scroll-snap-align:start;transition:transform .12s ease,box-shadow .16s ease,background .16s ease}.bookmark:hover{background:#f7eed5;transform:translateY(-1px)}.bookmark:active{transform:translateY(0)}.bookmark--current{background:#fff5dc;box-shadow:inset 0 0 0 2px var(--star)}.bookmark__thumb{display:flex;align-items:center;justify-content:center;min-width:60px;min-height:40px}.bookmark__num{font-size:11px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.warning{background:#fbeee5;color:#7a3b1c;border-radius:12px;padding:14px 16px;line-height:1.5;font-size:14px}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%);background:var(--success);color:#fff;padding:10px 18px;border-radius:999px;font-weight:600;font-size:14px;box-shadow:0 6px 24px #0000002e;pointer-events:none;z-index:10}.progress{display:flex;align-items:center;gap:10px;color:var(--ink-soft);font-size:13px}.spinner{width:14px;height:14px;border-radius:50%;border:2px solid var(--accent-soft);border-top-color:transparent;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
