:root{--bg:#FAF8F4;--bg-grid:#ECE7DD;--surface:#FFFFFF;--surface-soft:#F4F1EA;--border:#E5DFD2;--border-strong:#1A1814;--ink:#1A1814;--ink-2:#4A463E;--ink-3:#837D70;--ink-4:#B8B0A0;--c-yellow:#FFE066;--c-yellow-deep:#F5C518;--c-pink:#FFB8D1;--c-pink-deep:#E48BAE;--c-mint:#B8E6C8;--c-mint-deep:#6FBE8C;--c-sky:#B5DCFF;--c-sky-deep:#5BA3E0;--c-lavender:#D4C4F0;--c-lavender-deep:#9B7FD4;--c-peach:#FFCAA8;--c-peach-deep:#E8966A;--c-coral:#FFB3A8;--c-coral-deep:#E07A6E;--accent:#1A1814;--accent-fg:#FFF8E7;--shadow-sm:0 1px 2px rgba(26,24,20,0.06),0 1px 1px rgba(26,24,20,0.04);--shadow-md:0 4px 12px rgba(26,24,20,0.08),0 1px 3px rgba(26,24,20,0.06);--shadow-note:2px 4px 0 rgba(26,24,20,0.08),4px 8px 16px rgba(26,24,20,0.10);--shadow-note-hover:3px 6px 0 rgba(26,24,20,0.12),8px 16px 28px rgba(26,24,20,0.14);--radius-sm:4px;--radius-md:6px;--radius-lg:10px}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;background:var(--bg);color:var(--ink);font-family:Geist,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{height:56px;border-bottom:1px solid var(--border);background:var(--surface);padding:0 20px;gap:16px;position:-webkit-sticky;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.brand,.topbar{display:flex;align-items:center}.brand{gap:8px;font-weight:600;font-size:15px;letter-spacing:-.01em;cursor:pointer}.brand-mark{width:26px;height:26px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cg transform='rotate(-6 16 16)'%3E%3Crect x='5' y='5' width='22' height='22' rx='2.5' fill='%23FFE066' stroke='%231A1814' stroke-width='2'/%3E%3Cpath d='M10 13 h12 M10 17.5 h9' stroke='%231A1814' stroke-width='1.8' stroke-linecap='round'/%3E%3Cpath d='M10 22 h6' stroke='%231A1814' stroke-width='1.8' stroke-linecap='round'/%3E%3C/g%3E%3C/svg%3E") 50% /contain no-repeat}.topbar-spacer{flex:1 1}.topbar nav{display:flex;gap:4px}.topbar nav button{padding:6px 12px;font-size:13px;color:var(--ink-2);border-radius:var(--radius-sm);font-weight:500;transition:background .12s}.topbar nav button:hover{background:var(--surface-soft)}.topbar nav button.active{background:var(--ink);color:var(--accent-fg)}.search{display:flex;align-items:center;gap:8px;background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius-md);padding:6px 12px;width:280px;font-size:13px;color:var(--ink-3)}.search input{border:none;outline:none;background:transparent;flex:1 1;font-family:inherit;font-size:13px;color:var(--ink)}.btn{padding:7px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:all .12s;border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--ink);color:var(--accent-fg)}.btn-primary:hover{background:#2C2820}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--ink)}.btn-secondary:hover{background:var(--surface-soft);border-color:var(--ink-4)}.btn-ghost{background:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--surface-soft)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--c-peach);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--ink);border:1.5px solid var(--ink);flex-shrink:0}.home{flex:1 1;max-width:1200px;width:100%;margin:0 auto;padding:48px 32px 80px}.hero{margin-bottom:56px;display:grid;grid-template-columns:1.4fr 1fr;grid-gap:48px;gap:48px;align-items:center}.hero h1{font-family:"Instrument Serif",serif;font-weight:400;font-size:64px;line-height:1.1;letter-spacing:-.02em;margin-bottom:20px;color:var(--ink)}.hero h1 em{font-style:italic;color:var(--c-pink-deep)}.hero p{font-size:17px;color:var(--ink-2);max-width:460px;line-height:1.5;margin-bottom:28px}.hero-actions{display:flex;gap:10px}.hero-visual{position:relative;height:320px}.hero-visual .mini-note{position:absolute;width:140px;padding:16px;font-family:Caveat,cursive;font-size:17px;line-height:1.25;color:var(--ink);box-shadow:var(--shadow-note)}.hero-visual .mini-note:first-child{background:var(--c-yellow);top:20px;left:30px;transform:rotate(-5deg)}.hero-visual .mini-note:nth-child(2){background:var(--c-pink);top:60px;left:200px;transform:rotate(4deg)}.hero-visual .mini-note:nth-child(3){background:var(--c-mint);top:170px;left:70px;transform:rotate(-2deg)}.hero-visual .mini-note:nth-child(4){background:var(--c-sky);top:200px;left:230px;transform:rotate(6deg)}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px}.section-head h2{font-family:"Instrument Serif",serif;font-weight:400;font-size:28px;letter-spacing:-.01em}.section-head .filters{display:flex;gap:4px}.section-head .filters button{padding:5px 10px;font-size:12px;color:var(--ink-2);border-radius:var(--radius-sm);font-weight:500}.section-head .filters button:hover{background:var(--surface-soft)}.section-head .filters button.active{background:var(--ink);color:var(--accent-fg)}.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px;margin-bottom:56px}.guide-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all .16s;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}.guide-card:hover{border-color:var(--ink-4);transform:translateY(-2px);box-shadow:var(--shadow-md)}.guide-card-preview{height:120px;background:var(--surface-soft);border-radius:var(--radius-md);position:relative;overflow:hidden}.guide-card-preview .pv-note{position:absolute;width:50px;height:50px;border-radius:2px;box-shadow:var(--shadow-sm);font-family:Caveat,cursive;font-size:10px;padding:5px;color:var(--ink);overflow:hidden}.guide-card h3{font-family:"Instrument Serif",serif;font-weight:400;font-size:20px;line-height:1.2;letter-spacing:-.01em}.guide-card p{font-size:13px;color:var(--ink-3);line-height:1.45}.guide-card-meta{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--ink-3);margin-top:auto;padding-top:6px}.guide-card-meta .author{display:flex;align-items:center;gap:6px}.guide-card-meta .stat{display:inline-flex;align-items:center;gap:4px}.guide-view{flex:1 1;display:grid;grid-template-columns:280px 1fr 320px}.guide-sidebar{background:var(--surface);border-right:1px solid var(--border);padding:24px 20px;overflow-y:auto;position:-webkit-sticky;position:sticky;top:56px;height:calc(100vh - 56px)}.guide-sidebar h4{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:600;margin-bottom:10px}.guide-sidebar h4:not(:first-child){margin-top:28px}.branch-list{display:flex;flex-direction:column;gap:4px}.branch-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--ink);cursor:pointer;transition:background .12s}.branch-item.active,.branch-item:hover{background:var(--surface-soft)}.branch-item.active{font-weight:500}.branch-swatch{width:12px;height:12px;border-radius:2px;border:1px solid rgba(26,24,20,.3);flex-shrink:0}.branch-item .count{margin-left:auto;font-size:11px;color:var(--ink-3);display:inline-flex;align-items:center;gap:10px;flex-shrink:0;white-space:nowrap}.branch-item .count .icon-sm{width:10px;height:10px}.branch-item .branch-likes{display:inline-flex;align-items:center;gap:2px;font-size:11px;color:var(--ink-3);flex-shrink:0}.branch-item .branch-likes .icon-sm{width:10px;height:10px}.guide-main{display:flex;flex-direction:column;min-width:0;min-height:calc(100vh - 56px);background-color:var(--bg);background-image:radial-gradient(circle at center,var(--bg-grid) 1.2px,transparent 1.6px);background-size:24px 24px;background-position:0 0;padding-top:48px}.guide-canvas{position:relative;flex:1 1;overflow-x:auto;padding:12px 24px 120px}.guide-header{max-width:720px;margin:0 auto 36px;padding:0 12px}.guide-header .crumb{font-size:12px;color:var(--ink-3);margin-bottom:10px;display:flex;align-items:center;gap:6px}.guide-header h1{font-family:"Instrument Serif",serif;font-weight:400;font-size:44px;line-height:1.05;letter-spacing:-.015em;margin-bottom:14px}.guide-header .desc{font-size:15px;color:var(--ink-2);line-height:1.5;margin-bottom:18px;max-width:600px}.guide-header .by{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--ink-2);flex-wrap:wrap}.guide-header .by .author{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--ink)}.guide-header .by .dot{color:var(--ink-4)}.tree-wrap{position:relative;margin:0 auto}.tree-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.notes-layer{position:relative;z-index:2}.note{position:absolute;width:240px;padding:22px 20px 18px;font-family:Caveat,cursive;font-size:19px;line-height:1.3;color:var(--ink);background:var(--c-yellow);box-shadow:var(--shadow-note);transition:transform .2s cubic-bezier(.34,1.3,.64,1),box-shadow .2s;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.note:hover{transform:translate(-50%) rotate(0deg) scale(1.03)!important;box-shadow:var(--shadow-note-hover);z-index:5}.note.is-focused{outline:2px solid var(--ink);outline-offset:4px}.note:before{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(-1deg);width:56px;height:14px;background:rgba(255,255,255,.5);border:1px solid rgba(26,24,20,.06);box-shadow:0 1px 2px rgba(0,0,0,.05)}.note-step{font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(26,24,20,.55);margin-bottom:6px;display:flex;align-items:center;gap:6px}.note-step span{white-space:nowrap}.note-step span:last-child{overflow:hidden;text-overflow:ellipsis;min-width:0}.note-title{font-family:Geist,sans-serif;font-size:14px;font-weight:600;margin-bottom:8px;letter-spacing:-.01em;line-height:1.25}.note-body{font-family:Caveat,cursive;font-size:18px;line-height:1.3}.note-body-solo{font-size:21px;line-height:1.25}.note-body-solo.note-body-big{font-size:30px;font-weight:600;line-height:1.15}.note-foot{font-family:Geist,sans-serif;gap:10px;margin-top:12px;padding-top:10px;border-top:1px dashed rgba(26,24,20,.18);font-size:11px;color:rgba(26,24,20,.6)}.note-foot,.note-foot .author{display:flex;align-items:center}.note-foot .author{gap:5px;font-weight:500}.note-foot .avatar{width:18px;height:18px;font-size:9px;border-width:1px}.note-foot .stat{display:inline-flex;align-items:center;gap:3px}.fork-btn{position:absolute;bottom:-14px;right:14px;padding:5px 10px;font-family:Geist,sans-serif;font-size:11px;font-weight:600;background:var(--ink);color:var(--accent-fg);border-radius:100px;display:flex;align-items:center;gap:4px;opacity:0;transform:translateY(4px);transition:opacity .16s,transform .16s;box-shadow:var(--shadow-md);z-index:6}.note:hover .fork-btn{opacity:1;transform:translateY(0)}.note.c-yellow{background:var(--c-yellow)}.note.c-pink{background:var(--c-pink)}.note.c-mint{background:var(--c-mint)}.note.c-sky{background:var(--c-sky)}.note.c-lavender{background:var(--c-lavender)}.note.c-peach{background:var(--c-peach)}.note.c-coral{background:var(--c-coral)}.branch-label{position:absolute;font-family:Geist,sans-serif;font-size:11px;font-weight:600;background:var(--surface);border:1px solid var(--ink);padding:3px 8px;border-radius:100px;display:inline-flex;align-items:center;gap:5px;z-index:7;white-space:nowrap}.branch-label .dot{width:8px;height:8px;border-radius:2px;border:1px solid rgba(26,24,20,.4)}.guide-rail{background:var(--surface);border-left:1px solid var(--border);padding:24px 20px;overflow-y:auto;position:-webkit-sticky;position:sticky;top:56px;height:calc(100vh - 56px)}.guide-rail h4{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:600;margin-bottom:12px}.guide-rail h4:not(:first-child){margin-top:24px}.rail-empty{color:var(--ink-3);font-size:13px;border-radius:var(--radius-md);text-align:center;line-height:1.5}.detail-card,.rail-empty{padding:16px;background:var(--surface-soft)}.detail-card{border:1px solid var(--border);border-radius:var(--radius-md)}.detail-card .step-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}.detail-card h3{font-size:16px;font-weight:600;margin-bottom:10px;letter-spacing:-.01em}.detail-card p{font-size:13px;color:var(--ink-2);line-height:1.55;margin-bottom:12px}.detail-card .meta-row{display:flex;gap:14px;font-size:12px;color:var(--ink-3);padding-top:10px;border-top:1px solid var(--border)}.fork-list{display:flex;flex-direction:column;gap:8px}.fork-list-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;transition:all .12s}.fork-list-item:hover{border-color:var(--ink-4);background:var(--surface-soft)}.fork-list-item .swatch{width:18px;height:18px;border-radius:3px;border:1px solid rgba(26,24,20,.3);flex-shrink:0}.fork-list-item .info{flex:1 1;min-width:0}.fork-list-item .info .title{font-size:13px;font-weight:500;margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fork-list-item .info .by{font-size:11px;color:var(--ink-3)}.modal-bg{position:fixed;inset:0;background:rgba(26,24,20,.45);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .18s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:14px;width:560px;max-width:100%;max-height:90vh;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.25);display:flex;flex-direction:column;animation:rise .22s cubic-bezier(.34,1.3,.64,1)}@keyframes rise{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.modal-head h2{font-family:"Instrument Serif",serif;font-size:24px;font-weight:400;letter-spacing:-.01em;margin-bottom:4px}.modal-head p{font-size:13px;color:var(--ink-3)}.modal-close{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--ink-3)}.modal-close:hover{background:var(--surface-soft);color:var(--ink)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1 1}.field{margin-bottom:18px}.field label{display:block;font-size:12px;font-weight:600;color:var(--ink-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.field input,.field textarea{width:100%;font-family:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);outline:none;transition:border-color .12s}.field textarea{font-family:Caveat,cursive;font-size:18px;line-height:1.3;resize:vertical;min-height:90px}.field input:focus,.field textarea:focus{border-color:var(--ink)}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:36px;height:36px;border-radius:6px;border:2px solid transparent;transition:transform .12s,border-color .12s;position:relative}.color-swatch:after{content:"";position:absolute;inset:2px;border-radius:4px;border:1px solid rgba(26,24,20,.25)}.color-swatch.active{border-color:var(--ink);transform:scale(1.05)}.color-swatch:hover{transform:scale(1.08)}.color-swatch.active:hover{transform:scale(1.05)}.preview-note{margin:28px 0 24px;display:flex;justify-content:center}.preview-note .note:hover{transform:rotate(var(--pv-rot,0deg))!important;box-shadow:var(--shadow-note)}.preview-note .note{position:relative;width:220px;padding:18px 18px 14px}.preview-note .note:before{display:block}.modal-foot{padding:14px 24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--surface-soft)}.modal-foot .hint{font-size:12px;color:var(--ink-3)}.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--accent-fg);padding:10px 18px;border-radius:100px;font-size:13px;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);z-index:200;animation:rise .24s cubic-bezier(.34,1.3,.64,1);display:flex;align-items:center;gap:8px}.icon{width:14px;height:14px;flex-shrink:0}.icon-sm{width:12px;height:12px;flex-shrink:0}.tag{display:inline-flex;align-items:center;font-size:11px;padding:2px 8px;border-radius:100px;background:var(--surface-soft);color:var(--ink-2);border:1px solid var(--border);font-weight:500}.tag-row{display:flex;gap:6px;flex-wrap:wrap}a{color:inherit;text-decoration:none}.topbar nav a{padding:6px 12px;font-size:13px;color:var(--ink-2);border-radius:var(--radius-sm);font-weight:500;transition:background .12s}.topbar nav a:hover{background:var(--surface-soft)}.topbar nav a.active{background:var(--ink);color:var(--accent-fg)}.user-menu{position:relative}.user-menu .menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);min-width:180px;padding:6px;z-index:60;display:flex;flex-direction:column}.user-menu .menu .who{padding:8px 10px;font-size:12px;color:var(--ink-3);border-bottom:1px solid var(--border);margin-bottom:4px}.user-menu .menu .who strong{display:block;color:var(--ink);font-size:13px}.user-menu .menu a,.user-menu .menu button{text-align:left;padding:8px 10px;font-size:13px;border-radius:var(--radius-sm);color:var(--ink)}.user-menu .menu a:hover,.user-menu .menu button:hover{background:var(--surface-soft)}.heart-btn.hearted{color:var(--c-coral-deep)}.heart-btn.hearted .icon,.heart-btn.hearted .icon-sm{fill:currentColor}.btn.heart-btn.hearted{background:rgba(255,179,168,.25);border-color:var(--c-coral-deep)}.btn.heart-btn.hearted:hover{background:rgba(255,179,168,.4)}.add-step-note{position:absolute;width:240px;padding:20px;border:2px dashed var(--ink-4);border-radius:var(--radius-md);color:var(--ink-3);font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;background:rgba(255,255,255,.5);transition:all .12s;z-index:2}.add-step-note:hover{border-color:var(--ink);color:var(--ink);background:var(--surface)}.editor-page{max-width:680px;margin:0 auto;padding:48px 24px 120px;width:100%}.editor-page h1{font-family:"Instrument Serif",serif;font-weight:400;font-size:40px;letter-spacing:-.015em;margin-bottom:8px}.editor-page .sub{color:var(--ink-3);font-size:14px;margin-bottom:32px}.editor-step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;position:relative}.editor-step-card .step-num{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.editor-step-card .remove{color:var(--ink-3);font-size:11px;padding:2px 8px;border-radius:var(--radius-sm)}.editor-step-card .remove:hover{background:var(--surface-soft);color:var(--ink)}.form-error{background:#FDECEA;border:1px solid #f5c6c0;color:#B3261E;font-size:13px;padding:10px 14px;border-radius:var(--radius-md);margin-bottom:16px}.signin-page{flex:1 1;display:flex;align-items:center;justify-content:center;padding:40px 24px}.signin-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:40px;max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow-md)}.signin-card h1{font-family:"Instrument Serif",serif;font-weight:400;font-size:30px;margin:16px 0 8px}.signin-card p{color:var(--ink-3);font-size:14px;margin-bottom:24px}.empty-state{text-align:center;padding:80px 24px;color:var(--ink-3)}.empty-state h2{font-family:"Instrument Serif",serif;font-weight:400;font-size:28px;color:var(--ink);margin-bottom:8px}@keyframes spin{to{transform:rotate(1turn)}}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:currentcolor;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}@media (max-width:1000px){.guide-view{grid-template-columns:1fr}.guide-sidebar{border-right:none;border-bottom:1px solid var(--border);position:static;height:auto}.guide-main{min-height:auto}.guide-rail{display:none}.hero{grid-template-columns:1fr}.hero-visual{display:none}.guide-grid{grid-template-columns:1fr}.search{display:none}.hero h1{font-size:42px}}@media (max-width:1280px) and (min-width:1001px){.guide-grid{grid-template-columns:repeat(2,1fr)}}.branch-edit-btn{display:none;align-items:center;justify-content:center;width:20px;height:20px;border-radius:var(--radius-sm);color:var(--ink-3);flex-shrink:0}.branch-item:hover .branch-edit-btn{display:inline-flex}.branch-edit-btn:hover{background:var(--border);color:var(--ink)}.liked-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px;margin-bottom:56px;align-items:start}.liked-note-link{display:block}.liked-note{padding:18px 16px 14px;color:var(--ink);box-shadow:var(--shadow-note);transition:transform .16s,box-shadow .16s}.liked-note-link:nth-child(3n+1) .liked-note{transform:rotate(-1.5deg)}.liked-note-link:nth-child(3n+2) .liked-note{transform:rotate(1deg)}.liked-note-link:nth-child(3n) .liked-note{transform:rotate(2deg)}.liked-note-link:hover .liked-note{transform:rotate(0deg) scale(1.02);box-shadow:var(--shadow-note-hover)}.liked-note-body{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.liked-note-from{font-family:Geist,sans-serif;font-size:11px;color:rgba(26,24,20,.6);margin-top:10px;padding-top:8px;border-top:1px dashed rgba(26,24,20,.18)}@media (max-width:1000px){.liked-steps-grid{grid-template-columns:1fr}}.note-img{display:block;width:100%;height:110px;object-fit:cover;border-radius:2px;margin-bottom:8px;border:1px solid rgba(26,24,20,.12)}.note .note-body{display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.note-more{font-family:Geist,sans-serif;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(26,24,20,.5);margin-top:8px}.detail-img{display:block;width:100%;border-radius:var(--radius-sm);margin-bottom:12px;border:1px solid var(--border)}.detail-long{font-size:13px;color:var(--ink-2);line-height:1.6;border-top:1px dashed var(--border);padding-top:10px;margin-top:2px}.image-preview img{display:block;width:100%;max-height:220px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--border);margin-bottom:8px}.upload-drop{display:flex;align-items:center;justify-content:center;gap:8px;padding:22px;border:2px dashed var(--border);border-radius:var(--radius-md);color:var(--ink-3);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s}.upload-drop:hover{border-color:var(--ink-4);color:var(--ink);background:var(--surface-soft)}.handle-input{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);transition:border-color .12s}.handle-input:focus-within{border-color:var(--ink)}.handle-input span{padding:0 0 0 12px;color:var(--ink-3);font-size:14px}.handle-input input{border:none!important;outline:none;flex:1 1;padding:10px 12px 10px 4px!important;font-family:inherit;font-size:14px;background:transparent}.branch-heart{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--ink-3);padding:2px 5px;border-radius:var(--radius-sm);flex-shrink:0}.branch-heart:hover{background:var(--border);color:var(--ink)}.branch-heart.hearted{color:var(--c-coral-deep)}.branch-heart.hearted .icon-sm{fill:currentColor}.branch-label .branch-heart{margin-left:2px;padding:2px 4px}.branch-label .branch-edit-btn{display:none;align-items:center;justify-content:center;width:18px;height:18px;border-radius:var(--radius-sm);color:var(--ink-3)}.branch-label:hover .branch-edit-btn{display:inline-flex}.branch-label .branch-edit-btn:hover{background:var(--surface-soft);color:var(--ink)}.profile-head{display:flex;align-items:center;gap:20px;margin-bottom:28px}.profile-head h1{font-family:"Instrument Serif",serif;font-weight:400;font-size:36px;letter-spacing:-.01em;line-height:1.1}.profile-head p{color:var(--ink-3);font-size:13px;margin-top:4px}.profile-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:28px}.profile-tabs a{padding:8px 14px;font-size:13px;font-weight:500;color:var(--ink-2);border-bottom:2px solid transparent;margin-bottom:-1px}.profile-tabs a:hover{color:var(--ink)}.profile-tabs a.active{color:var(--ink);border-bottom-color:var(--ink)}.fork-card-list{display:flex;flex-direction:column;gap:10px;margin-bottom:56px;max-width:640px}.fork-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);transition:all .12s}.fork-card:hover{border-color:var(--ink-4);background:var(--surface-soft)}.fork-card .swatch{width:20px;height:20px;border-radius:4px;border:1px solid rgba(26,24,20,.3);flex-shrink:0}.fork-card .info{flex:1 1;min-width:0}.fork-card .info .title{font-size:14px;font-weight:500}.fork-card .info .by{font-size:12px;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fork-card .stat{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--ink-3);flex-shrink:0}.likes-empty{color:var(--ink-3);font-size:13px;margin-bottom:40px}.likes-empty .icon-sm{vertical-align:-2px}.card-link-overlay{position:absolute;inset:0;z-index:1}.guide-card .author-link{position:relative;z-index:2}.author-link:hover{text-decoration:underline}.branch-label .author-link{font-weight:600}.report-reasons{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.report-reasons .btn{justify-content:center}.tag-link:hover{border-color:var(--ink-4);background:var(--surface)}.note.is-archived{opacity:.75;box-shadow:var(--shadow-sm)}.note.is-archived:after{content:"";position:absolute;inset:0;border:2px dashed rgba(26,24,20,.25);pointer-events:none}.archived-tag{font-size:9px;letter-spacing:.08em;color:rgba(26,24,20,.55);background:rgba(255,255,255,.55);border:1px dashed rgba(26,24,20,.3);border-radius:100px;padding:2px 8px;display:inline-block;margin-bottom:6px}.archived-tag,.version-chip{font-family:Geist,sans-serif;font-weight:600;text-transform:uppercase}.version-chip{display:flex;align-items:center;gap:6px;color:rgba(26,24,20,.6);background:rgba(255,255,255,.6);border:1px solid rgba(26,24,20,.2);border-radius:100px;padding:3px 8px;margin-bottom:8px;width:-moz-fit-content;width:fit-content}.version-chip,.version-chip button{font-size:10px;letter-spacing:.05em}.version-chip button{font-weight:700;text-transform:uppercase;color:var(--ink);text-decoration:underline;padding:0}.branch-likes{display:inline-flex;align-items:center;gap:3px}.rich p{margin:0 0 8px}.rich p:last-child{margin-bottom:0}.rich ol,.rich ul{margin:0 0 8px;padding-left:20px}.rich ol:last-child,.rich ul:last-child{margin-bottom:0}.rich li{margin-bottom:2px}.rich u{text-decoration-thickness:1px;text-underline-offset:2px}.rail-body{font-family:Caveat,cursive;font-size:17px;color:var(--ink);margin-bottom:12px;line-height:1.3}.format-hint{font-size:11px;color:var(--ink-4);margin-top:5px}.guide-canvas.is-panning{cursor:-webkit-grabbing;cursor:grabbing;-webkit-user-select:none;-moz-user-select:none;user-select:none}.guide-canvas.is-panning .note{pointer-events:none}.note-num{position:absolute;top:7px;right:9px;min-width:21px;height:21px;padding:0 4px;border-radius:50%;border:1.5px solid rgba(26,24,20,.45);background:rgba(255,255,255,.55);font-family:Geist,sans-serif;font-size:11px;font-weight:700;color:rgba(26,24,20,.75);display:inline-flex;align-items:center;justify-content:center;transform:rotate(3deg)}.note-step .step-label{text-transform:none}.branch-label-clickable{cursor:pointer;transition:border-color .12s,box-shadow .12s}.branch-label-clickable:hover{border-color:var(--ink);box-shadow:var(--shadow-sm)}.rich-link{color:inherit;text-decoration:underline;-webkit-text-decoration-color:rgba(26,24,20,.45);text-decoration-color:rgba(26,24,20,.45);text-underline-offset:2px;font-weight:600}.rich-link:hover{-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.tip-empty{font-size:12px;color:var(--ink-3);margin-bottom:10px;line-height:1.5}.tip-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.tip-item{background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px}.tip-body{font-size:13px;line-height:1.5;color:var(--ink);margin-bottom:6px}.tip-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ink-3)}.tip-meta .heart-btn{display:inline-flex;align-items:center;gap:3px}.tip-delete{font-size:11px;color:var(--ink-4)}.tip-delete:hover{color:var(--c-coral-deep);text-decoration:underline}.tip-add textarea{width:100%;font-family:inherit;font-size:13px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);outline:none;min-height:60px;resize:vertical;margin-bottom:6px}.tip-add textarea:focus{border-color:var(--ink)}.tip-add .btn{width:100%;justify-content:center}.step-modal{width:640px}.step-modal .modal-head h2{font-size:28px;margin-top:4px}.step-modal-img{display:block;width:100%;max-height:300px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--border);margin-bottom:16px}.step-modal-paper{position:relative;padding:22px 20px 18px;margin:4px 0 18px;box-shadow:var(--shadow-note);transform:rotate(-.4deg)}.step-modal-paper:before{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(-1deg);width:56px;height:14px;background:rgba(255,255,255,.5);border:1px solid rgba(26,24,20,.06);box-shadow:0 1px 2px rgba(0,0,0,.05)}.step-modal-note{font-family:Caveat,cursive;font-size:22px;line-height:1.35;color:var(--ink)}.step-modal-details{font-size:14px;color:var(--ink-2);line-height:1.6}.step-modal-actions{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0 6px;padding-top:14px;border-top:1px solid var(--border)}.step-modal-h4{letter-spacing:.08em;margin:18px 0 10px}.step-modal-h4,.step-tag{font-size:11px;text-transform:uppercase;color:var(--ink-3);font-weight:600}.step-tag{display:inline-flex;align-items:center;gap:6px;letter-spacing:.06em;margin-bottom:8px}.branch-swatch{display:inline-block}.step-modal-title{font-family:Geist,sans-serif;font-size:19px;font-weight:600;letter-spacing:-.01em;line-height:1.25;margin-bottom:8px}.tree-sizer{position:relative;margin:0 auto}.zoom-controls{position:fixed;bottom:20px;right:344px;z-index:40;display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:100px;box-shadow:var(--shadow-md);overflow:hidden}.zoom-controls button{padding:7px 12px;font-size:14px;color:var(--ink-2);line-height:1}.zoom-controls button:hover{background:var(--surface-soft);color:var(--ink)}.zoom-controls .zoom-pct{font-size:11px;font-weight:600;min-width:48px;text-align:center;border-left:1px solid var(--border);border-right:1px solid var(--border)}@media (max-width:1000px){.zoom-controls{right:16px}}.contrib-list{display:flex;flex-direction:column;gap:14px}.contrib-author{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--ink);margin-bottom:5px}.contrib-forks{margin-left:11px;padding-left:14px;border-left:1px dashed var(--border);display:flex;flex-direction:column;gap:2px}.contrib-fork{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2);padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer}.contrib-fork.active,.contrib-fork:hover{background:var(--surface-soft);color:var(--ink)}.contrib-fork.active{font-weight:500}.contrib-fork .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contrib-fork .hearts{margin-left:auto;display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--ink-3);flex-shrink:0}.tip-item.is-hidden{opacity:.7;border-style:dashed}.tip-hidden-tag{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-4)}.tip-hidden-toggle{display:block;font-size:12px;color:var(--ink-3);padding:4px 0;margin-bottom:8px;text-decoration:underline;-webkit-text-decoration-style:dotted;text-decoration-style:dotted;text-underline-offset:3px}.tip-hidden-toggle:hover{color:var(--ink)}.legal-page{max-width:640px;margin:0 auto;padding:48px 24px 96px;width:100%}.legal-page h1{font-family:"Instrument Serif",serif;font-weight:400;font-size:36px;margin-bottom:4px}.legal-updated{color:var(--ink-3);font-size:12px;margin-bottom:28px}.legal-page h2{font-size:15px;font-weight:600;margin:24px 0 6px}.legal-page p{font-size:14px;color:var(--ink-2);line-height:1.65}.legal-page a{text-decoration:underline}.site-footer{display:flex;align-items:center;justify-content:center;gap:18px;padding:20px;border-top:1px solid var(--border);background:var(--surface);font-size:12px;color:var(--ink-3)}.site-footer a:hover{color:var(--ink);text-decoration:underline}.guide-chip{display:inline-flex;align-items:center;gap:5px;font-family:Geist,sans-serif;font-size:.78em;font-weight:600;letter-spacing:-.01em;color:var(--ink);background:var(--surface);border:1px solid var(--ink);border-radius:100px;padding:1px 9px 1px 6px;vertical-align:1px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;transition:box-shadow .12s,transform .12s}.guide-chip:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.guide-chip-mark{width:10px;height:10px;background:var(--c-yellow);border:1px solid var(--ink);border-radius:2px;transform:rotate(-6deg);flex-shrink:0}.guide-chip.is-broken{border-style:dashed;border-color:var(--ink-4);color:var(--ink-3);cursor:default}.link-previews{display:flex;flex-direction:column;gap:8px;margin-top:14px}.link-preview{display:flex;align-items:stretch;gap:0;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden;transition:border-color .12s,box-shadow .12s}.link-preview:hover{border-color:var(--ink-4);box-shadow:var(--shadow-sm)}.lp-img{width:110px;min-height:86px;object-fit:cover;flex-shrink:0;border-right:1px solid var(--border)}.lp-text{padding:10px 14px;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:2px}.lp-domain{font-size:11px;color:var(--ink-3);text-transform:lowercase}.lp-title{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3}.lp-desc,.lp-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lp-desc{font-size:12px;color:var(--ink-2);line-height:1.4}.note-link-preview{display:block;position:relative;margin-bottom:8px}.note-link-preview.has-img{border:1px solid rgba(26,24,20,.15);border-radius:2px;overflow:hidden}.note-link-preview.has-img:hover{border-color:rgba(26,24,20,.4)}.note-lp-img{display:block;width:100%;height:100px;object-fit:cover}.note-lp-chip{font-family:Geist,sans-serif;display:inline-block;font-size:10px;font-weight:600;color:var(--accent-fg);background:rgba(26,24,20,.82);border-radius:4px;padding:2px 8px;max-width:calc(100% - 12px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-link-preview.has-img .note-lp-chip{position:absolute;bottom:6px;left:6px}.draft-badge{display:inline-block;font-family:Geist,sans-serif;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#8A6D1A;background:var(--c-yellow);border:1px solid rgba(26,24,20,.25);border-radius:4px;padding:1px 7px;vertical-align:2px;margin-left:8px}.draft-bar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:#FFF6D6;border-bottom:1px solid rgba(26,24,20,.12)}.draft-bar .draft-badge{margin-left:0}.draft-bar-text{flex:1 1;font-size:13px;color:var(--ink-2)}.pv-polaroid{position:absolute;right:14px;top:16px;background:#FFFEF9;padding:4px 4px 14px;border-radius:1px;box-shadow:var(--shadow-note);transform:rotate(4deg);z-index:2}.pv-polaroid img{display:block;width:84px;height:62px;object-fit:cover}.route-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:3px 10px;background:var(--surface);font-size:12px;color:var(--ink-2)}.route-chip .branch-swatch{width:10px;height:10px}.route-chip-static{cursor:default}.fork-context-note{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:14px;padding:10px 12px;border:1px dashed var(--border);border-radius:var(--radius-md);background:var(--surface-soft);font-size:12px;color:var(--ink-2)}.fork-context-note .route-chip{background:var(--surface)}.guide-title-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:14px}.guide-title-row h1{margin-bottom:0}.guide-title-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.m-hidden{display:none!important}.map-head{position:fixed;top:0;left:0;right:0;height:50px;z-index:121;display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:var(--surface);border-bottom:1px solid var(--border);font-weight:600;font-size:14px}.map-head span{display:inline-flex;align-items:center;gap:8px}.guide-canvas.is-map{position:fixed;top:50px;left:0;right:0;bottom:0;z-index:120;overflow:auto;background-color:var(--bg);background-image:radial-gradient(circle at center,var(--bg-grid) 1.2px,transparent 1.6px);background-size:24px 24px;touch-action:pan-x pan-y}.zoom-controls.is-map{display:flex!important;z-index:122}.m-flow{max-width:430px;margin:0 auto;padding:26px 16px 90px}.m-flow .note{position:relative!important;left:0!important;top:0!important;width:100%;transform:none!important}.m-flow .note .fork-btn{display:none}.m-conn{width:0;border-left:2px dashed var(--c-yellow-deep);height:30px;margin:4px auto}.m-forks{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;margin:12px 0 2px;color:var(--ink-3)}.m-fork-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:4px 12px;background:var(--surface);font-size:12px;font-weight:500;color:var(--ink-2)}.m-fork-chip.active{background:var(--ink);color:var(--accent-fg);border-color:var(--ink)}.m-forks .m-fork-chip.active{background:var(--surface);color:var(--ink);border-color:var(--ink);font-weight:600}.m-forks .m-fork-chip.active .m-count{color:var(--ink-3)}.m-add{position:relative!important;left:auto!important;top:auto!important;transform:none!important;margin:20px auto 0;width:-moz-fit-content;width:fit-content}.map-fab{position:fixed;right:16px;bottom:18px;z-index:90;display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:var(--accent-fg);border-radius:999px;padding:11px 18px;font-size:13px;font-weight:500;box-shadow:var(--shadow-md)}@media (max-width:1080px){.guide-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:760px){.topbar{padding:0 12px;gap:10px}.topbar .search{display:none}.hero{grid-template-columns:1fr;gap:20px;margin-bottom:36px}.hero h1{font-size:40px}.hero-visual{display:none}.home{padding:28px 16px 60px}.guide-grid{grid-template-columns:1fr}.section-head{flex-direction:column;align-items:flex-start;gap:12px}.section-head .filters{max-width:100%;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}.section-head .filters::-webkit-scrollbar{display:none}.section-head .filters button{flex-shrink:0;white-space:nowrap;border:1px solid var(--border);border-radius:999px;padding:4px 13px;background:var(--surface)}.section-head .filters button.active{border-color:var(--ink)}.hero p{font-size:15px;margin-bottom:22px}.guide-view{display:block}.guide-rail,.guide-sidebar{display:none}.guide-main{background-image:radial-gradient(circle at center,rgba(236,231,221,.55) 1.2px,transparent 1.6px)}.guide-header{margin-bottom:8px;padding:0 16px}.guide-header .crumb{margin-bottom:6px}.guide-header .crumb .icon-sm,.guide-header .crumb span{display:none}.guide-header h1{font-size:30px}.guide-title-row{gap:12px;margin-bottom:10px}.guide-header{position:relative}.guide-header .crumb{display:flex;align-items:center;min-height:32px;margin-bottom:4px}.guide-title-actions{position:absolute;top:0;right:16px;height:32px;align-items:center;gap:6px}.guide-title-actions .btn{height:28px;padding:0 10px;font-size:12px;justify-content:center}.guide-title-actions .share-label{display:none}.guide-header .desc{font-size:14px;margin-bottom:10px}.guide-header .tag-row{margin-bottom:10px!important}.guide-header .by{font-size:12px;gap:8px;flex-wrap:wrap}.guide-header .by .avatar{width:22px;height:22px;font-size:9px}.zoom-controls{display:none}.modal{width:calc(100vw - 20px);max-height:92dvh;overflow-y:auto}.modal-foot{flex-wrap:wrap;padding:12px 16px;gap:10px}.modal-foot>.btn-ghost,.modal-foot>.hint{flex:1 1 100%;text-align:left}.modal-foot>div{margin-left:auto}.modal-head{padding-right:14px}.modal-body{padding:16px}.editor-page{padding:24px 16px 60px}}.m-branches{display:flex;align-items:center;gap:8px;overflow-x:auto;padding:2px 16px 14px;scrollbar-width:none}.m-branches::-webkit-scrollbar{display:none}.m-branches .m-fork-chip{flex-shrink:0}.m-count{font-size:11px;color:var(--ink-4);margin-left:2px}.m-fork-chip.active .m-count{color:var(--accent-fg);opacity:.7}