/* css/pages/library.css — page-scoped styles for /library.

   Lifted verbatim from fragra_ui.html as part of the MPA Phase 4
   migration. Two source ranges combined:
     - first <style> block, base .lib-*, .formula-card / .fc-*, .empty-shelf-anim
     - second <style> block, the full .library-luxe + .lf-* (apothecary
       flip-card) override sheet

   The .library-luxe overrides use !important throughout because the
   SPA layered them on top of the base styles to redress the page.
   Both sets are needed: the base supplies layout/structure, the
   luxe layer paints the apothecary aesthetic. */

/* ── base .lib-* layout (lines ~2584-2606 in fragra_ui.html) ───────── */
.search-wrap{position:relative}
.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted2);font-size:13px}
.lib-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.lib-header h2{font-size:22px;font-weight:800;letter-spacing:-0.5px}
.lib-stats{display:flex;gap:6px;align-items:center;padding:0 0 14px;font-size:12px;color:var(--muted);letter-spacing:0.2px}
.lib-stats b{font-weight:700;color:var(--ink2)}
.lib-tabs{display:flex;gap:0;margin-bottom:14px;border-bottom:1px solid var(--line)}
.lib-tab{padding:9px 16px;font-size:11px;font-weight:600;letter-spacing:0.4px;text-transform:uppercase;color:var(--muted);cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;transition:all .2s;font-family:inherit}
.lib-tab:hover{color:var(--ink)}
.lib-tab.active{color:var(--ink);border-bottom-color:var(--ink)}
.lib-tab .tab-count{font-size:9px;background:var(--accent-soft);padding:1px 6px;border-radius:8px;margin-left:4px;font-weight:700}
.collections-strip{display:flex;gap:6px;overflow-x:auto;padding:0 0 12px;scrollbar-width:none}
.collections-strip::-webkit-scrollbar{display:none}
.lib-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.lib-toolbar .search-wrap{flex:1;min-width:160px;position:relative}
.lib-toolbar .search-wrap input{width:100%;padding:8px 12px 8px 32px;font-size:12px;border-radius:10px}
.lib-toolbar .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:12px;pointer-events:none}
.lib-toolbar-right{display:flex;gap:6px;align-items:center}
.lib-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:14px}

/* ── base .formula-card / .fc-* (lines ~2607-2648) ─────────────────── */
.formula-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:all .2s;position:relative}
.formula-card:hover{box-shadow:var(--shadow);border-color:var(--line2);transform:translateY(-2px)}
.fc-color-bar{height:48px;border-radius:14px 14px 0 0}
.fc-body{padding:14px 16px}
.fc-body-v2{padding:14px 16px 12px}
.fc-name{font-size:13px;font-weight:700;line-height:1.3;letter-spacing:-0.2px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fc-summary{font-size:11px;color:var(--muted);line-height:1.4;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.fc-badges{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:6px}
.fc-badge{font-size:9px;padding:2px 8px;border-radius:6px;font-weight:700;letter-spacing:0.2px}
.fc-badge-fit{background:rgba(180,160,80,0.12);color:#9a8a30}
.fc-badge-refined{background:rgba(100,140,100,0.12);color:var(--sage)}
.fc-badge-saved{background:rgba(90,138,160,0.1);color:#5a8aa0}
.fc-badge-public{background:rgba(100,100,200,0.1);color:#6464c8}
.fc-badge-friends{background:rgba(160,120,80,0.1);color:#a07850}
.fc-badge-fav{background:rgba(200,80,80,0.1);color:var(--rose,#d94040)}
.fc-title{font-size:14px;font-weight:700;margin-bottom:4px;line-height:1.3;letter-spacing:-0.2px}
.fc-sub{font-size:11px;color:var(--muted);line-height:1.4}
.fc-tags{display:flex;gap:4px;flex-wrap:wrap}
.fc-tag{font-size:9px;padding:3px 10px;border-radius:99px;font-weight:600;letter-spacing:0.3px;background:var(--accent-soft);color:var(--ink2)}
.fc-meta{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.fc-date{font-size:10px;color:var(--muted2)}
.fc-fav{background:none;border:none;cursor:pointer;font-size:14px;color:var(--muted2);transition:all .15s;padding:2px}
.fc-fav.active{color:var(--rose,#d94040)}
.fc-fav:hover{transform:scale(1.2)}
.formula-card:hover .fc-hover-actions{opacity:1}
.fc-delete{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,0.85);border:1px solid var(--line);color:var(--muted2);cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:all .15s}
.fc-delete:hover{background:rgba(200,50,50,0.85);transform:scale(1.1);color:#fff}

/* ── empty-state shelf (lines ~2671-2676) ─────────────────────────── */
.empty-shelf-anim{display:inline-block;padding:10px 20px}
.shelf-row{display:flex;gap:14px;align-items:flex-end;justify-content:center;padding:0 10px}
.shelf-bottle{width:22px;border-radius:4px 4px 2px 2px;position:relative}
.shelf-bottle.ghost{background:var(--line);opacity:0.4;animation:bottlePulse 2s ease-in-out infinite}
.shelf-bottle.ghost::after{content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:8px;height:6px;border-radius:2px 2px 0 0;background:var(--line2);opacity:0.5}
.shelf-base{height:3px;background:var(--line2);border-radius:2px;margin-top:2px;width:100%}
@keyframes bottlePulse{0%,100%{opacity:0.4}50%{opacity:0.7}}

/* ── responsive (lines ~4240-4250) ────────────────────────────────── */
@media (max-width: 700px){
  .lib-grid{grid-template-columns:1fr}
  .lib-header{flex-wrap:wrap;gap:8px}
  .lib-toolbar{flex-direction:column}
  .lib-toolbar .search-wrap{width:100%}
  .lib-toolbar-right{width:100%;justify-content:space-between}
  .lib-tabs{overflow-x:auto;scrollbar-width:none}
  .lib-tabs::-webkit-scrollbar{display:none}
  .lib-tab{padding:8px 10px;font-size:10px;white-space:nowrap}
  .lib-header h2{font-size:18px}
}

/* ════════════════════════════════════════════════════════════════════
   LUXURY LIBRARY PAGE (.library-luxe) — Le Labo / Aesop / Hermès
   Lifted verbatim from fragra_ui.html lines 7049-7725.
   ════════════════════════════════════════════════════════════════════ */

.library-luxe{
  position:relative;
  padding-top:24px !important;
  padding-bottom:60px !important;
}
.library-luxe::before{
  content:"";
  position:absolute;
  top:0;left:50%;transform:translateX(-50%);
  width:100vw;height:100%;
  z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 30% at 50% 0%, rgba(184,150,78,0.10), transparent 75%);
}

/* ── Page header ─────────────────────────────────────────────────── */
.library-luxe .lib-header{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:32px 0 24px;margin-bottom:8px;
  border-bottom:1px solid rgba(184,150,78,0.18);
}
.library-luxe .lib-eyebrow{
  font-family:var(--font-display, Georgia, serif);
  font-size:10px;letter-spacing:3.5px;font-weight:600;
  color:var(--gold2);text-transform:uppercase;margin-bottom:8px;
}
.library-luxe .lib-header h2{
  font-family:var(--font-display, Georgia, serif) !important;
  font-size:36px !important;font-weight:300 !important;font-style:italic !important;
  color:var(--ink) !important;letter-spacing:-0.6px !important;line-height:1.1 !important;
  margin:0 !important;
}
.library-luxe .lib-refresh-btn{
  border-radius:0 !important;
  font-size:10px !important;letter-spacing:2px !important;
  text-transform:uppercase;font-weight:600 !important;
  padding:9px 16px !important;
  background:transparent !important;
  border:1px solid rgba(184,150,78,0.30) !important;
  color:var(--ink2) !important;
}
.library-luxe .lib-refresh-btn:hover{
  border-color:var(--gold2) !important;color:var(--ink) !important;
  background:rgba(184,150,78,0.04) !important;
}

/* ── Stats line ──────────────────────────────────────────────────── */
.library-luxe .lib-stats{
  font-size:10px !important;letter-spacing:1.5px !important;
  color:var(--muted) !important;text-transform:uppercase;
  padding:14px 0 18px !important;
}

/* ── Tabs (All / Recent / Favorites / Refined / Saved) ──────────── */
.library-luxe .lib-tabs{
  border-bottom:1px solid rgba(184,150,78,0.18) !important;
  gap:0 !important;margin-bottom:20px !important;
}
.library-luxe .lib-tab{
  padding:11px 20px !important;
  font-family:var(--font-display, Georgia, serif) !important;
  font-size:10px !important;letter-spacing:2.5px !important;
  font-weight:600 !important;color:var(--muted) !important;
  text-transform:uppercase;background:transparent !important;
  border:none !important;border-bottom:1px solid transparent !important;
  transition:color .2s, border-color .2s;
}
.library-luxe .lib-tab:hover{color:var(--ink) !important}
.library-luxe .lib-tab.active{
  color:var(--ink) !important;
  border-bottom-color:var(--gold2) !important;
}
.library-luxe .lib-tab .tab-count{
  background:transparent !important;
  color:var(--gold2) !important;
  font-size:9px !important;font-weight:600 !important;
  padding:0 !important;margin-left:5px !important;
  letter-spacing:1.5px;
}

/* ── Family collection pills ───────────────────────────────────── */
.library-luxe .collections-strip{
  gap:8px !important;padding:0 0 22px !important;
}
.library-luxe .collection-pill{
  padding:8px 18px !important;
  border:1px solid rgba(184,150,78,0.30) !important;
  background:transparent !important;
  border-radius:0 !important;
  color:var(--ink2) !important;
  font-family:inherit !important;
  font-size:10.5px !important;font-weight:500 !important;
  letter-spacing:1.6px !important;text-transform:uppercase;
  transition:all .2s;
  cursor:pointer;
}
.library-luxe .collection-pill:hover{
  border-color:var(--gold2) !important;color:var(--ink) !important;
  background:rgba(184,150,78,0.04) !important;
}
.library-luxe .collection-pill.active{
  background:var(--ink) !important;color:#fff !important;
  border-color:var(--ink) !important;
}

/* ── Toolbar (search + sort + family + view toggle) ─────────────── */
.library-luxe .lib-toolbar{
  gap:14px !important;align-items:stretch !important;
  margin-bottom:24px !important;padding-bottom:8px !important;
}
.library-luxe .lib-toolbar .search-wrap{flex:1;min-width:200px !important}
.library-luxe .lib-toolbar .search-wrap input,
.library-luxe #libSearch{
  width:100% !important;
  padding:11px 14px 11px 38px !important;
  font-size:13px !important;font-family:inherit !important;
  background:transparent !important;
  border:none !important;
  border-bottom:1px solid rgba(184,150,78,0.30) !important;
  border-radius:0 !important;color:var(--ink) !important;
  letter-spacing:0.2px;
  transition:border-color .2s;
}
.library-luxe .lib-toolbar .search-wrap input::placeholder{
  color:var(--muted) !important;font-style:italic;
}
.library-luxe .lib-toolbar .search-wrap input:focus,
.library-luxe #libSearch:focus{
  outline:none !important;
  border-bottom-color:var(--gold2) !important;
}
.library-luxe .lib-toolbar .search-icon{
  left:12px !important;color:var(--gold2) !important;
}
.library-luxe .lib-toolbar-right{gap:10px !important}
.library-luxe #libSort,
.library-luxe #libFamilyFilter{
  background:transparent !important;
  border:none !important;
  border-bottom:1px solid rgba(184,150,78,0.30) !important;
  border-radius:0 !important;
  padding:11px 24px 11px 4px !important;
  font-family:inherit !important;font-size:12px !important;
  color:var(--ink) !important;letter-spacing:0.5px;
  cursor:pointer;width:auto !important;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%23a08855' stroke-width='1.4' d='M1 1l4 4 4-4'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 4px center !important;
}
.library-luxe #libSort:focus,
.library-luxe #libFamilyFilter:focus{
  outline:none !important;border-bottom-color:var(--gold2) !important;
}

/* ── Grid spacing ────────────────────────────────────────────────── */
.library-luxe .lib-grid{
  gap:24px !important;
  grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)) !important;
}

/* ── Formula card chrome ─────────────────────────────────────────── */
.library-luxe .formula-card{
  background:#fdfcf9 !important;
  border:1px solid rgba(184,150,78,0.18) !important;
  border-radius:0 !important;
  box-shadow:none !important;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.library-luxe .formula-card:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 12px 30px rgba(40,28,12,0.08) !important;
  border-color:rgba(184,150,78,0.36) !important;
}

/* ════════════════════════════════════════════════════════════════════
   FORMULA FLIP-CARD (.lf-card / .lf-flipper / .lf-front / .lf-back)
   Apothecary-style paper card with a cursive handwritten overlay.
   ════════════════════════════════════════════════════════════════════ */
.library-luxe .lf-card{
  position:relative;
  perspective:1400px;
  background:transparent !important;
  border:none !important;border-radius:0 !important;
  box-shadow:none !important;
  cursor:pointer;
  transition:transform .25s ease, filter .25s ease;
}
.library-luxe .lf-card:hover{
  transform:translateY(-3px) !important;
  filter:drop-shadow(0 16px 32px rgba(40,28,12,0.22));
}
.library-luxe .lf-flipper{
  position:relative;width:100%;aspect-ratio:2/3;
  transform-style:preserve-3d;
  transition:transform .85s cubic-bezier(0.55, 0.085, 0.265, 1);
}
.library-luxe .lf-flipper[data-flipped="true"]{transform:rotateY(180deg)}
.library-luxe .lf-face{
  position:absolute;inset:0;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  overflow:hidden;
}
.library-luxe .lf-front{z-index:2}
.library-luxe .lf-back{transform:rotateY(180deg)}

/* ── Parchment paper (.lf-paper) — real PNG texture ──────────────── */
.library-luxe .lf-paper{
  position:absolute;inset:0;
  padding:11% 10% 9% 10%;
  color:#3a2a18;
  font-family:'Caveat', 'Brush Script MT', cursive;
  display:flex;flex-direction:column;
  background-color:#ece2c9;
  background-image:url('/img/card-paper.png') !important;
  background-size:cover !important;
  background-position:center !important;
  background-repeat:no-repeat !important;
  box-shadow:none !important;
  clip-path:none !important;
}

/* ── Hand-drawn-looking horizontal rules ─────────────────────────── */
.library-luxe .lf-rule{
  width:100%;height:2px;flex-shrink:0;
  background-repeat:no-repeat;background-size:100% 100%;
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='2' viewBox='0 0 400 2' preserveAspectRatio='none'%3E%3Cpath d='M2 1.1 Q 30 0.6 60 1.2 T 120 1.0 T 180 1.3 T 240 0.8 T 300 1.2 T 360 0.9 T 398 1.1' stroke='%233a2818' stroke-width='0.9' fill='none' opacity='0.55' stroke-linecap='round'/%3E%3C/svg%3E");
  opacity:0.85;
}

/* ── FRONT layout ────────────────────────────────────────────────── */
.library-luxe .lf-name{
  font-family:'Fraunces', Georgia, serif;
  font-size:clamp(13.5px, 2vw, 17px);
  font-weight:400;font-style:italic;line-height:1.22;
  color:#2a1a08;
  text-align:center;
  padding:3% 0 5%;
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;
  overflow:hidden;text-overflow:ellipsis;
  letter-spacing:-0.1px;
  overflow-wrap:break-word;word-break:normal;hyphens:auto;
}
.library-luxe .lf-rule-name{margin-bottom:4%}
.library-luxe .lf-meta{
  text-align:center;
  font-family:'Fraunces', Georgia, serif;
  font-size:clamp(10.5px, 1.6vw, 12.5px);
  font-style:italic;font-weight:400;
  color:#6a4e28;letter-spacing:0.2px;
  margin-bottom:7%;
}
.library-luxe .lf-meta-dot{margin:0 6px;opacity:0.55}
.library-luxe .lf-section{margin-bottom:8%}
.library-luxe .lf-section-date{margin-top:auto;margin-bottom:0}
.library-luxe .lf-section-label{
  font-family:'Inter', sans-serif;
  font-size:clamp(9px, 1.4vw, 11px);
  letter-spacing:2.8px;text-transform:uppercase;
  color:#5a3e1c;font-weight:600;
  margin-bottom:6px;
}
.library-luxe .lf-notes{
  display:flex;flex-direction:column;
  gap:clamp(10px, 2vw, 16px);
}
.library-luxe .lf-note-line{
  border-bottom:none;
  padding-bottom:4px;
  min-height:clamp(20px, 3.3vw, 26px);
  font-size:clamp(13px, 2.1vw, 17px);
  line-height:clamp(20px, 3.3vw, 26px);
  color:#3a2818;
  background-repeat:no-repeat;background-position:bottom;background-size:100% 1.5px;
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='2' viewBox='0 0 400 2' preserveAspectRatio='none'%3E%3Cpath d='M2 1.1 Q 30 0.5 60 1.3 T 120 1.0 T 180 1.4 T 240 0.7 T 300 1.2 T 360 0.9 T 398 1.1' stroke='%233a2818' stroke-width='0.8' fill='none' opacity='0.45' stroke-linecap='round'/%3E%3C/svg%3E");
}
.library-luxe .lf-note-line:empty::before{content:" "}

.library-luxe .lf-section-impression{margin-bottom:6%}
.library-luxe .lf-impression{
  font-family:'Fraunces', 'Caveat', Georgia, serif;
  font-size:clamp(13px, 2vw, 15.5px);
  line-height:1.45;
  color:#3a2818;
  font-style:italic;font-weight:400;
  letter-spacing:0.05px;
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:4;
  overflow:hidden;text-overflow:ellipsis;
}
.library-luxe .lf-date-line{
  padding-bottom:4px;
  min-height:clamp(20px, 3.3vw, 26px);
  font-size:clamp(13px, 2.1vw, 17px);
  line-height:clamp(20px, 3.3vw, 26px);
  color:#3a2818;
  background-repeat:no-repeat;background-position:bottom;background-size:100% 1.5px;
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='2' viewBox='0 0 400 2' preserveAspectRatio='none'%3E%3Cpath d='M2 1.1 Q 30 0.7 60 1.2 T 120 0.9 T 180 1.3 T 240 0.8 T 300 1.2 T 360 1.0 T 398 1.1' stroke='%233a2818' stroke-width='0.8' fill='none' opacity='0.45' stroke-linecap='round'/%3E%3C/svg%3E");
}
.library-luxe .lf-front-tags{display:none !important}

/* ── BACK layout ─────────────────────────────────────────────────── */
.library-luxe .lf-back-title{
  font-family:'Fraunces', Georgia, serif;
  font-size:clamp(15px, 2.4vw, 19px);
  font-weight:400;font-style:italic;letter-spacing:0;text-transform:none;
  color:#2a1a08;
  margin-bottom:4px;text-align:center;
}
.library-luxe .lf-back-sub{
  text-align:center;
  font-family:'Fraunces', Georgia, serif;
  font-size:clamp(10.5px, 1.6vw, 12.5px);
  font-style:italic;color:#6a4e28;
  margin-bottom:10px;
}
.library-luxe .lf-rule-back{margin-bottom:8px}
.library-luxe .lf-back-header{
  display:grid;grid-template-columns:1fr 60px 60px;gap:8px;
  font-family:'Fraunces', Georgia, serif;
  font-size:clamp(10px, 1.6vw, 12.5px);
  font-style:italic;font-weight:400;
  color:#6a4e28;letter-spacing:0.1px;
  padding:2px 0;
}
.library-luxe .lf-col-amt,
.library-luxe .lf-col-mass{text-align:right}
.library-luxe .lf-rule-back-header{margin-bottom:4px}
.library-luxe .lf-back-rows{
  display:flex;flex-direction:column;gap:0;flex:1;
}
.library-luxe .lf-row{
  display:grid;grid-template-columns:1fr 60px 60px;gap:8px;
  align-items:flex-end;
  font-size:clamp(12px, 1.9vw, 15px);
  line-height:clamp(22px, 3.6vw, 27px);
  min-height:clamp(22px, 3.6vw, 27px);
  color:#3a2818;font-weight:500;
  padding-bottom:3px;
  background-repeat:no-repeat;background-position:bottom;background-size:100% 1.5px;
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='2' viewBox='0 0 400 2' preserveAspectRatio='none'%3E%3Cpath d='M2 1.1 Q 30 0.6 60 1.2 T 120 1.0 T 180 1.3 T 240 0.8 T 300 1.2 T 360 0.9 T 398 1.1' stroke='%233a2818' stroke-width='0.8' fill='none' opacity='0.40' stroke-linecap='round'/%3E%3C/svg%3E");
}
.library-luxe .lf-ing{
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.library-luxe .lf-amt,
.library-luxe .lf-mass{
  text-align:right;
  white-space:nowrap;
}
.library-luxe .lf-row-empty{
  display:block !important;
  text-align:center;color:#6a4a24;font-style:italic;font-weight:400;
}

/* ── Per-card 3-dot menu ─────────────────────────────────────────── */
.library-luxe .lf-menu-trigger{
  position:absolute;top:10px;right:10px;z-index:5;
  width:30px;height:30px;border-radius:50%;
  background:rgba(253,252,249,0.92);
  border:1px solid rgba(184,150,78,0.30);
  color:var(--ink2);
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .15s;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.library-luxe .lf-menu-trigger:hover{
  background:var(--ink);color:#fff;border-color:var(--ink);
}
.library-luxe .lf-menu{
  position:absolute;top:46px;right:10px;z-index:6;
  min-width:220px;
  background:#fdfcf9;
  border:1px solid rgba(184,150,78,0.30);
  box-shadow:0 14px 32px rgba(40,28,12,0.16);
  padding:6px 0;
}
.library-luxe .lf-menu[hidden]{display:none !important}
.library-luxe .lf-menu-item{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  width:100%;padding:10px 14px;
  background:transparent;border:none;
  font-family:inherit;font-size:11px;letter-spacing:1.6px;
  text-transform:uppercase;font-weight:600;color:var(--ink2);
  cursor:pointer;text-align:left;
  transition:background .15s, color .15s;
}
.library-luxe .lf-menu-item:hover{
  background:rgba(184,150,78,0.06);color:var(--ink);
}
.library-luxe .lf-menu-chip{
  font-family:var(--font-display, Georgia, serif);
  font-size:9px;letter-spacing:1.5px;color:var(--gold2);
  border:1px solid rgba(184,150,78,0.40);
  padding:2px 6px;font-weight:600;
}

/* ── Pagination ──────────────────────────────────────────────────── */
.library-luxe .lib-pager{
  display:flex;align-items:center;justify-content:center;
  gap:14px;flex-wrap:wrap;
  margin:36px auto 8px;padding:18px 0 0;
  border-top:1px solid rgba(184,150,78,0.15);
  max-width:760px;
}
.library-luxe .lib-pager-arrow{
  background:transparent;
  border:1px solid rgba(184,150,78,0.30);
  border-radius:0;
  padding:8px 16px;
  font-family:inherit;
  font-size:10.5px;font-weight:600;
  letter-spacing:1.6px;text-transform:uppercase;
  color:var(--ink2);cursor:pointer;
  transition:all .2s;
}
.library-luxe .lib-pager-arrow:hover:not([disabled]){
  border-color:var(--gold2);color:var(--ink);
  background:rgba(184,150,78,0.04);
}
.library-luxe .lib-pager-arrow[disabled]{
  opacity:0.35;cursor:not-allowed;
}
.library-luxe .lib-pager-pages{
  display:inline-flex;align-items:center;gap:4px;
}
.library-luxe .lib-pager-num{
  background:transparent;border:none;cursor:pointer;
  width:30px;height:30px;
  font-family:var(--font-display, Georgia, serif);
  font-size:13px;color:var(--ink2);
  transition:color .15s, background .15s;
  border-radius:0;
}
.library-luxe .lib-pager-num:hover{color:var(--ink)}
.library-luxe .lib-pager-num.is-active{
  color:#fff;background:var(--ink);
}
.library-luxe .lib-pager-ellipsis{
  color:var(--muted);padding:0 4px;font-size:13px;
}
.library-luxe .lib-pager-count{
  font-family:var(--font-display, Georgia, serif);
  font-size:10px;letter-spacing:1.6px;
  color:var(--muted);text-transform:uppercase;
  margin-left:8px;
}
@media (max-width:700px){
  .library-luxe .lib-pager{gap:8px;padding-top:14px;margin-top:24px}
  .library-luxe .lib-pager-count{flex-basis:100%;text-align:center;margin:6px 0 0}
}

/* ── Mobile ──────────────────────────────────────────────────────── */
@media (max-width:700px){
  .library-luxe .lib-header h2{font-size:28px !important}
  .library-luxe .lib-toolbar{flex-direction:column;align-items:stretch !important}
  .library-luxe .lib-grid{gap:14px !important;grid-template-columns:1fr !important}
}

/* ── Recipe-PDF banner (shown on /library?recipe_pdf=1 from /shop) ── */
.lib-pdf-banner{
  margin:0 auto 18px;max-width:1180px;padding:0 24px;
}
.lib-pdf-banner-inner{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 18px;
  background:rgba(184,150,78,0.08);
  border:1px solid rgba(184,150,78,0.30);
  border-radius:2px;
  font-size:13px;color:var(--ink, #1a1410);line-height:1.55;
}
.lib-pdf-banner-eyebrow{
  font-family:'Fraunces', Georgia, serif;
  font-size:10px;letter-spacing:2.5px;font-weight:600;
  color:#a08855;text-transform:uppercase;
  white-space:nowrap;padding-top:3px;
}
.lib-pdf-banner-main{flex:1}
.lib-pdf-banner-main b{font-weight:600}
.lib-pdf-banner-dismiss{
  background:transparent;border:none;cursor:pointer;
  font-size:20px;line-height:1;color:#a08855;
  padding:0;width:24px;height:24px;flex-shrink:0;
}
.lib-pdf-banner-dismiss:hover{color:var(--ink, #1a1410)}
@media (max-width:600px){
  .lib-pdf-banner-inner{flex-direction:column;align-items:flex-start;gap:8px}
}
