:root {
  --font-family: "Fira Sans", sans-serif;
  --font-size-base: 17.9px;
  --line-height-base: 1.6;

  --max-w: 1580px;
  --space-x: 1.53rem;
  --space-y: 1.5rem;
  --gap: 1.36rem;
  --space-section-y: calc(var(--space-y) * 2.4);
  --space-section-x: var(--space-x);
  --space-block: calc(var(--gap) * 1.5);
  --space-card: calc(var(--space-y) * .75);
  --font-size-sm: calc(var(--font-size-base) * .875);
  --font-size-md: var(--font-size-base);
  --font-size-lg: calc(var(--font-size-base) * 1.125);
  --font-size-h3: calc(var(--font-size-base) * 1.35);
  --font-size-h2: calc(var(--font-size-base) * 2);
  --font-size-h1: calc(var(--font-size-base) * 2.65);
  --motion-distance: calc(var(--gap) * var(--random-number));

  --radius-xl: 1.09rem;
  --radius-lg: 0.82rem;
  --radius-md: 0.42rem;
  --radius-sm: 0.29rem;

  --shadow-sm: 0 2px 4px rgba(0,0,0,0.11);
  --shadow-md: 0 10px 20px rgba(0,0,0,0.14);
  --shadow-lg: 0 18px 54px rgba(0,0,0,0.18);

  --overlay: rgba(0,0,0,0.5);
  --anim-duration: 510ms;
  --anim-ease: cubic-bezier(0.16,1,0.3,1);
  --random-number: 2;

  --brand: #c62828;
  --brand-contrast: #ffffff;
  --accent: #e53935;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f5f5f5;
  --neutral-300: #bdbdbd;
  --neutral-600: #757575;
  --neutral-800: #424242;
  --neutral-900: #212121;

  --page-bg: #fafafa;
  --page-fg: #212121;
  --muted-bg: #f5f5f5;
  --muted-fg: #424242;
  --card-bg: #ffffff;
  --card-fg: #212121;
  --card-border: #e0e0e0;
  --inverse-bg: #212121;
  --inverse-fg: #ffffff;
  --primary-bg: #c62828;
  --primary-fg: #ffffff;
  --primary-hover: #b71c1c;
  --accent-bg: #e53935;
  --accent-fg: #ffffff;
  --accent-hover: #b71c1c;
  --gradient-hero-bg: linear-gradient(135deg, #c62828 0%, #e53935 100%);
  --gradient-hero-fg: #ffffff;
  --gradient-accent-bg: linear-gradient(135deg, #e53935 0%, #c62828 100%);
  --gradient-accent-fg: #ffffff;

  --ring: #c62828;

  --link: #c62828;
  --link-hover: #e53935;

  --btn-ghost-bg: transparent;
  --btn-ghost-bg-hover: color-mix(in srgb, currentColor 10%, transparent);
  --input-placeholder: rgba(255,255,255,0.55);
}
body{margin:0;padding:0;font-family:var(--font-family);box-sizing: border-box;}
*{box-sizing:border-box;}
a{color:inherit;}
.btn-primary,.btn.btn-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;border-color:var(--primary-bg)!important;}
.btn-primary:hover,.btn.btn-primary:hover{background:var(--primary-hover)!important;color:var(--primary-fg)!important;border-color:var(--primary-hover)!important;}
.btn-outline-primary{color:var(--primary-bg)!important;border-color:var(--primary-bg)!important;}
.btn-outline-primary:hover{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.bg-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.text-primary{color:var(--primary-bg)!important;}
.border-primary{border-color:var(--primary-bg)!important;}
.bg-light{background:var(--page-bg)!important;color:var(--page-fg)!important;}
.bg-dark{background:var(--inverse-bg)!important;color:var(--inverse-fg)!important;}

/* =============================================
   HEADER – diseño clásico, full-width, 
   con wrapper centrado, borde inferior sutil
   ============================================= */
.site-header {
  background-color: var(--page-bg, #ffffff);
  border-bottom: 1px solid var(--card-border, #e0e0e0);
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font-family, system-ui, sans-serif);
  position: relative; /* no fixed, no sticky */
  z-index: 100;
}

/* Wrapper interno: centrado, ancho máximo */
.header-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  padding: var(--space-y, 0.75rem) var(--space-x, 1.5rem);
  box-sizing: border-box;
  flex-wrap: nowrap;
}

/* Logo */
.logo {
  font-size: var(--font-size-h3, 1.5rem);
  font-weight: 600;
  color: var(--page-fg, #1a1a2e);
  text-decoration: none;
  letter-spacing: -0.02em;
  line-height: 1.2;
  white-space: nowrap;
  flex-shrink: 0;
}
.logo:hover {
  color: var(--link-hover, #0056b3);
}

/* Navegación horizontal (escritorio) */
.nav-main {
  display: flex;
  align-items: center;
}
.nav-list {
  display: flex;
  gap: var(--gap, 2rem);
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-link {
  font-size: var(--font-size-md, 1rem);
  color: var(--page-fg, #1a1a2e);
  text-decoration: none;
  padding: 0.25rem 0;
  border-bottom: 2px solid transparent;
  transition: border-color var(--anim-duration, 0.2s) var(--anim-ease, ease);
  font-weight: 500;
}
.nav-link:hover {
  border-bottom-color: var(--primary-bg, #0056b3);
  color: var(--link-hover, #0056b3);
}

/* CTA escritorio */
.cta-desktop {
  flex-shrink: 0;
}
.cta-button {
  display: inline-block;
  background-color: var(--primary-bg, #0056b3);
  color: var(--primary-fg, #ffffff);
  font-size: var(--font-size-sm, 0.9rem);
  font-weight: 600;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-md, 6px);
  text-decoration: none;
  transition: background-color var(--anim-duration, 0.2s) var(--anim-ease, ease);
  line-height: 1.4;
  white-space: nowrap;
}
.cta-button:hover {
  background-color: var(--primary-hover, #003d80);
  color: var(--primary-fg, #ffffff);
}

/* Hamburguesa (oculta en escritorio) */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.25rem;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm, 4px);
  transition: background var(--anim-duration, 0.2s);
}
.hamburger:hover {
  background-color: var(--muted-bg, #f0f0f0);
}
.bar {
  display: block;
  width: 26px;
  height: 3px;
  background-color: var(--page-fg, #1a1a2e);
  border-radius: 2px;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

/* Menú móvil (oculto por defecto) */
.mobile-menu {
  display: none; /* se activa con JS */
  background-color: var(--page-bg, #ffffff);
  border-top: 1px solid var(--card-border, #e0e0e0);
  padding: var(--space-y, 0.75rem) var(--space-x, 1.5rem);
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  box-sizing: border-box;
}
.mobile-menu.open {
  display: block;
}
.mobile-nav-list {
  list-style: none;
  margin: 0 0 1rem 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.mobile-nav-link {
  display: block;
  font-size: var(--font-size-md, 1rem);
  color: var(--page-fg, #1a1a2e);
  text-decoration: none;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--card-border, #e8e8e8);
  font-weight: 500;
}
.mobile-nav-link:hover {
  color: var(--link-hover, #0056b3);
}
.mobile-cta {
  margin-top: 0.5rem;
}
.mobile-cta-btn {
  width: 100%;
  text-align: center;
}

/* =============================================
   ADAPTACIÓN MÓVIL (max-width: 767px)
   ============================================= */
@media (max-width: 767px) {
  .header-wrapper {
    padding: var(--space-y, 0.6rem) var(--space-x, 1rem);
  }
  .nav-main {
    display: none; /* oculto en móvil */
  }
  .cta-desktop {
    display: none; /* oculto en móvil */
  }
  .hamburger {
    display: flex; /* visible en móvil */
  }
  .logo {
    font-size: var(--font-size-h3, 1.4rem);
  }
}

/* =============================================
   AJUSTES TABLET / ESCRITORIO PEQUEÑO (768-1024)
   ============================================= */
@media (min-width: 768px) {
  .mobile-menu {
    display: none !important; /* nunca visible en desktop */
  }
  .hamburger {
    display: none !important;
  }
}

/* =============================================
   TOQUES FINOS: densidad media, sin fixed
   ============================================= */
.site-header {
  box-shadow: none; /* solo borde inferior */
}

footer {
    background-color: #1a1a2e;
    color: #e0e0e0;
    padding: 2rem 1rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 0.9rem;
    line-height: 1.5;
  }
  .footer-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }
  .footer-brand {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  .footer-logo {
    font-size: 1.4rem;
    font-weight: 700;
    color: #ffffff;
    text-decoration: none;
    letter-spacing: 0.5px;
  }
  .footer-logo:hover {
    color: #4fc3f7;
  }
  .footer-disclaimer {
    font-size: 0.8rem;
    color: #b0b0b0;
    max-width: 600px;
    margin: 0;
    font-style: italic;
  }
  .footer-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem 1.5rem;
  }
  .footer-nav a {
    color: #b0b0b0;
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.2s;
  }
  .footer-nav a:hover {
    color: #4fc3f7;
  }
  .footer-contact {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    font-style: normal;
    color: #c0c0c0;
    font-size: 0.85rem;
  }
  .footer-contact a {
    color: #4fc3f7;
    text-decoration: none;
  }
  .footer-contact a:hover {
    text-decoration: underline;
  }
  .footer-legal {
    border-top: 1px solid #333;
    padding-top: 1rem;
    font-size: 0.8rem;
    color: #888;
  }
  .footer-legal p {
    margin: 0;
  }
  @media (min-width: 768px) {
    .footer-container {
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: space-between;
    }
    .footer-brand {
      flex: 1 1 100%;
    }
    .footer-nav {
      flex: 2 1 auto;
    }
    .footer-contact {
      flex: 1 1 auto;
      text-align: right;
    }
    .footer-legal {
      flex: 1 1 100%;
    }
  }

.cookies{position:fixed;left:var(--space-x);right:var(--space-x);bottom:var(--space-y);z-index:1200;}

    .cookies .shell{max-width:720px;margin:0 auto;background:var(--page-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-y) var(--space-x);color:var(--page-fg);}

    .cookies .meta{display:flex;align-items:center;gap:8px;}

    .cookies .dot{width:10px;height:10px;border-radius:50%;background:var(--accent-bg);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent-bg) 20%,transparent);color:var(--accent-fg);}

    .cookies .shell p{margin:8px 0 0;}

    .cookies .actions{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap;}

    .cookies .actions button{border:1px solid var(--card-border);background:var(--muted-bg);color:var(--muted-fg);border-radius:var(--radius-sm);padding:8px 12px;cursor:pointer;}

    .cookies .actions button[data-choice='accept']{background:var(--accent-bg);color:var(--accent-fg);border-color:transparent;font-weight:700;}

.intro-clearpanel{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.intro-clearpanel .clearpanel-shell{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:1rem;}.intro-clearpanel .clearpanel-box{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:1.25rem;color:var(--card-fg);}.intro-clearpanel h1{margin:0;font-size:clamp(2.3rem,5.4vw,4.8rem);line-height:.98;}.intro-clearpanel p{margin:1rem 0;color:var(--neutral-600);}
.intro-clearpanel .clearpanel-box div{display:flex;gap:.55rem;flex-wrap:wrap;}.intro-clearpanel a{background:var(--primary-bg);color:var(--primary-fg);border-radius:var(--radius-md);padding:.72rem .95rem;text-decoration:none;}.intro-clearpanel a+a{background:var(--muted-bg);color:var(--muted-fg);}.intro-clearpanel .clearpanel-stats{display:grid;gap:1rem;}.intro-clearpanel .article{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:1rem;color:var(--card-fg);}.intro-clearpanel strong{display:block;font-size:1.55rem;}.intro-clearpanel span{color:var(--neutral-600);}
@media (max-width:820px){.intro-clearpanel .clearpanel-shell{grid-template-columns:1fr;}}

.social-proof{padding:clamp(18px,3vw,44px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);position:relative;overflow:hidden;}

    .social-proof::before{content:'';position:absolute;inset:-30%;background:radial-gradient(circle at 25% 25%,color-mix(in srgb, currentColor 14%, transparent),transparent 55%),radial-gradient(circle at 80% 55%,rgba(255, 107, 53,0.18),transparent 55%);filter:blur(18px);animation:socialC2Bg 7s var(--anim-ease) infinite;pointer-events:none;}

    @keyframes socialC2Bg{
        0%, 100% {transform:translate3d(-1%, 0,0) scale(1);}
        50%{transform:translate3d(1.5%,-1%,0) scale(1.04);}
    }

    .social-proof .c{max-width:var(--max-w);margin:0 auto;position:relative;}

    .social-proof .h{margin-bottom:clamp(14px,2.2vw,22px);}

    .social-proof .title{margin:0;font-size:clamp(24px,4.6vw,44px);letter-spacing:-.02em;line-height:1.1;}

    .social-proof .sub{margin:10px 0 0;max-width:70ch;color:color-mix(in srgb, currentColor 82%, transparent);}

    .social-proof .grid{display:grid;grid-template-columns:1.2fr 0.8fr;gap:14px;align-items:stretch;}

    .social-proof .quotes{position:relative;border-radius:var(--radius-xl);background:color-mix(in srgb, currentColor 10%, transparent);border:1px solid color-mix(in srgb, currentColor 16%, transparent);box-shadow:var(--shadow-lg);overflow:hidden;}

    .social-proof .quote{display:none;padding:18px 18px 16px;}

    .social-proof .quote.is-on{display:block;}

    .social-proof .qtext{font-size:clamp(16px,2.2vw,20px);line-height:1.7;color:color-mix(in srgb, currentColor 92%, transparent);}

    .social-proof .qmeta{margin-top:14px;display:flex;gap:10px;align-items:baseline;flex-wrap:wrap;}

    .social-proof .qname{font-weight:900;}

    .social-proof .qrole{opacity:.85;}

    .social-proof .metrics{display:grid;gap:12px;}

    .social-proof .metric{border-radius:var(--radius-xl);background:color-mix(in srgb, currentColor 14%, transparent);border:1px solid color-mix(in srgb, currentColor 14%, transparent);box-shadow:var(--shadow-md);padding:16px;}

    .social-proof .mval{font-weight:900;font-size:clamp(22px,3vw,32px);letter-spacing:-.01em;}

    .social-proof .mlbl{margin-top:6px;color:color-mix(in srgb, currentColor 82%, transparent);}

    @media (max-width: 980px){.social-proof .grid{grid-template-columns:1fr;}
    }

    @media (prefers-reduced-motion: reduce){.social-proof::before{animation:none;}
    }

.legal-quietpage{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--page-bg);color:var(--page-fg)}
.legal-quietpage .quietpage-wrap{max-width:var(--max-w);margin:0 auto;background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:1.2rem;box-shadow:var(--shadow-sm)}
.legal-quietpage h1{margin:0;color:var(--card-fg);font-size:clamp(2rem,4.4vw,3.6rem);line-height:1.04}
.legal-quietpage .quietpage-date{color:var(--link);font-weight:700}
.legal-quietpage h2{margin:1.3rem 0 0;color:var(--card-fg);font-size:clamp(1.25rem,2.5vw,1.8rem);line-height:1.15}
.legal-quietpage p{margin:.75rem 0 0;color:var(--card-fg);opacity:.84;line-height:1.58}
.legal-quietpage ul{margin:.75rem 0 0;padding-left:1.2rem;color:var(--card-fg)}
.legal-quietpage li{margin:.35rem 0;line-height:1.5}

.next-step{padding:calc(var(--space-y) * 1.9) var(--space-x);background:var(--inverse-bg);color:var(--inverse-fg);}

    .next-step .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}

    .next-step h2,.next-step h3,.next-step p{margin:0;}

    .next-step a{text-decoration:none;}

    .next-step .center,.next-step .banner,.next-step .stack,.next-step .bar,.next-step .split,.next-step .duo article{padding:.9rem;border-radius:var(--radius-xl);background:var(--inverse-bg);border:1px solid var(--card-border);color:var(--inverse-fg);}

    .next-step .center{display:grid;gap:.5rem;justify-items:center;text-align:center;}

    .next-step .split{display:grid;grid-template-columns:1fr auto;gap:var(--gap);align-items:center;}

    .next-step .actions{display:flex;gap:.45rem;flex-wrap:wrap;}

    .next-step .actions a,.next-step .center a,.next-step .banner > a,.next-step .duo a{display:inline-flex;min-height:2.35rem;padding:0 .85rem;align-items:center;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-fg);border:1px solid var(--ring);}

    .next-step .banner{display:grid;gap:.6rem;}

    .next-step .numbers{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;}

    .next-step .numbers div{padding:.6rem;border-radius:var(--radius-md);background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);}

    .next-step .duo{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);}

    .next-step .duo article{display:grid;gap:.45rem;}

    .next-step .stack{display:grid;gap:.6rem;justify-items:start;}

    .next-step .chips{display:flex;gap:.35rem;flex-wrap:wrap;}

    .next-step .chips span{padding:.28rem .5rem;border-radius:var(--radius-sm);background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);}

    .next-step .bar{display:grid;grid-template-columns:1fr auto;gap:var(--gap);align-items:center;}

    @media (max-width: 820px){.next-step .split,.next-step .bar,.next-step .duo{grid-template-columns:1fr;}

        .next-step .numbers{grid-template-columns:1fr 1fr;}
    }

    @media (max-width: 620px){.next-step .numbers{grid-template-columns:1fr;}
    }

.block-faq{padding:calc(var(--space-y) * 2.8) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}

    .block-faq .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:1rem;}

    .block-faq h2{margin:0;font-size:clamp(1.8rem,3.3vw,2.5rem);}

    .block-faq .bands{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap);}

    .block-faq article{padding:1rem;border-radius:var(--radius-lg);background:var(--card-bg);box-shadow:var(--shadow-sm);color:var(--card-fg);}

    .block-faq h3{margin:0 0 .45rem;font-size:1rem;}

    .block-faq p{margin:0;}

    @media (max-width: 980px){.block-faq .bands{grid-template-columns:repeat(2,minmax(0,1fr));}
    }

    @media (max-width: 680px){.block-faq .bands{grid-template-columns:1fr;}
    }

.panel-project-list.light {
    padding: 48px 20px;
    background: var(--card-bg);
    color: var(--card-fg);
}

.panel-project-list .inner {
    max-width: var(--max-w);
    margin: 0 auto;
}

.panel-project-list .inner h2 {
    margin: 0 0 10px;
    font-size: clamp(22px, 3.5vw, 28px);
}

.panel-project-list .list {
    margin: 0;
    padding: 0;
    list-style: none;
    border-radius: var(--radius-xl);
    background: var(--page-bg);
    border: 1px solid var(--card-border);
    overflow: hidden;
    color: var(--page-fg);
}

.panel-project-list .row {
    display: grid;
    grid-template-columns:minmax(0, 1.6fr) auto;
    gap: 12px;
    padding: 8px 12px;
    border-top: 1px solid var(--card-border);
}

.panel-project-list .row:first-child {
    border-top: none;
}

.panel-project-list .row-title {
    font-size: 0.9rem;
}

.panel-project-list .row-meta {
    font-size: 0.9rem;
}

.picks{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);} .picks .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .picks h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .picks .sub{margin:.35rem 0 0;opacity:.9;} .picks article,.picks li{padding:.85rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);list-style:none;color:var(--accent-fg);} .picks p{margin:0;} .picks a{text-decoration:none;color:inherit;font-weight:700;} .picks .split{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);} .picks .panel{padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);} .picks .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;} .picks article{transition:transform var(--anim-duration) var(--anim-ease),box-shadow var(--anim-duration) var(--anim-ease);} .picks article:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);} @media (max-width:860px){.picks .split,.picks .media,.picks .grid,.picks .cards,.picks .bento,.picks .foot{grid-template-columns:1fr;}}

.partners.light{padding:40px 20px;background:var(--card-bg);color:var(--card-fg);}

.partners .inner{max-width:var(--max-w);margin:0 auto;}

.partners .inner h2{margin:0 0 10px;font-size:clamp(22px,3.5vw,28px);}

.partners .row{display:flex;flex-wrap:wrap;gap:8px;}

.partners .chip{padding:6px 10px;border-radius:999px;background:var(--page-bg);border:1px solid var(--card-border);font-size:0.85rem;color:var(--page-fg);}

.panel-project-item.light{padding:40px 20px;background:var(--page-bg);color:var(--page-fg);}

.panel-project-item .inner{max-width:720px;margin:0 auto;}

.panel-project-item .inner h1{margin:0 0 4px;font-size:clamp(24px,4vw,32px);}

.panel-project-item .meta{margin:0 0 8px;font-size:0.9rem;}

.panel-project-item .desc{margin:0;font-size:0.95rem;line-height:1.7;}

.contacts-calmgrid{padding:calc(var(--space-y)*2.6) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.contacts-calmgrid .calmgrid-box{max-width:var(--max-w);margin:0 auto;}
.contacts-calmgrid .calmgrid-intro{max-width:45rem;margin-bottom:1.35rem;}
.contacts-calmgrid h2{margin:0;font-size:clamp(1.85rem,3.2vw,2.75rem);line-height:1.08;}
.contacts-calmgrid .calmgrid-intro p{margin:.75rem 0 0;color:var(--neutral-600);}
.contacts-calmgrid .calmgrid-info{display:grid;grid-template-columns:1.1fr .9fr .85fr .85fr;border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.contacts-calmgrid .article{min-height:9.2rem;padding:1rem;border-right:1px solid var(--card-border);display:flex;flex-direction:column;justify-content:space-between;}
.contacts-calmgrid .article:last-child{border-right:0;}
.contacts-calmgrid b{font-size:.82rem;color:var(--neutral-600);}
.contacts-calmgrid .address,.contacts-calmgrid .article p{margin:0;font-style:normal;line-height:1.32;}
.contacts-calmgrid a{text-decoration:none;overflow-wrap:anywhere;}
.contacts-calmgrid .calmgrid-action a{font-weight:700;}
.contacts-calmgrid .calmgrid-chips{list-style:none;margin:.8rem 0 0;padding:0;display:flex;gap:.55rem;flex-wrap:wrap;}
.contacts-calmgrid .calmgrid-chips a{display:inline-flex;gap:.4rem;align-items:center;border-radius:var(--radius-sm);padding:.55rem .7rem;background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.contacts-calmgrid .calmgrid-chips span{color:var(--neutral-600);}
@media (max-width:900px){.contacts-calmgrid .calmgrid-info{grid-template-columns:1fr 1fr;}.contacts-calmgrid .article:nth-child(2){border-right:0;}.contacts-calmgrid .article{border-bottom:1px solid var(--card-border);}}
@media (max-width:560px){.contacts-calmgrid .calmgrid-info{grid-template-columns:1fr;}.contacts-calmgrid .article{border-right:0;min-height:auto;gap:1.2rem;}.contacts-calmgrid .article:nth-child(2){border-bottom:1px solid var(--card-border);}}

.inquiry {
    padding: calc(var(--space-y) * 2.9) var(--space-x);
    background: var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
  }
  .inquiry .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: var(--gap);
  }
  .inquiry h2 {
    margin: 0;
    font-size: clamp(1.85rem, 3.6vw, 2.8rem);
    line-height: 1.1;
  }
  .inquiry .sub {
    margin: .35rem 0 0;
    opacity: .9;
  }
  .inquiry .panel,
  .inquiry .box {
    padding: 1.1rem;
    border-radius: var(--radius-xl);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    box-shadow: var(--shadow-md);
    color: var(--accent-fg);
  }
  .inquiry form {
    display: grid;
    gap: .75rem;
  }
  .inquiry .field {
    display: grid;
    gap: .28rem;
  }
  .inquiry .field span {
    font-size: .82rem;
    font-weight: 700;
  }
  .inquiry input,
  .inquiry textarea {
    width: 100%;
    padding: .8rem .85rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--card-border);
    background: var(--card-bg);
    color: var(--card-fg);
    font: inherit;
    outline: none;
    transition: border-color var(--anim-duration) var(--anim-ease), box-shadow var(--anim-duration) var(--anim-ease);
  }
  .inquiry input:focus,
  .inquiry textarea:focus {
    border-color: var(--ring);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ring) 22%, transparent);
  }
  .inquiry textarea {
    min-height: 120px;
    resize: vertical;
  }
  .inquiry button {
    padding: .82rem 1rem;
    border: 0;
    border-radius: var(--radius-md);
    background: var(--primary-bg);
    color: var(--primary-fg);
    font-weight: 700;
    cursor: pointer;
    transition: transform var(--anim-duration) var(--anim-ease), background var(--anim-duration) var(--anim-ease);
  }
  .inquiry button:hover {
    transform: translateY(-1px);
    background: var(--primary-hover);
    color: var(--primary-fg);
  }
  .inquiry .split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gap);
  }
  .inquiry .grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
  }
  .inquiry .line {
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    color: var(--accent-fg);
  }
  .inquiry .bar {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    color: var(--accent-fg);
  }
  .inquiry .stack {
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    color: var(--accent-fg);
  }
  .inquiry .steps {
    display: flex;
    gap: .45rem;
    flex-wrap: wrap;
  }
  .inquiry .steps span {
    padding: .33rem .55rem;
    border-radius: var(--radius-sm);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    font-size: .8rem;
    color: var(--accent-fg);
  }
  .inquiry .agree {
    display: flex;
    align-items: center;
    gap: .45rem;
    font-size: .86rem;
  }
  .inquiry .media {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: var(--gap);
  }
  .inquiry .media img,
  .inquiry .frame img {
    width: 100%;
    height: 100%;
    min-height: 320px;
    object-fit: cover;
    border-radius: var(--radius-xl);
  }
  .inquiry .frame {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: var(--gap);
  }
  .inquiry .full {
    grid-column: 1 / -1;
  }
  .inquiry .panel {
    transition: transform var(--anim-duration) var(--anim-ease), box-shadow var(--anim-duration) var(--anim-ease);
  }
  .inquiry .panel:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
  }
  @media (max-width: 860px) {
    .inquiry .split,
    .inquiry .media,
    .inquiry .frame {
      grid-template-columns: 1fr;
    }
    .inquiry .grid,
    .inquiry .bar {
      grid-template-columns: 1fr;
    }
  }

.follow{padding:clamp(56px,8vw,96px) 16px;background:var(--muted-bg);color:var(--muted-fg);}

    .follow .wrap{max-width:860px;margin:0 auto;}

    .follow .header{margin-bottom:14px;}

    .follow h2{margin:0;font-size:clamp(28px,4vw,40px);}

    .follow .header p{margin:10px 0 0;}

    .follow ul{margin:0;padding:0;list-style:none;display:grid;gap:8px;}

    .follow li{border:1px solid var(--card-border);border-radius:12px;background:var(--page-bg);padding:10px 12px;display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;color:var(--page-fg);}

    .follow li span{font-size:.85rem;}

    .follow li a{text-decoration:none;}

    .follow .cta{display:inline-block;margin-top:12px;text-decoration:none;background:var(--primary-bg);color:var(--primary-fg);border-radius:10px;padding:10px 14px;}

    @media (max-width: 680px){.follow li{grid-template-columns:1fr;}
    }

.policy-deepfile{padding:calc(var(--space-y)*3) var(--space-x);background:var(--neutral-900);color:var(--neutral-0);}
.policy-deepfile .deepfile-wrap{max-width:var(--max-w);margin:0 auto;}.policy-deepfile h2{margin:0 0 1rem;font-size:clamp(2rem,4vw,3.2rem);line-height:1.04;}.policy-deepfile .deepfile-body{display:grid;grid-template-columns:.55fr 1.45fr;gap:var(--gap);}.policy-deepfile .deepfile-body>p{margin:0;color:var(--neutral-300);}.policy-deepfile .deepfile-body>div{display:grid;gap:.65rem;}.policy-deepfile .article{border:1px solid rgba(255,255,255,.22);border-radius:var(--radius-md);padding:.85rem;}.policy-deepfile h3{margin:0 0 .3rem;color:var(--neutral-0);font-size:1rem;}.policy-deepfile .article p{margin:0;color:var(--neutral-300);}
@media (max-width:780px){.policy-deepfile .deepfile-body{grid-template-columns:1fr;}}

.rules{padding:clamp(56px,8vw,96px) clamp(16px,4vw,36px);background:var(--card-bg);color:var(--card-fg);}

    .rules .wrap{max-width:900px;margin:0 auto;}

    .rules .section-head{margin-bottom:16px;text-align:center;}

    .rules h2{margin:0;font-size:clamp(28px,4vw,40px);}

    .rules .section-head p{margin:10px auto 0;color:var(--muted-fg);max-width:70ch;}

    .rules ol{margin:0;padding-left:18px;display:grid;gap:10px;}

    .rules li{background:var(--muted-bg);border-radius:var(--radius-md);border:1px solid var(--card-border);padding:12px;color:var(--muted-fg);}

    .rules h3{margin:0;font-size:1rem;}

    .rules li p{margin:8px 0 0;color:var(--muted-fg);}

.thank{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--inverse-bg);color:var(--inverse-fg);} .thank .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);} .thank h2{margin:0;font-size:clamp(1.85rem,3.6vw,2.8rem);line-height:1.1;} .thank .sub{margin:.35rem 0 0;opacity:.9;} .thank article,.thank li{padding:.85rem;border-radius:var(--radius-sm);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);list-style:none;color:var(--accent-fg);} .thank p{margin:0;} .thank a{text-decoration:none;color:inherit;font-weight:700;} .thank .split{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);} .thank .panel{padding:1rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid var(--btn-ghost-bg-hover);color:var(--accent-fg);} .thank .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;} @media (max-width:860px){.thank .split,.thank .media,.thank .grid,.thank .cards,.thank .bento,.thank .foot{grid-template-columns:1fr;}}

.unavailable{padding:clamp(56px,10vw,112px) 20px;background:linear-gradient(150deg,var(--primary-bg),var(--accent-bg));color:var(--primary-fg);}

    .unavailable .shell{max-width:700px;margin:0 auto;text-align:center;border-radius:var(--radius-xl);padding:clamp(28px,4vw,44px);background:rgba(15, 23, 42,.24);border:1px solid color-mix(in srgb, currentColor 24%, transparent);color:var(--neutral-0);}

    .unavailable h1{margin:0;font-size:clamp(32px,6vw,56px);}

    .unavailable p{margin:12px 0 0;opacity:.9;}

    .unavailable a{display:inline-block;margin-top:18px;padding:10px 16px;border-radius:var(--radius-sm);background:var(--page-bg);color:var(--page-fg);text-decoration:none;}