/* =========================================================
   CarnivalPrints — Brand Stylesheet
   A Carnival International Brand
   ========================================================= */

/* ---------- Brand tokens ---------- */
:root{
  --green:#116B38;
  --green-dark:#0B4A26;
  --green-deeper:#073418;
  --orange:#FF6A00;
  --orange-deep:#D85700;
  --ink:#1D1D1D;
  --slate:#4A4A4A;
  --muted:#6E6E6E;
  --cream:#F6EFE2;
  --cream-light:#FBF7EE;
  --soft:#F2F2EE;
  --rule:#D9D2C2;
  --paper:#FFFFFF;
  --shadow-sm:0 2px 8px rgba(17,107,56,.06);
  --shadow-md:0 4px 24px rgba(17,107,56,.08);
  --shadow-lg:0 16px 48px rgba(11,74,38,.12);
  --radius-sm:6px;
  --radius:10px;
  --radius-lg:16px;
  --max:1280px;
  --gutter:24px;
  --section-pad:96px;
  --easing:cubic-bezier(.22,.61,.36,1);
  --font-display:'Fraunces',Georgia,serif;
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,Menlo,monospace;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream-light);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}
ul{list-style:none;padding:0;margin:0}
h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2;color:var(--ink)}
p{margin:0 0 1em}
hr{border:none;border-top:1px solid var(--rule);margin:0}

/* ---------- Type scale ---------- */
.eyebrow{
  font-family:var(--font-sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--green);
  margin-bottom:14px;
}
.eyebrow--orange{color:var(--orange-deep)}
.eyebrow--cream{color:var(--cream)}

.display{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(40px,5.4vw,68px);
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--ink);
}
.display .accent{color:var(--orange)}
.h1{font-family:var(--font-display);font-size:clamp(34px,4vw,52px);line-height:1.1;letter-spacing:-.01em}
.h2{font-family:var(--font-display);font-size:clamp(28px,3vw,40px);line-height:1.15;letter-spacing:-.01em}
.h3{font-family:var(--font-sans);font-size:24px;font-weight:600}
.h4{font-family:var(--font-sans);font-size:18px;font-weight:600}
.lead{font-size:18px;line-height:1.6;color:var(--slate);max-width:62ch}
.muted{color:var(--muted)}
.mono{font-family:var(--font-mono)}

/* ---------- Layout ---------- */
.container{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gutter);
}
.section{padding:var(--section-pad) 0}
.section--sm{padding:64px 0}
.section--cream{background:var(--cream-light)}
.section--paper{background:var(--paper)}
.section--soft{background:var(--cream)}
.section--green{background:var(--green);color:#EAF6EE}
.section--green .h1,.section--green .h2,.section--green .h3{color:#fff}
.section--green .eyebrow{color:#9FD7B2}
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-12{grid-template-columns:repeat(12,1fr)}
.gap-12{gap:12px}.gap-16{gap:16px}.gap-32{gap:32px}.gap-48{gap:48px}

/* ---------- Top utility bar ---------- */
.topbar{
  background:var(--green-deeper);
  color:#D8EAE0;
  font-size:13px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.topbar__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px var(--gutter);
  max-width:var(--max);
  margin:0 auto;
}
.topbar__brand{letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:#fff;font-size:11px}
.topbar__links{display:flex;gap:18px;align-items:center}
.topbar__links a{color:#D8EAE0;display:inline-flex;align-items:center;gap:6px;transition:color .2s}
.topbar__links a:hover{color:var(--orange)}
.topbar__cta{
  background:var(--orange);
  color:#fff !important;
  padding:5px 12px;
  border-radius:var(--radius-sm);
  font-weight:600;
  font-size:12px;
  letter-spacing:.04em;
}
.topbar__cta:hover{background:var(--orange-deep);color:#fff !important}

/* ---------- Header / Nav ---------- */
.header{
  position:sticky;
  top:0;
  z-index:80;
  background:rgba(251,247,238,.92);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid rgba(217,210,194,.5);
  transition:box-shadow .2s;
}
.header.is-scrolled{box-shadow:var(--shadow-sm)}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px var(--gutter);
  max-width:var(--max);
  margin:0 auto;
  gap:24px;
}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:68px;width:auto;mix-blend-mode:multiply}
.nav{display:flex;gap:28px;align-items:center}
.nav a{
  font-size:15px;
  font-weight:500;
  color:var(--ink);
  position:relative;
  padding:8px 2px;
  transition:color .2s;
}
.nav a:hover,.nav a.is-active{color:var(--green)}
.nav a.is-active::after{
  content:'';
  position:absolute;
  bottom:-2px;left:0;right:0;height:2px;
  background:var(--orange);
}
.nav__cta{
  background:var(--orange);
  color:#fff !important;
  padding:11px 18px;
  border-radius:var(--radius-sm);
  font-weight:600 !important;
  font-size:14px !important;
  transition:background .2s,transform .15s;
}
.nav__cta:hover{background:var(--orange-deep);color:#fff !important;transform:translateY(-1px)}
.nav__cta.is-active::after{display:none}

.menu-toggle{
  display:none;
  width:44px;height:44px;
  border:1px solid var(--rule);
  border-radius:var(--radius-sm);
  align-items:center;justify-content:center;
}
.menu-toggle svg{width:22px;height:22px;stroke:var(--ink)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 22px;
  border-radius:var(--radius-sm);
  font-weight:600;
  font-size:15px;
  transition:transform .15s,background .2s,color .2s,box-shadow .2s;
  white-space:nowrap;
  text-align:center;
  justify-content:center;
}
.btn--primary{background:var(--orange);color:#fff}
.btn--primary:hover{background:var(--orange-deep);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--secondary{background:transparent;color:var(--green);border:1.5px solid var(--green)}
.btn--secondary:hover{background:var(--green);color:#fff}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--rule)}
.btn--ghost:hover{border-color:var(--green);color:var(--green)}
.btn--white{background:#fff;color:var(--green)}
.btn--white:hover{background:var(--cream);transform:translateY(-1px)}
.btn--whatsapp{background:#25D366;color:#fff}
.btn--whatsapp:hover{background:#1ea954}
.btn--lg{padding:16px 28px;font-size:16px}
.btn--sm{padding:10px 16px;font-size:13px}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:80px 0 100px;
  background:
    radial-gradient(ellipse 80% 60% at 90% 0%,rgba(255,106,0,.06),transparent 60%),
    radial-gradient(ellipse 60% 50% at 0% 100%,rgba(17,107,56,.08),transparent 60%),
    var(--cream-light);
  overflow:hidden;
}
.hero__inner{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:64px;
  align-items:center;
}
.hero__pre{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.hero__pre::before{content:'';width:32px;height:1.5px;background:var(--orange)}
.hero__pre span{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--green);
}
.hero__title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(40px,5vw,64px);
  line-height:1.05;
  letter-spacing:-.02em;
  margin-bottom:24px;
  color:var(--ink);
}
.hero__title .accent{color:var(--orange);font-style:italic}
.hero__sub{
  font-size:19px;
  line-height:1.6;
  color:var(--slate);
  margin-bottom:36px;
  max-width:54ch;
}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
.hero__trust{
  display:flex;flex-wrap:wrap;gap:18px 24px;
  padding-top:24px;
  border-top:1px solid var(--rule);
}
.hero__trust span{
  font-size:13px;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:8px;
  font-weight:500;
}
.hero__trust span::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--orange);
}
.hero__visual{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--cream) 0%,#EBE0C8 100%);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero__visual::before{
  content:'';
  position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Cpath d='M0 20h40M20 0v40' stroke='%23116B38' stroke-width='.2' stroke-opacity='.05'/%3E%3C/svg%3E");
}
.hero__visual img{
  position:relative;
  max-width:75%;
  max-height:75%;
  filter:drop-shadow(0 30px 60px rgba(11,74,38,.25));
}
.hero__badge{
  position:absolute;
  bottom:24px;left:24px;
  background:#fff;
  padding:14px 18px;
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  display:flex;align-items:center;gap:12px;
}
.hero__badge-icon{
  width:42px;height:42px;border-radius:50%;
  background:var(--green);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;
}
.hero__badge-text strong{display:block;font-size:14px;color:var(--ink)}
.hero__badge-text span{font-size:12px;color:var(--muted)}

/* ---------- Numbers strip ---------- */
.stats{
  background:#fff;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.stats__grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  padding:48px 0;
}
.stats__item{
  text-align:center;
  border-right:1px solid var(--rule);
  padding:8px 16px;
}
.stats__item:last-child{border-right:none}
.stats__num{
  font-family:var(--font-display);
  font-size:48px;
  font-weight:700;
  color:var(--green);
  letter-spacing:-.02em;
  line-height:1;
  margin-bottom:8px;
}
.stats__label{
  font-size:13px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:500;
}

/* ---------- Section heading ---------- */
.sec-head{margin-bottom:48px;max-width:760px}
.sec-head--center{margin:0 auto 48px;text-align:center}
.sec-head h2{
  font-family:var(--font-display);
  font-size:clamp(28px,3.4vw,44px);
  font-weight:600;
  letter-spacing:-.01em;
  margin-bottom:16px;
}
.sec-head p{font-size:18px;color:var(--slate);max-width:62ch}
.sec-head--center p{margin-left:auto;margin-right:auto}

/* ---------- Cards (Solutions) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:#fff;
  border:1px solid var(--rule);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .25s var(--easing),box-shadow .25s var(--easing),border-color .25s;
  display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(17,107,56,.25)}
.card__media{
  aspect-ratio:4/3;
  background:var(--cream);
  position:relative;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.card__media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s var(--easing);
}
.card:hover .card__media img{transform:scale(1.04)}
.card__media--svg{padding:32px}
.card__media--svg svg{width:100%;height:100%}
.card__body{padding:24px;display:flex;flex-direction:column;gap:8px;flex:1}
.card__cat{
  font-size:12px;
  color:var(--orange-deep);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.1em;
}
.card__title{
  font-family:var(--font-display);
  font-size:22px;
  font-weight:600;
  color:var(--ink);
  letter-spacing:-.01em;
  line-height:1.2;
}
.card__desc{
  color:var(--slate);
  font-size:14.5px;
  line-height:1.55;
  margin:0;
}
.card__link{
  margin-top:auto;
  padding-top:12px;
  color:var(--green);
  font-weight:600;
  font-size:14px;
  display:inline-flex;align-items:center;gap:6px;
  transition:gap .2s;
}
.card:hover .card__link{gap:10px;color:var(--orange-deep)}
.card__specs{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-top:6px;
}
.card__spec{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--green);
  background:var(--soft);
  padding:3px 8px;
  border-radius:4px;
}

/* ---------- Industry cards ---------- */
.industries{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.industry{
  position:relative;
  aspect-ratio:5/4;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--green-dark);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;
  color:#fff;
  transition:transform .25s var(--easing);
  cursor:pointer;
}
.industry::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(7,52,24,.92) 90%);
  z-index:1;
}
.industry img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform .5s var(--easing);
}
.industry:hover img{transform:scale(1.05)}
.industry:hover{transform:translateY(-3px)}
.industry__body{position:relative;z-index:2}
.industry__cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#9FD7B2;margin-bottom:8px}
.industry__title{font-family:var(--font-display);font-size:24px;font-weight:600;line-height:1.15;margin-bottom:6px}
.industry__desc{font-size:13px;color:#D8EAE0;line-height:1.5;opacity:.85}

/* ---------- Why us pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.pillar{
  padding:32px 28px;
  background:#fff;
  border:1px solid var(--rule);
  border-radius:var(--radius);
  transition:border-color .2s,transform .2s;
}
.pillar:hover{border-color:var(--orange);transform:translateY(-2px)}
.pillar__icon{
  width:54px;height:54px;
  border-radius:12px;
  background:var(--cream);
  color:var(--green);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
}
.pillar__icon svg{width:28px;height:28px}
.pillar h3{font-family:var(--font-display);font-size:20px;font-weight:600;margin-bottom:10px;color:var(--ink)}
.pillar p{font-size:14.5px;color:var(--slate);line-height:1.6;margin:0}

/* ---------- Craft showcase ---------- */
.craft{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.craft__media{
  aspect-ratio:5/6;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);
  overflow:hidden;position:relative;
  box-shadow:var(--shadow-lg);
}
.craft__media img{width:100%;height:100%;object-fit:cover;opacity:.85}
.craft__stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:16px;margin:32px 0;
  padding:24px;
  background:var(--soft);
  border-radius:var(--radius);
}
.craft__stat strong{
  display:block;
  font-family:var(--font-display);
  font-size:28px;
  color:var(--green);
  font-weight:700;
  line-height:1;margin-bottom:6px;
}
.craft__stat span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}

/* ---------- Export band ---------- */
.export-band{
  background:linear-gradient(135deg,var(--green-dark) 0%,var(--green-deeper) 100%);
  color:#EAF6EE;
  position:relative;
  overflow:hidden;
}
.export-band::before{
  content:'';
  position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M30 0v60M0 30h60' stroke='%23FF6A00' stroke-width='.5' stroke-opacity='.07'/%3E%3C/svg%3E");
  pointer-events:none;
}
.export-band__inner{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:64px;align-items:center;
  position:relative;z-index:1;
}
.export-band h2{color:#fff;margin-bottom:18px}
.export-band p{color:#C7DCCF;font-size:17px;line-height:1.65}
.export-band .ports{
  margin-top:24px;
  display:flex;flex-wrap:wrap;gap:8px;
}
.export-band .ports span{
  font-family:var(--font-mono);
  font-size:12px;
  padding:6px 12px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  border-radius:4px;
  color:#fff;
}
.world-map{
  width:100%;
  height:auto;
  filter:drop-shadow(0 12px 40px rgba(0,0,0,.3));
}

/* ---------- Testimonials ---------- */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tcard{
  padding:32px 28px;
  background:#fff;
  border:1px solid var(--rule);
  border-radius:var(--radius);
  position:relative;
}
.tcard__quote-mark{
  font-family:var(--font-display);
  font-size:54px;
  line-height:1;
  color:var(--orange);
  margin-bottom:10px;
}
.tcard__quote{
  font-family:var(--font-display);
  font-size:18px;
  line-height:1.5;
  color:var(--ink);
  margin-bottom:24px;
}
.tcard__author{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--rule)}
.tcard__avatar{
  width:44px;height:44px;
  border-radius:50%;
  background:var(--green);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:600;font-family:var(--font-display);
}
.tcard__author strong{display:block;font-size:14px;color:var(--ink)}
.tcard__author span{font-size:12px;color:var(--muted)}

/* ---------- Logo wall ---------- */
.logos{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:16px;
}
.logos__item{
  flex:0 0 calc((100% - 80px) / 6);
  min-height:84px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:14px 14px;
  background:#fff;
  border:1px solid var(--rule);
  border-radius:var(--radius-sm);
  letter-spacing:-.01em;
  opacity:.85;
  transition:opacity .2s,transform .2s,border-color .2s,box-shadow .2s;
  text-align:center;
}
.logos__item:hover{
  opacity:1;
  transform:translateY(-2px);
  border-color:var(--green);
  box-shadow:0 6px 18px -10px rgba(17,107,56,.35);
}
.logos__name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:14px;
  line-height:1.25;
  color:var(--ink);
}
.logos__city{
  margin-top:6px;
  font-family:var(--font-sans);
  font-size:10.5px;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orange);
}

/* ---------- Certifications ---------- */
.certs{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.cert{
  aspect-ratio:1/1;
  background:#fff;
  border:1px solid var(--rule);
  border-radius:var(--radius);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:18px 10px;text-align:center;
  transition:border-color .2s,transform .2s;
}
.cert:hover{border-color:var(--green);transform:translateY(-2px)}
.cert__seal{
  width:48px;height:48px;border-radius:50%;
  background:var(--cream);color:var(--green);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:10px;
  font-family:var(--font-display);
  font-weight:700;font-size:13px;
}
.cert__name{font-size:12px;font-weight:600;color:var(--ink);letter-spacing:.02em;line-height:1.3}
.cert__sub{font-size:10px;color:var(--muted);margin-top:4px;letter-spacing:.04em;text-transform:uppercase}

/* ---------- Insights / blog teaser ---------- */
.insights{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.insight{
  background:#fff;
  border:1px solid var(--rule);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .25s,box-shadow .25s;
}
.insight:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.insight__media{aspect-ratio:16/9;background:var(--cream);overflow:hidden}
.insight__media img{width:100%;height:100%;object-fit:cover}
.insight__body{padding:24px}
.insight__cat{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-deep);font-weight:600;margin-bottom:10px}
.insight__title{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--ink);margin-bottom:10px;line-height:1.25}
.insight__meta{font-size:12px;color:var(--muted)}

/* ---------- Inquiry block ---------- */
.inquiry{
  background:var(--cream);
  border-radius:var(--radius-lg);
  padding:64px;
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:64px;
  align-items:center;
}
.inquiry__copy h2{margin-bottom:18px}
.inquiry__copy p{color:var(--slate);font-size:17px;line-height:1.6;margin-bottom:28px}
.inquiry__actions{display:flex;flex-wrap:wrap;gap:14px}
.inquiry__contact{
  margin-top:32px;
  padding-top:24px;
  border-top:1px solid var(--rule);
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.inquiry__contact div{font-size:14px}
.inquiry__contact strong{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.inquiry__contact a{color:var(--ink);font-weight:500}
.inquiry__contact a:hover{color:var(--green)}

/* ---------- Forms ---------- */
.form{display:grid;gap:14px}
.form__grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:.01em}
.field label .req{color:var(--orange);margin-left:2px}
.field input,.field select,.field textarea{
  font:inherit;
  padding:12px 14px;
  border:1.5px solid var(--rule);
  border-radius:var(--radius-sm);
  background:#fff;
  color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
  width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;
  border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(255,106,0,.15);
}
.field textarea{min-height:96px;resize:vertical}
.field--hp{position:absolute;left:-9999px;top:-9999px;opacity:0;pointer-events:none}
.form__submit{margin-top:6px;width:100%;justify-content:center}
.form__notice{
  font-size:12px;color:var(--muted);
  margin-top:8px;line-height:1.5;
}

/* ---------- Footer ---------- */
.footer{
  background:var(--green-deeper);
  color:#C7DCCF;
  padding:80px 0 32px;
}
.footer__top{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__brand img{height:54px;filter:brightness(1.6) contrast(1.1)}
.footer__brand p{color:#9DBEA8;font-size:14px;line-height:1.6;margin-top:18px;max-width:32ch}
.footer__col h4{
  font-family:var(--font-sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#fff;
  margin-bottom:18px;
}
.footer__col ul li{margin-bottom:10px}
.footer__col a{font-size:14px;color:#9DBEA8;transition:color .2s}
.footer__col a:hover{color:var(--orange)}
.footer__contact strong{color:#fff;display:block;font-size:13px;margin-bottom:4px}
.footer__contact p{font-size:13px;color:#9DBEA8;line-height:1.6;margin-bottom:14px}
.footer__bottom{
  padding-top:32px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;
  font-size:12px;color:#7A9988;
}
.footer__bottom strong{color:#fff;font-weight:600}
.footer__compliance{display:flex;gap:18px;flex-wrap:wrap}
.footer__compliance span{font-family:var(--font-mono);font-size:11px;color:#9DBEA8}

/* ---------- WhatsApp floating ---------- */
.wa-float{
  position:fixed;
  bottom:24px;right:24px;
  width:60px;height:60px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.4);
  z-index:90;
  transition:transform .2s,box-shadow .2s;
  cursor:pointer;
  color:#fff;
}
.wa-float:hover{transform:scale(1.08);box-shadow:0 12px 32px rgba(37,211,102,.5)}
.wa-float svg{width:28px;height:28px}
.wa-float__pulse{
  position:absolute;inset:0;
  border-radius:50%;
  background:#25D366;
  opacity:.6;
  animation:wa-pulse 2s ease-out infinite;
  z-index:-1;
}
@keyframes wa-pulse{
  0%{transform:scale(1);opacity:.5}
  100%{transform:scale(1.6);opacity:0}
}

/* ---------- Mobile bottom dock ---------- */
.dock{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  background:#fff;
  border-top:1px solid var(--rule);
  z-index:85;
  padding:8px 0 calc(8px + env(safe-area-inset-bottom));
}
.dock__inner{
  display:grid;grid-template-columns:repeat(3,1fr);
  text-align:center;
}
.dock a{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:8px;
  font-size:11px;font-weight:600;
  color:var(--ink);
  border-right:1px solid var(--rule);
}
.dock a:last-child{border-right:none}
.dock a svg{width:22px;height:22px}
.dock a.is-primary{color:var(--orange)}
.dock a.is-whatsapp{color:#25D366}

/* ---------- Breadcrumb ---------- */
.crumbs{
  font-size:13px;color:var(--muted);
  padding:18px 0;
}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--green)}
.crumbs span{margin:0 8px;color:var(--rule)}

/* ---------- Page hero (interior pages) ---------- */
.pagehero{
  padding:72px 0 48px;
  background:linear-gradient(180deg,var(--cream-light) 0%,#fff 100%);
  border-bottom:1px solid var(--rule);
}
.pagehero__inner{max-width:780px}
.pagehero .eyebrow{margin-bottom:12px}
.pagehero h1{
  font-family:var(--font-display);
  font-size:clamp(36px,4.5vw,56px);
  font-weight:600;line-height:1.05;letter-spacing:-.02em;
  margin-bottom:18px;color:var(--ink);
}
.pagehero .lead{font-size:19px;color:var(--slate);max-width:60ch}

/* ---------- Generic ---------- */
.text-center{text-align:center}
.mb-0{margin-bottom:0}
.mb-md{margin-bottom:24px}
.mb-lg{margin-bottom:48px}
.divider{height:1px;background:var(--rule);margin:48px 0}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .6s ease-out,transform .6s ease-out}
.reveal.is-visible{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  :root{--section-pad:72px}
  .hero__inner{gap:48px}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cards,.tcards,.insights,.pillars{grid-template-columns:repeat(2,1fr)}
  .industries{grid-template-columns:repeat(2,1fr)}
  .logos__item{flex-basis:calc((100% - 48px) / 4)}
  .certs{grid-template-columns:repeat(4,1fr)}
  .footer__top{grid-template-columns:1fr 1fr 1fr;gap:32px}
  .footer__brand{grid-column:1/4}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stats__item{border-right:none;border-bottom:1px solid var(--rule);padding:24px}
  .stats__item:nth-child(odd){border-right:1px solid var(--rule)}
  .stats__item:nth-last-child(-n+2){border-bottom:none}
}

@media (max-width:768px){
  :root{--section-pad:56px;--gutter:20px}
  .topbar{display:none}
  .nav{
    display:none;
    position:fixed;top:97px;left:0;right:0;bottom:0;
    background:var(--cream-light);
    flex-direction:column;
    align-items:stretch;
    padding:24px 20px 32px;
    gap:0;
    overflow-y:auto;
    z-index:95;
  }
  .nav.is-open{display:flex}
  body.menu-open{overflow:hidden}
  body.menu-open .header{
    z-index:100;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:var(--cream-light);
  }
  body.menu-open .wa-float,
  body.menu-open .dock{display:none}
  .nav a{
    padding:16px 0;
    border-bottom:1px solid var(--rule);
    font-size:17px;
  }
  .nav__cta{
    margin-top:16px;
    background:var(--orange);color:#fff !important;
    text-align:center;
  }
  .menu-toggle{display:flex}
  .hero{padding:48px 0 64px}
  .hero__inner{grid-template-columns:1fr;gap:36px}
  .hero__visual{aspect-ratio:1/1;order:-1}
  .hero__title{font-size:36px}
  .hero__sub{font-size:16.5px;margin-bottom:28px}
  .cards,.tcards,.insights,.pillars,.industries{grid-template-columns:1fr}
  .logos__item{flex-basis:calc((100% - 32px) / 3)}
  .certs{grid-template-columns:repeat(3,1fr)}
  .craft,.export-band__inner,.inquiry{grid-template-columns:1fr;gap:32px;padding:32px}
  .inquiry{padding:32px 24px}
  .footer__top{grid-template-columns:1fr 1fr;gap:32px}
  .footer__brand{grid-column:1/3}
  .footer__bottom{flex-direction:column;text-align:center}
  .wa-float{bottom:88px;right:18px;width:54px;height:54px}
  .wa-float svg{width:24px;height:24px}
  .dock{display:block}
  body{padding-bottom:80px}
  .form__grid-2{grid-template-columns:1fr}
  .stats__grid{padding:32px 0}
  .stats__num{font-size:36px}
  .craft__stats{grid-template-columns:1fr;gap:12px;padding:18px}
}

@media (max-width:480px){
  .logos__item{flex-basis:calc((100% - 16px) / 2)}
  .certs{grid-template-columns:repeat(2,1fr)}
}

/* Print niceties */
@media print{
  .header,.topbar,.footer,.wa-float,.dock{display:none}
  body{background:#fff;color:#000}
}
