/* ============ ESTRATO · estilos compartidos ============ */
:root{
  --olive:#1d261f;
  --olive-2:#23302a;
  --cream:#f3efe4;
  --cream-dim:#c2bdae;
  --paper:#f6f2e9;
  --paper-2:#efe9db;
  --paper-3:#fbf9f3;
  --paper-ink:#262720;
  --paper-ink-dim:#5d5d52;
  --sage:#94a47e;
  --sage-solid:#5f6e50;
  --sage-ink:#566549;
  --copper:#c1854f;
  --copper-light:#d49a66;
  --copper-ink:#a4663a;
  --line:rgba(243,239,228,.12);
  --line-dark:rgba(38,39,32,.12);
  --shadow:0 22px 60px -30px rgba(40,40,20,.35);
  --rad:18px;
  --maxw:1180px;
  --ff-display:"Fraunces",Georgia,serif;
  --ff-body:"Archivo","Segoe UI",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:92px;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-body);background:var(--paper);color:var(--paper-ink);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
h1,h2,h3{font-family:var(--ff-display);font-weight:500;line-height:1.1;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.eyebrow{font-family:var(--ff-body);font-size:.74rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--copper-ink);display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--copper-ink);opacity:.7}
.eyebrow.light{color:var(--copper-light)}
.eyebrow.light::before{background:var(--copper-light)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--ff-body);font-weight:600;font-size:.93rem;padding:.85em 1.5em;border-radius:100px;cursor:pointer;border:1px solid transparent;transition:transform .25s,background .25s,color .25s,border-color .25s;letter-spacing:.01em;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:16px;height:16px}
.btn-copper{background:var(--copper);color:#22160c}
.btn-copper:hover{background:var(--copper-light)}
.btn-outline{background:transparent;color:var(--paper-ink);border-color:rgba(38,39,32,.25)}
.btn-outline:hover{border-color:var(--paper-ink);background:rgba(38,39,32,.04)}
.btn-light{background:transparent;color:var(--cream);border-color:var(--line)}
.btn-light:hover{border-color:var(--cream);background:rgba(243,239,228,.06)}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(29,38,31,.92);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .35s,box-shadow .35s}
header.scrolled{border-bottom-color:var(--line);box-shadow:0 10px 30px -18px rgba(0,0,0,.55)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand img{height:46px;width:auto}
.menu{display:flex;align-items:center;gap:30px}
.menu>a,.dd-toggle{font-size:.92rem;font-weight:500;color:var(--cream-dim);position:relative;transition:color .2s;cursor:pointer}
.menu>a::after,.dd-toggle::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--copper);transition:width .3s}
.menu>a:hover,.dd-toggle:hover{color:var(--cream)}
.menu>a:hover::after,.dd-toggle:hover::after{width:100%}
.menu>a.active{color:var(--cream)}
.menu>a.active::after{width:100%}
/* dropdown */
.has-dd{position:relative}
.dd-toggle{display:inline-flex;align-items:center;gap:.4em}
.dd-toggle.active{color:var(--cream)}
.caret{font-size:.7em;transition:transform .25s}
.has-dd:hover .caret,.has-dd.open .caret{transform:rotate(180deg)}
.dd-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);margin-top:14px;background:rgba(20,26,17,.98);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:14px;padding:10px;min-width:240px;display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:.25s;box-shadow:0 24px 44px -22px rgba(0,0,0,.7)}
.dd-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.has-dd:hover .dd-menu,.has-dd:focus-within .dd-menu,.has-dd.open .dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dd-menu a{padding:11px 14px;border-radius:9px;font-size:.92rem;color:var(--cream-dim);white-space:nowrap;transition:.2s}
.dd-menu a:hover{background:rgba(243,239,228,.06);color:var(--cream)}
.dd-menu a.active{color:var(--copper-light)}
/* burger */
.burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.burger span{position:absolute;left:0;height:2px;width:100%;background:var(--cream);transition:.3s}
.burger span:nth-child(1){top:2px}.burger span:nth-child(2){top:11px}.burger span:nth-child(3){top:20px}
body.nav-open .burger span:nth-child(1){top:11px;transform:rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){top:11px;transform:rotate(-45deg)}
.mobile-menu{position:fixed;top:78px;right:0;bottom:auto;left:0;background:rgba(20,26,17,.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .4s cubic-bezier(.6,.05,.1,1);z-index:99;padding:14px 28px 26px}
body.nav-open .mobile-menu{transform:translateY(0)}
.mobile-menu a{display:block;padding:13px 0;font-size:1.02rem;color:var(--cream);border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:16px;display:flex;width:100%;justify-content:center;text-align:center;border-bottom:none}

/* topo lines */
.topo{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}
.topo svg{width:100%;height:100%}

/* hero */
.hero{position:relative;background-color:var(--paper);background-image:url('data:image/svg+xml,<svg viewBox="0 0 1200 600" preserveAspectRatio="xMidYMid slice" fill="none" xmlns="http://www.w3.org/2000/svg"><g stroke="%238a9a72" stroke-width="1.1" opacity="0.5"><path d="M-50 150 C220 90 430 210 660 150 S1060 70 1260 150"/><path d="M-50 300 C230 220 440 380 670 300 S1070 200 1260 300"/><path d="M-50 450 C245 360 460 540 700 450 S1090 340 1260 450"/></g><g stroke="%23c1854f" stroke-width="1.1" opacity="0.4"><path d="M-50 225 C225 155 435 295 665 225 S1065 135 1260 225"/><path d="M-50 375 C235 295 445 455 675 375 S1075 275 1260 375"/></g></svg>');background-attachment:fixed;background-size:cover;background-repeat:no-repeat;padding:160px 0 100px;overflow:hidden}
.hero::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(115% 85% at 80% 8%,rgba(193,133,79,.12),transparent 55%),radial-gradient(90% 80% at 8% 100%,rgba(148,164,126,.16),transparent 55%)}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;gap:56px;align-items:center}
.hero-copy h1{font-size:clamp(2.4rem,5.2vw,4rem);margin:22px 0 0;letter-spacing:-.02em;color:var(--paper-ink);text-shadow:0 0 18px var(--paper),0 0 36px var(--paper)}
.hero-copy h1 .em{font-style:italic;color:var(--copper-ink);font-weight:400}
.hero-copy p.sub{font-size:1.14rem;color:var(--paper-ink-dim);margin:24px 0 34px;max-width:32em;line-height:1.6;text-shadow:0 0 14px var(--paper),0 0 28px var(--paper)}
.hero-copy .eyebrow{text-shadow:0 0 12px var(--paper),0 0 24px var(--paper)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-card{position:relative;border-radius:var(--rad);overflow:hidden;border:1px solid var(--line-dark);background:linear-gradient(160deg,#fff,#efe9db);min-height:460px;box-shadow:var(--shadow)}
.hero-card img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}
.hero-card .grid-lines{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.85}
.hero-card .ph{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-end;padding:26px}
.hero-card .ph .tag{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage-ink);font-weight:600}
.hero-card .ph .ph-t{font-family:var(--ff-display);font-size:1.35rem;margin-top:6px;color:var(--paper-ink)}

/* sections */
section{position:relative}
.sec{padding:96px 0}
.sec.alt{background:var(--paper-2)}
.sec-head{max-width:44em;margin-bottom:50px;position:relative;z-index:2}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(1.9rem,3.8vw,2.8rem);margin:16px 0 0;color:var(--paper-ink)}
.sec-head p{color:var(--paper-ink-dim);margin-top:14px;font-size:1.06rem}

/* sector doors */
.doors{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px;position:relative;z-index:2}
.door{background:var(--paper-3);border:1px solid var(--line-dark);border-radius:var(--rad);padding:30px 28px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:transform .35s,box-shadow .35s,border-color .35s}
.door::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--sage),var(--copper));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.door:hover{transform:translateY(-6px);box-shadow:0 28px 50px -30px rgba(40,40,20,.4);border-color:transparent}
.door:hover::before{transform:scaleX(1)}
.door h3{font-size:1.32rem;margin-bottom:10px}
.door p{flex:1;color:var(--paper-ink-dim);font-size:.96rem}
.door .go{margin-top:20px;color:var(--copper-ink);font-weight:600;display:inline-flex;align-items:center;gap:.4em;transition:gap .3s}
.door:hover .go{gap:.75em}

/* icon chip */
.ico{width:52px;height:52px;border-radius:13px;background:var(--olive);display:flex;align-items:center;justify-content:center;margin-bottom:20px;flex-shrink:0}
.ico svg{width:26px;height:26px;stroke:var(--sage);fill:none;stroke-width:1.5}

/* service cards */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;position:relative;z-index:2}
.svc-card{background:var(--paper-3);border:1px solid var(--line-dark);border-radius:var(--rad);padding:32px 28px 28px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:transform .35s,box-shadow .35s,border-color .35s}
.svc-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--sage),var(--copper));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 28px 50px -30px rgba(40,40,20,.4);border-color:transparent}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card h3{font-size:1.28rem;line-height:1.2}
.svc-card p{color:var(--paper-ink-dim);font-size:.95rem;margin-top:10px;line-height:1.55}

/* context band */
.band{position:relative;background:var(--olive);color:var(--cream);padding:84px 0;overflow:hidden}
.band .topo{opacity:.5}
.band .wrap{position:relative;z-index:2}
.band-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.band h2{font-size:clamp(1.7rem,3.4vw,2.4rem);color:var(--cream)}
.band p{color:var(--cream-dim);margin-top:16px}
.band .stat b{font-family:var(--ff-display);font-size:2.1rem;color:var(--copper-light);display:block;line-height:1}
.band .stat span{font-size:.85rem;color:var(--cream-dim)}
.band-stats{display:flex;flex-direction:column;gap:24px}
.band-stats .stat{border-left:2px solid var(--copper);padding-left:18px}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;position:relative;z-index:2}
.pillar{background:var(--paper-3);border:1px solid var(--line-dark);border-radius:14px;padding:24px 22px;transition:transform .3s,box-shadow .3s}
.pillar:hover{transform:translateY(-4px);box-shadow:0 20px 40px -30px rgba(40,40,20,.45)}
.pillar .pico{width:44px;height:44px;border-radius:11px;background:var(--sage-solid);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.pillar .pico svg{width:22px;height:22px;stroke:var(--cream);fill:none;stroke-width:1.6}
.pillar h4{font-family:var(--ff-body);font-weight:700;font-size:1rem;margin-bottom:6px}
.pillar p{font-size:.87rem;color:var(--paper-ink-dim);line-height:1.5}

/* nosotros */
.nos-quote{font-family:var(--ff-display);font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.3;font-style:italic;color:var(--paper-ink);margin:22px 0;padding-left:24px;border-left:3px solid var(--copper);max-width:30em}

/* cta band */
.cta{position:relative;background:var(--olive);color:var(--cream);overflow:hidden}
.cta .topo{opacity:.45}
.cta .inner{position:relative;z-index:2;text-align:center;padding:80px 24px;max-width:40em;margin:0 auto}
.cta h2{font-size:clamp(1.8rem,3.6vw,2.5rem);color:var(--cream)}
.cta p{color:var(--cream-dim);margin:16px auto 30px;max-width:32em}
.cta .hero-cta{justify-content:center}

/* contacto */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;position:relative;z-index:2}
.contact-info h2{font-size:clamp(1.9rem,3.8vw,2.6rem);margin:16px 0 20px;color:var(--paper-ink)}
.contact-info>p{color:var(--paper-ink-dim);max-width:26em;margin-bottom:30px}
.cinfo-list{display:flex;flex-direction:column;gap:18px}
.cinfo{display:flex;align-items:center;gap:16px}
.cinfo .ci-ic{width:46px;height:46px;border-radius:12px;border:1px solid var(--line-dark);background:var(--paper-3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cinfo .ci-ic svg{width:20px;height:20px;stroke:var(--copper-ink);fill:none;stroke-width:1.6}
.cinfo .lbl{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-ink);font-weight:600;display:block;margin-bottom:3px}
.cinfo a,.cinfo span.v{font-size:1rem;color:var(--paper-ink);font-weight:500}
.cinfo a:hover{color:var(--copper-ink)}
form{background:var(--paper-3);border:1px solid var(--line-dark);border-radius:var(--rad);padding:32px;box-shadow:var(--shadow)}
.fld{margin-bottom:18px}
.fld label{display:block;font-size:.8rem;letter-spacing:.05em;color:var(--paper-ink-dim);margin-bottom:7px;font-weight:600}
.fld input,.fld select,.fld textarea{width:100%;background:#fff;border:1px solid rgba(38,39,32,.18);border-radius:11px;padding:13px 15px;color:var(--paper-ink);font-family:var(--ff-body);font-size:.96rem;transition:border-color .2s,box-shadow .2s}
.fld textarea{resize:vertical;min-height:110px}
.fld input::placeholder,.fld textarea::placeholder{color:#a3a394}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--copper);box-shadow:0 0 0 3px rgba(193,133,79,.18)}
.fld select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a4663a' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
form .btn{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:.78rem;color:var(--paper-ink-dim);text-align:center;margin-top:14px}

/* portal / clientes */
.portal{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:140px 24px 90px;position:relative;overflow:hidden}
.portal .topo{opacity:.5}
.portal-card{position:relative;z-index:2;background:var(--paper-3);border:1px solid var(--line-dark);border-radius:var(--rad);box-shadow:var(--shadow);max-width:520px;width:100%;padding:44px 40px;text-align:center}
.portal-card .ico{margin:0 auto 22px}
.portal-card h1{font-size:2rem;margin-bottom:14px}
.portal-card p{color:var(--paper-ink-dim);margin-bottom:14px}
.portal-card .btn{margin-top:10px}
.portal-steps{text-align:left;margin:22px 0 8px;display:flex;flex-direction:column;gap:12px}
.portal-steps .st{display:flex;gap:12px;align-items:flex-start;font-size:.93rem;color:var(--paper-ink-dim)}
.portal-steps .st b{display:inline-flex;width:24px;height:24px;border-radius:50%;background:var(--sage-solid);color:#fff;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;margin-top:1px}

/* footer */
footer{background:var(--olive);color:var(--cream-dim);padding:60px 0 30px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.foot-brand img{height:168px;width:auto;margin-bottom:18px}
.foot-brand p{font-size:.9rem;max-width:24em;line-height:1.6}
.foot-col h5{font-family:var(--ff-body);color:var(--cream);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px}
.foot-col a,.foot-col p{display:block;font-size:.92rem;margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:var(--copper-light)}
.socials{display:flex;gap:12px;margin-top:4px}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.25s}
.socials a:hover{border-color:var(--copper);transform:translateY(-3px)}
.socials svg{width:17px;height:17px;fill:var(--cream-dim);transition:.25s}
.socials a:hover svg{fill:var(--copper-light)}
.foot-bottom{padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem}

/* whatsapp float */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:90;width:60px;height:60px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.5);transition:transform .3s;animation:wapulse 2.6s ease-in-out infinite}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px;fill:#fff}
@keyframes wapulse{0%,100%{box-shadow:0 12px 30px -8px rgba(37,211,102,.5)}50%{box-shadow:0 12px 30px -8px rgba(37,211,102,.5),0 0 0 12px rgba(37,211,102,0)}}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* responsive */
@media (max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .hero-card{min-height:300px}
  .band-grid,.contact-grid{grid-template-columns:1fr;gap:36px}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .menu{display:none}.burger{display:block}
  .sec{padding:70px 0}.hero{padding:116px 0 70px}
  .band{padding:64px 0}
  .pillars{grid-template-columns:1fr}.fld-row{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}.foot-bottom{flex-direction:column}
  .nav{height:66px}.brand img{height:40px}.mobile-menu{top:66px;right:0;bottom:auto;left:0}
  .portal-card{padding:34px 24px}
  .wrap{padding:0 20px}
}

/* ============ TEAM ============ */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:52px;position:relative;z-index:2}
.team-card{text-align:center}
.team-photo{width:156px;height:156px;border-radius:50%;overflow:hidden;margin:0 auto 14px;background:var(--paper-2);border:2px solid var(--line-dark);filter:grayscale(100%)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.team-photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2e3d2e,var(--olive))}
.team-photo-ph svg{width:44px;height:44px;stroke:rgba(243,239,228,.25);fill:none;stroke-width:0.8}
.team-card h4{font-family:var(--ff-body);font-weight:700;font-size:.95rem;color:var(--paper-ink);margin-bottom:4px}
.team-card .role{font-size:.82rem;color:var(--copper-ink);font-weight:500}
@media (max-width:920px){.team-grid{grid-template-columns:repeat(2,1fr);gap:24px}}
@media (max-width:480px){.team-grid{grid-template-columns:repeat(2,1fr);gap:16px}.team-photo{width:135px;height:135px}}

/* ============ SERVICE CARDS — clickable ============ */
a.svc-card{cursor:pointer;text-decoration:none}
.svc-card .go{margin-top:auto;padding-top:16px;color:var(--copper-ink);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:.4em;transition:gap .3s}
.svc-card:hover .go{gap:.75em}

/* ============ SERVICE DETAIL PAGE ============ */
.breadcrumb{font-size:.8rem;color:var(--paper-ink-dim);padding:96px 0 12px;position:relative;z-index:2;line-height:2}
.breadcrumb a{color:var(--copper-ink);transition:color .2s}.breadcrumb a:hover{color:var(--copper)}
.breadcrumb span{margin:0 .45em;opacity:.45;display:inline-block}
.svc-hero{padding:36px 0 80px;position:relative;overflow:hidden;background-image:url('data:image/svg+xml,<svg viewBox="0 0 1200 600" preserveAspectRatio="xMidYMid slice" fill="none" xmlns="http://www.w3.org/2000/svg"><g stroke="%238a9a72" stroke-width="1.1" opacity="0.5"><path d="M-50 150 C220 90 430 210 660 150 S1060 70 1260 150"/><path d="M-50 300 C230 220 440 380 670 300 S1070 200 1260 300"/><path d="M-50 450 C245 360 460 540 700 450 S1090 340 1260 450"/></g><g stroke="%23c1854f" stroke-width="1.1" opacity="0.4"><path d="M-50 225 C225 155 435 295 665 225 S1065 135 1260 225"/><path d="M-50 375 C235 295 445 455 675 375 S1075 275 1260 375"/></g></svg>');background-attachment:fixed;background-size:cover;background-repeat:no-repeat}
.svc-hero::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(110% 80% at 80% 10%,rgba(193,133,79,.1),transparent 55%),radial-gradient(80% 70% at 5% 100%,rgba(148,164,126,.12),transparent 55%)}
.svc-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}
.svc-hero h1{font-size:clamp(2rem,4.5vw,3.2rem);margin:18px 0 0;letter-spacing:-.02em;text-shadow:0 0 18px var(--paper),0 0 36px var(--paper)}
.svc-hero h1 .em{font-style:italic;color:var(--copper-ink);font-weight:400}
.svc-hero p.sub{color:var(--paper-ink-dim);font-size:1.1rem;margin:22px 0 32px;max-width:30em;line-height:1.6;text-shadow:0 0 14px var(--paper),0 0 28px var(--paper)}
.svc-hero .eyebrow{text-shadow:0 0 12px var(--paper),0 0 24px var(--paper)}
.svc-visual{border-radius:var(--rad);overflow:hidden;border:1px solid var(--line-dark);background:linear-gradient(160deg,#fff,#efe9db);min-height:380px;box-shadow:var(--shadow);position:relative}
.svc-visual img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}
.svc-visual-ph{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;background:linear-gradient(160deg,#e8e3d6,#d6d0c2)}
.svc-visual-ph .tag{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage-ink);font-weight:600}
.svc-visual-ph .ph-t{font-family:var(--ff-display);font-size:1.2rem;margin-top:6px;color:var(--paper-ink)}
/* image overlay when real photo is present */
.svc-visual.has-img .svc-visual-ph{background:linear-gradient(to top,rgba(20,26,17,.82) 0%,rgba(20,26,17,.3) 55%,transparent 100%);z-index:1}
.svc-visual.has-img .svc-visual-ph .tag{color:var(--copper-light)}
.svc-visual.has-img .svc-visual-ph .ph-t{color:var(--cream)}

/* detail content sections */
.detail-block{padding:80px 0}
.detail-block.alt{background:var(--paper-2)}
.detail-2col{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;position:relative;z-index:2}
.detail-2col.rev{direction:rtl}.detail-2col.rev>*{direction:ltr}
.detail-2col.detail-meth{margin-top:28px}
.detail-content h2{font-size:clamp(1.7rem,3.2vw,2.3rem);margin:16px 0 0}
.detail-content p{color:var(--paper-ink-dim);margin-top:14px;font-size:1rem;line-height:1.8}
.steps-list{list-style:none;padding:0;margin-top:24px;display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.steps-list li{list-style:none;display:flex;flex-direction:column;background:var(--paper-3);border:1px solid var(--line-dark);border-radius:14px;padding:20px 18px 18px;position:relative;overflow:hidden}
.steps-list li::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--sage),var(--copper))}
.step-num{width:28px;height:28px;border-radius:50%;background:var(--olive);color:var(--cream);font-family:var(--ff-display);font-size:.8rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:12px}
.steps-list li .step-title{font-family:var(--ff-body);font-weight:700;font-size:.94rem;color:var(--paper-ink);margin-bottom:6px;display:block}
.steps-list li p{color:var(--paper-ink-dim);font-size:.88rem;line-height:1.6;margin-top:0}
/* hero-card con imagen real */
.hero-card.has-img .ph{background:linear-gradient(to top,rgba(20,26,17,.85) 0%,rgba(20,26,17,.25) 60%,transparent 100%)}
.hero-card.has-img .ph .tag{color:var(--copper-light)}
.hero-card.has-img .ph .ph-t{color:var(--cream)}
.deliv-list{list-style:none;padding:0;margin-top:20px;display:flex;flex-direction:column;gap:0}
.deliv-list li{padding:13px 0;border-bottom:1px solid rgba(38,39,32,.28);font-size:.97rem;color:var(--paper-ink);line-height:1.55}
.deliv-list li:first-child{border-top:1px solid rgba(38,39,32,.28)}
.law-box{background:var(--olive);color:var(--cream);border-radius:var(--rad);padding:28px 30px;margin-top:28px}
.law-box h4{font-family:var(--ff-body);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper-light);margin-bottom:14px}
.law-box ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.law-box ul li{font-size:.93rem;color:var(--cream-dim);padding-left:16px;position:relative;line-height:1.5}
.law-box ul li::before{content:"·";position:absolute;left:0;color:var(--copper)}
.detail-img{border-radius:var(--rad);overflow:hidden;border:1px solid var(--line-dark);box-shadow:var(--shadow)}
.detail-img img{width:100%;height:360px;object-fit:cover;display:block}
.detail-img-ph{height:360px;background:linear-gradient(160deg,#e8e3d6,#ccc8ba);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px}
.detail-img-ph svg{width:48px;height:48px;stroke:rgba(38,39,32,.2);fill:none;stroke-width:1.2}
.detail-img-ph span{font-size:.8rem;color:rgba(38,39,32,.4);letter-spacing:.1em;text-transform:uppercase}
@media (max-width:920px){.svc-hero .wrap,.detail-2col{grid-template-columns:1fr;gap:36px}.svc-visual{min-height:260px}.detail-2col.rev{direction:ltr}}

/* ============ TRABAJÁ CON NOSOTROS ============ */
.trabaja-areas{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;position:relative;z-index:2;margin-top:10px}
.area-card{background:var(--paper-3);border:1px solid var(--line-dark);border-radius:14px;padding:24px 22px}
.area-card h4{font-family:var(--ff-body);font-weight:700;font-size:1rem;color:var(--paper-ink);margin-bottom:6px}
.area-card p{font-size:.88rem;color:var(--paper-ink-dim);line-height:1.5}
.fld input[type="file"]{padding:10px 12px;background:var(--paper);cursor:pointer;font-size:.88rem}
.fld input[type="file"]::file-selector-button{background:var(--olive);color:var(--cream);border:none;border-radius:8px;padding:7px 14px;font-family:var(--ff-body);font-size:.82rem;font-weight:600;cursor:pointer;margin-right:12px;transition:background .2s}
.fld input[type="file"]::file-selector-button:hover{background:var(--sage-solid)}
@media (max-width:680px){.trabaja-areas{grid-template-columns:1fr}}
@media (max-width:480px){.trabaja-areas{grid-template-columns:1fr}}
/* iOS Safari ignores background-attachment:fixed — switch to scroll on mobile so lines are visible */
@media (max-width:920px){.hero,.svc-hero{background-attachment:scroll}}
