/*
 Theme Name:   Sinatra Child
 Theme URI:    https://wso-academy.com
 Description:  Child theme for Sinatra with LearnDash compatibility tweaks.
 Author:       WSO Academy
 Author URI:   https://wso-academy.com
 Template:     sinatra
 Version:      1.0.0
 Text Domain:  sinatra-child
*/

@import url('https://fonts.googleapis.com/css2?family=Michroma&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fjalla+One&family=Oswald:wght@200..700&display=swap');

/* ===================================================================
   WSO Utility Helpers - v1.2
   Conflict-safe (prefix `wso-`). Bootstrap-like utility set.
   Primary color = WSO Brand Red. Secondary color = LearnDash Blue.
   =================================================================== */

/* ---------- Core Tokens ---------- */
:root{
  /* Spacing scale (reuses LearnDash tokens when available) */
  --wso-space-0: 0;
  --wso-space-1: var(--ld-spacer-1, .25rem);
  --wso-space-2: var(--ld-spacer-2, .5rem);
  --wso-space-3: var(--ld-spacer-3, 1rem);
  --wso-space-4: var(--ld-spacer-4, 1.5rem);
  --wso-space-5: var(--ld-spacer-5, 2rem);
  --wso-space-6: var(--ld-spacer-6, 3rem);
  --wso-space-7: var(--ld-spacer-7, 4rem);
  --wso-space-8: var(--ld-spacer-8, 5rem);

  /* Breakpoints (Bootstrap-ish) */
  --wso-bp-sm: 576px;
  --wso-bp-md: 768px;
  --wso-bp-lg: 992px;
  --wso-bp-xl: 1200px;

  /* Brand Palette */
  /* If Sinatra exposes a customizer var for accent, inherit it; fallback to #d42029 */
  --wso-color-primary: var(--sinatra--accent-color, #d42029); /* WSO Red */
  --wso-color-primary-dark: #b91c23;
  --wso-color-primary-light: #f04a51;
  --wso-color-primary-contrast: #fff;

  /* LearnDash / System palette (as secondary + statuses) */
  --wso-color-secondary: var(--ld-color-brand-primary, #235af3); /* LD Blue */
  --wso-color-success: var(--ld-color-semantic-success, #2f8351);
  --wso-color-danger:  var(--ld-color-semantic-error,   #db0000);
  --wso-color-warning: var(--ld-color-primitives-yellow-800, #eb7100);
  --wso-color-info:    var(--ld-color-primitives-blue-200,   #98acf5);
  --wso-color-dark:    var(--ld-color-system-dark,     #0e2a90);
  --wso-color-light:   var(--ld-color-system-light-2,  #f6f8fa);
  --wso-color-muted:   var(--ld-color-system-subtle-text, #73738c);

  /* Borders & radii */
  --wso-border-color: var(--ld-color-semantic-general-border, #dce1e8);
  --wso-radius-sm: .25rem;
  --wso-radius: .5rem;
  --wso-radius-lg: 1rem;
  --wso-radius-pill: 50rem;
}

/* ---------- Display ---------- */
.wso-d-none{display:none!important;}
.wso-d-block{display:block!important;}
.wso-d-inline{display:inline!important;}
.wso-d-inline-block{display:inline-block!important;}
.wso-d-flex{display:flex!important;}
.wso-d-inline-flex{display:inline-flex!important;}
.wso-d-grid{display:grid!important;}
@media (max-width: var(--wso-bp-md)){
  .wso-d-md-none{display:none!important;}
  .wso-d-md-block{display:block!important;}
  .wso-d-md-flex{display:flex!important;}
}

/* ---------- Flexbox ---------- */
.wso-flex-row{flex-direction:row!important;}
.wso-flex-column{flex-direction:column!important;}
.wso-flex-wrap{flex-wrap:wrap!important;}
.wso-justify-start{justify-content:flex-start!important;}
.wso-justify-center{justify-content:center!important;}
.wso-justify-end{justify-content:flex-end!important;}
.wso-justify-between{justify-content:space-between!important;}
.wso-justify-around{justify-content:space-around!important;}
.wso-align-start{align-items:flex-start!important;}
.wso-align-center{align-items:center!important;}
.wso-align-end{align-items:flex-end!important;}
/* Self & order */
.wso-align-self-start{align-self:flex-start!important;}
.wso-align-self-center{align-self:center!important;}
.wso-align-self-end{align-self:flex-end!important;}
.wso-order-0{order:0!important;}
.wso-order-1{order:1!important;}
.wso-order-2{order:2!important;}
.wso-order-3{order:3!important;}
.wso-order-4{order:4!important;}
.wso-order-5{order:5!important;}
.wso-flex-grow-1{flex-grow:1!important;}
.wso-flex-shrink-0{flex-shrink:0!important;}

/* ---------- Grid helpers (lightweight) ---------- */
.wso-grid-auto{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:var(--wso-space-3);}
.wso-grid-2{display:grid!important;grid-template-columns:repeat(2,1fr);gap:var(--wso-space-3);}
.wso-grid-3{display:grid!important;grid-template-columns:repeat(3,1fr);gap:var(--wso-space-3);}
.wso-grid-4{display:grid!important;grid-template-columns:repeat(4,1fr);gap:var(--wso-space-3);}
.wso-gap-1{gap:var(--wso-space-1)!important;}
.wso-gap-2{gap:var(--wso-space-2)!important;}
.wso-gap-3{gap:var(--wso-space-3)!important;}
.wso-gap-4{gap:var(--wso-space-4)!important;}
.wso-gap-5{gap:var(--wso-space-5)!important;}

/* ---------- Spacing (margin) ---------- */
.wso-m-0{margin:var(--wso-space-0)!important;}
.wso-m-1{margin:var(--wso-space-1)!important;}
.wso-m-2{margin:var(--wso-space-2)!important;}
.wso-m-3{margin:var(--wso-space-3)!important;}
.wso-m-4{margin:var(--wso-space-4)!important;}
.wso-m-5{margin:var(--wso-space-5)!important;}
/* axis */
.wso-mx-0{margin-left:0!important;margin-right:0!important;}
.wso-mx-1{margin-left:var(--wso-space-1)!important;margin-right:var(--wso-space-1)!important;}
.wso-mx-2{margin-left:var(--wso-space-2)!important;margin-right:var(--wso-space-2)!important;}
.wso-mx-3{margin-left:var(--wso-space-3)!important;margin-right:var(--wso-space-3)!important;}
.wso-mx-4{margin-left:var(--wso-space-4)!important;margin-right:var(--wso-space-4)!important;}
.wso-mx-5{margin-left:var(--wso-space-5)!important;margin-right:var(--wso-space-5)!important;}

.wso-my-0{margin-top:0!important;margin-bottom:0!important;}
.wso-my-1{margin-top:var(--wso-space-1)!important;margin-bottom:var(--wso-space-1)!important;}
.wso-my-2{margin-top:var(--wso-space-2)!important;margin-bottom:var(--wso-space-2)!important;}
.wso-my-3{margin-top:var(--wso-space-3)!important;margin-bottom:var(--wso-space-3)!important;}
.wso-my-4{margin-top:var(--wso-space-4)!important;margin-bottom:var(--wso-space-4)!important;}
.wso-my-5{margin-top:var(--wso-space-5)!important;margin-bottom:var(--wso-space-5)!important;}
/* sides */
.wso-mt-0{margin-top:0!important;} .wso-mt-1{margin-top:var(--wso-space-1)!important;} .wso-mt-2{margin-top:var(--wso-space-2)!important;} .wso-mt-3{margin-top:var(--wso-space-3)!important;} .wso-mt-4{margin-top:var(--wso-space-4)!important;} .wso-mt-5{margin-top:var(--wso-space-5)!important;}
.wso-mb-0{margin-bottom:0!important;} .wso-mb-1{margin-bottom:var(--wso-space-1)!important;} .wso-mb-2{margin-bottom:var(--wso-space-2)!important;} .wso-mb-3{margin-bottom:var(--wso-space-3)!important;} .wso-mb-4{margin-bottom:var(--wso-space-4)!important;} .wso-mb-5{margin-bottom:var(--wso-space-5)!important;}
.wso-ms-0{margin-left:0!important;} .wso-ms-1{margin-left:var(--wso-space-1)!important;} .wso-ms-2{margin-left:var(--wso-space-2)!important;} .wso-ms-3{margin-left:var(--wso-space-3)!important;} .wso-ms-4{margin-left:var(--wso-space-4)!important;} .wso-ms-5{margin-left:var(--wso-space-5)!important;}
.wso-me-0{margin-right:0!important;} .wso-me-1{margin-right:var(--wso-space-1)!important;} .wso-me-2{margin-right:var(--wso-space-2)!important;} .wso-me-3{margin-right:var(--wso-space-3)!important;} .wso-me-4{margin-right:var(--wso-space-4)!important;} .wso-me-5{margin-right:var(--wso-space-5)!important;}
/* autos */
.wso-ms-auto{margin-left:auto!important;}
.wso-me-auto{margin-right:auto!important;}

/* ---------- Spacing (padding) ---------- */
.wso-p-0{padding:0!important;}
.wso-p-1{padding:var(--wso-space-1)!important;}
.wso-p-2{padding:var(--wso-space-2)!important;}
.wso-p-3{padding:var(--wso-space-3)!important;}
.wso-p-4{padding:var(--wso-space-4)!important;}
.wso-p-5{padding:var(--wso-space-5)!important;}

.wso-px-0{padding-left:0!important;padding-right:0!important;}
.wso-px-2{padding-left:var(--wso-space-2)!important;padding-right:var(--wso-space-2)!important;}
.wso-px-3{padding-left:var(--wso-space-3)!important;padding-right:var(--wso-space-3)!important;}
.wso-px-4{padding-left:var(--wso-space-4)!important;padding-right:var(--wso-space-4)!important;}

.wso-py-0{padding-top:0!important;padding-bottom:0!important;}
.wso-py-2{padding-top:var(--wso-space-2)!important;padding-bottom:var(--wso-space-2)!important;}
.wso-py-3{padding-top:var(--wso-space-3)!important;padding-bottom:var(--wso-space-3)!important;}
.wso-py-4{padding-top:var(--wso-space-4)!important;padding-bottom:var(--wso-space-4)!important;}

.wso-pt-0{padding-top:0!important;} .wso-pt-1{padding-top:var(--wso-space-1)!important;} .wso-pt-2{padding-top:var(--wso-space-2)!important;} .wso-pt-3{padding-top:var(--wso-space-3)!important;} .wso-pt-4{padding-top:var(--wso-space-4)!important;}.wso-pt-5{padding-top:var(--wso-space-5)!important;}
.wso-pb-0{padding-bottom:0!important;} .wso-pb-1{padding-bottom:var(--wso-space-1)!important;} .wso-pb-2{padding-bottom:var(--wso-space-2)!important;} .wso-pb-3{padding-bottom:var(--wso-space-3)!important;} .wso-pb-4{padding-bottom:var(--wso-space-4)!important;}
.wso-ps-0{padding-left:0!important;} .wso-ps-2{padding-left:var(--wso-space-2)!important;} .wso-ps-3{padding-left:var(--wso-space-3)!important;} .wso-ps-4{padding-left:var(--wso-space-4)!important;}
.wso-pe-0{padding-right:0!important;} .wso-pe-2{padding-right:var(--wso-space-2)!important;} .wso-pe-3{padding-right:var(--wso-space-3)!important;} .wso-pe-4{padding-right:var(--wso-space-4)!important;}

/* ---------- Text ---------- */
.wso-text-start{text-align:left!important;}
.wso-text-center{text-align:center!important;}
.wso-text-end{text-align:right!important;}
.wso-fw-normal{font-weight:400!important;}
.wso-fw-medium{font-weight:500!important;}
.wso-fw-bold{font-weight:700!important;}
.wso-fs-sm{font-size:.875rem!important;}
.wso-fs-base{font-size:1rem!important;}
.wso-fs-lg{font-size:1.25rem!important;}
.wso-uppercase{text-transform:uppercase!important;}
.wso-lh-1{line-height:1!important;}
.wso-lh-sm{line-height:1.25!important;}
.wso-lh-base{line-height:1.5!important;}
/* Truncate */
.wso-text-truncate{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* ---------- Colors ---------- */
/* Brand (WSO) */
.wso-text-primary{color:var(--wso-color-primary)!important;}
.wso-text-primary-dark{color:var(--wso-color-primary-dark)!important;}
.wso-text-primary-light{color:var(--wso-color-primary-light)!important;}
.wso-text-white{color:var(--wso-color-primary-contrast)!important;}

.wso-bg-primary{background:var(--wso-color-primary)!important;color:var(--wso-color-primary-contrast)!important;}
.wso-bg-primary-dark{background:var(--wso-color-primary-dark)!important;color:var(--wso-color-primary-contrast)!important;}
.wso-bg-primary-light{background:var(--wso-color-primary-light)!important;color:var(--wso-color-primary-contrast)!important;}
.wso-border-primary{border-color:var(--wso-color-primary)!important;}
/* Hover helper */
.wso-hover-primary:hover,.wso-hover-primary:focus{background:var(--wso-color-primary-dark)!important;color:var(--wso-color-primary-contrast)!important;transition:all .2s ease-in-out;}

/* Secondary & statuses (LD/system) */
.wso-text-secondary{color:var(--wso-color-secondary)!important;}
.wso-text-success{color:var(--wso-color-success)!important;}
.wso-text-danger{color:var(--wso-color-danger)!important;}
.wso-text-warning{color:var(--wso-color-warning)!important;}
.wso-text-info{color:var(--wso-color-info)!important;}
.wso-text-muted{color:var(--wso-color-muted)!important;}

.wso-bg-secondary{background:var(--wso-color-secondary)!important;color:#fff!important;}
.wso-bg-success{background:var(--wso-color-success)!important;color:#fff!important;}
.wso-bg-danger{background:var(--wso-color-danger)!important;color:#fff!important;}
.wso-bg-warning{background:var(--wso-color-warning)!important;color:#000!important;}
.wso-bg-info{background:var(--wso-color-info)!important;color:#000!important;}
.wso-bg-light{background:var(--wso-color-light)!important;}
.wso-bg-dark{background:var(--wso-color-dark)!important;color:#fff!important;}

.wso-border{border:1px solid var(--wso-border-color)!important;}
.wso-border-0{border:0!important;}
.wso-border-top{border-top:1px solid var(--wso-border-color)!important;}
.wso-border-bottom{border-bottom:1px solid var(--wso-border-color)!important;}
.wso-border-start{border-left:1px solid var(--wso-border-color)!important;}
.wso-border-end{border-right:1px solid var(--wso-border-color)!important;}
.wso-border-secondary{border-color:var(--wso-color-secondary)!important;}
.wso-border-success{border-color:var(--wso-color-success)!important;}
.wso-border-danger{border-color:var(--wso-color-danger)!important;}
.wso-border-warning{border-color:var(--wso-color-warning)!important;}
.wso-border-info{border-color:var(--wso-color-info)!important;}

/* ---------- Radius and Shadows ---------- */
.wso-rounded{border-radius:var(--wso-radius-sm)!important;}
.wso-rounded-sm{border-radius:var(--wso-radius-sm)!important;}
.wso-rounded-md{border-radius:var(--wso-radius)!important;}
.wso-rounded-lg{border-radius:var(--wso-radius-lg)!important;}
.wso-rounded-pill{border-radius:var(--wso-radius-pill)!important;}

.wso-shadow-sm{box-shadow:0 .125rem .25rem rgba(0,0,0,.075)!important;}
.wso-shadow{box-shadow:0 .5rem 1rem rgba(0,0,0,.15)!important;}
.wso-shadow-none{box-shadow:none!important;}

/* ---------- Sizing ---------- */
.wso-w-25{width:25%!important;} .wso-w-50{width:50%!important;} .wso-w-75{width:75%!important;} .wso-w-100{width:100%!important;}
.wso-h-100{height:100%!important;} .wso-w-auto{width:auto!important;} .wso-h-auto{height:auto!important;}
.wso-maxw-sm{max-width:480px!important;} .wso-maxw-md{max-width:720px!important;} .wso-maxw-lg{max-width:960px!important;} .wso-maxw-xl{max-width:1140px!important;}
/* Container */
.wso-container{width:100%;margin-left:auto;margin-right:auto;padding-left:var(--wso-space-3);padding-right:var(--wso-space-3);}
@media (min-width: var(--wso-bp-sm)){.wso-container{max-width:540px;}}
@media (min-width: var(--wso-bp-md)){.wso-container{max-width:720px;}}
@media (min-width: var(--wso-bp-lg)){.wso-container{max-width:960px;}}
@media (min-width: var(--wso-bp-xl)){.wso-container{max-width:1140px;}}

/* ---------- Positioning and Overflow ---------- */
.wso-position-static{position:static!important;}
.wso-position-relative{position:relative!important;}
.wso-position-absolute{position:absolute!important;}
.wso-position-fixed{position:fixed!important;}
.wso-position-sticky{position:sticky!important;}
.wso-top-0{top:0!important;} .wso-bottom-0{bottom:0!important;} .wso-start-0{left:0!important;} .wso-end-0{right:0!important;}
.wso-overflow-hidden{overflow:hidden!important;}
.wso-overflow-auto{overflow:auto!important;}

/* ---------- Opacity & Z ---------- */
.wso-opacity-0{opacity:0!important;}
.wso-opacity-25{opacity:.25!important;}
.wso-opacity-50{opacity:.5!important;}
.wso-opacity-75{opacity:.75!important;}
.wso-opacity-100{opacity:1!important;}
.wso-z-0{z-index:0!important;} .wso-z-1{z-index:1!important;} .wso-z-10{z-index:10!important;} .wso-z-100{z-index:100!important;}

/* ---------- Helpers ---------- */
.wso-pointer{cursor:pointer!important;}
.wso-pe-none{pointer-events:none!important;}
.wso-visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important;}
.wso-clearfix::after{content:"";display:block;clear:both;}

/* ---------- Buttons (optional, brand-aligned) ---------- */
.wso-btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--wso-radius-pill);padding:.625rem 1.25rem;font-weight:700;line-height:1.25;text-decoration:none;transition:all .2s ease-in-out;cursor:pointer;}
.wso-btn:disabled{opacity:.65;cursor:not-allowed;}
.wso-btn-primary{background:var(--wso-color-primary);color:var(--wso-color-primary-contrast);border-color:var(--wso-color-primary);}
.wso-btn-primary:hover,.wso-btn-primary:focus{background:var(--wso-color-primary-dark);border-color:var(--wso-color-primary-dark);}
.wso-btn-outline-primary{background:transparent;color:var(--wso-color-primary);border-color:var(--wso-color-primary);}
.wso-btn-outline-primary:hover,.wso-btn-outline-primary:focus{background:var(--wso-color-primary-light);color:#fff;border-color:var(--wso-color-primary-light);}
.wso-btn-secondary{background:var(--wso-color-secondary);color:#fff;border-color:var(--wso-color-secondary);}
.wso-btn-secondary:hover,.wso-btn-secondary:focus{filter:brightness(.9);}

/* ===== WSO Academy - Landinger-style Pill Accordion (Pagelayer) ===== */
:root{
  --wso-accent:#d42029; /* brand color already used in dynamic-styles.css */
  --wso-text:var(--ld-color-semantic-text-body, #111);
  --wso-muted:var(--ld-color-semantic-text-body-subtle, #6b7280);
  --wso-bg-soft:#f7f7f3; /* soft band like Landinger */
  --wso-card:#fff;
  --wso-r-xl:28px;
  --wso-r-lg:16px;
  --wso-shadow:0 10px 24px -12px rgba(0,0,0,.15);
  --wso-font:var(--ld-typography-font-family, Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, sans-serif);
  --sp-4:var(--ld-spacer-4, 1.5rem);
}

/* Optional soft hero band—add class "wso-faq-hero" to a Row */
.wso-faq-hero{background:var(--wso-bg-soft);border-radius:3px;padding:calc(var(--sp-4) + 12px);text-align:center;margin-bottom:var(--sp-4);font-family:var(--wso-font);}
.wso-faq-hero h1{margin:0 0 .25em;font-weight:800;}
.wso-faq-hero p{margin:0;color:var(--wso-muted);}

/* Landinger - like pills on the Pagelayer Accordion */
.wso-pill-accordion{font-family:var(--wso-font);}
.wso-pill-accordion .pagelayer-accordion-item{border-radius:var(--wso-r-xl);background:transparent;margin-bottom:14px;}
/* Hide widget’s default icon if present */
.wso-pill-accordion .pagelayer-accordion-title .pagelayer-accordion-icon{display:none !important;}

.wso-pill-accordion .pagelayer-accordion-title{
  position:relative;display:flex;align-items:center;width:100%;cursor:pointer;
  border-radius:var(--wso-r-xl);padding:16px 56px 16px 20px;
  background:#f3f4ee;color:var(--wso-text);
  border:1px solid rgba(17,17,17,.06);
  transition:background .2s ease, border-color .2s ease, box-shadow .2s ease, color .2s ease;
  font-weight:600;
}
.wso-pill-accordion .pagelayer-accordion-title:hover{background:#edede8;border-color:rgba(17,17,17,.12);}

/* Plus/minus circle - agelayer toggles .pagelayer-accordion-active for us */
.wso-pill-accordion .pagelayer-accordion-title::after{
  content:"+";position:absolute;right:14px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  background:#fff;border:1px solid rgba(17,17,17,.08);color:var(--wso-accent);
  font-weight:800;line-height:1;transition:transform .25s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.wso-pill-accordion .pagelayer-accordion-title.pagelayer-accordion-active{background:var(--wso-card);box-shadow:var(--wso-shadow);}
.wso-pill-accordion .pagelayer-accordion-title.pagelayer-accordion-active::after{
  content:"–";background:var(--wso-accent);color:#fff;border-color:transparent;transform:translateY(-50%) rotate(180deg);
}

/* Content panel (Pagelayer handles the show/hide) */
.wso-pill-accordion .pagelayer-accordion-content{
  background:var(--wso-card);color:var(--wso-text);
  border:1px solid rgba(17,17,17,.06);border-top:none;
  border-radius:0 0 var(--wso-r-lg) var(--wso-r-lg);
  padding:18px 20px;line-height:1.65;
}
.wso-pill-accordion .pagelayer-accordion-content a{color:var(--wso-accent);text-decoration:underline;}


.pagelayer-accordion-tabs,
.active .pagelayer-accordion-tabs,
.pagelayer-accordion-tabs:hover {
    background-color:var(--wso-bg-soft)!important;
}
.pagelayer-accordion-tabs span.pagelayer-accordion-icon i {
    display:none;
}


/* ===================================================================
   WSO Custom CSS - v1.5
   =================================================================== */


.grecaptcha-badge {
    z-index: 99;
}

.blog .site-header .page-header,
.page-template-default .site-header .page-header {
    background:var(--wso-bg-soft)!important;
}

#sinatra-header .sinatra-logo .site-title {
    font-family: "Michroma", sans-serif;
    font-weight: normal;
    font-style: normal;
}

.entry-content .pagelayer-row>.pagelayer-col {
    padding-left: 15px;
    padding-right: 15px;
}

/* WSO Hero - two-column responsive layout with logo */

.wso-hero {
    position: relative;
    min-height: 70vh;
}

/* Background */
.wso-hero-bg {
    position: absolute;
    inset: 0;
    overflow: hidden;
    background: #000;
}
.wso-hero-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.wso-hero-image {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}
.wso-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, .55), rgba(0, 0, 0, .15));
    pointer-events: none;
}

/* Container - constrained to 1080px */
.wso-hero .si-container,
.wso-hero .si-container__wide {
    position: relative;
    z-index: 2;
    max-width: 1080px;
    width: 100%;
    margin: 0 auto;
    padding-left: 32px;
    padding-right: 32px;
}

/* Grid layout: 1/3 logo, 2/3 content */
.wso-hero-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 32px;
    align-items: center;
    min-height: clamp(420px, 72vh, 880px);
    padding-top: clamp(48px, 8vh, 120px);
    padding-bottom: clamp(48px, 8vh, 120px);
}

/* Logo column */
.wso-hero-logo {
    display: flex;
    align-items: center;
    justify-content: center;
}
.wso-hero-logo img {
    height: 320px;
    width: auto;
    max-width: 100%;
}

/* Content column (text stack) */
.wso-hero-stack {
    display: grid;
    align-content: center;
    justify-content: start;
    text-align: left;
}

/* Groups: overlay each other; only active one is visible */
.wso-hero-group {
    grid-area: 1 / 1;
    width: 100%;
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
    transition-property: opacity, transform;
}
.wso-hero-group.is-active {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

/* Typography */
.wso-hero-title {
    font-family: "Fjalla One", sans-serif;
    font-weight: bold;
    font-style: normal;
    margin: 0 0 .25em;
    font-size: clamp(36px, 4vw, 56px);
    line-height: 1.1;
    color: #fff;
    text-align: left;
}
.wso-hero-subtitle {
    margin: .25em 0 .5em;
    font-weight: 600;
    color: #fff;
    opacity: .95;
    font-size: clamp(18px, 2.2vw, 26px);
    text-align: left;
}
.wso-hero-brief {
    margin: .5em 0 1.25em;
    color: #fff;
    opacity: .9;
    font-size: clamp(16px, 1.8vw, 18px);
    max-width: 75ch;
    text-align: left;
}

h2.wso-block-title {
    font-family: "Fjalla One", sans-serif;
    font-weight: 400;
}

#sinatra-footer .sinatra-footer-column .si-widget {
    margin-bottom: 20px;
}

#sinatra-footer h2.wp-block-heading {
    font-family: "Fjalla One", sans-serif;
    font-weight: 400;
    font-size: 1.875rem;
    color: #fff;
}

#sinatra-footer .wp-block-list li {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid #757A80;
}

#sinatra-footer .footer-contact-list i {
    color: #d6202a;
}

#sinatra-footer #block-15 .wp-block-list li::before {
    font-family: "Font Awesome 5 Free", "Font Awesome 6 Free", sans-serif;
    content: "\f00c";
    font-weight: 900;
    color: #d6202a;
    flex-shrink: 0;
}

/* Social icons row */
#sinatra-footer .footer-social {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 6px;
}

#sinatra-footer .footer-social .social {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #757A80;
    border-radius: 999px;
    text-decoration: none;
    transition: transform .15s ease, border-color .15s ease, color .15s ease;
}

#sinatra-footer .footer-social .social i {
    font-size: 14px;
    color: #E5E7EB;
    /* light gray on dark footer */
}

/* Hover accents */
#sinatra-footer .footer-social .social:hover {
    transform: translateY(-1px);
    border-color: #d6202a;
}
#sinatra-footer .footer-social .social:hover i {
    color: #d6202a;
}

#sinatra-footer .si-footer-widget {
    padding-top: 1em;
}

#sinatra-footer .widget.si-entry:has(.footer-contact-list),
#sinatra-footer .widget.si-entry:has(.footer-social-text) {
    margin-bottom: 0;
}

#sinatra-footer .widget.si-entry p {
    margin-top: 0;
}

/* Buttons */
.wso-hero-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-start;
}
.wso-hero-cta .si-btn {
    margin-right: 0;
}

/* WSO Academy - 4 Column Course Grid */
.learndash-template-ld30 .si-container #primary {
    margin-top: 5px;
    margin-bottom: 50px;
}

.archive.post-type-archive-sfwd-courses #content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 2rem;
    margin-top: 2rem;
}

/* Course Card Style */
.post-type-archive-sfwd-courses .sinatra-article.sfwd-courses .thumbnail.entry-media>a,
.post-type-archive-sfwd-courses .sinatra-article.sfwd-courses .thumbnail.entry-media img {
    border-radius: 0px !important;
}

.archive.post-type-archive-sfwd-courses article.sfwd-courses {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    border-radius: 0 0 5px 5px;
}

.archive.post-type-archive-sfwd-courses article.sfwd-courses:hover {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.12);
}

/* Course Thumbnail - Dark Overlay + Centered Icon (No Zoom) */
.archive.post-type-archive-sfwd-courses .post-thumb {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    border-bottom: 3px solid #e8112d;
    border-radius: 10px 10px 0 0;
}

.archive.post-type-archive-sfwd-courses .post-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease, opacity 0.4s ease;
}

.archive.post-type-archive-sfwd-courses .post-thumb::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0);
    transition: background 0.4s ease;
    z-index: 1;
}

/* SVG Icon centered */
.archive.post-type-archive-sfwd-courses .post-thumb::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url('/wp-content/themes/sinatra-child/imgs/icon-hover.svg') no-repeat center center;
    background-size: clamp(72px, 30%, 220px);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 2;
}

/* Hover state - dark overlay and icon appear */
.archive.post-type-archive-sfwd-courses article.sfwd-courses:hover .post-thumb::after {
    background: rgba(0, 0, 0, 0.75);
}

.archive.post-type-archive-sfwd-courses article.sfwd-courses:hover .post-thumb::before {
    opacity: 1;
}

.si-blog-horizontal .sinatra-article .entry-media:hover img,
.si-blog-layout-1 .sinatra-article .entry-media:hover img {
    transform: none !important;
    transition: none !important;
}

/* Courses archive - Full-width Read More button (light gray) */
.archive.post-type-archive-sfwd-courses .entry-footer .si-btn.btn-text-1 {
    display: flex !important;
    width: 100%;
    justify-content: center;
    align-items: center;
    background: #EDEDE9 !important;
    color: #212121 !important;
    padding: 12px 16px !important;
    border-radius: 0 0 5px 5px !important;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0.2px;
    text-transform: uppercase;
    box-shadow: none;
    transition: background 0.25s ease, color 0.25s ease;
    text-decoration: none !important;
}

/* remove underline and pseudo elements */
.archive.post-type-archive-sfwd-courses .entry-footer .si-btn.btn-text-1::before,
.archive.post-type-archive-sfwd-courses .entry-footer .si-btn.btn-text-1::after,
.archive.post-type-archive-sfwd-courses .entry-footer .si-btn.btn-text-1 span::before,
.archive.post-type-archive-sfwd-courses .entry-footer .si-btn.btn-text-1 span::after {
    display: none !important;
    content: none !important;
}

/* Hover / focus */
.archive.post-type-archive-sfwd-courses .entry-footer .si-btn.btn-text-1:hover {
    background: #D4D4CF !important;
    color: #000 !important;
}

/* Title */
.archive.post-type-archive-sfwd-courses .entry-title {
    font-family: "Fjalla One", sans-serif;
    font-size: 1.5rem;
    font-weight: normal;
    color: #1a1a1a;
    margin: 1rem !important;
    line-height: 1.3;
}

.wso-fjalla-bold,
.learndash-wrapper .ld-login-modal .ld-modal-heading,
.si-page-header-wrapper h1.page-title {
    font-family: "Fjalla One", sans-serif!important;
    font-weight: 600;
}

.sfwd-courses-template-default.single .entry-content img {
    margin-bottom: 30px;
}

/* Summary text */
.archive.post-type-archive-sfwd-courses .entry-summary {
    font-size: 0.95rem;
    color: #444;
    margin: 0 1rem 1rem;
    flex-grow: 1;
}

.single-sfwd-topic h3.wp-block-heading,
.single-sfwd-lessons .ld-focus-content h1,
.single-sfwd-lessons h3.wp-block-heading {
    font-family: "Fjalla One", sans-serif;
}

.single-sfwd-lessons h3.wp-block-heading {
    padding-top: 25px;
}

/* ===== WSO Academy - Enroll button (works logged-in + logged-out) ===== */

/* Base styles for BOTH variants: input/button (.btn-join/#btn-join) and anchor (.ld-enrollment__join-button) */
.learndash-wrapper #btn-join,
.learndash-wrapper .btn-join,
.learndash-wrapper .ld-enrollment__join .ld-enrollment__join-button {
  background-color: #d42029 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 3px !important;
  text-decoration: none !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 44px !important;
  padding: 12px 16px !important;
  line-height: 1.25 !important;

  font-size: 1rem !important;
  font-weight: 700 !important;
  text-transform: none !important;
  cursor: pointer !important;

  box-shadow: none !important;
  outline: none !important;
  transform: none !important;
  transition: none !important;
  appearance: none !important;
}

/* Interactive states - identical box metrics, subtle color only */
.learndash-wrapper #btn-join:hover,
.learndash-wrapper .btn-join:hover,
.learndash-wrapper .ld-enrollment__join .ld-enrollment__join-button:hover,
.learndash-wrapper #btn-join:focus,
.learndash-wrapper .btn-join:focus,
.learndash-wrapper .ld-enrollment__join .ld-enrollment__join-button:focus,
.learndash-wrapper #btn-join:active,
.learndash-wrapper .btn-join:active,
.learndash-wrapper .ld-enrollment__join .ld-enrollment__join-button:active {
  background-color: #b71c24 !important;
  border: none !important;
  padding: 12px 16px !important;
  line-height: 1.25 !important;
  box-shadow: none !important;
  outline: none !important;
  transform: none !important;
  transition: none !important;
  font-weight: 700 !important;
}

/* Prevent inner elements from shifting/animating */
.learndash-wrapper #btn-join *,
.learndash-wrapper .btn-join *,
.learndash-wrapper .ld-enrollment__join .ld-enrollment__join-button * {
  transition: none !important;
  transform: none !important;
  animation: none !important;
  margin: 0 !important;
}

/* Ensure the join form container can expand full width */
.ld-enrollment__join form {
  width: 100% !important;
}
.learndash-wrapper .ld-login-modal .ld-login-modal-register{
    background:var(--wso-color-primary);
}
.learndash-wrapper:not(.ld-registration__outer-wrapper):not(.learndash-wrapper--modern) .ld-button.ld-button-reverse {
    color:var(--wso-color-primary-dark);
}
.learndash-wrapper:not(.ld-registration__outer-wrapper):not(.learndash-wrapper--modern) .ld-button.ld-button-reverse:hover {
    background:var(--wso-color-primary-dark);
    color:var(--wso-color-light);
}
.learndash-wrapper:not(.ld-registration__outer-wrapper):not(.learndash-wrapper--modern) .ld-button:focus {
    outline: none!important;
    outline-offset: 0px!important;
}
.learndash-wrapper .ld-login-modal input[type=submit] {
    background:var(--wso-color-primary);
}

.learndash-wrapper .ld-login-modal .ld-login-modal-login .ld-modal-heading {
    color: var(--wso-color-primary);
    font-family: "Fjalla One", sans-serif;
    font-weight: 600;
}

.page-id-380 .site-main .content-area {
    margin-bottom:var(--wso-space-0)!important;
}

/* Tablet (stack columns vertically) */
@media (max-width: 1079px) {
    .wso-hero .si-container,
    .wso-hero .si-container__wide {
        max-width: 100%;
        margin: 0;
        padding-left: 16px;
        padding-right: 16px;
    }
    .wso-hero-grid {
        grid-template-columns: 1fr;
        gap: 24px;
        justify-items: center;
    }
    .wso-hero-logo {
        justify-content: center;
    }
    .wso-hero-stack {
        justify-content: center;
        text-align: center;
    }
    .wso-hero-title,
    .wso-hero-subtitle,
    .wso-hero-brief {
        text-align: center;
    }
    .wso-hero-cta {
        justify-content: center;
    }
}

@media (max-width: 1024px) {
    .archive.post-type-archive-sfwd-courses #content {
        grid-template-columns: repeat(2, 1fr);
    }
    .wso-hero-grid {
        min-height: clamp(420px, 68vh, 760px);
    }
}

@media (max-width: 767px) {
    #sinatra-header .site-title a {
    font-size: 1.5rem;
    }
    .wso-hero-grid {
        min-height: clamp(420px, 64vh, 700px);
        padding-top: 56px;
        padding-bottom: 56px;
    }
    .wso-hero-logo img {
        height: 240px;
        /* Reduce logo size on mobile */
    }
    .wso-hero-title {
        font-size: clamp(28px, 3.5vw, 40px);
    }
    .wso-hero-subtitle {
        font-size: clamp(16px, 2vw, 22px);
    }
    .wso-hero-brief {
        font-size: clamp(14px, 1.6vw, 16px);
    }
}

@media (max-width: 600px) {
    .archive.post-type-archive-sfwd-courses #content {
        grid-template-columns: 1fr;
    }
}