/*
 * ow-rebuild.css
 * Styles supporting the native-widget Elementor rebuild of the portfolio page.
 * Enqueued from functions.php after style.css.
 *
 * Naming: every class in here is also referenced by an Elementor widget's
 * "CSS Classes" field. Editing visual style → edit this file. Editing copy
 * → use Elementor's UI.
 */

/* ─── Generic helpers ─────────────────────────────────────────────── */

.ow-section-head-row {
  display: flex;
  align-items: center;
  gap: 20px;
}
.ow-section-head-row .ow-section-num {
  font-family: var(--serif);
  font-size: 13px;
  font-weight: 300;
  color: var(--accent);
  letter-spacing: .1em;
  flex-shrink: 0;
}
.ow-section-head-row h2.ow-section-title {
  font-family: var(--serif) !important;
  font-size: clamp(32px, 4vw, 52px) !important;
  font-weight: 300 !important;
  color: var(--ink) !important;
  margin: 0 !important;
  flex-shrink: 0;
}
.ow-section-head-row .ow-section-rule {
  flex: 1;
  height: 1px;
  background: var(--ink-20);
  margin-left: 24px;
}

/* dark variants */
.ow-section-head-row-dark h2.ow-section-title-dark {
  color: var(--warm-white) !important;
}
.ow-section-head-row-dark .ow-section-rule-dark {
  background: rgba(253,252,249,.15);
}

.ow-eyebrow-plain {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}

/* ─── HERO ────────────────────────────────────────────────────────── */

.ow-hero-copy-col { min-height: 90vh; display: flex; flex-direction: column; justify-content: center; }
.ow-hero-photo-col { min-height: 90vh; position: relative; }

.ow-hero-logo img { width: 150px !important; height: 150px !important; object-fit: contain; }

.ow-hero-title .elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: clamp(48px, 5.5vw, 80px) !important;
  font-weight: 300 !important;
  line-height: 1.06 !important;
  letter-spacing: -.01em !important;
  color: var(--ink);
  margin: 0;
}
.ow-hero-title-accent .elementor-heading-title {
  color: var(--accent);
  font-style: italic;
}

.ow-hero-deck {
  font-size: 17px;
  font-weight: 300;
  color: var(--ink-60);
  line-height: 1.8;
  max-width: 440px;
  margin: 0;
}

.ow-hero-actions { margin: 0 !important; }
.ow-hero-actions .elementor-column { width: auto !important; }

.ow-hero-portrait { height: 90vh; overflow: hidden; }
.ow-hero-portrait img {
  width: 100% !important;
  height: 90vh !important;
  object-fit: cover;
  object-position: top center;
  display: block;
}

/* Floating credential badge */
.ow-hero-photo-col .ow-hero-credential-wrap {
  position: absolute;
  bottom: 40px;
  left: -20px;
  z-index: 5;
  margin: 0 !important;
}
.ow-hero-credential {
  background: var(--warm-white);
  border: 1px solid var(--ink-20);
  padding: 16px 24px;
  border-radius: 3px;
  box-shadow: 0 8px 32px rgba(26,24,20,.08);
  display: inline-block;
}
.ow-hero-credential strong {
  display: block;
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 400;
  color: var(--ink);
}
.ow-hero-credential span {
  font-size: 12px;
  font-weight: 400;
  color: var(--ink-60);
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* Hero ghost buttons */
.ow-btn-ghost .elementor-button {
  background: transparent !important;
  color: var(--ink-60) !important;
  padding: 14px 0 !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  letter-spacing: .1em;
  text-transform: uppercase;
  box-shadow: none !important;
  border: none !important;
}
.ow-btn-ghost .elementor-button:hover { color: var(--accent) !important; }

.ow-btn-primary .elementor-button {
  background: var(--ink) !important;
  color: var(--warm-white) !important;
  padding: 14px 32px !important;
  border-radius: 2px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.ow-btn-primary .elementor-button:hover { background: var(--accent) !important; }

/* ─── ABOUT — STATS ──────────────────────────────────────────────── */

.ow-stat-col { padding: 80px 60px; }

.ow-stat-row {
  border-top: 1px solid var(--ink-20);
  margin: 0 !important;
  padding-top: 24px;
  padding-bottom: 24px;
}
.ow-stat-number .elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: 48px !important;
  font-weight: 300 !important;
  color: var(--ink) !important;
  line-height: 1 !important;
  margin: 0 !important;
}
.ow-stat-label {
  font-size: 12px;
  font-weight: 400;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-60);
  margin: 0;
}

.ow-about-body p {
  font-size: 17px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.8;
  margin: 0 0 20px 0;
}
.ow-about-body p:last-child { margin-bottom: 0; }

/* ─── SKILLS ─────────────────────────────────────────────────────── */

.ow-skill-card {
  background: var(--warm-white);
  padding: 40px 36px;
  border: 1px solid var(--ink-20);
  border-radius: 2px;
  transition: background .2s;
}
.ow-skill-card:hover { background: var(--accent-light); }

.ow-skill-glyph .elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 26px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  margin: 0 !important;
}

.ow-skill-title .elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: 22px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  margin: 0 !important;
}

.ow-skill-desc {
  font-size: 14px;
  font-weight: 300;
  line-height: 1.7;
  color: var(--ink-60);
  margin: 0;
}

.ow-tag-list { display: flex; flex-wrap: wrap; gap: 6px; }
.ow-tag-list .ow-tag {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent);
  padding: 4px 10px;
  border-radius: 1px;
  margin: 0;
}

/* ─── FEATURED ───────────────────────────────────────────────────── */

.ow-featured-title .elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: clamp(26px, 3vw, 42px) !important;
  font-weight: 300 !important;
  line-height: 1.25 !important;
  color: var(--ink) !important;
  margin: 0 !important;
}

.ow-comp-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}
.ow-comp-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  margin-top: 7px;
  flex-shrink: 0;
}
.ow-comp-text strong {
  display: block;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 4px;
}
.ow-comp-text span {
  font-size: 14px;
  font-weight: 300;
  color: var(--ink-60);
  line-height: 1.6;
}

/* ─── EXPERIENCE TIMELINE (dark) ─────────────────────────────────── */

.ow-section-dark { color: var(--warm-white); }

.ow-timeline-item-dark {
  padding: 44px 0 !important;
  border-top: 1px solid rgba(253,252,249,.12);
  margin: 0 !important;
}
.ow-timeline-item-dark:last-child { border-bottom: 1px solid rgba(253,252,249,.12); }

.ow-timeline-date .elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent) !important;
  margin: 0 !important;
}
.ow-timeline-org .elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: 26px !important;
  font-weight: 300 !important;
  color: var(--warm-white) !important;
  line-height: 1.1 !important;
  margin: 0 !important;
}
.ow-timeline-sub {
  font-size: 12px;
  font-weight: 300;
  color: rgba(253,252,249,.4);
  margin: 0;
}
.ow-timeline-role .elementor-heading-title {
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(253,252,249,.6) !important;
  margin: 0 !important;
}
.ow-timeline-intro {
  font-size: 15px;
  font-weight: 300;
  line-height: 1.75;
  color: rgba(253,252,249,.65);
  margin: 0;
}
.ow-timeline-bullets {
  padding: 0;
  margin: 0;
  list-style: none;
}
.ow-timeline-bullets li {
  font-size: 14px;
  font-weight: 300;
  color: rgba(253,252,249,.5);
  padding-left: 18px;
  position: relative;
  line-height: 1.6;
  margin-bottom: 8px;
}
.ow-timeline-bullets li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--accent);
}
.ow-timeline-bullets li:last-child { margin-bottom: 0; }

/* ─── EDUCATION CARDS ────────────────────────────────────────────── */

.ow-edu-card {
  border: 1px solid var(--ink-20);
  border-radius: 2px;
  padding: 40px;
  position: relative;
  overflow: hidden;
  background: var(--warm-white);
}
.ow-edu-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent);
}

.ow-tag-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent);
  padding: 4px 10px;
  border-radius: 1px;
}

.ow-edu-title .elementor-heading-title {
  font-family: var(--serif) !important;
  font-size: 28px !important;
  font-weight: 300 !important;
  color: var(--ink) !important;
  margin: 0 !important;
}

.ow-edu-intro {
  font-size: 14px;
  font-weight: 300;
  color: var(--ink-60);
  margin: 0;
}

.ow-edu-row {
  border-top: 1px solid var(--ink-20);
  padding: 14px 0;
}
.ow-edu-row-title {
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 3px;
  line-height: 1.4;
}
.ow-edu-row-sub {
  font-size: 13px;
  font-weight: 300;
  color: var(--ink-60);
  margin-bottom: 8px;
}
.ow-edu-row-body {
  font-size: 13px;
  font-weight: 300;
  color: var(--ink-60);
  line-height: 1.6;
}

/* ─── TOOLS BAND ─────────────────────────────────────────────────── */

.ow-tools-band {
  border-top: 1px solid var(--ink-20);
  border-bottom: 1px solid var(--ink-20);
}
.ow-tools-eyebrow {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--ink-60);
  margin: 0;
  text-align: center;
}

.ow-tool-row {
  margin: 0 !important;
  align-items: baseline !important;
}
.ow-tool-cat {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}
.ow-tool-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ow-tool-chips .ow-tool-chip {
  font-size: 12px;
  color: var(--ink-60);
  background: var(--warm-white);
  border: 1px solid var(--ink-20);
  padding: 6px 14px;
  border-radius: 40px;
  margin: 0;
}

/* ─── CONTACT (dark) ─────────────────────────────────────────────── */

.ow-contact-section { color: rgba(253,252,249,.8); }

.ow-contact-intro {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.8;
  color: rgba(253,252,249,.65);
  margin: 0;
}

.ow-contact-link {
  display: flex;
  align-items: center;
  gap: 16px;
  text-decoration: none !important;
  padding: 16px 0;
  border-top: 1px solid rgba(253,252,249,.1);
}
.ow-contact-link:last-of-type { border-bottom: 1px solid rgba(253,252,249,.1); }
.ow-contact-link-label {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
  min-width: 80px;
}
.ow-contact-link-value {
  font-size: 15px;
  font-weight: 300;
  color: rgba(253,252,249,.8);
}
.ow-contact-link-arrow {
  margin-left: auto;
  color: rgba(253,252,249,.3);
  font-size: 16px;
}
.ow-contact-link:hover .ow-contact-link-value { color: var(--warm-white); }
.ow-contact-link:hover .ow-contact-link-arrow { color: var(--accent); }

.ow-contact-card {
  background: rgba(253,252,249,.04);
  border: 1px solid rgba(253,252,249,.1);
  padding: 44px !important;
  border-radius: 2px;
}
.ow-contact-card-title {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 300;
  color: var(--warm-white);
  margin: 0 0 6px 0;
}
.ow-contact-card-sub {
  font-size: 13px;
  font-weight: 300;
  color: rgba(253,252,249,.4);
  margin: 0 0 24px 0;
}
.ow-contact-card .wpcf7-form-control:not(.wpcf7-submit) {
  width: 100%;
  background: rgba(253,252,249,.06);
  border: 1px solid rgba(253,252,249,.12);
  border-radius: 2px;
  padding: 12px 16px;
  font-size: 14px;
  color: var(--warm-white);
  font-family: var(--sans);
  margin-bottom: 14px;
}
.ow-contact-card .wpcf7-form-control:not(.wpcf7-submit):focus {
  border-color: var(--gold);
  outline: none;
}
.ow-contact-card .wpcf7-submit {
  background: var(--accent);
  color: var(--warm-white);
  border: none;
  padding: 14px 32px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 2px;
}
.ow-contact-card .wpcf7-submit:hover { background: #9e4e2f; }

.ow-contact-logo img { width: 150px !important; height: 150px !important; object-fit: contain; }

/* ─── FOOTER ─────────────────────────────────────────────────────── */

.ow-footer-section { border-top: 1px solid rgba(253,252,249,.08); }
.ow-footer-logo {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 300;
  color: rgba(253,252,249,.4);
}
.ow-footer-copy {
  font-size: 11px;
  font-weight: 300;
  color: rgba(253,252,249,.25);
  letter-spacing: .06em;
}

/* ─── RESPONSIVE ─────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  .ow-hero-copy-col,
  .ow-stat-col,
  .ow-section-dark > .elementor-container > .elementor-column,
  .ow-tools-band > .elementor-container > .elementor-column { padding-left: 48px !important; padding-right: 48px !important; }
}

@media (max-width: 768px) {
  .ow-hero-copy-col {
    padding: 48px 24px !important;
    min-height: auto !important;
  }
  .ow-hero-photo-col {
    min-height: 60vw !important;
  }
  .ow-hero-portrait img {
    height: 60vw !important;
  }
  .ow-hero-photo-col .ow-hero-credential-wrap {
    bottom: 16px;
    left: 16px;
  }

  .ow-stat-col { padding: 48px 24px !important; }

  .ow-section-dark > .elementor-container > .elementor-column,
  .ow-tools-band > .elementor-container > .elementor-column,
  .ow-contact-section > .elementor-container > .elementor-column { padding-left: 24px !important; padding-right: 24px !important; }

  .ow-section-head-row { flex-wrap: wrap; }
  .ow-section-head-row .ow-section-rule { display: none; }

  .ow-tool-row .elementor-column { width: 100% !important; }
  .ow-tool-cat { margin-bottom: 12px; }

  .ow-timeline-item-dark .elementor-column { width: 100% !important; }
  .ow-timeline-item-dark .elementor-column:first-child { margin-bottom: 12px; }

  .ow-footer-section { padding: 24px !important; flex-direction: column; gap: 8px; text-align: center; }
}
