/* Meridian Studio — Visual language: landonorris.com */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;700;800&family=Inter:wght@400;500;600&display=swap');

:root {
  --color-bg: rgb(40, 44, 32);
  --color-bg-light: #f5f3ee;
  --color-accent: #d2ff00;
  --color-accent-secondary: #b2c73a;
  --color-surface: #3b3c38;
  --color-text: #ffffff;
  --color-text-dark: #282c20;
  --color-text-muted: rgba(255,255,255,0.65);
  --color-text-muted-dark: rgba(40,44,32,0.6);
  --color-border: rgba(255,255,255,0.12);
  --color-border-dark: rgba(40,44,32,0.12);
  --font-heading: 'Oswald', 'Impact', sans-serif;
  --font-body: 'Inter', 'Helvetica Neue', sans-serif;
  --section-padding: clamp(80px, 10vh, 140px);
  --container-max: 1200px;
  --grid-gap: 2rem;
  --nav-height: 80px;
  --ease-primary: cubic-bezier(0.65, 0.05, 0, 1);
  --ease-expo: cubic-bezier(0.19, 1, 0.22, 1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--color-text);background:var(--color-bg);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:800;text-transform:uppercase;letter-spacing:-0.02em;line-height:1.05;text-wrap:balance}
h1{font-size:clamp(3rem,8vw,7rem)}
h2{font-size:clamp(2rem,5vw,4rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.75rem)}
p{text-wrap:pretty}
.container{max-width:var(--container-max);margin:0 auto;padding:0 clamp(20px,4vw,40px)}

.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,40px);transition:color .6s var(--ease-expo),background-color .6s var(--ease-expo);color:var(--color-text-dark)}
.site-header.header--dark{color:var(--color-text)}
.header-logo{font-family:var(--font-heading);font-weight:800;font-size:1.5rem;text-transform:uppercase;letter-spacing:-0.02em;line-height:1.1;transition:color .6s var(--ease-expo)}
.header-logo span{display:block;font-weight:400;font-size:.6em;letter-spacing:.15em;opacity:.6}
.header-nav{display:flex;align-items:center;gap:2rem}
.header-nav a{font-family:var(--font-heading);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;transition:color .6s var(--ease-expo)}
.header-nav a:hover{color:var(--color-accent)}
.header-cta{display:inline-block;background:var(--color-accent);color:var(--color-text-dark);padding:.6rem 1.4rem;font-family:var(--font-heading);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;border:none;cursor:pointer;transition:background-color .75s var(--ease-primary),transform .3s var(--ease-expo)}
.header-cta:hover{background:#e8ff4d;transform:scale(1.05)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:2px solid currentColor;padding:10px;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:currentColor}

@media(max-width:1024px){
  .header-nav{display:none;position:absolute;top:var(--nav-height);left:0;right:0;background:var(--color-bg);flex-direction:column;padding:2rem;gap:1.5rem;border-bottom:1px solid var(--color-border)}
  .header-nav.open{display:flex}
  .header-nav a{font-size:1.1rem;color:var(--color-text)}
  .header-cta{display:none}
  .hamburger{display:flex}
  .header-logo{font-size:1.2rem}
}

.hero{position:relative;min-height:100dvh;display:flex;align-items:flex-end;padding:calc(var(--nav-height) + 60px) 0 var(--section-padding);background:var(--color-bg-light);color:var(--color-text-dark);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.2;will-change:transform}
.hero-blob{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.08;background-image:url("data:image/svg+xml,%3Csvg width='1440' height='900' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 400Q200 300 400 380T800 420T1200 370T1440 400' fill='none' stroke='%23282c20' stroke-width='2'/%3E%3Cpath d='M0 300Q300 220 600 300T1200 280T1440 300' fill='none' stroke='%23282c20' stroke-width='1.5'/%3E%3Cpath d='M0 550Q250 480 500 540T1000 500T1440 530' fill='none' stroke='%23282c20' stroke-width='1.5'/%3E%3Ccircle cx='300' cy='350' r='120' fill='none' stroke='%23282c20' stroke-width='1'/%3E%3Ccircle cx='900' cy='450' r='160' fill='none' stroke='%23282c20' stroke-width='.8'/%3E%3C/svg%3E");background-size:cover}
.hero-content{position:relative;z-index:2;max-width:800px;padding:0 clamp(20px,4vw,40px)}
.hero-label{font-family:var(--font-heading);font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;opacity:.45;margin-bottom:1.5rem}
.hero h1{margin-bottom:1.5rem}
.hero h1 em{font-style:normal;color:var(--color-accent-secondary)}
.hero-description{font-size:clamp(1rem,1.5vw,1.2rem);max-width:560px;opacity:.7;margin-bottom:2rem}
.btn-accent{display:inline-block;background:var(--color-accent);color:var(--color-text-dark);padding:.85rem 2rem;font-family:var(--font-heading);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;transition:background-color .75s var(--ease-primary),transform .3s var(--ease-expo)}
.btn-accent:hover{background:#e8ff4d;transform:scale(1.05)}
.hero-stats{display:flex;gap:clamp(1.5rem,3vw,3rem);margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border-dark)}
.hero-stat .stat-value{font-family:var(--font-heading);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1}
.hero-stat .stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;opacity:.45;margin-top:.25rem}
@media(max-width:640px){.hero-stats{flex-wrap:wrap;gap:1rem}.hero-stat{flex:0 0 45%}}

.marquee-section{background:var(--color-bg);padding:clamp(25px,4vh,50px) 0;overflow:hidden;position:relative}
.ticker-track{display:flex;width:max-content}
.ticker-track--left{animation:marquee-left 22s linear infinite}
.ticker-track--right{animation:marquee-right 22s linear infinite;margin-top:.25rem}
.ticker-item{font-family:var(--font-heading);font-size:clamp(3rem,7vw,5.5rem);font-weight:800;text-transform:uppercase;color:var(--color-accent);white-space:nowrap;padding:0 .75rem;line-height:1.1}
.ticker-item--outline{-webkit-text-stroke:2px var(--color-accent);color:transparent}
.ticker-dot{display:inline-block;width:12px;height:12px;background:var(--color-accent);border-radius:50%;margin:0 1rem;vertical-align:middle}
@keyframes marquee-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes marquee-right{from{transform:translateX(-50%)}to{transform:translateX(0)}}

.section-about{background:var(--color-bg);color:var(--color-text);padding:var(--section-padding) 0;position:relative}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start;position:relative;z-index:1}
.about-label{font-family:var(--font-heading);font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--color-accent);margin-bottom:1rem}
.about-text{font-size:clamp(1rem,1.2vw,1.1rem);color:var(--color-text-muted);line-height:1.7}
.about-text p+p{margin-top:1.5rem}
.about-image img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center}
@media(max-width:768px){.about-grid{grid-template-columns:1fr}}

.section-services{background:var(--color-bg-light);color:var(--color-text-dark);padding:var(--section-padding) 0}
.section-services h2{margin-bottom:1rem}
.section-subtitle{font-size:clamp(1rem,1.2vw,1.1rem);color:var(--color-text-muted-dark);max-width:500px;margin-bottom:3rem}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--grid-gap)}
.service-card{padding:clamp(1.5rem,3vw,2.5rem);border:1px solid var(--color-border-dark);transition:border-color .75s var(--ease-primary),background-color .75s var(--ease-primary)}
.service-card:hover{border-color:var(--color-accent-secondary);background:rgba(40,44,32,.04)}
.service-icon{font-size:2rem;margin-bottom:1.5rem;display:block}
.service-card h3{margin-bottom:1rem;font-size:1.15rem}
.service-card p{font-size:.9rem;color:var(--color-text-muted-dark);line-height:1.6}
@media(max-width:768px){.services-grid{grid-template-columns:1fr}}

.section-projects{background:var(--color-bg);color:var(--color-text);padding:var(--section-padding) 0;position:relative}
.section-projects h2{margin-bottom:1rem}
.projects-subtitle{color:var(--color-text-muted);max-width:500px;margin-bottom:3rem}
.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--grid-gap);position:relative;z-index:1}
.project-card{overflow:hidden}
.project-card img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:center;transition:transform .75s var(--ease-primary)}
.project-card:hover img{transform:scale(1.05)}
.project-info{padding:1.5rem 0}
.project-category{font-family:var(--font-heading);font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--color-accent);margin-bottom:.5rem}
.project-info h3{margin-bottom:.5rem;font-size:clamp(1.1rem,2vw,1.4rem)}
.project-info p{font-size:.85rem;color:var(--color-text-muted);line-height:1.5}
@media(max-width:640px){.projects-grid{grid-template-columns:1fr}}

.section-process{background:var(--color-bg-light);color:var(--color-text-dark);padding:var(--section-padding) 0}
.process-header{margin-bottom:3rem}
.process-header h2{margin-bottom:1rem}
.process-subtitle{color:var(--color-text-muted-dark);max-width:500px}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--grid-gap);counter-reset:process}
.process-step{position:relative;padding-top:3rem}
.process-step::before{content:counter(process);counter-increment:process;font-family:var(--font-heading);font-size:clamp(3rem,5vw,4.5rem);font-weight:800;color:var(--color-accent-secondary);opacity:.25;position:absolute;top:0;left:0;line-height:1}
.process-step h3{margin-bottom:.75rem;font-size:1.1rem}
.process-step p{font-size:.85rem;color:var(--color-text-muted-dark);line-height:1.6}
@media(max-width:768px){.process-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.process-grid{grid-template-columns:1fr}}

.section-testimonials{background:var(--color-bg);color:var(--color-text);padding:var(--section-padding) 0;position:relative}
.testimonials-header{text-align:center;margin-bottom:3rem;position:relative;z-index:1}
.testimonials-header h2 em{font-style:normal;color:var(--color-accent)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--grid-gap);position:relative;z-index:1}
.testimonial-card{padding:clamp(1.5rem,3vw,2.5rem);border:1px solid var(--color-border);display:flex;flex-direction:column;justify-content:space-between}
.testimonial-quote{font-size:clamp(.9rem,1.1vw,1rem);line-height:1.7;color:var(--color-text-muted);margin-bottom:2rem;padding-left:1.5rem;border-left:2px solid var(--color-accent)}
.testimonial-author{font-family:var(--font-heading);font-weight:700;text-transform:uppercase;font-size:.85rem;letter-spacing:.05em}
.testimonial-role{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}
@media(max-width:768px){.testimonials-grid{grid-template-columns:1fr}}

.section-cta{background:var(--color-accent);color:var(--color-text-dark);padding:var(--section-padding) 0;text-align:center}
.section-cta h2{margin-bottom:1rem}
.section-cta p{max-width:500px;margin:0 auto 2rem;opacity:.65}
.btn-dark{display:inline-block;background:var(--color-bg);color:var(--color-text);padding:1rem 2.5rem;font-family:var(--font-heading);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;transition:background-color .75s var(--ease-primary),transform .3s var(--ease-expo)}
.btn-dark:hover{background:var(--color-surface);transform:scale(1.05)}

.site-footer{background:var(--color-bg);color:var(--color-text);padding:var(--section-padding) 0 2rem;position:relative}
.footer-top{text-align:center;margin-bottom:var(--section-padding);position:relative;z-index:1}
.footer-tagline{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:2rem}
.footer-tagline em{font-style:normal;color:var(--color-accent)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--grid-gap);padding-top:3rem;border-top:1px solid var(--color-border);position:relative;z-index:1}
.footer-about p{font-size:.85rem;color:var(--color-text-muted);line-height:1.6;max-width:300px}
.footer-col h4{font-family:var(--font-heading);font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;margin-bottom:1rem;color:var(--color-accent)}
.footer-col a{display:block;font-size:.85rem;color:var(--color-text-muted);margin-bottom:.5rem;transition:color .6s var(--ease-expo)}
.footer-col a:hover{color:var(--color-accent)}
.footer-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--color-text-muted);position:relative;z-index:1}
.footer-legal a{margin-left:1.5rem;color:var(--color-text-muted);transition:color .6s var(--ease-expo)}
.footer-legal a:hover{color:var(--color-accent)}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}}

.reveal{opacity:0;transform:translateY(40px);transition:opacity .75s var(--ease-primary),transform .75s var(--ease-primary)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.clip-reveal{clip-path:inset(100% 0 0 0);transition:clip-path .75s var(--ease-primary)}
.clip-reveal.is-visible{clip-path:inset(0% 0 0 0)}
.gallery-item{opacity:0;transform:translateY(50px);transition:opacity .75s var(--ease-primary),transform .75s var(--ease-primary)}
.gallery-item.is-visible{opacity:1;transform:translateY(0)}

.topo-overlay{position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg width='800' height='800' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 400Q200 350 400 400T800 400' fill='none' stroke='%23fff' stroke-width='1.5'/%3E%3Cpath d='M0 300Q200 250 400 300T800 300' fill='none' stroke='%23fff' stroke-width='1'/%3E%3Cpath d='M0 500Q200 450 400 500T800 500' fill='none' stroke='%23fff' stroke-width='1'/%3E%3Ccircle cx='250' cy='350' r='100' fill='none' stroke='%23fff' stroke-width='.8'/%3E%3Ccircle cx='600' cy='450' r='130' fill='none' stroke='%23fff' stroke-width='.7'/%3E%3C/svg%3E");background-size:800px}
.gradient-divider{height:clamp(60px,10vh,100px);background:linear-gradient(to bottom,var(--color-accent),var(--color-bg))}

@media(prefers-reduced-motion:reduce){
  .reveal,.clip-reveal,.gallery-item{opacity:1!important;transform:none!important;clip-path:none!important;transition:none!important}
  .ticker-track--left,.ticker-track--right{animation:none!important}
}
