/* Rose City Fence & Deck — shared content-page styles */
:root{
  --bone:#efe7d5; --bone-2:#e7dcc6; --paper:#f7f1e4; --paper-2:#fbf6ec;
  --ink:#241b10; --ink-soft:#5d5240; --ink-faint:#8c8169;
  --forest:#1f3327; --forest-deep:#152119; --forest-2:#345039;
  --rust:#bc4525; --rust-2:#d3603a; --ochre:#cf9530;
  --line:#d6c9af; --line-dk:rgba(239,231,213,.16);
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bone);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:999;pointer-events:none;opacity:.04;
  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='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.serif{font-family:'Libre Caslon Display','Georgia',serif;font-weight:400;line-height:1.08;letter-spacing:-.01em}
.mono{font-family:'DM Mono',monospace}
a{color:var(--rust);text-decoration:none;border-bottom:1px solid rgba(188,69,37,.3);transition:border-color .15s}
a:hover{border-color:var(--rust)}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Hanken Grotesk',sans-serif;font-weight:700;font-size:1rem;padding:14px 26px;border:none;cursor:pointer;border-radius:999px;text-decoration:none;border-bottom:none;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.btn-rust{background:var(--rust);color:var(--paper-2);box-shadow:0 1px 0 #8f3219,0 8px 20px rgba(188,69,37,.28)}
.btn-rust:hover{transform:translateY(-2px);background:var(--rust-2);box-shadow:0 1px 0 #8f3219,0 14px 28px rgba(188,69,37,.38);border-bottom:none}
.btn-ink{background:var(--ink);color:var(--bone)}
.kicker{font-family:'DM Mono',monospace;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rust)}
.demo-tag{background:var(--ink);color:var(--ochre);text-align:center;font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:.14em;padding:7px;text-transform:uppercase}

/* NAV */
header.nav{position:sticky;top:0;z-index:60;background:rgba(239,231,213,.86);backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.logo{display:flex;align-items:center;gap:12px;border-bottom:none}
.logo .mark{width:34px;height:34px;background:var(--forest);position:relative;border-radius:3px;flex:0 0 auto}
.logo .mark::before{content:"";position:absolute;inset:6px 5px;background:repeating-linear-gradient(90deg,var(--ochre) 0 3px,transparent 3px 7px)}
.logo .name{font-family:'Libre Caslon Display',serif;font-size:1.32rem;color:var(--forest);line-height:1}
.logo .name small{display:block;font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.2em;color:var(--ink-faint);text-transform:uppercase;margin-top:3px;font-weight:400}
.nav-links{display:flex;gap:28px;align-items:center;font-weight:600;font-size:.93rem}
.nav-links a{color:var(--ink-soft);border-bottom:none;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--rust);transition:width .25s var(--ease)}
.nav-links a:hover{color:var(--ink)}.nav-links a:hover::after{width:100%}
.nav-cta{font-weight:700;color:var(--rust);font-size:.94rem;border-bottom:none}
@media(max-width:880px){.nav-links{display:none}.logo .name small{display:none}}

/* ARTICLE HERO */
.art-hero{padding:60px 0 40px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--paper-2),transparent)}
.crumbs{display:flex;align-items:center;gap:10px;font-family:'DM Mono',monospace;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:22px}
.crumbs a{color:var(--ink-faint);border-bottom:none}
.crumbs a:hover{color:var(--rust)}
.crumbs .sep{color:var(--ink-faint);opacity:.5}
h1.art{font-family:'Libre Caslon Display',serif;font-weight:400;font-size:clamp(2.4rem,5vw,3.8rem);color:var(--forest);line-height:1.06;margin-bottom:18px;letter-spacing:-.01em;max-width:22ch}
h1.art em{font-style:italic;color:var(--rust)}
.deck{font-size:1.2rem;color:var(--ink-soft);max-width:60ch;margin-bottom:22px}
.meta{display:flex;flex-wrap:wrap;gap:14px;font-family:'DM Mono',monospace;font-size:.78rem;color:var(--ink-faint);letter-spacing:.04em}
.meta span{display:inline-flex;align-items:center;gap:5px}

/* ARTICLE BODY */
article.body{padding:54px 0 30px;max-width:760px;margin:0 auto}
article.body h2{font-family:'Libre Caslon Display',serif;font-weight:400;font-size:2.05rem;color:var(--forest);line-height:1.12;margin:54px 0 16px;letter-spacing:-.01em}
article.body h2 em{font-style:italic;color:var(--rust)}
article.body h2:first-child{margin-top:0}
article.body h3{font-family:'Libre Caslon Display',serif;font-weight:500;font-size:1.42rem;color:var(--forest);margin:36px 0 12px;line-height:1.2}
article.body p{font-size:1.07rem;color:var(--ink);margin-bottom:18px;line-height:1.72}
article.body .lede{font-size:1.22rem;color:var(--ink);margin-bottom:32px;line-height:1.6;font-weight:500;border-left:4px solid var(--rust);padding:6px 0 6px 20px;background:linear-gradient(90deg,rgba(188,69,37,.04),transparent)}
article.body ul,article.body ol{margin:0 0 22px 26px;color:var(--ink)}
article.body li{margin-bottom:8px;font-size:1.05rem;line-height:1.65}
article.body strong{color:var(--forest-deep)}
article.body .cite{font-family:'DM Mono',monospace;font-size:.86rem;color:var(--rust);background:rgba(188,69,37,.07);padding:1px 7px;border-radius:3px;white-space:nowrap}
article.body blockquote{border-left:4px solid var(--ochre);padding:14px 22px;margin:24px 0;background:rgba(207,149,48,.07);font-family:'Libre Caslon Display',serif;font-style:italic;font-size:1.15rem;color:var(--ink);border-radius:0 3px 3px 0}
article.body blockquote .src{display:block;font-family:'DM Mono',monospace;font-style:normal;font-size:.78rem;color:var(--ink-faint);margin-top:8px;letter-spacing:.02em}

/* TABLES */
.tbl-wrap{overflow-x:auto;margin:26px 0;border:1px solid var(--line);border-radius:6px;background:var(--paper-2)}
table.data{width:100%;border-collapse:collapse;font-size:.97rem}
table.data th{background:var(--forest);color:var(--bone);text-align:left;padding:13px 16px;font-weight:600;font-size:.86rem;letter-spacing:.04em;border-right:1px solid var(--forest-deep)}
table.data th:last-child{border-right:none}
table.data td{padding:12px 16px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);color:var(--ink);vertical-align:top}
table.data td:last-child{border-right:none}
table.data tr:last-child td{border-bottom:none}
table.data tr:nth-child(even) td{background:rgba(207,149,48,.05)}
table.data .pr{font-family:'DM Mono',monospace;color:var(--rust);font-weight:600}

/* CALLOUTS */
.callout{display:flex;gap:14px;padding:18px 22px;border-radius:6px;margin:26px 0;border:1px solid var(--line);background:var(--paper-2)}
.callout .ic{flex:0 0 auto;font-size:1.3rem;line-height:1.4}
.callout p{margin:0 !important;font-size:1rem !important}
.callout-warn{border-color:#e7cf91;background:#fff6df}
.callout-warn .ic{color:#a17321}

/* INLINE CTA */
.inline-cta{margin:38px 0;padding:30px 32px;border-radius:8px;background:var(--forest);color:var(--bone);text-align:center}
.inline-cta h3{font-family:'Libre Caslon Display',serif;font-weight:400;font-size:1.5rem;color:var(--bone);margin-bottom:10px}
.inline-cta p{color:rgba(239,231,213,.82);font-size:1rem;margin-bottom:18px}
.inline-cta .btn-rust{background:var(--rust)}

/* FAQ */
.faq{max-width:760px;margin:36px auto 0;padding:0 0 20px}
.faq-h{font-family:'Libre Caslon Display',serif;font-weight:400;font-size:1.9rem;color:var(--forest);margin-bottom:20px}
.faq details{border-bottom:1px solid var(--line);padding:0}
.faq summary{padding:20px 4px;font-family:'Libre Caslon Display',serif;font-weight:500;font-size:1.16rem;color:var(--forest);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{font-family:'Hanken Grotesk';font-size:1.5rem;color:var(--rust);font-weight:400;transition:transform .25s var(--ease)}
.faq details[open] summary .pm{transform:rotate(45deg)}
.faq details p{padding:0 4px 22px;color:var(--ink-soft);font-size:1rem;max-width:64ch}

/* RELATED */
.related{max-width:1180px;margin:0 auto;padding:60px 28px 30px}
.related h2{font-family:'Libre Caslon Display',serif;font-weight:400;font-size:1.8rem;color:var(--forest);margin-bottom:24px}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rel-card{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:22px 24px;transition:.2s var(--ease);border-bottom:none}
.rel-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(20,42,30,.08);border-bottom:none}
.rel-card .tag{font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rust);margin-bottom:8px;display:block}
.rel-card h3{font-family:'Libre Caslon Display',serif;font-weight:500;font-size:1.18rem;color:var(--forest);margin-bottom:6px;line-height:1.25}
.rel-card p{color:var(--ink-soft);font-size:.93rem;margin:0}
@media(max-width:760px){.rel-grid{grid-template-columns:1fr}}

/* CTA BAND */
.cta-band{margin:50px 0 0;padding:64px 32px;text-align:center;background:linear-gradient(135deg,var(--rust),var(--rust-2));color:var(--paper-2);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.16;background-image:repeating-linear-gradient(90deg,#fff 0 1px,transparent 1px 40px)}
.cta-band h2{position:relative;font-family:'Libre Caslon Display',serif;font-weight:400;font-size:clamp(2.1rem,4vw,3rem);color:var(--paper-2);margin-bottom:12px}
.cta-band h2 em{font-style:italic}
.cta-band p{position:relative;font-size:1.12rem;margin-bottom:28px;opacity:.92}
.cta-band .btn{position:relative;background:var(--ink);color:var(--bone)}
.cta-band .btn:hover{background:var(--forest-deep);color:var(--bone)}

/* SLATS */
.slats{height:24px;background:var(--forest);
  -webkit-mask:repeating-linear-gradient(90deg,#000 0 22px,transparent 22px 34px);
  mask:repeating-linear-gradient(90deg,#000 0 22px,transparent 22px 34px)}

/* FOOTER */
footer.site{background:var(--forest-deep);color:rgba(239,231,213,.62);padding:0 0 34px}
.foot-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:34px;padding:60px 0 44px}
footer.site .logo .name{color:var(--bone)}
footer.site .blurb{margin-top:16px;max-width:330px;font-size:.95rem;line-height:1.6}
footer.site h4{font-family:'DM Mono',monospace;color:var(--ochre);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px}
footer.site a{display:block;margin-bottom:9px;font-size:.94rem;transition:color .15s;color:rgba(239,231,213,.7);border-bottom:none}
footer.site a:hover{color:var(--bone);border-bottom:none}
.foot-bottom{border-top:1px solid var(--line-dk);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:'DM Mono',monospace;font-size:.74rem;letter-spacing:.04em}
.foot-bottom a{color:inherit;border-bottom:none}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}
