/* ============================================================
   CAFREMA portal — built on the NGX Networks Design System
   Foundations (Ubuntu type, spacing, radii 6px, charcoal-tinted
   shadows, motion) come from NGX colors_and_type.css.
   Here we remap the BRAND color onto Cafrema's palette and add
   the warm teal/orange accents a food brand needs.
   ============================================================ */
@import "colors_and_type.css";

:root {
  /* ---- BRAND BLUE → Cafrema blue (overrides NGX blue scale) ---- */
  --ngx-blue-50:  #eff7fd;
  --ngx-blue-100: #dcedfa;
  --ngx-blue-200: #aed5f1;
  --ngx-blue-300: #76b7e6;
  --ngx-blue-400: #3e96d8;
  --ngx-blue-500: #1577c2;   /* ← Cafrema primary */
  --ngx-blue-600: #0e5c99;
  --ngx-blue-700: #0b4878;
  --ngx-blue-800: #093a60;
  --ngx-blue-900: #06294a;

  /* ---- DARK SURFACE → Cafrema navy (footer / hero) ---- */
  --ngx-ink-1000: #0a1b33;
  --ngx-ink-900:  #14294a;   /* Cafrema navy — also heading color */

  /* ---- focus ring retinted to Cafrema blue ---- */
  --shadow-focus: 0 0 0 3px rgba(21, 119, 194, 0.28);

  /* ---- Cafrema warm accents (teal + orange) ---- */
  --cf-teal-50:  #e5f9f9;
  --cf-teal-100: #c8f2f3;
  --cf-teal-300: #6fe0e2;
  --cf-teal-500: #1fc6c9;   /* secondary */
  --cf-teal-600: #16aaad;
  --cf-teal-700: #0e8c8f;

  --cf-orange-50:  #fceee3;
  --cf-orange-100: #fbddc6;
  --cf-orange-300: #f4a971;
  --cf-orange-500: #e8772e;   /* warm accent */
  --cf-orange-600: #d0631c;
  --cf-orange-700: #b25113;

  --cf-magenta: #e5337e;
  --cf-gold:    #f5b53d;

  /* hero gradient retinted to Cafrema navy→blue */
  --grad-hero: linear-gradient(135deg, #0a1b33 0%, #14294a 42%, #0b4878 100%);
  --grad-brand: linear-gradient(135deg, #1577c2 0%, #0b4878 100%);

  --maxw: 1200px;
}

/* ============================================================ BASE */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; font-family: var(--font-body); color: var(--fg-secondary);
  background: var(--bg-page); font-size: var(--t-body); line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: var(--fg-link); text-decoration: none; }
h1,h2,h3,h4,h5 { margin: 0; color: var(--fg-primary); font-family: var(--font-display); font-weight: var(--w-bold); letter-spacing: var(--ls-tight); line-height: var(--lh-snug); }
p { margin: 0; }
button { font-family: inherit; cursor: pointer; }
ul { margin: 0; padding: 0; list-style: none; }

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
.section { padding-block: clamp(56px, 8vw, 80px); }
.band-soft { background: var(--bg-page-soft); }
.band-navy { background: var(--bg-inverse); color: var(--fg-on-inverse); }

/* eyebrow — NGX style, no decorative mark */
.eyebrow {
  font-family: var(--font-body); font-size: var(--t-eyebrow); font-weight: var(--w-semibold);
  letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--ngx-blue-600);
  display: inline-block; margin-bottom: var(--space-3);
}
.eyebrow.teal { color: var(--cf-teal-700); }
.eyebrow.orange { color: var(--cf-orange-600); }
.eyebrow.on-dark { color: var(--ngx-blue-200); }

.lead { font-size: var(--t-body-lg); line-height: var(--lh-loose); color: var(--fg-secondary); }
.section-title { font-size: var(--t-h2); color: var(--fg-primary); }
.section-head { max-width: 60ch; margin-bottom: var(--space-10); }
.section-head.center { margin-inline: auto; text-align: center; }
.accent-teal { color: var(--cf-teal-600); }
.accent-orange { color: var(--cf-orange-500); }
.accent-blue { color: var(--ngx-blue-500); }

/* ============================================================ BUTTONS */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-weight: var(--w-bold); font-size: var(--t-body-sm);
  letter-spacing: .08em; text-transform: uppercase; line-height: 1;
  padding: 14px 26px; border-radius: var(--radius-md); border: 1px solid transparent;
  transition: background var(--dur-base) var(--ease-standard), border-color var(--dur-base) var(--ease-standard),
              color var(--dur-base) var(--ease-standard), transform var(--dur-quick) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard);
  white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; }
.btn:active { transform: scale(.98); }
.btn-blue { background: var(--ngx-blue-500); color: #fff; box-shadow: var(--shadow-sm); }
.btn-blue:hover { background: var(--ngx-blue-600); }
.btn-teal { background: var(--cf-teal-500); color: #06363a; box-shadow: var(--shadow-sm); }
.btn-teal:hover { background: var(--cf-teal-600); }
.btn-orange { background: var(--cf-orange-500); color: #fff; box-shadow: var(--shadow-sm); }
.btn-orange:hover { background: var(--cf-orange-600); }
.btn-ghost { background: transparent; color: var(--ngx-blue-700); border-color: var(--border-default); }
.btn-ghost:hover { border-color: var(--ngx-blue-400); background: var(--ngx-blue-50); }
.btn-white { background: #fff; color: var(--ngx-ink-900); box-shadow: var(--shadow-sm); }
.btn-white:hover { background: var(--ngx-ink-50); }
.btn-outline-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.btn-outline-light:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.7); }
.btn-lg { padding: 16px 32px; font-size: var(--t-body); }
.btn-block { width: 100%; }

/* ============================================================ HEADER */
.site-header { position: sticky; top: 0; z-index: 100; background: #fff; border-bottom: 1px solid var(--border-subtle); box-shadow: var(--shadow-xs); }
.nav { display: flex; align-items: center; justify-content: space-between; height: 72px; gap: var(--space-6); }
.nav-logo img { height: 34px; width: auto; }
.nav-links { display: flex; align-items: center; gap: clamp(14px, 1.8vw, 26px); }
.nav-links a {
  color: var(--ngx-ink-800); font-weight: var(--w-medium); font-size: var(--t-body-sm);
  position: relative; padding: 26px 0; transition: color var(--dur-base) var(--ease-standard);
}
.nav-links a::after { content: ""; position: absolute; left: 0; right: 0; bottom: 18px; height: 2px; background: var(--cf-teal-500); transform: scaleX(0); transition: transform var(--dur-base) var(--ease-standard); }
.nav-links a:hover { color: var(--ngx-blue-600); }
.nav-links a:hover::after, .nav-links a.active::after { transform: scaleX(1); }
.nav-links a.active { color: var(--ngx-blue-600); }
.nav-right { display: flex; align-items: center; gap: var(--space-4); }

/* EN/ES toggle — NGX pill, functional */
.lang { display: inline-flex; align-items: center; border: 1px solid var(--border-default); border-radius: var(--radius-pill); padding: 2px; font-family: var(--font-mono); font-size: var(--t-tiny); }
.lang button { border: 0; background: transparent; color: var(--fg-tertiary); padding: 4px 10px; border-radius: var(--radius-pill); transition: all var(--dur-base) var(--ease-standard); letter-spacing: .04em; }
.lang button.on { background: var(--ngx-blue-500); color: #fff; }

.burger { display: none; background: transparent; border: 0; padding: 6px; color: var(--ngx-ink-900); }
.burger svg { width: 26px; height: 26px; }

/* mobile drawer */
.m-drawer { position: fixed; inset: 0; z-index: 200; visibility: hidden; pointer-events: none; }
.m-drawer.open { visibility: visible; pointer-events: auto; }
.m-scrim { position: absolute; inset: 0; background: rgba(10,27,51,.55); opacity: 0; transition: opacity var(--dur-base) var(--ease-standard); }
.m-drawer.open .m-scrim { opacity: 1; }
.m-panel { position: absolute; top: 0; right: 0; height: 100%; width: min(86vw, 348px); background: #fff; padding: 20px; transform: translateX(100%); transition: transform var(--dur-slow) var(--ease-emphasized); display: flex; flex-direction: column; gap: 4px; }
.m-drawer.open .m-panel { transform: translateX(0); }
.m-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.m-top img { height: 30px; }
.m-panel a { padding: 14px 6px; font-weight: var(--w-medium); color: var(--ngx-ink-800); border-bottom: 1px solid var(--border-subtle); font-size: var(--t-body); }
.m-panel a.cta { color: var(--ngx-blue-600); font-weight: var(--w-bold); }
.m-close { background: var(--ngx-ink-50); border: 0; border-radius: var(--radius-md); width: 38px; height: 38px; display: grid; place-items: center; color: var(--ngx-ink-800); }

/* ============================================================ CARDS */
.card { background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); transition: box-shadow var(--dur-base) var(--ease-standard), border-color var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard); }
.card:hover { box-shadow: var(--shadow-md); border-color: var(--border-default); }

/* chips */
.chip { display: inline-flex; align-items: center; gap: 6px; height: 26px; padding: 0 12px; border-radius: var(--radius-pill); font-size: var(--t-caption); font-weight: var(--w-medium); background: var(--bg-brand-soft); color: var(--ngx-blue-700); }
.chip.teal { background: var(--cf-teal-50); color: var(--cf-teal-700); }
.chip.orange { background: var(--cf-orange-50); color: var(--cf-orange-700); }

/* ============================================================ FOOTER */
.site-footer { background: var(--ngx-ink-1000); color: var(--ngx-ink-300); }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.4fr; gap: var(--space-10); padding-block: var(--space-20) var(--space-10); }
.footer-grid h4 { color: #fff; font-family: var(--font-body); font-size: var(--t-tiny); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; margin-bottom: var(--space-5); font-weight: var(--w-bold); }
.footer-brand img { height: 38px; margin-bottom: var(--space-5); }
.footer-brand p { font-size: var(--t-body-sm); max-width: 34ch; line-height: var(--lh-loose); color: var(--ngx-ink-400); }
.footer-links a { display: block; color: var(--ngx-ink-300); padding: 6px 0; font-size: var(--t-body-sm); transition: color var(--dur-base) var(--ease-standard); }
.footer-links a:hover { color: var(--cf-teal-300); }
.footer-contact { font-size: var(--t-body-sm); color: var(--ngx-ink-300); }
.footer-contact .row { display: flex; gap: 12px; margin-bottom: 14px; line-height: var(--lh-snug); }
.footer-contact svg { width: 18px; height: 18px; color: var(--cf-teal-500); flex-shrink: 0; margin-top: 2px; }
.footer-contact .row a { color: var(--ngx-ink-300); }
.social { display: flex; gap: 10px; margin-top: var(--space-6); }
.social a { width: 38px; height: 38px; border-radius: var(--radius-md); display: grid; place-items: center; background: rgba(255,255,255,.07); color: #fff; transition: all var(--dur-base) var(--ease-standard); }
.social a:hover { background: var(--cf-teal-500); color: #06363a; }
.social svg { width: 18px; height: 18px; }
.footer-bottom { border-top: 1px solid var(--ngx-ink-700); padding-block: var(--space-6); font-size: var(--t-caption); color: var(--ngx-ink-500); display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }

/* ============================================================ FORMS */
.field { display: flex; flex-direction: column; gap: 7px; }
.field label, .field-label { font-size: var(--t-eyebrow); font-weight: var(--w-semibold); letter-spacing: .06em; text-transform: uppercase; color: var(--fg-tertiary); }
.field input, .field textarea, .field select, .cf-input {
  font-family: var(--font-body); font-size: var(--t-body); padding: 13px 14px;
  border: 1px solid var(--border-default); border-radius: var(--radius-md); background: #fff;
  color: var(--fg-primary); outline: none; width: 100%;
  transition: border-color var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard);
}
.field input:focus, .field textarea:focus, .field select:focus, .cf-input:focus { border-color: var(--ngx-blue-400); box-shadow: var(--shadow-focus); }
.field textarea { resize: vertical; min-height: 120px; }

/* ============================================================ HERO (shared dark) */
.hero { position: relative; overflow: hidden; color: #fff; background: var(--grad-hero); }
.hero .dotgrid { position: absolute; inset: 0; opacity: .3; background-image: radial-gradient(rgba(31,198,201,.4) 1px, transparent 1px); background-size: 30px 30px; -webkit-mask-image: radial-gradient(ellipse 80% 75% at 75% 45%, #000 30%, transparent 80%); mask-image: radial-gradient(ellipse 80% 75% at 75% 45%, #000 30%, transparent 80%); pointer-events: none; }
.hero .glow { position: absolute; border-radius: 50%; pointer-events: none; filter: blur(20px); }

/* page banner (interior pages) */
.banner { background: var(--grad-hero); color: #fff; position: relative; overflow: hidden; }
.banner .dotgrid { position: absolute; inset: 0; opacity: .25; background-image: radial-gradient(rgba(31,198,201,.4) 1px, transparent 1px); background-size: 30px 30px; -webkit-mask-image: radial-gradient(ellipse 70% 90% at 85% 30%, #000 20%, transparent 75%); mask-image: radial-gradient(ellipse 70% 90% at 85% 30%, #000 20%, transparent 75%); }
.banner-in { position: relative; padding-block: clamp(48px, 7vw, 84px); }
.banner h1 { color: #fff; font-size: clamp(36px, 5vw, 52px); line-height: 1.05; }
.banner p { color: var(--ngx-ink-300); margin-top: 14px; max-width: 56ch; font-size: var(--t-body-lg); }

/* ============================================================ REVEAL (capture-safe) */
.reveal { transition: opacity var(--dur-slow) var(--ease-emphasized), transform var(--dur-slow) var(--ease-emphasized); }
html.cf-anim .reveal { opacity: 0; transform: translateY(8px); }
html.cf-anim .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { html.cf-anim .reveal { opacity: 1 !important; transform: none !important; } }

/* ============================================================ RESPONSIVE */
@media (max-width: 920px) {
  .nav-links, .nav-right .lang, .nav-right .btn { display: none; }
  .nav-right .burger { display: inline-flex; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; }
}
