/*
Theme Name: EAS European Architectural Supply
Theme URI: https://eas-usa.com
Author: European Architectural Supply
Description: Premium theme for EAS — high-performance fenestration consultants.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
Text Domain: eas
*/

:root {
  --color-charcoal:   #1A1A1A;
  --color-gold:       #C8973A;
  --color-gold-light: #D9AB55;
  --color-stone:      #F5F2EE;
  --color-white:      #FFFFFF;
  --color-slate:      #6B7280;
  --color-navy:       #1B2C3E;
  --color-navy-deep:  #111E2B;
  --color-border:     #E5E0D8;
  --color-text:       #1A1A1A;
  --color-text-muted: #6B7280;
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
  --max-width: 1400px;
  --max-width-narrow: 760px;
  --max-width-mid: 1080px;
  --gutter: clamp(1.5rem, 4vw, 3rem);
  --transition-fast: 150ms ease;
  --transition-base: 300ms ease;
  --transition-slow: 600ms ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--color-text);background:var(--color-white);overflow-x:hidden}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,textarea,select{font:inherit}

h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:300;line-height:1.15;letter-spacing:-0.01em;color:var(--color-charcoal)}
.display-xl{font-size:clamp(3rem,7vw,6rem);font-family:var(--font-display);font-weight:300;line-height:1.05;letter-spacing:-0.02em}
.display-lg{font-size:clamp(2.25rem,5vw,4.5rem);font-family:var(--font-display);font-weight:300;line-height:1.1;letter-spacing:-0.02em}
.display-md{font-size:clamp(1.75rem,3.5vw,3rem);font-family:var(--font-display);font-weight:300;line-height:1.15}
.eyebrow{font-family:var(--font-body);font-size:0.75rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-gold)}
.eyebrow--light{color:rgba(200,151,58,0.85)}
.lead{font-size:clamp(1.125rem,2vw,1.25rem);line-height:1.65;color:var(--color-slate)}

.container{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:var(--max-width-narrow);margin-inline:auto;padding-inline:var(--gutter)}
.container--mid{max-width:var(--max-width-mid);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4rem,8vw,10rem)}
.section--stone{background:var(--color-stone)}
.section--navy{background:var(--color-navy);color:var(--color-white)}
.section--dark{background:var(--color-charcoal);color:var(--color-white)}

.btn{display:inline-flex;align-items:center;gap:.75rem;font-family:var(--font-body);font-size:.75rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:1rem 2rem;transition:all var(--transition-base);white-space:nowrap}
.btn-primary{background:var(--color-charcoal);color:var(--color-white);border:1px solid var(--color-charcoal)}
.btn-primary:hover{background:var(--color-navy);border-color:var(--color-navy);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.1)}
.btn-primary--gold{background:var(--color-gold);color:var(--color-white);border:1px solid var(--color-gold)}
.btn-primary--gold:hover{background:var(--color-gold-light);border-color:var(--color-gold-light);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--color-charcoal);border:1px solid var(--color-charcoal)}
.btn-secondary:hover{background:var(--color-charcoal);color:var(--color-white)}
.btn-secondary--light{color:var(--color-white);border-color:rgba(255,255,255,.6)}
.btn-secondary--light:hover{background:var(--color-white);color:var(--color-charcoal);border-color:var(--color-white)}
.btn-arrow::after{content:'→';font-size:1rem;font-weight:300;transition:transform var(--transition-base)}
.btn-arrow:hover::after{transform:translateX(4px)}

.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all var(--transition-slow);padding:1.5rem 0}
.site-header.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--color-border);padding:1rem 0}
.site-header.hero-page{background:transparent}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.site-logo img{height:36px;width:auto;transition:filter var(--transition-base)}
.hero-page .site-logo img{filter:brightness(0) invert(1)}
.hero-page.scrolled .site-logo img{filter:none}
.primary-nav{display:flex;align-items:center;gap:2.5rem}
.primary-nav a{font-family:var(--font-body);font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--color-charcoal);transition:color var(--transition-fast);position:relative}
.hero-page:not(.scrolled) .primary-nav a{color:rgba(255,255,255,.88)}
.hero-page:not(.scrolled) .primary-nav a:hover{color:#fff}
.primary-nav a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--color-gold);transform:scaleX(0);transition:transform var(--transition-base);transform-origin:left}
.primary-nav a:hover::after{transform:scaleX(1)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:.5rem}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--color-charcoal);transition:all var(--transition-base)}
.hero-page:not(.scrolled) .hamburger span{background:#fff}
.mobile-nav{display:none;position:fixed;inset:0;background:var(--color-charcoal);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--font-display);font-size:2.25rem;color:#fff;font-weight:300}
.mobile-nav-close{position:absolute;top:2rem;right:2rem;color:#fff;font-size:1.5rem;cursor:pointer}

@media(max-width:1024px){.primary-nav{display:none}.hamburger{display:flex}.nav-cta{display:none}}

.hero-full{position:relative;height:100svh;min-height:640px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;background-repeat:no-repeat;transform:scale(1.04);transition:transform 8s ease-out}
.hero-bg.loaded{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,30,43,.82) 0%,rgba(17,30,43,.35) 50%,rgba(17,30,43,.1) 100%)}
.hero-content{position:relative;z-index:2;padding-bottom:clamp(4rem,8vh,8rem);width:100%}
.hero-tagline{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}
.hero-tagline::before{content:'';display:block;width:40px;height:1px;background:var(--color-gold)}
.hero-title{color:#fff;max-width:800px;margin-bottom:2rem}
.hero-desc{color:rgba(255,255,255,.8);max-width:520px;font-size:1.125rem;line-height:1.65;margin-bottom:2.5rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:2.5rem;right:3rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;color:rgba(255,255,255,.6);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;font-family:var(--font-body);font-weight:500}
.hero-scroll::after{content:'';display:block;width:1px;height:48px;background:rgba(255,255,255,.3);animation:scrollPulse 2.5s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(.7)}}

.icp-paths{display:grid;grid-template-columns:repeat(3,1fr)}
.icp-card{position:relative;overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;cursor:pointer}
.icp-card-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform var(--transition-slow)}
.icp-card:hover .icp-card-bg{transform:scale(1.06)}
.icp-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,30,43,.88) 0%,rgba(17,30,43,.2) 60%,transparent 100%);transition:background var(--transition-slow)}
.icp-card:hover .icp-card-overlay{background:linear-gradient(to top,rgba(17,30,43,.92) 0%,rgba(17,30,43,.35) 60%,transparent 100%)}
.icp-card-content{position:relative;z-index:2;padding:2.5rem 2rem;width:100%}
.icp-card-title{font-family:var(--font-display);font-size:1.875rem;font-weight:300;color:#fff;margin-bottom:.75rem;line-height:1.1}
.icp-card-desc{color:rgba(255,255,255,.75);font-size:.875rem;line-height:1.6;margin-bottom:1.5rem;max-width:280px}
.icp-card-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--color-gold);font-size:.75rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;transition:gap var(--transition-base)}
.icp-card-link::after{content:'→'}
.icp-card:hover .icp-card-link{gap:1rem}
@media(max-width:768px){.icp-paths{grid-template-columns:1fr}.icp-card{aspect-ratio:4/3}}

.stats-bar{background:var(--color-charcoal);padding-block:3rem}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat-number{font-family:var(--font-display);font-size:clamp(2.25rem,5vw,3.75rem);font-weight:300;color:#fff;line-height:1;margin-bottom:.5rem}
.stat-number span{color:var(--color-gold)}
.stat-label{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500}
@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}

.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--color-border)}
.pillar{background:var(--color-white);padding:3rem 2.5rem;transition:background var(--transition-base)}
.pillar:hover{background:var(--color-stone)}
.pillar-number{font-family:var(--font-display);font-size:3rem;font-weight:300;color:var(--color-border);line-height:1;margin-bottom:1rem}
.pillar-title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:1rem}
.pillar-text{font-size:.875rem;color:var(--color-text-muted);line-height:1.7}
@media(max-width:900px){.pillar-grid{grid-template-columns:1fr}}

.split{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.split--60-40{grid-template-columns:3fr 2fr}
.split--40-60{grid-template-columns:2fr 3fr}
.split-image{position:relative;overflow:hidden;min-height:440px}
.split-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.split:hover .split-image img{transform:scale(1.03)}
.split-content{padding:clamp(3rem,6vw,5rem);display:flex;flex-direction:column;justify-content:center}
.split-content--stone{background:var(--color-stone)}
.split-content--navy{background:var(--color-navy);color:#fff}
@media(max-width:768px){.split,.split--60-40,.split--40-60{grid-template-columns:1fr}.split-image{min-height:300px}}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.gallery-item{position:relative;overflow:hidden;aspect-ratio:4/3;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item-overlay{position:absolute;inset:0;background:rgba(17,30,43,0);display:flex;align-items:flex-end;padding:1.5rem;transition:background var(--transition-base)}
.gallery-item:hover .gallery-item-overlay{background:rgba(17,30,43,.55)}
.gallery-item-caption{color:#fff;font-size:.875rem;font-weight:500;opacity:0;transform:translateY(8px);transition:all var(--transition-base)}
.gallery-item:hover .gallery-item-caption{opacity:1;transform:translateY(0)}
@media(max-width:768px){.gallery-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.gallery-grid{grid-template-columns:1fr}}

.testimonial-card{background:var(--color-white);padding:2.5rem 2rem;border-top:2px solid var(--color-gold)}
.testimonial-quote{font-family:var(--font-display);font-size:1.25rem;font-weight:300;line-height:1.55;color:var(--color-charcoal);margin-bottom:1.5rem}
.testimonial-quote::before{content:'\201C';color:var(--color-gold);font-size:2.25rem;line-height:.5;display:block;margin-bottom:1rem;font-family:var(--font-display)}
.testimonial-author{font-size:.875rem;font-weight:500;color:var(--color-charcoal)}
.testimonial-role{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}

.cta-banner{position:relative;overflow:hidden;padding-block:clamp(5rem,10vw,10rem);text-align:center}
.cta-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.cta-banner-overlay{position:absolute;inset:0;background:rgba(17,30,43,.8)}
.cta-banner-content{position:relative;z-index:2}
.cta-banner-title{font-family:var(--font-display);font-size:clamp(1.875rem,5vw,3.75rem);font-weight:300;color:#fff;margin-bottom:1.5rem;max-width:700px;margin-inline:auto}
.cta-banner-sub{color:rgba(255,255,255,.72);font-size:1.125rem;margin-bottom:2.5rem;max-width:480px;margin-inline:auto}
.cta-banner-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.site-footer{background:var(--color-navy-deep);color:rgba(255,255,255,.65);padding-top:6rem;padding-bottom:3rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;margin-bottom:4rem}
.footer-logo{margin-bottom:1.5rem}
.footer-logo img{height:32px;filter:brightness(0) invert(1);opacity:.85}
.footer-about{font-size:.875rem;line-height:1.7;max-width:320px;margin-bottom:2rem}
.footer-heading{font-family:var(--font-body);font-size:.75rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:1.25rem}
.footer-links{display:flex;flex-direction:column;gap:.75rem}
.footer-links a{font-size:.875rem;color:rgba(255,255,255,.55);transition:color var(--transition-fast)}
.footer-links a:hover{color:#fff}
.footer-contact-item{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem;font-size:.875rem}
.footer-contact-label{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.footer-contact-value{color:rgba(255,255,255,.75)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.75rem;color:rgba(255,255,255,.35)}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a{color:rgba(255,255,255,.35);transition:color var(--transition-fast)}
.footer-bottom-links a:hover{color:rgba(255,255,255,.7)}
.footer-national-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(200,151,58,.12);border:1px solid rgba(200,151,58,.25);padding:.5rem 1rem;margin-top:1rem}
.footer-national-badge span{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-gold);font-weight:500}
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr}}

.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}
.form-label{font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--color-slate)}
.form-input,.form-select,.form-textarea{width:100%;padding:1rem;border:1px solid var(--color-border);background:var(--color-white);font-family:var(--font-body);font-size:1rem;color:var(--color-charcoal);transition:border-color var(--transition-fast);border-radius:0;outline:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-charcoal)}
.form-textarea{min-height:140px;resize:vertical}

.text-gold{color:var(--color-gold)}
.text-white{color:#fff}
.text-muted{color:var(--color-text-muted)}
.text-center{text-align:center}
.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}
.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.fade-up{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up-delay-1{transition-delay:.1s}
.fade-up-delay-2{transition-delay:.2s}
.fade-up-delay-3{transition-delay:.3s}
.fade-up-delay-4{transition-delay:.4s}

.aligncenter{display:block;margin-inline:auto}
.alignleft{float:left;margin-right:1.5rem}
.alignright{float:right;margin-left:1.5rem}
