/*
Theme Name: Aninut
Theme URI: https://example.com/aninut
Author: Aninut Studio
Author URI: https://example.com
Description: A warm, editorial WordPress theme for premium pet food & treat brands. Built for Aninut — "For the love that spans a lifetime." Includes a full front-page template with hero, product rituals, brand promise, process timeline and trust footer, plus Customizer controls for every image and headline.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.6
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aninut
Tags: e-commerce, food-and-drink, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, threaded-comments, translation-ready
*/

/* =========================================================
   0. DESIGN TOKENS
========================================================= */
:root{
  --color-cream:        #f7f1e6;
  --color-cream-2:      #efe6d6;
  --color-blush:        #e9dccb;
  --color-ink:          #241c14;
  --color-ink-soft:     #463a2c;
  --color-brown:        #6b5a45;
  --color-gold:         #b9803a;
  --color-gold-dark:    #9c6a2c;
  --color-sage:         #5f6e4f;
  --color-maroon:       #6c2433;
  --color-line:         rgba(36,28,20,0.14);
  --color-white:        #fffdf9;

  --font-display: "Playfair Display", "Iowan Old Style", Georgia, serif;
  --font-body: "Jost", "Helvetica Neue", Arial, sans-serif;

  --container: 1240px;
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 28px;
  --radius-pill: 999px;

  --shadow-card: 0 18px 40px -22px rgba(36,28,20,0.35);
}

/* =========================================================
   1. RESET
========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--color-cream);
  color:var(--color-ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
ul{ margin:0; padding:0; list-style:none; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
input, textarea, select{ font-family:inherit; font-size:1rem; }
h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.18;
  margin:0 0 .5em;
  color:var(--color-ink);
}
p{ margin:0 0 1em; }
.screen-reader-text{
  position:absolute !important;
  clip:rect(1px,1px,1px,1px);
  overflow:hidden;
  height:1px;width:1px;
  word-wrap:normal !important;
}
:focus-visible{
  outline:2px solid var(--color-gold-dark);
  outline-offset:3px;
}

/* =========================================================
   2. LAYOUT HELPERS
========================================================= */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 32px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--color-gold-dark);
}
.section-head{
  text-align:center;
  max-width:640px;
  margin:0 auto 56px;
}
.section-head .eyebrow{ justify-content:center; margin-bottom:14px; }
.section-head h2{ font-size:clamp(1.9rem,3.2vw,2.5rem); }
.section-rule{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin:18px 0 0;
}
.section-rule .ln{ width:46px; height:1px; background:var(--color-line); }
.section-rule svg{ width:16px; height:16px; color:var(--color-gold); }
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:15px 30px;
  border-radius:var(--radius-pill);
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  border:1px solid transparent;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--color-gold); color:var(--color-white); }
.btn-primary:hover{ background:var(--color-gold-dark); transform:translateY(-1px); }
.btn-outline{ background:transparent; color:var(--color-ink); border-color:var(--color-ink); }
.btn-outline:hover{ background:var(--color-ink); color:var(--color-white); }
.btn-outline.light{ color:var(--color-white); border-color:rgba(255,255,255,.65); }
.btn-outline.light:hover{ background:var(--color-white); color:var(--color-ink); }
.btn-link{
  display:inline-flex; align-items:center; gap:6px;
  font-size:.78rem; font-weight:600; letter-spacing:.1em;
  text-transform:uppercase; color:var(--color-ink);
  border-bottom:1px solid currentColor; padding-bottom:2px;
}
.btn-link svg{ width:14px; height:14px; transition:transform .2s ease; }
.btn-link:hover svg{ transform:translateX(3px); }

/* =========================================================
   3. ANNOUNCEMENT BAR
========================================================= */
.announce-bar{
  background:var(--color-ink);
  color:#e7ddcb;
  font-size:.78rem;
  letter-spacing:.02em;
}
.announce-bar .container{
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  gap:36px;
  padding-top:10px;
  padding-bottom:10px;
}
.announce-bar .item{ display:flex; align-items:center; gap:8px; opacity:.92; }
.announce-bar svg{ width:14px; height:14px; flex:none; color:var(--color-gold); }

/* =========================================================
   4. SITE HEADER
========================================================= */
.site-header{
  background:var(--color-cream);
  border-bottom:1px solid var(--color-line);
  position:sticky;
  top:0;
  z-index:50;
}
.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding-top:18px;
  padding-bottom:18px;
}
.site-branding{ display:flex; align-items:center; gap:12px; }
.site-branding .brand-mark{ width:38px; height:38px; flex:none; color:var(--color-gold); }
.site-branding .brand-text{ line-height:1.1; }
.site-branding .brand-name{
  font-family:var(--font-display);
  font-size:1.45rem;
  letter-spacing:.2em;
  font-weight:600;
}
.site-branding .brand-tag{
  display:block;
  font-family:var(--font-body);
  font-size:.68rem;
  letter-spacing:.04em;
  color:var(--color-brown);
  margin-top:2px;
}
.site-branding img.custom-logo{ max-height:46px; width:auto; }

.primary-nav{ flex:1; display:flex; justify-content:center; }
.primary-nav ul{ display:flex; align-items:center; gap:38px; }
.primary-nav li{ position:relative; }
.primary-nav a{
  font-size:.82rem;
  font-weight:500;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--color-ink-soft);
  transition:color .2s ease;
}
.primary-nav a:hover, .primary-nav li:hover > a{ color:var(--color-gold-dark); }
.primary-nav li.menu-item-has-children > a{ display:flex; align-items:center; gap:5px; }
.primary-nav li.menu-item-has-children > a::after{
  content:"";
  width:7px; height:7px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg);
  margin-top:-3px;
}
.primary-nav .sub-menu{
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(8px);
  background:var(--color-white);
  border:1px solid var(--color-line);
  border-radius:var(--radius-sm);
  min-width:190px;
  padding:10px;
  box-shadow:var(--shadow-card);
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
}
.primary-nav li:hover > .sub-menu{ opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.primary-nav .sub-menu li{ width:100%; }
.primary-nav .sub-menu a{
  display:block; padding:8px 12px; border-radius:6px; text-transform:none;
  letter-spacing:.02em; font-size:.86rem;
}
.primary-nav .sub-menu a:hover{ background:var(--color-cream-2); }

.header-actions{ display:flex; align-items:center; gap:20px; }
.header-icon-link{
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; color:var(--color-ink-soft); position:relative;
}
.header-icon-link svg{ width:21px; height:21px; }
.cart-count{
  position:absolute; top:-8px; right:-10px;
  background:var(--color-gold); color:#fff;
  font-size:.62rem; font-weight:700;
  width:16px; height:16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.menu-toggle{
  display:none; background:none; border:0; padding:6px;
  flex-direction:column; gap:5px;
}
.menu-toggle span{ width:24px; height:2px; background:var(--color-ink); display:block; }

/* =========================================================
   5. HERO
========================================================= */
.hero{ background:var(--color-blush); overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,0.95fr); align-items:stretch; }
.hero-media{ position:relative; min-height:480px; }
.hero-media .img-fill{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-copy{ display:flex; flex-direction:column; justify-content:center; padding:64px 64px; }
.hero-copy h1{ font-size:clamp(2.3rem,4vw,3.4rem); margin-bottom:6px; }
.hero-copy h1 em{ font-style:italic; color:var(--color-gold-dark); font-weight:500; }
.hero-copy .section-rule{ justify-content:flex-start; margin:18px 0 22px; }
.hero-copy p.lede{ max-width:440px; font-size:1.02rem; color:var(--color-ink-soft); }
.hero-actions{ display:flex; gap:16px; margin-top:8px; flex-wrap:wrap; }

/* =========================================================
   6. RITUAL / PRODUCT CARDS
========================================================= */
.section{ padding:96px 0; }
.section.tight{ padding-top:88px; padding-bottom:0; }
.ritual-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.ritual-card{
  background:var(--color-white);
  border:1px solid var(--color-line);
  border-radius:var(--radius-md);
  padding:30px 30px 26px;
  display:flex; flex-direction:column;
}
.ritual-card .card-eyebrow{ font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:6px; }
.ritual-card.theme-gold .card-eyebrow{ color:var(--color-gold-dark); }
.ritual-card.theme-sage .card-eyebrow{ color:var(--color-sage); }
.ritual-card.theme-maroon .card-eyebrow{ color:var(--color-maroon); }
.ritual-card h3{ font-size:1.35rem; margin-bottom:4px; }
.ritual-card .card-sub{ font-size:.88rem; color:var(--color-brown); margin-bottom:18px; }
.ritual-card .card-features{ display:flex; flex-direction:column; gap:10px; margin-bottom:22px; }
.ritual-card .card-features li{ display:flex; align-items:center; gap:10px; font-size:.88rem; color:var(--color-ink-soft); }
.ritual-card .card-features svg{ width:16px; height:16px; flex:none; }
.ritual-card.theme-gold .card-features svg{ color:var(--color-gold); }
.ritual-card.theme-sage .card-features svg{ color:var(--color-sage); }
.ritual-card.theme-maroon .card-features svg{ color:var(--color-maroon); }
.card-visual{
  position:relative;
  margin-top:auto;
  display:grid;
  grid-template-columns:1fr 1.3fr;
  align-items:end;
  gap:14px;
  min-height:190px;
  margin-bottom:18px;
}
.card-visual .bowl-wrap, .card-visual .bag-wrap{
  border-radius:var(--radius-sm);
  overflow:hidden;
  background:var(--color-cream-2);
  aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
}
.card-visual .bag-wrap{ aspect-ratio:3/4; }
.card-visual img{ width:100%; height:100%; object-fit:cover; }
.placeholder-fill{
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  background:repeating-linear-gradient(135deg, var(--ph-a,#e7dac3) 0 14px, var(--ph-b,#ded0b3) 14px 28px);
  color:var(--color-ink-soft);
}
.placeholder-fill svg{ width:34%; height:34%; opacity:.55; }
.ritual-card .btn-link{ margin-top:auto; }

/* =========================================================
   7. PROMISE SECTION
========================================================= */
.promise{ background:var(--color-blush); border-radius:var(--radius-lg); }
.promise-inner{
  display:grid;
  grid-template-columns:0.85fr 1fr 0.85fr;
  gap:0;
  align-items:stretch;
}
.promise-text{ padding:56px 48px; display:flex; flex-direction:column; justify-content:center; }
.promise-text h2{ font-size:clamp(1.9rem,3vw,2.3rem); margin-bottom:16px; }
.promise-text h2 em{ font-style:italic; color:var(--color-gold-dark); font-weight:500; }
.promise-text p{ color:var(--color-ink-soft); max-width:380px; }
.promise-media{ position:relative; min-height:320px; }
.promise-media img, .promise-media .placeholder-fill{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:0; }
.promise-points{ display:grid; grid-template-columns:1fr 1fr; gap:0; }
.promise-point{
  padding:34px 26px;
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px;
}
.promise-points .promise-point:nth-child(odd){ border-right:1px solid rgba(36,28,20,.1); }
.promise-points .promise-point:nth-child(-n+2){ border-bottom:1px solid rgba(36,28,20,.1); }
.promise-point svg{ width:30px; height:30px; color:var(--color-gold-dark); }
.promise-point span{ font-size:.84rem; font-weight:500; line-height:1.35; }

/* =========================================================
   8. PROCESS / JOURNEY
========================================================= */
.process-track{ position:relative; }
.process-track::before{
  content:"";
  position:absolute; top:34px; left:8%; right:8%;
  height:1px;
  background-image:linear-gradient(to right, var(--color-gold) 0 6px, transparent 6px 14px);
  background-size:14px 1px;
  background-repeat:repeat-x;
  z-index:0;
}
.process-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:20px; position:relative; z-index:1; }
.process-step{ display:flex; flex-direction:column; align-items:center; text-align:center; }
.step-num{
  width:30px; height:30px; border-radius:50%;
  background:var(--color-gold);
  color:#fff; font-size:.8rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px;
}
.step-media{
  width:118px; height:118px; border-radius:50%; overflow:hidden;
  margin-bottom:18px; border:1px solid var(--color-line);
}
.step-media img, .step-media .placeholder-fill{ width:100%; height:100%; object-fit:cover; }
.process-step h4{ font-size:1.02rem; margin-bottom:6px; }
.process-step p{ font-size:.83rem; color:var(--color-brown); margin-bottom:0; }

/* =========================================================
   9. TRUST FOOTER BAR
========================================================= */
.trust-bar{ border-top:1px solid var(--color-line); background:var(--color-cream-2); }
.trust-bar .container{
  display:grid; grid-template-columns:repeat(6,1fr);
  padding-top:26px; padding-bottom:26px; gap:18px;
}
.trust-item{ display:flex; align-items:center; gap:12px; }
.trust-item svg{ width:26px; height:26px; color:var(--color-gold-dark); flex:none; }
.trust-item span{ font-size:.83rem; line-height:1.3; color:var(--color-ink-soft); }

/* =========================================================
   10. SITE FOOTER
========================================================= */
.site-footer{ background:var(--color-ink); color:#cfc3ad; }
.footer-top{ padding:72px 0 48px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:48px; }
.footer-brand .brand-name{ color:#f7f1e6; font-family:var(--font-display); font-size:1.3rem; letter-spacing:.18em; }
.footer-brand p{ color:#a99c83; font-size:.88rem; margin-top:14px; max-width:280px; }
.footer-col h5{ color:#f0e7d6; font-family:var(--font-body); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:18px; }
.footer-col ul{ display:flex; flex-direction:column; gap:11px; }
.footer-col a{ font-size:.9rem; color:#a99c83; transition:color .2s ease; }
.footer-col a:hover{ color:#f0e7d6; }
.footer-social{ display:flex; gap:12px; margin-top:18px; }
.footer-social a{
  width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,.18);
  display:flex; align-items:center; justify-content:center;
}
.footer-social svg{ width:16px; height:16px; }
.footer-newsletter input[type=email]{
  width:100%; padding:13px 16px; border-radius:var(--radius-pill);
  border:1px solid rgba(255,255,255,.2); background:rgba(255,255,255,.06); color:#fff;
  margin-bottom:10px;
}
.footer-newsletter input::placeholder{ color:#9a8d75; }
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding:22px 0; font-size:.8rem; color:#8d8068;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.footer-bottom a{ color:#a99c83; }
.footer-bottom a:hover{ color:#f0e7d6; }

/* =========================================================
   11. GENERIC PAGE / BLOG
========================================================= */
.page-hero{ background:var(--color-blush); padding:64px 0; text-align:center; }
.page-hero h1{ font-size:clamp(2rem,4vw,2.8rem); }
.content-area{ padding:72px 0; }
.entry-content{ max-width:760px; margin:0 auto; }
.entry-content h2{ margin-top:1.4em; }
.entry-content img{ border-radius:var(--radius-md); margin:1.5em 0; }
.entry-content blockquote{
  border-left:3px solid var(--color-gold);
  margin:1.6em 0; padding:.4em 0 .4em 22px;
  font-style:italic; color:var(--color-ink-soft);
}
.post-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; max-width:var(--container); margin:0 auto; }
.post-card{ background:var(--color-white); border:1px solid var(--color-line); border-radius:var(--radius-md); overflow:hidden; }
.post-card .post-thumb{ aspect-ratio:4/3; overflow:hidden; }
.post-card .post-thumb img{ width:100%; height:100%; object-fit:cover; }
.post-card .post-body{ padding:22px; }
.post-card h3{ font-size:1.1rem; }
.post-card .post-meta{ font-size:.75rem; letter-spacing:.08em; text-transform:uppercase; color:var(--color-gold-dark); margin-bottom:8px; }
.pagination{ display:flex; justify-content:center; gap:10px; margin-top:48px; }
.pagination a, .pagination span{
  width:40px; height:40px; border-radius:50%; border:1px solid var(--color-line);
  display:flex; align-items:center; justify-content:center; font-size:.85rem;
}
.pagination .current{ background:var(--color-ink); color:#fff; border-color:var(--color-ink); }

.comment-list{ list-style:none; margin:2em 0; padding:0; }
.comment-list li{ border-bottom:1px solid var(--color-line); padding:18px 0; }
.comment-form input, .comment-form textarea{
  width:100%; padding:12px 14px; border:1px solid var(--color-line);
  border-radius:var(--radius-sm); margin-bottom:14px; background:#fff;
}

/* =========================================================
   12. RESPONSIVE
========================================================= */
@media (max-width:1080px){
  .ritual-grid{ grid-template-columns:1fr 1fr; }
  .ritual-grid .ritual-card:last-child{ grid-column:1/-1; }
  .process-grid{ grid-template-columns:repeat(3,1fr); row-gap:40px; }
  .process-track::before{ display:none; }
  .trust-bar .container{ grid-template-columns:repeat(3,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .promise-inner{ grid-template-columns:1fr; }
  .promise-points{ grid-template-columns:repeat(4,1fr); }
  .promise-points .promise-point{ border-right:1px solid rgba(36,28,20,.1); border-bottom:0; }
  .promise-points .promise-point:last-child{ border-right:0; }
}
@media (max-width:880px){
  .primary-nav{ display:none; }
  .menu-toggle{ display:flex; }
  .hero-grid{ grid-template-columns:1fr; }
  .hero-media{ min-height:340px; order:-1; }
  .hero-copy{ padding:48px 28px; }
  .announce-bar .item:nth-child(n+2){ display:none; }
}
@media (max-width:700px){
  .container{ padding:0 20px; }
  .ritual-grid{ grid-template-columns:1fr; }
  .ritual-grid .ritual-card:last-child{ grid-column:auto; }
  .process-grid{ grid-template-columns:1fr 1fr; }
  .promise-points{ grid-template-columns:1fr 1fr; }
  .promise-text{ padding:40px 24px; text-align:center; }
  .promise-text p{ margin-left:auto; margin-right:auto; }
  .trust-bar .container{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:36px; }
  .post-list{ grid-template-columns:1fr; }
  .section{ padding:64px 0; }
}

/* Mobile nav drawer */
.mobile-nav{
  position:fixed; inset:0 0 0 auto; width:min(320px,86%);
  background:var(--color-white); z-index:100;
  transform:translateX(100%); transition:transform .3s ease;
  box-shadow:-10px 0 30px rgba(0,0,0,.2);
  padding:28px 26px; overflow-y:auto;
}
.mobile-nav.is-open{ transform:translateX(0); }
.mobile-nav-overlay{
  position:fixed; inset:0; background:rgba(20,15,10,.45);
  z-index:99; opacity:0; visibility:hidden; transition:opacity .3s ease;
}
.mobile-nav-overlay.is-open{ opacity:1; visibility:visible; }
.mobile-nav .close-nav{ background:none; border:0; margin-bottom:24px; }
.mobile-nav ul{ display:flex; flex-direction:column; gap:4px; }
.mobile-nav a{ display:block; padding:12px 4px; font-size:.95rem; border-bottom:1px solid var(--color-line); }
.mobile-nav .sub-menu{ padding-left:14px; display:none; }
