/* ==========================================================================
   Inspira Brechó — Design System
   Portado do handoff (project/_shared.js). Escopo: .ib (todo o conteúdo do
   tema é envolvido em <div class="ib"> via header.php/footer.php).

   NOTA: o protótipo usava !important em tudo porque era feito para colar em
   widgets HTML do Elementor. Aqui é um tema próprio com escopo .ib, então os
   !important foram removidos — o CSS fica sustentável e o WooCommerce continua
   sobrescrevível. As cores/medidas são idênticas ao design original.
   ========================================================================== */

/* ─── Tokens ──────────────────────────────────────────── */
.ib {
  --teal-900: #2F5052;
  --teal-800: #3D6063;
  --teal-700: #4A7274;
  --teal-600: #557577;
  --teal-500: #6B8B8C;
  --teal-400: #93B5B3;
  --teal-200: #C7D9D6;
  --teal-50:  #ECF1EF;
  --cream-50:  #FBF7EE;
  --cream-100: #F5EEE3;
  --cream-200: #F1EAE0;
  --cream-300: #E8DECE;
  --cream-400: #D8CBB4;
  --terracotta: #C97F50;
  --terracotta-700: #A86438;
  --ink-900: #2A241D;
  --ink-700: #4A3F33;
  --ink-500: #7A6B5B;
  --ink-400: #9B8C7C;
  --line: #DBCFBC;
  --success: #5C8A6A;
  --error: #B25C4A;
  --font-body: 'Outfit', system-ui, -apple-system, sans-serif;
  font-family: var(--font-body);
  color: var(--ink-700);
  background: var(--cream-200);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ─── Reset com escopo ────────────────────────────────── */
.ib *, .ib *::before, .ib *::after { box-sizing: border-box; }
.ib img { max-width: 100%; height: auto; display: block; }
.ib a { color: inherit; text-decoration: none; }
.ib button { font-family: inherit; cursor: pointer; border: 0; background: none; padding: 0; color: inherit; }
.ib input, .ib textarea, .ib select { font-family: inherit; color: inherit; }
/* Reset de headings: zera só margin-top (o que o browser adiciona e desalinha o topo).
   margin-bottom fica a cargo de cada classe de título (.ib-hero__h, .ib-edit__h, etc.);
   antes o shorthand margin:0 (0,1,1) vencia as classes (0,1,0) e grudava título no texto. */
.ib h1, .ib h2, .ib h3, .ib h4, .ib h5 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 500; color: var(--ink-900); line-height: 1.15; margin-top: 0; letter-spacing: -0.01em; }
.ib p { margin: 0; }
.ib ul, .ib ol { margin: 0; }
.ib :focus-visible { outline: 2px solid var(--teal-700); outline-offset: 2px; }
.ib .screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ─── Skip link (acessibilidade) ──────────────────────── */
.ib-skip-link { position: absolute; left: -9999px; top: 0; z-index: 1000; background: var(--teal-800); color: #fff; padding: 12px 18px; border-radius: 0 0 6px 0; font-size: 13px; font-weight: 700; }
.ib-skip-link:focus { left: 0; }

/* ─── Top bar ─────────────────────────────────────────── */
.ib-topbar { background: var(--teal-600); color: #F3EBDC; text-align: center; padding: 11px 16px; font-size: 13px; letter-spacing: 0.02em; }
.ib-topbar b { font-weight: 600; }

/* ─── Header ──────────────────────────────────────────── */
.ib-header { background: var(--cream-200); padding: 22px 40px 12px; }
.ib-header__row { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 16px; max-width: 1280px; margin: 0 auto; }
.ib-header__left, .ib-header__right { display: flex; align-items: center; gap: 24px; }
.ib-header__right { justify-content: flex-end; }
.ib-iconbtn { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; letter-spacing: 0.06em; color: var(--ink-900); font-weight: 500; text-transform: uppercase; position: relative; background: none; }
.ib-iconbtn svg { width: 22px; height: 22px; stroke: var(--ink-900); stroke-width: 1.6; fill: none; }
.ib-cart-count { position: absolute; top: -6px; right: -10px; background: var(--teal-700); color: #fff; font-size: 10px; line-height: 1; padding: 3px 5px; border-radius: 999px; min-width: 16px; text-align: center; }
.ib-logo { text-align: center; line-height: 1; }
.ib-logo img { display: inline-block; max-height: 64px; width: auto; margin: 0 auto; }
.ib-logo__word { font-family: 'Cormorant Garamond', Georgia, serif; font-style: italic; font-weight: 700; font-size: 44px; color: var(--teal-700); letter-spacing: 0.04em; }
.ib-logo__sub { font-family: 'Cormorant Garamond', Georgia, serif; font-style: italic; font-size: 14px; color: var(--teal-700); opacity: 0.85; letter-spacing: 0.04em; margin-top: 2px; }

/* ─── Hamburger (mobile) ──────────────────────────────── */
.ib-burger { display: none; width: 26px; height: 22px; position: relative; }
.ib-burger span { position: absolute; left: 0; right: 0; height: 2px; background: var(--ink-900); transition: transform .25s ease, opacity .25s ease; }
.ib-burger span:nth-child(1) { top: 0; }
.ib-burger span:nth-child(2) { top: 10px; }
.ib-burger span:nth-child(3) { top: 20px; }
.ib-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(10px) rotate(45deg); }
.ib-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.ib-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-10px) rotate(-45deg); }

/* ─── Nav ─────────────────────────────────────────────── */
.ib-nav { border-top: 1px solid var(--cream-300); padding-top: 14px; margin-top: 14px; }
.ib-nav__list { width: 100%; margin: 0; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 8px 14px; list-style: none; padding: 0; }
.ib-nav__list a { font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; font-weight: 600; color: var(--ink-900); padding: 4px 0; display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.ib-nav__list a.is-sale, .ib-nav__list li.is-sale > a { color: var(--terracotta); }
.ib-nav__list li.current-menu-item > a, .ib-nav__list a.is-active { color: var(--teal-700); }
.ib-nav__list li { position: relative; }
.ib-nav__caret { width: 7px; height: 7px; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg) translate(-1px,-2px); opacity: 0.6; flex-shrink: 0; }
/* ícone da categoria no menu */
.ib-cat-icon { width: 15px; height: 15px; flex-shrink: 0; color: var(--teal-700); }
.ib-nav__list li.is-sale > a .ib-cat-icon { color: var(--terracotta); }
/* submenu dropdown */
.ib-nav__list .sub-menu { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); min-width: 230px; background: #fff; border: 1px solid var(--cream-300); border-radius: 6px; box-shadow: 0 16px 40px rgba(42,36,29,0.12); padding: 8px; list-style: none; margin: 0; opacity: 0; visibility: hidden; transition: opacity .18s ease, transform .18s ease; z-index: 60; }
.ib-nav__list li:hover > .sub-menu, .ib-nav__list li:focus-within > .sub-menu, .ib-nav__list li.is-open > .sub-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(2px); }
.ib-nav__list .sub-menu a { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 4px; letter-spacing: 0.06em; }
.ib-nav__list .sub-menu a:hover { background: var(--cream-100); color: var(--teal-700); }
.ib-nav__list .sub-menu .ib-cat-icon { width: 18px; height: 18px; color: var(--teal-700); opacity: 0.85; }

/* ─── Buttons ─────────────────────────────────────────── */
.ib-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 13px 26px; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; border-radius: 4px; transition: all .2s ease; line-height: 1; border: 1.5px solid transparent; cursor: pointer; text-align: center; }
.ib-btn--primary { background: var(--teal-700); color: #fff; }
.ib-btn--primary:hover { background: var(--teal-800); color: #fff; }
.ib-btn--outline { background: transparent; color: var(--teal-800); border-color: var(--teal-700); }
.ib-btn--outline:hover { background: var(--teal-50); }
.ib-btn--ghost { background: transparent; color: var(--ink-900); border-color: var(--line); }
.ib-btn--full { width: 100%; }
.ib-btn--lg { padding: 16px 32px; font-size: 13px; }
.ib-btn svg { width: 16px; height: 16px; }
.ib-btn[disabled] { opacity: .55; cursor: not-allowed; }
/* Especificidade reforçada: o reset .ib a / .ib button (0,1,1) vencia .ib-btn--* (0,1,0),
   apagando cor/fundo/borda dos botões em <a> e <button>. Prefixar com .ib iguala em (0,2,0). */
.ib a.ib-btn, .ib button.ib-btn { padding: 13px 26px; border: 1.5px solid transparent; }
.ib a.ib-btn--lg, .ib button.ib-btn--lg { padding: 16px 32px; }
.ib a.ib-btn--primary, .ib button.ib-btn--primary { background: var(--teal-700); color: #fff; }
.ib a.ib-btn--primary:hover, .ib button.ib-btn--primary:hover { background: var(--teal-800); color: #fff; }
.ib a.ib-btn--outline, .ib button.ib-btn--outline { background: transparent; color: var(--teal-800); border-color: var(--teal-700); }
.ib a.ib-btn--outline:hover, .ib button.ib-btn--outline:hover { background: var(--teal-50); }
.ib a.ib-btn--ghost, .ib button.ib-btn--ghost { background: transparent; color: var(--ink-900); border-color: var(--line); }

/* ─── Heart accent doodle ─────────────────────────────── */
.ib-heart { display: inline-block; vertical-align: -2px; margin-left: 8px; width: 28px; height: 24px; }

/* ─── Breadcrumbs ─────────────────────────────────────── */
.ib-crumbs { font-size: 13px; color: var(--ink-500); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ib-crumbs a:hover { color: var(--teal-700); }
.ib-crumbs span.sep, .ib-crumbs .ib-crumbs__sep { opacity: 0.5; }
.ib-crumbs .now { color: var(--ink-900); }

/* ─── Container ───────────────────────────────────────── */
.ib-wrap { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
/* Variante larga para fluxos que pedem mais respiro horizontal (carrinho/checkout). */
.ib-wrap--wide { max-width: 1640px; }
.ib-section { padding: 72px 0; }

/* ─── Grids utilitários (responsivos) ─────────────────── */
/* Usados no lugar de style="grid-template-columns:repeat(N,1fr)" inline, que não
   colapsava no mobile. Colapso definido nas media queries (640/480px). */
.ib-grid { display: grid; gap: 24px; }
.ib-grid--2 { grid-template-columns: repeat(2, 1fr); }
.ib-grid--3 { grid-template-columns: repeat(3, 1fr); }
.ib-grid--4 { grid-template-columns: repeat(4, 1fr); }
.ib-section__title { text-align: center; font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 600; color: var(--ink-900); margin-bottom: 36px; font-family: var(--font-body); }
.ib-section__h { font-family: 'Cormorant Garamond', serif; font-size: 44px; color: var(--ink-900); font-weight: 500; line-height: 1.1; }
.ib-page-pad { padding: 28px 0 16px; }

/* ─── Hero ────────────────────────────────────────────── */
.ib-hero { display: grid; grid-template-columns: minmax(380px, 1fr) 1.4fr; gap: 0; background: var(--cream-100); align-items: stretch; }
.ib-hero__copy { padding: 80px 56px; display: flex; flex-direction: column; justify-content: center; max-width: 560px; margin-left: auto; }
.ib-hero__eyebrow { font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-500); font-weight: 600; margin-bottom: 18px; }
.ib-hero__h { font-size: 60px; line-height: 1.05; color: var(--ink-900); margin-bottom: 22px; font-weight: 500; }
.ib-hero__p { font-size: 16px; color: var(--ink-700); max-width: 420px; margin-bottom: 32px; }
.ib-hero__img { background: var(--cream-300); min-height: 560px; position: relative; overflow: hidden; }
.ib-hero__img img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }

/* ─── Placeholder image art ───────────────────────────── */
.ib-img { background: var(--cream-300); position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.ib-img > img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; z-index: 1; }
.ib-img::before { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(135deg, transparent 0 14px, rgba(74,63,51,0.05) 14px 15px); }
.ib-img.has-img::before { display: none; }
.ib-img__label { position: relative; z-index: 2; font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 11px; color: rgba(74,63,51,0.55); text-align: center; padding: 6px 14px; background: rgba(245,238,227,0.78); border: 1px dashed rgba(74,63,51,0.25); border-radius: 3px; }
.ib-img--warm { background: linear-gradient(135deg, #E8D9BF 0%, #D8C3A0 100%); }
.ib-img--olive { background: linear-gradient(135deg, #C7C8A8 0%, #A9AC85 100%); }
.ib-img--terra { background: linear-gradient(135deg, #D8A580 0%, #B6764B 100%); }
.ib-img--sage  { background: linear-gradient(135deg, #B5C2B1 0%, #8FA48A 100%); }
.ib-img--linen { background: linear-gradient(135deg, #EFE6D2 0%, #DCCFB1 100%); }
.ib-img--mauve { background: linear-gradient(135deg, #CFB7B5 0%, #A48584 100%); }
.ib-img--mustard { background: linear-gradient(135deg, #DDC07A 0%, #B89548 100%); }
.ib-img--charcoal { background: linear-gradient(135deg, #6B6B66 0%, #43423E 100%); }
.ib-img--cream { background: linear-gradient(135deg, #F2E8D2 0%, #E2D2B0 100%); }

/* ─── Benefits row ────────────────────────────────────── */
.ib-benefits { background: var(--cream-100); padding: 28px 0; border-top: 1px solid var(--cream-300); border-bottom: 1px solid var(--cream-300); }
.ib-benefits__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.ib-benefit { display: flex; align-items: center; gap: 16px; padding: 12px 24px; border-right: 1px solid var(--cream-300); }
.ib-benefit:last-child { border-right: 0; }
.ib-benefit svg { width: 38px; height: 38px; stroke: var(--teal-700); stroke-width: 1.4; fill: none; flex-shrink: 0; }
.ib-benefit__t { font-size: 11.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-900); margin-bottom: 4px; }
.ib-benefit__d { font-size: 12.5px; color: var(--ink-500); line-height: 1.4; }

/* ─── Categories grid (HOME) ──────────────────────────── */
.ib-cats { display: grid; grid-template-columns: repeat(8, 1fr); gap: 14px; padding: 0 40px; max-width: 1440px; margin: 0 auto; }
.ib-cat { position: relative; aspect-ratio: 3 / 4; border-radius: 6px; overflow: hidden; display: block; }
.ib-cat img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.ib-cat::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.5) 100%); z-index: 1; }
.ib-cat__name { position: absolute; bottom: 14px; left: 0; right: 0; z-index: 2; text-align: center; color: #fff; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; text-shadow: 0 1px 2px rgba(0,0,0,0.4); }

/* ─── Editorial 2-col ──────────────────────────────────── */
.ib-edit { display: grid; grid-template-columns: 1fr 1fr; gap: 0; background: var(--cream-100); }
.ib-edit__card { padding: 64px 56px; display: flex; flex-direction: column; justify-content: center; }
.ib-edit__card--media { padding: 0; min-height: 460px; }
.ib-edit__eyebrow { font-size: 11.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--teal-700); font-weight: 700; margin-bottom: 16px; }
/* Badge do ícone da categoria no hero (.ib-edit__card de archive-product). */
.ib-cat-hero-badge { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: 999px; background: #fff; border: 1px solid var(--cream-300); margin-bottom: 18px; }
.ib-cat-hero-icon { width: 28px; height: 28px; color: var(--teal-700); }
.ib-edit__h { font-size: 38px; color: var(--ink-900); margin-bottom: 20px; line-height: 1.1; }
.ib-edit__p { font-size: 15px; color: var(--ink-700); margin-bottom: 14px; }
.ib-edit__media-split { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 6px; height: 100%; min-height: 460px; }
.ib-edit__media-split > div { min-height: 220px; }
.ib-edit__list { list-style: none; padding: 0; margin: 8px 0 22px; display: flex; flex-direction: column; gap: 10px; }
.ib-edit__list li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--ink-700); }
.ib-edit__list li::before { content: ''; width: 7px; height: 7px; border-radius: 999px; background: var(--terracotta); margin-top: 7px; flex-shrink: 0; }
/* Respiro entre o último texto/lista e o botão do card editorial (estava colado). */
.ib-edit__card > div:has(> .ib-btn) { margin-top: 28px; }

/* ─── Product cards ───────────────────────────────────── */
.ib-pgrid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 20px; }
.ib-pgrid--5 { grid-template-columns: repeat(5, 1fr); }
.ib-pgrid--4 { grid-template-columns: repeat(4, 1fr); }
.ib-pgrid--3 { grid-template-columns: repeat(3, 1fr); }
.ib-card { position: relative; }
.ib-card__media { aspect-ratio: 4 / 5; border-radius: 4px; overflow: hidden; margin-bottom: 12px; position: relative; display: block; }
.ib-card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.ib-card:hover .ib-card__media img { transform: scale(1.04); }
.ib-card__fav { position: absolute; top: 10px; right: 10px; width: 32px; height: 32px; background: rgba(255,255,255,0.92); border-radius: 999px; display: flex; align-items: center; justify-content: center; z-index: 3; transition: background .2s; }
.ib-card__fav:hover { background: #fff; }
.ib-card__fav svg { width: 16px; height: 16px; stroke: var(--ink-900); stroke-width: 1.6; fill: none; }
.ib-card__fav.is-active svg { fill: var(--terracotta); stroke: var(--terracotta); }
.ib-card__tag { position: absolute; top: 10px; left: 10px; background: var(--terracotta); color: #fff; font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; padding: 4px 8px; border-radius: 3px; z-index: 3; }
.ib-card__tag--green { background: var(--success); }
.ib-card__name { font-size: 13.5px; color: var(--ink-900); font-weight: 500; margin-bottom: 4px; font-family: var(--font-body); }
.ib-card__price { font-size: 14px; color: var(--ink-900); font-weight: 700; }
.ib-card__price del { color: var(--ink-400); font-weight: 500; margin-right: 6px; font-size: 13px; }
.ib-card__price ins { text-decoration: none; }
.ib-card__inst { font-size: 12px; color: var(--ink-500); margin-top: 2px; }

/* ─── Footer strip ────────────────────────────────────── */
.ib-foot-strip { background: var(--cream-100); border-top: 1px solid var(--cream-300); padding: 28px 0; }
.ib-foot-strip__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.ib-foot-strip__item { display: flex; gap: 14px; padding: 8px 24px; border-right: 1px solid var(--cream-300); align-items: center; }
.ib-foot-strip__item:last-child { border-right: 0; }
.ib-foot-strip__item svg { width: 36px; height: 36px; stroke: var(--teal-700); stroke-width: 1.4; fill: none; flex-shrink: 0; }
.ib-foot-strip__t { font-size: 11.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-900); margin-bottom: 3px; }
.ib-foot-strip__d { font-size: 12px; color: var(--ink-500); line-height: 1.4; }

/* ─── Footer ──────────────────────────────────────────── */
.ib-footer { background: var(--teal-800); color: #E8DECE; padding: 64px 0 24px; }
.ib-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1.2fr; gap: 36px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.ib-footer__brand { font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 700; font-size: 34px; color: #F3EBDC; line-height: 1; margin-bottom: 10px; }
.ib-footer__brand-sub { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 13px; color: rgba(243,235,220,0.78); margin-bottom: 18px; }
.ib-footer__desc { font-size: 13px; line-height: 1.6; color: rgba(232,222,206,0.78); margin-bottom: 22px; max-width: 300px; }
.ib-footer__h { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; color: #F3EBDC; margin-bottom: 18px; font-family: var(--font-body); }
.ib-footer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.ib-footer__list a { font-size: 13.5px; color: rgba(232,222,206,0.82); }
.ib-footer__list a:hover { color: #fff; }
.ib-footer__newsletter { display: flex; flex-direction: column; gap: 8px; }
.ib-footer__newsletter input { width: 100%; padding: 12px 14px; border: 1px solid rgba(255,255,255,0.22); border-radius: 4px; outline: none; background: rgba(255,255,255,0.04); color: #fff; font-size: 13px; }
.ib-footer__newsletter input:focus { border-color: rgba(255,255,255,0.5); }
.ib-footer__newsletter input::placeholder { color: rgba(232,222,206,0.55); }
.ib-footer__newsletter button { width: 100%; padding: 12px 18px; border-radius: 4px; background: var(--cream-200); color: var(--teal-800); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; }
.ib-footer__newsletter button:hover { background: #fff; }
.ib-footer__pay { display: flex; gap: 8px; margin-top: 22px; flex-wrap: wrap; }
.ib-footer__pay span { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.12); border-radius: 3px; padding: 6px 10px; font-size: 10px; letter-spacing: 0.08em; font-weight: 700; color: #F3EBDC; }
.ib-footer__social { display: flex; gap: 12px; margin-top: 22px; }
.ib-footer__social a { width: 36px; height: 36px; border: 1px solid rgba(255,255,255,0.22); border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; }
.ib-footer__social a:hover { border-color: rgba(255,255,255,0.5); }
.ib-footer__social svg { width: 16px; height: 16px; stroke: #F3EBDC; stroke-width: 1.6; fill: none; }
.ib-footer__bottom { padding-top: 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; font-size: 12px; color: rgba(232,222,206,0.6); }

/* ─── Forms ──────────────────────────────────────────── */
.ib-field { display: flex; flex-direction: column; gap: 7px; }
.ib-field__label, .ib label.ib-field__label { font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; color: var(--ink-900); }
.ib-field__label .req, .ib .required { color: var(--terracotta); }
.ib-input, .ib-select, .ib-textarea,
.ib input[type="text"], .ib input[type="email"], .ib input[type="tel"],
.ib input[type="password"], .ib input[type="number"], .ib input[type="search"],
.ib input[type="url"], .ib textarea, .ib select {
  background: #fff; border: 1px solid var(--cream-400); padding: 13px 14px; border-radius: 4px; font-size: 14px; color: var(--ink-900); outline: none; width: 100%; transition: border-color .2s; font-family: inherit;
}
.ib-input:focus, .ib-select:focus, .ib-textarea:focus,
.ib input:focus, .ib textarea:focus, .ib select:focus { border-color: var(--teal-700); }
.ib-textarea, .ib textarea { min-height: 120px; resize: vertical; }
.ib-checkbox { display: inline-flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--ink-700); cursor: pointer; }
.ib-checkbox input { width: 18px; height: 18px; margin-top: 1px; accent-color: var(--teal-700); flex-shrink: 0; }

/* ─── Cards genéricos / boxes ─────────────────────────── */
.ib-box { background: #fff; border: 1px solid var(--cream-300); border-radius: 8px; padding: 28px; }
.ib-box--cream { background: var(--cream-100); }
.ib-box--summary { background: #EFE4D1; border-color: #E4D4BB; }

/* ─── Filter bar ──────────────────────────────────────── */
/* Flex (não grid fixo): a barra se adapta ao nº real de filtros. Antes era
   grid de 6 colunas fixas, então quando Tamanho/Cor não existiam sobravam
   colunas vazias e os itens ficavam desalinhados. */
.ib-filterbar { display: flex; flex-wrap: wrap; align-items: stretch; gap: 0; background: #fff; border: 1px solid var(--cream-300); border-radius: 6px; margin-bottom: 28px; }
.ib-filterbar__item { padding: 14px 18px; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; color: var(--ink-900); display: flex; align-items: center; justify-content: space-between; gap: 12px; border-right: 1px solid var(--cream-300); cursor: pointer; position: relative; background: none; min-width: 150px; }
.ib-filterbar__item:last-child { border-right: 0; }
.ib-filterbar__item .ib-nav__caret { opacity: 0.5; }
/* "Ordenar por" empurra a si e ao "Limpar" para a direita. */
.ib-filterbar__sort { margin-left: auto; color: var(--ink-500); font-weight: 500; text-transform: none; letter-spacing: 0; font-size: 13px; }
.ib-filterbar__sort select { border: 0; background: none; padding: 0 18px 0 4px; width: auto; font-weight: 700; color: var(--ink-900); cursor: pointer; }
.ib-filterbar__clear { color: var(--teal-800); font-weight: 700; }
.ib-filterbar__panel { position: absolute; top: calc(100% + 6px); left: -1px; min-width: 220px; background: #fff; border: 1px solid var(--cream-300); border-radius: 6px; box-shadow: 0 16px 40px rgba(42,36,29,0.12); padding: 12px; z-index: 50; display: none; text-transform: none; letter-spacing: 0; font-weight: 500; }
.ib-filterbar__item.is-open .ib-filterbar__panel { display: block; }
.ib-filterbar__panel a { display: block; padding: 7px 8px; border-radius: 4px; font-size: 13px; color: var(--ink-700); }
.ib-filterbar__panel a:hover { background: var(--cream-100); color: var(--teal-700); }

/* ─── Pagination ──────────────────────────────────────── */
.ib-pager { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 40px; }
.ib-pager a, .ib-pager span { width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--cream-300); border-radius: 4px; font-size: 13px; font-weight: 600; color: var(--ink-700); }
.ib-pager .current, .ib-pager a.is-active { background: var(--teal-700); color: #fff; border-color: var(--teal-700); }
.ib-pager a:hover { border-color: var(--teal-700); color: var(--teal-700); }

/* ─── Star rating ─────────────────────────────────────── */
.ib-stars { color: var(--terracotta); letter-spacing: 2px; font-size: 14px; }

/* ─── Notices (WooCommerce) ───────────────────────────── */
.ib-notice, .ib .woocommerce-message, .ib .woocommerce-info, .ib .woocommerce-error, .ib .woocommerce-noreviews {
  border-radius: 6px; padding: 14px 18px; font-size: 14px; margin-bottom: 20px; list-style: none; border: 1px solid;
}
.ib .woocommerce-message { background: #EAF3EC; border-color: #CADFCF; color: #2F5B3C; }
.ib .woocommerce-info, .ib .woocommerce-noreviews { background: var(--teal-50); border-color: var(--teal-200); color: var(--teal-900); }
.ib .woocommerce-error { background: #F7E7E2; border-color: #E7C5BB; color: #8A3B2A; }
.ib .woocommerce-error li, .ib .woocommerce-message li, .ib .woocommerce-info li { margin: 0; }

/* ==========================================================================
   Componentes específicos de páginas (estavam inline no protótipo)
   ========================================================================== */

/* ─── Depoimentos (home) ──────────────────────────────── */
.ib-quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ib-quote { background: #fff; border: 1px solid var(--cream-300); border-radius: 8px; padding: 28px; }
.ib-quote__stars { margin-bottom: 12px; }
.ib-quote__text { font-family: 'Cormorant Garamond', serif; font-size: 20px; color: var(--ink-900); line-height: 1.4; margin-bottom: 16px; font-style: italic; }
.ib-quote__who { font-size: 13px; font-weight: 700; color: var(--ink-900); }
.ib-quote__meta { font-size: 12px; color: var(--ink-500); margin-top: 2px; }

/* ─── Instagram grid (home) ───────────────────────────── */
.ib-insta-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; }
.ib-insta-grid .ib-img { aspect-ratio: 1 / 1; border-radius: 6px; }

/* ─── Newsletter band ─────────────────────────────────── */
.ib-news-band { background: var(--cream-100); border-top: 1px solid var(--cream-300); border-bottom: 1px solid var(--cream-300); }
.ib-news-form { display: flex; gap: 10px; max-width: 480px; margin: 0 auto; }
.ib-news-form input { flex: 1; }

/* ─── Single product layout ───────────────────────────── */
.ib-product { display: grid; grid-template-columns: 110px 1fr 460px; gap: 28px; align-items: start; }
.ib-product__thumbs { display: flex; flex-direction: column; gap: 10px; }
.ib-product__thumb { aspect-ratio: 4/5; border-radius: 4px; overflow: hidden; border: 2px solid transparent; cursor: pointer; position: relative; background: var(--cream-300); }
.ib-product__thumb.is-active { border-color: var(--teal-700); }
.ib-product__thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ib-product__main { aspect-ratio: 4/5; border-radius: 6px; overflow: hidden; position: relative; }
.ib-product__main img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ib-product__h { font-size: 36px; color: var(--ink-900); margin-bottom: 12px; }
.ib-product__price { font-size: 26px; color: var(--ink-900); font-weight: 700; font-family: var(--font-body); }
.ib-product__price del { color: var(--ink-400); font-weight: 500; font-size: 18px; margin-right: 8px; }
.ib-product__price ins { text-decoration: none; }
.ib-product__inst { font-size: 13px; color: var(--ink-500); margin-top: 4px; }
.ib-product__hr { border: 0; border-top: 1px solid var(--cream-300); margin: 22px 0; }
.ib-product__short { font-size: 15px; color: var(--ink-700); line-height: 1.6; }
.ib-swatches { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.ib-swatch { min-width: 46px; padding: 11px 12px; border: 1.5px solid var(--cream-400); border-radius: 4px; font-size: 13px; font-weight: 700; color: var(--ink-900); text-align: center; background: #fff; cursor: pointer; transition: all .15s; }
.ib-swatch:hover { border-color: var(--teal-700); }
.ib-swatch.is-active { background: var(--teal-700); color: #fff; border-color: var(--teal-700); }
.ib-swatch.is-disabled { opacity: .4; cursor: not-allowed; text-decoration: line-through; }
.ib-measure-link { font-size: 12px; color: var(--teal-800); font-weight: 700; text-decoration: underline; margin-left: auto; }
.ib-condition { background: var(--teal-50); border: 1px solid var(--teal-200); border-radius: 6px; padding: 14px 16px; display: flex; gap: 12px; align-items: flex-start; margin: 18px 0; }
.ib-condition svg { width: 24px; height: 24px; stroke: var(--teal-700); fill: none; stroke-width: 1.6; flex-shrink: 0; }
.ib-condition__t { font-size: 11.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--teal-900); margin-bottom: 3px; }
.ib-condition__d { font-size: 13px; color: var(--ink-700); }
.ib-cep { border: 1px dashed var(--cream-400); border-radius: 6px; padding: 16px; margin-top: 18px; }
.ib-cep__row { display: flex; gap: 8px; margin-top: 8px; }
.ib-cep__row input { flex: 1; }
.ib-qty { display: inline-flex; align-items: center; border: 1px solid var(--cream-400); border-radius: 4px; overflow: hidden; }
.ib-qty button { width: 40px; height: 46px; font-size: 18px; color: var(--ink-900); background: #fff; }
.ib-qty button:hover { background: var(--cream-100); }
.ib-qty input { width: 48px; height: 46px; text-align: center; border: 0; border-left: 1px solid var(--cream-400); border-right: 1px solid var(--cream-400); padding: 0; border-radius: 0; -moz-appearance: textfield; }
.ib-qty input::-webkit-outer-spin-button, .ib-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.ib-product__actions { display: flex; gap: 12px; margin-top: 18px; flex-wrap: wrap; }
.ib-product__actions .ib-qty { flex-shrink: 0; }
.ib-product__actions .ib-btn--primary { flex: 1; }

/* specs / cuidados / faq do produto */
.ib-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 14px; }
.ib-specs__card { background: #fff; border: 1px solid var(--cream-300); border-radius: 10px; padding: 26px 28px; }
.ib-specs__head { display: flex; align-items: center; gap: 10px; padding-bottom: 14px; margin-bottom: 16px; border-bottom: 1px solid var(--cream-300); }
.ib-specs__head svg { color: var(--teal-700); flex-shrink: 0; }
.ib-specs__h { font-size: 22px; margin: 0; }
.ib-specs__list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.ib-specs__list li { display: flex; gap: 10px; font-size: 14px; color: var(--ink-700); align-items: flex-start; }
.ib-specs__list li::before { content: ''; width: 6px; height: 6px; border-radius: 999px; background: var(--teal-700); margin-top: 8px; flex-shrink: 0; }
.ib-specs__care { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.ib-specs__care li { display: flex; gap: 10px; font-size: 14px; color: var(--ink-700); align-items: flex-start; line-height: 1.5; }
.ib-specs__care svg { color: var(--teal-700); flex-shrink: 0; margin-top: 2px; }

/* acordeão genérico (details/summary nativo) */
.ib-acc { border: 1px solid var(--cream-300); border-radius: 8px; overflow: hidden; background: #fff; }
.ib-acc details { border-bottom: 1px solid var(--cream-300); }
.ib-acc details:last-child { border-bottom: 0; }
.ib-acc summary { list-style: none; cursor: pointer; padding: 18px 20px; font-weight: 600; color: var(--ink-900); font-size: 15px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.ib-acc summary::-webkit-details-marker { display: none; }
.ib-acc summary .ib-nav__caret { transition: transform .2s; }
.ib-acc details[open] summary .ib-nav__caret { transform: rotate(225deg) translate(2px,2px); }
.ib-acc__body { padding: 0 20px 18px; font-size: 14px; color: var(--ink-700); line-height: 1.6; }

/* ─── Cart ────────────────────────────────────────────── */
.ib-cart-table { background: #fff; border: 1px solid var(--cream-300); border-radius: 8px; overflow: hidden; }
.ib-cart-head, .ib-cart-row { display: grid; grid-template-columns: 2.6fr 1fr 1fr 1.2fr 1fr auto; align-items: center; gap: 12px; padding: 16px 20px; }
.ib-cart-head { background: var(--cream-100); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; color: var(--ink-500); }
.ib-cart-row { border-top: 1px solid var(--cream-300); }
.ib-cart-prod { display: flex; gap: 14px; align-items: center; }
.ib-cart-prod__media { width: 72px; height: 90px; border-radius: 4px; overflow: hidden; flex-shrink: 0; position: relative; background: var(--cream-300); }
.ib-cart-prod__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ib-cart-prod__name { font-size: 14px; font-weight: 600; color: var(--ink-900); }
.ib-cart-prod__sub { font-size: 12px; color: var(--ink-500); margin-top: 2px; }
.ib-cart-remove { color: var(--ink-400); }
.ib-cart-remove svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.6; }
.ib-cart-remove:hover { color: var(--error); }
.ib-cart-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 16px; font-size: 13px; font-weight: 700; letter-spacing: 0.04em; }
.ib-cart-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 28px; align-items: start; }
.ib-summary__row { display: flex; justify-content: space-between; padding: 10px 0; font-size: 14px; color: var(--ink-700); border-bottom: 1px solid rgba(0,0,0,0.06); }
.ib-summary__row--total { font-size: 18px; font-weight: 700; color: var(--ink-900); border-bottom: 0; padding-top: 16px; }
.ib-summary__inst { font-size: 12px; color: var(--ink-500); text-align: right; margin-top: 4px; }
.ib-coupon-row { display: flex; gap: 8px; }
.ib-coupon-row input { flex: 1; }
.ib-trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 40px; }
.ib-trust__item { display: flex; gap: 12px; align-items: center; padding: 16px; background: #fff; border: 1px solid var(--cream-300); border-radius: 8px; }
.ib-trust__item svg { width: 30px; height: 30px; stroke: var(--teal-700); fill: none; stroke-width: 1.5; flex-shrink: 0; }
.ib-trust__t { font-size: 12px; font-weight: 700; color: var(--ink-900); }
.ib-trust__d { font-size: 12px; color: var(--ink-500); }
.ib-cart-empty { text-align: center; padding: 60px 20px; }

/* ─── Checkout ────────────────────────────────────────── */
.ib-checkout { display: grid; grid-template-columns: 1.4fr 1fr; gap: 28px; align-items: start; }

/* Resumo do pedido (review-order.php) — itens com imagem + totais limpos.
   Tudo numa única <table> (exigência do JS do checkout); estilizada como blocos. */
.ib-review { width: 100%; border-collapse: collapse; }
.ib-review__item td { padding: 14px 0; border-bottom: 1px solid rgba(74,63,51,0.10); vertical-align: middle; }
.ib-review__items tr:first-child td { padding-top: 0; }
.ib-review__cell { display: flex; align-items: center; gap: 14px; }
.ib-review__thumb { position: relative; width: 56px; height: 70px; flex-shrink: 0; border-radius: 4px; overflow: hidden; background: var(--cream-200); }
.ib-review__thumb-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ib-review__qty { position: absolute; top: -7px; right: -7px; min-width: 20px; height: 20px; padding: 0 5px; border-radius: 999px; background: var(--teal-700); color: #fff; font-size: 11px; font-weight: 700; display: flex; align-items: center; justify-content: center; line-height: 1; }
.ib-review__info { min-width: 0; }
.ib-review__name { font-size: 13.5px; font-weight: 600; color: var(--ink-900); line-height: 1.3; }
.ib-review__meta { font-size: 12px; color: var(--ink-500); margin-top: 2px; }
.ib-review__qtylabel { font-size: 12px; color: var(--ink-500); margin-top: 3px; }
.ib-review__price { font-size: 14px; font-weight: 700; color: var(--ink-900); white-space: nowrap; text-align: right; vertical-align: middle; }
/* Totais (tfoot). */
.ib-review__totals th, .ib-review__totals td { padding: 9px 0; font-size: 14px; text-align: left; font-weight: 400; color: var(--ink-700); border: 0; }
.ib-review__totals td { text-align: right; font-weight: 600; color: var(--ink-900); }
.ib-review__totals tr { border-bottom: 1px solid rgba(74,63,51,0.08); }
.ib-review__totals tr:first-child th, .ib-review__totals tr:first-child td { padding-top: 16px; }
.ib-review__totals .order-total { border-bottom: 0; }
.ib-review__totals .order-total th { font-size: 16px; font-weight: 700; color: var(--ink-900); padding-top: 14px; }
.ib-review__totals .order-total td { font-size: 20px; font-weight: 700; color: var(--ink-900); padding-top: 14px; }
.ib-review__totals .order-total .woocommerce-Price-amount { color: var(--teal-800); }
.ib-steps { display: flex; align-items: center; gap: 0; margin-bottom: 26px; }
.ib-step { display: flex; align-items: center; gap: 10px; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; color: var(--ink-400); }
.ib-step__num { width: 28px; height: 28px; border-radius: 999px; background: var(--cream-300); color: var(--ink-500); display: flex; align-items: center; justify-content: center; font-size: 12px; }
.ib-step.is-active { color: var(--ink-900); }
.ib-step.is-active .ib-step__num { background: var(--teal-700); color: #fff; }
.ib-step__line { flex: 1; height: 1px; background: var(--cream-300); margin: 0 16px; min-width: 24px; }
.ib-fieldgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ib-fieldgrid--3 { grid-template-columns: 1fr 1fr 1fr; }
.ib-fieldgrid .ib-col-2 { grid-column: span 2; }
.ib-card-block { margin-bottom: 22px; }
.ib-card-block__h { font-size: 22px; margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.ib-ship-opt { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1px solid var(--cream-400); border-radius: 6px; margin-bottom: 10px; cursor: pointer; }
.ib-ship-opt.is-active, .ib-ship-opt:has(input:checked) { border-color: var(--teal-700); background: var(--teal-50); }
.ib-ship-opt input { width: 18px; height: 18px; accent-color: var(--teal-700); }
.ib-ship-opt__name { font-size: 14px; font-weight: 600; color: var(--ink-900); }
.ib-ship-opt__meta { font-size: 12px; color: var(--ink-500); }
.ib-ship-opt__price { margin-left: auto; font-weight: 700; color: var(--ink-900); }
.ib-paytabs { display: flex; gap: 8px; margin-bottom: 16px; }
.ib-paytab { flex: 1; padding: 13px; border: 1.5px solid var(--cream-400); border-radius: 6px; font-size: 12px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-700); background: #fff; }
.ib-paytab.is-active { border-color: var(--teal-700); background: var(--teal-50); color: var(--teal-900); }
.ib-order-mini { display: flex; flex-direction: column; gap: 12px; margin-bottom: 16px; }
.ib-order-mini__item { display: flex; gap: 12px; align-items: center; }
.ib-order-mini__media { width: 54px; height: 64px; border-radius: 4px; overflow: hidden; flex-shrink: 0; position: relative; background: var(--cream-300); }
.ib-order-mini__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ib-order-mini__name { font-size: 13px; font-weight: 600; color: var(--ink-900); }
.ib-order-mini__sub { font-size: 12px; color: var(--ink-500); }
.ib-order-mini__price { margin-left: auto; font-size: 13px; font-weight: 700; }
.ib-ssl { display: flex; gap: 8px; align-items: center; justify-content: center; font-size: 12px; color: var(--ink-500); margin-top: 14px; }
.ib-ssl svg { width: 16px; height: 16px; stroke: var(--success); fill: none; stroke-width: 1.8; }

/* ─── Account (login/register) ────────────────────────── */
.ib-auth { display: grid; grid-template-columns: 1fr 1fr; background: #fff; border: 1px solid var(--cream-300); border-radius: 10px; overflow: hidden; }
.ib-auth__col { padding: 48px; }
.ib-auth__col + .ib-auth__col { border-left: 1px solid var(--cream-300); }
.ib-auth__col--cream { background: var(--cream-100); }
.ib-auth__h { font-size: 30px; margin-bottom: 8px; }
.ib-auth__sub { font-size: 14px; color: var(--ink-500); margin-bottom: 24px; }
.ib-auth__form { display: flex; flex-direction: column; gap: 16px; }
.ib-auth__row { display: flex; justify-content: space-between; align-items: center; font-size: 13px; }
.ib-auth__sep { display: flex; align-items: center; gap: 14px; color: var(--ink-400); font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; margin: 4px 0; }
.ib-auth__sep::before, .ib-auth__sep::after { content: ''; flex: 1; height: 1px; background: var(--cream-300); }
.ib-benefits-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 16px; margin: 8px 0 26px; }
.ib-benefits-list li { display: flex; gap: 12px; align-items: flex-start; font-size: 14px; color: var(--ink-700); }
.ib-benefits-list svg { width: 22px; height: 22px; stroke: var(--teal-700); fill: none; stroke-width: 1.6; flex-shrink: 0; }
.ib-register { display: grid; grid-template-columns: 1.1fr 1fr; background: #fff; border: 1px solid var(--cream-300); border-radius: 10px; overflow: hidden; }
.ib-register__media { min-height: 100%; }
/* My account dashboard (WooCommerce) */
.ib-account { display: grid; grid-template-columns: 230px minmax(0, 1fr); gap: 28px; align-items: start; }
/* nav e conteúdo precisam preencher suas colunas (sem isso, encolhiam ao conteúdo). */
.ib-account > .woocommerce-MyAccount-navigation { width: 100%; }
.ib-account > .woocommerce-MyAccount-content { width: 100%; min-width: 0; }
.ib-account__nav { width: 100%; list-style: none; padding: 0; margin: 0; background: #fff; border: 1px solid var(--cream-300); border-radius: 8px; overflow: hidden; }
.ib-account__nav li { border-bottom: 1px solid var(--cream-300); }
.ib-account__nav li:last-child { border-bottom: 0; }
.ib-account__nav a { display: block; padding: 13px 18px; font-size: 13px; font-weight: 600; color: var(--ink-700); white-space: nowrap; }
.ib-account__nav li.is-active a, .ib-account__nav li.woocommerce-MyAccount-navigation-link--dashboard.is-active a { background: var(--cream-100); color: var(--teal-800); }
.ib-account__nav a:hover { background: var(--cream-50); color: var(--teal-800); }
/* Endereços (cobrança/entrega) — flex no lugar do float legado do WooCommerce. */
.ib .woocommerce-Addresses.col2-set { display: flex; flex-wrap: wrap; gap: 24px; width: 100%; }
.ib .woocommerce-Addresses.col2-set .col-1,
.ib .woocommerce-Addresses.col2-set .col-2,
.ib .woocommerce-Addresses .u-column1,
.ib .woocommerce-Addresses .u-column2 { flex: 1 1 0; min-width: 0; max-width: none !important; float: none !important; margin: 0 !important; clear: none !important; }
.ib .woocommerce-Address { background: #fff; border: 1px solid var(--cream-300); border-radius: 10px; padding: 20px 22px; height: 100%; }
.ib .woocommerce-Address-title { margin-bottom: 10px; }
.ib .woocommerce-Address-title h2, .ib .woocommerce-Address-title h3 { font-size: 20px; margin: 0 0 4px; }
.ib .woocommerce-Address-title .edit { font-size: 13px; color: var(--teal-700); font-weight: 600; }
.ib address { font-style: normal; font-size: 14px; color: var(--ink-700); line-height: 1.6; }

/* ─── Contato ─────────────────────────────────────────── */
.ib-contact-hero { display: grid; grid-template-columns: 1fr 1.1fr; gap: 0; }
.ib-contact-info { padding: 64px 56px 64px 0; display: flex; flex-direction: column; justify-content: center; }
.ib-contact-block { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 22px; }
.ib-contact-block svg { width: 26px; height: 26px; stroke: var(--teal-700); fill: none; stroke-width: 1.6; flex-shrink: 0; margin-top: 2px; }
.ib-contact-block__t { font-size: 11.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-900); margin-bottom: 3px; }
.ib-contact-block__d { font-size: 14px; color: var(--ink-700); line-height: 1.5; }
.ib-contact-form { display: grid; grid-template-columns: 1fr 1.4fr; gap: 40px; align-items: start; }

/* ─── FAQ / Legal (TOC layout) ────────────────────────── */
.ib-doc { display: grid; grid-template-columns: 240px 1fr; gap: 40px; align-items: start; }
.ib-doc__toc { position: sticky; top: 24px; list-style: none; padding: 0; margin: 0; }
.ib-doc__toc-h { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; color: var(--ink-500); margin-bottom: 12px; }
.ib-doc__toc a { display: block; padding: 8px 12px; border-radius: 4px; font-size: 13px; color: var(--ink-700); margin-bottom: 2px; }
.ib-doc__toc a:hover, .ib-doc__toc a.is-active { background: var(--cream-100); color: var(--teal-800); }
.ib-doc__article section { margin-bottom: 36px; scroll-margin-top: 24px; }
.ib-doc__article h2 { font-size: 26px; margin-bottom: 14px; }
.ib-doc__article p { font-size: 15px; color: var(--ink-700); line-height: 1.7; margin-bottom: 12px; }
.ib-doc__article ul { margin: 10px 0 14px 20px; color: var(--ink-700); font-size: 15px; line-height: 1.7; }
.ib-faq-group { margin-bottom: 32px; scroll-margin-top: 24px; }
.ib-faq-group__h { font-size: 24px; margin-bottom: 14px; }
.ib-doc-cta { background: var(--cream-100); border-radius: 8px; padding: 36px; text-align: center; margin-top: 24px; }
.ib-doc-cta__btns { display: flex; gap: 12px; justify-content: center; margin-top: 18px; flex-wrap: wrap; }

/* ─── Rastreio ────────────────────────────────────────── */
.ib-track-form { max-width: 560px; margin: 0 auto; }
.ib-track-sep { display: flex; align-items: center; gap: 14px; color: var(--ink-400); font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; margin: 16px 0; }
.ib-track-sep::before, .ib-track-sep::after { content: ''; flex: 1; height: 1px; background: var(--cream-300); }
.ib-timeline { display: flex; justify-content: space-between; position: relative; max-width: 820px; margin: 40px auto 0; }
.ib-timeline::before { content: ''; position: absolute; top: 16px; left: 8%; right: 8%; height: 2px; background: var(--cream-300); z-index: 0; }
.ib-timeline__step { display: flex; flex-direction: column; align-items: center; gap: 10px; position: relative; z-index: 1; flex: 1; }
.ib-timeline__dot { width: 34px; height: 34px; border-radius: 999px; background: var(--cream-300); color: var(--ink-500); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; border: 3px solid var(--cream-200); }
.ib-timeline__step.is-done .ib-timeline__dot { background: var(--teal-700); color: #fff; }
.ib-timeline__step.is-current .ib-timeline__dot { background: var(--terracotta); color: #fff; }
.ib-timeline__label { font-size: 11.5px; font-weight: 700; text-align: center; color: var(--ink-700); max-width: 90px; }

/* ─── 404 ─────────────────────────────────────────────── */
.ib-404 { text-align: center; padding: 40px 0; }
.ib-404__num { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 200px; line-height: 1; color: var(--teal-700); }
.ib-404__btns { display: flex; gap: 12px; justify-content: center; margin: 28px 0 0; flex-wrap: wrap; }
.ib-404__cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 18px; }
.ib-404__cat { position: relative; aspect-ratio: 3/2; border-radius: 6px; overflow: hidden; display: block; }
.ib-404__cat::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.5) 100%); z-index: 1; }
.ib-404__cat span { position: absolute; bottom: 12px; left: 0; right: 0; text-align: center; color: #fff; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; z-index: 2; }

/* ==========================================================================
   Mapeamento de elementos NATIVOS do WooCommerce para o visual do tema.
   (botões, formulário de variação, quantidade, calculadora de frete, etc.)
   ========================================================================== */
.ib .button, .ib button.button, .ib input.button,
.ib .checkout-button, .ib #place_order,
.ib .single_add_to_cart_button, .ib .wc-block-components-button {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 28px; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
  font-weight: 700; border-radius: 4px; transition: all .2s ease; line-height: 1;
  border: 1.5px solid var(--teal-700); background: var(--teal-700); color: #fff; cursor: pointer; width: auto;
}
.ib .button:hover, .ib .checkout-button:hover, .ib #place_order:hover, .ib .single_add_to_cart_button:hover {
  background: var(--teal-800); border-color: var(--teal-800); color: #fff;
}
.ib .checkout-button, .ib #place_order, .ib .single_add_to_cart_button { width: 100%; padding: 16px 32px; font-size: 13px; }
.ib .button.alt { background: var(--teal-700); }
/* botões "outline" do WC (ex.: aplicar cupom já estilizado pelo tema) */
.ib button[name="apply_coupon"], .ib button[name="update_cart"] { letter-spacing: 0.1em; }

/* Quantidade nativa do WooCommerce */
.ib .quantity { display: inline-flex; align-items: center; border: 1px solid var(--cream-400); border-radius: 4px; overflow: hidden; }
.ib .quantity input.qty { width: 56px; height: 46px; text-align: center; border: 0; padding: 0; border-radius: 0; -moz-appearance: textfield; background: #fff; }
.ib .quantity input.qty::-webkit-outer-spin-button, .ib .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Formulário de variações */
.ib .variations { width: 100%; border-collapse: collapse; margin-bottom: 14px; }
.ib .variations th { text-align: left; padding: 8px 12px 8px 0; vertical-align: middle; font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; color: var(--ink-900); }
.ib .variations td { padding: 8px 0; }
.ib .variations select { max-width: 320px; }
.ib .reset_variations { font-size: 12px; color: var(--teal-800); font-weight: 700; margin-left: 8px; }
.ib .woocommerce-variation-price { font-size: 22px; font-weight: 700; color: var(--ink-900); margin: 10px 0; font-family: var(--font-body); }
.ib .woocommerce-variation-availability { font-size: 13px; color: var(--ink-500); margin-bottom: 8px; }
.ib form.cart { margin: 18px 0; }
.ib form.cart:not(.variations_form) { display: flex; gap: 12px; align-items: stretch; flex-wrap: wrap; }
.ib form.variations_form .woocommerce-variation-add-to-cart { display: flex; gap: 12px; align-items: stretch; flex-wrap: wrap; margin-top: 12px; }
.ib form.cart .quantity { flex-shrink: 0; }
.ib form.cart .single_add_to_cart_button { flex: 1; min-width: 200px; }
.ib .stock.out-of-stock { color: var(--error); font-weight: 700; font-size: 14px; }
.ib .stock.in-stock { color: var(--success); font-size: 13px; }

/* Calculadora de frete */
.ib .shipping-calculator-form p { margin-bottom: 10px; }
.ib .shipping-calculator-button { color: var(--teal-800); font-weight: 700; font-size: 13px; text-decoration: underline; }
.ib .shipping-calculator-form .button { width: 100%; margin-top: 6px; }

/* Avaliações (reviews) */
.ib #reviews .woocommerce-Reviews-title { font-size: 26px; font-family: 'Cormorant Garamond', serif; color: var(--ink-900); margin-bottom: 18px; }
.ib #reviews .commentlist { list-style: none; padding: 0; margin: 0 0 28px; display: flex; flex-direction: column; gap: 14px; }
.ib #reviews .commentlist li { margin: 0; }
.ib #reviews .comment_container { display: flex; gap: 14px; background: #fff; border: 1px solid var(--cream-300); border-radius: 10px; padding: 18px 20px; }
.ib #reviews .comment_container img.avatar { width: 44px; height: 44px; border-radius: 999px; flex-shrink: 0; }
.ib #reviews .comment-text { flex: 1; min-width: 0; }
.ib #reviews .meta { font-size: 13px; color: var(--ink-500); margin-bottom: 6px; }
.ib #reviews .meta strong { color: var(--ink-900); font-size: 14px; }
.ib #reviews .description p { font-size: 14px; color: var(--ink-700); line-height: 1.6; margin: 0; }
.ib #reviews .star-rating { color: var(--terracotta); margin-bottom: 6px; }
.ib .woocommerce-noreviews { margin-bottom: 20px; }

/* Form de avaliação */
.ib #review_form_wrapper { background: var(--cream-100); border: 1px solid var(--cream-300); border-radius: 10px; padding: 26px 28px; }
.ib .comment-reply-title { font-size: 22px; font-family: 'Cormorant Garamond', serif; color: var(--ink-900); margin-bottom: 16px; display: block; }
.ib #review_form .comment-form-rating, .ib #review_form .comment-form-comment, .ib #review_form .comment-form-author, .ib #review_form .comment-form-email { margin-bottom: 16px; }
.ib #review_form label { display: block; font-size: 11.5px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700; color: var(--ink-900); margin-bottom: 8px; }
.ib #review_form textarea, .ib #review_form input[type="text"], .ib #review_form input[type="email"] { width: 100%; border: 1px solid var(--cream-400); border-radius: 6px; padding: 12px 14px; font-family: var(--font-body); font-size: 14px; color: var(--ink-900); background: #fff; outline: none; }
.ib #review_form textarea { min-height: 120px; resize: vertical; }
.ib #review_form textarea:focus, .ib #review_form input:focus { border-color: var(--teal-700); }
.ib #review_form .form-submit { margin-bottom: 0; }
.ib #review_form .submit, .ib #review_form input#submit { display: inline-flex; align-items: center; justify-content: center; padding: 13px 26px; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; border-radius: 4px; border: 1.5px solid transparent; background: var(--teal-700); color: #fff; cursor: pointer; transition: background .2s ease; }
.ib #review_form .submit:hover, .ib #review_form input#submit:hover { background: var(--teal-800); }

/* Seletor de estrelas interativo (p.stars) — o tema removeu o CSS geral do WC,
   então recriamos o widget de estrelas clicáveis a partir dos links .star-N. */
.ib p.stars { margin: 0; line-height: 1; }
.ib p.stars > span { display: inline-flex; gap: 3px; }
.ib p.stars a { position: relative; display: inline-block; width: 1.5em; height: 1.5em; text-indent: -9999px; overflow: hidden; font-size: 1em; }
.ib p.stars a::before { content: "\2605"; position: absolute; inset: 0; text-indent: 0; font-size: 1.5em; line-height: 1; color: var(--cream-400); transition: color .12s ease; }
/* estado selecionado (classe .active que o JS do WC aplica ao clicar) */
.ib p.stars a.active::before, .ib p.stars a.active ~ a.active::before { color: var(--terracotta); }
/* hover: acende da 1ª estrela até a que está sob o cursor */
.ib p.stars:hover a::before { color: var(--terracotta); }
.ib p.stars a:hover ~ a::before { color: var(--cream-400); }

/* Mensagens / formulários nativos do account/checkout */
.ib .woocommerce form .form-row { margin-bottom: 16px; }
.ib .required { color: var(--terracotta); }
.ib .select2-container--default .select2-selection--single { border: 1px solid var(--cream-400); border-radius: 4px; height: 48px; }
.ib .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 46px; padding-left: 14px; }
.ib .select2-container--default .select2-selection--single .select2-selection__arrow { height: 46px; }

/* Wrappers utilitários referenciados nos templates */
.ib-widget { margin-bottom: 16px; }
.ib-main { display: block; }
.ib-shop { display: block; }
.ib-product__buy { margin: 18px 0; }
.ib-qty-wrap { display: inline-flex; }

/* ─── Utilities ───────────────────────────────────────── */
.ib-text-center { text-align: center; }
.ib-mt-0 { margin-top: 0; }
.ib-muted { color: var(--ink-500); }
.ib-eyebrow { font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-500); font-weight: 600; }

/* ==========================================================================
   Responsivo
   ========================================================================== */
@media (max-width: 1100px) {
  .ib-cats { grid-template-columns: repeat(4, 1fr); }
  .ib-pgrid { grid-template-columns: repeat(3, 1fr); }
  .ib-pgrid--5, .ib-pgrid--4, .ib-pgrid--3 { grid-template-columns: repeat(3, 1fr); }
  .ib-insta-grid { grid-template-columns: repeat(3, 1fr); }
  .ib-hero { grid-template-columns: 1fr; }
  .ib-hero__img { min-height: 360px; }
  .ib-hero__copy { padding: 56px 32px; max-width: none; }
  .ib-hero__h { font-size: 44px; }
  .ib-edit { grid-template-columns: 1fr; }
  .ib-benefits__grid { grid-template-columns: repeat(2, 1fr); }
  .ib-benefit { border-right: 0; border-bottom: 1px solid var(--cream-300); }
  .ib-foot-strip__grid { grid-template-columns: repeat(2, 1fr); }
  .ib-foot-strip__item { border-right: 0; border-bottom: 1px solid var(--cream-300); }
  .ib-footer__grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .ib-nav__list { gap: 16px; overflow-x: auto; padding: 0 12px; justify-content: flex-start; }
  .ib-filterbar__item { flex: 1 1 50%; border-right: 0; border-bottom: 1px solid var(--cream-300); justify-content: space-between; }
  .ib-filterbar__sort { margin-left: 0; }
  .ib-section { padding: 48px 0; }
  .ib-wrap { padding: 0 20px; }
  .ib-header { padding: 18px 20px 10px; }
  .ib-product { grid-template-columns: 90px 1fr; }
  .ib-product__info { grid-column: 1 / -1; }
  .ib-checkout { grid-template-columns: 1fr; }
  .ib-contact-form { grid-template-columns: 1fr; }
  .ib-contact-hero { grid-template-columns: 1fr; }
  .ib-contact-info { padding: 48px 0; }
  .ib-quotes { grid-template-columns: 1fr; }
  .ib-trust { grid-template-columns: 1fr; }
}
@media (max-width: 880px) {
  .ib-doc { grid-template-columns: 1fr; }
  .ib-doc__toc { position: static; display: flex; flex-wrap: wrap; gap: 6px; }
  .ib-account { grid-template-columns: 1fr; }
  .ib-auth, .ib-register { grid-template-columns: 1fr; }
  .ib-auth__col + .ib-auth__col { border-left: 0; border-top: 1px solid var(--cream-300); }
  .ib-register__media { display: none; }
  .ib-specs { grid-template-columns: 1fr; }
  .ib .woocommerce-Addresses.col2-set .col-1, .ib .woocommerce-Addresses.col2-set .col-2 { flex: 1 1 100%; }
}
@media (max-width: 760px) {
  /* mostra hamburguer e esconde a nav inline */
  .ib-burger { display: block; }
  .ib-nav { display: none; border-top: 1px solid var(--cream-300); }
  .ib-nav.is-open { display: block; }
  .ib-nav__list { flex-direction: column; align-items: stretch; gap: 0; overflow: visible; padding: 0; }
  .ib-nav__list li { border-bottom: 1px solid var(--cream-300); }
  .ib-nav__list a { padding: 13px 4px; justify-content: space-between; }
  .ib-nav__list .sub-menu { position: static; transform: none; opacity: 1; visibility: visible; box-shadow: none; border: 0; border-radius: 0; padding: 0 0 8px 16px; display: none; }
  .ib-nav__list li.is-open > .sub-menu { display: block; }
  .ib-cart-head { display: none; }
  .ib-cart-row { grid-template-columns: 1fr auto; gap: 8px 12px; }
  .ib-cart-grid { grid-template-columns: 1fr; }
  /* Seções editoriais e hero empilham (texto sobre imagem). */
  .ib-hero { grid-template-columns: 1fr; }
  .ib-edit { grid-template-columns: 1fr; }
  .ib-edit__card--media { min-height: 320px; }
  .ib-edit__media-split, .ib-edit__media-split > div { min-height: 200px; }
  .ib-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .ib-foot-strip__grid { grid-template-columns: repeat(2, 1fr); gap: 8px 20px; }
}
@media (max-width: 640px) {
  .ib-header__row { grid-template-columns: auto 1fr auto; }
  .ib-iconbtn span { display: none; }
  .ib-logo__word { font-size: 32px; }
  .ib-cats { grid-template-columns: repeat(2, 1fr); padding: 0 20px; }
  .ib-pgrid, .ib-pgrid--5, .ib-pgrid--4, .ib-pgrid--3 { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .ib-hero__h { font-size: 36px; }
  .ib-section__h { font-size: 30px; }
  .ib-footer__grid { grid-template-columns: 1fr; }
  .ib-edit__card { padding: 44px 24px; }
  .ib-edit__h { font-size: 28px; }
  .ib-product { grid-template-columns: 1fr; }
  .ib-product__thumbs { flex-direction: row; }
  .ib-fieldgrid, .ib-fieldgrid--3 { grid-template-columns: 1fr; }
  .ib-auth__col { padding: 32px 24px; }
  .ib-timeline { flex-wrap: wrap; gap: 18px; }
  .ib-timeline::before { display: none; }
  .ib-timeline__step { flex: 0 0 40%; }
  .ib-404__num { font-size: 120px; }
  .ib-404__cats { grid-template-columns: repeat(2, 1fr); }
  .ib-auth__col + .ib-auth__col { border-top: 1px solid var(--cream-300); }
  /* Grids utilitários e seções multi-coluna empilham no celular. */
  .ib-grid--2, .ib-grid--3, .ib-grid--4 { grid-template-columns: 1fr; }
  .ib-benefits__grid { grid-template-columns: 1fr; }
  .ib-benefit { padding: 12px 6px; }
  .ib-foot-strip__grid { grid-template-columns: 1fr; gap: 18px; }
  .ib-insta-grid { grid-template-columns: repeat(3, 1fr); }
}
