/*
Theme Name: Catálogo WhatsApp Custom
Theme URI: https://openai.local/
Author: OpenAI
Description: Tema customizado de catálogo com carrinho e checkout próprio via WhatsApp, sem WooCommerce.
Version: 1.0.0
Text Domain: cwtheme
*/

:root {
  --cw-primary: #ec0070;
  --cw-primary-dark: #c4005d;
  --cw-accent: #78c94b;
  --cw-bg: #f3f3f3;
  --cw-card: #ffffff;
  --cw-text: #263238;
  --cw-muted: #6b7280;
  --cw-border: #dadada;
  --cw-radius: 24px;
  --cw-shadow: 0 10px 30px rgba(0,0,0,.08);
}
* { box-sizing: border-box; }
html, body { margin:0; padding:0; }
body {
  font-family: Arial, Helvetica, sans-serif;
  color: var(--cw-text);
  background: var(--cw-bg);
}
a { color: inherit; text-decoration:none; }
img { max-width:100%; height:auto; display:block; }
.container { width:min(1180px, calc(100% - 28px)); margin:0 auto; }
.site-header {
  position: sticky; top:0; z-index:100;
  background: var(--cw-primary);
  padding: 12px 0;
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
.site-header__inner { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.menu-btn, .cart-btn {
  width:48px; height:48px; border:none; border-radius:14px; background:rgba(255,255,255,.12); color:#fff; font-size:22px; cursor:pointer;
}
.logo-wrap { background:#fff; border-radius:999px; padding:8px 20px; min-width:120px; text-align:center; box-shadow: var(--cw-shadow); }
.logo-wrap img { max-height:52px; margin:0 auto; }
.logo-text { color:#244c55; font-weight:700; }
.cart-indicator { position:relative; display:inline-flex; }
.cart-count {
  position:absolute; top:-6px; right:-6px; width:22px; height:22px; border-radius:50%; background:#ff7a00; color:#fff; font-size:12px; font-weight:700; display:flex; align-items:center; justify-content:center;
}
.search-box { margin:18px 0; }
.search-box input {
  width:100%; border:2px solid var(--cw-border); border-radius:999px; padding:16px 18px; font-size:18px; background:#fff;
}
.hero {
  background: linear-gradient(135deg,#ffe9f3,#fff7f9);
  border-radius:32px; overflow:hidden; box-shadow: var(--cw-shadow); min-height:220px; display:grid; grid-template-columns:1.1fr .9fr; align-items:center;
}
.hero__content { padding:28px; }
.hero__title { font-size:42px; line-height:1.05; margin:0 0 10px; color:var(--cw-primary); }
.hero__text { color:var(--cw-muted); font-size:18px; margin-bottom:18px; }
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px; border:none; border-radius:999px; padding:14px 22px; font-size:17px; font-weight:700; cursor:pointer;
}
.btn-primary { background:var(--cw-primary); color:#fff; }
.btn-outline { background:#fff; color:var(--cw-primary); border:2px solid #f5bfd7; }
.btn-green { background:var(--cw-accent); color:#fff; }
.section-title { font-size:32px; margin:28px 0 16px; }
.cards-grid {
  display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:18px;
}
.product-card {
  background:var(--cw-card); border-radius:26px; overflow:hidden; box-shadow:var(--cw-shadow); border:1px solid #ececec;
}
.product-card__img { aspect-ratio:1/1; background:#fff; display:flex; align-items:center; justify-content:center; }
.product-card__body { padding:14px; }
.product-card__title { font-size:20px; margin:0 0 8px; min-height:48px; }
.price-row { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.old-price { color:#9ca3af; text-decoration:line-through; font-size:15px; }
.current-price { color:var(--cw-primary); font-weight:700; font-size:24px; }
.product-card__actions { display:flex; gap:10px; flex-wrap:wrap; }
.badge-note { font-size:14px; color:var(--cw-muted); margin-top:10px; }
.single-wrap { display:grid; grid-template-columns:1fr 1fr; gap:32px; margin:24px 0; }
.gallery-main { background:#fff; border-radius:30px; overflow:hidden; box-shadow:var(--cw-shadow); }
.gallery-main img { width:100%; aspect-ratio:1/1; object-fit:cover; }
.thumb-row { display:flex; gap:12px; overflow:auto; padding:14px 2px 4px; }
.thumb-row button { border:2px solid transparent; background:#fff; border-radius:18px; padding:0; overflow:hidden; width:88px; min-width:88px; box-shadow:var(--cw-shadow); cursor:pointer; }
.thumb-row button.active { border-color:var(--cw-primary); }
.thumb-row img { width:88px; height:88px; object-fit:cover; }
.single-summary { background:#fff; border-radius:30px; padding:24px; box-shadow:var(--cw-shadow); }
.single-title { font-size:40px; margin:0 0 8px; }
.qty-box { display:flex; align-items:center; gap:10px; margin:20px 0; }
.qty-control { display:inline-flex; align-items:center; overflow:hidden; border:2px solid var(--cw-border); border-radius:18px; }
.qty-control button, .qty-control input { width:48px; height:48px; border:none; background:#fff; text-align:center; font-size:22px; }
.qty-control input { width:64px; font-size:20px; }
.cart-page, .checkout-page { display:grid; grid-template-columns:1.2fr .8fr; gap:28px; margin:28px 0 48px; }
.panel { background:#fff; border-radius:30px; box-shadow:var(--cw-shadow); padding:24px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:16px; }
.form-group.full { grid-column:1/-1; }
.form-group label { display:block; font-size:14px; color:#555; margin:0 0 8px; font-weight:700; text-transform:uppercase; }
.form-control, .form-select, textarea.form-control {
  width:100%; border:2px solid #d7d7d7; border-radius:999px; padding:16px 18px; font-size:18px; background:#fafafa;
}
textarea.form-control { min-height:110px; border-radius:28px; }
.inline-3 { display:grid; grid-template-columns:1.3fr 1fr 1.25fr; gap:16px; }
.payment-options { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:18px; }
.payment-option { border:2px solid #d9d9d9; border-radius:22px; padding:16px; font-weight:700; cursor:pointer; background:#fff; text-align:center; }
.payment-option.active { border-color:var(--cw-primary); color:var(--cw-primary); box-shadow:0 8px 20px rgba(236,0,112,.14); }
.notice-minimum { background:#fff8df; border-radius:18px; padding:14px 16px; color:#7a6322; font-weight:700; margin-bottom:16px; }
.summary-list { display:flex; flex-direction:column; gap:14px; }
.summary-item { display:flex; align-items:center; justify-content:space-between; gap:14px; border-bottom:1px dashed #ddd; padding-bottom:10px; }
.total-row { display:flex; justify-content:space-between; align-items:center; font-size:30px; font-weight:800; color:var(--cw-primary); margin-top:18px; }
.floating-wa {
  position:fixed; right:18px; bottom:18px; width:68px; height:68px; border-radius:50%; background:var(--cw-accent); color:#fff; display:flex; align-items:center; justify-content:center; font-size:32px; box-shadow:var(--cw-shadow); z-index:90;
}
.empty-state { text-align:center; color:var(--cw-muted); padding:40px 16px; }
.cw-hidden { display:none !important; }
.checkout-success { background:#ecfff1; color:#23633a; border-radius:24px; padding:16px; margin-bottom:16px; }
.site-footer { padding:40px 0 80px; color:#777; font-size:14px; }
.mobile-nav {
  position:fixed; inset:0 auto 0 0; width:min(320px, 84vw); background:#fff; transform:translateX(-100%); transition:.25s; z-index:120; box-shadow:var(--cw-shadow); padding:24px;
}
.mobile-nav.is-open { transform:none; }
.overlay { position:fixed; inset:0; background:rgba(0,0,0,.35); z-index:110; opacity:0; pointer-events:none; transition:.25s; }
.overlay.is-open { opacity:1; pointer-events:auto; }
@media (max-width: 900px){
  .hero { grid-template-columns:1fr; }
  .cards-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .single-wrap, .cart-page, .checkout-page { grid-template-columns:1fr; }
}
@media (max-width: 640px){
  .container { width:min(100% - 18px, 100%); }
  .hero__title { font-size:34px; }
  .section-title { font-size:26px; }
  .single-title { font-size:32px; }
  .product-card__title { font-size:17px; min-height:40px; }
  .cards-grid { grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
  .form-grid, .inline-3, .payment-options { grid-template-columns:1fr; }
  .panel { border-radius:22px; padding:18px; }
  .logo-wrap { min-width:100px; padding:8px 16px; }
}
