/* =============================================================
   COONNATE STUDIO — MASTER STYLESHEET v2.0
   ============================================================= */

/* ── Variables ── */
:root {
  --blue:        #2563EB;
  --blue-light:  #3B82F6;
  --blue-dark:   #1D4ED8;
  --dark:        #0A0F1E;
  --dark-card:   #111827;
  --white:       #FFFFFF;
  --off-white:   #F8FAFC;
  --gray-100:    #F1F5F9;
  --gray-200:    #E2E8F0;
  --gray-400:    #94A3B8;
  --gray-600:    #475569;
  --gray-800:    #1E293B;
  --text-dark:   #0F172A;
  --text-muted:  #64748B;
  --radius-sm:   8px;
  --radius-md:   16px;
  --radius-lg:   24px;
  --radius-xl:   32px;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.08);
  --shadow-md:   0 4px 20px rgba(0,0,0,.10);
  --shadow-lg:   0 10px 40px rgba(0,0,0,.15);
  --shadow-blue: 0 8px 32px rgba(37,99,235,.28);
  --font-head:   'Space Grotesk', sans-serif;
  --font-body:   'Inter', sans-serif;
  --ease:        cubic-bezier(.4,0,.2,1);
  --t:           all .3s var(--ease);
  --tf:          all .18s var(--ease);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text-dark);background:var(--white);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:var(--font-body)}

/* ── Typography ── */
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:700;line-height:1.1;color:var(--text-dark)}
.eyebrow{display:flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:16px}
.eyebrow::before{content:'';display:block;width:32px;height:2px;background:var(--blue);border-radius:2px;flex-shrink:0}

/* ── Layout ── */
.container{max-width:1280px;margin:0 auto;padding:0 48px}
section{padding:96px 0}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:50px;font-family:var(--font-body);font-size:15px;font-weight:600;border:none;transition:var(--t);position:relative;overflow:hidden;cursor:pointer}
.btn-primary{background:var(--blue);color:#fff;box-shadow:var(--shadow-blue)}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 12px 40px rgba(37,99,235,.45)}
.btn-primary:active{transform:translateY(0)}
.btn-outline{background:transparent;color:var(--text-dark);border:1.5px solid var(--gray-200)}
.btn-outline:hover{border-color:var(--text-dark);background:var(--text-dark);color:#fff;transform:translateY(-2px)}
.btn-dark{background:var(--text-dark);color:#fff}
.btn-dark:hover{background:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-blue)}
.btn-white{background:#fff;color:var(--blue);font-weight:700}
.btn-white:hover{background:var(--off-white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.btn-nav{background:var(--text-dark);color:#fff;padding:11px 22px;font-size:14px;border-radius:50px}
.btn-nav:hover{background:var(--blue);transform:translateY(-1px);box-shadow:var(--shadow-blue)}

/* ── Header / Nav ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.06);transition:var(--t)}
.site-header.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-size:17px;font-weight:800;letter-spacing:-.02em;color:var(--text-dark);transition:var(--tf)}
.nav-logo:hover{color:var(--blue)}
.logo-icon{width:38px;height:38px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;transform:rotate(45deg);transition:var(--t);flex-shrink:0}
.logo-icon::after{content:'';width:14px;height:14px;border:2.5px solid #fff;border-radius:3px;transform:rotate(-45deg)}
.logo-icon:hover{transform:rotate(45deg) scale(1.05)}
.nav-menu{display:flex;align-items:center;gap:2px}
.nav-link{padding:8px 14px;font-size:14.5px;font-weight:500;color:var(--gray-600);border-radius:8px;transition:var(--tf);white-space:nowrap}
.nav-link:hover,.nav-link.active{color:var(--text-dark);background:var(--gray-100)}
.nav-link.active{color:var(--blue);background:transparent}
.nav-dropdown{position:relative}
.nav-dropdown>.nav-link::after{content:'';display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;margin-left:5px;vertical-align:middle;opacity:.5;transition:var(--tf)}
.nav-dropdown:hover>.nav-link::after{transform:rotate(180deg);opacity:1}

/* ── Services mega-dropdown ── */
.dropdown-menu{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  padding:20px 16px 16px;
  min-width:280px;
  box-shadow:0 20px 60px rgba(0,0,0,.12);
  opacity:0;
  visibility:hidden;
  transform:translateY(-10px);
  transition:var(--t);
  z-index:200;
}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}

/* "EXPLORE ALL SERVICES" header label */
.dropdown-header{
  font-size:11px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--blue);
  padding:0 12px 14px;
  border-bottom:1px solid var(--gray-100);
  margin-bottom:8px;
  display:block;
}

/* Each dropdown row */
.dropdown-menu a{
  display:flex;
  align-items:center;
  gap:12px;
  padding:11px 12px;
  font-size:14.5px;
  font-weight:500;
  color:var(--gray-800);
  border-radius:10px;
  transition:var(--tf);
}
.dropdown-menu a:hover{background:var(--gray-100);color:var(--blue)}
.dropdown-menu a:hover .dd-icon{background:var(--blue)}
.dropdown-menu a:hover .dd-icon svg{color:#fff}

/* Icon box inside dropdown row */
.dd-icon{
  width:34px;
  height:34px;
  background:var(--gray-100);
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:var(--tf);
}
.dd-icon svg{width:17px;height:17px;color:var(--blue);transition:var(--tf)}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--text-dark);border-radius:2px;transition:var(--t)}
.chat-bubble{position:fixed;bottom:32px;right:32px;width:52px;height:52px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:999;box-shadow:var(--shadow-blue);transition:var(--t)}
.chat-bubble:hover{transform:scale(1.1);box-shadow:0 12px 40px rgba(37,99,235,.5)}
.chat-bubble svg{width:22px;height:22px;color:#fff}

/* ── Animations ── */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ── HERO ── */
.hero{padding:152px 0 96px;background:linear-gradient(155deg,#EFF4FF 0%,#fff 55%,var(--gray-100) 100%);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-200px;right:-200px;width:700px;height:700px;background:radial-gradient(circle,rgba(37,99,235,.055) 0%,transparent 70%);pointer-events:none}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border:1px solid var(--gray-200);border-radius:50px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-600);margin-bottom:22px;box-shadow:var(--shadow-sm)}
.hero-badge-dot{width:8px;height:8px;background:var(--blue);border-radius:50%;animation:pulse-dot 2s infinite}
.hero-title{font-size:clamp(48px,5.5vw,76px);font-weight:800;line-height:1.0;letter-spacing:-.03em;margin-bottom:22px}
.hero-title .accent{color:var(--blue)}
.hero-desc{font-size:17px;color:var(--text-muted);line-height:1.7;max-width:500px;margin-bottom:36px}
.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-image-card{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3;background:linear-gradient(135deg,#0A0F1E 0%,#1a2744 50%,#0d1b3e 100%);position:relative}
.hero-image-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 60% 40%,rgba(37,99,235,.15) 0%,transparent 70%);z-index:1;pointer-events:none}
.hero-image-card img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:var(--t);display:block;position:absolute;inset:0;z-index:2}
.hero-image-card:hover img{filter:grayscale(0%)}
.hero-stat-card{position:absolute;bottom:-20px;left:-24px;background:#fff;border-radius:var(--radius-md);padding:20px 28px;box-shadow:var(--shadow-lg);animation:float 6s ease-in-out infinite}
.stat-num{font-family:var(--font-head);font-size:32px;font-weight:800;color:var(--blue);line-height:1}
.stat-lbl{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-top:4px}

/* ── Services Home Section ── */
.services-home{background:var(--gray-100)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc-card{background:#fff;border-radius:var(--radius-lg);padding:36px 32px;border:1px solid transparent;transition:var(--t);position:relative;overflow:hidden}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--blue);transform:scaleX(0);transition:var(--t)}
.svc-card:hover{border-color:var(--blue-light);transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{width:52px;height:52px;background:var(--gray-100);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:var(--t)}
.svc-card:hover .svc-icon{background:rgba(37,99,235,.1)}
.svc-icon svg{width:24px;height:24px;color:var(--blue)}
.svc-card h3{font-size:20px;font-weight:700;margin-bottom:10px}
.svc-card p{font-size:14.5px;color:var(--text-muted);line-height:1.65;margin-bottom:22px}
.svc-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--blue);transition:var(--tf)}
.svc-link:hover{gap:10px}

/* ── Why Us ── */
.why-us{background:#fff}
.why-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.why-content h2{font-size:clamp(32px,3.5vw,48px);letter-spacing:-.02em;margin-bottom:18px}
.why-content>p{font-size:16px;color:var(--text-muted);margin-bottom:36px;line-height:1.7}
.feature-list{display:flex;flex-direction:column;gap:26px}
.feature-item{display:flex;gap:16px;align-items:flex-start}
.feat-icon{width:44px;height:44px;background:rgba(37,99,235,.08);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--t)}
.feature-item:hover .feat-icon{background:var(--blue)}
.feature-item:hover .feat-icon svg{color:#fff}
.feat-icon svg{width:20px;height:20px;color:var(--blue);transition:var(--t)}
.feature-item h4{font-size:16px;font-weight:700;margin-bottom:3px}
.feature-item p{font-size:14px;color:var(--text-muted);line-height:1.6}
.why-image{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg)}
.why-image img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:var(--t)}
.why-image:hover img{filter:grayscale(0%)}

/* ── Portfolio Preview (Home) ── */
.portfolio-preview{background:#fff}
.portfolio-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px}
.portfolio-header h2{font-size:clamp(36px,4vw,52px);letter-spacing:-.02em}
.port-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.port-item{border-radius:var(--radius-xl);overflow:hidden;position:relative;cursor:pointer}
.port-item img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:grayscale(100%);transition:var(--t);display:block}
.port-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(37,99,235,.92) 0%,transparent 100%);padding:28px;transform:translateY(100%);transition:var(--t)}
.port-item:hover img{filter:grayscale(0%);transform:scale(1.03)}
.port-item:hover .port-overlay{transform:translateY(0)}
.port-overlay h3{color:#fff;font-size:20px;margin-bottom:4px}
.port-overlay p{color:rgba(255,255,255,.8);font-size:13px}
.port-cat{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:6px}

/* ── CTA Banner ── */
.cta-home{background:var(--blue);background-image:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 100%);position:relative;overflow:hidden;padding:0}
.cta-home::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:40px 40px}
.cta-card{background:#fff;border-radius:28px;padding:80px;text-align:center;margin:80px 0;position:relative;z-index:1;box-shadow:0 24px 80px rgba(0,0,0,.2)}
.cta-card h2{font-size:clamp(32px,4.5vw,58px);letter-spacing:-.03em;margin-bottom:14px}
.cta-card p{font-size:17px;color:var(--text-muted);margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto}

/* ── ABOUT PAGE ── */
.about-hero{padding:136px 0 72px;background:#fff}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.about-title{font-size:clamp(38px,5vw,66px);letter-spacing:-.03em;line-height:1.0;margin-bottom:28px}
.about-text{font-size:16px;color:var(--text-muted);line-height:1.8;margin-bottom:18px}
.about-stats{display:flex;gap:44px;margin-top:36px;padding-top:36px;border-top:1px solid var(--gray-200)}
.astat-num{font-family:var(--font-head);font-size:38px;font-weight:800;color:var(--blue);line-height:1;margin-bottom:4px}
.astat-lbl{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}
.about-visual{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.av-img{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}
.av-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:var(--t)}
.av-img:hover img{filter:grayscale(0%)}
.av-badge-blue{grid-column:2;grid-row:1;background:var(--blue);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;text-align:center;padding:28px;color:#fff;font-family:var(--font-head);font-size:20px;font-weight:700;line-height:1.3}
.av-badge-white{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;padding:24px;font-family:var(--font-head);font-size:17px;font-weight:700;color:var(--blue);box-shadow:var(--shadow-sm)}
.av-img2{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1}
.av-img2 img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:var(--t)}
.av-img2:hover img{filter:grayscale(0%)}
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.vm-card{border-radius:var(--radius-xl);padding:52px 44px;position:relative;overflow:hidden}
.vm-blue{background:var(--blue);color:#fff}
.vm-dark{background:var(--dark-card);color:#fff}
.vm-icon{width:54px;height:54px;background:rgba(255,255,255,.15);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.vm-icon svg{width:26px;height:26px;color:#fff}
.vm-card h3{font-size:34px;font-weight:800;color:#fff;margin-bottom:18px}
.vm-card p{font-size:16px;line-height:1.7;color:rgba(255,255,255,.8);margin-bottom:28px}
.vm-tag{font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.45);border-top:1px solid rgba(255,255,255,.18);padding-top:18px;display:block}
.values-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px 64px;margin-top:48px}
.val-item{display:flex;gap:18px;align-items:flex-start;padding:22px;border-radius:var(--radius-md);transition:var(--t)}
.val-item:hover{background:#fff;box-shadow:var(--shadow-md)}
.val-icon{width:46px;height:46px;background:rgba(37,99,235,.08);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--t)}
.val-item:hover .val-icon{background:var(--blue)}
.val-item:hover .val-icon svg{color:#fff}
.val-icon svg{width:22px;height:22px;color:var(--blue);transition:var(--t)}
.val-item h4{font-size:17px;font-weight:700;margin-bottom:6px}
.val-item p{font-size:14px;color:var(--text-muted);line-height:1.6}

/* ── SERVICES PAGE ── */
.services-page-hero{padding:136px 0 72px;background:#fff}
.services-page-hero h1{font-size:clamp(40px,5vw,68px);letter-spacing:-.03em;margin-bottom:18px}
.services-page-hero p{font-size:17px;color:var(--text-muted);max-width:580px;line-height:1.7}
.services-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc-full-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:36px 32px;transition:var(--t)}
.svc-full-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-full-card .svc-icon{background:var(--gray-100)}
.svc-full-card:hover .svc-icon{background:rgba(37,99,235,.1)}
.svc-full-card h3{font-size:20px;font-weight:700;margin-bottom:10px}
.svc-full-card>p{font-size:14.5px;color:var(--text-muted);line-height:1.65;margin-bottom:20px}
.svc-sub-list{margin-bottom:22px;display:flex;flex-direction:column;gap:6px}
.svc-sub-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--gray-600)}
.svc-sub-item::before{content:'›';color:var(--blue);font-size:16px;font-weight:700}
.svc-custom-card{background:var(--blue);border-radius:var(--radius-lg);padding:36px 32px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;text-align:center;align-items:center}
.svc-custom-card h3{font-size:26px;color:#fff;margin-bottom:14px}
.svc-custom-card p{color:rgba(255,255,255,.85);font-size:15px;line-height:1.6;margin-bottom:28px}

/* ── PORTFOLIO PAGE ── */
.portfolio-page-hero{padding:136px 0 72px;background:#fff;text-align:center}
.port-hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:#fff;border:1px solid var(--gray-200);border-radius:50px;font-size:13px;font-weight:600;color:var(--gray-600);margin-bottom:22px;box-shadow:var(--shadow-sm)}
.port-hero-badge span{width:8px;height:8px;background:var(--blue);border-radius:50%;display:inline-block}
.portfolio-page-hero h1{font-size:clamp(44px,6vw,76px);letter-spacing:-.03em;margin-bottom:18px}
.portfolio-page-hero h1 .accent{color:var(--blue)}
.portfolio-page-hero p{font-size:17px;color:var(--text-muted);max-width:580px;margin:0 auto;line-height:1.7}
.port-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;padding:72px 0}

/* ── Portfolio Card ── */
.port-card{
  background:#fff;
  border-radius:var(--radius-xl);
  overflow:hidden;
  border:1px solid var(--gray-200);
  transition:transform .32s var(--ease), box-shadow .32s var(--ease), border-color .32s var(--ease), background .32s var(--ease);
  cursor:pointer;
}

/* Hover state: card lifts, gets blue-tinted gradient background at bottom */
.port-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 56px rgba(37,99,235,.18);
  border-color:transparent;
  background:linear-gradient(to bottom, #fff 55%, #dbeafe 100%);
}

/* Image wrapper */
.port-card-img{
  position:relative;
  overflow:hidden;
  aspect-ratio:16/11;
}

.port-card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(100%);
  transition:filter .35s var(--ease), transform .35s var(--ease);
  display:block;
}

/* On hover: image gets blue overlay tint + slight scale */
.port-card:hover .port-card-img img{
  filter:grayscale(0%) brightness(.72) saturate(1.4);
  transform:scale(1.03);
}

/* Blue tint overlay that fades in */
.port-card-img::after{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(37,99,235,.38);
  opacity:0;
  transition:opacity .32s var(--ease);
  pointer-events:none;
  border-radius:0;
}
.port-card:hover .port-card-img::after{opacity:1}

/* Action buttons — centered on image, appear on hover */
.port-actions{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%) scale(.85);
  display:flex;
  gap:12px;
  opacity:0;
  transition:opacity .28s var(--ease), transform .28s var(--ease);
  z-index:2;
}
.port-card:hover .port-actions{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}

.port-actions button{
  width:46px;
  height:46px;
  background:#fff;
  border:none;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(0,0,0,.18);
  transition:transform .18s var(--ease), background .18s var(--ease);
}
.port-actions button:hover{
  transform:scale(1.12);
  background:var(--blue);
  color:#fff;
}
.port-actions button svg{width:18px;height:18px;transition:color .18s}
.port-actions button:hover svg{color:#fff}

/* Card body */
.port-card-body{padding:26px 28px}

/* Category label — stays blue */
.port-cat{
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:8px;
  transition:var(--tf);
}

/* Title — turns blue on hover */
.port-card h3{
  font-size:19px;
  font-weight:700;
  color:var(--text-dark);
  margin-bottom:8px;
  transition:color .28s var(--ease);
}
.port-card:hover h3{color:var(--blue)}

.port-card>div>p,
.port-card-body p{
  font-size:14px;
  color:var(--text-muted);
  line-height:1.6;
  margin-bottom:16px;
  transition:color .28s var(--ease);
}

/* Tags */
.port-tags{display:flex;gap:7px;flex-wrap:wrap}
.port-tag{
  padding:4px 12px;
  background:var(--gray-100);
  border-radius:50px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.05em;
  color:var(--gray-600);
  transition:background .25s var(--ease), color .25s var(--ease);
}
.port-card:hover .port-tag{
  background:rgba(37,99,235,.1);
  color:var(--blue);
}

/* Portfolio CTA */
.port-cta{background:var(--blue);border-radius:var(--radius-xl);padding:72px;text-align:center;margin-bottom:96px;position:relative;overflow:hidden}
.port-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 100%)}
.port-cta>*{position:relative;z-index:1}
.port-cta h2{font-size:46px;color:#fff;margin-bottom:14px}
.port-cta p{color:rgba(255,255,255,.8);margin-bottom:28px;font-size:16px}

/* ── PRICING PAGE ── */
.pricing-page{padding:136px 0 60px;background:#fff}
.pricing-page-header{text-align:center;margin-bottom:72px}
.pricing-page-header h1{font-size:clamp(40px,5vw,68px);letter-spacing:-.03em;margin-bottom:0}
.pricing-divider-line{display:flex;align-items:center;gap:16px;justify-content:center;margin-bottom:12px}
.pricing-divider-line::before,.pricing-divider-line::after{content:'';width:60px;height:1.5px;background:var(--blue)}
.pricing-divider-line span{font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--blue)}

/* Promo Banner */
.promo-banner{border-radius:var(--radius-xl);overflow:hidden;margin-bottom:72px;background:var(--blue);display:grid;grid-template-columns:1fr 1fr;min-height:420px;position:relative}
.promo-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#1a3fbe 0%,var(--blue) 100%)}
.promo-content{padding:56px 52px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1}
.promo-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.18);color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:7px 16px;border-radius:50px;margin-bottom:22px;width:fit-content}
.promo-badge svg{width:14px;height:14px;color:#FCD34D}
.promo-heading{font-family:var(--font-head);font-size:clamp(36px,4vw,54px);font-weight:900;color:#fff;line-height:1.0;margin-bottom:18px}
.promo-heading .accent-yellow{color:#FCD34D}
.promo-desc{font-size:16px;color:rgba(255,255,255,.9);line-height:1.65;margin-bottom:28px;max-width:420px}
.promo-checks{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:32px}
.promo-check{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.9);font-size:14px;font-weight:500}
.promo-check-icon{width:20px;height:20px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;color:#fff}
.promo-note{font-size:13px;color:rgba(255,255,255,.55);font-style:italic;margin-top:14px}
.promo-image{position:relative;overflow:hidden}
.promo-image img{width:100%;height:100%;object-fit:cover;opacity:.85}

/* Pricing Section Heading */
.pricing-section-label{display:flex;align-items:center;gap:12px;margin-bottom:32px}
.pricing-section-icon{width:44px;height:44px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pricing-section-icon svg{width:22px;height:22px;color:#fff}
.pricing-section-label h2{font-size:24px;font-weight:700}

/* Pricing Cards */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:80px;align-items:start}
.price-card{background:#fff;border:1.5px solid var(--gray-200);border-radius:var(--radius-xl);padding:0;transition:var(--t);position:relative;overflow:visible}
.price-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--blue-light)}
.price-card.featured{background:var(--blue);border-color:var(--blue)}
.price-card.featured:hover{box-shadow:0 16px 56px rgba(37,99,235,.45)}
.most-popular-badge{position:absolute;top:-16px;left:50%;transform:translateX(-50%);background:var(--text-dark);color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 18px;border-radius:50px;white-space:nowrap;z-index:2}
.price-card-inner{padding:36px 32px}
.price-card-icon{width:52px;height:52px;background:var(--gray-100);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.price-card.featured .price-card-icon{background:rgba(255,255,255,.2)}
.price-card-icon svg{width:24px;height:24px;color:var(--blue)}
.price-card.featured .price-card-icon svg{color:#fff}
.price-plan-name{font-size:20px;font-weight:700;color:var(--text-dark);margin-bottom:8px}
.price-card.featured .price-plan-name{color:#fff}
.price-amount{font-family:var(--font-head);font-size:48px;font-weight:900;color:var(--text-dark);line-height:1;display:inline}
.price-card.featured .price-amount{color:#fff}
.price-once{font-size:14px;font-weight:500;color:var(--text-muted);margin-left:4px}
.price-card.featured .price-once{color:rgba(255,255,255,.7)}
.price-period{font-size:14px;font-weight:500;color:var(--text-muted);margin-left:2px}
.price-card.featured .price-period{color:rgba(255,255,255,.7)}
.price-tagline{font-size:14px;color:var(--text-muted);line-height:1.6;margin-top:12px;margin-bottom:22px}
.price-card.featured .price-tagline{color:rgba(255,255,255,.8)}
.price-divider{height:1px;background:var(--gray-200);margin-bottom:22px}
.price-card.featured .price-divider{background:rgba(255,255,255,.2)}
.price-features{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.price-feature{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-dark)}
.price-card.featured .price-feature{color:rgba(255,255,255,.9)}
.price-check{width:18px;height:18px;background:rgba(37,99,235,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.price-card.featured .price-check{background:rgba(255,255,255,.25)}
.price-check svg{width:10px;height:10px;color:var(--blue)}
.price-card.featured .price-check svg{color:#fff}
.btn-price{width:100%;padding:15px;border-radius:var(--radius-md);font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--t);cursor:pointer;border:none;font-family:var(--font-body)}
.btn-price-dark{background:var(--text-dark);color:#fff}
.btn-price-dark:hover{background:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-blue)}
.btn-price-white{background:#fff;color:var(--blue);font-weight:700}
.btn-price-white:hover{background:var(--off-white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}

/* Questions CTA */
.questions-cta{background:var(--gray-100);border-radius:var(--radius-xl);padding:64px;text-align:center;margin-bottom:96px}
.questions-cta h2{font-size:36px;font-weight:700;margin-bottom:12px}
.questions-cta p{font-size:16px;color:var(--text-muted);max-width:540px;margin:0 auto 28px;line-height:1.7}

/* ── CONTACT PAGE ── */
.contact-page{padding:136px 0 96px;background:#fff}
.contact-header{margin-bottom:56px}
.contact-header h1{font-size:clamp(38px,5vw,64px);letter-spacing:-.03em}
.contact-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:72px;align-items:start}
.contact-info>p{font-size:16px;color:var(--text-muted);line-height:1.7;margin-bottom:44px}
.contact-details{display:flex;flex-direction:column;gap:26px}
.contact-detail{display:flex;align-items:flex-start;gap:14px}
.cd-icon{width:46px;height:46px;background:rgba(37,99,235,.08);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--t)}
.contact-detail:hover .cd-icon{background:var(--blue)}
.contact-detail:hover .cd-icon svg{color:#fff}
.cd-icon svg{width:20px;height:20px;color:var(--blue);transition:var(--t)}
.cd-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:3px}
.cd-value{font-size:15px;font-weight:600;color:var(--text-dark)}
.contact-form-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:44px;box-shadow:var(--shadow-md)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-600);margin-bottom:7px}
.form-input,.form-textarea{width:100%;padding:13px 16px;background:var(--gray-100);border:1.5px solid transparent;border-radius:var(--radius-md);font-family:var(--font-body);font-size:15px;color:var(--text-dark);transition:var(--t);outline:none}
.form-input::placeholder,.form-textarea::placeholder{color:var(--gray-400)}
.form-input:focus,.form-textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px rgba(37,99,235,.1)}
.form-textarea{min-height:140px;resize:vertical}
.btn-submit{width:100%;padding:16px;background:var(--blue);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;transition:var(--t);margin-top:6px;cursor:pointer}
.btn-submit:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-blue)}

/* ── FOOTER ── */
.site-footer{background:var(--gray-100);padding:72px 0 36px}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:72px;padding-bottom:52px;border-bottom:1px solid var(--gray-200);margin-bottom:36px}
.footer-brand p{font-size:15px;color:var(--text-muted);line-height:1.7;margin-top:14px;max-width:300px}
.footer-socials{display:flex;gap:10px;margin-top:24px}
.footer-social{width:38px;height:38px;background:#fff;border:1px solid var(--gray-200);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--t);cursor:pointer;text-decoration:none}
.footer-social:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-2px)}
.footer-social:hover svg{color:#fff}
.footer-social svg{width:15px;height:15px;color:var(--gray-600);transition:var(--t)}
.footer-col h4{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-400);margin-bottom:18px}
.footer-nav-link{display:block;font-size:15px;color:var(--gray-600);padding:5px 0;transition:var(--tf)}
.footer-nav-link:hover{color:var(--blue);padding-left:4px}
.footer-bottom{display:flex;align-items:center;justify-content:space-between}
.footer-copyright{font-size:14px;color:var(--text-muted)}
.footer-legal{display:flex;gap:22px}
.footer-legal a{font-size:14px;color:var(--text-muted);transition:var(--tf)}
.footer-legal a:hover{color:var(--blue)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .container{padding:0 32px}
  .hero-inner,.why-inner,.about-inner,.contact-inner{grid-template-columns:1fr;gap:44px}
  .services-grid,.services-full-grid,.port-full-grid,.values-grid,.vm-grid{grid-template-columns:repeat(2,1fr)}
  .port-grid-2{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .promo-banner{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:768px){
  .container{padding:0 18px}
  section{padding:56px 0}
  .nav-menu,.nav-actions{display:none}
  .nav-toggle{display:flex}
  .nav-menu.open{display:flex;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:#fff;border-bottom:1px solid var(--gray-200);padding:14px;box-shadow:var(--shadow-lg)}
  .nav-actions.open{display:flex;padding:0 14px 14px;flex-direction:column;position:absolute;top:calc(72px + var(--menu-height,300px));left:0;right:0;background:#fff}
  .services-grid,.services-full-grid,.port-full-grid,.port-grid-2,.values-grid,.vm-grid{grid-template-columns:1fr}
  .about-visual{grid-template-columns:1fr}
  .about-stats{gap:20px;flex-wrap:wrap}
  .form-row{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .promo-image{display:none}
  .cta-card,.port-cta,.questions-cta{padding:40px 22px}
  .pricing-page-header h1{font-size:clamp(32px,8vw,52px)}
}

/* ── Logo Image ── */
.nav-logo{
  display:flex;
  align-items:center;
  gap:0;
  text-decoration:none;
  background:none;
  line-height:0; /* remove extra baseline gap */
}
.nav-logo .logo-icon{display:none} /* hide CSS diamond fallback */

/* Header logo */
.site-logo-img{
  height:52px;    /* tall enough for new logo with tagline */
  width:auto;
  max-width:220px;
  display:block;
  object-fit:contain;
  object-position:left center;
  background:transparent;
  transition:opacity .2s;
}
.nav-logo:hover .site-logo-img{opacity:.85}

/* Footer logo — same full-colour logo, slightly smaller */
.footer-logo-link{
  display:inline-block;
  line-height:0;
  margin-bottom:14px;
}
.site-logo-img--footer{
  height:48px;
  width:auto;
  max-width:200px;
  object-fit:contain;
  object-position:left center;
  filter:none;   /* show full colour - NOT white inversion */
  background:transparent;
}

/* WP Customizer outputs a wrapped <a> - strip extra wrapper styling */
.custom-logo-link{
  display:inline-block;
  line-height:0;
}
.custom-logo-link img,
.custom-logo{
  height:52px !important;
  width:auto !important;
  max-width:220px !important;
  display:block;
  object-fit:contain;
}


/* ════════════════════════════════════════════════
   SERVICE DETAIL PAGE STYLES
   ════════════════════════════════════════════════ */

/* Hero banner — full width dark image with overlay */
.svc-detail-hero{
  position:relative;
  min-height:420px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:#111;
  margin-top:72px; /* below fixed header */
}
.svc-detail-hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  filter:grayscale(100%);
  opacity:.55;
  transition:opacity .6s;
}
.svc-detail-hero:hover .svc-detail-hero-bg{opacity:.65}
.svc-detail-hero-content{
  position:relative;
  z-index:2;
  padding:56px 0 52px;
  width:100%;
}
.svc-back-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:rgba(255,255,255,.75);
  font-size:14px;
  font-weight:500;
  margin-bottom:28px;
  transition:color .2s;
  text-decoration:none;
}
.svc-back-link:hover{color:#fff}
.svc-back-link svg{width:16px;height:16px}
.svc-hero-icon{
  width:56px;height:56px;
  background:var(--blue);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
}
.svc-hero-icon svg{width:28px;height:28px;color:#fff}
.svc-detail-hero h1{
  font-family:var(--font-head);
  font-size:clamp(40px,6vw,80px);
  font-weight:700;
  color:#fff;
  line-height:1.05;
  letter-spacing:-.02em;
  margin-bottom:16px;
}
.svc-detail-hero p{
  font-size:18px;
  color:rgba(255,255,255,.8);
  max-width:600px;
  line-height:1.65;
}

/* Main body layout */
.svc-detail-body{
  padding:72px 0 96px;
  background:#fff;
}
.svc-detail-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:56px;
  align-items:start;
}

/* Left: Overview */
.svc-overview-title{
  font-size:28px;
  font-weight:700;
  margin-bottom:18px;
  color:var(--text-dark);
}
.svc-overview-text{
  font-size:16px;
  color:var(--text-muted);
  line-height:1.8;
  margin-bottom:40px;
}

/* Sub-service cards grid */
.svc-sub-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:0;
}
.svc-sub-card{
  background:var(--gray-100);
  border-radius:var(--radius-md);
  padding:28px 24px;
  border:1px solid transparent;
  transition:var(--t);
}
.svc-sub-card:hover{
  background:#fff;
  border-color:var(--blue-light);
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}
.svc-sub-card h4{
  font-size:16px;
  font-weight:700;
  color:var(--text-dark);
  margin-bottom:8px;
}
.svc-sub-card p{
  font-size:13.5px;
  color:var(--text-muted);
  line-height:1.6;
}

/* Right: Sidebar */
.svc-sidebar{
  display:flex;
  flex-direction:column;
  gap:22px;
  position:sticky;
  top:96px;
}
.svc-sidebar-box{
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:var(--radius-lg);
  padding:28px;
}
.svc-sidebar-box h3{
  font-size:18px;
  font-weight:700;
  color:var(--text-dark);
  margin-bottom:18px;
}
.svc-why-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.svc-why-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14.5px;
  color:var(--gray-800);
  font-weight:500;
}
.svc-why-bullet{
  width:26px;height:26px;
  background:rgba(37,99,235,.1);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  color:var(--blue);
  font-size:12px;
}
.svc-why-bullet svg{width:13px;height:13px;color:var(--blue)}

/* CTA sidebar card — dark */
.svc-cta-box{
  background:var(--text-dark);
  border-radius:var(--radius-lg);
  padding:32px 28px;
}
.svc-cta-box h3{
  font-size:20px;
  font-weight:700;
  color:#fff;
  margin-bottom:10px;
}
.svc-cta-box p{
  font-size:14px;
  color:rgba(255,255,255,.7);
  line-height:1.6;
  margin-bottom:22px;
}
.btn-svc-cta{
  display:block;
  width:100%;
  padding:15px;
  background:var(--blue);
  color:#fff;
  border:none;
  border-radius:var(--radius-md);
  font-family:var(--font-head);
  font-size:15px;
  font-weight:600;
  text-align:center;
  cursor:pointer;
  transition:var(--t);
  text-decoration:none;
}
.btn-svc-cta:hover{
  background:var(--blue-dark);
  transform:translateY(-2px);
  box-shadow:var(--shadow-blue);
}

/* Services nav links update - make sub-items linkable */
.dropdown-menu a.dd-current{
  background:rgba(37,99,235,.06);
  color:var(--blue);
}

/* Responsive service detail */
@media(max-width:1024px){
  .svc-detail-layout{grid-template-columns:1fr;gap:36px}
  .svc-sidebar{position:static}
}
@media(max-width:640px){
  .svc-sub-grid{grid-template-columns:1fr}
  .svc-detail-hero h1{font-size:clamp(32px,8vw,52px)}
}
