/* ============================================================
   ReadyWeb Studio v4 — Premium Gold + Navy Theme
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Playfair+Display:ital,wght@0,600;0,700;0,800;1,600;1,700&display=swap');

/* ── TOKENS ─────────────────────────────────────────────── */
:root {
  --white:#FFFFFF;
  --navy:#0F172A;

  /* Gold accent */
  --gold:       #D97706;
  --gold-dark:  #B45309;
  --gold-light: #FFFBEB;
  --gold-mid:   #FEF3C7;
  --gold-dim:   rgba(217,119,6,.1);
  --gold-border:rgba(217,119,6,.22);

  /* Indigo structural */
  --indigo:      #1E3A8A;
  --indigo-mid:  #1D4ED8;
  --indigo-light:#EFF6FF;
  --indigo-dim:  rgba(29,78,216,.08);

  /* Green success */
  --green:      #059669;
  --green-light:#D1FAE5;
  --green-dim:  rgba(5,150,105,.1);

  /* Text */
  --t0:#0F172A; --t1:#1E293B; --t2:#334155; --t3:#64748B; --t4:#94A3B8;

  /* Backgrounds */
  --bg0:#FFFFFF; --bg1:#FAFBFC; --bg2:#F8FAFC; --bg3:#F1F5F9;

  /* Borders */
  --b0:#E2E8F0; --b1:#CBD5E1;

  /* Shadows */
  --sh-xs:0 1px 3px rgba(0,0,0,.06);
  --sh-sm:0 4px 6px rgba(0,0,0,.05);
  --sh-md:0 10px 25px rgba(0,0,0,.08);
  --sh-lg:0 25px 50px rgba(0,0,0,.10);
  --sh-xl:0 40px 80px rgba(0,0,0,.12);
  --sh-gold:0 8px 24px rgba(217,119,6,.22);

  /* Radius */
  --r-xs:4px; --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:24px; --r-full:9999px;

  /* Spacing */
  --sp-1:.5rem; --sp-2:.75rem; --sp-3:1rem; --sp-4:1.5rem;
  --sp-5:2rem;  --sp-6:3rem;   --sp-7:4rem; --sp-8:6rem;

  /* Type */
  --ff-body:'Plus Jakarta Sans',system-ui,sans-serif;
  --ff-disp:'Playfair Display',Georgia,serif;

  /* Misc */
  --nav-h:70px;
  --ease:cubic-bezier(.4,0,.2,1);
}
/* Final compatibility token aliases */
:root {
  --pink: var(--gold);
  --pink-dark: var(--gold-dark);
  --pink-light: var(--gold-light);
  --pink-mid: var(--gold-mid);
  --pink-border: var(--gold-border);
  --border: var(--b0);
  --t-muted: var(--t3);
  --bg-section: var(--bg2);
  --font-display: var(--ff-disp);
  --sh-pink: var(--sh-gold);
}


/* ── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff-body);background:var(--bg0);color:var(--t0);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit}
ul{list-style:none}

/* ── TYPOGRAPHY ─────────────────────────────────────────── */
h1{font-family:var(--ff-disp);font-size:clamp(2.1rem,5vw,3.6rem);font-weight:700;line-height:1.15;letter-spacing:-.02em;color:var(--t0)}
h2{font-family:var(--ff-disp);font-size:clamp(1.65rem,3.5vw,2.5rem);font-weight:700;line-height:1.2;letter-spacing:-.015em;color:var(--t0)}
h3{font-size:clamp(1.05rem,2vw,1.3rem);font-weight:700;line-height:1.3;color:var(--t0)}
h4{font-size:1rem;font-weight:700;color:var(--t0)}
p{color:var(--t2);line-height:1.75}

.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:var(--sp-2)}
.eyebrow::before{content:'';display:block;width:18px;height:2px;background:var(--gold);border-radius:2px;flex-shrink:0}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
.section-hd{margin-bottom:var(--sp-6)}
.section-hd.center{text-align:center}
.section-hd p{font-size:1.05rem;margin-top:var(--sp-2);color:var(--t3)}
.section-hd.center p{max-width:560px;margin-left:auto;margin-right:auto}
em.gold-italic{font-style:italic;color:var(--gold)}
.text-gold{color:var(--gold)}
.text-navy{color:var(--indigo)}

/* ── LAYOUT ─────────────────────────────────────────────── */
.container{max-width:1220px;margin:0 auto;padding:0 var(--sp-5)}
.section{padding:var(--sp-8) 0}
.section-sm{padding:var(--sp-6) 0}
.bg-soft{background:var(--bg1)}
.bg-section{background:var(--bg2)}
.bg-gold{background:var(--gold-light)}
.border-top{border-top:1px solid var(--b0)}
.border-bottom{border-bottom:1px solid var(--b0)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3)}
@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.72rem 1.6rem;font-family:var(--ff-body);font-size:.875rem;font-weight:600;border-radius:var(--r-sm);border:none;cursor:pointer;transition:all .22s var(--ease);white-space:nowrap;letter-spacing:.01em}
.btn-primary{background:var(--gold);color:#fff;box-shadow:0 4px 14px rgba(217,119,6,.3)}
.btn-primary:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:var(--sh-gold)}
.btn-navy{background:var(--indigo);color:#fff}
.btn-navy:hover{background:#163267;transform:translateY(-2px);box-shadow:0 8px 24px rgba(30,58,138,.2)}
.btn-outline{background:transparent;color:var(--gold);border:2px solid var(--gold)}
.btn-outline:hover{background:var(--gold);color:#fff}
.btn-outline-navy{background:transparent;color:var(--indigo);border:2px solid var(--indigo)}
.btn-outline-navy:hover{background:var(--indigo);color:#fff}
.btn-ghost{background:transparent;color:var(--t2);border:1.5px solid var(--b0)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:var(--gold-light)}
.btn-sm{padding:.5rem 1.1rem;font-size:.82rem}
.btn-lg{padding:.9rem 2rem;font-size:.95rem}
.btn-xl{padding:1.05rem 2.4rem;font-size:1rem}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none !important;box-shadow:none !important}

/* ── BADGES ─────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:.22rem .7rem;font-size:.68rem;font-weight:700;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
.badge-gold{background:var(--gold-dim);color:var(--gold-dark);border:1px solid var(--gold-border)}
.badge-navy{background:var(--indigo-dim);color:var(--indigo);border:1px solid rgba(29,78,216,.15)}
.badge-green{background:var(--green-dim);color:var(--green);border:1px solid rgba(5,150,105,.2)}
.badge-blue{background:rgba(59,130,246,.08);color:#2563EB;border:1px solid rgba(59,130,246,.18)}

/* ── FORMS ──────────────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:var(--sp-3)}
.form-label{font-size:.78rem;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.05em}
.form-control{background:var(--bg0);border:1.5px solid var(--b0);color:var(--t0);border-radius:var(--r-sm);padding:.72rem 1rem;font-size:.9rem;width:100%;transition:border-color .15s,box-shadow .15s;font-family:var(--ff-body)}
.form-control:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(217,119,6,.1)}
.form-control::placeholder{color:var(--t4)}
select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;padding-right:2.5rem;appearance:none}
textarea.form-control{resize:vertical;min-height:100px}
.form-submit-msg{padding:.8rem 1rem;border-radius:var(--r-sm);font-size:.875rem;font-weight:500;display:none;margin-top:var(--sp-2)}
.form-submit-msg.success{background:var(--green-light);color:#065F46;border:1px solid rgba(5,150,105,.2)}
.form-submit-msg.error{background:#FEE2E2;color:#991B1B;border:1px solid rgba(239,68,68,.2)}

/* ── NAVBAR ─────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--b0);transition:box-shadow .3s}
.navbar.scrolled{box-shadow:var(--sh-md)}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%;position:relative}
.navbar-logo{display:flex;align-items:center;gap:.55rem;font-size:1.05rem;font-weight:800;color:var(--t0);letter-spacing:-.02em;flex-shrink:0}
.logo-mark{width:34px;height:34px;background:var(--indigo);color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-weight:800;font-size:.9rem;flex-shrink:0}
.nav-center{display:flex;align-items:center;gap:.1rem}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:.3rem;padding:.5rem .85rem;font-size:.875rem;font-weight:600;color:var(--t2);border-radius:var(--r-sm);transition:all .15s;background:none;border:none;cursor:pointer;font-family:var(--ff-body)}
.nav-link:hover,.nav-link.active{color:var(--gold);background:var(--gold-dim)}
.nav-arrow{width:14px;height:14px;transition:transform .15s;color:var(--t4);flex-shrink:0}
.nav-item.dd-open .nav-arrow{transform:rotate(180deg);color:var(--gold)}
.nav-cta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}

/* Dropdowns */
.dropdown{position:absolute;top:calc(100% + 8px);background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-lg);border:1px solid var(--b0);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-10px) scale(.97);transition:opacity .22s,transform .22s,visibility .22s;z-index:200;min-width:280px}
.dropdown.dd-visible{opacity:1;visibility:visible;pointer-events:all;transform:translateY(0) scale(1)}
.dd-industries{left:-40px;width:660px;padding:var(--sp-3)}
.dd-industries .dd-cols{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.dd-services{left:-20px;width:320px;padding:var(--sp-3)}
.dd-item{display:flex;align-items:flex-start;gap:.7rem;padding:.65rem .8rem;border-radius:var(--r-sm);transition:background .12s;cursor:pointer;text-decoration:none;color:inherit}
.dd-item:hover{background:var(--gold-light)}
.dd-item:hover .dd-name{color:var(--gold)}
.dd-item:hover .dd-icon{background:var(--gold);color:#fff}
.dd-icon{width:32px;height:32px;background:var(--gold-mid);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);flex-shrink:0;margin-top:1px;transition:all .12s}
.dd-name{font-size:.82rem;font-weight:700;color:var(--t0);transition:color .12s}
.dd-desc{font-size:.72rem;color:var(--t3);margin-top:1px;line-height:1.4}
.dd-footer{padding:var(--sp-2) var(--sp-2) var(--sp-1);border-top:1px solid var(--b0);margin-top:var(--sp-2);display:flex;justify-content:center}
.dd-footer a{font-size:.78rem;font-weight:700;color:var(--gold)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:4.5px;background:none;border:none;padding:.4rem;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:var(--t0);border-radius:2px;transition:all .25s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;top:var(--nav-h);background:#fff;z-index:999;overflow-y:auto;padding:var(--sp-4) var(--sp-3);transform:translateX(100%);transition:transform .3s var(--ease);display:flex;flex-direction:column}
.mobile-menu.mm-open{transform:translateX(0)}
.mob-link{display:flex;align-items:center;justify-content:space-between;padding:.85rem var(--sp-2);border-bottom:1px solid var(--b0);font-weight:600;color:var(--t2);font-size:.95rem}
.mob-link.active{color:var(--gold)}
.mob-acc-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.85rem var(--sp-2);border-bottom:1px solid var(--b0);font-weight:600;color:var(--t2);background:none;border-top:none;border-left:none;border-right:none;font-family:var(--ff-body);font-size:.95rem;cursor:pointer;text-align:left}
.mob-acc-btn.acc-open{color:var(--gold)}
.mob-acc-icon{width:16px;height:16px;transition:transform .15s;flex-shrink:0}
.mob-acc-btn.acc-open .mob-acc-icon{transform:rotate(180deg)}
.mob-sub{max-height:0;overflow:hidden;transition:max-height .3s ease}
.mob-sub.sub-open{max-height:700px}
.mob-sub-link{display:flex;align-items:center;gap:.6rem;padding:.65rem var(--sp-2) .65rem var(--sp-4);font-size:.85rem;color:var(--t2);text-decoration:none;border-bottom:1px solid rgba(0,0,0,.04)}
.mob-sub-link:hover{color:var(--gold)}
.mob-sub-icon{width:26px;height:26px;background:var(--gold-mid);border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);flex-shrink:0}
@media(max-width:960px){.nav-center,.nav-cta{display:none}.hamburger{display:flex}}

/* ── HERO ────────────────────────────────────────────────── */
.hero{min-height:100vh;padding-top:var(--nav-h);display:flex;align-items:center;background:linear-gradient(135deg,#fff 0%,var(--gold-light) 100%);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-20%;right:-10%;width:60%;height:80%;background:radial-gradient(ellipse,rgba(217,119,6,.06) 0%,transparent 70%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6);align-items:center;padding:var(--sp-7) 0;position:relative;z-index:1}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:var(--sp-5);padding:var(--sp-5) 0}}
.hero-tag-pill{display:inline-flex;align-items:center;gap:.5rem;background:var(--gold-mid);color:var(--gold-dark);border:1px solid var(--gold-border);border-radius:var(--r-full);padding:.38rem 1rem;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--sp-4)}
.hero-tag-dot{width:7px;height:7px;background:var(--gold);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.hero-desc{font-size:1.05rem;color:var(--t3);margin-bottom:var(--sp-5);line-height:1.8;max-width:520px}
.hero-actions{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-5)}
.hero-trust{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:var(--sp-6)}
.trust-pill{display:flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--b0);border-radius:var(--r-full);padding:.3rem .8rem;font-size:.72rem;font-weight:600;color:var(--t2);box-shadow:var(--sh-xs)}
.trust-pill svg{color:var(--green);flex-shrink:0}
.hero-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--b0);padding-top:var(--sp-4)}
@media(max-width:640px){.hero-stats-row{grid-template-columns:repeat(2,1fr)}}
.hero-stat{padding:0 var(--sp-3);border-right:1px solid var(--b0)}
.hero-stat:first-child{padding-left:0}
.hero-stat:last-child{border-right:none}
.hero-stat-num{font-family:var(--ff-disp);font-size:1.8rem;font-weight:700;color:var(--gold);display:block;line-height:1}
.hero-stat-lbl{font-size:.7rem;color:var(--t3);margin-top:.3rem;text-transform:uppercase;letter-spacing:.08em}

/* Hero image side */
.hero-visual{position:relative}
.hero-img-wrap{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-xl)}
.hero-img-wrap img{width:100%;height:480px;object-fit:cover;display:block}
.hero-img-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(217,119,6,.1) 0%,transparent 60%)}
.float-card{position:absolute;background:#fff;border-radius:var(--r-md);padding:.8rem 1rem;box-shadow:var(--sh-lg);display:flex;align-items:center;gap:.7rem;z-index:2;animation:float-anim 6s ease-in-out infinite}
@keyframes float-anim{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.float-card-tl{top:6%;left:-8%;animation-delay:0s}
.float-card-br{bottom:8%;right:-8%;animation-delay:2s}
.float-card-tr{top:30%;right:-10%;animation-delay:1s}
.fc-icon-wrap{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fc-gold{background:var(--gold-mid);color:var(--gold-dark)}
.fc-green{background:var(--green-light);color:var(--green)}
.fc-navy{background:var(--indigo-light);color:var(--indigo)}
.fc-title{font-size:.72rem;font-weight:700;color:var(--t0)}
.fc-sub{font-size:.64rem;color:var(--t3)}
.fc-live-dot{width:8px;height:8px;background:var(--green);border-radius:50%;box-shadow:0 0 6px rgba(5,150,105,.6);animation:blink 2s infinite}
@media(max-width:960px){.hero-visual{order:-1}.float-card{display:none}}

/* ── TRUST BAND ──────────────────────────────────────────── */
.trust-band{background:var(--bg1);border-top:1px solid var(--b0);border-bottom:1px solid var(--b0);padding:var(--sp-4) 0}
.trust-band-inner{display:flex;align-items:center;justify-content:center;gap:var(--sp-5);flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:.55rem;font-size:.82rem;font-weight:600;color:var(--t3)}
.trust-item svg{color:var(--gold);flex-shrink:0}

/* ── WEBSITE CARDS ───────────────────────────────────────── */
.websites-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
@media(max-width:1100px){.websites-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.websites-grid{grid-template-columns:1fr}}
.website-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);overflow:hidden;transition:all .22s var(--ease);cursor:pointer;display:flex;flex-direction:column}
.website-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:var(--gold-border)}
.card-preview{position:relative;height:220px;overflow:hidden;background:var(--bg2);flex-shrink:0}
.card-real-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .45s var(--ease)}
.website-card:hover .card-real-img{transform:scale(1.06)}
.card-mockup-base{position:absolute;inset:0;width:100%;height:100%}
.card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,23,42,.8) 0%,rgba(15,23,42,.2) 50%,transparent 100%);display:flex;align-items:flex-end;justify-content:center;padding:var(--sp-3);gap:.4rem;opacity:0;transition:opacity .22s}
.website-card:hover .card-overlay{opacity:1}
.card-top-left{position:absolute;top:.75rem;left:.75rem;display:flex;gap:.3rem;z-index:2}
.card-top-right{position:absolute;top:.75rem;right:.75rem;z-index:2}
.featured-tag{background:var(--gold);color:#fff;font-size:.62rem;font-weight:800;padding:.22rem .6rem;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.08em}
.card-body{padding:var(--sp-4);display:flex;flex-direction:column;flex:1}
.card-cat{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--indigo);margin-bottom:.4rem}
.card-title{font-size:1rem;font-weight:700;color:var(--t0);margin-bottom:.4rem;line-height:1.3}
.card-desc{font-size:.8rem;color:var(--t3);margin-bottom:var(--sp-3);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.card-includes{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:var(--sp-3);padding-bottom:var(--sp-3);border-bottom:1px solid var(--b0)}
.inc-pill{display:inline-flex;align-items:center;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .5rem;border-radius:var(--r-full)}
.inc-fe{background:rgba(59,130,246,.08);color:#2563EB;border:1px solid rgba(59,130,246,.18)}
.inc-be{background:var(--green-dim);color:var(--green);border:1px solid rgba(5,150,105,.18)}
.inc-db{background:rgba(124,58,237,.08);color:#7C3AED;border:1px solid rgba(124,58,237,.18)}
.inc-adm{background:var(--gold-dim);color:var(--gold-dark);border:1px solid var(--gold-border)}
.card-footer{display:flex;align-items:center;justify-content:space-between}
.card-price{display:flex;align-items:baseline;gap:.35rem}
.price-now{font-family:var(--ff-disp);font-size:1.35rem;font-weight:700;color:var(--gold)}
.price-was{font-size:.78rem;color:var(--t4);text-decoration:line-through}
.card-tech{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:var(--sp-3)}
.tech-tag{background:var(--bg2);color:var(--t3);font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:var(--r-xs);border:1px solid var(--b0)}

/* CSS Mockups */
.preview-mockup{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:var(--bg2)}
.mkp-bar{display:flex;align-items:center;gap:5px;padding:7px 10px;background:#fff;border-bottom:1px solid var(--b0);flex-shrink:0}
.mkp-dot{width:7px;height:7px;border-radius:50%}
.mkp-dot-r{background:#FF5F57}.mkp-dot-y{background:#FEBC2E}.mkp-dot-g{background:#28C840}
.mkp-url{flex:1;height:11px;background:var(--bg3);border-radius:3px;margin-left:5px}
.mkp-body{flex:1;padding:8px;display:flex;flex-direction:column;gap:7px;overflow:hidden}
.mkp-hero{flex:1.6;border-radius:6px;display:flex;flex-direction:column;justify-content:center;padding:12px;gap:7px}
.mkp-line{height:7px;border-radius:3px;background:rgba(0,0,0,.1)}
.mkp-btn{height:18px;width:60px;border-radius:3px;background:var(--gold);opacity:.6;margin-top:3px}
.mkp-cards{flex:1;display:flex;gap:6px}
.mkp-card{flex:1;border-radius:5px;background:rgba(0,0,0,.05);border:1px solid rgba(0,0,0,.07)}
.mkp-restaurant .mkp-hero{background:linear-gradient(135deg,rgba(251,191,36,.2),rgba(245,158,11,.15))}
.mkp-realestate .mkp-hero{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(37,99,235,.1))}
.mkp-salon     .mkp-hero{background:linear-gradient(135deg,rgba(217,119,6,.15),rgba(180,83,9,.1))}
.mkp-cleaning  .mkp-hero{background:linear-gradient(135deg,rgba(6,182,212,.15),rgba(8,145,178,.1))}
.mkp-dental    .mkp-hero{background:linear-gradient(135deg,rgba(5,150,105,.12),rgba(4,120,87,.1))}
.mkp-agency    .mkp-hero{background:linear-gradient(135deg,rgba(124,58,237,.12),rgba(109,40,217,.08))}
.mkp-interior  .mkp-hero{background:linear-gradient(135deg,rgba(217,119,6,.15),rgba(180,83,9,.1))}
.mkp-gym       .mkp-hero{background:linear-gradient(135deg,rgba(239,68,68,.15),rgba(220,38,38,.1))}
.mkp-law       .mkp-hero{background:linear-gradient(135deg,rgba(15,23,42,.12),rgba(30,41,59,.08))}
.mkp-default   .mkp-hero{background:linear-gradient(135deg,rgba(217,119,6,.1),rgba(29,78,216,.08))}

/* ── FILTER BAR ──────────────────────────────────────────── */
.filter-bar{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-4)}
.search-wrap{flex:1;min-width:220px;display:flex;align-items:center;gap:.6rem;background:#fff;border:1.5px solid var(--b0);border-radius:var(--r-sm);padding:0 var(--sp-3);transition:border-color .15s}
.search-wrap:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px rgba(217,119,6,.1)}
.search-wrap svg{color:var(--t4);flex-shrink:0}
.search-wrap input{background:none;border:none;color:var(--t0);font-size:.875rem;outline:none;width:100%;padding:.72rem 0;font-family:var(--ff-body)}
.search-wrap input::placeholder{color:var(--t4)}
.filter-sel{background:#fff;border:1.5px solid var(--b0);color:var(--t2);border-radius:var(--r-sm);padding:.72rem 2.2rem .72rem .85rem;font-size:.82rem;font-family:var(--ff-body);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center}
.filter-sel:focus{outline:none;border-color:var(--gold)}
.cat-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:var(--sp-5)}
.cat-chip{padding:.38rem .9rem;border-radius:var(--r-full);font-size:.75rem;font-weight:600;cursor:pointer;border:1.5px solid var(--b0);background:#fff;color:var(--t3);transition:all .15s;font-family:var(--ff-body)}
.cat-chip:hover{border-color:var(--gold);color:var(--gold)}
.cat-chip.active{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 4px 10px rgba(217,119,6,.25)}

/* ── HOW IT WORKS ────────────────────────────────────────── */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}
@media(max-width:900px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.steps-grid{grid-template-columns:1fr}}
.step-card{padding:var(--sp-5) var(--sp-4);background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);transition:all .22s}
.step-card:hover{border-color:var(--gold-border);transform:translateY(-3px);box-shadow:var(--sh-md)}
.step-num{width:48px;height:48px;border-radius:var(--r-full);background:var(--gold-mid);color:var(--gold-dark);font-weight:800;font-size:1rem;font-family:var(--ff-disp);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-3);border:2px solid var(--gold-border)}
.step-title{font-size:.95rem;font-weight:700;color:var(--t0);margin-bottom:.5rem}
.step-desc{font-size:.82rem;color:var(--t3);line-height:1.7}

/* ── WHY CARDS ───────────────────────────────────────────── */
.why-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-5);transition:all .22s}
.why-card:hover{border-color:var(--gold-border);transform:translateY(-3px);box-shadow:var(--sh-md)}
.why-icon{width:48px;height:48px;background:var(--gold-mid);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);margin-bottom:var(--sp-3);flex-shrink:0}
.why-title{font-size:.95rem;font-weight:700;color:var(--t0);margin-bottom:.4rem}
.why-desc{font-size:.82rem;color:var(--t3);line-height:1.7}

/* ── PACKAGES ────────────────────────────────────────────── */
.packages-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}
@media(max-width:1100px){.packages-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.packages-grid{grid-template-columns:1fr}}
.pkg-card{background:#fff;border:1.5px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-5);position:relative;transition:all .22s;display:flex;flex-direction:column}
.pkg-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px)}
.pkg-card.popular{border-color:var(--gold);box-shadow:var(--sh-gold)}
.pkg-ribbon{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--gold);color:#fff;font-size:.62rem;font-weight:800;padding:.22rem .9rem;border-radius:0 0 var(--r-sm) var(--r-sm);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}
.pkg-name{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--t3);margin-bottom:var(--sp-2)}
.pkg-price{font-family:var(--ff-disp);font-size:2rem;font-weight:700;color:var(--t0);margin-bottom:.25rem}
.pkg-price sup{font-size:.9rem;font-weight:400;color:var(--t3)}
.pkg-desc{font-size:.8rem;color:var(--t3);margin-bottom:var(--sp-4);line-height:1.65}
.pkg-features{display:flex;flex-direction:column;gap:.5rem;margin-bottom:var(--sp-5);flex:1}
.pkg-feat{display:flex;align-items:flex-start;gap:.55rem;font-size:.8rem;color:var(--t2)}
.pkg-feat-check{width:16px;height:16px;background:var(--green-light);color:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;font-size:.55rem;font-weight:900}
.pkg-feat.muted{opacity:.38}
.pkg-feat.muted .pkg-feat-check{background:var(--bg2);color:var(--t4)}

/* ── TESTIMONIALS ────────────────────────────────────────── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
@media(max-width:900px){.testi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.testi-grid{grid-template-columns:1fr}}
.testi-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4);transition:all .22s}
.testi-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.testi-stars{display:flex;gap:2px}
.testi-star{color:#F59E0B;font-size:.9rem}
.testi-quote{font-size:.9rem;color:var(--t2);line-height:1.8;flex:1;font-style:italic}
.testi-author{display:flex;align-items:center;gap:.75rem}
.testi-avatar{width:42px;height:42px;border-radius:50%;background:var(--gold-mid);border:2px solid var(--gold-border);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:var(--gold-dark);flex-shrink:0;font-family:var(--ff-disp)}
.testi-name{font-size:.875rem;font-weight:700;color:var(--t0)}
.testi-role{font-size:.72rem;color:var(--t3)}

/* ── BLOG CARDS ──────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.blog-grid{grid-template-columns:1fr}}
.blog-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);overflow:hidden;transition:all .22s}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.blog-card-img{height:210px;overflow:hidden;background:var(--bg2)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .45s var(--ease)}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-body{padding:var(--sp-4)}
.blog-card-cat{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin-bottom:.5rem}
.blog-card-title{font-size:1rem;font-weight:700;color:var(--t0);margin-bottom:.5rem;line-height:1.35}
.blog-card-title a{color:inherit;transition:color .15s}
.blog-card-title a:hover{color:var(--gold)}
.blog-card-excerpt{font-size:.8rem;color:var(--t3);line-height:1.65;margin-bottom:var(--sp-3);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-meta{display:flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--t4);flex-wrap:wrap}
.blog-card-author{font-weight:600;color:var(--t3)}
.meta-dot{width:3px;height:3px;background:var(--b1);border-radius:50%}

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--b0)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) 0;cursor:pointer;font-weight:600;color:var(--t2);font-size:.95rem;gap:var(--sp-3);background:none;border:none;width:100%;text-align:left;font-family:var(--ff-body);transition:color .15s}
.faq-question:hover{color:var(--gold)}
.faq-icon{width:26px;height:26px;background:var(--bg2);border:1.5px solid var(--b0);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--t3);font-size:.8rem;transition:all .22s}
.faq-item.faq-open .faq-icon{background:var(--gold);border-color:var(--gold);color:#fff;transform:rotate(45deg)}
.faq-item.faq-open .faq-question{color:var(--gold)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .38s ease}
.faq-item.faq-open .faq-answer{max-height:400px}
.faq-answer p{padding:0 0 var(--sp-4);color:var(--t3);font-size:.875rem;line-height:1.82}

/* ── CTA BAND ────────────────────────────────────────────── */
.cta-band{background:linear-gradient(135deg,var(--navy) 0%,#1E293B 100%);padding:var(--sp-8) 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-50%;right:-10%;width:50%;height:200%;background:radial-gradient(ellipse,rgba(217,119,6,.1) 0%,transparent 70%);pointer-events:none}
.cta-band h2{color:#fff;margin-bottom:var(--sp-3)}
.cta-band p{color:rgba(255,255,255,.7);margin-bottom:var(--sp-5);max-width:540px;margin-left:auto;margin-right:auto}

/* ── STATS ───────────────────────────────────────────────── */
.stats-band{display:grid;grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.stats-band{grid-template-columns:repeat(2,1fr)}}
.stat-item{padding:var(--sp-6) var(--sp-5);text-align:center;border-right:1px solid var(--b0);background:#fff}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--ff-disp);font-size:2.5rem;font-weight:700;color:var(--gold);display:block;line-height:1}
.stat-lbl{font-size:.72rem;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;margin-top:.4rem}

/* ── CONTACT ─────────────────────────────────────────────── */
.contact-split{display:grid;grid-template-columns:1fr 1.4fr;gap:var(--sp-7);align-items:start}
@media(max-width:900px){.contact-split{grid-template-columns:1fr}}
.ci-item{display:flex;gap:var(--sp-3);align-items:flex-start}
.ci-icon{width:46px;height:46px;background:var(--gold-mid);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);flex-shrink:0}
.ci-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);margin-bottom:.2rem}
.ci-value{font-size:.9rem;color:var(--t2)}
.ci-value a{color:var(--gold)}
.contact-form-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-xl);padding:var(--sp-6);box-shadow:var(--sh-md)}
.contact-info-list{display:flex;flex-direction:column;gap:var(--sp-4);margin-top:var(--sp-4)}

/* ── FOOTER ──────────────────────────────────────────────── */
.footer{background:var(--navy);padding:var(--sp-8) 0 var(--sp-5)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr .8fr;gap:var(--sp-6);margin-bottom:var(--sp-6)}
@media(max-width:1100px){.footer-grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:700px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-logo{display:flex;align-items:center;gap:.55rem;font-size:1rem;font-weight:800;color:#fff;margin-bottom:var(--sp-3)}
.footer-logo-mark{width:32px;height:32px;background:var(--gold);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-weight:800;font-size:.85rem;color:#fff;flex-shrink:0}
.footer-blurb{font-size:.82rem;color:rgba(255,255,255,.5);line-height:1.75;max-width:260px}
.footer-socials{display:flex;gap:.5rem;margin-top:var(--sp-3)}
.footer-social{width:34px;height:34px;background:rgba(255,255,255,.08);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:all .15s}
.footer-social:hover{background:var(--gold);color:#fff}
.footer-col-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.35);margin-bottom:var(--sp-3)}
.footer-links{display:flex;flex-direction:column;gap:.55rem}
.footer-link{font-size:.83rem;color:rgba(255,255,255,.55);transition:color .15s}
.footer-link:hover{color:var(--gold)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:var(--sp-4);border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap;gap:var(--sp-3)}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.3)}
.footer-credit{font-size:.78rem;color:rgba(255,255,255,.3)}
.footer-credit span{color:var(--gold);font-weight:600}

/* ── WHATSAPP ────────────────────────────────────────────── */
.wa-btn{position:fixed;bottom:1.5rem;right:1.5rem;z-index:990;width:52px;height:52px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:all .3s}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.5)}
.wa-btn svg{width:27px;height:27px;fill:white}

/* ── DETAIL PAGE ─────────────────────────────────────────── */
.detail-hero{padding:calc(var(--nav-h)+var(--sp-6)) 0 var(--sp-6);background:var(--bg1);border-bottom:1px solid var(--b0)}
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:var(--sp-6);align-items:start}
@media(max-width:1024px){.detail-grid{grid-template-columns:1fr}}
.detail-breadcrumb{font-size:.75rem;color:var(--t3);display:flex;align-items:center;gap:.4rem;margin-bottom:var(--sp-3)}
.detail-breadcrumb a{color:var(--gold)}
.detail-img{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--b0);height:360px;background:var(--bg2)}
.detail-img img{width:100%;height:100%;object-fit:cover}
.detail-sidebar{position:sticky;top:calc(var(--nav-h)+1rem);display:flex;flex-direction:column;gap:var(--sp-3)}
.price-card{background:#fff;border:1.5px solid var(--gold-border);border-radius:var(--r-lg);padding:var(--sp-5);box-shadow:var(--sh-gold)}
.price-big{font-family:var(--ff-disp);font-size:2.2rem;font-weight:700;color:var(--gold)}
.price-orig{font-size:1rem;color:var(--t4);text-decoration:line-through}
.info-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-4)}
.info-card-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--t3);margin-bottom:var(--sp-3)}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--b0);font-size:.82rem}
.info-row:last-child{border-bottom:none}
.info-key{color:var(--t3)}
.info-val{color:var(--t0);font-weight:600;text-align:right}
.tabs{display:flex;gap:.15rem;margin-bottom:var(--sp-4);border-bottom:2px solid var(--b0);overflow-x:auto}
.tab-btn{padding:.65rem 1.1rem;font-size:.82rem;font-weight:600;color:var(--t3);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;transition:all .15s;font-family:var(--ff-body);margin-bottom:-2px}
.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab-panel{display:none}
.tab-panel.active{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}
.tab-panel.list-mode{display:none}
.tab-panel.list-mode.active{display:flex;flex-wrap:wrap;gap:.4rem}
@media(max-width:640px){.tab-panel.active{grid-template-columns:1fr}}
.feat-item{display:flex;align-items:flex-start;gap:.5rem;padding:.6rem .75rem;background:var(--bg1);border-radius:var(--r-sm);border:1px solid var(--b0)}
.feat-check{width:18px;height:18px;background:var(--green-light);color:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:900;flex-shrink:0;margin-top:1px}
.feat-text{font-size:.8rem;color:var(--t2);line-height:1.5}
.page-tag{background:var(--bg1);border:1px solid var(--b0);color:var(--t2);font-size:.75rem;padding:.28rem .7rem;border-radius:var(--r-sm)}
.tech-badge{background:rgba(29,78,216,.08);border:1px solid rgba(29,78,216,.15);color:var(--indigo-mid);font-size:.72rem;padding:.28rem .7rem;border-radius:var(--r-full);font-weight:600}
.demo-cred{background:var(--bg1);border:1px solid var(--b0);border-radius:var(--r-sm);padding:.5rem .85rem;font-size:.78rem;color:var(--t2);font-family:monospace;word-break:break-all}

/* ── BLOG DETAIL ─────────────────────────────────────────── */
.blog-hero{padding:calc(var(--nav-h)+var(--sp-5)) 0 var(--sp-3);background:var(--bg1);border-bottom:1px solid var(--b0)}
.blog-detail-grid{display:grid;grid-template-columns:1fr 300px;gap:var(--sp-6);align-items:start;padding:var(--sp-6) 0}
@media(max-width:1024px){.blog-detail-grid{grid-template-columns:1fr}}
.blog-content{font-size:.95rem;color:var(--t2);line-height:1.9}
.blog-content h2{font-family:var(--ff-disp);font-size:1.25rem;color:var(--t0);margin:var(--sp-5) 0 var(--sp-2)}
.blog-content h3{font-size:1.05rem;color:var(--t0);margin:var(--sp-4) 0 var(--sp-2)}
.blog-content p{margin-bottom:var(--sp-3)}
.blog-content ul{margin:var(--sp-2) 0 var(--sp-3) var(--sp-5)}
.blog-content li{margin-bottom:.4rem}
.blog-sidebar-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-4)}
.blog-sidebar-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--t3);margin-bottom:var(--sp-3)}
.rel-post{padding:.6rem 0;border-bottom:1px solid var(--b0)}
.rel-post:last-child{border-bottom:none}
.rel-cat{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);margin-bottom:.25rem}
.rel-title{font-size:.82rem;font-weight:600;color:var(--t2);line-height:1.4}
.rel-title a{color:inherit}
.rel-title a:hover{color:var(--gold)}
.rel-meta{font-size:.68rem;color:var(--t4);margin-top:.2rem}
.tag{background:var(--bg1);border:1px solid var(--b0);color:var(--t3);font-size:.72rem;padding:.22rem .6rem;border-radius:var(--r-full)}

/* ── MODALS ──────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(15,23,42,.6);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:var(--sp-4);opacity:0;pointer-events:none;transition:opacity .22s}
.modal-overlay.modal-open{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:var(--r-xl);width:100%;max-height:90vh;overflow-y:auto;transform:scale(.95);transition:transform .22s var(--ease);box-shadow:var(--sh-xl)}
.modal-overlay.modal-open .modal{transform:scale(1)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--b0)}
.modal-title{font-size:1rem;font-weight:700;color:var(--t0)}
.modal-close{width:32px;height:32px;background:var(--bg1);border:1px solid var(--b0);color:var(--t3);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.85rem;transition:all .15s;font-family:var(--ff-body)}
.modal-close:hover{background:#FEE2E2;color:#DC2626;border-color:rgba(220,38,38,.2)}
.modal-body{padding:var(--sp-5)}
.qv-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5)}
@media(max-width:768px){.qv-grid{grid-template-columns:1fr}}
.qv-img{border-radius:var(--r-lg);overflow:hidden;height:280px;background:var(--bg2)}
.qv-img img{width:100%;height:100%;object-fit:cover}
.qv-details{display:flex;flex-direction:column;gap:var(--sp-3)}
.qv-includes{display:flex;flex-wrap:wrap;gap:.3rem;margin:var(--sp-1) 0}
.qv-feature-list{display:flex;flex-direction:column;gap:.35rem}
.qv-feat{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;color:var(--t2)}
.qv-check{color:var(--green);flex-shrink:0;font-weight:700}
.qv-section-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--t3);margin-bottom:.4rem}

/* ── LOADING / EMPTY ─────────────────────────────────────── */
.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--sp-7)}
.spinner{width:36px;height:36px;border:2px solid var(--b0);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:var(--sp-7) var(--sp-5)}
.empty-state-title{font-size:1.15rem;font-weight:700;color:var(--t0);margin-bottom:.4rem}
.empty-state-desc{font-size:.875rem;color:var(--t3);margin-bottom:var(--sp-4)}
.skel-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);overflow:hidden}
.skel-img{height:220px}
.skel-body{padding:var(--sp-4);display:flex;flex-direction:column;gap:.6rem}
.skel{background:linear-gradient(90deg,var(--bg2) 0%,#fff 50%,var(--bg2) 100%);background-size:200% 100%;animation:shimmer 1.6s infinite;border-radius:var(--r-sm)}
.skel-line{height:11px}
.skel-s{width:35%}.skel-m{width:60%}.skel-l{width:85%}.skel-f{width:100%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── TOAST ───────────────────────────────────────────────── */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(calc(100% + 2rem));z-index:9999;background:var(--navy);color:#fff;border-radius:var(--r-md);padding:.8rem 1.4rem;display:flex;align-items:center;gap:.6rem;font-size:.875rem;font-weight:600;box-shadow:var(--sh-lg);transition:transform .3s var(--ease);white-space:nowrap}
.toast.toast-show{transform:translateX(-50%) translateY(0)}
.toast.success{background:var(--green)}
.toast.error{background:#DC2626}

/* ── REVEAL ──────────────────────────────────────────────── */
.reveal{opacity:1;transform:translateY(0);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.js-enabled .reveal{opacity:0;transform:translateY(24px)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.4s}

/* ── PAGE HEROES ─────────────────────────────────────────── */
.page-hero{padding:calc(var(--nav-h)+var(--sp-6)) 0 var(--sp-6);background:linear-gradient(135deg,var(--bg1) 0%,var(--gold-light) 100%);border-bottom:1px solid var(--b0);text-align:center}
.page-hero h1{margin-bottom:var(--sp-3)}
.page-hero p{color:var(--t3);max-width:580px;margin:0 auto;font-size:1.05rem}
.simple-hero{padding:calc(var(--nav-h)+var(--sp-5)) 0 var(--sp-5);background:var(--bg1);border-bottom:1px solid var(--b0);text-align:center}
.simple-content{max-width:780px;margin:0 auto;padding:var(--sp-7) var(--sp-4)}
.simple-content h2{font-family:var(--ff-disp);font-size:1.2rem;color:var(--t0);margin:var(--sp-5) 0 var(--sp-2)}
.simple-content p{color:var(--t2);margin-bottom:var(--sp-3);line-height:1.85}
.simple-content a{color:var(--gold)}

/* ── CEO SECTION ─────────────────────────────────────────── */
.ceo-split{display:grid;grid-template-columns:1fr 1.25fr;gap:var(--sp-8);align-items:center}
@media(max-width:960px){.ceo-split{grid-template-columns:1fr;gap:var(--sp-5)}}
.ceo-photo-col{display:flex;align-items:center;justify-content:center}
.ceo-photo-wrap{position:relative;width:100%;max-width:420px}
.ceo-corner{position:absolute;width:40px;height:40px;z-index:3}
.ceo-corner-tl{top:-10px;left:-10px;border-top:2px solid var(--gold);border-left:2px solid var(--gold);border-radius:4px 0 0 0}
.ceo-corner-br{bottom:-10px;right:-10px;border-bottom:2px solid var(--gold);border-right:2px solid var(--gold);border-radius:0 0 4px 0}
.ceo-photo{width:100%;border-radius:16px;display:block;position:relative;z-index:1;box-shadow:var(--sh-xl);-webkit-mask-image:linear-gradient(to bottom,black 70%,transparent 100%);mask-image:linear-gradient(to bottom,black 70%,transparent 100%)}
.ceo-badge-float{position:absolute;bottom:12%;right:-24px;z-index:4;background:#fff;border:1px solid var(--gold-border);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-gold),var(--sh-md)}
.ceo-badge-icon{width:44px;height:44px;background:var(--gold);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-size:1rem;font-weight:800;flex-shrink:0}
.ceo-badge-label{font-size:.65rem;color:var(--t3);text-transform:uppercase;letter-spacing:.1em}
.ceo-badge-value{font-size:.82rem;font-weight:700;color:var(--t0);margin-top:1px}
.ceo-live-badge{position:absolute;top:16px;left:-20px;z-index:4;background:#fff;border:1px solid rgba(5,150,105,.25);border-radius:var(--r-full);padding:7px 14px;font-size:.7rem;font-weight:700;color:var(--green);display:flex;align-items:center;gap:7px;box-shadow:var(--sh-md);letter-spacing:.04em}
.ceo-live-dot{width:7px;height:7px;background:var(--green);border-radius:50%;box-shadow:0 0 6px rgba(5,150,105,.6);animation:blink 2s infinite;flex-shrink:0}
@media(max-width:960px){.ceo-badge-float{right:0;bottom:-20px}.ceo-live-badge{left:0}.ceo-photo-wrap{max-width:340px}}
.ceo-name{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.1;margin-bottom:var(--sp-2)}
.ceo-title-line{font-size:.8rem;font-weight:600;color:var(--t3);letter-spacing:.04em;margin-bottom:var(--sp-4);padding-bottom:var(--sp-4);border-bottom:1px solid var(--b0)}
.ceo-bio{font-size:.9rem;color:var(--t3);line-height:1.85}
.ceo-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin:var(--sp-5) 0;padding:var(--sp-4) 0;border-top:1px solid var(--b0);border-bottom:1px solid var(--b0)}
@media(max-width:640px){.ceo-stats{grid-template-columns:repeat(2,1fr)}}
.ceo-stat{text-align:center}
.ceo-stat-num{font-family:var(--ff-disp);font-size:1.6rem;font-weight:700;color:var(--gold);line-height:1;margin-bottom:.3rem}
.ceo-stat-lbl{font-size:.68rem;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;line-height:1.4}
.ceo-skills{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:var(--sp-4)}
.ceo-skill{background:var(--bg1);border:1.5px solid var(--b0);color:var(--t3);font-size:.72rem;font-weight:600;padding:.28rem .75rem;border-radius:var(--r-full);transition:all .15s}
.ceo-skill:hover{border-color:var(--gold-border);color:var(--gold);background:var(--gold-light)}
.ceo-links{display:flex;gap:var(--sp-2);flex-wrap:wrap}

/* ── SERVICES PAGE ───────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
@media(max-width:900px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.services-grid{grid-template-columns:1fr}}
.svc-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-5);transition:all .22s;cursor:pointer;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:var(--gold-border)}
.svc-icon{width:52px;height:52px;background:var(--gold-mid);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);margin-bottom:var(--sp-3)}
.svc-name{font-size:1rem;font-weight:700;color:var(--t0);margin-bottom:.4rem}
.svc-desc{font-size:.82rem;color:var(--t3);line-height:1.7;flex:1;margin-bottom:var(--sp-3)}
.svc-price{font-size:.78rem;font-weight:700;color:var(--gold);margin-bottom:var(--sp-3)}
.svc-links{display:flex;gap:.4rem;flex-wrap:wrap}

/* ── PROCESS PAGE ────────────────────────────────────────── */
.process-step{display:grid;grid-template-columns:80px 1fr;gap:var(--sp-4);padding:var(--sp-5) 0;border-bottom:1px solid var(--b0);align-items:flex-start}
.process-step:last-child{border-bottom:none}
.process-num{width:64px;height:64px;background:var(--gold-mid);border:2px solid var(--gold-border);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-size:1.2rem;font-weight:800;color:var(--gold-dark);flex-shrink:0}
.process-content h3{margin-bottom:.5rem}
.process-content p{font-size:.9rem}
.process-content ul{margin:var(--sp-2) 0 0 var(--sp-4)}
.process-content li{font-size:.85rem;color:var(--t3);margin-bottom:.3rem}

/* ── PRICING PAGE ────────────────────────────────────────── */
.pricing-compare{overflow-x:auto;margin:var(--sp-6) 0}
.pricing-table{width:100%;border-collapse:collapse;font-size:.82rem;min-width:600px}
.pricing-table th{background:var(--bg1);padding:.8rem 1rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);border-bottom:1px solid var(--b0);text-align:left}
.pricing-table td{padding:.75rem 1rem;border-bottom:1px solid var(--b0);vertical-align:middle}
.pricing-table tr:last-child td{border-bottom:none}
.pricing-table tr:hover td{background:var(--bg1)}
.check-yes{color:var(--green)}
.check-no{color:var(--b1)}
.check-partial{color:var(--gold);font-size:.85rem;font-weight:600}

/* ── ABOUT / VALUES ──────────────────────────────────────── */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
@media(max-width:768px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.values-grid{grid-template-columns:1fr}}
.value-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-4);text-align:center;transition:all .22s}
.value-card:hover{border-color:var(--gold-border);transform:translateY(-3px);box-shadow:var(--sh-md)}
.value-icon{width:52px;height:52px;background:var(--gold-mid);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);margin:0 auto var(--sp-3)}
.value-name{font-size:.95rem;font-weight:700;color:var(--t0);margin-bottom:.4rem}
.value-desc{font-size:.82rem;color:var(--t3);line-height:1.65}

/* ── BUNDLES ─────────────────────────────────────────────── */
.bundles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4)}
@media(max-width:640px){.bundles-grid{grid-template-columns:1fr}}
.bundle-card{background:#fff;border:1.5px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-5);transition:all .22s}
.bundle-card:hover{border-color:var(--gold-border);box-shadow:var(--sh-md)}
.bundle-name{font-size:1rem;font-weight:700;color:var(--t0);margin-bottom:.3rem}
.bundle-desc{font-size:.82rem;color:var(--t3);margin-bottom:var(--sp-3)}
.bundle-items{display:flex;flex-direction:column;gap:.35rem}
.bundle-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--t2)}
.bundle-item-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;flex-shrink:0}

/* ── ADMIN ───────────────────────────────────────────────── */
.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-sidebar{background:var(--navy);border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;width:240px;overflow-y:auto;z-index:100}
.admin-main{margin-left:240px;min-height:100vh;display:flex;flex-direction:column}
@media(max-width:1024px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{display:none}.admin-main{margin-left:0}}
.admin-sidebar-logo{display:flex;align-items:center;gap:.6rem;padding:var(--sp-4);border-bottom:1px solid rgba(255,255,255,.08)}
.admin-sidebar-logo-mark{width:32px;height:32px;background:var(--gold);color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-weight:800;font-size:.85rem;flex-shrink:0}
.admin-sidebar-logo-text{font-size:.875rem;font-weight:700;color:#fff;line-height:1.2}
.admin-sidebar-logo-text span{display:block;font-size:.65rem;color:rgba(255,255,255,.4);font-weight:400}
.admin-nav{flex:1;padding:var(--sp-3);display:flex;flex-direction:column;gap:2px}
.admin-nav-section{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.3);padding:.75rem .5rem .25rem;margin-top:.25rem}
.admin-nav-link{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:var(--r-sm);font-size:.82rem;font-weight:500;color:rgba(255,255,255,.55);cursor:pointer;transition:all .15s;font-family:var(--ff-body)}
.admin-nav-link:hover{background:rgba(255,255,255,.06);color:#fff}
.admin-nav-link.active{background:rgba(217,119,6,.15);color:var(--gold)}
.admin-sidebar-footer{padding:var(--sp-3);border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.6rem}
.admin-user-info{display:flex;align-items:center;gap:.6rem;margin-bottom:.25rem}
.admin-avatar{width:32px;height:32px;background:rgba(217,119,6,.2);border:1px solid rgba(217,119,6,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:var(--gold);flex-shrink:0;font-family:var(--ff-disp)}
.admin-user-name{font-size:.82rem;font-weight:700;color:#fff}
.admin-user-role{font-size:.65rem;color:rgba(255,255,255,.35)}
.admin-topbar{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--b0);background:#fff;position:sticky;top:0;z-index:10;box-shadow:var(--sh-xs)}
.admin-page-title{font-size:1.05rem;font-weight:700;color:var(--t0)}
.admin-content{flex:1;padding:var(--sp-5);background:var(--bg2)}
.admin-section{display:none}
.admin-section.active{display:block}
.stats-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin-bottom:var(--sp-4)}
@media(max-width:1100px){.stats-cards{grid-template-columns:repeat(2,1fr)}}
.stat-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-4)}
.stat-card-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);margin-bottom:.5rem}
.stat-card-value{font-family:var(--ff-disp);font-size:2rem;font-weight:700;color:var(--gold);line-height:1}
.stat-card-sub{font-size:.72rem;color:var(--t3);margin-top:.3rem}
.admin-table-wrapper{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);overflow:hidden;margin-bottom:var(--sp-3)}
.admin-table-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--b0);flex-wrap:wrap;gap:var(--sp-2)}
.admin-table-title{font-size:.9rem;font-weight:700;color:var(--t0)}
.admin-table{width:100%;border-collapse:collapse;font-size:.8rem;min-width:640px}
.admin-table th{text-align:left;padding:.6rem 1rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);background:var(--bg1);border-bottom:1px solid var(--b0);white-space:nowrap}
.admin-table td{padding:.72rem 1rem;border-bottom:1px solid var(--b0);color:var(--t2);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--bg1)}
.admin-table-actions{display:flex;gap:.35rem}
.admin-form-section{background:#fff;border:1px solid var(--b0);border-radius:var(--r-lg);padding:var(--sp-6)}
.admin-form-section-title{font-size:1.05rem;font-weight:700;color:var(--t0);margin-bottom:var(--sp-5);padding-bottom:var(--sp-3);border-bottom:1px solid var(--b0)}
.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
@media(max-width:768px){.admin-form-grid{grid-template-columns:1fr}}
.admin-form-full{grid-column:1/-1}

/* Admin login */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg1) 0%,var(--gold-light) 100%);padding:var(--sp-5)}
.login-box{width:100%;max-width:420px}
.login-logo{text-align:center;margin-bottom:var(--sp-6)}
.login-logo-mark{width:52px;height:52px;background:var(--indigo);color:#fff;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;font-family:var(--ff-disp);font-weight:800;font-size:1.1rem;margin-bottom:var(--sp-3)}
.login-title{font-family:var(--ff-disp);font-size:1.5rem;font-weight:700;color:var(--t0);margin-bottom:.25rem}
.login-sub{font-size:.82rem;color:var(--t3)}
.login-card{background:#fff;border:1px solid var(--b0);border-radius:var(--r-xl);padding:var(--sp-6);box-shadow:var(--sh-lg)}
.login-back{text-align:center;margin-top:var(--sp-4);font-size:.8rem;color:var(--t3)}
.login-back a{color:var(--gold)}
.mt-auto{margin-top:auto}

/* Static header/footer safeguard */
#navbar-root:empty,#footer-root:empty{display:none;}
.navbar{display:block!important;}
.footer{display:block!important;}
/* Header Industry Dropdown */
.has-dropdown {
  position: relative;
}

.nav-caret {
  font-size: 0.75rem;
  margin-left: 5px;
}

.industry-dropdown {
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  width: 720px;
  max-width: 92vw;
  transform: translateX(-50%) translateY(10px);
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 20px;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.16);
  padding: 18px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 9999;
  transition: all 0.25s ease;
}

.has-dropdown:hover .industry-dropdown,
.has-dropdown:focus-within .industry-dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.industry-dropdown a {
  display: block;
  padding: 12px 14px;
  border-radius: 12px;
  color: #14213d;
  font-size: 0.92rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
}

.industry-dropdown a:hover {
  background: rgba(224, 117, 0, 0.09);
  color: #d96f00;
  transform: translateX(3px);
}

@media (max-width: 900px) {
  .industry-dropdown {
    position: static;
    width: 100%;
    max-width: 100%;
    transform: none;
    grid-template-columns: 1fr;
    box-shadow: none;
    border-radius: 14px;
    margin-top: 10px;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    display: none;
  }

  .has-dropdown:hover .industry-dropdown,
  .has-dropdown:focus-within .industry-dropdown {
    display: grid;
    transform: none;
  }
}
/* ============================================================
   Final v6 dropdown/header fixes
   - keeps dropdown visible under fixed navbar
   - supports hover + click-open state
   - gives page heroes enough top space below fixed header
   ============================================================ */
.navbar,
.navbar-inner,
.nav-center,
.nav-item,
.has-dropdown {
  overflow: visible !important;
}

.navbar {
  z-index: 10000;
}

.nav-center {
  position: relative;
}

.has-dropdown {
  display: inline-flex;
  align-items: center;
}

.has-dropdown > .nav-link {
  cursor: pointer;
}

.nav-caret {
  display: inline-block;
  margin-left: 6px;
  font-size: 0.72rem;
  line-height: 1;
  transition: transform .2s ease;
}

.has-dropdown:hover .nav-caret,
.has-dropdown:focus-within .nav-caret,
.has-dropdown.dropdown-open .nav-caret {
  transform: rotate(180deg);
}

.industry-dropdown {
  top: calc(100% + 18px) !important;
  left: 50% !important;
  width: min(760px, 92vw) !important;
  max-height: calc(100vh - var(--nav-h) - 34px);
  overflow-y: auto;
  transform: translateX(-50%) translateY(10px) !important;
  z-index: 10001 !important;
}

.has-dropdown:hover .industry-dropdown,
.has-dropdown:focus-within .industry-dropdown,
.has-dropdown.dropdown-open .industry-dropdown {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

.page-hero {
  padding-top: calc(var(--nav-h) + 5.5rem) !important;
}

.hero {
  padding-top: calc(var(--nav-h) + 4rem) !important;
}

section[id] {
  scroll-margin-top: calc(var(--nav-h) + 24px);
}

@media (max-width: 960px) {
  .has-dropdown {
    display: block;
  }

  .industry-dropdown {
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: none;
    overflow: visible;
    transform: none !important;
    grid-template-columns: 1fr !important;
    box-shadow: none;
    border-radius: 14px;
    margin-top: 10px;
    display: none;
  }

  .has-dropdown:hover .industry-dropdown,
  .has-dropdown:focus-within .industry-dropdown,
  .has-dropdown.dropdown-open .industry-dropdown {
    display: grid;
    transform: none !important;
  }
}
/* Fix Industry Dropdown mouse movement issue */
.has-dropdown {
  position: relative;
}

.has-dropdown::after {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
  height: 24px;
  background: transparent;
  z-index: 9998;
}

.industry-dropdown {
  top: calc(100% + 8px);
}

.has-dropdown:hover .industry-dropdown,
.has-dropdown:focus-within .industry-dropdown,
.has-dropdown.dropdown-open .industry-dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
/* Final dropdown stability override */
.industry-dropdown {
  top: calc(100% + 8px) !important;
}

.has-dropdown::after {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
  height: 28px;
  background: transparent;
  z-index: 10000;
}
/* ============================================================
   FINAL LAYOUT REPAIR - 2026-05-28
   Fixes oversized blank hero space and fixed-navbar overlap on
   static pages after audit cleanup.
   ============================================================ */

/* Keep content visible even if a page-specific reveal initializer fails. */
.js-enabled .reveal,
.reveal {
  opacity: 1 !important;
  transform: none !important;
}

/* Consistent top spacing below the fixed navbar. */
.page-hero,
.about-hero,
.detail-hero,
.blog-hero,
.simple-hero {
  padding-top: calc(var(--nav-h) + 2.75rem) !important;
  padding-bottom: var(--sp-5) !important;
}

.page-hero {
  min-height: auto !important;
}

.about-hero {
  background: linear-gradient(135deg, var(--bg1) 0%, var(--gold-light) 100%);
  border-bottom: 1px solid var(--b0);
  text-align: center;
}

.about-hero .section-hd {
  margin-bottom: 0 !important;
}

/* Reduce the large empty gap between hero/filter areas and content grids. */
.page-hero + .section,
.about-hero + .section,
.blog-hero + .section,
.detail-hero + .section,
.simple-hero + .section {
  padding-top: var(--sp-5) !important;
}

/* Industry and blog listing pages should start content closer to the filters. */
#websites-grid,
#blog-grid {
  margin-top: 0 !important;
}

/* Prevent fixed header from covering anchor targets. */
section[id],
#contact,
#request,
#faq,
#services,
#process {
  scroll-margin-top: calc(var(--nav-h) + 24px) !important;
}

/* Keep dropdown stable and above page content. */
.navbar,
.navbar-inner,
.nav-center,
.nav-item,
.has-dropdown {
  overflow: visible !important;
}

.navbar {
  z-index: 10000 !important;
}

.industry-dropdown {
  top: calc(100% + 8px) !important;
  z-index: 10001 !important;
}

.has-dropdown::after {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
  height: 28px;
  background: transparent;
  z-index: 10000;
}

@media (max-width: 960px) {
  .page-hero,
  .about-hero,
  .detail-hero,
  .blog-hero,
  .simple-hero {
    padding-top: calc(var(--nav-h) + 2rem) !important;
  }
}

/* Final blog card click fix */
.blog-card {
  cursor: pointer;
}

.blog-card:focus {
  outline: 3px solid rgba(217,119,6,.25);
  outline-offset: 4px;
}
/* Final Premium Blog Detail Page */
.blog-detail-premium-hero {
  padding: calc(var(--nav-h) + 4rem) 0 3.5rem !important;
  background: linear-gradient(135deg, #ffffff 0%, var(--gold-light) 100%);
  border-bottom: 1px solid var(--b0);
}

.blog-detail-premium-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 3.5rem;
  align-items: center;
}

.blog-detail-premium-copy {
  min-width: 0;
}

.blog-breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
  color: var(--t3);
  font-size: 0.78rem;
  margin-bottom: 1.5rem;
}

.blog-breadcrumb a {
  color: var(--gold);
  font-weight: 600;
}

.blog-detail-cat {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--gold);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 1rem;
}

.blog-detail-cat::before {
  content: "";
  width: 20px;
  height: 2px;
  background: var(--gold);
  border-radius: 999px;
}

.blog-detail-premium-hero h1 {
  max-width: 760px;
  font-size: clamp(2.25rem, 4.5vw, 4rem) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.035em;
  margin-bottom: 1.25rem;
}

.blog-detail-premium-hero p {
  max-width: 650px;
  font-size: 1.02rem;
  color: var(--t3);
  line-height: 1.85;
  margin-bottom: 1.35rem;
}

.blog-detail-meta {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
  color: var(--t3);
  font-size: 0.82rem;
}

.blog-detail-meta strong {
  color: var(--t1);
  font-weight: 700;
}

.blog-detail-meta .meta-dot {
  width: 4px;
  height: 4px;
  background: var(--b1);
  border-radius: 50%;
}

.blog-detail-premium-image {
  height: 430px;
  overflow: hidden;
  border-radius: 28px;
  background: var(--bg2);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 28px 70px rgba(15, 23, 42, 0.16);
}

.blog-detail-premium-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-detail-premium-body {
  padding: 0;
  background: #ffffff;
}

.blog-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 3.5rem;
  align-items: start;
  padding: 4rem 0 !important;
}

.blog-content {
  max-width: 760px;
  font-size: 1rem;
  line-height: 1.9;
}

.blog-content > p:first-child {
  font-size: 1.08rem;
  color: var(--t2);
}

.blog-tags-wrap {
  margin-top: var(--sp-5);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--b0);
}

.blog-tags-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.blog-share-box {
  margin-top: var(--sp-4);
  padding: var(--sp-4);
  background: var(--bg1);
  border: 1px solid var(--b0);
  border-radius: var(--r-md);
}

.blog-share-actions {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.blog-cta-box {
  margin-top: var(--sp-5);
  padding: var(--sp-5);
  background: var(--gold-light);
  border: 1px solid var(--gold-border);
  border-radius: var(--r-lg);
}

.blog-cta-box h3 {
  font-size: 1rem;
  margin-bottom: 0.4rem;
}

.blog-cta-box p {
  font-size: 0.84rem;
  color: var(--t3);
  margin-bottom: var(--sp-3);
}

.blog-cta-actions {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.blog-sidebar-card {
  position: sticky;
  top: calc(var(--nav-h) + 1.5rem);
}

@media (max-width: 980px) {
  .blog-detail-premium-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .blog-detail-premium-image {
    height: 330px;
  }

  .blog-detail-grid {
    grid-template-columns: 1fr;
  }

  .blog-sidebar-card {
    position: static;
  }
}

@media (max-width: 640px) {
  .blog-detail-premium-hero {
    padding-top: calc(var(--nav-h) + 2.5rem) !important;
  }

  .blog-detail-premium-hero h1 {
    font-size: 2.1rem !important;
  }

  .blog-detail-premium-image {
    height: 240px;
    border-radius: 20px;
  }
}
/* Final homepage hero spacing fix */
body:has(.hero) .hero,
.hero {
  min-height: auto !important;
  padding-top: 6.5rem !important;
  padding-bottom: 3rem !important;
}

.hero .container,
.hero-grid,
.hero-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.hero-badge,
.hero .eyebrow,
.hero .section-kicker {
  margin-top: 0 !important;
}

@media (max-width: 768px) {
  body:has(.hero) .hero,
  .hero {
    padding-top: 5.5rem !important;
    padding-bottom: 2.5rem !important;
  }
}
/* Homepage industry demo cards with images */
.home-demo-showcase {
  padding: 5rem 0;
  background: #ffffff;
}

.home-demo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.4rem;
  margin-top: 2.75rem;
}

.home-demo-card {
  overflow: hidden;
  border: 1px solid var(--b0);
  border-radius: 26px;
  background: #ffffff;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.home-demo-card:hover {
  transform: translateY(-7px);
  border-color: var(--gold-border);
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.12);
}

.home-demo-img {
  display: block;
  height: 205px;
  overflow: hidden;
  background: var(--bg2);
}

.home-demo-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}

.home-demo-card:hover .home-demo-img img {
  transform: scale(1.06);
}

.home-demo-body {
  padding: 1.35rem;
}

.home-demo-category {
  color: var(--gold);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 0.55rem;
}

.home-demo-body h3 {
  font-size: 1.05rem;
  margin-bottom: 0.55rem;
  color: var(--t1);
}

.home-demo-body p {
  min-height: 78px;
  color: var(--t3);
  font-size: 0.84rem;
  line-height: 1.65;
  margin-bottom: 1rem;
}

.home-demo-action {
  display: flex;
  justify-content: center;
  margin-top: 2.4rem;
}

@media (max-width: 1100px) {
  .home-demo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .home-demo-showcase {
    padding: 3.5rem 0;
  }

  .home-demo-grid {
    grid-template-columns: 1fr;
  }

  .home-demo-img {
    height: 210px;
  }
}
/* Homepage blog cards full-card click */
#blog-preview-grid .blog-card {
  cursor: pointer;
}

#blog-preview-grid .blog-card:focus {
  outline: 3px solid rgba(224, 120, 0, 0.25);
  outline-offset: 4px;
}
/* Hidden footer admin access */
.hidden-admin-link {
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-left: 8px;
  border-radius: 50%;
  opacity: 0.18;
  color: transparent;
  background: rgba(255, 255, 255, 0.25);
  text-decoration: none;
  vertical-align: middle;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.hidden-admin-link:hover {
  opacity: 0.9;
  transform: scale(1.25);
}
/* ============================================================
   FINAL ADMIN DASHBOARD REPAIR
   Fixes broken sidebar/main layout, squeezed titles, hidden tables
   ============================================================ */

body.admin-body {
  margin: 0 !important;
  padding: 0 !important;
  min-height: 100vh !important;
  background: #f8fafc !important;
  overflow-x: hidden !important;
}

/* Stop grid + fixed sidebar conflict */
body.admin-body .admin-layout {
  display: block !important;
  width: 100% !important;
  min-height: 100vh !important;
  background: #f8fafc !important;
}

/* Fixed sidebar */
body.admin-body .admin-sidebar {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  bottom: 0 !important;
  width: 260px !important;
  height: 100vh !important;
  z-index: 1000 !important;
  display: flex !important;
  flex-direction: column !important;
  background: var(--navy) !important;
  overflow-y: auto !important;
}

/* Main admin area */
body.admin-body .admin-main {
  margin-left: 260px !important;
  width: calc(100% - 260px) !important;
  min-height: 100vh !important;
  display: block !important;
  background: #f8fafc !important;
}

/* Topbar */
body.admin-body .admin-topbar {
  position: sticky !important;
  top: 0 !important;
  z-index: 100 !important;
  width: 100% !important;
  min-height: 76px !important;
  padding: 1rem 2rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  background: #ffffff !important;
  border-bottom: 1px solid var(--b0) !important;
  box-shadow: var(--sh-xs) !important;
}

/* Title fix */
body.admin-body .admin-page-title,
body.admin-body #admin-page-title {
  display: block !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  line-height: 1.2 !important;
  font-family: var(--ff-disp) !important;
  font-size: 1.8rem !important;
  font-weight: 700 !important;
  color: var(--t0) !important;
  margin: 0 !important;
}

/* Main content area */
body.admin-body .admin-content {
  width: 100% !important;
  max-width: none !important;
  min-height: calc(100vh - 76px) !important;
  padding: 2rem !important;
  background: #f8fafc !important;
  box-sizing: border-box !important;
}

/* Section visibility */
body.admin-body .admin-section {
  display: none !important;
  width: 100% !important;
  max-width: none !important;
}

body.admin-body .admin-section.active {
  display: block !important;
}

/* Dashboard cards */
body.admin-body .stats-cards {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(180px, 1fr)) !important;
  gap: 1rem !important;
  width: 100% !important;
  margin-bottom: 1.5rem !important;
}

body.admin-body .stat-card {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* Two-column dashboard sections */
body.admin-body .grid-2 {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1.5rem !important;
  width: 100% !important;
}

/* Tables */
body.admin-body .admin-table-wrapper {
  width: 100% !important;
  max-width: none !important;
  overflow: hidden !important;
  background: #ffffff !important;
  border: 1px solid var(--b0) !important;
  border-radius: var(--r-lg) !important;
}

body.admin-body .admin-table-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  flex-wrap: wrap !important;
  width: 100% !important;
}

body.admin-body .admin-table {
  width: 100% !important;
  min-width: 900px !important;
}

/* Forms */
body.admin-body .admin-form-section {
  width: 100% !important;
  max-width: none !important;
  background: #ffffff !important;
}

body.admin-body .admin-form-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1rem !important;
  width: 100% !important;
}

/* Buttons should not shrink weirdly */
body.admin-body .btn {
  flex-shrink: 0 !important;
}

/* Mobile/tablet */
@media (max-width: 1024px) {
  body.admin-body .admin-sidebar {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
  }

  body.admin-body .admin-main {
    margin-left: 0 !important;
    width: 100% !important;
  }

  body.admin-body .admin-topbar {
    position: relative !important;
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  body.admin-body .stats-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body.admin-body .grid-2 {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  body.admin-body .admin-content {
    padding: 1rem !important;
  }

  body.admin-body .stats-cards,
  body.admin-body .admin-form-grid {
    grid-template-columns: 1fr !important;
  }

  body.admin-body .admin-page-title,
  body.admin-body #admin-page-title {
    font-size: 1.45rem !important;
  }
}
/* ============================================================
   FINAL MOBILE MENU VISIBILITY FIX
   ============================================================ */
@media (max-width: 960px) {
  .hamburger {
    display: flex !important;
    position: relative;
    z-index: 10002 !important;
  }

  .mobile-menu {
    position: fixed !important;
    top: var(--nav-h) !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: calc(100vh - var(--nav-h)) !important;
    background: #ffffff !important;
    z-index: 9999 !important;
    transform: translateX(100%) !important;
    transition: transform 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    overflow-y: auto !important;
    pointer-events: none !important;
  }

  .mobile-menu.mm-open {
    transform: translateX(0) !important;
    pointer-events: auto !important;
  }

  .mob-sub {
    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height 0.3s ease !important;
  }

  .mob-sub.sub-open {
    max-height: 900px !important;
  }
}
/* Final homepage mobile menu fix */
@media (max-width: 960px) {
  .nav-center,
  .nav-cta {
    display: none !important;
  }

  .hamburger {
    display: flex !important;
    position: relative !important;
    z-index: 10005 !important;
    pointer-events: auto !important;
    cursor: pointer !important;
  }

  .mobile-menu {
    position: fixed !important;
    top: var(--nav-h, 86px) !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: calc(100vh - var(--nav-h, 86px)) !important;
    background: #ffffff !important;
    z-index: 10000 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 1rem 1.25rem 2rem !important;
    overflow-y: auto !important;
    transform: translateX(100%) !important;
    transition: transform 0.3s ease !important;
    pointer-events: none !important;
  }

  .mobile-menu.mm-open {
    transform: translateX(0) !important;
    pointer-events: auto !important;
  }

  .mob-link,
  .mob-acc-btn,
  .mob-sub-link {
    width: 100% !important;
    display: flex !important;
  }

  .mob-sub {
    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height 0.3s ease !important;
  }

  .mob-sub.sub-open {
    max-height: 900px !important;
  }
}
/* ============================================================
   CLEAN HOMEPAGE HERO + SECTION SPACING FINAL FIX
   ============================================================ */

/* Desktop homepage spacing */
@media (min-width: 961px) {
  .hero {
    min-height: auto !important;
    padding-top: calc(var(--nav-h) + 2.5rem) !important;
    padding-bottom: 2.75rem !important;
  }

  .hero-grid {
    padding: 2.5rem 0 1rem !important;
    align-items: center !important;
    gap: 4rem !important;
  }

  .hero-content {
    margin-top: 0 !important;
  }

  .hero-visual {
    margin-top: -2.25rem !important;
  }

  .hero-img-wrap {
    height: 500px !important;
    max-height: 500px !important;
    border-radius: 30px !important;
    overflow: hidden !important;
    transform: none !important;
  }

  .hero-img-wrap img {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    object-fit: cover !important;
    object-position: center center !important;
  }

  .hero-trust {
    margin-bottom: 2rem !important;
  }

  .hero-stats-row {
    margin-top: 1.75rem !important;
    padding-top: 1.5rem !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .trust-band {
    margin-top: 0 !important;
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }

  .section {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }

  #how,
  #demos,
  .home-demo-showcase {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }

  .section-hd {
    margin-bottom: 2.25rem !important;
  }
}

/* Mobile homepage spacing */
@media (max-width: 960px) {
  .hero {
    min-height: auto !important;
    padding-top: calc(var(--nav-h) + 1.5rem) !important;
    padding-bottom: 2.5rem !important;
  }

  .hero-grid {
    padding: 1.5rem 0 0 !important;
    gap: 2rem !important;
  }

  .hero-visual {
    order: -1 !important;
    margin-top: 0 !important;
  }

  .hero-img-wrap {
    height: auto !important;
    max-height: none !important;
    transform: none !important;
  }

  .hero-img-wrap img {
    min-height: 360px !important;
    height: 360px !important;
    object-fit: cover !important;
    object-position: center center !important;
  }

  .hero-stats-row {
    margin-top: 1.5rem !important;
    padding-top: 1.25rem !important;
  }

  .section {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  #how,
  #demos,
  .home-demo-showcase {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }

  .section-hd {
    margin-bottom: 1.75rem !important;
  }
}
/* Final hero balance adjustment */
@media (min-width: 961px) {
  .hero {
    padding-top: calc(var(--nav-h) + 0.75rem) !important;
  }

  .hero-grid {
    padding-top: 0.75rem !important;
    align-items: center !important;
  }

  .hero-visual {
    margin-top: -11.75rem !important;
  }

  .hero-img-wrap img {
    object-position: center 32% !important;
  }
}
/* Contact FAQ direct accordion fix */
#faq .faq-question {
  cursor: pointer;
}

#faq .faq-answer {
  display: none;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.3s ease, opacity 0.3s ease;
}

#faq .faq-item.faq-open .faq-answer {
  display: block;
  opacity: 1;
}