@font-face{font-family:'Instrument Serif';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/InstrumentSerif-Regular.woff2') format('woff2')}
@font-face{font-family:'Instrument Serif';font-style:italic;font-weight:400;font-display:swap;src:url('/static/fonts/InstrumentSerif-Italic.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 800;font-display:swap;src:url('/static/fonts/HankenGrotesk-Variable.woff2') format('woff2')}
:root{
  --paper:#F4F0E6; --card:#FBF9F3; --ink:#171510; --soft:#56503F; --accent:#DE3C16;
  --line:#e3ddcf; --ok:#3a7d34; --warn:#b5651d;
  --serif:'Instrument Serif',Georgia,serif; --sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:15px;line-height:1.5}
a{color:#1a5fb4;text-decoration:none}a:hover{text-decoration:underline}
button{font-family:inherit;cursor:pointer}
.serif{font-family:var(--serif)}

/* ---- auth pages ---- */
.authwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.authcard{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:34px 32px;max-width:400px;width:100%;box-shadow:0 10px 40px rgba(0,0,0,.06)}
.logo{font-family:var(--serif);font-size:22px;margin-bottom:4px}
.logo span{color:var(--accent)}
.authcard h1{font-family:var(--serif);font-weight:normal;font-size:24px;margin:8px 0 4px}
.authcard p.sub{color:var(--soft);margin:0 0 20px;font-size:14px}
label{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--soft);margin:14px 0 5px}
input[type=text],input[type=email],input[type=password],input[type=search],textarea,select{
  width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:15px;color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)}
button.primary,.authcard button{width:100%;margin-top:20px;padding:12px;background:var(--ink);color:var(--paper);border:none;border-radius:10px;font-weight:bold;font-size:15px}
button.primary:hover,.authcard button:hover{background:#000}
.err{margin-top:14px;background:#fdecea;border:1px solid #f5c6bf;color:#9b2417;padding:10px 12px;border-radius:10px;font-size:.9rem}
.ok-note{margin:0 0 14px;background:#eaf5e8;border:1px solid #c5e3bf;color:#2c5e27;padding:10px 12px;border-radius:10px;font-size:.9rem}
.muted{color:var(--soft)}
.hint{margin-top:16px;font-size:.86rem;color:var(--soft)}

/* ---- app shell ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--card);border-bottom:1px solid var(--line);padding:10px 18px}
.brand{font-family:var(--serif);font-size:19px;color:var(--ink)}.brand span{color:var(--accent)}.brand em{color:var(--soft);font-style:italic}
.topright{display:flex;align-items:center;gap:16px;font-size:.9rem}
.topright .who{color:var(--soft)}
.lnk{background:none;border:none;color:#1a5fb4;font-size:.9rem;padding:0}
.inline{display:inline;margin:0}
.layout{display:flex;min-height:calc(100vh - 53px)}
.sidebar{width:210px;flex:0 0 210px;background:var(--card);border-right:1px solid var(--line);padding:16px 12px}
.compose-btn{display:block;text-align:center;background:var(--accent);color:#fff;border-radius:10px;padding:11px;font-weight:bold;margin-bottom:16px}
.compose-btn:hover{background:#c4330f;text-decoration:none}
.folders{list-style:none;margin:0;padding:0}
.folders li a{display:flex;justify-content:space-between;align-items:center;padding:9px 11px;border-radius:9px;color:var(--ink)}
.folders li a:hover{background:#efe9da;text-decoration:none}
.folders li.active a{background:var(--ink);color:var(--paper);font-weight:600}
.folders .badge{background:var(--accent);color:#fff;border-radius:10px;font-size:.72rem;padding:1px 7px;min-width:18px;text-align:center}
.folders li.active .badge{background:var(--paper);color:var(--ink)}
.main{flex:1;padding:18px 22px;min-width:0}
.mobilenav{display:none}  /* desktop: hidden (sidebar handles nav); mobile: horizontal folder bar */

/* ---- message list ---- */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.toolbar h1{font-family:var(--serif);font-weight:normal;font-size:1.4rem;margin:0}
.searchform{display:flex;gap:6px}.searchform input{width:220px;padding:8px 10px}
.searchform button,.btn{background:var(--ink);color:var(--paper);border:none;border-radius:9px;padding:8px 14px;font-size:.85rem}
.btn.warn{background:var(--warn)}.btn.ghost{background:#efe9da;color:var(--ink)}
.mlist{list-style:none;margin:0;padding:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card)}
.mlist li{border-bottom:1px solid var(--line)}.mlist li:last-child{border-bottom:none}
.mlist a{display:grid;grid-template-columns:200px 1fr 130px;gap:12px;padding:11px 14px;color:var(--ink);align-items:center}
.mlist a:hover{background:#efe9da;text-decoration:none}
.mlist .unread{font-weight:700}
.mlist .from{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mlist .subj{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mlist .date{text-align:right;color:var(--soft);font-size:.82rem;white-space:nowrap}
.mlist .clip{color:var(--soft)}
.empty{padding:40px;text-align:center;color:var(--soft)}
.pager{display:flex;gap:10px;align-items:center;justify-content:center;margin-top:16px;color:var(--soft);font-size:.9rem}

/* ---- message view ---- */
.msgcard{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.msghead{padding:16px 18px;border-bottom:1px solid var(--line)}
.msghead h1{font-family:var(--serif);font-weight:normal;font-size:1.35rem;margin:0 0 8px}
.msgmeta{font-size:.88rem;color:var(--soft);line-height:1.6}
.msgmeta b{color:var(--ink);font-weight:600}
.msgactions{display:flex;gap:8px;flex-wrap:wrap;padding:12px 18px;border-bottom:1px solid var(--line);background:#fbf6ec}
.msgactions form{margin:0}
.imgbanner{background:#fff7e6;border:1px solid #f0dca8;color:#7a5c12;padding:9px 14px;font-size:.86rem;display:flex;justify-content:space-between;align-items:center}
.msgbody{width:100%;border:none;min-height:420px;background:#fff;display:block}
.attach{padding:12px 18px;border-top:1px solid var(--line)}
.attach a{display:inline-block;margin:4px 8px 4px 0;background:#efe9da;padding:6px 12px;border-radius:8px;color:var(--ink);font-size:.85rem}
.backlink{display:inline-block;margin-bottom:12px;font-size:.9rem}

/* ---- compose / settings ---- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px 22px;max-width:760px;margin-bottom:18px}
.panel h2{font-family:var(--serif);font-weight:normal;margin:0 0 12px}
.row2{display:flex;gap:12px}.row2>div{flex:1}
textarea.body{min-height:300px;font-family:inherit;resize:vertical}
textarea.sig{min-height:120px}
.formactions{margin-top:16px;display:flex;gap:10px}
.qr{display:block;margin:14px 0;border:1px solid var(--line);border-radius:10px;padding:10px;background:#fff;width:max-content}
code.secret{background:#efe9da;padding:4px 8px;border-radius:6px;font-size:.9rem;word-break:break-all}
@media(max-width:760px){
  .topbar{padding:9px 13px}
  .brand{font-size:16px}
  .topright{gap:11px}
  .topright .who{display:none}                 /* save space — email is on the Settings page */
  .sidebar{display:none}
  .mobilenav{display:flex;gap:7px;overflow-x:auto;padding:9px 11px;background:var(--card);
    border-bottom:1px solid var(--line);-webkit-overflow-scrolling:touch}
  .m-item{flex:0 0 auto;padding:7px 13px;border-radius:9px;background:#efe9da;color:var(--ink);
    font-size:.84rem;white-space:nowrap}
  .m-item:hover{text-decoration:none}
  .m-item.active{background:var(--ink);color:var(--paper);font-weight:600}
  .m-item.m-compose{background:var(--accent);color:#fff}
  .m-item b{background:var(--accent);color:#fff;border-radius:9px;padding:0 6px;font-size:.72rem;
    margin-left:3px;font-weight:700}
  .m-item.active b{background:var(--paper);color:var(--ink)}
  .layout{min-height:0}
  .main{padding:14px 13px}
  .mlist a{grid-template-columns:1fr 78px}
  .mlist .subj{display:none}
  .searchform input{width:140px}
  .panel{padding:16px 15px}
  .row2{flex-direction:column;gap:0}
  .msgbody{min-height:340px}
}
