/*
Theme Name: CannaBrandLab
Theme URI: https://cannabrandlab.com
Author: CannaBrandLab
Author URI: https://cannabrandlab.com
Description: Editorial Engineer (Locomotive-style) theme for CannaBrandLab — cannabis growth agency. Custom CPTs for Services, Case Studies, and Verticals, native WP blog, ACF-powered content blocks.
Version: 1.4.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cannabrandlab
*/

/* BREADCRUMBS */
.breadcrumbs{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--grey-1);padding:20px var(--gutter)}
.breadcrumbs a{color:var(--grey-1)}
.breadcrumbs a:hover{color:var(--oxblood)}
.bc-sep{margin:0 8px;opacity:.4}

:root{
  --paper:#F5F1E8;--paper-warm:#EFE9D8;--carbon:#0A0A0A;--ink-2:#1A1A1A;
  --grey-1:#4B4B4B;--grey-2:#706F6A;--grey-3:#C7C7C0;--border:#E5E5DF;
  --accent:#FFD84D;--oxblood:#8B2E2E;--clay:#D96B3E;
  --f-display:'Fraunces',ui-serif,Georgia,serif;
  --f-body:'Inter',ui-sans-serif,system-ui,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
html,body{background:var(--paper);color:var(--carbon);font-family:var(--f-body);font-size:18px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
img{max-width:100%;display:block;height:auto}

body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.035;mix-blend-mode:multiply;
}

.wrap{max-width:1600px;margin:0 auto;padding:0 48px}
@media(max-width:900px){.wrap{padding:0 24px}}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:10002;padding:24px 48px;display:flex;align-items:center;justify-content:space-between;mix-blend-mode:difference;color:#fff}
@media(max-width:900px){.site-header{padding:20px 24px}}
.logo{font-family:var(--f-display);font-size:22px;font-weight:500;letter-spacing:-.02em}
.logo em{font-style:italic;font-weight:300}
.primary-nav ul{display:flex;gap:40px;list-style:none;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.primary-nav a:hover{color:var(--accent)}
.menu-toggle{display:none;width:40px;height:40px;position:relative;z-index:10002}
.menu-toggle span{position:absolute;left:8px;right:8px;height:1.5px;background:currentColor;transition:transform .4s var(--ease),top .4s var(--ease),opacity .3s}
.menu-toggle span:nth-child(1){top:14px}.menu-toggle span:nth-child(2){top:21px}.menu-toggle span:nth-child(3){top:28px}
body.menu-open .menu-toggle span:nth-child(1){top:21px;transform:rotate(45deg)}
body.menu-open .menu-toggle span:nth-child(2){opacity:0}
body.menu-open .menu-toggle span:nth-child(3){top:21px;transform:rotate(-45deg)}
.mobile-nav{position:fixed;inset:0;background:var(--carbon);color:var(--paper);z-index:10001;display:flex;align-items:center;justify-content:center;transform:translateY(-100%);transition:transform .6s var(--ease);pointer-events:none}
body.menu-open .mobile-nav{transform:translateY(0);pointer-events:auto}
.mobile-nav ul{list-style:none;text-align:center}
.mobile-nav li{margin:20px 0}
.mobile-nav a{font-family:var(--f-display);font-size:clamp(36px,10vw,64px);font-weight:400;letter-spacing:-.02em}
.mobile-nav a:hover{color:var(--accent)}
@media(max-width:900px){.primary-nav ul{display:none}.menu-toggle{display:block}}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:16px;padding:18px 28px;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--carbon);transition:all .4s var(--ease);position:relative;overflow:hidden}
.btn > *{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;background:var(--carbon);transform:translateY(101%);transition:transform .5s var(--ease);z-index:1}
.btn:hover::before{transform:translateY(0)}
.btn:hover{color:var(--paper)}
.btn-primary{background:var(--carbon);color:var(--paper)}
.btn-primary::before{background:var(--accent);transform:translateY(101%)}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary:hover{color:var(--carbon)}
.btn .arrow{display:inline-block;transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* GENERIC SECTIONS */
section{position:relative}
.section-pad{padding:160px 0}
@media(max-width:900px){.section-pad{padding:100px 0}}
.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.label{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-1)}
.eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--oxblood);margin-bottom:48px;display:flex;align-items:center;gap:16px}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--oxblood)}

/* HERO — uses explicit rows to prevent any displacement */
.hero{padding:220px 0 140px;background:var(--paper)}
.hero .wrap{display:flex;flex-direction:column;gap:0}
.hero-eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--oxblood);margin-bottom:48px;display:flex;align-items:center;gap:16px}
.hero-eyebrow::before{content:"";width:32px;height:1px;background:var(--oxblood)}
.hero-title{max-width:83.33%;font-family:var(--f-display);font-size:clamp(52px,9vw,148px);font-weight:400;line-height:.98;letter-spacing:-.035em;font-variation-settings:"opsz" 144,"SOFT" 30;padding-bottom:40px;color:var(--carbon)}
.hero-title em{font-style:italic;font-weight:300;color:var(--oxblood)}
.hero-sub{max-width:66.66%;font-family:var(--f-display);font-size:clamp(20px,2vw,28px);font-weight:300;line-height:1.35;color:var(--grey-1)}
@media(max-width:900px){.hero{padding:160px 0 80px}.hero-title,.hero-sub{max-width:100%}}

/* META STRIP */
.meta-strip{padding:60px 0;background:var(--paper);border-top:1px solid var(--carbon);border-bottom:1px solid var(--carbon)}
.meta-strip .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.meta-strip .meta{grid-column:span 3;font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--grey-1)}
.meta-strip .meta strong{display:block;font-family:var(--f-display);font-size:22px;font-weight:400;color:var(--carbon);margin-top:8px;letter-spacing:-.01em;text-transform:none}
@media(max-width:900px){.meta-strip .meta{grid-column:span 6;margin-bottom:24px}}

/* DARK BAND */
.dark{background:var(--carbon);color:var(--paper);padding:180px 0;border-top:1px solid var(--carbon)}
.dark .wrap{display:flex;flex-direction:column;gap:0}
.dark .section-label{margin-bottom:48px;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--grey-2)}
.dark h2{margin-left:calc(16.66%);max-width:75%;font-family:var(--f-display);font-size:clamp(36px,5.5vw,84px);font-weight:400;line-height:1.02;letter-spacing:-.03em;font-variation-settings:"opsz" 144,"SOFT" 30;margin-bottom:64px}
.dark h2 em{font-style:italic;font-weight:300;color:var(--accent)}
.dark .body{margin-left:calc(16.66%);font-size:18px;line-height:1.65;color:var(--grey-3);max-width:66.66%}
@media(max-width:900px){.dark{padding:120px 0}.dark h2,.dark .body{margin-left:0;max-width:100%}}

/* PAPER WARM BAND */
.band-warm{background:var(--paper-warm);padding:180px 0;border-top:1px solid var(--carbon);border-bottom:1px solid var(--carbon)}
.band-warm .wrap{display:flex;flex-direction:column;gap:0}
.band-warm .section-label{margin-bottom:48px;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--grey-1)}
.band-warm h2{margin-left:calc(16.66%);max-width:75%;font-family:var(--f-display);font-size:clamp(36px,5vw,72px);font-weight:400;line-height:1.05;letter-spacing:-.025em;margin-bottom:64px}
.band-warm h2 em{font-style:italic;font-weight:300;color:var(--clay)}
.band-warm .body{margin-left:calc(16.66%);font-size:18px;line-height:1.65;color:var(--grey-1);max-width:66.66%}
@media(max-width:900px){.band-warm{padding:120px 0}.band-warm h2,.band-warm .body{margin-left:0;max-width:100%}}

/* OXBLOOD STATEMENT */
.statement{padding:200px 0;background:var(--oxblood);color:var(--paper);border-bottom:1px solid var(--carbon)}
.statement .wrap{display:flex;flex-direction:column;gap:0}
.statement .label{margin-bottom:48px;color:rgba(245,241,232,.6)}
.statement p{margin-left:calc(16.66%);max-width:75%;font-family:var(--f-display);font-size:clamp(32px,4.5vw,72px);font-weight:300;line-height:1.1;letter-spacing:-.025em;color:var(--paper)}
.statement p em{font-style:italic;color:#F2C9A0}
.statement p strong{color:var(--accent);font-weight:500;font-style:normal}
@media(max-width:900px){.statement{padding:120px 0}.statement p{margin-left:0;max-width:100%}}

/* GRIDS - CARDS / LISTS */
.card-grid{padding:160px 0;background:var(--paper)}
.card-grid .wrap{display:flex;flex-direction:column;gap:24px}
.card-grid h2{font-family:var(--f-display);font-size:clamp(36px,5.5vw,84px);font-weight:400;line-height:1.02;letter-spacing:-.03em;margin-bottom:80px}
.card-grid h2 em{font-style:italic;font-weight:300;color:var(--oxblood)}
.cards{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--carbon)}
.card{padding:48px 32px 48px 0;border-bottom:1px solid var(--carbon);border-right:1px solid var(--carbon);position:relative;transition:background .3s var(--ease)}
.card:nth-child(3n){border-right:0}
.card:hover{background:var(--paper-warm)}
.card .num{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--oxblood);margin-bottom:20px;display:block;padding-left:32px}
.card h3{font-family:var(--f-display);font-size:clamp(22px,2vw,30px);font-weight:400;letter-spacing:-.015em;margin-bottom:16px;padding:0 32px;line-height:1.15}
.card p{font-size:15px;line-height:1.6;color:var(--grey-1);padding:0 32px;margin-bottom:24px}
.card .more{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--oxblood);padding:0 32px;display:inline-block}
@media(max-width:900px){.card-grid{padding:100px 0}.cards{grid-template-columns:1fr}.card,.card:nth-child(3n){border-right:0}}

/* NUMBERS LEDGER */
.numbers{padding:160px 0;background:var(--paper)}
.numbers .wrap{display:flex;flex-direction:column;gap:0}
.numbers .label{margin-bottom:64px}
.numbers-grid{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:48px 32px}
.n .v{font-family:var(--f-display);font-size:clamp(48px,6vw,104px);font-weight:400;line-height:1;letter-spacing:-.035em;display:block;margin-bottom:16px}
.n .v em{font-style:italic;color:var(--oxblood);font-weight:300}
.n .k{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-1);line-height:1.5}
@media(max-width:900px){.numbers{padding:100px 0}.numbers .label{margin-bottom:40px}.numbers-grid{grid-template-columns:repeat(2,1fr);gap:40px 24px}}

/* CTA BAND */
.cta-section{padding:200px 0;background:var(--accent);color:var(--carbon);border-top:1px solid var(--carbon)}
.cta-section .wrap{display:flex;flex-direction:column;gap:0}
.cta-label{margin-bottom:48px;font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.cta-headline{margin-left:calc(16.66%);max-width:75%;font-family:var(--f-display);font-size:clamp(44px,7vw,116px);font-weight:400;line-height:.95;letter-spacing:-.035em;margin-bottom:56px}
.cta-headline em{font-style:italic;font-weight:300}
.cta-bottom{margin-left:calc(16.66%);display:flex;gap:20px;flex-wrap:wrap}
@media(max-width:900px){.cta-section{padding:120px 0}.cta-headline,.cta-bottom{margin-left:0;max-width:100%}}

/* FOOTER */
.site-footer{background:var(--carbon);color:var(--grey-3);padding:100px 0 40px}
.site-footer .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.foot-brand{grid-column:1/5}
.foot-brand .logo{color:var(--paper);margin-bottom:24px;display:block}
.foot-brand p{font-size:13px;line-height:1.6;color:var(--grey-2);max-width:320px}
.foot-social{display:flex;gap:16px;margin-top:24px}
.social-icon{color:var(--grey-2);transition:color .3s var(--ease)}
.social-icon:hover{color:var(--accent)}
.foot-col{grid-column:span 2}
.foot-col h5{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--paper);margin-bottom:20px}
.foot-col ul{list-style:none;font-size:13px;line-height:2}
.foot-col a:hover{color:var(--accent)}
.foot-legal{grid-column:1/13;border-top:1px solid rgba(255,255,255,.1);margin-top:80px;padding-top:32px;display:flex;justify-content:space-between;font-size:11px;font-family:var(--f-mono);color:var(--grey-2);text-transform:uppercase;letter-spacing:.08em;flex-wrap:wrap;gap:16px}
@media(max-width:900px){.foot-brand{grid-column:1/13;margin-bottom:48px}.foot-col{grid-column:span 6}}

/* CURSOR */
.cursor{position:fixed;top:0;left:0;width:10px;height:10px;background:var(--oxblood);border-radius:50%;pointer-events:none;z-index:10000;transition:width .3s var(--ease),height .3s var(--ease),background .3s var(--ease),border .3s var(--ease);transform:translate(-50%,-50%)}
.cursor.active{width:48px;height:48px;background:transparent;border:1.5px solid var(--oxblood)}
@media(max-width:900px){.cursor{display:none}}

/* BLOG */
.blog-hero{padding:220px 0 100px;background:var(--paper)}
.blog-hero .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.blog-hero h1{grid-column:1/13;font-family:var(--f-display);font-size:clamp(52px,9vw,128px);font-weight:400;line-height:.98;letter-spacing:-.035em;color:var(--carbon)}
.blog-hero h1 em{font-style:italic;font-weight:300;color:var(--oxblood)}
.blog-hero p{grid-column:1/9;font-family:var(--f-display);font-size:clamp(20px,2vw,28px);font-weight:300;line-height:1.35;color:var(--grey-1);margin-top:32px}

/* FEATURED POST — oversized hero card */
.post-featured{padding:60px 0 40px;background:var(--paper)}
.post-featured .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.post-featured article{grid-column:1/13;display:grid;grid-template-columns:repeat(12,1fr);gap:32px;padding:48px 0;border-top:1px solid var(--carbon);border-bottom:1px solid var(--carbon);transition:background .3s var(--ease)}
.post-featured article:hover{background:var(--paper-warm)}
.post-featured .img{grid-column:1/8;aspect-ratio:16/10;overflow:hidden;border:1px solid var(--carbon);background:var(--paper-warm)}
.post-featured .img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.post-featured article:hover .img img{transform:scale(1.04)}
.post-featured .body{grid-column:8/13;display:flex;flex-direction:column;justify-content:center}
.post-featured .tag{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--oxblood);margin-bottom:20px;display:flex;gap:16px}
.post-featured .body h2{font-family:var(--f-display);font-size:clamp(32px,4vw,60px);font-weight:400;letter-spacing:-.025em;line-height:1;margin-bottom:24px}
.post-featured .body h2 em{font-style:italic;color:var(--oxblood);font-weight:300}
.post-featured .body .excerpt{font-family:var(--f-display);font-size:clamp(18px,1.6vw,22px);font-weight:300;line-height:1.4;color:var(--grey-1);margin-bottom:28px}
.post-featured .more{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--oxblood)}
@media(max-width:900px){.post-featured article{padding:32px 0;gap:20px}.post-featured .img,.post-featured .body{grid-column:1/13}.post-featured .img{aspect-ratio:16/9}}

/* MASONRY POST GRID */
.post-list{padding:80px 0 200px;background:var(--paper)}
.post-list .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.post-list-label{grid-column:1/13;padding-bottom:32px;border-bottom:1px solid var(--carbon);margin-bottom:48px;font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-1);display:flex;justify-content:space-between}
.masonry{grid-column:1/13;columns:3;column-gap:32px}
@media(max-width:1200px){.masonry{columns:2}}
@media(max-width:720px){.masonry{columns:1}}
.masonry-item{break-inside:avoid;margin-bottom:56px;display:block;border:1px solid transparent;transition:border-color .4s var(--ease),background .4s var(--ease)}
.masonry-item:hover{border-color:var(--carbon);background:var(--paper-warm)}
.masonry-item .img{aspect-ratio:4/5;overflow:hidden;background:var(--paper-warm);border-bottom:1px solid var(--carbon)}
.masonry-item:nth-child(3n+1) .img{aspect-ratio:4/5}
.masonry-item:nth-child(3n+2) .img{aspect-ratio:4/3}
.masonry-item:nth-child(3n) .img{aspect-ratio:1/1}
.masonry-item .img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);filter:saturate(.9)}
.masonry-item:hover .img img{transform:scale(1.05);filter:saturate(1.05)}
.masonry-item .img.noimg{background:var(--carbon);display:flex;align-items:center;justify-content:center;color:var(--accent);font-family:var(--f-display);font-size:clamp(28px,3vw,52px);font-weight:300;letter-spacing:-.02em;padding:32px;text-align:center;font-style:italic}
.masonry-item .meta{padding:24px 24px 8px;font-family:var(--f-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--oxblood);display:flex;gap:16px;flex-wrap:wrap}
.masonry-item .meta .dot{color:var(--grey-2)}
.masonry-item h2{padding:0 24px 16px;font-family:var(--f-display);font-size:clamp(22px,2vw,30px);font-weight:400;letter-spacing:-.015em;line-height:1.1;color:var(--carbon)}
.masonry-item:hover h2{color:var(--oxblood)}
.masonry-item .excerpt{padding:0 24px 24px;font-size:14px;line-height:1.55;color:var(--grey-1)}
.masonry-item .more{padding:0 24px 24px;display:block;font-family:var(--f-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--oxblood)}

/* Pagination under masonry */
.post-list .pagination{grid-column:1/13;margin-top:24px;justify-content:center}

/* SINGLE POST */
.post-hero{padding:220px 0 80px;background:var(--paper)}
.post-hero .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.post-hero .meta{grid-column:1/13;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--oxblood);margin-bottom:40px;display:flex;gap:24px;flex-wrap:wrap}
.post-hero h1{grid-column:1/11;font-family:var(--f-display);font-size:clamp(40px,6.5vw,100px);font-weight:400;line-height:1;letter-spacing:-.03em;color:var(--carbon)}
.post-hero h1 em{font-style:italic;font-weight:300;color:var(--oxblood)}
.post-hero .excerpt{grid-column:1/9;margin-top:32px;font-family:var(--f-display);font-size:clamp(20px,1.8vw,26px);font-weight:300;line-height:1.4;color:var(--grey-1)}
.post-feature{padding:40px 0 80px;background:var(--paper)}
.post-feature .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.post-feature img{grid-column:1/13;width:100%;aspect-ratio:16/9;object-fit:cover;border:1px solid var(--carbon)}

.post-body{padding:80px 0 160px;background:var(--paper);border-top:1px solid var(--border)}
.post-body .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.post-body .content{grid-column:3/11;font-size:19px;line-height:1.75;color:var(--carbon)}
.post-body .content p{margin-bottom:28px}
.post-body .content h2{font-family:var(--f-display);font-size:clamp(30px,3.5vw,52px);font-weight:400;letter-spacing:-.02em;line-height:1.1;margin:72px 0 24px}
.post-body .content h2 em{font-style:italic;color:var(--oxblood);font-weight:300}
.post-body .content h3{font-family:var(--f-display);font-size:clamp(22px,2.2vw,32px);font-weight:400;letter-spacing:-.015em;margin:48px 0 16px}
.post-body .content blockquote{border-left:3px solid var(--oxblood);padding:16px 0 16px 32px;margin:40px 0;font-family:var(--f-display);font-size:clamp(22px,2.2vw,32px);font-weight:300;line-height:1.35;font-style:italic;color:var(--carbon)}
.post-body .content ul,.post-body .content ol{margin:0 0 28px 24px}
.post-body .content li{margin-bottom:10px}
.post-body .content a{color:var(--oxblood);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:4px}
.post-body .content img{margin:40px 0;width:100%;border:1px solid var(--carbon)}
.post-body .content code{font-family:var(--f-mono);font-size:14px;background:var(--paper-warm);padding:2px 6px;border-radius:3px}
.post-body .content pre{background:var(--carbon);color:var(--paper);padding:24px;overflow-x:auto;font-family:var(--f-mono);font-size:13px;line-height:1.6;margin:32px 0}
.post-body .content pre code{background:transparent;color:inherit;padding:0}
@media(max-width:900px){.post-hero{padding:160px 0 40px}.post-hero h1,.post-hero .excerpt{grid-column:1/13}.post-body .content{grid-column:1/13}}

/* SIDEBAR / CATEGORY NAV */
.cat-nav{padding:32px 0;background:var(--paper-warm);border-bottom:1px solid var(--carbon);position:sticky;top:0;z-index:50}
.cat-nav .wrap{display:flex;gap:24px;overflow-x:auto;font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em}
.cat-nav a{padding:8px 16px;border:1px solid var(--carbon);white-space:nowrap;transition:all .3s var(--ease)}
.cat-nav a:hover,.cat-nav a.active{background:var(--carbon);color:var(--paper)}

/* PAGINATION */
.pagination{grid-column:3/13;margin-top:64px;display:flex;gap:16px;font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.pagination a,.pagination span{padding:14px 20px;border:1px solid var(--carbon);transition:all .3s var(--ease)}
.pagination a:hover,.pagination .current{background:var(--carbon);color:var(--paper)}

/* 404 */
.notfound{padding:260px 0 200px;background:var(--paper);text-align:center}
.notfound h1{font-family:var(--f-display);font-size:clamp(80px,15vw,240px);font-weight:400;line-height:.9;letter-spacing:-.04em;color:var(--oxblood)}
.notfound p{font-family:var(--f-display);font-size:clamp(24px,3vw,40px);font-weight:300;margin:32px 0 48px;color:var(--grey-1)}

/* CONTACT FORM */
.contact-split{padding:120px 0 200px;background:var(--paper);border-top:1px solid var(--carbon)}
.contact-split .wrap{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.form-label{grid-column:1/3;font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-1);padding-top:16px}
.form-wrap{grid-column:3/9}
.form-wrap h2{font-family:var(--f-display);font-size:clamp(32px,4vw,56px);font-weight:400;letter-spacing:-.025em;line-height:1.05;margin-bottom:56px}
.form-wrap h2 em{font-style:italic;color:var(--oxblood);font-weight:300}
.field{margin-bottom:36px;border-bottom:1px solid var(--carbon);padding-bottom:14px}
.field label{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-1);margin-bottom:10px}
.field input,.field textarea,.field select{width:100%;border:0;background:transparent;font-family:var(--f-display);font-size:clamp(20px,2vw,28px);font-weight:400;color:var(--carbon);padding:4px 0;outline:none;letter-spacing:-.01em}
.field textarea{resize:vertical;min-height:120px;font-family:var(--f-body);font-size:17px;line-height:1.55}
.field select{appearance:none;-webkit-appearance:none}
.field input::placeholder,.field textarea::placeholder{color:var(--grey-2);font-weight:300}
.form-actions{margin-top:48px;display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.form-actions .note{font-family:var(--f-mono);font-size:11px;color:var(--grey-1);text-transform:uppercase;letter-spacing:.06em}
.meta-col{grid-column:10/13;padding-top:16px}
.meta-block{margin-bottom:56px;padding-bottom:32px;border-bottom:1px solid var(--border)}
.meta-block:last-child{border-bottom:0}
.meta-block h5{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-1);margin-bottom:14px}
.meta-block p,.meta-block a{font-family:var(--f-display);font-size:22px;line-height:1.3;font-weight:400;letter-spacing:-.01em;color:var(--carbon);display:block}
.meta-block a:hover{color:var(--oxblood)}
.meta-block .small{font-size:14px;color:var(--grey-1);font-family:var(--f-body);line-height:1.55;margin-top:8px}
@media(max-width:1200px){.form-wrap{grid-column:3/10}.meta-col{grid-column:1/13;margin-top:80px;display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.meta-block{border-bottom:0;margin-bottom:0;padding-bottom:0}}
@media(max-width:900px){.contact-split{padding:80px 0 120px}.form-label,.form-wrap{grid-column:1/13}.meta-col{grid-template-columns:1fr;gap:40px;margin-top:60px}}

/* MANIFESTO / ABOUT */
.manifesto{padding:160px 0;background:var(--paper);border-top:1px solid var(--carbon)}
.manifesto .wrap{display:flex;flex-wrap:wrap;gap:24px}
.manifesto .label{width:calc(16.66% - 12px);flex-shrink:0;padding-top:12px}
.manifesto-body{flex:1;max-width:75%;font-family:var(--f-display);font-size:clamp(26px,3.2vw,48px);font-weight:300;line-height:1.25;letter-spacing:-.015em;color:var(--carbon)}
.manifesto-body p{margin-bottom:40px}
.manifesto-body em{font-style:italic;color:var(--oxblood);font-weight:300}
.manifesto-body strong{font-weight:500;font-style:normal}
@media(max-width:900px){.manifesto{padding:100px 0}.manifesto .label,.manifesto-body{width:100%;max-width:100%}}

/* DELIVERABLES GRID (service pages) */
.deliverables-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:48px 40px;border-top:1px solid rgba(255,255,255,.15);padding-top:48px}
.deliverable h3{font-family:var(--f-display);font-size:clamp(22px,2.2vw,32px);font-weight:400;margin-bottom:14px;color:var(--paper);letter-spacing:-.015em}
.deliverable p{font-size:15px;line-height:1.6;color:var(--grey-3)}
@media(max-width:900px){.deliverables-grid{grid-template-columns:1fr}}

/* TIMELINE ROWS (service pages) */
.timeline-row{display:grid;grid-template-columns:140px 1fr;gap:32px;padding:32px 0;border-top:1px solid var(--carbon)}
.timeline-label{font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;color:var(--clay);padding-top:6px}
.timeline-row h4{font-family:var(--f-display);font-size:clamp(20px,1.8vw,28px);font-weight:400;margin-bottom:10px;letter-spacing:-.015em}
.timeline-row p{font-size:15px;color:var(--grey-1);line-height:1.6;max-width:720px}
@media(max-width:900px){.timeline-row{grid-template-columns:1fr}}

/* FAQ ITEMS (service pages) */
.faq-item{padding:32px 0;border-top:1px solid var(--carbon)}
.faq-item h4{font-family:var(--f-display);font-size:clamp(20px,1.8vw,28px);font-weight:400;margin-bottom:12px;letter-spacing:-.015em}
.faq-item p{font-size:16px;color:var(--grey-1);line-height:1.65;max-width:820px}

/* PRINCIPLES GRID (about page) */
.principles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid rgba(255,255,255,.15)}
.principle{padding:48px 40px 48px 0;border-bottom:1px solid rgba(255,255,255,.15)}
.principle:nth-child(odd){border-right:1px solid rgba(255,255,255,.15)}
.principle:nth-child(even){padding-left:40px}
.principle .num{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;color:var(--accent);margin-bottom:20px;display:block}
.principle h3{font-family:var(--f-display);font-size:clamp(22px,2vw,30px);font-weight:400;letter-spacing:-.015em;margin-bottom:14px;color:var(--paper);line-height:1.15}
.principle p{font-size:15px;line-height:1.6;color:var(--grey-3)}
@media(max-width:900px){.principles-grid{grid-template-columns:1fr}.principle,.principle:nth-child(odd){border-right:0;padding-left:0}}

/* ORIGIN TIMELINE (about page) */
.origin-list{border-top:1px solid var(--carbon)}
.origin-row{display:grid;grid-template-columns:120px 1fr;gap:40px;padding:36px 0;border-bottom:1px solid var(--border)}
.origin-year{font-family:var(--f-mono);font-size:13px;letter-spacing:.05em;color:var(--clay);font-weight:500;padding-top:6px}
.origin-row h4{font-family:var(--f-display);font-size:clamp(20px,1.8vw,28px);font-weight:400;letter-spacing:-.015em;margin-bottom:12px}
.origin-row p{font-size:15px;line-height:1.6;color:var(--grey-1);max-width:720px}
@media(max-width:900px){.origin-row{grid-template-columns:1fr}}

/* CLIENT QUOTES (homepage) */
.quotes-grid{display:grid;gap:48px}
.quote-text{font-family:var(--f-display);font-size:clamp(18px,1.6vw,24px);font-weight:400;font-style:italic;line-height:1.4;letter-spacing:-.01em;margin-bottom:20px}
.quote-attr{font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--clay)}

/* GRID UTILITY */
.col-wide{grid-column:3/13}
@media(max-width:900px){.col-wide{grid-column:1/13}}

/* VIEW ALL LINK */
.view-all{grid-column:1/13;margin-top:40px;text-align:right}
.view-all a{font-family:var(--f-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--oxblood);transition:color .3s var(--ease)}
.view-all a:hover{color:var(--carbon)}

@media(max-width:1200px){html,body{font-size:17px}}
@media(max-width:640px){
  .wrap{padding:0 20px}
  .site-header{padding:16px 20px}
  .hero-title{font-size:clamp(38px,11vw,64px)}
  .btn{padding:14px 22px;font-size:13px}
}
@media(max-width:480px){
  html,body{font-size:15px}
  .wrap{padding:0 16px}
  .cta-bottom,.form-actions{flex-direction:column;align-items:stretch}
  .btn{width:100%;justify-content:center}
}
/* MASKED REVEAL (legacy — clip-path used instead, no wrapper divs) */

/* CARD IMAGE HOVER REVEAL */
.card-img-reveal{position:absolute;width:160px;height:160px;border-radius:50%;overflow:hidden;pointer-events:none;opacity:0;transition:opacity .4s var(--ease);z-index:10}
.card-img-inner{width:100%;height:100%;background:var(--oxblood);opacity:.15;border-radius:50%}

/* ATMOSPHERIC SECTION TRANSITIONS */
.statement::before,.cta-section::before,.dark::before{content:"";position:absolute;top:-40px;left:0;right:0;height:40px;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.04));pointer-events:none;z-index:1}
.statement::after{content:"";position:absolute;bottom:-40px;left:0;right:0;height:40px;background:linear-gradient(to top,transparent,rgba(139,46,46,.03));pointer-events:none;z-index:1}
.dark::after{content:"";position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,var(--carbon),transparent);pointer-events:none;z-index:0}
.band-warm::before{content:"";position:absolute;top:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,rgba(0,0,0,.02),transparent);pointer-events:none}

/* FOCUS VISIBLE */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--oxblood);outline-offset:4px;border-radius:2px}
.card:focus-within{background:var(--paper-warm);outline:2px solid var(--oxblood);outline-offset:-2px}

/* PAGE ENTER */
@keyframes pageEnter{from{opacity:0}to{opacity:1}}
body{animation:pageEnter .6s var(--ease) both}

@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
