/*
Theme Name: Pawfield
Theme URI: https://pawfield.example.com
Author: Pawfield Studio
Description: A warm, natural, premium WooCommerce theme for pet supplies. Earth tones, editorial serif headlines, generous whitespace.
Version: 1.0.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: pawfield
Tags: e-commerce, woocommerce
WC requires at least: 7.0
*/

/* ---------- Tokens ---------- */
:root {
  --cream: #F7F2E9;
  --cream-2: #EFE7D8;
  --green: #2E4636;
  --green-deep: #21362A;
  --terracotta: #C4683F;
  --terracotta-dark: #A9522D;
  --tan: #D9C7A7;
  --ink: #22291F;
  --muted: #6E7268;
  --white: #FFFFFF;
  --radius: 18px;
  --radius-sm: 10px;
  --shadow: 0 10px 30px rgba(34, 41, 31, .08);
  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Nunito Sans", -apple-system, Helvetica, Arial, sans-serif;
}

/* ---------- Reset / base ---------- */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--green); text-decoration: none; transition: color .2s; }
a:hover { color: var(--terracotta); }
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--green-deep);
  line-height: 1.15;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(2.4rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); }
h3 { font-size: 1.35rem; }
.pf-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* ---------- Buttons ---------- */
.pf-btn, .woocommerce a.button, .woocommerce button.button,
.woocommerce input.button, .woocommerce #respond input#submit,
.woocommerce button.button.alt, .woocommerce a.button.alt,
.wc-block-components-button {
  display: inline-block;
  background: var(--green);
  color: var(--cream) !important;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .03em;
  padding: 14px 30px;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  transition: background .2s, transform .15s;
  text-align: center;
}
.pf-btn:hover, .woocommerce a.button:hover, .woocommerce button.button:hover,
.woocommerce button.button.alt:hover, .woocommerce a.button.alt:hover {
  background: var(--terracotta);
  transform: translateY(-1px);
}
.pf-btn--ghost {
  background: transparent;
  color: var(--green) !important;
  box-shadow: inset 0 0 0 2px var(--green);
}
.pf-btn--ghost:hover { background: var(--green); color: var(--cream) !important; }
.pf-btn--terra { background: var(--terracotta); }
.pf-btn--terra:hover { background: var(--terracotta-dark); }

/* ---------- Announcement bar ---------- */
.pf-announce {
  background: var(--green-deep);
  color: var(--cream);
  text-align: center;
  font-size: .85rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 9px 16px;
}

/* ---------- Header ---------- */
.pf-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(247, 242, 233, .92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--cream-2);
}
.pf-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px 24px;
  max-width: 1200px;
  margin: 0 auto;
}
.pf-logo {
  font-family: var(--font-display);
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--green-deep);
  letter-spacing: -.02em;
}
.pf-logo span { color: var(--terracotta); }
.pf-nav ul { display: flex; gap: 28px; list-style: none; }
.pf-nav a {
  font-weight: 700;
  font-size: .95rem;
  color: var(--ink);
  letter-spacing: .02em;
}
.pf-nav a:hover { color: var(--terracotta); }
.pf-header__cart {
  position: relative;
  font-weight: 700;
  font-size: .95rem;
  color: var(--green-deep);
}
.pf-cart-count {
  display: inline-block;
  min-width: 22px;
  height: 22px;
  line-height: 22px;
  text-align: center;
  background: var(--terracotta);
  color: #fff;
  border-radius: 999px;
  font-size: .75rem;
  margin-left: 6px;
}

/* ---------- Hero ---------- */
.pf-hero { background: var(--cream); overflow: hidden; }
.pf-hero__grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 48px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 72px 24px 88px;
}
.pf-eyebrow {
  display: inline-block;
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--terracotta);
  margin-bottom: 18px;
}
.pf-hero p.pf-lead {
  font-size: 1.15rem;
  color: var(--muted);
  margin: 22px 0 34px;
  max-width: 480px;
}
.pf-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.pf-hero__img {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  aspect-ratio: 4 / 4.4;
}
.pf-hero__img img { width: 100%; height: 100%; object-fit: cover; }
.pf-hero__badges {
  display: flex;
  gap: 28px;
  margin-top: 40px;
  flex-wrap: wrap;
}
.pf-hero__badges li {
  list-style: none;
  font-size: .9rem;
  font-weight: 700;
  color: var(--green);
}
.pf-hero__badges li::before { content: "✦ "; color: var(--terracotta); }

/* ---------- Section scaffolding ---------- */
.pf-section { padding: 84px 0; }
.pf-section--cream2 { background: var(--cream-2); }
.pf-section--green { background: var(--green-deep); }
.pf-section__head { text-align: center; max-width: 640px; margin: 0 auto 52px; }
.pf-section__head p { color: var(--muted); margin-top: 14px; }

/* ---------- Category cards ---------- */
.pf-cats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
.pf-cat-card {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 3 / 3.6;
  box-shadow: var(--shadow);
}
.pf-cat-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.pf-cat-card:hover img { transform: scale(1.05); }
.pf-cat-card__label {
  position: absolute;
  left: 14px; right: 14px; bottom: 14px;
  background: rgba(247, 242, 233, .94);
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  font-weight: 800;
  color: var(--green-deep);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.pf-cat-card__label span { color: var(--terracotta); }

/* ---------- Values strip ---------- */
.pf-values {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.pf-value {
  background: var(--white);
  border-radius: var(--radius);
  padding: 36px 30px;
  box-shadow: var(--shadow);
}
.pf-value__icon { font-size: 1.9rem; margin-bottom: 14px; }
.pf-value h3 { margin-bottom: 10px; }
.pf-value p { color: var(--muted); font-size: .98rem; }

/* ---------- Story split ---------- */
.pf-story {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.pf-story__img {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  aspect-ratio: 4 / 4.2;
}
.pf-story__img img { width: 100%; height: 100%; object-fit: cover; }
.pf-story p { color: var(--muted); margin: 18px 0 26px; }

/* ---------- Testimonials ---------- */
.pf-section--green h2, .pf-section--green .pf-eyebrow { color: var(--cream); }
.pf-quotes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}
.pf-quote {
  background: rgba(247, 242, 233, .07);
  border: 1px solid rgba(247, 242, 233, .16);
  border-radius: var(--radius);
  padding: 32px 28px;
  color: var(--cream);
}
.pf-quote p { font-family: var(--font-display); font-size: 1.08rem; line-height: 1.5; }
.pf-quote footer { margin-top: 18px; font-size: .88rem; opacity: .75; }
.pf-stars { color: var(--tan); letter-spacing: .15em; margin-bottom: 14px; }

/* ---------- Newsletter ---------- */
.pf-news {
  background: var(--terracotta);
  border-radius: var(--radius);
  padding: 56px 48px;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 36px;
  align-items: center;
  color: var(--cream);
}
.pf-news h2 { color: var(--cream); }
.pf-news p { opacity: .9; margin-top: 10px; }
.pf-news form { display: flex; gap: 10px; }
.pf-news input[type="email"] {
  flex: 1;
  border: none;
  border-radius: 999px;
  padding: 14px 22px;
  font-size: 1rem;
  font-family: var(--font-body);
}
.pf-news .pf-btn { background: var(--green-deep); }

/* ---------- Footer ---------- */
.pf-footer {
  background: var(--green-deep);
  color: var(--cream);
  padding: 64px 0 36px;
  margin-top: 84px;
}
.pf-footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 36px;
  margin-bottom: 44px;
}
.pf-footer .pf-logo { color: var(--cream); }
.pf-footer h4 {
  color: var(--tan);
  font-family: var(--font-body);
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: 16px;
}
.pf-footer ul { list-style: none; }
.pf-footer li { margin-bottom: 10px; }
.pf-footer a { color: var(--cream); opacity: .85; }
.pf-footer a:hover { opacity: 1; color: var(--tan); }
.pf-footer__bottom {
  border-top: 1px solid rgba(247, 242, 233, .15);
  padding-top: 26px;
  font-size: .85rem;
  opacity: .65;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}

/* ---------- WooCommerce: catalog ---------- */
.woocommerce .pf-shop-wrap { max-width: 1200px; margin: 0 auto; padding: 56px 24px; }
.woocommerce ul.products li.product {
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform .25s ease, box-shadow .25s ease;
  text-align: left;
  padding-bottom: 20px;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 44px rgba(34, 41, 31, .14);
}
.woocommerce ul.products li.product a img {
  aspect-ratio: 1 / 1;
  object-fit: cover;
  margin-bottom: 0;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-display);
  font-size: 1.12rem;
  color: var(--green-deep);
  padding: 16px 20px 4px;
}
.woocommerce ul.products li.product .price {
  color: var(--terracotta);
  font-weight: 800;
  font-size: 1rem;
  padding: 0 20px;
}
.woocommerce ul.products li.product .button {
  margin: 14px 20px 0;
  padding: 11px 22px;
  font-size: .85rem;
}
.woocommerce span.onsale {
  background: var(--terracotta);
  border-radius: 999px;
  padding: 6px 14px;
  line-height: 1.6;
  font-weight: 800;
  min-height: 0;
  min-width: 0;
}
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering { margin-bottom: 28px; color: var(--muted); }
.woocommerce .woocommerce-ordering select {
  border: 1px solid var(--cream-2);
  border-radius: 999px;
  padding: 8px 16px;
  background: var(--white);
  font-family: var(--font-body);
}
.woocommerce nav.woocommerce-pagination ul {
  border: none;
}
.woocommerce nav.woocommerce-pagination ul li {
  border: none;
  margin: 0 4px;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border-radius: 999px;
  padding: 10px 16px;
  background: var(--white);
  color: var(--green);
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--green);
  color: var(--cream);
}

/* ---------- WooCommerce: single product ---------- */
.woocommerce div.product div.images img { border-radius: var(--radius); }
.woocommerce div.product .product_title {
  font-family: var(--font-display);
  font-size: 2.2rem;
  color: var(--green-deep);
}
.woocommerce div.product p.price {
  color: var(--terracotta);
  font-size: 1.5rem;
  font-weight: 800;
  margin: 14px 0 20px;
}
.woocommerce div.product form.cart div.quantity .qty {
  border: 1px solid var(--tan);
  border-radius: 999px;
  padding: 12px;
  width: 80px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding-left: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-color: var(--cream-2); }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent;
  border: none;
  border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--terracotta); }

/* ---------- Woo: notices, cart, checkout ---------- */
.woocommerce-message, .woocommerce-info {
  border-top-color: var(--green);
  background: var(--white);
  border-radius: var(--radius-sm);
}
.woocommerce-message::before, .woocommerce-info::before { color: var(--green); }
.woocommerce table.shop_table {
  border: 1px solid var(--cream-2);
  border-radius: var(--radius-sm);
  background: var(--white);
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 1px solid var(--tan);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  background: var(--white);
}

/* ---------- Generic page content ---------- */
.pf-page {
  max-width: 880px;
  margin: 0 auto;
  padding: 64px 24px;
  background: transparent;
}
.pf-page h1 { margin-bottom: 28px; }
.pf-page p { margin-bottom: 18px; }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .pf-hero__grid, .pf-story, .pf-news { grid-template-columns: 1fr; }
  .pf-cats { grid-template-columns: repeat(2, 1fr); }
  .pf-values, .pf-quotes { grid-template-columns: 1fr; }
  .pf-footer__grid { grid-template-columns: 1fr 1fr; }
  .pf-nav { display: none; }
  .pf-hero__grid { padding: 48px 24px 60px; }
  .pf-section { padding: 60px 0; }
}


/* Sticky header offset under the logged-in admin bar */
.admin-bar .pf-header{top:32px}
@media screen and (max-width:782px){.admin-bar .pf-header{top:46px}}
