/* ============================================================
   TERRA HOME — Catálogo Mayorista
   Paleta y tipografías según Manual de Marca
   ============================================================ */
:root{
  --gold:#B5946A;
  --gold-deep:#9C7C53;
  --choco:#4A3A2C;
  --choco-soft:#6A574545;
  --beige:#E7DCCB;
  --beige-soft:#EFE7D8;
  --crema:#F6F1E8;
  --blanco:#FFFFFF;
  --line:#D8C9B2;

  --font-serif:'Cormorant Garamond', Georgia, serif;
  --font-script:'Parisienne', cursive;
  --font-sans:'Jost', system-ui, sans-serif;

  --sheet-w:210mm;
  --sheet-h:297mm;
  --pad:18mm;
}

*{ box-sizing:border-box; }

html,body{ margin:0; padding:0; }
body{
  font-family:var(--font-sans);
  background:#cdbfa8;
  color:var(--choco);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ============================================================
   TOOLBAR
   ============================================================ */
.toolbar{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:18px;
  padding:11px 20px;
  background:rgba(246,241,232,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 14px rgba(74,58,44,.10);
}
.tb-brand{
  display:flex; align-items:baseline; gap:9px;
  font-family:var(--font-serif);
  letter-spacing:.18em; font-size:15px; font-weight:600;
  color:var(--choco); text-transform:uppercase;
  white-space:nowrap;
}
.tb-brand small{
  font-family:var(--font-sans);
  letter-spacing:.14em; font-size:9.5px; font-weight:500;
  color:var(--gold-deep); text-transform:uppercase;
}
.tb-spacer{ flex:1; }
.tb-group{ display:flex; align-items:center; gap:8px; }
.tb-label{
  font-size:9.5px; letter-spacing:.13em; text-transform:uppercase;
  color:var(--gold-deep); font-weight:600;
}

.btn{
  font-family:var(--font-sans); font-size:12.5px; font-weight:500;
  letter-spacing:.04em;
  padding:8px 15px; border-radius:2px; cursor:pointer;
  border:1px solid var(--line); background:var(--blanco); color:var(--choco);
  transition:all .16s ease; white-space:nowrap;
  display:inline-flex; align-items:center; gap:7px;
}
.btn:hover{ border-color:var(--gold); color:var(--gold-deep); }
.btn svg{ width:15px; height:15px; }
.btn-primary{
  background:var(--choco); color:var(--crema); border-color:var(--choco);
}
.btn-primary:hover{ background:var(--gold-deep); border-color:var(--gold-deep); color:#fff; }
.btn-ghost{ background:transparent; border-color:transparent; color:var(--gold-deep); }
.btn-ghost:hover{ background:var(--beige-soft); color:var(--choco); }

/* segmented control for cover style */
.seg{ display:flex; border:1px solid var(--line); border-radius:2px; overflow:hidden; background:#fff; }
.seg button{
  font-family:var(--font-sans); font-size:12px; font-weight:500;
  padding:7px 12px; border:0; background:transparent; color:var(--choco);
  cursor:pointer; transition:all .14s; border-left:1px solid var(--line);
}
.seg button:first-child{ border-left:0; }
.seg button.active{ background:var(--gold); color:#fff; }

.tb-hint{
  font-size:11px; color:var(--gold-deep); letter-spacing:.02em;
}
.tb-hint b{ color:var(--choco); font-weight:600; }

/* ============================================================
   PAGES / SHEETS
   ============================================================ */
#pages{
  display:flex; flex-direction:column; align-items:center;
  gap:26px; padding:34px 16px 80px;
}
.sheet{
  width:var(--sheet-w); min-height:var(--sheet-h);
  background:var(--crema);
  position:relative; overflow:hidden;
  box-shadow:0 10px 40px rgba(74,58,44,.22);
  display:flex; flex-direction:column;
}
.sheet-pad{ padding:var(--pad); flex:1; display:flex; flex-direction:column; }

/* page footer number */
.pagemark{
  position:absolute; bottom:10mm; left:0; right:0;
  text-align:center; font-size:9px; letter-spacing:.32em;
  color:var(--gold-deep); text-transform:uppercase;
  font-family:var(--font-sans);
}
.pagemark::before{ content:'TERRA HOME · '; }

/* ============================================================
   EDITABLE AFFORDANCES
   ============================================================ */
[contenteditable]{ outline:none; cursor:text; border-radius:2px; transition:background .12s, box-shadow .12s; }
[contenteditable]:hover{ background:rgba(181,148,106,.10); box-shadow:0 0 0 3px rgba(181,148,106,.10); }
[contenteditable]:focus{ background:rgba(181,148,106,.14); box-shadow:0 0 0 2px var(--gold); }
[contenteditable]:empty:before{ content:attr(data-ph); color:var(--gold); opacity:.55; }

/* photo slots */
.photo{
  position:relative; cursor:pointer; overflow:hidden;
  background:repeating-linear-gradient(45deg,#EAE0CF,#EAE0CF 9px,#E2D6C1 9px,#E2D6C1 18px);
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line);
  transition:box-shadow .14s;
}
.photo:hover{ box-shadow:inset 0 0 0 2px var(--gold); }
.photo img{ width:100%; height:100%; object-fit:cover; display:block; user-select:none; -webkit-user-drag:none; }
.photo.has-img{ cursor:grab; }
.photo.dragging{ cursor:grabbing; }
.photo .ph-label{
  font-family:'Courier New',monospace; font-size:10.5px; letter-spacing:.08em;
  color:var(--gold-deep); text-align:center; text-transform:uppercase;
  padding:8px 12px; line-height:1.6; pointer-events:none;
}
.photo .ph-label .plus{ display:block; font-size:22px; margin-bottom:4px; font-weight:300; }

/* photo reposition controls */
.photo-ctrls{ position:absolute; top:8px; right:8px; z-index:5; display:flex; gap:6px; opacity:0; transition:opacity .15s; }
.photo.has-img:hover .photo-ctrls{ opacity:1; }
.photo-btn{
  font-family:var(--font-sans); font-size:10.5px; letter-spacing:.03em; font-weight:500;
  padding:5px 9px; border-radius:2px; border:1px solid rgba(255,255,255,.55);
  background:rgba(74,58,44,.82); color:#fff; cursor:pointer;
  backdrop-filter:blur(3px); display:inline-flex; align-items:center; gap:5px;
}
.photo-btn svg{ width:13px; height:13px; }
.photo-btn:hover{ background:var(--gold-deep); border-color:var(--gold-deep); }
.photo-hint{
  position:absolute; bottom:9px; left:50%; transform:translateX(-50%); z-index:5;
  font-family:var(--font-sans); font-size:10.5px; letter-spacing:.04em; font-weight:500;
  color:#fff; background:rgba(74,58,44,.72); padding:5px 11px; border-radius:20px;
  display:inline-flex; align-items:center; gap:5px;
  opacity:0; transition:opacity .15s; pointer-events:none; white-space:nowrap;
}
.photo.has-img:hover .photo-hint{ opacity:1; }
.photo.dragging .photo-hint, .photo.dragging .photo-ctrls{ opacity:0; }

/* ============================================================
   COVER (3 variations)
   ============================================================ */
.cover{ flex:1; display:flex; position:relative; }
.cover .min-note{
  font-family:var(--font-sans); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase;
}

/* monogram default logo */
.logo-slot{ cursor:pointer; position:relative; display:inline-flex; align-items:center; justify-content:center; }
.logo-slot img{ max-width:100%; max-height:100%; object-fit:contain; }
.logo-slot:hover .mono{ box-shadow:0 0 0 2px var(--gold); }
.mono{
  display:flex; flex-direction:column; align-items:center; gap:7px;
  padding:18px 22px;
  transition:box-shadow .14s; border-radius:3px;
}
.mono .glyph{
  font-family:var(--font-serif); font-weight:600;
  letter-spacing:.06em; line-height:1;
  border:1px solid currentColor; border-radius:50%;
  width:74px; height:74px; display:flex; align-items:center; justify-content:center;
  font-size:30px;
}
.mono .mono-name{ font-family:var(--font-serif); letter-spacing:.34em; font-size:13px; font-weight:500; text-transform:uppercase; }
.logo-slot .edit-tag{
  position:absolute; bottom:-18px; left:50%; transform:translateX(-50%);
  font-family:var(--font-sans); font-size:8.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--gold-deep); opacity:0; transition:opacity .14s; white-space:nowrap;
}
.logo-slot:hover .edit-tag{ opacity:1; }

/* --- Cover A: centered classic --- */
.cover-a{ flex-direction:column; align-items:center; justify-content:center; text-align:center; }
.cover-a::before{
  content:''; position:absolute; inset:9mm;
  border:1px solid var(--gold); pointer-events:none;
}
.cover-a::after{
  content:''; position:absolute; inset:11mm;
  border:1px solid rgba(181,148,106,.4); pointer-events:none;
}
.cover-a .ca-logo{ margin-bottom:30px; }
.cover-a .ca-title{
  font-family:var(--font-serif); font-weight:500;
  font-size:62px; line-height:1.02; letter-spacing:.14em;
  text-transform:uppercase; color:var(--choco); margin:0;
}
.cover-a .ca-tag{
  font-family:var(--font-sans); font-size:12px; letter-spacing:.42em;
  text-transform:uppercase; color:var(--gold-deep); margin:18px 0 0;
}
.cover-a .ca-cat{
  font-family:var(--font-script); font-size:46px; color:var(--gold-deep);
  margin:40px 0 0; line-height:1;
}
.cover-a .min-note{ position:absolute; bottom:20mm; left:0; right:0; color:var(--gold-deep); }

/* --- Cover B: editorial split --- */
.cover-b{ flex-direction:row; }
.cover-b .cb-panel{
  width:46%; background:var(--choco); color:var(--crema);
  padding:24mm 16mm; display:flex; flex-direction:column; justify-content:space-between;
}
.cover-b .cb-logo .mono{ color:var(--crema); }
.cover-b .cb-title{
  font-family:var(--font-serif); font-weight:500; font-size:50px; line-height:1.05;
  letter-spacing:.1em; text-transform:uppercase; margin:0;
}
.cover-b .cb-cat{ font-family:var(--font-script); font-size:38px; color:var(--gold); margin:14px 0 0; }
.cover-b .cb-tag{ font-family:var(--font-sans); font-size:11px; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); margin:0 0 18px; }
.cover-b .cb-photo{ width:54%; }
.cover-b .min-note{ color:var(--gold); }

/* --- Cover C: full photo hero --- */
.cover-c{ align-items:stretch; }
.cover-c .cc-photo{ position:absolute; inset:0; border:0; }
.cover-c .cc-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(40,30,22,.28) 0%, rgba(40,30,22,.10) 38%, rgba(40,30,22,.62) 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; color:#fff; padding:24mm;
  pointer-events:none;
}
.cover-c .cc-overlay .logo-slot,
.cover-c .cc-overlay [contenteditable],
.cover-c .cc-overlay .min-note{ pointer-events:auto; }
.cover-c .cc-frame{ pointer-events:none; }
.cover-c .cc-frame{ position:absolute; inset:10mm; border:1px solid rgba(255,255,255,.5); pointer-events:none; }
.cover-c .cc-logo .mono{ color:#fff; }
.cover-c .cc-title{
  font-family:var(--font-serif); font-weight:500; font-size:58px; line-height:1.04;
  letter-spacing:.14em; text-transform:uppercase; margin:26px 0 0;
  text-shadow:0 2px 18px rgba(0,0,0,.35);
}
.cover-c .cc-cat{ font-family:var(--font-script); font-size:42px; margin:14px 0 0; color:#fff; text-shadow:0 2px 16px rgba(0,0,0,.4); }
.cover-c .cc-tag{ font-family:var(--font-sans); font-size:11px; letter-spacing:.4em; text-transform:uppercase; margin:18px 0 0; color:rgba(255,255,255,.85); }
.cover-c .min-note{ position:absolute; bottom:18mm; left:0; right:0; color:rgba(255,255,255,.92); text-shadow:0 1px 8px rgba(0,0,0,.4); }

/* ============================================================
   SECTION HEADERS (interior pages)
   ============================================================ */
.section-eyebrow{
  font-family:var(--font-sans); font-size:11px; letter-spacing:.4em;
  text-transform:uppercase; color:var(--gold-deep); margin:0 0 12px;
  display:flex; align-items:center; gap:12px;
}
.section-eyebrow::before{ content:''; width:34px; height:1px; background:var(--gold); display:inline-block; }
.section-title{
  font-family:var(--font-serif); font-weight:500; font-size:42px; line-height:1.08;
  letter-spacing:.04em; color:var(--choco); margin:0 0 6px;
}
.rule-gold{ height:1px; background:var(--line); margin:18px 0 26px; }

/* QUIÉNES SOMOS */
.about-body{
  font-family:var(--font-serif); font-size:24px; line-height:1.7; color:var(--choco);
  max-width:62ch; font-weight:400;
}
.about-quote{
  font-family:var(--font-script); font-size:38px; color:var(--gold-deep);
  margin-top:34px; line-height:1.2;
}
.about-photo{ margin-top:auto; height:78mm; width:100%; }

/* POR QUÉ ELEGIR */
.why-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px 32px; margin-top:6px; }
.why-item{ display:flex; flex-direction:column; gap:6px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.why-num{ font-family:var(--font-serif); font-size:20px; color:var(--gold); font-weight:600; }
.why-t{ font-family:var(--font-serif); font-size:23px; font-weight:600; color:var(--choco); letter-spacing:.01em; }
.why-d{ font-family:var(--font-sans); font-size:13px; line-height:1.6; color:#6a5a48; }

/* ============================================================
   PRODUCT GRID  (2 columns)
   ============================================================ */
.cat-head{ margin-bottom:8px; }
.cat-sub{ font-family:var(--font-sans); font-size:13.5px; line-height:1.6; color:#6a5a48; max-width:64ch; margin:2px 0 0; }
.prod-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:22px; }

.card{
  background:var(--blanco); border:1px solid var(--line);
  display:flex; flex-direction:column; position:relative;
  break-inside:avoid;
}
.card .photo{ height:52mm; border:0; border-bottom:1px solid var(--line); }
.card-body{ padding:16px 18px 18px; display:flex; flex-direction:column; gap:9px; flex:1; }
.card-name{
  font-family:var(--font-script); font-size:30px; line-height:.95; color:var(--choco);
  margin:0;
}
.card-notes{
  font-family:var(--font-sans); font-size:13px; line-height:1.55; color:var(--choco); font-weight:400;
  min-height:2.7em;
}
.specs{ display:flex; gap:0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.spec{ flex:1; padding:8px 4px; text-align:center; border-left:1px solid var(--line); }
.spec:first-child{ border-left:0; }
.spec .sl{ font-family:var(--font-sans); font-size:8px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep); display:flex; align-items:center; justify-content:center; gap:3px; margin-bottom:3px; }
.spec .sv{ font-family:var(--font-sans); font-size:12px; font-weight:600; color:var(--choco); }
.spec-info{
  display:inline-flex; align-items:center; justify-content:center;
  width:13px; height:13px; padding:0; border-radius:50%;
  border:1px solid var(--gold); background:transparent; color:var(--gold-deep);
  font-family:var(--font-serif); font-style:italic; font-weight:700; font-size:9px; line-height:1;
  cursor:pointer; transition:all .14s; flex:0 0 auto;
}
.spec-info:hover{ background:var(--gold); color:#fff; }

/* glossary popover */
.glo-pop{
  position:absolute; z-index:200; background:#fff; border:1px solid var(--line);
  box-shadow:0 16px 44px rgba(74,58,44,.24); padding:16px 18px 17px; border-radius:3px;
}
.glo-arrow{ position:absolute; top:-7px; width:12px; height:12px; background:#fff; border-left:1px solid var(--line); border-top:1px solid var(--line); transform:rotate(45deg); }
.glo-h{ font-family:var(--font-serif); font-size:19px; font-weight:600; color:var(--choco); margin-bottom:5px; letter-spacing:.01em; }
.glo-b{ font-family:var(--font-sans); font-size:12.5px; line-height:1.62; color:#5a4a3a; }
.glo-x{ position:absolute; top:8px; right:9px; width:20px; height:20px; border:0; background:transparent; color:var(--gold-deep); font-size:18px; line-height:1; cursor:pointer; border-radius:50%; }
.glo-x:hover{ background:var(--beige-soft); color:var(--choco); }

/* ============================================================
   MODALIDADES MAYORISTAS
   ============================================================ */
.mod-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:30px; }
.mod-card{
  border:1px solid var(--line); background:#fff; padding:30px 28px 30px;
  display:flex; flex-direction:column; position:relative; break-inside:avoid;
}
.mod-card.is-highlight{ border:1.5px solid var(--gold); box-shadow:0 12px 34px rgba(181,148,106,.16); }
.mod-tag{
  position:absolute; top:-12px; left:28px;
  font-family:var(--font-sans); font-size:9.5px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:600; color:#fff; background:var(--gold); padding:6px 13px; border-radius:2px;
}
.mod-card.is-plain .mod-tag{ background:var(--choco); }
.mod-name{ font-family:var(--font-serif); font-size:31px; font-weight:600; color:var(--choco); margin:8px 0 0; letter-spacing:.01em; line-height:1.05; }
.mod-desc{ font-family:var(--font-sans); font-size:13px; line-height:1.6; color:#5a4a3a; margin:9px 0 0; }
.mod-invest{ margin:22px 0; padding:17px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.mod-invest .il{ font-family:var(--font-sans); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); }
.mod-invest .iv{ font-family:var(--font-serif); font-size:38px; font-weight:600; color:var(--choco); line-height:1; margin-top:5px; }
.mod-benefits{ display:flex; flex-direction:column; gap:11px; }
.mod-ben{ display:flex; align-items:flex-start; gap:10px; position:relative; }
.ben-check{ flex:0 0 auto; width:17px; height:17px; margin-top:1px; color:var(--gold); display:inline-flex; }
.ben-check svg{ width:17px; height:17px; }
.ben-txt{ font-family:var(--font-sans); font-size:13px; line-height:1.5; color:var(--choco); flex:1; }
.ben-del{
  flex:0 0 auto; width:18px; height:18px; border-radius:50%; border:1px solid var(--line);
  background:#fff; color:var(--choco); cursor:pointer; font-size:12px; line-height:1;
  display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .14s;
}
.mod-ben:hover .ben-del{ opacity:1; }
.ben-del:hover{ background:#c0392b; color:#fff; border-color:#c0392b; }
.mod-add{
  margin-top:4px; align-self:flex-start; border:1px dashed var(--line); background:transparent;
  color:var(--gold-deep); padding:7px 14px; border-radius:2px; cursor:pointer;
  font-family:var(--font-sans); font-size:11.5px; letter-spacing:.04em; transition:all .14s;
  display:inline-flex; align-items:center; gap:6px;
}
.mod-add span{ font-size:15px; line-height:1; }
.mod-add:hover{ border-color:var(--gold); background:rgba(181,148,106,.08); color:var(--choco); }
.prices{ display:flex; align-items:flex-end; justify-content:space-between; gap:10px; margin-top:auto; padding-top:8px; }
.price-may{ display:flex; flex-direction:column; flex:0 0 auto; }
.price-may .pl{ font-family:var(--font-sans); font-size:8.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:2px; white-space:nowrap; }
.price-may .pv{ font-family:var(--font-serif); font-size:27px; font-weight:600; color:var(--choco); line-height:1; white-space:nowrap; }
.price-may > div{ white-space:nowrap; }
.price-sug{ text-align:right; flex:0 0 auto; }
.price-sug .pl{ font-family:var(--font-sans); font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); white-space:nowrap; }
.price-sug .pv{ font-family:var(--font-sans); font-size:14px; color:#8a7660; white-space:nowrap; }

/* card delete */
.card-del{
  position:absolute; top:8px; right:8px; z-index:3;
  width:26px; height:26px; border-radius:50%; border:1px solid var(--line);
  background:rgba(255,255,255,.92); color:var(--choco); cursor:pointer;
  font-size:15px; line-height:1; display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .14s, background .14s;
}
.card:hover .card-del{ opacity:1; }
.card-del:hover{ background:#c0392b; color:#fff; border-color:#c0392b; }

/* add product button */
.add-prod{
  border:1.5px dashed var(--line); background:transparent; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  color:var(--gold-deep); min-height:120px; transition:all .14s; border-radius:2px;
  font-family:var(--font-sans); font-size:12px; letter-spacing:.06em;
}
.add-prod:hover{ border-color:var(--gold); background:rgba(181,148,106,.07); color:var(--choco); }
.add-prod .plus{ font-size:26px; font-weight:300; line-height:1; }

/* add category button (screen only, between sheets) */
.add-cat-wrap{ display:flex; justify-content:center; }
.add-cat{
  border:1.5px dashed var(--gold); background:rgba(246,241,232,.6);
  color:var(--gold-deep); padding:13px 26px; cursor:pointer; border-radius:2px;
  font-family:var(--font-sans); font-size:12.5px; letter-spacing:.08em;
  display:flex; align-items:center; gap:9px; transition:all .14s;
}
.add-cat:hover{ background:var(--gold); color:#fff; }

/* ============================================================
   CONTACTO
   ============================================================ */
.contact-sheet{ background:var(--choco); color:var(--crema); }
.contact-sheet .section-eyebrow{ color:var(--gold); }
.contact-sheet .section-eyebrow::before{ background:var(--gold); }
.contact-sheet .section-title{ color:var(--crema); }
.contact-sheet .pagemark{ color:rgba(231,220,203,.5); }
.contact-wrap{ display:flex; flex-direction:column; height:100%; }
.contact-lead{ font-family:var(--font-serif); font-size:24px; line-height:1.6; color:var(--beige); max-width:60ch; margin:6px 0 0; }
.contact-min{
  margin:30px 0; padding:22px 26px; border:1px solid var(--gold);
  display:flex; align-items:baseline; gap:16px; background:rgba(181,148,106,.10);
}
.contact-min .cm-l{ font-family:var(--font-sans); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); }
.contact-min .cm-v{ font-family:var(--font-serif); font-size:38px; font-weight:600; color:var(--crema); }
.contact-channels{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:6px; }
.channel{ display:flex; flex-direction:column; gap:4px; padding:18px 0; border-top:1px solid rgba(181,148,106,.4); }
.channel .ch-l{ font-family:var(--font-sans); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.channel .ch-v{ font-family:var(--font-serif); font-size:26px; font-weight:500; color:var(--crema); }
.contact-terms{ margin-top:auto; padding-top:24px; }
.contact-terms li{ font-family:var(--font-sans); font-size:12px; line-height:1.9; color:var(--beige); list-style:none; padding-left:18px; position:relative; }
.contact-terms li::before{ content:'·'; position:absolute; left:4px; color:var(--gold); font-size:18px; line-height:1; }
.contact-foot-logo{ margin-top:30px; display:flex; justify-content:center; }
.contact-foot-logo .mono{ color:var(--gold); }
.contact-foot-logo .logo-slot{ max-width:220px; }
.contact-foot-logo .logo-slot img{ max-height:96px; }
.contact-foot-logo .edit-tag{ color:var(--gold); }

/* ============================================================
   PRINT  →  PDF
   ============================================================ */
@media print{
  @page{ size:A4 portrait; margin:0; }
  html,body{ background:#fff; }
  .toolbar, .no-print, .add-prod, .add-cat-wrap, .card-del, .edit-tag, .ph-empty-hint{ display:none !important; }
  #pages{ gap:0; padding:0; }
  .sheet{
    box-shadow:none; margin:0;
    width:210mm; min-height:297mm; height:297mm;
    page-break-after:always; break-after:page;
  }
  .sheet:last-child{ page-break-after:auto; }
  [contenteditable]:hover, [contenteditable]:focus{ background:transparent !important; box-shadow:none !important; }
  .photo{ box-shadow:none !important; }
  *{ -webkit-print-color-adjust:exact !important; print-color-adjust:exact !important; }
}
