/* ============================================================
   Ink Solutions – Estilos globales del plugin
   ============================================================ */

:root {
  --ink-yellow:  #F4E020;
  --ink-magenta: #E91E8C;
  --ink-cyan:    #00AEEF;
  --ink-dark:    #1a1a1a;
  --ink-gray:    #555;
  --ink-light:   #f8f8f8;
}

/* ---- Botones ---- */
.ink-btn-primary {
  display: inline-block;
  background: var(--ink-magenta);
  color: #fff !important;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  padding: 14px 34px;
  border-radius: 50px;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 6px 28px rgba(233,30,140,.35);
}
.ink-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 40px rgba(233,30,140,.45); }

.ink-btn-secondary {
  display: inline-block;
  border: 2px solid var(--ink-dark);
  color: var(--ink-dark) !important;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  padding: 12px 30px;
  border-radius: 50px;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.ink-btn-secondary:hover { background: var(--ink-dark); color: #fff !important; }

/* ---- Section label badge ---- */
.ink-section-label {
  display: inline-block;
  background: var(--ink-yellow);
  color: var(--ink-dark);
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 4px;
  margin-bottom: 10px;
}
.ink-section-label.pink  { background: var(--ink-magenta); color: #fff; }
.ink-section-label.cyan  { background: var(--ink-cyan);    color: #fff; }
.ink-section-label.dark  { background: var(--ink-dark);    color: #fff; }

/* ---- Utility ---- */
.ink-section-title {
  font-family: 'Poppins', sans-serif;
  font-weight: 900;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  line-height: 1.15;
  color: var(--ink-dark);
  margin-bottom: 14px;
}
.ink-section-title span.accent { color: var(--ink-magenta); }
.ink-section-sub {
  font-size: 1.05rem;
  color: var(--ink-gray);
  line-height: 1.7;
  max-width: 540px;
}

/* ================================================================
   1. HERO
   ================================================================ */
.ink-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: 100px 5% 70px;
  position: relative;
  overflow: hidden;
  background: #fff;
}
.ink-hero-bg { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.ink-hero-bg .shape {
  position: absolute; border-radius: 50%; filter: blur(80px); opacity: .15;
}
.ink-hero-bg .s1 { width:500px;height:500px;background:var(--ink-yellow);top:-100px;right:-100px; }
.ink-hero-bg .s2 { width:400px;height:400px;background:var(--ink-magenta);bottom:-100px;left:-100px; }
.ink-hero-bg .s3 { width:300px;height:300px;background:var(--ink-cyan);top:40%;left:40%; }

.ink-hero-content { position:relative;z-index:1;max-width:580px; }

.ink-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.8);
  border: 1px solid rgba(0,0,0,.1);
  padding: 6px 16px; border-radius: 50px;
  font-size: .82rem; font-weight: 700; color: var(--ink-gray);
  letter-spacing: .5px; margin-bottom: 22px;
}
.ink-hero-badge-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ink-magenta);
  animation: inkPulse 1.5s infinite;
}
@keyframes inkPulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(1.4); }
}

.ink-hero-title {
  font-family: 'Poppins', sans-serif;
  font-weight: 900;
  font-size: clamp(2.2rem,5vw,3.8rem);
  line-height: 1.1;
  color: var(--ink-dark);
  margin-bottom: 20px;
}
.ink-hero-title .t-accent { color: var(--ink-magenta); }

.ink-hero-sub { font-size:1.1rem; color:var(--ink-gray); line-height:1.7; margin-bottom:34px; max-width:480px; }

.ink-hero-btns { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:44px; }

.ink-hero-stats { display:flex; gap:38px; flex-wrap:wrap; }
.ink-stat-num {
  font-family: 'Poppins', sans-serif; font-weight: 900; font-size: 2.2rem; line-height:1;
}
.ink-stat-num.m { color: var(--ink-magenta); }
.ink-stat-num.c { color: var(--ink-cyan); }
.ink-stat-num.y { color: #b8a800; }
.ink-stat-lbl { font-size: .8rem; font-weight: 700; color: var(--ink-gray); letter-spacing: .5px; }

.ink-hero-image {
  position: absolute; right: 5%; top: 50%; transform: translateY(-50%);
  width: clamp(260px,35vw,480px);
  animation: inkFloat 3s ease-in-out infinite alternate;
}
.ink-hero-image img { width:100%; filter:drop-shadow(0 20px 60px rgba(0,0,0,.12)); }
@keyframes inkFloat {
  from { transform: translateY(-50%) translateY(0); }
  to   { transform: translateY(-50%) translateY(-16px); }
}

/* ================================================================
   2. STRIP
   ================================================================ */
.ink-strip {
  background: var(--ink-dark);
  padding: 26px 0;
  overflow: hidden;
  white-space: nowrap;
}
.ink-strip-track {
  display: inline-flex; gap: 52px; align-items: center;
  animation: inkMarquee 20s linear infinite;
}
.ink-strip-item {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Poppins', sans-serif; font-weight: 700; font-size:1rem; color:#fff;
}
.ink-strip-dot { width:8px;height:8px;border-radius:50%;flex-shrink:0; }
.ink-strip-dot.m { background:var(--ink-magenta); }
.ink-strip-dot.y { background:var(--ink-yellow); }
.ink-strip-dot.c { background:var(--ink-cyan); }
@keyframes inkMarquee {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ================================================================
   3. QUIÉNES SOMOS
   ================================================================ */
.ink-quienes {
  display: grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center;
  padding: 90px 5%; background: var(--ink-light);
}
.ink-mv-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:28px; }
.ink-mv-card { border-radius:18px; padding:28px 22px; position:relative; overflow:hidden; }
.ink-mv-card.mision { background:var(--ink-magenta); color:#fff; }
.ink-mv-card.vision { background:var(--ink-dark); color:#fff; }
.ink-mv-card h3 {
  font-family:'Poppins',sans-serif; font-weight:700; font-size:1.05rem; margin-bottom:10px;
}
.ink-mv-card.vision h3 { color:var(--ink-yellow); }
.ink-mv-card p { font-size:.88rem; line-height:1.65; opacity:.92; }
.ink-mv-deco { position:absolute;right:-10px;bottom:-10px;font-size:4.5rem;opacity:.08; pointer-events:none; }

.ink-valores-grid { display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:28px; }
.ink-valor-card {
  background:#fff; border-radius:16px; padding:20px;
  display:flex; align-items:flex-start; gap:12px;
  box-shadow:0 4px 20px rgba(0,0,0,.06);
  transition:transform .2s,box-shadow .2s;
}
.ink-valor-card:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(0,0,0,.1); }
.ink-valor-icon {
  width:42px;height:42px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;
}
.vi-m { background:rgba(233,30,140,.1); }
.vi-y { background:rgba(244,224,32,.22); }
.vi-c { background:rgba(0,174,239,.1); }
.vi-d { background:rgba(26,26,26,.07); }
.ink-valor-card h4 { font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem;color:var(--ink-dark);margin-bottom:4px; }
.ink-valor-card p  { font-size:.8rem;color:var(--ink-gray);line-height:1.5; }

/* ================================================================
   4. SERVICIOS
   ================================================================ */
.ink-servicios { padding:90px 5%;background:#fff; }
.ink-servicios-header { text-align:center;margin-bottom:52px; }
.ink-servicios-header .ink-section-sub { margin:0 auto; }
.ink-servicios-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px; }

.ink-serv-card {
  border-radius:20px;overflow:hidden;background:var(--ink-light);
  transition:transform .3s,box-shadow .3s;
  position:relative;
}
.ink-serv-card:hover { transform:translateY(-6px);box-shadow:0 16px 50px rgba(0,0,0,.1); }
.ink-serv-top { padding:30px 26px 22px;position:relative; }
.ink-serv-num {
  position:absolute;top:18px;right:22px;
  font-family:'Poppins',sans-serif;font-weight:900;font-size:2.8rem;
  opacity:.07;line-height:1;color:var(--ink-dark);
}
.ink-serv-icon {
  width:54px;height:54px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px;
}
.si-m .ink-serv-icon { background:rgba(233,30,140,.1); }
.si-c .ink-serv-icon { background:rgba(0,174,239,.1); }
.si-y .ink-serv-icon { background:rgba(244,224,32,.22); }
.si-d .ink-serv-icon { background:rgba(26,26,26,.08); }

.ink-serv-card h3 { font-family:'Poppins',sans-serif;font-weight:700;font-size:1.1rem;color:var(--ink-dark);margin-bottom:10px; }
.ink-serv-card p  { font-size:.88rem;color:var(--ink-gray);line-height:1.65; }
.ink-serv-bottom  { padding:0 26px 22px; }
.ink-serv-cta {
  font-family:'Poppins',sans-serif;font-weight:700;font-size:.85rem;
  color:var(--ink-magenta);text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;transition:gap .2s;
}
.ink-serv-cta:hover { gap:10px; }

/* ================================================================
   5. GALERÍA
   ================================================================ */
.ink-galeria { background:var(--ink-dark);padding:90px 5%;text-align:center; }
.ink-galeria .ink-section-title { color:#fff; }
.ink-galeria .ink-section-sub   { color:rgba(255,255,255,.6);margin:0 auto 16px; }
.ink-galeria-quote {
  font-family:'Poppins',sans-serif;font-weight:700;
  font-size:clamp(1.1rem,2.5vw,1.5rem);
  color:var(--ink-yellow);font-style:italic;margin-bottom:44px;
}
.ink-gallery-grid {
  display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:200px 200px;gap:14px;
}
.ink-gallery-item {
  border-radius:16px;overflow:hidden;position:relative;
  display:flex;align-items:center;justify-content:center;
  background:#2a2a2a;
}
.ink-gallery-item:first-child { grid-row:1 / 3; }
.ink-gi-label {
  position:absolute;bottom:14px;left:14px;
  background:rgba(0,0,0,.65);color:#fff;
  font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;
  padding:5px 12px;border-radius:50px;
}
.ink-gi-icon { font-size:2.8rem;opacity:.25; }
.gi-1 { background:linear-gradient(135deg,rgba(233,30,140,.3),rgba(233,30,140,.5)); }
.gi-2 { background:linear-gradient(135deg,rgba(0,174,239,.25),rgba(0,174,239,.45)); }
.gi-3 { background:linear-gradient(135deg,rgba(244,224,32,.2),rgba(244,224,32,.4)); }
.gi-4 { background:linear-gradient(135deg,rgba(233,30,140,.15),rgba(0,174,239,.25)); }
.gi-5 { background:linear-gradient(135deg,rgba(244,224,32,.15),rgba(233,30,140,.25)); }

/* ================================================================
   6. TESTIMONIOS
   ================================================================ */
.ink-testimonios { padding:90px 5%;background:var(--ink-light); }
.ink-testimonios-header { text-align:center;margin-bottom:46px; }
.ink-testimonios-header .ink-section-sub { margin:0 auto; }
.ink-test-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px; }

.ink-test-card {
  background:#fff;border-radius:20px;padding:28px;
  box-shadow:0 4px 20px rgba(0,0,0,.06);
  position:relative;transition:transform .2s;
}
.ink-test-card:hover { transform:translateY(-4px); }
.ink-test-card::before {
  content:'"';font-family:'Poppins',sans-serif;font-size:5rem;line-height:.8;
  color:var(--ink-magenta);opacity:.12;
  position:absolute;top:16px;left:18px;font-weight:900;pointer-events:none;
}
.ink-test-stars { color:var(--ink-yellow);font-size:1rem;margin-bottom:12px;letter-spacing:2px; }
.ink-test-text  { font-size:.92rem;color:var(--ink-gray);line-height:1.7;margin-bottom:20px; }
.ink-test-author { display:flex;align-items:center;gap:12px; }
.ink-test-avatar {
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Poppins',sans-serif;font-weight:700;font-size:1rem;color:#fff;flex-shrink:0;
}
.av-m { background:var(--ink-magenta); }
.av-c { background:var(--ink-cyan); }
.av-y { background:#b8a800; }
.ink-test-name    { font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem; }
.ink-test-company { font-size:.8rem;color:var(--ink-gray); }

/* ================================================================
   7. CONTACTO
   ================================================================ */
.ink-contacto {
  padding:90px 5%;background:#fff;
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;
}
.ink-contact-items { display:flex;flex-direction:column;gap:20px;margin-top:30px; }
.ink-contact-item  { display:flex;align-items:flex-start;gap:16px; }
.ink-ci-icon {
  width:48px;height:48px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;
}
.ci-wh  { background:rgba(37,211,102,.12); }
.ci-em  { background:rgba(233,30,140,.12); }
.ci-fb  { background:rgba(0,119,255,.12); }
.ci-loc { background:rgba(0,174,239,.12); }
.ink-ci-txt h4 { font-family:'Poppins',sans-serif;font-weight:700;font-size:.95rem;margin-bottom:4px; }
.ink-ci-txt a,
.ink-ci-txt p  { font-size:.9rem;color:var(--ink-gray);text-decoration:none; }
.ink-ci-txt a:hover { color:var(--ink-magenta); }

.ink-contact-form-wrap { background:var(--ink-light);border-radius:24px;padding:38px; }
.ink-contact-form-wrap h3 {
  font-family:'Poppins',sans-serif;font-weight:700;font-size:1.25rem;
  color:var(--ink-dark);margin-bottom:26px;
}
.ink-form-grid { display:grid;grid-template-columns:1fr 1fr;gap:14px; }
.ink-form-grid .full { grid-column:1 / -1; }
.ink-form-field { display:flex;flex-direction:column;gap:6px; }
.ink-form-field label {
  font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;
  color:var(--ink-gray);letter-spacing:.5px;text-transform:uppercase;
}
.ink-form-field input,
.ink-form-field textarea,
.ink-form-field select {
  padding:12px 16px;border-radius:12px;border:2px solid transparent;
  background:#fff;font-family:'Lato',sans-serif;font-size:.95rem;color:var(--ink-dark);
  outline:none;transition:border-color .2s;resize:none;
}
.ink-form-field input:focus,
.ink-form-field textarea:focus,
.ink-form-field select:focus { border-color:var(--ink-magenta); }
.ink-form-field textarea { min-height:110px; }
.ink-form-submit {
  width:100%;margin-top:8px;
  background:var(--ink-magenta);color:#fff;
  padding:15px;border-radius:50px;border:none;
  font-family:'Poppins',sans-serif;font-weight:700;font-size:1rem;
  cursor:pointer;transition:transform .2s,box-shadow .2s;
  box-shadow:0 6px 28px rgba(233,30,140,.3);
}
.ink-form-submit:hover { transform:translateY(-2px);box-shadow:0 10px 38px rgba(233,30,140,.4); }

/* ================================================================
   8. FOOTER
   ================================================================ */
.ink-footer { background:var(--ink-dark);padding:60px 5% 28px; }
.ink-footer-top {
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;
}
.ink-footer-logo {
  font-family:'Poppins',sans-serif;font-weight:900;font-size:1.6rem;color:#fff;
  display:inline-block;margin-bottom:12px;
}
.ink-footer-logo em { font-style:normal;color:var(--ink-magenta); }
.ink-footer-desc { font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.7;max-width:230px; }
.ink-footer-col h4 { font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem;color:#fff;margin-bottom:16px; }
.ink-footer-col ul { list-style:none;display:flex;flex-direction:column;gap:10px; }
.ink-footer-col ul a { font-size:.85rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color .2s; }
.ink-footer-col ul a:hover { color:var(--ink-magenta); }
.ink-social-links { display:flex;gap:10px;margin-top:18px; }
.ink-social-link {
  width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.6);text-decoration:none;font-size:.95rem;
  transition:background .2s,color .2s,border-color .2s;
}
.ink-social-link:hover { background:var(--ink-magenta);color:#fff;border-color:var(--ink-magenta); }
.ink-footer-bottom {
  border-top:1px solid rgba(255,255,255,.08);padding-top:22px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.ink-footer-copy { font-size:.82rem;color:rgba(255,255,255,.35); }
.ink-cmyk-bar { display:flex;gap:4px; }
.ink-cmyk-bar span { width:12px;height:12px;border-radius:3px; }

/* ================================================================
   WhatsApp flotante
   ================================================================ */
.ink-wa-float {
  position:fixed;bottom:28px;right:28px;z-index:9999;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;text-decoration:none;
  box-shadow:0 6px 28px rgba(37,211,102,.45);
  transition:transform .2s,box-shadow .2s;
}
.ink-wa-float:hover { transform:scale(1.1);box-shadow:0 10px 38px rgba(37,211,102,.55); }
.ink-wa-tooltip {
  position:absolute;right:66px;bottom:50%;transform:translateY(50%);
  background:var(--ink-dark);color:#fff;white-space:nowrap;
  font-family:'Poppins',sans-serif;font-weight:700;font-size:.8rem;
  padding:7px 14px;border-radius:8px;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.ink-wa-float:hover .ink-wa-tooltip { opacity:1; }

/* ================================================================
   Responsive
   ================================================================ */
@media (max-width:900px) {
  .ink-quienes,
  .ink-contacto { grid-template-columns:1fr;gap:44px; }
  .ink-footer-top { grid-template-columns:1fr 1fr;gap:28px; }
  .ink-hero-image { display:none; }
  .ink-gallery-grid { grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,160px); }
  .ink-gallery-item:first-child { grid-row:auto; }
  .ink-mv-grid { grid-template-columns:1fr; }
}
@media (max-width:600px) {
  .ink-hero { padding:90px 4% 56px; }
  .ink-footer-top { grid-template-columns:1fr; }
  .ink-form-grid { grid-template-columns:1fr; }
  .ink-form-grid .full { grid-column:auto; }
  .ink-gallery-grid { grid-template-columns:1fr;grid-template-rows:repeat(5,150px); }
  .ink-gallery-item:first-child { grid-row:auto; }
  .ink-valores-grid { grid-template-columns:1fr; }
}
