/* RENOVA — shared stylesheet */
:root{
  --green-900:#0B3D30;
  --green-800:#0F4F3F;
  --green-700:#155B4A;
  --green-600:#1E6E5B;
  --green-300:#7BA89B;
  --green-100:#DDE8E3;
  --green-50:#EEF4F0;
  --cream:#FFFFFF;
  --cream-2:#FFFFFF;
  --ivory:#FFFFFF;
  --paper:#FFFFFF;
  --ink:#0C1A16;
  --ink-60:rgba(12,26,22,0.62);
  --ink-40:rgba(12,26,22,0.38);
  --rule:rgba(12,26,22,0.12);
  --rule-light:rgba(12,26,22,0.06);
  --accent:#C8835B; /* warm terracotta accent */
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--ivory);color:var(--ink);font-family:"Montserrat",system-ui,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%;max-width:100vw;touch-action:pan-y}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
body.is-loading{overflow:hidden}

/* Page loader */
.page-loader{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:#fff;color:var(--green-900);
  transition:opacity .55s cubic-bezier(.4,0,.2,1),visibility .55s cubic-bezier(.4,0,.2,1);
}
.page-loader::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 50% 46%, rgba(126,208,168,.12), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,250,248,.98));
}
.page-loader.is-hidden{opacity:0;visibility:hidden}
.page-loader-inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:22px;
  transform:translateY(-4px);
}
.page-loader-logo{
  width:118px;height:auto;object-fit:contain;
  animation:loaderMark 1.4s cubic-bezier(.4,0,.2,1) infinite alternate;
}
.page-loader-line{
  width:160px;height:2px;border-radius:999px;overflow:hidden;
  background:rgba(11,61,48,.1);
}
.page-loader-line span{
  display:block;width:46%;height:100%;border-radius:inherit;
  background:linear-gradient(90deg, var(--green-900), var(--accent));
  animation:loaderLine 1.05s cubic-bezier(.65,0,.35,1) infinite;
}
.page-loader-text{
  font-family:"Montserrat",sans-serif;font-size:10px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--ink-40);
}
@keyframes loaderMark{
  from{opacity:.55;transform:translateY(2px)}
  to{opacity:1;transform:translateY(-2px)}
}
@keyframes loaderLine{
  0%{transform:translateX(-110%)}
  100%{transform:translateX(235%)}
}

/* Typography system */
.display{font-family:"Montserrat",sans-serif;font-weight:700;letter-spacing:-0.02em;line-height:0.92}
.mono{font-family:"Montserrat",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:0.14em;font-size:11px}
.eyebrow{font-family:"Montserrat",sans-serif;text-transform:uppercase;letter-spacing:0.18em;font-size:11px;color:var(--green-800);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--green-800)}

/* Grain overlay — promoted to its own GPU layer to avoid repaint on scroll */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:100;opacity:.28;mix-blend-mode:multiply;
  will-change:transform;transform:translateZ(0);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.05  0 0 0 0 0.05  0 0 0 0 0.05  0 0 0 0.14 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Header / Nav */
.nav {
  position:fixed;
  top: 16px; left:50%; transform:translateX(-50%);
  width: calc(100% - 32px); max-width: 1300px;
  z-index:50;
  padding: 10px 24px;
  display:flex;align-items:center;justify-content:space-between;
  border-radius: 999px;
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border: 1px solid rgba(255,255,255,0.8);
  box-shadow:0 14px 40px rgba(0,0,0,0.06);
}
.nav .brand{display:flex;align-items:center}
.nav .brand-logo{height:24px;width:auto;object-fit:contain;display:block;transition:height 0.4s}
.nav ul{list-style:none;display:flex;gap:36px;align-items:center}
.nav ul a {
  font-size:13px;font-weight:600;color:var(--ink);
  opacity:.75;transition:opacity .3s, color .3s;
  position: relative;
  padding: 8px 0;
}
.nav ul a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 2px;
  background: var(--green-800);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.nav ul a:hover, .nav ul a.active {
  opacity: 1; color: var(--green-900);
}
.nav ul a:hover::after, .nav ul a.active::after {
  transform: scaleX(1);
  transform-origin: left;
}
.nav .cta {
  background:var(--green-900);
  color:var(--ivory);
  padding:12px 24px 12px 16px;
  border-radius:999px;
  font-size:13px;font-weight:600;
  display:inline-flex;align-items:center;gap:12px;
  transition:all .3s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.nav .cta:hover {
  background:var(--green-800);
  transform:translateY(-2px);
  box-shadow:0 12px 24px rgba(15,79,63,.2);
}
.nav .cta .dot{width:6px;height:6px;border-radius:50%;background:#7ED0A8;box-shadow:0 0 0 4px rgba(126,208,168,.25);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(126,208,168,.25)}50%{box-shadow:0 0 0 7px rgba(126,208,168,0)}}

/* Footer */
footer.site-footer{
  background:var(--green-900);color:var(--cream);padding:140px 44px 36px;position:relative;overflow:hidden;
  border-top:1px solid rgba(255,255,255,0.1);
}
footer.site-footer .bg-type{
  position:absolute;left:-2vw;right:-2vw;bottom:-34px;
  font-family:"Montserrat",sans-serif;font-size:clamp(180px,26vw,440px);line-height:0.8;
  color:rgba(255,255,255,0.02);pointer-events:none;letter-spacing:-0.04em;white-space:nowrap;
  background: linear-gradient(180deg, rgba(255,255,255,0.06) 0%, transparent 80%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
footer.site-footer .top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:60px;position:relative;z-index:1;padding-bottom:100px;
  border-bottom:1px solid rgba(255,255,255,0.1)
}
footer.site-footer h4{
  font-family:"Montserrat",sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:30px;
}
footer.site-footer .pitch{
  font-family:"Montserrat",sans-serif;font-weight:700;font-size:clamp(32px,4.5vw,56px);line-height:1.05;letter-spacing:-0.02em;margin-bottom:40px;max-width:400px;
}
footer.site-footer ul{
  list-style:none;display:flex;flex-direction:column;gap:16px
}
footer.site-footer a{
  font-size:15px;color:rgba(255,255,255,.65);transition:color .3s, transform .3s cubic-bezier(.2,.85,.2,1);display:inline-block;
}
footer.site-footer ul a:hover{
  color:#fff;transform:translateX(6px);
}
footer.site-footer .bottom{
  display:flex;justify-content:space-between;align-items:center;margin-top:28px;font-size:12px;color:rgba(255,255,255,.4);position:relative;z-index:1
}
footer.site-footer .footer-credit{
  position:relative;z-index:1;
  margin-top:22px;padding-top:22px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:"Montserrat",sans-serif;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.42);
}
footer.site-footer .footer-credit a{
  display:inline-flex;align-items:center;opacity:.78;transition:opacity .25s, transform .25s;
}
footer.site-footer .footer-credit a:hover{opacity:1;transform:translateY(-1px)}
footer.site-footer .footer-credit img{
  width:54px;height:auto;display:block;
}
footer.site-footer .contact-line{
  font-size:15px;line-height:1.8;color:rgba(255,255,255,.7);
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  padding: 24px;
  border-radius: 16px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
footer.site-footer .contact-line a{display:inline;transition:color .2s}
footer.site-footer .contact-line a:hover{color:var(--accent);transform:none}

/* Premium Footer CTA */
footer.site-footer .btn-footer{
  display: inline-flex; align-items: center; gap: 16px;
  background: white; color: var(--green-900);
  padding: 14px 20px 14px 34px; border-radius: 999px;
  font-family: "Montserrat", sans-serif; font-size: 16px; letter-spacing: -0.01em; font-weight: 500; text-decoration: none;
  box-shadow: 0 20px 40px rgba(0,0,0,0.2), 0 0 0 0 rgba(255,255,255,0); transition: all 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative; overflow: hidden;
}
footer.site-footer .btn-footer::before {
  content: ""; position: absolute; inset: -50%;
  background: radial-gradient(circle at center, rgba(126,208,168,0.4) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.5s ease; pointer-events: none;
}
footer.site-footer .btn-footer:hover {
  transform: translateY(-4px) scale(1.02);
  color: var(--green-900);
  box-shadow: 0 30px 60px rgba(0,0,0,0.3), 0 0 0 6px rgba(255,255,255,0.08);
}
footer.site-footer .btn-footer:hover::before { opacity: 1; }
footer.site-footer .btn-footer span:first-child { position: relative; z-index: 2; }
footer.site-footer .btn-footer span:last-child {
  position: relative; z-index: 2; display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; background: var(--green-900); color: white; border-radius: 50%;
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1), background 0.3s; margin-left: 10px;
}
footer.site-footer .btn-footer:hover span:last-child {
  transform: translateX(8px) rotate(-15deg); background: var(--green-800);
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:12px;padding:16px 28px;border-radius:100px;font-size:14px;font-weight:500;letter-spacing:-0.01em;transition:all .3s cubic-bezier(.2,.85,.2,1);border:1px solid transparent;box-shadow:0 4px 12px rgba(0,0,0,0.04)}
.btn-primary{background:var(--green-900);color:var(--ivory)}
.btn-primary:hover{background:var(--green-800);transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,79,63,0.15)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--rule);box-shadow:none}
.btn-ghost:hover{background:var(--ink);color:var(--ivory);border-color:var(--ink);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,0.1)}
.btn .arrow{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.16);display:inline-flex;align-items:center;justify-content:center;transition:transform .4s cubic-bezier(.2,.85,.2,1), background .3s, color .3s;font-size:0;color:var(--ivory)}
.btn .arrow::after{content:"";display:block;width:16px;height:16px;background-color:currentColor;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='4' y1='12' x2='20' y2='12'%3E%3C/line%3E%3Cpolyline points='13 5 20 12 13 19'%3E%3C/polyline%3E%3C/svg%3E") no-repeat center;-webkit-mask-size:contain;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='4' y1='12' x2='20' y2='12'%3E%3C/line%3E%3Cpolyline points='13 5 20 12 13 19'%3E%3C/polyline%3E%3C/svg%3E") no-repeat center;mask-size:contain;}
.btn:hover .arrow{transform:rotate(-45deg) scale(1.05)}
.btn-primary:hover .arrow{background:var(--ivory);color:var(--green-900)}
.btn-ghost .arrow{background:var(--rule-light);color:var(--ink)}
.btn-ghost:hover .arrow{background:var(--ink);color:var(--ivory)}

/* Utility */
.container{max-width:1440px;margin:0 auto;padding:0 44px}
.section{padding:140px 44px}
.grid{display:grid}
.rule{height:1px;background:var(--rule)}
.rule-v{width:1px;background:var(--rule);align-self:stretch}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.4s}

/* ===== Modern animation system ===== */

/* Word-by-word title reveal — split done in JS via .anim-words */
.anim-words{display:block}
.anim-words .aw-line{display:inline}
.anim-words .aw-word{display:inline-flex;overflow:hidden;vertical-align:top;line-height:inherit}
.anim-words .aw-inner{
  display:inline-block;transform:translateY(115%);opacity:0;
  transition:transform 1s cubic-bezier(.2,.85,.2,1),opacity .8s ease-out;
}
.anim-words.anim-in .aw-inner{transform:translateY(0);opacity:1}

/* Char-by-char (hero) */
.anim-chars .ac-char{
  display:inline-block;transform:translateY(110%);opacity:0;
  transition:transform .9s cubic-bezier(.2,.85,.2,1),opacity .7s ease-out;
}
.anim-chars.anim-in .ac-char{transform:translateY(0);opacity:1}

/* Image clip-path reveal + Ken Burns zoom */
.anim-img{position:relative;overflow:hidden;display:block;border-radius:18px;
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1s cubic-bezier(.76,0,.24,1);
  will-change:clip-path}
.anim-img.from-left{clip-path:inset(0 0 0 100%)}
.anim-img.from-bottom{clip-path:inset(100% 0 0 0)}
.anim-img.anim-in{clip-path:inset(0 0 0 0)}
.anim-img > img,.anim-img > .ph,.anim-img > .img-bg{
  display:block;width:100%;height:100%;object-fit:cover;
  transform:scale(1.06);
  transition:transform 1.8s cubic-bezier(.16,1,.3,1);
  will-change:transform;
}
.anim-img.anim-in > img,.anim-img.anim-in > .ph,.anim-img.anim-in > .img-bg{transform:scale(1)}

/* Generic up/fade/scale */
.anim-up{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.anim-up.anim-in{opacity:1;transform:none}
.anim-fade{opacity:0;transition:opacity 1.2s cubic-bezier(.4,0,.2,1)}
.anim-fade.anim-in{opacity:1}
.anim-scale{opacity:0;transform:scale(.92);transition:opacity 1s,transform 1.1s cubic-bezier(.2,.85,.2,1)}
.anim-scale.anim-in{opacity:1;transform:none}

/* Stagger delays (stack with anim-in) */
.dly-1{transition-delay:.08s !important}
.dly-2{transition-delay:.16s !important}
.dly-3{transition-delay:.24s !important}
.dly-4{transition-delay:.32s !important}
.dly-5{transition-delay:.4s !important}

/* Magnetic hover only on real cursor devices */
@media (hover: hover) and (pointer: fine){
  .magnetic{transition:transform .4s cubic-bezier(.22,1,.36,1)}
}

/* Image hover zoom (cards) */
.img-hover{overflow:hidden;display:block;position:relative;border-radius:18px}
.img-hover .img-bg,.img-hover img{
  display:block;width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s cubic-bezier(.2,.85,.2,1),filter .6s;
}
.img-hover:hover .img-bg,.img-hover:hover img{transform:scale(1.06)}

/* Background image utility */
.img-bg{background-size:cover;background-position:center;background-repeat:no-repeat}

/* Subtle gradient overlay for hero/section images */
.img-overlay{position:relative}
.img-overlay::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(11,61,48,.55) 100%);pointer-events:none}

/* Fancy underline on hover for inline links */
.link-fx{position:relative;display:inline-block;background-image:linear-gradient(currentColor,currentColor);background-size:0 1px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .5s cubic-bezier(.2,.85,.2,1)}
.link-fx:hover{background-size:100% 1px}

/* Cursor follower completely removed per user request */

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .page-loader,.page-loader-logo,.page-loader-line span{animation:none !important;transition:none !important}
  .page-loader-line span{transform:none;width:100%}
  .anim-words .aw-inner,.anim-chars .ac-char,.anim-up,.anim-fade,.anim-scale,.anim-img,.reveal{transition:none !important;transform:none !important;opacity:1 !important;clip-path:none !important}
  .anim-img > img,.anim-img > .ph,.anim-img > .img-bg{transform:none !important}
}

/* Page intro */
.page-hero{padding:180px 44px 100px;background:var(--paper);position:relative;overflow:hidden;border-bottom:1px solid var(--rule-light)}
.page-hero .crumbs{display:flex;gap:10px;font-family:"Montserrat",sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-60);margin-bottom:40px}
.page-hero h1{font-family:"Montserrat",sans-serif;font-weight:800;font-size:clamp(52px,7vw,108px);line-height:.92;letter-spacing:-0.025em;color:var(--green-900);max-width:1300px}
.page-hero h1 em{font-style:italic;color:var(--green-700)}
.page-hero .lede{margin-top:36px;max-width:620px;font-size:18px;line-height:1.5;color:var(--ink-60)}
.page-hero .meta{position:absolute;right:44px;top:220px;font-family:"Montserrat",sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-40);text-align:right}
.page-hero .meta b{display:block;color:var(--ink);font-weight:400;margin-top:6px}

/* Media placeholder */
.ph{
  background:
    repeating-linear-gradient(135deg, rgba(15,79,63,0.06) 0 2px, transparent 2px 10px),
    linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%);
  border:1px solid var(--rule-light);
  position:relative;overflow:hidden;
}
.ph .ph-label{position:absolute;left:16px;bottom:14px;font-family:"Montserrat",sans-serif;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-60);background:var(--ivory);padding:6px 10px;border:1px solid var(--rule-light)}
.ph.ph-dark{background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 10px),
    linear-gradient(180deg, var(--green-800) 0%, var(--green-900) 100%);
    border-color:rgba(255,255,255,.1)
}
.ph.ph-dark .ph-label{color:rgba(255,255,255,.7);background:rgba(0,0,0,.25);border-color:rgba(255,255,255,.08)}

/* Tag pill */
.tag{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid var(--rule);border-radius:999px;font-family:"Montserrat",sans-serif;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-60)}

/* Table-style data row */
.row{display:grid;grid-template-columns:80px 1fr auto auto;gap:30px;padding:28px 0;border-top:1px solid var(--rule);align-items:center}
.row:last-child{border-bottom:1px solid var(--rule)}
.row .num{font-family:"Montserrat",sans-serif;font-size:12px;color:var(--ink-40)}
.row .ttl{font-family:"Montserrat",sans-serif;font-size:34px;line-height:1;letter-spacing:-0.01em;color:var(--green-900)}
.row .desc{font-size:14px;color:var(--ink-60);max-width:380px}
.row .go{width:44px;height:44px;border-radius:50%;border:1px solid var(--rule);display:inline-flex;align-items:center;justify-content:center;transition:all .3s}
.row:hover .go{background:var(--green-800);color:var(--ivory);border-color:var(--green-800);transform:rotate(-45deg)}

/* Cards */
.card{background:var(--ivory);border:1px solid var(--rule-light);padding:40px;border-radius:24px;transition:transform .4s cubic-bezier(.2,.85,.2,1), box-shadow .4s cubic-bezier(.2,.85,.2,1)}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 60px -20px rgba(12,26,22,.08)}

/* Contact Cards (c-cards) */
.c-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;background:transparent;border:none}
.c-card-link{
  background:#fff;
  border:1px solid var(--rule-light);
  border-radius:24px;
  padding:48px 36px;
  min-height:280px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:border-color .4s, box-shadow .4s;
  color:var(--green-900);
  text-decoration:none;
  position:relative;
  overflow:hidden;
}
.c-card-link::before {
  content:"";position:absolute;inset:-50%;
  background:radial-gradient(circle at center, rgba(126,208,168,0.15) 0%, transparent 60%);
  opacity:0;transition:opacity .5s ease;pointer-events:none;
}
.c-card-link:hover::before {opacity:1}
.c-card-link:hover{
  border-color:var(--rule);
  box-shadow:0 30px 60px -20px rgba(0,0,0,0.06);
}
.c-card-link .k{font-family:"Montserrat",sans-serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-60);margin-bottom:14px;transition:color .3s}
.c-card-link .v{font-family:"Montserrat",sans-serif;font-size:clamp(18px,2.2vw,28px);color:var(--green-900);letter-spacing:-0.01em;line-height:1.15;transition:color .3s;white-space:nowrap}
.c-card-link .go{margin-top:20px;font-family:"Montserrat",sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--green-600);transition:transform .3s;}
.c-card-link:hover .go{transform:translateX(6px);}

/* Marquee — GPU-composited via will-change */
.marquee{overflow:hidden;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:22px 0;background:var(--paper)}
.marquee-track{display:flex;gap:60px;animation:scroll 17s linear infinite;white-space:nowrap;will-change:transform}
.marquee-track span{font-family:"Montserrat",sans-serif;font-size:32px;color:var(--green-800);display:inline-flex;align-items:center;gap:60px}
.marquee-track span::after{content:"✦";color:var(--green-600);margin-left:60px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== Nav burger ===== */
.nav-right{display:flex;align-items:center;gap:14px}
.nav-burger {
  display:none;
  width:44px;height:44px;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  background:var(--green-900);border-radius:50%;
  cursor:pointer;flex-shrink:0;
  transition:transform .3s ease;
}
.nav-burger:hover {
  transform:scale(1.05);
}
.nav-burger span {
  display:block;width:18px;height:1.5px;background:#fff;border-radius:2px;
  transition:all .3s cubic-bezier(.2,.85,.2,1);
}
.nav-burger span:nth-child(2) {
  width:12px;transform:translateX(3px);
}
.nav-burger:hover span:nth-child(2) {
  width:18px;transform:translateX(0);
}

/* ===== Mobile fullscreen menu ===== */
.nav-mobile{
  display:flex;
  position:fixed;inset:0;z-index:60;
  background:rgba(11,61,48,0.92);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  flex-direction:column;
  visibility:hidden;opacity:0;
  transform:translateY(-100%);
  border-radius: 0 0 40px 40px;
  transition:visibility 0s linear .5s, opacity .5s cubic-bezier(.4,0,.2,1), transform .5s cubic-bezier(.4,0,.2,1), border-radius .5s;
  pointer-events:none;
}
.nav-mobile.open{
  visibility:visible;opacity:1;transform:none;
  border-radius: 0;
  transition-delay:0s;
  pointer-events:auto;
}

/* Menu header */
.nav-mobile-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;
  flex-shrink:0;
}
.nav-mobile-logo{
  height:28px;width:auto;object-fit:contain;
  filter:brightness(0) invert(1);
  opacity:.95;
}
.nav-mobile-close{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  color:rgba(255,255,255,.8);font-size:15px;line-height:1;
  transition:background .2s,border-color .2s;
  flex-shrink:0;
}
.nav-mobile-close:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15)}

/* Divider */
.nav-mobile-divider{
  height:1px;background:rgba(255,255,255,.08);margin:0 24px;flex-shrink:0;
}

/* Links */
.nav-mobile-links{
  flex:1;display:flex;flex-direction:column;justify-content:center;
  padding:10px 24px 20px;
  overflow-y:auto;
}
.nav-mobile-links a{
  display:flex;align-items:center;gap:0;
  padding:15px 0;
  font-family:"Montserrat",sans-serif;font-size:clamp(24px,6.5vw,36px);font-weight:700;
  color:rgba(255,255,255,.65);
  letter-spacing:-0.025em;
  border-bottom:1px solid rgba(255,255,255,.07);
  opacity: 0; transform: translateY(20px);
  transition:color .3s, padding-left .4s cubic-bezier(.2,.85,.2,1), opacity 0.5s, transform 0.5s cubic-bezier(.2,.85,.2,1);
  position:relative;
}
.nav-mobile.open .nav-mobile-links a {
  opacity: 1; transform: none;
}
.nav-mobile.open .nav-mobile-links a:nth-child(1) { transition-delay: 0.1s; }
.nav-mobile.open .nav-mobile-links a:nth-child(2) { transition-delay: 0.15s; }
.nav-mobile.open .nav-mobile-links a:nth-child(3) { transition-delay: 0.2s; }
.nav-mobile.open .nav-mobile-links a:nth-child(4) { transition-delay: 0.25s; }
.nav-mobile.open .nav-mobile-links a:nth-child(5) { transition-delay: 0.3s; }
.nav-mobile.open .nav-mobile-links a:nth-child(6) { transition-delay: 0.35s; }
.nav-mobile.open .nav-mobile-links a:nth-child(7) { transition-delay: 0.4s; }

.nav-mobile-links a:first-child{border-top:1px solid rgba(255,255,255,.07)}
.nav-mobile-num{
  font-family:"Montserrat",sans-serif;font-size:10px;letter-spacing:.12em;
  color:rgba(255,255,255,.28);
  min-width:36px;margin-top:2px;
  transition:color .2s;
}
.nav-mobile-links a .nav-mobile-arrow{
  margin-left:auto;font-size:13px;
  color:rgba(255,255,255,.2);
  transition:color .2s,transform .3s cubic-bezier(.2,.85,.2,1);
}
.nav-mobile-links a:hover,
.nav-mobile-links a.active{
  color:#fff;padding-left:10px;
}
.nav-mobile-links a:hover .nav-mobile-arrow,
.nav-mobile-links a.active .nav-mobile-arrow{
  color:var(--green-300);transform:translateX(5px) rotate(-45deg);
}
.nav-mobile-links a.active .nav-mobile-num{color:var(--green-300)}

/* Mobile Footer */
.nav-mobile-footer{
  padding:20px 24px 28px;flex-shrink:0;
}
.nav-mobile-cta{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:16px 18px 16px 22px;
  border-radius:14px;
  background:#fff;color:var(--green-900);
  font-family:"Montserrat",sans-serif;font-size:15px;font-weight:700;
  letter-spacing:-0.01em;
  opacity: 0; transform: translateY(20px);
  transition:opacity 0.5s, transform 0.5s cubic-bezier(.2,.85,.2,1);
}
.nav-mobile.open .nav-mobile-cta {
  opacity: 1; transform: none; transition-delay: 0.4s;
}
.nav-mobile-cta-arrow{
  width:38px;height:38px;background:var(--green-900);color:#fff;
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:16px;transition:transform .25s;flex-shrink:0;
}
.nav-mobile-cta:hover .nav-mobile-cta-arrow{transform:rotate(-45deg)}
.nav-mobile-contact{
  display:flex;justify-content:space-between;
  margin-top:14px;
  font-family:"Montserrat",sans-serif;font-size:11px;letter-spacing:.03em;
  color:rgba(255,255,255,.38);
}
.nav-mobile-contact a{transition:color .2s}
.nav-mobile-contact a:hover{color:rgba(255,255,255,.8)}

/* ===== Responsive ===== */
@media (max-width:900px){
  /* Contact Cards */
  .c-cards{grid-template-columns:1fr}
  .c-cards .v{white-space:normal;font-size:20px}

  /* Nav */
  .nav.scrolled {
    width: calc(100% - 24px);
    padding: 12px 18px;
    top: 12px;
  }
  .nav{padding:14px 18px}
  .nav .brand{font-size:22px}
  .nav .brand .mark{width:24px;height:24px}
  .nav ul{display:none}
  .nav .cta{display:none}
  .nav-burger{display:flex}

  /* Page hero */
  .page-hero{padding:120px 24px 60px}
  .page-hero h1{font-size:clamp(44px,12vw,72px)}
  .page-hero .lede{font-size:16px;margin-top:24px;line-height:1.6}
  .page-hero .meta{display:none}
  .page-hero .crumbs{font-size:10px;margin-bottom:24px;flex-wrap:wrap}

  /* Sections */
  .section{padding:80px 24px}
  .container{padding:0 24px;max-width:100%}

  /* Marquee */
  .marquee{padding:14px 0}
  .marquee-track{gap:32px}
  .marquee-track span{font-size:18px;gap:32px}
  .marquee-track span::after{margin-left:32px}

  /* Row component */
  .row{grid-template-columns:40px 1fr 34px;gap:12px;padding:24px 0}
  .row .desc{display:none}
  .row .ttl{font-size:20px}

  /* Footer */
  footer.site-footer{padding:80px 24px 32px}
  footer.site-footer .top{grid-template-columns:1fr;gap:50px;padding-bottom:50px}
  footer.site-footer .pitch{font-size:clamp(32px,10vw,48px);line-height:1}
  footer.site-footer .btn-footer{padding:12px 16px 12px 24px;font-size:14px;width:100%;justify-content:space-between}
  footer.site-footer .bottom{flex-direction:column;gap:20px;text-align:center;font-size:12px;opacity:0.6}
  footer.site-footer .footer-credit{margin-top:20px;font-size:10px;gap:9px}
  footer.site-footer .footer-credit img{width:48px}
  footer.site-footer .contact-line{padding:20px}
  footer.site-footer .bg-type{font-size:120px;bottom:-10px}

  /* Buttons */
  .btn{padding:16px 24px;font-size:14px;gap:10px}
  .btn .arrow{width:26px;height:26px}

  /* Tag */
  .tag{font-size:9px;padding:6px 10px}

  /* Reveal — smaller offset on mobile */
  .reveal{transform:translateY(14px)}

  /* Tighter, faster animations on mobile */
  .anim-words .aw-inner{transition-duration:.6s}
  .anim-up{transform:translateY(16px);transition-duration:.6s}
  .anim-img{transition-duration:.8s}
  .anim-img > img,.anim-img > .ph,.anim-img > .img-bg{transform:scale(1.04);transition-duration:1.2s}

  /* No magnetic / cursor on mobile */
  .magnetic{transform:none !important}
  .cursor-dot{display:none !important}
}

@media (max-width:1180px) and (min-width:901px){
  .nav{padding:10px 18px}
  .nav ul{gap:18px}
  .nav ul a{font-size:12px}
  .nav .cta{padding:10px 16px 10px 14px;font-size:12px}
  .nav .cta .dot{width:5px;height:5px}
}
