/* StitchVault — jewel-toned editorial knitting reference */
:root{
  --teal-900:#0f3733;
  --teal-800:#164842;
  --teal-700:#1d4e4a;
  --teal-600:#2a6b62;
  --teal-500:#3f8a7d;
  --rose-700:#9a4a4a;
  --rose-500:#c98a8a;
  --rose-300:#e8c8c8;
  --gold:#b88a3e;
  --gold-soft:#d6b372;
  --cream:#f7efde;
  --cream-2:#efe4cb;
  --cream-3:#e7d8b6;
  --paper:#fdf9f0;
  --ink:#1a2a26;
  --ink-2:#3b4f48;
  --muted:#7a8881;
  --line:#dccdaa;
  --line-soft:#e8dcc0;
  --shadow-sm: 0 1px 0 rgba(15,55,51,.05), 0 6px 16px -10px rgba(15,55,51,.18);
  --shadow-md: 0 1px 0 rgba(15,55,51,.05), 0 16px 36px -22px rgba(15,55,51,.32);
  --radius: 14px;
  --maxw: 1180px;
  --serif: "Cormorant Garamond", "Iowan Old Style", "Apple Garamond", Georgia, "Times New Roman", serif;
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
}
@font-face{font-family:"Cormorant Garamond";font-weight:400;font-style:normal;src:local("Cormorant Garamond"),local("Iowan Old Style"),local("Georgia");font-display:swap}
@font-face{font-family:"Inter";font-weight:400;font-style:normal;src:local("Inter"),local("Helvetica Neue"),local("Arial");font-display:swap}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background-color:var(--cream);
  background-image:url("/assets/img/stitch-grid.svg");
  background-repeat:repeat;
  background-size:48px 48px;
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--teal-700);text-decoration:none;text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{text-decoration:underline;color:var(--teal-800)}

h1,h2,h3,h4{font-family:var(--serif);color:var(--teal-900);letter-spacing:-0.005em;line-height:1.15;margin:0 0 .5rem;font-weight:600}
h1{font-size:clamp(2.2rem, 4.4vw, 3.6rem)}
h1 em{font-style:italic;color:var(--rose-700);font-weight:500}
h2{font-size:clamp(1.55rem, 2.6vw, 2.15rem)}
h3{font-size:1.22rem}
h4{font-size:1.03rem;color:var(--teal-800)}
p{margin:0 0 1rem;color:var(--ink-2)}
.lead{font-size:1.18rem;color:var(--ink);font-family:var(--serif);font-weight:400;line-height:1.55}
.muted{color:var(--muted)}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--rose-700);font-weight:600}

.container{max-width:var(--maxw);margin:0 auto;padding:0 1.4rem}
section{padding:3.5rem 0}
section.alt{background:var(--cream-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
section.deep{background:var(--teal-900);color:#e8e0c9}
section.deep h1,section.deep h2,section.deep h3{color:#fbf6e7}
section.deep p{color:#cfd9c9}
.section-head{max-width:62ch;margin-bottom:2rem}

/* Header */
.site-header{background:var(--cream);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;backdrop-filter:saturate(1.1)}
.header-inner{display:flex;align-items:center;gap:1.5rem;padding:.85rem 1.4rem;flex-wrap:wrap}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;color:var(--teal-900)}
.brand:hover{text-decoration:none}
.brand-mark{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:9px;background:var(--teal-700);color:var(--cream);font-family:var(--serif);font-size:.95rem;letter-spacing:.04em;font-weight:700;box-shadow:inset 0 -2px 0 rgba(0,0,0,.15)}
.brand-name{font-family:var(--serif);font-size:1.32rem;font-weight:600;letter-spacing:.005em}
.primary-nav{display:flex;gap:1.25rem;flex-wrap:wrap;flex:1;justify-content:center}
.primary-nav a{color:var(--ink-2);font-size:.95rem;font-weight:500}
.primary-nav a:hover{color:var(--teal-700);text-decoration:none}
.header-search{display:flex;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.35rem .35rem .35rem 1rem;min-width:240px}
.header-search input{flex:1;border:none;background:transparent;font:inherit;color:var(--ink);outline:none}
.header-search button{border:none;background:var(--teal-700);color:#fff;border-radius:999px;padding:.45rem .85rem;font:inherit;font-size:.85rem;cursor:pointer}
.header-search button:hover{background:var(--teal-800)}
@media (max-width:760px){.primary-nav{order:3;width:100%;justify-content:flex-start}.header-search{width:100%}}

/* Hero */
.hero{padding:4.5rem 0 3.5rem;border-bottom:1px solid var(--line);background:linear-gradient(180deg, var(--cream) 0%, var(--cream) 60%, var(--paper) 100%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
@media (max-width:880px){.hero-grid{grid-template-columns:1fr}}
.hero h1{margin-bottom:1rem}
.hero p.lead{max-width:54ch;color:var(--ink-2)}
.hero-search{display:flex;align-items:center;gap:.5rem;margin-top:1.6rem;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.45rem .55rem .45rem 1.3rem;box-shadow:var(--shadow-sm);max-width:540px}
.hero-search input{flex:1;border:none;background:transparent;font:inherit;font-size:1.02rem;color:var(--ink);outline:none}
.hero-search input::placeholder{color:var(--muted)}
.hero-search button{border:none;background:var(--teal-700);color:#fff;border-radius:999px;padding:.65rem 1.25rem;font:inherit;font-weight:600;cursor:pointer}
.hero-search button:hover{background:var(--teal-800)}
.hero-popular{margin-top:.8rem;font-size:.85rem;color:var(--muted)}
.hero-popular a{margin-right:.6rem;color:var(--teal-700);font-weight:500}
.hero-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.4rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.3rem;border-radius:999px;font-family:var(--sans);font-weight:600;font-size:.95rem;border:1px solid transparent;cursor:pointer;transition:.18s}
.btn-primary{background:var(--teal-700);color:#fff}
.btn-primary:hover{background:var(--teal-800);text-decoration:none}
.btn-ghost{background:transparent;color:var(--teal-800);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--teal-700);text-decoration:none;background:var(--paper)}
.hero-art{position:relative}
.hero-art img{border-radius:18px;box-shadow:var(--shadow-md);border:1px solid var(--line)}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2.4rem;padding-top:1.6rem;border-top:1px dashed var(--line)}
.hero-stats div{text-align:left}
.hero-stats strong{display:block;font-family:var(--serif);font-size:1.7rem;color:var(--teal-700);font-weight:600}
.hero-stats span{display:block;font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}

/* Featured cards */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media (max-width:880px){.feat-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.feat-grid{grid-template-columns:1fr}}
.feat-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;display:block;color:var(--ink);box-shadow:var(--shadow-sm);transition:.2s}
.feat-card:hover{transform:translateY(-2px);border-color:var(--teal-600);box-shadow:var(--shadow-md);text-decoration:none}
.feat-card .feat-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--rose-700);font-weight:600;margin-bottom:.5rem}
.feat-card h3{margin-bottom:.4rem}
.feat-card .feat-meta{font-size:.82rem;color:var(--muted);margin-top:.6rem;display:flex;gap:.4rem;flex-wrap:wrap}
.feat-card .feat-meta span{background:var(--cream-2);padding:.18rem .55rem;border-radius:999px;color:var(--teal-800)}

/* Category & list grids */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:880px){.cat-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.cat-grid{grid-template-columns:1fr}}
.cat-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;display:block;color:var(--ink);transition:.18s}
.cat-card:hover{border-color:var(--teal-600);transform:translateY(-1px);text-decoration:none;box-shadow:var(--shadow-sm)}
.cat-card h3{margin-bottom:.3rem;color:var(--teal-800)}
.cat-card p{margin:.3rem 0 .7rem;font-size:.95rem}
.cat-card .count{font-family:var(--sans);color:var(--muted);font-size:.85rem;font-weight:500}

/* Pattern grid (also stitch grid) */
.pattern-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:880px){.pattern-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.pattern-grid{grid-template-columns:1fr}}
.pattern-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;display:block;color:var(--ink);transition:.18s}
.pattern-card:hover{border-color:var(--teal-600);text-decoration:none;box-shadow:var(--shadow-sm)}
.pattern-card h3{font-size:1.06rem;margin-bottom:.35rem;color:var(--teal-800)}
.pattern-card .meta{font-size:.78rem;color:var(--muted);display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem}
.pattern-card .meta span{background:var(--cream-2);padding:.18rem .55rem;border-radius:999px;color:var(--teal-800)}

/* Detail layouts (with sidebar) */
.detail{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:2.5rem;padding:2.5rem 0}
@media (max-width:980px){.detail{grid-template-columns:1fr}}
.detail-with-spec{display:grid;grid-template-columns:minmax(0,1fr) 260px 280px;gap:2rem;padding:2.5rem 0}
@media (max-width:1080px){.detail-with-spec{grid-template-columns:minmax(0,1fr) 280px}}
@media (max-width:780px){.detail-with-spec{grid-template-columns:1fr}}
.detail h1{margin-bottom:.4rem}
.detail .byline{color:var(--muted);font-size:.95rem;margin-bottom:1.5rem}
.detail .article > section{padding:1.6rem 0;border-top:1px solid var(--line-soft)}
.detail .article > section:first-of-type{border-top:0}
.detail h2{font-size:1.4rem;margin-bottom:.6rem}

.spec-card{position:sticky;top:90px;align-self:start;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem;font-family:var(--sans);box-shadow:var(--shadow-sm)}
.spec-card .spec-eyebrow{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-700);font-weight:600;margin-bottom:.4rem}
.spec-card h2{font-family:var(--serif);font-size:1.25rem;margin-bottom:.8rem;color:var(--teal-800)}
.spec-card dt{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;margin-top:.8rem;font-weight:600}
.spec-card dt:first-of-type{margin-top:0}
.spec-card dd{margin:0 0 .15rem;color:var(--ink);font-weight:600;font-size:.95rem}
.skill-badge{display:inline-block;padding:.25rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600;background:var(--rose-300);color:var(--rose-700);text-transform:uppercase;letter-spacing:.06em}
.skill-badge.beginner{background:#dceee2;color:#1d6549}
.skill-badge.easy{background:#dfeae6;color:var(--teal-700)}
.skill-badge.intermediate{background:#f3e1c7;color:#86601a}
.skill-badge.advanced{background:#ead4d4;color:var(--rose-700)}

/* Stitch chart */
.chart-wrap{margin:1.2rem 0;padding:1rem;background:#fbf6ec;border:1px solid var(--line);border-radius:12px;overflow-x:auto}
.stitch-chart{max-width:100%;height:auto;display:block;margin:0 auto}
.chart-legend{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;margin-top:.8rem;font-size:.85rem}
.chart-legend .lg-item{display:flex;align-items:center;gap:.5rem;background:var(--paper);border:1px solid var(--line-soft);border-radius:8px;padding:.35rem .6rem}
.chart-legend .lg-cell{width:22px;height:22px;display:inline-grid;place-items:center;border:1px solid #bba274;font-family:var(--sans);font-size:.85rem}

/* Written rows + abbreviations */
.row-list{counter-reset:row;list-style:none;padding:0;margin:0}
.row-list li{padding:.55rem .8rem;border-left:3px solid var(--teal-600);background:var(--paper);border-radius:6px;margin:.45rem 0;font-family:var(--sans);font-size:.95rem;color:var(--ink-2)}
.abbrev-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.4rem;list-style:none;padding:0;margin:.6rem 0}
.abbrev-list li{font-family:var(--sans);font-size:.88rem;color:var(--ink-2);padding:.3rem 0;border-bottom:1px dotted var(--line)}
.abbrev-list b{color:var(--teal-800);font-family:var(--sans);margin-right:.4rem}
.tip-list{list-style:none;padding:0;margin:.6rem 0}
.tip-list li{padding:.6rem .8rem .6rem 2rem;background:var(--cream);border:1px solid var(--line-soft);border-radius:8px;margin:.45rem 0;position:relative;font-size:.95rem}
.tip-list li::before{content:"✦";position:absolute;left:.7rem;top:.55rem;color:var(--gold);font-size:1rem}

/* Sidebar (PBN block) */
.sidebar{display:flex;flex-direction:column;gap:1.4rem}
.pbn-block{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow-sm);position:sticky;top:90px}
.pbn-eyebrow{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-700);font-weight:700;margin-bottom:.35rem}
.pbn-heading{font-family:var(--serif);font-size:1.18rem;color:var(--teal-800);margin-bottom:.9rem;border-bottom:1px solid var(--line-soft);padding-bottom:.7rem}
.pbn-list{list-style:none;padding:0;margin:0}
.pbn-item{padding:.7rem 0;border-bottom:1px dotted var(--line)}
.pbn-item:last-child{border-bottom:0}
.pbn-link{display:block;color:var(--ink);text-decoration:none}
.pbn-link:hover{color:var(--teal-700)}
.pbn-link:hover .pbn-title{text-decoration:underline}
.pbn-title{display:block;font-family:var(--serif);font-size:1rem;line-height:1.35;color:var(--teal-900);font-weight:500;margin-bottom:.15rem}
.pbn-kicker{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:500}
.pbn-note{margin-top:.9rem;font-size:.78rem;color:var(--muted);font-style:italic}
.pbn-inline{margin:1.4rem 0;padding:.8rem 1rem;background:var(--cream-2);border-left:3px solid var(--gold);border-radius:0 8px 8px 0;font-size:.95rem;color:var(--ink-2)}
.pbn-inline-kicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--rose-700);font-weight:700;margin-right:.4rem}
.pbn-inline-link{color:var(--teal-700);font-weight:500}

/* Search results */
.search-form{display:flex;gap:.5rem;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.45rem .5rem .45rem 1.2rem;max-width:600px;margin:1.5rem auto;box-shadow:var(--shadow-sm)}
.search-form input{flex:1;border:none;background:transparent;font:inherit;font-size:1rem;outline:none}
.search-form button{border:none;background:var(--teal-700);color:#fff;border-radius:999px;padding:.6rem 1.2rem;font:inherit;font-weight:600;cursor:pointer}
.search-section{margin:2rem 0}
.search-section h2{font-size:1.25rem;border-bottom:1px solid var(--line);padding-bottom:.5rem;margin-bottom:1rem;color:var(--teal-800)}
.search-empty{padding:2.5rem;text-align:center;background:var(--paper);border:1px dashed var(--line);border-radius:var(--radius)}

/* Breadcrumbs */
.crumbs{font-size:.85rem;color:var(--muted);padding:1rem 0;border-bottom:1px solid var(--line-soft)}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--teal-700)}
.crumbs .sep{margin:0 .35rem;opacity:.6}

/* Pagination */
.pagination{display:flex;gap:.4rem;justify-content:center;padding:2rem 0;flex-wrap:wrap;font-family:var(--sans)}
.pagination a,.pagination span{padding:.55rem .85rem;border:1px solid var(--line);border-radius:8px;color:var(--ink-2);background:var(--paper);font-size:.9rem;font-weight:500}
.pagination a:hover{background:var(--cream-2);text-decoration:none;border-color:var(--teal-600)}
.pagination span.current{background:var(--teal-700);color:#fff;border-color:var(--teal-700)}

/* Yarn / needle / technique cards */
.ref-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media (max-width:680px){.ref-grid{grid-template-columns:1fr}}
.ref-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;color:var(--ink);transition:.18s;display:block}
.ref-card:hover{border-color:var(--teal-600);text-decoration:none;box-shadow:var(--shadow-sm)}
.ref-card h3{color:var(--teal-800);margin-bottom:.4rem}
.ref-card .ref-meta{font-size:.85rem;color:var(--muted);margin-top:.6rem;display:flex;gap:.5rem;flex-wrap:wrap}
.ref-card .ref-meta span{background:var(--cream-2);padding:.2rem .55rem;border-radius:999px;color:var(--teal-800)}

/* Tables */
.ref-table{width:100%;border-collapse:collapse;margin:1rem 0;background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden;font-family:var(--sans);font-size:.92rem}
.ref-table th{background:var(--cream-2);text-align:left;padding:.65rem 1rem;color:var(--teal-800);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em}
.ref-table td{padding:.55rem 1rem;border-top:1px solid var(--line-soft);color:var(--ink-2)}
.ref-table tr:hover td{background:var(--cream)}

/* Footer */
.site-footer{background:var(--teal-900);color:#cdd6c9;padding:3.5rem 0 1.6rem;margin-top:4rem;background-image:linear-gradient(180deg, var(--teal-900) 0%, var(--teal-800) 100%)}
.site-footer h4{color:var(--cream);font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;font-family:var(--sans);margin-bottom:.7rem}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.3rem 0}
.site-footer a{color:#cdd6c9;font-size:.92rem}
.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2rem}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-tag{color:#9caaa3;font-size:.92rem;max-width:32ch;margin-top:.6rem}
.brand-footer .brand-mark{background:var(--cream);color:var(--teal-900)}
.brand-footer .brand-name{color:var(--cream)}
.footer-meta{padding-top:1.4rem;border-top:1px solid #1f4f49;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.footer-meta small{color:#9caaa3;font-size:.85rem}
.footer-pbn{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.5rem;font-size:.78rem}
.footer-pbn a{color:#9caaa3;font-style:italic}
.footer-pbn a:hover{color:#fff}

/* Prose */
.prose{max-width:68ch}
.prose p,.prose li{font-size:1.04rem;color:var(--ink-2);line-height:1.7}
.prose h2{margin-top:2rem;font-size:1.5rem;color:var(--teal-800)}
.prose h3{margin-top:1.4rem;font-size:1.18rem;color:var(--teal-800)}
.prose ul, .prose ol{padding-left:1.4rem}

/* Adslot placeholder */
.adslot{margin:1.4rem 0;padding:.6rem;text-align:center;font-size:.72rem;color:var(--muted);background:rgba(0,0,0,.02);border:1px dashed var(--line);border-radius:8px}

/* Tag pills (used on stitch detail meta) */
.tag-row{display:flex;gap:.4rem;flex-wrap:wrap;margin:.6rem 0 1.2rem}
.tag-pill{display:inline-block;padding:.28rem .7rem;background:var(--cream-2);color:var(--teal-800);border-radius:999px;font-family:var(--sans);font-size:.82rem;text-decoration:none;border:1px solid var(--line-soft)}
.tag-pill:hover{background:var(--teal-700);color:#fff;border-color:var(--teal-700);text-decoration:none}

/* Sub-nav (under hero on index pages) */
.subnav{background:var(--paper);border-bottom:1px solid var(--line);padding:.7rem 0;font-family:var(--sans);font-size:.92rem;position:sticky;top:64px;z-index:20}
.subnav-inner{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.subnav-label{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:600;margin-right:.5rem}
.subnav a{color:var(--ink-2);padding:.25rem .65rem;border-radius:999px;border:1px solid transparent}
.subnav a:hover{background:var(--cream-2);border-color:var(--line);text-decoration:none}
.subnav a.active{background:var(--teal-700);color:#fff}

/* Layout body wrapper that hosts main + global sidebar */
.body-grid{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:2rem;align-items:start}
@media (max-width:980px){.body-grid{grid-template-columns:1fr}}

/* Reqs (homepage) */
.reqs{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:780px}
@media (max-width:680px){.reqs{grid-template-columns:1fr}}
.req{padding:1rem 1.2rem;border:1px dashed var(--line);border-radius:var(--radius);background:rgba(255,250,240,.5)}
.req h4{margin:0 0 .25rem;font-family:var(--sans);font-size:.95rem;color:var(--teal-700)}
.req p{margin:0;color:var(--ink-2);font-size:.95rem}
