/* Produtos do Ceará – tema moderno (CE: verde/amarelo/branco)
   Mantém Bootstrap 5 como base e sobrescreve tokens/estilos. */

:root {
  /* Brand (CE) */
  --pc-green: #11823b; /* verde vivo, acessível */
  --pc-green-2: #0a6b30;
  --pc-yellow: #f2c200; /* amarelo quente (usar como acento) */
  --pc-white: #ffffff;

  /* Neutros */
  --pc-ink: #0b1220;
  --pc-muted: #556070;
  --pc-border: rgba(11, 18, 32, 0.10);

  /* Layout */
  --pc-radius: 1rem;
  --pc-radius-sm: .75rem;
  --pc-shadow: 0 14px 40px rgba(11, 18, 32, 0.12);
  --pc-shadow-sm: 0 10px 24px rgba(11, 18, 32, 0.10);
  --pc-ring: 0 0 0 .25rem rgba(17, 130, 59, 0.18);

  /* Bootstrap tokens (5.3+) */
  --bs-primary: var(--pc-green);
  --bs-primary-rgb: 17, 130, 59;
  --bs-success: var(--pc-green);
  --bs-success-rgb: 17, 130, 59;
  --bs-warning: var(--pc-yellow);
  --bs-warning-rgb: 242, 194, 0;
  --bs-body-color: var(--pc-ink);
  --bs-secondary-color: var(--pc-muted);
  --bs-border-color: var(--pc-border);
  --bs-link-color: var(--pc-green);
  --bs-link-hover-color: var(--pc-green-2);
  --bs-border-radius: var(--pc-radius-sm);
  --bs-border-radius-lg: var(--pc-radius);
  --bs-focus-ring-color: rgba(17, 130, 59, 0.25);
  --bs-body-font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
}

/* Fundo com personalidade (leve, sem poluir) */
body {
  background:
    radial-gradient(1100px 520px at 10% -10%, rgba(242, 194, 0, 0.22), transparent 55%),
    radial-gradient(900px 480px at 95% 0%, rgba(17, 130, 59, 0.20), transparent 55%),
    linear-gradient(180deg, #f7f9fb 0%, #f3f6f8 40%, #f7f9fb 100%);
}

/* Tipografia/hierarquia */
h1, h2, h3, .navbar-brand {
  letter-spacing: -0.01em;
}

/* Navbar premium */
.pc-navbar {
  background: linear-gradient(90deg, var(--pc-green) 0%, #0f8b3d 45%, rgba(17, 130, 59, 0.92) 100%);
  border-bottom: 1px solid rgba(255,255,255,0.14);
}
.pc-navbar .navbar-brand {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
}
.pc-brand-mark {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.55), transparent 55%),
    linear-gradient(135deg, var(--pc-yellow), rgba(255,255,255,0.15)),
    linear-gradient(135deg, var(--pc-green), var(--pc-green-2));
  box-shadow: 0 10px 24px rgba(0,0,0,0.18);
}
.pc-navbar .nav-link,
.pc-navbar .navbar-brand,
.pc-navbar .navbar-toggler {
  color: rgba(255,255,255,0.96) !important;
}
.pc-navbar .nav-link {
  opacity: 0.92;
}
.pc-navbar .nav-link:hover,
.pc-navbar .nav-link:focus {
  opacity: 1;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 6px;
}

/* Contêiner principal com respiro */
.pc-main {
  padding-top: 1.25rem;
  padding-bottom: 2.25rem;
}

/* Cards e superfícies */
.card {
  border: 1px solid var(--pc-border);
  border-radius: var(--pc-radius);
  box-shadow: var(--pc-shadow-sm);
}
.card.shadow-sm {
  box-shadow: var(--pc-shadow-sm) !important;
}
.card .card-body {
  padding: 1.15rem;
}

/* Botões com “punch” */
.btn {
  border-radius: .85rem;
}
.btn-success, .btn-primary {
  box-shadow: 0 10px 22px rgba(17, 130, 59, 0.18);
}
.btn-success:hover, .btn-primary:hover {
  transform: translateY(-1px);
}
.btn-success:active, .btn-primary:active {
  transform: translateY(0);
}
.btn-outline-success {
  border-color: rgba(17, 130, 59, 0.45);
}

/* Inputs */
.form-control, .form-select {
  border-radius: .85rem;
  border-color: rgba(11, 18, 32, 0.14);
}
.form-control:focus, .form-select:focus {
  border-color: rgba(17, 130, 59, 0.55);
  box-shadow: var(--pc-ring);
}

/* Tabelas mais modernas */
.table {
  --bs-table-striped-bg: rgba(17, 130, 59, 0.05);
}
.table thead th {
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(11, 18, 32, 0.65);
}

/* Lista de produtos (cards) */
.pc-card-img {
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: #f6f7f9;
}
.pc-product-card {
  position: relative;
  overflow: hidden;
  border-radius: calc(var(--pc-radius) + .25rem);
  border: 1px solid rgba(255,255,255,0.55);
  background:
    radial-gradient(780px 320px at 12% 6%, rgba(242, 194, 0, 0.22), transparent 60%),
    radial-gradient(680px 300px at 95% 0%, rgba(17, 130, 59, 0.14), transparent 62%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.56));
}
.pc-product-card::after {
  content: "";
  position: absolute;
  inset: -140px -180px auto auto;
  width: 360px;
  height: 360px;
  background: radial-gradient(circle at 30% 30%, rgba(242,194,0,0.45), rgba(242,194,0,0) 65%);
  transform: rotate(10deg);
  pointer-events: none;
}
.pc-product-card .card-body {
  position: relative; /* acima do ::after */
}
.pc-product-card__media {
  position: relative;
  padding: .85rem .85rem 0;
}
.pc-product-card__img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: #f6f7f9;
  border-radius: calc(var(--pc-radius) - .05rem);
  border: 1px solid rgba(11,18,32,0.10);
  box-shadow: 0 14px 36px rgba(11, 18, 32, 0.16);
}
.pc-product-card__img--placeholder {
  background:
    radial-gradient(520px 220px at 10% 0%, rgba(242, 194, 0, 0.20), transparent 55%),
    radial-gradient(520px 240px at 95% 0%, rgba(17, 130, 59, 0.14), transparent 60%),
    #f6f7f9;
}
.pc-product-card__kicker {
  max-width: 70%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pc-product-card__price-pill {
  font-weight: 750;
  font-variant-numeric: tabular-nums;
  padding: .35rem .6rem;
  border-radius: 999px;
  background: rgba(17, 130, 59, 0.10);
  border: 1px solid rgba(17, 130, 59, 0.18);
  color: rgba(11,18,32,0.88);
}
.pc-product-card__title {
  color: var(--pc-ink);
  font-weight: 700;
  text-decoration: none;
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.pc-product-card__title:hover,
.pc-product-card__title:focus {
  color: var(--pc-green-2);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}
.pc-product-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .25rem .45rem;
}
.pc-product-card__sep {
  opacity: .7;
}
.pc-card-hover {
  transition: transform 140ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.pc-card-hover:hover {
  transform: translateY(-3px);
  box-shadow: var(--pc-shadow);
  border-color: rgba(17, 130, 59, 0.20);
}
.pc-price {
  font-variant-numeric: tabular-nums;
}

/* Produto */
.pc-product-main-img {
  aspect-ratio: 1 / 1;
  object-fit: contain;
  background: #ffffff;
}
.pc-thumb-btn {
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  border-radius: .75rem;
  padding: .25rem;
  width: 64px;
  height: 64px;
}
.pc-thumb-btn.active,
.pc-thumb-btn:focus {
  border-color: rgba(17, 130, 59, 0.75);
  box-shadow: var(--pc-ring);
}
.pc-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: .55rem;
  background: #f6f7f9;
}
.pc-sticky-buy {
  position: sticky;
  top: 1rem;
}

/* “Hero” (home) */
.pc-hero {
  position: relative;
  overflow: hidden;
  border-radius: calc(var(--pc-radius) + .25rem);
  border: 1px solid rgba(255,255,255,0.55);
  background:
    radial-gradient(900px 360px at 15% 10%, rgba(242, 194, 0, 0.30), transparent 60%),
    radial-gradient(700px 320px at 85% 0%, rgba(255,255,255,0.28), transparent 55%),
    linear-gradient(135deg, rgba(17, 130, 59, 0.16), rgba(17, 130, 59, 0.06));
  box-shadow: var(--pc-shadow);
}
.card.pc-hero,
.card.pc-hero.shadow-sm {
  /* Garante o “peso” do hero mesmo com .shadow-sm do Bootstrap */
  box-shadow: var(--pc-shadow) !important;
}
.pc-hero::after {
  content: "";
  position: absolute;
  inset: -120px -180px auto auto;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle at 30% 30%, rgba(242,194,0,0.55), rgba(242,194,0,0) 65%);
  filter: blur(0.2px);
  transform: rotate(12deg);
  pointer-events: none;
}
.pc-hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem .65rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.68);
  border: 1px solid rgba(11,18,32,0.08);
  font-size: .85rem;
  color: rgba(11,18,32,0.72);
}
.pc-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--pc-green);
  box-shadow: 0 0 0 .25rem rgba(242,194,0,0.22);
}

/* Home: faixa de categorias (cards pequenos) */
.pc-categorias-strip {
  display: flex;
  gap: .6rem;
  overflow-x: auto;
  padding: .25rem .1rem;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
}
.pc-categorias-strip::-webkit-scrollbar {
  height: 10px;
}
.pc-categorias-strip::-webkit-scrollbar-thumb {
  background: rgba(11, 18, 32, 0.12);
  border-radius: 999px;
}
.pc-categoria-card {
  flex: 0 0 auto;
  scroll-snap-align: start;
  border: 1px solid rgba(11, 18, 32, 0.12);
  background: rgba(255,255,255,0.72);
  backdrop-filter: blur(10px);
  border-radius: 999px;
  padding: .45rem .8rem;
  font-weight: 650;
  font-size: .9rem;
  color: rgba(11, 18, 32, 0.86);
  box-shadow: 0 10px 22px rgba(11, 18, 32, 0.08);
  transition: transform 140ms ease, border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
}
.pc-categoria-card:hover,
.pc-categoria-card:focus {
  transform: translateY(-1px);
  border-color: rgba(17, 130, 59, 0.25);
  box-shadow: 0 14px 34px rgba(11, 18, 32, 0.12);
}
.pc-categoria-card.is-active {
  border-color: rgba(17, 130, 59, 0.35);
  background: rgba(17, 130, 59, 0.10);
  box-shadow: 0 14px 34px rgba(17, 130, 59, 0.14);
}
.pc-categoria-card:focus {
  outline: none;
  box-shadow: var(--pc-ring);
}

/* CTA card (home) – “mini hero” */
.pc-cta-card {
  position: relative;
  overflow: hidden;
  border-radius: calc(var(--pc-radius) + .15rem);
  border: 1px solid rgba(255,255,255,0.55);
  background:
    radial-gradient(520px 260px at 15% 20%, rgba(242, 194, 0, 0.24), transparent 60%),
    radial-gradient(520px 260px at 95% 0%, rgba(17, 130, 59, 0.18), transparent 60%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.52));
  box-shadow: var(--pc-shadow-sm);
}
.pc-cta-card::after {
  content: "";
  position: absolute;
  inset: auto -120px -160px auto;
  width: 360px;
  height: 360px;
  background: radial-gradient(circle at 30% 30%, rgba(17,130,59,0.18), rgba(17,130,59,0) 60%);
  transform: rotate(-10deg);
  pointer-events: none;
}

/* Indicador de carregamento (HTMX) */
.pc-top-progress {
  position: fixed;
  z-index: 1056; /* acima do navbar */
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--pc-yellow), #ffe27a, var(--pc-yellow));
  box-shadow: 0 10px 28px rgba(242, 194, 0, 0.25);
  opacity: 0;
  transition: width 220ms ease, opacity 180ms ease;
}
.pc-top-progress.is-active {
  opacity: 1;
}

/* Footer */
.pc-footer {
  border-top: 1px solid rgba(11,18,32,0.08);
  background: rgba(255,255,255,0.72);
  backdrop-filter: blur(10px);
}
.pc-footer a {
  text-decoration: none;
}
.pc-footer a:hover {
  text-decoration: underline;
  text-underline-offset: 4px;
}

/* Acessibilidade: reduzir animações */
@media (prefers-reduced-motion: reduce) {
  .pc-card-hover,
  .btn-success,
  .btn-primary,
  .pc-top-progress {
    transition: none !important;
  }
  .btn-success:hover,
  .btn-primary:hover {
    transform: none !important;
  }
}
