
:root{
  --cream:#FBF6EC;
  --cream-deep:#F2E9D6;
  --paper:#FFFBF2;
  --ink:#21201C;
  --ink-soft:#403E37;
  --muted:#7A7569;
  --rule:#E8DEC5;
  --brand:#D03A38;
  --brand-deep:#B12B29;
  --sage:#7E8F6B;
  --sage-soft:#C9D2B6;
  --terra:#D69470;
  --butter:#F4D58D;
  --shadow:0 1px 0 rgba(33,32,28,.04), 0 30px 60px -30px rgba(33,32,28,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Manrope",ui-sans-serif,system-ui,sans-serif;
  font-feature-settings:"ss01","ss02","cv11";
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.13  0 0 0 0 0.12  0 0 0 0 0.11  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;opacity:.55;
}
a{color:var(--brand-deep);text-decoration:none;border-bottom:1px solid rgba(176,43,41,.25);transition:.2s ease}
a:hover{color:var(--brand);border-bottom-color:var(--brand)}
img{max-width:100%;display:block;height:auto}
h1,h2,h3,h4{
  font-family:"Fraunces",ui-serif,Georgia,serif;
  font-variation-settings:"SOFT" 60,"WONK" 1,"opsz" 144;
  font-weight:500;
  letter-spacing:-.012em;
  color:var(--ink);
  margin:0 0 .4em;
  line-height:1.05;
}
h1{font-size:clamp(2.6rem,7vw,5.6rem)}
h2{font-size:clamp(1.9rem,4vw,3.2rem)}
h3{font-size:1.5rem;font-variation-settings:"SOFT" 40,"WONK" 0,"opsz" 36}
.serif{font-family:"Fraunces",ui-serif,Georgia,serif}
.italic{font-style:italic}

.wrap{position:relative;z-index:1;max-width:1280px;margin:0 auto;padding:0 28px}
.narrow{max-width:780px;margin:0 auto;padding:0 28px}

/* nav */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(251,246,236,.78);
  border-bottom:1px solid rgba(232,222,197,.6);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;max-width:1280px;margin:0 auto}
.brand-mark{display:flex;align-items:center;gap:14px;border:none}
.brand-mark img{width:144px;height:auto}
.brand-mark:hover{border:none}
.nav-links{display:flex;gap:28px;align-items:center;list-style:none;padding:0;margin:0;font-size:14px;letter-spacing:.04em;text-transform:uppercase}
.nav-links a{color:var(--ink-soft);border:none;font-weight:500}
.nav-links a:hover{color:var(--brand)}
.nav-links .pill{padding:10px 18px;border-radius:999px;background:var(--ink);color:var(--cream)!important;letter-spacing:.05em}
.nav-links .pill:hover{background:var(--brand);color:#fff!important}
@media (max-width:760px){
  .nav-links{gap:14px;font-size:12px}
  .nav-links li:nth-child(n+4){display:none}
}

/* hero */
.hero{
  position:relative;padding:80px 0 60px;overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;gap:30px}}
.kicker{display:inline-flex;align-items:center;gap:10px;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);font-weight:600}
.kicker::before{content:"";width:24px;height:1px;background:var(--sage)}
.hero h1 em{font-style:italic;color:var(--brand-deep);font-variation-settings:"SOFT" 100,"WONK" 1,"opsz" 144}
.hero .lede{font-size:1.18rem;color:var(--ink-soft);margin-top:18px;max-width:46ch}
.hero-cta{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;background:var(--ink);color:var(--cream);font-size:14px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;border:none;cursor:pointer;transition:.2s}
.btn:hover{background:var(--brand);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream);box-shadow:inset 0 0 0 1.5px var(--ink)}
.hero-figure{position:relative}
.hero-figure .blob{position:absolute;inset:-30px;background:radial-gradient(60% 60% at 40% 50%, var(--butter) 0%, transparent 60%), radial-gradient(50% 50% at 70% 60%, var(--sage-soft) 0%, transparent 60%);filter:blur(8px);z-index:0}
.hero-figure img{position:relative;z-index:1;border-radius:24px;box-shadow:var(--shadow);transform:rotate(-1.5deg)}

/* paw divider */
.paws{display:flex;justify-content:center;gap:18px;color:var(--rule);margin:60px 0;font-size:22px;letter-spacing:.6em}
.paws svg{opacity:.6}

/* section header */
.sec{padding:70px 0;position:relative}
.sec-head{display:flex;align-items:end;justify-content:space-between;gap:30px;margin-bottom:48px;flex-wrap:wrap}
.sec-head .lede{color:var(--muted);max-width:48ch}

/* card grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:36px 28px}
.card{position:relative;display:block;border:none;color:inherit}
.card:hover{border:none}
.card-img{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;background:var(--cream-deep)}
.card-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(33,32,28,.18), transparent 40%);opacity:.5}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .card-img img{transform:scale(1.04)}
.card-meta{display:flex;align-items:center;gap:10px;margin-top:14px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.card-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--brand)}
.card h3{margin:8px 0 6px;font-size:1.4rem;font-variation-settings:"SOFT" 50,"opsz" 36}
.card .ex{color:var(--ink-soft);font-size:.95rem;line-height:1.5}

/* product showcase variant */
.show-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.show{position:relative;background:var(--paper);border-radius:22px;padding:28px;box-shadow:var(--shadow);transition:.3s}
.show:hover{transform:translateY(-3px)}
.show .show-img{aspect-ratio:1;border-radius:14px;overflow:hidden;background:var(--cream-deep);margin-bottom:18px}
.show .show-img img{width:100%;height:100%;object-fit:cover}
.show h3{margin:0 0 6px;font-size:1.25rem}
.show .sku{font-size:11px;letter-spacing:.18em;color:var(--sage);text-transform:uppercase;font-weight:600}
.show .tagline{color:var(--ink-soft);margin-top:8px;font-size:.95rem}
.badge{display:inline-block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;background:var(--sage-soft);color:#445033;padding:5px 10px;border-radius:999px;font-weight:700}

/* article */
.article{padding:60px 0 100px}
.article-head{text-align:center;max-width:780px;margin:0 auto 48px}
.article-meta{display:flex;justify-content:center;gap:14px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.article-meta span+span::before{content:"·";margin-right:14px;color:var(--rule)}
.article-hero{margin:0 auto 56px;max-width:980px;border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.article-hero img{width:100%}
.prose{max-width:680px;margin:0 auto;font-size:1.08rem;color:var(--ink-soft);line-height:1.75}
.prose p{margin:0 0 1.2em}
.prose h2{margin:1.8em 0 .5em;color:var(--ink)}
.prose h3{margin:1.5em 0 .4em;color:var(--ink)}
.prose blockquote{border-left:3px solid var(--brand);background:var(--paper);padding:18px 24px;margin:1.6em 0;border-radius:0 12px 12px 0;font-family:"Fraunces",serif;font-style:italic;font-size:1.2rem;color:var(--ink)}
.prose ul,.prose ol{padding-left:1.3em}
.prose ul.features{list-style:none;padding:0;margin:1.8em 0}
.prose ul.features li{padding:14px 0 14px 28px;border-top:1px solid var(--rule);position:relative;color:var(--ink-soft)}
.prose ul.features li:first-child{border-top:none}
.prose ul.features li::before{content:"";position:absolute;left:0;top:22px;width:16px;height:1.5px;background:var(--brand);border-radius:1px}
.prose ul.features li strong{color:var(--ink);font-weight:600;display:block;margin-bottom:2px;font-size:.98rem}
.prose img{margin:1.6em auto;border-radius:14px}
.prose a{color:var(--brand-deep);font-weight:500}

/* footer */
.footer{margin-top:80px;padding:60px 0 40px;background:var(--cream-deep);position:relative}
.footer .grid-f{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
@media (max-width:760px){.footer .grid-f{grid-template-columns:1fr}}
.footer h4{font-size:13px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);font-family:"Manrope",sans-serif;font-weight:700;margin-bottom:16px}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin:6px 0}
.footer a{color:var(--ink-soft);border:none;font-size:14px}
.footer a:hover{color:var(--brand)}
.footer img{width:130px}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;font-size:12px;color:var(--muted);letter-spacing:.05em}

/* hero pattern (paw spray) */
.paw{display:inline-block;width:18px;height:18px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><path d='M32 38c-6 0-12 5-12 11 0 5 5 9 12 9s12-4 12-9c0-6-6-11-12-11zm-16-8c4 0 7-4 7-9s-3-9-7-9-7 4-7 9 3 9 7 9zm32 0c4 0 7-4 7-9s-3-9-7-9-7 4-7 9 3 9 7 9zm-22-9c3 0 5-4 5-8s-2-8-5-8-5 4-5 8 2 8 5 8zm12 0c3 0 5-4 5-8s-2-8-5-8-5 4-5 8 2 8 5 8z'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><path d='M32 38c-6 0-12 5-12 11 0 5 5 9 12 9s12-4 12-9c0-6-6-11-12-11zm-16-8c4 0 7-4 7-9s-3-9-7-9-7 4-7 9 3 9 7 9zm32 0c4 0 7-4 7-9s-3-9-7-9-7 4-7 9 3 9 7 9zm-22-9c3 0 5-4 5-8s-2-8-5-8-5 4-5 8 2 8 5 8zm12 0c3 0 5-4 5-8s-2-8-5-8-5 4-5 8 2 8 5 8z'/></svg>") center/contain no-repeat}

/* feature strip */
.feat-strip{background:var(--ink);color:var(--cream);padding:24px 0}
.feat-strip .row{display:flex;justify-content:space-around;gap:30px;align-items:center;flex-wrap:wrap;font-size:13px;letter-spacing:.14em;text-transform:uppercase}
.feat-strip .row span{display:flex;align-items:center;gap:10px;color:var(--cream)}
.feat-strip .row .paw{color:var(--brand)}

/* about block */
.about{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media (max-width:900px){.about{grid-template-columns:1fr}}
.about figure{position:relative}
.about figure img{border-radius:24px;box-shadow:var(--shadow)}
.about .blob-2{position:absolute;width:80%;height:80%;background:radial-gradient(circle at 30% 30%, var(--sage-soft), transparent 70%);top:-20px;left:-20px;z-index:-1;border-radius:50%}

/* blog list */
.post-list{display:flex;flex-direction:column;gap:0}
.post-row{display:grid;grid-template-columns:200px 1fr 110px;gap:30px;align-items:center;padding:28px 0;border-top:1px solid var(--rule);text-decoration:none;color:inherit;border-bottom:none;transition:.25s}
.post-row:first-of-type{border-top:none}
.post-row:hover{padding-left:8px;background:linear-gradient(to right, var(--paper), transparent)}
.post-row img{width:200px;height:130px;object-fit:cover;border-radius:14px}
.post-row h3{margin:0 0 4px;font-size:1.35rem;font-variation-settings:"SOFT" 40,"opsz" 36}
.post-row .ex{color:var(--muted);font-size:.95rem;line-height:1.5;margin:0}
.post-row time{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--sage);font-weight:600;text-align:right}
@media (max-width:760px){
  .post-row{grid-template-columns:1fr;gap:14px}
  .post-row img{width:100%;height:200px}
  .post-row time{text-align:left}
}

/* page generic */
.page-head{padding:80px 0 30px;text-align:center}
.page-head .kicker{justify-content:center;display:flex}
.page-head h1{max-width:18ch;margin-left:auto;margin-right:auto}

/* tag */
.tag{display:inline-block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;background:var(--cream-deep);color:var(--ink-soft);padding:5px 11px;border-radius:999px;margin:2px 4px 2px 0;font-weight:600;border:none}
.tag:hover{background:var(--brand);color:#fff}

/* fade-in */
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.rise{animation:rise .9s cubic-bezier(.2,.7,.2,1) both}
.rise-2{animation-delay:.12s}
.rise-3{animation-delay:.24s}
.rise-4{animation-delay:.36s}
