/* =====================================================================
   Fiveium Studio — marketplace styles (carousels, cards, selling pages)
   Built to sit on top of the shared Fiveium subdomain styles.
   ===================================================================== */
:root{ --fv-accent:#4E4FEB; --fv-ink:#071d3a; --fv-muted:#69738e; --fv-line:#e4e9f6; --fv-soft:#f7f9ff; }

.fv-studio a{ text-decoration:none; }
.fv-container{ width:100%; max-width:1280px; margin:0 auto; padding:0 24px; }

/* ---------- HERO ---------- */
.fv-studio-hero{ position:relative; padding:90px 0 80px; background:
  radial-gradient(1200px 480px at 80% -10%, rgba(78,79,235,.14), transparent 60%),
  linear-gradient(180deg,#fff 0%, #f7f9ff 100%); border-bottom:1px solid var(--fv-line); overflow:hidden; }
.fv-studio-hero .fv-eyebrow{ display:inline-flex; align-items:center; gap:8px; color:var(--fv-accent);
  background:rgba(78,79,235,.09); border-radius:999px; padding:7px 15px; font-size:12px; font-weight:900;
  letter-spacing:.08em; text-transform:uppercase; }
.fv-studio-hero h1{ color:var(--fv-ink); font-size:clamp(38px,5.2vw,64px); line-height:1.04; letter-spacing:-.04em;
  font-weight:800; margin:18px 0 16px; max-width:880px; }
.fv-studio-hero p{ color:var(--fv-muted); font-size:19px; line-height:1.7; font-weight:500; max-width:680px; }
.fv-hero-actions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
.fv-hero-stats{ display:flex; flex-wrap:wrap; gap:34px; margin-top:46px; }
.fv-hero-stats .num{ font-size:30px; font-weight:900; color:var(--fv-ink); letter-spacing:-.03em; }
.fv-hero-stats .lbl{ font-size:13px; font-weight:700; color:var(--fv-muted); text-transform:uppercase; letter-spacing:.05em; }

/* ---------- BUTTONS ---------- */
.fv-btn{ display:inline-flex; align-items:center; gap:9px; height:50px; padding:0 24px; border-radius:14px;
  font-weight:800; font-size:15px; border:1.5px solid transparent; transition:.18s; cursor:pointer; }
.fv-btn-primary{ background:var(--fv-accent); color:#fff; box-shadow:0 14px 30px rgba(78,79,235,.28); }
.fv-btn-primary:hover{ filter:brightness(1.06); color:#fff; transform:translateY(-1px); }
.fv-btn-ghost{ background:#fff; color:var(--fv-ink); border-color:var(--fv-line); }
.fv-btn-ghost:hover{ border-color:var(--fv-accent); color:var(--fv-accent); }
.fv-btn-sm{ height:42px; padding:0 18px; font-size:14px; border-radius:12px; }
.fv-btn-block{ width:100%; justify-content:center; }

/* ---------- SECTION HEADERS ---------- */
.fv-sec{ padding:64px 0; }
.fv-sec.soft{ background:var(--fv-soft); }
.fv-sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:30px; flex-wrap:wrap; }
.fv-sec-head .fv-sec-eyebrow{ display:inline-flex; align-items:center; gap:9px; font-weight:900; font-size:13px;
  text-transform:uppercase; letter-spacing:.07em; color:var(--cat-accent,var(--fv-accent)); }
.fv-sec-head h2{ color:var(--fv-ink); font-size:clamp(26px,3vw,38px); font-weight:800; letter-spacing:-.03em; margin:8px 0 0; }
.fv-sec-head p{ color:var(--fv-muted); font-weight:500; margin:6px 0 0; }
.fv-sec-head .fv-view-all{ color:var(--cat-accent,var(--fv-accent)); font-weight:800; white-space:nowrap; }
.fv-sec-head .fv-view-all i{ margin-left:6px; }

/* ---------- PRODUCT CARD ---------- */
.fv-card{ position:relative; display:flex; flex-direction:column; height:100%; background:#fff;
  border:1px solid var(--fv-line); border-radius:20px; overflow:hidden; transition:.2s; }
.fv-card:hover{ transform:translateY(-4px); box-shadow:0 26px 60px rgba(7,29,58,.12); border-color:rgba(78,79,235,.25); }
.fv-card-media{ position:relative; aspect-ratio:16/10; background:linear-gradient(135deg,#eef1fb,#f7f9ff);
  display:flex; align-items:center; justify-content:center; overflow:hidden; }
.fv-card-media img{ width:100%; height:100%; object-fit:cover; }
.fv-card-media .fv-card-glyph{ font-size:54px; color:var(--cat-accent,var(--fv-accent)); opacity:.85; }
.fv-badge{ position:absolute; top:12px; left:12px; z-index:2; background:var(--cat-accent,var(--fv-accent)); color:#fff;
  font-size:11px; font-weight:900; letter-spacing:.05em; text-transform:uppercase; padding:5px 11px; border-radius:999px; }
.fv-badge.free{ background:#35b757; }
.fv-card-body{ padding:18px 18px 20px; display:flex; flex-direction:column; flex:1; }
.fv-card-cat{ font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.05em; color:var(--cat-accent,var(--fv-accent)); }
.fv-card-title{ color:var(--fv-ink); font-size:18px; font-weight:800; margin:6px 0 6px; letter-spacing:-.02em; }
.fv-card-title a{ color:inherit; }
.fv-card-desc{ color:var(--fv-muted); font-size:14px; line-height:1.6; font-weight:500; margin:0 0 14px; flex:1; }
.fv-card-meta{ display:flex; align-items:center; gap:10px; font-size:13px; color:var(--fv-muted); margin-bottom:14px; }
.fv-card-meta .fv-stars{ color:#f5a623; letter-spacing:1px; }
.fv-card-foot{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:14px; border-top:1px solid var(--fv-line); }
.fv-price-now{ color:var(--fv-ink); font-size:20px; font-weight:900; letter-spacing:-.02em; }
.fv-price-old{ color:#a6adbf; font-size:14px; font-weight:700; text-decoration:line-through; margin-left:6px; }
.fv-price-free{ color:#35b757; font-size:18px; font-weight:900; }

/* ---------- CAROUSEL ---------- */
.fv-carousel{ margin:0 -10px; }
.fv-carousel .fv-slide{ padding:0 10px; height:auto; }
.fv-carousel .slick-track{ display:flex !important; }
.fv-carousel .slick-slide{ height:auto; }
.fv-carousel .slick-slide > div{ height:100%; }
.fv-cat-block .slick-arrow{ position:absolute; top:-58px; width:42px; height:42px; border-radius:12px; border:1px solid var(--fv-line);
  background:#fff; color:var(--fv-ink); z-index:3; font-size:0; cursor:pointer; transition:.15s; }
.fv-cat-block .slick-arrow:hover{ border-color:var(--cat-accent,var(--fv-accent)); color:var(--cat-accent,var(--fv-accent)); }
.fv-cat-block .slick-arrow:before{ font-family:'Font Awesome 6 Free'; font-weight:900; font-size:15px; }
.fv-cat-block .slick-prev{ right:58px; left:auto; }
.fv-cat-block .slick-next{ right:8px; }
.fv-cat-block .slick-prev:before{ content:'\f060'; }
.fv-cat-block .slick-next:before{ content:'\f061'; }
.fv-cat-block{ position:relative; }
.fv-carousel .slick-list{ padding:6px 0 12px; }

/* ---------- CATEGORY TILE GRID (home) ---------- */
.fv-cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.fv-cat-tile{ position:relative; display:flex; gap:16px; padding:22px; border-radius:20px; background:#fff;
  border:1px solid var(--fv-line); transition:.2s; overflow:hidden; }
.fv-cat-tile:hover{ transform:translateY(-3px); box-shadow:0 22px 50px rgba(7,29,58,.1); }
.fv-cat-tile .ic{ flex:none; width:56px; height:56px; border-radius:16px; display:flex; align-items:center; justify-content:center;
  font-size:24px; color:#fff; }
.fv-cat-tile h3{ color:var(--fv-ink); font-size:18px; font-weight:800; margin:0 0 4px; }
.fv-cat-tile p{ color:var(--fv-muted); font-size:14px; font-weight:500; margin:0; line-height:1.55; }
.fv-cat-tile .cnt{ font-size:12px; font-weight:800; color:var(--fv-muted); margin-top:8px; display:inline-block; }

/* ---------- CATEGORY HERO (per-category landing) ---------- */
.fv-cat-hero{ position:relative; padding:80px 0 56px; border-bottom:1px solid var(--fv-line); overflow:hidden; }
.fv-cat-hero .fv-eyebrow{ display:inline-flex; align-items:center; gap:9px; color:var(--cat-accent); background:var(--cat-soft);
  border-radius:999px; padding:7px 15px; font-size:12px; font-weight:900; letter-spacing:.07em; text-transform:uppercase; }
.fv-cat-hero h1{ color:var(--fv-ink); font-size:clamp(34px,4.6vw,56px); font-weight:800; letter-spacing:-.04em; margin:16px 0 14px; }
.fv-cat-hero p{ color:var(--fv-muted); font-size:18px; line-height:1.7; font-weight:500; max-width:680px; }
.fv-cat-hero .fv-cat-bigicon{ font-size:120px; color:var(--cat-accent); opacity:.16; position:absolute; right:40px; top:50%; transform:translateY(-50%); }
.fv-chip-row{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.fv-chip{ display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:999px; background:#fff;
  border:1px solid var(--fv-line); font-size:13px; font-weight:700; color:var(--fv-ink); }
.fv-chip i{ color:var(--cat-accent); }

/* layout-specific accents for category heroes */
.layout-chrome .fv-cat-hero{ background:linear-gradient(180deg,#eef4ff,#fff); }
.layout-wordpress .fv-cat-hero{ background:linear-gradient(180deg,#eaf3f7,#fff); }
.layout-php .fv-cat-hero{ background:linear-gradient(180deg,#f0effb,#fff); }
.layout-html .fv-cat-hero{ background:linear-gradient(180deg,#fdeee8,#fff); }
.layout-addons .fv-cat-hero{ background:linear-gradient(180deg,#e9f7ee,#fff); }

/* products grid (category page) */
.fv-prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.fv-toolbar{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:26px; }
.fv-toolbar .fv-filters{ display:flex; gap:8px; flex-wrap:wrap; }
.fv-filter{ padding:8px 16px; border-radius:999px; border:1px solid var(--fv-line); background:#fff; font-weight:700;
  font-size:14px; color:var(--fv-ink); cursor:pointer; }
.fv-filter.active,.fv-filter:hover{ background:var(--cat-accent); color:#fff; border-color:var(--cat-accent); }

/* ---------- PRODUCT (selling) PAGE ---------- */
.fv-pd-hero{ padding:48px 0 40px; border-bottom:1px solid var(--fv-line); }
.fv-breadcrumbs{ font-size:13px; font-weight:600; color:var(--fv-muted); margin-bottom:18px; }
.fv-breadcrumbs a{ color:var(--fv-muted); } .fv-breadcrumbs a:hover{ color:var(--cat-accent); }
.fv-pd-grid{ display:grid; grid-template-columns:1.4fr .9fr; gap:38px; align-items:start; }
.fv-pd-gallery{ }
.fv-pd-main-img{ width:100%; border-radius:20px; border:1px solid var(--fv-line); overflow:hidden; background:#f4f6fd; aspect-ratio:16/9; }
.fv-pd-main-img img{ width:100%; height:100%; object-fit:cover; }
.fv-pd-thumbs{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.fv-pd-thumbs img{ width:90px; height:60px; object-fit:cover; border-radius:10px; border:2px solid var(--fv-line); cursor:pointer; }
.fv-pd-thumbs img.active{ border-color:var(--cat-accent); }
.fv-pd-title{ color:var(--fv-ink); font-size:34px; font-weight:800; letter-spacing:-.03em; margin:6px 0 10px; }
.fv-pd-tagline{ color:var(--fv-muted); font-size:17px; font-weight:500; line-height:1.6; }
.fv-pd-buybox{ position:sticky; top:20px; background:#fff; border:1px solid var(--fv-line); border-radius:22px; padding:26px;
  box-shadow:0 24px 60px rgba(7,29,58,.09); }
.fv-pd-price{ display:flex; align-items:baseline; gap:8px; margin-bottom:6px; }
.fv-pd-price .fv-price-now{ font-size:34px; }
.fv-pd-buybox ul{ list-style:none; padding:0; margin:18px 0; }
.fv-pd-buybox li{ display:flex; gap:10px; align-items:flex-start; color:var(--fv-ink); font-weight:600; font-size:14px; margin-bottom:11px; }
.fv-pd-buybox li i{ color:#35b757; margin-top:3px; }
.fv-pd-specs{ margin-top:18px; border-top:1px solid var(--fv-line); padding-top:16px; font-size:13px; }
.fv-pd-specs .row{ display:flex; justify-content:space-between; padding:6px 0; color:var(--fv-muted); font-weight:600; }
.fv-pd-specs .row b{ color:var(--fv-ink); font-weight:800; }
.fv-tags{ display:flex; gap:8px; flex-wrap:wrap; margin-top:14px; }
.fv-tag{ font-size:12px; font-weight:700; color:var(--cat-accent); background:var(--cat-soft); padding:5px 11px; border-radius:999px; }
.fv-pd-section{ padding:54px 0; }
.fv-pd-section h2{ color:var(--fv-ink); font-size:28px; font-weight:800; letter-spacing:-.03em; margin:0 0 18px; }
.fv-pd-desc{ color:#2c3a57; font-size:16px; line-height:1.8; font-weight:500; max-width:820px; }
.fv-feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.fv-feat{ background:#fff; border:1px solid var(--fv-line); border-radius:18px; padding:24px; }
.fv-feat .ic{ width:50px; height:50px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  font-size:20px; color:var(--cat-accent); background:var(--cat-soft); margin-bottom:14px; }
.fv-feat h3{ color:var(--fv-ink); font-size:17px; font-weight:800; margin:0 0 7px; }
.fv-feat p{ color:var(--fv-muted); font-size:14px; line-height:1.6; font-weight:500; margin:0; }

/* CTA band */
.fv-cta{ background:linear-gradient(120deg,var(--cat-accent,#4E4FEB),#2d2eb0); border-radius:26px; padding:48px; color:#fff; text-align:center; }
.fv-cta h2{ color:#fff; font-size:30px; font-weight:800; margin:0 0 10px; letter-spacing:-.02em; }
.fv-cta p{ color:rgba(255,255,255,.85); font-weight:500; margin:0 auto 24px; max-width:560px; }
.fv-cta .fv-btn-ghost{ background:#fff; }

/* empty state */
.fv-empty{ text-align:center; padding:60px 20px; color:var(--fv-muted); }
.fv-empty i{ font-size:46px; color:var(--fv-line); margin-bottom:14px; }

/* ---------- responsive ---------- */
@media (max-width:991px){
  .fv-cat-grid,.fv-prod-grid,.fv-feat-grid{ grid-template-columns:repeat(2,1fr); }
  .fv-pd-grid{ grid-template-columns:1fr; }
  .fv-pd-buybox{ position:static; }
  .fv-cat-hero .fv-cat-bigicon{ display:none; }
}
@media (max-width:600px){
  .fv-cat-grid,.fv-prod-grid,.fv-feat-grid{ grid-template-columns:1fr; }
  .fv-hero-stats{ gap:22px; }
}

/* FV-PRICING-PATCH v1 */
/* ============ Pricing options, Chrome badge, new layouts, product polish ============ */

.fv-price-per{ font-size:15px; font-weight:700; color:var(--fv-muted); }
.fv-pd-pricenote{ color:var(--fv-muted); font-size:13px; font-weight:600; margin:2px 0 4px; }

/* ---- Chrome Web Store badge (HTML/CSS) ---- */
.fv-cb-wrap{ margin:14px 0 4px; }
.fv-chrome-badge{ display:inline-flex; align-items:center; gap:12px; width:100%; box-sizing:border-box;
  background:#1a1a1a; color:#fff; border-radius:13px; padding:11px 18px; text-decoration:none;
  border:1px solid #1a1a1a; transition:.18s; box-shadow:0 6px 18px rgba(0,0,0,.18); }
.fv-chrome-badge:hover{ background:#000; transform:translateY(-1px); box-shadow:0 10px 24px rgba(0,0,0,.26); }
.fv-cb-bag{ position:relative; flex:none; width:46px; height:46px; border-radius:11px; background:#fff;
  display:flex; align-items:center; justify-content:center; }
.fv-cb-bag::before{ content:""; position:absolute; top:7px; left:50%; transform:translateX(-50%);
  width:18px; height:9px; border:2.5px solid #c9ccd1; border-bottom:none; border-radius:9px 9px 0 0; }
.fv-cb-bag img{ width:27px; height:27px; margin-top:5px; }
.fv-cb-txt{ display:flex; flex-direction:column; line-height:1.15; text-align:left; }
.fv-cb-txt small{ font-size:11px; font-weight:500; opacity:.85; }
.fv-cb-txt b{ font-size:18px; font-weight:700; letter-spacing:-.01em; }

/* ---- Purchase option cards ---- */
.fv-price-opts{ display:flex; flex-direction:column; gap:10px; margin:16px 0 4px; }
.fv-price-opt{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  border:1.5px solid var(--fv-line); border-radius:14px; padding:12px 14px; transition:.16s; }
.fv-price-opt:hover{ border-color:var(--cat-accent,var(--fv-accent)); background:#fcfdff; }
.fv-price-opt .po-info{ display:flex; align-items:center; gap:12px; }
.fv-price-opt .po-ic{ width:38px; height:38px; flex:none; border-radius:10px; display:flex; align-items:center; justify-content:center;
  background:var(--cat-soft,rgba(78,79,235,.1)); color:var(--cat-accent,var(--fv-accent)); font-size:15px; }
.fv-price-opt .po-name{ display:block; font-weight:800; font-size:14px; color:var(--fv-ink); }
.fv-price-opt .po-badge{ font-style:normal; font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.03em;
  color:#1f8a4c; background:#e7f7ec; padding:2px 7px; border-radius:999px; margin-left:5px; }
.fv-price-opt .po-price{ display:block; font-weight:800; font-size:15px; color:var(--fv-ink); margin-top:1px; }
.fv-price-opt .po-price small{ font-weight:600; color:var(--fv-muted); font-size:12px; }
.fv-price-opt .po-note{ display:block; font-size:11.5px; color:var(--fv-muted); font-weight:600; margin-top:1px; }

/* ---- Product page polish ---- */
.fv-breadcrumbs i{ font-size:11px; opacity:.6; margin:0 2px; }
.fv-pd-metarow{ display:flex; align-items:center; flex-wrap:wrap; gap:10px 14px; margin:16px 0 22px; }
.fv-pd-meta-txt{ color:var(--fv-muted); font-weight:600; font-size:14px; }
.fv-pd-chip{ display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:800;
  color:var(--cat-accent,var(--fv-accent)); background:var(--cat-soft,rgba(78,79,235,.1)); padding:5px 12px; border-radius:999px; }
.fv-pd-chip.alt{ color:#b26a00; background:#fff3e0; }
.fv-pd-glyph{ display:flex; align-items:center; justify-content:center; height:100%; min-height:320px;
  font-size:120px; color:var(--cat-accent,var(--fv-accent)); opacity:.22; }

/* highlight strip */
.fv-pd-strip{ border-top:1px solid var(--fv-line); border-bottom:1px solid var(--fv-line); background:#fff; }
.fv-pd-strip-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; padding:24px 0; }
.fv-pd-strip-grid > div{ display:flex; align-items:center; gap:13px; }
.fv-pd-strip-grid span{ width:44px; height:44px; flex:none; border-radius:12px; display:flex; align-items:center; justify-content:center;
  background:var(--cat-soft,rgba(78,79,235,.1)); color:var(--cat-accent,var(--fv-accent)); font-size:17px; }
.fv-pd-strip-grid b{ display:block; font-size:14px; color:var(--fv-ink); font-weight:800; }
.fv-pd-strip-grid small{ color:var(--fv-muted); font-size:12.5px; font-weight:600; }

/* two-column body */
.fv-pd-cols{ display:grid; grid-template-columns:1fr 312px; gap:42px; align-items:start; }
.fv-pd-infocard{ position:sticky; top:20px; background:#fff; border:1px solid var(--fv-line); border-radius:18px; padding:22px; }
.fv-pd-infocard h3{ font-size:15px; font-weight:800; margin:0 0 14px; color:var(--fv-ink); }
.fv-pd-infocard .row{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:9px 0; border-bottom:1px solid var(--fv-line); font-size:13.5px; }
.fv-pd-infocard .row:last-child{ border-bottom:none; }
.fv-pd-infocard .row span{ color:var(--fv-muted); font-weight:600; display:inline-flex; align-items:center; gap:8px; }
.fv-pd-infocard .row span i{ color:var(--cat-accent,var(--fv-accent)); width:15px; text-align:center; }
.fv-pd-infocard .row b{ color:var(--fv-ink); font-weight:800; text-align:right; }

/* ---- New category layout themes ---- */
.layout-cpanel .fv-cat-hero{ background:linear-gradient(180deg,#fff1ea,#fff); }
.layout-plesk  .fv-cat-hero{ background:linear-gradient(180deg,#e9f6fd,#fff); }

@media (max-width:900px){
  .fv-pd-strip-grid{ grid-template-columns:repeat(2,1fr); }
  .fv-pd-cols{ grid-template-columns:1fr; gap:30px; }
  .fv-pd-infocard{ position:static; }
}
/* END FV-PRICING-PATCH v1 */

/* FV-PLANS-PATCH v2 */
/* ============ Free + Full version plans (stacked), refreshed look ============ */

/* headline */
.fv-price-amp{ display:inline-block; margin-left:8px; font-size:13px; font-weight:800; color:var(--fv-muted);
  vertical-align:middle; }
.fv-price-plus{ display:inline-block; margin-left:7px; font-size:12px; font-weight:700; color:var(--fv-muted); }

/* stacked tiers */
.fv-tiers{ display:flex; flex-direction:column; gap:14px; margin:18px 0 6px; }
.fv-tier{ border:1.5px solid var(--fv-line); border-radius:16px; padding:16px 16px 14px; background:#fff; }
.fv-tier.is-full{ border-color:color-mix(in srgb, var(--cat-accent,#4E4FEB) 55%, #fff);
  background:linear-gradient(180deg, var(--cat-soft,rgba(78,79,235,.07)), rgba(255,255,255,0) 70%); }
.fv-tier-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px; }
.fv-tier-name{ font-weight:800; font-size:14.5px; color:var(--fv-ink); display:inline-flex; align-items:center; gap:9px; }
.fv-tier-name i{ color:var(--cat-accent,var(--fv-accent)); font-size:15px; }
.fv-tier-tag{ font-size:11px; font-weight:800; letter-spacing:.02em; color:var(--fv-muted);
  background:var(--fv-soft,#f3f5fb); border:1px solid var(--fv-line); padding:3px 10px; border-radius:999px; }
.fv-tier-flag{ font-size:10.5px; font-weight:900; text-transform:uppercase; letter-spacing:.05em;
  color:var(--cat-accent,var(--fv-accent)); background:#fff;
  border:1.5px solid color-mix(in srgb, var(--cat-accent,#4E4FEB) 45%, #fff); padding:3px 10px; border-radius:999px; }
.fv-tier-note{ font-size:12.5px; color:var(--fv-muted); font-weight:600; margin:0 0 12px; line-height:1.45; }
.fv-tier.is-full .fv-price-opts{ margin-top:0; }
.fv-tier .fv-cb-wrap{ margin:0 0 12px; }

/* soft button (free version) */
.fv-btn-soft{ background:var(--cat-soft,rgba(78,79,235,.1)); color:var(--cat-accent,var(--fv-accent));
  border:1.5px solid color-mix(in srgb, var(--cat-accent,#4E4FEB) 28%, #fff); box-shadow:none; }
.fv-btn-soft:hover{ background:color-mix(in srgb, var(--cat-accent,#4E4FEB) 14%, #fff); transform:translateY(-1px); }
.fv-btn-block{ display:flex; align-items:center; justify-content:center; gap:9px; width:100%; box-sizing:border-box; }

/* refresh option badge away from green -> accent-tinted */
.fv-price-opt .po-badge{ background:var(--cat-soft,rgba(78,79,235,.12)) !important;
  color:var(--cat-accent,var(--fv-accent)) !important; border:none !important; }
.po-note{ display:block; font-size:11.5px; color:var(--fv-muted); font-weight:600; margin-top:2px; }

@media (max-width:560px){
  .fv-tier{ padding:14px; }
  .fv-tier-name{ font-size:14px; }
}
/* END FV-PLANS-PATCH v2 */

/* FV-LEGAL-PATCH v1 */
/* ============ Privacy policy + Contact pages ============ */

.fv-legal-hero{ background:linear-gradient(180deg,#f7f9ff,rgba(247,249,255,0)); border-bottom:1px solid var(--fv-line); padding:48px 0 34px; }
.fv-legal-hero h1{ font-size:38px; font-weight:800; color:var(--fv-ink); margin:8px 0 12px; letter-spacing:-.01em; }
.fv-legal-sub{ color:var(--fv-muted); font-size:16px; font-weight:500; max-width:680px; line-height:1.6; margin:0; }
.fv-legal-updated{ color:var(--fv-muted); font-size:13px; font-weight:700; margin-top:14px; display:inline-flex; align-items:center; gap:8px; }
.fv-breadcrumbs{ font-size:13px; font-weight:600; color:var(--fv-muted); margin-bottom:6px; }
.fv-breadcrumbs a{ color:var(--fv-accent); text-decoration:none; }
.fv-breadcrumbs span{ margin:0 7px; opacity:.6; }

.fv-legal-wrap{ display:grid; grid-template-columns:1fr 264px; gap:48px; align-items:start; padding-top:40px; padding-bottom:64px; }
.fv-legal-body{ max-width:780px; }
.fv-legal-body h2{ font-size:21px; font-weight:800; color:var(--fv-ink); margin:34px 0 12px; scroll-margin-top:90px; }
.fv-legal-body h2:first-of-type{ margin-top:0; }
.fv-legal-body p{ color:#41506e; font-size:15.5px; line-height:1.72; margin:0 0 14px; }
.fv-legal-body ul{ margin:0 0 16px; padding-left:22px; }
.fv-legal-body li{ color:#41506e; font-size:15.5px; line-height:1.7; margin-bottom:8px; }
.fv-legal-body a{ color:var(--fv-accent); }
.fv-legal-body b{ color:var(--fv-ink); }
.fv-legal-callout{ display:flex; gap:14px; align-items:flex-start; background:var(--fv-soft,#f7f9ff); border:1px solid var(--fv-line);
  border-left:4px solid var(--fv-accent); border-radius:12px; padding:16px 18px; margin:0 0 28px; }
.fv-legal-callout i{ color:var(--fv-accent); font-size:20px; margin-top:2px; }
.fv-legal-callout p{ margin:0; font-size:14.5px; }
.fv-legal-contact{ background:var(--fv-soft,#f7f9ff); border:1px solid var(--fv-line); border-radius:12px; padding:16px 18px; }
.fv-legal-fineprint{ font-size:13px !important; color:var(--fv-muted) !important; border-top:1px dashed var(--fv-line); padding-top:18px; margin-top:30px !important; }

.fv-legal-toc{ position:sticky; top:20px; background:#fff; border:1px solid var(--fv-line); border-radius:16px; padding:18px; }
.fv-legal-toc h3{ font-size:13px; text-transform:uppercase; letter-spacing:.05em; color:var(--fv-muted); margin:0 0 12px; }
.fv-legal-toc nav{ display:flex; flex-direction:column; gap:3px; }
.fv-legal-toc a{ color:#41506e; text-decoration:none; font-size:13.5px; font-weight:600; padding:6px 8px; border-radius:8px; transition:.14s; }
.fv-legal-toc a:hover{ background:var(--fv-soft,#f7f9ff); color:var(--fv-accent); }

/* ---- Contact ---- */
.fv-contact-grid{ display:grid; grid-template-columns:1fr 320px; gap:40px; align-items:start; padding-top:44px; padding-bottom:64px; }
.fv-contact-form-card{ background:#fff; border:1px solid var(--fv-line); border-radius:20px; padding:28px 28px 30px; box-shadow:0 12px 40px rgba(16,30,70,.06); }
.fv-contact-form-card h2{ font-size:21px; font-weight:800; color:var(--fv-ink); margin:0 0 20px; }
.fv-cf-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fv-cf-fld{ margin-bottom:16px; }
.fv-cf-fld label{ display:block; font-size:13px; font-weight:700; color:var(--fv-ink); margin-bottom:7px; }
.fv-cf-fld input, .fv-cf-fld textarea{ width:100%; box-sizing:border-box; border:1.5px solid var(--fv-line); border-radius:11px;
  padding:12px 14px; font-size:14.5px; font-family:inherit; color:var(--fv-ink); background:#fcfdff; transition:.16s; }
.fv-cf-fld input:focus, .fv-cf-fld textarea:focus{ outline:none; border-color:var(--fv-accent); background:#fff; box-shadow:0 0 0 3px rgba(78,79,235,.12); }
.fv-cf-fld textarea{ resize:vertical; min-height:130px; }
.fv-cf-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.fv-contact-success{ display:flex; gap:14px; align-items:flex-start; background:#eafaf0; border:1px solid #b9e7cb; border-radius:14px; padding:18px 20px; }
.fv-contact-success i{ color:#35b757; font-size:24px; margin-top:2px; }
.fv-contact-success b{ color:var(--fv-ink); font-size:15.5px; }
.fv-contact-success p{ color:#41506e; font-size:14px; margin:4px 0 0; }
.fv-contact-error{ display:flex; gap:10px; align-items:center; background:#fdeeee; border:1px solid #f3c4c4; color:#b53535;
  border-radius:11px; padding:12px 15px; font-size:14px; font-weight:600; margin-bottom:18px; }
.fv-contact-side{ display:flex; flex-direction:column; gap:14px; }
.fv-contact-info{ display:flex; gap:14px; align-items:flex-start; background:#fff; border:1px solid var(--fv-line); border-radius:14px; padding:16px 18px; }
.fv-contact-info .ic{ width:42px; height:42px; flex:none; border-radius:11px; display:flex; align-items:center; justify-content:center;
  background:var(--fv-soft,rgba(78,79,235,.1)); color:var(--fv-accent); font-size:17px; }
.fv-contact-info b{ display:block; color:var(--fv-ink); font-size:14.5px; margin-bottom:3px; }
.fv-contact-info p{ color:var(--fv-muted); font-size:13.5px; line-height:1.5; margin:0; }
.fv-contact-info a{ color:var(--fv-accent); text-decoration:none; font-weight:600; font-size:14px; }

@media (max-width:860px){
  .fv-legal-wrap, .fv-contact-grid{ grid-template-columns:1fr; gap:28px; }
  .fv-legal-toc{ position:static; order:-1; }
  .fv-cf-row{ grid-template-columns:1fr; }
}
/* END FV-LEGAL-PATCH v1 */
