/*
Theme Name: SnugHide
Theme URI: https://snughide.com
Description: Custom warm-naturalist editorial theme for SnugHide ball python care. Lean, fast, no page builders.
Author: SnugHide
Version: 1.0
License: GPL-2.0-or-later
Text Domain: snughide
*/

/* ===========================================================================
   SnugHide, design system  (warm naturalist editorial)
   Display: Fraunces  ·  Body: Hanken Grotesk
   =========================================================================== */

:root{
  --ink:#15231a;            /* near-black forest */
  --jungle:#0e2e20;         /* deep emerald */
  --jungle-2:#15402c;
  --moss:#2f5e43;
  --fern:#5b8c5a;
  --substrate:#f6ecd9;      /* warm coconut cream */
  --paper:#fbf6ec;
  --paper-2:#f3e9d6;
  --amber:#c9842b;
  --amber-soft:#e7b56a;
  --banana:#ffce3a;         /* vivid accent */
  --coral:#ff7a52;          /* vivid accent */
  --violet:#9b6bff;         /* morph accent (sparingly) */
  --line:rgba(21,35,26,.12);
  --shadow:0 18px 40px -18px rgba(20,46,32,.45);
  --shadow-sm:0 8px 22px -12px rgba(20,46,32,.4);
  --radius:22px;
  --radius-lg:34px;
  --maxw:1180px;
  --display:'Fraunces',Georgia,serif;
  --body:'Hanken Grotesk',system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);
  background:
    radial-gradient(1100px 600px at 85% -10%, #fff7e6 0%, transparent 60%),
    radial-gradient(900px 700px at -10% 10%, #eef6ea 0%, transparent 55%),
    var(--substrate);
  line-height:1.6;-webkit-font-smoothing:antialiased;
}
/* film grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:2}
a{color:inherit}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:-.01em;margin:0}
h2{font-size:clamp(1.7rem,3.4vw,2.7rem)}
h3{font-size:1.4rem}
p{margin:0 0 1rem}
.eyebrow{font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;color:var(--amber)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem;
  padding:.85rem 1.5rem;border-radius:999px;border:0;cursor:pointer;text-decoration:none;transition:.25s}
.btn-primary{background:var(--jungle);color:#fdf7e9}
.btn-primary:hover{background:var(--jungle-2);transform:translateY(-2px);box-shadow:0 14px 28px -14px rgba(14,46,32,.7)}
.btn-primary .arr{transition:.25s}
.btn-primary:hover .arr{transform:translateX(4px)}
.btn-banana{background:var(--banana);color:var(--ink)}
.btn-banana:hover{background:#ffd95e;transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--moss);background:#fff}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:40;backdrop-filter:blur(10px);
  background:rgba(246,236,217,.82);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px;gap:2rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;font-size:1.4rem;text-decoration:none;flex-shrink:0}
.brand .dot{width:34px;height:34px;border-radius:11px;background:
  conic-gradient(from 200deg,var(--banana),var(--amber),var(--coral),var(--moss),var(--banana));
  display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.brand svg{width:40px;height:40px;flex-shrink:0}
.nav-links{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.nav-links li{list-style:none;margin:0;padding:0;display:flex;align-items:center}
.nav-links a{text-decoration:none;font-weight:600;font-size:.95rem;color:var(--ink);opacity:.8;transition:.2s;white-space:nowrap}
.nav-links a:hover{opacity:1;color:var(--moss)}
.nav-cta{padding:.55rem 1.1rem!important;font-size:.88rem!important}
.nav-toggle{display:none;background:none;border:0;padding:6px;margin:0;cursor:pointer;color:var(--ink);line-height:0;-webkit-tap-highlight-color:transparent}
.nav-toggle svg{width:28px;height:28px;display:block}
@media(max-width:820px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav-in{gap:1rem}
  .nav-links{position:absolute;top:100%;left:0;right:0;display:none;flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:0;background:rgb(246,236,217);border-bottom:1px solid var(--line);box-shadow:0 14px 30px rgba(21,35,26,.14);padding:6px 24px 16px}
  .nav-links.open{display:flex}
  .nav-links li{display:block}
  .nav-links a{display:block;padding:13px 2px;opacity:1;border-bottom:1px solid var(--line);font-size:1rem}
  .nav-links .nav-cta{margin-top:12px;border-bottom:0;justify-content:center;text-align:center}
}

/* ---- ad zones (clearly marked) ---- */
.ad-zone{display:grid;place-items:center;border:2px dashed var(--amber-soft);border-radius:16px;
  background:repeating-linear-gradient(45deg,rgba(231,181,106,.08),rgba(231,181,106,.08) 12px,transparent 12px,transparent 24px);
  color:var(--amber);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.7rem;text-align:center;padding:14px}
.ad-zone span{display:block;opacity:.7;font-size:.64rem;margin-top:4px;font-weight:600}
.ad-leaderboard{height:120px}
.ad-rect{height:266px;width:100%;max-width:336px;margin-inline:auto}
.ad-incontent{height:128px;margin:2rem 0}

/* ---- image placeholders ---- */
.ph{position:relative;border-radius:var(--radius);overflow:hidden;background:
  linear-gradient(135deg,#3a5a44,#1c3a29);box-shadow:var(--shadow)}
.ph::after{content:attr(data-label);position:absolute;left:12px;bottom:12px;z-index:2;
  font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.78);
  background:rgba(14,46,32,.5);padding:5px 9px;border-radius:8px;backdrop-filter:blur(3px)}
.ph::before{content:"";position:absolute;inset:0;z-index:1;opacity:.5;background:
  radial-gradient(120px 80px at 30% 30%,rgba(255,206,58,.4),transparent),
  radial-gradient(160px 120px at 75% 70%,rgba(255,122,82,.35),transparent),
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M20 0l20 20-20 20L0 20z' fill='none' stroke='%23ffffff22'/%3E%3C/svg%3E")}
.r16x9{aspect-ratio:16/9}
.r4x3{aspect-ratio:4/3}
.r1x1{aspect-ratio:1/1}

/* ---- reveal (progressive enhancement: content visible without JS) ---- */
.reveal{transition:.7s cubic-bezier(.2,.7,.2,1)}
html.js .reveal{opacity:0;transform:translateY(22px)}
html.js .reveal.in{opacity:1;transform:none}

/* ---- footer ---- */
.foot{background:var(--jungle);color:#e7e0cf;margin-top:80px;padding:60px 0 34px;position:relative;z-index:2}
.foot a{color:#cfe3cf;text-decoration:none;opacity:.85}
.foot a:hover{opacity:1}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
.foot h4{color:#fff;font-size:1rem;margin-bottom:.8rem;font-family:var(--body);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;opacity:.7}
.foot ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem;font-size:.92rem}
.disclosure{margin-top:34px;padding-top:20px;border-top:1px solid rgba(255,255,255,.14);font-size:.8rem;opacity:.7;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ===== from index.html ===== */
/* hero */
.hero{position:relative;padding:54px 0 40px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);line-height:.98;letter-spacing:-.02em}
.hero h1 em{font-style:italic;color:var(--amber)}
.hero .lede{font-size:1.18rem;max-width:30rem;margin:1.3rem 0 1.8rem;color:#3a4a3e}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.chips{display:flex;gap:.5rem;margin-top:1.8rem;flex-wrap:wrap}
.chip{font-size:.78rem;font-weight:700;padding:.45rem .8rem;border-radius:999px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;gap:.45rem}
.chip i{width:12px;height:12px;border-radius:50%}
.snake-stage{position:relative;aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;
  background:radial-gradient(120% 120% at 70% 20%,#2c5440,#0c2a1d);box-shadow:var(--shadow)}
.snake-stage .label{position:absolute;left:16px;bottom:16px;color:rgba(255,255,255,.8);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(0,0,0,.3);padding:6px 10px;border-radius:8px}
.blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.55}
.tongue{transform-origin:center;animation:flick 3.4s ease-in-out infinite}
@keyframes flick{0%,82%,100%{transform:scaleY(1)}88%{transform:scaleY(1.5) translateY(3px)}}
/* sections */
section{position:relative;z-index:2}
.sec{padding:56px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px}
.sec-head p{max-width:34rem;color:#46564a;margin:.5rem 0 0}
.journey{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.jcard{background:#fff;border-radius:var(--radius);padding:26px;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:.3s;position:relative;overflow:hidden}
.jcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.jcard .num{font-family:var(--display);font-size:2.4rem;color:var(--amber-soft)}
.jcard h3{margin:.3rem 0 .5rem}
.jcard p{color:#52624f;font-size:.96rem;margin:0}
.jcard .go{position:absolute;top:24px;right:24px;color:var(--moss);font-weight:800}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pill{border-radius:var(--radius);padding:24px;color:#fff;min-height:170px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-sm);transition:.3s;text-decoration:none}
.pill:hover{transform:translateY(-5px) scale(1.01);box-shadow:var(--shadow)}
.pill h3{color:#fff}.pill span{opacity:.85;font-size:.86rem;font-weight:600}
.pill .c{font-size:.78rem;font-weight:700;background:rgba(255,255,255,.2);align-self:flex-start;padding:.3rem .6rem;border-radius:999px}
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.fcard{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:.3s;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.fcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.fcard .body{padding:18px}
.fcard .cat{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--coral)}
.fcard h3{font-size:1.18rem;margin:.35rem 0 .4rem}
.fcard p{font-size:.9rem;color:#56654f;margin:0}
.morphstrip{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}
.swatch{flex:1;min-width:90px;border-radius:16px;height:84px;position:relative;display:flex;align-items:flex-end;padding:10px;color:#fff;font-weight:700;font-size:.8rem;box-shadow:var(--shadow-sm)}
.trust{background:linear-gradient(120deg,var(--jungle),var(--jungle-2));border-radius:var(--radius-lg);color:#eee6d3;padding:44px;display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:center;box-shadow:var(--shadow)}
.trust h2{color:#fff}.trust p{color:#cdd9c8}
.trust .stats{display:flex;gap:28px;margin-top:18px}
.trust .stats b{font-family:var(--display);font-size:2rem;color:var(--banana);display:block}
.trust .stats span{font-size:.8rem;opacity:.8}
@media(max-width:880px){.hero-grid,.trust{grid-template-columns:1fr}.journey,.pillars,.feat{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.journey,.pillars,.feat{grid-template-columns:1fr}}

/* ===== from pillar.html ===== */
.crumb{font-size:.82rem;font-weight:600;color:#6a7a64;padding:18px 0}
.crumb a{text-decoration:none}.crumb b{color:var(--ink)}
.phero{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;align-items:center;
  background:linear-gradient(135deg,#2f5e43,#143d2b);color:#eee6d3;border-radius:var(--radius-lg);padding:42px;box-shadow:var(--shadow);overflow:hidden;position:relative}
.phero h1{color:#fff;font-size:clamp(2.2rem,5vw,3.4rem)}
.phero p{color:#cdd9c8;max-width:34rem;margin-top:.8rem}
.phero .meta{display:flex;gap:18px;margin-top:18px;font-size:.85rem}
.phero .meta b{font-family:var(--display);font-size:1.4rem;color:var(--banana);display:block}
.layout{display:grid;grid-template-columns:1fr 320px;gap:40px;margin-top:40px;align-items:start}
.subhead{display:flex;align-items:center;gap:.6rem;margin:34px 0 18px}
.subhead h2{font-size:1.7rem}.subhead .ln{flex:1;height:1px;background:var(--line)}
.glist{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.gitem{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);transition:.3s}
.gitem:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.gitem .th{width:130px;flex:none}
.gitem .th .ph{border-radius:0;height:100%}
.gitem .th img{width:100%;height:100%;min-height:120px;object-fit:cover}
.gitem .bd{padding:16px}
.gitem .cat{font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--coral)}
.gitem h3{font-size:1.05rem;margin:.3rem 0}
.gitem p{font-size:.84rem;color:#5a6a54;margin:0}
.big{grid-column:1/-1;flex-direction:column}
.big .th{width:100%;height:200px}
.big h3{font-size:1.5rem}
aside .card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);margin-bottom:22px}
aside h4{font-family:var(--body);text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--amber);margin:0 0 .8rem}
aside ul{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
aside li a{text-decoration:none;font-weight:600;font-size:.92rem;display:flex;gap:.5rem}
aside li a:hover{color:var(--moss)}
.sticky{position:sticky;top:90px}
@media(max-width:900px){.layout,.phero{grid-template-columns:1fr}.glist{grid-template-columns:1fr}}

/* ===== from article.html ===== */
.crumb{font-size:.82rem;font-weight:600;color:#6a7a64;padding:18px 0}
.crumb a{text-decoration:none}.crumb b{color:var(--ink)}
.ahead{max-width:760px;margin:0 auto}
.ahead .cat{font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.ahead h1{font-size:clamp(2.1rem,4.6vw,3.3rem);margin:.5rem 0 .8rem;line-height:1.04}
.ahead .sub{font-size:1.15rem;color:#46564a;margin:0 0 1.4rem}
.byline{display:flex;align-items:center;gap:12px;font-size:.9rem;color:#52624f}
.byline .av{width:42px;height:42px;border-radius:50%;background:conic-gradient(from 200deg,var(--banana),var(--amber),var(--coral),var(--moss),var(--banana))}
.byline b{color:var(--ink)}
.byline .meta{display:flex;gap:10px;align-items:center}
.byline .meta::before{content:"·";margin-right:6px}
.featured{margin:26px auto 0;max-width:1000px}
.featured .ph{aspect-ratio:16/9;border-radius:var(--radius-lg)}
/* real WP images: ALWAYS keep their natural aspect ratio (no stretch, no forced height) */
img{max-width:100%;height:auto}
.featured{overflow:hidden;border-radius:var(--radius-lg)}
.featured img{display:block;width:100%;height:auto;border-radius:var(--radius-lg)}
.article-body img{display:block;max-width:100%;height:auto;border-radius:var(--radius);margin-inline:auto}
.article-body figure{margin:1.8rem 0}
.article-body figure img{width:100%}
.article-body figure figcaption{font-size:.82rem;color:#6a7a64;margin-top:.5rem;text-align:center}
.rcard img{display:block;width:100%;height:auto;border-radius:var(--radius)}
/* never overflow the viewport horizontally (fixes mobile zoom + side-scroll) */
html,body{overflow-x:clip}
.layout>*{min-width:0}
.article{min-width:0}
/* mobile: wide tables scroll horizontally. Higher specificity than the base .article-body table{overflow:hidden} (rounded corners) so it is NOT overridden. */
@media(max-width:768px){.article .article-body table{display:block;width:100%;overflow-x:auto !important;-webkit-overflow-scrolling:touch}}
.layout{display:block;max-width:760px;margin:40px auto 0}
.layout>aside{display:none}
.gitem.big{position:relative}
.gitem.big .bd{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;background:linear-gradient(to top,rgba(12,28,20,.92),rgba(12,28,20,.45) 55%,transparent)}
.gitem.big .bd .cat{color:var(--banana)}
.gitem.big .bd h3,.gitem.big .bd p{color:#fff}
.article{max-width:none}
.article-body{font-size:1.085rem;line-height:1.75;color:#27332a}
.article-body>p:first-of-type::first-letter{font-family:var(--display);font-size:3.6rem;float:left;line-height:.8;padding:.05em .12em 0 0;color:var(--amber)}
.article-body h2{font-size:1.7rem;margin:2.2rem 0 .8rem;scroll-margin-top:84px}
.article-body h2::before{content:"";display:block;width:46px;height:4px;border-radius:2px;background:var(--banana);margin-bottom:.7rem}
.article-body a{color:var(--moss);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.article-body ul{padding-left:1.1rem}.article-body li{margin:.4rem 0}
.article-body table{width:100%;border-collapse:collapse;margin:1.4rem 0;font-size:.95rem;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.article-body th{background:var(--jungle);color:#fdf7e9;text-align:left;padding:12px 14px;font-family:var(--body);font-size:.82rem;text-transform:uppercase;letter-spacing:.06em}
.article-body td{padding:12px 14px;border-top:1px solid var(--line);vertical-align:top}
.inbody{margin:1.8rem 0}.inbody .ph{aspect-ratio:4/3;border-radius:var(--radius)}.inbody figcaption{font-size:.82rem;color:#6a7a64;margin-top:.5rem;text-align:center}
.faq{margin-top:30px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:16px;padding:4px 20px;margin-bottom:12px;box-shadow:var(--shadow-sm)}
.faq summary{font-family:var(--display);font-weight:600;font-size:1.12rem;padding:14px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--amber);font-size:1.5rem;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 16px;margin:0;color:#3a4a3e}
.sources{background:var(--paper-2);border-radius:var(--radius);padding:24px;margin-top:30px;font-size:.92rem}
.sources h3{font-size:1.1rem;margin-bottom:.8rem}.sources ul{margin:0;padding-left:1.1rem}.sources li{margin:.4rem 0;color:#4a5a48}
.sources a{color:var(--moss);text-decoration:underline;text-underline-offset:2px;font-weight:600;word-break:break-word}
.sources a:hover{color:var(--coral)}
.authorbox{display:flex;gap:18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-top:30px;box-shadow:var(--shadow-sm)}
.authorbox .av{width:64px;height:64px;border-radius:18px;flex:none;background:conic-gradient(from 200deg,var(--banana),var(--amber),var(--coral),var(--moss),var(--banana))}
.authorbox h4{font-size:1.05rem}.authorbox p{font-size:.9rem;color:#56654f;margin:.3rem 0 0}
.related{margin-top:36px}
.rgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.rcard{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);transition:.3s}
.rcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.rcard .bd{padding:14px}.rcard h4{font-size:1rem}.rcard .cat{font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--coral)}
aside .card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:20px}
aside h4{font-family:var(--body);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--amber);margin:0 0 .7rem}
.toc{list-style:none;padding:0;margin:0;display:grid;gap:.5rem;font-size:.9rem}
.toc a{text-decoration:none;color:#3a4a3e;border-left:2px solid var(--line);padding-left:.7rem}
.toc a:hover{border-color:var(--banana);color:var(--ink)}
.sticky{position:sticky;top:90px}
.disc{font-size:.82rem;color:#6a7a64;border-top:1px solid var(--line);margin-top:30px;padding-top:16px;font-style:italic}
@media(max-width:900px){.layout{grid-template-columns:1fr}.rgrid{grid-template-columns:1fr}}
