@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Outfit:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap');

:root {
  --c-ink:     #0b1a10;
  --c-deep:    #0d2818;
  --c-forest:  #1a4a2e;
  --c-mid:     #2d6a4f;
  --c-bright:  #40916c;
  --c-accent:  #52b788;
  --c-glow:    #74c69d;
  --c-light:   #b7e4c7;
  --c-pale:    #d8f3dc;
  --c-cream:   #f6f3ee;
  --c-white:   #ffffff;
  --c-amber:   #e9a716;
  --c-muted:   #5a7a62;
  --c-border:  rgba(45,106,79,.15);
  --ff-display:'Cormorant Garamond', Georgia, serif;
  --ff-body:   'Outfit', sans-serif;
  --ff-mono:   'DM Mono', monospace;
  --nav-h:     76px;
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 28px;
  --shadow-sm: 0 2px 12px rgba(11,26,16,.08);
  --shadow-md: 0 8px 32px rgba(11,26,16,.12);
  --shadow-lg: 0 24px 64px rgba(11,26,16,.16);
  --ease-out:  cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);background:var(--c-cream);color:var(--c-ink);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:var(--ff-body);cursor:pointer;border:none;background:none}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--c-pale)}
::-webkit-scrollbar-thumb{background:var(--c-accent);border-radius:99px}

.container{max-width:1200px;margin:0 auto;padding:0 40px}
.label{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-accent)}
.section-title{font-family:var(--ff-display);font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:600;line-height:1.1;color:var(--c-ink)}
.section-title em{font-style:italic;color:var(--c-forest)}
.section-title--light{color:#fff}
.section-title--light em{color:var(--c-glow)}
.divider{width:48px;height:3px;background:linear-gradient(90deg,var(--c-accent),transparent);border-radius:99px;margin:20px 0 28px}
.divider--light{background:linear-gradient(90deg,var(--c-glow),transparent)}
.body-text{font-size:1.05rem;font-weight:300;line-height:1.8;color:var(--c-muted)}
.body-text--light{color:rgba(255,255,255,.65)}

/* BUTTONS */
.cg-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border-radius:99px;font-size:.9rem;font-weight:500;letter-spacing:.02em;transition:transform .25s var(--ease-out),box-shadow .25s,background .2s}
.cg-btn:hover{transform:translateY(-2px)}
.btn-arrow{transition:transform .25s var(--ease-out)}
.cg-btn:hover .btn-arrow{transform:translateX(4px)}
.cg-btn--primary{background:linear-gradient(135deg,var(--c-accent),var(--c-forest));color:#fff;box-shadow:0 6px 24px rgba(64,145,108,.35)}
.cg-btn--primary:hover{box-shadow:0 12px 36px rgba(64,145,108,.45)}
.cg-btn--outline{border:1.5px solid var(--c-accent);color:var(--c-forest)}
.cg-btn--outline:hover{background:var(--c-pale)}
.cg-btn--ghost{border:1.5px solid rgba(255,255,255,.35);color:#fff;background:rgba(255,255,255,.06)}
.cg-btn--ghost:hover{background:rgba(255,255,255,.14)}

/* BOOTSTRAP NAVBAR OVERRIDES */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  transition: background .4s, box-shadow .4s;
  height: var(--nav-h);
}
.navbar.scrolled {
  background: rgba(11,26,16,.96) !important;
  backdrop-filter: blur(20px);
  box-shadow: 0 2px 24px rgba(0,0,0,.2);
}
.navbar-brand img { height: 36px; object-fit: contain; }
.navbar-nav .nav-link {
  font-size: .88rem;
  color: rgba(255,255,255,.8) !important;
  position: relative;
  transition: color .2s;
}
.navbar-nav .nav-link:hover, .navbar-nav .nav-link.active { color: #fff !important; }
.navbar-toggler { border-color: rgba(255,255,255,.3); }
.navbar-toggler-icon { filter: invert(1); }
.navbar-collapse { background: rgba(11,26,16,.97); }
@media(min-width:992px) {
  .navbar-collapse { background: transparent; }
}

/* HERO */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-image:url('../images/cullet-green.png');background-size:cover;background-position:center;transition:transform 8s ease;transform:scale(1.06)}
.hero__bg.ken{transform:scale(1)}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(11,26,16,.93) 0%,rgba(13,40,24,.82) 50%,rgba(11,26,16,.55) 100%)}
.hero__content{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:calc(var(--nav-h) + 60px) 40px 80px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;min-height:100vh}
.hero__eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.hero__eyebrow-line{width:32px;height:1.5px;background:var(--c-accent)}
.hero__h1{font-family:var(--ff-display);font-size:clamp(3rem,5.5vw,5.5rem);font-weight:600;line-height:1.02;color:#fff;margin-bottom:24px}
.hero__h1 em{font-style:italic;color:var(--c-glow);display:block}
.hero__desc{font-size:1.1rem;font-weight:300;color:rgba(255,255,255,.65);line-height:1.75;max-width:480px;margin-bottom:48px}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap}
.hero__right{display:flex;flex-direction:column;gap:16px;align-items:flex-end}
.hero__stat-card{background:rgba(255,255,255,.07);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.13);border-radius:var(--radius-md);padding:28px 36px;text-align:center;transition:background .3s,transform .3s var(--ease-out);width:200px}
.hero__stat-card:hover{background:rgba(255,255,255,.11);transform:translateY(-4px)}
.hero__stat-num{font-family:var(--ff-display);font-size:2.8rem;font-weight:700;color:var(--c-glow);line-height:1;margin-bottom:8px}
.hero__stat-label{font-size:.75rem;color:rgba(255,255,255,.5);font-family:var(--ff-mono);letter-spacing:.08em;text-transform:uppercase;line-height:1.5}
.hero__scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2;opacity:.45;animation:bounce 2.2s ease-in-out infinite}
.hero__scroll span{font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:#fff}
.hero__scroll-arrow{width:16px;height:16px;border-right:1.5px solid #fff;border-bottom:1.5px solid #fff;transform:rotate(45deg)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(9px)}}

/* TICKER */
.ticker{background:var(--c-deep);border-top:1px solid rgba(255,255,255,.05);overflow:hidden;padding:14px 0}
.ticker__track{display:flex;animation:ticker 32s linear infinite;white-space:nowrap}
.ticker:hover .ticker__track{animation-play-state:paused}
.ticker__item{display:flex;align-items:center;gap:32px;padding-right:48px;font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.ticker__dot{width:4px;height:4px;border-radius:50%;background:var(--c-accent);flex-shrink:0}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* INTRO */
.intro{padding:120px 0;background:var(--c-white)}
.intro__images{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:260px 180px;gap:12px}
.intro__img{border-radius:var(--radius-md);overflow:hidden;position:relative}
.intro__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out)}
.intro__img:hover img{transform:scale(1.06)}
.intro__img--tall{grid-row:1/3}
.intro__img-tag{position:absolute;bottom:12px;left:12px;font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85);background:rgba(11,26,16,.6);backdrop-filter:blur(8px);padding:5px 10px;border-radius:4px}

/* PRODUCTS */
.products{padding:120px 0;background:var(--c-cream)}
.products__header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px;flex-wrap:wrap;gap:24px}
.product-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden;transition:transform .35s var(--ease-out),box-shadow .35s}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.product-card__img{height:240px;overflow:hidden;position:relative}
.product-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.product-card:hover .product-card__img img{transform:scale(1.08)}
.product-card__img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,26,16,.5),transparent 60%)}
.product-card__badge{position:absolute;top:16px;left:16px;background:rgba(11,26,16,.7);backdrop-filter:blur(8px);color:var(--c-glow);font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;padding:5px 12px;border-radius:4px}
.product-card__body{padding:28px 28px 32px}
.product-card__icon{font-size:1.8rem;margin-bottom:12px}
.product-card__title{font-family:var(--ff-display);font-size:1.5rem;font-weight:600;color:var(--c-ink);margin-bottom:12px}
.product-card__desc{font-size:.9rem;font-weight:300;color:var(--c-muted);line-height:1.7;margin-bottom:20px}
.product-card__link{display:inline-flex;align-items:center;gap:6px;font-size:.84rem;font-weight:500;color:var(--c-forest);transition:gap .2s}
.product-card:hover .product-card__link{gap:10px}

/* STATS BAND */
.stats-band{background:var(--c-deep);padding:80px 0}
.stats-band__card{padding:52px 40px;text-align:center;transition:background .3s;border-right:1px solid rgba(255,255,255,.06)}
.stats-band__card:last-child{border-right:none}
.stats-band__card:hover{background:rgba(116,198,157,.06)}
.stats-band__num{font-family:var(--ff-display);font-size:3.4rem;font-weight:700;color:var(--c-glow);line-height:1;margin-bottom:10px}
.stats-band__unit{font-size:1.6rem;color:var(--c-accent)}
.stats-band__label{font-size:.8rem;font-weight:300;color:rgba(255,255,255,.45);font-family:var(--ff-mono);letter-spacing:.06em;line-height:1.5}

/* GALLERY */
.gallery{padding:120px 0;background:var(--c-ink)}
.gallery__mosaic{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:420px 280px;gap:10px;margin-top:64px}
.gallery__tile{border-radius:var(--radius-md);overflow:hidden;position:relative}
.gallery__tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.gallery__tile:hover img{transform:scale(1.05)}
.gallery__tile--main{grid-row:1/3}
.gallery__tile-cap{position:absolute;bottom:0;left:0;right:0;padding:20px 22px;background:linear-gradient(to top,rgba(11,26,16,.85),transparent);font-family:var(--ff-mono);font-size:.63rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.75)}

/* 3R */
.three-r{padding:120px 0;background:var(--c-cream)}
.r-card{border-radius:var(--radius-lg);padding:52px 40px;position:relative;overflow:hidden;transition:transform .35s var(--ease-out),box-shadow .35s}
.r-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.r-card--1{background:var(--c-deep)}
.r-card--2{background:var(--c-forest)}
.r-card--3{background:var(--c-bright)}
.r-card::before{content:attr(data-num);position:absolute;top:-20px;right:-10px;font-family:var(--ff-display);font-size:9rem;font-weight:700;color:rgba(255,255,255,.04);line-height:1;pointer-events:none}
.r-card__icon{font-size:2.8rem;margin-bottom:24px;display:block}
.r-card__title{font-family:var(--ff-display);font-size:2.2rem;font-weight:600;color:#fff;margin-bottom:16px}
.r-card__desc{font-size:.95rem;line-height:1.75;color:rgba(255,255,255,.7);font-weight:300}
.r-card__badge{position:absolute;top:24px;right:24px;font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;padding:5px 12px;border-radius:4px;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.5)}

/* LEGACY */
.legacy{padding:120px 0;background:var(--c-white)}
.legacy__timeline{padding-left:36px;border-left:2px solid var(--c-pale)}
.tl-item{margin-bottom:44px;position:relative}
.tl-item::before{content:'';position:absolute;left:-44px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 0 4px rgba(82,183,136,.2)}
.tl-year{font-family:var(--ff-mono);font-size:.7rem;color:var(--c-accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}
.tl-item h3{font-family:var(--ff-display);font-size:1.3rem;font-weight:600;color:var(--c-ink);margin-bottom:8px}
.tl-item p{font-size:.9rem;color:var(--c-muted);line-height:1.7}

/* WHY US */
.why{padding:120px 0;background:var(--c-deep)}
.why-card{padding:44px 36px;border-right:1px solid rgba(255,255,255,.06);transition:background .3s}
.why-card:last-child{border-right:none}
.why-card:nth-child(4),.why-card:nth-child(5),.why-card:nth-child(6){border-top:1px solid rgba(255,255,255,.06)}
.why-card:hover{background:rgba(116,198,157,.06)}
.why-card__icon{width:48px;height:48px;background:rgba(82,183,136,.1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:20px;border:1px solid rgba(82,183,136,.2)}
.why-card h3{font-family:var(--ff-display);font-size:1.2rem;font-weight:600;color:#fff;margin-bottom:10px}
.why-card p{font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.65;font-weight:300}

/* QUOTE */
.quote-band{padding:100px 0;background:var(--c-forest)}
.quote-band__inner{text-align:center;max-width:820px;margin:0 auto;padding:0 40px}
.quote-mark{font-family:var(--ff-display);font-size:6rem;color:rgba(255,255,255,.12);line-height:.6;margin-bottom:24px}
.quote-band blockquote{font-family:var(--ff-display);font-size:clamp(1.4rem,2.5vw,2rem);font-style:italic;font-weight:400;color:#fff;line-height:1.55;margin-bottom:32px}
.quote-band cite{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-glow);font-style:normal}

/* IMPACT */
.impact{padding:120px 0;background:var(--c-cream)}
.impact-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:36px 32px;transition:transform .3s var(--ease-out),box-shadow .3s}
.impact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.impact-card__icon{font-size:2.2rem;margin-bottom:16px}
.impact-card h3{font-family:var(--ff-display);font-size:1.25rem;font-weight:600;color:var(--c-ink);margin-bottom:10px}
.impact-card p{font-size:.88rem;color:var(--c-muted);line-height:1.65}

/* CTA FOOTER */
.cta-footer{padding:120px 0 80px;background:var(--c-deep);text-align:center}
.cta-footer__tagline{font-family:var(--ff-display);font-size:clamp(2.2rem,5vw,4.2rem);font-weight:600;color:#fff;line-height:1.1;margin-bottom:20px}
.cta-footer__tagline em{font-style:italic;color:var(--c-glow)}
.cta-footer__sub{font-size:1.05rem;font-weight:300;color:rgba(255,255,255,.55);max-width:520px;margin:0 auto 48px;line-height:1.75}
.cta-footer__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
.footer{background:var(--c-ink);padding:72px 0 40px;border-top:1px solid rgba(255,255,255,.05)}
.footer__brand-logo{display:flex;align-items:center;gap:10px;font-family:var(--ff-display);font-size:1.4rem;font-weight:600;color:#fff;margin-bottom:16px}
.footer__brand p{font-size:.9rem;color:rgba(255,255,255,.4);line-height:1.7;max-width:280px}
.footer__col h4{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--c-accent);margin-bottom:20px}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer__col ul li a{font-size:.88rem;color:rgba(255,255,255,.45);transition:color .2s}
.footer__col ul li a:hover{color:var(--c-glow)}
.footer__contact-item{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:rgba(255,255,255,.45);line-height:1.6;margin-bottom:12px}
.footer__contact-item .fi{color:var(--c-accent);flex-shrink:0;margin-top:2px}
.footer__bottom{padding-top:32px;border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-top:64px}
.footer__bottom p{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.1em;color:rgba(255,255,255,.2)}
.footer__social{display:flex;gap:12px}
.footer__social a{width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:rgba(255,255,255,.4);transition:border-color .2s,color .2s,background .2s}
.footer__social a:hover{border-color:var(--c-accent);color:var(--c-glow);background:rgba(82,183,136,.08)}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero__content{grid-template-columns:1fr;gap:48px;min-height:auto;padding:calc(var(--nav-h)+40px) 40px 80px}
  .hero__right{flex-direction:row;flex-wrap:wrap;align-items:flex-start;justify-content:flex-start}
  .hero__stat-card{width:160px}
  .gallery__mosaic{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gallery__tile--main{grid-row:auto;grid-column:1/3;height:300px}
  .gallery__tile:not(.gallery__tile--main){height:220px}
}
@media(max-width:768px){
  :root{--nav-h:66px}
  .container{padding:0 20px}
  section{padding:80px 0 !important}
  .products__header{flex-direction:column;align-items:flex-start}
  .stats-band__card{border-right:none;border-bottom:1px solid rgba(255,255,255,.06)}
}
@media(max-width:480px){
  .hero__actions{flex-direction:column}
  .hero__right{display:none}
  .gallery__mosaic{grid-template-columns:1fr}
  .gallery__tile--main{grid-column:auto;height:280px}
  .gallery__tile:not(.gallery__tile--main){height:200px}
}
