:root{--blue:#1e3a8a;--blue-mid:#e30613;--blue-light:#fff5f5;--blue-pale:#ffe4e4;--red:#e30613;--red-dark:#b00010;--ink:#111827;--ink-2:#374151;--ink-3:#6b7280;--paper:#ffffff;--paper-2:#fff8f8;--paper-3:#fff0f0;--border:#e5e7eb;--border-2:#dbeafe;--font-display:'Fraunces', Georgia, serif;--font-body:'Figtree', -apple-system, sans-serif;--container:1280px;--r:8px}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}img{max-width:100%;height:auto;display:block}a{text-decoration:none}1,9..144,300..700&family=Figtree:wght@300;400;500;600;700&display=swap');

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5,h6{line-height:1.2;color:var(--ink)}
p{color:var(--ink-3);line-height:1.7}

/* ── CONTAINER ── */
.container{max-width:1200px;margin:0 auto;padding:0 40px}

/* ═══════════════════════════════════
   HEADER / NAV
═══════════════════════════════════ */
.site-header{
  position:sticky;top:0;z-index:500;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s;
}
.site-header.scrolled{box-shadow:0 4px 24px rgba(30,58,138,.08)}
.header-inner{
  max-width:1200px;margin:0 auto;padding:18px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
}
.site-logo{
  font-family:var(--font-display);font-style:italic;font-weight:400;
  font-size:28px;color:var(--ink)!important;letter-spacing:-.02em;
  display:flex;align-items:baseline;gap:1px;
}
.site-logo .dot{color:var(--blue-mid);font-style:normal}
.site-logo:hover{color:var(--blue)!important}
.site-nav{display:flex;align-items:center;gap:8px}
.nav-link{
  color:var(--ink-2)!important;font-size:14px;font-weight:500;
  padding:8px 14px;border-radius:6px;
  transition:color .15s,background .15s;
}
.nav-link:hover{color:var(--blue)!important;background:var(--blue-light)}
.nav-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 22px;background:var(--blue);color:#fff!important;
  font-size:14px;font-weight:600;border-radius:var(--r);
  transition:background .2s,transform .15s;
  margin-left:8px;
}
.nav-cta:hover{background:#1e40af;transform:translateY(-1px)}

/* ═══════════════════════════════════
   BUTTONS
═══════════════════════════════════ */
.btn-prim{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;background:var(--blue);color:#fff!important;
  font-size:15px;font-weight:600;border-radius:var(--r);
  transition:background .2s,transform .15s;text-decoration:none;
}
.btn-prim:hover{background:#1e40af;transform:translateY(-1px)}
.btn-out{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border:2px solid var(--blue);color:var(--blue)!important;
  font-size:15px;font-weight:600;border-radius:var(--r);
  transition:background .2s;text-decoration:none;
}
.btn-out:hover{background:var(--blue-light)}

/* ═══════════════════════════════════
   FOOTER
═══════════════════════════════════ */
.site-footer{
  background:var(--ink);
  padding:80px 0 40px;
}
.footer-grid{
  max-width:1200px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:56px;
}
.footer-brand{
  font-family:var(--font-display);font-style:italic;
  font-size:42px;color:#fff;margin-bottom:16px;
}
.footer-brand .dot{color:var(--blue-mid);font-style:normal}
.footer-about{font-size:14px;line-height:1.7;color:rgba(255,255,255,.55);max-width:300px}
.footer-col h5{
  font-size:11px;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;color:var(--blue-mid);margin-bottom:20px;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{color:rgba(255,255,255,.6)!important;font-size:14px;transition:color .15s}
.footer-col a:hover{color:#fff!important}
.footer-bottom{
  max-width:1200px;margin:0 auto;padding:32px 40px 0;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
}
.footer-copy{font-size:13px;color:rgba(255,255,255,.4)}
.footer-address{font-size:13px;color:rgba(255,255,255,.4)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:13px;color:rgba(255,255,255,.4)!important;transition:color .15s}
.footer-legal a:hover{color:rgba(255,255,255,.8)!important}

/* ═══════════════════════════════════
   COOKIE BANNER
═══════════════════════════════════ */
#adoan-cookie{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:#fff;color:var(--ink);padding:.9rem 2rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;
  box-shadow:0 -4px 24px rgba(0,0,0,.08);
  border-top:1px solid var(--border);
  font-size:.84rem;line-height:1.5;
}
#adoan-cookie a{color:var(--blue-mid);text-decoration:underline}
.cookie-btns{display:flex;gap:.6rem;flex-shrink:0}
.cookie-btns button{
  padding:.5rem 1.2rem;border-radius:6px;border:none;
  cursor:pointer;font-size:.82rem;font-weight:600;
}
.cookie-acc{background:var(--blue);color:#fff}
.cookie-acc:hover{background:#1e40af}
.cookie-rej{background:var(--paper-2);color:var(--ink-2);border:1px solid var(--border)!important}

/* ═══════════════════════════════════
   CHATBOT BUTTON
═══════════════════════════════════ */
#adoan-chat-btn{
  position:fixed;bottom:28px;right:28px;z-index:9998;
  width:56px;height:56px;border-radius:50%;
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(30,58,138,.35);
  cursor:pointer;border:none;
  transition:transform .2s,box-shadow .2s;
}
#adoan-chat-btn:hover{transform:scale(1.08);box-shadow:0 8px 28px rgba(30,58,138,.45)}

/* ═══════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* ═══════════════════════════════════
   RESPONSIVE
═══════════════════════════════════ */
@media(max-width:900px){
  .header-inner{padding:14px 20px}
  .container{padding:0 20px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr}
  .site-nav{display:none}
}


/* ── SHOP PAGE — dynamic grid ───────────────────────────────────── */
.sh-shop { background: var(--paper); }

.sh-shop-hero { padding: 80px 0 60px; background: var(--paper); border-bottom: 1px solid var(--border); }
.sh-shop-hero-inner { display: flex; gap: 48px; align-items: flex-start; }
.sh-shop-hero-content { flex: 1; }
.sh-shop-h1 { font-family: var(--serif); font-size: clamp(2.2rem,5vw,3.4rem); font-weight: 700; color: var(--ink); line-height: 1.15; margin: 12px 0 16px; }
.sh-shop-h1 em { font-style: italic; color: var(--blue); }
.sh-shop-sub { font-size: 1.05rem; color: var(--ink-2); max-width: 480px; line-height: 1.65; margin-bottom: 24px; }
.sh-shop-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.sh-shop-badges span { border: 1px solid var(--border); border-radius: 999px; padding: 5px 14px; font-size: .8rem; color: var(--ink-2); }

.sh-cta-card { background: var(--paper-2); border: 1px solid var(--border); border-radius: 16px; padding: 28px; min-width: 300px; }
.sh-cta-title { font-size: 1.1rem; font-weight: 700; color: var(--ink); margin-bottom: 8px; }
.sh-cta-desc { font-size: .9rem; color: var(--ink-2); line-height: 1.55; margin-bottom: 20px; }
.sh-btn { display: inline-block; padding: 13px 22px; border-radius: 8px; font-size: .9rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: opacity .2s; }
.sh-btn:hover { opacity: .85; }
.sh-btn-prim { background: var(--blue); color: #fff; width: 100%; text-align: center; box-sizing: border-box; }
.sh-btn-dark { background: var(--blue); color: #fff; font-size: .85rem; padding: 11px 18px; }
.sh-cta-checks { margin-top: 12px; display: flex; flex-direction: column; gap: 4px; font-size: .8rem; color: var(--ink-3); }

/* Body / category grid */
.sh-shop-body { padding: 60px 0 100px; }
.sh-cat-section { margin-bottom: 56px; }
.sh-cat-header { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 2px solid var(--border); }
.sh-cat-icon { width: 36px; height: 36px; border-radius: 8px; background: var(--paper-3); display: flex; align-items: center; justify-content: center; font-size: .7rem; font-weight: 700; color: var(--blue); letter-spacing: .05em; flex-shrink: 0; line-height: 36px; text-align: center; }
.sh-cat-name { font-size: 1.3rem; font-weight: 700; color: var(--ink); flex: 1; }
.sh-cat-count { font-size: .82rem; color: var(--ink-3); }

.sh-prod-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }

/* ── PREMIUM ANIMATED PRODUCT CARDS (wearebrand-style) ── */

/* Grid */
.sh-prod-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 24px;
  margin-top: 24px;
}

/* Card base */
.sh-prod-card {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  background: var(--paper);
  border: 1px solid var(--border);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  transition: box-shadow .5s cubic-bezier(.23,1,.32,1), transform .5s cubic-bezier(.23,1,.32,1);
  transform-style: preserve-3d;
  will-change: transform;
  cursor: pointer;
}
.sh-prod-card:hover {
  box-shadow: 0 28px 56px rgba(0,0,0,.18), 0 0 0 1px rgba(0,0,0,.04);
}

/* Visual area */
.sh-card-vis {
  position: relative;
  height: 200px;
  overflow: hidden;
}

/* Dot grid texture */
.sh-card-grid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.15) 1px, transparent 1px);
  background-size: 20px 20px;
  z-index: 1;
}

/* Glowing orb */
.sh-card-orb {
  position: absolute;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  top: -50px;
  right: -40px;
  opacity: .35;
  filter: blur(50px);
  animation: orb-float 4s ease-in-out infinite;
  z-index: 1;
}
@keyframes orb-float {
  0%,100% { transform: translateY(0) scale(1); opacity:.35; }
  50%      { transform: translateY(-10px) scale(1.1); opacity:.5; }
}

/* SVG Icon */
.sh-card-ico {
  position: absolute;
  bottom: 18px;
  left: 20px;
  width: 52px;
  height: 52px;
  z-index: 2;
  transition: transform .5s cubic-bezier(.23,1,.32,1), filter .3s;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.3));
}
.sh-prod-card:hover .sh-card-ico {
  transform: translateY(-6px) scale(1.12);
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.4));
}

/* Category label badge */
.sh-card-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.9);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 99px;
}

/* Shine sweep on hover */
.sh-card-shine {
  position: absolute;
  inset: 0;
  z-index: 4;
  background: linear-gradient(
    105deg,
    transparent 20%,
    rgba(255,255,255,.08) 50%,
    transparent 80%
  );
  background-size: 200% 100%;
  background-position: 200% 0;
  transition: background-position .7s ease;
  pointer-events: none;
}
.sh-prod-card:hover .sh-card-shine {
  background-position: -100% 0;
}

/* Bottom slide-up overlay */
.sh-card-overlay {
  position: absolute;
  inset: 0;
  z-index: 5;
  background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,0) 60%);
  opacity: 0;
  transition: opacity .4s ease;
  pointer-events: none;
}
.sh-prod-card:hover .sh-card-overlay { opacity: 1; }

/* Text body */
.sh-prod-body {
  padding: 18px 20px 20px;
}
.sh-prod-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.3;
  margin-bottom: 8px;
  transition: color .2s;
}
.sh-prod-card:hover .sh-prod-title { color: var(--red); }

.sh-prod-desc {
  font-size: .82rem;
  color: var(--ink-3);
  line-height: 1.55;
  margin-bottom: 14px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sh-prod-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.sh-prod-price {
  font-size: .92rem;
  font-weight: 700;
  color: var(--ink);
}
.sh-btn {
  font-size: .8rem;
  font-weight: 700;
  color: var(--red);
  text-decoration: none;
  letter-spacing: .03em;
  transition: gap .2s;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.sh-btn:hover { gap: 8px; }

/* Category section */
.sh-cat-section { margin-bottom: 60px; }
.sh-cat-header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--border);
  margin-bottom: 8px;
}
.sh-cat-title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--ink);
}
.sh-cat-count {
  font-size: .82rem;
  color: var(--ink-3);
  font-weight: 500;
}

/* Shop hero */
.sh-shop { background: var(--paper); padding-bottom: 80px; }
.sh-shop-hero { padding: 70px 0 50px; border-bottom: 1px solid var(--border); margin-bottom: 60px; }
.sh-shop-h1 { font-family: var(--font-display); font-size: clamp(2rem,5vw,3.2rem); font-weight: 700; color: var(--ink); margin-bottom: 10px; }
.sh-shop-sub { font-size: 1rem; color: var(--ink-3); }
.sh-shop-body {}

/* Page default */
.pg-main { padding: 80px 0; }
.pg-title { font-family: var(--font-display); font-size: 2rem; font-weight: 700; margin-bottom: 24px; }
.pg-body { color: var(--ink-2); line-height: 1.7; }


/* ── ADOAN Animated Card Visuals ── */
.sh-anim{position:absolute;inset:0;overflow:hidden}
.sh-anim-bars{display:flex;align-items:flex-end;justify-content:center;gap:8px;padding:16px 24px 22px}
.sh-anim-bars>span{flex:1;max-width:16px;height:var(--h);background:rgba(255,255,255,.82);border-radius:3px 3px 0 0;transform-origin:bottom;animation:adoan-bar 1.8s ease-in-out infinite;animation-delay:var(--d)}
@keyframes adoan-bar{0%,100%{transform:scaleY(1);opacity:.5}50%{transform:scaleY(.22);opacity:1}}
.sh-anim-rings{display:flex;align-items:center;justify-content:center}
.sh-ring{position:absolute;width:46px;height:46px;border-radius:50%;border:2px solid rgba(255,255,255,.75);animation:adoan-ring 2.1s ease-out infinite}
.sh-ring:nth-child(2){animation-delay:.7s}
.sh-ring:nth-child(3){animation-delay:1.4s}
.sh-ring-core{position:relative;z-index:2;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center}
.sh-ring-core>svg{width:24px;height:24px}
@keyframes adoan-ring{to{transform:scale(4.5);opacity:0}}
.sh-anim-chart{display:flex;align-items:flex-end}
.sh-anim-chart>svg{width:100%;height:100%;display:block;overflow:visible}
.sh-chart-fill{fill:rgba(255,255,255,.1)}
.sh-chart-line{fill:none;stroke:rgba(255,255,255,.9);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:380;animation:adoan-cdraw 3s ease-in-out infinite}
.sh-chart-dot{fill:#fff;animation:adoan-cdot 3s ease-in-out infinite}
@keyframes adoan-cdraw{0%{stroke-dashoffset:380;opacity:0}15%{opacity:1}70%{stroke-dashoffset:0;opacity:1}90%,100%{stroke-dashoffset:0;opacity:0}}
@keyframes adoan-cdot{0%,65%{r:0;opacity:0}75%{r:6;opacity:1}85%{r:8;opacity:.5}100%{r:0;opacity:0}}
.sh-anim-nodes>svg{width:100%;height:100%;display:block}
.sh-nl{stroke:rgba(255,255,255,.28);stroke-width:1.2;stroke-dasharray:160;animation:adoan-nl 2.5s ease-in-out infinite;animation-delay:var(--nd)}
.sh-nd{fill:rgba(255,255,255,.85);animation:adoan-nd 2.5s ease-in-out infinite;animation-delay:var(--nd)}
@keyframes adoan-nl{0%,100%{stroke-dashoffset:160;opacity:0}35%{stroke-dashoffset:0;opacity:.75}65%{stroke-dashoffset:0;opacity:.2}}
@keyframes adoan-nd{0%,100%{opacity:.4}50%{opacity:1;filter:drop-shadow(0 0 5px rgba(255,255,255,.9))}}
.sh-anim-city{display:flex;align-items:flex-end;justify-content:center;gap:4px;padding:0 14px}
.sh-anim-city>div{flex:1;height:var(--bh);background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-bottom:none;transform-origin:bottom;animation:adoan-rise 1.2s cubic-bezier(.23,1,.32,1) var(--bd) both,adoan-blink 4s ease-in-out calc(var(--bd) + 1.2s) infinite}
@keyframes adoan-rise{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes adoan-blink{0%,100%{background:rgba(255,255,255,.18)}50%{background:rgba(255,255,255,.38)}}
.sh-anim-scan{position:relative}
.sh-scan-ring,.sh-scan-ring2{position:absolute;left:50%;top:50%;border-radius:50%;border:1px solid rgba(255,255,255,.4);transform:translate(-50%,-50%)}
.sh-scan-ring{width:90px;height:90px}
.sh-scan-ring2{width:55px;height:55px}
.sh-scan-radar{position:absolute;left:50%;top:50%;width:45px;height:2px;background:linear-gradient(90deg,rgba(255,255,255,.05),rgba(255,255,255,.9));transform-origin:left center;margin-top:-1px;animation:adoan-radar 2s linear infinite;box-shadow:0 0 8px rgba(255,255,255,.3)}
.sh-scan-dot{position:absolute;left:50%;top:50%;width:8px;height:8px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);animation:adoan-sdot 2s ease-in-out infinite;box-shadow:0 0 12px rgba(255,255,255,.8)}
@keyframes adoan-radar{to{transform:rotate(360deg)}}
@keyframes adoan-sdot{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.4);opacity:1}}
.sh-anim-chat{display:flex;flex-direction:column;justify-content:center;gap:8px;padding:14px 16px}
.sh-bubble{padding:5px 11px;border-radius:10px;font-size:.63rem;font-weight:500;color:rgba(255,255,255,.95);opacity:0;animation:adoan-bpop 3.6s ease-in-out infinite;animation-delay:var(--cd);max-width:82%;line-height:1.4}
.sh-bl{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);align-self:flex-start;border-bottom-left-radius:2px}
.sh-br{background:rgba(255,255,255,.32);border:1px solid rgba(255,255,255,.4);align-self:flex-end;border-bottom-right-radius:2px}
@keyframes adoan-bpop{0%{opacity:0;transform:translateY(7px) scale(.9)}12%{opacity:1;transform:none}65%{opacity:1}80%,100%{opacity:0;transform:translateY(-4px)}}
.sh-anim-wave{display:flex;align-items:center}
.sh-anim-wave>svg{width:100%;height:100%;display:block;overflow:visible}
.sh-wave{fill:none;stroke:rgba(255,255,255,.85);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:520;animation:adoan-wdraw 2.5s ease-in-out infinite}
.sh-wpulse{position:absolute;right:14px;top:50%;width:9px;height:9px;border-radius:50%;background:#fff;transform:translateY(-50%);box-shadow:0 0 14px rgba(255,255,255,.8);animation:adoan-wpulse 2.5s ease-in-out infinite}
@keyframes adoan-wdraw{0%{stroke-dashoffset:520;opacity:0}15%{opacity:1}65%{stroke-dashoffset:0;opacity:1}80%,100%{stroke-dashoffset:0;opacity:0}}
@keyframes adoan-wpulse{0%,60%{opacity:0;transform:translateY(-50%) scale(0)}70%{opacity:1;transform:translateY(-50%) scale(1.3)}82%,90%{opacity:1;transform:translateY(-50%) scale(1)}97%,100%{opacity:0;transform:translateY(-50%) scale(0)}}
.sh-gear-lg,.sh-gear-sm{position:absolute;top:50%;border-radius:8px;background:rgba(255,255,255,.55)}
.sh-gear-lg{width:58px;height:58px;left:22px;animation:adoan-glg 5s linear infinite}
.sh-gear-sm{width:42px;height:42px;right:22px;border-radius:6px;background:rgba(255,255,255,.5);animation:adoan-gsm 3.3s linear infinite}
.sh-gear-lg::before,.sh-gear-lg::after,.sh-gear-sm::before,.sh-gear-sm::after{content:'';position:absolute;inset:0;background:inherit;border-radius:inherit}
.sh-gear-lg::before,.sh-gear-sm::before{transform:rotate(30deg)}
.sh-gear-lg::after,.sh-gear-sm::after{transform:rotate(60deg)}
.sh-gear-hole{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;background:rgba(0,0,0,.45);z-index:1}
.sh-gear-lg .sh-gear-hole{width:26px;height:26px}
.sh-gear-sm .sh-gear-hole{width:18px;height:18px}
@keyframes adoan-glg{from{transform:translateY(-50%) rotate(0)}to{transform:translateY(-50%) rotate(360deg)}}
@keyframes adoan-gsm{from{transform:translateY(-50%) rotate(0)}to{transform:translateY(-50%) rotate(-360deg)}}
.sh-anim-doc{display:flex;flex-direction:column;justify-content:center;padding:18px 28px;gap:10px}
.sh-docline{height:7px;border-radius:3px;background:rgba(255,255,255,.7);width:0;animation:adoan-docl 4s ease-in-out infinite;animation-delay:var(--dd)}
.sh-doc-seal{font-size:2.4rem;opacity:0;text-align:center;margin-top:2px;animation:adoan-seal 4s ease-in-out 1.8s infinite}
@keyframes adoan-docl{0%{width:0;opacity:1}28%{width:var(--dw)}55%{width:var(--dw);opacity:1}70%,100%{width:var(--dw);opacity:0}}
@keyframes adoan-seal{0%,35%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.15)}62%,75%{opacity:1;transform:scale(1)}88%,100%{opacity:0}}
.sh-anim-funnel{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.sh-fln{height:20px;border-radius:4px;background:rgba(255,255,255,var(--fo));border:1px solid rgba(255,255,255,.45);width:0;animation:adoan-fln 2.5s cubic-bezier(.23,1,.32,1) var(--fd) infinite}
.sh-fdot{width:12px;height:12px;border-radius:50%;background:#fff;margin-top:6px;animation:adoan-fdrop 2.5s ease-in-out infinite;box-shadow:0 0 16px rgba(255,255,255,.9)}
@keyframes adoan-fln{0%{width:0;opacity:0}25%{width:var(--fw);opacity:1}65%{width:var(--fw);opacity:.9}85%,100%{width:var(--fw);opacity:0}}
@keyframes adoan-fdrop{0%{transform:translateY(-55px);opacity:0}20%{opacity:1}55%{transform:translateY(0);opacity:1}75%,100%{transform:translateY(14px);opacity:0}}

/* ══════════════════════════════════════════
   HOMEPAGE — Consulting Layout (hp-*)
══════════════════════════════════════════ */

/* ── Shared ── */
.hp-container{max-width:1100px;margin:0 auto;padding:0 24px}
.hp-section-label{font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#2563eb;margin-bottom:14px}
.hp-section-h2{font-size:clamp(1.9rem,3.5vw,2.8rem);font-weight:700;line-height:1.2;color:#0f172a;margin:0 0 16px}
.hp-section-h2 em{color:#2563eb;font-style:normal}
.hp-section-sub{font-size:1.05rem;color:#475569;max-width:640px;margin:0 0 48px;line-height:1.65}
.hp-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:8px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s;cursor:pointer;border:2px solid transparent}
.hp-btn-prim{background:#2563eb;color:#fff;border-color:#2563eb}
.hp-btn-prim:hover{background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 8px 24px rgba(37,99,235,.3)}
.hp-btn-ghost{background:transparent;color:#2563eb;border-color:#2563eb}
.hp-btn-ghost:hover{background:#eff6ff}
.hp-btn-white{background:#fff;color:#2563eb;border-color:#fff}
.hp-btn-white:hover{background:#f1f5f9}
.hp-btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.hp-btn-outline-white:hover{background:rgba(255,255,255,.1)}

/* ── Hero ── */
.hp-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 60%,#1d4ed8 100%);padding:100px 24px 110px;text-align:center}
.hp-hero-inner{max-width:800px;margin:0 auto}
.hp-hero-badge{display:inline-block;background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:7px 18px;border-radius:99px;border:1px solid rgba(255,255,255,.2);margin-bottom:32px}
.hp-hero-h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;line-height:1.15;color:#fff;margin:0 0 24px}
.hp-hero-h1 em{color:#93c5fd;font-style:normal}
.hp-hero-sub{font-size:1.15rem;color:rgba(255,255,255,.8);line-height:1.7;margin:0 auto 40px;max-width:640px}
.hp-hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.hp-hero-trust{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;font-size:.82rem;color:rgba(255,255,255,.65)}
.hp-hero-trust span::before{content:''}

/* ── Services ── */
.hp-services{padding:90px 0;background:#fff}
.hp-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-bottom:40px}
.hp-svc-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:36px 30px;transition:all .25s}
.hp-svc-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.hp-svc-card--featured{background:linear-gradient(145deg,#eff6ff,#dbeafe);border-color:#bfdbfe}
.hp-svc-icon{font-size:2rem;margin-bottom:18px}
.hp-svc-card h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 12px}
.hp-svc-card>p{color:#475569;font-size:.95rem;line-height:1.6;margin:0 0 20px}
.hp-svc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.hp-svc-list li{font-size:.88rem;color:#334155;padding-left:20px;position:relative}
.hp-svc-list li::before{content:'→';position:absolute;left:0;color:#2563eb;font-weight:700}
.hp-services-cta{text-align:center}

/* ── Process ── */
.hp-process{padding:90px 0;background:#f8fafc}
.hp-process-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:start;gap:16px;margin-top:8px}
.hp-step{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:28px 24px}
.hp-step-num{font-size:2.5rem;font-weight:800;color:#dbeafe;line-height:1;margin-bottom:12px}
.hp-step-body h4{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 8px}
.hp-step-body p{font-size:.88rem;color:#475569;line-height:1.6;margin:0}
.hp-step-arrow{font-size:1.8rem;color:#bfdbfe;align-self:center;margin-top:20px}

/* ── Why ADOAN ── */
.hp-why{padding:90px 0;background:#0f172a}
.hp-why-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.hp-why .hp-section-label{color:#60a5fa}
.hp-why .hp-section-h2{color:#f8fafc}
.hp-why .hp-section-h2 em{color:#60a5fa}
.hp-why>div>p,.hp-why-text>p{color:#94a3b8;font-size:1rem;line-height:1.7;margin-bottom:32px}
.hp-why-features{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.hp-wf-item{display:flex;gap:12px;align-items:flex-start}
.hp-wf-icon{font-size:1.5rem;flex-shrink:0}
.hp-wf-item strong{display:block;font-size:.95rem;color:#f1f5f9;margin-bottom:4px}
.hp-wf-item p{font-size:.83rem;color:#64748b;margin:0;line-height:1.5}
.hp-why-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp-stat-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:28px 24px}
.hp-stat-num{font-size:2.4rem;font-weight:800;color:#60a5fa;display:block;margin-bottom:8px}
.hp-stat-card p{font-size:.83rem;color:#94a3b8;margin:0;line-height:1.5}

/* ── Industries ── */
.hp-industries{padding:90px 0;background:#fff}
.hp-industries-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.hp-ind-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:28px 24px;transition:all .2s}
.hp-ind-item:hover{border-color:#bfdbfe;background:#eff6ff;transform:translateY(-2px)}
.hp-ind-item span{font-size:2rem;display:block;margin-bottom:12px}
.hp-ind-item strong{display:block;font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:8px}
.hp-ind-item p{font-size:.85rem;color:#475569;margin:0;line-height:1.55}

/* ── FAQ ── */
.hp-faq{padding:90px 0;background:#f8fafc}
.hp-faq-inner{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.hp-faq-head .hp-section-h2{margin-bottom:0}
.hp-faq-list{display:flex;flex-direction:column;gap:0}
.hp-faq-item{border-bottom:1px solid #e2e8f0;padding:22px 0}
.hp-faq-item:first-child{border-top:1px solid #e2e8f0}
.hp-faq-q{font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:10px;cursor:pointer}
.hp-faq-q::before{content:'Q ';color:#2563eb;font-size:.8rem;letter-spacing:.05em}
.hp-faq-a{font-size:.92rem;color:#475569;line-height:1.7;margin:0}

/* ── CTA Final ── */
.hp-cta-final{background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);padding:100px 24px;text-align:center}
.hp-cta-final .hp-container{max-width:720px}
.hp-cta-badge{display:inline-block;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:6px 16px;border-radius:99px;border:1px solid rgba(255,255,255,.25);margin-bottom:24px}
.hp-cta-final h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:#fff;line-height:1.2;margin:0 0 20px}
.hp-cta-final h2 em{color:#93c5fd;font-style:normal}
.hp-cta-final p{font-size:1.05rem;color:rgba(255,255,255,.8);line-height:1.7;margin:0 auto 40px;max-width:560px}
.hp-cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.hp-cta-trust{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;font-size:.82rem;color:rgba(255,255,255,.6)}

/* ── Responsive ── */
@media(max-width:900px){
  .hp-services-grid,.hp-industries-grid{grid-template-columns:1fr 1fr}
  .hp-why-inner{grid-template-columns:1fr}
  .hp-faq-inner{grid-template-columns:1fr}
  .hp-process-steps{grid-template-columns:1fr;gap:12px}
  .hp-step-arrow{transform:rotate(90deg);justify-self:center;margin-top:0}
}
@media(max-width:640px){
  .hp-services-grid,.hp-industries-grid,.hp-why-features{grid-template-columns:1fr}
  .hp-why-stats{grid-template-columns:1fr 1fr}
  .hp-hero-cta,.hp-cta-actions{flex-direction:column;align-items:center}
}


/* ============================================================
   BRUTAL ANIMATIONS v1.0
   ============================================================ */

/* --- Curtain Intro --- */
#hp-curtain {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  pointer-events: none;
}
.hp-curtain-top,
.hp-curtain-bot {
  flex: 1;
  background: #0f172a;
  transition: transform 0.95s cubic-bezier(0.76, 0, 0.24, 1);
  will-change: transform;
}
.hp-curtain-top {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 8px;
}
#hp-curtain.hp-curtain-open .hp-curtain-top { transform: translateY(-100%); }
#hp-curtain.hp-curtain-open .hp-curtain-bot { transform: translateY(100%); }
.hp-curtain-logo {
  font-size: clamp(2.5rem, 9vw, 8rem);
  font-weight: 900;
  color: #fff;
  letter-spacing: .2em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(12px);
  animation: curtainLogoIn 0.5s 0.1s cubic-bezier(0.16,1,0.3,1) forwards;
}
@keyframes curtainLogoIn {
  to { opacity: 1; transform: none; }
}

/* --- Hero headline scramble wrappers --- */
.hp-hero-h1 .hp-hl1,
.hp-hero-h1 .hp-hl2 {
  display: inline-block;
  opacity: 0;
  will-change: opacity;
  transition: opacity 0.5s ease;
}
.hp-hero-h1 .hp-hl1.in,
.hp-hero-h1 .hp-hl2.in {
  opacity: 1;
}

/* --- Marquee Band --- */
.hp-marquee {
  background: #1d4ed8;
  padding: 13px 0;
  overflow: hidden;
  white-space: nowrap;
  cursor: default;
  user-select: none;
}
.hp-marquee-inner {
  display: inline-flex;
  align-items: center;
  animation: hp-marquee-scroll 30s linear infinite;
  will-change: transform;
}
.hp-marquee:hover .hp-marquee-inner {
  animation-play-state: paused;
}
.hp-marquee-item {
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  color: #fff;
  letter-spacing: .16em;
  padding: 0 28px;
  flex-shrink: 0;
}
.hp-marquee-sep {
  color: rgba(255,255,255,.4);
  font-size: .65rem;
  flex-shrink: 0;
}
@keyframes hp-marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* --- Scroll Reveal --- */
.reveal {
  opacity: 0;
  transform: translateY(44px);
  transition: opacity 0.72s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.72s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* --- Custom Cursor (fine pointer / desktop only) --- */
#hp-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 10px;
  height: 10px;
  background: #3b82f6;
  border-radius: 50%;
  pointer-events: none;
  z-index: 99998;
  transform: translate(-50%, -50%) scale(1);
  transition: transform 0.18s ease;
  mix-blend-mode: screen;
}
#hp-cursor-ring {
  position: fixed;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  border: 1.5px solid rgba(59, 130, 246, 0.5);
  border-radius: 50%;
  pointer-events: none;
  z-index: 99997;
  transform: translate(-50%, -50%);
  transition: width 0.28s ease, height 0.28s ease;
}
@media (hover: none), (pointer: coarse) {
  #hp-cursor, #hp-cursor-ring { display: none !important; }
}
/* ============================================================
   ANIMATIONS v2 — Premium Loader + Word Stagger
   ============================================================ */

/* --- Loader: single full-screen panel slides up --- */
#hp-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: #0f172a;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  transition: transform 1.1s cubic-bezier(0.76, 0, 0.24, 1);
  will-change: transform;
}
#hp-loader.hp-loader-exit {
  transform: translateY(-100%);
}
.hp-loader-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.hp-loader-logo {
  font-size: clamp(3.5rem, 11vw, 10rem);
  font-weight: 900;
  color: #fff;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  line-height: 1;
  opacity: 0;
  animation: loaderLogoIn 0.55s 0.1s cubic-bezier(0.16,1,0.3,1) forwards;
}
.hp-loader-tagline {
  font-size: clamp(.75rem, 1.5vw, 1rem);
  font-weight: 500;
  color: rgba(255,255,255,.45);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0;
  animation: loaderLogoIn 0.55s 0.3s cubic-bezier(0.16,1,0.3,1) forwards;
}
@keyframes loaderLogoIn {
  to { opacity: 1; }
}
.hp-loader-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  background: #2563eb;
  width: 0;
  transition: width 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* --- Hero: word-by-word slide up from below --- */
.hp-hero-h1 .hp-hl1,
.hp-hero-h1 .hp-hl2 {
  display: inline-block;
}
.hp-word-wrap {
  display: inline-block;
  overflow: hidden;
  vertical-align: bottom;
}
.hp-word {
  display: inline-block;
  transform: translateY(115%);
  transition: transform 0.75s cubic-bezier(0.16, 1, 0.3, 1);
}
.hp-word.in {
  transform: translateY(0);
}

/* --- Marquee Band --- */
.hp-marquee {
  background: #1d4ed8;
  padding: 13px 0;
  overflow: hidden;
  white-space: nowrap;
  cursor: default;
  user-select: none;
}
.hp-marquee-inner {
  display: inline-flex;
  align-items: center;
  animation: hp-marquee-scroll 30s linear infinite;
  will-change: transform;
}
.hp-marquee:hover .hp-marquee-inner {
  animation-play-state: paused;
}
.hp-marquee-item {
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  color: #fff;
  letter-spacing: .16em;
  padding: 0 28px;
  flex-shrink: 0;
}
.hp-marquee-sep {
  color: rgba(255,255,255,.4);
  font-size: .65rem;
  flex-shrink: 0;
}
@keyframes hp-marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* --- Scroll Reveal --- */
.reveal {
  opacity: 0;
  transform: translateY(44px);
  transition: opacity 0.72s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.72s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* --- Custom Cursor (desktop only) --- */
#hp-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 10px;
  height: 10px;
  background: #3b82f6;
  border-radius: 50%;
  pointer-events: none;
  z-index: 99998;
  transform: translate(-50%, -50%) scale(1);
  transition: transform 0.18s ease;
  mix-blend-mode: screen;
}
#hp-cursor-ring {
  position: fixed;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  border: 1.5px solid rgba(59, 130, 246, 0.5);
  border-radius: 50%;
  pointer-events: none;
  z-index: 99997;
  transform: translate(-50%, -50%);
  transition: width 0.28s ease, height 0.28s ease;
}
@media (hover: none), (pointer: coarse) {
  #hp-cursor, #hp-cursor-ring { display: none !important; }
}

/* --- Fix: word-wrap spans visible, override old opacity:0 on hl1/hl2 --- */
.hp-hero-h1 .hp-hl1,
.hp-hero-h1 .hp-hl2 { opacity: 1 !important; display: inline-block; }
/* Old curtain no longer used */
#hp-curtain { display: none !important; }


/* ══════════════════════════════════════════
   ADOAN — Premium Button System v2.0
   World-class Swiss Consulting Design
══════════════════════════════════════════ */

/* ── Base reset ── */
.hp-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-body); font-size: 15px; font-weight: 600;
  letter-spacing: .025em; text-decoration: none; cursor: pointer;
  border: 1.5px solid transparent; position: relative; overflow: hidden;
  transition: all 0.32s cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-font-smoothing: antialiased; padding: 0;
}

/* ── PRIMARY — Kostenloses Erstgespräch ── */
.hp-btn-prim {
  padding: 18px 36px;
  border-radius: 14px;
  background: linear-gradient(138deg, #1e3a8a 0%, #2563eb 58%, #3b82f6 100%);
  color: #fff;
  border-color: rgba(96,165,250,0.35);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    0 4px 20px rgba(37,99,235,0.42),
    0 1px 4px rgba(0,0,0,0.18);
}

/* Shimmer light sweep */
.hp-btn-prim::before {
  content: '';
  position: absolute; top: 0; left: -100%;
  width: 50%; height: 100%;
  background: linear-gradient(110deg,
    transparent 25%,
    rgba(255,255,255,0.2) 50%,
    transparent 75%);
  transform: skewX(-18deg);
  transition: left 0.65s ease;
  pointer-events: none;
}
.hp-btn-prim:hover::before { left: 180%; }

.hp-btn-prim:hover {
  background: linear-gradient(138deg, #1e3a8a 0%, #1d4ed8 52%, #2563eb 100%);
  border-color: rgba(147,197,253,0.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.15),
    0 12px 44px rgba(37,99,235,0.58),
    0 2px 10px rgba(0,0,0,0.22);
  transform: translateY(-2px);
}
.hp-btn-prim:active { transform: translateY(0); box-shadow: 0 4px 16px rgba(37,99,235,0.4); }

.hp-btn-prim .hp-btn-text { position: relative; }
.hp-btn-prim .hp-btn-arrow {
  display: flex; align-items: center;
  opacity: 0.85;
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1), opacity 0.3s;
}
.hp-btn-prim:hover .hp-btn-arrow { transform: translateX(5px); opacity: 1; }

/* ── GHOST — Telefon Button ── */
.hp-btn-ghost {
  padding: 17px 28px;
  border-radius: 14px;
  background: rgba(255,255,255,0.05);
  color: rgba(255,255,255,0.88);
  border-color: rgba(255,255,255,0.16) !important;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 2px 12px rgba(0,0,0,0.12);
}
.hp-btn-ghost::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background: linear-gradient(135deg, rgba(255,255,255,0.08) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.3s; pointer-events: none;
}
.hp-btn-ghost:hover::after { opacity: 1; }
.hp-btn-ghost:hover {
  background: rgba(255,255,255,0.11);
  border-color: rgba(255,255,255,0.32) !important;
  color: #fff;
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    0 10px 32px rgba(0,0,0,0.22);
}
.hp-btn-ghost .hp-btn-icon {
  display: flex; align-items: center;
  color: rgba(255,255,255,0.65);
  transition: color 0.25s, transform 0.3s;
}
.hp-btn-ghost:hover .hp-btn-icon { color: #fff; }

@keyframes hp-phone-ring {
  0%,100% { transform: rotate(0deg) scale(1); }
  20%      { transform: rotate(-12deg) scale(1.15); }
  40%      { transform: rotate(10deg) scale(1.12); }
  60%      { transform: rotate(-6deg) scale(1.08); }
}
.hp-btn-ghost:hover .hp-btn-icon svg { animation: hp-phone-ring 0.55s ease; }

/* ── WHITE variant ── */
.hp-btn-white {
  padding: 16px 32px; border-radius: 12px;
  background: #fff; color: var(--ink,#111827);
  border-color: rgba(0,0,0,0.06);
  box-shadow: 0 2px 12px rgba(0,0,0,0.08), 0 1px 3px rgba(0,0,0,0.06);
}
.hp-btn-white:hover {
  background: #f0f4ff; color: #1d4ed8;
  box-shadow: 0 6px 24px rgba(0,0,0,0.12);
  transform: translateY(-2px);
}

/* ── OUTLINE-WHITE ── */
.hp-btn-outline-white {
  padding: 15px 28px; border-radius: 12px;
  background: transparent; color: rgba(255,255,255,0.85);
  border-color: rgba(255,255,255,0.22) !important;
}
.hp-btn-outline-white:hover {
  background: rgba(255,255,255,0.1); color: #fff;
  border-color: rgba(255,255,255,0.5) !important;
  transform: translateY(-2px);
}


/* ══════════════════════════════════════════
   Premium Section Heading Reveal (wearebrand-style)
   Clip-path mask reveal on scroll
══════════════════════════════════════════ */
.hp-reveal-mask {
  clip-path: inset(0 0 100% 0);
  opacity: 0;
  transform: translateY(8px);
  transition:
    clip-path 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: clip-path, opacity, transform;
}
.hp-reveal-mask.in {
  clip-path: inset(0 0 -10% 0);
  opacity: 1;
  transform: translateY(0);
}


/* ══════════════════════════════════════════
   AI-Agent Network Canvas (hero background)
══════════════════════════════════════════ */
.hp-hero { position: relative; overflow: hidden; }
.hp-hero-canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  z-index: 0; pointer-events: none;
  opacity: 0;
  animation: hpCanvasFade 1.6s ease 0.6s forwards;
}
@keyframes hpCanvasFade { to { opacity: 1; } }
.hp-hero-inner { position: relative; z-index: 2; }
/* keep the existing radial glows above canvas but below content */
.hp-hero::before, .hp-hero::after { z-index: 1; }


/* ══════════════════════════════════════════════════════
   ADOAN — World-Class Section Redesign v3.0
   FAQ · Branchen · Warum ADOAN
══════════════════════════════════════════════════════ */

/* ===== Shared section label ===== */
.hp-section-label {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: #2563eb; margin-bottom: 18px;
}
.hp-section-label::before {
  content: ''; width: 28px; height: 2px;
  background: linear-gradient(90deg, #2563eb, #60a5fa); border-radius: 2px;
}

/* ════════ BRANCHEN — Premium Card Grid ════════ */
.hp-branches { padding: 110px 0; background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%); }
.hp-branches .hp-container { text-align: center; }
.hp-branches .hp-section-label { justify-content: center; }
.hp-section-sub {
  font-size: 19px; color: #475569; line-height: 1.7;
  max-width: 560px; margin: 0 auto 56px;
}
.hp-branch-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
  text-align: left;
}
.hp-branch-tile {
  position: relative; background: #fff;
  border: 1px solid #e8edf5; border-radius: 18px;
  padding: 32px 28px; overflow: hidden;
  transition: transform .4s cubic-bezier(0.16,1,0.3,1), box-shadow .4s, border-color .4s;
}
.hp-branch-tile::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #2563eb, #60a5fa);
  transform: scaleX(0); transform-origin: left; transition: transform .45s cubic-bezier(0.16,1,0.3,1);
}
.hp-branch-tile::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(120% 100% at 0% 0%, rgba(37,99,235,.05) 0%, transparent 45%);
  opacity: 0; transition: opacity .4s;
}
.hp-branch-tile:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 50px rgba(37,99,235,.13), 0 4px 14px rgba(0,0,0,.05);
  border-color: rgba(37,99,235,.25);
}
.hp-branch-tile:hover::before { transform: scaleX(1); }
.hp-branch-tile:hover::after { opacity: 1; }
.hp-branch-icon {
  width: 56px; height: 56px; border-radius: 15px;
  display: flex; align-items: center; justify-content: center;
  font-size: 27px; margin-bottom: 20px; position: relative;
  background: linear-gradient(145deg, #eef4ff 0%, #dce9ff 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 4px 12px rgba(37,99,235,.1);
  transition: transform .4s cubic-bezier(0.16,1,0.3,1);
}
.hp-branch-tile:hover .hp-branch-icon { transform: scale(1.08) rotate(-4deg); }
.hp-branch-tile h3 {
  font-size: 19px; font-weight: 700; margin-bottom: 10px; color: #0f172a;
  position: relative;
}
.hp-branch-tile p {
  font-size: 14.5px; color: #64748b; line-height: 1.65; position: relative; margin: 0;
}

/* ════════ FAQ — Elegant Accordion Cards ════════ */
.hp-faq { padding: 110px 0; background: #ffffff; }
.hp-faq-inner {
  display: grid; grid-template-columns: 320px 1fr; gap: 64px;
  max-width: 1180px; margin: 0 auto; padding: 0 24px; align-items: start;
}
.hp-faq-heading {
  position: sticky; top: 110px;
}
.hp-faq-heading .hp-section-label { margin-bottom: 16px; }
.hp-faq-heading h2 {
  font-size: 2.4rem; font-weight: 800; line-height: 1.1; letter-spacing: -.02em;
  color: #0f172a; margin: 0 0 18px;
}
.hp-faq-heading p { font-size: 16px; color: #64748b; line-height: 1.7; }
.hp-faq-list { display: flex; flex-direction: column; gap: 14px; }
.hp-faq-item {
  position: relative; display: block;
  background: #fff; border: 1px solid #e8edf5; border-radius: 16px;
  padding: 26px 28px 26px 64px; cursor: pointer;
  transition: border-color .35s, box-shadow .35s, background .35s;
}
.hp-faq-item:hover {
  border-color: rgba(37,99,235,.3);
  box-shadow: 0 12px 32px rgba(37,99,235,.1);
}
.hp-faq-item.open {
  border-color: rgba(37,99,235,.4);
  box-shadow: 0 16px 40px rgba(37,99,235,.13);
  background: linear-gradient(180deg, #fff 0%, #fafcff 100%);
}
/* The 'Q' badge */
.hp-faq-item > strong:first-child {
  position: absolute; left: 22px; top: 24px;
  width: 30px; height: 30px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(145deg, #2563eb, #1d4ed8);
  color: #fff; font-size: 13px; font-weight: 800;
  box-shadow: 0 4px 12px rgba(37,99,235,.35);
}
.hp-faq-item > div > strong {
  display: block; font-size: 17.5px; font-weight: 700; color: #0f172a;
  line-height: 1.4; padding-right: 36px;
}
.hp-faq-item > div > p {
  font-size: 15px; color: #64748b; line-height: 1.7; margin: 0;
  max-height: 0; opacity: 0; overflow: hidden;
  transition: max-height .5s cubic-bezier(0.16,1,0.3,1), opacity .4s, margin-top .4s;
}
.hp-faq-item.open > div > p { max-height: 220px; opacity: 1; margin-top: 12px; }
/* Plus/minus chevron */
.hp-faq-item > div > strong::after {
  content: ''; position: absolute; right: 26px; top: 30px;
  width: 11px; height: 11px;
  border-right: 2px solid #94a3b8; border-bottom: 2px solid #94a3b8;
  transform: rotate(45deg); transition: transform .4s cubic-bezier(0.16,1,0.3,1), border-color .3s;
}
.hp-faq-item.open > div > strong::after { transform: rotate(-135deg); border-color: #2563eb; }

/* ════════ WARUM ADOAN — Premium Dark Section ════════ */
.hp-why { padding: 110px 0; background: linear-gradient(160deg, #0f172a 0%, #131a32 100%); position: relative; overflow: hidden; }
.hp-why::before {
  content: ''; position: absolute; top: -150px; right: -100px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(37,99,235,.14) 0%, transparent 65%);
  pointer-events: none;
}
.hp-why-inner {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 72px; align-items: start;
  position: relative;
}
.hp-why-text > .hp-section-label { color: #60a5fa; }
.hp-why-text > .hp-section-label::before { background: linear-gradient(90deg,#60a5fa,#93c5fd); }
.hp-why-text > .hp-section-h2 { color: #fff; font-size: clamp(2rem,3vw,2.7rem); font-weight: 800; letter-spacing: -.02em; margin-bottom: 20px; }
.hp-why-text > p { font-size: 16px; color: rgba(255,255,255,.62); line-height: 1.8; margin-bottom: 40px; }
.hp-why-features { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.hp-why-feat {
  display: flex; gap: 14px; align-items: flex-start;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px; padding: 20px;
  transition: background .35s, border-color .35s, transform .35s;
}
.hp-why-feat:hover {
  background: rgba(37,99,235,.1); border-color: rgba(96,165,250,.3);
  transform: translateY(-3px);
}
.hp-why-feat > span {
  flex-shrink: 0; width: 42px; height: 42px; border-radius: 11px;
  display: flex; align-items: center; justify-content: center; font-size: 20px;
  background: rgba(96,165,250,.14); border: 1px solid rgba(96,165,250,.2);
}
.hp-why-feat > div > strong { display: block; font-size: 15px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.hp-why-feat > div > p { font-size: 13.5px; color: rgba(255,255,255,.55); line-height: 1.6; margin: 0; }
/* Stats column */
.hp-why-stats {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.hp-why-stat {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px; padding: 28px 24px;
  transition: background .35s, border-color .35s, transform .35s;
}
.hp-why-stat:hover {
  background: linear-gradient(160deg, rgba(37,99,235,.16) 0%, rgba(37,99,235,.05) 100%);
  border-color: rgba(96,165,250,.32); transform: translateY(-4px);
}
.hp-why-stat-num {
  font-family: var(--font-display, Georgia, serif);
  font-size: 2.6rem; font-weight: 900; line-height: 1;
  background: linear-gradient(135deg, #60a5fa 0%, #93c5fd 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  margin-bottom: 12px;
}
.hp-why-stat p { font-size: 13.5px; color: rgba(255,255,255,.6); line-height: 1.6; margin: 0; }

/* ===== Responsive ===== */
@media (max-width: 980px) {
  .hp-branch-grid { grid-template-columns: 1fr 1fr; }
  .hp-faq-inner { grid-template-columns: 1fr; gap: 36px; }
  .hp-faq-heading { position: static; }
  .hp-why-inner { grid-template-columns: 1fr; gap: 48px; }
}
@media (max-width: 640px) {
  .hp-branch-grid { grid-template-columns: 1fr; }
  .hp-why-features, .hp-why-stats { grid-template-columns: 1fr; }
  .hp-faq-item { padding-left: 60px; }
}


/* ══════════════════════════════════════════════════════
   CTA Buttons (white + outline-white) — Premium v2
   + CTA Flowing-Waves Canvas
══════════════════════════════════════════════════════ */

/* WHITE primary CTA on blue */
.hp-btn-white {
  padding: 18px 36px; border-radius: 14px;
  background: #ffffff; color: #1d4ed8;
  border: 1.5px solid rgba(255,255,255,.9);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 6px 24px rgba(0,0,0,.18),
    0 1px 3px rgba(0,0,0,.1);
  font-weight: 700; position: relative; overflow: hidden;
  transition: all .32s cubic-bezier(0.4,0,0.2,1);
}
.hp-btn-white::before {
  content: ''; position: absolute; top: 0; left: -100%;
  width: 55%; height: 100%;
  background: linear-gradient(110deg, transparent 25%, rgba(37,99,235,.12) 50%, transparent 75%);
  transform: skewX(-18deg); transition: left .6s ease; pointer-events: none;
}
.hp-btn-white:hover::before { left: 180%; }
.hp-btn-white:hover {
  color: #1e3a8a;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,1),
    0 14px 40px rgba(0,0,0,.24),
    0 2px 8px rgba(0,0,0,.12);
  transform: translateY(-2px);
}
.hp-btn-white .hp-btn-arrow { display: flex; align-items: center; transition: transform .3s cubic-bezier(0.4,0,0.2,1); }
.hp-btn-white:hover .hp-btn-arrow { transform: translateX(5px); }

/* OUTLINE-WHITE phone CTA */
.hp-btn-outline-white {
  padding: 17px 28px; border-radius: 14px;
  background: rgba(255,255,255,.06);
  color: #fff; border: 1.5px solid rgba(255,255,255,.28);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
  font-weight: 600; position: relative; overflow: hidden;
  transition: all .32s cubic-bezier(0.4,0,0.2,1);
}
.hp-btn-outline-white:hover {
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.5);
  transform: translateY(-2px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 10px 30px rgba(0,0,0,.2);
}
.hp-btn-outline-white .hp-btn-icon { display: flex; align-items: center; color: rgba(255,255,255,.75); transition: color .25s; }
.hp-btn-outline-white:hover .hp-btn-icon { color: #fff; }
.hp-btn-outline-white:hover .hp-btn-icon svg { animation: hp-phone-ring .55s ease; }

/* CTA section + canvas */
.hp-cta-final { position: relative; overflow: hidden; }
.hp-cta-canvas {
  position: absolute; inset: 0; width: 100%; height: 100%;
  z-index: 0; pointer-events: none;
  opacity: 0; animation: hpCanvasFade 1.6s ease .4s forwards;
}
.hp-cta-final-inner { position: relative; z-index: 2; }


/* ══════════════════════════════════════════════════════
   ADOAN — Premium Button System v4.0 (FINAL)
   White-pill primaries · Glass-pill secondaries
   World-class, high-contrast, cohesive
══════════════════════════════════════════════════════ */

/* ===== Shared base ===== */
.hp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 11px;
  font-family: var(--font-body, 'Inter', sans-serif);
  font-size: 15.5px; font-weight: 650; letter-spacing: .01em;
  line-height: 1; cursor: pointer; text-decoration: none;
  border: none; position: relative; overflow: hidden;
  -webkit-font-smoothing: antialiased;
  transition: transform .35s cubic-bezier(0.34,1.56,0.64,1), box-shadow .35s ease, background .35s ease, color .3s ease;
}
.hp-btn svg { display: block; }

/* ════ PRIMARY (hero + cta) — luminous white pill ════ */
.hp-btn-prim, .hp-btn-white {
  padding: 19px 38px; border-radius: 100px;
  background: #ffffff; color: #15203a; font-weight: 700;
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 10px 30px -6px rgba(8,18,48,.45),
    0 2px 6px rgba(8,18,48,.25),
    0 0 0 0 rgba(96,165,250,0);
}
/* shimmer sweep */
.hp-btn-prim::before, .hp-btn-white::before {
  content: ''; position: absolute; top: 0; left: -120%;
  width: 60%; height: 100%;
  background: linear-gradient(110deg, transparent 20%, rgba(37,99,235,.16) 50%, transparent 80%);
  transform: skewX(-20deg); transition: left .7s cubic-bezier(0.4,0,0.2,1); pointer-events: none;
}
.hp-btn-prim:hover::before, .hp-btn-white:hover::before { left: 200%; }
.hp-btn-prim:hover, .hp-btn-white:hover {
  color: #1d4ed8; transform: translateY(-3px);
  box-shadow:
    0 1px 0 rgba(255,255,255,1) inset,
    0 22px 48px -8px rgba(8,18,48,.55),
    0 4px 12px rgba(8,18,48,.3),
    0 0 30px rgba(147,197,253,.45);
}
.hp-btn-prim:active, .hp-btn-white:active { transform: translateY(-1px); }
.hp-btn-prim .hp-btn-arrow, .hp-btn-white .hp-btn-arrow {
  display: flex; align-items: center; color: #2563eb;
  transition: transform .35s cubic-bezier(0.34,1.56,0.64,1);
}
.hp-btn-prim:hover .hp-btn-arrow, .hp-btn-white:hover .hp-btn-arrow { transform: translateX(6px); }
.hp-btn-prim .hp-btn-text, .hp-btn-white .hp-btn-text { position: relative; }

/* ════ SECONDARY (hero ghost + cta outline) — glass pill ════ */
.hp-btn-ghost, .hp-btn-outline-white {
  padding: 18px 32px; border-radius: 100px;
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.92); font-weight: 600;
  border: 1.5px solid rgba(255,255,255,.22);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 1px 0 rgba(255,255,255,.1) inset, 0 6px 20px rgba(0,0,0,.12);
}
.hp-btn-ghost:hover, .hp-btn-outline-white:hover {
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.45);
  color: #fff; transform: translateY(-3px);
  box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 14px 34px rgba(0,0,0,.22);
}
.hp-btn-ghost .hp-btn-icon, .hp-btn-outline-white .hp-btn-icon {
  display: flex; align-items: center; color: rgba(255,255,255,.7);
  transition: color .25s;
}
.hp-btn-ghost:hover .hp-btn-icon, .hp-btn-outline-white:hover .hp-btn-icon { color: #fff; }
.hp-btn-ghost:hover .hp-btn-icon svg, .hp-btn-outline-white:hover .hp-btn-icon svg { animation: hp-phone-ring .6s ease; }

/* On the WHITE cta section the outline button needs visible border */
.hp-cta-final .hp-btn-outline-white { color: #fff; }

@keyframes hp-phone-ring {
  0%,100% { transform: rotate(0) scale(1); }
  20% { transform: rotate(-13deg) scale(1.16); }
  45% { transform: rotate(11deg) scale(1.12); }
  70% { transform: rotate(-6deg) scale(1.06); }
}


/* ══════════════════════════════════════════════════════
   ADOAN — Premium Wordmark Logo
══════════════════════════════════════════════════════ */
.site-logo { display: inline-flex; align-items: center; text-decoration: none; }
.site-logo img { display: none; }
.adoan-mark {
  font-family: var(--font-display, 'Fraunces', Georgia, serif);
  font-size: 26px; font-weight: 900; letter-spacing: .14em;
  color: #15203a; line-height: 1; text-transform: uppercase;
  display: inline-flex; align-items: baseline;
  transition: color .3s ease, letter-spacing .35s cubic-bezier(0.4,0,0.2,1);
}
.adoan-mark-a {
  background: linear-gradient(135deg, #2563eb 0%, #1e3a8a 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.adoan-mark-dot {
  color: #2563eb; margin-left: 1px;
  -webkit-text-fill-color: #2563eb;
}
.site-logo:hover .adoan-mark { letter-spacing: .2em; color: #1d4ed8; }
.site-logo:hover .adoan-mark-dot { animation: adoanDotPulse .6s ease; }
@keyframes adoanDotPulse {
  0%,100% { transform: translateY(0); }
  40% { transform: translateY(-4px) scale(1.3); }
}


/* ══════════════════════════════════════════════════════
   ADOAN — Button System v5.0 — SOLID & BOLD (final)
   Vivid blue solid primaries · clean outline secondaries
   Squared-modern 10px · strong shadow
══════════════════════════════════════════════════════ */

.hp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 11px;
  font-family: var(--font-body, 'Inter', sans-serif);
  font-size: 15.5px; font-weight: 700; letter-spacing: .015em;
  line-height: 1; cursor: pointer; text-decoration: none;
  border: none; position: relative; overflow: hidden;
  -webkit-font-smoothing: antialiased;
  transition: transform .3s cubic-bezier(0.4,0,0.2,1), box-shadow .3s ease, background .28s ease, color .25s ease;
}
.hp-btn svg { display: block; }

/* ════ PRIMARY — solid vivid blue, squared, strong shadow ════ */
.hp-btn-prim, .hp-btn-white {
  padding: 19px 38px; border-radius: 10px;
  background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%);
  color: #ffffff !important; font-weight: 700;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.25),
    0 8px 22px -4px rgba(37,99,235,.6),
    0 3px 8px rgba(15,23,42,.3);
}
.hp-btn-prim::before, .hp-btn-white::before {
  content: ''; position: absolute; top: 0; left: -120%;
  width: 60%; height: 100%;
  background: linear-gradient(110deg, transparent 20%, rgba(255,255,255,.22) 50%, transparent 80%);
  transform: skewX(-20deg); transition: left .7s cubic-bezier(0.4,0,0.2,1); pointer-events: none;
}
.hp-btn-prim:hover::before, .hp-btn-white:hover::before { left: 200%; }
.hp-btn-prim:hover, .hp-btn-white:hover {
  background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%);
  transform: translateY(-3px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.3),
    0 16px 38px -6px rgba(37,99,235,.7),
    0 5px 14px rgba(15,23,42,.35);
}
.hp-btn-prim:active, .hp-btn-white:active { transform: translateY(-1px); }
.hp-btn-prim .hp-btn-text, .hp-btn-white .hp-btn-text { position: relative; color: #fff; }
.hp-btn-prim .hp-btn-arrow, .hp-btn-white .hp-btn-arrow {
  display: flex; align-items: center; color: #fff;
  transition: transform .32s cubic-bezier(0.34,1.56,0.64,1);
}
.hp-btn-prim:hover .hp-btn-arrow, .hp-btn-white:hover .hp-btn-arrow { transform: translateX(6px); }

/* ════ SECONDARY — clean outline, pairs with solid ════ */
.hp-btn-ghost, .hp-btn-outline-white {
  padding: 18px 32px; border-radius: 10px;
  background: rgba(255,255,255,.04);
  color: #fff !important; font-weight: 600;
  border: 1.5px solid rgba(255,255,255,.35);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.hp-btn-ghost:hover, .hp-btn-outline-white:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.6);
  transform: translateY(-3px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14), 0 12px 28px rgba(15,23,42,.3);
}
.hp-btn-ghost .hp-btn-icon, .hp-btn-outline-white .hp-btn-icon {
  display: flex; align-items: center; color: rgba(255,255,255,.8); transition: color .25s;
}
.hp-btn-ghost:hover .hp-btn-icon, .hp-btn-outline-white:hover .hp-btn-icon { color: #fff; }
.hp-btn-ghost:hover .hp-btn-icon svg, .hp-btn-outline-white:hover .hp-btn-icon svg { animation: hp-phone-ring .6s ease; }
.hp-btn-ghost .hp-btn-text, .hp-btn-outline-white .hp-btn-text { color: #fff; }

@keyframes hp-phone-ring {
  0%,100% { transform: rotate(0) scale(1); }
  20% { transform: rotate(-13deg) scale(1.16); }
  45% { transform: rotate(11deg) scale(1.12); }
  70% { transform: rotate(-6deg) scale(1.06); }
}


/* CTA section (blue bg): primary = solid dark navy so it POPS */
.hp-cta-final .hp-btn-white {
  background: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    0 10px 26px -4px rgba(8,15,35,.55),
    0 3px 8px rgba(8,15,35,.4);
}
.hp-cta-final .hp-btn-white:hover {
  background: linear-gradient(180deg, #0f172a 0%, #020617 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.2),
    0 18px 40px -6px rgba(8,15,35,.65),
    0 5px 14px rgba(8,15,35,.45);
}
.hp-cta-final .hp-btn-white::before {
  background: linear-gradient(110deg, transparent 20%, rgba(96,165,250,.25) 50%, transparent 80%);
}
.hp-cta-final .hp-btn-white .hp-btn-arrow { color: #60a5fa; }


/* ══════════════════════════════════════════════════════
   ADOAN — Header CTA + Arrow-Chip buttons + Nav polish v6
══════════════════════════════════════════════════════ */

/* ----- Header nav-cta button (top right) ----- */
.header-actions { display: flex; align-items: center; gap: 16px; }
.nav-cta {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 11px 12px 11px 22px; border-radius: 100px;
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  color: #fff !important; text-decoration: none;
  font-family: var(--font-body,'Inter',sans-serif);
  font-size: 14.5px; font-weight: 650; letter-spacing: .01em;
  box-shadow: 0 4px 14px -2px rgba(37,99,235,.5), inset 0 1px 0 rgba(255,255,255,.25);
  transition: transform .3s cubic-bezier(0.4,0,0.2,1), box-shadow .3s, background .3s;
  position: relative; overflow: hidden;
}
.nav-cta:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #1d4ed8 0%, #1e3a8a 100%);
  box-shadow: 0 10px 26px -4px rgba(37,99,235,.65), inset 0 1px 0 rgba(255,255,255,.3);
}
.nav-cta-chip {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 50%;
  background: #fff; color: #1d4ed8; flex-shrink: 0;
  transition: transform .35s cubic-bezier(0.34,1.56,0.64,1);
}
.nav-cta:hover .nav-cta-chip { transform: translateX(3px) rotate(0deg); }
.nav-cta:hover .nav-cta-chip svg { animation: chipArrow .5s ease; }
@keyframes chipArrow { 0%{transform:translateX(0)} 50%{transform:translateX(3px)} 100%{transform:translateX(0)} }

/* ----- Nav links polish ----- */
.main-nav a {
  position: relative; font-weight: 550;
  transition: color .25s ease;
}
.main-nav a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -6px;
  height: 2px; border-radius: 2px;
  background: linear-gradient(90deg, #2563eb, #60a5fa);
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s cubic-bezier(0.4,0,0.2,1);
}
.main-nav a:hover { color: #1d4ed8; }
.main-nav a:hover::after { transform: scaleX(1); }

/* ══ ARROW-CHIP detail on the main primary buttons ══ */
/* Turn the plain arrow into a circular chip — premium agency look */
.hp-btn-prim .hp-btn-arrow,
.hp-btn-white .hp-btn-arrow {
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(255,255,255,.92);
  display: inline-flex; align-items: center; justify-content: center;
  color: #1d4ed8 !important; margin-left: 2px;
  transition: transform .35s cubic-bezier(0.34,1.56,0.64,1), background .3s;
}
.hp-btn-prim:hover .hp-btn-arrow,
.hp-btn-white:hover .hp-btn-arrow { transform: translateX(4px); background: #fff; }
/* CTA dark button: chip stays white with blue arrow */
.hp-cta-final .hp-btn-white .hp-btn-arrow { background: #60a5fa; color: #0f172a !important; }
.hp-cta-final .hp-btn-white:hover .hp-btn-arrow { background: #93c5fd; }

/* slightly increase primary button left/right balance for the chip */
.hp-btn-prim, .hp-btn-white { padding: 13px 14px 13px 30px; }

@media (max-width: 768px){
  .nav-cta { display: none; }
}


/* ══════════════════════════════════════════════════════
   ADOAN — Header Rebuild + Lively Buttons v7
══════════════════════════════════════════════════════ */

/* ---------- HEADER: balanced logo-left / nav-right ---------- */
.site-header {
  background: rgba(255,255,255,.85) !important;
  backdrop-filter: blur(18px) saturate(160%); -webkit-backdrop-filter: blur(18px) saturate(160%);
  border-bottom: 1px solid rgba(15,23,42,.06) !important;
  height: auto !important;
}
.header-inner {
  padding: 16px 40px !important;
  gap: 40px !important;
}
.main-nav {
  display: flex !important; align-items: center; gap: 38px;
  margin-left: auto !important;
}
.main-nav a {
  font-size: 14.5px; font-weight: 550; color: #334155;
  letter-spacing: .005em;
}
.header-actions { margin-left: 0 !important; }

/* logo a touch bigger, anchored left */
.adoan-mark { font-size: 27px; }

/* ---------- BUTTONS: lively expanding fill on hover ---------- */
/* primary (hero + CTA) keep solid blue + chip; add fill-from-chip */
.hp-btn-prim, .hp-btn-white { position: relative; overflow: hidden; isolation: isolate; }
.hp-btn-prim::after, .hp-btn-white::after {
  content: ''; position: absolute; z-index: -1;
  right: 30px; top: 50%;
  width: 24px; height: 24px; border-radius: 50%;
  background: #0f2db5;
  transform: translateY(-50%) scale(0);
  transition: transform .55s cubic-bezier(0.65,0,0.35,1);
}
.hp-btn-prim:hover::after, .hp-btn-white:hover::after {
  transform: translateY(-50%) scale(26);
}
/* CTA dark button: fill expands brighter navy */
.hp-cta-final .hp-btn-white::after { background: #1e3a8a; }

/* make chip pop a bit more + spin arrow on hover */
.hp-btn-prim .hp-btn-arrow svg, .hp-btn-white .hp-btn-arrow svg {
  transition: transform .4s cubic-bezier(0.34,1.56,0.64,1);
}
.hp-btn-prim:hover .hp-btn-arrow svg, .hp-btn-white:hover .hp-btn-arrow svg {
  transform: translateX(2px);
}

/* secondary buttons: subtle fill sweep too */
.hp-btn-ghost, .hp-btn-outline-white { position: relative; overflow: hidden; isolation: isolate; }
.hp-btn-ghost::after, .hp-btn-outline-white::after {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background: rgba(255,255,255,.16);
  transform: scaleX(0); transform-origin: left;
  transition: transform .45s cubic-bezier(0.65,0,0.35,1);
}
.hp-btn-ghost:hover::after, .hp-btn-outline-white:hover::after { transform: scaleX(1); }


/* ══════════════════════════════════════════════════════
   ADOAN — BOLD Buttons v8 — animated gradient ring + glow
══════════════════════════════════════════════════════ */
@property --hp-angle { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
@keyframes hpSpin { to { --hp-angle: 360deg; } }
@keyframes hpGlowPulse {
  0%,100% { box-shadow: 0 8px 26px -4px rgba(37,99,235,.55), 0 0 0 0 rgba(96,165,250,.0); }
  50%     { box-shadow: 0 10px 32px -4px rgba(37,99,235,.7), 0 0 24px 2px rgba(96,165,250,.35); }
}

/* PRIMARY — bigger, bolder, animated gradient ring + breathing glow */
.hp-btn-prim, .hp-btn-white {
  padding: 17px 16px 17px 34px !important;
  font-size: 16px !important; font-weight: 750 !important; letter-spacing: .015em !important;
  border-radius: 13px !important;
  background: linear-gradient(180deg,#3b82f6 0%,#1d4ed8 100%) !important;
  border: none !important;
  animation: hpGlowPulse 3.2s ease-in-out infinite;
}
/* animated flowing gradient ring (uses ::before) */
.hp-btn-prim::before, .hp-btn-white::before {
  content: '' !important; position: absolute !important; inset: -2px !important;
  border-radius: 15px !important; z-index: -2 !important;
  background: conic-gradient(from var(--hp-angle), #60a5fa, #2563eb, #93c5fd, #1e3a8a, #60a5fa) !important;
  animation: hpSpin 4s linear infinite !important;
  opacity: .9; left: auto; top: auto; width: auto; height: auto; transform: none !important;
}
/* inner solid so ring shows only as border */
.hp-btn-prim::after, .hp-btn-white::after {
  content: '' !important; position: absolute !important; inset: 0 !important; z-index: -1 !important;
  border-radius: 13px !important;
  background: linear-gradient(180deg,#3b82f6 0%,#1d4ed8 100%) !important;
  transition: background .35s ease; transform: none !important; width:auto; height:auto; right:auto; top:auto;
}
.hp-btn-prim:hover, .hp-btn-white:hover {
  transform: translateY(-3px);
  animation-play-state: paused;
}
.hp-btn-prim:hover::after, .hp-btn-white:hover::after {
  background: linear-gradient(180deg,#1d4ed8 0%,#1e3a8a 100%) !important;
}
.hp-btn-prim:hover::before, .hp-btn-white:hover::before { animation-duration: 1.2s !important; }

/* arrow chip stays crisp */
.hp-btn-prim .hp-btn-arrow, .hp-btn-white .hp-btn-arrow {
  width: 32px !important; height: 32px !important; border-radius: 50% !important;
  background: #fff !important; color: #1d4ed8 !important;
}
.hp-btn-prim:hover .hp-btn-arrow, .hp-btn-white:hover .hp-btn-arrow { transform: translateX(4px) rotate(0); }

/* CTA section: ring in lighter tones over the dark button */
.hp-cta-final .hp-btn-white,
.hp-cta-final .hp-btn-white::after {
  background: linear-gradient(180deg,#1e293b 0%,#0f172a 100%) !important;
}
.hp-cta-final .hp-btn-white .hp-btn-arrow { background: #60a5fa !important; color:#0f172a !important; }


/* ══════════════════════════════════════════════════════
   ADOAN — CLEAN PROFESSIONAL Buttons v9 (FINAL)
   Restrained, Stripe/Linear-style. Kills all gimmicks.
══════════════════════════════════════════════════════ */

/* kill all decorative pseudos + animations from earlier versions */
.hp-btn-prim::before, .hp-btn-white::before,
.hp-btn-prim::after,  .hp-btn-white::after,
.hp-btn-ghost::before, .hp-btn-outline-white::before,
.hp-btn-ghost::after,  .hp-btn-outline-white::after {
  display: none !important; content: none !important;
}
.hp-btn-prim, .hp-btn-white, .hp-btn-ghost, .hp-btn-outline-white { animation: none !important; }

/* ---------- PRIMARY: clean solid blue ---------- */
.hp-btn-prim, .hp-btn-white {
  display: inline-flex !important; align-items: center; gap: 9px;
  padding: 14px 26px !important;
  border-radius: 9px !important;
  background: #2563eb !important;
  color: #fff !important;
  font-size: 15px !important; font-weight: 600 !important; letter-spacing: 0 !important;
  border: none !important;
  box-shadow: 0 1px 2px rgba(16,24,40,.12), 0 2px 10px -2px rgba(37,99,235,.35) !important;
  transition: background .2s ease, box-shadow .2s ease, transform .2s ease !important;
}
.hp-btn-prim:hover, .hp-btn-white:hover {
  background: #1d4ed8 !important;
  box-shadow: 0 2px 4px rgba(16,24,40,.14), 0 8px 20px -4px rgba(37,99,235,.45) !important;
  transform: translateY(-1px) !important;
}
.hp-btn-prim:active, .hp-btn-white:active { transform: translateY(0) !important; }

/* simple inline arrow (no circular chip) */
.hp-btn-prim .hp-btn-arrow, .hp-btn-white .hp-btn-arrow {
  width: auto !important; height: auto !important; border-radius: 0 !important;
  background: transparent !important; color: #fff !important; margin: 0 !important;
  display: inline-flex; align-items: center;
  transition: transform .2s ease !important;
}
.hp-btn-prim:hover .hp-btn-arrow, .hp-btn-white:hover .hp-btn-arrow { transform: translateX(3px) !important; }

/* ---------- SECONDARY: clean subtle ---------- */
.hp-btn-ghost, .hp-btn-outline-white {
  display: inline-flex !important; align-items: center; gap: 9px;
  padding: 13px 24px !important; border-radius: 9px !important;
  background: rgba(255,255,255,.06) !important;
  color: #fff !important; font-size: 15px !important; font-weight: 600 !important;
  border: 1px solid rgba(255,255,255,.25) !important;
  box-shadow: none !important;
  transition: background .2s ease, border-color .2s ease, transform .2s ease !important;
}
.hp-btn-ghost:hover, .hp-btn-outline-white:hover {
  background: rgba(255,255,255,.12) !important;
  border-color: rgba(255,255,255,.45) !important;
  transform: translateY(-1px) !important;
}
.hp-btn-ghost .hp-btn-icon, .hp-btn-outline-white .hp-btn-icon { color: rgba(255,255,255,.85) !important; }

/* CTA section (blue bg): primary becomes white for contrast (Stripe-style inverse) */
.hp-cta-final .hp-btn-white {
  background: #ffffff !important; color: #1d4ed8 !important;
  box-shadow: 0 1px 2px rgba(16,24,40,.14), 0 8px 20px -6px rgba(8,15,35,.4) !important;
}
.hp-cta-final .hp-btn-white:hover { background: #f1f5ff !important; transform: translateY(-1px) !important; }
.hp-cta-final .hp-btn-white .hp-btn-arrow { color: #1d4ed8 !important; }


/* ══════════════════════════════════════════════════════
   FIXES v10 — invisible CTA text · stray cursor · polish
══════════════════════════════════════════════════════ */

/* FIX: CTA white button — make text dark/blue (was invisible white-on-white) */
.hp-cta-final .hp-btn-white,
.hp-cta-final .hp-btn-white .hp-btn-text {
  color: #1d4ed8 !important;
}
.hp-cta-final .hp-btn-white .hp-btn-arrow { color: #1d4ed8 !important; }

/* FIX: hide broken custom cursor artefact (stray circles) */
#hp-cursor, #hp-cursor-ring, .hp-cursor, .hp-cursor-ring { display: none !important; }

/* Footer logo: hide old JPG, show clean text wordmark instead */
.site-footer .footer-logo img,
footer img[src*="adoan-logo"] { display: none !important; }


/* ══════════════════════════════════════════════════════
   SVG Icon styling (replaces childish emojis) v11
══════════════════════════════════════════════════════ */
/* Service card icons — blue badge */
.hp-svc-icon {
  width: 56px !important; height: 56px !important;
  border-radius: 14px !important;
  background: linear-gradient(145deg,#eff4ff 0%,#dce8ff 100%) !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  color: #2563eb !important; margin-bottom: 20px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 4px 12px rgba(37,99,235,.12);
}
.hp-svc-icon svg { display: block; }

/* Branch tile icons — already have badge; set SVG color */
.hp-branch-icon { color: #2563eb !important; }
.hp-branch-icon svg { display: block; }

/* Why-ADOAN feature icons (dark bg) — light blue */
.hp-why-feat > span { color: #93c5fd !important; }
.hp-why-feat > span svg { display: block; }


/* ══════════════════════════════════════════════════════
   ADOAN — PROFESSIONAL SYSTEM v12
   Unified buttons · Dark footer · Refined header
══════════════════════════════════════════════════════ */

/* ============ UNIFIED BUTTONS (consistent everywhere) ============ */
/* PRIMARY = white solid, dark text, blue arrow — identical on hero + CTA */
.hp-btn-prim, .hp-btn-white, .hp-cta-final .hp-btn-white {
  display:inline-flex !important; align-items:center; gap:9px;
  padding:15px 26px !important; border-radius:10px !important;
  background:#ffffff !important; color:#15203a !important;
  font-size:15px !important; font-weight:650 !important; letter-spacing:0 !important;
  border:1px solid rgba(255,255,255,.6) !important;
  box-shadow:0 1px 2px rgba(16,24,40,.12), 0 8px 22px -6px rgba(2,6,23,.45) !important;
  transition:background .2s ease, box-shadow .2s ease, transform .2s ease !important;
}
.hp-btn-prim:hover, .hp-btn-white:hover, .hp-cta-final .hp-btn-white:hover {
  background:#eef3ff !important; transform:translateY(-2px) !important;
  box-shadow:0 2px 4px rgba(16,24,40,.14), 0 14px 32px -8px rgba(2,6,23,.55) !important;
}
.hp-btn-prim .hp-btn-text, .hp-btn-white .hp-btn-text,
.hp-cta-final .hp-btn-white .hp-btn-text { color:#15203a !important; }
.hp-btn-prim .hp-btn-arrow, .hp-btn-white .hp-btn-arrow,
.hp-cta-final .hp-btn-white .hp-btn-arrow {
  color:#2563eb !important; background:transparent !important; width:auto !important; height:auto !important; border-radius:0 !important;
  transition:transform .2s ease !important;
}
.hp-btn-prim:hover .hp-btn-arrow, .hp-btn-white:hover .hp-btn-arrow,
.hp-cta-final .hp-btn-white:hover .hp-btn-arrow { transform:translateX(3px) !important; }

/* SECONDARY = ghost outline, identical everywhere */
.hp-btn-ghost, .hp-btn-outline-white {
  display:inline-flex !important; align-items:center; gap:9px;
  padding:14px 24px !important; border-radius:10px !important;
  background:transparent !important; color:#fff !important;
  font-size:15px !important; font-weight:600 !important;
  border:1.5px solid rgba(255,255,255,.35) !important; box-shadow:none !important;
  transition:background .2s, border-color .2s, transform .2s !important;
}
.hp-btn-ghost:hover, .hp-btn-outline-white:hover {
  background:rgba(255,255,255,.1) !important; border-color:rgba(255,255,255,.6) !important;
  transform:translateY(-2px) !important;
}
.hp-btn-ghost .hp-btn-text, .hp-btn-outline-white .hp-btn-text { color:#fff !important; }
.hp-btn-ghost .hp-btn-icon, .hp-btn-outline-white .hp-btn-icon { color:rgba(255,255,255,.8) !important; }

/* ============ HEADER — refined professional ============ */
.site-header { background:rgba(255,255,255,.9) !important; border-bottom:1px solid rgba(15,23,42,.07) !important; }
.header-inner { padding:18px 48px !important; max-width:1240px !important; }
.main-nav { gap:34px !important; }
.main-nav a {
  font-size:15px !important; font-weight:500 !important; color:#475569 !important;
  letter-spacing:.005em;
}
.main-nav a:hover { color:#0f172a !important; }
.adoan-mark { font-size:25px !important; letter-spacing:.16em !important; }

/* ============ FOOTER — dark, premium ============ */
.site-footer {
  background:#0b1220 !important; color:rgba(255,255,255,.62) !important;
  padding:80px 0 0 !important; border-top:none !important;
}
.ft-inner { max-width:1240px; margin:0 auto; padding:0 48px; }
.ft-grid {
  display:grid !important; grid-template-columns:1.6fr 1fr 1fr 1fr !important;
  gap:56px !important; padding-bottom:56px !important;
}
.ft-brand .adoan-mark { color:#fff !important; font-size:26px !important; margin-bottom:20px; display:inline-flex; }
.ft-brand .adoan-mark-a { -webkit-text-fill-color:#60a5fa !important; }
.ft-brand .adoan-mark-dot { -webkit-text-fill-color:#60a5fa !important; color:#60a5fa !important; }
.ft-desc { font-size:14.5px !important; line-height:1.7 !important; color:rgba(255,255,255,.55) !important; max-width:320px; margin-bottom:24px; }
.ft-contact { font-size:14px; color:rgba(255,255,255,.7); line-height:2; }
.ft-contact a { color:rgba(255,255,255,.7) !important; text-decoration:none; transition:color .2s; }
.ft-contact a:hover { color:#60a5fa !important; }
.ft-col h4, .ft-col strong, .ft-col-title {
  font-size:12px !important; font-weight:700 !important; letter-spacing:.13em !important;
  text-transform:uppercase !important; color:rgba(255,255,255,.4) !important; margin-bottom:18px !important; display:block;
}
.ft-col a {
  display:block; font-size:14.5px !important; color:rgba(255,255,255,.62) !important;
  text-decoration:none; padding:7px 0; transition:color .2s, padding-left .2s;
}
.ft-col a:hover { color:#fff !important; padding-left:5px; }
.ft-bottom {
  border-top:1px solid rgba(255,255,255,.08) !important;
  padding:26px 0 !important; margin-top:0 !important;
  display:flex !important; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  font-size:13px !important; color:rgba(255,255,255,.4) !important;
}
.ft-bottom a { color:rgba(255,255,255,.45) !important; text-decoration:none; transition:color .2s; }
.ft-bottom a:hover { color:rgba(255,255,255,.8) !important; }
.ft-tagline { color:rgba(255,255,255,.4) !important; }

@media (max-width:900px){
  .ft-grid { grid-template-columns:1fr 1fr !important; gap:36px !important; }
  .header-inner { padding:16px 24px !important; }
}
@media (max-width:600px){
  .ft-grid { grid-template-columns:1fr !important; }
  .ft-inner { padding:0 24px; }
}


/* ===== Footer detail elements v13 ===== */
.ft-contact { display:flex; flex-direction:column; gap:8px; margin-bottom:24px; }
.ft-contact a, .ft-loc { font-size:14.5px; color:rgba(255,255,255,.7); text-decoration:none; transition:color .2s; }
.ft-contact a:hover { color:#60a5fa; }
.ft-loc { color:rgba(255,255,255,.45); }
.ft-social { display:flex; gap:12px; }
.ft-social a {
  width:38px; height:38px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.65); transition:all .25s;
}
.ft-social a:hover { background:#2563eb; border-color:#2563eb; color:#fff; transform:translateY(-2px); }
.ft-legal { display:flex; gap:22px; }
.ft-logo { display:inline-block; text-decoration:none; }


/* ══════════════════════════════════════════════════════
   ADOAN — BRUTAL HEADER (Medri-style, bolder) v14
══════════════════════════════════════════════════════ */
.site-header {
  position: sticky !important; top: 0; left:0; right:0;
  background: #ffffff !important; backdrop-filter: none !important;
  border-bottom: none !important; height: auto !important; padding: 0 !important;
  overflow: hidden !important;
  box-shadow: 0 2px 18px rgba(15,23,42,.08) !important;
}
.header-bar {
  display: flex !important; align-items: center;
  height: 84px; padding: 0 0 0 44px !important;
  max-width: none !important;
}
.site-logo { display:inline-flex; align-items:center; text-decoration:none; flex-shrink:0; }
.site-logo .adoan-mark { font-size: 30px !important; letter-spacing:.12em !important; color:#0f172a !important; }

/* NAV — bold uppercase with icons */
.main-nav {
  display: flex !important; align-items: center; gap: 30px !important;
  margin-left: auto !important; margin-right: 360px !important;
}
.main-nav a {
  display: inline-flex !important; align-items: center; gap: 8px !important;
  font-size: 14.5px !important; font-weight: 800 !important;
  letter-spacing: .04em !important; text-transform: uppercase !important;
  color: #15203a !important; text-decoration: none; white-space: nowrap;
  transition: color .2s;
}
.main-nav a svg { color: #2563eb; flex-shrink:0; transition: transform .25s; }
.main-nav a::after { display:none !important; }
.main-nav a:hover { color: #2563eb !important; }
.main-nav a:hover svg { transform: scale(1.15); }

/* ANGLED PHONE BANNER — brutal blue, diagonal cut */
.header-phone {
  position: absolute !important; top: 0; right: 0; height: 100%;
  display: flex !important; align-items: center; gap: 14px;
  padding: 0 44px 0 78px !important;
  background: linear-gradient(120deg, #2563eb 0%, #1d4ed8 60%, #1e3a8a 100%) !important;
  color: #fff !important; text-decoration: none !important;
  clip-path: polygon(54px 0, 100% 0, 100% 100%, 0 100%);
  box-shadow: -8px 0 30px rgba(37,99,235,.35);
  transition: filter .25s;
}
.header-phone:hover { filter: brightness(1.08); }
.header-phone-ic { display:inline-flex; color:#fff; }
.header-phone-ic svg { display:block; }
.header-phone-num { font-size: 25px !important; font-weight: 900 !important; letter-spacing:.01em; color:#fff !important; }

/* hamburger hidden on desktop, banner+nav hidden on mobile */
.menu-toggle { display: none; }
@media (max-width: 1100px){
  .main-nav { margin-right: 300px !important; gap:20px !important; }
  .main-nav a { font-size:13px !important; }
  .header-phone-num { font-size:20px !important; }
}
@media (max-width: 860px){
  .main-nav, .header-phone { display: none !important; }
  .menu-toggle { display:flex !important; flex-direction:column; gap:5px; margin-left:auto; margin-right:24px; background:none; border:none; cursor:pointer; }
  .menu-toggle span { width:26px; height:3px; background:#0f172a; border-radius:2px; }
  .header-bar { height:68px; padding-left:24px !important; }
}


/* ══════════════════════════════════════════════════════
   Service card animated visuals (brutal, wearebrand-style) v15
══════════════════════════════════════════════════════ */
.hp-svc-card { position: relative !important; overflow: hidden !important; }
.hp-svc-card .hp-svc-icon,
.hp-svc-card h3,
.hp-svc-card p,
.hp-svc-card ul { position: relative; z-index: 2; max-width: 60%; }
.hp-svc-viz {
  position: absolute !important; right: 40px; top: 50%;
  transform: translateY(-50%);
  width: 340px; height: 230px; z-index: 1; pointer-events: none;
  opacity: .98;
  filter: drop-shadow(0 12px 30px rgba(37,99,235,.18));
}
.hp-svc-viz svg { display: block; width: 100%; height: 100%; }
/* subtle glow plate behind each viz */
.hp-svc-viz::before {
  content:''; position:absolute; inset:-10% -6%;
  background: radial-gradient(60% 60% at 50% 50%, rgba(37,99,235,.08) 0%, transparent 70%);
  z-index:-1;
}
@media (max-width: 980px){
  .hp-svc-viz { display: none !important; }
  .hp-svc-card .hp-svc-icon,
  .hp-svc-card h3, .hp-svc-card p, .hp-svc-card ul { max-width: 100%; }
}


/* ══════════════════════════════════════════════════════
   Process stepper (horizontal) + FAQ left column v16
══════════════════════════════════════════════════════ */

/* ---- PROCESS: horizontal 4-step stepper with connector ---- */
.hp-process .hp-section-sub { text-align:center; max-width:560px; margin:14px auto 56px; }
.hp-process-grid {
  display: grid !important; grid-template-columns: repeat(4, 1fr) !important;
  gap: 28px !important; position: relative; max-width: 1080px; margin: 0 auto;
}
.hp-process-grid::before {
  content:''; position:absolute; top:30px; left:13%; right:13%; height:2px;
  background: linear-gradient(90deg,#2563eb 0%, #93c5fd 50%, #cbd5e1 100%); z-index:0;
}
.hp-process-arrow { display: none !important; }
.hp-process-step { text-align:center !important; padding:0 12px; position:relative; }
.hp-process-num {
  width:60px !important; height:60px !important; border-radius:50% !important;
  display:flex !important; align-items:center; justify-content:center;
  margin:0 auto 22px !important;
  background: linear-gradient(135deg,#2563eb,#1d4ed8) !important;
  color:#fff !important; font-size:21px !important; font-weight:800 !important;
  box-shadow: 0 10px 22px rgba(37,99,235,.4), 0 0 0 6px #fff, 0 0 0 8px #e7eeff;
  position:relative; z-index:2;
}
.hp-process-step h3 { font-size:17px !important; font-weight:700; margin-bottom:10px; color:#0f172a; }
.hp-process-step p { font-size:14px !important; color:#64748b !important; line-height:1.65; margin:0; }

/* ---- FAQ left column fill ---- */
.hp-faq-intro {
  font-size:16px; color:#64748b; line-height:1.7; margin:18px 0 28px; max-width:300px;
}
.hp-faq-help {
  display:flex; gap:14px; align-items:flex-start;
  background:#f4f7ff; border:1px solid #e2e9f7; border-radius:14px; padding:20px; max-width:320px;
}
.hp-faq-help-q {
  flex-shrink:0; width:34px; height:34px; border-radius:10px;
  background:linear-gradient(135deg,#2563eb,#1d4ed8); color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:800; font-size:16px;
}
.hp-faq-help strong { display:block; font-size:15px; color:#0f172a; margin-bottom:4px; }
.hp-faq-help a { font-size:14px; color:#2563eb; font-weight:600; text-decoration:none; }
.hp-faq-help a:hover { text-decoration:underline; }

@media (max-width: 860px){
  .hp-process-grid { grid-template-columns:1fr 1fr !important; gap:36px 20px !important; }
  .hp-process-grid::before { display:none; }
}
@media (max-width: 520px){
  .hp-process-grid { grid-template-columns:1fr !important; }
}


/* ══════════════════════════════════════════════════════
   On-light primary button (blue, for light sections) v17
══════════════════════════════════════════════════════ */
.hp-btn-onlight, .hp-btn-prim.hp-btn-onlight {
  background: #2563eb !important; color: #fff !important;
  border: none !important; margin-top: 8px;
  box-shadow: 0 1px 2px rgba(16,24,40,.12), 0 10px 24px -6px rgba(37,99,235,.5) !important;
}
.hp-btn-onlight:hover {
  background: #1d4ed8 !important; transform: translateY(-2px) !important;
  box-shadow: 0 2px 4px rgba(16,24,40,.14), 0 16px 32px -8px rgba(37,99,235,.6) !important;
}
.hp-btn-onlight .hp-btn-text { color: #fff !important; }
.hp-btn-onlight .hp-btn-arrow { color: #fff !important; }
.hp-btn-onlight:hover .hp-btn-arrow { transform: translateX(3px) !important; }

/* keep the featured card from clipping its button */
.hp-svc-card.hp-svc-featured { overflow: visible !important; }


/* ===== WORLD-CLASS HEADER v20 ===== */
.ad-topline{height:3px;background:linear-gradient(90deg,#2563eb,#60a5fa,#1e3a8a,#2563eb);background-size:300% 100%;animation:adGrad 6s linear infinite;position:relative;z-index:1001}
@keyframes adGrad{to{background-position:300% 0}}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.88);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid #ecebe4;transition:box-shadow .35s ease}
.site-header.shrunk{box-shadow:0 8px 30px -10px rgba(15,23,42,.14)}
.header-bar{display:flex;align-items:center;gap:40px;max-width:1280px;margin:0 auto;padding:20px 40px;height:auto;transition:padding .35s ease}
.site-header.shrunk .header-bar{padding:13px 40px}
.site-logo .adoan-mark{font-size:25px;letter-spacing:.01em}
.main-nav{display:flex;align-items:center;gap:34px;margin-left:auto}
.nl{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#15203a;position:relative;padding-bottom:2px}
.nl svg{color:#2563eb;transition:transform .3s ease}
.nl:hover svg{transform:translateY(-2px) scale(1.12)}
.nl .roll{display:inline-flex;flex-direction:column;height:1.15em;overflow:hidden;line-height:1.15em}
.nl .roll span{transition:transform .42s cubic-bezier(.6,0,.2,1)}
.nl .roll span:nth-child(2){color:#2563eb}
.nl:hover .roll span{transform:translateY(-100%)}
.nl::after{content:'';position:absolute;left:24px;right:0;bottom:-7px;height:2px;background:#2563eb;transform:scaleX(0);transform-origin:left;transition:transform .38s cubic-bezier(.6,0,.2,1)}
.nl:hover::after{transform:scaleX(1)}
.ad-cta{display:inline-flex;align-items:center;background:#1d4ed8;color:#fff;border-radius:100px;padding:8px 8px 8px 22px;font-size:14px;font-weight:600;letter-spacing:.01em;transition:background .3s,transform .3s,box-shadow .3s;white-space:nowrap}
.ad-cta:hover{background:#1e40af;transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(29,78,216,.6)}
.ad-cta-chip{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#fff;color:#1d4ed8;margin-left:14px;transition:transform .45s cubic-bezier(.34,1.56,.64,1)}
.ad-cta:hover .ad-cta-chip{transform:translateX(3px)}
.header-phone{display:none!important}
.menu-toggle{display:none}
.ad-mobile{display:none}
@media(max-width:980px){
  .main-nav,.header-bar>.ad-cta{display:none}
  .menu-toggle{display:flex;flex-direction:column;gap:5px;margin-left:auto;background:none;border:none;cursor:pointer;padding:4px}
  .menu-toggle span{width:26px;height:3px;background:#15203a;border-radius:2px;transition:transform .3s,opacity .3s}
  .menu-toggle.x span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .menu-toggle.x span:nth-child(2){opacity:0}
  .menu-toggle.x span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .ad-mobile{position:fixed;left:0;right:0;top:63px;bottom:0;background:#fff;z-index:998;padding:34px 28px;flex-direction:column;gap:4px;overflow-y:auto;border-top:1px solid #ecebe4}
  .ad-mobile.open{display:flex}
  .ad-mobile a{font-family:'Playfair Display',Georgia,serif;font-size:30px;font-weight:800;padding:14px 0;border-bottom:1px solid #f1efe9;color:#15203a}
  .ad-mobile a.ad-cta{font-family:inherit;font-size:15px;color:#fff;border:none;padding:14px 26px}
  .header-bar{padding:16px 22px}
}

/* header override v25 */
header.site-header .header-bar{max-width:1280px!important;margin:0 auto!important;padding:20px 40px!important;gap:36px!important}
header.site-header.shrunk .header-bar{padding:13px 40px!important}
header.site-header .main-nav{gap:30px!important;margin-left:auto!important}
header.site-header .ad-cta{margin-left:8px}
@media(max-width:980px){header.site-header .header-bar{padding:16px 22px!important}}

/* header fit v26 */
header.site-header .header-bar{justify-content:space-between!important;gap:24px!important}
header.site-header .main-nav{margin:0!important;gap:24px!important;flex-wrap:nowrap}
header.site-header .nl{font-size:12.5px!important;letter-spacing:.02em!important;gap:7px!important;white-space:nowrap}
header.site-header .nl svg{width:15px;height:15px}
header.site-header .ad-cta{flex-shrink:0;margin-left:0}
header.site-header .site-logo{flex-shrink:0}

/* ===== BRUTAL CTA v28 ===== */
@property --adang{syntax:'<angle>';inherits:false;initial-value:0deg}
header.site-header .ad-cta{position:relative;display:inline-flex;align-items:center;background:#0a0f1c!important;color:#fff!important;border-radius:100px;padding:10px 10px 10px 18px!important;font-size:12px!important;font-weight:700!important;letter-spacing:.14em!important;text-transform:uppercase;overflow:visible;isolation:isolate;z-index:0;transition:transform .3s,box-shadow .3s}
header.site-header .ad-cta::before{content:'';position:absolute;inset:-2px;border-radius:inherit;background:conic-gradient(from var(--adang),#1d4ed8,#7cc0ff,#1d4ed8,#0a0f1c,#0a0f1c,#1d4ed8);animation:adAng 3s linear infinite;z-index:-2}
header.site-header .ad-cta::after{content:'';position:absolute;inset:0;border-radius:inherit;background:#0a0f1c;z-index:-1}
@keyframes adAng{to{--adang:360deg}}
header.site-header .ad-cta:hover{transform:translateY(-2px);box-shadow:0 16px 34px -10px rgba(29,78,216,.75)}
header.site-header .ad-pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:#34d399;margin-right:10px;flex-shrink:0;box-shadow:0 0 0 0 rgba(52,211,153,.7);animation:adPulse 1.8s infinite}
@keyframes adPulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.6)}70%{box-shadow:0 0 0 7px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}
header.site-header .ad-cta-t{min-width:108px;text-align:center;font-variant-numeric:tabular-nums}
header.site-header .ad-cta-chip{background:#fff!important;color:#0a0f1c!important;margin-left:12px}

/* ===== CLEAN PRO CTA v29 (resets v28) ===== */
header.site-header .ad-cta{position:relative;display:inline-flex;align-items:center;background:#0f1729!important;color:#fff!important;border-radius:100px;padding:10px 8px 10px 22px!important;font-size:14px!important;font-weight:600!important;letter-spacing:0!important;text-transform:none!important;overflow:hidden;isolation:auto;transition:background .35s ease,transform .35s ease,box-shadow .35s ease}
header.site-header .ad-cta::before,header.site-header .ad-cta::after{display:none!important;content:none!important}
header.site-header .ad-pulse{display:none!important}
header.site-header .ad-cta:hover{background:#1d4ed8!important;transform:translateY(-1px);box-shadow:0 12px 26px -10px rgba(29,78,216,.55)}
header.site-header .ad-cta-t{min-width:0!important;letter-spacing:0!important;text-transform:none}
header.site-header .ad-cta-chip{width:30px;height:30px;background:#fff!important;color:#0f1729!important;margin-left:13px;transition:transform .4s cubic-bezier(.6,0,.2,1),color .35s ease}
header.site-header .ad-cta:hover .ad-cta-chip{transform:translateX(4px);color:#1d4ed8!important}

/* anchor scroll fix v30 */
html{scroll-behavior:smooth}
#agents,#system,#beratung{scroll-margin-top:96px}

/* ===== POLISH v31 ===== */
/* 1) fix invisible masked headings (reveal observer unreliable) */
html body .hp-reveal-mask,html body .hp-reveal-mask.reveal{animation:none!important;opacity:1!important;clip-path:none!important;-webkit-clip-path:none!important;transform:none!important;filter:none!important;visibility:visible!important}
html body .hp-reveal-mask>*,html body .hp-reveal-mask .word,html body .hp-reveal-mask .line{animation:none!important;opacity:1!important;transform:none!important;clip-path:none!important}
/* 2) remove double bullets in service-card lists */
.hp-services ul{list-style:none!important;padding-left:0!important;margin-left:0!important}
.hp-services li{list-style:none!important;padding-left:0!important;position:relative}
/* 3) consistent centered section labels (match centered headings) */
.hp-services .hp-section-label,.hp-process .hp-section-label{display:block;width:100%;text-align:center}

/* ===== MOTIVATION QUOTE v34 ===== */
.hp-quote{position:relative;padding:120px 0;background:#0a0f1c;overflow:hidden}
.hp-quote-glow{position:absolute;top:50%;left:50%;width:760px;height:420px;transform:translate(-50%,-50%);background:radial-gradient(ellipse at center,rgba(37,99,235,.30),rgba(37,99,235,0) 70%);filter:blur(20px);pointer-events:none;animation:hpQuoteGlow 7s ease-in-out infinite}
@keyframes hpQuoteGlow{0%,100%{opacity:.55;transform:translate(-50%,-50%) scale(1)}50%{opacity:.9;transform:translate(-50%,-50%) scale(1.08)}}
.hp-quote-inner{position:relative;z-index:1;max-width:920px;margin:0 auto;padding:0 28px;text-align:center}
.hp-quote-mark{font-family:'Playfair Display',Georgia,serif;font-size:130px;line-height:.5;color:#3b82f6;opacity:.45;height:64px}
.hp-quote-text{font-family:'Playfair Display',Georgia,serif;font-style:italic;font-weight:600;font-size:clamp(1.7rem,3.8vw,3rem);line-height:1.28;color:#fff;margin:0 auto 30px;max-width:14ch}
.hp-quote-text{max-width:none}
.hp-quote-author{display:inline-flex;align-items:center;gap:14px;font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#9db6e6}
.hp-quote-line{display:inline-block;width:42px;height:1px;background:linear-gradient(90deg,transparent,#3b82f6)}
@media(max-width:640px){.hp-quote{padding:80px 0}.hp-quote-mark{font-size:90px}}

/* ===== LANG SWITCHER v35 ===== */
header.site-header .ad-lang{display:inline-flex;align-items:center;border:1px solid #e3e1d9;background:#fff;border-radius:100px;padding:4px;flex-shrink:0}
header.site-header .ad-lang-sep{display:none}
header.site-header .ad-lang-i{appearance:none;border:none;background:none;cursor:pointer;font:inherit;font-size:12.5px;font-weight:700;letter-spacing:.06em;color:#9aa1ad;padding:6px 14px;border-radius:100px;line-height:1;transition:background .25s ease,color .25s ease}
header.site-header .ad-lang-i.is-active{background:#0f1729;color:#fff}
header.site-header .ad-lang-i:not(.is-active):hover{color:#1d4ed8}
header.site-header .ad-lang-i[data-soon]{position:relative}
.ad-lang-toast{position:fixed;top:78px;right:24px;z-index:2000;background:#0f1729;color:#fff;font-size:13px;font-weight:500;padding:11px 16px;border-radius:10px;box-shadow:0 14px 34px -10px rgba(15,23,42,.5);opacity:0;transform:translateY(-8px);transition:opacity .3s,transform .3s;pointer-events:none}
.ad-lang-toast.show{opacity:1;transform:none}
@media(max-width:980px){header.site-header .ad-lang{display:none}}

/* unify centered section headers v36 */
.hp-services .hp-section-h2,.hp-services .hp-section-sub,.hp-process .hp-section-h2,.hp-process .hp-section-sub{text-align:center!important}
.hp-services .hp-section-sub,.hp-process .hp-section-sub{margin-left:auto!important;margin-right:auto!important}

/* ===== ANIMATED LANG TOGGLE + GTRANSLATE v37 ===== */
header.site-header .ad-lang{position:relative;display:inline-flex;align-items:center;border:1px solid #e3e1d9;background:#f5f4ef;border-radius:100px;padding:4px;overflow:hidden;flex-shrink:0}
header.site-header .ad-lang-thumb{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);background:#0f1729;border-radius:100px;transition:transform .4s cubic-bezier(.5,0,.15,1);transform:translateX(calc(var(--thumb-x,0) * 100%));z-index:0}
header.site-header .ad-lang-i{position:relative;z-index:1;appearance:none;border:none;background:none;cursor:pointer;font:inherit;font-size:12.5px;font-weight:700;letter-spacing:.06em;line-height:1;padding:7px 17px;border-radius:100px;color:#8b909b;transition:color .3s ease;min-width:44px;text-align:center}
header.site-header .ad-lang-i.is-active{color:#fff}
header.site-header .ad-lang-i:not(.is-active):hover{color:#1d4ed8}
/* hide Google Translate top banner + reset body offset */
.goog-te-banner-frame,.goog-te-banner,iframe.skiptranslate{display:none!important;visibility:hidden!important}
body{top:0!important;position:static!important}
#google_translate_element{display:none!important}
.goog-tooltip,.goog-tooltip:hover,#goog-gt-tt,.goog-te-balloon-frame{display:none!important}
.goog-text-highlight{background:none!important;box-shadow:none!important}
@media(max-width:980px){header.site-header .ad-lang{display:none}}

/* ===== SAFE CSS-ONLY HERO/CTA GLOW v41 (GPU transform only) ===== */
.hp-hero-canvas,.hp-cta-canvas{display:none!important}
.hp-hero,.hp-cta-final{position:relative;overflow:hidden}
.hp-hero>*,.hp-cta-final>*{position:relative;z-index:2}
.hp-hero::before,.hp-hero::after,.hp-cta-final::before,.hp-cta-final::after{content:'';position:absolute;width:56vw;height:56vw;max-width:720px;max-height:720px;border-radius:50%;pointer-events:none;z-index:0;filter:blur(64px);opacity:.5;will-change:transform}
.hp-hero::before{background:radial-gradient(circle,rgba(96,165,250,.55),rgba(96,165,250,0) 60%);top:-18%;left:-8%;animation:adBlobA 17s ease-in-out infinite}
.hp-hero::after{background:radial-gradient(circle,rgba(37,99,235,.5),rgba(37,99,235,0) 60%);bottom:-22%;right:-6%;animation:adBlobB 21s ease-in-out infinite}
.hp-cta-final::before{background:radial-gradient(circle,rgba(191,219,254,.4),rgba(191,219,254,0) 60%);top:-20%;left:-6%;animation:adBlobA 19s ease-in-out infinite}
.hp-cta-final::after{background:radial-gradient(circle,rgba(255,255,255,.22),rgba(255,255,255,0) 60%);bottom:-24%;right:-8%;animation:adBlobB 23s ease-in-out infinite}
@keyframes adBlobA{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(6%,8%,0) scale(1.15)}}
@keyframes adBlobB{0%,100%{transform:translate3d(0,0,0) scale(1.1)}50%{transform:translate3d(-7%,-6%,0) scale(1)}}
@media(prefers-reduced-motion:reduce){.hp-hero::before,.hp-hero::after,.hp-cta-final::before,.hp-cta-final::after{animation:none}}

/* ===== SAFE DRIFTING STARFIELD v42 (CSS background + GPU transform only) ===== */
.hp-hero .hp-hero-canvas,.hp-cta-final .hp-cta-canvas{display:block!important;position:absolute!important;top:-15%!important;left:-15%!important;width:130%!important;height:130%!important;z-index:1!important;pointer-events:none;border:0;background-image:radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.55),transparent 60%),radial-gradient(1.6px 1.6px at 70% 60%,rgba(190,215,255,.5),transparent 60%),radial-gradient(2px 2px at 42% 82%,rgba(255,255,255,.45),transparent 60%),radial-gradient(1.6px 1.6px at 85% 22%,rgba(165,200,255,.5),transparent 60%),radial-gradient(2px 2px at 12% 70%,rgba(255,255,255,.4),transparent 60%),radial-gradient(1.6px 1.6px at 58% 12%,rgba(205,225,255,.5),transparent 60%),radial-gradient(1.4px 1.4px at 33% 50%,rgba(255,255,255,.4),transparent 60%);background-size:340px 340px;opacity:.75;animation:adDrift 26s ease-in-out infinite alternate;will-change:transform}
@keyframes adDrift{from{transform:translate3d(0,0,0)}to{transform:translate3d(-6%,-5%,0)}}
@media(prefers-reduced-motion:reduce){.hp-hero .hp-hero-canvas,.hp-cta-final .hp-cta-canvas{animation:none}}

/* ===== VISIBLE ANIMATION v43 (still GPU transform/opacity only) ===== */
/* brighter, bigger, faster drifting starfield */
.hp-hero .hp-hero-canvas,.hp-cta-final .hp-cta-canvas{opacity:1!important;background-size:280px 280px!important;animation:adDrift 13s ease-in-out infinite alternate!important}
@keyframes adDrift{0%{transform:translate3d(-2%,-1%,0)}100%{transform:translate3d(-13%,-11%,0)}}
/* dramatic pulsing glow blobs */
.hp-hero::before{top:-10%!important;left:-6%!important;opacity:.85!important;filter:blur(60px)!important;animation:adBlobA 8s ease-in-out infinite!important}
.hp-hero::after{bottom:-14%!important;right:-4%!important;opacity:.8!important;filter:blur(60px)!important;animation:adBlobB 10s ease-in-out infinite!important}
.hp-cta-final::before{opacity:.7!important;animation:adBlobA 9s ease-in-out infinite!important}
.hp-cta-final::after{opacity:.6!important;animation:adBlobB 11s ease-in-out infinite!important}
@keyframes adBlobA{0%{transform:translate3d(-10%,-8%,0) scale(.9);opacity:.35}50%{transform:translate3d(14%,12%,0) scale(1.3);opacity:.9}100%{transform:translate3d(-10%,-8%,0) scale(.9);opacity:.35}}
@keyframes adBlobB{0%{transform:translate3d(12%,10%,0) scale(1.25);opacity:.85}50%{transform:translate3d(-14%,-10%,0) scale(.9);opacity:.3}100%{transform:translate3d(12%,10%,0) scale(1.25);opacity:.85}}
/* slow rotating light sheen behind hero headline */
.hp-hero-inner{position:relative}
.hp-hero-inner::before{content:'';position:absolute;top:50%;left:50%;width:130%;height:280%;transform:translate(-50%,-50%);z-index:-1;pointer-events:none;background:conic-gradient(from 0deg,rgba(96,165,250,0),rgba(120,180,255,.22),rgba(96,165,250,0),rgba(160,200,255,.18),rgba(96,165,250,0));filter:blur(50px);animation:adSpin 24s linear infinite;will-change:transform}
@keyframes adSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
/* keep accessibility but only soften, not kill */
@media(prefers-reduced-motion:reduce){.hp-hero .hp-hero-canvas,.hp-cta-final .hp-cta-canvas,.hp-hero::before,.hp-hero::after,.hp-cta-final::before,.hp-cta-final::after,.hp-hero-inner::before{animation-duration:40s!important}}

/* ===== CLEARLY VISIBLE ANIM v44 (continuous starfield + bold glow, GPU only) ===== */
.hp-hero .hp-hero-canvas,.hp-cta-final .hp-cta-canvas{display:block!important;position:absolute!important;top:-20%!important;left:-20%!important;width:140%!important;height:140%!important;z-index:1!important;opacity:1!important;background-image:radial-gradient(2.5px 2.5px at 30px 40px,#ffffff,transparent),radial-gradient(2px 2px at 120px 90px,#cfe0ff,transparent),radial-gradient(2.5px 2.5px at 70px 160px,#ffffff,transparent),radial-gradient(2px 2px at 175px 35px,#bcd4ff,transparent),radial-gradient(2px 2px at 20px 120px,#ffffff,transparent),radial-gradient(2.5px 2.5px at 150px 150px,#e6efff,transparent),radial-gradient(1.6px 1.6px at 95px 20px,#ffffff,transparent),radial-gradient(1.6px 1.6px at 50px 95px,#d6e6ff,transparent)!important;background-size:200px 200px!important;background-repeat:repeat!important;animation:adDrift 9s linear infinite!important;will-change:transform}
@keyframes adDrift{from{transform:translate3d(0,0,0)}to{transform:translate3d(-200px,-200px,0)}}
.hp-hero::before{top:-12%!important;left:-6%!important;opacity:.9!important;filter:blur(46px)!important;background:radial-gradient(circle,rgba(120,180,255,.85),rgba(120,180,255,0) 62%)!important;animation:adBlobA 7s ease-in-out infinite!important}
.hp-hero::after{bottom:-14%!important;right:-4%!important;opacity:.85!important;filter:blur(46px)!important;background:radial-gradient(circle,rgba(160,205,255,.8),rgba(160,205,255,0) 62%)!important;animation:adBlobB 9s ease-in-out infinite!important}
.hp-cta-final::before{opacity:.8!important;filter:blur(46px)!important;background:radial-gradient(circle,rgba(200,225,255,.7),rgba(200,225,255,0) 62%)!important;animation:adBlobA 8s ease-in-out infinite!important}
.hp-cta-final::after{opacity:.7!important;filter:blur(46px)!important;background:radial-gradient(circle,rgba(255,255,255,.5),rgba(255,255,255,0) 62%)!important;animation:adBlobB 10s ease-in-out infinite!important}
@keyframes adBlobA{0%{transform:translate3d(-12%,-8%,0) scale(.85);opacity:.3}50%{transform:translate3d(16%,12%,0) scale(1.35);opacity:.95}100%{transform:translate3d(-12%,-8%,0) scale(.85);opacity:.3}}
@keyframes adBlobB{0%{transform:translate3d(14%,10%,0) scale(1.3);opacity:.9}50%{transform:translate3d(-16%,-12%,0) scale(.85);opacity:.25}100%{transform:translate3d(14%,10%,0) scale(1.3);opacity:.9}}
.hp-hero-inner::before{background:conic-gradient(from 0deg,rgba(130,185,255,0),rgba(150,200,255,.4),rgba(130,185,255,0),rgba(190,215,255,.32),rgba(130,185,255,0))!important;filter:blur(44px)!important;animation:adSpin 18s linear infinite!important}

/* ===== v45 — TWO BRUTAL SAFE ANIMS (GPU transform/opacity only) ===== */
.hp-hero{position:relative;overflow:hidden;isolation:isolate}
.hp-hero .hp-hero-canvas{display:block!important;position:absolute!important;inset:-30%!important;top:-30%!important;left:-30%!important;width:160%!important;height:160%!important;z-index:0!important;opacity:.95!important;background:radial-gradient(38% 38% at 28% 32%,rgba(56,130,246,.6),transparent 62%),radial-gradient(34% 34% at 72% 26%,rgba(34,211,238,.5),transparent 62%),radial-gradient(46% 46% at 58% 80%,rgba(99,102,241,.55),transparent 62%),radial-gradient(30% 30% at 84% 66%,rgba(168,85,247,.4),transparent 62%)!important;background-size:auto!important;filter:blur(38px)!important;animation:auroraSpin 22s ease-in-out infinite alternate!important}
@keyframes auroraSpin{0%{transform:translate3d(-4%,-3%,0) rotate(0deg) scale(1.05)}50%{transform:translate3d(5%,4%,0) rotate(10deg) scale(1.25)}100%{transform:translate3d(-3%,4%,0) rotate(-8deg) scale(1.12)}}
.hp-hero::before{top:-10%!important;left:-8%!important;width:60vw!important;height:60vw!important;max-width:760px!important;max-height:760px!important;opacity:.8!important;filter:blur(50px)!important;background:radial-gradient(circle,rgba(34,211,238,.7),rgba(34,211,238,0) 62%)!important;animation:floatA 15s ease-in-out infinite!important}
.hp-hero::after{bottom:-14%!important;right:-8%!important;width:62vw!important;height:62vw!important;max-width:780px!important;max-height:780px!important;opacity:.75!important;filter:blur(50px)!important;background:radial-gradient(circle,rgba(129,140,248,.65),rgba(129,140,248,0) 62%)!important;animation:floatB 18s ease-in-out infinite!important}
@keyframes floatA{0%{transform:translate3d(-12%,-8%,0) scale(.9)}50%{transform:translate3d(18%,14%,0) scale(1.25)}100%{transform:translate3d(-12%,-8%,0) scale(.9)}}
@keyframes floatB{0%{transform:translate3d(14%,10%,0) scale(1.2)}50%{transform:translate3d(-16%,-12%,0) scale(.9)}100%{transform:translate3d(14%,10%,0) scale(1.2)}}
.hp-hero-inner::before{content:''!important;position:absolute!important;top:50%!important;left:50%!important;width:760px!important;height:520px!important;transform:translate(-50%,-50%)!important;z-index:-1!important;pointer-events:none!important;background:radial-gradient(closest-side,rgba(255,255,255,.18),rgba(140,190,255,.1) 45%,transparent 70%)!important;filter:blur(30px)!important;animation:coreGlow 6.5s ease-in-out infinite!important}
@keyframes coreGlow{0%,100%{opacity:.45;transform:translate(-50%,-50%) scale(.95)}50%{opacity:.95;transform:translate(-50%,-50%) scale(1.12)}}
.hp-cta-final{position:relative;overflow:hidden;isolation:isolate}
.hp-cta-final .hp-cta-canvas{display:block!important;position:absolute!important;left:-25%!important;right:auto!important;bottom:-6%!important;top:auto!important;width:150%!important;height:78%!important;z-index:0!important;opacity:.6!important;background:none!important;background-image:repeating-linear-gradient(to right,rgba(150,205,255,.55) 0 2px,transparent 2px 84px),repeating-linear-gradient(to bottom,rgba(150,205,255,.55) 0 2px,transparent 2px 84px)!important;background-size:84px 84px!important;transform:perspective(440px) rotateX(64deg)!important;transform-origin:bottom center!important;-webkit-mask-image:linear-gradient(to top,#000 0%,rgba(0,0,0,.6) 45%,transparent 88%)!important;mask-image:linear-gradient(to top,#000 0%,rgba(0,0,0,.6) 45%,transparent 88%)!important;animation:gridScroll 3.6s linear infinite!important;filter:drop-shadow(0 0 6px rgba(120,190,255,.5))!important}
@keyframes gridScroll{from{transform:perspective(440px) rotateX(64deg) translateY(0)}to{transform:perspective(440px) rotateX(64deg) translateY(84px)}}
.hp-cta-final::before{content:''!important;position:absolute!important;left:0!important;right:0!important;top:auto!important;bottom:30%!important;width:100%!important;height:160px!important;max-width:none!important;max-height:none!important;border-radius:0!important;opacity:.8!important;filter:blur(40px)!important;background:radial-gradient(60% 100% at 50% 100%,rgba(120,200,255,.6),transparent 70%)!important;animation:none!important}
.hp-cta-final::after{content:''!important;position:absolute!important;left:50%!important;right:auto!important;top:18%!important;bottom:auto!important;width:50vw!important;height:50vw!important;max-width:620px!important;max-height:620px!important;transform:translateX(-50%)!important;opacity:.5!important;filter:blur(60px)!important;background:radial-gradient(circle,rgba(99,102,241,.5),transparent 62%)!important;animation:floatB 16s ease-in-out infinite!important}
@media(prefers-reduced-motion:reduce){.hp-hero .hp-hero-canvas,.hp-hero::before,.hp-hero::after,.hp-hero-inner::before,.hp-cta-final .hp-cta-canvas,.hp-cta-final::after{animation-duration:40s!important}}

/* ===== v47 FORCE ALL CONTENT VISIBLE (reveal observer removed earlier) ===== */
html body .reveal{opacity:1!important;transform:none!important;clip-path:none!important;-webkit-clip-path:none!important;filter:none!important;visibility:visible!important}

/* ===== v51 — make CTA neon grid BOLD ===== */
.hp-cta-final .hp-cta-canvas{opacity:.92!important;height:90%!important;bottom:-8%!important;background-image:repeating-linear-gradient(to right,rgba(170,215,255,.85) 0 2px,transparent 2px 74px),repeating-linear-gradient(to bottom,rgba(170,215,255,.85) 0 2px,transparent 2px 74px)!important;background-size:74px 74px!important;-webkit-mask-image:linear-gradient(to top,#000 0%,rgba(0,0,0,.75) 55%,transparent 92%)!important;mask-image:linear-gradient(to top,#000 0%,rgba(0,0,0,.75) 55%,transparent 92%)!important;filter:drop-shadow(0 0 8px rgba(130,195,255,.8))!important;animation:gridScroll 3s linear infinite!important}
@keyframes gridScroll{from{transform:perspective(440px) rotateX(66deg) translateY(0)}to{transform:perspective(440px) rotateX(66deg) translateY(74px)}}
.hp-cta-final::before{bottom:24%!important;height:200px!important;opacity:.95!important;background:radial-gradient(60% 100% at 50% 100%,rgba(130,200,255,.8),transparent 72%)!important}

/* ===== v52 — HERO ENERGY PORTAL (GPU transform/opacity only) ===== */
.hp-hero{position:relative;overflow:hidden;isolation:isolate}
.hp-hero .hp-hero-canvas{display:block!important;position:absolute!important;top:50%!important;left:50%!important;width:min(1200px,118vw)!important;height:min(1200px,118vw)!important;inset:auto!important;transform:translate(-50%,-50%)!important;border-radius:50%!important;z-index:0!important;opacity:.7!important;background:conic-gradient(from 0deg,rgba(34,211,238,0) 0deg,rgba(34,211,238,.55) 60deg,rgba(99,102,241,.5) 140deg,rgba(168,85,247,.4) 220deg,rgba(56,130,246,.55) 300deg,rgba(34,211,238,0) 360deg)!important;background-size:auto!important;filter:blur(36px)!important;-webkit-mask:radial-gradient(closest-side,#000 58%,transparent 78%)!important;mask:radial-gradient(closest-side,#000 58%,transparent 78%)!important;animation:vortexSpin 26s linear infinite!important}
@keyframes vortexSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.hp-hero::before{top:50%!important;left:50%!important;right:auto!important;bottom:auto!important;width:560px!important;height:560px!important;max-width:80vw!important;max-height:80vw!important;border-radius:50%!important;opacity:.95!important;filter:blur(26px)!important;background:radial-gradient(circle,rgba(200,230,255,.95),rgba(120,180,255,.45) 36%,transparent 66%)!important;animation:corePulse 5.5s ease-in-out infinite!important;z-index:0!important}
@keyframes corePulse{0%,100%{transform:translate(-50%,-50%) scale(.92);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.16);opacity:1}}
.hp-hero::after{top:50%!important;left:50%!important;right:auto!important;bottom:auto!important;width:720px!important;height:720px!important;max-width:92vw!important;max-height:92vw!important;border-radius:50%!important;opacity:.9!important;filter:drop-shadow(0 0 10px rgba(120,205,255,.85))!important;background:conic-gradient(from 0deg,transparent 0deg,rgba(120,205,255,.95) 50deg,transparent 120deg,transparent 200deg,rgba(150,180,255,.8) 250deg,transparent 320deg)!important;-webkit-mask:radial-gradient(transparent 60%,#000 62%,#000 67%,transparent 69%)!important;mask:radial-gradient(transparent 60%,#000 62%,#000 67%,transparent 69%)!important;animation:ringSpin 14s linear infinite!important}
@keyframes ringSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.hp-hero-inner::before{content:''!important;position:absolute!important;top:50%!important;left:50%!important;width:940px!important;height:940px!important;max-width:104vw!important;max-height:104vw!important;border-radius:50%!important;z-index:-1!important;pointer-events:none!important;opacity:.8!important;filter:drop-shadow(0 0 8px rgba(168,140,255,.7))!important;background:conic-gradient(from 90deg,transparent 0deg,rgba(168,140,255,.85) 60deg,transparent 140deg,rgba(120,210,255,.85) 230deg,transparent 300deg)!important;-webkit-mask:radial-gradient(transparent 71%,#000 72.5%,#000 75%,transparent 77%)!important;mask:radial-gradient(transparent 71%,#000 72.5%,#000 75%,transparent 77%)!important;animation:ringSpinRev 20s linear infinite!important}
@keyframes ringSpinRev{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(-360deg)}}
.hp-hero-inner{position:relative;z-index:2}
.hp-hero-inner h1,.hp-hero-inner .hp-hero-title,.hp-hero h1{text-shadow:0 2px 34px rgba(6,12,32,.55),0 1px 4px rgba(6,12,32,.4)}
@media(prefers-reduced-motion:reduce){.hp-hero .hp-hero-canvas,.hp-hero::before,.hp-hero::after,.hp-hero-inner::before{animation-duration:60s!important}}

/* ===== v53 — CTA SYNTHWAVE SUN over neon grid ===== */
.hp-cta-final{position:relative;overflow:hidden;isolation:isolate}
.hp-cta-final::before{content:''!important;position:absolute!important;left:50%!important;top:30%!important;right:auto!important;bottom:auto!important;width:420px!important;height:420px!important;max-width:80vw!important;max-height:80vw!important;border-radius:50%!important;transform:translate(-50%,-50%)!important;z-index:0!important;opacity:.92!important;background:repeating-linear-gradient(to bottom,rgba(8,12,30,0) 0 9px,rgba(8,12,30,.55) 9px 12px),linear-gradient(to bottom,#a6dcff,#6aa6ff 38%,#9a78ff 70%,#cf7bff)!important;filter:drop-shadow(0 0 50px rgba(140,150,255,.85)) drop-shadow(0 0 18px rgba(110,200,255,.7))!important;animation:sunPulse 6s ease-in-out infinite!important}
@keyframes sunPulse{0%,100%{transform:translate(-50%,-48%) scale(.97);filter:drop-shadow(0 0 40px rgba(140,150,255,.7))}50%{transform:translate(-50%,-52%) scale(1.04);filter:drop-shadow(0 0 70px rgba(150,160,255,.95))}}
.hp-cta-final::after{content:''!important;position:absolute!important;left:50%!important;top:auto!important;bottom:18%!important;right:auto!important;transform:translateX(-50%)!important;width:120%!important;height:240px!important;max-width:none!important;max-height:none!important;border-radius:0!important;opacity:.8!important;filter:blur(30px)!important;background:radial-gradient(60% 100% at 50% 100%,rgba(120,200,255,.7),transparent 72%)!important;animation:none!important}
@media(prefers-reduced-motion:reduce){.hp-cta-final::before{animation-duration:30s!important}}

/* ===== v54 — CTA sun readability tune ===== */
.hp-cta-final::before{top:19%!important;width:360px!important;height:360px!important;opacity:.58!important}
.hp-cta-final h2,.hp-cta-final p,.hp-cta-final .hp-eyebrow,.hp-cta-final .eyebrow,.hp-cta-final .hp-section-label{text-shadow:0 2px 22px rgba(6,12,32,.7),0 1px 5px rgba(6,12,32,.6)!important}

/* ===== v55 — CTA STARFIELD (sun + grid removed) ===== */
.hp-cta-final{position:relative;overflow:hidden;isolation:isolate;background:linear-gradient(180deg,#070b1c 0%,#0c1330 55%,#0a1640 100%)}
.hp-cta-final .hp-cta-canvas{display:block!important;position:absolute!important;top:-20%!important;left:-20%!important;right:auto!important;bottom:auto!important;width:140%!important;height:140%!important;z-index:0!important;opacity:1!important;border:0!important;background:none!important;background-image:radial-gradient(1.5px 1.5px at 25px 30px,#fff,transparent),radial-gradient(1px 1px at 90px 70px,#cfe0ff,transparent),radial-gradient(1.5px 1.5px at 60px 130px,#fff,transparent),radial-gradient(1px 1px at 150px 40px,#bcd4ff,transparent),radial-gradient(1.5px 1.5px at 130px 165px,#fff,transparent),radial-gradient(1px 1px at 40px 100px,#e6efff,transparent),radial-gradient(1px 1px at 185px 120px,#fff,transparent),radial-gradient(1px 1px at 100px 20px,#dbe8ff,transparent)!important;background-size:200px 200px!important;background-repeat:repeat!important;-webkit-mask:none!important;mask:none!important;filter:none!important;transform:none!important;animation:starDriftA 26s ease-in-out infinite alternate,starTwinkleA 4s ease-in-out infinite!important}
@keyframes starDriftA{from{transform:translate3d(0,0,0)}to{transform:translate3d(-34px,-22px,0)}}
@keyframes starTwinkleA{0%,100%{opacity:.65}50%{opacity:1}}
.hp-cta-final::before{content:''!important;position:absolute!important;top:-20%!important;left:-20%!important;right:auto!important;bottom:auto!important;width:140%!important;height:140%!important;max-width:none!important;max-height:none!important;border-radius:0!important;z-index:0!important;opacity:1!important;filter:none!important;-webkit-mask:none!important;mask:none!important;background:none!important;background-image:radial-gradient(2.5px 2.5px at 60px 50px,#fff,transparent),radial-gradient(2px 2px at 230px 150px,#dbe8ff,transparent),radial-gradient(2.5px 2.5px at 330px 80px,#fff,transparent),radial-gradient(2px 2px at 150px 250px,#cfe0ff,transparent),radial-gradient(2.5px 2.5px at 310px 230px,#fff,transparent),radial-gradient(2px 2px at 30px 200px,#fff,transparent)!important;background-size:380px 380px!important;background-repeat:repeat!important;animation:starDriftB 34s ease-in-out infinite alternate,starTwinkleB 3.2s ease-in-out infinite!important}
@keyframes starDriftB{from{transform:translate3d(0,0,0)}to{transform:translate3d(46px,30px,0)}}
@keyframes starTwinkleB{0%,100%{opacity:.85}50%{opacity:.45}}
.hp-cta-final::after{content:''!important;position:absolute!important;top:14%!important;left:-12%!important;right:auto!important;bottom:auto!important;width:160px!important;height:2px!important;max-width:none!important;max-height:none!important;border-radius:2px!important;z-index:0!important;opacity:0!important;background:linear-gradient(90deg,transparent,#cfe0ff,#fff)!important;box-shadow:0 0 8px 1px rgba(190,215,255,.9)!important;filter:none!important;transform:rotate(20deg)!important;animation:shootStar 6.5s ease-in infinite!important}
@keyframes shootStar{0%{opacity:0;transform:translate3d(0,0,0) rotate(20deg)}6%{opacity:1}14%{opacity:1}22%{opacity:0;transform:translate3d(950px,330px,0) rotate(20deg)}100%{opacity:0;transform:translate3d(950px,330px,0) rotate(20deg)}}
@media(prefers-reduced-motion:reduce){.hp-cta-final .hp-cta-canvas,.hp-cta-final::before,.hp-cta-final::after{animation:none!important;opacity:1!important}.hp-cta-final::after{display:none!important}}

/* ===== v56 — CTA ROTATING STARFIELD (stars orbit around) ===== */
.hp-cta-final .hp-cta-canvas{display:block!important;position:absolute!important;top:50%!important;left:50%!important;right:auto!important;bottom:auto!important;width:170vw!important;height:170vw!important;z-index:0!important;opacity:1!important;border:0!important;background:none!important;background-image:radial-gradient(1.5px 1.5px at 25px 30px,#fff,transparent),radial-gradient(1px 1px at 90px 70px,#cfe0ff,transparent),radial-gradient(1.5px 1.5px at 60px 130px,#fff,transparent),radial-gradient(1px 1px at 150px 40px,#bcd4ff,transparent),radial-gradient(1.5px 1.5px at 130px 165px,#fff,transparent),radial-gradient(1px 1px at 40px 100px,#e6efff,transparent),radial-gradient(1px 1px at 185px 120px,#fff,transparent),radial-gradient(1px 1px at 100px 20px,#dbe8ff,transparent)!important;background-size:200px 200px!important;background-repeat:repeat!important;-webkit-mask:none!important;mask:none!important;filter:none!important;animation:spinStarsA 90s linear infinite,starTwinkleA 4s ease-in-out infinite!important}
@keyframes spinStarsA{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes starTwinkleA{0%,100%{opacity:.6}50%{opacity:1}}
.hp-cta-final::before{content:''!important;position:absolute!important;top:50%!important;left:50%!important;right:auto!important;bottom:auto!important;width:170vw!important;height:170vw!important;max-width:none!important;max-height:none!important;border-radius:0!important;z-index:0!important;opacity:1!important;filter:none!important;-webkit-mask:none!important;mask:none!important;background:none!important;background-image:radial-gradient(2.5px 2.5px at 60px 50px,#fff,transparent),radial-gradient(2px 2px at 230px 150px,#dbe8ff,transparent),radial-gradient(2.5px 2.5px at 330px 80px,#fff,transparent),radial-gradient(2px 2px at 150px 250px,#cfe0ff,transparent),radial-gradient(2.5px 2.5px at 310px 230px,#fff,transparent),radial-gradient(2px 2px at 30px 200px,#fff,transparent)!important;background-size:360px 360px!important;background-repeat:repeat!important;animation:spinStarsB 64s linear infinite,starTwinkleB 3.2s ease-in-out infinite!important}
@keyframes spinStarsB{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(-360deg)}}
@keyframes starTwinkleB{0%,100%{opacity:.85}50%{opacity:.45}}
.hp-cta-final::after{content:''!important;position:absolute!important;top:0!important;left:0!important;right:auto!important;bottom:auto!important;width:5px!important;height:5px!important;max-width:none!important;max-height:none!important;border-radius:50%!important;z-index:0!important;opacity:1!important;background:#fff!important;box-shadow:0 0 10px 2px rgba(190,220,255,.95)!important;filter:none!important;offset-path:circle(230px at 50% 50%)!important;animation:orbitStar 14s linear infinite!important}
@keyframes orbitStar{from{offset-distance:0%}to{offset-distance:100%}}
@media(prefers-reduced-motion:reduce){.hp-cta-final .hp-cta-canvas,.hp-cta-final::before,.hp-cta-final::after{animation:none!important}.hp-cta-final::after{display:none!important}}

/* ===== v57 — PREMIUM FOOTER ===== */
footer{position:relative;overflow:hidden}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#1d4ed8,#60a5fa,#1d4ed8,transparent);background-size:200% 100%;animation:ftLine 7s linear infinite;z-index:2}
@keyframes ftLine{to{background-position:200% 0}}
footer::after{content:'';position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:760px;max-width:90%;height:320px;background:radial-gradient(ellipse at center,rgba(37,99,235,.20),transparent 70%);pointer-events:none;z-index:0;filter:blur(8px)}
footer .ft-inner{position:relative;z-index:1}
footer .ft-col h4{position:relative;color:#9fb0cf}
footer .ft-col h4::after{content:'';display:block;width:26px;height:2px;margin-top:10px;border-radius:2px;background:linear-gradient(90deg,#2563eb,#60a5fa)}
footer .ft-col a{position:relative;display:inline-block;color:#aeb8c9;text-decoration:none;transition:color .25s ease,transform .25s ease;padding-left:0}
footer .ft-col a::before{content:'\2192';position:absolute;left:-18px;opacity:0;color:#60a5fa;transition:opacity .25s ease,transform .25s ease;transform:translateX(-4px)}
footer .ft-col a:hover{color:#fff;transform:translateX(18px)}
footer .ft-col a:hover::before{opacity:1;transform:translateX(0)}
footer .ft-social a{transition:transform .28s cubic-bezier(.34,1.56,.64,1),background .25s ease,box-shadow .25s ease,border-color .25s ease}
footer .ft-social a:hover{transform:translateY(-4px);background:#1d4ed8!important;border-color:#1d4ed8!important;box-shadow:0 10px 24px -8px rgba(37,99,235,.7)}
footer .ft-social a:hover svg{color:#fff!important;fill:#fff!important}
footer .ft-logo{transition:transform .3s ease;display:inline-block}
footer .ft-logo:hover{transform:translateY(-2px)}
footer .ft-bottom{border-top:1px solid rgba(255,255,255,.08)}
footer .ft-legal a{position:relative;transition:color .25s ease}
footer .ft-legal a::after{content:'';position:absolute;left:0;right:0;bottom:-3px;height:1px;background:#60a5fa;transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
footer .ft-legal a:hover{color:#fff}
footer .ft-legal a:hover::after{transform:scaleX(1)}
footer .ft-contact a{transition:color .25s ease}footer .ft-contact a:hover{color:#60a5fa}

/* v58 — footer links back to vertical */
footer .ft-col a{display:block!important;width:fit-content;margin-bottom:14px}
footer .ft-col a:last-child{margin-bottom:0}

/* ===== v59 — BRUTAL FOOTER ===== */
footer{padding-bottom:0!important}
footer .ft-inner{position:relative;z-index:1}
footer .ft-inner::before{content:'ADOAN';position:absolute;left:50%;bottom:-1.5vw;transform:translateX(-50%);font-family:'Playfair Display',Georgia,serif;font-weight:900;font-size:clamp(90px,23vw,360px);line-height:.78;letter-spacing:.01em;white-space:nowrap;z-index:-1;pointer-events:none;background:linear-gradient(180deg,rgba(120,165,255,.20),rgba(37,99,235,.03));-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
footer::before{height:3px!important;background:linear-gradient(90deg,transparent,#1d4ed8,#7cc0ff,#1d4ed8,transparent)!important;background-size:200% 100%!important;box-shadow:0 0 16px 2px rgba(60,130,255,.55)!important}
footer::after{top:-180px!important;width:900px!important;height:360px!important;background:radial-gradient(ellipse at center,rgba(37,99,235,.32),transparent 70%)!important}
footer .ft-logo .adoan-mark{font-size:30px!important}
footer .ft-col h4{color:#bcd0f5!important;letter-spacing:.16em!important}
footer .ft-col h4::after{width:34px!important;height:3px!important;box-shadow:0 0 10px rgba(60,130,255,.7)!important}

/* ===== v60 — ADOAN CHAT WIDGET ===== */
#adChat *{box-sizing:border-box}
.adc-launch{position:fixed;right:22px;bottom:22px;z-index:99990;width:62px;height:62px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1e3a8a);color:#fff;box-shadow:0 14px 34px -8px rgba(37,99,235,.75);display:flex;align-items:center;justify-content:center;transition:transform .25s ease,box-shadow .25s ease}
.adc-launch:hover{transform:translateY(-3px) scale(1.06)}
.adc-launch svg{width:28px;height:28px}
.adc-dot{position:absolute;top:11px;right:11px;width:13px;height:13px;border-radius:50%;background:#34d399;border:2px solid #1e3a8a;animation:adcPulse 1.9s infinite}
@keyframes adcPulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.6)}70%{box-shadow:0 0 0 9px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}
.adc-launch.hide{opacity:0;pointer-events:none;transform:scale(.6)}
.adc-panel{position:fixed;right:22px;bottom:22px;z-index:99991;width:374px;max-width:calc(100vw - 28px);height:560px;max-height:calc(100vh - 100px);background:#0e1426;border:1px solid rgba(255,255,255,.09);border-radius:20px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7);display:none;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(24px) scale(.97);transition:opacity .28s ease,transform .28s ease}
.adc-panel.open{display:flex;opacity:1;transform:none}
.adc-head{display:flex;align-items:center;gap:12px;padding:15px 16px;background:linear-gradient(135deg,#1d4ed8,#1e3a8a);color:#fff;flex-shrink:0}
.adc-av{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:800;font-size:18px}
.adc-head h5{margin:0;font-size:15px;font-weight:700;line-height:1.2}
.adc-status{font-size:12px;opacity:.9;display:flex;align-items:center;gap:5px;margin-top:2px}
.adc-status::before{content:'';width:7px;height:7px;border-radius:50%;background:#34d399}
.adc-close{margin-left:auto;background:rgba(255,255,255,.12);border:none;color:#fff;cursor:pointer;font-size:18px;width:30px;height:30px;border-radius:50%;line-height:1}
.adc-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.adc-msg{max-width:84%;padding:11px 14px;border-radius:15px;font-size:14px;line-height:1.5;animation:adcIn .25s ease}
@keyframes adcIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.adc-bot{align-self:flex-start;background:#1b2336;color:#e8edf7;border-bottom-left-radius:4px}
.adc-user{align-self:flex-end;background:#2563eb;color:#fff;border-bottom-right-radius:4px}
.adc-cta{display:inline-flex;align-items:center;gap:6px;margin-top:9px;background:#2563eb;color:#fff!important;padding:9px 16px;border-radius:100px;font-size:13px;font-weight:600;text-decoration:none}
.adc-cta:hover{background:#1d4ed8}
.adc-typing{align-self:flex-start;display:inline-flex;gap:4px;padding:13px 14px;background:#1b2336;border-radius:15px;border-bottom-left-radius:4px}
.adc-typing span{width:7px;height:7px;border-radius:50%;background:#6b7a99;animation:adcType 1s infinite}
.adc-typing span:nth-child(2){animation-delay:.15s}.adc-typing span:nth-child(3){animation-delay:.3s}
@keyframes adcType{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.adc-chips{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 10px;flex-shrink:0}
.adc-chip{background:rgba(37,99,235,.12);border:1px solid rgba(37,99,235,.45);color:#9ec1ff;font-size:12.5px;padding:8px 13px;border-radius:100px;cursor:pointer;transition:background .2s,color .2s}
.adc-chip:hover{background:#2563eb;color:#fff}
.adc-foot{display:flex;gap:8px;padding:12px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}
.adc-input{flex:1;background:#1b2336;border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:11px 16px;color:#fff;font-size:14px;outline:none}
.adc-input::placeholder{color:#7e8aa3}
.adc-send{background:#2563eb;border:none;border-radius:50%;width:42px;height:42px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.adc-send:hover{background:#1d4ed8}
@media(max-width:520px){.adc-panel{right:14px;left:14px;width:auto;bottom:14px;height:auto;top:74px;max-height:none}.adc-launch{right:16px;bottom:16px}}

/* ===== v61 — CONVERSION + POLISH BATCH ===== */
/* page fade removed (caused mobile NO_LCP) */
.hp-midcta{position:relative;padding:90px 0;background:linear-gradient(135deg,#1d4ed8,#1e3a8a);overflow:hidden;text-align:center}
.hp-midcta::before{content:'';position:absolute;inset:0;background:radial-gradient(60% 130% at 50% 0%,rgba(255,255,255,.14),transparent 60%);pointer-events:none}
.hp-midcta-in{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:0 24px}
.hp-midcta-eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#bcd4ff;background:rgba(255,255,255,.13);padding:6px 14px;border-radius:100px;margin-bottom:18px}
.hp-midcta h2{color:#fff;font-size:clamp(1.8rem,4vw,2.8rem);margin:0 0 14px;line-height:1.15}
.hp-midcta p{color:rgba(255,255,255,.88);font-size:1.05rem;line-height:1.6;margin:0 auto 28px;max-width:560px}
.hp-midcta-btn{display:inline-flex;align-items:center;gap:10px;background:#fff;color:#1d4ed8;font-weight:700;padding:15px 30px;border-radius:100px;text-decoration:none;transition:transform .25s,box-shadow .25s}
.hp-midcta-btn:hover{transform:translateY(-3px);box-shadow:0 16px 34px -10px rgba(0,0,0,.45)}
.hp-midcta-btn span{transition:transform .25s}.hp-midcta-btn:hover span{transform:translateX(5px)}
.err404{position:relative;min-height:72vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(180deg,#0a1024,#0c1738)}
.err404-glow{position:absolute;top:42%;left:50%;width:620px;height:620px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(37,99,235,.38),transparent 65%);filter:blur(44px);pointer-events:none}
.err404-in{position:relative;z-index:1;text-align:center;padding:60px 24px;max-width:680px}
.err404-code{font-family:'Playfair Display',Georgia,serif;font-weight:900;font-size:clamp(110px,22vw,220px);line-height:.9;background:linear-gradient(180deg,#93b8ff,#2563eb);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.err404 h1{color:#fff;font-size:clamp(1.5rem,3.5vw,2.2rem);margin:10px 0 14px}
.err404 p{color:#9fb0cf;font-size:1.05rem;line-height:1.6;margin:0 auto 30px;max-width:480px}
.err404-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.err404-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:100px;font-weight:600;text-decoration:none;transition:.25s}
.err404-btn--primary{background:#2563eb;color:#fff}.err404-btn--primary:hover{background:#1d4ed8;transform:translateY(-2px)}
.err404-btn--ghost{border:1px solid rgba(255,255,255,.25);color:#fff}.err404-btn--ghost:hover{background:rgba(255,255,255,.08)}
.err404-links{font-size:14px;color:#7e8aa3;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;align-items:center}
.err404-links a{color:#9ec1ff;text-decoration:none}.err404-links a:hover{color:#fff;text-decoration:underline}
#cookie-banner{display:flex!important;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center;left:20px!important;right:20px!important;bottom:20px!important;max-width:720px;margin:0 auto!important;padding:16px 22px!important;background:rgba(14,20,38,.92)!important;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1)!important;border-radius:16px!important;box-shadow:0 22px 55px -15px rgba(0,0,0,.65)!important;color:#cdd6e8!important;font-size:14px!important}
#cookie-banner a{color:#9ec1ff!important}
#cookie-banner button{border-radius:100px!important;padding:9px 20px!important;font-weight:600!important;font-size:14px!important;border:none!important;cursor:pointer;transition:.2s;margin:0 0 0 6px!important}
#cookie-banner button:first-of-type{background:#2563eb!important;color:#fff!important}#cookie-banner button:first-of-type:hover{background:#1d4ed8!important}
#cookie-banner button:last-of-type{background:transparent!important;color:#9fb0cf!important;border:1px solid rgba(255,255,255,.22)!important}#cookie-banner button:last-of-type:hover{background:rgba(255,255,255,.08)!important;color:#fff!important}

body{opacity:1!important;animation:none}

/* ===== v64 — pause decorative anims until loaded (mobile Speed Index) ===== */
body:not(.anim-go) .hp-hero .hp-hero-canvas,body:not(.anim-go) .hp-hero::before,body:not(.anim-go) .hp-hero::after,body:not(.anim-go) .hp-hero-inner::before,body:not(.anim-go) .ad-topline,body:not(.anim-go) .hp-marquee-inner{animation-play-state:paused!important}

/* ===== v65 — accessibility contrast fixes ===== */
header.site-header .ad-lang-i{color:#4b5563!important}
header.site-header .ad-lang-i.is-active{color:#fff!important}
header.site-header .ad-lang-i:not(.is-active):hover{color:#1d4ed8!important}
#cookie-banner a{text-decoration:underline!important;color:#bcd6ff!important}

/* ===== v66 — PREMIUM COOKIE BANNER ===== */
#cookie-banner{display:flex!important;align-items:center;gap:16px 20px;flex-wrap:wrap;justify-content:center;left:24px!important;right:24px!important;bottom:24px!important;max-width:660px;margin:0 auto!important;padding:18px 24px!important;background:linear-gradient(135deg,rgba(16,23,42,.97),rgba(12,18,38,.97))!important;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(120,160,255,.20)!important;border-radius:18px!important;box-shadow:0 26px 64px -18px rgba(0,0,0,.72)!important;color:#cfd8ea!important;font-size:14px!important;line-height:1.5}
#cookie-banner::before{content:'';flex-shrink:0;width:40px;height:40px;border-radius:11px;background:rgba(37,99,235,.15) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2360a5fa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l7 3v5c0 4.5-3 7.7-7 9-4-1.3-7-4.5-7-9V6l7-3z'/%3E%3Cpath d='M9 12l2 2 4-4'/%3E%3C/svg%3E") center/22px 22px no-repeat;border:1px solid rgb(96 165 250 / .25)}#cookie-banner>span{flex:1;min-width:200px}#cookie-banner>div{display:inline-flex;gap:10px;flex-wrap:wrap}#cookie-banner a{text-decoration:underline!important;color:#9ec1ff!important;font-weight:600}#cookie-banner button{font:inherit!important;font-weight:600!important;font-size:13.5px!important;border-radius:100px!important;padding:11px 24px!important;cursor:pointer;border:none!important;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;letter-spacing:.01em;margin:0!important}#cookie-banner button:first-of-type{background:linear-gradient(135deg,#3b82f6,#1d4ed8)!important;color:#fff!important;box-shadow:0 8px 22px -6px rgb(37 99 235 / .65)!important}#cookie-banner button:first-of-type:hover{transform:translateY(-2px)!important;box-shadow:0 14px 30px -6px rgb(37 99 235 / .8)!important}#cookie-banner button:last-of-type{background:rgb(255 255 255 / .06)!important;color:#aab4c8!important;border:1px solid rgb(255 255 255 / .16)!important}#cookie-banner button:last-of-type:hover{background:rgb(255 255 255 / .12)!important;color:#fff!important;transform:translateY(-1px)!important}#cookie-banner button:focus-visible{outline:2px solid #60a5fa!important;outline-offset:2px}