/*
Theme Name: Harrison Ventures
Theme URI: https://harrisonventures.llc
Author: Tanner Harrison
Author URI: https://tannerharrison.com
Description: A light, professional portfolio theme for Harrison Ventures LLC — a family holding company operating CyberCascadia, NW Lighting, T&T Rentals, and 3BG.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: harrisonventures
Tags: one-column, custom-menu, featured-images, theme-options, portfolio, light

Design System:
  Background: #FAFAF8 (warm white)
  Headings: DM Serif Display
  Body: Inter
  Primary: #1B6B3A (forest green)
*/

:root {
    --bg: #FAFAF8;
    --bg-white: #FFFFFF;
    --bg-muted: #F0F0EC;
    --bg-card: #F5F5F2;
    --border: #E4E4E0;
    --border-hover: #D0D0CC;
    --text-primary: #1A1A1A;
    --text-secondary: #5A5A5A;
    --text-muted: #8A8A8A;
    --green: #1B6B3A;
    --green-light: #E8F2EC;
    --green-hover: #237A45;
    --green-dark: #144D2B;
    --font-heading: 'DM Serif Display', Georgia, serif;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* ── Nav ── */
.site-nav{position:fixed;top:0;width:100%;z-index:100;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;background:rgba(250,250,248,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:all .3s ease}
.nav-logo{font-family:var(--font-heading);font-size:1.15rem;color:var(--text-primary);letter-spacing:-.01em}
.nav-logo span{color:var(--green)}
.nav-menu{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-menu a{color:var(--text-secondary);font-size:.82rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;transition:color .25s ease}
.nav-menu a:hover,.nav-menu .current-menu-item a,.nav-menu .current_page_item a{color:var(--green)}
.mobile-toggle{display:none;background:none;border:none;color:var(--text-primary);font-size:1.4rem;cursor:pointer}

/* ── Hero ── */
.hero{min-height:92vh;display:flex;align-items:center;padding:8rem 2rem 6rem;position:relative}
.hero-inner{max-width:900px;margin:0 auto;width:100%}
.hero-tag{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:2rem;font-weight:500}
.hero-tag::before{content:'';width:24px;height:1px;background:var(--green)}
.hero h1{font-family:var(--font-heading);font-size:clamp(2.8rem,7vw,4.8rem);line-height:1.08;font-weight:400;margin-bottom:1.5rem;letter-spacing:-.02em;color:var(--text-primary)}
.hero h1 em{color:var(--green);font-style:normal}
.hero-sub{font-size:1.1rem;color:var(--text-secondary);max-width:540px;line-height:1.75;margin-bottom:2.5rem;font-weight:400}
.hero-links{display:flex;gap:1rem;flex-wrap:wrap}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.6rem;font-size:.85rem;font-weight:600;letter-spacing:.02em;border-radius:3px;transition:all .25s ease;font-family:var(--font-body);cursor:pointer;border:none;text-decoration:none}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-hover);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}

/* ── Modal Logo Override ── */
.modal-logo{max-width:280px;height:88px;display:flex;align-items:center}
.modal-logo img{max-height:88px!important;width:auto!important;height:auto!important;object-fit:contain}
.modal-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:12px;font-size:1.8rem;background:var(--green-light);color:var(--green)}

/* ── Sections ── */
.section{padding:6rem 2rem}
.section-inner{max-width:1000px;margin:0 auto}
.section-label{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.75rem;font-weight:500}
.section-title{font-family:var(--font-heading);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:400;margin-bottom:1rem;letter-spacing:-.01em}
.section-desc{color:var(--text-secondary);max-width:540px;line-height:1.75;margin-bottom:3rem;font-weight:400}
.bg-white{background:var(--bg-white)}
.divider{width:100%;height:1px;background:var(--border)}

/* ── Company Cards (Home) ── */
.companies-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.company-card{position:relative;padding:2.5rem 2rem;background:var(--bg-white);border:1px solid var(--border);border-radius:4px;text-decoration:none;color:inherit;transition:all .35s ease;display:flex;flex-direction:column;gap:.75rem;overflow:hidden;cursor:pointer}
.company-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--green);opacity:0;transition:opacity .35s ease}
.company-card:hover{border-color:var(--border-hover);box-shadow:0 4px 24px rgba(0,0,0,.04);transform:translateY(-2px)}
.company-card:hover::before{opacity:1}
.company-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:1rem;background:var(--green-light);color:var(--green)}
.company-logo{width:100%;max-width:180px;height:48px;display:flex;align-items:center}
.company-logo img{max-height:48px!important;width:auto!important;height:auto!important;object-fit:contain}
.company-name{font-family:var(--font-heading);font-size:1.3rem;letter-spacing:-.01em}
.company-type{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:500}
.company-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.65;font-weight:400}
.company-link{font-size:.78rem;color:var(--text-muted);margin-top:auto;display:flex;align-items:center;gap:.4rem;font-weight:500;transition:color .25s ease}
.company-card:hover .company-link{color:var(--green)}
.company-link::after{content:'→';transition:transform .25s ease}
.company-card:hover .company-link::after{transform:translateX(3px)}

/* ── Mission / About ── */
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.mission-text{color:var(--text-secondary);line-height:1.85;font-weight:400}
.mission-text p+p{margin-top:1.25rem}
.mission-callout{padding:2rem;background:var(--green-light);border-left:3px solid var(--green);border-radius:0 4px 4px 0}
.mission-callout p{font-family:var(--font-heading);font-size:1.15rem;line-height:1.5;color:var(--green-dark)}

/* ── Company Page (Single) ── */
.company-hero{padding:10rem 2rem 4rem;max-width:800px;margin:0 auto}
.company-hero .company-type{margin-bottom:.75rem;display:inline-block}
.company-hero h1{font-family:var(--font-heading);font-size:clamp(2.2rem,5vw,3.2rem);font-weight:400;margin-bottom:1.5rem;letter-spacing:-.02em}
.company-hero .company-overview{font-size:1.1rem;color:var(--text-secondary);line-height:1.75;max-width:600px}
.company-body{max-width:720px;margin:0 auto;padding:2rem 2rem 6rem}
.company-body h2{font-family:var(--font-heading);font-size:1.6rem;font-weight:400;margin:3rem 0 1rem}
.company-body p{color:var(--text-secondary);line-height:1.85;margin-bottom:1.5rem}
.company-body ul{color:var(--text-secondary);margin:0 0 1.5rem 1.5rem;line-height:1.85}
.company-body a{color:var(--green);text-decoration:underline;text-underline-offset:2px}
.company-cta{padding:3rem;background:var(--green-light);border-radius:4px;text-align:center;margin:3rem 0}
.company-cta p{color:var(--green-dark);font-size:1rem;margin-bottom:1rem}

/* ── Blog Cards ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{padding:2rem;background:var(--bg-white);border:1px solid var(--border);border-radius:4px;text-decoration:none;color:inherit;transition:all .3s ease;display:flex;flex-direction:column}
.blog-card:hover{border-color:var(--border-hover);box-shadow:0 4px 24px rgba(0,0,0,.04);transform:translateY(-2px)}
.blog-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}
.blog-tag{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;padding:.2rem .5rem;border-radius:3px;font-weight:600;background:var(--green-light);color:var(--green)}
.blog-date{font-size:.72rem;color:var(--text-muted)}
.blog-card-title{font-family:var(--font-heading);font-size:1.1rem;margin-bottom:.6rem;line-height:1.3}
.blog-excerpt{font-size:.85rem;color:var(--text-secondary);line-height:1.65;flex-grow:1}
.blog-read{font-size:.75rem;color:var(--text-muted);margin-top:1rem;font-weight:500;transition:color .25s ease}
.blog-card:hover .blog-read{color:var(--green)}

/* ── Single Post ── */
.post-header{padding:10rem 2rem 4rem;text-align:center;max-width:720px;margin:0 auto}
.post-header h1{font-family:var(--font-heading);font-size:clamp(1.8rem,4.5vw,2.8rem);font-weight:400;line-height:1.15;margin-bottom:1.5rem}
.post-content{max-width:680px;margin:0 auto;padding:0 2rem 6rem}
.post-content p{color:var(--text-secondary);line-height:1.85;margin-bottom:1.5rem;font-size:1.02rem}
.post-content h2{font-family:var(--font-heading);font-size:1.6rem;font-weight:400;margin:3rem 0 1rem;color:var(--text-primary)}
.post-content h3{font-size:1.2rem;font-weight:600;margin:2.5rem 0 .75rem;color:var(--text-primary)}
.post-content blockquote{border-left:3px solid var(--green);padding-left:1.5rem;margin:2rem 0;font-family:var(--font-heading);font-size:1.15rem;color:var(--text-secondary)}
.post-content a{color:var(--green);text-decoration:underline;text-underline-offset:2px}
.post-content code{background:var(--bg-muted);padding:.15rem .4rem;border-radius:3px;font-size:.9em}
.post-content pre{background:var(--bg-muted);border:1px solid var(--border);padding:1.5rem;border-radius:4px;overflow-x:auto;margin-bottom:1.5rem}
.post-content img{border-radius:4px;margin:2rem 0}
.post-nav{max-width:680px;margin:0 auto;padding:0 2rem 4rem;display:flex;justify-content:space-between;gap:2rem}
.post-nav a{color:var(--text-muted);font-size:.85rem;font-weight:500;transition:color .25s ease}
.post-nav a:hover{color:var(--green)}

/* ── Archive ── */
.archive-header{padding:10rem 2rem 3rem;text-align:center}
.archive-header h1{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:400;margin-bottom:1rem}
.archive-header p{color:var(--text-secondary);font-size:1.02rem;max-width:480px;margin:0 auto}
.archive-content{max-width:1000px;margin:0 auto;padding:0 2rem 6rem}

/* ── Page ── */
.page-header{padding:10rem 2rem 3rem;text-align:center}
.page-header h1{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:400}
.page-content{max-width:680px;margin:0 auto;padding:2rem 2rem 6rem}
.page-content p{color:var(--text-secondary);line-height:1.85;margin-bottom:1.5rem}

/* ── Footer ── */
.site-footer{padding:3rem 2rem;border-top:1px solid var(--border);background:var(--bg-white)}
.footer-inner{max-width:1000px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.75rem;color:var(--text-muted)}
.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-links a{font-size:.75rem;color:var(--text-muted);font-weight:500;transition:color .25s ease}
.footer-links a:hover{color:var(--green)}

/* ── Animations ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.s1{transition-delay:.1s}.s2{transition-delay:.2s}.s3{transition-delay:.3s}.s4{transition-delay:.4s}

/* ── Comments ── */
.comments-area{max-width:680px;margin:0 auto;padding:0 2rem 4rem}
.comments-area h2{font-family:var(--font-heading);font-size:1.4rem;margin-bottom:2rem}
.comment-list{list-style:none}
.comment-body{padding:1.5rem;background:var(--bg-white);border:1px solid var(--border);border-radius:4px;margin-bottom:1rem}
.comment-reply-link{color:var(--green);font-size:.8rem;font-weight:500}
.search-form{display:flex;gap:.5rem;max-width:400px;margin:2rem auto}
.search-form input[type="search"]{flex:1;background:var(--bg-white);border:1px solid var(--border);padding:.75rem 1rem;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;border-radius:3px}
.search-form input[type="submit"]{background:var(--green);color:#fff;border:none;padding:.75rem 1.5rem;font-family:var(--font-body);font-size:.85rem;font-weight:600;border-radius:3px;cursor:pointer}

/* ── Responsive ── */
@media(max-width:768px){
    .nav-menu{display:none}
    .nav-menu.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:rgba(250,250,248,.98);padding:1.5rem 2rem;gap:1.25rem;border-bottom:1px solid var(--border)}
    .mobile-toggle{display:block}
    .hero{padding:7rem 1.5rem 4rem}
    .companies-grid{grid-template-columns:1fr}
    .mission-grid{grid-template-columns:1fr}
    .blog-grid{grid-template-columns:1fr}
    .section{padding:4rem 1.5rem}
}
