/* ═══════════════════════════════════════════════════════════════════
   CE Orbit — Public Site Design System
   Glassmorphism — Translucent surfaces, gradient accents, animated orbs
   ═══════════════════════════════════════════════════════════════════ */

/* ── Reset ─────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── Tokens ────────────────────────────────────────────────────────── */
:root{
  /* Surfaces */
  --bg:#06050f;
  --bg-2:rgba(18,14,40,0.5);
  --bg-3:rgba(30,25,60,0.4);
  --bg-elevated:rgba(18,14,40,0.7);
  --surface:rgba(255,255,255,0.04);
  --surface-hover:rgba(255,255,255,0.08);

  /* Borders */
  --border:rgba(255,255,255,0.06);
  --border-hover:rgba(255,255,255,0.14);

  /* Text */
  --text:#f0eef8;
  --text-m:#9b95b5;
  --text-d:#5b4f7c;

  /* Accent — Purple / Cyan gradient like ceconferences */
  --accent:#a855f7;
  --accent-hover:#c084fc;
  --accent-secondary:#22d3ee;
  --accent-bg:rgba(168,85,247,0.08);
  --accent-subtle:rgba(168,85,247,0.15);
  --accent-glow:rgba(168,85,247,0.4);
  --gradient:linear-gradient(135deg,#a855f7,#22d3ee);

  /* Utility */
  --success:#22c55e;
  --warn:#f59e0b;
  --danger:#ef4444;

  /* Typography */
  --font:'Outfit','Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono','Fira Code',monospace;

  /* Spacing & shape */
  --radius:12px;
  --radius-lg:16px;
  --radius-xl:22px;
  --transition:all 0.3s ease;
  --max-w:1200px;
  --glass-blur:blur(20px) saturate(180%);

  /* Motion — cards & hovers (uniform, smooth handoff between adjacent tiles) */
  --ease-card:cubic-bezier(0.4,0,0.2,1);
  --duration-card:0.28s;
}

/* Light mode */
[data-theme="light"]{
  --bg:#faf8ff;
  --bg-2:rgba(255,255,255,0.6);
  --bg-3:rgba(245,240,255,0.5);
  --bg-elevated:rgba(255,255,255,0.85);
  --surface:rgba(255,255,255,0.5);
  --surface-hover:rgba(255,255,255,0.7);
  --border:rgba(0,0,0,0.08);
  --border-hover:rgba(0,0,0,0.15);
  --text:#1a0e3a;
  --text-m:#5b4f7c;
  --text-d:#9b95b5;
  --accent:#7c3aed;
  --accent-hover:#6d28d9;
  --accent-secondary:#0891b2;
  --accent-bg:rgba(124,58,237,0.06);
  --accent-subtle:rgba(124,58,237,0.12);
  --accent-glow:rgba(124,58,237,0.2);
  --gradient:linear-gradient(135deg,#7c3aed,#0891b2);
}

/* Anti-flicker: suppress transitions on initial load until theme is applied */
.no-transitions,.no-transitions *,.no-transitions *::before,.no-transitions *::after{transition:none!important}

/* ── Base ──────────────────────────────────────────────────────────── */
html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  position:relative;
  animation:pageIn 0.5s ease-out;
}
@keyframes pageIn{from{opacity:0}to{opacity:1}}
@media(prefers-reduced-motion:reduce){body{animation:none}}
a{color:var(--accent);text-decoration:none;transition:color 0.3s ease}
a:hover{color:var(--accent-hover)}
button{cursor:pointer;font-family:inherit}
img{display:block;max-width:100%}
::selection{background:var(--accent-subtle);color:var(--accent)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ── Orbit-themed background ──────────────────────────────────────── */
.page-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:hidden}
.orbit-ring{
  position:absolute;
  top:50%;left:50%;
  border-radius:50%;
  border:1px solid rgba(168,85,247,0.22);
  box-sizing:border-box;
  opacity:0.85;
  animation:orbitSpin 24s linear infinite;
}
.orbit-ring-1{width:min(88vmax,880px);height:min(88vmax,880px);margin-left:min(-44vmax,-440px);margin-top:min(-44vmax,-440px)}
.orbit-ring-2{width:min(62vmax,620px);height:min(45vmax,450px);margin-left:min(-31vmax,-310px);margin-top:min(-22.5vmax,-225px);animation-duration:32s;animation-direction:reverse;border-color:rgba(34,211,238,0.2);opacity:0.7}
.orbit-ring-3{width:min(48vmax,480px);height:min(48vmax,480px);margin-left:min(-24vmax,-240px);margin-top:min(-24vmax,-240px);animation-duration:28s;border-color:rgba(168,85,247,0.15)}
[data-theme="light"] .orbit-ring{border-color:rgba(168,85,247,0.15);opacity:0.5}
[data-theme="light"] .orbit-ring-2{border-color:rgba(34,211,238,0.12)}
@keyframes orbitSpin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.orbit-ring{animation:none}}

/* ── Typography ────────────────────────────────────────────────────── */
h1,h2,h3,h4{font-weight:700;letter-spacing:-.02em;line-height:1.2}
h1{font-size:clamp(2.25rem,5vw,3.75rem)}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.5rem)}
h4{font-size:1.125rem}
p{color:var(--text-m)}

.text-accent{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.text-balance{text-wrap:balance}
.text-sm{font-size:.875rem}
.text-xs{font-size:.75rem}
.text-mono{font-family:var(--mono)}
.gradient-text{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ── Layout ────────────────────────────────────────────────────────── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px;position:relative;z-index:1}
.container-sm{max-width:720px}
.container-lg{max-width:1400px}
section{padding:100px 0;position:relative}

/* Flex / Grid helpers */
.flex{display:flex}.flex-col{flex-direction:column}
.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.gap-sm{gap:8px}.gap-md{gap:16px}.gap-lg{gap:24px}.gap-xl{gap:40px}
.grid{display:grid}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-auto{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}

/* ── Navigation (Glassmorphism) ────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(6,5,15,0.4);
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  border-bottom:1px solid var(--border);
  transition:background .3s,box-shadow .3s;
}
.nav.scrolled{background:rgba(6,5,15,0.8);box-shadow:0 4px 30px rgba(0,0,0,0.3)}
[data-theme="light"] .nav{background:rgba(250,248,255,0.6)}
[data-theme="light"] .nav.scrolled{background:rgba(250,248,255,0.85);box-shadow:0 4px 20px rgba(0,0,0,0.06)}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max-w);margin:0 auto;padding:0 24px;height:64px;
}
.nav-logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.02em;text-decoration:none}
.orbit-mark{display:inline-flex;flex-shrink:0;line-height:0}
.orbit-mark svg{width:32px;height:32px;display:block}
.orbit-mark-footer svg{width:28px;height:28px}
.nav-logo-text{display:inline-block}
.nav-logo .nav-logo-text span{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
@media(max-width:600px){.nav-logo-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}}
.nav-links{display:flex;align-items:center;gap:8px;list-style:none}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--text-m);padding:6px 14px;border-radius:50px;
  transition:color 0.2s ease,background 0.2s ease,transform 0.2s ease;position:relative;
}
.nav-links a:hover{color:var(--text);background:rgba(168,85,247,0.08);transform:translateY(-1px)}
.nav-links a.active{color:var(--text)}
.nav-links a.active::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:20px;height:2px;background:var(--gradient);border-radius:1px;
}
.nav-actions{display:flex;align-items:center;gap:12px}
.theme-toggle{
  background:none;border:none;color:var(--text-m);
  font-size:16px;padding:8px;border-radius:var(--radius);
  transition:var(--transition);
}
.theme-toggle:hover{color:var(--text);background:var(--surface-hover)}
.install-app-btn{
  display:none;
  align-items:center;gap:0.4rem;
  padding:7px 14px;border-radius:50px;
  border:1px solid var(--border);background:rgba(168,85,247,0.1);
  color:var(--text);font-size:13px;font-weight:600;
  font-family:var(--font);cursor:pointer;transition:all 0.2s ease;
}
.install-app-btn:hover{border-color:rgba(168,85,247,0.3);background:rgba(168,85,247,0.18);transform:translateY(-1px)}
.install-app-btn i{font-size:12px}
@media(max-width:768px){
  .install-app-btn.mobile-visible{display:inline-flex}
}
.nav-cta{
  padding:8px 22px;background:var(--gradient);color:#fff;
  border-radius:50px;font-size:14px;font-weight:600;
  border:none;transition:transform 0.25s ease,box-shadow 0.3s ease;
  box-shadow:0 4px 16px var(--accent-glow);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--accent-glow),0 0 20px rgba(168,85,247,0.15);color:#fff}

/* Mobile menu */
.mobile-menu-btn{display:none;background:none;border:none;color:var(--text);font-size:20px;padding:8px}
.mobile-menu{
  position:fixed;top:0;right:-100%;
  width:min(78vw,320px);height:100vh;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(18,14,40,0.94) 0%,rgba(6,5,15,0.96) 100%);
  backdrop-filter:blur(24px) saturate(150%);-webkit-backdrop-filter:blur(24px) saturate(150%);
  border-left:1px solid var(--border);
  padding:5.5rem 1.2rem 1.5rem;
  gap:0.5rem;overflow-y:auto;
  transition:right 0.3s cubic-bezier(.4,0,.2,1);
  box-shadow:-16px 0 40px rgba(0,0,0,0.35);
  z-index:1001;
}
[data-theme="light"] .mobile-menu{
  background:linear-gradient(180deg,rgba(255,255,255,0.96) 0%,rgba(244,237,255,0.98) 100%);
  box-shadow:-12px 0 30px rgba(50,23,94,0.1);
}
.mobile-menu.open{right:0}
.mobile-menu-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:0.5rem;padding:0 0.5rem 0.75rem;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
[data-theme="light"] .mobile-menu-header{border-bottom-color:rgba(0,0,0,0.06)}
.mobile-menu-title{
  font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-d);
}
.mobile-menu-close{
  background:none;border:none;color:var(--text-m);
  font-size:1.25rem;padding:0.5rem;line-height:1;
  cursor:pointer;border-radius:var(--radius);
  transition:var(--transition);
}
.mobile-menu-close:hover{color:var(--text);background:rgba(255,255,255,0.06)}
.mobile-menu a{
  display:flex;align-items:center;width:100%;padding:0.9rem 1rem;
  border-radius:16px;border:1px solid rgba(255,255,255,0.04);
  background:rgba(255,255,255,0.02);
  font-size:15px;color:var(--text-m);transition:all 0.2s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03);
}
[data-theme="light"] .mobile-menu a{border-color:rgba(0,0,0,0.04);background:rgba(0,0,0,0.02);box-shadow:none}
.mobile-menu a:hover{
  background:rgba(168,85,247,0.1);border-color:rgba(168,85,247,0.18);
  color:var(--text);transform:translateX(-2px);
}
/* Overlay is body.menu-open::before in mobile media query (below) – no separate backdrop div */

/* ── Buttons ───────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 26px;border-radius:50px;
  font-size:14px;font-weight:600;border:none;
  transition:var(--transition);text-decoration:none;
  cursor:pointer;font-family:var(--font);
}
.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 4px 20px var(--accent-glow);transition:transform 0.25s ease,box-shadow 0.3s ease}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 36px var(--accent-glow),0 0 24px rgba(168,85,247,0.2);color:#fff}
.btn-secondary{background:transparent;color:var(--text-m);border:2px solid var(--border);transition:transform 0.25s ease,border-color 0.25s ease,color 0.2s ease}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-lg{padding:14px 32px;font-size:15px}
.btn-sm{padding:6px 16px;font-size:13px}

/* ── Hero ──────────────────────────────────────────────────────────── */
.hero{
  padding:180px 0 140px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-300px;left:50%;transform:translateX(-50%);
  width:800px;height:800px;
  background:radial-gradient(circle,rgba(168,85,247,0.12) 0%,rgba(34,211,238,0.06) 40%,transparent 70%);
  pointer-events:none;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 20px;
  background:rgba(168,85,247,0.08);
  border:1px solid rgba(168,85,247,0.2);
  border-radius:999px;font-size:13px;font-weight:600;
  color:var(--accent);margin-bottom:28px;
  backdrop-filter:blur(8px);
}
.hero h1{margin-bottom:20px;position:relative}
.hero .subtitle{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--text-m);max-width:640px;margin:0 auto 24px}
.hero-contact-bar{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;
  max-width:720px;margin:0 auto 28px;
}
.contact-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:999px;
  font-size:13px;font-weight:600;color:var(--text-m);
  background:var(--surface);
  border:1px solid var(--border);
  text-decoration:none;
  box-shadow:0 2px 12px rgba(0,0,0,0.08),inset 0 1px 0 rgba(255,255,255,0.05);
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  transition:transform var(--duration-card) var(--ease-card),border-color 0.2s ease,box-shadow 0.2s ease,color 0.2s ease,background 0.2s ease;
}
.contact-pill i{font-size:14px;opacity:0.9;flex-shrink:0}
.contact-pill span{line-height:1.2}
.contact-pill:hover{
  color:var(--text);
  border-color:rgba(168,85,247,0.35);
  box-shadow:0 8px 28px rgba(0,0,0,0.14),0 0 24px rgba(168,85,247,0.12);
  transform:translateY(-2px);
}
.contact-pill:focus-visible{outline:2px solid var(--accent-secondary);outline-offset:2px}
.contact-pill--whatsapp{
  color:#e8fff0;
  background:rgba(37,211,102,0.12);
  border-color:rgba(37,211,102,0.35);
}
.contact-pill--whatsapp:hover{
  color:#fff;
  background:rgba(37,211,102,0.22);
  border-color:rgba(37,211,102,0.55);
  box-shadow:0 8px 28px rgba(0,0,0,0.14),0 0 28px rgba(37,211,102,0.2);
}
[data-theme="light"] .contact-pill{background:rgba(255,255,255,0.75);color:var(--text-m)}
[data-theme="light"] .contact-pill:hover{color:var(--text)}
[data-theme="light"] .contact-pill--whatsapp{color:#0d4d2a}
[data-theme="light"] .contact-pill--whatsapp:hover{color:#063a1f}
.contact-pill--block{width:100%;justify-content:center}
.mobile-menu-contact{
  margin-top:auto;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,0.08);
  display:flex;flex-direction:column;gap:0.5rem;
}
[data-theme="light"] .mobile-menu-contact{border-top-color:rgba(0,0,0,0.08)}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:2}
.hero-actions .btn{backface-visibility:hidden;will-change:transform}

/* ── Section Header ────────────────────────────────────────────────── */
.section-header{text-align:center;max-width:640px;margin:0 auto 60px}
.section-header .overline{
  display:inline-block;font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;
  background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:12px;
}
.section-header h2{margin-bottom:12px}
.section-header p{color:var(--text-m);font-size:1.0625rem}
.section-header p a{color:var(--accent);text-decoration:none;font-weight:500}
.section-header p a:hover{text-decoration:underline}

/* ── Glass Card (shared) ───────────────────────────────────────────── */
.glass-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  box-shadow:0 8px 32px rgba(0,0,0,0.15),inset 0 1px 0 rgba(255,255,255,0.05);
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card),border-color 0.25s ease,background 0.25s ease;
}
.glass-card:hover{
  background:var(--surface-hover);
  border-color:rgba(168,85,247,0.25);
  box-shadow:0 24px 56px rgba(0,0,0,0.25),inset 0 1px 0 rgba(255,255,255,0.08),0 0 40px rgba(168,85,247,0.15),0 0 80px rgba(34,211,238,0.08);
  transform:translateY(-6px) scale(1.01);
}

/* ── Service Cards ─────────────────────────────────────────────────── */
.service-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:36px;
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  box-shadow:0 8px 32px rgba(0,0,0,0.12),inset 0 1px 0 rgba(255,255,255,0.05);
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card),border-color 0.25s ease;
}
.service-card:hover{
  border-color:rgba(168,85,247,0.3);
  box-shadow:0 20px 50px rgba(0,0,0,0.22),0 0 40px rgba(168,85,247,0.18),0 0 60px rgba(34,211,238,0.1);
  transform:translateY(-8px);
}
.service-icon{
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-bg);border:1px solid rgba(168,85,247,0.15);
  border-radius:var(--radius-lg);
  margin-bottom:20px;font-size:22px;color:var(--accent);
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card);
}
.service-card:hover .service-icon,
a.tool-card.tool-link-card:hover .service-icon{
  transform:scale(1.08);
  box-shadow:0 0 24px rgba(168,85,247,0.25);
}
.service-card h3{margin-bottom:8px}
.service-card p{font-size:14px;margin-bottom:0}
.service-card > .btn{margin-top:1.25rem}

/* ── Tool tiles (links) — distinct from static service cards ─────── */
a.service-card.tool-link-card{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  -webkit-tap-highlight-color:rgba(168,85,247,0.15);
}
a.tool-card.tool-link-card{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  -webkit-tap-highlight-color:rgba(168,85,247,0.15);
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:24px;
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  box-shadow:0 8px 32px rgba(0,0,0,0.12),inset 0 1px 0 rgba(255,255,255,0.05);
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card),border-color 0.25s ease;
}
a.tool-card.tool-link-card:hover{
  border-color:rgba(168,85,247,0.3);
  box-shadow:0 20px 50px rgba(0,0,0,0.22),0 0 40px rgba(168,85,247,0.18),0 0 60px rgba(34,211,238,0.1);
  transform:translateY(-8px);
  color:inherit;
}
.tool-link-cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:1.25rem;
  padding:10px 14px;
  border-radius:999px;
  font-size:0.8125rem;
  font-weight:600;
  letter-spacing:0.02em;
  text-transform:uppercase;
  color:var(--text);
  background:linear-gradient(135deg,rgba(168,85,247,0.18),rgba(34,211,238,0.12));
  border:1px solid rgba(168,85,247,0.35);
  box-shadow:0 0 0 1px rgba(255,255,255,0.04) inset;
  transition:background var(--duration-card) var(--ease-card),border-color var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card),transform var(--duration-card) var(--ease-card);
}
.tool-link-cta i{
  font-size:0.75rem;
  opacity:0.9;
  transition:transform var(--duration-card) var(--ease-card);
}
a.service-card.tool-link-card:hover .tool-link-cta,
a.tool-card.tool-link-card:hover .tool-link-cta{
  background:linear-gradient(135deg,rgba(168,85,247,0.28),rgba(34,211,238,0.18));
  border-color:rgba(168,85,247,0.55);
  box-shadow:0 0 20px rgba(168,85,247,0.2),0 0 0 1px rgba(255,255,255,0.06) inset;
}
a.service-card.tool-link-card:hover .tool-link-cta i,
a.tool-card.tool-link-card:hover .tool-link-cta i{
  transform:translateX(4px);
}
a.service-card.tool-link-card:focus-visible,
a.tool-card.tool-link-card:focus-visible{
  outline:2px solid var(--accent-secondary);
  outline-offset:3px;
}
a.service-card.tool-link-card:focus-visible .tool-link-cta,
a.tool-card.tool-link-card:focus-visible .tool-link-cta{
  border-color:var(--accent-secondary);
  box-shadow:0 0 0 3px rgba(34,211,238,0.2);
}

/* Tool listing page typography */
.tool-card h2{font-size:1.05rem;margin-bottom:8px}
.tool-card p{font-size:0.9rem;color:var(--text-m);line-height:1.5;margin-bottom:10px}
.tool-card .soft{font-size:0.85rem;color:var(--text-d);font-style:italic}

/* ── Portfolio Cards ───────────────────────────────────────────────── */
.portfolio-card{
  display:flex;flex-direction:column;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  overflow:hidden;
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card),border-color 0.25s ease;
}
.portfolio-card:hover{
  border-color:rgba(168,85,247,0.25);
  box-shadow:0 24px 56px rgba(0,0,0,0.22),0 0 40px rgba(168,85,247,0.12),0 0 70px rgba(34,211,238,0.08);
  transform:translateY(-8px) scale(1.02);
}
.portfolio-img{
  width:100%;height:220px;
  background:var(--bg-3);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-d);font-size:40px;
  overflow:hidden;
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
}
.portfolio-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.45s var(--ease-card);display:block}
.portfolio-card:hover .portfolio-img img{transform:scale(1.08)}
.portfolio-body{
  flex:1;display:flex;flex-direction:column;min-height:0;
  min-height:160px;padding:24px;
}
.portfolio-body h3{margin-bottom:8px;font-size:1.1rem}
.portfolio-body h3 a{color:inherit;text-decoration:none}
.portfolio-body h3 a:hover{color:var(--accent)}
.portfolio-category{
  display:inline-block;margin-bottom:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:#22d3ee;background:rgba(34,211,238,0.12);border:1px solid rgba(34,211,238,0.3);border-radius:999px;padding:4px 10px;
}
[data-theme="light"] .portfolio-category{color:#0e7490;background:rgba(6,182,212,0.12);border-color:rgba(6,182,212,0.35)}
[data-theme="light"] .portfolio-card{
  background:#fff;
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:0 4px 20px rgba(0,0,0,0.06);
}
[data-theme="light"] .portfolio-card:hover{
  border-color:rgba(124,58,237,0.25);
  box-shadow:0 12px 40px rgba(0,0,0,0.1),0 0 24px rgba(124,58,237,0.08);
}
[data-theme="light"] .portfolio-img{background:rgba(0,0,0,0.04)}
.portfolio-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;flex-shrink:0}
.portfolio-card-buttons{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:16px;flex-shrink:0;
}
.portfolio-card-buttons .portfolio-card-btn{flex:1 1 auto;min-width:0;justify-content:center}
.section-header .btn{margin-top:16px;display:inline-flex;align-items:center;gap:8px}
.portfolio-img-link{display:block;color:inherit;text-decoration:none}
.portfolio-empty{text-align:center;padding:64px 24px;color:var(--text-d)}
.portfolio-empty i{font-size:40px;margin-bottom:12px;display:block;opacity:.6}
.tag{
  display:inline-flex;align-items:center;
  padding:4px 12px;font-size:12px;font-weight:500;
  background:var(--accent-bg);color:var(--accent);border-radius:999px;
  border:1px solid rgba(168,85,247,0.12);
}

/* Portfolio carousel — no extra background; only cards have style */
.portfolio-carousel-outer{display:flex;align-items:center;gap:1rem;position:relative}
.portfolio-carousel-track-wrap{flex:1;overflow:hidden}
.portfolio-carousel-track{
  display:flex;gap:1.5rem;
  transition:transform 0.4s cubic-bezier(0.4,0,0.2,1);will-change:transform;
}
.portfolio-carousel-track .portfolio-card{flex:none;min-width:0}
.portfolio-carousel-btn{
  flex-shrink:0;width:44px;height:44px;border-radius:50%;
  border:1px solid var(--border);background:var(--surface);color:var(--text);
  cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.9rem;
  transition:background .2s,color .2s,border-color .2s,opacity .2s;
}
.portfolio-carousel-btn:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:#fff}
.portfolio-carousel-btn:disabled{opacity:.25;cursor:default;pointer-events:none}
.portfolio-carousel-dots{display:flex;justify-content:center;gap:0.5rem;margin-top:1.25rem}
.portfolio-dot{
  width:8px;height:8px;border-radius:50%;border:none;
  background:rgba(255,255,255,0.2);cursor:pointer;padding:0;
  transition:background .2s,transform .2s;
}
.portfolio-dot.active{background:var(--accent);transform:scale(1.25)}
[data-theme="light"] .portfolio-dot{background:rgba(0,0,0,0.15)}
[data-theme="light"] .portfolio-dot.active{background:var(--accent)}
@media (max-width:639px){
  .portfolio-carousel-outer{gap:0.5rem}
  .portfolio-carousel-track{gap:0}
  .portfolio-carousel-btn{width:40px;height:40px;font-size:0.85rem}
}

/* ── Project detail page ────────────────────────────────────────────── */
.project-detail-page{padding:120px 0 96px;min-height:60vh}
.project-loading,.project-error{text-align:center;padding:64px 24px;color:var(--text-d)}
.project-error .btn{margin-top:16px}
.project-content{max-width:720px;margin:0 auto}
.project-back{display:inline-flex;align-items:center;gap:8px;color:var(--text-d);text-decoration:none;font-size:14px;margin-bottom:24px}
.project-back:hover{color:var(--accent)}
.project-hero-img{margin-bottom:24px;border-radius:var(--radius-xl);overflow:hidden;background:var(--bg-3)}
.project-hero-img img{width:100%;height:auto;max-height:400px;object-fit:cover;display:block}
.project-meta{margin-bottom:12px}
.project-title{font-size:clamp(1.75rem,4vw,2.25rem);margin-bottom:8px;line-height:1.25}
.project-client{font-size:15px;color:var(--text-d);margin-bottom:16px}
.project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.project-description{font-size:1.05rem;line-height:1.75;color:var(--text);white-space:pre-wrap}
.project-actions{margin-top:32px}
.project-view-btn{display:inline-flex;align-items:center;gap:8px}

/* ── Projects list page (all projects) ──────────────────────────────── */
.hero-subpage{padding:120px 0 64px}
.projects-list-page{padding:0 0 96px}
.projects-toolbar{
  display:flex;flex-wrap:wrap;gap:0.75rem;align-items:center;margin-bottom:2rem;
}
.projects-search-wrap{position:relative;flex:1 1 240px;min-width:200px}
.projects-search-wrap i{
  position:absolute;left:0.9rem;top:50%;transform:translateY(-50%);
  color:var(--text-d);font-size:0.9rem;pointer-events:none;
}
.projects-search{
  width:100%;padding:0.65rem 0.85rem 0.65rem 2.4rem;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  color:var(--text);font-size:0.95rem;font-family:inherit;outline:none;transition:border-color .15s;
}
.projects-search::placeholder{color:var(--text-d)}
.projects-search:focus{border-color:var(--accent)}
.projects-filter{
  padding:0.65rem 2rem 0.65rem 0.85rem;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text);font-size:0.9rem;font-family:inherit;
  outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2394a3b8'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .65rem center;transition:border-color .15s;
}
.projects-filter:focus{border-color:var(--accent)}
.projects-filter option{background:#1a1625;color:#e8e4f0}
[data-theme="light"] .projects-filter option{background:#f8f7fc;color:#1a1625}
.projects-count{font-size:0.88rem;color:var(--text-d);white-space:nowrap;margin-left:auto}
.projects-loading,.projects-empty{text-align:center;padding:4rem 1rem;color:var(--text-d)}
.projects-empty i{font-size:2.5rem;opacity:0.5;display:block;margin-bottom:1rem}
.projects-empty .btn{margin-top:12px}
.projects-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.25rem}
.projects-list-item{
  display:flex;gap:1.5rem;align-items:flex-start;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);
  overflow:hidden;transition:border-color var(--duration-card) var(--ease-card),transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card);
}
.projects-list-item:hover{
  border-color:rgba(168,85,247,0.35);transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
}
.projects-list-thumb{
  flex-shrink:0;width:200px;min-height:140px;display:block;background:var(--bg-3);overflow:hidden;
}
.projects-list-thumb-img{width:100%;height:100%;min-height:140px;object-fit:cover;display:block}
.projects-list-thumb-placeholder{
  width:100%;height:140px;display:flex;align-items:center;justify-content:center;color:var(--text-d);font-size:2rem;
}
.projects-list-body{flex:1;padding:1.25rem 1.25rem 1.25rem 0;min-width:0;display:flex;flex-direction:column;gap:0.5rem}
.projects-list-category{
  display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:#22d3ee;background:rgba(34,211,238,0.12);border:1px solid rgba(34,211,238,0.3);border-radius:999px;padding:3px 10px;width:fit-content;
}
[data-theme="light"] .projects-list-category{color:#0e7490;background:rgba(6,182,212,0.12);border-color:rgba(6,182,212,0.35)}
.projects-list-title{font-size:1.15rem;font-weight:700;margin:0;line-height:1.3}
.projects-list-title a{color:inherit;text-decoration:none}
.projects-list-title a:hover{color:var(--accent)}
.projects-list-client{font-size:0.9rem;color:var(--text-d);margin:0}
.projects-list-desc{font-size:0.9rem;color:var(--text);line-height:1.55;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.projects-list-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.projects-list-actions{display:flex;gap:0.6rem;margin-top:auto;flex-wrap:wrap}
.projects-list-actions .btn{font-size:0.83rem;padding:0.45rem 1rem}
@media (max-width:640px){
  .projects-list-item{flex-direction:column}
  .projects-list-thumb{width:100%;min-height:160px}
  .projects-list-thumb-img,.projects-list-thumb-placeholder{min-height:160px}
  .projects-list-body{padding:1rem}
}

/* ── Testimonials ──────────────────────────────────────────────────── */
.testimonial-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:32px;
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  box-shadow:0 8px 32px rgba(0,0,0,0.1);
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card),border-color 0.25s ease;
}
.testimonial-card:hover{
  border-color:rgba(168,85,247,0.2);
  box-shadow:0 20px 48px rgba(0,0,0,0.18),0 0 36px rgba(168,85,247,0.12);
  transform:translateY(-6px);
}
.testimonial-quote{font-size:15px;line-height:1.7;color:var(--text);margin-bottom:20px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--accent-bg);display:flex;align-items:center;
  justify-content:center;color:var(--accent);font-size:14px;
  overflow:hidden;flex-shrink:0;border:1px solid rgba(168,85,247,0.15);
}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-name{font-size:14px;font-weight:600;color:var(--text)}
.testimonial-company{font-size:12px;color:var(--text-d)}
.testimonial-rating{color:var(--warn);font-size:13px;margin-top:4px}

/* ── Contact ───────────────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info h3{margin-bottom:16px}
.contact-info p{margin-bottom:24px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:16px}
.contact-list li{display:flex;align-items:center;gap:12px;color:var(--text-m);font-size:14px}
.contact-list li a{color:inherit;text-decoration:none}
.contact-list li a:hover{color:var(--accent)}
.contact-whatsapp-label{font-size:12px;opacity:.85}
.contact-list .icon{
  width:40px;height:40px;display:flex;align-items:center;
  justify-content:center;background:var(--accent-bg);
  border:1px solid rgba(168,85,247,0.12);
  border-radius:var(--radius);color:var(--accent);font-size:16px;flex-shrink:0;
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card);
}
.contact-list .icon.icon--whatsapp{
  background:rgba(37,211,102,0.1);
  border-color:rgba(37,211,102,0.28);
  color:#25d366;
  font-size:18px;
}
[data-theme="light"] .contact-list .icon.icon--whatsapp{color:#128c7e}
.contact-list li:hover .icon{
  transform:scale(1.06);
  box-shadow:0 0 16px rgba(168,85,247,0.2);
}
.contact-list li:hover .icon.icon--whatsapp{
  box-shadow:0 0 18px rgba(37,211,102,0.25);
}
.contact-form{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:36px;
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-m);margin-bottom:6px}
.form-input{
  width:100%;padding:12px 16px;
  background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text);
  font-size:14px;font-family:var(--font);transition:var(--transition);
}
[data-theme="light"] .form-input{background:rgba(255,255,255,0.6)}
.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(168,85,247,0.1)}
.form-input::placeholder{color:var(--text-d)}
textarea.form-input{resize:vertical;min-height:120px}

/* ── Blog Cards ────────────────────────────────────────────────────── */
.blog-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  overflow:hidden;
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  box-shadow:0 8px 32px rgba(0,0,0,0.1);
  transition:transform var(--duration-card) var(--ease-card),box-shadow var(--duration-card) var(--ease-card),border-color 0.25s ease;
  display:flex;flex-direction:column;
}
.blog-card:hover{
  border-color:rgba(168,85,247,0.25);
  box-shadow:0 20px 50px rgba(0,0,0,0.2),0 0 36px rgba(168,85,247,0.12);
  transform:translateY(-6px);
}
.blog-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-card .blog-date{font-size:12px;color:var(--text-d);margin-bottom:8px}
.blog-card h3{font-size:18px;margin-bottom:8px}
.blog-card h3 a{color:var(--text)}
.blog-card h3 a:hover{color:var(--accent)}
.blog-card p{font-size:14px;flex:1;margin-bottom:12px}
.blog-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.blog-card-footer .author{font-size:13px;color:var(--text-d)}
.read-more{font-size:13px;font-weight:600;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* Blog post page */
.blog-post{max-width:720px;margin:0 auto;padding-top:40px}
.blog-post-header{margin-bottom:40px}
.blog-post-header h1{margin-bottom:12px}
.blog-post-meta{display:flex;gap:16px;color:var(--text-d);font-size:13px;flex-wrap:wrap}
.blog-post-content{font-size:16px;line-height:1.8;color:var(--text-m)}
.blog-post-content h2{color:var(--text);font-size:1.5rem;margin:32px 0 12px}
.blog-post-content h3{color:var(--text);font-size:1.25rem;margin:24px 0 8px}
.blog-post-content p{margin-bottom:16px}
.blog-post-content ul,.blog-post-content ol{margin-bottom:16px;padding-left:20px}
.blog-post-content li{margin-bottom:8px}
.blog-post-content code{background:var(--accent-bg);padding:2px 6px;border-radius:4px;font-size:14px;font-family:var(--mono);color:var(--accent)}
.blog-post-content pre{background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:var(--radius);padding:16px;overflow-x:auto;margin-bottom:16px}
.blog-post-content pre code{background:none;padding:0;color:var(--text)}
.blog-post-content blockquote{border-left:3px solid var(--accent);padding-left:16px;margin:16px 0;font-style:italic;color:var(--text-d)}
.blog-post-content img{border-radius:var(--radius);margin:16px 0}
.blog-post-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* ── Footer ────────────────────────────────────────────────────────── */
.footer{
  background:rgba(6,5,15,0.6);
  backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  border-top:1px solid var(--border);
  padding:64px 0 32px;
  position:relative;z-index:1;
}
[data-theme="light"] .footer{background:rgba(250,248,255,0.7)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand{max-width:280px}
.footer-logo{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px;text-decoration:none;font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.02em}
.footer-logo-standalone{margin-bottom:20px}
.footer-logo-text{display:inline-block}
.footer-logo .footer-logo-text span{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.footer-brand p{font-size:14px;color:var(--text-d)}
.footer-col h4{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-m);margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:8px}
.footer-col a{font-size:14px;color:var(--text-d);transition:color 0.2s ease,transform 0.2s ease;display:inline-block}
.footer-col a:hover{color:var(--accent);transform:translateX(4px)}
.footer-bottom{text-align:center;border-top:1px solid var(--border);padding-top:24px;font-size:13px;color:var(--text-d)}

/* ── Toast ─────────────────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:24px;left:24px;z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{
  padding:12px 20px;
  background:rgba(12,10,30,0.9);
  backdrop-filter:blur(12px);
  border:1px solid var(--border);
  border-radius:var(--radius);font-size:14px;color:var(--text);
  box-shadow:0 4px 20px rgba(0,0,0,.3);animation:toastIn .2s ease;
}
[data-theme="light"] .toast{background:rgba(255,255,255,0.9)}
.toast.success{border-color:rgba(34,197,94,.4)}
.toast.error{border-color:rgba(239,68,68,.4)}
@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── Reading progress bar (blog posts) ───────────────────────────────── */
.reading-progress{
  position:fixed;top:0;left:0;width:0%;height:3px;
  background:var(--gradient);
  z-index:10000;
  transition:width .12s linear;
  pointer-events:none;
  box-shadow:0 0 12px var(--accent-glow);
}

/* ── Scroll reveal ─────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(0.22,1,0.36,1),transform .65s cubic-bezier(0.22,1,0.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){
  .reveal{transition-duration:.2s}
  .service-card,.glass-card,.portfolio-card,.testimonial-card,.blog-card,a.tool-card.tool-link-card,.contact-pill{
    transition-duration:0.01ms!important;
  }
  .service-icon,.portfolio-img img,.tool-link-cta,.tool-link-cta i{
    transition-duration:0.01ms!important;
  }
}

/* ── Responsive ────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  body.menu-open{overflow:hidden}
  body.menu-open::before{
    content:'';
    position:fixed;
    inset:0;
    background:linear-gradient(90deg,rgba(2,6,23,0.18) 0%,rgba(2,6,23,0.32) 100%);
    backdrop-filter:blur(10px) saturate(115%);
    -webkit-backdrop-filter:blur(10px) saturate(115%);
    z-index:998;
    pointer-events:none;
  }
  section{padding:64px 0}
  .hero{padding:140px 0 100px}
  .nav{z-index:1001}
  .nav-links{display:none}
  .nav-cta{display:none}
  .mobile-menu-btn{display:block}
  .grid-2,.grid-3,.grid-auto{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .section-header{margin-bottom:36px}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .hero-actions{flex-direction:column;align-items:center}
  .hero-contact-bar{flex-direction:column;align-items:stretch}
  .hero-contact-bar .contact-pill{justify-content:center}
  .enq-checkboxes{grid-template-columns:1fr}
}
