/* Consaltex theme — main stylesheet */

:root{
  --c-teal: #1E40AF;          /* overridden by inline <style> from functions.php */
  --c-teal-deep: #1E3A8A;
  --c-teal-soft: #E7EBFA;
  --c-orange: #F97316;
  --c-ink: #0F1B23;
  --c-graphite: #2B3741;
  --c-gray: #7A8995;
  --c-gray-soft: #B9C2C9;
  --c-line: #E5E9EC;
  --c-paper: #FAF9F6;
  --c-canvas: #FFFFFF;
}

*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100% }
body{
  margin:0;background:#fff;color:var(--c-ink);
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;font-size:16px;line-height:1.55;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
button{font:inherit}

.screen-reader-text{
  position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  position:fixed;left:1rem;top:1rem;background:#fff;padding:8px 12px;border-radius:8px;
  width:auto;height:auto;z-index:9999;box-shadow:0 6px 18px rgba(0,0,0,.15);
}

.cx-wrap{max-width:1320px;margin:0 auto;padding:0 32px}
.cx-section{padding:88px 0}
.cx-center{text-align:center}
.cx-row{display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap}

/* Logo wordmark ---------------------------------------------------- */
.cx-logo{
  display:inline-flex;align-items:baseline;gap:0;
  font-weight:700;letter-spacing:-0.02em;line-height:1;
  font-size:28px;
}
.cx-logo .cx-a{color:var(--c-teal)}
.cx-logo .cx-b{color:var(--c-orange);position:relative;display:inline-block;padding:0 1px}
.cx-logo .cx-b::before{
  content:"";position:absolute;left:50%;top:-0.18em;
  width:0.18em;height:0.18em;border-radius:50%;
  background:var(--c-orange);transform:translateX(-50%);
}
.cx-logo .cx-c{color:var(--c-gray)}

/* Buttons ---------------------------------------------------------- */
.cx-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 20px;border-radius:10px;border:1px solid transparent;
  font-weight:600;font-size:14.5px;line-height:1;cursor:pointer;
  transition:transform .12s ease, box-shadow .15s ease, background .15s ease;
}
.cx-btn:hover{text-decoration:none}
.cx-btn-accent{background:var(--c-orange);color:#fff;border-color:var(--c-orange)}
.cx-btn-accent:hover{filter:brightness(.95)}
.cx-btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.25)}
.cx-btn-ghost:hover{background:rgba(255,255,255,.08)}
.cx-btn-light{background:#fff;color:var(--c-ink);border-color:var(--c-line);font-size:12.5px;letter-spacing:.04em;padding:10px 18px}
.cx-btn-light:hover{background:var(--c-paper)}
.cx-btn-lg{padding:16px 28px;font-size:14px;letter-spacing:.06em;font-weight:700}

.cx-icon{display:inline-block;flex:none}

/* Utility bar ------------------------------------------------------ */
.cx-utility{background:var(--c-ink);color:rgba(255,255,255,.7);font-size:12.5px}
.cx-utility-inner{display:flex;justify-content:space-between;align-items:center;padding:8px 32px}
.cx-utility-inner div{display:flex;gap:22px}
.cx-utility a{color:#fff}

/* Header ----------------------------------------------------------- */
.cx-header{background:#fff;border-bottom:1px solid var(--c-line);position:sticky;top:0;z-index:50}
.cx-header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;gap:24px}
.cx-nav{position:relative}
.cx-nav-list{list-style:none;padding:0;margin:0;display:flex;gap:32px;font-size:14.5px;font-weight:500;color:var(--c-graphite)}
.cx-nav-list > li{position:relative}
.cx-nav-list a{color:inherit;display:inline-block;padding:8px 0}
.cx-nav-list a:hover{color:var(--c-teal-deep);text-decoration:none}
.cx-nav-list .menu-item-has-children > a::after{content:"";display:inline-block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:translateY(-2px) rotate(45deg);margin-left:8px;opacity:.6}
.cx-nav-list .sub-menu{position:absolute;top:100%;left:-16px;min-width:240px;list-style:none;margin:0;padding:8px 0;background:#fff;border:1px solid var(--c-line);border-radius:10px;box-shadow:0 18px 40px -18px rgba(15,30,52,.25);opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .15s ease,transform .15s ease,visibility .15s;z-index:60;display:flex;flex-direction:column;gap:0}
.cx-nav-list > li:hover > .sub-menu,
.cx-nav-list > li:focus-within > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.cx-nav-list .sub-menu li{display:block}
.cx-nav-list .sub-menu a{display:block;padding:10px 18px;font-size:14px;font-weight:500;color:var(--c-graphite);white-space:nowrap;border-radius:0}
.cx-nav-list .sub-menu a:hover{background:var(--c-bg-soft);color:var(--c-teal-deep)}
.cx-header-cta{padding:10px 18px;border-radius:999px;font-size:14px}

/* Hero ------------------------------------------------------------- */
.cx-hero{padding:48px 0 56px}
.cx-hero-card{
  position:relative;border-radius:16px;overflow:hidden;
  min-height:480px;color:#fff;
  background:linear-gradient(135deg,#0F1B23 0%, color-mix(in srgb, var(--c-teal-deep) 60%, #0F1B23) 60%, var(--c-teal) 100%);
}
.cx-hero-bg{position:absolute;inset:0;width:100%;height:100%;opacity:.35}
.cx-hero-inner{position:relative;padding:72px 64px;max-width:780px}
.cx-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;
  background:rgba(255,255,255,.12);color:#E5F2F5;font-size:12.5px;font-weight:600;letter-spacing:.04em;
  border:1px solid rgba(255,255,255,.18);margin-bottom:28px;
}
.cx-pill-dot{width:6px;height:6px;border-radius:99px;background:#5BC4D6}
.cx-h1{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:600;
  font-size:clamp(40px,5.5vw,76px);line-height:1.02;letter-spacing:-0.025em;
  margin:0 0 20px;color:#fff;
}
.cx-hero-desc{font-size:19px;color:rgba(255,255,255,.85);max-width:600px;margin:0 0 28px}
.cx-hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.cx-hero-slide{display:none}
.cx-hero-slide.is-active{display:block;animation:cx-fade .35s ease}
@keyframes cx-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.cx-hero-dots{position:absolute;left:64px;bottom:32px;display:flex;gap:8px}
.cx-dot{width:10px;height:4px;border-radius:99px;background:rgba(255,255,255,.4);border:0;padding:0;cursor:pointer;transition:width .25s,background .15s}
.cx-dot.is-active{width:36px;background:#fff}
.cx-hero-counter{position:absolute;right:64px;bottom:28px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:rgba(255,255,255,.7);letter-spacing:.08em}

/* Section heads ---------------------------------------------------- */
.cx-section-head{margin-bottom:40px}
.cx-section-head.cx-center{margin-bottom:48px}
.cx-eyebrow{
  font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--c-teal-deep);margin-bottom:10px;display:inline-block;
}
.cx-eyebrow-orange{color:var(--c-orange)}
.cx-h2{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:600;
  font-size:clamp(30px,3.4vw,44px);letter-spacing:-0.02em;line-height:1.1;margin:0;
}
.cx-h2-light{color:#fff}
.cx-section-sub{margin:8px 0 0;color:rgba(255,255,255,.7);font-size:16px}
.cx-link{font-size:14px;color:var(--c-gray)}
.cx-link-light{color:rgba(255,255,255,.7)}

/* Process ---------------------------------------------------------- */
.cx-process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.cx-process-rail{position:absolute;top:24px;left:12.5%;right:12.5%;height:1px;background:var(--c-line)}
.cx-step{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center}
.cx-step-num{
  width:48px;height:48px;border-radius:99px;background:#fff;
  border:1px solid var(--c-line);color:var(--c-teal);
  font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:13px;
  display:grid;place-items:center;margin-bottom:20px;
  box-shadow:0 1px 0 rgba(15,27,35,.04);
}
.cx-step-title{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700;letter-spacing:.02em;margin-bottom:10px}
.cx-step-desc{font-size:14px;color:var(--c-graphite);max-width:240px;margin:0 0 18px}

/* Services --------------------------------------------------------- */
.cx-services{background:var(--c-paper)}
.cx-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cx-card{
  background:#fff;border:1px solid var(--c-line);border-radius:14px;
  padding:28px;display:flex;flex-direction:column;gap:14px;min-height:220px;
  transition:transform .15s ease, box-shadow .2s ease, border-color .15s ease;
  color:var(--c-ink);
}
.cx-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(15,27,35,.08);border-color:var(--c-gray-soft);text-decoration:none}
.cx-card-row{display:flex;justify-content:space-between;align-items:center}
.cx-icon-tile{
  width:44px;height:44px;border-radius:10px;
  background:var(--c-teal-soft);color:var(--c-teal-deep);
  display:grid;place-items:center;
}
.cx-tag{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--c-gray);letter-spacing:.08em}
.cx-card-title{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:600;letter-spacing:-0.01em}
.cx-card-desc{font-size:14.5px;color:var(--c-graphite);margin:0;line-height:1.5}
.cx-card-more{margin-top:auto;font-size:13.5px;color:var(--c-teal-deep);font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* Portfolio -------------------------------------------------------- */
.cx-portfolio{background:var(--c-ink);color:#fff}
.cx-portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cx-project{display:flex;flex-direction:column;gap:14px;color:#fff}
.cx-project:hover{text-decoration:none}
.cx-project-img{
  position:relative;aspect-ratio:4/3;border-radius:6px;overflow:hidden;
  background:repeating-linear-gradient(135deg,#1a262e 0 14px,#131e25 14px 28px);
  border:1px solid #243038;
}
.cx-project-img::after{
  content:attr(data-label);
  position:absolute;inset:auto auto 12px 12px;
  font:500 11px/1 'IBM Plex Mono',monospace;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  background:rgba(15,27,35,.55);padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(4px);
}
.cx-project-name{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:600}
.cx-project-tag{font-size:13.5px;color:rgba(255,255,255,.65);margin:0;line-height:1.5}

/* CTA band --------------------------------------------------------- */
.cx-cta-card{
  background:var(--c-teal-soft);border-radius:20px;
  padding:44px 48px;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;
}
.cx-cta-card .cx-h2{color:var(--c-teal-deep)}

/* Footer ----------------------------------------------------------- */
.cx-footer{background:#3A3A3A;color:rgba(255,255,255,.78);font-size:14px;padding:56px 0 24px}
.cx-footer-grid{display:grid;grid-template-columns:1fr 1.3fr 1fr 1.3fr;gap:40px;margin-bottom:40px}
.cx-footer-h{color:var(--c-orange);font-weight:700;margin-bottom:16px;font-size:13px;letter-spacing:.06em}
.cx-footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.cx-footer-col a{color:rgba(255,255,255,.78)}
.cx-footer-contact strong{color:#fff}
.cx-footer-contact p{margin:0 0 14px;line-height:1.6}
.cx-footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);padding:20px 32px 0;
  display:flex;justify-content:space-between;color:rgba(255,255,255,.55);font-size:12.5px;
  flex-wrap:wrap;gap:12px;
}

/* Generic prose pages --------------------------------------------- */
.cx-prose{max-width:780px}
.cx-rt{font-size:17px;line-height:1.7;color:var(--c-graphite)}
.cx-rt h2,.cx-rt h3{font-family:'Bricolage Grotesque',sans-serif;color:var(--c-ink);margin-top:1.6em}

/* Mobile navigation ------------------------------------------------ */
.cx-burger{display:none;position:relative;width:44px;height:44px;border:1px solid var(--c-line);border-radius:10px;background:#fff;padding:0;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;z-index:70}
.cx-burger span{display:block;width:18px;height:2px;background:var(--c-ink);border-radius:2px;transition:transform .2s ease,opacity .2s ease}
.cx-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.cx-burger.is-open span:nth-child(2){opacity:0}
.cx-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.cx-mobile-drawer{position:fixed;inset:0;background:#fff;z-index:65;overflow-y:auto;padding:88px 24px 32px;opacity:0;transition:opacity .2s ease;display:none}
.cx-mobile-drawer.is-open{opacity:1}
.cx-mobile-nav{display:flex;flex-direction:column;gap:8px;max-width:520px;margin:0 auto}
.cx-mobile-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.cx-mobile-list > li{position:relative;border-bottom:1px solid var(--c-line)}
.cx-mobile-list > li > a{display:block;padding:18px 4px;font-size:18px;font-weight:600;color:var(--c-ink);font-family:'Bricolage Grotesque',sans-serif}
.cx-mobile-list .sub-menu{list-style:none;margin:0;padding:0 0 12px 12px;display:none}
.cx-mobile-list .sub-menu a{display:block;padding:10px 4px;font-size:15px;color:var(--c-graphite)}
.cx-mobile-list .menu-item-has-children.is-open > .sub-menu{display:block}
.cx-mobile-sub-toggle{position:absolute;top:8px;right:0;width:44px;height:44px;background:transparent;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center}
.cx-mobile-sub-toggle span{display:block;width:8px;height:8px;border-right:2px solid var(--c-graphite);border-bottom:2px solid var(--c-graphite);transform:translateY(-2px) rotate(45deg);transition:transform .2s ease}
.menu-item-has-children.is-open > .cx-mobile-sub-toggle span{transform:translateY(2px) rotate(-135deg)}
.cx-mobile-cta{margin-top:16px;text-align:center;justify-content:center}
.cx-mobile-contact{display:flex;flex-direction:column;gap:6px;margin-top:24px;padding-top:24px;border-top:1px solid var(--c-line);font-size:15px;color:var(--c-graphite)}
.cx-mobile-contact a{color:var(--c-teal-deep);font-weight:500}
body.cx-no-scroll{overflow:hidden}

/* Responsive ------------------------------------------------------- */
@media (max-width: 960px){
  .cx-services-grid{grid-template-columns:repeat(2,1fr)}
  .cx-portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .cx-process-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .cx-process-rail{display:none}
  .cx-footer-grid{grid-template-columns:1fr 1fr}
  .cx-hero-inner{padding:56px 32px}
  .cx-hero-dots{left:32px}
  .cx-hero-counter{right:32px}
  .cx-row{align-items:start}
}
@media (max-width: 860px){
  .cx-header-inner{padding:14px 20px;gap:12px}
  .cx-nav{display:none}
  .cx-header-cta{display:none}
  .cx-burger{display:flex}
  .cx-mobile-drawer{display:block}
}
@media (max-width: 640px){
  .cx-section{padding:56px 0}
  .cx-wrap{padding:0 20px}
  .cx-utility-inner{flex-direction:column;gap:4px;align-items:flex-start;font-size:12.5px}
  .cx-utility-inner div:last-child{display:none}
  .cx-services-grid,.cx-portfolio-grid,.cx-process-grid{grid-template-columns:1fr}
  .cx-footer-grid{grid-template-columns:1fr}
  .cx-cta-card{padding:32px 24px;flex-direction:column;align-items:flex-start}
  .cx-hero-inner{padding:48px 20px;min-height:480px}
  .cx-h1{font-size:clamp(34px,9vw,52px)}
  .cx-h2{font-size:clamp(28px,7vw,40px)}
  .cx-hero-dots{left:20px;bottom:20px}
  .cx-hero-counter{right:20px;bottom:20px}
  .cx-row{flex-direction:column;align-items:flex-start;gap:24px}
}
