/* ============================================================
   The St James's Household & Travelling Companion
   Typographic catalogue — cream paper, oxblood rules, engraved serifs
   ============================================================ */

/* ---- Fonts (self-hosted, offline-safe) ---- */
@font-face{font-family:'EB Garamond';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/ebgaramond-400.woff2') format('woff2');}
@font-face{font-family:'EB Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/ebgaramond-500.woff2') format('woff2');}
@font-face{font-family:'EB Garamond';font-style:italic;font-weight:400;font-display:swap;src:url('assets/fonts/ebgaramond-400i.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/cormorant-500.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/cormorant-600.woff2') format('woff2');}

:root{
  --paper:#f4eee0;
  --paper-edge:#efe7d4;
  --card:#f7f2e6;
  --ink:#211c16;
  --ink-soft:#5a4f43;
  --ink-faint:#8a7d6a;
  --oxblood:#7c2621;
  --oxblood-soft:#9a4038;
  --rule:#cdc2a6;
  --rule-faint:#ddd3ba;
  --gold:#8a7a44;
  --display:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --body:'EB Garamond',Georgia,'Palatino Linotype','Book Antiqua',serif;
  --maxw:680px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:18px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-bottom:env(safe-area-inset-bottom);
}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;color:inherit;cursor:pointer;}

/* ---- Shell ---- */
.app{max-width:var(--maxw);margin:0 auto;min-height:100vh;position:relative;}
.view{padding:22px 20px 96px;animation:fade .35s ease;}
@keyframes fade{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

/* ---- Eyebrow / labels (the engraved small-caps look) ---- */
.label{
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--oxblood);font-weight:500;
}
.muted{color:var(--ink-faint);}

/* ---- Top bar ---- */
.topbar{
  display:flex;align-items:center;gap:14px;
  padding:14px 20px 12px;max-width:var(--maxw);margin:0 auto;
  border-bottom:1px solid var(--rule);
}
.topbar .back{
  font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--oxblood);
  background:none;border:none;padding:6px 0;
}
.topbar .crumb{
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);
  margin-left:auto;
}

/* ============================================================
   FRONTISPIECE
   ============================================================ */
.frontispiece{text-align:center;padding-top:38px;}
.emblem{width:108px;height:auto;margin:0 auto 22px;display:block;opacity:.95;}
.fp-the{font-size:13px;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px;}
.fp-title{
  font-family:var(--display);font-weight:600;line-height:1.02;
  font-size:clamp(40px,12vw,62px);margin:0 0 4px;letter-spacing:.005em;
}
.fp-title .amp{color:var(--oxblood);font-style:italic;font-weight:500;}
.fp-rule{display:flex;align-items:center;justify-content:center;gap:12px;margin:18px auto 16px;color:var(--oxblood);}
.fp-rule::before,.fp-rule::after{content:"";height:1px;width:60px;background:var(--oxblood);opacity:.5;}
.fp-sub{font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:var(--oxblood);margin:0;}
.fp-compiled{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-faint);margin-top:10px;}

/* Search */
.search-wrap{margin:30px auto 8px;max-width:520px;position:relative;}
.search{
  width:100%;background:var(--card);border:1px solid var(--rule);
  padding:14px 16px 14px 42px;font-family:var(--body);font-size:17px;color:var(--ink);
  outline:none;border-radius:2px;
}
.search:focus{border-color:var(--oxblood);box-shadow:0 0 0 2px rgba(124,38,33,.12);}
.search-wrap::before{
  content:"";position:absolute;left:15px;top:50%;width:15px;height:15px;
  transform:translateY(-50%);opacity:.55;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237c2621' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
}
.search-hint{font-size:13px;color:var(--ink-faint);text-align:center;margin-top:10px;font-style:italic;}

/* Frontispiece nav list — reads as a contents stub */
.fp-nav{max-width:520px;margin:26px auto 0;border-top:1px solid var(--rule);}
.fp-nav a{
  display:flex;align-items:baseline;gap:12px;padding:15px 4px;border-bottom:1px solid var(--rule-faint);
}
.fp-nav a .rom{font-size:12px;letter-spacing:.1em;color:var(--oxblood);min-width:30px;}
.fp-nav a .nm{font-size:19px;}
.fp-nav a .ct{margin-left:auto;font-size:13px;color:var(--ink-faint);}

/* ============================================================
   TABLE OF CONTENTS
   ============================================================ */
.page-head{text-align:center;margin-bottom:22px;}
.page-head h1{
  font-family:var(--display);font-weight:600;font-size:34px;margin:2px 0 0;line-height:1.08;
}
.page-head .label{display:block;margin-bottom:6px;}
.toc{border-top:1px solid var(--rule);}
.toc-row{
  display:flex;align-items:baseline;gap:14px;
  padding:16px 4px;border-bottom:1px solid var(--rule-faint);
}
.toc-row .rom{font-size:13px;color:var(--oxblood);min-width:34px;letter-spacing:.06em;}
.toc-row .ttl{font-size:17px;flex:1;}
.toc-row .ttl small{display:block;font-size:13px;color:var(--ink-faint);letter-spacing:.04em;margin-top:1px;}
.toc-row .ct{font-size:13px;color:var(--ink-faint);font-variant-numeric:tabular-nums;}
.toc-sep{padding:18px 4px 6px;font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);}

/* ============================================================
   REGISTER LINE
   ============================================================ */
.register{border-top:1px solid var(--rule);}
.rline{
  display:block;padding:14px 4px 15px;border-bottom:1px solid var(--rule-faint);
}
.rline:active{background:var(--paper-edge);}
.rline-top{display:flex;align-items:baseline;gap:10px;margin-bottom:2px;}
.rline-no{font-size:12px;letter-spacing:.08em;color:var(--oxblood);font-variant-numeric:tabular-nums;min-width:54px;}
.rline-house{font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);}
.rline-article{font-family:var(--display);font-size:21px;font-weight:600;line-height:1.12;}
.rline-meta{font-size:14px;color:var(--ink-soft);font-style:italic;margin-top:1px;}
.rline-meta .sep{color:var(--rule);font-style:normal;margin:0 6px;}

/* Filters */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 16px;}
.chip{
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  padding:7px 12px;border:1px solid var(--rule);background:var(--card);color:var(--ink-soft);
  border-radius:2px;
}
.chip.on{border-color:var(--oxblood);color:var(--oxblood);background:#f3e8dd;}
.filter-bar{position:relative;margin-bottom:14px;}
.filter-select{
  width:100%;-webkit-appearance:none;appearance:none;background:var(--card);
  border:1px solid var(--rule);padding:11px 14px;font-family:var(--body);font-size:15px;color:var(--ink);
  border-radius:2px;
}
.row-count{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 10px;text-align:right;}

/* ============================================================
   CATALOGUE CARD (short)
   ============================================================ */
.card{
  background:var(--card);border:1px solid var(--rule);border-radius:2px;
  padding:16px 18px 18px;margin-bottom:14px;position:relative;
}
.card-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;
  padding-bottom:8px;margin-bottom:10px;border-bottom:1px solid var(--rule-faint);}
.card-no{font-size:12px;letter-spacing:.1em;color:var(--oxblood);font-variant-numeric:tabular-nums;}
.card-dept{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);text-align:right;}
.card-house{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1px;}
.card-article{font-family:var(--display);font-size:24px;font-weight:600;line-height:1.08;margin-bottom:10px;}
.card-field{margin-top:9px;}
.card-field .label{display:block;margin-bottom:1px;}
.card-field .val{font-size:16px;}
.card-field .val.ital{font-style:italic;}
.card-standing{margin-top:12px;padding-top:10px;border-top:1px solid var(--rule-faint);
  font-style:italic;color:var(--ink-soft);font-size:15px;}

/* ============================================================
   ARTICLE NOTICE (full)
   ============================================================ */
.notice{
  background:var(--card);border:1.5px solid var(--oxblood);border-radius:2px;
  padding:0;overflow:hidden;
}
.notice-inner{border:1px solid var(--oxblood);margin:5px;padding:24px 22px 20px;}
.notice-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.notice-no{font-size:13px;letter-spacing:.08em;color:var(--ink);font-variant-numeric:tabular-nums;}
.notice-dept-r{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--oxblood);text-align:right;line-height:1.4;max-width:48%;}
.notice-divider{display:flex;align-items:center;justify-content:center;gap:10px;margin:14px 0 18px;color:var(--oxblood);}
.notice-divider::before,.notice-divider::after{content:"";height:1px;flex:1;background:var(--oxblood);opacity:.45;}
.notice-divider span{font-size:13px;}
.notice-title{font-family:var(--display);font-weight:600;font-size:clamp(30px,8vw,40px);
  line-height:1.04;text-align:center;margin:0;}
.notice-house{text-align:center;font-size:17px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);margin:8px 0 4px;}
.notice-house .dot{display:block;width:40px;height:1px;background:var(--oxblood);opacity:.5;margin:14px auto;}
.field{padding:13px 0;border-bottom:1px solid var(--rule-faint);}
.field:last-of-type{border-bottom:none;}
.field .label{display:block;margin-bottom:3px;}
.field .val{font-size:17px;line-height:1.45;}
.field .val.exact{font-size:19px;}
.field .val.price{font-size:22px;font-family:var(--display);font-weight:600;}
.field .val.em{font-style:italic;color:var(--ink-soft);}
.field .val.empty{color:var(--ink-faint);}
.notice-foot{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px;color:var(--oxblood);opacity:.7;font-size:14px;}
.notice-foot::before,.notice-foot::after{content:"";height:1px;width:46px;background:var(--oxblood);opacity:.5;}

/* Secondary actions (discreet, never a marchand CTA) */
.actions{display:flex;gap:10px;justify-content:center;margin:18px 0 0;flex-wrap:wrap;}
.act{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--oxblood);
  background:none;border:1px solid var(--rule);padding:9px 16px;border-radius:2px;
}
.act:active{background:var(--paper-edge);}
.act.primary{background:var(--oxblood);color:var(--paper);border-color:var(--oxblood);}

/* ============================================================
   DEPARTMENT HEADER
   ============================================================ */
.dept-head{text-align:center;margin-bottom:8px;}
.dept-vignette{width:100%;max-width:560px;height:auto;display:block;margin:6px auto 2px;mix-blend-mode:multiply;}
.dept-rom{font-size:13px;letter-spacing:.2em;color:var(--oxblood);}
.dept-title{font-family:var(--display);font-weight:600;font-size:clamp(26px,7vw,34px);
  line-height:1.06;margin:6px auto 4px;max-width:520px;}
.dept-rule{height:1px;background:var(--oxblood);opacity:.4;max-width:120px;margin:14px auto 22px;}
.class-nav{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:20px;}
.class-nav .chip{cursor:pointer;}

/* ============================================================
   HOUSE INDEX
   ============================================================ */
.hindex{border-top:1px solid var(--rule);}
.hrow{display:flex;align-items:baseline;gap:12px;padding:15px 4px;border-bottom:1px solid var(--rule-faint);}
.hrow .hname{font-family:var(--display);font-size:21px;font-weight:600;line-height:1.1;}
.hrow .hspec{font-size:13px;color:var(--ink-faint);font-style:italic;margin-top:1px;}
.hrow .hct{margin-left:auto;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--oxblood);white-space:nowrap;}

/* ============================================================
   FORMS
   ============================================================ */
.form-section{margin-bottom:20px;}
.form-section > .label{display:block;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--rule);}
.fg{margin-bottom:15px;}
.fg label{display:block;font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:5px;}
.fg label .req{color:var(--oxblood);}
.fg input,.fg textarea,.fg select{
  width:100%;background:var(--card);border:1px solid var(--rule);border-radius:2px;
  padding:11px 13px;font-family:var(--body);font-size:16px;color:var(--ink);outline:none;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--oxblood);box-shadow:0 0 0 2px rgba(124,38,33,.1);}
.fg textarea{min-height:74px;resize:vertical;line-height:1.45;}
.fg select{-webkit-appearance:none;appearance:none;}
.fg-row{display:flex;gap:12px;}
.fg-row .fg{flex:1;}
.fg-price{flex:0 0 96px;}
.disclose{
  background:none;border:1px dashed var(--rule);width:100%;text-align:left;
  padding:13px 14px;border-radius:2px;color:var(--oxblood);
  font-size:12px;letter-spacing:.13em;text-transform:uppercase;margin-bottom:18px;
}
.form-actions{display:flex;gap:10px;margin-top:8px;}
.form-actions .act{flex:1;text-align:center;padding:13px;}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty{text-align:center;padding:48px 20px;color:var(--ink-faint);}
.empty .em-mark{font-family:var(--display);font-size:40px;color:var(--oxblood);opacity:.5;margin-bottom:10px;}
.empty p{font-size:16px;margin:6px 0;}
.empty .empty-act{margin-top:18px;}

/* ============================================================
   BOTTOM NAV
   ============================================================ */
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:20;
  background:var(--paper-edge);border-top:1px solid var(--rule);
  display:flex;max-width:var(--maxw);margin:0 auto;
  padding-bottom:env(safe-area-inset-bottom);
}
.tabbar a{
  flex:1;text-align:center;padding:9px 4px 8px;
  font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);
  border-right:1px solid var(--rule-faint);
}
.tabbar a:last-child{border-right:none;}
.tabbar a.on{color:var(--oxblood);}
.tabbar a .ic{display:block;font-family:var(--display);font-size:19px;line-height:1;margin-bottom:3px;color:inherit;}
.tabbar a.add .ic{color:var(--oxblood);}

/* Toast */
.toast{
  position:fixed;left:50%;bottom:78px;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:2px;
  font-size:13px;letter-spacing:.08em;opacity:0;pointer-events:none;transition:.3s;z-index:40;
  max-width:88vw;text-align:center;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* utilities */
.hidden{display:none!important;}
:focus-visible{outline:2px solid var(--oxblood);outline-offset:2px;}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}
