/* ============================================================
   GIASEG — Design System V5
   Inter · Azul Institucional · Oro · Púrpura
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --blue-dark:#1D3861; --blue-main:#2596BE;
  --blue-soft:rgba(37,150,190,0.09); --blue-border:rgba(37,150,190,0.22);
  --gold:#B99A4A; --gold-strong:#A9822E; --gold-soft:#FFF6DA;
  --purple:#6D3FE5; --purple-soft:#F1ECFF;
  --ink:#1F2937; --ink-soft:#334155; --muted:#64748B; --muted-2:#8995A6;
  --bg:#F7F9FC; --bg-warm:#F7F4EE; --surface:#FFFFFF;
  --surface-2:#EEF3F7; --line:#DDE5EC;
  --success:#22C55E; --error:#EF4444;
  --font:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',sans-serif;
  --shadow:0 22px 70px rgba(29,56,97,.10);
  --shadow-soft:0 16px 40px rgba(29,56,97,.07);
  --shadow-sm:0 4px 16px rgba(29,56,97,.07);
  --radius-xl:32px; --radius-lg:24px; --radius-md:16px;
  --radius-sm:10px; --radius-pill:999px;
  --ease:cubic-bezier(.4,0,.2,1); --transition:.22s var(--ease);
  --nav-h:78px; --max-w:1180px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font);
  background:
    radial-gradient(circle at 6% 0%,rgba(37,150,190,.11),transparent 27rem),
    radial-gradient(circle at 94% 8%,rgba(185,154,74,.12),transparent 29rem),
    linear-gradient(180deg,#fff 0%,var(--bg) 42%,#F3F6FA 100%);
  background-attachment:fixed;
  color:var(--ink);line-height:1.58;letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;min-height:100vh;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font:inherit}
::selection{background:var(--purple-soft);color:var(--ink)}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--blue-main);border-radius:3px}

/* Typography */
h1,h2,h3,h4,h5{color:var(--blue-dark);line-height:1.12;letter-spacing:-.04em}
h1{font-size:clamp(2.3rem,5vw,4rem);font-weight:700}
h2{font-size:clamp(1.65rem,3vw,2.4rem);font-weight:700}
h3{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:700}
h4{font-size:1rem;font-weight:600;letter-spacing:-.02em}
h1 span,h2 span{color:var(--blue-main)}
p{color:var(--muted);line-height:1.7}

/* Layout */
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}
.section{padding:5.5rem 0}
.section-sm{padding:3.5rem 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.flex-gap{display:flex;gap:1rem;flex-wrap:wrap}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.w-full{width:100%}
.section-header{text-align:center;max-width:680px;margin:0 auto 3.5rem}
.section-header .eyebrow{margin-bottom:1rem}
.section-header h2{margin-bottom:1rem}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.section-head p{max-width:420px;font-size:.92rem}

/* Eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:var(--radius-pill);
  background:var(--blue-soft);border:1px solid var(--blue-border);
  color:var(--blue-dark);font-size:.78rem;font-weight:600;letter-spacing:.04em;
}
.eyebrow::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--blue-main);box-shadow:0 0 0 4px rgba(37,150,190,.15);flex-shrink:0}
.eyebrow.gold{background:var(--gold-soft);border-color:rgba(185,154,74,.3);color:var(--gold-strong)}
.eyebrow.gold::before{background:var(--gold);box-shadow:0 0 0 4px rgba(185,154,74,.15)}
.eyebrow.purple{background:var(--purple-soft);border-color:rgba(109,63,229,.2);color:var(--purple)}
.eyebrow.purple::before{background:var(--purple);box-shadow:0 0 0 4px rgba(109,63,229,.15)}
.kicker{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-main);margin-bottom:.5rem;display:block}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:46px;padding:0 22px;border-radius:var(--radius-pill);
  border:1px solid transparent;
  font-family:var(--font);font-size:.9rem;font-weight:800;letter-spacing:-.015em;
  white-space:nowrap;cursor:pointer;
  transition:transform var(--transition),box-shadow var(--transition),background var(--transition),border-color var(--transition);
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--blue-dark);color:var(--bg);box-shadow:0 16px 34px rgba(29,56,97,.20)}
.btn-primary:hover{background:#274777;box-shadow:0 20px 40px rgba(29,56,97,.28)}
.btn-blue{background:var(--blue-main);color:var(--bg);box-shadow:0 16px 34px rgba(37,150,190,.22)}
.btn-blue:hover{background:#1e82a8;box-shadow:0 20px 40px rgba(37,150,190,.32)}
.btn-gold{background:var(--gold);color:var(--blue-dark);box-shadow:0 16px 34px rgba(185,154,74,.22)}
.btn-gold:hover{background:#c8a84f;box-shadow:0 20px 40px rgba(185,154,74,.32)}
.btn-purple{background:var(--purple);color:#fff;box-shadow:0 16px 34px rgba(109,63,229,.22)}
.btn-purple:hover{background:#5d34cc}
.btn-secondary{background:rgba(255,255,255,.9);color:var(--ink);border-color:var(--line);box-shadow:0 8px 18px rgba(31,41,55,.07)}
.btn-secondary:hover{background:var(--surface);box-shadow:0 12px 24px rgba(31,41,55,.12)}
.btn-ghost-dark{background:rgba(247,249,252,.10);color:var(--bg);border-color:rgba(247,249,252,.32)}
.btn-ghost-dark:hover{background:rgba(247,249,252,.18)}
.btn-sm{min-height:36px;padding:0 16px;font-size:.83rem}
.btn-lg{min-height:54px;padding:0 28px;font-size:.96rem}
.component-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:1.25rem;align-items:center}

/* Topline */
.topline{height:4px;background:linear-gradient(90deg,var(--blue-dark),var(--blue-main),var(--purple),var(--gold))}
#topbar{position:fixed;top:0;left:0;right:0;z-index:1001}

/* Navbar */
#navbar{
  position:fixed;top:4px;left:0;right:0;z-index:1000;height:var(--nav-h);
  background:rgba(255,255,255,.93);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);transition:box-shadow var(--transition);
}
#navbar.scrolled{box-shadow:0 4px 32px rgba(29,56,97,.10)}
.nav-inner{
  max-width:var(--max-w);margin:0 auto;padding:0 1.5rem;height:100%;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
/* Logo */
.nav-logo{display:flex;align-items:center;flex-direction:column;align-items:flex-start;flex-shrink:0}
.logo-text{font-family:var(--font);font-size:1.65rem;font-weight:900;letter-spacing:-.06em;line-height:1}
.logo-iso{color:var(--blue-main)}
.logo-suru{color:var(--blue-dark)}
.logo-tagline{font-size:.5rem;font-weight:500;color:var(--muted-2);letter-spacing:.14em;text-transform:uppercase;margin-top:3px}
/* Nav links */
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{
  padding:8px 11px;font-size:.84rem;font-weight:500;color:var(--muted);
  border-radius:var(--radius-sm);transition:all var(--transition);
  position:relative;white-space:nowrap;
}
.nav-links a::after{
  content:'';position:absolute;left:11px;right:11px;bottom:2px;
  height:2px;border-radius:99px;background:var(--blue-main);
  opacity:0;transform:scaleX(.5);transition:.2s ease;
}
.nav-links a:hover{color:var(--blue-dark)}
.nav-links a:hover::after,.nav-links a.active::after{opacity:1;transform:scaleX(1)}
.nav-links a.active{color:var(--blue-dark);font-weight:600}
.nav-proveedores{
  background:var(--purple-soft)!important;color:var(--purple)!important;
  border-radius:var(--radius-pill)!important;padding:6px 14px!important;
  font-weight:700!important;border:1px solid rgba(109,63,229,.2)!important;
}
.nav-proveedores::after{display:none!important}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.lang-toggle{
  font-size:.77rem;font-weight:700;letter-spacing:.06em;color:var(--blue-dark);
  border:1px solid var(--line);border-radius:var(--radius-pill);
  padding:6px 14px;background:none;cursor:pointer;transition:all var(--transition);
}
.lang-toggle:hover{background:var(--blue-dark);color:var(--bg);border-color:var(--blue-dark)}
/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all var(--transition)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
/* Mobile nav */
.mobile-nav{
  display:none;position:fixed;top:calc(var(--nav-h) + 4px);left:0;right:0;
  background:var(--surface);border-bottom:1px solid var(--line);
  padding:1.25rem 1.5rem;flex-direction:column;gap:4px;z-index:999;
  box-shadow:var(--shadow-soft);
}
.mobile-nav.open{display:flex}
.mobile-nav a{color:var(--ink-soft);padding:10px 12px;border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;transition:all var(--transition)}
.mobile-nav a:hover{background:var(--surface-2);color:var(--blue-dark)}
.mobile-nav .lang-toggle{align-self:flex-start;margin-top:8px}

/* Hero */
.hero{padding:calc(var(--nav-h) + 4px + 4.5rem) 0 4rem}
.hero-inner{display:grid;grid-template-columns:1fr .88fr;gap:3.5rem;align-items:center}
.hero-eyebrow{margin-bottom:1.5rem;display:inline-flex}
.hero h1{max-width:640px;margin-bottom:1.25rem}
.hero-copy{color:var(--ink-soft);font-size:1.08rem;line-height:1.65;max-width:560px;margin-bottom:2rem}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:1.75rem}
.hero-chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;
  border-radius:var(--radius-pill);background:var(--surface);border:1px solid var(--line);
  font-size:.78rem;font-weight:600;color:var(--ink-soft);box-shadow:var(--shadow-sm);
}
.chip i{color:var(--blue-main);font-size:.85rem}
.chip.gold-chip i{color:var(--gold)}

/* Featured product (hero right) */
.featured-product{position:relative;padding-top:18px}
.featured-tag{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--blue-dark);
  font-size:.7rem;font-weight:800;padding:5px 16px;
  border-radius:var(--radius-pill);white-space:nowrap;z-index:2;
  box-shadow:0 4px 14px rgba(185,154,74,.3);
}
.product-card{
  background:var(--surface);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);
}
.product-card-head{
  background:linear-gradient(135deg,var(--blue-dark),#274777);
  padding:1.6rem 1.75rem;display:flex;align-items:flex-start;gap:1rem;
}
.product-icon{
  width:50px;height:50px;
  background:rgba(37,150,190,.15);border:1px solid rgba(37,150,190,.3);
  border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;flex-shrink:0;
}
.product-card-head small{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-main);display:block;margin-bottom:4px}
.product-card-head h3{color:#FAFAF7;font-size:1.15rem}
.product-card-body{padding:1.6rem 1.75rem}
.product-card-body p{font-size:.88rem;color:var(--ink-soft);margin-bottom:1.1rem;line-height:1.65}
.product-list{display:flex;flex-direction:column;gap:7px;margin-bottom:1.4rem}
.product-list li{display:flex;align-items:center;gap:7px;font-size:.84rem;color:var(--ink-soft)}
.product-list li i{color:var(--blue-main);font-size:.72rem;flex-shrink:0}
.product-actions{display:flex;gap:8px;flex-wrap:wrap}
.product-actions .btn{flex:1;min-width:120px}

/* Cards */
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:1.75rem;
  transition:box-shadow var(--transition),transform var(--transition);
}
.card:hover{box-shadow:var(--shadow-soft);transform:translateY(-3px)}
.kit-card{padding:0;overflow:hidden}
.kit-head{
  background:linear-gradient(135deg,var(--blue-dark),#274777);
  padding:1.4rem 1.75rem;display:flex;align-items:center;gap:1rem;
}
.kit-icon{
  width:46px;height:46px;background:rgba(37,150,190,.15);border:1px solid rgba(37,150,190,.3);
  border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;
}
.kit-head small{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-main);display:block;margin-bottom:3px}
.kit-head h3{color:#FAFAF7;font-size:1.05rem}
.kit-body{padding:1.5rem 1.75rem}
.kit-body p{font-size:.88rem;margin-bottom:1rem}
.feature-icon{
  width:50px;height:50px;background:var(--blue-soft);border:1px solid var(--blue-border);
  border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;margin-bottom:1rem;transition:all var(--transition);
}
.card:hover .feature-icon{background:var(--blue-dark);border-color:var(--blue-dark)}
.list{display:flex;flex-direction:column;gap:8px}
.list li{display:flex;align-items:flex-start;gap:8px;font-size:.88rem;color:var(--ink-soft);line-height:1.5}
.list li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--blue-main);margin-top:7px;flex-shrink:0}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 10px;border-radius:var(--radius-pill);font-size:.72rem;font-weight:700;background:var(--blue-soft);color:var(--blue-dark);border:1px solid var(--blue-border)}
.badge.gold{background:var(--gold-soft);color:var(--gold-strong);border-color:rgba(185,154,74,.3)}
.badge.purple{background:var(--purple-soft);color:var(--purple);border-color:rgba(109,63,229,.2)}
.badge.dark{background:var(--ink);color:var(--bg);border-color:transparent}
.badge.success{background:rgba(34,197,94,.1);color:#166534;border-color:rgba(34,197,94,.25)}
.badge.error{background:rgba(239,68,68,.1);color:#991b1b;border-color:rgba(239,68,68,.25)}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;align-items:start}
.pricing-card{background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}
.pricing-card:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:var(--blue-main)}
.pricing-card.featured{border-color:var(--blue-main);box-shadow:var(--shadow)}
.pricing-header{padding:1.75rem;border-bottom:1px solid var(--line)}
.pricing-card.featured .pricing-header{background:linear-gradient(135deg,var(--blue-dark),#274777);border-bottom-color:rgba(37,150,190,.2)}
.plan-label{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-main);margin-bottom:6px}
.pricing-header h3{font-size:1.35rem;margin-bottom:1rem}
.pricing-card.featured .pricing-header h3{color:#FAFAF7}
.price{display:flex;align-items:baseline;gap:3px}
.price-currency{font-size:1rem;font-weight:700;color:var(--blue-main)}
.price-amount{font-size:2.7rem;font-weight:900;letter-spacing:-.06em;color:var(--blue-dark);line-height:1}
.pricing-card.featured .price-amount{color:#FAFAF7}
.price-period{font-size:.84rem;color:var(--muted);margin-left:2px}
.pricing-card.featured .price-period{color:rgba(247,249,252,.5)}
.pricing-body{padding:1.75rem}
.pricing-card.featured .pricing-body{background:var(--blue-dark)}
.feature-list{display:flex;flex-direction:column;gap:10px;margin-bottom:1.75rem}
.feature-list li{display:flex;align-items:flex-start;gap:8px;font-size:.87rem;color:var(--ink-soft)}
.pricing-card.featured .feature-list li{color:rgba(247,249,252,.78)}
.feature-list li i{color:var(--blue-main);margin-top:2px;flex-shrink:0}
.most-popular{display:inline-block;font-size:.64rem;font-weight:800;letter-spacing:.08em;background:var(--blue-main);color:#fff;padding:3px 10px;border-radius:var(--radius-pill);margin-left:6px;vertical-align:middle}

/* Technical boxes */
.technical-box{background:var(--surface-2);border:1px solid var(--line);border-left:4px solid var(--blue-main);border-radius:var(--radius-md);padding:1.5rem}
.technical-box.gold{border-left-color:var(--gold);background:var(--gold-soft)}
.technical-box.dark{background:var(--blue-dark);border-left-color:var(--blue-main);border-color:transparent}
.technical-box.dark h3{color:#FAFAF7}
.technical-box.dark p{color:rgba(247,249,252,.7)}
.technical-box.success{border-left-color:var(--success);background:rgba(34,197,94,.07)}

/* Dark band */
.dark-band{background:var(--blue-dark);border-radius:var(--radius-lg);padding:3.5rem;position:relative;overflow:hidden}
.dark-band::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(37,150,190,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(37,150,190,.05) 1px,transparent 1px);background-size:48px 48px}
.dark-band .kicker{color:var(--blue-main)}
.dark-band h2{color:var(--bg);position:relative}
.dark-band p{color:rgba(247,249,252,.65);position:relative;margin:1rem 0 2rem}
.dark-band .component-row{position:relative}

/* Testimonials */
.testimonial-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.75rem;position:relative}
.testimonial-card::before{content:'"';position:absolute;top:.75rem;left:1.5rem;font-size:4rem;color:var(--blue-main);opacity:.12;line-height:1;font-family:Georgia,serif}
.testimonial-text{font-size:.88rem;line-height:1.75;color:var(--ink-soft);margin-bottom:1.1rem;padding-top:.75rem}
.testimonial-author{display:flex;align-items:center;gap:10px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--blue-soft);border:1px solid var(--blue-border);display:flex;align-items:center;justify-content:center;color:var(--blue-dark);font-weight:700;font-size:.82rem;flex-shrink:0}
.author-name{font-weight:600;font-size:.87rem;color:var(--ink)}
.author-role{font-size:.77rem;color:var(--muted)}

/* Page hero */
.page-hero{background:linear-gradient(135deg,var(--blue-dark),#274777 60%,#1a4080);padding:calc(var(--nav-h) + 4px + 3rem) 0 3.5rem;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(37,150,190,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(37,150,190,.06) 1px,transparent 1px);background-size:56px 56px}
.page-hero-inner{position:relative;z-index:2}
.page-hero .eyebrow{background:rgba(37,150,190,.15);border-color:rgba(37,150,190,.3);color:#FAFAF7;margin-bottom:1rem;display:inline-flex}
.page-hero .eyebrow::before{background:var(--blue-main)}
.page-hero h1{color:#FAFAF7;margin-bottom:1rem}
.page-hero p{color:rgba(247,249,252,.65);max-width:600px;font-size:1.05rem}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.77rem;color:rgba(247,249,252,.4);margin-bottom:1.5rem}
.breadcrumb a{color:rgba(37,150,190,.8)}
.breadcrumb a:hover{color:var(--blue-main)}
.breadcrumb i{font-size:.58rem}

/* Table */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;min-width:500px}
th{background:var(--blue-dark);color:var(--bg);padding:.85rem 1.25rem;text-align:left;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
td{padding:.9rem 1.25rem;border-bottom:1px solid var(--line);font-size:.88rem;color:var(--ink-soft);background:var(--surface)}
td strong{display:block;color:var(--ink);font-size:.9rem}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg)}
.check-yes{color:var(--success)}
.check-no{color:var(--muted-2)}

/* Forms */
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:.83rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.78rem 1rem;border:1.5px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font);font-size:.9rem;color:var(--ink);background:var(--surface);transition:border-color var(--transition),box-shadow var(--transition);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue-main);box-shadow:0 0 0 3px rgba(37,150,190,.12)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

/* Accordion */
.accordion-item{border-bottom:1px solid var(--line)}
.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.2rem 0;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--font);font-size:.92rem;font-weight:600;color:var(--ink);transition:color var(--transition)}
.accordion-header:hover{color:var(--blue-dark)}
.accordion-icon{color:var(--blue-main);transition:transform var(--transition);flex-shrink:0}
.accordion-header.open .accordion-icon{transform:rotate(180deg)}
.accordion-body{font-size:.88rem;color:var(--muted);line-height:1.8;max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .3s}
.accordion-body.open{max-height:600px;padding-bottom:1.5rem}

/* Footer */
footer{background:var(--blue-dark);color:rgba(247,249,252,.6);padding:5rem 0 2rem;position:relative}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue-dark),var(--blue-main),var(--purple),var(--gold))}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:4rem}
.footer-brand p{font-size:.87rem;line-height:1.7;color:rgba(247,249,252,.45);max-width:260px;margin:.75rem 0 1.5rem}
.footer-logo-wrap{margin-bottom:.25rem}
.footer-logo-text{font-size:1.4rem;font-weight:900;letter-spacing:-.05em;display:block;line-height:1}
.footer-logo-text .fi{color:var(--blue-main)}
.footer-logo-text .fs{color:#FAFAF7}
.footer-tagline-f{font-size:.48rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(247,249,252,.3);display:block;margin-top:3px}
.footer-socials{display:flex;gap:8px;margin-top:1.5rem}
.social-btn{width:36px;height:36px;border:1px solid rgba(247,249,252,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(247,249,252,.5);font-size:.85rem;transition:all var(--transition)}
.social-btn:hover{background:var(--blue-main);color:#fff;border-color:var(--blue-main)}
.footer-col h5{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-main);margin-bottom:1.25rem}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col ul a{font-size:.87rem;color:rgba(247,249,252,.5);transition:color var(--transition)}
.footer-col ul a:hover{color:var(--blue-main)}
.footer-bottom{border-top:1px solid rgba(247,249,252,.08);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.77rem;color:rgba(247,249,252,.3)}
.footer-bottom a{color:rgba(37,150,190,.65)}
.footer-bottom a:hover{color:var(--blue-main)}

/* WA Float */
.wa-float{position:fixed;bottom:2rem;right:2rem;z-index:900;width:54px;height:54px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;box-shadow:0 4px 20px rgba(37,211,102,.5);transition:all var(--transition);animation:waPulse 2.5s ease-in-out infinite}
.wa-float:hover{transform:scale(1.1);animation:none;box-shadow:0 6px 28px rgba(37,211,102,.7)}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.5)}50%{box-shadow:0 4px 32px rgba(37,211,102,.8)}}

/* Animations */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* Legal pages */
.legal-layout{display:grid;grid-template-columns:240px 1fr;gap:3rem;align-items:start}
.legal-nav{position:sticky;top:calc(var(--nav-h) + 4px + 2rem);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem}
.legal-nav h5{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-main);margin-bottom:1rem}
.legal-nav a{display:block;font-size:.82rem;color:var(--muted);padding:5px 0 5px 10px;border-left:2px solid transparent;transition:all var(--transition)}
.legal-nav a:hover{color:var(--blue-dark);border-left-color:var(--blue-main)}
.legal-content h2{font-size:1.35rem;margin:2.5rem 0 1rem;padding-top:1rem;border-top:1px solid var(--line)}
.legal-content h2:first-child{margin-top:0;border-top:none}
.legal-content h3{font-size:1rem;margin:1.5rem 0 .75rem;color:var(--blue-dark)}
.legal-content p{margin-bottom:1rem;font-size:.92rem;line-height:1.8}
.legal-content ul{margin:.5rem 0 1.25rem 1.5rem}
.legal-content ul li{font-size:.92rem;line-height:1.75;color:var(--ink-soft);margin-bottom:6px;list-style:disc}
.legal-content table{margin:1rem 0 2rem;font-size:.87rem}
.legal-info-box{background:rgba(37,150,190,.06);border:1px solid var(--blue-border);border-radius:var(--radius-sm);padding:1.1rem 1.4rem;margin:1.5rem 0}
.legal-info-box p{margin:0;font-size:.88rem}
.legal-date{display:inline-block;background:var(--blue-dark);color:var(--bg);font-size:.75rem;padding:4px 14px;border-radius:var(--radius-pill);margin-bottom:2rem}
.pay-methods{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem}
.pay-item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:1.5px solid var(--line);border-radius:var(--radius-md);font-size:.88rem;font-weight:600;color:var(--ink);background:var(--surface)}
.pay-item i{color:var(--blue-main);font-size:1.1rem}

/* Responsive */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .pricing-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .proveedores-services{grid-template-columns:repeat(2,1fr)}
  .proveedores-plans{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  :root{--nav-h:68px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero-inner{grid-template-columns:1fr}
  .featured-product{display:none}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .section{padding:3.5rem 0}
  .legal-layout{grid-template-columns:1fr}
  .legal-nav{display:none}
  .proveedores-services,.proveedores-plans{grid-template-columns:1fr}
}
@media(max-width:480px){
  .wa-float{bottom:1.25rem;right:1.25rem}
  .dark-band{padding:2.5rem 1.5rem}
}


/* GIASEG Phase 1 — official logo image */
.site-logo{width:clamp(190px,18vw,260px);height:auto;object-fit:contain;display:block}
.footer-logo-img{width:min(260px,100%);height:auto;object-fit:contain;filter:none;background:rgba(255,255,255,.96);border-radius:14px;padding:8px 10px}
.nav-inner{max-width:1280px}
.nav-links{gap:0}
.nav-links a{font-size:.8rem;padding:8px 8px}
.footer-col li span{font-size:.87rem;color:rgba(247,249,252,.5)}
@media(max-width:1120px){.nav-links a{font-size:.76rem;padding:8px 6px}.site-logo{width:190px}}
@media(max-width:980px){.nav-links{display:none}.hamburger{display:flex}}


/* ======================== FASE 2A — Ajuste estructural y comercial ======================== */
html{scroll-padding-top:calc(var(--nav-h) + 34px)}
[id]{scroll-margin-top:calc(var(--nav-h) + 42px)}
.section{padding:3.6rem 0}.section-sm{padding:2.5rem 0}.section.compact{padding:3.1rem 0}.section-header{margin-bottom:2.1rem}.section-head{margin-bottom:2rem}.grid-3,.grid-2{gap:1.25rem}.grid-4{gap:1rem}.card{padding:1.35rem}.dark-band{padding:2.5rem}.page-hero{padding:calc(var(--nav-h) + 4px + 2.2rem) 0 2.6rem}.hero{padding:calc(var(--nav-h) + 4px + 3rem) 0 3rem}.hero-inner{gap:2rem}.hero h1{margin-bottom:1rem}.hero-content p{margin-bottom:1.4rem}.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:1.2rem}.align-start{align-items:start}.note-text{font-size:.86rem;color:var(--muted);margin-top:1rem}.mini-list{margin-top:1rem}
.logo-img{height:52px;width:auto;max-width:220px;object-fit:contain}.nav-logo{display:flex;align-items:flex-start;justify-content:center;flex-shrink:0;background:transparent!important}.footer-logo-img{max-width:210px;height:auto}.nav-links{gap:0}.nav-link{display:inline-flex!important;align-items:center;gap:5px}.nav-item{position:relative}.dropdown-menu{position:absolute;left:0;top:100%;min-width:280px;background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 50px rgba(29,56,97,.14);padding:.65rem;opacity:0;visibility:hidden;transform:translateY(10px);transition:.18s ease;z-index:2000}.nav-item:hover .dropdown-menu,.nav-item:focus-within .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-menu a{display:block!important;padding:9px 12px!important;border-radius:10px!important;color:var(--ink-soft)!important;font-size:.82rem!important;white-space:normal!important}.dropdown-menu a:hover{background:var(--blue-soft)!important;color:var(--blue-dark)!important}.dropdown-menu a::after,.nav-link i::after{display:none!important}.mobile-details{border-bottom:1px solid var(--line);padding:4px 0}.mobile-details summary{font-weight:700;color:var(--blue-dark);padding:10px 12px;cursor:pointer}.mobile-sub{display:block;margin-left:12px;font-size:.84rem!important}.mobile-main{font-weight:700}.panel-priority{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:1.75rem;box-shadow:var(--shadow-soft)}.priority-stack{display:flex;flex-direction:column;gap:.7rem;margin-top:1rem}.priority-stack a{display:flex;align-items:center;gap:.8rem;background:var(--bg);border:1px solid var(--line);padding:.9rem 1rem;border-radius:16px;transition:all var(--transition)}.priority-stack a:hover{background:var(--blue-soft);transform:translateY(-2px)}.priority-stack span{font-size:1.3rem}.hero-card h3{margin-top:.75rem}.route-card h3{margin:.7rem 0 .5rem}.route-card .badge{margin:.4rem 0}.featured-route{border-color:rgba(185,154,74,.45);box-shadow:0 14px 32px rgba(185,154,74,.12)}.featured-resource{display:grid;grid-template-columns:1.5fr .85fr;gap:1.5rem;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-soft)}.about-protagonist{background:linear-gradient(135deg,#fff, #F7F9FC)}.resource-snapshot{border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--blue-dark),#274777);color:var(--bg);min-height:210px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.5rem;gap:.7rem}.resource-snapshot div{font-size:3rem}.resource-snapshot strong{font-size:1.1rem;color:#fff}.resource-snapshot span{font-size:.82rem;color:rgba(247,249,252,.72)}.quick-wa:hover{background:var(--blue-soft)}.no-list li i{color:var(--error)!important}.form-note{font-size:.85rem;color:var(--muted)}.route-grid .card{min-height:100%}.reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.08s}.reveal-delay-2{transition-delay:.16s}
@media(max-width:1050px){.nav-links{display:none}.hamburger{display:flex}.featured-resource{grid-template-columns:1fr}.hero-inner{grid-template-columns:1fr}.hero-visual{max-width:620px}.pricing-grid,.grid-3,.grid-4{grid-template-columns:1fr 1fr}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.section,.section.compact{padding:2.5rem 0}.page-hero{padding:calc(var(--nav-h) + 4px + 1.6rem) 0 2.1rem}.grid-2,.grid-3,.grid-4,.pricing-grid{grid-template-columns:1fr}.dark-band{padding:1.6rem}.featured-resource{padding:1.35rem}.container{padding:0 1rem}.logo-img{height:44px;max-width:180px}.btn-lg{min-height:48px;padding:0 18px}.hero-chips{gap:.5rem}.chip{font-size:.78rem}.footer-grid{grid-template-columns:1fr}.footer-bottom{gap:.6rem}}

/* === Fase 2B Final refinements === */
.nav-right .lang-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:34px;margin-right:2px;white-space:nowrap}
.mobile-nav .lang-toggle{display:inline-flex;width:max-content;margin:0 0 8px 10px;background:var(--surface-2)}
.logo-img{max-height:48px;width:auto;display:block}.nav-logo{min-width:145px}.footer-logo-img{max-width:180px;height:auto;display:block}.partner-note{font-size:.78rem;color:rgba(247,249,252,.7)}
.feature-icon,.tech-icon{color:var(--blue-main)}.feature-icon i,.product-icon i,.kit-icon i,.tech-icon i{font-size:1.18rem;color:inherit}.feature-icon{font-size:1rem}.feature-icon.lg,.tech-icon.lg{width:58px;height:58px;font-size:1.35rem}.tech-icon{width:34px;height:34px;border-radius:10px;background:var(--blue-soft);border:1px solid var(--blue-border);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.tech-icon.lg{background:rgba(37,150,190,.15);border-color:rgba(37,150,190,.35)}
.equal-cards{align-items:stretch}.equal-cards>.card,.equal-cards>.pricing-card,.equal-cards>.route-service-card,.equal-cards>.quick-wa{height:100%;display:flex;flex-direction:column}.card-actions{margin-top:auto;display:flex;gap:10px;flex-wrap:wrap;align-items:center}.card-actions.two .btn{flex:1;min-width:110px}.component-row.card-actions{margin-top:auto}.route-card,.course-card,.standard-card,.asset-type-card,.dna-card,.principle-card,.diff-card,.contact-card,.kit-service-card{display:flex;flex-direction:column}.route-card p,.course-card p,.standard-card p,.asset-type-card p,.dna-card p,.principle-card p,.diff-card p{color:var(--ink-soft);line-height:1.62}.mini-list{margin:1rem 0}.route-card-top{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.route-includes{display:grid;grid-template-columns:1.2fr .8fr;gap:1rem;margin:1.25rem 0}.scope-box{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-md);padding:1rem}.scope-box h4{margin-bottom:.5rem}.scope-box p{font-size:.9rem;margin:0}.hero-priority-card{background:linear-gradient(180deg,#fff,#f5f9fc);border:1px solid var(--line);border-radius:var(--radius-lg);padding:0;box-shadow:var(--shadow);overflow:hidden}.priority-card-head{background:linear-gradient(135deg,var(--blue-dark),#274777);padding:1.8rem;display:flex;gap:1rem;align-items:center;color:#fff}.priority-card-head small{color:var(--gold);font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem}.priority-card-head h3{color:#fff;margin:0;font-size:1.25rem}.priority-stack.professional{padding:1.3rem;gap:10px;display:flex;flex-direction:column}.priority-stack.professional a{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);padding:14px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:var(--ink)}.hero-card-footer{display:flex;gap:8px;padding:0 1.3rem 1.3rem}.hero-card-footer span{font-size:.75rem;font-weight:800;background:var(--gold-soft);color:var(--gold-strong);border:1px solid rgba(185,154,74,.28);border-radius:999px;padding:5px 10px}.dark-section{background:linear-gradient(135deg,var(--blue-dark),#173052);color:#fff}.section-header.light h2,.section-header.light p{color:#fff}.dark-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:1.5rem;color:#fff;display:flex;flex-direction:column}.dark-card h4{color:#fff}.dark-card p{color:rgba(247,249,252,.75)}.step-num{font-family:var(--font);font-size:.75rem;font-weight:900;color:var(--gold);letter-spacing:.1em;margin-bottom:.7rem}.dark-closing{text-align:center;color:rgba(247,249,252,.86);font-weight:700;margin-top:2rem}.pricing-grid.four-cols{grid-template-columns:repeat(4,1fr)}.price-balanced{font-size:1.18rem!important;line-height:1.25;font-weight:800!important;color:var(--blue-dark)}.pricing-body p{font-size:.9rem;color:var(--ink-soft);line-height:1.62;margin-bottom:1rem}.final-cta-card{background:linear-gradient(135deg,var(--blue-dark),#274777 55%,var(--blue-main));color:#fff;border-radius:var(--radius-xl);padding:2.3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;box-shadow:0 20px 55px rgba(29,56,97,.22);overflow:hidden;position:relative}.final-cta-card h2{color:#fff}.final-cta-card p{color:rgba(247,249,252,.82);max-width:720px}.resource-showcase{display:grid;grid-template-columns:1.3fr .7fr;gap:2rem;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-soft)}.resource-panel{background:linear-gradient(135deg,var(--blue-dark),#274777);color:#fff;border-radius:var(--radius-lg);padding:1.6rem}.resource-panel h3{color:#fff}.resource-panel p{color:rgba(247,249,252,.75)}.payment-box{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-soft)}.payment-box p{color:var(--ink-soft)}.payment-box .note{font-size:.88rem}.payment-chips{display:flex;flex-wrap:wrap;gap:10px;align-content:center}.payment-chips span{background:var(--blue-soft);color:var(--blue-dark);border:1px solid var(--blue-border);padding:9px 12px;border-radius:999px;font-size:.86rem;font-weight:800}.theory-practice-band{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:center;background:linear-gradient(135deg,#fff,#f5f9fc);border:1px solid var(--line);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-soft)}.system-diagram{display:grid;grid-template-columns:1fr 1fr;gap:12px}.system-diagram span{background:var(--blue-dark);color:#fff;border-radius:var(--radius-md);padding:1rem;font-weight:800;text-align:center}.mission-card p{font-size:1rem;line-height:1.75}.diff-card{border-left:4px solid var(--blue-main)}.table-wrap{overflow-x:auto}.compare-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft)}.compare-table th{background:var(--blue-dark);color:#fff;padding:12px 14px;text-align:left;font-size:.82rem}.compare-table td{padding:12px 14px;border-bottom:1px solid var(--line);font-size:.86rem;color:var(--ink-soft)}.compare-table td:first-child{font-weight:800;color:var(--blue-dark)}.legal-card p{margin-bottom:1rem;color:var(--ink-soft)}
@media (max-width:1120px){.pricing-grid.four-cols{grid-template-columns:repeat(2,1fr)}.nav-links a{padding:8px 8px;font-size:.78rem}.nav-logo{min-width:128px}.logo-img{max-height:42px}}
@media (max-width:760px){.pricing-grid.four-cols,.route-includes,.resource-showcase,.payment-box,.theory-practice-band{grid-template-columns:1fr}.final-cta-card{flex-direction:column;align-items:flex-start}.system-diagram{grid-template-columns:1fr}.nav-right .lang-toggle{display:none}.mobile-nav .lang-toggle{display:inline-flex}.hero-priority-card{margin-top:1rem}}

/* ===== Producción V2 JUN17 · Microajustes finales ===== */
.lang-toggle{display:none!important;visibility:hidden!important}
#navbar{background:#FFFFFF!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-bottom:1px solid var(--line)!important}
.nav-logo{background:#FFFFFF!important;border-radius:0!important;box-shadow:none!important;padding:0!important;min-width:150px!important}
.logo-img{height:42px!important;max-width:260px!important;width:auto!important;object-fit:contain!important;display:block!important}
.footer-logo-img{background:rgba(255,255,255,.96);border-radius:14px;padding:8px 10px;max-width:210px;height:auto}
.priority-stack.professional a{align-items:flex-start!important;background:linear-gradient(135deg,#FFFFFF,#F7F9FC)!important;border-color:rgba(37,150,190,.18)!important}
.priority-stack.professional a small{display:block;color:var(--muted);font-size:.76rem;font-weight:600;line-height:1.35;margin-top:2px}
.priority-stack.professional .tech-icon{background:rgba(37,150,190,.10);border:1px solid rgba(37,150,190,.22);box-shadow:none}
.pricing-card,.standard-card,.route-card,.route-service-card,.kit-service-card,.course-card,.asset-type-card{display:flex!important;flex-direction:column!important;height:100%!important}
.pricing-body,.kit-body{display:flex!important;flex-direction:column!important;flex:1!important}
.pricing-body .feature-list,.kit-body .feature-list,.mini-list{margin-bottom:1rem}
.card-actions,.component-row.card-actions{margin-top:auto!important;align-items:center!important}
.card-actions.two .btn{flex:1 1 0;min-width:112px}
.price-balanced{font-size:1.08rem!important;line-height:1.28!important;font-weight:800!important;letter-spacing:-.025em!important}
.quote-price{font-size:1rem!important;font-weight:800!important;color:var(--blue-dark)!important}
.scope-note-global{max-width:760px;margin:-1.6rem auto 2.2rem;text-align:center;color:var(--ink-soft);font-size:.95rem;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.85rem 1.2rem;box-shadow:var(--shadow-sm)}
.scope-box p{font-size:.88rem!important;line-height:1.58!important}
.resource-showcase p{font-size:.98rem;line-height:1.68;margin-bottom:1.35rem}.resource-showcase .btn{margin-top:.2rem}.resource-panel{box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.payment-box{align-items:center}.payment-box p{font-size:.94rem!important;line-height:1.65!important}.payment-box .note{font-size:.94rem!important;color:var(--ink-soft)!important;margin-top:.75rem}.payment-chips span{font-size:.88rem!important;line-height:1.2!important}
@media(max-width:760px){.logo-img{height:38px!important;max-width:220px!important}.nav-logo{min-width:130px!important}.scope-note-global{border-radius:18px;margin:-.8rem auto 1.6rem}.nav-right .lang-toggle,.mobile-nav .lang-toggle{display:none!important}}


/* ===== GIASEG ajustes finales post revisión visual ===== */
.logo-img{height:30px!important;max-width:205px!important;width:auto!important;object-fit:contain!important}
.nav-logo{min-width:190px!important;background:#fff!important;align-items:flex-start!important;justify-content:center!important}
@media(max-width:760px){.logo-img{height:28px!important;max-width:185px!important}.nav-logo{min-width:150px!important}}

footer{padding:4rem 0 1.8rem!important;background:var(--blue-dark)!important}
.footer-grid.footer-grid-clean{grid-template-columns:1.25fr .9fr .9fr .85fr 1.05fr!important;gap:2rem!important;align-items:start!important;margin-bottom:3rem!important}
.footer-wordmark-text{font-size:2rem;font-weight:900;letter-spacing:.08em;line-height:1;color:#fff;margin-bottom:1rem}
.footer-brand p{max-width:320px!important;color:rgba(247,249,252,.62)!important;margin:.2rem 0 1.2rem!important}
.footer-logo-img{display:none!important;background:none!important;padding:0!important;border-radius:0!important}
.footer-socials{display:none!important}
.footer-contact-mini{display:flex;flex-direction:column;gap:.55rem;margin-top:1rem}
.footer-contact-mini a{display:inline-flex;align-items:center;gap:.55rem;color:rgba(247,249,252,.68);font-size:.86rem;font-weight:600}
.footer-contact-mini a:hover{color:#fff}
.footer-col ul{gap:.55rem!important}.footer-col ul a,.footer-col li span{font-size:.86rem!important;color:rgba(247,249,252,.58)!important}.footer-col ul a:hover{color:#fff!important}.partner-note{font-weight:700;color:rgba(247,249,252,.72)!important}.footer-bottom{margin-top:0!important}
@media(max-width:1024px){.footer-grid.footer-grid-clean{grid-template-columns:1fr 1fr!important}}
@media(max-width:760px){.footer-grid.footer-grid-clean{grid-template-columns:1fr!important;gap:1.8rem!important}.footer-wordmark-text{font-size:1.7rem}.footer-brand p{max-width:none!important}}

.kit-service-card .route-card-top{margin-bottom:.65rem!important}.kit-service-card p{margin-bottom:.75rem!important}.kit-service-card .list{gap:7px!important;margin-top:.25rem}.kit-service-card .card-actions{margin-top:auto!important;padding-top:1rem}.kit-service-card{padding:1.45rem!important}.kit-service-card .feature-icon{margin-bottom:.4rem!important}
.academia-page .section.compact{padding:2.35rem 0!important}.academia-page .section-header{margin-bottom:1.5rem!important}.course-card .feature-icon{margin-bottom:.75rem!important}.course-card .card-actions{margin-top:auto!important;padding-top:1rem}
.contact-main-wrap{max-width:760px;margin:0 auto}.contact-card-main{text-align:left;padding:2.2rem!important}.contact-card-main .component-row{justify-content:flex-start}.contact-card-main p{max-width:620px}
.pricing-card .card-actions{margin-top:auto!important;padding-top:1rem}.pricing-body{display:flex!important;flex-direction:column!important}.pricing-body .feature-list{margin-bottom:1rem!important}.payment-box p,.payment-box .note{font-size:.94rem!important;line-height:1.62!important}.payment-chips span{font-size:.88rem!important;line-height:1.2!important}
.rutas-cumplimiento .card-actions .btn-blue,.route-service-card .card-actions .btn-blue{min-width:170px}


/* === GIASEG global wordmark correction === */
.nav-logo{min-width:176px!important;display:flex!important;align-items:center!important;justify-content:flex-start!important;background:#fff!important;padding:0!important;border-radius:0!important;box-shadow:none!important;}
.logo-img{width:172px!important;height:auto!important;max-height:32px!important;max-width:172px!important;object-fit:contain!important;display:block!important;}
.footer-wordmark-text{display:none!important;}
.footer-wordmark-img{display:block!important;width:168px!important;max-width:100%!important;height:auto!important;background:transparent!important;border-radius:0!important;padding:0!important;margin:0 0 1rem!important;filter:none!important;}
.footer-brand p{margin-top:.35rem!important;}
@media(max-width:1120px){.nav-logo{min-width:152px!important}.logo-img{width:150px!important;max-width:150px!important;max-height:30px!important}}
@media(max-width:760px){.nav-logo{min-width:138px!important}.logo-img{width:138px!important;max-width:138px!important;max-height:28px!important}.footer-wordmark-img{width:150px!important}}

/* ============================================================
   GIASEG HEADER FINAL — MISMA RETÍCULA DE LA LANDING ANTIGUA
   - No usa espaciador invisible.
   - No usa logo con lienzo/canvas.
   - Header, logo, menú y CTA quedan dentro del mismo contenedor que el sitio.
   - Inspirado en la estructura antigua: <div class="container nav">.
   ============================================================ */

#navbar{
  width:100% !important;
  padding-left:0 !important;
  padding-right:0 !important;
  background:#FFFFFF !important;
  border-bottom:1px solid var(--line) !important;
}

#navbar .nav-inner{
  width:min(92%, var(--max-w)) !important;
  max-width:var(--max-w) !important;
  height:var(--nav-h) !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:0 !important;
  padding-right:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:22px !important;
  box-sizing:border-box !important;
}

.nav-logo{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  flex-direction:row !important;
  flex:0 0 auto !important;
  width:auto !important;
  min-width:auto !important;
  max-width:none !important;
  margin:0 !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
}

.nav-logo::before{
  content:none !important;
  display:none !important;
  width:0 !important;
  min-width:0 !important;
  flex-basis:0 !important;
}

.logo-img{
  display:block !important;
  width:clamp(190px, 18vw, 240px) !important;
  max-width:240px !important;
  height:auto !important;
  max-height:44px !important;
  object-fit:contain !important;
  object-position:left center !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}

.nav-links{
  flex:1 1 auto !important;
  min-width:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.nav-right{
  flex:0 0 auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  margin-left:0 !important;
}

@media(max-width:1280px){
  #navbar .nav-inner{
    width:min(94%, var(--max-w)) !important;
    gap:14px !important;
  }
  .logo-img{
    width:clamp(172px, 17vw, 214px) !important;
    max-width:214px !important;
    max-height:40px !important;
  }
  .nav-links a{
    font-size:.76rem !important;
    padding-left:6px !important;
    padding-right:6px !important;
  }
}

@media(max-width:1050px){
  #navbar .nav-inner{
    width:calc(100% - 2rem) !important;
  }
  .nav-links{
    display:none !important;
  }
  .hamburger{
    display:flex !important;
  }
  .logo-img{
    width:190px !important;
    max-width:190px !important;
  }
}

@media(max-width:760px){
  #navbar .nav-inner{
    width:calc(100% - 1.5rem) !important;
    gap:.75rem !important;
  }
  .logo-img{
    width:150px !important;
    max-width:150px !important;
    max-height:30px !important;
  }
}

/* ============================================================
   GIASEG HEADER — AJUSTE FINO DE POSICIÓN DEL WORDMARK
   Base: retícula del header antiguo conservada.
   Ajuste: desplazar SOLO el bloque de marca hacia la derecha para
   igualar el arranque visual del hero, sin tocar menú, hero ni secciones.
   ============================================================ */
#navbar .nav-logo{
  margin-left: clamp(32px, 2.4vw, 42px) !important;
}

@media(max-width:1120px){
  #navbar .nav-logo{
    margin-left: 18px !important;
  }
}

@media(max-width:760px){
  #navbar .nav-logo{
    margin-left: 0 !important;
  }
}
/* Ajuste específico: Política de Tratamiento de Datos Personales */
.legal-card h2{
  font-size: clamp(1.15rem, 1.8vw, 1.55rem);
  line-height: 1.2;
  letter-spacing: -0.015em;
  margin: 1.85rem 0 .75rem;
  color: var(--blue-dark);
}
.legal-card h2:first-child{margin-top:0}
.legal-card ul{
  margin: .5rem 0 1.2rem 1.25rem;
  color: var(--ink-soft);
}
.legal-card li{
  margin-bottom: .55rem;
  color: var(--ink-soft);
}
.legal-card strong{color:var(--blue-dark)}
.legal-meta{
  display:grid;
  grid-template-columns: repeat(2,minmax(0,1fr));
  gap:.85rem;
  margin:1.2rem 0 1.6rem;
}
.legal-meta div{
  padding:1rem;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  box-shadow:var(--shadow-soft);
  color:var(--ink-soft);
}
.legal-note{
  margin-top:2rem;
  padding:1.1rem 1.2rem;
  border-radius:18px;
  border:1px solid rgba(37,150,190,.2);
  background:rgba(37,150,190,.06);
  color:var(--ink-soft);
}
@media(max-width:760px){
  .legal-meta{grid-template-columns:1fr}
}

/* ============================================================
   GIASEG HOME HERO — AJUSTE VISUAL DE DESCRIPCIONES DERECHAS
   Mantener textos descriptivos y encajarlos en una tercera columna
   estable dentro de cada fila del bloque "Rutas prioritarias".
   No toca header ni estructura general.
   ============================================================ */
.priority-stack.professional a{
  display:grid !important;
  grid-template-columns: 42px minmax(0, 1fr) minmax(180px, 220px) !important;
  align-items:center !important;
  column-gap:14px !important;
  row-gap:4px !important;
  padding:15px 18px !important;
}
.priority-stack.professional a > .tech-icon{
  grid-column:1 !important;
  grid-row:1 / span 2 !important;
  align-self:center !important;
  justify-self:start !important;
}
.priority-stack.professional a > strong{
  grid-column:2 !important;
  grid-row:1 / span 2 !important;
  min-width:0 !important;
  line-height:1.28 !important;
  align-self:center !important;
}
.priority-stack.professional a > small{
  grid-column:3 !important;
  grid-row:1 / span 2 !important;
  display:block !important;
  width:100% !important;
  min-width:0 !important;
  max-width:100% !important;
  margin:0 !important;
  padding-left:16px !important;
  border-left:1px solid rgba(37,150,190,.18) !important;
  color:var(--muted) !important;
  font-size:.76rem !important;
  font-weight:600 !important;
  line-height:1.34 !important;
  text-align:left !important;
  align-self:center !important;
  overflow-wrap:anywhere !important;
}
@media(max-width:1180px){
  .priority-stack.professional a{
    grid-template-columns: 42px minmax(0, 1fr) 180px !important;
    column-gap:12px !important;
  }
  .priority-stack.professional a > small{
    padding-left:12px !important;
    font-size:.74rem !important;
  }
}
@media(max-width:760px){
  .priority-stack.professional a{
    grid-template-columns: 42px minmax(0,1fr) !important;
    align-items:flex-start !important;
  }
  .priority-stack.professional a > .tech-icon{
    grid-row:1 / span 2 !important;
  }
  .priority-stack.professional a > strong{
    grid-column:2 !important;
    grid-row:1 !important;
  }
  .priority-stack.professional a > small{
    grid-column:2 !important;
    grid-row:2 !important;
    border-left:0 !important;
    padding-left:0 !important;
    margin-top:2px !important;
  }
}

/* ============================================================
   GIASEG HOME HERO — DESCRIPCIONES EN VERTICAL
   Ajuste aprobado: quitar columnas internas y dejar el título
   arriba con la descripción debajo, conservando los textos.
   No toca header, footer, política ni estructura general.
   ============================================================ */
.priority-stack.professional a{
  display:grid !important;
  grid-template-columns: 42px minmax(0, 1fr) !important;
  grid-template-rows:auto auto !important;
  align-items:center !important;
  column-gap:14px !important;
  row-gap:4px !important;
  padding:15px 18px !important;
}
.priority-stack.professional a > .tech-icon{
  grid-column:1 !important;
  grid-row:1 / span 2 !important;
  align-self:center !important;
  justify-self:start !important;
}
.priority-stack.professional a > strong{
  grid-column:2 !important;
  grid-row:1 !important;
  min-width:0 !important;
  line-height:1.25 !important;
  align-self:end !important;
}
.priority-stack.professional a > small{
  grid-column:2 !important;
  grid-row:2 !important;
  display:block !important;
  width:100% !important;
  min-width:0 !important;
  max-width:100% !important;
  margin:0 !important;
  padding-left:0 !important;
  border-left:0 !important;
  color:var(--muted) !important;
  font-size:.78rem !important;
  font-weight:600 !important;
  line-height:1.35 !important;
  text-align:left !important;
  align-self:start !important;
  overflow-wrap:normal !important;
}
@media(max-width:1180px){
  .priority-stack.professional a{
    grid-template-columns: 42px minmax(0, 1fr) !important;
    column-gap:12px !important;
  }
  .priority-stack.professional a > small{
    font-size:.76rem !important;
  }
}
@media(max-width:760px){
  .priority-stack.professional a{
    grid-template-columns: 42px minmax(0,1fr) !important;
    align-items:center !important;
  }
  .priority-stack.professional a > .tech-icon{
    grid-row:1 / span 2 !important;
  }
}
