:root{--paper:#f4ecdc;--card:#fbf6ea;--field:#fffdf6;--ink:#2a241b;--ink-soft:#6b6150;--rule:#d8ccb2;--rule-strong:#b9a986;--accent:#8a5523;--accent-press:#6d4119;--danger:#9c3a2e;--radius:4px;--serif:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,"Times New Roman",serif}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--serif);font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased}.app{max-width:680px;margin:0 auto;padding:8px 20px calc(env(safe-area-inset-bottom) + 48px)}.masthead{text-align:center;padding:18px 0 20px;border-bottom:3px double var(--rule-strong);margin-bottom:28px}.masthead-bar{display:flex;align-items:center;justify-content:space-between;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--rule);padding-bottom:8px;margin-bottom:16px}.masthead .title{margin:0;font-size:42px;font-weight:700;letter-spacing:.01em;line-height:1.05}.masthead .tagline{margin:8px 0 0;font-style:italic;color:var(--ink-soft);font-size:16px}.card{background:var(--card);border:1px solid var(--rule);border-radius:var(--radius);padding:22px}.field{margin-bottom:16px}.field label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin-bottom:6px}input[type=email],input[type=password],input[type=text],textarea{width:100%;background:var(--field);border:1px solid var(--rule-strong);border-radius:var(--radius);color:var(--ink);font-family:var(--serif);font-size:17px;padding:11px 12px;resize:vertical}input[type=email]::placeholder,input[type=password]::placeholder,input[type=text]::placeholder,textarea::placeholder{color:#b3a78d}input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(138,85,35,.15)}textarea.body{min-height:240px;line-height:1.7}.row{display:flex;gap:16px}.row .field{flex:1 1}button{font-family:var(--serif);font-size:16px;border-radius:var(--radius);border:1px solid var(--rule-strong);background:var(--field);color:var(--ink);padding:10px 16px;cursor:pointer;transition:background .12s ease,color .12s ease}button:hover{border-color:var(--accent);color:var(--accent)}button.primary{background:var(--accent);border-color:var(--accent);color:#fdf7ec;font-weight:600;letter-spacing:.02em;flex:1 1;padding:12px 16px}button.primary:hover{background:var(--accent-press);color:#fdf7ec}button:disabled{opacity:.5;cursor:not-allowed}button.linkbtn{border:none;background:none;padding:0;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}button.linkbtn:hover{color:var(--accent)}.editor-tabs{display:inline-flex;border-bottom:1px solid var(--rule);margin-bottom:12px;gap:4px}.editor-tabs button{background:none;border-radius:0;padding:6px 12px;color:var(--ink-soft);border:none;border-bottom:2px solid transparent;margin-bottom:-1px}.editor-tabs button.active{color:var(--ink);border-bottom-color:var(--accent)}.photobar{display:flex;align-items:center;gap:12px;margin:4px 0 12px}.thumbs{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 16px}.thumb{position:relative;width:76px;height:76px;border:1px solid var(--rule-strong);border-radius:var(--radius);overflow:hidden;background:var(--field)}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb .ph{display:flex;align-items:center;justify-content:center;height:100%;font-size:22px}.thumb .remove{position:absolute;top:2px;right:2px;width:20px;height:20px;padding:0;line-height:1;border-radius:50%;background:rgba(42,36,27,.78);color:#fff;border:none;font-size:13px}.preview{background:var(--field);border:1px solid var(--rule-strong);border-radius:var(--radius);padding:16px 20px;min-height:240px;line-height:1.7}.preview h1,.preview h2,.preview h3{font-weight:700;margin-top:.6em}.preview img{max-width:100%;border-radius:var(--radius);border:1px solid var(--rule)}.preview blockquote{border-left:3px solid var(--rule-strong);margin:0;padding-left:14px;color:var(--ink-soft);font-style:italic}.preview code{background:#efe6d2;padding:1px 5px;border-radius:3px;font-size:.9em}.offline-banner{background:#f3e2c2;border:1px solid var(--rule-strong);border-radius:var(--radius);padding:10px 14px;margin-bottom:16px;font-size:15px;color:#6b4a16}.progress{margin-top:16px}.progress-track{height:8px;background:#e7dcc4;border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .4s ease}.progress.done .progress-fill{background:#3f7d52}.progress-label{margin-top:6px;font-size:14px;font-style:italic;color:var(--ink-soft)}.progress.done .progress-label{color:#3f7d52;font-style:normal}ul.saved{list-style:none;margin:0 0 14px;padding:0}ul.saved li{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--card);border:1px solid var(--rule);border-radius:var(--radius);padding:12px 14px;margin-bottom:8px}.saved-main{display:flex;flex-direction:column;gap:2px;min-width:0}.saved-title{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-actions{display:flex;align-items:center;gap:10px;flex:none}button.linkbtn.danger{color:var(--danger)}.actions{display:flex;gap:12px;margin-top:18px}.status{font-size:15px;margin-top:12px;min-height:20px;font-style:italic}.status.ok{color:var(--accent)}.status.err{color:var(--danger)}.hint{color:var(--ink-soft);font-size:14px;font-style:italic;margin-top:8px}section.recent{margin-top:36px}section.recent h2{font-size:13px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);border-bottom:1px solid var(--rule);padding-bottom:8px;margin-bottom:14px}ul.posts{list-style:none;margin:0;padding:0}ul.posts li{border-bottom:1px dotted var(--rule);padding:10px 2px;font-size:16px;display:flex;justify-content:space-between;gap:16px}ul.posts li:last-child{border-bottom:none}ul.posts li .when{font-size:13px;white-space:nowrap}.empty,ul.posts li .when{color:var(--ink-soft);font-style:italic}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.masthead-bar a{color:var(--ink-soft);text-decoration:none}.masthead-bar a:hover{color:var(--accent)}.masthead-bar .nav a{margin-left:16px}ul.blog-list{list-style:none;margin:0;padding:0}ul.blog-list li{border-bottom:1px solid var(--rule)}ul.blog-list li:last-child{border-bottom:none}a.blog-link{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:16px 2px;color:var(--ink)}a.blog-link,a.blog-link:hover{text-decoration:none}a.blog-link:hover .blog-title{color:var(--accent)}.blog-title{font-size:22px;font-weight:700}.article{font-size:19px;line-height:1.75}.article h1,.article h2,.article h3{font-weight:700;margin-top:1.2em}.article img{max-width:100%;border-radius:var(--radius);border:1px solid var(--rule);margin:1em 0}.article blockquote{border-left:3px solid var(--rule-strong);margin:1em 0;padding-left:16px;color:var(--ink-soft);font-style:italic}.article code{background:#efe6d2;padding:1px 5px;border-radius:3px;font-size:.9em}.article pre{background:#efe6d2;padding:14px;border-radius:var(--radius);overflow:auto}ul.requests{list-style:none;margin:0;padding:0}ul.requests li{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--card);border:1px solid var(--rule);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px}.req-email{font-size:17px}.req-actions{display:flex;gap:8px}.req-actions button.primary{flex:none;padding:8px 14px}