/* =========================================================
   Ampenet Solutions — shared stylesheet
   Clean · minimal · corporate  (navy / orange design system)
   ========================================================= */

:root{
  --navy:#044386;
  --orange:#FF6200;
  --ink:#1F2A37;
  --muted:#65758B;
  --line:#E6EAEF;
  --bg:#FFFFFF;
  --bg-alt:#FAFBFC;
  --max:1440px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Cabin',system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
h2,h3,h4{color:var(--navy);font-weight:600;letter-spacing:-0.02em;line-height:1.18}
h1,.hero-headline{font-family:'DM Serif Display',Georgia,serif;font-weight:400;font-style:italic;color:var(--navy);letter-spacing:-0.02em;line-height:1.1}
h1 .accent,.hero-headline .accent{font-style:normal;color:var(--orange)}

.label{font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.label::before{content:"";display:inline-block;width:18px;height:1px;background:var(--orange);vertical-align:middle;margin-right:10px}

:focus-visible{outline:2px solid var(--navy);outline-offset:3px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;background:var(--navy);color:#fff;padding:12px 26px;font-size:.9rem;font-weight:500;transition:background .15s;cursor:pointer;border:none;font-family:inherit}
.btn:hover{background:var(--orange)}
.btn-outline{display:inline-flex;align-items:center;gap:9px;border:1.5px solid var(--navy);color:var(--navy);padding:11px 24px;font-size:.9rem;font-weight:500;transition:all .15s}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-white{display:inline-flex;align-items:center;gap:9px;background:#fff;color:var(--navy);padding:13px 28px;font-size:.9rem;font-weight:600;border:none;cursor:pointer;font-family:inherit;letter-spacing:-.01em;transition:opacity .15s}
.btn-white:hover{opacity:.9}
.btn::after,.btn-outline::after,.btn-white::after{content:"";width:14px;height:14px;flex-shrink:0;background:currentColor;transition:transform .15s ease;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='M12 5l7 7-7 7'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='M12 5l7 7-7 7'/%3E%3C/svg%3E") center/contain no-repeat}
.btn:hover::after,.btn-outline:hover::after,.btn-white:hover::after{transform:translateX(3px)}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--navy);color:rgba(255,255,255,.8);font-size:.8rem;line-height:1;position:relative;z-index:40}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:40px;gap:20px}
.topbar a{color:rgba(255,255,255,.8);transition:color .15s}
.topbar a:hover{color:#fff}
.tb-phones{display:flex;align-items:center;min-width:0}
.tb-pic{flex-shrink:0;margin-right:12px;opacity:.6}
.tb-phones a{display:inline-flex;align-items:center;gap:6px;padding:0 13px;white-space:nowrap}
.tb-phones a:first-of-type{padding-left:0}
.tb-phones a + a{border-left:1px solid rgba(255,255,255,.1)}
.tb-right{display:flex;align-items:center;gap:18px;flex-shrink:0}
.tb-mail{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.tb-mail svg{flex-shrink:0;opacity:.6}
.tb-soc{display:flex;gap:13px}
.tb-soc a{display:inline-flex}
.tb-soc svg{width:14px;height:14px}
@media (max-width:920px){
  .topbar .wrap{height:36px}
  .tb-phones a:not(:first-of-type){display:none}
  .tb-soc{display:none}
}
@media (max-width:400px){ .tb-mail span,.tb-mail{font-size:.76rem} }
/* Inner pages: white topbar with dark text (homepage keeps navy / transparent over hero) */
body:not(.home-hero) .topbar{background:#fff;color:var(--muted);border-bottom:1px solid var(--line)}
body:not(.home-hero) .topbar a{color:var(--muted)}
body:not(.home-hero) .topbar a:hover{color:var(--navy)}
body:not(.home-hero) .tb-phones a + a{border-left-color:var(--line)}
body:not(.home-hero) .tb-pic,body:not(.home-hero) .tb-mail svg{opacity:.75}

/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .25s ease,border-color .25s ease}
header.scrolled{box-shadow:0 6px 24px rgba(4,67,134,.07);border-bottom-color:transparent}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:inline-flex;align-items:center;font-weight:600;font-size:1.05rem;color:var(--navy);letter-spacing:-0.01em}
.logo em{font-style:normal;color:var(--orange)}
.logo img{width:auto}
.logo-full{display:block;height:46px}
.logo-mark{display:none;height:44px}
.nav-links{display:flex;gap:34px;font-size:.9rem;color:var(--muted);align-items:center}
.nav-links > a:hover{color:var(--navy)}
.nav-links > a.active{color:var(--navy);font-weight:500}
.nav-right{display:flex;align-items:center;gap:22px}

/* dropdowns (Solutions + Client login share mechanics) */
.dd{position:relative}
.dd-btn{background:none;border:none;font:inherit;font-size:.9rem;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:6px;padding:8px 0}
.dd-btn:hover,.dd-btn.active{color:var(--navy)}
.dd-menu{position:absolute;left:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);min-width:250px;padding:6px;display:none;box-shadow:0 8px 24px rgba(4,67,134,.06)}
.dd-menu.right{left:auto;right:0}
.dd-menu.open{display:block}
.dd-menu a{display:block;padding:9px 14px;font-size:.88rem;color:var(--ink)}
.dd-menu a:hover{background:var(--bg-alt);color:var(--navy)}
.dd-group{font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:12px 14px 4px}
.dd-group:first-child{padding-top:8px}
.dd-menu .dd-sub{font-size:.84rem;color:var(--muted);padding-left:14px}
.dd-menu .dd-sub:hover{color:var(--navy)}
.dd-btn svg{transition:transform .15s}
.dd-btn[aria-expanded="true"] svg{transform:rotate(180deg)}
@keyframes ddIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.dd-menu.open{animation:ddIn .16s ease}

/* mega menu (Solutions) */
.dd-mega{left:-120px;min-width:0;width:940px;max-width:calc(100vw - 400px);padding:26px 26px 18px;grid-template-columns:repeat(4,1fr);gap:4px 22px}
.dd-mega.open{display:grid}
.dd-mega .dd-col{display:flex;flex-direction:column}
.dd-mega .dd-group{padding:0 0 10px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.dd-mega a{padding:9px 10px;margin:0 -10px}
.dd-mega a strong{display:block;font-size:.86rem;font-weight:600;color:var(--navy);letter-spacing:-.01em;transition:color .15s}
.dd-mega a span{display:block;font-size:.76rem;color:var(--muted);line-height:1.45;margin-top:2px}
.dd-mega a:hover{background:var(--bg-alt)}
.dd-mega a:hover strong{color:var(--orange)}
.dd-mega-foot{grid-column:1/-1;display:flex;align-items:center;gap:8px;margin-top:12px;padding:14px 10px 2px;border-top:1px solid var(--line);font-size:.82rem;font-weight:600;color:var(--navy)}
.dd-mega-foot svg{transition:transform .15s}
.dd-mega-foot:hover{color:var(--orange);background:none}
.dd-mega-foot:hover svg{transform:translateX(4px)}

.burger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.burger span{display:block;width:20px;height:1.5px;background:var(--navy);margin:5px 0}

/* ---------- Home hero ---------- */
.hero{position:relative;overflow:hidden;min-height:calc(100vh - 72px);min-height:calc(100svh - 72px);display:flex;align-items:center;padding:60px 0}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-fx-mask{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,rgba(6,16,33,.88) 0%,rgba(6,16,33,.6) 40%,rgba(6,16,33,.28) 72%,rgba(6,16,33,.12) 100%),linear-gradient(180deg,rgba(6,16,33,.5) 0%,rgba(6,16,33,0) 26%)}
@media (max-width:920px){.hero-photo,.hero-fx-mask{display:none}}

/* hero slider */
.hero-slider{display:block;padding:0}
.hero-slide{position:absolute;inset:0;z-index:0;display:flex;align-items:center;padding:60px 0;opacity:0;visibility:hidden;transition:opacity .8s ease,visibility 0s linear .8s}
.hero-slide.is-active{opacity:1;visibility:visible;z-index:1;transition:opacity .8s ease}
.hero-slide .wrap{position:relative;z-index:2;width:100%}
.hero-copy > *{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.hero-slide.is-active .hero-copy > *{opacity:1;transform:none}
.hero-slide.is-active .hero-copy > :nth-child(1){transition-delay:.15s}
.hero-slide.is-active .hero-copy > :nth-child(2){transition-delay:.25s}
.hero-slide.is-active .hero-copy > :nth-child(3){transition-delay:.35s}
.hero-slide.is-active .hero-copy > :nth-child(4){transition-delay:.45s}
.hero-dots{position:absolute;bottom:38px;left:50%;transform:translateX(-50%);width:100%;max-width:var(--max);padding:0 28px;z-index:5;display:flex;gap:9px}
.hero-dot{width:34px;height:4px;padding:0;border:none;border-radius:3px;background:rgba(4,67,134,.22);cursor:pointer;transition:background .2s}
.hero-dot:hover{background:rgba(4,67,134,.45)}
.hero-dot.is-active{background:var(--navy)}
.hero h1,.hero .hero-headline{font-size:clamp(2.6rem,5vw,4.2rem);max-width:20ch;margin:22px 0 24px}
.hero p{max-width:56ch;color:var(--muted);font-size:1.06rem;margin-bottom:40px}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-foot{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:80px;padding-top:28px;border-top:1px solid var(--line)}
.hero-foot div b{display:block;color:var(--navy);font-weight:600;font-size:.98rem}
.hero-foot div span{font-size:.81rem;color:var(--muted)}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;overflow:hidden;padding:94px 0 80px;background:linear-gradient(118deg,#04386f 0%,#063063 46%,#05223f 100%)}
.page-hero > .hero-fx{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;pointer-events:none}
.page-hero > .page-hero-fade{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,rgba(4,28,55,.72) 0%,rgba(4,28,55,.32) 42%,rgba(4,28,55,0) 72%)}
.page-hero::after{content:"";position:absolute;top:50%;right:-160px;transform:translateY(-50%);width:560px;height:560px;border-radius:50%;background:repeating-radial-gradient(circle,transparent 0 43px,rgba(255,255,255,.05) 43px 44px);z-index:1;pointer-events:none}
.page-hero > .wrap{position:relative;z-index:2}
@media (max-width:768px){.page-hero > .hero-fx,.page-hero > .page-hero-fade,.page-hero::after{display:none}.page-hero h1,.page-hero p{max-width:none}}
.page-hero .label{color:rgba(255,255,255,.75)}
.page-hero h1{font-size:clamp(2.1rem,4vw,3.2rem);max-width:75%;margin:20px 0 18px;color:#fff}
.page-hero p{max-width:75%;color:rgba(255,255,255,.82);font-size:1.04rem}
.page-hero .hero-actions{margin-top:34px}
.page-hero .btn{background:var(--orange);color:#fff}
.page-hero .btn:hover{background:#fff;color:var(--navy)}
.page-hero .btn-outline{border-color:rgba(255,255,255,.5);color:#fff}
.page-hero .btn-outline:hover{background:#fff;color:var(--navy);border-color:#fff}
.crumbs{font-size:.8rem;color:var(--muted);margin-bottom:26px}
.crumbs a:hover{color:var(--navy)}
.crumbs span{margin:0 8px;color:var(--line)}
.page-hero .crumbs{color:rgba(255,255,255,.55)}
.page-hero .crumbs a:hover{color:#fff}
.page-hero .crumbs span{color:rgba(255,255,255,.3)}

/* hero with image split */
.page-hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
.page-hero-img{border:1px solid var(--line)}
.page-hero-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}

/* ---------- Generic sections ---------- */
.section{padding:90px 0}
.section.alt{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section.line-top{border-top:1px solid var(--line)}
.sec-intro{max-width:none;margin-bottom:60px}
.sec-intro h2{font-size:clamp(1.5rem,3vw,2.05rem);margin:18px 0 14px}
.sec-intro p{color:var(--muted);max-width:80ch}

/* ---------- Card grids ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line)}
.svc-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.svc-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.svc-card{padding:36px 32px;border-right:1px solid var(--line);display:flex;flex-direction:column;background:var(--bg)}
.svc-card:last-child{border-right:none}
.svc-grid.wraps{border:none;gap:0}
.svc-grid.wraps .svc-card{border:1px solid var(--line);margin:0 -1px -1px 0}
.svc-icon{width:40px;height:40px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:26px;flex-shrink:0}
.svc-card h3{font-size:1.05rem;margin-bottom:10px}
.svc-card p{font-size:.92rem;color:var(--muted);line-height:1.72;flex:1}
.svc-link{display:inline-flex;align-items:center;gap:7px;font-size:.84rem;font-weight:500;color:var(--navy);margin-top:22px;transition:color .15s}
.svc-link svg{transition:transform .15s}
.svc-link:hover{color:var(--orange)}
.svc-link:hover svg{transform:translateX(4px)}
.svc-card .svc-tag{font-size:.66rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.svc-grid.wraps .svc-icon{margin-bottom:18px}
.pkg-card p{flex:none}
.pkg-list{list-style:none;margin:16px 0 0;display:flex;flex-direction:column;gap:9px}
.pkg-list li{position:relative;padding-left:23px;font-size:.875rem;color:var(--muted);line-height:1.5}
.pkg-list li::before{content:"";position:absolute;left:2px;top:3px;width:5px;height:9px;border:solid var(--orange);border-width:0 2px 2px 0;transform:rotate(45deg)}

/* card with photo */
.photo-card{border:1px solid var(--line);display:flex;flex-direction:column;background:var(--bg)}
.photo-card img{width:100%;aspect-ratio:16/10;object-fit:cover;border-bottom:1px solid var(--line)}
.photo-card .pc-body{padding:28px 28px 32px;display:flex;flex-direction:column;flex:1}
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.photo-grid.cols-2{grid-template-columns:repeat(2,1fr)}

/* ---------- Feature split (text + list / image) ---------- */
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.feature-grid.center{align-items:center}
.feature-copy h2{font-size:clamp(1.5rem,3vw,2.05rem);margin:18px 0 16px}
.feature-copy p{color:var(--muted);margin-bottom:16px}
.feature-img{border:1px solid var(--line)}
.feature-img img{width:100%;object-fit:cover}

.feat-list{margin-top:4px}
.feat-item{display:grid;grid-template-columns:36px 1fr;gap:16px;padding:16px 0;border-top:1px solid var(--line);align-items:start}
.feat-item:last-child{border-bottom:1px solid var(--line)}
.feat-icon{width:32px;height:32px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.feat-text h3,.feat-text h4{font-size:.93rem;font-weight:600;color:var(--navy);margin-bottom:2px}
.feat-text span{font-size:.85rem;color:var(--muted)}
.feat-cta{margin-top:32px}
/* feature list wrapped in a container */
.feat-panel{border:1px solid var(--line);background:var(--bg);padding:4px 28px}
.feat-panel .feat-item:first-child{border-top:none}
.feat-panel .feat-item:last-child{border-bottom:none}

/* ---------- Full-bleed feature band ---------- */
.feature-band{position:relative;overflow:hidden}
.feature-band .fb-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feature-band .fb-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.5) 38%,rgba(0,0,0,.12) 70%,rgba(0,0,0,0) 100%)}
.feature-band .wrap{position:relative;padding:104px 28px}
.feature-band .label{color:rgba(255,255,255,.5)}
.feature-band h2{color:#fff;font-size:clamp(1.6rem,3vw,2.3rem);margin:18px 0 18px;max-width:20ch}
.feature-band p{color:rgba(255,255,255,.72);max-width:50ch;margin-bottom:34px}
.fb-stats{display:flex;gap:48px;margin-bottom:36px;flex-wrap:wrap}
.fb-stats b{display:block;font-size:1.9rem;font-weight:600;color:#fff;letter-spacing:-.02em;line-height:1.1}
.fb-stats b em{font-style:normal;color:var(--orange)}
.fb-stats span{font-size:.8rem;color:rgba(255,255,255,.5)}

/* ---------- Tags ---------- */
.assets-label{display:block;font-size:.69rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;margin-top:28px}
.tag-cloud{display:flex;flex-wrap:wrap;gap:7px}
.tag{font-size:.75rem;font-weight:500;color:var(--navy);border:1px solid var(--line);padding:5px 11px;letter-spacing:.01em}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line)}
.stats.cols-3{grid-template-columns:repeat(3,1fr)}
.stat{padding:30px 28px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat b{display:block;font-size:1.7rem;font-weight:600;color:var(--navy);letter-spacing:-.02em;line-height:1.1;margin-bottom:6px}
.stat b em{font-style:normal;color:var(--orange)}
.stat span{font-size:.81rem;color:var(--muted)}

/* ---------- Spec tables ---------- */
.spec-table{width:100%;border-collapse:collapse;border:1px solid var(--line);font-size:.89rem}
.spec-table th,.spec-table td{padding:12px 16px;border:1px solid var(--line);text-align:left;vertical-align:top}
.spec-table th{background:var(--bg-alt);color:var(--navy);font-weight:600;font-size:.8rem;letter-spacing:.04em;white-space:nowrap}
.spec-table td{color:var(--muted)}
.spec-table td:first-child{color:var(--navy);font-weight:500;white-space:nowrap}
.spec-table .yes{color:var(--navy);font-weight:600}
.spec-table .no{color:#C2CAD4}

/* collapsible spec blocks */
details.spec{border:1px solid var(--line);margin-bottom:-1px;background:var(--bg)}
details.spec summary{cursor:pointer;list-style:none;padding:18px 22px;font-size:.95rem;font-weight:600;color:var(--navy);display:flex;justify-content:space-between;align-items:center}
details.spec summary::-webkit-details-marker{display:none}
details.spec summary::after{content:"+";font-weight:400;font-size:1.2rem;color:var(--muted)}
details.spec[open] summary::after{content:"–"}
details.spec .spec-body{padding:0 22px 22px}
details.spec .spec-body p{font-size:.9rem;color:var(--muted);margin-bottom:12px}

/* ---------- Checklist ---------- */
.check-list{list-style:none}
.check-list li{position:relative;padding:10px 0 10px 30px;font-size:.92rem;color:var(--muted);border-top:1px solid var(--line)}
.check-list li:last-child{border-bottom:1px solid var(--line)}
.check-list li::before{content:"";position:absolute;left:2px;top:17px;width:12px;height:7px;border-left:2px solid var(--orange);border-bottom:2px solid var(--orange);transform:rotate(-45deg)}
.check-list li b{color:var(--navy);font-weight:600}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line)}
.steps.cols-4{grid-template-columns:repeat(4,1fr)}
.step{padding:32px 28px;border-right:1px solid var(--line)}
.step:last-child{border-right:none}
.step-num{font-family:'DM Serif Display',Georgia,serif;font-style:italic;font-size:1.6rem;color:var(--orange);display:block;margin-bottom:14px}
.step h3{font-size:.98rem;margin-bottom:8px}
.step p{font-size:.88rem;color:var(--muted)}

/* ---------- Logo strip ---------- */
.logo-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.logo-strip div{background:#fff;display:flex;align-items:center;justify-content:center;padding:22px 18px;min-height:88px}
.logo-strip img{max-height:44px;max-width:120px;object-fit:contain;filter:grayscale(1);opacity:.65;transition:all .2s}
.logo-strip div:hover img{filter:none;opacity:1}

/* ---------- Industries ---------- */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ind-card{border:1px solid var(--line);padding:32px 30px;background:var(--bg)}
.ind-card h3{font-size:1.02rem;margin-bottom:10px}
.ind-card p{font-size:.9rem;color:var(--muted);margin-bottom:16px}
.ind-card .tag-cloud{margin-top:auto}

/* industry detail rows on industries.html */
.ind-row{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;padding:56px 0;border-top:1px solid var(--line);align-items:start}
.ind-row:last-child{border-bottom:1px solid var(--line)}
.ind-row h3{font-size:1.3rem;margin-bottom:12px}
.ind-row > div > p{color:var(--muted);font-size:.95rem}

/* industries page — selector cards */
.ind-pick p{flex:none}
.svc-grid.wraps .ind-pick:hover{transform:none;box-shadow:none}
.sol-pills{display:flex;flex-wrap:wrap;gap:6px;margin:14px 0 2px}
.sol-pill{font-size:.66rem;font-weight:500;color:var(--navy);background:var(--bg-alt);border:1px solid var(--line);border-radius:20px;padding:4px 10px;line-height:1.3;white-space:nowrap}
/* industries page — alternating photo blocks */
.ind-blocks .ind-block{display:grid;grid-template-columns:1fr 1.12fr;gap:56px;align-items:center;padding:60px 0;border-top:1px solid var(--line);scroll-margin-top:96px}
.ind-blocks .ind-block:first-child{border-top:none}
.ind-blocks .ind-block:nth-child(even) .ind-photo{order:2}
.ind-photo{overflow:hidden;border:1px solid var(--line)}
.ind-photo img{width:100%;height:100%;object-fit:cover;aspect-ratio:5/4;display:block;transition:transform .5s ease}
.ind-block:hover .ind-photo img{transform:scale(1.03)}
.ind-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.ind-icon{width:46px;height:46px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ind-content h3{font-size:1.4rem}
.ind-content > p{color:var(--muted);font-size:.96rem;margin-bottom:20px}
/* industry service list — descriptive icons, no dividers */
.icon-list{list-style:none;display:grid;gap:4px}
.icon-list li{display:grid;grid-template-columns:34px 1fr;gap:14px;align-items:start;padding:8px 0;font-size:.92rem;color:var(--muted);line-height:1.62}
.icon-list .li-icon{width:34px;height:34px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.icon-list li b{color:var(--navy);font-weight:600}
.icon-list li a{color:var(--navy);transition:color .15s}
.icon-list li a:hover{color:var(--orange)}
.icon-list.cols-2{grid-template-columns:1fr 1fr;gap:4px 40px}
@media (max-width:768px){.icon-list.cols-2{grid-template-columns:1fr}}

/* ---------- CTA band ---------- */
.cta-band{background:var(--navy);padding:80px 0}
.cta-band .label{color:rgba(255,255,255,.38)}
.cta-band h2{color:#fff;font-size:clamp(1.5rem,3vw,2.05rem);margin:18px 0 14px;max-width:24ch}
.cta-band p{color:rgba(255,255,255,.5);max-width:54ch;margin-bottom:34px}
.cta-band-inner{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
/* two-path action cards */
.cta-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:38px}
.cta-card{border:1px solid rgba(255,255,255,.14);padding:30px 28px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.cta-card:hover{border-color:rgba(255,255,255,.45);transform:translateY(-3px)}
.cta-card .cta-ic{width:40px;height:40px;border:1px solid rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.cta-card h3{color:#fff;font-size:1.08rem;margin-bottom:8px}
.cta-card p{color:rgba(255,255,255,.5);font-size:.9rem;margin-bottom:20px;max-width:none}
.cta-card .go{display:inline-flex;align-items:center;gap:8px;color:#fff;font-size:.85rem;font-weight:600}
.cta-card .go svg{transition:transform .15s}
.cta-card:hover .go{color:var(--orange)}
.cta-card:hover .go svg{transform:translateX(4px)}

/* ---------- SMS demo panel ---------- */
.sms-panel{background:var(--navy);padding:28px}
.sms-panel-label{font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.36);margin-bottom:18px}
.sms-to-row{font-size:.82rem;color:rgba(255,255,255,.55);padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.09);margin-bottom:14px}
.sms-to-row b{color:#fff;font-weight:500}
.sms-msg{font-size:.9rem;color:#fff;line-height:1.72;min-height:72px}
.sms-msg .hi{color:var(--orange)}
.sms-stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:22px;border-top:1px solid rgba(255,255,255,.09);padding-top:18px;gap:1px}
.sms-stat{text-align:center}
.sms-stat b{display:block;color:#fff;font-size:.96rem;font-weight:600;margin-bottom:2px}
.sms-stat span{font-size:.68rem;color:rgba(255,255,255,.36);text-transform:uppercase;letter-spacing:.12em}

/* ---------- Contact ---------- */
.contact{padding:100px 0;background:var(--navy)}
.contact .label{color:rgba(255,255,255,.78)}
.contact .label::before{background:var(--orange)}
.contact-heading{color:#fff;font-size:clamp(1.5rem,3vw,2.05rem);margin:18px 0 10px}
.contact-sub{color:rgba(255,255,255,.74);margin-bottom:56px;font-size:1rem}
.contact-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:80px;align-items:start}
.cform{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform-field{display:block}
.cform-field.full{grid-column:1/-1}
.field-lbl{display:block;font-size:.69rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:8px}
.cform input,
.cform select,
.cform textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.11);color:#fff;font-family:inherit;font-size:.9rem;padding:11px 13px;outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none;border-radius:0}
.cform input::placeholder,.cform textarea::placeholder{color:rgba(255,255,255,.22)}
.cform input:focus,.cform select:focus,.cform textarea:focus{border-color:rgba(255,255,255,.38)}
.cform select{cursor:pointer;background-color:rgba(255,255,255,.06);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='rgba(255,255,255,0.35)' stroke-width='2.2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center}
.cform select option{background:var(--navy);color:#fff}
.cform textarea{resize:vertical;min-height:106px}
.cinfo h3{font-size:1rem;color:#fff;font-weight:600;margin-bottom:12px;letter-spacing:-.01em}
.cinfo address{font-style:normal;font-size:.88rem;color:rgba(255,255,255,.74);line-height:1.8;margin-bottom:10px}
.cinfo a{display:block;font-size:.88rem;color:rgba(255,255,255,.6);padding:2px 0;transition:color .15s}
.cinfo a:hover{color:#fff}
.cinfo-divider{height:1px;background:rgba(255,255,255,.09);margin:28px 0}

/* ---------- Wide two-zone contact form ---------- */
.cform.cform-2col{grid-template-columns:5fr 7fr;gap:44px;align-items:start}
.cf-left,.cf-right{display:grid;gap:16px;align-content:start}
.field-lbl em{font-style:normal;font-weight:400;text-transform:none;letter-spacing:0;opacity:.55}
/* phone with adaptive country code */
.phone-group{display:flex;align-items:stretch;border:1px solid rgba(255,255,255,.11);background:rgba(255,255,255,.06);transition:border-color .15s}
.phone-group:focus-within{border-color:rgba(255,255,255,.38)}
.phone-code{display:flex;align-items:center;padding:0 13px;font-size:.9rem;font-weight:500;color:rgba(255,255,255,.9);border-right:1px solid rgba(255,255,255,.11);background:rgba(255,255,255,.05);white-space:nowrap}
.cform .phone-group input{border:none;background:transparent;flex:1;min-width:0}
/* multi-select service chips */
.chip-groups{display:grid;gap:16px;margin-top:6px}
.chip-group-label{display:block;font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:9px}
.chip-select{display:flex;flex-wrap:wrap;gap:9px;margin-top:4px}
.chip-group .chip-select{margin-top:0}
.chip{cursor:pointer;display:inline-flex}
.chip input{position:absolute;width:1px;height:1px;opacity:0}
.chip span{display:inline-flex;align-items:center;font-size:.82rem;color:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.18);padding:9px 15px;transition:background .15s,border-color .15s,color .15s;-webkit-user-select:none;user-select:none}
.chip:hover span{border-color:rgba(255,255,255,.45);color:#fff}
.chip input:checked + span{background:var(--orange);border-color:var(--orange);color:#fff}
.chip input:checked + span::after{content:"";width:16px;height:16px;margin-left:8px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='12' fill='%23ffffff'/%3E%3Cpath d='M6.5 12.5l3.6 3.6 7.4-8' fill='none' stroke='%23ff6200' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat}
.chip input:focus-visible + span{outline:2px solid #fff;outline-offset:2px}

/* ---------- Footer ---------- */
footer{background:var(--navy);padding:28px 0}
.foot-bar{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:14px}
.foot-social{display:flex;gap:8px;align-items:center}
.foot-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:color .15s,background .15s,border-color .15s}
.foot-social a:hover{color:var(--navy);background:#fff;border-color:#fff}
.foot-social svg{width:15px;height:15px}

/* ---------- Rounded corners ---------- */
.btn,.btn-outline,.btn-white{border-radius:6px}
.cform input,.cform select,.cform textarea{border-radius:6px}
.phone-group{border-radius:6px;overflow:hidden}
.chip span{border-radius:6px}
.foot-social a{border-radius:6px}
.svc-icon,.feat-icon,.ind-icon,.li-icon,.cta-ic{border-radius:6px}
.photo-card,.ind-photo,.feature-img,.page-hero-img{border-radius:10px}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}
/* staggered children */
.stagger > *{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.stagger.in > *{opacity:1;transform:none}

/* ---------- Hover micro-interactions ---------- */
.svc-grid.wraps .svc-card,.ind-card,.photo-card{transition:transform .2s ease,box-shadow .2s ease}
.svc-grid.wraps .svc-card:hover,.ind-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(4,67,134,.07);position:relative;z-index:1}
.photo-card{overflow:hidden}
.photo-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(4,67,134,.09)}
.photo-card img,.page-hero-img img,.feature-img img{transition:transform .45s ease}
.photo-card:hover img,.page-hero-img:hover img{transform:scale(1.04)}
.page-hero-img,.feature-img{overflow:hidden}
.logo-strip img{transition:filter .2s ease,opacity .2s ease,transform .2s ease}
.logo-strip div:hover img{transform:scale(1.05)}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal,.stagger > *{opacity:1;transform:none;transition:none}
  .hero-slide,.hero-copy > *{transition:none}
  .hero-slide.is-active .hero-copy > *{transition:none}
  .svc-card:hover,.ind-card:hover,.photo-card:hover{transform:none}
  .photo-card:hover img,.page-hero-img:hover img,.logo-strip div:hover img{transform:none}
  *{animation-duration:.001ms !important;animation-delay:.001ms !important}
}

/* ---------- Responsive ---------- */
@media (max-width: 920px){
  .feature-grid,.contact-grid,.page-hero-grid,.ind-row{grid-template-columns:1fr;gap:44px}
  .ind-blocks .ind-block{grid-template-columns:1fr;gap:28px;padding:44px 0}
  .ind-blocks .ind-block:nth-child(even) .ind-photo{order:0}
  .svc-grid,.svc-grid.cols-4,.svc-grid.cols-2{grid-template-columns:1fr}
  .svc-card{border-right:none;border-bottom:1px solid var(--line)}
  .svc-card:last-child{border-bottom:none}
  .photo-grid,.photo-grid.cols-2{grid-template-columns:1fr}
  .ind-grid{grid-template-columns:1fr}
  .steps,.steps.cols-4{grid-template-columns:1fr}
  .step{border-right:none;border-bottom:1px solid var(--line)}
  .step:last-child{border-bottom:none}
  .stats,.stats.cols-3{grid-template-columns:1fr 1fr}
  .stat{border-bottom:1px solid var(--line)}
  .logo-strip{grid-template-columns:repeat(3,1fr)}
  .cform{grid-template-columns:1fr}
  .cform.cform-2col{grid-template-columns:1fr;gap:18px}
  .cform-field.full{grid-column:1}
  .spec-table{display:block;overflow-x:auto}

  /* mobile nav */
  .nav-links{position:fixed;inset:72px 0 auto 0;background:#fff;flex-direction:column;align-items:flex-start;padding:24px 28px 32px;gap:20px;border-bottom:1px solid var(--line);display:none;max-height:calc(100vh - 72px);overflow-y:auto}
  .nav-links.open{display:flex}
  .nav-links .dd{width:100%}
  .nav-links .dd-menu{position:static;border:none;box-shadow:none;min-width:0;padding:4px 0 0 12px}
  .nav-links .dd-mega{display:block;width:auto;max-width:none;padding:4px 0 0 12px;gap:0}
  .nav-links .dd-mega .dd-group{border-bottom:none;padding:14px 0 4px}
  .nav-links .dd-mega a{margin:0;padding:7px 0}
  .nav-links .dd-mega a span{display:none}
  .nav-links .dd-mega-foot{margin-top:6px;padding:10px 0 2px;border-top:none}
  .cta-cards{grid-template-columns:1fr}
  .feature-band .wrap{padding:72px 28px}
  .feature-band .fb-ov{background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.85))}
  .fb-stats{gap:28px}
  .burger{display:block}
  .nav-right .btn{display:none}
  .logo-full{display:none}
  .logo-mark{display:block}
}
@media (max-width: 480px){
  .logo-mark{height:38px}
  .hero-foot{grid-template-columns:1fr;gap:20px}
  .stats,.stats.cols-3{grid-template-columns:1fr}
  .logo-strip{grid-template-columns:repeat(2,1fr)}
}

/* ---------- Home: full-bleed hero image behind a transparent navbar (desktop) ---------- */
@media (min-width:921px){
  .home-hero .topbar{background:transparent;z-index:41}
  .home-hero .topbar .wrap{border-bottom:1px solid rgba(255,255,255,.18)}
  .home-hero header{background:transparent;backdrop-filter:none;border-bottom-color:transparent;box-shadow:none}
  .home-hero header .logo-full{display:none}
  .home-hero header .logo-mark{display:block;height:42px}
  .home-hero header .nav-links > a,
  .home-hero header .dd-btn{color:rgba(255,255,255,.82)}
  .home-hero header .nav-links > a:hover,
  .home-hero header .dd-btn:hover,
  .home-hero header .nav-links > a.active{color:#fff}
  .home-hero header .btn{background:#fff;color:var(--navy)}
  .home-hero header .btn:hover{background:var(--orange);color:#fff}
  /* solid once scrolled past the hero */
  .home-hero header.past-hero{background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(4,67,134,.07)}
  .home-hero header.past-hero .logo-full{display:block}
  .home-hero header.past-hero .logo-mark{display:none}
  .home-hero header.past-hero .nav-links > a,
  .home-hero header.past-hero .dd-btn{color:var(--muted)}
  .home-hero header.past-hero .nav-links > a:hover,
  .home-hero header.past-hero .dd-btn:hover,
  .home-hero header.past-hero .nav-links > a.active{color:var(--navy)}
  .home-hero header.past-hero .btn{background:var(--navy);color:#fff}
  .home-hero header.past-hero .btn:hover{background:var(--orange)}

  .home-hero .hero{min-height:100vh;min-height:100svh;margin-top:-113px}
  .home-hero .hero .label{color:rgba(255,255,255,.72)}
  .home-hero .hero h1,.home-hero .hero .hero-headline{color:#fff}
  .home-hero .hero p{color:rgba(255,255,255,.85)}
  .home-hero .hero .btn{background:#fff;color:var(--navy)}
  .home-hero .hero .btn:hover{background:var(--orange);color:#fff}
  .home-hero .hero .btn-outline{border-color:rgba(255,255,255,.55);color:#fff}
  .home-hero .hero .btn-outline:hover{background:#fff;color:var(--navy);border-color:#fff}
  .home-hero .hero-dot{background:rgba(255,255,255,.4)}
  .home-hero .hero-dot:hover{background:rgba(255,255,255,.7)}
  .home-hero .hero-dot.is-active{background:#fff}
}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:100;font-size:.85rem;font-weight:600}
.skip-link:focus{left:0;top:0}
