/*
Theme Name: Urban Futures (SaaS demo)
Template: twentytwentyfive
Description: Urban Futures brand child theme — navy + warm gold over Twenty Twenty-Five.
Version: 1.3
Text Domain: uf-saas
*/

/* === Newsreader (display serif) — variable, self-hosted from gstatic =====
   Used selectively for hero/section H1+H2 and stat numbers — keeps the
   editorial weight without converting the whole site to a serif. */
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 200 800;
  font-display: swap;
  src: url('assets/fonts/newsreader-italic-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Newsreader';
  font-style: italic;
  font-weight: 200 800;
  font-display: swap;
  src: url('assets/fonts/newsreader-italic-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url('assets/fonts/newsreader-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Newsreader';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url('assets/fonts/newsreader-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* === Editorial display class — applied via className on hero H1.
   Newsreader at large optical size, near-tight tracking, narrow leading. */
.uf-display {
  font-family: 'Newsreader', Georgia, serif !important;
  font-weight: 400 !important;
  letter-spacing: -0.015em !important;
  line-height: 1.05 !important;
  font-variation-settings: "opsz" 36;
}

/* === Hero typographic plate ("45+" watermark) ============================
   Dropped behind the hero copy at low opacity. Decorative; aria-hidden in
   markup; pointer-events:none so it doesn't block clicks. */
.uf-hero-plate {
  position: absolute;
  right: -0.05em;
  bottom: -0.18em;
  font-family: 'Newsreader', Georgia, serif;
  font-weight: 200;
  font-style: italic;
  font-size: clamp(180px, 30vw, 440px);
  line-height: 0.9;
  color: rgba(29, 62, 94, 0.07);
  pointer-events: none;
  user-select: none;
  z-index: 0;
  font-variation-settings: "opsz" 72;
}
/* Hero copy must sit ABOVE the plate. */
.uf-hero-stack { position: relative; z-index: 1; }

/* === Monumental stats strip =============================================
   Newsreader 600 numbers, gold leading hairline, generous vertical rhythm,
   tabular figures so columns line up. */
.uf-stat { padding-top: 8px; }
.uf-stat::before {
  content: '';
  display: block;
  width: 32px;
  height: 1px;
  background: #b48a3c;
  margin-bottom: 18px;
}
.uf-stat-num {
  font-family: 'Newsreader', Georgia, serif !important;
  font-weight: 600 !important;
  font-size: clamp(40px, 6vw, 88px) !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
  color: #1d3e5e !important;
  font-variant-numeric: lining-nums tabular-nums;
  margin: 0 0 12px 0 !important;
}
.uf-stat-cap {
  font-size: 11px !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase;
  color: #64748b !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}

/* === Chapter eyebrow: leading "NN /" + gold hairline rule before label
   Used on top-level section eyebrows for editorial pagination feel. */
.uf-eyebrow-chap { display: flex; align-items: center; gap: 14px; }
.uf-eyebrow-num {
  font-variant-numeric: tabular-nums;
  opacity: 0.85;
  font-weight: 700;
}
.uf-eyebrow-rule {
  display: inline-block;
  flex: 0 0 56px;
  height: 1px;
  background: #b48a3c;
  opacity: 0.55;
}

/* === Hairline card — replaces 1px-border + 8px-radius "box" treatment.
   Used on stacked Leadership + Services cards. Top rule on every card,
   bottom rule on the final card; cards run flush with each other. */
.uf-card-hairline {
  border: none !important;
  border-top: 1px solid rgba(29, 62, 94, 0.16) !important;
  border-radius: 0 !important;
  padding: 32px 4px !important;
}
.uf-card-hairline:last-of-type {
  border-bottom: 1px solid rgba(29, 62, 94, 0.16) !important;
}

/* === Card-leading number (Newsreader, gold) for numbered cards. */
.uf-card-num {
  display: block;
  font-family: 'Newsreader', Georgia, serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #b48a3c;
  font-variant-numeric: tabular-nums;
  margin: 0 0 6px 0;
  text-transform: none;
}

/* === Navy gradient → flat navy + low-opacity gold dot-grid pattern.
   This selector beats the inline `background:linear-gradient(...)` on
   .uf-on-navy boxes, but only because we removed that inline declaration
   from the markup. */
.uf-on-navy {
  background-color: #1d3e5e !important;
  background-image: radial-gradient(rgba(180, 138, 60, 0.14) 1px, transparent 1px) !important;
  background-size: 14px 14px !important;
  background-position: 0 0 !important;
}

/* ========================================================================
   Existing rules (kept from v0.9)
   ======================================================================== */

/* Navy gradient blocks: force readable contrast. */
.uf-on-navy,
.uf-on-navy p,
.uf-on-navy li,
.uf-on-navy ul,
.uf-on-navy ol,
.uf-on-navy strong { color: #e2eaf3 !important; }
.uf-on-navy h1,
.uf-on-navy h2,
.uf-on-navy h3,
.uf-on-navy h4 { color: #ffffff !important; }
.uf-on-navy li::marker { color: #b48a3c; }
.uf-on-navy a:not(.wp-block-button__link) { color: #b48a3c !important; text-decoration: none; }
.uf-on-navy a:not(.wp-block-button__link):hover { color: #ffffff !important; text-decoration: underline; }
.uf-on-navy .wp-block-button__link { color: #ffffff !important; }
.uf-on-navy .wp-block-button__link:hover { color: #ffffff !important; }
.uf-on-navy .uf-eyebrow { color: #b48a3c !important; }

/* Light cards: list items must be readably dark. */
.wp-block-list,
.wp-block-list li,
.wp-block-group:not(.uf-on-navy) .wp-block-list,
.wp-block-group:not(.uf-on-navy) .wp-block-list li { color: #334155; }
.wp-block-list li::marker { color: #b48a3c; }

/* Buttons. */
.wp-block-button__link { color: #ffffff !important; }
.wp-block-button.is-style-outline .wp-block-button__link { color: #1d3e5e !important; }
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: #1d3e5e !important;
  color: #ffffff !important;
}

/* Kill TT5's automatic block-gap and root padding. */
.wp-site-blocks > * + * { margin-block-start: 0 !important; }
.entry-content > * + * { margin-block-start: 0 !important; }
:where(.wp-site-blocks) { padding-top: 0 !important; }
.wp-block-post-content { padding-top: 0 !important; }

/* Site logo: full requested size. */
.wp-block-site-logo img { max-width: none; }
.wp-block-site-logo a img { display: block; }

/* Footer: tight. */
footer.wp-block-template-part { padding: 0 !important; }
.uf-footer { border-top: 1px solid #e2e8f0; }

/* Header: collapse nav to hamburger below 1024px. */
@media (max-width: 1023.98px) {
  .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: flex !important;
  }
  .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: none !important;
  }
  .wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open {
    position: fixed !important;
    top: 60px !important;
    right: 16px !important;
    bottom: auto !important;
    left: auto !important;
    width: auto !important;
    min-width: 140px;
    max-width: calc(100vw - 32px);
    height: auto !important;
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    background: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18) !important;
    padding: 8px !important;
    align-items: flex-start !important;
  }
  .wp-block-navigation .is-menu-open .wp-block-navigation__responsive-close,
  .wp-block-navigation .is-menu-open .wp-block-navigation__responsive-dialog,
  .wp-block-navigation .is-menu-open .wp-block-navigation__responsive-container-content {
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: none !important;
  }
  .wp-block-navigation .is-menu-open .wp-block-navigation__container,
  .wp-block-navigation .is-menu-open ul {
    flex-direction: column !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    gap: 2px !important;
  }
  .wp-block-navigation .is-menu-open li { width: 100% !important; }
  .wp-block-navigation .is-menu-open .wp-block-navigation-item__content {
    display: block !important;
    padding: 8px 12px !important;
    border-radius: 4px !important;
    color: #1d3e5e !important;
    font-weight: 500;
  }
  .wp-block-navigation .is-menu-open .wp-block-navigation-item__content:hover {
    background: #f4f7fb !important;
  }
  .wp-block-navigation .is-menu-open .wp-block-navigation__responsive-container-close {
    position: absolute !important;
    top: 4px !important;
    right: 4px !important;
    padding: 4px !important;
    z-index: 1;
    display: none !important;
  }
  .has-modal-open { overflow: visible !important; }
}

/* Phone-sized header: shrink Sign in button + logo so they fit. */
@media (max-width: 600px) {
  header .wp-block-button.is-style-outline .wp-block-button__link {
    padding: 4px 10px !important;
    font-size: 12px !important;
  }
  header .wp-block-site-logo img { max-width: 150px !important; height: auto !important; }
}

/* ========================================================================
   Contact Form 7 — brand-aligned styling for the /contact/ form.
   Form template wraps fields in .uf-cf7. CF7's plugin CSS isn't loaded
   (we don't enqueue it), so everything here is the source of truth.
   ======================================================================== */

.uf-cf7 {
  --cf-border: #d3d6dc;
  --cf-border-focus: #1d3e5e;
  --cf-text: #334155;
  --cf-muted: #64748b;
  --cf-accent: #b48a3c;
  --cf-radius: 6px;
}

.uf-cf7 p {
  margin: 0 0 18px 0;
  display: flex;
  flex-direction: column;
}

.uf-cf7 label {
  color: var(--cf-text);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.4;
}

.uf-cf7 label .req {
  color: var(--cf-muted);
  font-weight: 400;
  font-size: 12px;
  margin-left: 4px;
}

/* Form template uses <label>Text<br>[input]</label>; the <br> wastes space. */
.uf-cf7 label br { display: none; }

.uf-cf7 input[type="text"],
.uf-cf7 input[type="email"],
.uf-cf7 input[type="tel"],
.uf-cf7 textarea {
  width: 100%;
  padding: 10px 12px;
  margin-top: 6px;
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius);
  font-family: inherit;
  font-size: 15px;
  line-height: 1.5;
  color: var(--cf-text);
  background: #fff;
  box-shadow: none;
  box-sizing: border-box;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}

.uf-cf7 input:focus,
.uf-cf7 textarea:focus {
  outline: none;
  border-color: var(--cf-border-focus);
  box-shadow: 0 0 0 3px rgba(29, 62, 94, 0.12);
}

.uf-cf7 textarea {
  min-height: 130px;
  resize: vertical;
}

.uf-cf7 ::placeholder { color: #9ca3af; }

.uf-cf7 .wpcf7-form-control-wrap { display: block; }

.uf-cf7 .wpcf7-submit {
  background: var(--cf-border-focus);
  color: #fff;
  border: none;
  padding: 12px 26px;
  font-size: 15px;
  font-weight: 600;
  border-radius: var(--cf-radius);
  cursor: pointer;
  margin-top: 4px;
  transition: background 120ms ease, transform 120ms ease;
}

.uf-cf7 .wpcf7-submit:hover { background: #143052; }
.uf-cf7 .wpcf7-submit:focus { outline: 2px solid var(--cf-accent); outline-offset: 2px; }

.uf-cf7 .wpcf7-spinner {
  background-color: var(--cf-border-focus);
  margin-left: 12px;
}

/* The mystery blue rectangle: CF7 renders an empty .wpcf7-response-output
   div on every form load. Hide when empty; style by form state when filled. */
.wpcf7-response-output {
  margin: 16px 0 0 0;
  padding: 12px 16px;
  border-radius: var(--cf-radius);
  border: 1px solid transparent;
  font-size: 14px;
  line-height: 1.5;
}
.wpcf7-response-output:empty { display: none; }

.wpcf7 form.sent .wpcf7-response-output {
  border-color: #10b981;
  background: #ecfdf5;
  color: #047857;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
  border-color: #f59e0b;
  background: #fffbeb;
  color: #92400e;
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output {
  border-color: #ef4444;
  background: #fef2f2;
  color: #b91c1c;
}

.wpcf7-not-valid { border-color: #ef4444 !important; }
.wpcf7-not-valid-tip {
  color: #b91c1c;
  font-size: 13px;
  margin-top: 4px;
  display: block;
}


/* Footer columns */
.uf-footer__cols {
    gap: 3rem !important;
    align-items: flex-start !important;
}
.uf-footer__col {
    flex: 1 1 180px;
    min-width: 180px;
}
.uf-footer__col h3 {
    color: #1d3e5e;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 0.75rem;
    font-weight: 700;
}
.uf-footer__list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.uf-footer__list li {
    margin: 0.35rem 0;
}
.uf-footer__list a {
    color: inherit;
    text-decoration: none;
}
.uf-footer__list a:hover,
.uf-footer__list a:focus-visible {
    color: #b48a3c;
    text-decoration: underline;
}
.uf-footer__brand a {
    color: inherit;
    text-decoration: none;
}
@media (max-width: 600px) {
    .uf-footer__cols { gap: 1.5rem !important; }
    .uf-footer__col { flex: 1 1 100%; }
}

/* ---------- Platform diagram (refined editorial blueprint) ---------- */
.uf-platform-diagram {
    position: relative;
    max-width: 1100px;
    margin: 64px auto 64px;
    padding: 0 24px;
    text-align: center;
}

.uf-platform-diagram__kicker {
    font-family: 'Fira Sans', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #b48a3c;
    margin: 0 0 12px;
}

.uf-platform-diagram__title {
    font-family: 'Manrope', sans-serif;
    color: #1d3e5e;
    font-size: clamp(24px, 3.4vw, 34px);
    line-height: 1.18;
    font-weight: 700;
    margin: 0 0 14px;
    letter-spacing: -0.005em;
}

.uf-platform-diagram__lede {
    max-width: 660px;
    margin: 0 auto 40px;
    color: #5d6b80;
    font-size: 16px;
    line-height: 1.6;
}

.uf-platform-diagram__frame {
    position: relative;
    max-width: 920px;
    margin: 0 auto;
    padding: 32px 20px 24px;
    background:
        radial-gradient(ellipse at 50% 0%, rgba(180,138,60,0.06), transparent 65%),
        linear-gradient(180deg, #f4f7fb 0%, #e8eef6 100%);
    border: 1px solid rgba(29,62,94,0.08);
    border-radius: 18px;
    box-shadow:
        0 1px 0 rgba(255,255,255,0.7) inset,
        0 24px 60px -28px rgba(29,62,94,0.22);
}

.uf-platform-diagram__svg {
    display: block;
    width: 100%;
    height: auto;
    max-width: 880px;
    margin: 0 auto;
}

.uf-pd-mod > circle:first-of-type {
    transition: stroke 220ms ease, stroke-width 220ms ease, transform 220ms ease;
    transform-origin: center;
    transform-box: fill-box;
}
.uf-pd-mod:hover > circle:first-of-type {
    stroke: #b48a3c;
    stroke-width: 2;
    transform: scale(1.04);
}

@keyframes uf-pd-fade-in {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}
.uf-platform-diagram__frame {
    animation: uf-pd-fade-in 700ms cubic-bezier(0.22, 0.94, 0.42, 1.06) both;
}

@media (max-width: 520px) {
    .uf-platform-diagram__frame { padding: 16px 8px; border-radius: 12px; }
}

@media (prefers-reduced-motion: reduce) {
    .uf-platform-diagram__frame { animation: none !important; }
    .uf-pd-mod > circle:first-of-type { transition: none !important; }
}
