/* ============================================================
   Hello Amanuel — Production CSS
   Fonts: Outfit (display) + Inter (body) — loaded via <link> in layout.antlers.html
   Accent: #0052f5 | Navy: #04091a
   ============================================================ */

/* ── Tokens ── */
:root {
  --ink:         #07111f;
  --ink-2:       #1c2840;
  --muted:       #52637d;
  --muted-2:     #8194b0;
  --surface:     #ffffff;
  --surface-2:   #f3f6fb;
  --surface-3:   #e8edf7;
  --accent:      #0052f5;
  --accent-2:    #0062ff;
  --accent-dark: #003acc;
  --accent-soft: rgba(0,82,245,0.07);
  --accent-ring: rgba(0,82,245,0.18);
  --gold:        #e8a020;
  --green:       #16a34a;
  --navy:        #04091a;
  --navy-2:      #0b1425;
  --navy-3:      #142035;
  --border:      rgba(7,17,31,0.08);
  --border-2:    rgba(7,17,31,0.14);
  --shadow-xs:   0 1px 3px rgba(7,17,31,0.06);
  --shadow-sm:   0 2px 12px rgba(7,17,31,0.08);
  --shadow-md:   0 8px 32px rgba(7,17,31,0.10);
  --shadow-lg:   0 20px 60px rgba(7,17,31,0.12);
  --shadow-xl:   0 32px 80px rgba(7,17,31,0.14);
  --shadow-accent: 0 6px 28px rgba(0,82,245,0.30);
  --r-sm:  8px; --r-md: 14px; --r-lg: 20px; --r-xl: 28px; --r-2xl: 36px;
  --ease:    cubic-bezier(0.22,1,0.36,1);
  --spring:  cubic-bezier(0.34,1.56,0.64,1);
  --bounce:  cubic-bezier(0.68,-0.55,0.27,1.55);
  --header-h: 76px;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{margin:0;min-height:100dvh;display:flex;flex-direction:column;font-family:'Inter',ui-sans-serif,system-ui,sans-serif;font-size:16px;line-height:1.6;color:var(--ink);background:var(--surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:'Outfit',ui-sans-serif,system-ui,sans-serif;font-weight:800;line-height:1.1;letter-spacing:-0.035em;color:var(--ink);margin:0}
p{margin:0;line-height:1.72}
a{color:inherit;text-decoration:none}
img,video,svg{max-width:100%;display:block}
ul,ol{padding:0;margin:0;list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
::selection{background:rgba(0,82,245,0.13);color:var(--ink)}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(0,82,245,0.2);border-radius:99px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}

/* ── Keyframes ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulseRing{0%{box-shadow:0 0 0 0 rgba(0,82,245,0.4)}70%{box-shadow:0 0 0 14px rgba(0,82,245,0)}100%{box-shadow:0 0 0 0 rgba(0,82,245,0)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes countUp{from{opacity:0}to{opacity:1}}

/* ── Layout utilities ── */
.ha-wrap{width:min(1200px,100% - 2.5rem);margin-inline:auto}
.ha-wrap-sm{width:min(760px,100% - 2.5rem);margin-inline:auto}
.ha-wrap-md{width:min(960px,100% - 2.5rem);margin-inline:auto}
.ha-section{padding:clamp(4rem,8vw,6rem) 0}
.ha-section-muted{padding:clamp(4rem,8vw,6rem) 0;background:var(--surface-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.ha-center{text-align:center}
.ha-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* ── Skip link ── */
.ha-skip{position:absolute;left:-9999px;z-index:9999;padding:.6rem 1.25rem;background:var(--accent);color:#fff;font-weight:700;font-size:.875rem;border-radius:0 0 8px 8px;text-decoration:none}
.ha-skip:focus{left:1.5rem;top:0}

/* ── Buttons ── */
.ha-btn{display:inline-flex;align-items:center;gap:.45rem;padding:.875rem 1.75rem;font-weight:700;font-size:.95rem;border-radius:12px;text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s,background .15s}
.ha-btn-primary{background:linear-gradient(135deg,#0062ff,#003acc);color:#fff!important;box-shadow:var(--shadow-accent)}
.ha-btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(0,82,245,.44)}
.ha-btn-ghost{background:transparent;color:var(--ink)!important;border:1.5px solid rgba(7,17,31,.16)}
.ha-btn-ghost:hover{border-color:var(--accent);color:var(--accent)!important;background:var(--accent-soft);transform:translateY(-2px)}
.ha-btn-white{background:#fff;color:var(--accent)!important;box-shadow:0 8px 32px rgba(0,0,0,.18)}
.ha-btn-white:hover{transform:translateY(-3px);box-shadow:0 16px 48px rgba(0,0,0,.26)}
.ha-btn-outline-white{background:transparent;color:#fff!important;border:1.5px solid rgba(255,255,255,.45)}
.ha-btn-outline-white:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}
.ha-btn svg{width:14px;height:14px;flex-shrink:0}

/* ── Eyebrow badge ── */
.ha-eyebrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.69rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-ring);padding:.28rem .85rem .28rem .65rem;border-radius:99px;margin-bottom:1.25rem;align-self:flex-start}
.ha-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}

/* ============================================================
   HEADER
   ============================================================ */
.ha-header{position:fixed;top:0;left:0;right:0;z-index:9000;height:var(--header-h);background:rgba(255,255,255,.93);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--border);transition:box-shadow .3s var(--ease),background .3s}
.ha-header.scrolled{box-shadow:0 4px 28px rgba(7,17,31,.08)}
.ha-header-inner{height:var(--header-h);width:min(1200px,100% - 2.5rem);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}

/* Brand */
.ha-brand{display:flex;flex-direction:column;gap:.05rem;flex-shrink:0;text-decoration:none}
.ha-brand-name{font-family:'Outfit',sans-serif;font-weight:900;font-size:1.2rem;letter-spacing:-.05em;line-height:1;background:linear-gradient(125deg,var(--ink) 0%,#1a4fff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ha-brand-sub{font-size:.65rem;font-weight:600;color:var(--muted);-webkit-text-fill-color:var(--muted);letter-spacing:.01em;line-height:1}

/* Desktop nav */
.ha-nav{display:flex;align-items:center;gap:.05rem;flex:1;justify-content:center}
.ha-nav a{font-size:.875rem;font-weight:500;color:var(--muted);padding:.4rem .72rem;border-radius:8px;text-decoration:none;white-space:nowrap;transition:color .15s,background .15s}
.ha-nav a:hover{color:var(--ink);background:var(--surface-2)}
.ha-nav a.active{color:var(--accent);background:var(--accent-soft);font-weight:600}

/* Dropdown */
.ha-dropdown{position:relative}
.ha-dropdown-btn{display:inline-flex;align-items:center;gap:.28rem;font-size:.875rem;font-weight:500;color:var(--muted);background:transparent;cursor:default;padding:.4rem .72rem .8rem;margin-bottom:-.4rem;border-radius:8px;font-family:inherit;transition:color .15s,background .15s}
.ha-dropdown:hover .ha-dropdown-btn{color:var(--ink);background:var(--surface-2)}
.ha-dropdown-chevron{width:10px;height:10px;transition:transform .22s var(--ease)}
.ha-dropdown:hover .ha-dropdown-chevron{transform:rotate(180deg)}

.ha-dropdown-panel{position:absolute;top:calc(100% + 2px);left:50%;transform:translateX(-50%) translateY(6px);width:580px;max-width:calc(100vw - 2rem);background:#fff;border:1px solid rgba(7,17,31,.09);border-radius:20px;box-shadow:0 28px 70px rgba(7,17,31,.13),0 4px 16px rgba(7,17,31,.06);overflow:hidden;z-index:500;opacity:0;pointer-events:none;transition:opacity .18s var(--ease),transform .18s var(--ease)}
.ha-dropdown-panel::before{content:'';position:absolute;top:-8px;left:0;right:0;height:8px}
.ha-dropdown:hover .ha-dropdown-panel,.ha-dropdown:focus-within .ha-dropdown-panel{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(4px)}
.ha-dd-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:8px}
.ha-dd-item{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border-radius:13px;text-decoration:none;transition:background .12s}
.ha-dd-item:hover{background:var(--surface-2)}
.ha-dd-icon{flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--_ibg,var(--accent-soft));color:var(--_ic,var(--accent));border-radius:10px}
.ha-dd-label{display:block;font-size:.84rem;font-weight:600;color:var(--ink);line-height:1.3}
.ha-dd-desc{display:block;font-size:.74rem;color:var(--muted);line-height:1.45;margin-top:.1rem}
.ha-dd-footer{border-top:1px solid var(--border);padding:.7rem 1.1rem;background:var(--surface-2);display:flex;align-items:center;justify-content:space-between}
.ha-dd-footer a{font-size:.8rem;font-weight:700;color:var(--accent)}

/* Header CTA */
.ha-header-cta{display:inline-flex;align-items:center;gap:.4rem;padding:.52rem 1.1rem;font-weight:700;font-size:.84rem;color:#fff!important;background:linear-gradient(135deg,#0062ff,#003acc);border-radius:10px;text-decoration:none;box-shadow:0 4px 16px rgba(0,82,245,.28);transition:transform .2s var(--ease),box-shadow .2s;flex-shrink:0;white-space:nowrap}
.ha-header-cta:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,82,245,.42)}
.ha-header-cta svg{width:12px;height:12px}

/* Hamburger */
.ha-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:8px;border-radius:10px;flex-shrink:0;z-index:9200;transition:background .2s}
.ha-hamburger:hover{background:var(--surface-2)}
.ha-hamburger span{display:block;height:1.8px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s,width .2s;transform-origin:center}
.ha-hamburger.open span:nth-child(1){transform:translateY(6.8px) rotate(45deg)}
.ha-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.ha-hamburger.open span:nth-child(3){transform:translateY(-6.8px) rotate(-45deg)}

/* Mobile overlay */
.ha-overlay{position:fixed;inset:0;z-index:9000;background:rgba(4,9,26,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:none}
.ha-overlay.open{display:block;animation:fadeIn .25s var(--ease)}

/* Mobile drawer */
.ha-drawer{position:fixed;top:0;right:0;bottom:0;width:min(380px,100vw);z-index:9100;background:#fff;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateX(100%);transition:transform .32s var(--ease);box-shadow:-8px 0 40px rgba(4,9,26,.18)}
.ha-drawer.open{transform:translateX(0)}
.ha-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:max(1.25rem,env(safe-area-inset-top)) 1.5rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}
.ha-drawer-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--muted);cursor:pointer;transition:background .15s,color .15s}
.ha-drawer-close:hover{background:var(--surface-3);color:var(--ink)}
.ha-drawer-nav{display:flex;flex-direction:column;padding:.5rem .75rem;border-bottom:1px solid var(--border)}
.ha-drawer-nav a{font-size:1rem;font-weight:600;color:var(--ink);padding:.95rem .75rem;border-radius:10px;border-bottom:1px solid var(--border);text-decoration:none;display:flex;align-items:center;transition:color .15s,background .15s}
.ha-drawer-nav a:hover{color:var(--accent);background:var(--surface-2)}
.ha-drawer-nav a.active{color:var(--accent);background:var(--accent-soft)}
.ha-drawer-services{padding:1rem 1.25rem;flex:1}
.ha-drawer-s-label{display:block;font-size:.62rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:.65rem;padding:0 .25rem}
.ha-drawer-s-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:14px;text-decoration:none;margin-bottom:.35rem;transition:background .15s,border-color .15s,transform .15s var(--ease)}
.ha-drawer-s-item:hover{background:var(--surface-2);border-color:rgba(0,82,245,.15);transform:translateX(2px)}
.ha-drawer-s-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--_ibg,var(--accent-soft));color:var(--_ic,var(--accent));border-radius:11px}
.ha-drawer-s-name{display:block;font-size:.9rem;font-weight:600;color:var(--ink);line-height:1.3}
.ha-drawer-s-desc{display:block;font-size:.74rem;color:var(--muted)}
.ha-drawer-foot{padding:1rem 1.25rem max(1.25rem,env(safe-area-inset-bottom));border-top:1px solid var(--border);flex-shrink:0}
.ha-drawer-cta{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.925rem 1.5rem;font-weight:700;font-size:.975rem;color:#fff!important;text-decoration:none;background:linear-gradient(135deg,#0062ff,#003acc);border-radius:14px;box-shadow:0 4px 20px rgba(0,82,245,.30);transition:transform .2s var(--ease),box-shadow .2s}
.ha-drawer-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,82,245,.42)}
.ha-drawer-note{text-align:center;font-size:.69rem;color:var(--muted);margin-top:.5rem}

@media(max-width:900px){.ha-nav{display:none}.ha-header-cta{display:none}.ha-hamburger{display:flex}}

/* ============================================================
   MAIN WRAPPER
   ============================================================ */
.ha-main{flex:1;padding-top:var(--header-h)}

/* ============================================================
   HERO — ADVANCED
   ============================================================ */
.ha-hero{position:relative;overflow:hidden;padding:clamp(4rem,10vw,7rem) 0 clamp(3.5rem,8vw,5.5rem);background:#fff}
.ha-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 80% 60% at 72% 12%,rgba(0,82,245,.065) 0%,transparent 60%),radial-gradient(ellipse 45% 45% at 6% 88%,rgba(0,82,245,.035) 0%,transparent 55%)}
.ha-hero::after{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(0,82,245,.085) 1px,transparent 1px);background-size:28px 28px;mask-image:linear-gradient(to left,black 0%,transparent 55%);-webkit-mask-image:linear-gradient(to left,black 0%,transparent 55%);opacity:.5}
.ha-hero-inner{position:relative;z-index:1;width:min(1200px,100% - 2.5rem);margin-inline:auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem 5rem;align-items:center}
.ha-hero-text{display:flex;flex-direction:column;animation:fadeUp .7s var(--ease) both}
.ha-hero-h1{font-family:'Outfit',sans-serif;font-size:clamp(2.3rem,5vw,3.7rem);font-weight:900;line-height:1.06;letter-spacing:-.05em;color:var(--ink);margin-bottom:1.375rem}
.ha-hero-h1 .grad{background:linear-gradient(135deg,var(--accent-2),var(--accent-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ha-hero-sub{font-size:1.05rem;line-height:1.72;color:var(--muted);max-width:36rem;margin-bottom:2rem;white-space:pre-line}
.ha-hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.25rem}
.ha-hero-trust{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem}
.ha-hero-trust li{display:flex;align-items:center;gap:.4rem;font-size:.855rem;font-weight:500;color:var(--muted)}
.ha-hero-trust li svg{color:var(--accent);flex-shrink:0;width:14px;height:14px}

.ha-hero-visual{display:flex;align-items:center;justify-content:center;animation:scaleIn .8s .2s var(--ease) both}
.ha-hero-illus{width:100%;max-width:480px;background:linear-gradient(145deg,#f7faff,#edf2ff);border:1px solid rgba(0,82,245,.1);border-radius:24px;padding:1rem;box-shadow:0 2px 8px rgba(7,17,31,.04),0 20px 60px rgba(0,82,245,.08);position:relative;overflow:hidden;animation:float 6s ease-in-out infinite}
.ha-hero-illus::before{content:'';position:absolute;top:0;right:0;width:55%;height:55%;background:radial-gradient(circle at top right,rgba(0,82,245,.07) 0%,transparent 70%);pointer-events:none}
.ha-hero-portrait{border-radius:22px;overflow:hidden;box-shadow:0 24px 64px rgba(0,15,40,.14);border:3px solid #fff;outline:1px solid var(--border);aspect-ratio:4/5;max-width:380px;width:100%}
.ha-hero-portrait img{width:100%;height:100%;object-fit:cover}

@media(max-width:860px){.ha-hero-inner{grid-template-columns:1fr;gap:2.5rem}.ha-hero-visual{display:none}}

/* Hero Simple */
.ha-hero-simple{position:relative;overflow:hidden;padding:clamp(3rem,7vw,5rem) 0 clamp(2.5rem,5vw,4rem);background:var(--surface-2);border-bottom:1px solid var(--border)}
.ha-hero-simple::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 65% 75% at 90% 50%,rgba(0,82,245,.05),transparent)}
.ha-hero-simple .ha-wrap{position:relative;z-index:1}
.ha-hero-simple-h1{font-size:clamp(2rem,4.5vw,3.2rem)}
.ha-hero-simple-sub{margin-top:1rem;max-width:44rem;font-size:1.08rem;color:var(--muted);line-height:1.7}

/* ============================================================
   STATS
   ============================================================ */
.ha-stats-wrap{width:min(1200px,100% - 2.5rem);margin-inline:auto}
.ha-stats-heading{font-size:clamp(1.8rem,3vw,2.4rem);text-align:center;margin-bottom:3rem}
.ha-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:1.25rem}
.ha-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem 1.5rem 1.5rem;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-xs);transition:transform .25s var(--ease),box-shadow .25s}
.ha-stat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),#00c6ff)}
.ha-stat:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.ha-stat-val{display:block;font-family:'Outfit',sans-serif;font-size:2.5rem;font-weight:900;letter-spacing:-.05em;background:linear-gradient(135deg,var(--accent-2),var(--accent-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem}
.ha-stat-lbl{display:block;font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.07em}

/* ============================================================
   SERVICES GRID
   ============================================================ */
.ha-svc-header{text-align:center;margin-bottom:3.25rem}
.ha-svc-heading{font-size:clamp(1.85rem,3.5vw,2.6rem);margin-bottom:.75rem}
.ha-svc-intro{max-width:46rem;margin-inline:auto;color:var(--muted);font-size:1.05rem;line-height:1.72}
.ha-svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(275px,1fr));gap:1.5rem}
.ha-svc-card{background:var(--surface);border-radius:var(--r-lg);padding:2.25rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;position:relative;overflow:hidden;transition:transform .4s var(--spring),box-shadow .4s,border-color .3s}
.ha-svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg),0 10px 40px rgba(0,82,245,.08);border-color:rgba(0,82,245,.35)}
.ha-svc-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,82,245,.025),transparent);opacity:0;transition:opacity .3s;pointer-events:none}
.ha-svc-card:hover::after{opacity:1}
.ha-svc-icon-wrap{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--accent-soft);color:var(--accent);border-radius:12px;flex-shrink:0;margin-bottom:1.5rem;transition:transform .5s var(--spring),background .3s,color .3s}
.ha-svc-card:hover .ha-svc-icon-wrap{transform:rotate(10deg) scale(1.12);background:var(--accent);color:#fff}
.ha-svc-card h3{font-family:'Outfit',sans-serif;font-size:1.25rem;font-weight:700;color:var(--ink);letter-spacing:-.025em;margin-bottom:.75rem}
.ha-svc-card p{color:var(--muted);font-size:.955rem;line-height:1.66;margin-bottom:1.25rem}
.ha-svc-card ul{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.75rem;flex:1}
.ha-svc-card li{position:relative;padding-left:1.1rem;font-size:.875rem;color:var(--ink-2)}
.ha-svc-card li::before{content:'';position:absolute;left:0;top:.56em;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.ha-text-link{display:inline-flex;align-items:center;gap:.35rem;font-weight:700;font-size:.875rem;color:var(--accent);text-decoration:none;transition:gap .2s}
.ha-text-link:hover{gap:.6rem}
.ha-text-link svg{width:12px;height:12px;flex-shrink:0}

/* ============================================================
   REVIEWS / TESTIMONIALS
   ============================================================ */
.ha-reviews-header{text-align:center;margin-bottom:1.5rem}
.ha-reviews-heading{font-size:clamp(1.85rem,3.5vw,2.6rem);margin-bottom:.75rem}
.ha-reviews-intro{max-width:44rem;margin:0 auto 1.5rem;color:var(--muted);font-size:1.05rem;line-height:1.72}
.ha-tp-row{display:flex;justify-content:center;margin-bottom:3rem}
.ha-tp-link{display:inline-flex;align-items:center;gap:1.25rem;padding:.7rem 1.4rem;background:var(--surface);border:1px solid var(--border);border-radius:99px;text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .2s,border-color .2s}
.ha-tp-link:hover{transform:translateY(-2px);border-color:#00b67a}
.ha-tp-logo{display:flex;align-items:center;gap:.45rem;font-weight:700;font-size:.95rem;color:var(--ink)}
.ha-tp-logo svg{color:#00b67a;flex-shrink:0}
.ha-tp-stars{display:flex;gap:2px}
.ha-tp-stars svg{width:14px;height:14px;color:#00b67a;fill:#00b67a}
.ha-tp-sep{width:1px;height:24px;background:var(--border)}
.ha-tp-text{font-size:.84rem;color:var(--muted)}
@media(max-width:600px){.ha-tp-link{flex-direction:column;gap:.5rem;border-radius:20px;padding:1rem 1.25rem}.ha-tp-sep{width:40px;height:1px}}

.ha-reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,330px),1fr));gap:1.75rem}
.ha-review-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.875rem;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;position:relative;transition:transform .25s var(--ease),box-shadow .25s}
.ha-review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ha-review-card::before{content:'\201C';position:absolute;top:.75rem;right:1.25rem;font-size:4.5rem;font-family:'Outfit',sans-serif;color:var(--accent);opacity:.09;line-height:1;pointer-events:none}
.ha-review-source{display:inline-flex;align-items:center;gap:.3rem;font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.18rem .58rem;border-radius:99px;margin-bottom:.65rem;align-self:flex-start}
.ha-review-source.tp{color:#00b67a;background:rgba(0,182,122,.1);border:1px solid rgba(0,182,122,.2)}
.ha-review-source.client{color:var(--muted);background:var(--surface-2);border:1px solid var(--border)}
.ha-stars{display:flex;gap:2px;margin-bottom:.85rem}
.ha-stars svg{width:15px;height:15px;color:var(--gold);fill:var(--gold)}
.ha-review-card blockquote{margin:0 0 1.25rem;font-size:.955rem;line-height:1.72;color:var(--ink-2);font-style:italic;flex:1}
.ha-review-card figcaption{padding-top:1rem;border-top:1px solid var(--border)}
.ha-review-card figcaption strong{display:block;font-size:.88rem;font-weight:700;color:var(--ink)}
.ha-review-card figcaption span{display:block;font-size:.78rem;color:var(--muted);margin-top:.1rem}

/* ============================================================
   CTA BAND
   ============================================================ */
.ha-cta{padding:clamp(3.5rem,8vw,5.5rem) 0;background:linear-gradient(135deg,#0052f5 0%,var(--accent-dark) 55%,#001a80 100%);text-align:center;color:#fff;position:relative;overflow:hidden}
.ha-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.055) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.ha-cta::after{content:'';position:absolute;inset:-50%;background:radial-gradient(circle at 50% 50%,rgba(0,196,255,.1),transparent 55%);pointer-events:none}
.ha-cta .ha-wrap{position:relative;z-index:1}
.ha-cta h2{font-size:clamp(1.75rem,4vw,2.6rem);margin-bottom:.9rem;color:#fff;font-weight:800;letter-spacing:-.04em}
.ha-cta p{margin:0 auto 2rem;max-width:40rem;opacity:.9;line-height:1.66;font-size:1.05rem;white-space:pre-line}
.ha-cta-btns{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}

/* ============================================================
   FAQ
   ============================================================ */
.ha-faq-list{display:flex;flex-direction:column;gap:.45rem}
.ha-faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:box-shadow .2s,border-color .2s}
.ha-faq-item[open]{box-shadow:var(--shadow-sm);border-color:rgba(0,82,245,.2)}
.ha-faq-summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.2rem 1.5rem;font-size:.975rem;font-weight:600;color:var(--ink);user-select:none;transition:background .15s}
.ha-faq-summary::-webkit-details-marker{display:none}
.ha-faq-summary:hover{background:var(--surface-2)}
.ha-faq-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--accent-soft);border:1px solid var(--accent-ring);display:flex;align-items:center;justify-content:center;transition:transform .22s var(--ease),background .2s}
.ha-faq-icon svg{width:11px;height:11px;color:var(--accent);transition:transform .22s var(--ease)}
.ha-faq-item[open] .ha-faq-icon{background:var(--accent);border-color:var(--accent)}
.ha-faq-item[open] .ha-faq-icon svg{color:#fff;transform:rotate(45deg)}
.ha-faq-answer{padding:1rem 1.5rem 1.375rem;font-size:.935rem;line-height:1.75;color:var(--muted);border-top:1px solid var(--border)}

/* ============================================================
   PRICING
   ============================================================ */
.ha-pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(275px,1fr));gap:1.5rem;align-items:start}
.ha-pricing-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:2rem 1.75rem 2.25rem;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;position:relative;transition:transform .25s var(--ease),box-shadow .25s}
.ha-pricing-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.ha-pricing-card.featured{border-color:var(--accent);box-shadow:var(--shadow-accent);transform:scale(1.025)}
.ha-pricing-card.featured:hover{transform:scale(1.025) translateY(-5px)}
.ha-pricing-badge{display:inline-block;font-size:.63rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:linear-gradient(135deg,var(--accent-2),var(--accent-dark));padding:.25rem .7rem;border-radius:99px;margin-bottom:1rem;align-self:flex-start}
.ha-pricing-audience{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.4rem}
.ha-pricing-title{font-family:'Outfit',sans-serif;font-size:1.45rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.18rem}
.ha-pricing-price{font-family:'Outfit',sans-serif;font-size:1.95rem;font-weight:900;letter-spacing:-.04em;color:var(--accent);line-height:1.1;margin-bottom:.18rem}
.ha-pricing-delivery{font-size:.77rem;color:var(--muted-2);margin-bottom:1.25rem}
.ha-pricing-hi{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}
.ha-pricing-hi li{display:flex;align-items:center;gap:.45rem;font-size:.875rem;color:var(--muted)}
.ha-pricing-hi li::before{content:'✓';color:var(--accent);font-weight:800;font-size:.77rem;flex-shrink:0}
.ha-pricing-hr{border:none;border-top:1px solid var(--border);margin:1.25rem 0}
.ha-pricing-inc-head{font-size:.67rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.75rem}
.ha-pricing-inc{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.75rem;flex:1}
.ha-pricing-inc li{display:flex;align-items:flex-start;gap:.45rem;font-size:.875rem;color:var(--muted);line-height:1.5}
.ha-pricing-inc li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.65;flex-shrink:0;margin-top:.55em}
.ha-pricing-cta{display:block;width:100%;padding:.875rem 1.5rem;font-weight:700;font-size:.93rem;text-align:center;border-radius:12px;text-decoration:none;margin-top:auto;transition:transform .2s var(--ease),box-shadow .2s}
.ha-pricing-cta.solid{color:#fff!important;background:linear-gradient(135deg,var(--accent-2),var(--accent-dark));box-shadow:var(--shadow-accent)}
.ha-pricing-cta.solid:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,82,245,.42)}
.ha-pricing-cta.outline{color:var(--accent)!important;background:transparent;border:1.5px solid var(--accent)}
.ha-pricing-cta.outline:hover{background:var(--accent-soft);transform:translateY(-2px)}

/* ============================================================
   ADD-ONS
   ============================================================ */
.ha-addons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.25rem}
.ha-addon{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:1.5rem;display:flex;flex-direction:column;gap:.4rem;transition:border-color .2s,box-shadow .2s}
.ha-addon:hover{border-color:rgba(0,82,245,.22);box-shadow:var(--shadow-sm)}
.ha-addon-title{font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;color:var(--ink)}
.ha-addon-price{font-size:.875rem;font-weight:700;color:var(--accent)}
.ha-addon-desc{font-size:.9rem;color:var(--muted);line-height:1.6}

/* ============================================================
   TRUST POINTS
   ============================================================ */
.ha-trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}
.ha-trust-card{padding:1.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs);transition:transform .25s var(--ease),box-shadow .2s}
.ha-trust-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.ha-trust-title{font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:.4rem;display:flex;align-items:center;gap:.5rem}
.ha-trust-title::before{content:'✓';font-size:.78rem;color:var(--accent);background:var(--accent-soft);width:21px;height:21px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.ha-trust-body{font-size:.9rem;color:var(--muted);line-height:1.65}

/* ============================================================
   TECH STACK
   ============================================================ */
.ha-tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.25rem}
.ha-tech{padding:1.5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color .2s,background .2s}
.ha-tech:hover{background:var(--surface);border-color:rgba(0,82,245,.2)}
.ha-tech-name{font-family:'Outfit',sans-serif;font-size:.97rem;font-weight:700;color:var(--ink);margin-bottom:.32rem}
.ha-tech-desc{font-size:.875rem;color:var(--muted);line-height:1.6}

/* ============================================================
   TIMELINE
   ============================================================ */
.ha-timeline{max-width:44rem;margin-inline:auto}
.ha-timeline ol{padding-left:1.5rem;border-left:2px solid var(--border-2)}
.ha-timeline-item{position:relative;margin-bottom:2.5rem;padding-left:1.5rem}
.ha-timeline-item::before{content:'';position:absolute;left:calc(-1.5rem - 6px);top:.45rem;width:12px;height:12px;border-radius:50%;background:var(--accent);border:3px solid var(--surface);box-shadow:0 0 0 2px var(--accent)}
.ha-timeline-period{display:inline-block;font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.18rem .62rem;border-radius:99px;margin-bottom:.5rem}
.ha-timeline-title{font-family:'Outfit',sans-serif;font-size:1.1rem;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:.18rem}
.ha-timeline-sub{font-size:.88rem;font-weight:600;color:var(--muted);margin-bottom:.32rem}
.ha-timeline-body{font-size:.91rem;line-height:1.65;color:var(--muted)}

/* ============================================================
   PROJECT HIGHLIGHTS
   ============================================================ */
.ha-projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.25rem}
.ha-project{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;box-shadow:var(--shadow-xs);transition:transform .25s var(--ease),box-shadow .2s}
.ha-project:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ha-project-cat{font-size:.67rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.4rem}
.ha-project-title{font-family:'Outfit',sans-serif;font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:.65rem}
.ha-project-metric{font-size:1.55rem;font-weight:900;font-family:'Outfit',sans-serif;letter-spacing:-.04em;color:var(--accent)}

/* ============================================================
   CONTACT CHANNELS
   ============================================================ */
.ha-channels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(235px,1fr));gap:1.5rem}
.ha-channel{padding:2rem 1.75rem;background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:.75rem;position:relative;overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s}
.ha-channel:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ha-channel::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),#00c6ff)}
.ha-channel[data-v=phone]::before{background:linear-gradient(90deg,#64748b,#94a3b8)}
.ha-channel[data-v=whatsapp]::before{background:linear-gradient(90deg,#25d366,#128c7e)}
.ha-channel-label{font-size:.68rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.ha-channel[data-v=phone] .ha-channel-label{color:var(--muted)}
.ha-channel[data-v=whatsapp] .ha-channel-label{color:#128c7e}
.ha-channel-desc{font-size:.91rem;line-height:1.65;color:var(--muted);flex:1}
.ha-channel-val{font-size:1rem;font-weight:600;color:var(--ink);text-decoration:none;word-break:break-word;transition:color .2s}
.ha-channel-val:hover{color:var(--accent)}
.ha-channel-btn{display:inline-flex;align-self:flex-start;padding:.55rem 1.15rem;font-weight:700;font-size:.875rem;color:#fff!important;background:linear-gradient(135deg,#25d366,#128c7e);border-radius:9px;text-decoration:none;transition:opacity .2s,transform .2s}
.ha-channel-btn:hover{opacity:.9;transform:translateY(-1px)}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.ha-form-card{max-width:680px;margin-inline:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:clamp(2rem,5vw,3rem);box-shadow:var(--shadow-md)}
.ha-form-title{font-size:clamp(1.6rem,3vw,2rem);margin-bottom:.5rem}
.ha-form-intro{color:var(--muted);margin-bottom:2rem}
.ha-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media(max-width:560px){.ha-form-row{grid-template-columns:1fr}}
.ha-label{display:flex;flex-direction:column;gap:.4rem;font-size:.875rem;font-weight:600;color:var(--ink)}
.ha-input,.ha-textarea{font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--surface);border:1.5px solid var(--border-2);border-radius:10px;padding:.75rem 1rem;width:100%;transition:border-color .2s,box-shadow .2s}
.ha-input:focus,.ha-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,82,245,.1)}
.ha-textarea{resize:vertical;min-height:140px;line-height:1.65}
.ha-consent{display:flex;align-items:flex-start;gap:.75rem;margin-top:.5rem}
.ha-consent input{margin-top:.15rem;accent-color:var(--accent);width:16px;height:16px;flex-shrink:0}
.ha-consent span{font-size:.875rem;color:var(--muted);line-height:1.55}
.ha-submit{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem 2rem;font-weight:700;font-size:1rem;color:#fff!important;background:linear-gradient(135deg,#0062ff,#003acc);border:none;border-radius:12px;width:100%;margin-top:.75rem;box-shadow:0 6px 24px rgba(0,82,245,.30);cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s,opacity .2s}
.ha-submit:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(0,82,245,.44)}
.ha-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.ha-success{background:rgba(22,163,74,.08);border:1px solid rgba(22,163,74,.25);color:var(--green);border-radius:10px;padding:1rem 1.25rem;font-size:.95rem;font-weight:600;margin-bottom:1.5rem}
.ha-form-error-msg{background:rgba(220,38,38,.07);border:1px solid rgba(220,38,38,.2);color:#b91c1c;border-radius:10px;padding:.875rem 1.25rem;font-size:.875rem;margin-bottom:1rem}
.ha-honeypot{position:absolute;left:-9999px;opacity:0;pointer-events:none}

/* ============================================================
   BLOG
   ============================================================ */
.ha-blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.75rem}
.ha-blog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xs);transition:transform .25s var(--ease),box-shadow .25s}
.ha-blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.ha-blog-img{aspect-ratio:16/9;overflow:hidden;background:var(--surface-2)}
.ha-blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.ha-blog-card:hover .ha-blog-img img{transform:scale(1.06)}
.ha-blog-body{padding:1.5rem 1.75rem 1.75rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.ha-blog-topic{font-size:.67rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--accent)}
.ha-blog-title{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:700;line-height:1.3;letter-spacing:-.025em}
.ha-blog-title a{color:var(--ink);text-decoration:none;transition:color .2s}
.ha-blog-title a:hover{color:var(--accent)}
.ha-blog-excerpt{font-size:.91rem;line-height:1.66;color:var(--muted);flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ha-blog-meta{font-size:.78rem;color:var(--muted)}
.ha-read-more{display:inline-flex;align-items:center;gap:.35rem;font-weight:700;font-size:.875rem;color:var(--accent);text-decoration:none;transition:gap .2s}
.ha-read-more:hover{gap:.6rem}
.ha-read-more svg{width:12px;height:12px;flex-shrink:0}

/* Blog filter */
.ha-blog-filter{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.5rem;margin-bottom:2.5rem;display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}
.ha-blog-filter label{display:flex;flex-direction:column;gap:.38rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);flex:1;min-width:175px}
.ha-filter-input{font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--surface);border:1.5px solid var(--border-2);border-radius:9px;padding:.62rem .875rem;transition:border-color .2s,box-shadow .2s}
.ha-filter-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,82,245,.1)}
.ha-filter-btns{display:flex;gap:.5rem;align-self:flex-end}
.ha-filter-submit{padding:.62rem 1.25rem;font-weight:700;font-size:.875rem;color:#fff;background:var(--accent);border:none;border-radius:9px;cursor:pointer;transition:background .2s}
.ha-filter-submit:hover{background:var(--accent-dark)}
.ha-filter-reset{padding:.62rem 1.25rem;font-weight:600;font-size:.875rem;color:var(--muted);background:var(--surface);border:1.5px solid var(--border-2);border-radius:9px;text-decoration:none;transition:border-color .2s,color .2s;display:inline-flex;align-items:center}
.ha-filter-reset:hover{border-color:var(--accent);color:var(--accent)}

/* Pagination */
.ha-pagination{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:3rem;justify-content:center}
.ha-pagination a{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 .875rem;font-size:.875rem;font-weight:600;color:var(--muted);background:var(--surface);border:1.5px solid var(--border-2);border-radius:9px;text-decoration:none;transition:all .2s}
.ha-pagination a:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}
.ha-pagination a.current,.ha-pagination span.current{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 .875rem;font-size:.875rem;font-weight:700;color:#fff;background:var(--accent);border:1.5px solid var(--accent);border-radius:9px}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.ha-portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.75rem}
.ha-portfolio-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s}
.ha-portfolio-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.ha-portfolio-img{aspect-ratio:16/9;overflow:hidden;background:var(--surface-2)}
.ha-portfolio-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.ha-portfolio-card:hover .ha-portfolio-img img{transform:scale(1.06)}
.ha-portfolio-body{padding:1.5rem 1.75rem 1.75rem;flex:1;display:flex;flex-direction:column;gap:.55rem}
.ha-portfolio-tags{display:flex;flex-wrap:wrap;gap:.35rem}
.ha-portfolio-tag{font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.16rem .52rem;border-radius:99px;border:1px solid var(--accent-ring)}
.ha-portfolio-title{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:700;color:var(--ink)}
.ha-portfolio-title a{color:inherit;text-decoration:none}
.ha-portfolio-title a:hover{color:var(--accent)}
.ha-portfolio-excerpt{font-size:.91rem;line-height:1.66;color:var(--muted);flex:1}

/* ============================================================
   ARTICLE (blog/portfolio single)
   ============================================================ */
.ha-article{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:clamp(2rem,5vw,3.5rem);box-shadow:var(--shadow-md)}
.ha-article-header{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}
.ha-article-h1{font-size:clamp(2rem,4vw,2.8rem)}
.ha-article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:1rem;font-size:.875rem;color:var(--muted)}
.ha-article-tag{font-size:.67rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.2rem .58rem;border-radius:99px;border:1px solid var(--accent-ring)}
.ha-article-img{margin-bottom:2.5rem;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9}
.ha-article-img img{width:100%;height:100%;object-fit:cover}
.ha-article-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:700;color:var(--accent);text-decoration:none;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border);transition:gap .2s}
.ha-article-back:hover{gap:.65rem}
.ha-article-back svg{width:14px;height:14px;flex-shrink:0}
.ha-article-sidebar{position:sticky;top:calc(var(--header-h) + 1.5rem)}

/* ============================================================
   PROSE (rich text)
   ============================================================ */
.ha-prose h2{font-family:'Outfit',sans-serif;margin:2.5rem 0 .75rem;font-size:clamp(1.35rem,2.5vw,1.75rem);font-weight:800;letter-spacing:-.03em}
.ha-prose h3{font-family:'Outfit',sans-serif;margin:1.75rem 0 .5rem;font-size:1.15rem;font-weight:700}
.ha-prose p{margin-bottom:1.1rem;color:var(--muted);line-height:1.76}
.ha-prose ul,.ha-prose ol{padding-left:1.5rem;color:var(--muted);line-height:1.7;margin-bottom:1rem}
.ha-prose ul li{list-style:disc}
.ha-prose ol li{list-style:decimal}
.ha-prose li{margin-bottom:.4rem}
.ha-prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.ha-prose blockquote{border-left:3px solid var(--accent);padding:.75rem 1.25rem;margin:1.5rem 0;background:var(--accent-soft);font-style:italic;border-radius:0 var(--r-sm) var(--r-sm) 0}
.ha-prose code{font-family:ui-monospace,'Fira Code','Cascadia Code',monospace;font-size:.87em;background:var(--surface-2);padding:.15em .4em;border-radius:4px;color:var(--accent)}
.ha-prose pre{background:var(--navy-2);border-radius:var(--r-md);padding:1.25rem;overflow-x:auto;margin-bottom:1.25rem}
.ha-prose pre code{background:none;color:rgba(255,255,255,.88);font-size:.875rem;padding:0}
.ha-prose strong{font-weight:700;color:var(--ink)}
.ha-prose img{border-radius:var(--r-md);border:1px solid var(--border);margin:1.5rem 0;max-width:100%}
.ha-prose table{width:100%;border-collapse:collapse;margin-bottom:1.25rem;font-size:.9rem}
.ha-prose th{background:var(--surface-2);font-weight:700;padding:.65rem 1rem;border:1px solid var(--border);text-align:left}
.ha-prose td{padding:.65rem 1rem;border:1px solid var(--border)}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.ha-breadcrumbs{width:min(1200px,100% - 2.5rem);margin-inline:auto;padding:.75rem 0;font-size:.78rem;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:.3rem}
.ha-breadcrumbs a{color:var(--muted);text-decoration:none;transition:color .15s}
.ha-breadcrumbs a:hover{color:var(--accent)}
.ha-breadcrumbs-sep{opacity:.45}
.ha-breadcrumbs-current{color:var(--ink);font-weight:500}

/* ============================================================
   SECTION HEADING SHARED
   ============================================================ */
.ha-section-heading{font-size:clamp(1.85rem,3.5vw,2.6rem);text-align:center;margin-bottom:.75rem}
.ha-section-intro{text-align:center;max-width:46rem;margin:0 auto 3rem;color:var(--muted);font-size:1.05rem;line-height:1.72}

/* ============================================================
   FOOTER
   ============================================================ */
.ha-footer{background:var(--navy);color:rgba(255,255,255,.7);position:relative;overflow:hidden;margin-top:auto}
.ha-footer::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 55% at 100% 0%,rgba(0,98,255,.16),transparent),radial-gradient(ellipse 55% 65% at 0% 100%,rgba(0,98,255,.09),transparent)}
.ha-footer-grid{position:relative;width:min(1200px,100% - 2.5rem);margin-inline:auto;display:grid;grid-template-columns:2fr 1.1fr 1fr 1.5fr;gap:3rem;padding:5rem 0 3.5rem}
@media(max-width:900px){.ha-footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem;padding:3.5rem 0 3rem}}
@media(max-width:540px){.ha-footer-grid{grid-template-columns:1fr;gap:2rem;padding:3rem 0 2.5rem}}
.ha-footer-brand{display:flex;flex-direction:column}
.ha-footer-brand-name{font-family:'Outfit',sans-serif;font-size:1.6rem;font-weight:900;letter-spacing:-.05em;color:#fff;margin-bottom:.875rem;line-height:1}
.ha-footer-brand-name span{color:#4d90ff}
.ha-footer p{font-size:.875rem;line-height:1.75;color:rgba(255,255,255,.52)}
.ha-footer h4,.ha-footer-h{font-size:.62rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin:0 0 1.25rem;color:rgba(255,255,255,.35)}
.ha-footer ul{display:flex;flex-direction:column;gap:.5rem}
.ha-footer li{margin:0}
.ha-footer a{font-size:.875rem;color:rgba(255,255,255,.58)!important;text-decoration:none;transition:color .2s}
.ha-footer a:hover{color:#fff!important}
.ha-footer-contact-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem;font-size:.875rem}
.ha-footer-contact-row svg{opacity:.55;flex-shrink:0;width:13px;height:13px}
.ha-social{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.1rem}
.ha-social a{display:inline-flex;width:2.1rem;height:2.1rem;align-items:center;justify-content:center;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);font-size:.69rem;font-weight:800;color:rgba(255,255,255,.6)!important;text-decoration:none;transition:all .2s!important}
.ha-social a:hover{background:rgba(0,98,255,.32)!important;border-color:rgba(77,144,255,.5)!important;color:#fff!important;transform:translateY(-2px)}
.ha-footer-bar{border-top:1px solid rgba(255,255,255,.07)}
.ha-footer-bar-inner{width:min(1200px,100% - 2.5rem);margin-inline:auto;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:1.25rem 0;font-size:.77rem;color:rgba(255,255,255,.32)}
.ha-footer-bar-inner a{color:rgba(255,255,255,.4)!important;margin-left:1.25rem;text-decoration:none;transition:color .2s}
.ha-footer-bar-inner a:hover{color:rgba(255,255,255,.72)!important}

/* ============================================================
   COOKIE CONSENT
   ============================================================ */
.ha-cookie{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:9999;width:min(560px,calc(100vw - 2rem));background:var(--navy-2);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:1.25rem 1.5rem;box-shadow:0 24px 64px rgba(4,9,26,.5);display:none;align-items:center;gap:1.25rem;flex-wrap:wrap}
.ha-cookie.visible{display:flex;animation:fadeUp .4s var(--ease)}
.ha-cookie p{font-size:.875rem;line-height:1.6;flex:1;min-width:200px;margin:0}
.ha-cookie a{color:#6aabff!important;text-decoration:underline}
.ha-cookie-btns{display:flex;gap:.5rem;flex-shrink:0}
.ha-cookie-accept{padding:.52rem 1.05rem;font-weight:700;font-size:.84rem;color:#fff;background:var(--accent);border:none;border-radius:9px;cursor:pointer;transition:background .2s}
.ha-cookie-accept:hover{background:var(--accent-2)}
.ha-cookie-decline{padding:.52rem 1.05rem;font-weight:600;font-size:.84rem;color:rgba(255,255,255,.6);background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:9px;cursor:pointer;transition:border-color .2s}
.ha-cookie-decline:hover{border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.8)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ============================================================
   404
   ============================================================ */
.ha-404{text-align:center;padding:clamp(5rem,15vw,10rem) 0}
.ha-404-code{font-family:'Outfit',sans-serif;font-size:clamp(5rem,15vw,9rem);font-weight:900;letter-spacing:-.05em;background:linear-gradient(135deg,var(--accent-2),var(--accent-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:1rem}
.ha-404-h{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:1rem}
.ha-404-p{color:var(--muted);max-width:36rem;margin:0 auto 2.5rem}

/* ============================================================
   SERVICE REQUEST FORM
   ============================================================ */
.ha-req-form{padding:0 0 3rem}
/* Step indicator */
.ha-req-steps{display:flex;align-items:center;justify-content:center;margin-bottom:2rem}
.ha-req-step{display:flex;flex-direction:column;align-items:center;gap:.3rem}
.ha-req-step-num{width:2.1rem;height:2.1rem;border-radius:50%;border:2px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--muted);transition:all .25s var(--ease)}
.ha-req-step em{font-size:.6rem;font-weight:700;font-style:normal;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);transition:color .25s;white-space:nowrap}
.ha-req-step.active .ha-req-step-num{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 4px var(--accent-soft)}
.ha-req-step.active em{color:var(--accent)}
.ha-req-step.done .ha-req-step-num{background:var(--accent);border-color:var(--accent);color:#fff}
.ha-req-step.done em{color:var(--accent)}
.ha-req-step-line{flex:1;height:2px;background:var(--border);margin:0 .75rem;margin-bottom:1.35rem;min-width:1.5rem;max-width:5rem;transition:background .3s}
/* Card wrapper */
.ha-req-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:clamp(1.5rem,4vw,2.25rem);box-shadow:0 2px 20px rgba(7,17,31,.05)}
/* Panels */
.ha-req-panel{display:none}
.ha-req-panel.active{display:block;animation:reqIn .3s var(--ease) both}
@keyframes reqIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.ha-req-panel-title{font-family:'Outfit',sans-serif;font-size:1.45rem;font-weight:800;letter-spacing:-.04em;color:var(--ink);margin-bottom:.35rem}
.ha-req-panel-sub{color:var(--muted);font-size:.925rem;margin-bottom:1.75rem}
/* Service cards */
.ha-req-svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.625rem;margin-bottom:1.5rem}
@media(max-width:600px){.ha-req-svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:380px){.ha-req-svc-grid{grid-template-columns:1fr}}
.ha-req-svc{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;padding:.875rem .875rem .75rem;background:var(--bg);border:2px solid var(--border);border-radius:14px;text-align:left;cursor:pointer;transition:border-color .18s var(--ease),background .18s,transform .18s var(--ease);width:100%}
.ha-req-svc:hover{border-color:rgba(0,82,245,.25);background:var(--surface-2);transform:translateY(-2px)}
.ha-req-svc.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft)}
.ha-req-svc-icon{width:36px;height:36px;border-radius:10px;flex-shrink:0;background:var(--_ibg,var(--accent-soft));color:var(--_ic,var(--accent));display:flex;align-items:center;justify-content:center}
.ha-req-svc-name{font-size:.88rem;font-weight:700;color:var(--ink);line-height:1.3}
.ha-req-svc-desc{font-size:.72rem;color:var(--muted);line-height:1.4}
/* Budget / timeline pills */
.ha-req-group-label{font-size:.8rem;font-weight:700;color:var(--ink);margin-bottom:.7rem;display:block}
.ha-req-pills{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.35rem}
.ha-req-pill{padding:.475rem .95rem;border:1.5px solid var(--border);border-radius:8px;background:var(--bg);font-size:.855rem;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s;font-family:inherit}
.ha-req-pill:hover{border-color:rgba(0,82,245,.3);color:var(--ink);background:var(--surface-2)}
.ha-req-pill.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600}
/* Input rows */
.ha-req-row{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}
@media(max-width:540px){.ha-req-row{grid-template-columns:1fr}}
.ha-req-group{display:flex;flex-direction:column;gap:.35rem}
.ha-req-lbl{font-size:.8rem;font-weight:700;color:var(--ink)}
.ha-req-optional{font-weight:400;color:var(--muted)}
.ha-req-required{color:var(--accent)}
.ha-req-input{padding:.72rem 1rem;border:1.5px solid var(--border);border-radius:10px;background:var(--bg);font-size:.925rem;color:var(--ink);font-family:inherit;transition:border-color .15s,box-shadow .15s;width:100%;display:block}
.ha-req-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.ha-req-input-error{border-color:#e53e3e!important}
.ha-req-input-error:focus{box-shadow:0 0 0 3px rgba(229,62,62,.15)!important}
.ha-req-textarea{resize:vertical;min-height:130px;line-height:1.65}
.ha-req-hint{font-size:.74rem;color:var(--muted);line-height:1.5}
/* Consent */
.ha-req-consent{display:flex;align-items:flex-start;gap:.75rem;font-size:.875rem;color:var(--muted);cursor:pointer;margin-top:1.25rem;line-height:1.55}
.ha-req-consent input[type=checkbox]{margin-top:.18rem;accent-color:var(--accent);width:15px;height:15px;flex-shrink:0;cursor:pointer}
.ha-req-consent a{color:var(--accent)}
/* Summary strip */
.ha-req-summary{display:flex;flex-wrap:wrap;gap:.45rem;padding:1rem 1.1rem;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;margin-bottom:1.25rem;min-height:2.5rem}
.ha-req-summary:empty{display:none}
.ha-req-sum-item{display:inline-flex;align-items:center;padding:.28rem .65rem;background:var(--accent-soft);color:var(--accent);border-radius:6px;font-size:.78rem;font-weight:600}
/* Nav bar */
.ha-req-nav{display:flex;justify-content:space-between;align-items:center;margin-top:1.75rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.ha-req-next-btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
/* Errors */
.ha-req-error{font-size:.775rem;color:#e53e3e;margin-top:.2rem;line-height:1.4}
.ha-req-server-errors{background:#fff5f5;border:1px solid #fed7d7;border-radius:10px;padding:1rem 1.25rem;margin-top:1rem;font-size:.875rem;color:#c53030;line-height:1.65}
/* Success state */
.ha-req-success{text-align:center;padding:3.5rem 1rem}
.ha-req-success-icon{width:4.5rem;height:4.5rem;background:rgba(22,163,74,.1);color:#16a34a;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.ha-req-success h2{font-family:'Outfit',sans-serif;font-size:1.9rem;font-weight:900;letter-spacing:-.05em;color:var(--ink);margin-bottom:.75rem}
.ha-req-success p{color:var(--muted);font-size:1rem;max-width:30rem;margin:0 auto 1.25rem;line-height:1.7}
.ha-req-success-meta{display:flex;justify-content:center;flex-wrap:wrap;gap:.45rem;margin-bottom:2rem}
.ha-req-success-meta span{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:.25rem .75rem;font-size:.8rem;font-weight:600;color:var(--muted)}
