/* ===== ADPCO — shared stylesheet ===== */
:root{
  /* exact logo colors */
  --maroon:#7f072b;
  --maroon-deep:#5a061f;
  --maroon-bright:#a30a31;
  --blue:#154bf3;
  --blue-soft:#446ee3;
  --peach:#f6d8c5;
  --peach-soft:#fbeee5;

  --ink:#1a1117;
  --graphite:#2a2228;
  --paper:#fbf8f6;
  --paper-2:#f3ece8;
  --line:rgba(90,6,31,.14);
  --line-soft:rgba(26,17,23,.1);

  --display:'Fraunces',Georgia,serif;
  --body:'Archivo',system-ui,sans-serif;

  --shadow:0 18px 50px rgba(90,6,31,.13);
  --shadow-sm:0 8px 24px rgba(26,17,23,.08);
  --maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--paper);color:var(--ink);line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,32px)}

/* ---------- HEADER ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(251,248,246,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.bar{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,32px);height:78px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;cursor:pointer;flex-shrink:0}
.brand img{height:46px;width:auto}
.brand .txt{font-family:var(--display);font-weight:600;font-size:23px;letter-spacing:1px;color:var(--maroon);line-height:1}
.brand .txt small{display:block;font-family:var(--body);font-size:8.5px;letter-spacing:2.4px;text-transform:uppercase;color:var(--blue);font-weight:600;margin-top:3px}
nav{display:flex;gap:2px;align-items:center}
nav a{font-size:13px;font-weight:500;padding:9px 13px;border-radius:8px;color:var(--graphite);transition:.2s;white-space:nowrap}
nav a:hover{background:var(--peach-soft);color:var(--maroon)}
nav a.active{color:var(--maroon);font-weight:700}
nav a.cta{background:var(--maroon);color:#fff}
nav a.cta:hover{background:var(--maroon-bright);color:#fff}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.burger span{width:25px;height:2px;background:var(--maroon);border-radius:2px;transition:.25s}
.burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- BUTTONS ---------- */
.btn{padding:14px 28px;border-radius:10px;font-weight:600;font-size:14.5px;transition:.22s;cursor:pointer;border:1px solid transparent;display:inline-block}
.btn-primary{background:var(--maroon);color:#fff}
.btn-primary:hover{background:var(--maroon-bright);transform:translateY(-2px);box-shadow:0 14px 32px rgba(127,7,43,.35)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-soft);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{border-color:var(--maroon);color:var(--maroon)}
.btn-outline:hover{background:var(--maroon);color:#fff}

/* ---------- HERO (home) ---------- */
.hero{position:relative;min-height:58vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:#0c0a0c}
.hero video.bgvid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.hero .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(12,10,12,.82) 0%,rgba(12,10,12,.62) 40%,rgba(12,10,12,.4) 70%,rgba(12,10,12,.34) 100%)}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,14,18,.74) 0%,rgba(20,14,18,.5) 42%,rgba(20,14,18,.22) 70%,rgba(20,14,18,.08) 100%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:64px clamp(18px,4vw,32px);width:100%}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--peach);font-weight:600;margin-bottom:22px}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--peach)}
.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(30px,4.6vw,54px);line-height:1.1;max-width:18ch;letter-spacing:-.5px}
.hero p{max-width:56ch;margin-top:22px;font-size:clamp(15px,1.6vw,18px);color:rgba(255,255,255,.9)}
.hero-actions{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{margin-top:48px;display:flex;gap:40px;flex-wrap:wrap}
.hero-stats .st b{font-family:var(--display);font-size:34px;font-weight:600;color:#fff;display:block;line-height:1}
.hero-stats .st span{font-size:12.5px;letter-spacing:1px;text-transform:uppercase;color:var(--peach);font-weight:600}

/* ---------- SECTIONS ---------- */
section{padding:clamp(56px,8vw,96px) 0}
.tag{font-size:12.5px;letter-spacing:3.5px;text-transform:uppercase;color:var(--maroon);font-weight:700;margin-bottom:14px}
.tag.blue{color:var(--blue)}
.h2{font-family:var(--display);font-weight:600;font-size:clamp(26px,4vw,42px);line-height:1.1;letter-spacing:-.4px;color:var(--ink)}
.lede{font-family:var(--display);font-weight:500;font-size:clamp(21px,2.7vw,31px);line-height:1.34;max-width:30ch;color:var(--ink)}
.lede em{color:var(--maroon);font-style:italic}
.muted{color:rgba(26,17,23,.72);font-size:16px}

.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(34px,5vw,72px);align-items:center}
.about-grid .imgwrap{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.about-grid .imgwrap img{width:100%;height:100%;object-fit:cover}
.about-grid .imgwrap::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.25);border-radius:18px;pointer-events:none}
.badge-row{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px}
.badge{border:1px solid var(--line);border-radius:100px;padding:9px 17px;font-size:12.5px;font-weight:600;color:var(--maroon);background:#fff;display:flex;align-items:center;gap:8px}
.badge span{width:7px;height:7px;border-radius:50%;background:var(--blue)}

/* divisions grid — clean, image-free professional cards, unified soft background */
.div-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:6px}
.div-card{position:relative;border:1px solid var(--line);border-radius:16px;cursor:pointer;background:var(--paper-2);padding:34px 30px;display:flex;flex-direction:column;min-height:248px;transition:.28s;overflow:hidden}
.div-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--maroon);transform:scaleY(0);transform-origin:top;transition:.32s}
.div-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent;background:#fff}
.div-card:hover::before{transform:scaleY(1)}
.div-card .k{font-family:var(--display);font-size:30px;font-weight:600;color:var(--maroon-bright);opacity:.45;line-height:1;transition:.28s}
.div-card:hover .k{opacity:1}
.div-card h3{font-family:var(--display);font-weight:600;font-size:23px;margin:14px 0 10px;color:var(--ink)}
.div-card p{font-size:14px;color:rgba(26,17,23,.66);max-width:36ch;flex-grow:1}
.div-card .go{margin-top:18px;font-size:13px;font-weight:700;color:var(--maroon);display:flex;align-items:center;gap:8px;transition:.2s}
.div-card:hover .go{gap:12px}
.div-card.feature{background:linear-gradient(150deg,var(--maroon),var(--maroon-deep));border-color:transparent}
.div-card.feature::before{display:none}
.div-card.feature .k{color:var(--peach);opacity:1;font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase}
.div-card.feature h3,.div-card.feature p{color:#fff}
.div-card.feature p{color:rgba(255,255,255,.82)}
.div-card.feature .go{color:#fff}
.div-card.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow);background:linear-gradient(150deg,var(--maroon),var(--maroon-deep))}

/* MVV */
.mvv{background:linear-gradient(150deg,var(--maroon) 0%,var(--maroon-deep) 100%);color:#fff;position:relative;overflow:hidden}
.mvv::before{content:"";position:absolute;right:-140px;top:-140px;width:560px;height:560px;border:1px solid rgba(255,255,255,.1);border-radius:50%;box-shadow:0 0 0 70px rgba(255,255,255,.035)}
.mvv .tag{color:var(--peach)}
.mvv .h2{color:#fff}
.blocks{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px;position:relative}
.block{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:16px;padding:30px 26px;transition:.25s}
.block:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.block .num{font-family:var(--display);font-size:13px;color:var(--peach);font-weight:600;letter-spacing:2px;margin-bottom:14px;display:block}
.block h3{font-family:var(--display);font-weight:600;font-size:21px;margin-bottom:10px;color:#fff}
.block p{font-size:14.5px;color:rgba(255,255,255,.8)}

/* values */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;margin-top:6px}
.val{padding:32px 26px;border-right:1px solid var(--line)}
.val:last-child{border-right:none}
.val .icn{width:48px;height:48px;border-radius:12px;background:var(--peach-soft);color:var(--maroon);font-family:var(--display);font-size:24px;font-weight:700;display:grid;place-items:center;margin-bottom:16px}
.val h4{font-family:var(--display);font-size:19px;font-weight:600;margin-bottom:8px}
.val p{font-size:13.5px;color:rgba(26,17,23,.68)}

/* clients */
.clients{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.client-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:8px}
.client-grid div{border:1px solid var(--line);border-radius:12px;padding:18px 14px;font-size:13px;font-weight:600;color:var(--graphite);text-align:center;background:var(--paper);min-height:70px;display:flex;align-items:center;justify-content:center;transition:.2s}
.client-grid div:hover{border-color:var(--maroon);color:var(--maroon);transform:translateY(-3px)}
.vendor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.vendor{border:1px solid var(--line);border-radius:14px;padding:22px 24px;background:#fff;display:flex;justify-content:space-between;align-items:center;gap:14px;transition:.2s}
.vendor:hover{box-shadow:var(--shadow-sm)}
.vendor b{font-family:var(--display);font-size:16px;color:var(--ink)}
.vendor span{font-size:11.5px;color:rgba(26,17,23,.55);display:block;margin-top:2px;letter-spacing:.5px}
.vendor .id{font-family:var(--display);font-size:18px;color:var(--maroon);font-weight:700;white-space:nowrap}

/* ---------- SERVICE PAGE ---------- */
.page-hero{position:relative;min-height:32vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(12,10,12,.82),rgba(12,10,12,.55) 55%,rgba(12,10,12,.32))}
.page-hero .wrap{position:relative;padding-bottom:38px;padding-top:48px;width:100%}
.crumb{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--peach);font-weight:600}
.crumb a:hover{color:#fff}
.page-hero h1{font-family:var(--display);font-weight:600;font-size:clamp(30px,4.6vw,50px);margin-top:14px;max-width:20ch;letter-spacing:-.4px}

.two-col{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(36px,5vw,60px);align-items:start}
.glance{font-family:var(--display);font-weight:600;font-size:clamp(22px,3vw,30px);margin-bottom:20px;color:var(--ink)}
.prose p{font-size:16px;color:rgba(26,17,23,.84);margin-bottom:16px;max-width:74ch}
.subsection{margin-top:36px}
.subsection h3{font-family:var(--display);font-weight:600;font-size:21px;color:var(--maroon);margin-bottom:8px}
.feat-title{font-family:var(--display);font-weight:600;font-size:23px;margin:14px 0 22px;padding-bottom:14px;border-bottom:2px solid var(--maroon);display:inline-block}
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 38px;list-style:none}
.features li{display:flex;gap:12px;font-size:14.5px;color:rgba(26,17,23,.85);padding:5px 0}
.features li::before{content:"";flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--blue);margin-top:8px}

/* product gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.gallery figure{border-radius:14px;overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:.28s}
.gallery figure:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.gallery figure .imgbox{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2)}
.gallery figure img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery figure:hover img{transform:scale(1.07)}
.gallery figcaption{padding:14px 16px;font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink)}

.gallery2{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:14px}
.gallery2 .ph{border-radius:14px;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-sm);position:relative}
.gallery2 .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery2 .ph:hover img{transform:scale(1.07)}
.gallery2 .ph.tall{grid-row:span 2;aspect-ratio:auto}

/* contact card */
.contact-card{background:linear-gradient(155deg,var(--maroon),var(--maroon-deep));color:#fff;border-radius:18px;padding:36px;position:sticky;top:100px;box-shadow:var(--shadow)}
.contact-card .role{font-family:var(--display);font-size:20px;font-weight:600;margin-bottom:4px}
.contact-card .role small{display:block;font-family:var(--body);font-size:12.5px;font-weight:500;color:var(--peach);margin-top:5px;letter-spacing:.5px}
.contact-card .lines{margin-top:20px;font-size:14px;color:rgba(255,255,255,.88);line-height:2}
.contact-card .lines a{color:#fff;border-bottom:1px solid rgba(255,255,255,.3)}
.contact-card .hr{height:1px;background:rgba(255,255,255,.16);margin:20px 0}

/* materials table */
.mat-tables{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.mat-card{border:1px solid var(--line);border-radius:14px;padding:22px;background:#fff}
.mat-card h4{font-family:var(--display);font-size:16px;color:var(--maroon);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.mat-card .row{font-size:13px;display:flex;justify-content:space-between;gap:12px;padding:5px 0;color:rgba(26,17,23,.8)}
.mat-card .row b{color:var(--ink);font-weight:600;flex-shrink:0}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.field{margin-bottom:15px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--graphite)}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;font-family:var(--body);font-size:14px;background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--maroon);box-shadow:0 0 0 3px rgba(127,7,43,.1)}
.info-line{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.info-line .lbl{font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:var(--blue);font-weight:700;min-width:74px;padding-top:2px}
.info-line .v{font-size:15px}
.info-line .v a{border-bottom:1px solid var(--line)}

/* ---------- FOOTER ---------- */
footer{background:var(--graphite);color:#fff;padding:64px 0 28px}
.foot{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:36px}
.foot .brand .txt{color:#fff}
.foot p,.foot a{font-size:13.5px;color:rgba(255,255,255,.66);line-height:1.95}
.foot h5{font-family:var(--display);font-size:14px;letter-spacing:1.5px;text-transform:uppercase;color:var(--peach);margin-bottom:14px;font-weight:600}
.foot a:hover{color:#fff}
.copy{margin-top:46px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:rgba(255,255,255,.5)}

/* reveal animation — content is VISIBLE BY DEFAULT. JS adds a gentle fade/slide
   only when it's working. This guarantees text is never invisible if JS/CSS load
   out of order on the server. */
.reveal{opacity:1;transform:none}
.js-ready .reveal{opacity:0;transform:translateY(24px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.js-ready .reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
/* failsafe: even under .js-ready, force-show after 1.4s if .in never arrives */
@keyframes adpcoFailsafeReveal{to{opacity:1;transform:none}}
.js-ready .reveal{animation:adpcoFailsafeReveal .01s linear 1.4s forwards}
.js-ready .reveal.in{animation:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1080px){
  nav{position:fixed;inset:78px 0 auto 0;flex-direction:column;background:var(--paper);padding:16px;gap:2px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:.32s;box-shadow:var(--shadow);z-index:55}
  nav.open{transform:translateY(0)}
  nav a{padding:14px;font-size:15px}
  .burger{display:flex}
  .div-grid,.blocks,.mat-tables,.gallery{grid-template-columns:repeat(2,1fr)}
  .values{grid-template-columns:repeat(2,1fr)}
  .val:nth-child(2){border-right:none}
  .val:nth-child(1),.val:nth-child(2){border-bottom:1px solid var(--line)}
  .vendor-grid{grid-template-columns:repeat(2,1fr)}
  .client-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:760px){
  .about-grid,.two-col,.contact-grid,.foot,.blocks{grid-template-columns:1fr}
  .about-grid .imgwrap{order:-1}
  .div-grid,.gallery,.gallery2,.features,.mat-tables{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .val{border-right:none;border-bottom:1px solid var(--line)}
  .val:last-child{border-bottom:none}
  .client-grid{grid-template-columns:repeat(2,1fr)}
  .vendor-grid{grid-template-columns:1fr}
  .contact-card{position:static}
  .hero-stats{gap:26px}
  .foot{gap:28px}
}

/* ---------- CLIENTS & PARTNERS PAGES ---------- */
.logo-wall{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:14px}
.logo-card{border:1px solid var(--line);border-radius:14px;background:#fff;aspect-ratio:3/2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:22px;transition:.25s}
.logo-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-4px);border-color:rgba(127,7,43,.25)}
.logo-card img{max-height:56px;max-width:80%;width:auto;object-fit:contain}
.logo-card .nm{font-size:12.5px;font-weight:600;color:var(--graphite);text-align:center;letter-spacing:.3px}
.partner-board{margin-top:18px;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);padding:10px}
.partner-board img{width:100%;border-radius:10px}
.name-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.name-tags span{border:1px solid var(--line);border-radius:100px;padding:9px 16px;font-size:13px;font-weight:600;color:var(--graphite);background:#fff}
@media(max-width:1080px){.logo-wall{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.logo-wall{grid-template-columns:repeat(2,1fr)}}
