:root{
  --accent:#ccff00;
  --accent-hover:#b3e600;
  --accent-glow:rgba(204,255,0,.4);
  --text-on-accent:#000;

  --bg-primary:#fff;
  --bg-secondary:#f8fafc;
  --text-primary:#09090b;
  --text-secondary:#52525b;
  --border-color:#e2e8f0;
  --card-bg:#fff;
  --nav-bg:rgba(255,255,255,.7);
  --soft-shadow:0 10px 30px -10px rgba(0,0,0,.1);

  --footer-bg:#09090b;
  --footer-text:#fafafa;

  --font-heading:'Montserrat',sans-serif;
  --font-body:'Inter',sans-serif;
  --transition:all .3s cubic-bezier(.4,0,.2,1);
}

body.dark-theme{
  --bg-primary:#09090b;
  --bg-secondary:#121214;
  --text-primary:#fafafa;
  --text-secondary:#a1a1aa;
  --border-color:#27272a;
  --card-bg:#18181b;
  --nav-bg:rgba(9,9,11,.7);
  --soft-shadow:0 10px 30px -10px rgba(0,0,0,.5);
}

*{ margin:0; padding:0; box-sizing:border-box; scroll-behavior:smooth; }
body{
  background:var(--bg-primary);
  color:var(--text-primary);
  font-family:var(--font-body);
  transition:background-color .4s,color .4s;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{ color:inherit; }

::-webkit-scrollbar{ width:8px; }
::-webkit-scrollbar-track{ background:var(--bg-primary); }
::-webkit-scrollbar-thumb{ background:#3f3f46; border-radius:4px; }
::-webkit-scrollbar-thumb:hover{ background:var(--accent); }

.container{ max-width:1280px; margin:0 auto; padding:0 5%; }
.text-center{ text-align:center; }
.bg-secondary{ background-color:var(--bg-secondary); transition:background-color .4s; }
.border-y{ border-top:1px solid var(--border-color); border-bottom:1px solid var(--border-color); transition:border-color .4s; padding:120px 0px;}
.mt-10{ margin-top:10px; } .mt-20{ margin-top:20px; } .mt-30{ margin-top:30px; } .mt-40{ margin-top:40px; } .mt-50{ margin-top:50px; }
.mb-40{ margin-bottom:40px; }
.w-100{ width:100%; display:block; }

h1,h2,h3,h4{
  font-family:var(--font-heading);
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:-.6px;
  color:var(--text-primary);
  transition:color .4s;
}
.section-title{
  font-size:clamp(2.2rem,4vw,3.5rem);
  margin-bottom:15px;
  line-height:1.05;
}
.section-desc{
  font-size:1.1rem;
  color:var(--text-secondary);
  max-width:780px;
  margin:0 auto;
  line-height:1.65;
  font-weight:650;
}

.text-marker{
  background-color:var(--accent);
  color:var(--text-on-accent);
  padding:0 10px;
  display:inline-block;
  border-radius:10px;
  transform:rotate(-1deg);
  box-shadow:var(--soft-shadow);
}
.dot-marker{ color:var(--accent); }
i[data-lucide]{ width:20px; height:20px; }
.icon-marker{ color:var(--accent); stroke-width:2.5px; }

/* mouse glow */
.mouse-glow-effect{
  position:fixed; top:0; left:0;
  width:800px; height:800px;
  background:radial-gradient(circle,var(--accent-glow) 0%,rgba(0,0,0,0) 60%);
  border-radius:50%;
  pointer-events:none;
  z-index:-1;
  transform:translate(-50%,-50%);
  opacity:.5;
  transition:opacity .4s ease;
}
body.dark-theme .mouse-glow-effect{ opacity:.8; }

/* floating */
.floating-actions{
  position:fixed; bottom:30px; right:30px;
  display:flex; flex-direction:column; gap:15px;
  z-index:99;
}
.float-btn{
  width:50px; height:50px;
  border-radius:50%;
  border:1px solid var(--border-color);
  background:var(--card-bg);
  color:var(--text-primary);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  box-shadow:var(--soft-shadow);
  transition:var(--transition);
}
.float-btn:hover{
  background:var(--accent);
  color:var(--text-on-accent);
  border-color:var(--accent);
  transform:scale(1.08);
}
.btt-hidden{ opacity:0; pointer-events:none; transform:translateY(20px); }
.btt-visible{ opacity:1; pointer-events:auto; transform:translateY(0); }

/* buttons */
.btn-primary{
  background:var(--accent);
  color:var(--text-on-accent) !important;
  font-family:var(--font-heading);
  font-weight:900;
  font-size:.95rem;
  padding:16px 32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:none;
  border-radius:999px;
  letter-spacing:.5px;
  cursor:pointer;
  text-decoration:none;
  transition:var(--transition);
}
.btn-primary.soft-shadow{ box-shadow:0 4px 20px var(--accent-glow); }
.btn-primary:hover{
  background:var(--accent-hover);
  transform:translateY(-3px);
  box-shadow:0 10px 34px var(--accent-glow);
}
.btn-massive{ padding:20px 45px; font-size:1.1rem; }

/* pill nav */
.pill-navbar{
  position:fixed;
  top:20px;
  width:100%;
  display:flex;
  justify-content:center;
  z-index:100;
  pointer-events:none;
}
.pill-inner{
  pointer-events:auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:var(--nav-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border-color);
  padding:10px 10px 10px 30px;
  border-radius:999px;
  width:90%;
  max-width:1120px;
  box-shadow:var(--soft-shadow);
}
.logo{
  font-family:var(--font-heading);
  font-size:1.4rem;
  font-weight:900;
  color:var(--text-primary);
}
.logo-link{ text-decoration:none; display:inline-flex; align-items:center; gap:10px;}
.sl-logo{ height:34px; width:auto; display:none; }
body.dark-theme .sl-logo--dark{ display:inline-block; }
body:not(.dark-theme) .sl-logo--light{ display:inline-block; }

.nav-links{ display:flex; align-items:center; }

/* Desktop primary menu markup (UL/LI) */
.nav-links .menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:28px;
  align-items:center;
}
.nav-links .menu > li{ position:relative; }
.nav-links .menu a{
  font-family:var(--font-heading);
  font-size:.85rem;
  font-weight:900;
  color:var(--text-secondary);
  text-decoration:none;
  text-transform:uppercase;
  transition:var(--transition);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.nav-links .menu a:hover{ color:var(--text-primary); }

/* Dropdowns */
.nav-links .menu li.menu-item-has-children > a:after{
  content:"▾";
  font-size:12px;
  opacity:.8;
  transform:translateY(-1px);
}
.nav-links .menu .sub-menu{
  list-style:none;
  position:absolute;
  top:100%;
  left:0;
  margin:0;
  padding:10px;
  min-width:220px;
  background:var(--card-bg);
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  box-shadow:0 24px 60px rgba(0,0,0,.35);
  opacity:0;
  transform:translateY(8px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:9999;
}
.nav-links .menu .sub-menu li{ margin:0; }
.nav-links .menu .sub-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  white-space:nowrap;
  color:var(--text-secondary);
}
.nav-links .menu .sub-menu a:hover{
  background:rgba(255,255,255,.06);
  color:var(--text-primary);
}
.nav-links .menu li.menu-item-has-children:hover > .sub-menu,
.nav-links .menu li.menu-item-has-children:focus-within > .sub-menu{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.hamburger-btn{
  background:none;
  border:none;
  color:var(--text-primary);
  cursor:pointer;
  padding:10px;
  display:flex;
  align-items:center;
}
.desktop-nav{ display:flex; align-items:center; }
.mobile-nav{ display:none; }

/* main wrapper */
.main-content-wrapper{
  position:relative;
  z-index:2;
  background:var(--bg-primary);
  box-shadow:0 20px 50px rgba(0,0,0,.2);
  margin-bottom:500px;
  border-bottom-left-radius:32px;
  border-bottom-right-radius:32px;
  overflow:hidden;
}

/* hero */
.hero-section{ padding:200px 0 120px; min-height:90vh; display:flex; align-items:center; }
.availability-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid var(--border-color);
  padding:8px 20px;
  border-radius:999px;
  font-size:.85rem;
  font-weight:900;
  color:var(--text-secondary);
  margin-bottom:30px;
  font-family:var(--font-heading);
  text-transform:uppercase;
  background:var(--bg-secondary);
}
.pulse-indicator{
  width:8px; height:8px;
  background:var(--accent);
  border-radius:50%;
  box-shadow:0 0 10px var(--accent-glow);
  animation:pulseAccent 2s infinite;
}
@keyframes pulseAccent{ 50%{ opacity:.4; transform:scale(1.2); } }
.hero-title{
  font-size:clamp(3.5rem,8vw,7rem);
  margin-bottom:30px;
  line-height:1;
  letter-spacing:-2px;
}
.sliding-text-container{ display:inline-block; height:1em; overflow:hidden; vertical-align:bottom; }
.sliding-words-wrapper{ display:inline-flex; flex-direction:column; animation:slideUp 8s cubic-bezier(.65,0,.35,1) infinite; }
.sliding-word{ height:1em; line-height:1; padding:0 5px; }
@keyframes slideUp{
  0%,20%{ transform:translateY(0); }
  25%,45%{ transform:translateY(-1em); }
  50%,70%{ transform:translateY(-2em); }
  75%,95%{ transform:translateY(-3em); }
  100%{ transform:translateY(0); }
}
.hero-subtitle{
  font-size:1.25rem;
  color:var(--text-secondary);
  max-width:780px;
  margin:0 auto 50px;
  line-height:1.65;
  font-weight:650;
}
.hero-cta-wrap{ display:flex; flex-direction:column; align-items:center; gap:15px; }
.cta-subtext{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.95rem;
  color:var(--text-secondary);
  font-weight:700;
}
.cta-subtext--center{
  justify-content:center;
  text-align:center;
  width:100%;
}

/* TECH STRIP */
.tech-strip-section{ padding:0; }
.marquee-strip{
  overflow:hidden;
  border-top:1px solid var(--border-color);
  border-bottom:1px solid var(--border-color);
  background:var(--card-bg);
}
.marquee-strip--full{ width:100%; border-left:none; border-right:none; border-radius:0; box-shadow:none; }
.marquee-strip--padded{ padding:22px 0; }
.marquee-track{
  display:inline-flex;
  white-space:nowrap;
  will-change:transform;
  transform:translateX(0);
}
.marquee-track--gap{ gap:90px; }
.marquee-strip span{
  font-family:var(--font-heading);
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--text-primary);
  font-size:1rem;
  padding-left:28px;
}
/* FIX marquee spacing around dot */
.marquee-strip em{
  font-style:normal;
  opacity:.7;
  margin:0 26px;
  color:var(--text-secondary);
}
.marquee-strip:not(.marquee-on) .marquee-track{ transform:translateX(0) !important; }
.marquee-strip.marquee-on .marquee-track{ animation:marq 22s linear infinite; }
@keyframes marq{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ABOUT */
.about-section{ padding:140px 0; }
.about-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:26px;
  align-items:start;
}
.kicker-pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--border-color);
  background:var(--bg-secondary);
  padding:10px 14px;
  border-radius:999px;
  box-shadow:var(--soft-shadow);
  font-family:var(--font-heading);
  font-weight:900;
  font-size:.78rem;
  letter-spacing:1px;
  color:var(--text-secondary);
  text-transform:uppercase;
}
.kicker-pill i{ width:18px; height:18px; color:var(--text-primary); }

.about-title{
  font-family:var(--font-heading);
  font-weight:900;
  font-size:clamp(2rem,3.3vw,3rem);
  line-height:1.05;
  letter-spacing:-1px;
  margin-top:14px;
}
.about-text{
  color:var(--text-secondary);
  font-weight:650;
  line-height:1.75;
  font-size:1.08rem;
  max-width:720px;
}
.about-points{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.about-point{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px 14px;
  border:1px solid var(--border-color);
  border-radius:16px;
  background:var(--bg-secondary);
  box-shadow:var(--soft-shadow);
  font-weight:750;
  color:var(--text-secondary);
}
.about-actions{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.about-mini-note{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--text-secondary);
  font-weight:800;
}

.about-visual-card{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  border:1px solid var(--border-color);
  background:var(--card-bg);
  box-shadow:var(--soft-shadow);
}
.about-visual-card img{
  width:100%;
  height:340px;
  object-fit:cover;
  display:block;
}
.about-visual-overlay{
  position:absolute;
  inset:0;
  padding:18px;
  display:flex;
  gap:10px;
  align-items:flex-end;
  justify-content:flex-start;
  background:linear-gradient(to top, rgba(0,0,0,.55), rgba(0,0,0,0) 60%);
}
.overlay-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  color:#fff;
  padding:10px 14px;
  border-radius:999px;
  font-family:var(--font-heading);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1px;
  font-size:.75rem;
}

.about-stats{
  margin-top:16px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.stat{
  border:1px solid var(--border-color);
  background:var(--card-bg);
  border-radius:18px;
  box-shadow:var(--soft-shadow);
  padding:14px 14px;
}
.stat-top{
  display:flex;
  gap:10px;
  align-items:center;
  font-family:var(--font-heading);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1px;
  font-size:.74rem;
  color:var(--text-secondary);
  margin-bottom:8px;
}
.stat-top i{ width:18px; height:18px; color:var(--text-primary); }
.stat-val{ font-weight:800; color:var(--text-primary); opacity:.9; line-height:1.4; }

/* DRAGGABLE */
.draggable-container{ width:100%; overflow:hidden; padding:10px 0 44px; }
.draggable-slider{
  display:flex;
  gap:30px;
  overflow-x:auto;
  padding:0 5%;
  scroll-behavior:smooth;
  cursor:grab;
  -ms-overflow-style:none;
  scrollbar-width:none;
}
.draggable-slider::-webkit-scrollbar{ display:none; }
.draggable-slider.active{ cursor:grabbing; scroll-behavior:auto; }

/* cards */
.proj-card{
  width:450px;
  flex-shrink:0;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--border-color);
  background:var(--card-bg);
  box-shadow:var(--soft-shadow);
  transition:var(--transition);
  user-select:none;
}
.proj-card:hover{ border-color:var(--accent); transform:translateY(-3px); }
.proj-card img{ width:100%; height:300px; object-fit:cover; pointer-events:none; }
.proj-info{ padding:26px; border-top:1px solid var(--border-color); transition:var(--transition); }
.proj-card:hover .proj-info{ border-top-color:var(--accent); }
.proj-cat{
  font-family:var(--font-heading);
  font-weight:900;
  font-size:.8rem;
  letter-spacing:1px;
  text-transform:uppercase;
  display:block;
  margin-bottom:6px;
}
.proj-info h3{ font-size:1.55rem; margin-bottom:6px; }
.proj-info p{ color:var(--text-secondary); font-weight:650; }

/* arrows only row */
.carousel-arrows-only{
  display:flex;
  justify-content:center;
  gap:14px;
  margin:28px auto 8px;
  padding:0 5%;
}
.carousel-arrows-only--top{ margin-top:0; }
.carousel-arrow{
  width:46px; height:46px;
  border-radius:999px;
  border:1px solid var(--border-color);
  background:var(--card-bg);
  color:var(--text-primary);
  box-shadow:var(--soft-shadow);
  cursor:pointer;
  transition:var(--transition);
  display:flex; align-items:center; justify-content:center;
}
.carousel-arrow:hover{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--text-on-accent);
  transform:translateY(-2px);
}

/* SERVICES */
.services-section{ padding:120px 0; }
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:30px;
  max-width:1100px;
  margin-inline:auto;
}
.soft-service-box{
  background:var(--card-bg);
  border:1px solid var(--border-color);
  padding:40px;
  border-radius:22px;
  cursor:pointer;
  transition:var(--transition);
  box-shadow:var(--soft-shadow);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  position:relative;
  overflow:hidden;
}
.soft-service-box:hover{
  border-color:var(--accent);
  transform:translateY(-7px);
  box-shadow:0 20px 40px -15px var(--accent-glow);
}
.soft-service-box::after{
  content:'';
  position:absolute;
  bottom:0; left:0;
  width:100%;
  height:4px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s ease;
}
.soft-service-box:hover::after{ transform:scaleX(1); }

.soft-icon{
  width:60px; height:60px;
  background:var(--bg-secondary);
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:25px;
  transition:var(--transition);
  color:var(--text-primary);
}
.soft-icon i{ width:30px; height:30px; }
.soft-service-box:hover .soft-icon{ background:var(--accent-glow); }
.soft-service-box h3{ font-size:1.4rem; margin-bottom:15px; }
.soft-service-box p{ font-size:1rem; color:var(--text-secondary); line-height:1.6; font-weight:650; }

/* TESTIMONIALS */
.testimonials-section{ padding:100px 0; overflow:hidden; }
.test-slider{ gap:30px; }
.test-card{
  width:450px;
  flex-shrink:0;
  background:var(--card-bg);
  border:1px solid var(--border-color);
  padding:40px;
  border-radius:22px;
  box-shadow:var(--soft-shadow);
  user-select:none;
  transition:var(--transition);
}
.test-card:hover{ border-color:var(--accent); transform:translateY(-3px); }
.stars{ display:flex; gap:6px; margin-bottom:20px; color:var(--accent); }
.stars i{ width:18px; height:18px; }
.quote{ font-size:1.18rem; line-height:1.75; font-style:italic; color:var(--text-secondary); margin-bottom:20px; font-weight:650; }
.test-card h4{ font-size:1.1rem; }

/* CTA */
.cta-section{ padding:140px 0; }
.massive-title{ font-size:clamp(3rem,7vw,6rem); line-height:1.1; margin-bottom:20px; }
.cta-actions{ display:flex; flex-direction:column; align-items:center; }

/* FOOTER */
.footer-reveal{
  position:fixed;
  bottom:0; left:0;
  width:100%;
  background:var(--footer-bg);
  color:var(--footer-text);
  padding:100px 0 30px;
  z-index:1;
  border-top:5px solid var(--accent);
  overflow:hidden;
}
.footer-glow{
  position:absolute;
  inset:-200px;
  background:radial-gradient(circle, rgba(204,255,0,.18) 0%, rgba(0,0,0,0) 55%);
  transform:translate(-50%,-50%);
  pointer-events:none;
  opacity:0;
  transition:opacity .2s ease;
}
.footer-reveal:hover .footer-glow{ opacity:1; }

.footer-grid{
  position:relative;
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:40px;
  margin-bottom:60px;
}
.footer-grid--extended{
  grid-template-columns:1.6fr 1fr 1fr;
}
.footer-brand h2{ color:var(--footer-text); font-size:2.5rem; margin-bottom:15px; }
.footer-brand p{ color:#a1a1aa; max-width:420px; line-height:1.6; font-weight:650; }

.footer-links h4,
.footer-contact h4{
  font-size:1rem;
  color:#a1a1aa;
  margin-bottom:15px;
  font-weight:900;
  font-family:var(--font-heading);
  text-transform:uppercase;
  letter-spacing:1px;
}
.footer-list{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-list a{
  text-decoration:none;
  color:#a1a1aa;
  font-weight:750;
  transition:var(--transition);
}
.footer-list a:hover{ color:var(--accent); padding-left:6px; }

.footer-mail{
  font-size:1.5rem;
  font-weight:900;
  font-family:var(--font-heading);
  text-decoration:none;
  color:var(--accent);
  transition:color .3s;
}
.footer-mail:hover{ color:#fff; }
.border-y-footer{ border-top:1px solid #27272a; }
.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:30px;
  color:#a1a1aa;
  font-size:.85rem;
  font-family:var(--font-heading);
  font-weight:900;
  position:relative;
}
.social-links{ display:flex; gap:20px; }
.social-links a{ color:#a1a1aa; transition:var(--transition); }
.social-links a:hover{ color:var(--accent); transform:translateY(-2px); }

/* OFFCANVAS + MODAL */
.offcanvas-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(8px);
  z-index:1000;
  opacity:0;
  visibility:hidden;
  transition:.4s ease;
  cursor:pointer;
}
.offcanvas-backdrop.active{ opacity:1; visibility:visible; }
.offcanvas-panel{
  position:fixed;
  top:0; right:-450px;
  width:450px; max-width:100%;
  height:100vh;
  background:var(--card-bg);
  z-index:1001;
  border-left:1px solid var(--border-color);
  display:flex;
  flex-direction:column;
  transition:right .4s cubic-bezier(.4,0,.2,1);
  box-shadow:var(--soft-shadow);
}
.offcanvas-panel.active{ right:0; }
.offcanvas-header{
  padding:30px 40px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--border-color);
}
.offcanvas-close{
  background:transparent;
  border:none;
  color:var(--text-secondary);
  cursor:pointer;
  transition:var(--transition);
}
.offcanvas-close:hover{ color:var(--text-primary); transform:rotate(90deg); }
.offcanvas-body{ padding:40px; flex:1; overflow-y:auto; }
.offcanvas-footer{
  padding:30px 40px;
  background:var(--bg-secondary);
  border-top:1px solid var(--border-color);
}
/* Mobile nav (offcanvas) uses WP menu markup (UL/LI) */
.mobile-nav-list ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:25px; }
.mobile-nav-list li{ margin:0; padding:0; }
.mobile-nav-list a{
  font-family:var(--font-heading);
  font-size:2rem;
  font-weight:900;
  text-decoration:none;
  color:var(--text-primary);
  transition:var(--transition);
}
.mobile-nav-list a:hover{
  padding-left:10px;
  border-left:5px solid var(--accent);
}
/* Sub-menu indentation */
.mobile-nav-list .sub-menu{ margin-top:12px; margin-left:18px; padding-left:14px; border-left:1px solid rgba(255,255,255,.12); gap:16px; }
.mobile-nav-list .sub-menu a{ font-size:1.4rem; opacity:.9; }
.service-title-text{ font-size:1.5rem; }
.service-desc-text{ font-size:1.1rem; color:var(--text-secondary); line-height:1.6; font-weight:650; }
.feature-list{ list-style:none; display:flex; flex-direction:column; gap:18px; }
.feature-list li{ display:flex; align-items:flex-start; gap:12px; color:var(--text-secondary); line-height:1.5; font-weight:650; }
.feature-list i{ width:20px; height:20px; margin-top:2px; }
.feature-list .feat-ico{ color:var(--text-primary); }
body.dark-theme .feature-list .feat-ico{ color:var(--accent); }

/* reveal */
.reveal-fade{
  opacity:0;
  transform:translateY(30px);
  transition:all .8s cubic-bezier(.4,0,.2,1);
}
.reveal-fade.is-visible{ opacity:1; transform:translateY(0); }

/* lead modal */
.lead-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(10px);
  z-index:2000;
  opacity:0;
  visibility:hidden;
  transition:.25s ease;
}
.lead-modal{
  position:fixed;
  z-index:2001;
  left:50%; top:50%;
  transform:translate(-50%,-48%) scale(.98);
  width:min(860px,92vw);
  background:var(--card-bg);
  border:1px solid var(--border-color);
  border-radius:22px;
  box-shadow:0 30px 90px rgba(0,0,0,.45);
  opacity:0;
  visibility:hidden;
  transition:.25s ease;
}
.lead-backdrop.active{ opacity:1; visibility:visible; }
.lead-modal.active{ opacity:1; visibility:visible; transform:translate(-50%,-50%) scale(1); }
.lead-modal-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:20px;
  padding:26px 28px 18px;
  border-bottom:1px solid var(--border-color);
}
.lead-kicker{
  display:inline-flex;
  font-family:var(--font-heading);
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
  font-size:.75rem;
  color:var(--text-secondary);
}
.lead-modal-title h3{ margin-top:6px; font-size:1.6rem; }
.lead-modal-title p{
  margin-top:6px;
  color:var(--text-secondary);
  font-weight:650;
  line-height:1.6;
  max-width:520px;
}
.lead-close{
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid var(--border-color);
  background:var(--bg-secondary);
  color:var(--text-primary);
  cursor:pointer;
  transition:var(--transition);
  display:flex; align-items:center; justify-content:center;
}
.lead-close:hover{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--text-on-accent);
  transform:rotate(90deg);
}
.lead-form{ padding:22px 28px 28px; }
.lead-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.lead-field{ display:flex; flex-direction:column; gap:8px; }
.lead-field--full{ grid-column:1 / -1; }
.lead-field span{
  font-family:var(--font-heading);
  font-weight:900;
  font-size:.75rem;
  letter-spacing:1px;
  color:var(--text-secondary);
  text-transform:uppercase;
}
.lead-field input,
.lead-field select,
.lead-field textarea{
  width:100%;
  padding:14px 14px;
  border-radius:14px;
  border:1px solid var(--border-color);
  background:var(--bg-secondary);
  color:var(--text-primary);
  font-weight:650;
  outline:none;
  transition:var(--transition);
}
.lead-field textarea{ resize:vertical; min-height:120px; }
.lead-field input:focus,
.lead-field select:focus,
.lead-field textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 6px rgba(204,255,0,.12);
  background:var(--card-bg);
}
.lead-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:18px;
  flex-wrap:wrap;
}
.lead-note{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--text-secondary);
  font-weight:750;
}
.lead-success{
  margin-top:18px;
  border:1px solid var(--border-color);
  background:var(--bg-secondary);
  border-radius:16px;
  padding:16px;
}

/* responsive */
@media (max-width:1024px){
  .desktop-nav{ display:none !important; }
  .mobile-nav{ display:flex; }
  .about-grid{ grid-template-columns:1fr; }
  .about-stats{ grid-template-columns:1fr 1fr; }
}
@media (max-width:768px){
  .hero-title{ font-size:2.8rem; }
  .about-stats{ grid-template-columns:1fr; }

  .footer-grid--extended{ grid-template-columns:1fr; text-align:center; }
  .footer-bottom{ flex-direction:column; gap:20px; text-align:center; }

  .offcanvas-panel{ width:100%; right:-100%; }
  .offcanvas-header,.offcanvas-body,.offcanvas-footer{ padding-left:25px; padding-right:25px; }

  .proj-card{ width:300px; }
  .proj-card img{ height:220px; }
  .test-card{ width:320px; }

  .pill-inner{ width:95%; padding:10px 20px; }
  .main-content-wrapper{ margin-bottom:0 !important; border-radius:0; }
  .footer-reveal{ position:relative; padding:60px 0 30px; border-top:none; }
  .mouse-glow-effect{ display:none; }
  .lead-grid{ grid-template-columns:1fr; }
}

/* =========================================================
   ABOUT PAGE (page-about.php)
   ========================================================= */
/* Ensure list styling is reset without breaking dropdown layout */
.nav-links .menu > li{list-style:none;margin:0;padding:0;}
.nav-links .menu > li::marker{content:'';}
.nav-links .menu > li > a{display:inline-flex}

/* Inner hero for pages */
.inner-hero{min-height:80vh;padding:180px 0 80px;justify-content:center}
.hero-office-images{
  position:absolute; top:0; bottom:0; width:250px;
  display:flex; flex-direction:column; gap:30px;
  opacity:0.12; pointer-events:none; z-index:0;
  mask-image:linear-gradient(to bottom, transparent 0%, black 20%, black 80%, transparent 100%);
  -webkit-mask-image:linear-gradient(to bottom, transparent 0%, black 20%, black 80%, transparent 100%);
  transition:opacity .4s ease;
}
body.dark-theme .hero-office-images{opacity:0.25}
.hero-office-images.left{left:2%;transform:translateY(-20px) rotate(-3deg)}
.hero-office-images.right{right:2%;transform:translateY(20px) rotate(3deg)}
.hero-office-images img{
  width:100%; height:320px; object-fit:cover; border-radius:20px;
  filter:grayscale(100%);
}

.manifesto-section{padding:150px 0}
.huge-quote-icon{width:80px;height:80px;color:var(--accent);opacity:0.3;margin-bottom:30px}
.manifesto-text{
  font-family:var(--font-heading);
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:800; line-height:1.4;
  color:var(--text-primary);
  max-width:1000px;margin:0 auto;
  text-transform:none; letter-spacing:-1px;
}

.founder-section{padding:140px 0}
.founder-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:stretch}
.founder-image-wrapper{
  position:relative;border-radius:24px;overflow:hidden;
  border:1px solid var(--border-color);
  background:var(--card-bg);
  height:100%;min-height:500px;
}
.founder-image-wrapper img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(80%) contrast(1.1);transition:var(--transition)}
.founder-image-wrapper:hover img{filter:grayscale(0%) contrast(1);transform:scale(1.03)}
.founder-overlay{position:absolute;bottom:0;left:0;width:100%;padding:30px;background:linear-gradient(to top, rgba(0,0,0,0.9), rgba(0,0,0,0));color:#fff}
.founder-overlay h4{font-size:1.5rem;margin-bottom:5px;color:#fff}
.founder-overlay p{color:var(--accent);font-family:var(--font-heading);font-size:0.9rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}

.founder-text-wrapper{
  background:var(--card-bg);
  padding:50px;border-radius:24px;border:1px solid var(--border-color);
  box-shadow:var(--soft-shadow);
  height:100%;display:flex;flex-direction:column;justify-content:center;
}
.founder-title{font-size:clamp(1.8rem,3vw,2.4rem);line-height:1.2;margin-bottom:25px}
.founder-desc{font-size:1.1rem;line-height:1.7;color:var(--text-secondary);margin-bottom:20px;font-weight:500}

.founder-stats{display:flex;gap:30px;flex-wrap:wrap;border-top:1px solid var(--border-color);padding-top:30px;margin-top:auto}
.f-stat{display:flex;align-items:center;gap:12px}
.f-stat span{font-weight:700;color:var(--text-primary);font-size:0.95rem}

.values-section{padding:140px 0}
.values-bento-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:1000px;margin-inline:auto}
.value-card{background:var(--card-bg);border:1px solid var(--border-color);padding:40px;border-radius:20px;box-shadow:var(--soft-shadow);transition:var(--transition)}
.value-card:hover{border-color:var(--accent);transform:translateY(-5px)}
.v-icon{width:60px;height:60px;background:var(--bg-secondary);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:25px;transition:var(--transition)}
.v-icon i{color:var(--text-primary);width:30px;height:30px;transition:var(--transition)}
.value-card:hover .v-icon{background:var(--accent-glow)}
.value-card:hover .v-icon i{color:var(--accent)}
.value-card h3{font-size:1.3rem;margin-bottom:15px}
.value-card p{color:var(--text-secondary);line-height:1.6;font-weight:500}

.cta-section{padding:140px 0}
.massive-title{font-size:clamp(3rem,7vw,6rem);line-height:1.1;margin-bottom:20px}
.cta-actions{display:flex;flex-direction:column;align-items:center}

.sl-about-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  padding:30px;color:var(--text-secondary);
  background:var(--bg-secondary);
}

@media (max-width: 1024px){
  .founder-grid{grid-template-columns:1fr;gap:40px}
  .founder-image-wrapper{min-height:400px}
  .hero-office-images{display:none}
}
@media (max-width: 768px){
  .values-bento-grid{grid-template-columns:1fr}
  .manifesto-text{font-size:1.6rem}
  .founder-text-wrapper{padding:30px}
  .founder-stats{flex-direction:column;align-items:flex-start;gap:15px}
}


/* ===========================
   Media Group template
   =========================== */
.page-template-page-media-group .main-content-wrapper{
  margin-bottom:500px;
}
@media (max-width:768px){
  .page-template-page-media-group .main-content-wrapper{ margin-bottom:0 !important; border-radius:0; }
}

/* Hero background pattern + side marquees */
.media-hero{ position:relative; overflow:hidden; }
.media-bg-pattern{
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 15% 20%, rgba(204,255,0,.18) 0%, rgba(0,0,0,0) 45%),
    radial-gradient(circle at 85% 30%, rgba(204,255,0,.12) 0%, rgba(0,0,0,0) 55%);
  pointer-events:none;
  z-index:0;
}
.media-hero .container{ position:relative; z-index:2; }

.hero-side-marquees{
  position:absolute; inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.65;
}
.side-marquee{
  position:absolute;
  top:0; bottom:0;
  width:84px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.side-marquee.left{ left:12px; }
.side-marquee.right{ right:12px; }
.side-track{
  display:flex;
  flex-direction:column;
  gap:30px;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  font-family:var(--font-heading);
  font-weight:900;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--text-secondary);
  font-size:.9rem;
  opacity:.9;
}
.side-track span{ padding:16px 0; }
.track-down{ animation:sl_side_down 20s linear infinite; }
.track-up{ animation:sl_side_up 20s linear infinite; }
@keyframes sl_side_down{ from{ transform:translateY(-35%); } to{ transform:translateY(35%); } }
@keyframes sl_side_up{ from{ transform:translateY(35%); } to{ transform:translateY(-35%); } }

@media (max-width:1024px){
  .hero-side-marquees{ display:none; }
}

/* Stats */
.stats-section{ padding:120px 0; }
.huge-stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.stat-big-card{
  position:relative;
  border:1px solid var(--border-color);
  background:var(--card-bg);
  border-radius:22px;
  padding:34px 28px;
  overflow:hidden;
  box-shadow:var(--soft-shadow);
  transition:var(--transition);
}
.stat-big-card:hover{
  border-color:var(--accent);
  transform:translateY(-5px);
  box-shadow:0 20px 40px -15px var(--accent-glow);
}
.stat-number{
  font-family:var(--font-heading);
  font-weight:900;
  font-size:2.5rem;
  letter-spacing:-1px;
  line-height:1;
}
.stat-label{
  margin-top:10px;
  color:var(--text-secondary);
  font-weight:750;
  line-height:1.4;
}
.stat-bg-icon{
  position:absolute;
  right:-10px; bottom:-10px;
  width:120px; height:120px;
  opacity:.08;
}
@media (max-width:1024px){
  .huge-stats-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .huge-stats-grid{ grid-template-columns:1fr; }
  .stat-number{ font-size:2.2rem; }
}

/* Packages */
.advertising-packages-section{ padding:120px 0; }
.ad-packages-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
}
.ad-card{
  border:1px solid var(--border-color);
  background:var(--card-bg);
  border-radius:22px;
  padding:34px 30px;
  transition:var(--transition);
}
.ad-card:hover{
  border-color:var(--accent);
  transform:translateY(-6px);
  box-shadow:0 20px 40px -15px var(--accent-glow);
}
.ad-icon{
  width:62px; height:62px;
  border-radius:18px;
  background:var(--bg-secondary);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  transition:var(--transition);
}
.ad-icon i{ width:30px; height:30px; }
.ad-card:hover .ad-icon{ background:var(--accent-glow); }
.ad-card h3{ font-size:1.35rem; margin-bottom:10px; }
.ad-desc{
  color:var(--text-secondary);
  line-height:1.65;
  font-weight:650;
  margin-bottom:16px;
}
.ad-features{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.ad-features li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:var(--text-secondary);
  font-weight:650;
  line-height:1.5;
}
.ad-features i{ color:var(--accent); stroke-width:2.6px; margin-top:2px; }

@media (max-width:1024px){
  .ad-packages-grid{ grid-template-columns:1fr; }
}

/* Local power */
.local-power-section{ padding:120px 0; }
.grid-2-columns{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:34px;
  align-items:center;
}
.rounded-img{
  width:100%;
  height:auto;
  border-radius:24px;
  border:1px solid var(--border-color);
  display:block;
}
.btn-outline-primary{
  border:1px solid var(--border-color);
  background:transparent;
  color:var(--text-primary);
  font-family:var(--font-heading);
  font-weight:900;
  font-size:.92rem;
  padding:16px 28px;
  border-radius:999px;
  cursor:pointer;
  letter-spacing:.5px;
  text-transform:uppercase;
  transition:var(--transition);
}
.btn-outline-primary:hover{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--text-on-accent);
  transform:translateY(-2px);
  box-shadow:0 12px 34px var(--accent-glow);
}
@media (max-width:1024px){
  .grid-2-columns{ grid-template-columns:1fr; }
}


/* =========================
   404 + Single Post styling
   ========================= */
.sl-404{ padding: 160px 0 140px; }
.sl-404-code{
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: clamp(4rem, 10vw, 8rem);
  line-height: 1;
  letter-spacing: -2px;
  color: var(--accent);
  text-shadow: 0 10px 40px var(--accent-glow);
  margin-bottom: 10px;
}
.sl-404-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.sl-404-search form{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top: 10px; }
.sl-404-search input[type="search"]{
  width: min(520px, 92vw);
  padding: 14px 16px;
  border-radius: 999px;
  border: 1px solid var(--border-color);
  background: var(--bg-secondary);
  color: var(--text-primary);
  outline: none;
}
.sl-404-search input[type="submit"]{
  padding: 14px 22px;
  border-radius: 999px;
  border: 1px solid var(--border-color);
  background: var(--card-bg);
  color: var(--text-primary);
  font-family: var(--font-heading);
  font-weight: 800;
  cursor: pointer;
  transition: var(--transition);
}
.sl-404-search input[type="submit"]:hover{
  background: var(--accent);
  color: var(--text-on-accent);
  border-color: var(--accent);
}

/* Single post */
.sl-single{ padding: 160px 0 120px; }
.sl-article{ max-width: 920px; margin: 0 auto; }
.sl-article-meta{
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: .85rem;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 16px;
}
.sl-meta-dot{ opacity: .6; }
.sl-article-title{
  font-family: var(--font-heading);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -1px;
  font-size: clamp(2rem, 4.2vw, 3.4rem);
  line-height: 1.1;
  margin-bottom: 26px;
}
.sl-article-thumb{
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--border-color);
  background: var(--card-bg);
  margin: 0 auto 34px;
}
.sl-article-thumb img{ width:100%; height:auto; display:block; }

.sl-article-content{
  border: 1px solid var(--border-color);
  background: var(--card-bg);
  border-radius: 22px;
  padding: 34px;
  box-shadow: var(--soft-shadow);
}
.sl-article-content :is(p, li){ color: var(--text-secondary); font-size: 1.05rem; line-height: 1.8; font-weight: 500; }
.sl-article-content h2, .sl-article-content h3{ margin-top: 28px; margin-bottom: 12px; }
.sl-article-content a{ text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 4px; }
.sl-post-nav{
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  margin-top: 28px;
}
.sl-post-nav a{
  display:inline-flex;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid var(--border-color);
  background: var(--bg-secondary);
  font-family: var(--font-heading);
  font-weight: 800;
  text-transform: uppercase;
  font-size: .85rem;
  transition: var(--transition);
}
.sl-post-nav a:hover{
  background: var(--accent);
  color: var(--text-on-accent);
  border-color: var(--accent);
}

/* =========================================
   PORTFOLIO (Projects archive)
   ========================================= */
.portfolio-showcase-section{ padding: 80px 0 140px; }
.portfolio-filters{ display:flex; justify-content:center; flex-wrap:wrap; gap: 15px; margin-top: 40px; }
.filter-btn{
  background: var(--card-bg);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  padding: 12px 28px;
  border-radius: 999px;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: .9rem;
  text-transform: uppercase;
  cursor:pointer;
  transition: var(--transition);
  box-shadow: var(--soft-shadow);
}
.filter-btn:hover{ border-color: var(--accent); }
.filter-btn.active{ background: var(--accent); color: var(--text-on-accent); border-color: var(--accent); box-shadow: 0 4px 15px var(--accent-glow); }

.portfolio-showcase-grid{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 40px; }
.portfolio-showcase-grid .port-card{
  position: relative;
  border-radius: 24px;
  overflow:hidden;
  background: var(--bg-primary);
  cursor:pointer;
  transform: scale(1);
  transition: transform .4s cubic-bezier(.4,0,.2,1), opacity .4s ease;
  display:block;
}
.portfolio-showcase-grid .port-card.hidden{ display:none; }
.port-image{ width: 100%; aspect-ratio: 4/3; overflow:hidden; border-radius: 24px; }
.port-image img{ width:100%; height:100%; object-fit:cover; transition: transform .8s cubic-bezier(.16,1,.3,1); }
.portfolio-showcase-grid .port-card:hover .port-image img{ transform: scale(1.05); }

.port-overlay{
  position:absolute;
  bottom:0; left:0;
  width:100%;
  padding: 40px 30px;
  background: linear-gradient(to top, rgba(9,9,11,.95) 0%, rgba(9,9,11,.7) 60%, rgba(0,0,0,0) 100%);
  color:#fff;
  transform: translateY(10px);
  opacity:0;
  transition: all .4s cubic-bezier(.4,0,.2,1);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
.portfolio-showcase-grid .port-card:hover .port-overlay{ transform: translateY(0); opacity:1; }
.port-cat{ font-family: var(--font-heading); font-size: .8rem; font-weight: 800; color: var(--accent); text-transform: uppercase; letter-spacing: 2px; display:block; margin-bottom: 10px; }
.port-overlay h3{ font-size: 2rem; margin-bottom: 10px; color:#fff; }
.port-overlay p{ font-size: 1.05rem; color: #a1a1aa; margin-bottom: 20px; line-height: 1.5; }
.port-tech{ display:flex; gap:10px; flex-wrap:wrap; }
.port-tech span{ background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); padding: 6px 14px; border-radius: 999px; font-family: var(--font-heading); font-size: .75rem; font-weight: 700; color:#fff; text-transform: uppercase; letter-spacing: 1px; }

/* =========================================
   CASE STUDY (Projects single)
   ========================================= */
.cs-hero{ padding: 180px 0 80px; position: relative; }
.cs-main-image{ width: 100%; border-radius: 24px; overflow:hidden; border: 1px solid var(--border-color); background: var(--card-bg); box-shadow: var(--soft-shadow); }
.cs-main-image img{ width:100%; height:auto; max-height: 700px; object-fit: cover; display:block; }

.cs-meta-section{ padding: 40px 0 80px; }
.cs-meta-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 30px; padding: 40px 0; }
.meta-item h4{ font-family: var(--font-heading); font-size: .85rem; color: var(--text-secondary); margin-bottom: 10px; text-transform: uppercase; letter-spacing: 1px; }
.meta-item p{ font-family: var(--font-heading); font-weight: 800; font-size: 1.3rem; color: var(--text-primary); margin-bottom: 5px; }
.meta-item span{ font-size: .95rem; color: var(--accent); font-weight: 600; }

.cs-story-section{ padding: 60px 0 120px; }
.cs-story-content{ border: 1px solid var(--border-color); background: var(--card-bg); border-radius: 24px; padding: 34px; box-shadow: var(--soft-shadow); }
.cs-story-content :is(p, li){ color: var(--text-secondary); font-size: 1.05rem; line-height: 1.8; font-weight: 500; }
.cs-story-content h2, .cs-story-content h3{ margin-top: 22px; margin-bottom: 12px; }
.cs-story-content a{ text-decoration: underline; text-underline-offset: 4px; }

.cs-results-section{ padding: 120px 0; }
.cs-results-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.cs-result-card{ background: var(--card-bg); border: 1px solid var(--border-color); padding: 50px 30px; border-radius: 24px; text-align:center; transition: var(--transition); box-shadow: var(--soft-shadow); }
.cs-result-card:hover{ border-color: var(--accent); transform: translateY(-5px); }
.cs-result-card h3{ font-size: clamp(3rem, 5vw, 4.5rem); margin-bottom: 15px; line-height: 1; }
.cs-result-card p{ color: var(--text-secondary); font-size: 1.1rem; font-weight: 600; }

.cs-next-project{ padding: 150px 0; }
.cs-next-label{ font-family: var(--font-heading); color: var(--text-secondary); font-weight: 800; font-size: .9rem; letter-spacing: 2px; margin-bottom: 20px; text-transform: uppercase; }
.cs-next-title{ font-family: var(--font-heading); font-weight: 900; font-size: clamp(2.5rem, 6vw, 6rem); color: var(--text-primary); display:inline-flex; align-items:center; gap: 20px; transition: var(--transition); }
.cs-next-title i{ width: clamp(40px, 6vw, 80px); height: clamp(40px, 6vw, 80px); color: var(--border-color); transition: var(--transition); }
.cs-next-title:hover{ color: var(--accent); }
.cs-next-title:hover i{ color: var(--accent); transform: translateX(20px); }

@media (max-width: 768px){
  .sl-single{ padding: 140px 0 90px; }
  .sl-article-content{ padding: 22px; }

  .portfolio-showcase-grid{ grid-template-columns: 1fr; }
  .port-image{ aspect-ratio: 1/1; }
  .port-overlay{ opacity: 1; transform: translateY(0); padding: 30px 20px; background: linear-gradient(to top, rgba(9,9,11,.95) 0%, rgba(9,9,11,.4) 100%); }
  .port-overlay h3{ font-size: 1.5rem; }

  .cs-meta-grid{ grid-template-columns: 1fr; gap: 22px; }
  .cs-results-grid{ grid-template-columns: 1fr; }
  .cs-next-project{ padding: 100px 0; }
}



/* Thumbnails and hero images */
.proj-card img{object-position:top center}
.project-hero-image img{object-position:top center}
