/*
Theme Name: WebPro360
Theme URI: https://webpro360.com/
Author: WebPro360
Author URI: https://webpro360.com/
Description: WebPro360 child theme for Kadence. Locks the palette, typography, and spacing defined in theme.json and carries the small set of custom CSS hooks the homepage patterns depend on. Do not edit in the WordPress admin — edit the child theme in version control.
Template: kadence
Version: 1.0.1
Requires at least: 6.5
Requires PHP: 8.2
License: Proprietary
Text Domain: webpro360
*/

/* ─────────────────────────────────────────────────────────────
   WebPro360 child theme — the custom CSS hooks.
   theme.json handles 90%. These rules handle the 10% it can't.
   Each block is paired with a pattern in /patterns/.
   ───────────────────────────────────────────────────────────── */

/* Custom timing tokens used by small transitions */
:root {
  --wp-dur-fast: 140ms;
  --wp-dur-base: 220ms;
  --wp-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ─── Shared button affordances ──────────────────────────────── */
.wp-btn .wp-btn__arrow {
  display: inline-block;
  margin-left: 6px;
  transition: transform var(--wp-dur-fast) var(--wp-ease-out);
}
.wp-btn:hover .wp-btn__arrow { transform: translateX(2px); }

.wp-btn--amber .wp-element-button:hover,
.wp-btn--amber:hover .wp-element-button {
  background-color: var(--wp--preset--color--amber-600) !important;
}

/* ─── Hero Masthead (see patterns/_hero-masthead.css extended here) ── */
.wp-hero--masthead { position: relative; overflow: hidden; min-height: 820px; display: flex; flex-direction: column; }
.wp-hero--masthead::before { content:""; position:absolute; inset:0; background-image: radial-gradient(rgba(60,200,212,0.09) 1px, transparent 1px); background-size: 22px 22px; pointer-events:none; z-index:0; }
.wp-hero--masthead::after  { content:""; position:absolute; inset:0; background: radial-gradient(ellipse 900px 500px at 80% -10%, rgba(31,168,184,0.12), transparent 60%); pointer-events:none; z-index:0; }
.wp-hero__inner { position: relative; z-index: 1; margin-inline: auto; width: 100%; max-width: 1200px; flex: 1 1 auto; display: flex; flex-direction: column; }
.wp-hero__eyebrow { align-items: center; gap: 14px; }
.wp-hero__rule { display: inline-block; width: 36px; height: 1px; background: var(--wp--preset--color--teal-500); }
.wp-hero__h1 .wp-hero__accent { font-family: var(--wp--preset--font-family--serif); font-style: italic; font-weight: 400; color: var(--wp--preset--color--teal-300); letter-spacing: -0.02em; }
.wp-hero__strip-cols > .wp-block-column + .wp-block-column { border-left: 1px solid rgba(255,255,255,0.12); padding-left: 28px; }
.wp-hero__strip-cols > .wp-block-column { padding-right: 24px; }
@media (max-width: 782px) {
  .wp-hero--masthead { min-height: 0; }
  .wp-hero__strip-cols > .wp-block-column + .wp-block-column { border-left: none; border-top: 1px solid rgba(255,255,255,0.12); padding-left: 0; padding-top: 20px; }
}

/* ─── AI Stance ──────────────────────────────────────────────── */
.wp-ai-stance__quote { position: relative; padding-left: 28px; }
.wp-ai-stance__quote::before { content:""; position:absolute; left:0; top:8px; bottom:8px; width: 2px; background: var(--wp--preset--color--teal-500); }
.wp-ai-stance__counter { font-family: var(--wp--preset--font-family--sans); font-style: normal; font-weight: 500; color: var(--wp--preset--color--teal-600); letter-spacing: -0.03em; }
.wp-ai-stance__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 18px; }
.wp-ai-stance__list li { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; }
.wp-ai-stance__mark { width: 22px; height: 22px; color: var(--wp--preset--color--teal-600); flex-shrink: 0; margin-top: 2px; }
.wp-ai-stance__mark--dash { border: 1.5px solid var(--wp--preset--color--ink-300); border-radius: 4px; display: inline-flex; align-items: center; justify-content: center; }
.wp-ai-stance__mark--dash > span { width: 10px; height: 1.5px; background: var(--wp--preset--color--ink-400); display: block; }
.wp-ai-stance__item-t { font-family: var(--wp--preset--font-family--sans); font-size: 20px; font-weight: 500; color: var(--wp--preset--color--navy-900); letter-spacing: -0.015em; line-height: 1.2; margin: 0; }
.wp-ai-stance__col--dont .wp-ai-stance__item-t { color: var(--wp--preset--color--ink-600); }
.wp-ai-stance__item-d { font-size: 15px; color: var(--wp--preset--color--ink-600); margin: 4px 0 0; line-height: 1.5; }
.wp-ai-stance__col--dont .wp-ai-stance__item-d { color: var(--wp--preset--color--ink-500); }
.wp-ai-stance__principals { display: flex; align-items: center; gap: 16px; }
.wp-ai-stance__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--wp--preset--color--navy-900); color: var(--wp--preset--color--teal-300); display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 15px; }
.wp-ai-stance__principals-n { font-size: 15px; font-weight: 500; color: var(--wp--preset--color--navy-900); }
.wp-ai-stance__principals-m { font-size: 13px; color: var(--wp--preset--color--ink-600); }
@media (max-width: 720px) {
  .wp-ai-stance__cols { grid-template-columns: 1fr !important; }
  .wp-ai-stance__col { border-right: none !important; padding: 24px 0 !important; border-top: 1px solid var(--wp--preset--color--ink-200); }
  .wp-ai-stance__signature { flex-direction: column; align-items: flex-start; gap: 20px; }
}

/* ─── Verticals ──────────────────────────────────────────────── */
.wp-verticals__grid { display: grid; grid-template-columns: repeat(2, 1fr) 0.8fr; gap: 24px; }
@media (max-width: 1023px) { .wp-verticals__grid { grid-template-columns: 1fr 1fr; } .wp-vcard--future { grid-column: 1 / -1; } }
@media (max-width: 720px)  { .wp-verticals__grid { grid-template-columns: 1fr; } }
.wp-vcard { background:#fff; border:1px solid var(--wp--preset--color--ink-200); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 4px 12px rgba(15,40,70,0.06); transition: transform var(--wp-dur-base) var(--wp-ease-out), box-shadow var(--wp-dur-base) var(--wp-ease-out); }
.wp-vcard:hover { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(15,40,70,0.10), 0 4px 8px rgba(15,40,70,0.05); }
.wp-vcard__preview { position: relative; aspect-ratio: 16 / 10; overflow: hidden; border-bottom: 1px solid var(--wp--preset--color--ink-100); }
.wp-vcard__preview img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.wp-vcard__preview-scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,0) 60%, rgba(255,255,255,0.85) 100%); pointer-events: none; }
.wp-vcard__meta { position: absolute; left: 20px; bottom: 18px; display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; background:#fff; border: 1px solid var(--wp--preset--color--ink-200); border-radius: 999px; font-family: var(--wp--preset--font-family--mono); font-size: 11px; color: var(--wp--preset--color--navy-900); }
.wp-vcard__meta-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--v-accent); }
.wp-vcard__body { padding: 28px; display: flex; flex-direction: column; gap: 16px; flex: 1; }
.wp-vcard__head { display: flex; align-items: center; justify-content: space-between; }
.wp-vcard__wordmark { height: 28px; width: auto; }
.wp-vcard__badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; background: var(--v-soft); color: var(--v-accent); font-family: var(--wp--preset--font-family--mono); font-size: 10.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; }
.wp-vcard__badge-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.wp-vcard__badge--outline { background: transparent; border: 1px solid var(--wp--preset--color--ink-300); color: var(--wp--preset--color--ink-600); align-self: flex-start; }
.wp-vcard__tagline { font-size: 22px; font-weight: 500; color: var(--wp--preset--color--navy-900); letter-spacing: -0.02em; line-height: 1.25; margin: 0; text-wrap: balance; }
.wp-vcard__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; padding-top: 12px; border-top: 1px solid var(--wp--preset--color--ink-100); margin: 0; }
.wp-vcard__stats > div { padding-top: 14px; }
.wp-vcard__stats > div + div { border-left: 1px solid var(--wp--preset--color--ink-100); padding-left: 16px; }
.wp-vcard__stats dt { font-family: var(--wp--preset--font-family--mono); font-size: 22px; font-weight: 600; color: var(--v-accent); letter-spacing: -0.01em; line-height: 1; }
.wp-vcard__stats dd { font-size: 11px; color: var(--wp--preset--color--ink-500); letter-spacing: 0.06em; text-transform: uppercase; margin: 6px 0 0; }
.wp-vcard__foot { margin-top: auto; padding-top: 12px; display: flex; justify-content: space-between; align-items: center; }
.wp-vcard__site { font-family: var(--wp--preset--font-family--mono); font-size: 12px; color: var(--wp--preset--color--ink-500); }
.wp-vcard__link { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 500; color: var(--v-accent); text-decoration: none; }
.wp-vcard--future { background: transparent; border: 1.5px dashed var(--wp--preset--color--ink-300); box-shadow: none; padding: 28px; gap: 16px; }
.wp-vcard--future:hover { transform: none; box-shadow: none; }
.wp-vcard__future-h { font-size: 30px; font-weight: 500; letter-spacing: -0.025em; color: var(--wp--preset--color--navy-900); line-height: 1.1; margin: 8px 0 0; text-wrap: balance; }
.wp-vcard__future-d { font-size: 14px; line-height: 1.55; color: var(--wp--preset--color--ink-600); margin: 0; }
.wp-vcard__future-prompt { margin-top: auto; display: flex; flex-direction: column; gap: 10px; padding: 16px; background:#fff; border: 1px solid var(--wp--preset--color--ink-100); border-radius: 6px; }
.wp-vcard__future-lbl { font-size: 12px; color: var(--wp--preset--color--ink-500); letter-spacing: 0.08em; text-transform: uppercase; }
.wp-vcard__future-link { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 500; color: var(--wp--preset--color--teal-600); text-decoration: none; }

/* ─── Services ───────────────────────────────────────────────── */
.wp-services__list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--wp--preset--color--ink-200); counter-reset: svc; }
.wp-service a { display: grid; grid-template-columns: 80px 1fr 40px; gap: 24px; align-items: start; padding: 28px 16px; border-bottom: 1px solid var(--wp--preset--color--ink-200); color: inherit; text-decoration: none; transition: background var(--wp-dur-fast) var(--wp-ease-out); }
.wp-service a:hover { background: var(--wp--preset--color--ink-050); }
.wp-service a:hover .wp-service__arrow { transform: translateX(4px); color: var(--wp--preset--color--teal-600); }
.wp-service__num { font-family: var(--wp--preset--font-family--mono); color: var(--wp--preset--color--teal-600); font-size: 16px; font-weight: 500; padding-top: 6px; letter-spacing: 0.04em; }
.wp-service__t { font-size: 22px; font-weight: 500; color: var(--wp--preset--color--navy-900); letter-spacing: -0.015em; margin: 0; line-height: 1.25; }
.wp-service__d { font-size: 15.5px; color: var(--wp--preset--color--ink-600); line-height: 1.55; margin: 6px 0 0; max-width: 56ch; }
.wp-service__arrow { font-size: 20px; color: var(--wp--preset--color--navy-900); padding-top: 6px; transition: transform var(--wp-dur-fast) var(--wp-ease-out), color var(--wp-dur-fast) var(--wp-ease-out); justify-self: end; }

/* ─── Longevity ──────────────────────────────────────────────── */
.wp-longevity__timeline { position: relative; max-width: 1000px; margin: 0 auto; }
.wp-longevity__row { position: absolute; top: 40px; left: 0; right: 0; height: 1px; background: rgba(255,255,255,0.12); }
.wp-longevity__marks { list-style: none; display: grid; grid-template-columns: repeat(5, 1fr); gap: 32px; padding: 0; margin: 0; position: relative; }
.wp-longevity__marks li { padding-top: 64px; position: relative; }
.wp-longevity__marks li::before { content: ""; position: absolute; top: 36px; left: 0; width: 9px; height: 9px; background: var(--wp--preset--color--teal-400); border-radius: 50%; }
.wp-longevity__n { display: block; font-family: var(--wp--preset--font-family--serif); font-style: italic; font-weight: 400; color: var(--wp--preset--color--teal-400); font-size: 4.75rem; line-height: 1; letter-spacing: -0.02em; margin-bottom: 10px; }
.wp-longevity__marks li p { font-size: 14px; color: var(--wp--preset--color--ink-300); line-height: 1.45; max-width: 16ch; margin: 0; }
@media (max-width: 720px) { .wp-longevity__marks { grid-template-columns: 1fr 1fr; gap: 32px 24px; } .wp-longevity__row { display: none; } .wp-longevity__marks li { padding-top: 0; } .wp-longevity__marks li::before { display: none; } }

/* ─── Testimonials ───────────────────────────────────────────── */
.wp-testimonials__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.wp-tcard { display: flex; flex-direction: column; gap: 20px; background: #fff; border: 1px solid var(--wp--preset--color--ink-200); border-radius: 10px; padding: 28px; box-shadow: 0 1px 3px rgba(15,40,70,0.04); }
.wp-tcard__stat { display: flex; flex-direction: column; gap: 6px; }
.wp-tcard__stat span { font-family: var(--wp--preset--font-family--mono); font-weight: 600; font-size: 3rem; color: var(--wp--preset--color--teal-500); line-height: 1; letter-spacing: -0.015em; }
.wp-tcard__stat em { font-style: normal; font-family: var(--wp--preset--font-family--mono); font-size: 12px; color: var(--wp--preset--color--ink-600); letter-spacing: 0.08em; text-transform: uppercase; }
.wp-tcard__quote { font-family: var(--wp--preset--font-family--sans); font-style: normal; font-size: 17px; color: var(--wp--preset--color--navy-900); line-height: 1.5; margin: 0; padding: 0; border: none; text-wrap: pretty; }
.wp-tcard__attr { margin-top: auto; padding-top: 16px; border-top: 1px solid var(--wp--preset--color--ink-200); }
.wp-tcard__attr strong { display: block; font-weight: 500; color: var(--wp--preset--color--navy-900); font-size: 14px; }
.wp-tcard__attr span { display: block; font-size: 13px; color: var(--wp--preset--color--ink-600); margin-top: 2px; }
.wp-testimonials__more { margin-top: 32px; font-family: var(--wp--preset--font-family--mono); font-size: 13px; text-align: right; }
.wp-testimonials__more a { color: var(--wp--preset--color--teal-600); text-decoration: none; }
@media (max-width: 900px) { .wp-testimonials__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .wp-testimonials__grid { grid-template-columns: 1fr; } }

/* ─── ShieldPRO ──────────────────────────────────────────────── */
.wp-shieldpro__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.wp-shieldpro__list li { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; color: var(--wp--preset--color--ink-300); font-size: 15px; line-height: 1.55; }
.wp-shieldpro__list svg { width: 20px; height: 20px; color: var(--wp--preset--color--teal-400); flex-shrink: 0; margin-top: 2px; }
.wp-shieldpro__list strong { color: var(--wp--preset--color--ink-050); font-weight: 500; }
.wp-fleet { margin: 0; background: var(--wp--preset--color--navy-950); border: 1px solid rgba(255,255,255,0.08); border-radius: 10px; overflow: hidden; }
.wp-fleet__head { display: flex; align-items: center; gap: 10px; padding: 14px 20px; border-bottom: 1px solid rgba(255,255,255,0.08); font-family: var(--wp--preset--font-family--mono); font-size: 12px; color: var(--wp--preset--color--ink-400); }
.wp-fleet__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--wp--preset--color--teal-400); box-shadow: 0 0 8px currentColor; color: var(--wp--preset--color--teal-400); }
.wp-fleet__title { color: var(--wp--preset--color--ink-050); font-weight: 500; flex: 1; }
.wp-fleet__body { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin: 0; padding: 0; }
.wp-fleet__body > div { padding: 18px 20px; border-top: 1px solid rgba(255,255,255,0.06); }
.wp-fleet__body > div:nth-child(even) { border-left: 1px solid rgba(255,255,255,0.06); }
.wp-fleet__body dt { font-family: var(--wp--preset--font-family--mono); font-size: 11px; color: var(--wp--preset--color--ink-500); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
.wp-fleet__body dd { margin: 0; font-family: var(--wp--preset--font-family--mono); font-size: 1.75rem; font-weight: 500; color: var(--wp--preset--color--ink-050); line-height: 1; }
.wp-fleet__body dd small { font-size: 13px; color: var(--wp--preset--color--teal-300); margin-left: 3px; font-weight: 400; }
.wp-fleet__foot { padding: 12px 20px; border-top: 1px solid rgba(255,255,255,0.08); font-family: var(--wp--preset--font-family--mono); font-size: 11px; color: var(--wp--preset--color--ink-500); }
@media (max-width: 782px) { .wp-fleet__body { grid-template-columns: 1fr; } .wp-fleet__body > div:nth-child(even) { border-left: none; } }

/* ─── Sticky nav (header partial) ────────────────────────────── */
.site-header.wp-nav--scrolled { background: rgba(255,255,255,0.82); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--wp--preset--color--ink-200); box-shadow: 0 1px 3px rgba(15,40,70,0.04); }
