:root{--paper:#f4eee1;--paper-2:#faf6ec;--panel:#fbf8f0;--ink:#211e18;--ink-soft:#4c473d;--ink-faint:#8d8674;--line:#d9cfb9;--line-soft:#e7ddc8;--stamp:#c8442d;--stamp-deep:#9c2f1e;--blue:#284a63;--ok:#2f6b4a;--err:#b23222;--font-display:"Fraunces","Noto Serif TC",Georgia,serif;--font-serif:"Noto Serif TC","Fraunces",Georgia,serif;--font-body:"Noto Sans TC",ui-sans-serif,system-ui,sans-serif;--font-mono:"IBM Plex Mono",ui-monospace,monospace;--shadow-press:5px 5px 0 rgba(33,30,24,0.14)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-body);font-weight:400;color:var(--ink);background-color:var(--paper);background-image:radial-gradient(120% 80% at 100% 0,rgba(200,68,45,.06),transparent 55%),radial-gradient(120% 90% at 0 100%,rgba(40,74,99,.06),transparent 55%);background-attachment:fixed;line-height:1.55;letter-spacing:.01em}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.045;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.page{position:relative;z-index:1;max-width:1000px;margin:0 auto;padding:2rem 1.6rem 4rem}.masthead{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-bottom:.7rem;border-bottom:3px double var(--ink);margin-bottom:2.2rem}.brand{display:flex;align-items:baseline;gap:.55rem}.brand-mark{color:var(--stamp);font-size:1.7rem;line-height:1;transform:translateY(2px)}.brand-mark,.brand-name{font-family:var(--font-display)}.brand-name{font-weight:600;font-size:1.85rem;letter-spacing:-.01em}.brand-tag{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.22em;color:var(--ink-faint);padding-bottom:.25rem}.topnav{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap}.navlink{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;text-decoration:none;color:var(--ink-soft);padding-bottom:2px;border-bottom:2px solid transparent}.navlink:hover{color:var(--ink);border-bottom-color:var(--line)}.navlink.active{color:var(--stamp);border-bottom-color:var(--stamp)}.who{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-faint);padding:.15rem .5rem;border:1px dashed var(--line);border-radius:2px}.content{animation:fade .6s ease both}h1{letter-spacing:.01em;margin:0}h1,h2{font-family:var(--font-serif);font-weight:600}h2{margin:0 0 .6rem;font-size:1.05rem}a{color:var(--blue);text-underline-offset:3px}.panel{background:var(--panel);border:1px solid var(--ink);box-shadow:var(--shadow-press)}.sheet{padding:2rem 2.1rem 2.3rem;position:relative}.sheet:after{content:"RESEND";position:absolute;top:1.4rem;right:1.6rem;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.3em;color:var(--ink-faint);border:1px solid var(--line);padding:.2rem .45rem;transform:rotate(4deg)}.sheet-head{margin-bottom:1.6rem}.sheet-title{font-size:1.9rem}.sheet-sub{margin:.25rem 0 0;color:var(--ink-faint);font-size:.9rem}.letter{display:flex;flex-direction:column;gap:1.05rem}.addr-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1.05rem;gap:1.05rem}.addr-grid .field-to{grid-column:1/-1}.field{display:flex;flex-direction:column;gap:.3rem}.field label{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint)}input,select,textarea{width:100%;font-family:var(--font-body);font-size:.98rem;color:var(--ink);background:rgba(255,255,255,.55);border:1px solid var(--line);border-bottom:2px solid var(--ink-soft);border-radius:3px 3px 1px 1px;padding:.62rem .7rem;transition:border-color .15s,background .15s}input::placeholder,textarea::placeholder{color:var(--ink-faint);opacity:.7}input:focus,select:focus,textarea:focus{outline:none;border-bottom-color:var(--stamp);background:#fff}.letter-body{min-height:13rem;resize:vertical;line-height:1.7;background-color:rgba(255,255,255,.55);background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 1.69rem,var(--line-soft) 1.7rem);background-attachment:local}.actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.4rem}.btn{font-family:var(--font-body);font-weight:500;font-size:.95rem;cursor:pointer;border:none;border-radius:3px;padding:.7rem 1.5rem}.btn-primary{background:var(--stamp);color:#fff;border:1px solid var(--stamp-deep);box-shadow:3px 3px 0 var(--ink);transition:transform .12s ease,box-shadow .12s ease;letter-spacing:.04em}.btn-primary:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}.btn-primary:active:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.btn-primary:disabled{opacity:.55;cursor:progress;box-shadow:2px 2px 0 var(--ink)}.btn-ghost{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;background:transparent;color:var(--stamp-deep);border:1px solid var(--line);border-radius:2px;padding:.28rem .7rem;cursor:pointer;transition:background .15s,border-color .15s}.btn-ghost:hover{background:rgba(200,68,45,.08);border-color:var(--stamp)}.flash{font-size:.88rem;font-family:var(--font-mono)}.flash-ok{color:var(--ok)}.error,.flash-err{color:var(--err)}.ok{color:var(--ok)}.ledger-head{display:flex;align-items:baseline;gap:.8rem;margin-bottom:1.2rem}.ledger-head h1{font-size:1.7rem}.count{font-family:var(--font-mono);font-size:.72rem;border:1px solid var(--line);border-radius:2px;padding:.12rem .5rem}.count,.empty{color:var(--ink-faint)}.empty{font-style:italic}.ledger{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{font-family:var(--font-mono);font-weight:500;font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);text-align:left;border-bottom:2px solid var(--ink);white-space:nowrap}tbody td,thead th{padding:.7rem .85rem}tbody td{border-bottom:1px solid var(--line-soft);font-size:.85rem;vertical-align:top}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .12s}tbody tr:hover{background:rgba(200,68,45,.045)}td.addr,td.when{font-family:var(--font-mono);font-size:.76rem;color:var(--ink-soft);white-space:nowrap}td.subj a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}td.subj a:hover{color:var(--stamp);border-bottom-color:var(--stamp)}td.body-prev{color:var(--ink-faint)}.stamp{display:inline-block;font-family:var(--font-mono);font-size:.62rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;padding:.12rem .45rem;border:1.5px solid;border-radius:3px;transform:rotate(-3.5deg)}.stamp-sent{color:var(--ok)}.stamp-failed{color:var(--err)}.back{font-family:var(--font-mono);font-size:.76rem;text-decoration:none}.receipt{padding:1.8rem 2rem}.receipt h1{font-size:1.6rem;margin-bottom:1.2rem}dl.receipt-dl{display:grid;grid-template-columns:max-content 1fr;grid-gap:.55rem 1.4rem;gap:.55rem 1.4rem;margin:0 0 1.4rem}dl.receipt-dl dt{font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);padding-top:.15rem}dl.receipt-dl dd{margin:0;font-size:.95rem;word-break:break-word}dl.receipt-dl dd.mono{font-family:var(--font-mono);font-size:.84rem}pre.letter-paper{white-space:pre-wrap;word-break:break-word;font-family:var(--font-body);font-size:.96rem;line-height:1.75;margin:0;padding:1.1rem 1.2rem;background:rgba(255,255,255,.6);border:1px solid var(--line);border-left:3px solid var(--stamp);border-radius:2px}.auth-page{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;padding:2rem 1.2rem}.auth-card{width:100%;max-width:30rem;padding:2.4rem 2.2rem}.auth-brand{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1.8rem}.auth-brand .brand-name{font-size:1.5rem}.auth-title{font-size:1.7rem;margin-bottom:1.4rem}.auth-form{display:flex;flex-direction:column;gap:1.1rem}.auth-form .btn-primary{margin-top:.4rem}.authtabs{display:flex;gap:1.2rem;margin-top:1.6rem;padding-top:1.2rem;border-top:1px solid var(--line)}.authtabs a{font-family:var(--font-mono);font-size:.76rem;color:var(--ink-soft);text-decoration:none}.authtabs a:hover{color:var(--stamp)}.footer{margin-top:3rem;padding-top:1rem;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;color:var(--ink-faint);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.reveal{animation:rise .55s cubic-bezier(.2,.7,.2,1) both}.auth-form .field,.letter .field{animation:rise .5s cubic-bezier(.2,.7,.2,1) both}.letter .field:first-child{animation-delay:.05s}.letter .field:nth-child(2){animation-delay:.1s}.letter .field:nth-child(3){animation-delay:.15s}.letter .field:nth-child(4){animation-delay:.2s}.letter .actions{animation:rise .5s cubic-bezier(.2,.7,.2,1) .25s both}@media (prefers-reduced-motion:reduce){*,:before{animation:none!important;transition:none!important}}@media (max-width:620px){.addr-grid{grid-template-columns:1fr}.brand-name{font-size:1.55rem}.masthead{align-items:flex-start}dl.receipt-dl{grid-template-columns:1fr;gap:.2rem 0}dl.receipt-dl dd{margin-bottom:.7rem}}