/* ═══════════════════════════════════════════════════════════
   custom.css — Global styles for all front-end pages
   ═══════════════════════════════════════════════════════════ */

/* ── TOKENS ──────────────────────────────────────────────── */
:root{
  --bg:#fff;--bg2:#f7f8fc;--bg3:#eef1fa;
  --border:#e2e5ef;--border2:#c8cde0;
  --text:#0d0f1a;--text2:#4a5068;--text3:#8c93af;
  --blue:#1a56db;--blue-h:#1447c0;--blue-lt:#eff4ff;--blue-lt2:#dce8ff;
  --green:#059669;--green-lt:#ecfdf5;
  --amber:#d97706;
  --ff-disp:'Bebas Neue','Arial Black',sans-serif;
  --ff-serif:'Instrument Serif',Georgia,serif;
  --ff-body:'Instrument Sans',system-ui,sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
}

/* ── LUCIDE ICONS (frontend) ─────────────────────────────── */
[data-lucide]{display:inline-flex;flex-shrink:0;}
.mob-sub a i[data-lucide],.mob-sub a svg{width:14px;height:14px;vertical-align:middle;margin-right:5px;stroke-width:1.75;}
.foot-ul a i[data-lucide],.foot-ul a svg{width:12px;height:12px;vertical-align:middle;margin-right:4px;stroke-width:1.75;}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--ff-body);background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.6;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;object-fit:cover;}
button{border:none;background:none;font-family:inherit;cursor:pointer;}
::selection{background:var(--blue-lt2);color:var(--blue);}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:var(--bg2);}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:2px;}

/* ── LAYOUT ──────────────────────────────────────────────── */
.wrap{max-width:1280px;margin:0 auto;padding:0 40px;}

/* ── TYPOGRAPHY ──────────────────────────────────────────── */
.t-disp{font-family:var(--ff-disp);line-height:.92;letter-spacing:.01em;color:var(--text);}
.t-body{font-size:15px;line-height:1.75;color:var(--text2);}
.t-small{font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--text3);}
.grad-blue{background:linear-gradient(135deg,var(--blue) 0%,#5b8def 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.lbl{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);padding:5px 14px;border:1px solid var(--blue-lt2);border-radius:100px;background:var(--blue-lt);}
.lbl-dot{width:5px;height:5px;border-radius:50%;background:var(--green);animation:blink 2s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.3;}}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;border-radius:6px;font-family:var(--ff-body);font-size:14px;font-weight:600;cursor:pointer;transition:all .25s var(--ease);white-space:nowrap;}
.btn-p{background:var(--blue);color:#fff;box-shadow:0 1px 3px rgba(26,86,219,.2);}
.btn-p:hover{background:var(--blue-h);transform:translateY(-1px);box-shadow:0 6px 20px rgba(26,86,219,.28);}
.btn-s{background:var(--bg);color:var(--text);border:1.5px solid var(--border2);}
.btn-s:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px);}
.btn-ar{width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.22);display:inline-flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;transition:transform .25s var(--ease);}
.btn-p:hover .btn-ar{transform:rotate(-45deg);}
.btn-s .btn-ar{background:var(--bg2);}
.btn-s:hover .btn-ar{background:var(--blue-lt);transform:rotate(-45deg);}

/* ── REVEAL ANIMATIONS ───────────────────────────────────── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .65s var(--ease),transform .65s var(--ease);will-change:opacity,transform;}
.rv.on{opacity:1;transform:none;}
.rv-l{opacity:0;transform:translateX(-28px);transition:opacity .65s var(--ease),transform .65s var(--ease);will-change:opacity,transform;}
.rv-l.on{opacity:1;transform:none;}
.rv-r{opacity:0;transform:translateX(28px);transition:opacity .65s var(--ease),transform .65s var(--ease);will-change:opacity,transform;}
.rv-r.on{opacity:1;transform:none;}

/* ── NAVBAR ──────────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(255,255,255,.93);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:box-shadow .25s;transform:translateZ(0);}
#nav.elevated{box-shadow:0 2px 16px rgba(0,0,0,.06);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:0 40px;height:64px;}
.nav-logo{display:flex;align-items:center;gap:9px;font-family:var(--ff-disp);font-size:20px;letter-spacing:.06em;color:var(--text);flex-shrink:0;}
.logo-mark{width:32px;height:32px;border-radius:7px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-size:17px;color:#fff;flex-shrink:0;}

/* Nav links */
.nav-links{display:flex;align-items:stretch;list-style:none;height:64px;}
.nav-links>li{position:relative;display:flex;align-items:center;}
.nav-links>li>a{display:flex;align-items:center;gap:5px;padding:0 15px;height:100%;font-size:13.5px;font-weight:500;color:var(--text2);transition:color .15s;white-space:nowrap;border-bottom:2px solid transparent;}
.nav-links>li>a:hover{color:var(--text);}
.nav-links>li:hover>a{color:var(--blue);border-bottom-color:var(--blue);}
.nav-links>li>a svg{width:11px;height:11px;flex-shrink:0;transition:transform .2s ease;margin-top:1px;}
.nav-links>li:hover>a svg{transform:rotate(180deg);}

/* Dropdown shell */
.nav-drop,.nav-mega{position:absolute;top:calc(100% + 2px);background:#fff;border:1px solid #e8eaf4;border-radius:16px;box-shadow:0 8px 24px rgba(13,15,26,.08),0 32px 64px rgba(13,15,26,.06);opacity:0;visibility:hidden;transform:translateY(-8px) scale(.98);transition:opacity .2s ease,visibility .2s ease,transform .2s var(--ease);pointer-events:none;overflow:hidden;}
.nav-drop::before,.nav-mega::before{content:'';position:absolute;top:-20px;left:-20px;right:-20px;height:20px;background:transparent;}
.nav-links>li:hover .nav-drop,.nav-links>li:hover .nav-mega,.nav-links>li.dd-open .nav-drop,.nav-links>li.dd-open .nav-mega{opacity:1;visibility:visible;transform:translateY(0) scale(1);pointer-events:auto;}

/* Simple dropdown */
.nav-drop{left:50%;transform:translateX(-50%) translateY(-8px) scale(.98);min-width:256px;padding:8px;}
.nav-links>li:hover .nav-drop,.nav-links>li.dd-open .nav-drop{transform:translateX(-50%) translateY(0) scale(1);}
.drop-head{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);padding:8px 12px 6px;margin-bottom:2px;border-bottom:1px solid var(--bg3);}
.drop-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;font-size:13.5px;color:var(--text2);font-weight:500;transition:background .12s,color .12s;position:relative;}
.drop-item:hover{background:var(--blue-lt);color:var(--blue);}
.drop-item:hover .drop-arr{opacity:1;transform:translateX(0);}
.drop-txt{flex:1;}
.drop-txt b{display:block;font-size:13px;font-weight:600;line-height:1.2;}
.drop-txt small{font-size:11px;color:var(--text3);font-weight:400;}
.drop-arr{font-size:12px;color:var(--blue);opacity:0;transform:translateX(-6px);transition:opacity .15s,transform .15s;flex-shrink:0;}
.drop-footer{margin-top:4px;padding:10px 12px 4px;border-top:1px solid var(--bg3);display:flex;align-items:center;justify-content:space-between;}
.drop-footer span{font-size:11.5px;color:var(--text3);}
.drop-footer a{font-size:12px;font-weight:700;color:var(--blue);letter-spacing:.02em;}
.drop-footer a:hover{text-decoration:underline;}

/* Mega dropdown */
.nav-mega{left:50%;transform:translateX(-50%) translateY(-8px) scale(.98);width:580px;}
.nav-links>li:hover .nav-mega,.nav-links>li.dd-open .nav-mega{transform:translateX(-50%) translateY(0) scale(1);}
.mega-wrap{display:grid;grid-template-columns:180px 1fr;}
.mega-sidebar{background:linear-gradient(160deg,var(--blue-lt) 0%,#e8f0ff 100%);padding:20px 16px;display:flex;flex-direction:column;justify-content:space-between;}
.mega-sidebar-title{font-family:var(--ff-disp);font-size:22px;letter-spacing:.04em;color:var(--text);line-height:1.1;margin-bottom:6px;}
.mega-sidebar-sub{font-size:12px;color:var(--text2);line-height:1.5;margin-bottom:20px;}
.mega-sidebar-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--blue);padding:8px 12px;background:#fff;border-radius:8px;border:1px solid var(--blue-lt2);transition:all .15s;}
.mega-sidebar-link:hover{background:var(--blue);color:#fff;border-color:var(--blue);}
.mega-grid{padding:16px;display:grid;grid-template-columns:1fr 1fr;gap:3px;align-content:start;}
.mega-item{display:flex;align-items:flex-start;gap:10px;padding:10px;border-radius:10px;transition:background .12s;cursor:pointer;}
.mega-item:hover{background:var(--blue-lt);}
.mega-item:hover .mega-text strong{color:var(--blue);}
.mega-text strong{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;transition:color .12s;}
.mega-text span{font-size:11px;color:var(--text3);line-height:1.35;}

/* Nav right & hamburger */
.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.ham{display:none;flex-direction:column;gap:5px;width:38px;height:38px;align-items:center;justify-content:center;border:1.5px solid var(--border2);border-radius:7px;cursor:pointer;transition:border-color .2s;}
.ham:hover{border-color:var(--blue);}
.ham span{display:block;width:16px;height:1.5px;background:var(--text);border-radius:1px;transition:all .25s;}
.ham.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.ham.open span:nth-child(2){opacity:0;}
.ham.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* Mobile nav overlay */
#mob{position:fixed;inset:0;z-index:800;background:#fff;padding:80px 24px 40px;overflow-y:auto;opacity:0;visibility:hidden;transition:opacity .28s,visibility .28s;}
#mob.open{opacity:1;visibility:visible;}
.mob-ul{list-style:none;display:flex;flex-direction:column;}
.mob-ul>li{border-bottom:1px solid var(--border);}
.mob-ul>li>a{display:flex;align-items:center;justify-content:space-between;padding:18px 0;font-family:var(--ff-disp);font-size:30px;letter-spacing:.04em;color:var(--text2);transition:color .15s;}
.mob-ul>li>a:hover{color:var(--blue);}
.mob-sub{padding:8px 0 12px;display:none;flex-direction:column;gap:2px;}
.mob-sub a{padding:9px 12px;font-size:14px;color:var(--text2);border-radius:8px;transition:background .12s,color .12s;}
.mob-sub a:hover{background:var(--bg2);color:var(--blue);}
.mob-cta{display:flex;flex-direction:column;gap:10px;margin-top:28px;}

/* Scroll-to-top */
#stt{position:fixed;bottom:28px;right:28px;z-index:500;width:40px;height:40px;border-radius:10px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;opacity:0;transform:translateY(12px);transition:all .3s var(--ease);box-shadow:0 4px 14px rgba(26,86,219,.28);}
#stt.on{opacity:1;transform:translateY(0);}
#stt:hover{background:var(--blue-h);transform:translateY(-3px);}

/* ── FOOTER ──────────────────────────────────────────────── */
footer{background:#0d0f1a;color:#8c93af;padding:80px 0 36px;}
.foot-grid{display:grid;grid-template-columns:280px 1fr 1fr 1fr;gap:56px;margin-bottom:56px;}
.foot-logo{display:flex;align-items:center;gap:9px;font-family:var(--ff-disp);font-size:20px;letter-spacing:.06em;color:#fff;margin-bottom:16px;}
.foot-lm{width:32px;height:32px;border-radius:7px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-size:17px;color:#fff;}
.foot-desc{font-size:14px;line-height:1.7;color:#8c93af;margin-bottom:20px;}
.foot-offices{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;}
.foot-office{display:flex;align-items:flex-start;gap:8px;}
.fo-ic{font-size:14px;margin-top:1px;flex-shrink:0;}
.fo-text{font-size:12px;line-height:1.5;}
.fo-city{font-weight:700;color:#eef0f5;display:block;}
.fo-addr{color:#8c93af;}
.foot-trust{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;}
.trust-b{display:flex;align-items:center;gap:5px;padding:5px 10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:100px;font-size:11px;color:#8c93af;font-weight:600;}
.foot-social{display:flex;gap:8px;}
.fs-b{width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;color:#8c93af;font-size:14px;transition:all .2s;}
.fs-b:hover{background:var(--blue);border-color:var(--blue);color:#fff;}
footer h4{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#8c93af;margin-bottom:16px;}
.foot-ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.foot-ul a{font-size:14px;color:#8c93af;transition:color .15s;}
.foot-ul a:hover{color:#fff;}
.foot-nl{display:flex;gap:6px;margin-top:14px;}
.foot-nl input{flex:1;padding:10px 12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:13px;outline:none;font-family:var(--ff-body);}
.foot-nl input::placeholder{color:#8c93af;}
.foot-nl input:focus{border-color:var(--blue);}
.foot-nl button{padding:10px 14px;background:var(--blue);color:#fff;border-radius:6px;font-size:13px;font-weight:600;}
.foot-nl button:hover{background:var(--blue-h);}
.foot-bot{display:flex;align-items:center;justify-content:space-between;padding-top:28px;border-top:1px solid rgba(255,255,255,.07);gap:16px;flex-wrap:wrap;}
.foot-bot p{font-size:13px;color:#8c93af;}
.foot-bl{display:flex;gap:20px;}
.foot-bl a{font-size:13px;color:#8c93af;transition:color .15s;}
.foot-bl a:hover{color:#fff;}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — mobile-first overrides
   Breakpoints: 1024 (tablet), 768 (small tablet), 540 (mobile)
   ════════════════════════════════════════════════════════════ */

/* Hide desktop nav, show hamburger at tablet */
@media(max-width:1024px){
  .nav-links{display:none;}
  .ham{display:flex;}
}

/* Wrap & nav padding */
@media(max-width:768px){
  .wrap{padding:0 20px;}
  .nav-inner{padding:0 20px;}

  /* Reduce hero button size */
  .btn{padding:11px 20px;font-size:13px;}

  /* Footer: 2 column on tablet */
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px;}
  footer{padding:56px 0 28px;}
  .foot-grid{margin-bottom:36px;}
}

/* Footer: 1 column on small mobile */
@media(max-width:540px){
  .foot-grid{grid-template-columns:1fr;gap:28px;}
  .foot-bot{flex-direction:column;align-items:flex-start;gap:12px;}

  /* Smaller scroll-to-top on mobile */
  #stt{bottom:16px;right:16px;width:36px;height:36px;font-size:15px;}
}

/* ── PAGE SECTION PADDING: reduce on mobile ────────────────
   These classes appear in page-specific blade CSS.
   Overrides here cascade after @stack('styles').          */
@media(max-width:768px){
  /* Common section padding pattern */
  .stats-sec,
  .svc-sec,.proc-sec,.testi-sec,.blog-sec,.faq-sec,
  .tech-sec,.offices-sec,
  .svc-index-sec,.mkt-sec,.opt-sec,
  .work-sec,.about-sec,.team-sec,.values-sec,.careers-sec{
    padding-top:60px !important;
    padding-bottom:60px !important;
  }
  .cta-sec{ padding:64px 0 !important; }

  /* Section headers */
  .sec-hdr{ margin-bottom:36px !important; }
  .sec-split{ flex-direction:column; gap:16px !important; }
  .sec-aside{ max-width:100%; }

  /* Hero */
  .hero-inner{padding:0 20px;}
  .scroll-hint{display:none;}
  .hero-strip{margin-top:32px; padding-top:20px;}

  /* Process layout */
  .proc-layout{grid-template-columns:1fr !important; gap:40px !important;}
  .proc-img{height:280px !important;}

  /* Testimonials */
  .testi-layout{grid-template-columns:1fr !important; gap:28px !important;}
  .t-dots{flex-direction:row; flex-wrap:wrap; gap:8px; margin-top:16px;}
  .td{border-bottom:none; padding:6px 0;}
  .slide-btns{margin-top:12px;}

  /* FAQ */
  .faq-layout{grid-template-columns:1fr !important; gap:32px !important;}
  .faq-img{display:none;}

  /* Blog grid */
  .blog-grid{grid-template-columns:1fr 1fr !important;}

  /* Offices grid */
  .offices-grid{grid-template-columns:1fr 1fr !important;}

  /* CTA section */
  .cta-btns{flex-direction:column; align-items:stretch;}
  .cta-btns .btn{justify-content:center;}

  /* Portfolio / project grid */
  .port-grid{display:flex !important; flex-direction:column !important;}

  /* Morph section — disable sticky on mobile */
  #morph{height:auto !important; }
  .morph-stick{position:relative !important; height:auto !important;}
  .morph-panels{min-height:auto !important;}

  /* Inner page hero spacing */
  .page-hero,.inner-hero{padding:60px 0 48px !important;}

  /* Detail page grid */
  .detail-grid,.detail-layout{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }

  /* About */
  .about-grid{gap:32px !important; padding:48px 0 !important;}

  /* Work page filter */
  .work-filters{flex-wrap:wrap; gap:8px;}
}

/* Smallest mobile */
@media(max-width:540px){
  .blog-grid{grid-template-columns:1fr !important;}
  .offices-grid{grid-template-columns:1fr !important;}
  .hero-ctas{flex-direction:column; align-items:stretch; width:100%;}
  .hero-ctas .btn{justify-content:center;}

  /* Compact hero strip numbers */
  .h-stat{flex:1 1 40%; padding:0 12px 12px 0; margin:0;}
  .h-stat:nth-child(even){border-right:none;}

  /* Mobile nav font size */
  .mob-ul>li>a{font-size:24px; padding:14px 0;}

  /* Make cards full-width in contact page */
  .ci-offices,.ci-contact-items{gap:10px;}
}
