/* realbacktesting — FICHAS (product spec sheets) shared component styles.
 * Loaded AFTER styles.css so it inherits every brand token (:root vars).
 * These pages are STANDALONE: not linked from nav, noindex, reachable only by exact URL.
 * They are the future "anchor" pages (features · params · config · manual) per product. */

/* ---- topbar (slim, static — no public nav chrome) ------------------------ */
.ficha-topbar{ position: sticky; top: 0; z-index: 20;
  display:flex; align-items:center; justify-content:space-between; gap: 16px;
  padding: 13px var(--pad); background: rgba(10,11,13,.82); backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line); }
.ficha-topbar .brand{ display:inline-flex; align-items:center; text-decoration:none; }
.ficha-topbar .tb-cta{ display:flex; gap: 10px; align-items:center; }
.ficha-topbar .btn{ font: 600 .84rem/1 var(--sans); padding: 9px 15px; border-radius: var(--r-sm);
  text-decoration:none; white-space:nowrap; }
.tb-lang{ display:inline-flex; align-items:center; gap:2px; margin-right: 4px;
  border:1px solid var(--line-2); border-radius: 999px; overflow:hidden; }
.tb-l{ font: 600 .72rem/1 var(--mono); letter-spacing:.04em; padding: 7px 11px; text-decoration:none;
  color: var(--ink-3); }
.tb-l.on{ color: var(--ink); background: var(--bg-2); }
a.tb-l:hover{ color: var(--ink); background: rgba(255,255,255,.04); }

/* ---- page shell ---------------------------------------------------------- */
.ficha-wrap{ max-width: 1040px; margin: 0 auto; padding: 0 var(--pad); }
.ficha main{ padding-top: 84px; padding-bottom: 96px; }
.ficha-eyebrow{ font: 600 .72rem/1 var(--mono); letter-spacing:.14em; text-transform:uppercase;
  color: var(--accent); display:inline-flex; gap:.5rem; align-items:center; }
.ficha-back{ font: 500 .85rem/1 var(--sans); color: var(--ink-3); text-decoration:none;
  display:inline-block; margin-bottom: 18px; }
.ficha-back:hover{ color: var(--ink); }

/* internal-only banner (these pages are not yet public) */
.ficha-flag{ display:flex; gap:.6rem; align-items:center; margin: 0 0 22px;
  padding: 9px 14px; border-radius: var(--r-sm);
  background: var(--accent-wash); border:1px solid var(--accent-line);
  font: 500 .8rem/1.4 var(--sans); color: var(--ink-2); }
.ficha-flag b{ color: var(--accent-hi); font-weight:600; }

/* ---- hero ---------------------------------------------------------------- */
.fh{ display:grid; grid-template-columns: 1fr; gap: 22px; padding: 8px 0 30px;
  border-bottom: 1px solid var(--line); margin-bottom: 40px; }
.fh-id{ display:flex; gap:16px; align-items:flex-start; }
.fh-icon{ flex:none; width:52px; height:52px; border-radius: var(--r-sm);
  display:grid; place-items:center; color: var(--accent);
  background: var(--bg-2); border:1px solid var(--line-2); }
.fh-icon svg{ width:28px; height:28px; }
.fh-tier{ font: 600 .76rem/1 var(--mono); letter-spacing:.06em; text-transform:uppercase;
  color: var(--ink-3); margin-bottom: 8px; }
.fh-name{ font: 600 2.1rem/1.04 var(--sans); letter-spacing:-.02em; margin:0; color: var(--ink); }
.fh-name .accent{ color: var(--accent); }
.fh-tag{ font: 400 1.06rem/1.5 var(--sans); color: var(--ink-2); margin: 12px 0 0; max-width: 60ch; }
.fh-meta{ display:flex; flex-wrap:wrap; gap: 10px; margin-top: 18px; }
.fh-chip{ font: 500 .8rem/1 var(--sans); color: var(--ink-2);
  background: var(--bg-2); border:1px solid var(--line-2); border-radius: 999px; padding: 7px 13px; }
.fh-chip b{ color: var(--ink); font-weight:600; }

.fh-buy{ display:flex; flex-wrap:wrap; gap: 14px; align-items:center; }
.fh-price{ display:flex; flex-direction:column; }
.fh-price b{ font: 600 1.7rem/1 var(--mono); color: var(--ink); letter-spacing:-.01em; }
.fh-price small{ font: 500 .76rem/1.3 var(--sans); color: var(--ink-3); margin-top: 5px; }
.fh-price b.free{ color: var(--pos); }

/* ---- sections ------------------------------------------------------------ */
.fsec{ margin: 0 0 52px; }
.fsec > h2{ font: 600 1.32rem/1.2 var(--sans); letter-spacing:-.01em; color: var(--ink);
  margin: 0 0 6px; display:flex; align-items:center; gap:.6rem; }
.fsec > h2::before{ content:""; width: 4px; height: 1.05em; border-radius: 2px;
  background: var(--accent); flex:none; }
.fsec > .fsub{ font: 400 .95rem/1.5 var(--sans); color: var(--ink-3); margin: 0 0 22px; max-width: 72ch; }
.fsec h3{ font: 600 1rem/1.3 var(--sans); color: var(--ink); margin: 26px 0 12px; }

/* ---- value cards --------------------------------------------------------- */
.fcards{ display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 14px; }
.fcard{ background: var(--bg-1); border:1px solid var(--line); border-radius: var(--r);
  padding: 18px 18px 20px; }
.fcard .fc-ico{ color: var(--accent); margin-bottom: 10px; display:block; }
.fcard .fc-ico svg{ width:22px; height:22px; }
.fcard h4{ font: 600 .98rem/1.3 var(--sans); color: var(--ink); margin: 0 0 6px; }
.fcard p{ font: 400 .88rem/1.5 var(--sans); color: var(--ink-2); margin: 0; }

/* ---- key metrics strip --------------------------------------------------- */
.fmetrics{ display:grid; grid-template-columns: repeat(auto-fit, minmax(120px,1fr)); gap: 1px;
  background: var(--line); border:1px solid var(--line); border-radius: var(--r); overflow:hidden; }
.fmetric{ background: var(--bg-1); padding: 16px 16px 17px; }
.fmetric .k{ font: 500 .72rem/1.2 var(--sans); color: var(--ink-3); display:block; margin-bottom: 7px; }
.fmetric b{ font: 600 1.32rem/1 var(--mono); color: var(--ink); letter-spacing:-.01em; }
.fmetric .sub{ font: 500 .68rem/1.2 var(--mono); color: var(--ink-4); display:block; margin-top:5px; }
.fmetric b.pos{ color: var(--pos); }
.fmetric b.neg{ color: var(--neg); }

/* ---- comparison (editions) ----------------------------------------------- */
.fcompare{ width:100%; border-collapse: collapse; font: 400 .9rem/1.4 var(--sans);
  border:1px solid var(--line); border-radius: var(--r); overflow:hidden; }
.fcompare thead th{ text-align:left; padding: 14px 16px; background: var(--bg-2);
  font: 600 .8rem/1.2 var(--mono); letter-spacing:.04em; text-transform:uppercase; color: var(--ink-2);
  border-bottom:1px solid var(--line-2); }
.fcompare thead th.col-paid{ color: var(--accent-hi); }
.fcompare thead th.col-free{ color: var(--pos); }
.fcompare tbody td{ padding: 12px 16px; border-bottom:1px solid var(--line); color: var(--ink-2);
  vertical-align: top; }
.fcompare tbody tr:last-child td{ border-bottom:0; }
.fcompare td:first-child{ color: var(--ink); font-weight:500; width: 46%; }
.fcompare .yes{ color: var(--pos); font-weight:600; }
.fcompare .no{ color: var(--ink-4); }
.fcompare .partial{ color: var(--ink-2); }
.fcompare tbody tr:hover td{ background: rgba(255,255,255,.015); }
.fcompare .grp td{ background: var(--bg-2); color: var(--ink-3);
  font: 600 .72rem/1 var(--mono); letter-spacing:.08em; text-transform:uppercase; padding: 9px 16px; }

/* ---- feature lists ------------------------------------------------------- */
.flist{ list-style:none; margin: 0; padding: 0; display:grid; gap: 10px; }
.flist li{ position:relative; padding-left: 26px; font: 400 .92rem/1.5 var(--sans); color: var(--ink-2); }
.flist li::before{ content:""; position:absolute; left: 4px; top: .55em;
  width: 7px; height: 7px; border-radius: 2px; background: var(--accent); }
.flist li b{ color: var(--ink); font-weight:600; }
.flist.pro li::before{ background: var(--accent); }
.flist.cols{ grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 10px 28px; }

/* ---- strategy roster (cBots — anti-copy) --------------------------------- */
.froster{ display:grid; grid-template-columns: repeat(auto-fill, minmax(168px,1fr)); gap: 12px; }
.fstrat{ background: var(--bg-1); border:1px solid var(--line); border-radius: var(--r-sm);
  padding: 14px 15px; }
.fstrat .market{ font: 600 .9rem/1.2 var(--sans); color: var(--ink); }
.fstrat .fam{ display:inline-block; margin-top: 8px; font: 500 .7rem/1 var(--mono);
  letter-spacing:.04em; text-transform:uppercase; color: var(--accent-hi);
  background: var(--accent-wash); border:1px solid var(--accent-line); border-radius: 999px; padding: 4px 9px; }
.fstrat .role{ display:block; margin-top: 10px; font: 400 .76rem/1.4 var(--sans); color: var(--ink-3); }
.froster-note{ margin-top: 16px; padding: 14px 16px; border-radius: var(--r-sm);
  background: var(--bg-2); border:1px dashed var(--line-strong);
  font: 400 .86rem/1.55 var(--sans); color: var(--ink-2); }
.froster-note b{ color: var(--ink); }

/* ---- parameter tables ---------------------------------------------------- */
.fparam-group{ border:1px solid var(--line); border-radius: var(--r); overflow:hidden; margin-bottom: 14px; }
.fparam-group > summary{ cursor:pointer; list-style:none; padding: 14px 18px;
  background: var(--bg-1); font: 600 .95rem/1.2 var(--sans); color: var(--ink);
  display:flex; align-items:center; justify-content:space-between; gap: 12px; }
.fparam-group > summary::-webkit-details-marker{ display:none; }
.fparam-group > summary .count{ font: 500 .74rem/1 var(--mono); color: var(--ink-3);
  background: var(--bg-3); border-radius: 999px; padding: 4px 10px; }
.fparam-group > summary::after{ content:"▸"; color: var(--ink-3); margin-left:auto; transition: transform .15s; }
.fparam-group[open] > summary::after{ transform: rotate(90deg); }
.fparam-group[open] > summary{ border-bottom:1px solid var(--line); }
.fptable{ width:100%; border-collapse: collapse; font: 400 .86rem/1.45 var(--sans); }
.fptable th{ text-align:left; padding: 9px 14px; background: var(--bg-2); color: var(--ink-3);
  font: 600 .68rem/1 var(--mono); letter-spacing:.06em; text-transform:uppercase; border-bottom:1px solid var(--line); }
.fptable td{ padding: 10px 14px; border-bottom:1px solid var(--line); color: var(--ink-2); vertical-align: top; }
.fptable tr:last-child td{ border-bottom:0; }
.fptable td.p-name{ color: var(--ink); font-weight:500; white-space:nowrap; }
.fptable td.p-def{ font: 500 .8rem/1.3 var(--mono); color: var(--accent-hi); white-space:nowrap; }
.fptable td.p-range{ font: 500 .76rem/1.4 var(--mono); color: var(--ink-3); white-space:normal; word-break:normal; line-height:1.5; }
.fptable .tag-free{ display:inline-block; font: 600 .62rem/1 var(--mono); color: var(--pos);
  border:1px solid var(--pos); border-radius: 4px; padding: 2px 5px; margin-left: 6px; vertical-align: middle; }
.fptable .tag-pro{ display:inline-block; font: 600 .62rem/1 var(--mono); color: var(--accent-hi);
  border:1px solid var(--accent-line); border-radius: 4px; padding: 2px 5px; margin-left: 6px; vertical-align: middle; }

/* ---- manual (numbered steps) --------------------------------------------- */
.fmanual{ counter-reset: step; display:grid; gap: 12px; }
.fstep{ position:relative; padding: 16px 18px 16px 60px;
  background: var(--bg-1); border:1px solid var(--line); border-radius: var(--r); }
.fstep::before{ counter-increment: step; content: counter(step);
  position:absolute; left: 16px; top: 16px; width: 30px; height: 30px; border-radius: 50%;
  display:grid; place-items:center; font: 600 .9rem/1 var(--mono); color: var(--accent-hi);
  background: var(--accent-wash); border:1px solid var(--accent-line); }
.fstep h4{ font: 600 .98rem/1.3 var(--sans); color: var(--ink); margin: 4px 0 5px; }
.fstep p{ font: 400 .88rem/1.55 var(--sans); color: var(--ink-2); margin: 0; }
.fstep code{ font: 500 .82rem/1 var(--mono); color: var(--accent-hi);
  background: var(--bg-3); border-radius: 5px; padding: 2px 6px; }

/* ---- video --------------------------------------------------------------- */
.fvideo{ position:relative; display:block; border-radius: var(--r); overflow:hidden;
  border:1px solid var(--line-2); aspect-ratio: 16/9; background: var(--bg-2); text-decoration:none; }
.fvideo img{ width:100%; height:100%; object-fit: cover; display:block; opacity:.92; transition: opacity .2s, transform .2s; }
.fvideo:hover img{ opacity:1; transform: scale(1.015); }
.fvideo .play{ position:absolute; inset:0; display:grid; place-items:center; }
.fvideo .play span{ width: 66px; height: 66px; border-radius: 50%;
  background: rgba(10,11,13,.62); border:1.5px solid rgba(255,255,255,.55); backdrop-filter: blur(3px);
  display:grid; place-items:center; transition: background .2s, transform .2s; }
.fvideo:hover .play span{ background: var(--accent); transform: scale(1.06); border-color: var(--accent-hi); }
.fvideo .play svg{ width: 26px; height: 26px; fill: #fff; margin-left: 3px; }
.fvideo .vlabel{ position:absolute; left:14px; bottom:12px; right:14px;
  font: 500 .82rem/1.3 var(--sans); color: #fff; text-shadow: 0 1px 8px rgba(0,0,0,.7); }
.fvideo-note{ font: 400 .8rem/1.5 var(--sans); color: var(--ink-3); margin: 10px 0 0; }

/* ---- honesty / legal ----------------------------------------------------- */
.fhonesty{ background: var(--bg-1); border:1px solid var(--line); border-radius: var(--r); padding: 20px 22px; }
.fhonesty ul{ margin: 0; padding-left: 20px; display:grid; gap: 8px; }
.fhonesty li{ font: 400 .86rem/1.55 var(--sans); color: var(--ink-2); }
.fhonesty li b{ color: var(--ink); }

/* ---- buttons (reuse brand .btn where present; safe fallbacks) ------------- */
.ficha .btn-accent{ background: var(--accent); color:#fff; border:1px solid var(--accent); }
.ficha .btn-ghost{ background: transparent; color: var(--ink); border:1px solid var(--line-strong); }

/* ---- responsive ---------------------------------------------------------- */
/* Mobile-first: defaults are sized for ~360-480px phones. Breakpoints grow
 * the layout at 600px (large phones / small tablets), 900px (tablets /
 * small laptops), and 1200px (desktop). Each component gets explicit
 * mobile treatment instead of relying on a single desktop-shrink. */

/* ========== DEFAULT = MOBILE (≤ 600px) ========== */

.ficha-wrap{ padding: 0 16px; }
.ficha main{ padding-top: 64px; padding-bottom: 64px; }

/* topbar — stack on phones so the CTA doesn't collide with the brand */
.ficha-topbar{ flex-wrap: wrap; gap: 10px 16px; padding: 12px 16px; }
.ficha-topbar .tb-cta{ width: 100%; justify-content: space-between; }
.ficha-topbar .btn{ font-size: .78rem; padding: 8px 12px; }

/* back link + flag */
.ficha-back{ font-size: .8rem; margin-bottom: 14px; }
.ficha-flag{ font-size: .74rem; padding: 8px 12px; margin-bottom: 18px; }

/* hero — single column, smaller, tighter */
.fh{ gap: 20px; padding: 4px 0 22px; margin-bottom: 30px; }
.fh-id{ flex-direction: column; gap: 14px; align-items: flex-start; }
.fh-icon{ width: 44px; height: 44px; }
.fh-icon svg{ width: 24px; height: 24px; }
.fh-tier{ font-size: .68rem; margin-bottom: 6px; }
.fh-name{ font-size: 1.55rem; }
.fh-tag{ font-size: .94rem; line-height: 1.5; margin-top: 10px; max-width: 100%; }
.fh-meta{ gap: 6px; margin-top: 14px; }
.fh-chip{ font-size: .72rem; padding: 5px 10px; }
.fh-buy{ flex-direction: column; gap: 14px; align-items: flex-start; width: 100%; }
.fh-price b{ font-size: 1.4rem; }
.fh-price small{ font-size: .7rem; }

/* sections — tighter vertical rhythm on phones */
.fsec{ margin: 0 0 36px; }
.fsec > h2{ font-size: 1.12rem; margin-bottom: 8px; }
.fsec > .fsub{ font-size: .88rem; line-height: 1.55; margin-bottom: 18px; max-width: 100%; }
.fsec h3{ font-size: .95rem; margin: 22px 0 10px; }

/* value cards — single column on phones */
.fcards{ grid-template-columns: 1fr; gap: 10px; }
.fcard{ padding: 14px; }
.fcard .fc-ico svg{ width: 20px; height: 20px; }
.fcard h4{ font-size: .92rem; }
.fcard p{ font-size: .82rem; line-height: 1.5; }

/* metrics strip */
.fmetric{ padding: 12px 14px; }
.fmetric b{ font-size: 1.12rem; }
.fmetric .k{ font-size: .68rem; }

/* comparison table — scrollable on phones (Option A from MDN guide) */
.fcompare-wrap{ overflow-x: auto; -webkit-overflow-scrolling: touch;
  margin: 0 -16px; padding: 0 16px; }   /* edge-to-edge scroll gutter */
.fcompare{ font-size: .8rem; min-width: 480px; }
.fcompare thead th{ padding: 10px 12px; font-size: .68rem; }
.fcompare tbody td{ padding: 10px 12px; font-size: .82rem; }
.fcompare td:first-child{ width: auto; }
.fcompare .grp td{ padding: 8px 12px; font-size: .66rem; }

/* parameter table — flip to card stack on phones (Option C) */
.ficha-wrap .fsec .fparam-group{ overflow: hidden; }
.fparam-group{ margin-bottom: 12px; }
.fparam-group > summary{ padding: 12px 14px; font-size: .88rem; gap: 8px; }
.fparam-group > summary .count{ font-size: .68rem; padding: 3px 8px; }
.fptable thead{ display: none; }
.fptable,
.fptable tbody,
.fptable tr,
.fptable td{ display: block; width: 100%; box-sizing: border-box; }
.fptable tr{ padding: 14px 12px; border-bottom: 1px solid var(--line); }
.fptable tr:last-child{ border-bottom: 0; }
.fptable td{ padding: 6px 0; border-bottom: 0; min-width: 0; }
.fptable td.p-name{ font: 600 .9rem/1.3 var(--sans); color: var(--ink); margin-bottom: 8px; padding-top: 0; }
.fptable td.p-def,
.fptable td.p-range{ white-space: normal; word-break: break-word; }
.fptable td.p-def{
  font: 500 .8rem/1.4 var(--mono); color: var(--accent-hi);
  margin-bottom: 6px; overflow-wrap: anywhere;
}
.fptable td.p-range{
  font: 500 .8rem/1.5 var(--mono); color: var(--ink-2);
  margin-bottom: 8px; overflow-wrap: anywhere;
}
.fptable td:nth-child(4){
  color: var(--ink-2); white-space: normal; word-break: break-word;
  padding-bottom: 0;
}
.fptable td.p-def::before,
.fptable td.p-range::before,
.fptable td:nth-child(4)::before{
  color: var(--ink-4); text-transform: uppercase; letter-spacing: .04em;
  font: 500 .62rem/1 var(--mono); display: block; margin-bottom: 4px;
}
.fptable td.p-def::before{ content: "default"; }
.fptable td.p-range::before{ content: "values"; }
.fptable td:nth-child(4)::before{ content: "what it does"; }
.fptable .tag-free,
.fptable .tag-pro{ font-size: .56rem; padding: 1px 4px; margin-left: 4px; }

/* manual steps */
.fmanual{ gap: 10px; }
.fstep{ padding: 14px 14px 14px 52px; }
.fstep::before{ width: 26px; height: 26px; left: 14px; top: 14px; font-size: .78rem; }
.fstep h4{ font-size: .9rem; }
.fstep p{ font-size: .82rem; line-height: 1.55; }
.fstep code{ font-size: .74rem; padding: 1px 5px; }

/* video — let the label wrap, keep aspect ratio */
.fvideo .vlabel{ font-size: .74rem; left: 12px; right: 12px; bottom: 10px; }
.fvideo-note{ font-size: .74rem; margin-top: 8px; }

/* honesty / legal */
.fhonesty{ padding: 16px 18px; }
.fhonesty ul{ gap: 10px; }
.fhonesty li{ font-size: .82rem; line-height: 1.55; }

/* feature lists */
.flist li{ font-size: .86rem; line-height: 1.55; padding-left: 24px; }

/* footer */
.ficha footer.foot{ padding: 24px 16px; }
.ficha footer.foot .foot-tag{ font-size: .82rem; }

/* ========== ≥ 600px — large phones / small tablets ========== */
@media (min-width: 600px){
  .ficha-wrap{ padding: 0 20px; }
  .ficha main{ padding-top: 72px; padding-bottom: 80px; }

  .ficha-topbar{ flex-wrap: nowrap; padding: 13px 20px; }
  .ficha-topbar .tb-cta{ width: auto; justify-content: flex-end; }

  .fh-id{ flex-direction: row; gap: 16px; align-items: flex-start; }
  .fh-name{ font-size: 1.85rem; }
  .fh-tag{ font-size: 1rem; max-width: 60ch; }
  .fh-buy{ flex-direction: row; flex-wrap: wrap; gap: 16px; align-items: center; }

  .fcards{ grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
  .fcard{ padding: 16px; }

  .fcompare-wrap{ margin: 0; padding: 0; }
  .fcompare{ min-width: 0; }

  .fsec > h2{ font-size: 1.22rem; }
}

/* ========== ≥ 900px — tablets / small laptops ========== */
@media (min-width: 900px){
  .ficha-wrap{ padding: 0 28px; }
  .ficha main{ padding-top: 80px; padding-bottom: 88px; }

  .fh-name{ font-size: 2rem; }
  .fh-meta{ gap: 10px; }
  .fh-chip{ font-size: .8rem; padding: 7px 13px; }
  .fh-price b{ font-size: 1.55rem; }

  .fsec{ margin: 0 0 44px; }
  .fsec > h2{ font-size: 1.28rem; }
  .fsec > .fsub{ font-size: .92rem; margin-bottom: 20px; max-width: 72ch; }

  .fcards{ grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
  .fcard{ padding: 18px; }
  .fcard h4{ font-size: .98rem; }
  .fcard p{ font-size: .88rem; }

  .fcompare{ font-size: .88rem; }
  .fcompare thead th{ padding: 12px 14px; font-size: .74rem; }
  .fcompare tbody td{ padding: 11px 14px; font-size: .88rem; }
  .fcompare td:first-child{ width: 46%; }

  /* restore full table layout for the parameter table */
  .ficha-wrap .fsec .fparam-group{ overflow: hidden; }
  .fptable thead{ display: table-header-group; }
  .fptable,
  .fptable tbody,
  .fptable tr,
  .fptable td{ display: revert; width: auto; box-sizing: border-box; }
  .fptable tr{ padding: 0; border-bottom: 1px solid var(--line); }
  .fptable tr:last-child{ border-bottom: 0; }
  .fptable td{ padding: 10px 14px; border-bottom: 0; }
  .fptable td.p-name{ font: 500 .86rem/1.45 var(--sans); margin: 0; white-space: nowrap; }
  .fptable td.p-def{ font: 500 .8rem/1.3 var(--mono); margin: 0; white-space: nowrap; }
  .fptable td.p-range{ font: 500 .76rem/1.4 var(--mono); margin: 0; white-space: normal; }
  .fptable td:nth-child(4){ font: 400 .86rem/1.45 var(--sans); margin: 0; }
  .fptable td.p-def::before,
  .fptable td.p-range::before,
  .fptable td:nth-child(4)::before{ display: none; }

  .fstep{ padding: 16px 18px 16px 60px; }
  .fstep::before{ width: 30px; height: 30px; left: 16px; top: 16px; font-size: .9rem; }
  .fstep h4{ font-size: .98rem; }
  .fstep p{ font-size: .88rem; }

  .fhonesty{ padding: 20px 22px; }
  .fhonesty li{ font-size: .86rem; }
}

/* ========== ≥ 1200px — desktop ========== */
@media (min-width: 1200px){
  .ficha-wrap{ max-width: 1040px; margin: 0 auto; padding: 0 var(--pad); }
  .ficha main{ padding-top: 84px; padding-bottom: 96px; }
  .fh{ padding: 8px 0 30px; margin-bottom: 40px; }
  .fh-name{ font-size: 2.1rem; }
  .fsec{ margin: 0 0 52px; }
  .fsec > h2{ font-size: 1.32rem; }
  .fsec > .fsub{ font-size: .95rem; margin-bottom: 22px; }
}
