/* =====================================================================
   Server Wizards theme
   Hybrid dark SaaS + terminal aesthetic. Gold/amber brand accent.
   Color tokens are CSS custom properties so the Customizer can override
   them via an inline <style> block (see inc/customizer.php).
   ===================================================================== */

:root {
  --sw-bg:        #0a0e14;
  --sw-bg-2:      #0d1219;
  --sw-surface:   #141b26;
  --sw-surface-2: #1a2230;
  --sw-border:    #232c3b;
  --sw-border-2:  #2e3a4d;
  --sw-text:      #e6edf3;
  --sw-muted:     #9aa7b6;
  --sw-faint:     #66758a;
  --sw-gold:      #f0d050;
  --sw-gold-deep: #d4a82a;
  --sw-cyan:      #38bdf8;
  --sw-green:     #4ade80;
  --sw-red:       #ff5c57;

  --sw-radius:    14px;
  --sw-radius-sm: 9px;
  --sw-maxw:      1180px;
  --sw-gap:       clamp(1rem, 2vw, 1.6rem);

  --sw-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --sw-mono: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --sw-shadow:    0 18px 50px -20px rgba(0,0,0,.7);
  --sw-glow-gold: 0 0 0 1px rgba(240,208,80,.25), 0 12px 40px -12px rgba(240,208,80,.25);
}

/* ----------------------------- reset ------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--sw-sans);
  background: var(--sw-bg);
  color: var(--sw-text);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--sw-gold); text-decoration: none; transition: color .18s ease; }
a:hover { color: var(--sw-gold-deep); }
h1, h2, h3, h4 { line-height: 1.15; font-weight: 800; letter-spacing: -.02em; margin: 0 0 .5em; text-wrap: balance; }
h1 { font-size: clamp(2.2rem, 5.5vw, 3.6rem); }
h2 { font-size: clamp(1.7rem, 3.6vw, 2.6rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.5rem); }
p  { margin: 0 0 1.1em; color: var(--sw-text); }
ul, ol { color: var(--sw-text); }
code, pre, kbd { font-family: var(--sw-mono); }
:focus-visible { outline: 2px solid var(--sw-gold); outline-offset: 3px; border-radius: 4px; }
::selection { background: rgba(240,208,80,.28); color: #fff; }

/* --------------------------- utilities ---------------------------- */
.sw-container { width: 100%; max-width: var(--sw-maxw); margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2.2rem); }
.sw-section  { padding-block: clamp(3.5rem, 8vw, 6.5rem); position: relative; }
.sw-narrow   { max-width: 760px; }
.sw-center   { text-align: center; }
.sw-mono     { font-family: var(--sw-mono); }
.sw-gold     { color: var(--sw-gold); }
.sw-screen-reader-text { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(1px,1px,1px,1px); white-space:nowrap; }

.sw-eyebrow {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--sw-mono);
  font-size: .8rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--sw-gold);
  border: 1px solid var(--sw-border-2);
  background: var(--sw-surface);
  padding: .35rem .8rem; border-radius: 100px;
  margin-bottom: 1.2rem;
}
.sw-eyebrow::before { content: ""; width:7px; height:7px; border-radius:50%; background: var(--sw-green); box-shadow: 0 0 10px var(--sw-green); }

.sw-section-head { max-width: 720px; margin-bottom: clamp(2rem, 4vw, 3rem); }
.sw-center .sw-section-head, .sw-section-head.sw-center { margin-inline: auto; }
.sw-section-head p { color: var(--sw-muted); font-size: 1.08rem; }

/* ---------------------------- buttons ----------------------------- */
.sw-btn {
  display: inline-flex; align-items: center; gap: .55rem;
  font-weight: 700; font-size: .98rem;
  padding: .85rem 1.4rem; border-radius: var(--sw-radius-sm);
  border: 1px solid transparent; cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
  white-space: nowrap; line-height: 1;
}
.sw-btn svg { width: 1.05em; height: 1.05em; }
.sw-btn-primary { background: var(--sw-gold); color: #1a1407; box-shadow: var(--sw-glow-gold); }
.sw-btn-primary:hover { background: #ffe173; color: #1a1407; transform: translateY(-2px); }
.sw-btn-ghost { background: transparent; color: var(--sw-text); border-color: var(--sw-border-2); }
.sw-btn-ghost:hover { border-color: var(--sw-gold); color: var(--sw-gold); transform: translateY(-2px); }
.sw-btn-block { width: 100%; justify-content: center; }
.sw-btn-lg { padding: 1.05rem 1.8rem; font-size: 1.05rem; }

/* ----------------------------- header ----------------------------- */
.sw-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(10,14,20,.72);
  backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s ease, background .3s ease;
}
.sw-header.is-stuck { border-bottom-color: var(--sw-border); background: rgba(10,14,20,.92); }
.sw-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; height: 74px; }
.sw-brand { display: flex; align-items: center; gap: .65rem; flex-shrink: 0; }
.sw-brand img { height: 48px; width: auto; }
.custom-logo-link { display: inline-flex; align-items: center; flex-shrink: 0; }
.custom-logo-link img, img.custom-logo { height: 48px; width: auto; max-width: 280px; }
.sw-brand__text { font-weight: 800; font-size: 1.25rem; letter-spacing: -.02em; }
.sw-brand__text b { color: var(--sw-gold); font-weight: 800; }

.sw-nav { display: flex; align-items: center; gap: 1.8rem; }
.sw-nav ul { list-style: none; display: flex; align-items: center; gap: 1.6rem; margin: 0; padding: 0; }
.sw-nav a { color: var(--sw-muted); font-weight: 600; font-size: .98rem; position: relative; }
.sw-nav a:hover, .sw-nav .current-menu-item > a { color: var(--sw-text); }
.sw-nav .current-menu-item > a::after { content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background: var(--sw-gold); border-radius:2px; }
.sw-header__cta { display: flex; align-items: center; gap: .9rem; }

/* submenus */
.sw-nav li { position: relative; }
.sw-nav .sub-menu {
  position: absolute; top: calc(100% + 14px); left: 50%; transform: translateX(-50%) translateY(6px);
  background: var(--sw-surface); border: 1px solid var(--sw-border); border-radius: var(--sw-radius-sm);
  min-width: 220px; padding: .5rem; flex-direction: column; gap: .1rem; box-shadow: var(--sw-shadow);
  opacity: 0; visibility: hidden; transition: all .18s ease;
}
.sw-nav li:hover > .sub-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.sw-nav .sub-menu a { display: block; padding: .55rem .7rem; border-radius: 7px; }
.sw-nav .sub-menu a:hover { background: var(--sw-surface-2); }

/* mobile nav */
.sw-nav-toggle { display: none; background: none; border: 1px solid var(--sw-border-2); color: var(--sw-text); width: 44px; height: 44px; border-radius: 10px; cursor: pointer; align-items: center; justify-content: center; }
.sw-nav-toggle svg { width: 22px; height: 22px; }

/* ------------------------------ hero ------------------------------ */
.sw-hero { position: relative; padding-block: clamp(3.5rem, 8vw, 7rem); overflow: hidden; }
.sw-hero__grid { text-align: center; max-width: 860px; margin-inline: auto; }
.sw-hero h1 { margin-bottom: 1rem; }
.sw-hero h1 .sw-gold { display: inline; }
.sw-hero .sw-eyebrow { margin-inline: auto; }
.sw-hero__lead { font-size: 1.18rem; color: var(--sw-muted); max-width: 52ch; margin-inline: auto; }
.sw-hero__cta { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 1.8rem; justify-content: center; }
.sw-hero__visual { max-width: 660px; margin: 2.8rem auto 0; text-align: left; }
.sw-hero__meta { display: flex; flex-wrap: wrap; gap: 1.4rem 2rem; margin-top: 2.2rem; font-family: var(--sw-mono); font-size: .85rem; color: var(--sw-faint); justify-content: center; }
.sw-hero__meta span { display: inline-flex; align-items: center; gap: .5rem; }
.sw-hero__meta b { color: var(--sw-text); font-weight: 600; }
.sw-hero__meta .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--sw-green); box-shadow: 0 0 10px var(--sw-green); animation: sw-pulse 2s infinite; }

/* background glow + grid */
.sw-hero::before {
  content: ""; position: absolute; inset: -20% -10% auto -10%; height: 70%;
  background: radial-gradient(60% 100% at 70% 0%, rgba(240,208,80,.12), transparent 60%),
              radial-gradient(50% 80% at 20% 10%, rgba(56,189,248,.10), transparent 60%);
  pointer-events: none; z-index: 0;
}
.sw-grid-bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .5;
  background-image: linear-gradient(var(--sw-border) 1px, transparent 1px), linear-gradient(90deg, var(--sw-border) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 75%);
          mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 75%);
}
.sw-hero > .sw-container { position: relative; z-index: 1; }

/* terminal window */
.sw-terminal {
  background: #0b0f16; border: 1px solid var(--sw-border-2); border-radius: var(--sw-radius);
  box-shadow: var(--sw-shadow); overflow: hidden; font-family: var(--sw-mono);
}
.sw-terminal__bar { display: flex; align-items: center; gap: .5rem; padding: .7rem .9rem; background: #11161f; border-bottom: 1px solid var(--sw-border); }
.sw-terminal__bar i { width: 12px; height: 12px; border-radius: 50%; display: inline-block; }
.sw-terminal__bar i:nth-child(1){ background:#ff5f57; } .sw-terminal__bar i:nth-child(2){ background:#febc2e; } .sw-terminal__bar i:nth-child(3){ background:#28c840; }
.sw-terminal__bar span { margin-left: .6rem; font-size: .78rem; color: var(--sw-faint); }
.sw-terminal__body { padding: 1.1rem 1.2rem; font-size: .9rem; line-height: 1.75; min-height: 240px; }
.sw-terminal__body .line { white-space: pre-wrap; }
.sw-terminal .pr { color: var(--sw-green); } .sw-terminal .pr::after { content:" "; }
.sw-terminal .ok { color: var(--sw-green); } .sw-terminal .warn { color: var(--sw-gold); } .sw-terminal .info { color: var(--sw-cyan); } .sw-terminal .dim { color: var(--sw-faint); }
.sw-terminal .cursor { display:inline-block; width:9px; height:1.05em; background: var(--sw-gold); vertical-align:-2px; animation: sw-blink 1s steps(2) infinite; }

/* --------------------------- trust / stats ------------------------ */
.sw-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--sw-border); border: 1px solid var(--sw-border); border-radius: var(--sw-radius); overflow: hidden; }
.sw-stats--3 { grid-template-columns: repeat(3, 1fr); }
.sw-stat { background: var(--sw-bg-2); padding: 1.6rem 1.2rem; text-align: center; }
.sw-stat__num { font-family: var(--sw-mono); font-size: clamp(1.6rem, 3vw, 2.3rem); font-weight: 700; color: var(--sw-gold); line-height: 1; }
.sw-stat__label { color: var(--sw-muted); font-size: .92rem; margin-top: .5rem; }

/* --------------------------- distro marquee ----------------------- */
.sw-marquee { border-block: 1px solid var(--sw-border); background: var(--sw-bg-2); padding-block: 1.3rem; overflow: hidden; }
.sw-marquee__track { display: flex; gap: 3rem; width: max-content; animation: sw-scroll 32s linear infinite; }
.sw-marquee:hover .sw-marquee__track { animation-play-state: paused; }
.sw-marquee__item { font-family: var(--sw-mono); color: var(--sw-faint); font-size: .98rem; display: inline-flex; align-items: center; gap: .5rem; white-space: nowrap; }
.sw-marquee__item::before { content: "›"; color: var(--sw-gold); }

/* ---------------------------- cards / grid ------------------------ */
.sw-grid { display: grid; gap: var(--sw-gap); }
.sw-grid-2 { grid-template-columns: repeat(2, 1fr); }
.sw-grid-3 { grid-template-columns: repeat(3, 1fr); }
.sw-grid-4 { grid-template-columns: repeat(4, 1fr); }

.sw-card {
  background: var(--sw-surface); border: 1px solid var(--sw-border); border-radius: var(--sw-radius);
  padding: 1.6rem; position: relative; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  height: 100%; display: flex; flex-direction: column;
}
.sw-card:hover { transform: translateY(-4px); border-color: var(--sw-border-2); box-shadow: var(--sw-shadow); }
.sw-card__icon {
  width: 48px; height: 48px; border-radius: 12px; display: grid; place-items: center;
  background: linear-gradient(145deg, rgba(240,208,80,.16), rgba(240,208,80,.04));
  border: 1px solid rgba(240,208,80,.25); color: var(--sw-gold); margin-bottom: 1.1rem;
}
.sw-card__icon svg { width: 24px; height: 24px; }
.sw-card h3 { margin-bottom: .5rem; }
.sw-card h3 a { color: var(--sw-text); }
.sw-card h3 a:hover { color: var(--sw-gold); }
.sw-card p { color: var(--sw-muted); font-size: .98rem; margin-bottom: 1rem; }
.sw-card__link { margin-top: auto; font-family: var(--sw-mono); font-size: .85rem; font-weight: 600; display: inline-flex; align-items: center; gap: .4rem; }
.sw-card__link::after { content: "→"; transition: transform .18s ease; }
.sw-card:hover .sw-card__link::after { transform: translateX(4px); }
.sw-card--accent { border-color: rgba(240,208,80,.35); }
.sw-card__tag { position:absolute; top:1rem; right:1rem; font-family:var(--sw-mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--sw-red); border:1px solid rgba(255,92,87,.35); background:rgba(255,92,87,.08); padding:.2rem .5rem; border-radius:6px; }

/* ----------------------- why-us / feature rows -------------------- */
.sw-feature { display: flex; gap: 1rem; align-items: flex-start; }
.sw-feature__icon { flex-shrink: 0; width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; background: var(--sw-surface-2); border: 1px solid var(--sw-border); color: var(--sw-cyan); }
.sw-feature__icon svg { width: 20px; height: 20px; }
.sw-feature h3 { font-size: 1.12rem; margin-bottom: .35rem; }
.sw-feature p { color: var(--sw-muted); font-size: .96rem; margin: 0; }

/* ------------------------------ process --------------------------- */
.sw-steps { counter-reset: step; display: grid; gap: var(--sw-gap); grid-template-columns: repeat(4, 1fr); }
.sw-step { position: relative; padding-top: 2.6rem; }
.sw-step::before { counter-increment: step; content: "0" counter(step); position: absolute; top: 0; left: 0; font-family: var(--sw-mono); font-size: 1.1rem; font-weight: 700; color: var(--sw-gold); border: 1px solid var(--sw-border-2); border-radius: 9px; width: 42px; height: 42px; display: grid; place-items: center; background: var(--sw-surface); }
.sw-step h3 { font-size: 1.12rem; }
.sw-step p { color: var(--sw-muted); font-size: .95rem; margin: 0; }

/* --------------------------- testimonials ------------------------- */
.sw-quote { background: var(--sw-surface); border: 1px solid var(--sw-border); border-radius: var(--sw-radius); padding: 1.8rem; height: 100%; display: flex; flex-direction: column; }
.sw-quote__mark { font-family: var(--sw-mono); color: var(--sw-gold); font-size: 2rem; line-height: 1; margin-bottom: .4rem; }
.sw-quote p { font-size: 1.05rem; color: var(--sw-text); }
.sw-quote__by { margin-top: auto; display: flex; align-items: center; gap: .8rem; padding-top: 1rem; }
.sw-quote__avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--sw-surface-2); border: 1px solid var(--sw-border-2); display: grid; place-items: center; font-family: var(--sw-mono); font-weight: 700; color: var(--sw-gold); }
.sw-quote__name { font-weight: 700; font-size: .98rem; }
.sw-quote__role { color: var(--sw-faint); font-size: .85rem; }

/* ------------------------------- CTA ------------------------------ */
.sw-cta { position: relative; border: 1px solid var(--sw-border-2); border-radius: var(--sw-radius); padding: clamp(2rem, 5vw, 3.5rem); text-align: center; overflow: hidden; background: linear-gradient(160deg, var(--sw-surface), var(--sw-bg-2)); }
.sw-cta::before { content:""; position:absolute; inset:0; background: radial-gradient(60% 120% at 50% 0%, rgba(240,208,80,.14), transparent 60%); pointer-events:none; }
.sw-cta > * { position: relative; }
.sw-cta h2 { margin-bottom: .6rem; }
.sw-cta p { color: var(--sw-muted); max-width: 52ch; margin-inline: auto; }
.sw-cta__btns { display: flex; gap: .9rem; justify-content: center; flex-wrap: wrap; margin-top: 1.6rem; }

/* emergency banner */
.sw-emergency { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:.6rem 1rem; background:rgba(255,92,87,.08); border:1px solid rgba(255,92,87,.3); border-radius:var(--sw-radius); padding:1rem 1.4rem; font-family:var(--sw-mono); font-size:.95rem; }
.sw-emergency b { color: var(--sw-red); }
.sw-emergency a { color: var(--sw-text); font-weight:700; }

/* ------------------------------ footer ---------------------------- */
.sw-footer { border-top: 1px solid var(--sw-border); background: var(--sw-bg-2); padding-block: clamp(3rem, 6vw, 4.5rem) 1.5rem; margin-top: 2rem; }
.sw-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.4fr; gap: 2.4rem; }
.sw-footer h4 { font-family: var(--sw-mono); font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; color: var(--sw-faint); margin-bottom: 1.1rem; }
.sw-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.sw-footer a { color: var(--sw-muted); font-size: .96rem; }
.sw-footer a:hover { color: var(--sw-gold); }
.sw-footer__about img { height: 32px; margin-bottom: 1rem; }
.sw-footer__about p { color: var(--sw-muted); font-size: .96rem; max-width: 34ch; }
.sw-footer__contact li { display: flex; gap: .6rem; color: var(--sw-muted); font-size: .96rem; }
.sw-footer__contact svg { width: 18px; height: 18px; color: var(--sw-gold); flex-shrink: 0; margin-top: 3px; }
.sw-social { display: flex; gap: .6rem; margin-top: 1.2rem; }
.sw-social a { width: 40px; height: 40px; border-radius: 10px; border: 1px solid var(--sw-border); display: grid; place-items: center; color: var(--sw-muted); }
.sw-social a:hover { border-color: var(--sw-gold); color: var(--sw-gold); transform: translateY(-2px); }
.sw-social svg { width: 18px; height: 18px; }
.sw-footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; margin-top: 2.6rem; padding-top: 1.6rem; border-top: 1px solid var(--sw-border); color: var(--sw-faint); font-size: .88rem; font-family: var(--sw-mono); }

/* ----------------------- page hero / inner banner ----------------- */
.sw-pagehero { position: relative; padding-block: clamp(3rem, 7vw, 5rem) clamp(2rem,4vw,3rem); border-bottom: 1px solid var(--sw-border); overflow: hidden; text-align: center; }
.sw-pagehero::before { content:""; position:absolute; inset:0; background: radial-gradient(60% 100% at 50% 0%, rgba(240,208,80,.10), transparent 60%); pointer-events:none; }
.sw-pagehero > .sw-container { position: relative; }
.sw-pagehero .sw-eyebrow { margin-inline: auto; }
.sw-pagehero h1 { margin-bottom: .6rem; font-size: clamp(1.85rem, 3.8vw, 2.7rem); max-width: 24ch; margin-inline: auto; }
.sw-pagehero p { color: var(--sw-muted); font-size: 1.12rem; max-width: 62ch; margin-inline: auto; }
.sw-breadcrumb { font-family: var(--sw-mono); font-size: .82rem; color: var(--sw-faint); margin-bottom: 1rem; }
.sw-breadcrumb a { color: var(--sw-muted); }
.sw-breadcrumb span { color: var(--sw-gold); }

/* --------------------------- prose / content ---------------------- */
.sw-prose { max-width: 760px; }
.sw-prose > * { margin-block: 0 1.2em; }
.sw-prose h2 { margin-top: 1.8em; }
.sw-prose h3 { margin-top: 1.4em; }
.sw-prose ul, .sw-prose ol { padding-left: 1.3em; display: grid; gap: .5em; }
.sw-prose li { color: var(--sw-text); }
.sw-prose li::marker { color: var(--sw-gold); }
.sw-prose blockquote { border-left: 3px solid var(--sw-gold); margin: 1.5em 0; padding: .4em 1.2em; color: var(--sw-muted); background: var(--sw-surface); border-radius: 0 var(--sw-radius-sm) var(--sw-radius-sm) 0; }
.sw-prose code { background: var(--sw-surface-2); padding: .15em .4em; border-radius: 5px; font-size: .9em; color: var(--sw-cyan); }
.sw-prose pre { background: #0b0f16; border: 1px solid var(--sw-border); border-radius: var(--sw-radius-sm); padding: 1.1rem 1.2rem; overflow-x: auto; }
.sw-prose pre code { background: none; padding: 0; color: var(--sw-text); }
.sw-prose a { text-decoration: underline; text-underline-offset: 3px; }
.sw-prose img { border-radius: var(--sw-radius-sm); border: 1px solid var(--sw-border); }
.sw-prose hr { border: none; border-top: 1px solid var(--sw-border); margin: 2em 0; }

/* checklist used in service bodies */
.sw-check { list-style: none; padding: 0; display: grid; gap: .7rem; }
.sw-check li { position: relative; padding-left: 1.9rem; color: var(--sw-text); }
.sw-check li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--sw-green); font-weight: 700; font-family: var(--sw-mono); }
.sw-check--2col { grid-template-columns: repeat(2, 1fr); gap: .7rem 2rem; }
.sw-check .sw-check__head { padding-left: 0; margin-top: .3rem; color: var(--sw-faint); font-family: var(--sw-mono); font-size: .82rem; letter-spacing: .04em; text-transform: uppercase; }
.sw-check .sw-check__head::before { content: none; }

/* -------------------------- support packages ---------------------- */
.sw-pkgs { align-items: stretch; margin-top: .6rem; }
.sw-pkg { position: relative; }
.sw-pkg--featured { border-color: var(--sw-gold); box-shadow: var(--sw-glow-gold); }
.sw-pkg__badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--sw-gold); color: #1a1407; font-family: var(--sw-mono); font-size: .7rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: .3rem .8rem; border-radius: 100px; white-space: nowrap; }
.sw-pkg__head { border-bottom: 1px solid var(--sw-border); padding-bottom: 1.1rem; margin-bottom: 1.2rem; }
.sw-pkg__name { font-size: 1.6rem; margin-bottom: .35rem; }
.sw-pkg--featured .sw-pkg__name { color: var(--sw-gold); }
.sw-pkg__tagline { color: var(--sw-muted); font-size: .96rem; margin: 0; }
.sw-pkg .sw-check { margin-bottom: 1.6rem; }
.sw-pkg .sw-btn { margin-top: auto; }
.sw-pkg-footnote { color: var(--sw-faint); max-width: 60ch; margin: 2.2rem auto 0; font-size: .9rem; }

/* ----------------------------- contact ---------------------------- */
.sw-contact-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.sw-form { display: grid; gap: 1.1rem; }
.sw-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.sw-field { display: grid; gap: .4rem; }
.sw-field label { font-family: var(--sw-mono); font-size: .82rem; color: var(--sw-muted); }
.sw-field label .req { color: var(--sw-gold); }
.sw-input, .sw-textarea, .sw-select {
  width: 100%; background: var(--sw-bg-2); border: 1px solid var(--sw-border-2); color: var(--sw-text);
  border-radius: var(--sw-radius-sm); padding: .8rem .9rem; font: inherit; transition: border-color .18s ease, box-shadow .18s ease;
}
.sw-input:focus, .sw-textarea:focus, .sw-select:focus { outline: none; border-color: var(--sw-gold); box-shadow: 0 0 0 3px rgba(240,208,80,.15); }
.sw-textarea { min-height: 150px; resize: vertical; }
.sw-hp { position: absolute; left: -9999px; opacity: 0; height: 0; width: 0; overflow: hidden; }
.sw-notice { border-radius: var(--sw-radius-sm); padding: .9rem 1.1rem; font-size: .96rem; }
.sw-notice--ok { background: rgba(74,222,128,.1); border: 1px solid rgba(74,222,128,.35); color: #b8f5cb; }
.sw-notice--err { background: rgba(255,92,87,.1); border: 1px solid rgba(255,92,87,.35); color: #ffc4c1; }
.sw-info-card { background: var(--sw-surface); border: 1px solid var(--sw-border); border-radius: var(--sw-radius); padding: 1.6rem; }
.sw-info-card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 1.1rem; }
.sw-info-card li { display: flex; gap: .8rem; }
.sw-info-card svg { width: 20px; height: 20px; color: var(--sw-gold); flex-shrink: 0; margin-top: 3px; }
.sw-info-card .lbl { font-family: var(--sw-mono); font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; color: var(--sw-faint); }
.sw-info-card .val { color: var(--sw-text); font-weight: 600; }
.sw-info-card a.val:hover { color: var(--sw-gold); }

/* Contact Form 7 — match the theme's form styling */
.wpcf7 .sw-field .wpcf7-form-control-wrap { display: block; }
.wpcf7 .sw-form { margin: 0; }
.wpcf7-not-valid-tip { color: var(--sw-red); font-size: .82rem; margin-top: .3rem; }
.wpcf7 .sw-input.wpcf7-not-valid, .wpcf7 .sw-textarea.wpcf7-not-valid, .wpcf7 .sw-select.wpcf7-not-valid { border-color: var(--sw-red); }
.wpcf7-response-output { border-radius: var(--sw-radius-sm); padding: .9rem 1.1rem !important; font-size: .96rem; margin: 1.3rem 0 0 !important; border: 1px solid var(--sw-border-2) !important; color: var(--sw-text); }
.wpcf7 form.sent .wpcf7-response-output { background: rgba(74,222,128,.1); border-color: rgba(74,222,128,.35) !important; color: #b8f5cb; }
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.failed .wpcf7-response-output, .wpcf7 form.spam .wpcf7-response-output { background: rgba(255,92,87,.1); border-color: rgba(255,92,87,.35) !important; color: #ffc4c1; }
.wpcf7-spinner { background-color: var(--sw-gold); }
.wpcf7 input.wpcf7-submit { width: auto; }

/* ----------------------------- blog ------------------------------- */
.sw-post-card { background: var(--sw-surface); border: 1px solid var(--sw-border); border-radius: var(--sw-radius); overflow: hidden; display: flex; flex-direction: column; height: 100%; transition: transform .2s ease, border-color .2s ease; }
.sw-post-card:hover { transform: translateY(-4px); border-color: var(--sw-border-2); }
.sw-post-card__thumb { aspect-ratio: 16/9; background: var(--sw-surface-2); overflow: hidden; display: block; }
.sw-post-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.sw-post-card__ph {
  width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .5rem;
  color: var(--sw-gold);
  background:
    radial-gradient(60% 100% at 50% 0%, rgba(240,208,80,.12), transparent 65%),
    linear-gradient(var(--sw-border) 1px, transparent 1px) 0 0 / 22px 22px,
    linear-gradient(90deg, var(--sw-border) 1px, transparent 1px) 0 0 / 22px 22px,
    var(--sw-bg-2);
}
.sw-post-card__ph .sw-mono { color: var(--sw-faint); font-size: .82rem; }
.sw-post-card__body { padding: 1.4rem; display: flex; flex-direction: column; flex: 1; }
.sw-post-card__meta { font-family: var(--sw-mono); font-size: .8rem; color: var(--sw-faint); margin-bottom: .6rem; }
.sw-post-card h3 { font-size: 1.2rem; }
.sw-post-card h3 a { color: var(--sw-text); }
.sw-post-card h3 a:hover { color: var(--sw-gold); }
.sw-post-card p { color: var(--sw-muted); font-size: .96rem; }
.sw-pagination { display: flex; gap: .5rem; justify-content: center; margin-top: 3rem; flex-wrap: wrap; }
.sw-pagination a, .sw-pagination span { padding: .55rem .9rem; border-radius: 9px; border: 1px solid var(--sw-border-2); font-family: var(--sw-mono); font-size: .9rem; color: var(--sw-muted); }
.sw-pagination .current { background: var(--sw-gold); color: #1a1407; border-color: var(--sw-gold); }
.sw-pagination a:hover { border-color: var(--sw-gold); color: var(--sw-gold); }

/* single service sidebar */
.sw-service-layout { display: grid; grid-template-columns: 1fr 320px; gap: clamp(1.5rem,4vw,3rem); align-items: start; }
.sw-sidebar { position: sticky; top: 96px; display: grid; gap: 1.2rem; }
.sw-sidebar .sw-card h3 { font-size: 1.1rem; }
.sw-service-nav { list-style: none; padding: 0; margin: 0; display: grid; gap: .2rem; }
.sw-service-nav a { display: flex; align-items: center; gap: .6rem; padding: .6rem .7rem; border-radius: 8px; color: var(--sw-muted); font-size: .95rem; }
.sw-service-nav a:hover, .sw-service-nav .is-current a { background: var(--sw-surface-2); color: var(--sw-text); }
.sw-service-nav .is-current a { color: var(--sw-gold); }

/* 404 */
.sw-404 { text-align: center; padding-block: clamp(4rem, 10vw, 8rem); }
.sw-404 .code { font-family: var(--sw-mono); font-size: clamp(4rem, 14vw, 9rem); color: var(--sw-gold); line-height: 1; font-weight: 700; }

/* ---------------------------- animations -------------------------- */
@keyframes sw-blink { 50% { opacity: 0; } }
@keyframes sw-pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
@keyframes sw-scroll { to { transform: translateX(-50%); } }
.sw-reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.sw-reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .sw-reveal { opacity: 1; transform: none; }
}

/* ---------------------------- responsive -------------------------- */
@media (max-width: 1024px) {
  .sw-service-layout { grid-template-columns: 1fr; }
  .sw-sidebar { position: static; }
  .sw-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .sw-steps { grid-template-columns: repeat(2, 1fr); }
  .sw-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .sw-nav, .sw-header__cta .sw-btn-ghost { display: none; }
  .sw-nav-toggle { display: inline-flex; }
  .sw-nav.is-open {
    display: flex; position: fixed; inset: 74px 0 0 0; background: var(--sw-bg);
    flex-direction: column; align-items: stretch; padding: 1.4rem clamp(1.1rem,4vw,2.2rem); gap: 0; z-index: 99; overflow-y: auto;
  }
  .sw-nav.is-open ul { flex-direction: column; align-items: stretch; gap: 0; width: 100%; }
  .sw-nav.is-open a { padding: 1rem 0; border-bottom: 1px solid var(--sw-border); font-size: 1.15rem; }
  .sw-nav.is-open .sub-menu { position: static; transform: none; opacity: 1; visibility: visible; box-shadow: none; border: none; background: none; padding-left: 1rem; }
}
@media (max-width: 720px) {
  body { font-size: 16px; }
  .sw-grid-2, .sw-grid-3, .sw-grid-4 { grid-template-columns: 1fr; }
  .sw-check--2col { grid-template-columns: 1fr; }
  .sw-stats { grid-template-columns: repeat(2, 1fr); }
  .sw-stats--3 { grid-template-columns: 1fr; }
  .sw-steps { grid-template-columns: 1fr; }
  .sw-contact-grid, .sw-footer__grid { grid-template-columns: 1fr; }
  .sw-form .row { grid-template-columns: 1fr; }
  .sw-footer__bottom { flex-direction: column; }
}

/* WP core alignment / admin bar niceties */
.alignwide { width: min(100%, 1100px); margin-inline: auto; }
.alignfull { width: 100%; }
.wp-caption-text, figcaption { color: var(--sw-faint); font-size: .85rem; text-align: center; margin-top: .5rem; }
body.admin-bar .sw-header { top: 32px; }
@media (max-width: 782px) { body.admin-bar .sw-header { top: 46px; } }
