/* Notaría Castejón — theme.css
 * Single bundled stylesheet for the WordPress theme.
 * = colors_and_type.css (design tokens + base type + buttons + forms + cards + badges)
 * + responsive.css       (mobile/tablet overrides via [data-comp] hooks)
 * + theme-only additions (WP-specific overrides at the bottom)
 */

/* ============================================================
   Notaría Castejón — Foundations
   Single source of truth for color, type, spacing, motion.
   Link this once in <head>; everything else reads from here.
   ============================================================ */

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

:root {
  /* ---------- Color: paper & ink ---------- */
  --bone-50:  #FAF6EE;   /* page bg */
  --bone-100: #F1EADC;   /* alt section bg */
  --bone-200: #E9E0CC;   /* deep paper */
  --ivory:    #FFFEFB;   /* card / input bg */
  --border:   #E5DCC9;   /* hairline on bone */
  --border-strong: #D4C8AC;

  --ink-900: #0B1A2B;    /* primary ink — headlines, primary btn, footer */
  --ink-800: #142436;
  --ink-700: #1F3147;    /* body */
  --ink-500: #4A5A6E;    /* secondary */
  --ink-400: #6B7889;
  --ink-300: #8A95A4;    /* tertiary, disabled */
  --ink-200: #B8C0CB;

  /* ---------- Color: accent ---------- */
  --brass-700: #7C6438;
  --brass-500: #A6864E;  /* THE accent — use sparingly */
  --brass-400: #BFA06B;  /* hover */
  --brass-100: #EFE3C8;  /* tint bg, eyebrow chip */

  /* ---------- Color: semantic ---------- */
  --success-700: #2E7D5B;
  --success-100: #DDEBE2;
  --warning-700: #B8853A;
  --warning-100: #F4E7CE;
  --error-700:   #A8443A;
  --error-100:   #F0D8D4;

  /* ---------- Semantic role aliases ---------- */
  --color-bg:           var(--bone-50);
  --color-bg-alt:       var(--bone-100);
  --color-surface:      var(--ivory);
  --color-surface-ink:  var(--ink-900);
  --color-text:         var(--ink-700);
  --color-text-strong:  var(--ink-900);
  --color-text-muted:   var(--ink-500);
  --color-text-faint:   var(--ink-300);
  --color-text-inverse: var(--bone-50);
  --color-border:       var(--border);
  --color-border-strong:var(--border-strong);
  --color-accent:       var(--brass-500);
  --color-accent-hover: var(--brass-400);
  --color-focus:        var(--brass-500);

  /* ---------- Typography ---------- */
  --font-display: 'Spectral', 'Source Serif 4', 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Manrope', 'Söhne', 'Helvetica Neue', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', 'IBM Plex Mono', ui-monospace, monospace;

  /* Type scale (modular, 1.250 minor third on desktop, 1.200 on mobile) */
  --text-xs:   12px;
  --text-sm:   14px;
  --text-base: 16px;
  --text-md:   18px;
  --text-lg:   20px;
  --text-xl:   24px;
  --text-2xl:  30px;
  --text-3xl:  38px;
  --text-4xl:  48px;
  --text-5xl:  60px;
  --text-6xl:  76px;

  --leading-tight:  1.12;
  --leading-snug:   1.28;
  --leading-normal: 1.55;
  --leading-relaxed:1.7;

  --tracking-tight:  -0.02em;
  --tracking-normal: 0;
  --tracking-wide:   0.06em;
  --tracking-eyebrow:0.18em;

  /* ---------- Spacing scale (4px base) ---------- */
  --space-0:   0;
  --space-1:   4px;
  --space-2:   8px;
  --space-3:   12px;
  --space-4:   16px;
  --space-5:   20px;
  --space-6:   24px;
  --space-7:   32px;
  --space-8:   40px;
  --space-9:   48px;
  --space-10:  64px;
  --space-11:  80px;
  --space-12:  96px;
  --space-13:  128px;
  --space-14:  160px;

  /* ---------- Radii ---------- */
  --radius-sm:   4px;   /* inputs, small buttons */
  --radius-md:   6px;   /* cards, large buttons */
  --radius-lg:  10px;   /* modals, hero images */
  --radius-xl:  16px;   /* rarely used */
  --radius-pill: 999px; /* chips only */

  /* ---------- Shadows (warm-tinted, never gray) ---------- */
  --shadow-1: 0 1px 2px rgba(11,26,43,0.04), 0 1px 1px rgba(11,26,43,0.03);
  --shadow-2: 0 4px 12px rgba(11,26,43,0.06), 0 2px 4px rgba(11,26,43,0.04);
  --shadow-3: 0 24px 48px rgba(11,26,43,0.14), 0 8px 16px rgba(11,26,43,0.08);
  --shadow-focus: 0 0 0 2px var(--bone-50), 0 0 0 4px var(--brass-500);

  /* ---------- Layout ---------- */
  --container:        1200px;
  --container-narrow:  840px;   /* blog post column */
  --container-wide:   1320px;   /* hero + nav max */
  --gutter:            24px;
  --page-pad:          32px;

  /* ---------- Motion ---------- */
  --ease-quiet:    cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --dur-hover:   120ms;
  --dur-focus:   200ms;
  --dur-reveal:  320ms;

  /* ---------- Z layers ---------- */
  --z-nav:    50;
  --z-modal:  100;
  --z-toast:  150;
}

/* ============================================================
   Base
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* ============================================================
   Typography
   ============================================================ */

h1, h2, h3, h4, h5, .display, .h1, .h2, .h3, .h4, .h5 {
  font-family: var(--font-display);
  color: var(--color-text-strong);
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  margin: 0;
}

/* Opt-in balanced text — apply via class, not globally, to avoid layout-shift bugs */
.balance { text-wrap: balance; }

.display, h1, .h1 {
  font-size: var(--text-5xl);
  font-weight: 400;
  letter-spacing: -0.025em;
  line-height: 1.05;
}
h2, .h2 { font-size: var(--text-4xl); font-weight: 500; line-height: 1.1; }
h3, .h3 { font-size: var(--text-2xl); font-weight: 500; line-height: 1.2; }
h4, .h4 { font-size: var(--text-xl);  font-weight: 600; line-height: 1.25; }
h5, .h5 { font-size: var(--text-md);  font-weight: 600; line-height: 1.3;  font-family: var(--font-body); letter-spacing: 0; }

@media (max-width: 640px) {
  .display, h1, .h1 { font-size: var(--text-4xl); }
  h2, .h2 { font-size: var(--text-3xl); }
  h3, .h3 { font-size: var(--text-xl); }
}

p { margin: 0 0 var(--space-4) 0; text-wrap: pretty; }
p.lead { font-size: var(--text-md); line-height: var(--leading-relaxed); color: var(--ink-700); }

small, .caption { font-size: var(--text-sm); color: var(--color-text-muted); line-height: var(--leading-snug); }
.micro { font-size: var(--text-xs); color: var(--color-text-muted); }

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--brass-500);
  margin: 0 0 var(--space-3) 0;
  display: inline-block;
}

.serif       { font-family: var(--font-display); }
.sans        { font-family: var(--font-body); }
.mono        { font-family: var(--font-mono); font-size: 0.92em; }

a {
  color: var(--ink-900);
  text-decoration: none;
  border-bottom: 1px solid var(--brass-500);
  padding-bottom: 1px;
  transition: border-color var(--dur-hover) var(--ease-quiet);
}
a:hover { border-bottom-color: var(--brass-400); border-bottom-width: 2px; padding-bottom: 0; }

/* Inline legal references (e.g. art. 1.462 CC) */
.ref {
  font-family: var(--font-mono);
  font-size: 0.88em;
  color: var(--ink-500);
  white-space: nowrap;
}

/* Section sign ornament */
.ornament {
  font-family: var(--font-display);
  color: var(--brass-500);
  font-size: 1.4em;
  line-height: 1;
}

/* ============================================================
   Focus
   ============================================================ */

:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--brass-500);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ============================================================
   Buttons
   ============================================================ */

.btn {
  --btn-bg: var(--ink-900);
  --btn-fg: var(--bone-50);
  --btn-border: var(--ink-900);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1;
  padding: 14px 22px;
  min-height: 48px;
  border-radius: var(--radius-md);
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--btn-border);
  cursor: pointer;
  transition: background var(--dur-hover) var(--ease-quiet),
              transform var(--dur-hover) var(--ease-quiet),
              box-shadow var(--dur-hover) var(--ease-quiet),
              border-color var(--dur-hover) var(--ease-quiet);
  text-decoration: none;
  white-space: nowrap;
}
.btn:hover  { background: var(--ink-800); border-color: var(--ink-800); }
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline-offset: 3px; }

.btn--secondary {
  --btn-bg: transparent;
  --btn-fg: var(--ink-900);
  --btn-border: var(--ink-900);
}
.btn--secondary:hover { background: var(--ink-900); color: var(--bone-50); }

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--ink-900);
  --btn-border: transparent;
  padding-left: 12px;
  padding-right: 12px;
}
.btn--ghost:hover { background: var(--bone-100); border-color: var(--bone-100); }

.btn--brass {
  --btn-bg: var(--brass-500);
  --btn-fg: var(--ivory);
  --btn-border: var(--brass-500);
}
.btn--brass:hover { background: var(--brass-700); border-color: var(--brass-700); }

.btn[disabled], .btn[aria-disabled="true"] {
  background: var(--bone-100);
  color: var(--ink-300);
  border-color: var(--border);
  cursor: not-allowed;
  pointer-events: none;
}

.btn--sm { min-height: 36px; padding: 8px 14px; font-size: var(--text-xs); }
.btn--lg { min-height: 56px; padding: 18px 28px; font-size: var(--text-base); }

/* ============================================================
   Form fields
   ============================================================ */

.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--ink-900);
  letter-spacing: 0.005em;
}
.field .hint { font-size: var(--text-xs); color: var(--ink-500); }
.field .error-msg { font-size: var(--text-xs); color: var(--error-700); }

.input, .textarea, .select {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--ink-900);
  background: var(--ivory);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  min-height: 48px;
  width: 100%;
  transition: border-color var(--dur-hover) var(--ease-quiet),
              box-shadow var(--dur-hover) var(--ease-quiet);
}
.input::placeholder, .textarea::placeholder { color: var(--ink-300); }
.input:hover, .textarea:hover, .select:hover { border-color: var(--ink-500); }
.input:focus-visible, .textarea:focus-visible, .select:focus-visible {
  border-color: var(--brass-500);
  box-shadow: 0 0 0 3px rgba(166,134,78,0.18);
  outline: none;
}
.textarea { min-height: 120px; resize: vertical; padding: 12px 14px; line-height: 1.55; }

.input[aria-invalid="true"] { border-color: var(--error-700); }
.input[aria-invalid="true"]:focus-visible {
  box-shadow: 0 0 0 3px rgba(168,68,58,0.18);
}

.input[disabled], .textarea[disabled] {
  background: var(--bone-100);
  color: var(--ink-300);
  cursor: not-allowed;
}

/* ============================================================
   Card
   ============================================================ */

.card {
  background: var(--ivory);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-7);
  box-shadow: var(--shadow-1);
  transition: box-shadow var(--dur-hover) var(--ease-quiet),
              transform var(--dur-hover) var(--ease-quiet);
}
.card--hover:hover { box-shadow: var(--shadow-2); }
.card__eyebrow { font-family: var(--font-display); color: var(--brass-500); font-size: 22px; line-height: 1; }

/* ============================================================
   Container & layout helpers
   ============================================================ */

.container { max-width: var(--container); margin-inline: auto; padding-inline: var(--page-pad); }
.container--narrow { max-width: var(--container-narrow); margin-inline: auto; padding-inline: var(--page-pad); }
.container--wide   { max-width: var(--container-wide);   margin-inline: auto; padding-inline: var(--page-pad); }

@media (max-width: 640px) {
  .container, .container--narrow, .container--wide { padding-inline: 16px; }
}

.section { padding-block: var(--space-13); }
.section--tight { padding-block: var(--space-11); }
@media (max-width: 640px) {
  .section { padding-block: var(--space-11); }
  .section--tight { padding-block: var(--space-10); }
}

.divider { border: 0; border-top: 1px solid var(--border); margin: 0; }

/* ============================================================
   Badges / status chips
   ============================================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--bone-100);
  color: var(--ink-700);
  border: 1px solid var(--border);
}
.badge--brass   { background: var(--brass-100); color: var(--brass-700); border-color: transparent; }
.badge--success { background: var(--success-100); color: var(--success-700); border-color: transparent; }
.badge--warning { background: var(--warning-100); color: var(--warning-700); border-color: transparent; }
.badge--error   { background: var(--error-100);   color: var(--error-700);   border-color: transparent; }
.badge__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* ============================================================
   Reduced motion
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}


/* ============================================================
   responsive.css
   Overrides for mobile/tablet. Uses !important to win over the
   inline styles used in our JSX components.
   Breakpoints:
     XL  ≥ 1280  full layouts
     LG  1024–1279
     MD   768–1023  tablet
     SM   640– 767  large phone
     XS   < 640    phone
   ============================================================ */

/* ---------- Section padding ---------- */
@media (max-width: 1023px) {
  [data-comp="hero"],
  [data-comp="services"],
  [data-comp="process"],
  [data-comp="about"],
  [data-comp="blog"],
  [data-comp="cta"],
  [data-comp="contact"] {
    padding-block: 80px !important;
  }
}
@media (max-width: 640px) {
  [data-comp="hero"],
  [data-comp="services"],
  [data-comp="process"],
  [data-comp="about"],
  [data-comp="blog"],
  [data-comp="cta"],
  [data-comp="contact"] {
    padding-block: 64px !important;
  }
}

/* ---------- Header ---------- */
@media (max-width: 1023px) {
  [data-comp="header-links"] { display: none !important; }
  [data-comp="header-lang"]  { display: none !important; }
  [data-comp="header-burger"]{ display: inline-flex !important; }
  [data-comp="header"] > div { gap: 12px !important; }
}
@media (max-width: 640px) {
  [data-comp="header"] > div {
    padding: 12px 16px !important;
  }
  [data-comp="header"] img { height: 36px !important; }
  [data-comp="header-cta"]  { display: none !important; }
}

/* ---------- Hero ---------- */
@media (max-width: 1023px) {
  [data-comp="hero-inner"] {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
  /* On tablet, push the photograph below the headline */
  [data-comp="hero-inner"] > figure {
    max-width: 460px;
    width: 100%;
    margin-inline: 0;
  }
}
@media (max-width: 640px) {
  [data-comp="hero-inner"] {
    gap: 36px !important;
  }
  [data-comp="hero"] h1 {
    font-size: clamp(36px, 9vw, 48px) !important;
  }
  [data-comp="hero-inner"] > div > div:last-child {
    /* meta row: stack */
    flex-direction: column !important;
    gap: 16px !important;
  }
}

/* ---------- Trust strip ---------- */
@media (max-width: 768px) {
  [data-comp="trust-inner"] {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
}

/* ---------- Services ---------- */
@media (max-width: 1023px) {
  [data-comp="services-head"] {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    margin-bottom: 36px !important;
  }
  [data-comp="services-grid"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 640px) {
  [data-comp="services-grid"] {
    grid-template-columns: 1fr !important;
  }
  [data-comp="services"] h2 { font-size: 36px !important; }
}

/* ---------- Process ---------- */
@media (max-width: 1023px) {
  [data-comp="process-head"] {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    margin-bottom: 32px !important;
  }
}
@media (max-width: 768px) {
  [data-comp="process-grid"] {
    grid-template-columns: 1fr !important;
  }
  [data-comp="process"] h2 { font-size: 36px !important; }
}

/* ---------- About ---------- */
@media (max-width: 1023px) {
  [data-comp="about-inner"] {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
  [data-comp="about-inner"] > figure {
    max-width: 420px;
    margin-inline: 0;
  }
  [data-comp="about"] h2 { font-size: 40px !important; }
}
@media (max-width: 640px) {
  [data-comp="about"] h2 { font-size: 34px !important; }
  [data-comp="about-inner"] > div:last-child > div:last-child {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ---------- Blog ---------- */
@media (max-width: 768px) {
  [data-comp="blog"] article {
    grid-template-columns: 1fr auto !important;
    gap: 16px !important;
    align-items: start !important;
  }
  [data-comp="blog"] article > div:first-child {
    grid-column: 1 / -1 !important;
    margin-bottom: -8px;
  }
  [data-comp="blog"] h2 { font-size: 36px !important; }
  [data-comp="blog"] h3 { font-size: 22px !important; }
}

/* ---------- AppointmentCTA ---------- */
@media (max-width: 1023px) {
  [data-comp="cta-inner"] {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
  [data-comp="cta"] h2 { font-size: 44px !important; }
}
@media (max-width: 640px) {
  [data-comp="cta"] h2 { font-size: 34px !important; }
  [data-comp="cta"] form { padding: 22px !important; }
  [data-comp="cta"] form > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }
}

/* ---------- Contact ---------- */
@media (max-width: 1023px) {
  [data-comp="contact-inner"] {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
  [data-comp="contact"] h2 { font-size: 36px !important; }
}

/* ---------- Footer ---------- */
@media (max-width: 1023px) {
  [data-comp="footer-grid"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 36px !important;
  }
  [data-comp="footer-grid"] > div:first-child {
    grid-column: 1 / -1;
  }
}
@media (max-width: 640px) {
  [data-comp="footer-grid"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  [data-comp="footer"] > div > div:last-child {
    flex-direction: column !important;
    gap: 8px !important;
    align-items: flex-start !important;
  }
}

/* ---------- Pricing / Aranceles ---------- */
@media (max-width: 1023px) {
  [data-comp="pricing-grid"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  [data-comp="pricing"] h2 { font-size: 42px !important; }
}
@media (max-width: 640px) {
  [data-comp="pricing"] h2 { font-size: 34px !important; }
}

/* ---------- Standalone contact-page form ---------- */
@media (max-width: 1023px) {
  [data-comp="contact-page"] {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
}
@media (max-width: 640px) {
  [data-comp="contact-page-row"] {
    grid-template-columns: 1fr !important;
  }
}



/* ============================================================
   WordPress-specific additions
   ============================================================ */

/* Admin bar offset */
body.admin-bar [data-comp="header"] { top: 32px; }
@media (max-width: 782px) {
  body.admin-bar [data-comp="header"] { top: 46px; }
}

/* WordPress core block alignments */
.alignleft   { float: left;  margin-right: var(--space-6); margin-bottom: var(--space-4); }
.alignright  { float: right; margin-left:  var(--space-6); margin-bottom: var(--space-4); }
.aligncenter { display: block; margin-inline: auto; margin-bottom: var(--space-4); }
.alignfull   { width: 100%; }
.alignwide   { max-width: var(--container-wide); margin-inline: auto; }

.screen-reader-text {
  border: 0; clip: rect(1px,1px,1px,1px); -webkit-clip-path: inset(50%); clip-path: inset(50%);
  height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute;
  word-wrap: normal !important;
}
.screen-reader-text:focus {
  background: var(--bone-50); color: var(--ink-900);
  clip: auto !important; -webkit-clip-path: none; clip-path: none;
  display: block; font-weight: 600; height: auto; padding: 12px 18px;
  left: 5px; top: 5px; line-height: normal; text-decoration: none;
  width: auto; z-index: 100000;
}

/* WP wp-block-image captions */
.wp-block-image figcaption,
.wp-caption-text {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--text-sm); color: var(--ink-500); margin-top: var(--space-3);
  text-align: center;
}

/* Single post — long-form prose */
.nc-prose {
  font-family: var(--font-body);
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--ink-700);
}
.nc-prose h2, .nc-prose h3, .nc-prose h4 {
  font-family: var(--font-display);
  color: var(--ink-900);
  letter-spacing: var(--tracking-tight);
  margin: var(--space-9) 0 var(--space-4);
}
.nc-prose h2 { font-size: var(--text-3xl); font-weight: 500; line-height: 1.15; }
.nc-prose h3 { font-size: var(--text-2xl); font-weight: 500; }
.nc-prose h4 { font-size: var(--text-xl);  font-weight: 600; font-family: var(--font-body); letter-spacing: 0; }
.nc-prose p  { margin: 0 0 var(--space-5); }
.nc-prose a  { color: var(--ink-900); border-bottom: 1px solid var(--brass-500); padding-bottom: 1px; }
.nc-prose a:hover { border-bottom-width: 2px; padding-bottom: 0; }
.nc-prose blockquote {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--text-xl); line-height: 1.45;
  color: var(--ink-900);
  border-left: 2px solid var(--brass-500); padding-left: var(--space-6);
  margin: var(--space-9) 0; max-width: 100%;
}
.nc-prose ul, .nc-prose ol { padding-left: var(--space-6); margin: 0 0 var(--space-5); }
.nc-prose li { margin-bottom: var(--space-2); }
.nc-prose code {
  font-family: var(--font-mono); font-size: 0.92em;
  background: var(--bone-100); padding: 2px 6px; border-radius: 3px;
  color: var(--ink-700);
}
.nc-prose figure { margin: var(--space-9) 0; }
.nc-prose img { max-width: 100%; height: auto; border-radius: var(--radius-md); }
.nc-prose hr {
  border: 0; border-top: 1px solid var(--border);
  margin: var(--space-10) auto; width: 80px;
}

/* Comments fallback styling */
.nc-comments {
  margin-top: var(--space-11);
  padding-top: var(--space-9);
  border-top: 1px solid var(--border);
}
.nc-comments .comment { padding: var(--space-6) 0; border-bottom: 1px solid var(--border); }
.nc-comments .comment:last-child { border-bottom: 0; }
.nc-comments .comment-meta { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--ink-500); margin-bottom: var(--space-2); }



/* ============================================================
   Component classes (used by PHP templates instead of inline styles).
   Mirrors the inline styles from the React UI kit exactly.
   ============================================================ */

/* ---------- HEADER ---------- */
.nc-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,246,238,0.96);
  -webkit-backdrop-filter: saturate(180%);
          backdrop-filter: saturate(180%);
  border-bottom: 1px solid transparent;
  transition: border-color 200ms var(--ease-quiet);
}
.nc-header.is-scrolled { border-bottom-color: var(--border); }
.nc-header__inner {
  max-width: var(--container-wide); margin: 0 auto;
  padding: 14px var(--page-pad);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.nc-header__brand { display: flex; align-items: center; border: 0; padding: 0; }
.nc-header__brand img,
.nc-header__brand .custom-logo { height: 44px; width: auto; display: block; }
.nc-nav-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; gap: 22px; align-items: center;
}
.nc-nav-list li { margin: 0; }
.nc-nav-list a {
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  color: var(--ink-700); padding: 4px 0; text-decoration: none;
  border: 0; white-space: nowrap;
  transition: color 120ms var(--ease-quiet);
}
.nc-nav-list a:hover { color: var(--ink-900); }
.nc-nav-list .current-menu-item > a,
.nc-nav-list .current_page_item > a,
.nc-nav-list a[aria-current="page"] {
  color: var(--ink-900);
  border-bottom: 1.5px solid var(--brass-500);
  padding-bottom: 2px;
}
.nc-header__right { display: flex; align-items: center; gap: 12px; }
.nc-header__lang {
  display: inline-flex; gap: 6px; align-items: center;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em;
  color: var(--ink-500); padding: 5px 12px;
  border: 1px solid var(--border); border-radius: 999px;
  background: transparent; cursor: pointer;
}
.nc-header__lang span.is-active { color: var(--ink-900); font-weight: 600; }
.nc-header__burger {
  display: none;
  width: 44px; height: 44px; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--ink-900); cursor: pointer;
}
@media (max-width: 1023px) {
  .nc-nav-list { display: none; }
  .nc-header__lang { display: none; }
  .nc-header__burger { display: inline-flex; }
}
@media (max-width: 640px) {
  .nc-header__inner { padding: 12px 16px; }
  .nc-header__brand img,
  .nc-header__brand .custom-logo { height: 36px; }
  .nc-header__cta { display: none; }
}

/* Mobile menu overlay */
.nc-mobile-menu {
  position: fixed; inset: 0; z-index: 60;
  background: var(--bone-50);
  display: none;
  flex-direction: column;
  padding: 14px var(--page-pad) 32px;
  overflow: auto;
}
.nc-mobile-menu.is-open { display: flex; }
.nc-mobile-menu__head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 20px; border-bottom: 1px solid var(--border); margin-bottom: 28px;
}
.nc-mobile-menu__head img { height: 36px; }
.nc-mobile-menu__close {
  width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--ink-900); cursor: pointer;
}
.nc-mobile-menu__list,
.nc-mobile-menu .nc-nav-list {
  display: flex; flex-direction: column; gap: 0; list-style: none; padding: 0; margin: 0;
}
.nc-mobile-menu__list a,
.nc-mobile-menu .nc-nav-list a {
  font-family: var(--font-display); font-size: 28px; font-weight: 500;
  color: var(--ink-900); letter-spacing: -0.01em;
  padding: 20px 0; border-bottom: 1px solid var(--border);
  text-decoration: none; display: flex; justify-content: space-between; align-items: center;
}
.nc-mobile-menu__footer { margin-top: auto; padding-top: 28px; display: flex; flex-direction: column; gap: 14px; }

/* ---------- HERO ---------- */
.nc-hero {
  background: var(--bone-50);
  padding-block: var(--space-13);
  position: relative; overflow: hidden;
}
.nc-hero__watermark {
  position: absolute; top: -120px; right: -80px; width: 520px; height: 520px;
  opacity: 0.035; pointer-events: none;
}
.nc-hero__inner {
  position: relative; max-width: var(--container-wide); margin: 0 auto;
  padding: 0 var(--page-pad);
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 64px; align-items: center;
}
.nc-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-body); font-size: 12px; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--brass-500);
}
.nc-eyebrow__rule { width: 28px; height: 1px; background: var(--brass-500); display: inline-block; }
.nc-hero__h1 {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(44px, 5.4vw, 76px); letter-spacing: -0.025em;
  line-height: 1.02; color: var(--ink-900);
  margin: 20px 0 24px;
}
.nc-hero__h1 em { font-style: italic; color: var(--ink-700); font-weight: 400; }
.nc-hero__lead {
  font-family: var(--font-body); font-size: 18px; line-height: 1.6;
  color: var(--ink-500); max-width: 520px; margin: 0 0 32px;
}
.nc-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.nc-hero__meta {
  margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--border);
  display: flex; gap: 40px; flex-wrap: wrap;
}
.nc-hero__meta-item {
  font-family: var(--font-body); font-size: 13px; color: var(--ink-500); line-height: 1.45;
}
.nc-hero__meta-label {
  display: block; color: var(--ink-900); font-weight: 600;
  letter-spacing: 0.06em; font-size: 11px; text-transform: uppercase; margin-bottom: 4px;
}

/* Photo / portrait figures */
.nc-figure {
  position: relative; aspect-ratio: 4/5; border-radius: var(--radius-lg);
  overflow: hidden; background: var(--ivory);
  border: 1px solid var(--border); box-shadow: var(--shadow-2); margin: 0;
}
.nc-figure img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: sepia(0.18) saturate(0.85) brightness(0.96);
}
.nc-figure__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(11,26,43,0) 55%, rgba(11,26,43,0.55) 100%);
}
.nc-figure__caption {
  position: absolute; bottom: 22px; left: 24px; right: 24px; color: var(--bone-50);
  font-family: var(--font-display); font-style: italic; font-size: 14px; line-height: 1.4; margin: 0;
}
.nc-figure__caption-label {
  display: block; font-style: normal;
  font-family: var(--font-body); font-size: 10px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--brass-400); margin-bottom: 6px;
}

/* ---------- TRUST STRIP ---------- */
.nc-trust {
  background: var(--bone-100);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  padding: 22px var(--page-pad);
}
.nc-trust__inner {
  max-width: var(--container); margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; align-items: center;
}
.nc-trust__item { display: flex; align-items: center; gap: 14px; color: var(--ink-700); }
.nc-trust__icon { color: var(--brass-500); flex-shrink: 0; }
.nc-trust__text { font-family: var(--font-body); font-size: 14px; line-height: 1.4; }
.nc-trust__text b { color: var(--ink-900); font-weight: 600; display: block; margin-bottom: 2px; }

/* ---------- SERVICES ---------- */
.nc-section { background: var(--bone-50); padding-block: var(--space-13); }
.nc-section--alt { background: var(--bone-100); }
.nc-section--ink { background: var(--ink-900); color: var(--bone-50); }
.nc-section__inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--page-pad); }
.nc-section__head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 56px;
}
.nc-section__head--centered {
  display: block; max-width: 820px; margin-inline: 0; margin-bottom: 48px;
}
.nc-section__h2 {
  font-family: var(--font-display); font-size: 48px; font-weight: 400;
  letter-spacing: -0.025em; line-height: 1.05; color: var(--ink-900);
  margin: 12px 0 0; max-width: 600px;
}
.nc-section__h2--xl { font-size: 56px; line-height: 1.04; }
.nc-section__h2 em { font-style: italic; color: var(--ink-700); font-weight: 400; }
.nc-section__sub {
  font-family: var(--font-body); font-size: 16px; line-height: 1.6;
  color: var(--ink-500); margin: 0; max-width: 380px;
}
.nc-section__sub--wide { max-width: 720px; font-size: 18px; }

.nc-services__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.nc-svc {
  position: relative;
  background: var(--ivory); border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px 26px 26px;
  box-shadow: var(--shadow-1);
  transition: box-shadow 200ms var(--ease-quiet);
  display: flex; flex-direction: column; min-height: 220px;
  text-decoration: none; color: inherit;
}
.nc-svc:hover { box-shadow: var(--shadow-2); border-color: var(--border-strong); }
.nc-svc__ornament {
  position: absolute; top: 18px; right: 22px;
  font-family: var(--font-display); color: var(--brass-500);
  font-size: 24px; line-height: 1; font-weight: 400;
}
.nc-svc__title {
  font-family: var(--font-display); font-size: 26px; font-weight: 500;
  color: var(--ink-900); letter-spacing: -0.01em; margin: 0 0 12px; line-height: 1.15;
}
.nc-svc__desc {
  font-family: var(--font-body); font-size: 14px; line-height: 1.6;
  color: var(--ink-500); margin: 0;
}
.nc-svc__link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: auto; padding-top: 20px;
  font-family: var(--font-body); font-size: 13px; font-weight: 600; color: var(--ink-900);
}
.nc-svc__link span { border-bottom: 1px solid var(--brass-500); padding-bottom: 1px; }

/* ---------- PROCESS / MISIÓN ---------- */
.nc-process__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  background: var(--border); gap: 1px;
  border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden;
}
.nc-process__step { background: var(--bone-50); padding: 32px 28px; }
.nc-process__num {
  font-family: var(--font-mono); font-size: 12px; font-weight: 500;
  color: var(--brass-500); letter-spacing: 0.12em; margin-bottom: 24px;
  display: inline-flex; align-items: center; gap: 8px;
}
.nc-process__num-rule { width: 24px; height: 1px; background: var(--brass-500); display: inline-block; }
.nc-process__title {
  font-family: var(--font-display); font-size: 24px; font-weight: 500;
  color: var(--ink-900); letter-spacing: -0.01em; margin: 0 0 12px; line-height: 1.2;
}
.nc-process__desc { font-family: var(--font-body); font-size: 14px; line-height: 1.65; color: var(--ink-500); margin: 0 0 16px; }
.nc-process__meta {
  font-family: var(--font-body); font-size: 12px; color: var(--ink-500);
  padding-top: 16px; border-top: 1px dashed var(--border-strong);
  display: flex; align-items: center; gap: 6px;
}
.nc-process__meta-icon { color: var(--brass-500); }

/* ---------- PRICING / ARANCELES ---------- */
.nc-aranceles__head { text-align: left; margin-bottom: 56px; max-width: 820px; }
.nc-aranceles__body {
  display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: start;
}
.nc-principle {
  display: grid; grid-template-columns: 56px 1fr; gap: 24px;
  padding: 28px 0; border-bottom: 1px solid var(--border);
}
.nc-principle:first-child { padding-top: 0; }
.nc-principle:last-child  { border-bottom: 0; padding-bottom: 0; }
.nc-principle__num {
  font-family: var(--font-display); font-size: 32px; font-weight: 400;
  color: var(--brass-500); letter-spacing: -0.02em; line-height: 1;
}
.nc-principle__title {
  font-family: var(--font-display); font-size: 24px; font-weight: 500;
  color: var(--ink-900); letter-spacing: -0.01em; margin: 0 0 8px; line-height: 1.2;
}
.nc-principle__desc { font-family: var(--font-body); font-size: 15px; line-height: 1.6; color: var(--ink-500); margin: 0; }
.nc-principle__desc strong { color: var(--ink-900); font-weight: 600; }

.nc-refs-panel {
  background: var(--ivory); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 32px;
  box-shadow: var(--shadow-1); position: sticky; top: 96px;
}
.nc-refs-panel__badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--brass-500);
  padding-bottom: 14px; margin-bottom: 18px; border-bottom: 1px solid var(--border); width: 100%;
}
.nc-refs-panel__title {
  font-family: var(--font-display); font-size: 22px; font-weight: 500;
  color: var(--ink-900); letter-spacing: -0.01em; margin: 0 0 16px; line-height: 1.25;
}
.nc-refs-panel__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.nc-refs-panel__item {
  font-family: var(--font-body); font-size: 13px; line-height: 1.5; color: var(--ink-700);
  display: flex; gap: 10px; align-items: flex-start;
}
.nc-refs-panel__item-icon { color: var(--brass-500); flex-shrink: 0; margin-top: 3px; }
.nc-refs-panel__code {
  font-family: var(--font-mono); font-size: 12px; color: var(--ink-500); display: block; margin-top: 2px;
}

.nc-aranceles__cta {
  margin-top: 56px; padding: 36px 40px;
  background: var(--bone-100); border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap;
}
.nc-aranceles__cta-text { display: flex; flex-direction: column; gap: 4px; }
.nc-aranceles__cta-title {
  font-family: var(--font-display); font-size: 24px; font-weight: 500;
  color: var(--ink-900); letter-spacing: -0.01em; margin: 0;
}
.nc-aranceles__cta-desc {
  font-family: var(--font-body); font-size: 14px; color: var(--ink-500);
  line-height: 1.5; margin: 0; max-width: 460px;
}

/* ---------- ABOUT ---------- */
.nc-about__inner {
  max-width: var(--container); margin: 0 auto; padding: 0 var(--page-pad);
  display: grid; grid-template-columns: 1fr 1.15fr; gap: 80px; align-items: center;
}
.nc-about__h2 {
  font-family: var(--font-display); font-size: 48px; font-weight: 400;
  letter-spacing: -0.025em; line-height: 1.05; color: var(--ink-900);
  margin: 12px 0 24px;
}
.nc-about__para {
  font-family: var(--font-display); font-size: 19px; line-height: 1.65;
  color: var(--ink-700); margin: 0 0 18px;
}
.nc-about__para-sans {
  font-family: var(--font-body); font-size: 15px; line-height: 1.65;
  color: var(--ink-500); margin: 0 0 24px;
}
.nc-about__facts {
  margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--border);
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
.nc-about__fact-label {
  font-family: var(--font-body); font-size: 10px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--brass-500); margin-bottom: 6px;
}
.nc-about__fact-value { font-family: var(--font-body); font-size: 14px; color: var(--ink-900); line-height: 1.5; }

/* ---------- BLOG (recent + archive) ---------- */
.nc-blog__head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 40px; gap: 40px; flex-wrap: wrap; }
.nc-blog__view-all {
  font-family: var(--font-body); font-size: 13px; font-weight: 600;
  color: var(--ink-900); border-bottom: 1px solid var(--brass-500); padding-bottom: 2px;
  display: inline-flex; align-items: center; gap: 6px; text-decoration: none;
}
.nc-blog__list { border-top: 1px solid var(--border); }
.nc-post-row {
  display: grid; grid-template-columns: 120px 1fr auto; gap: 32px;
  padding: 32px 0; border-bottom: 1px solid var(--border);
  align-items: baseline;
  transition: background 200ms var(--ease-quiet);
  text-decoration: none; color: inherit;
}
.nc-post-row:hover { background: rgba(166,134,78,0.04); }
.nc-post-row__date {
  font-family: var(--font-mono); font-size: 12px; color: var(--ink-500); letter-spacing: 0.04em;
}
.nc-post-row__cat {
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--brass-500); margin-bottom: 6px;
}
.nc-post-row__title {
  font-family: var(--font-display); font-size: 28px; font-weight: 500;
  color: var(--ink-900); letter-spacing: -0.015em; margin: 0 0 8px; line-height: 1.18; max-width: 640px;
}
.nc-post-row__excerpt {
  font-family: var(--font-body); font-size: 14px; line-height: 1.6;
  color: var(--ink-500); margin: 0; max-width: 640px;
}
.nc-post-row__arrow { color: var(--ink-500); }

/* Single post layout */
.nc-post-header { max-width: var(--container-narrow); margin: 0 auto; padding: var(--space-13) var(--page-pad) var(--space-9); }
.nc-post-header__cat {
  font-family: var(--font-body); font-size: 12px; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--brass-500);
}
.nc-post-header__title {
  font-family: var(--font-display); font-size: 60px; font-weight: 400;
  letter-spacing: -0.025em; line-height: 1.04; color: var(--ink-900);
  margin: 14px 0 18px;
}
.nc-post-header__meta {
  font-family: var(--font-mono); font-size: 12px; color: var(--ink-500); letter-spacing: 0.04em;
}
.nc-post-body { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--page-pad) var(--space-13); }

/* ---------- APPOINTMENT CTA (dark inline form) ---------- */
.nc-cta {
  background: var(--ink-900); color: var(--bone-50);
  padding-block: var(--space-13); position: relative; overflow: hidden;
}
.nc-cta__watermark {
  position: absolute; top: 50%; right: -120px; width: 520px; height: 520px;
  transform: translateY(-50%);
  opacity: 0.06; pointer-events: none;
}
.nc-cta__inner {
  position: relative; max-width: var(--container); margin: 0 auto;
  padding: 0 var(--page-pad);
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: start;
}
.nc-cta__h2 {
  font-family: var(--font-display); font-size: 56px; font-weight: 400;
  letter-spacing: -0.025em; line-height: 1.02;
  margin: 12px 0 20px; color: var(--bone-50);
}
.nc-cta__h2 em { font-style: italic; color: var(--brass-400); font-weight: 400; }
.nc-cta__lead {
  font-family: var(--font-body); font-size: 17px; line-height: 1.6;
  color: var(--ink-200); margin: 0 0 28px; max-width: 480px;
}
.nc-cta__bullet {
  display: flex; align-items: flex-start; gap: 12px;
  color: var(--bone-50); font-family: var(--font-body); font-size: 14px; line-height: 1.5;
  margin-bottom: 12px;
}
.nc-cta__bullet-icon { color: var(--brass-400); flex-shrink: 0; margin-top: 2px; }

.nc-cta__form {
  background: rgba(250,246,238,0.04);
  border: 1px solid rgba(250,246,238,0.10);
  border-radius: var(--radius-lg); padding: 32px;
  display: flex; flex-direction: column; gap: 18px;
}
.nc-cta__form-head { padding-bottom: 16px; margin-bottom: 4px; border-bottom: 1px solid rgba(250,246,238,0.10); }
.nc-cta__form-title { font-family: var(--font-display); font-size: 22px; font-weight: 500; color: var(--bone-50); margin: 0 0 4px; }
.nc-cta__form-sub   { font-family: var(--font-body); font-size: 12px; color: var(--ink-300); margin: 0; }
.nc-cta__form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.nc-cta__form .field { display: flex; flex-direction: column; gap: 6px; }
.nc-cta__form label { font-family: var(--font-body); font-size: 12px; font-weight: 600; color: var(--bone-50); }
.nc-cta__form input, .nc-cta__form select, .nc-cta__form textarea {
  font-family: var(--font-body); font-size: 14px; color: var(--bone-50);
  background: rgba(0,0,0,0.25); border: 1px solid rgba(250,246,238,0.15);
  border-radius: var(--radius-sm); padding: 12px 14px; outline: none;
  transition: border-color 120ms var(--ease-quiet);
}
.nc-cta__form input:focus, .nc-cta__form select:focus, .nc-cta__form textarea:focus { border-color: var(--brass-400); }
.nc-cta__form textarea { min-height: 90px; resize: vertical; line-height: 1.5; }
.nc-cta__form .nc-consent {
  font-family: var(--font-body); font-size: 11px; color: var(--ink-300); line-height: 1.5;
  display: flex; gap: 8px; align-items: flex-start;
}
.nc-cta__form .nc-consent a { color: var(--brass-400); border-bottom: 1px solid var(--brass-700); padding: 0 0 1px; }
.nc-cta__form .honeypot { position: absolute; left: -9999px; }
.nc-cta__form-status {
  font-family: var(--font-body); font-size: 13px; padding: 16px; border-radius: var(--radius-md);
  display: flex; align-items: center; gap: 12px;
}
.nc-cta__form-status.is-success { background: rgba(46,125,91,0.18); border: 1px solid rgba(46,125,91,0.4); color: var(--bone-50); }
.nc-cta__form-status.is-error   { background: rgba(168,68,58,0.18);  border: 1px solid rgba(168,68,58,0.4);  color: var(--bone-50); }

/* ---------- CONTACT (light variant for Ubicación page) ---------- */
.nc-contact__inner {
  max-width: var(--container); margin: 0 auto; padding: 0 var(--page-pad);
  display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: start;
}
.nc-contact__block { padding-bottom: 22px; margin-bottom: 22px; border-bottom: 1px solid var(--border); }
.nc-contact__block:last-child { padding-bottom: 0; margin-bottom: 0; border-bottom: 0; }
.nc-contact__label {
  font-family: var(--font-body); font-size: 10px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--brass-500); margin-bottom: 8px;
}
.nc-contact__value { font-family: var(--font-display); font-size: 20px; color: var(--ink-900); line-height: 1.45; font-weight: 500; margin: 0; }
.nc-contact__value-sans { font-family: var(--font-body); font-size: 15px; color: var(--ink-700); line-height: 1.5; margin: 0; }

.nc-map {
  aspect-ratio: 4/3; background: var(--bone-100); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; position: relative; box-shadow: var(--shadow-1);
}
.nc-map__pattern {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(transparent 95%, rgba(166,134,78,0.18) 95%),
    linear-gradient(90deg, transparent 95%, rgba(166,134,78,0.18) 95%);
  background-size: 48px 48px;
}
.nc-map__pin {
  position: absolute; top: 38%; left: 46%; transform: translate(-50%, -100%);
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.nc-map__pin-circle {
  width: 18px; height: 18px; border-radius: 50%; background: var(--brass-500);
  border: 3px solid var(--bone-50); box-shadow: var(--shadow-2);
}
.nc-map__pin-label {
  background: var(--ink-900); color: var(--bone-50);
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: var(--radius-sm); margin-top: 8px; white-space: nowrap;
}
.nc-map__badge {
  position: absolute; bottom: 16px; left: 16px;
  background: var(--ivory); color: var(--ink-500);
  font-family: var(--font-mono); font-size: 10px;
  padding: 5px 10px; border-radius: 999px; border: 1px solid var(--border);
  letter-spacing: 0.08em; text-transform: uppercase;
}

/* ---------- FOOTER ---------- */
.nc-footer { background: var(--ink-900); color: var(--bone-50); padding-block: 64px 28px; }
.nc-footer__inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--page-pad); }
.nc-footer__grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 56px; border-bottom: 1px solid rgba(255,255,255,0.08);
}
.nc-footer__logo { height: 60px; display: block; }
.nc-footer__tag {
  font-family: var(--font-display); font-style: italic;
  font-size: 14px; color: var(--brass-400); margin-top: 16px;
  line-height: 1.55; max-width: 280px;
}
.nc-footer__col-title {
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--brass-400);
  margin: 8px 0 18px;
}
.nc-footer__list, .nc-footer ul.menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.nc-footer__list li, .nc-footer ul.menu li {
  font-family: var(--font-body); font-size: 14px; color: var(--ink-200); line-height: 1.55;
}
.nc-footer__list a, .nc-footer ul.menu a {
  color: var(--ink-200); text-decoration: none; border: 0; padding: 0;
  transition: color 120ms var(--ease-quiet);
}
.nc-footer__list a:hover, .nc-footer ul.menu a:hover { color: var(--bone-50); }
.nc-footer__bar {
  margin-top: 28px; display: flex; justify-content: space-between;
  font-family: var(--font-body); font-size: 11px; color: var(--ink-300);
  letter-spacing: 0.04em; flex-wrap: wrap; gap: 16px;
}

/* ---------- RESPONSIVE OVERRIDES for the class-based components ---------- */
@media (max-width: 1023px) {
  .nc-hero__inner,
  .nc-about__inner,
  .nc-cta__inner,
  .nc-contact__inner { grid-template-columns: 1fr; gap: 48px; }
  .nc-section__head { grid-template-columns: 1fr; gap: 20px; margin-bottom: 36px; }
  .nc-services__grid { grid-template-columns: repeat(2, 1fr); }
  .nc-aranceles__body { grid-template-columns: 1fr; gap: 32px; }
  .nc-refs-panel { position: static; }
  .nc-footer__grid { grid-template-columns: 1fr 1fr; }
  .nc-footer__grid > *:first-child { grid-column: 1 / -1; }
  .nc-trust__inner { grid-template-columns: 1fr; gap: 14px; }
  .nc-process__grid { grid-template-columns: 1fr; }
  .nc-section { padding-block: 80px; }
  .nc-cta { padding-block: 80px; }
}
@media (max-width: 640px) {
  .nc-services__grid { grid-template-columns: 1fr; }
  .nc-section__h2, .nc-about__h2 { font-size: 36px; }
  .nc-section__h2--xl, .nc-cta__h2, .nc-post-header__title { font-size: 40px; }
  .nc-cta__form-row { grid-template-columns: 1fr; }
  .nc-footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .nc-section, .nc-cta { padding-block: 64px; }
}
