/* ================================================================
   JUSTSOFTTECH — FINAL DESIGN SYSTEM
   Matched to reference dashboard: #f4f5f7 body · white cards
   Cyan #00c3c8 · Gold #e6b31e · Inter + Fira Code
   Tight type scale · Spatial glass · Portal-grade hero
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Fira+Code:wght@400;500&display=swap');

:root {
  /* ── Brand (locked to dashboard reference) ─ */
  --cyan:        #00c3c8;
  --cyan-glow:   rgba(0,195,200,.40);
  --cyan-dim:    rgba(0,195,200,.15);
  --cyan-mid:    #009fa4;
  --gold:        #e6b31e;
  --gold-glow:   rgba(230,179,30,.35);
  --gold-dim:    rgba(230,179,30,.15);

  /* ── Surface ─────────────────────────────── */
  --bg:          #f4f5f7;          /* exact dashboard body */
  --card:        #ffffff;
  --card-dark:   #111827;
  --glass:       rgba(255,255,255,.85);
  --glass-mid:   rgba(255,255,255,.60);

  /* ── Type ────────────────────────────────── */
  --ink:         #111827;
  --ink-2:       #1f2937;
  --muted:       #6b7280;
  --subtle:      #9ca3af;
  --on-dark:     rgba(255,255,255,.88);
  --on-dark-dim: rgba(255,255,255,.50);

  /* ── Structure ───────────────────────────── */
  --line:        #e5e7eb;
  --line-dark:   rgba(255,255,255,.10);
  --line-cyan:   rgba(0,195,200,.30);

  /* ── Radii ───────────────────────────────── */
  --r-xs: 4px;  --r-sm: 8px;  --r: 12px;
  --r-lg: 16px; --r-xl: 24px; --r-2xl: 32px;

  /* ── Shadows ─────────────────────────────── */
  --sh-xs: 0 1px 3px rgba(0,0,0,.05);
  --sh-sm: 0 4px 20px rgba(0,0,0,.06);
  --sh-md: 0 8px 32px rgba(0,0,0,.09);
  --sh-lg: 0 20px 60px rgba(0,0,0,.12);
  --sh-xl: 0 40px 90px rgba(0,0,0,.15);
  --sh-cyan: 0 4px 16px var(--cyan-glow);
  --sh-gold: 0 4px 16px var(--gold-glow);

  /* ── Motion ──────────────────────────────── */
  --ease: cubic-bezier(.16,1,.3,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
  --t: 200ms;
  --t-slow: 380ms;

  --max: 1180px;

  /* ── Type scale (tight) ──────────────────── */
  --fs-xs:   11px;
  --fs-sm:   12px;
  --fs-base: 13.5px;
  --fs-md:   15px;
  --fs-lg:   18px;
  --fs-xl:   22px;
  --fs-2xl:  28px;
  --fs-3xl:  36px;
  --fs-hero: clamp(32px, 4.2vw, 54px);
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:'Inter',ui-sans-serif,system-ui,sans-serif;
  font-size:var(--fs-base);
  background:var(--bg);color:var(--ink);
  line-height:1.6;overflow-x:hidden;
}
a{color:inherit;text-decoration:none;transition:color var(--t)}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}

/* ── Layout ─────────────────────────────────────────────────── */
.container{width:min(100% - 48px,var(--max));margin-inline:auto}
.narrow{max-width:720px}

/* ── Announcement bar ────────────────────────────────────────── */
.announcement{
  background:var(--card-dark);
  color:var(--on-dark-dim);
  font-size:var(--fs-xs);font-weight:500;
  letter-spacing:.05em;text-transform:uppercase;
}
.announcement-inner{
  display:flex;justify-content:center;align-items:center;
  gap:28px;min-height:30px;flex-wrap:wrap;
}
.announcement-inner span{position:relative}
.announcement-inner span:not(:last-child)::after{
  content:'';position:absolute;right:-16px;top:50%;
  width:3px;height:3px;border-radius:50%;
  background:var(--cyan);transform:translateY(-50%);
}

/* ── Header ──────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:200;
  background:var(--glass);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  transition:box-shadow var(--t-slow) var(--ease);
}
.site-header.scrolled{box-shadow:var(--sh-md)}

.navbar{
  min-height:60px;
  display:flex;align-items:center;
  justify-content:space-between;gap:20px;
}

/* Brand */
.brand{display:flex;align-items:center;gap:10px;min-width:max-content}
.brand img{width:36px;height:36px;object-fit:contain}
.brand span{display:flex;flex-direction:column;line-height:1.1}
.brand strong{
  font-size:15px;font-weight:700;
  letter-spacing:-.02em;color:var(--ink);
}
.brand small{
  font-size:9px;font-weight:600;
  text-transform:uppercase;letter-spacing:.10em;color:var(--cyan-mid);
}

/* Nav links */
.nav-links{display:flex;align-items:center;gap:1px;font-size:var(--fs-sm);font-weight:500}
.nav-links a{
  color:var(--muted);padding:6px 10px;border-radius:var(--r-sm);
  transition:color var(--t),background var(--t);
}
.nav-links a:hover{color:var(--ink);background:rgba(0,0,0,.04)}
.nav-links a.active{color:var(--cyan-mid);background:var(--cyan-dim)}
.nav-toggle{
  display:none;background:none;border:1px solid var(--line);
  border-radius:var(--r-sm);padding:7px 9px;
  flex-direction:column;gap:4px;cursor:pointer;
}
.nav-toggle span{width:18px;height:1.5px;background:var(--ink);border-radius:2px;display:block}
.btn-nav{
  background:var(--cyan);color:#fff !important;
  font-size:var(--fs-xs);font-weight:600;padding:7px 15px;
  border-radius:999px;border:none;cursor:pointer;
  box-shadow:var(--sh-cyan);
  transition:background var(--t),transform var(--t) var(--spring);
}
.btn-nav:hover{background:var(--cyan-mid);transform:translateY(-1px)}

/* ── Buttons ──────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:7px;border:none;border-radius:999px;
  padding:10px 20px;font-size:var(--fs-sm);font-weight:600;
  cursor:pointer;white-space:nowrap;
  transition:transform var(--t) var(--spring),box-shadow var(--t),background var(--t);
  background:var(--cyan);color:#fff;
  box-shadow:var(--sh-cyan);
}
.btn:hover{background:var(--cyan-mid);transform:translateY(-2px);box-shadow:0 8px 24px var(--cyan-glow)}
.btn:active{transform:scale(.98)}
.btn-outline{
  background:var(--card);color:var(--ink);
  border:1px solid var(--line);box-shadow:var(--sh-xs);
}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan-mid);background:var(--cyan-dim);box-shadow:var(--sh-sm)}
.btn-dark{
  background:var(--card-dark);color:#fff;
  box-shadow:var(--sh-md);
}
.btn-dark:hover{background:#1f2937;box-shadow:var(--sh-lg)}
.btn-gold{
  background:var(--gold);color:var(--ink);
  box-shadow:var(--sh-gold);
}
.btn-gold:hover{background:#d4a219;box-shadow:0 8px 24px var(--gold-glow)}
.btn.small{padding:7px 14px;font-size:var(--fs-xs)}
.btn.tiny{padding:5px 11px;font-size:10px}

/* ── Eyebrow ──────────────────────────────────────────────────── */
.eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  padding:4px 12px;border-radius:999px;
  border:1px solid var(--line-cyan);
  background:var(--cyan-dim);color:var(--cyan-mid);
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.10em;
}
.eyebrow::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}
.eyebrow.light{
  color:rgba(0,195,200,.9);background:rgba(0,195,200,.08);
  border-color:rgba(0,195,200,.2);
}

/* ── Section spacing ──────────────────────────────────────────── */
.section{padding:72px 0}
.section-sm{padding:44px 0}
.alt-section{background:var(--card)}
.section-head{text-align:center;margin-bottom:44px}
.section-head .eyebrow{margin-inline:auto;display:flex;width:max-content}
.section-head h2{margin-top:12px}
.section-head p{
  font-size:var(--fs-base);color:var(--muted);
  max-width:560px;margin:10px auto 0;line-height:1.7;
}

/* ── Typography ────────────────────────────────────────────────── */
.section-head h2,
.split-grid h2,
.cta-card h2,
.footer-cta h2,
.content-card h2{
  font-size:clamp(20px,3vw,32px);
  font-weight:700;letter-spacing:-.04em;color:var(--ink);
}
h3{font-size:var(--fs-md);font-weight:600;letter-spacing:-.02em}

/* ── Dark section ─────────────────────────────────────────────── */
.dark-section{
  background:var(--card-dark);color:var(--on-dark);
  position:relative;overflow:hidden;
}
.dark-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 600px 400px at 5% 20%,rgba(0,195,200,.10),transparent 55%),
    radial-gradient(ellipse 400px 300px at 95% 80%,rgba(230,179,30,.07),transparent 55%);
}
.dark-section .dot-grid{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:24px 24px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.5),transparent 60%);
}
.dark-section>.container{position:relative;z-index:1}
.dark-section h2,.dark-section h3{color:#fff}
.dark-section .section-head p{color:var(--on-dark-dim)}

/* ════════════════════════════════════════════════════════════════
   HERO — PORTAL SLIDER
   Full-width dark command panel with sliding panels
════════════════════════════════════════════════════════════════ */
.hero-portal{
  position:relative;
  background:var(--card-dark);
  overflow:hidden;
  min-height:580px;
  display:flex;flex-direction:column;
}

/* Background mesh */
.hero-portal::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(0,195,200,.05) 1px,transparent 1px);
  background-size:24px 24px;
}
/* Ambient glow */
.hero-portal::after{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 700px 500px at 15% 50%,rgba(0,195,200,.08),transparent 55%),
    radial-gradient(ellipse 500px 400px at 85% 10%,rgba(230,179,30,.06),transparent 50%);
}

/* ── Slider track ─────────────────────────────────────────────── */
.hero-slider{
  position:relative;z-index:2;
  flex:1;display:flex;flex-direction:column;
}
.hero-slides{
  display:flex;flex:1;
  transition:transform .6s var(--ease);
  will-change:transform;
}
.hero-slide{
  min-width:100%;
  display:grid;grid-template-columns:1fr 1fr;
  gap:48px;align-items:center;
  padding:56px 0 48px;
}
.container.slide-inner{width:min(100% - 48px,var(--max));margin-inline:auto;display:contents}
.hero-slide>.slide-copy{padding-left:calc((100vw - min(100% - 48px,var(--max))) / 2);padding-right:24px}
.hero-slide>.slide-visual{padding-right:calc((100vw - min(100% - 48px,var(--max))) / 2);padding-left:24px}

/* Slide copy */
.slide-copy h1{
  font-size:var(--fs-hero);
  font-weight:800;letter-spacing:-.06em;
  color:#fff;line-height:1.03;
  margin:14px 0 16px;
}
.slide-copy h1 em{
  font-style:normal;
  background:linear-gradient(90deg,var(--cyan) 0%,#00e8f0 60%,var(--cyan-mid) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.slide-copy p{
  font-size:var(--fs-base);color:rgba(255,255,255,.6);
  max-width:440px;line-height:1.75;
}
.slide-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}

/* Metric row inside hero */
.hero-metrics{
  display:flex;gap:24px;margin-top:28px;
}
.hero-metric{
  display:flex;flex-direction:column;gap:2px;
}
.hero-metric strong{
  font-size:var(--fs-xl);font-weight:700;
  color:#fff;line-height:1;letter-spacing:-.04em;
}
.hero-metric strong span{color:var(--cyan);font-size:14px}
.hero-metric small{font-size:var(--fs-xs);color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em}

/* Slide visual — glass dashboard card */
.slide-visual{
  display:flex;justify-content:center;align-items:center;
}
.portal-card{
  width:min(400px,100%);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--r-xl);padding:22px;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 24px 60px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.08);
  animation:float 6s ease-in-out infinite;
}
.portal-card-top{display:flex;gap:6px;margin-bottom:16px}
.portal-card-top span{width:10px;height:10px;border-radius:50%;background:#FF5F57}
.portal-card-top span:nth-child(2){background:#FEBC2E}
.portal-card-top span:nth-child(3){background:#28C840}
.portal-card-label{
  font-size:var(--fs-xs);font-weight:600;color:var(--cyan);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;
}
.portal-card-title{
  font-size:var(--fs-lg);font-weight:700;color:#fff;letter-spacing:-.03em;margin-bottom:14px;
}
/* Inline mini chart in card */
.mini-chart{height:56px;margin:0 -4px 14px}
.mini-chart svg{width:100%;height:100%}
/* Bento mini grid */
.portal-bento{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.portal-bento-cell{
  background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.06);
  border-radius:var(--r);padding:10px 12px;
}
.portal-bento-cell small{display:block;color:rgba(255,255,255,.35);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.portal-bento-cell b{display:block;color:#fff;font-size:var(--fs-lg);font-weight:700;margin-top:3px;letter-spacing:-.03em}
/* Code snippet in card */
.portal-code{
  background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.06);
  border-radius:var(--r);padding:10px 12px;
  font-family:'Fira Code',monospace;font-size:11px;
  display:grid;gap:4px;
}
.portal-code span{color:rgba(0,195,200,.8)}
.portal-code span:first-child{color:rgba(230,179,30,.8)}
.portal-code span:last-child{color:rgba(255,255,255,.25)}

/* ── Slider controls ──────────────────────────────────────────── */
.hero-controls{
  position:relative;z-index:3;
  display:flex;align-items:center;justify-content:center;gap:20px;
  padding:16px 0 24px;background:var(--card-dark);
  border-top:1px solid rgba(255,255,255,.05);
}
.slider-dots{display:flex;gap:8px;align-items:center}
.slider-dot{
  width:6px;height:6px;border-radius:999px;
  background:rgba(255,255,255,.2);border:none;cursor:pointer;
  transition:background var(--t),width var(--t),box-shadow var(--t);
  padding:0;
}
.slider-dot.active{
  background:var(--cyan);width:22px;
  box-shadow:0 0 10px var(--cyan-glow);
}
.slider-arrow{
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.5);font-size:13px;
  display:grid;place-items:center;cursor:pointer;
  transition:background var(--t),color var(--t),border-color var(--t);
}
.slider-arrow:hover{background:rgba(0,195,200,.15);border-color:rgba(0,195,200,.4);color:var(--cyan)}

/* Trust strip */
.trust-strip{
  padding:12px 0;
  background:var(--card);
  border-bottom:1px solid var(--line);
}
.trust-grid{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.trust-grid span{
  border:1px solid var(--line);border-radius:999px;
  background:var(--bg);padding:5px 14px;
  color:var(--muted);font-size:11px;font-weight:500;
  transition:border-color var(--t),color var(--t);
}
.trust-grid span:hover{border-color:var(--line-cyan);color:var(--cyan-mid)}

/* ── Cards ─────────────────────────────────────────────────────── */
.card-grid{display:grid;gap:14px}
.card-grid.two  {grid-template-columns:repeat(2,1fr)}
.card-grid.three{grid-template-columns:repeat(3,1fr)}
.card-grid.four {grid-template-columns:repeat(4,1fr)}

.service-card,.mini-card,.blog-card,.pricing-card,
.testimonial,.content-card,.quote-form,.contact-panel .content-card{
  position:relative;overflow:hidden;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r-lg);padding:22px;
  box-shadow:var(--sh-sm);
  transition:transform var(--t) var(--spring),box-shadow var(--t),border-color var(--t);
}
/* Top glare */
.service-card::before,.mini-card::before,.pricing-card::before{
  content:'';position:absolute;
  top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.9),transparent);
  pointer-events:none;
}
.service-card:hover,.mini-card:hover,.blog-card:hover,.pricing-card:hover{
  transform:translateY(-4px) scale(1.004);
  box-shadow:var(--sh-md);border-color:var(--line-cyan);
}
.icon-badge{
  display:grid;place-items:center;
  width:44px;height:44px;border-radius:12px;
  background:var(--cyan-dim);
  border:1px solid var(--line-cyan);
  font-size:20px;margin-bottom:16px;
  transition:transform var(--t) var(--spring);
}
.service-card:hover .icon-badge{transform:scale(1.1) rotate(-3deg)}
.service-card small,.mini-card small,.case-card small,
.blog-card small,.pricing-card small,.content-card small{
  color:var(--cyan-mid);font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
}
.service-card h3,.mini-card h3,.case-card h3,.blog-card h3,
.pricing-card h3,.content-card h3{
  font-size:var(--fs-md);font-weight:600;letter-spacing:-.02em;
  color:var(--ink);margin:8px 0 7px;
}
.service-card p,.mini-card p,.case-card p,.blog-card p,
.pricing-card p,.testimonial p,.content-card p{
  color:var(--muted);font-size:var(--fs-base);line-height:1.65;
}
.service-card strong{display:block;color:var(--cyan-mid);font-weight:600;margin-top:14px;font-size:var(--fs-sm)}

/* Case cards — dark */
.case-card{
  display:block;
  background:#111827;
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);padding:22px;
  color:var(--on-dark);min-height:200px;
  box-shadow:var(--sh-sm);
  transition:transform var(--t) var(--spring),box-shadow var(--t),border-color var(--t);
}
.case-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(0,195,200,.3)}
.case-card h3{color:#fff;font-size:var(--fs-md)}
.case-card p{color:rgba(255,255,255,.55);font-size:var(--fs-base)}
.case-card span,.blog-card span{color:var(--gold);font-weight:600;font-size:var(--fs-sm);display:block;margin-top:14px}

/* Split grid */
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.align-start{align-items:start}
.split-grid.reverse>div:first-child{order:2}
.split-grid h2{margin-top:12px}
.split-grid>div>p{color:var(--muted);font-size:var(--fs-base);line-height:1.7;margin-top:12px}

/* Process list */
.process-list{display:grid;gap:8px;counter-reset:step}
.process-list div{
  display:grid;grid-template-columns:36px 1fr;gap:12px;align-items:start;
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:14px 16px;
  box-shadow:var(--sh-xs);
  transition:border-color var(--t),transform var(--t);
  counter-increment:step;
}
.process-list div::before{
  content:counter(step,decimal-leading-zero);
  font-family:'Fira Code',monospace;font-size:11px;
  font-weight:500;color:var(--cyan-mid);padding-top:1px;
}
.process-list div:hover{border-color:var(--line-cyan);transform:translateX(3px)}
.process-list span{color:var(--cyan-mid);font-weight:700;font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:.06em}
.process-list p{margin:3px 0 0;color:var(--muted);font-size:var(--fs-sm)}

/* Stack card */
.stack-card{
  background:var(--bg);border:1px solid var(--line);
  border-radius:var(--r);padding:14px 16px;margin-bottom:8px;
  transition:border-color var(--t);
}
.stack-card:hover{border-color:var(--line-cyan)}
.stack-card span{display:block;color:var(--subtle);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em}
.stack-card b{display:block;font-size:var(--fs-md);font-weight:600;color:var(--ink);margin-top:4px}

/* Check list */
.check-list{display:grid;gap:8px;list-style:none;margin:14px 0}
.check-list li{position:relative;padding-left:22px;color:var(--muted);font-size:var(--fs-base)}
.check-list li::before{content:'✓';position:absolute;left:0;top:0;color:var(--cyan-mid);font-weight:700;font-size:12px}
.check-list.compact li{font-size:var(--fs-sm)}

/* Pricing */
.pricing-card.popular{
  border:1.5px solid var(--cyan);
  background:linear-gradient(160deg,var(--cyan-dim),var(--card));
  box-shadow:0 0 0 3px rgba(0,195,200,.07),var(--sh-md);
}
.price-line{
  display:block;font-size:var(--fs-xl);font-weight:700;
  letter-spacing:-.04em;color:var(--ink);margin:7px 0 12px;
}
.pricing-card .btn{margin-top:16px;width:100%;justify-content:center}
.dual-card{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}
.dual-card article{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:14px}

/* CTA card */
.cta-card,.footer-cta{
  display:flex;align-items:center;justify-content:space-between;
  gap:28px;border-radius:var(--r-2xl);padding:40px;
  background:var(--card-dark);color:var(--on-dark);
  box-shadow:var(--sh-xl);overflow:hidden;position:relative;
}
.cta-card::before,.footer-cta::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 400px 300px at 0% 50%,rgba(0,195,200,.12),transparent 55%),
    radial-gradient(ellipse 350px 250px at 100% 0%,rgba(230,179,30,.08),transparent 50%);
}
.cta-card::after,.footer-cta::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:24px 24px;
}
.cta-card>*,.footer-cta>*{position:relative;z-index:1}
.cta-card h2,.footer-cta h2{color:#fff !important}
.cta-card p,.footer-cta p{color:var(--on-dark-dim);max-width:500px;margin-top:8px;font-size:var(--fs-base)}

/* Page hero */
.page-hero{padding:72px 0 44px;text-align:center}
.page-hero .container{display:grid;place-items:center}
.page-hero h1{
  font-size:clamp(26px,4vw,44px);font-weight:700;
  letter-spacing:-.06em;color:var(--ink);
  margin:14px 0 16px;line-height:1.05;
}
.page-hero p{font-size:var(--fs-base);color:var(--muted);max-width:520px;margin-inline:auto;line-height:1.7}

/* Forms */
.quote-form label{display:grid;gap:6px;color:var(--ink);font-size:var(--fs-sm);font-weight:600}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.quote-form input,.quote-form textarea,.quote-form select{
  width:100%;border:1px solid var(--line);
  border-radius:var(--r);padding:10px 13px;
  background:var(--bg);color:var(--ink);outline:none;
  font-size:var(--fs-base);transition:border-color var(--t),box-shadow var(--t);
}
.quote-form input:focus,.quote-form textarea:focus{
  border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-dim);
}
.quote-form input::placeholder,.quote-form textarea::placeholder{color:var(--subtle)}
.quote-form textarea{min-height:140px;resize:vertical}
.hp-field{position:absolute !important;left:-9999px !important;opacity:0 !important}
.notice{padding:11px 14px;border-radius:var(--r);margin-bottom:14px;font-weight:600;font-size:var(--fs-sm)}
.notice.success{background:#ecfdf5;color:#065f46;border:1px solid rgba(5,150,105,.2)}
.notice.error{background:#fff1f2;color:#9f1239;border:1px solid rgba(159,18,57,.2)}

.contact-panel{display:grid;gap:12px}
.contact-panel a{color:var(--cyan-mid);font-weight:600}
.contact-panel a:hover{color:var(--cyan)}
.mini-contact-card{
  background:var(--card-dark);color:var(--on-dark-dim);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);padding:20px;
  display:grid;gap:7px;position:relative;overflow:hidden;
}
.mini-contact-card strong{color:#fff;font-size:var(--fs-md);font-weight:600;position:relative}
.mini-contact-card span{font-size:var(--fs-sm);line-height:1.65;position:relative}

/* ════════════════════════════════════════════════════════════════
   FOOTER — PROPER DARK PANEL
════════════════════════════════════════════════════════════════ */
.footer{
  background:#0d1117;
  color:rgba(255,255,255,.55);
  padding:0;
  border-top:1px solid rgba(255,255,255,.06);
}
/* Footer CTA strip */
.footer-cta{
  margin:0;border-radius:0;
  padding:40px calc((100vw - min(100% - 48px,var(--max))) / 2);
  padding-left:max(24px, calc((100vw - var(--max)) / 2 + 24px));
  padding-right:max(24px, calc((100vw - var(--max)) / 2 + 24px));
  background:linear-gradient(90deg,#13203a,#111827);
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow:none;
}
/* Grid */
.footer-inner{padding:48px 0 32px}
.footer-grid{
  display:grid;
  grid-template-columns:1.8fr 1fr 1fr 1.2fr;
  gap:40px;align-items:start;
  margin-bottom:40px;
}
.footer h3{
  color:rgba(255,255,255,.85);font-size:var(--fs-sm);
  font-weight:600;margin-bottom:16px;letter-spacing:.02em;
}
.footer a{
  display:block;color:rgba(255,255,255,.45);
  margin:7px 0;font-size:var(--fs-sm);
  transition:color var(--t),transform var(--t);
}
.footer a:hover{color:var(--gold);transform:translateX(3px)}
.footer p{color:rgba(255,255,255,.35);font-size:var(--fs-sm);line-height:1.7}
.footer-brand .brand img{width:36px;height:36px}
.footer-brand .brand strong{color:#fff}
.footer-about p{max-width:280px;margin-top:12px}
.socials{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.socials a{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);
  border-radius:999px;padding:5px 13px;margin:0;font-size:11px;font-weight:500;transform:none;
  transition:background var(--t),border-color var(--t),color var(--t);
}
.socials a:hover{background:rgba(0,195,200,.12);border-color:var(--line-cyan);color:var(--cyan);transform:none}

/* Footer divider line */
.footer-divider{height:1px;background:rgba(255,255,255,.07);margin:0 0 28px}
/* Footer bottom row */
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
  color:rgba(255,255,255,.25);font-size:11px;
  padding-bottom:8px;
}
.footer-bottom a{display:inline;margin:0;color:rgba(255,255,255,.3);transform:none}
.footer-bottom a:hover{color:var(--gold);transform:none}

/* Status indicator in footer */
.footer-status{
  display:flex;align-items:center;gap:7px;
  font-size:10px;color:rgba(255,255,255,.35);font-weight:500;
}
.footer-status-dot{
  width:6px;height:6px;border-radius:50%;
  background:#10b981;box-shadow:0 0 6px #10b981;
  animation:pulse 2s ease infinite;
}

/* WhatsApp */
.whatsapp{
  position:fixed;right:20px;bottom:20px;z-index:300;
  background:#25d366;color:#fff !important;
  border-radius:999px;padding:10px 18px;
  font-size:12px;font-weight:700;
  box-shadow:0 6px 24px rgba(37,211,102,.4);
  transition:transform var(--t) var(--spring),box-shadow var(--t);
}
.whatsapp:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 10px 32px rgba(37,211,102,.5)}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.show{opacity:1;transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.22s}
.delay-3{transition-delay:.32s}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:1100px){
  .hero-slide{grid-template-columns:1fr;gap:0}
  .hero-slide>.slide-visual{display:none}
  .split-grid{grid-template-columns:1fr}
  .card-grid.three,.card-grid.four{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-card,.footer-cta{flex-direction:column;align-items:flex-start;gap:20px}
  .split-grid.reverse>div:first-child{order:0}
}
@media(max-width:860px){
  .announcement{display:none}
  .nav-toggle{display:flex}
  .nav-links{
    position:absolute;top:64px;left:12px;right:12px;
    display:none;flex-direction:column;align-items:stretch;gap:2px;
    background:rgba(255,255,255,.97);border:1px solid var(--line);
    border-radius:var(--r-lg);padding:12px;box-shadow:var(--sh-lg);
    backdrop-filter:blur(20px);
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:9px 12px;border-radius:var(--r-sm)}
  .nav-cta{margin-top:4px}
}
@media(max-width:640px){
  .container{width:min(100% - 24px,var(--max))}
  .section{padding:52px 0}
  .hero-portal{min-height:auto}
  .hero-slide{padding:40px 0 32px}
  .hero-slide>.slide-copy h1{font-size:28px}
  .card-grid.two,.card-grid.three,.card-grid.four,
  .form-grid,.dual-card{grid-template-columns:1fr}
  .process-list div{grid-template-columns:28px 1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .cta-card,.footer-cta{padding:28px 22px;border-radius:var(--r-xl)}
  .service-card,.mini-card,.case-card,.blog-card,.pricing-card,.content-card{padding:18px}
  .hero-controls{gap:12px}
}
:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:var(--r-sm)}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
}

/* ================================================================
   V8 STABILITY + PREMIUM UI FIXES
   Fixes full-width page, professional footer, dashboard hero,
   package grouping, testimonial slider and logo radius.
   ================================================================ */
html, body, .site-shell { width: 100%; min-width: 0; }
.site-shell { min-height: 100vh; overflow-x: clip; }
main, .site-header, .footer, .hero-portal, .trust-strip { width: 100%; max-width: none; }
.brand img, .footer-brand img { border-radius: 50%; object-fit: cover; background: #fff; box-shadow: 0 10px 28px rgba(0,0,0,.10); }
.site-header { left: 0; right: 0; }
.navbar { min-height: 64px; }
.nav-links { gap: 2px; }
.btn-nav { padding: 10px 16px; }

/* Hero dashboard slider */
.hero-v8 { min-height: 640px; }
.hero-v8 .hero-slide { grid-template-columns: minmax(0,.85fr) minmax(560px,1.15fr); gap: 30px; padding: 44px max(24px, calc((100vw - var(--max)) / 2 + 24px)); }
.hero-v8 .slide-copy { padding: 0 !important; align-self: center; }
.hero-v8 .slide-visual { padding: 0 !important; align-self: center; min-width: 0; }
.hero-v8 .slide-copy h1 { font-size: clamp(34px, 4.3vw, 58px); max-width: 670px; }
.hero-v8 .slide-copy p { max-width: 530px; font-size: 15px; }
.dashboard-hero-wrap { perspective: 1500px; }
.dashboard-hero-wrap .advanced-dashboard { transform: rotateY(-7deg) rotateX(2deg); transform-origin: center; box-shadow: 0 42px 100px rgba(0,0,0,.42); }

/* Advanced dashboard component based on uploaded reference */
.advanced-dashboard{
  --ad-cyan: var(--cyan); --ad-gold: var(--gold); --ad-bg:#f4f5f7; --ad-card:#fff; --ad-ink:#111827; --ad-muted:#6b7280; --ad-line:#e5e7eb;
  width: min(720px, 100%); min-height: 430px; border-radius: 28px; overflow: hidden; display: grid; grid-template-columns: 150px 1fr;
  background: var(--ad-bg); border: 1px solid rgba(255,255,255,.18); box-shadow: 0 30px 90px rgba(0,0,0,.25); color: var(--ad-ink); position: relative;
}
.advanced-dashboard::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 28% 12%,rgba(0,195,200,.18),transparent 32%),radial-gradient(circle at 80% 10%,rgba(230,179,30,.10),transparent 30%);}
.ad-sidebar{position:relative;z-index:1;background:rgba(255,255,255,.72);backdrop-filter:blur(22px);border-right:1px solid var(--ad-line);padding:20px 14px;display:flex;flex-direction:column;gap:24px;}
.ad-brand-mark small{display:block;color:var(--ad-cyan);font-size:8px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;margin-top:2px;}
.ad-logo-text{font-size:28px;font-weight:900;line-height:1}.ad-logo-text span:first-child{color:var(--ad-cyan);text-shadow:0 4px 12px rgba(0,195,200,.35)}.ad-logo-text span:nth-child(2),.ad-logo-text span:nth-child(3){color:var(--ad-gold);text-shadow:0 4px 12px rgba(230,179,30,.35)}
.ad-menu{display:grid;gap:8px}.ad-menu span{display:flex;align-items:center;gap:9px;border-radius:10px;padding:10px;color:var(--ad-muted);font-size:12px;font-weight:600}.ad-menu span.active{background:var(--ad-cyan);color:#fff;box-shadow:0 10px 22px rgba(0,195,200,.35)}.ad-menu i{font-style:normal;width:18px;text-align:center}
.ad-main{position:relative;z-index:1;padding:20px;display:flex;flex-direction:column;gap:16px;min-width:0}.ad-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.ad-kicker{font-size:9px;text-transform:uppercase;color:var(--ad-muted);letter-spacing:.08em;font-weight:700}.ad-head h3{font-size:20px;margin:1px 0 0;font-weight:600}.ad-controls{display:flex;align-items:center;gap:9px}.ad-search{position:relative}.ad-search span{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ad-muted);font-size:12px}.ad-search input{width:190px;border:1px solid var(--ad-line);border-radius:18px;padding:8px 10px 8px 28px;background:#fff;font-size:11px;color:var(--ad-muted)}.ad-icon{position:relative;display:grid;place-items:center;width:24px;height:24px;color:var(--ad-muted);font-size:13px}.ad-icon i{position:absolute;right:3px;top:2px;width:7px;height:7px;border-radius:50%;background:#10b981;box-shadow:0 0 8px #10b981}.ad-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--ad-cyan),#0f766e);border:2px solid #fff;box-shadow:0 8px 18px rgba(0,0,0,.12)}
.ad-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:115px 210px;gap:11px;min-height:0}.ad-card{background:#fff;border:1px solid var(--ad-line);border-radius:14px;padding:12px;box-shadow:0 8px 28px rgba(17,24,39,.06);position:relative;overflow:hidden}.ad-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:11px;font-weight:600;color:var(--ad-ink);margin-bottom:8px}.ad-card-head b{font-size:8px;color:#84cc16;display:flex;gap:4px;align-items:center}.ad-card-head b i{width:6px;height:6px;border-radius:50%;background:#84cc16;box-shadow:0 0 8px #84cc16}.ad-card-head em{font-style:normal;color:var(--ad-muted)}.ad-data-one{grid-column:1/2}.ad-data-two{grid-column:2/3}.ad-radial-one{grid-column:3/4}.ad-radial-two{grid-column:4/5}.ad-api{grid-column:1/3;grid-row:2}.ad-radial-three{grid-column:3/4;grid-row:2}.ad-code{grid-column:4/5;grid-row:2;background:#111827;border-color:#1f2937;color:#e5e7eb}.ad-code .ad-card-head{color:#f3f4f6}.ad-chart{height:70px;margin:4px -12px -12px;background:linear-gradient(180deg,rgba(0,195,200,.24),rgba(0,195,200,0));clip-path:polygon(0 70%,18% 58%,34% 68%,52% 30%,70% 58%,84% 38%,100% 20%,100% 100%,0 100%);border-bottom:2px solid rgba(0,195,200,.45);filter:drop-shadow(0 5px 8px rgba(0,195,200,.2))}.ad-area-b{clip-path:polygon(0 55%,16% 68%,31% 30%,51% 58%,70% 40%,100% 52%,100% 100%,0 100%)}
.ad-radial{display:grid;place-items:center;position:relative;height:calc(100% - 24px)}.ad-radial::before,.ad-radial::after{content:'';position:absolute;border-radius:50%;inset:16px;border:4px solid var(--ad-line);border-top-color:var(--ad-cyan);border-right-color:var(--ad-cyan)}.ad-radial::after{inset:30px;border-width:4px;border-top-color:var(--ad-gold);border-right-color:var(--ad-line);transform:rotate(55deg)}.ad-radial span{position:relative;z-index:1;font-size:12px;font-weight:700;color:var(--ad-ink)}.ad-legend{position:absolute;bottom:10px;left:12px;right:12px;display:flex;gap:8px;justify-content:center;color:var(--ad-muted);font-size:9px}.ad-legend i{width:6px;height:6px;border-radius:50%;background:var(--ad-cyan);display:inline-block}.ad-legend i:nth-child(2){background:var(--ad-gold)}
.ad-network{height:100%;position:relative}.ad-network::before{content:'';position:absolute;left:13%;right:10%;top:16%;bottom:22%;background:repeating-linear-gradient(90deg,transparent 0 48px,rgba(0,195,200,.08) 49px),repeating-linear-gradient(0deg,transparent 0 42px,rgba(0,195,200,.05) 43px);border-bottom:1px solid var(--ad-line)}.node{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--ad-cyan);box-shadow:0 0 14px rgba(0,195,200,.55)}.node.center{left:42%;top:46%;width:24px;height:24px;transform:translate(-50%,-50%);border:5px solid rgba(255,255,255,.75)}.node.a{left:10%;top:24%}.node.b{left:10%;top:48%}.node.c{left:10%;top:70%}.node.d{right:30%;top:18%}.node.e{right:30%;top:48%}.node.f{right:30%;top:74%}.node.g{right:10%;top:48%}.line{position:absolute;height:1px;background:rgba(0,195,200,.35);transform-origin:left center}.l1{left:13%;top:27%;width:30%;transform:rotate(18deg)}.l2{left:13%;top:51%;width:29%;transform:rotate(-3deg)}.l3{left:13%;top:72%;width:30%;transform:rotate(-18deg)}.l4{left:45%;top:47%;width:26%;transform:rotate(-31deg)}.l5{left:45%;top:47%;width:26%;transform:rotate(3deg)}.l6{left:61%;top:50%;width:28%;transform:rotate(0)}.label{position:absolute;color:var(--ad-muted);font-size:9px}.label.one{left:0;top:10%}.label.two{left:0;top:35%}.label.three{left:0;top:62%}.label.four{left:38%;top:36%;color:var(--ad-ink);font-weight:700}.ad-code pre{margin:0;font-family:'Fira Code',monospace;font-size:10px;line-height:1.75;color:#d1d5db;overflow:auto}.ad-code .num{color:#4b5563}.ad-code .kw{color:#ff7b72}.ad-code .str{color:#a5d6ff}.ad-code .ok{color:#10b981}

/* Testimonials */
.testimonial-section{background:linear-gradient(180deg,#fff,var(--bg));}.testimonial-slider{position:relative;overflow:hidden}.testimonial-track{display:flex;gap:16px;transition:transform .45s var(--ease);will-change:transform}.testimonial-slide{min-width:calc((100% - 32px)/3);background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:var(--sh-sm)}.testimonial-slide .stars{color:var(--gold);font-size:14px;letter-spacing:2px;margin-bottom:12px}.testimonial-slide p{font-size:14px;color:var(--ink-2);line-height:1.75;margin-bottom:18px}.testimonial-slide strong{display:block;color:var(--ink);font-size:14px}.testimonial-slide span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.testimonial-controls{display:flex;justify-content:center;gap:10px;margin-top:18px}.testimonial-controls button{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;box-shadow:var(--sh-xs);transition:.2s}.testimonial-controls button:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-2px)}

/* Professional packages */
.package-note{display:flex;justify-content:space-between;align-items:center;gap:20px;background:#111827;color:rgba(255,255,255,.78);border-radius:22px;padding:18px 22px;margin-bottom:28px}.package-note strong{color:#fff}.package-note span{font-size:13px;color:rgba(255,255,255,.58)}.package-category-list{display:grid;gap:34px}.package-category-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:14px}.package-category-head span{display:block;font-size:22px;font-weight:800;letter-spacing:-.04em;color:var(--ink)}.package-category-head p{color:var(--muted);font-size:13px;max-width:620px;margin-top:4px}.package-category-head a{font-size:12px;color:var(--cyan-mid);font-weight:700}.popular-pill{position:absolute;top:14px;right:14px;background:var(--gold);color:#111827;border-radius:999px;padding:4px 10px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.pricing-card{min-height:100%;}.pricing-card strong,.pricing-card .price-line{display:block;font-size:22px;font-weight:800;letter-spacing:-.04em;color:var(--ink);margin:8px 0 12px}.ownership-card{max-width:900px;margin-inline:auto}.ownership-card .eyebrow{margin-bottom:12px}

/* Footer v8 */
.footer-v8{background:#0b111c;color:rgba(255,255,255,.6);position:relative;overflow:hidden}.footer-v8::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 10% 10%,rgba(0,195,200,.10),transparent 32%),radial-gradient(circle at 90% 0,rgba(230,179,30,.08),transparent 34%);pointer-events:none}.footer-command{position:relative;border-bottom:1px solid rgba(255,255,255,.08);background:linear-gradient(90deg,rgba(0,195,200,.08),rgba(230,179,30,.05));}.footer-command-inner{display:flex;justify-content:space-between;align-items:center;gap:28px;padding-top:38px;padding-bottom:38px}.footer-command h2{font-size:clamp(22px,3vw,34px);color:#fff;letter-spacing:-.04em;margin:10px 0 8px}.footer-command p{color:rgba(255,255,255,.55);max-width:680px}.footer-command-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.footer-outline{background:rgba(255,255,255,.06)!important;color:#fff!important;border-color:rgba(255,255,255,.12)!important}.footer-v8 .footer-inner{position:relative;padding:42px 0 28px}.footer-grid-v8{grid-template-columns:1.5fr .8fr .9fr 1.05fr;gap:28px}.footer-card-brand,.footer-contact-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:24px}.footer-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:18px}.footer-mini-grid span{display:block;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px}.footer-mini-grid b{display:block;color:var(--cyan);font-size:12px}.footer-mini-grid small{display:block;color:rgba(255,255,255,.44);font-size:10px;margin-top:2px}.footer-link-col h3,.footer-contact-card h3{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.footer-link-col a,.footer-contact-card a{display:block;font-size:13px;color:rgba(255,255,255,.50);margin:9px 0}.footer-link-col a:hover,.footer-contact-card a:hover{color:var(--cyan);transform:translateX(3px)}.footer-contact-card p{font-size:13px;color:rgba(255,255,255,.46);line-height:1.75;margin-bottom:14px}.footer-v8 .footer-bottom{position:relative;border-top:1px solid rgba(255,255,255,.08);padding-top:18px;padding-bottom:0}.footer-v8 .footer-divider{display:none}

/* Responsive public */
@media(max-width:1180px){.hero-v8 .hero-slide{grid-template-columns:1fr;}.dashboard-hero-wrap .advanced-dashboard{transform:none;margin-inline:auto}.hero-v8 .slide-copy{text-align:left}.footer-grid-v8{grid-template-columns:1fr 1fr}.testimonial-slide{min-width:calc((100% - 16px)/2)}}
@media(max-width:860px){.hero-v8{min-height:auto}.hero-v8 .hero-slide{padding:42px 18px 28px}.hero-v8 .slide-copy h1{font-size:32px}.dashboard-hero-wrap{display:none}.footer-command-inner{flex-direction:column;align-items:flex-start}.footer-grid-v8{grid-template-columns:1fr}.footer-command-actions{justify-content:flex-start}.package-note{flex-direction:column;align-items:flex-start}.testimonial-slide{min-width:100%}.advanced-dashboard{grid-template-columns:1fr;width:100%;min-height:auto}.ad-sidebar{display:none}.ad-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}.ad-data-one,.ad-data-two,.ad-radial-one,.ad-radial-two,.ad-api,.ad-radial-three,.ad-code{grid-column:auto;grid-row:auto}.ad-controls{display:none}}
@media(max-width:640px){.brand strong{font-size:14px}.brand img{width:38px;height:38px}.footer-mini-grid,.card-grid.three{grid-template-columns:1fr}.package-category-head{align-items:flex-start;flex-direction:column}.ad-main{padding:14px}.ad-grid{grid-template-columns:1fr}.ad-card{min-height:120px}.ad-api,.ad-code{min-height:210px}}

/* ================================================================
   V9 — PROFESSIONAL SOLUTIONS UI PATCH
   Fixes process cards, full-width layout, portal slider animation,
   professional footer and solution-based pages.
   ================================================================ */
html, body { width: 100%; max-width: 100%; margin: 0; overflow-x: hidden; }
body { background: #f4f5f7; }
.site-shell, main, .site-header, .footer, .hero-portal, .trust-strip, .section { width: 100%; max-width: none; }
.container { width: min(100% - 44px, 1180px); }
.brand img, .footer-brand-v9 img, .footer-brand img { border-radius: 50%; object-fit: cover; background:#fff; }
.site-header { left: 0; right: 0; }
.navbar { min-height: 66px; }
.nav-links a { font-size: 12px; font-weight: 650; }
.nav-cta, .btn-nav { border-radius: 14px; padding: 9px 15px; }

/* Portal hero */
.hero-v9 { min-height: 680px; isolation: isolate; }
.hero-v9 .hero-slides { will-change: transform; }
.hero-v9 .hero-slide {
  grid-template-columns: minmax(0,.82fr) minmax(560px,1.18fr);
  gap: 34px;
  padding: 52px max(24px, calc((100vw - var(--max)) / 2 + 24px));
  transition: opacity .55s var(--ease), filter .55s var(--ease), transform .65s var(--ease);
  position: relative;
}
.hero-v9 .hero-slide[aria-hidden="true"] { opacity: .35; filter: blur(10px) saturate(.7); transform: scale(.94); }
.hero-v9 .hero-slide.active { opacity: 1; filter: none; transform: scale(1); }
.hero-v9 .hero-slide.leaving { filter: blur(12px) saturate(.7); transform: scale(.90) translateX(-24px); }
.hero-v9 .slide-copy { padding: 0 !important; align-self: center; position: relative; z-index: 5; }
.hero-v9 .slide-copy h1 { font-size: clamp(34px, 4.8vw, 62px); max-width: 720px; line-height: .98; letter-spacing: -.07em; }
.hero-v9 .slide-copy h1 em { color: var(--cyan); font-style: normal; text-shadow: 0 0 34px rgba(0,195,200,.28); }
.hero-v9 .slide-copy p { max-width: 575px; font-size: 15px; color: rgba(255,255,255,.64); line-height: 1.75; }
.hero-v9 .slide-visual { padding: 0 !important; align-self: center; min-width: 0; position: relative; z-index: 3; }
.hero-v9 .dashboard-hero-wrap { perspective: 1600px; }
.hero-v9 .dashboard-hero-wrap .advanced-dashboard { transform: rotateY(-8deg) rotateX(3deg) translateZ(0); transform-origin: center; box-shadow: 0 44px 110px rgba(0,0,0,.48); }
.hero-v9.portal-switching .dashboard-hero-wrap .advanced-dashboard { animation: portalPass .72s var(--ease) both; }
.portal-vortex { position: absolute; inset: auto 8% 8% auto; width: 480px; height: 480px; z-index: 1; pointer-events: none; opacity: .45; filter: blur(.1px); }
.portal-vortex span { position:absolute; inset: 0; border-radius: 50%; border: 1px solid rgba(0,195,200,.18); box-shadow: inset 0 0 40px rgba(0,195,200,.18), 0 0 42px rgba(0,195,200,.10); animation: portalSpin 14s linear infinite; }
.portal-vortex span:nth-child(2) { inset: 46px; border-color: rgba(230,179,30,.18); animation-direction: reverse; animation-duration: 18s; }
.portal-vortex span:nth-child(3) { inset: 98px; border-color: rgba(255,255,255,.10); animation-duration: 11s; }
.hero-v9.portal-switching .portal-vortex { animation: vortexPulse .72s var(--ease) both; }
.hero-controls { border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.035); border-radius: 999px; padding: 8px 12px; backdrop-filter: blur(18px); width: max-content; margin: 0 auto 28px; }
.slider-arrow, .slider-dot { transition: transform .2s var(--spring), background .2s, border-color .2s; }
.slider-arrow:hover { transform: translateY(-1px) scale(1.04); }
.slider-dot.active { background: var(--gold); box-shadow: 0 0 18px rgba(230,179,30,.45); }
@keyframes portalSpin { to { transform: rotate(360deg); } }
@keyframes vortexPulse { 0%{transform:scale(.96);opacity:.32} 45%{transform:scale(1.08);opacity:.72} 100%{transform:scale(1);opacity:.45} }
@keyframes portalPass { 0%{transform:rotateY(-8deg) rotateX(3deg) scale(.98);filter:brightness(.9)} 45%{transform:rotateY(-2deg) rotateX(1deg) scale(1.025);filter:brightness(1.18)} 100%{transform:rotateY(-8deg) rotateX(3deg) scale(1);filter:brightness(1)} }

/* Solution marquee */
.solution-slider-section { background: #fff; border-block: 1px solid var(--line); overflow:hidden; }
.solution-marquee { overflow: hidden; mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); }
.solution-marquee-track { display: flex; gap: 12px; padding: 16px 0; width: max-content; animation: solutionFlow 34s linear infinite; }
.solution-marquee-track span { display:inline-flex; align-items:center; gap:8px; white-space:nowrap; border:1px solid var(--line); background:#f8fafc; border-radius:999px; padding:8px 14px; font-size:12px; font-weight:750; color:var(--ink-2); box-shadow:var(--sh-xs); }
.solution-marquee-track span::before { content:''; width:7px; height:7px; border-radius:50%; background:var(--cyan); box-shadow:0 0 12px var(--cyan-glow); }
@keyframes solutionFlow { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Broken process text fix + upgraded method layout */
.method-section { background: linear-gradient(180deg,#fff,#f8fafc); }
.method-grid { align-items: start; }
.method-copy { position: sticky; top: 118px; }
.method-copy .btn { margin-top: 22px; }
.process-list, .process-list-v9 { display: grid; grid-template-columns: 1fr; gap: 12px; width: 100%; }
.process-list div { grid-template-columns: 36px minmax(0,1fr); }
.process-list div::before { grid-row: 1 / span 2; grid-column: 1; }
.process-list div > span { grid-column: 2; grid-row: 1; }
.process-list div > p { grid-column: 2; grid-row: 2; min-width:0; }
.process-step-v9 { display:grid; grid-template-columns: 46px minmax(0,1fr); gap: 16px; align-items:start; background:#fff; border:1px solid var(--line); border-radius:18px; padding:18px; box-shadow:var(--sh-sm); transition: transform .22s var(--spring), border-color .22s, box-shadow .22s; }
.process-step-v9:hover { transform: translateY(-3px); border-color: var(--line-cyan); box-shadow: var(--sh-md); }
.process-step-v9 b { display:grid; place-items:center; width:38px; height:38px; border-radius:14px; background:var(--cyan-dim); color:var(--cyan-mid); font:700 12px 'Fira Code',monospace; }
.process-step-v9 span { display:block; color:var(--ink); font-size:13px; font-weight:850; text-transform:uppercase; letter-spacing:.08em; }
.process-step-v9 p { margin-top:5px; color:var(--muted); font-size:13px; line-height:1.65; }

/* Stronger package categorisation */
.package-category-tabs { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:30px; }
.package-category-tabs a { border:1px solid var(--line); background:#fff; border-radius:999px; padding:10px 15px; box-shadow:var(--sh-xs); color:var(--ink-2); font-size:12px; font-weight:800; }
.package-category-tabs a:hover { color:var(--cyan-mid); border-color:var(--line-cyan); background:var(--cyan-dim); }
.package-category { scroll-margin-top: 96px; }
.pricing-card { position: relative; overflow:hidden; }
.pricing-card::after { content:''; position:absolute; inset:auto 18px 0 18px; height:3px; background:linear-gradient(90deg,var(--cyan),var(--gold)); border-radius:10px 10px 0 0; opacity:.70; }

/* Professional footer v9 */
.footer-v9 { background: #080e18; color: rgba(255,255,255,.62); position:relative; overflow:hidden; border-top:1px solid rgba(255,255,255,.08); }
.footer-v9::before { content:''; position:absolute; inset:0; pointer-events:none; background: radial-gradient(circle at 8% 12%, rgba(0,195,200,.13), transparent 30%), radial-gradient(circle at 92% 0%, rgba(230,179,30,.10), transparent 28%), linear-gradient(180deg, rgba(255,255,255,.03), transparent 38%); }
.footer-command-v9 { position:relative; border-bottom:1px solid rgba(255,255,255,.09); }
.footer-command-v9-inner { display:flex; justify-content:space-between; align-items:center; gap:34px; padding-top:44px; padding-bottom:44px; }
.footer-command-copy h2 { color:#fff; font-size:clamp(24px,3.2vw,38px); letter-spacing:-.055em; line-height:1.05; margin:13px 0 10px; max-width:740px; }
.footer-command-copy p { color:rgba(255,255,255,.58); max-width:720px; font-size:14px; line-height:1.75; }
.footer-command-actions { display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end; min-width:max-content; }
.footer-outline { background: rgba(255,255,255,.06)!important; color:#fff!important; border-color: rgba(255,255,255,.14)!important; }
.footer-main-v9 { position:relative; padding:44px 0 28px; }
.footer-grid-v9-pro { display:grid; grid-template-columns: 1.45fr .75fr 1fr 1.05fr; gap:32px; align-items:start; }
.footer-company-v9, .footer-contact-v9 { background: rgba(255,255,255,.045); border:1px solid rgba(255,255,255,.09); border-radius: 26px; padding:24px; box-shadow: inset 0 1px 0 rgba(255,255,255,.04); }
.footer-brand-v9 { align-items:center; }
.footer-brand-v9 strong { color:#fff; font-size:15px; }
.footer-brand-v9 small { color: var(--cyan); }
.footer-company-v9 p, .footer-contact-v9 p { color:rgba(255,255,255,.48); font-size:13px; line-height:1.78; margin-top:16px; }
.footer-capabilities-v9 { display:grid; grid-template-columns:repeat(2,1fr); gap:9px; margin-top:20px; }
.footer-capabilities-v9 span { display:block; border:1px solid rgba(255,255,255,.09); background:rgba(255,255,255,.04); border-radius:16px; padding:12px; }
.footer-capabilities-v9 b { display:block; color:var(--cyan); font-size:12px; }
.footer-capabilities-v9 small { display:block; color:rgba(255,255,255,.45); font-size:10px; margin-top:2px; }
.footer-col-v9 h3 { color:#fff; font-size:12px; text-transform:uppercase; letter-spacing:.11em; margin-bottom:15px; }
.footer-col-v9 a { display:block; color:rgba(255,255,255,.50); font-size:13px; margin:10px 0; transition: color .2s, transform .2s; }
.footer-col-v9 a:hover { color: var(--cyan); transform: translateX(4px); }
.footer-bottom-v9 { position:relative; border-top:1px solid rgba(255,255,255,.08); padding:17px 0 20px; }
.footer-bottom-v9-inner { display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap; color:rgba(255,255,255,.38); font-size:11px; }
.footer-bottom-v9 a { color:rgba(255,255,255,.42); display:inline; margin:0; }
.footer-bottom-v9 a:hover { color:var(--gold); }
.footer-live-v9 { display:inline-flex; align-items:center; gap:7px; }
.footer-live-v9 i { width:7px; height:7px; border-radius:50%; background:#10b981; box-shadow:0 0 12px #10b981; }

/* Home dashboard size balance */
.split-grid.reverse .advanced-dashboard { width:100%; max-width:660px; margin-inline:auto; }

@media(max-width:1180px){
  .hero-v9 .hero-slide { grid-template-columns: 1fr; }
  .hero-v9 .dashboard-hero-wrap .advanced-dashboard { transform:none; max-width:860px; margin-inline:auto; }
  .portal-vortex { right:-120px; bottom:80px; }
  .footer-grid-v9-pro { grid-template-columns:1fr 1fr; }
  .footer-command-v9-inner { flex-direction:column; align-items:flex-start; }
  .footer-command-actions { justify-content:flex-start; }
  .method-copy { position:static; }
}
@media(max-width:860px){
  .container { width:min(100% - 32px, 1180px); }
  .announcement { display:none; }
  .nav-toggle { display:flex; }
  .nav-links { position:fixed; left:16px; right:16px; top:74px; display:grid; gap:8px; background:rgba(255,255,255,.96); border:1px solid var(--line); border-radius:22px; padding:14px; box-shadow:var(--sh-xl); opacity:0; pointer-events:none; transform:translateY(-8px); transition:.22s var(--ease); z-index:400; }
  .nav-links.open { opacity:1; pointer-events:auto; transform:none; }
  .nav-links a { padding:12px 14px; }
  .nav-cta { justify-content:center; }
  .hero-v9 { min-height:auto; }
  .hero-v9 .hero-slide { padding:44px 18px 34px; }
  .hero-v9 .slide-copy h1 { font-size:34px; }
  .hero-v9 .slide-copy p { font-size:14px; }
  .hero-v9 .dashboard-hero-wrap { display:none; }
  .portal-vortex { width:300px; height:300px; right:-80px; bottom:10px; }
  .hero-controls { margin-bottom:18px; }
  .split-grid, .method-grid { grid-template-columns:1fr; gap:28px; }
  .footer-grid-v9-pro { grid-template-columns:1fr; }
  .footer-command-v9-inner, .footer-main-v9 { padding-left:0; padding-right:0; }
  .footer-command-actions { min-width:0; }
  .footer-command-actions .btn { width:100%; }
}
@media(max-width:640px){
  .hero-v9 .slide-actions { flex-direction:column; align-items:stretch; }
  .hero-v9 .slide-actions .btn { width:100%; }
  .hero-metrics { grid-template-columns:1fr; }
  .process-step-v9 { grid-template-columns: 40px minmax(0,1fr); padding:15px; }
  .package-category-tabs a { width:100%; justify-content:center; }
  .footer-capabilities-v9 { grid-template-columns:1fr 1fr; }
  .footer-bottom-v9-inner { flex-direction:column; align-items:flex-start; }
}

/* ================================================================
   V11 — Portal Hero Animation + Inline Random Package Slider
   Inspired by uploaded portal concept, integrated into current design.
================================================================ */
.hero-v11{
  --portal-color: rgba(0,195,200,.86);
  min-height: min(720px, calc(100vh - 80px));
}
.hero-v11 .hero-slider{overflow:hidden;}
.hero-v11 .hero-slides{transition:transform .92s cubic-bezier(.68,0,.18,1);}
.hero-v11 .hero-slide{backface-visibility:hidden;}
.hero-v11 .portal-transition-ring{
  position:absolute;
  left:50%;
  top:50%;
  width:0;
  height:0;
  border-radius:50%;
  transform:translate(-50%,-50%) rotate(0deg) scale(.1);
  border:2px solid rgba(255,255,255,.92);
  box-shadow:
    0 0 30px 8px var(--portal-color),
    0 0 90px 18px rgba(0,195,200,.26),
    inset 0 0 32px 8px var(--portal-color),
    inset 0 0 90px rgba(230,179,30,.18);
  opacity:0;
  z-index:8;
  pointer-events:none;
  mix-blend-mode:screen;
}
.hero-v11 .portal-transition-flash{
  position:absolute;
  inset:-2px;
  opacity:0;
  pointer-events:none;
  z-index:7;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.32), rgba(0,195,200,.18) 16%, transparent 42%),
    linear-gradient(90deg, transparent, rgba(255,255,255,.16), transparent);
}
.hero-v11.portal-opening .portal-transition-ring{
  opacity:1;
  width:18vw;
  height:18vw;
  transform:translate(-50%,-50%) rotate(180deg) scale(1);
  transition:all .48s cubic-bezier(.2,.85,.2,1);
}
.hero-v11.portal-opening .portal-transition-flash{
  animation:portalSoftFlash .48s ease both;
}
.hero-v11.portal-opening .hero-slide.active .slide-copy{
  animation:portalSuckCopy .52s cubic-bezier(.62,0,.18,1) both;
}
.hero-v11.portal-opening .hero-slide.active .dashboard-hero-wrap{
  animation:portalSuckVisual .52s cubic-bezier(.62,0,.18,1) both;
}
.hero-v11.portal-expanding .portal-transition-ring{
  opacity:1;
  width:260vw;
  height:260vw;
  transform:translate(-50%,-50%) rotate(760deg) scale(1);
  transition:all 1.05s cubic-bezier(.72,0,.22,1);
}
.hero-v11.portal-expanding .portal-transition-flash{
  animation:portalFullFlash 1.05s ease both;
}
.hero-v11.portal-expanding .hero-slide.active .slide-copy,
.hero-v11.portal-expanding .hero-slide.active .dashboard-hero-wrap{
  animation:portalArrive .76s cubic-bezier(.18,.9,.22,1) both;
}
.hero-v11.portal-switching .portal-vortex{animation:vortexPulse .9s var(--ease) both;}
@keyframes portalSuckCopy{
  0%{opacity:1;transform:translateY(0) scale(1);filter:none;}
  100%{opacity:.18;transform:translateY(18px) scale(.86);filter:blur(14px);}
}
@keyframes portalSuckVisual{
  0%{opacity:1;transform:translateZ(0) scale(1);filter:none;}
  100%{opacity:.25;transform:translateZ(-220px) scale(.82);filter:blur(12px) brightness(1.25);}
}
@keyframes portalArrive{
  0%{opacity:0;transform:translateY(-18px) scale(1.06);filter:blur(14px) brightness(1.3);}
  100%{opacity:1;transform:translateY(0) scale(1);filter:none;}
}
@keyframes portalSoftFlash{0%{opacity:0}45%{opacity:.55}100%{opacity:.08}}
@keyframes portalFullFlash{0%{opacity:.12}40%{opacity:.42}100%{opacity:0}}

/* Inline random package slider on homepage */
.package-inline-shell{
  position:relative;
  margin-top:-4px;
  margin-bottom:34px;
  padding:18px;
  border:1px solid var(--line);
  border-radius:28px;
  background:
    radial-gradient(circle at 8% 30%, rgba(0,195,200,.10), transparent 30%),
    radial-gradient(circle at 88% 0%, rgba(230,179,30,.10), transparent 28%),
    #fff;
  box-shadow:var(--sh-sm);
  overflow:hidden;
}
.package-inline-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  padding:2px 4px 16px;
}
.package-inline-head span{
  color:var(--ink);
  font-size:13px;
  font-weight:850;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.package-inline-head small{
  color:var(--muted);
  font-size:12px;
  line-height:1.55;
  max-width:580px;
  text-align:right;
}
.package-inline-slider{
  overflow:hidden;
  mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.package-inline-track{
  display:flex;
  gap:14px;
  width:max-content;
  animation:packageInlineFlow 42s linear infinite;
  will-change:transform;
}
.package-inline-slider:hover .package-inline-track{animation-play-state:paused;}
.package-inline-card{
  width:260px;
  min-height:128px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:8px;
  border:1px solid rgba(15,23,42,.10);
  border-radius:22px;
  padding:18px;
  background:rgba(255,255,255,.82);
  box-shadow:0 18px 46px rgba(15,23,42,.08);
  color:var(--ink);
  transform:translateZ(0);
  transition:transform .24s var(--spring), border-color .24s, box-shadow .24s;
}
.package-inline-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,195,200,.34);
  box-shadow:0 24px 58px rgba(0,195,200,.13);
}
.package-inline-card small{
  color:var(--cyan-mid);
  font-size:10px;
  font-weight:850;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.package-inline-card strong{
  font-size:16px;
  line-height:1.2;
  letter-spacing:-.035em;
}
.package-inline-card span{
  align-self:flex-start;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(0,195,200,.12), rgba(230,179,30,.16));
  border:1px solid rgba(0,195,200,.18);
  padding:7px 10px;
  color:#0f172a;
  font-size:12px;
  font-weight:850;
}
@keyframes packageInlineFlow{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

@media(max-width:860px){
  .hero-v11 .portal-transition-ring{display:none;}
  .hero-v11 .portal-transition-flash{display:none;}
  .package-inline-head{align-items:flex-start;flex-direction:column;}
  .package-inline-head small{text-align:left;}
  .package-inline-shell{border-radius:22px;padding:14px;margin-bottom:24px;}
  .package-inline-card{width:230px;min-height:122px;padding:16px;}
}
@media(prefers-reduced-motion:reduce){
  .hero-v11 .portal-transition-ring,
  .hero-v11 .portal-transition-flash,
  .package-inline-track{animation:none!important;transition:none!important;}
}

/* ================================================================
   V12 — Homepage Packages Only Sliding + CMS Sliders + Footer Consistency
================================================================ */
.package-category-list{display:none!important;}
.footer-v9{
  background:
    radial-gradient(circle at 12% 0%, rgba(0,195,200,.16), transparent 34%),
    radial-gradient(circle at 86% 0%, rgba(230,179,30,.12), transparent 32%),
    linear-gradient(180deg,#07111f 0%,#080e18 46%,#050914 100%)!important;
  color:rgba(255,255,255,.66)!important;
}
.footer-v9 .container{width:min(100% - 44px,1180px);}
.footer-command-v9{padding:0;border-bottom:1px solid rgba(255,255,255,.08)!important;}
.footer-command-v9-inner{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  gap:28px!important;
  align-items:center!important;
  padding-top:42px!important;
  padding-bottom:42px!important;
}
.footer-command-copy h2{font-size:clamp(24px,3vw,36px)!important;line-height:1.08!important;max-width:780px;}
.footer-command-copy p{font-size:14px!important;line-height:1.75!important;max-width:760px;}
.footer-command-actions{min-width:0!important;display:flex!important;gap:12px!important;justify-content:flex-end!important;}
.footer-main-v9{padding:34px 0 26px!important;}
.footer-grid-v9-pro{
  display:grid!important;
  grid-template-columns:1.35fr .82fr 1fr 1.04fr!important;
  gap:16px!important;
  align-items:stretch!important;
}
.footer-company-v9,
.footer-col-v9,
.footer-contact-v9{
  min-height:100%;
  background:rgba(255,255,255,.045)!important;
  border:1px solid rgba(255,255,255,.09)!important;
  border-radius:24px!important;
  padding:22px!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 24px 70px rgba(0,0,0,.18)!important;
}
.footer-col-v9 h3,.footer-contact-v9 h3{margin:0 0 16px!important;color:#fff!important;font-size:12px!important;letter-spacing:.12em!important;text-transform:uppercase!important;}
.footer-col-v9 a,.footer-contact-v9 a{display:block!important;margin:10px 0!important;color:rgba(255,255,255,.58)!important;font-size:13px!important;line-height:1.45!important;}
.footer-col-v9 a:hover,.footer-contact-v9 a:hover{color:var(--cyan)!important;transform:translateX(4px)!important;}
.footer-company-v9 p,.footer-contact-v9 p{font-size:13px!important;line-height:1.75!important;color:rgba(255,255,255,.50)!important;}
.footer-capabilities-v9{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:9px!important;}
.footer-capabilities-v9 span{min-width:0!important;}
.footer-bottom-v9{padding:16px 0 18px!important;border-top:1px solid rgba(255,255,255,.08)!important;}
.footer-bottom-v9-inner{display:flex!important;justify-content:space-between!important;align-items:center!important;gap:14px!important;flex-wrap:wrap!important;}
.footer-brand-v9 img{width:48px!important;height:48px!important;border-radius:50%!important;}
.footer-brand-v9 strong{display:block;line-height:1.18;}
.footer-brand-v9 small{display:block;margin-top:3px;}

.admin-nav a[href$="/admin/sliders"] .nav-icon{color:var(--cyan-mid);}

@media(max-width:1080px){
  .footer-command-v9-inner{grid-template-columns:1fr!important;align-items:flex-start!important;}
  .footer-command-actions{justify-content:flex-start!important;}
  .footer-grid-v9-pro{grid-template-columns:1fr 1fr!important;}
}
@media(max-width:680px){
  .footer-v9 .container{width:min(100% - 30px,1180px);}
  .footer-command-actions{width:100%;flex-direction:column!important;}
  .footer-command-actions .btn{width:100%;justify-content:center;}
  .footer-grid-v9-pro{grid-template-columns:1fr!important;}
  .footer-bottom-v9-inner{align-items:flex-start!important;flex-direction:column!important;}
}

/* V13 package builder improvements */
.package-meta,.package-info-strip{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0;color:var(--muted);font-size:.88rem}.package-meta b{color:var(--ink);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.package-info-strip span{border:1px solid var(--line);background:rgba(255,255,255,.72);border-radius:999px;padding:6px 10px}.package-details{border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin:10px 0;background:rgba(255,255,255,.72)}.package-details summary{font-weight:800;color:var(--ink);cursor:pointer}.package-details ul{margin:8px 0 0 18px;color:var(--muted)}.package-wa{display:inline-flex;margin-top:10px;font-weight:800;color:var(--cyan)}

/* ================================================================
   V15 — Images, category anchors and package card polish
   ================================================================ */
.package-category{scroll-margin-top:120px}.package-category-tabs{position:sticky;top:92px;z-index:5;background:rgba(255,255,255,.78);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:22px;padding:10px;box-shadow:var(--sh-xs)}.package-category-tabs a{display:inline-flex;align-items:center}.package-category-tabs a:focus{outline:3px solid rgba(0,195,200,.22);outline-offset:3px}.package-image,.package-card-image,.project-card-image,.solution-card-image,.case-card-image,.solution-page-image{width:100%;border-radius:18px;overflow:hidden;margin-bottom:16px;border:1px solid var(--line);background:linear-gradient(135deg,var(--cyan-dim),rgba(230,179,30,.08))}.package-image img,.package-card-image img,.project-card-image img,.solution-card-image img,.case-card-image img,.solution-page-image img{display:block;width:100%;height:180px;object-fit:cover}.pricing-card .package-image{margin-top:-4px}.case-card-image img,.project-card-image img{height:170px}.solution-card-image img,.solution-page-image img{height:150px}.package-card-image img{height:155px}.pricing-card{display:flex;flex-direction:column}.pricing-card .btn{margin-top:auto}.project-card,.solution-card,.case-card{overflow:hidden}.project-card-image,.solution-card-image{margin:-4px 0 15px}.solution-page-image,.case-card-image{margin-bottom:18px}.package-info-strip{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}.package-info-strip span{font-size:11px;font-weight:800;border:1px solid var(--line);border-radius:999px;padding:6px 9px;background:#fff;color:var(--ink-2)}
@media(max-width:860px){.package-category-tabs{position:relative;top:auto}.package-category-tabs a{width:100%}.package-image img,.package-card-image img,.project-card-image img,.solution-card-image img,.case-card-image img,.solution-page-image img{height:150px}}

/* V16 — ensure package category cards remain visible after category click */
.package-category-list{display:grid!important;gap:34px!important;}

/* ================================================================
   V17 — Package category alignment and complete visibility
   ================================================================ */
.package-category-list{
  display:grid!important;
  gap:clamp(26px,3vw,44px)!important;
}
.package-category{
  display:block!important;
  position:relative;
  padding:clamp(18px,2vw,28px);
  border:1px solid var(--line);
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,251,252,.96));
  box-shadow:var(--sh-xs);
  overflow:hidden;
}
.package-category::before{
  content:'';
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg,var(--cyan),var(--gold));
  opacity:.85;
}
.package-category-head{
  align-items:flex-start!important;
  margin-bottom:18px!important;
  padding-left:2px;
}
.package-category-head span{
  font-size:clamp(20px,2.1vw,28px)!important;
  line-height:1.05!important;
}
.package-category-head p{
  font-size:14px!important;
  line-height:1.65!important;
  max-width:760px!important;
}
.package-category .card-grid.three{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  align-items:stretch!important;
  gap:18px!important;
}
.pricing-card{
  display:flex!important;
  flex-direction:column!important;
  min-height:100%!important;
  padding:clamp(18px,2vw,24px)!important;
}
.pricing-card h3{
  min-height:unset!important;
  font-size:clamp(18px,1.45vw,22px)!important;
  line-height:1.18!important;
}
.pricing-card p{
  min-height:72px;
  line-height:1.65!important;
}
.pricing-card .check-list{
  margin-top:10px;
}
.pricing-card .btn{
  margin-top:auto!important;
}
.package-category-tabs{
  margin-bottom:24px!important;
}
.package-category-tabs a.active-tab,
.package-category-tabs a[aria-current="true"]{
  background:var(--cyan)!important;
  color:white!important;
  border-color:transparent!important;
  box-shadow:0 14px 34px rgba(0,195,200,.22)!important;
}
@media(max-width:1100px){
  .package-category .card-grid.three{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media(max-width:680px){
  .package-category{padding:18px;border-radius:22px;}
  .package-category .card-grid.three{grid-template-columns:1fr!important;}
  .pricing-card p{min-height:unset;}
}

/* ================================================================
   V18 — Receipt number compactness + package visibility/alignment
   ================================================================ */
.jst-receipt-document .receipt-title-row{
  align-items:center!important;
  gap:clamp(18px,3vw,44px)!important;
}
.jst-receipt-document .receipt-title-row h2{
  font-size:clamp(28px,4vw,52px)!important;
  letter-spacing:.06em!important;
  line-height:1!important;
}
.jst-receipt-document .receipt-no{
  display:flex!important;
  align-items:baseline!important;
  justify-content:flex-end!important;
  gap:10px!important;
  min-width:0!important;
  white-space:nowrap!important;
}
.jst-receipt-document .receipt-no span{
  font-size:clamp(18px,2.2vw,34px)!important;
  font-weight:900!important;
  color:var(--ink)!important;
}
.jst-receipt-document .receipt-no strong{
  font-size:clamp(18px,2.3vw,34px)!important;
  letter-spacing:.08em!important;
  color:var(--gold)!important;
  text-shadow:none!important;
  line-height:1!important;
}
.jst-receipt-document .receipt-check i.checked::after{
  content:'✓';
  display:grid;
  place-items:center;
  width:100%;
  height:100%;
  font-size:13px;
  font-weight:900;
  color:var(--cyan-mid);
}
.jst-receipt-document .receipt-balance b{
  color:var(--ink)!important;
}

.packages-section{overflow:visible!important;}
.package-category-list{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:clamp(30px,4vw,56px)!important;
  align-items:start!important;
}
.package-category{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  min-height:auto!important;
  scroll-margin-top:125px!important;
}
.package-category[hidden], .package-category.is-hidden{display:block!important;}
.package-category-tabs{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  overflow-x:auto!important;
  scrollbar-width:thin;
}
.package-category-tabs a{
  flex:0 0 auto!important;
  display:inline-flex!important;
  gap:8px!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:42px!important;
}
.package-category-tabs a small{
  display:inline-block;
  color:inherit;
  opacity:.72;
  font-size:11px;
  font-weight:800;
}
.package-grid-pro{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:18px!important;
  align-items:stretch!important;
}
.package-pro-card{
  min-width:0!important;
  height:100%!important;
  display:flex!important;
  flex-direction:column!important;
  border-radius:24px!important;
}
.package-pro-card .price-line{
  color:var(--cyan-mid)!important;
  font-size:clamp(20px,1.6vw,26px)!important;
}
.package-pro-card p{
  min-height:auto!important;
}
.package-pro-card .check-list{
  margin-bottom:14px!important;
}
.package-pro-card .package-details{
  border:1px solid var(--line)!important;
  border-radius:14px!important;
  padding:10px 12px!important;
  margin-top:8px!important;
  background:#fff!important;
}
.package-pro-card .package-details summary{
  cursor:pointer;
  font-weight:900;
  font-size:12px;
  color:var(--ink);
}
.ownership-mini{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  background:linear-gradient(135deg,rgba(0,195,200,.10),rgba(230,179,30,.10));
  color:var(--ink-2);
  font-size:12px;
  line-height:1.55;
  font-weight:700;
}
.category-cta{
  border:1px solid var(--line-cyan)!important;
  background:var(--cyan-dim)!important;
  color:var(--cyan-mid)!important;
  border-radius:999px!important;
  padding:10px 14px!important;
  font-weight:900!important;
  white-space:nowrap!important;
}
.default-preview{border-style:dashed!important;}
.default-preview::before{opacity:.35!important;}
@media(max-width:1100px){.package-grid-pro{grid-template-columns:repeat(2,minmax(0,1fr))!important;}}
@media(max-width:720px){
  .package-grid-pro{grid-template-columns:1fr!important;}
  .package-category-tabs{position:relative!important;top:auto!important;border-radius:18px!important;}
  .package-category-tabs a{width:auto!important;min-width:max-content!important;}
  .jst-receipt-document .receipt-title-row{grid-template-columns:1fr!important;text-align:left!important;}
  .jst-receipt-document .receipt-no{justify-content:flex-start!important;}
}

/* V21 premium footer waves + team section */
.footer-v9{position:relative;overflow:hidden;margin-top:70px;border-radius:42px 42px 0 0;background:#081421!important;}
.footer-v9::before{content:"";position:absolute;left:0;right:0;top:-1px;height:92px;background:radial-gradient(90% 120% at 12% 0%,rgba(0,195,200,.24),transparent 55%),radial-gradient(70% 120% at 88% 0%,rgba(230,179,30,.18),transparent 55%);clip-path:ellipse(72% 66% at 50% 0%);z-index:1;pointer-events:none;}
.footer-v9::after{content:"";position:absolute;left:-8%;right:-8%;top:0;height:56px;background:#fff;clip-path:polygon(0 0,100% 0,100% 32%,82% 52%,64% 34%,48% 60%,30% 38%,12% 58%,0 42%);z-index:2;pointer-events:none;}
.footer-command-v9,.footer-main-v9,.footer-bottom-v9{position:relative;z-index:3;}
.footer-command-v9{padding-top:110px!important;}
.team-section{position:relative;overflow:hidden;}
.team-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;align-items:stretch;}
.team-card{background:#fff;border:1px solid var(--line,#e5e7eb);border-radius:28px;overflow:hidden;box-shadow:0 18px 55px rgba(15,23,42,.08);display:flex;flex-direction:column;min-height:100%;}
.team-photo{aspect-ratio:4/3;background:linear-gradient(135deg,rgba(0,195,200,.12),rgba(230,179,30,.12));overflow:hidden;}
.team-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:.35s ease;}
.team-card:hover .team-photo img{transform:scale(1.05);}
.team-info{padding:18px;display:grid;gap:6px;}
.team-info small{color:var(--cyan-mid,#00aeb2);font-size:11px;text-transform:uppercase;letter-spacing:.13em;font-weight:900;}
.team-info h3{margin:0;font-size:20px;line-height:1.1;letter-spacing:-.03em;color:var(--ink,#111827);}
.team-position{margin:0!important;color:var(--gold,#e6b31e)!important;font-weight:900!important;}
.team-info p:not(.team-position){margin:2px 0 0;color:var(--muted,#64748b);font-size:14px;line-height:1.55;}
@media(max-width:1050px){.team-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.footer-v9{border-radius:30px 30px 0 0;}}
@media(max-width:640px){.team-grid{grid-template-columns:1fr}.footer-command-v9{padding-top:82px!important}.footer-v9::before{height:70px}.footer-v9::after{height:42px}}
.project-gallery-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.project-gallery-grid img{width:100%;height:260px;object-fit:cover;border-radius:24px;border:1px solid var(--line,#e5e7eb);box-shadow:0 18px 55px rgba(15,23,42,.08);background:#fff;}
.project-gallery-main{grid-column:span 2;height:360px!important;}
.gallery-preview-admin{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin:10px 0;}
.gallery-preview-admin img{width:100%;height:90px;object-fit:cover;border-radius:14px;border:1px solid #e5e7eb;}
@media(max-width:900px){.project-gallery-grid{grid-template-columns:1fr 1fr}.project-gallery-main{grid-column:span 2}}
@media(max-width:600px){.project-gallery-grid{grid-template-columns:1fr}.project-gallery-main{grid-column:auto;height:260px!important}}

/* V22 dynamic client logo slider */
.client-logo-section{background:linear-gradient(180deg,#fff,#f7fbfc)}.client-logo-marquee{overflow:hidden;border:1px solid rgba(0,195,200,.18);border-radius:30px;background:rgba(255,255,255,.86);box-shadow:0 24px 70px rgba(15,23,42,.06);position:relative}.client-logo-marquee:before,.client-logo-marquee:after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}.client-logo-marquee:before{left:0;background:linear-gradient(90deg,#fff,transparent)}.client-logo-marquee:after{right:0;background:linear-gradient(270deg,#fff,transparent)}.client-logo-track{display:flex;gap:16px;width:max-content;animation:client-logo-slide 34s linear infinite;padding:18px}.client-logo-marquee:hover .client-logo-track{animation-play-state:paused}.client-logo-card{width:210px;min-height:116px;border-radius:24px;border:1px solid #e5eef2;background:linear-gradient(135deg,#fff,#f8fdff);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:16px;box-shadow:0 14px 34px rgba(15,23,42,.045);transition:.25s ease}.client-logo-card:hover{transform:translateY(-4px);box-shadow:0 22px 48px rgba(0,195,200,.12)}.client-logo-card span{width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,#00c3c8,#e6b31e);display:grid;place-items:center;color:#fff;font-weight:900;overflow:hidden;margin-bottom:9px}.client-logo-card img{width:100%;height:100%;object-fit:cover}.client-logo-card strong{font-size:14px;color:#0f172a}.client-logo-card small{color:#64748b;font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:10px}@keyframes client-logo-slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}@media(max-width:640px){.client-logo-card{width:170px}.client-logo-track{animation-duration:26s}.client-logo-marquee:before,.client-logo-marquee:after{width:40px}}

/* V25 — compact animated method orbit: one process stage at a time */
.process-orbit{width:100%;min-width:0;}
.process-orbit-shell{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:32px;background:linear-gradient(145deg,#fff,#f7fbfc);box-shadow:0 26px 70px rgba(15,23,42,.08);padding:22px;min-height:310px;display:grid;grid-template-rows:auto 1fr auto;}
.process-orbit-shell::before{content:"";position:absolute;right:-80px;top:-80px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(0,195,200,.18),transparent 65%);animation:orbitGlow 4.5s ease-in-out infinite;}
.process-orbit-shell::after{content:"";position:absolute;left:24px;top:78px;bottom:58px;width:2px;background:linear-gradient(180deg,rgba(0,195,200,.0),rgba(0,195,200,.42),rgba(230,179,30,.38),rgba(0,195,200,.0));}
.process-orbit-topline{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;}
.process-orbit-topline span{display:inline-flex;align-items:center;gap:8px;color:var(--cyan-mid);font-size:12px;font-weight:900;letter-spacing:.11em;text-transform:uppercase;}
.process-orbit-topline span::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 15px rgba(230,179,30,.5);}
.process-orbit-topline small{color:var(--muted);font-size:12px;font-weight:750;}
.process-orbit-window{position:relative;z-index:2;min-height:190px;}
.process-orbit-card{position:absolute;inset:0;display:grid;grid-template-columns:58px minmax(0,1fr);gap:18px;align-items:start;border:1px solid var(--line);border-radius:26px;background:rgba(255,255,255,.9);box-shadow:var(--sh-sm);padding:28px;opacity:0;transform:translateY(38px) scale(.985);filter:blur(3px);pointer-events:none;transition:opacity .55s var(--ease),transform .65s var(--spring),filter .55s ease;}
.process-orbit-card.active{opacity:1;transform:translateY(0) scale(1);filter:blur(0);pointer-events:auto;}
.process-orbit-card.leaving{opacity:0;transform:translateY(-34px) scale(.985);filter:blur(4px);}
.process-orbit-card b{display:grid;place-items:center;width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,var(--cyan-dim),rgba(230,179,30,.14));border:1px solid var(--line-cyan);color:var(--cyan-mid);font:900 13px 'Fira Code',monospace;box-shadow:0 10px 28px rgba(0,195,200,.12);}
.process-orbit-card span{display:block;color:var(--ink);font-size:clamp(16px,1.5vw,22px);font-weight:900;letter-spacing:.08em;text-transform:uppercase;line-height:1.15;}
.process-orbit-card p{max-width:540px;margin:14px 0 0;color:var(--muted);font-size:15px;line-height:1.75;}
.process-orbit-dots{position:relative;z-index:2;display:flex;gap:9px;margin-top:18px;}
.process-orbit-dots i{width:9px;height:9px;border-radius:999px;background:#dbe7ed;transition:width .3s var(--spring),background .3s,box-shadow .3s;}
.process-orbit-dots i.active{width:32px;background:linear-gradient(90deg,var(--cyan),var(--gold));box-shadow:0 0 18px rgba(0,195,200,.28);}
@keyframes orbitGlow{0%,100%{transform:scale(1);opacity:.65}50%{transform:scale(1.08);opacity:.95}}
@media(max-width:860px){.process-orbit-shell{min-height:290px;padding:18px;border-radius:26px}.process-orbit-card{padding:22px;grid-template-columns:48px minmax(0,1fr)}.process-orbit-card b{width:40px;height:40px}.process-orbit-card p{font-size:14px}.process-orbit-topline{flex-direction:column;align-items:flex-start}}

/* V30 contact service selector */
.quote-form select[name="service_needed"]{
  appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--teal-2) 50%),linear-gradient(135deg,var(--teal-2) 50%,transparent 50%);
  background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;
  background-size:5px 5px,5px 5px;
  background-repeat:no-repeat;
  padding-right:38px;
}
.quote-form [data-service-other-field]{
  animation:serviceOtherIn .22s ease both;
}
@keyframes serviceOtherIn{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}

/* ================================================================
   V58 FRONTEND / REVEAL SAFETY
   Keeps frontend sections visible even if JS/IntersectionObserver fails.
================================================================ */
.reveal,.reveal.show,.section .reveal,.solution-marquee.reveal,.service-card.reveal,.mini-card.reveal,.case-card.reveal,.team-card.reveal,.testimonial-slider.reveal,.cta-card.reveal{opacity:1!important;transform:none!important;visibility:visible!important;}


/* ================================================================
   V66 — Dynamic CMS image display for Services & Packages
   All uploaded images render equally, regardless of original size.
================================================================ */
.service-card-dynamic,
.package-card-dynamic,
.pricing-card,
.package-pro-card {
  display:flex;
  flex-direction:column;
}

.service-card-image,
.service-detail-image,
.package-inline-thumb {
  display:block;
  width:100%;
  overflow:hidden;
  background:
    radial-gradient(circle at 15% 10%, rgba(0,195,200,.18), transparent 32%),
    linear-gradient(135deg, rgba(0,195,200,.10), rgba(230,179,30,.10));
  border:1px solid var(--line);
}

.service-card-image {
  aspect-ratio: 16 / 10;
  border-radius: 18px;
  margin: -4px 0 16px;
}

.service-card-image img,
.service-detail-image img,
.package-inline-thumb img,
.package-image img,
.package-card-image img,
.project-card-image img,
.solution-card-image img,
.case-card-image img,
.solution-page-image img {
  width:100% !important;
  height:100% !important;
  min-height:0 !important;
  max-height:none !important;
  object-fit:cover !important;
  object-position:center center !important;
  display:block;
}

.service-card-dynamic .icon-badge {
  margin-bottom:16px;
}

.service-detail-image {
  aspect-ratio: 16 / 9;
  border-radius: 22px;
  margin: 0 0 18px;
}

.package-image,
.package-card-image,
.project-card-image,
.solution-card-image,
.case-card-image,
.solution-page-image {
  aspect-ratio: 16 / 10;
  min-height:0 !important;
}

.package-image img,
.package-card-image img {
  height:100% !important;
}

.package-inline-card {
  overflow:hidden;
}

.package-inline-thumb {
  aspect-ratio: 16 / 9;
  border-radius: 16px;
  margin-bottom: 6px;
  min-height: 86px;
}

.package-inline-card strong,
.service-card h3,
.pricing-card h3,
.package-card h3 {
  overflow-wrap:anywhere;
}

.service-card p,
.pricing-card p,
.package-card p {
  flex:1;
}

@media(max-width:720px){
  .service-card-image,
  .package-image,
  .package-card-image,
  .project-card-image,
  .solution-card-image,
  .case-card-image,
  .solution-page-image {
    aspect-ratio: 16 / 9;
  }
  .package-inline-thumb{min-height:74px}
}
