/*
 * Felipe Albarrán — Landing Page Styles
 * Administradores de Fincas · Badajoz
 * Fonts: Outfit + Lora (enqueued via functions.php)
 */

/* ============================================================
   TOKENS
   ============================================================ */
:root{
  --brand:#C4562B;
  --brand-dark:#9A3F1C;
  --brand-light:#D97045;
  --brand-pale:#FDF0EB;
  --dark:#1B1916;
  --text:#3A3632;
  --muted:#7A746D;
  --cream:#FDFBF7;
  --off:#F6F2ED;
  --line:rgba(154,63,28,.10);
  --white:#FFFFFF;
  --shadow-soft:0 2px 8px rgba(30,22,16,.04);
  --shadow-md:0 16px 40px rgba(30,22,16,.07);
  --shadow-lg:0 32px 64px rgba(30,22,16,.10);
  --shadow-brand:0 16px 40px rgba(196,86,43,.18);
  --r-sm:12px;
  --r-md:20px;
  --r-lg:28px;
  --r-xl:40px;
  --ease:cubic-bezier(.32,.72,0,1);
  --ease-spring:cubic-bezier(.175,.885,.32,1.275);
  --dur:.55s;
  --brand-glow:rgba(196,86,43,.14);
  --font-body:'Outfit',system-ui,-apple-system,sans-serif;
  --font-serif:'Lora',Georgia,'Times New Roman',serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--text);
  background:var(--cream);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{text-decoration:none;color:inherit;transition:color var(--dur) var(--ease)}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--brand-pale);color:var(--brand-dark)}

/* Film-grain overlay */
body::after{
  content:'';
  position:fixed;
  inset:0;
  z-index:9999;
  pointer-events:none;
  opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{max-width:1320px;margin:0 auto;padding:0 clamp(20px,4vw,48px)}
section{position:relative}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brand);margin-bottom:20px;
}
.eyebrow::before{
  content:'';width:24px;height:1.5px;
  background:var(--brand);border-radius:999px;flex-shrink:0;
}
.display{
  font-family:var(--font-serif);
  font-size:clamp(2.6rem,5.2vw,4.8rem);
  font-weight:600;color:var(--dark);
  line-height:1.06;letter-spacing:-.035em;
  margin-bottom:24px;
}
.display em{font-style:italic;color:var(--brand)}
.headline{
  font-family:var(--font-serif);
  font-size:clamp(1.8rem,3.2vw,2.8rem);
  font-weight:600;color:var(--dark);
  line-height:1.12;letter-spacing:-.03em;
  margin-bottom:18px;
}
.headline em{font-style:italic;color:var(--brand)}
.body-lg{font-size:1.06rem;color:var(--muted);line-height:1.82;max-width:52ch}
.body-md{font-size:.92rem;color:var(--muted);line-height:1.78;max-width:52ch}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 20px 14px 26px;
  border-radius:999px;
  font-size:.88rem;font-weight:600;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease);
}
.btn .btn-arrow{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--dur) var(--ease);
  flex-shrink:0;
}
.btn .btn-arrow svg{width:16px;height:16px}
.btn:active{transform:scale(.97)}

.btn-brand{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);
  color:var(--white);
  box-shadow:var(--shadow-brand);
}
.btn-brand .btn-arrow{background:rgba(255,255,255,.18)}
.btn-brand:hover{transform:translateY(-2px);box-shadow:0 20px 48px rgba(196,86,43,.24)}
.btn-brand:hover .btn-arrow{transform:translate(2px,-1px) scale(1.06)}

.btn-ghost{
  padding:14px 26px;
  background:rgba(255,255,255,.6);
  color:var(--dark);
  border:1px solid var(--line);
  backdrop-filter:blur(12px);
}
.btn-ghost:hover{background:var(--white);border-color:rgba(154,63,28,.22);transform:translateY(-2px);box-shadow:var(--shadow-soft)}

.btn-dark{
  background:var(--dark);color:var(--white);
  box-shadow:0 16px 36px rgba(27,25,22,.16);
}
.btn-dark .btn-arrow{background:rgba(255,255,255,.12)}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 20px 44px rgba(27,25,22,.22)}
.btn-dark:hover .btn-arrow{transform:translate(2px,-1px) scale(1.06)}

/* ============================================================
   DOUBLE-BEZEL CARD SYSTEM
   ============================================================ */
.bezel{
  background:rgba(255,255,255,.35);
  border:1px solid rgba(154,63,28,.06);
  padding:6px;
  border-radius:var(--r-xl);
}
.bezel-inner{
  background:var(--white);
  border-radius:calc(var(--r-xl) - 6px);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.6),var(--shadow-soft);
  overflow:hidden;
}

/* ============================================================
   NAVBAR — Floating Island
   ============================================================ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:18px 0;
  transition:padding var(--dur) var(--ease),background var(--dur) var(--ease);
}
.navbar.scrolled{padding:10px 0;background:rgba(253,251,247,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-logo img{height:48px;width:auto;transition:height var(--dur) var(--ease)}
.navbar.scrolled .nav-logo img{height:40px}

.nav-links{
  display:flex;align-items:center;gap:4px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(154,63,28,.08);
  border-radius:999px;padding:5px 6px;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:var(--shadow-soft);
}
.nav-links a{
  font-size:.82rem;font-weight:500;
  padding:9px 18px;border-radius:999px;
  color:var(--text);
  transition:color var(--dur) var(--ease),background var(--dur) var(--ease);
}
.nav-links a:hover{color:var(--brand);background:rgba(196,86,43,.06)}
.nav-cta{
  background:linear-gradient(135deg,var(--brand),var(--brand-dark))!important;
  color:var(--white)!important;
  font-weight:600!important;
  box-shadow:0 8px 20px rgba(196,86,43,.16);
}
.nav-cta:hover{color:var(--white)!important;box-shadow:0 12px 28px rgba(196,86,43,.22)}

.nav-hamburger{
  display:none;width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.8);border:1px solid var(--line);
  align-items:center;justify-content:center;flex-direction:column;gap:5px;
  backdrop-filter:blur(12px);
}
.nav-hamburger span{display:block;width:18px;height:1.5px;background:var(--dark);border-radius:2px;transition:transform var(--dur) var(--ease),opacity var(--dur) var(--ease)}
.nav-hamburger.open span:nth-child(1){transform:translateY(3.25px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-3.25px) rotate(-45deg)}

/* Mobile menu overlay */
.mob-overlay{
  position:fixed;inset:0;z-index:999;
  background:rgba(253,251,247,.96);
  backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease);
}
.mob-overlay.open{opacity:1;pointer-events:auto}
.mob-overlay a{
  font-family:var(--font-serif);font-size:1.6rem;font-weight:500;color:var(--dark);
  padding:14px 28px;border-radius:var(--r-md);
  opacity:0;transform:translateY(20px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s var(--ease);
}
.mob-overlay.open a{opacity:1;transform:none}
.mob-overlay.open a:nth-child(1){transition-delay:.06s}
.mob-overlay.open a:nth-child(2){transition-delay:.12s}
.mob-overlay.open a:nth-child(3){transition-delay:.18s}
.mob-overlay.open a:nth-child(4){transition-delay:.24s}
.mob-overlay.open a:nth-child(5){transition-delay:.30s}
.mob-overlay a:hover{color:var(--brand)}

/* ============================================================
   HERO — Editorial Split
   ============================================================ */
.hero,#inicio{
  min-height:100vh;min-height:100dvh;
  display:flex;align-items:center;
  padding:0 0 40px;
  background:linear-gradient(168deg,var(--cream) 0%,#f5ede5 52%,var(--cream) 100%);
  overflow:hidden;
}
.hero::before,#inicio::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(154,63,28,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(154,63,28,.035) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 70% 60% at 35% 40%,#000 10%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 35% 40%,#000 10%,transparent 80%);
  pointer-events:none;
}
.hero::after,#inicio::after{
  content:'';position:absolute;
  right:-10%;top:10%;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(196,86,43,.12) 0%,transparent 65%);
  pointer-events:none;
}

.hero-grid,#heroGrid{
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  align-items:center;gap:clamp(32px,5vw,72px);
  padding:clamp(130px,16vh,180px) 0 clamp(60px,8vh,100px);
}
.hero-text,#heroText{max-width:560px}
.hero-kicker{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.7);border:1px solid var(--line);
  color:var(--brand-dark);font-size:.7rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:8px 16px;border-radius:999px;margin-bottom:28px;
  backdrop-filter:blur(12px);box-shadow:var(--shadow-soft);
}
.hero-kicker svg{width:14px;height:14px;flex-shrink:0}
.hero-h1{
  font-family:var(--font-serif);
  font-size:clamp(2.6rem,5.4vw,5rem);
  font-weight:600;color:var(--dark);
  line-height:1.04;letter-spacing:-.045em;
  margin-bottom:24px;
}
.hero-h1 em{font-style:italic;color:var(--brand)}
.hero-sub{font-size:1.06rem;color:var(--muted);line-height:1.85;margin-bottom:36px;max-width:48ch}
.hero-actions,#heroActions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}

/* Hero stats */
.hero-stats,#heroStats{
  display:flex;gap:0;
  border-top:1px solid var(--line);
  padding-top:32px;
}
.hero-stat,[id^="heroStat-"]{flex:1;padding:0 24px;position:relative}
.hero-stat:not(:last-child)::after,[id^="heroStat-"]:not(:last-child)::after{
  content:'';position:absolute;right:0;top:2px;bottom:2px;width:1px;
  background:var(--line);
}
.hero-stat:first-child,[id^="heroStat-"]:first-child{padding-left:0}
.hero-stat:last-child,[id^="heroStat-"]:last-child{padding-right:0}
.hero-stat-val{
  font-family:var(--font-serif);font-size:2.2rem;font-weight:600;
  color:var(--brand);line-height:1;
}
.hero-stat-lbl{
  font-size:.7rem;color:var(--muted);text-transform:uppercase;
  letter-spacing:.08em;margin-top:6px;
}

/* Hero visual — app screenshots */
.hero-visual,#heroVisual{position:relative}
.hero-screenshots,#heroScreenshots{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;position:relative;z-index:1;
}
.hero-screenshots img,#heroScreenshots img{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  border-radius:var(--r-lg);
  border:1px solid rgba(154,63,28,.08);
  box-shadow:var(--shadow-md);
  opacity:0;transform:translateY(16px) scale(.97);
  animation:imgReveal .6s var(--ease) forwards;
}
.hero-screenshots img:nth-child(1),#heroScreenshots img:nth-child(1){animation-delay:.1s}
.hero-screenshots img:nth-child(2),#heroScreenshots img:nth-child(2){animation-delay:.18s}
.hero-screenshots img:nth-child(3),#heroScreenshots img:nth-child(3){animation-delay:.26s}
.hero-screenshots img:nth-child(4),#heroScreenshots img:nth-child(4){animation-delay:.34s}
.hero-screenshots img:nth-child(5),#heroScreenshots img:nth-child(5){animation-delay:.42s}
.hero-screenshots img:nth-child(6),#heroScreenshots img:nth-child(6){animation-delay:.5s}
.hero-screenshots img:nth-child(7),#heroScreenshots img:nth-child(7){animation-delay:.58s}
.hero-screenshots img:nth-child(8),#heroScreenshots img:nth-child(8){animation-delay:.66s}
.hero-screenshots img:hover,#heroScreenshots img:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
@keyframes imgReveal{to{opacity:1;transform:translateY(0) scale(1)}}

/* Portal callout */
.hero-portal,#heroPortal{
  margin-top:20px;padding:20px 0 0;
  border-top:1px solid var(--line);
}
.hero-portal-label{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand);margin-bottom:10px;
}
.hero-portal-label svg{width:13px;height:13px}
.hero-portal strong{display:block;font-size:.95rem;font-weight:600;color:var(--dark);line-height:1.5;margin-bottom:6px}
.hero-portal p{font-size:.82rem;color:var(--muted);line-height:1.72}
.hero-portal-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.hero-portal-tags span{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;
  background:rgba(196,86,43,.06);font-size:.72rem;color:var(--dark);
}
.hero-portal-tags span svg{width:12px;height:12px;color:var(--brand)}

/* ============================================================
   ABOUT — Asymmetric overlap
   ============================================================ */
.about,#sobre-nosotros{padding:clamp(100px,14vw,160px) 0}
.about-grid,#aboutGrid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:clamp(40px,6vw,80px);
  align-items:center;
}
.about-img-wrap,#aboutImageWrap{position:relative}
.about-img{
  width:100%;min-height:520px;object-fit:cover;
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);
}
.about-float{
  position:absolute;bottom:24px;left:24px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:var(--white);border-radius:var(--r-lg);
  padding:22px 26px;box-shadow:var(--shadow-brand);
}
.about-float-val{font-family:var(--font-serif);font-size:2.4rem;font-weight:700;line-height:1}
.about-float-lbl{font-size:.7rem;color:rgba(255,255,255,.78);margin-top:4px}
.about-badge{
  position:absolute;top:24px;right:24px;
  width:88px;height:88px;border-radius:50%;
  background:rgba(255,255,255,.92);border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--brand-dark);text-align:center;line-height:1.3;
  box-shadow:var(--shadow-md);
}
.about-badge svg{width:18px;height:18px;color:var(--brand);margin-bottom:4px}

.about-text .body-lg,#aboutText .body-lg{margin-bottom:14px}
.about-values,#aboutValues{
  display:grid;grid-template-columns:1fr 1fr;
  gap:14px;margin-top:36px;
}
.av,[id^="aboutValue-"]{
  padding:22px;border-radius:var(--r-lg);
  background:rgba(255,255,255,.52);border:1px solid rgba(154,63,28,.07);
  backdrop-filter:blur(12px);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.av:hover,[id^="aboutValue-"]:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(196,86,43,.18)}
.av svg,[id^="aboutValue-"] svg{color:var(--brand);width:22px;height:22px;margin-bottom:12px}
.av h4,[id^="aboutValue-"] h4{font-size:.88rem;font-weight:700;color:var(--dark);margin-bottom:4px}
.av p,[id^="aboutValue-"] p{font-size:.78rem;color:var(--muted);line-height:1.7}

/* ============================================================
   TEAM — Staggered editorial cards
   ============================================================ */
.team,#equipo{padding:clamp(100px,14vw,160px) 0;background:linear-gradient(180deg,var(--cream) 0%,var(--off) 100%)}
.team-head,#teamHead{text-align:center;margin-bottom:clamp(48px,6vw,72px)}
.team-head .body-lg,#teamHead .body-lg{margin:0 auto}
.team-grid,#teamGrid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:28px;max-width:1000px;margin:0 auto;
}
.team-card,[id^="teamCard-"]{
  border-radius:var(--r-xl);overflow:hidden;
  background:var(--white);border:1px solid rgba(154,63,28,.07);
  box-shadow:var(--shadow-md);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.team-card:nth-child(2),[id^="teamCard-"]:nth-child(2){margin-top:52px}
.team-card:hover,[id^="teamCard-"]:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.team-photo,[id^="teamPhoto-"]{height:380px;position:relative;overflow:hidden;background:linear-gradient(135deg,#efe6e0,#f8f4f1)}
.team-photo::after,[id^="teamPhoto-"]::after{
  content:'';position:absolute;inset:auto 0 0 0;height:100px;
  background:linear-gradient(180deg,transparent,rgba(26,26,26,.06));
}
.team-photo img,[id^="teamPhoto-"] img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s var(--ease)}
.team-card:hover .team-photo img,[id^="teamCard-"]:hover [id^="teamPhoto-"] img{transform:scale(1.04)}
.team-body,[id^="teamBody-"]{padding:28px 28px 30px}
.team-body h3{font-family:var(--font-serif);font-size:1.15rem;font-weight:600;color:var(--dark);margin-bottom:4px;letter-spacing:-.02em}
.team-role{font-size:.76rem;color:var(--brand);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.team-coleg{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(196,86,43,.06);color:var(--muted);
  font-size:.7rem;font-weight:600;padding:6px 12px;
  border-radius:999px;margin-bottom:14px;
}
.team-coleg svg{width:12px;height:12px}
.team-body>p{font-size:.84rem;color:var(--muted);line-height:1.78}

.team-colegio,#teamColegio{
  display:flex;align-items:center;gap:26px;
  max-width:1000px;margin:48px auto 0;
  padding:32px 0 0;border-top:1px solid var(--line);
}
.team-colegio img,#teamColegio img{height:72px;width:auto;flex-shrink:0}
.team-colegio p,#teamColegio p{font-size:.88rem;color:var(--muted);line-height:1.78;max-width:480px}

/* ============================================================
   SERVICES — Bento asymmetric grid
   ============================================================ */
.services,#servicios{padding:clamp(100px,14vw,160px) 0;background:linear-gradient(180deg,var(--off) 0%,var(--cream) 100%)}
.srv-header,#servicesHeader{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,6vw,72px);align-items:end;
  margin-bottom:clamp(48px,6vw,64px);
}
.srv-grid,#servicesGrid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:18px;
  counter-reset:srv;
}
.srv-card,[id^="srvCard-"]{
  grid-column:span 2;
  padding:6px;border-radius:var(--r-xl);
  background:rgba(255,255,255,.35);border:1px solid rgba(154,63,28,.06);
  counter-increment:srv;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.srv-card:nth-child(1),.srv-card:nth-child(2),[id^="srvCard-"]:nth-child(1),[id^="srvCard-"]:nth-child(2){grid-column:span 3}
.srv-card:hover,[id^="srvCard-"]:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(196,86,43,.14)}

.srv-card-inner,[id^="srvInner-"]{
  background:var(--white);border-radius:calc(var(--r-xl) - 6px);
  padding:32px 28px;position:relative;overflow:hidden;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.5);
  height:100%;
}
.srv-card-inner::before,[id^="srvInner-"]::before{
  content:'0' counter(srv);position:absolute;top:16px;right:20px;
  font-family:var(--font-serif);font-size:2.6rem;line-height:1;
  color:rgba(196,86,43,.08);pointer-events:none;
}
.srv-icon,[id^="srvIcon-"]{
  width:52px;height:52px;border-radius:18px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:var(--white);display:flex;align-items:center;justify-content:center;
  margin-bottom:22px;box-shadow:0 10px 22px rgba(196,86,43,.18);
}
.srv-icon svg,[id^="srvIcon-"] svg{width:22px;height:22px}
.srv-card h3,[id^="srvCard-"] h3{font-size:.98rem;font-weight:700;color:var(--dark);margin-bottom:10px;max-width:20ch}
.srv-card>div>p,[id^="srvCard-"]>div>p{font-size:.82rem;color:var(--muted);line-height:1.78;margin-bottom:16px;max-width:40ch}
.srv-list{display:flex;flex-direction:column;gap:7px}
.srv-list li{display:flex;align-items:flex-start;gap:8px;font-size:.78rem;color:var(--muted)}
.srv-list li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--brand);flex-shrink:0;margin-top:8px}

/* Roles band */
.roles-band,#rolesHead{
  margin-top:72px;padding:56px 0 0;
  border-top:1px solid var(--line);
}
.roles-head,#rolesHead{text-align:center;margin-bottom:44px}
.roles-head .body-lg,#rolesHead .body-lg{margin:0 auto}
.roles-grid,#rolesGrid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.role-card,[id^="roleCard-"]{
  background:rgba(255,255,255,.5);border:1px solid rgba(154,63,28,.07);
  border-radius:var(--r-lg);padding:26px 22px;
  backdrop-filter:blur(12px);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.role-card:hover,[id^="roleCard-"]:hover{box-shadow:var(--shadow-md);border-color:rgba(196,86,43,.18);transform:translateY(-4px)}
.role-card svg,[id^="roleCard-"] svg{color:var(--brand);width:26px;height:26px;margin-bottom:14px}
.role-card h4,[id^="roleCard-"] h4{font-family:var(--font-serif);font-size:1.02rem;font-weight:600;color:var(--dark);margin-bottom:8px}
.role-card p,[id^="roleCard-"] p{font-size:.78rem;color:var(--muted);line-height:1.72}

/* ============================================================
   STATS — Terracotta strip
   ============================================================ */
.stats,#faStats{
  padding:80px 0;
  background:linear-gradient(135deg,var(--brand-dark) 0%,var(--brand) 100%);
  position:relative;
}
.stats::before,#faStats::before{
  content:'';position:absolute;top:-1px;left:0;right:0;height:64px;
  background:linear-gradient(180deg,var(--cream),transparent);pointer-events:none;
}
.stats::after,#faStats::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:64px;
  background:linear-gradient(0deg,var(--cream),transparent);pointer-events:none;
}
.stats-grid,#statsGrid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;text-align:center;padding:24px 0;
}
.stats-grid>div,#statsGrid>div{position:relative;padding:12px 8px}
.stats-grid>div:not(:last-child)::after,#statsGrid>div:not(:last-child)::after{
  content:'';position:absolute;top:8px;right:-12px;bottom:8px;width:1px;
  background:rgba(255,255,255,.14);
}
.stat-num{font-family:var(--font-serif);font-size:3rem;font-weight:700;color:var(--white);line-height:1}
.stat-num sup{font-size:1.3rem;vertical-align:super}
.stat-lbl{font-size:.72rem;color:rgba(255,255,255,.72);margin-top:8px;text-transform:uppercase;letter-spacing:.12em}

/* ============================================================
   CONTACT — Split with Double-Bezel form
   ============================================================ */
.contact,#contacto{
  padding:clamp(100px,14vw,160px) 0;
  background:linear-gradient(180deg,var(--cream) 0%,var(--off) 100%);
}
.contact-head,#contactHead{text-align:center;margin-bottom:clamp(48px,6vw,64px)}
.contact-head .body-lg,#contactHead .body-lg{margin:0 auto}
.contact-grid,#contactGrid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:clamp(32px,5vw,64px);
  align-items:start;
}
.contact-info-text{font-size:.96rem;color:var(--muted);line-height:1.85;margin-bottom:32px}
.contact-list,#contactList{display:flex;flex-direction:column;gap:20px;margin-bottom:36px}
.ci,[id^="contactItem-"]{display:flex;align-items:flex-start;gap:16px}
.ci-ico,[id^="contactIcon-"]{
  width:46px;height:46px;flex-shrink:0;border-radius:16px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  display:flex;align-items:center;justify-content:center;
  color:var(--white);box-shadow:0 10px 20px rgba(196,86,43,.18);
}
.ci-ico svg,[id^="contactIcon-"] svg{width:18px;height:18px}
.ci-txt h4,[id^="contactText-"] h4{font-size:.82rem;font-weight:700;color:var(--dark);margin-bottom:3px}
.ci-txt p,.ci-txt a,[id^="contactText-"] p,[id^="contactText-"] a{font-size:.86rem;color:var(--muted);line-height:1.72}
.ci-txt a:hover,[id^="contactText-"] a:hover{color:var(--brand)}

.schedule,#contactSchedule{
  background:rgba(255,255,255,.5);border-radius:var(--r-lg);
  padding:22px 24px;border:1px solid rgba(154,63,28,.07);
  backdrop-filter:blur(12px);
}
.schedule h4,#contactSchedule h4{
  font-size:.84rem;font-weight:700;color:var(--dark);
  margin-bottom:14px;display:flex;align-items:center;gap:8px;
}
.schedule h4 svg,#contactSchedule h4 svg{width:16px;height:16px;color:var(--brand)}
.sch-row,[id^="scheduleRow-"]{
  display:flex;justify-content:space-between;gap:16px;
  font-size:.8rem;padding:9px 0;border-bottom:1px solid rgba(154,63,28,.06);color:var(--muted);
}
.sch-row:last-child,[id^="scheduleRow-"]:last-child{border:none}
.sch-row strong,[id^="scheduleRow-"] strong{color:var(--dark)}

/* Form — Double Bezel */
.contact-form-wrap,#contactFormWrap{
  padding:6px;border-radius:var(--r-xl);
  background:rgba(255,255,255,.35);border:1px solid rgba(154,63,28,.06);
}
.contact-form,#contactForm{
  background:var(--white);border-radius:calc(var(--r-xl) - 6px);
  padding:clamp(32px,4vw,48px) clamp(28px,3.5vw,44px);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.5);
}
.contact-form h3,#contactForm h3{
  font-family:var(--font-serif);font-size:1.4rem;font-weight:600;
  color:var(--dark);margin-bottom:4px;letter-spacing:-.02em;
}
.contact-form .form-sub,#contactForm .form-sub{font-size:.84rem;color:var(--muted);margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:.72rem;font-weight:700;color:var(--dark);text-transform:uppercase;letter-spacing:.08em}
.fg input,.fg select,.fg textarea{
  padding:13px 16px;
  border:1.5px solid rgba(154,63,28,.1);
  border-radius:var(--r-md);
  font-family:var(--font-body);font-size:.88rem;color:var(--text);
  background:var(--white);outline:none;width:100%;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:rgba(154,63,28,.32);
  box-shadow:0 0 0 4px rgba(196,86,43,.06);
}
.fg textarea{resize:vertical;min-height:120px}
.btn-submit{width:100%;justify-content:center;padding:15px;font-size:.92rem}
.form-legal{font-size:.7rem;color:var(--muted);text-align:center;margin-top:14px;opacity:.7}
.form-legal a{color:var(--brand)}

/* ============================================================
   FOOTER — Minimal editorial
   ============================================================ */
.footer,#faFooter{
  background:var(--off);color:var(--muted);
  padding:clamp(60px,8vw,88px) 0 32px;
  border-top:1px solid var(--line);
}
.footer-grid,#footerGrid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:clamp(28px,4vw,52px);
  margin-bottom:44px;
}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.footer-logo img{height:48px;width:auto}
.footer-brand p,#footerBrand p{font-size:.84rem;line-height:1.82;max-width:300px;margin-top:14px}
.footer-col h5,#footerNav h5,#footerServices h5,#footerContact h5{
  font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;color:var(--dark);margin-bottom:20px;
}
.footer-col ul,#footerNav ul,#footerServices ul,#footerContact ul{display:flex;flex-direction:column;gap:11px}
.footer-col a,#footerNav a,#footerServices a,#footerContact a{
  font-size:.82rem;color:var(--muted);
  display:inline-flex;
  transition:color var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.footer-col a:hover,#footerNav a:hover,#footerServices a:hover,#footerContact a:hover{color:var(--brand);transform:translateX(3px)}
.footer-bottom{
  border-top:1px solid var(--line);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  gap:18px;font-size:.74rem;
}
.coleg{display:flex;gap:10px;flex-wrap:wrap}
.cb{
  background:rgba(255,255,255,.6);border:1px solid rgba(154,63,28,.07);
  border-radius:999px;padding:7px 14px;font-size:.68rem;color:var(--muted);
}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-l{opacity:0;transform:translateX(-28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-r{opacity:0;transform:translateX(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in,.reveal-l.in,.reveal-r.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.40s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:32px;padding:140px 0 80px}
  .hero-text{max-width:none}
  .hero-h1{max-width:none}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-img{min-height:400px}
  .about-float{display:none}
  .team-grid{max-width:none}
  .team-card:nth-child(2){margin-top:0}
  .srv-header{grid-template-columns:1fr;gap:24px}
  .srv-grid{grid-template-columns:1fr 1fr}
  .srv-card,.srv-card:nth-child(1),.srv-card:nth-child(2){grid-column:span 1}
  .roles-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stats-grid>div:nth-child(2)::after{display:none}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .navbar{padding:12px 0}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .hero-grid{padding:120px 0 60px}
  .hero-h1{font-size:clamp(2.2rem,10vw,3.2rem)}
  .hero-stats{flex-direction:column;gap:16px}
  .hero-stat{padding:12px 0}
  .hero-stat:not(:last-child)::after{display:none;top:auto;right:auto;bottom:0;left:0;width:100%;height:1px}
  .hero-screenshots{grid-template-columns:1fr 1fr;gap:10px}
  .hero-screenshots img:nth-child(n+5){display:none}
  .about-grid{gap:32px}
  .about-img{min-height:340px}
  .about-badge{display:none}
  .about-values{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr;max-width:440px}
  .team-photo{height:300px}
  .team-colegio{flex-direction:column;align-items:flex-start;gap:16px}
  .srv-grid{grid-template-columns:1fr}
  .roles-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr;gap:12px;padding:20px 0}
  .stats-grid>div::after{display:none}
  .contact-form{padding:28px 22px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-l,.reveal-r{opacity:1;transform:none;transition:none}
  .hero-screenshots img{opacity:1;transform:none;animation:none}
}

/* Scrollbar */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--brand-pale);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--brand-light)}

/* ============================================================
   GRADIENT MESH BLOBS
   ============================================================ */
.hero-blob{
  position:absolute;border-radius:50%;pointer-events:none;
  filter:blur(80px);will-change:transform;
}
.hero-blob-1{
  width:480px;height:480px;top:-5%;right:8%;
  background:radial-gradient(circle,rgba(196,86,43,.16) 0%,transparent 70%);
  animation:blobFloat 14s ease-in-out infinite;
}
.hero-blob-2{
  width:360px;height:360px;bottom:5%;left:12%;
  background:radial-gradient(circle,rgba(217,112,69,.10) 0%,transparent 70%);
  animation:blobFloat 18s ease-in-out infinite reverse;
}
.hero-blob-3{
  width:260px;height:260px;top:30%;left:50%;
  background:radial-gradient(circle,rgba(196,86,43,.08) 0%,transparent 70%);
  animation:blobFloat 22s ease-in-out infinite 3s;
}
@keyframes blobFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  25%{transform:translate(30px,-20px) scale(1.05)}
  50%{transform:translate(-20px,30px) scale(.95)}
  75%{transform:translate(15px,15px) scale(1.03)}
}

/* ============================================================
   HERO TEXT REVEAL
   ============================================================ */
.hero-line{display:block;overflow:hidden}
.hero-line-inner{
  display:block;
  opacity:0;transform:translateY(100%);
  animation:lineReveal .8s var(--ease) forwards;
}
.hero-line:nth-child(1) .hero-line-inner{animation-delay:.25s}
.hero-line:nth-child(2) .hero-line-inner{animation-delay:.40s}
.hero-line:nth-child(3) .hero-line-inner{animation-delay:.55s}
@keyframes lineReveal{to{opacity:1;transform:translateY(0)}}

.hero-kicker,
.hero-sub,
.hero-actions,
.hero-stats,
.hero-visual,
.hero-screenshots img{
  opacity:1;
  transform:none;
  animation:none;
}

/* ============================================================
   MAGNETIC BUTTON
   ============================================================ */
.magnetic{transition:transform .35s var(--ease-spring)}

/* ============================================================
   SPOTLIGHT GLOW
   ============================================================ */
.srv-card::after{
  content:'';position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(196,86,43,.10) 0%,transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .4s;z-index:0;
  transform:translate(-50%,-50%);left:var(--mx,50%);top:var(--my,50%);
}
.srv-card{position:relative;overflow:hidden}
.srv-card:hover::after{opacity:1}

.role-card{position:relative;overflow:hidden}
.role-card::before,[id^="roleCard-"]::before{
  content:'';position:absolute;width:180px;height:180px;border-radius:50%;
  background:radial-gradient(circle,rgba(196,86,43,.10) 0%,transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .4s;
  transform:translate(-50%,-50%);left:var(--mx,50%);top:var(--my,50%);
}
.role-card:hover::before,[id^="roleCard-"]:hover::before{opacity:1}

.av,[id^="aboutValue-"]{position:relative;overflow:hidden}
.av::before,[id^="aboutValue-"]::before{
  content:'';position:absolute;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(196,86,43,.10) 0%,transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .4s;
  transform:translate(-50%,-50%);left:var(--mx,50%);top:var(--my,50%);
}
.av:hover::before,[id^="aboutValue-"]:hover::before{opacity:1}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-strip,#trustStrip{
  padding:36px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--white);
}
.trust-grid,#trustGrid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;text-align:center;
}
.trust-item,[id^="trustItem-"]{
  padding:14px 20px;position:relative;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.trust-item:not(:last-child)::after,[id^="trustItem-"]:not(:last-child)::after{
  content:'';position:absolute;right:0;top:12px;bottom:12px;width:1px;
  background:var(--line);
}
.trust-ico{
  width:44px;height:44px;border-radius:14px;
  background:rgba(196,86,43,.06);color:var(--brand);
  display:flex;align-items:center;justify-content:center;
  transition:transform .4s var(--ease-spring),background .3s var(--ease);
}
.trust-item:hover .trust-ico,[id^="trustItem-"]:hover .trust-ico{transform:scale(1.1) rotate(-3deg);background:rgba(196,86,43,.10)}
.trust-item .elementor-icon-box-wrapper,[id^="trustItem-"] .elementor-icon-box-wrapper{display:flex;flex-direction:column;align-items:center;gap:10px}
.trust-item .elementor-icon-box-icon,[id^="trustItem-"] .elementor-icon-box-icon{
  width:44px;height:44px;border-radius:14px;
  background:rgba(196,86,43,.06);color:var(--brand);
  display:flex;align-items:center;justify-content:center;
  transition:transform .4s var(--ease-spring),background .3s var(--ease);
}
.trust-item:hover .elementor-icon-box-icon,[id^="trustItem-"]:hover .elementor-icon-box-icon{transform:scale(1.1) rotate(-3deg);background:rgba(196,86,43,.10)}
.trust-item .elementor-icon-box-icon svg,[id^="trustItem-"] .elementor-icon-box-icon svg{width:20px;height:20px}
.trust-item .elementor-icon-box-title,[id^="trustItem-"] .elementor-icon-box-title{font-size:.74rem;font-weight:600;color:var(--dark);line-height:1.4}
.trust-item .elementor-icon-box-description,[id^="trustItem-"] .elementor-icon-box-description{font-size:.66rem;color:var(--muted);margin-top:-4px}
.trust-ico svg{width:20px;height:20px}
.trust-label{font-size:.74rem;font-weight:600;color:var(--dark);line-height:1.4}
.trust-sub{font-size:.66rem;color:var(--muted);margin-top:-4px}

/* ============================================================
   ABOUT — BG text + rotating badge
   ============================================================ */
.about-bg-text{
  position:absolute;top:50%;left:-4%;
  font-family:var(--font-serif);font-size:clamp(6rem,14vw,16rem);
  font-weight:600;font-style:italic;color:rgba(196,86,43,.035);
  line-height:1;pointer-events:none;
  transform:translateY(-50%);white-space:nowrap;
}
.about-badge{animation:badgeSpin 20s linear infinite}
.about-badge svg{animation:badgeSpin 20s linear infinite reverse}
@keyframes badgeSpin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}

/* ============================================================
   STATS — Giant background serif text
   ============================================================ */
.stats-bg{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--font-serif);font-size:clamp(5rem,18vw,14rem);
  font-weight:700;font-style:italic;color:rgba(255,255,255,.05);
  white-space:nowrap;pointer-events:none;line-height:1;
}

/* ============================================================
   PARALLAX TILT
   ============================================================ */
.hero-screenshots,#heroScreenshots{perspective:800px;transition:transform .15s linear}

/* ============================================================
   MICRO INTERACTIONS
   ============================================================ */
.srv-icon,[id^="srvIcon-"]{transition:transform .4s var(--ease-spring)}
.srv-card:hover .srv-icon,[id^="srvCard-"]:hover [id^="srvIcon-"]{transform:scale(1.08) rotate(-3deg)}

.ci-ico,[id^="contactIcon-"]{transition:transform .4s var(--ease-spring)}
.ci:hover .ci-ico,[id^="contactItem-"]:hover [id^="contactIcon-"]{transform:scale(1.08) rotate(-3deg)}

.hero-portal-tags span{transition:background .3s var(--ease),transform .3s var(--ease)}
.hero-portal-tags span:hover{background:rgba(196,86,43,.12);transform:translateY(-2px)}
