/* ============================================================
   SILLY RAT COLLECTION — refined, editorial storefront
   Neutral cream + black · elegant serif · minimal
   (matches the ArtDesignByNora banner aesthetic)
   ============================================================ */

:root{
  --cream:#f4efe6;
  --cream-2:#efe8dc;
  --paper:#ffffff;
  --ink:#1b1916;
  --ink-soft:#3a352e;
  --muted:#7c7367;
  --line:#e0d7c8;
  --line-strong:#c9bfae;
  --accent:#1b1916;
  --radius:10px;
  --shadow:0 10px 30px rgba(27,25,22,.06);
  --serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:'Jost', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --track:.18em;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.label{
  font-family:var(--sans);text-transform:uppercase;letter-spacing:var(--track);
  font-size:.72rem;font-weight:500;color:var(--muted);
}

/* ---------- Top nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(244,239,230,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:700;font-size:1.25rem;letter-spacing:.01em}
.brand .rat{font-size:1.35rem;filter:grayscale(1)}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;font-weight:500;
  padding:10px 16px;border-radius:6px;transition:.18s;color:var(--ink-soft);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a.cta{
  background:var(--ink);color:var(--cream);border:1px solid var(--ink);
  letter-spacing:.14em;
}
.nav-links a.cta:hover{background:#000;color:#fff}
.burger{display:none;font-size:1.5rem;background:none;border:none;cursor:pointer;color:var(--ink)}

/* ---------- Hero / banner ---------- */
.hero{background:var(--cream)}
.banner-link{display:block;background:var(--cream-2)}
.banner-photo{width:100%;height:auto;display:block}
/* Fallback shown only if the banner image is missing */
.hero-fallback{display:none}
.hero.no-banner .banner-link{display:none}
.hero.no-banner .hero-fallback{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:90px 24px;
  background:var(--cream-2);border-bottom:1px solid var(--line);
}
.hero-fallback .kicker{margin-bottom:14px}
.hero-fallback h1{font-family:var(--serif);font-weight:700;font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.02}
.hero-fallback p{color:var(--muted);margin-top:12px;max-width:560px}

/* ---------- Trust bar (real badges) ---------- */
.trustbar{
  background:var(--ink);color:var(--cream);
}
.trustbar .wrap{
  display:flex;align-items:center;justify-content:center;gap:44px;flex-wrap:wrap;
  padding:16px 28px;
}
.trustbar span{
  text-transform:uppercase;letter-spacing:var(--track);font-size:.74rem;font-weight:500;
  display:flex;align-items:center;gap:9px;color:#e9e2d5;
}
.trustbar span b{font-weight:600;color:#fff}

/* ---------- Section headers ---------- */
.section{padding:74px 0}
.section .kicker{text-align:center;display:block;margin-bottom:12px}
.section h2{
  font-family:var(--serif);font-weight:700;font-size:clamp(1.9rem,4vw,2.9rem);
  text-align:center;line-height:1.1;
}
.section .sub{text-align:center;color:var(--muted);margin:12px auto 44px;max-width:560px}

/* ---------- Product grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:30px}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:.25s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.card .thumb{
  aspect-ratio:4/5;background:var(--cream-2);display:flex;align-items:center;justify-content:center;
  font-size:3.6rem;position:relative;border-bottom:1px solid var(--line);
}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .tag{
  position:absolute;top:14px;left:14px;background:var(--ink);color:var(--cream);
  text-transform:uppercase;letter-spacing:.12em;font-size:.62rem;font-weight:500;
  padding:5px 11px;border-radius:3px;
}
.card .body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.card h3{font-family:var(--serif);font-weight:600;font-size:1.18rem;line-height:1.22;margin-bottom:8px}
.card .price{font-size:.95rem;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:14px;font-weight:500}
.card ul.feat{list-style:none;margin:0 0 20px;font-size:.86rem;color:var(--muted)}
.card ul.feat li{padding-left:16px;position:relative;margin-bottom:5px}
.card ul.feat li::before{content:"—";position:absolute;left:0;color:var(--line-strong)}
.buy{
  margin-top:auto;display:block;text-align:center;
  background:var(--ink);color:var(--cream);
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:500;
  padding:14px;border-radius:6px;transition:.18s;border:1px solid var(--ink);
}
.buy:hover{background:#000;color:#fff}

/* ---------- About block ---------- */
.about-wrap{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:56px;max-width:820px;margin:0 auto;
}
.about-wrap .kicker{text-align:center;display:block;margin-bottom:14px}
.about-wrap p{margin-bottom:18px;font-size:1.04rem;color:var(--ink-soft)}
.about-wrap p:first-of-type{font-family:var(--serif);font-size:1.35rem;line-height:1.4;color:var(--ink)}

/* ---------- Buttons (shared) ---------- */
.btn-ghost{
  display:inline-block;text-align:center;border:1px solid var(--ink);color:var(--ink);
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:500;
  padding:14px 30px;border-radius:6px;transition:.18s;
}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-solid{
  display:inline-block;text-align:center;background:var(--ink);color:var(--cream);
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:500;
  padding:14px 30px;border-radius:6px;transition:.18s;border:1px solid var(--ink);
}
.btn-solid:hover{background:#000;color:#fff}

/* ---------- Contact form ---------- */
.form-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:44px;max-width:600px;margin:0 auto;
}
.form-card label{display:block;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:500;color:var(--muted);margin:18px 0 8px}
.form-card input,.form-card textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line-strong);border-radius:6px;
  font-family:var(--sans);font-size:.98rem;background:var(--cream);color:var(--ink);transition:.15s;
}
.form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--ink);background:#fff}
.form-card textarea{min-height:140px;resize:vertical}
.form-card button{
  margin-top:24px;width:100%;background:var(--ink);color:var(--cream);border:1px solid var(--ink);
  text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;font-weight:500;padding:15px;border-radius:6px;
  cursor:pointer;transition:.18s;
}
.form-card button:hover{background:#000;color:#fff}
.form-note{text-align:center;margin-top:18px;color:var(--muted);font-size:.9rem}
.contact-alt{text-align:center;margin-top:28px;color:var(--muted);font-size:.92rem}
.contact-alt a{color:var(--ink);border-bottom:1px solid var(--line-strong)}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:30px}
.post-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:.25s;
}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.post-card .pc-hero{font-size:2.6rem;padding:34px;text-align:center;border-bottom:1px solid var(--line);background:var(--cream-2);filter:grayscale(1)}
.post-card .pc-body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-card .pc-date{text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;font-weight:500;color:var(--muted)}
.post-card h3{font-family:var(--serif);font-weight:600;font-size:1.24rem;margin:10px 0 10px;line-height:1.25}
.post-card p{font-size:.9rem;color:var(--muted);margin-bottom:18px}
.post-card .read{margin-top:auto;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:500;color:var(--ink);border-bottom:1px solid var(--ink);align-self:flex-start;padding-bottom:2px}

/* ---------- Single article ---------- */
.article{max-width:760px;margin:0 auto}
.article .art-hero{font-size:3.4rem;text-align:center;padding:20px 0 26px;filter:grayscale(1)}
.article .art-date{text-align:center;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:500;color:var(--muted);display:block}
.article h1{font-family:var(--serif);font-weight:700;font-size:clamp(2rem,4.4vw,3rem);margin:14px 0 8px;line-height:1.12;text-align:center}
.article .art-rule{width:54px;height:1px;background:var(--line-strong);margin:26px auto 34px}
.article .art-body h2{font-family:var(--serif);font-weight:600;font-size:1.55rem;margin:34px 0 12px}
.article .art-body p{margin-bottom:18px;font-size:1.08rem;color:var(--ink-soft)}
.article .art-body ul{margin:0 0 18px 22px;color:var(--ink-soft)}
.article .art-body li{margin-bottom:8px}
.article .art-body strong{color:var(--ink)}
.art-cta{
  display:block;text-align:center;margin:40px 0 0;background:var(--ink);color:var(--cream);
  text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;font-weight:500;
  padding:16px;border-radius:6px;transition:.18s;
}
.art-cta:hover{background:#000;color:#fff}
.back-link{display:inline-block;margin-bottom:8px;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:500;color:var(--muted)}
.back-link:hover{color:var(--ink)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#cfc7ba;margin-top:20px}
.footer .wrap{display:grid;grid-template-columns:1.6fr 1fr 1.2fr;gap:44px;padding:64px 28px 40px}
.footer h4{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:500;color:#fff;margin-bottom:16px}
.footer a{display:block;padding:5px 0;color:#cfc7ba;transition:.15s;font-size:.9rem}
.footer a:hover{color:#fff}
.footer .blog-list{columns:2;font-size:.84rem}
.footer .brand-foot{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.footer .brand-foot .rat{filter:grayscale(1)}
.footer .foot-note{opacity:.85;font-size:.9rem;margin-top:6px;line-height:1.6}
.footer .foot-social{margin-top:14px}
.footer .foot-social a{display:inline-block;margin-right:18px;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:2px}
.footer-bottom{text-align:center;padding:22px;border-top:1px solid rgba(255,255,255,.12);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#9a9184}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .nav-links{
    position:absolute;top:76px;left:0;right:0;background:var(--cream);
    flex-direction:column;gap:0;border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .28s;
  }
  .nav-links.open{max-height:360px;padding:10px 0}
  .nav-links a{width:calc(100% - 40px);margin:2px 20px;text-align:center;padding:13px}
  .burger{display:block}
  .trustbar .wrap{gap:14px 26px}
  .footer .wrap{grid-template-columns:1fr;gap:34px}
  .footer .blog-list{columns:1}
  .about-wrap{padding:34px}
}
