/* =========================================================
   SASCOM IT | Hoja de estilos corporativa
   Archivo: css/sascom.css
   Uso: estilos generales para el sitio corporativo
   ========================================================= */

/* =========================================================
   FUENTES CORPORATIVAS
   ========================================================= */
@font-face {
  font-family: 'Kohinoor Devanagari';
  src: url('../fonts/KohinoorDevanagari-Book.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Kohinoor Devanagari';
  src: url('../fonts/KohinoorDevanagari-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Kohinoor Devanagari';
  src: url('../fonts/KohinoorDevanagari-Demi.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Kohinoor Devanagari';
  src: url('../fonts/KohinoorDevanagari-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Venus Rising';
  src: url('../fonts/VENUSRIS.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* =========================================================
   VARIABLES CORPORATIVAS
   Colores oficiales SASCOM IT:
   #F1F1F1 | #1A1A1A | #002AA9 | #CB7F00
   ========================================================= */
:root {
  --sascom-blue: #002AA9;
  --sascom-blue-dark: #001A66;
  --sascom-blue-deep: #061536;
  --sascom-blue-soft: #EAF0FF;
  --sascom-gold: #CB7F00;
  --sascom-gold-soft: #FFF3DD;
  --sascom-gray: #F1F1F1;
  --sascom-white: #FFFFFF;
  --sascom-black: #1A1A1A;
  --sascom-text: #3E4654;
  --sascom-muted: #6B7280;

  --sascom-font-main: 'Kohinoor Devanagari', Arial, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --sascom-font-display: 'Venus Rising', 'Kohinoor Devanagari', Arial, sans-serif;

  --sascom-radius-sm: .9rem;
  --sascom-radius-md: 1.25rem;
  --sascom-radius-lg: 2rem;

  --sascom-shadow-sm: 0 10px 24px rgba(26, 26, 26, .07);
  --sascom-shadow-md: 0 20px 42px rgba(0, 42, 169, .16);
  --sascom-shadow-lg: 0 28px 80px rgba(0, 0, 0, .35);
}

/* =========================================================
   BASE
   ========================================================= */
* {
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  min-height: 100%;
  overflow-x: hidden;
}

body {
  font-family: var(--sascom-font-main);
  color: var(--sascom-black);
  background:
    radial-gradient(circle at 15% 10%, rgba(203, 127, 0, .22), transparent 28%),
    radial-gradient(circle at 90% 15%, rgba(0, 42, 169, .38), transparent 30%),
    linear-gradient(135deg, #061536 0%, #002AA9 48%, #071229 100%);
}

img {
  max-width: 100%;
  height: auto;
}

a {
  transition: color .2s ease, background-color .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

/* =========================================================
   LAYOUT GENERAL
   ========================================================= */
.page-shell {
  min-height: 100vh;
  padding: 1rem;
  display: flex;
  align-items: center;
}

.intro-card {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  border: 1px solid rgba(255, 255, 255, .28);
  border-radius: var(--sascom-radius-lg);
  overflow: hidden;
  background: rgba(255, 255, 255, .96);
  box-shadow: var(--sascom-shadow-lg);
  position: relative;
}

/* =========================================================
   PANEL HERO / INICIO
   ========================================================= */
.brand-panel {
  min-height: 100%;
  color: var(--sascom-white);
  background:
    linear-gradient(160deg, rgba(6, 21, 54, .97), rgba(0, 42, 169, .94)),
    url('https://sascom.mx/assets/brand/sistemas/bg-code.jpg');
  background-size: cover;
  background-position: center;
  position: relative;
  isolation: isolate;
}

.brand-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
  background-size: 38px 38px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.9), transparent 90%);
  z-index: -1;
}

.brand-panel::after {
  content: "</>";
  position: absolute;
  right: 1.2rem;
  bottom: .5rem;
  font-size: clamp(6rem, 20vw, 15rem);
  font-weight: 700;
  line-height: 1;
  color: rgba(255,255,255,.055);
  z-index: -1;
}

.logo-box {
  background: rgba(255,255,255,.97);
  border-radius: var(--sascom-radius-md);
  display: inline-flex;
  padding: .95rem 1.15rem;
  box-shadow: 0 16px 35px rgba(0,0,0,.18);
}

.brand-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.logo-box img {
  width: min(285px, 72vw);
  height: auto;
}

.eyebrow {
  display: flex;
  width: min(285px, 72vw);
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .5rem .85rem;
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  color: #FFFFFF;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .02em;
  white-space: nowrap;
}


.eyebrow i {
  color: var(--sascom-gold);
}

.hero-title {
  font-size: clamp(2.1rem, 5vw, 4.45rem);
  line-height: .98;
  font-weight: 700;
  letter-spacing: -.045em;
}

.hero-title span {
  color: var(--sascom-gold);
}

.hero-copy {
  color: rgba(255,255,255,.80);
  font-size: clamp(1rem, 1.6vw, 1.16rem);
  max-width: 620px;
}

/* =========================================================
   BOTONES
   ========================================================= */
.btn-sascom {
  --bs-btn-bg: var(--sascom-gold);
  --bs-btn-border-color: var(--sascom-gold);
  --bs-btn-hover-bg: #E19713;
  --bs-btn-hover-border-color: #E19713;
  --bs-btn-color: #1A1A1A;
  --bs-btn-hover-color: #1A1A1A;
  font-weight: 700;
  border-radius: 999px;
  box-shadow: 0 14px 30px rgba(203,127,0,.30);
}

.btn-glass {
  color: var(--sascom-white);
  border-color: rgba(255,255,255,.35);
  background: rgba(255,255,255,.08);
  border-radius: 999px;
  font-weight: 600;
}

.btn-glass:hover {
  color: var(--sascom-white);
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.5);
}

/* =========================================================
   CONTACTO RÁPIDO
   ========================================================= */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  width: 100%;
}

.brand-panel .contact-grid {
  margin-top: 1rem;
}

.contact-tile {
  min-height: 92px;
  border-radius: 1.2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  padding: .75rem;
  color: var(--sascom-white);
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(14px);
  transition:
    transform .22s ease,
    background .22s ease,
    border-color .22s ease;
}

.contact-tile:hover {
  color: var(--sascom-white);
  transform: translateY(-3px);
  background: rgba(255,255,255,.18);
  border-color: rgba(203,127,0,.55);
}

.contact-tile i {
  font-size: 1.45rem;
  color: var(--sascom-gold);
}

.contact-tile span {
  font-size: .82rem;
  font-weight: 700;
}

/* =========================================================
   PANEL DE ACCESOS / NAVEGACIÓN
   ========================================================= */
.menu-panel {
  background:
    radial-gradient(circle at 88% 8%, rgba(203,127,0,.12), transparent 26%),
    linear-gradient(180deg, #FFFFFF 0%, #F1F1F1 100%);
}

.quick-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  width: 100%;
  padding: 1rem;
  border-radius: var(--sascom-radius-md);
  text-decoration: none;
  color: var(--sascom-black);
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(0,42,169,.08);
  box-shadow: 0 12px 30px rgba(26, 26, 26, .07);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.quick-card:hover {
  color: var(--sascom-black);
  transform: translateY(-3px);
  border-color: rgba(203,127,0,.38);
  box-shadow: var(--sascom-shadow-md);
}

.quick-icon {
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 1rem;
  color: var(--sascom-white);
  background: linear-gradient(135deg, var(--sascom-blue), var(--sascom-blue-dark));
  box-shadow: 0 12px 24px rgba(0,42,169,.24);
  font-size: 1.25rem;
}

.quick-title {
  display: block;
  font-weight: 700;
  color: var(--sascom-blue-dark);
  line-height: 1.1;
}

.quick-text {
  display: block;
  color: var(--sascom-text);
  font-size: .88rem;
  margin-top: .25rem;
}

/* =========================================================
   ÁREAS DE SOLUCIÓN
   ========================================================= */
.solutions-box {
  border-radius: 1.4rem;
  padding: 1.1rem;
  background: var(--sascom-blue-soft);
  border: 1px solid rgba(0,42,169,.08);
  box-shadow: 0 12px 28px rgba(26, 26, 26, .06);
}

.solutions-title {
  color: var(--sascom-blue-dark);
  font-weight: 700;
  font-size: .95rem;
  margin-bottom: .85rem;
}

.solution-item {
  display: flex;
  align-items: center;
  gap: .65rem;
  color: var(--sascom-text);
  font-size: .84rem;
  padding: .38rem 0;
  border-bottom: 1px solid rgba(0,42,169,.08);
}

.solution-item:last-child {
  border-bottom: 0;
}

.solution-item i {
  color: var(--sascom-gold);
  font-size: 1rem;
}

/* =========================================================
   TARJETAS DE SERVICIO / MÉTRICAS
   ========================================================= */
.metric-card {
  border-radius: 1.2rem;
  padding: 1rem;
  height: 100%;
  background: var(--sascom-white);
  border: 1px solid rgba(0,42,169,.08);
  box-shadow: var(--sascom-shadow-sm);
}

.metric-card strong {
  display: block;
  font-family: var(--sascom-font-display);
  font-size: .9rem;
  color: var(--sascom-blue-dark);
  line-height: 1;
  letter-spacing: .02em;
}

.metric-card span {
  display: block;
  margin-top: .4rem;
  color: var(--sascom-text);
  font-size: .78rem;
  line-height: 1.15;
}

/* =========================================================
   UTILIDADES CORPORATIVAS
   ========================================================= */
.text-sascom-blue {
  color: var(--sascom-blue) !important;
}

.text-sascom-gold {
  color: var(--sascom-gold) !important;
}

.bg-sascom-blue {
  background-color: var(--sascom-blue) !important;
}

.bg-sascom-gray {
  background-color: var(--sascom-gray) !important;
}

.bg-sascom-soft {
  background-color: var(--sascom-blue-soft) !important;
}

.border-sascom-soft {
  border-color: rgba(0,42,169,.08) !important;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 991.98px) {
  .page-shell {
    align-items: flex-start;
  }

  .brand-panel {
    min-height: auto;
  }

  .intro-card {
    border-radius: 1.5rem;
  }

  .hero-title {
    max-width: 680px;
  }
}

@media (max-width: 575.98px) {
  body {
    background: linear-gradient(145deg, #061536 0%, #002AA9 100%);
  }

  .page-shell {
    padding: .65rem;
  }

  .brand-panel,
  .menu-panel {
    padding: 1.25rem !important;
  }

  .hero-title {
    font-size: 2.2rem;
  }

  .hero-copy {
    font-size: .96rem;
  }

  .eyebrow {
    width: 100%;
    justify-content: center;
    font-size: .74rem;
    padding: .5rem .65rem;
    letter-spacing: 0;
  }

  .eyebrow .hide-mobile {
    display: none;
  }

  .contact-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: .85rem;
  }

  .contact-tile {
    min-height: 72px;
    border-radius: 1rem;
  }

  .metric-card {
    padding: .85rem;
  }

  .quick-card {
    padding: .85rem;
    border-radius: 1rem;
  }

  .quick-icon {
    width: 42px;
    height: 42px;
    flex-basis: 42px;
    border-radius: .9rem;
  }

  .quick-text {
    font-size: .8rem;
  }
}
