/* ================================================================
   components.css — Buttons, cards, posts, services, all UI pieces
   ================================================================ */

/* ── Buttons ─────────────────────────────────────────────────── */
.btn {
    display:        inline-flex;
    align-items:    center;
    gap:            9px;
    font-family:    inherit;
    font-size:      .96rem;
    font-weight:    800;
    padding:        13px 26px;
    border-radius:  40px;
    border:         1.8px solid transparent;
    cursor:         pointer;
    transition:     background .2s, color .2s, border-color .2s, transform .15s, box-shadow .2s;
    white-space:    nowrap;
    text-decoration:none;
}
.btn:hover { transform: translateY(-2px); }

.btn-gold {
    background:  var(--gold);
    color:       var(--navy-deep);
    box-shadow:  0 14px 30px -16px rgba(202, 177, 144, .90);
}
.btn-gold:hover { background: var(--gold-soft); color: var(--navy-deep); }

.btn-navy { background: var(--navy); color: #fff; }
.btn-navy:hover { background: var(--navy-700); color: #fff; }

.btn-ghost {
    background:   transparent;
    border-color: var(--gold);
    color:        var(--navy);
}
.btn-ghost:hover { background: var(--navy); color: #fff; border-color: var(--navy); }

/* Ghost on dark background (inside hero / cta-band) */
.btn-ghost.on-dark       { color: #fff; border-color: rgba(255,255,255,.4); }
.btn-ghost.on-dark:hover { background: rgba(255,255,255,.1); border-color: #fff; }

/* ── Service cards (grid preview) ────────────────────────────── */
.card {
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 18px;
    padding:       30px 28px;
    transition:    transform .22s, box-shadow .28s, border-color .2s;
    position:      relative;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: rgba(202,177,144,.5); }

.ico {
    width:         56px;
    height:        56px;
    border-radius: 14px;
    background:    var(--navy);
    display:       flex;
    align-items:   center;
    justify-content:center;
    margin-bottom: 20px;
    flex-shrink:   0;
}
.ico svg {
    width:          28px;
    height:         28px;
    stroke:         #fff;
    fill:           none;
    stroke-width:   1.6;
    stroke-linecap: round;
    stroke-linejoin:round;
}
.ico.gold { background: var(--gold); }
.ico.gold svg { stroke: var(--navy-deep); }

.card h3 { font-size: 1.1rem; margin-bottom: 10px; }
.card p  { font-size: .97rem; color: var(--charcoal); }

.card .more {
    margin-top:  16px;
    display:     inline-flex;
    align-items: center;
    gap:         7px;
    color:       var(--navy);
    font-weight: 800;
    font-size:   .92rem;
    transition:  color .18s;
}
.card .more:hover { color: var(--gold); }
.card .more svg {
    width:        15px;
    height:       15px;
    stroke:       var(--gold);
    fill:         none;
    stroke-width: 2.2;
    transition:   transform .2s;
}

/* ── Gap cards (numbered) ────────────────────────────────────── */
.gap-card {
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 18px;
    padding:       32px 28px;
    position:      relative;
    overflow:      hidden;
}
.gap-card .gn {
    font-family: Georgia, serif;
    font-style:  italic;
    font-size:   2.6rem;
    color:       var(--gold);
    line-height: 1;
    opacity:     .5;
    margin-bottom: 10px;
}
.gap-card h3 { font-size: 1.15rem; margin-bottom: 8px; }
.gap-card p  { font-size: .95rem;  color: var(--charcoal); }

/* ── Why / Objectives items ──────────────────────────────────── */
.why {
    display:       flex;
    gap:           18px;
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 16px;
    padding:       24px 26px;
}
.why .wn {
    flex:          0 0 auto;
    width:         42px;
    height:        42px;
    border-radius: 50%;
    border:        1.6px solid var(--gold);
    color:         var(--gold);
    display:       flex;
    align-items:   center;
    justify-content:center;
    font-weight:   800;
    font-family:   Georgia, serif;
    font-style:    italic;
    font-size:     1rem;
}
.why h4 { font-size: 1.05rem; margin-bottom: 6px; }
.why p  { font-size: .93rem;  color: var(--charcoal); }

/* ── Sector cards ────────────────────────────────────────────── */
.sector {
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 14px;
    padding:       22px 16px;
    text-align:    center;
    transition:    .2s;
}
.sector:hover { border-color: rgba(202,177,144,.6); box-shadow: var(--shadow-sm); }
.sector .sic {
    width:          44px;
    height:         44px;
    margin:         0 auto 12px;
    border-radius:  50%;
    background:     var(--cream);
    display:        flex;
    align-items:    center;
    justify-content:center;
}
.sector .sic svg {
    width:          22px;
    height:         22px;
    stroke:         var(--navy);
    fill:           none;
    stroke-width:   1.7;
    stroke-linecap: round;
    stroke-linejoin:round;
}
.sector b     { display: block; font-size: .96rem; }
.sector small { font-size: .8rem; color: var(--gray-mid); display: block; margin-top: 4px; line-height: 1.6; }

/* ── Post / insight cards ────────────────────────────────────── */
.post {
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 18px;
    overflow:      hidden;
    transition:    transform .22s, box-shadow .28s;
}
.post:hover { transform: translateY(-4px); box-shadow: var(--shadow); }

.post .thumb {
    height:     170px;
    background: linear-gradient(155deg, var(--navy-700), var(--navy-deep));
    position:   relative;
    display:    flex;
    align-items:flex-end;
    padding:    18px;
    overflow:   hidden;
}
.post .thumb img {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    .7;
}
.post .thumb .cat {
    position:      relative;
    z-index:       2;
    font-size:     .74rem;
    font-weight:   800;
    color:         var(--navy-deep);
    background:    var(--gold);
    padding:       5px 12px;
    border-radius: 30px;
}

.post .pbody { padding: 22px 22px 24px; }
.post .pbody h3 { font-size: 1.08rem; margin-bottom: 12px; line-height: 1.5; }
.post .meta {
    display:     flex;
    gap:         14px;
    font-size:   .82rem;
    color:       var(--gray-mid);
    font-family: Georgia, serif;
    font-style:  italic;
}

/* ── Featured article (archive top) ─────────────────────────── */
.featured .fimg {
    background:  linear-gradient(150deg, var(--navy), var(--navy-deep));
    min-height:  320px;
    position:    relative;
    overflow:    hidden;
}
.featured .fimg img {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    .6;
}
.featured .fbody {
    padding:        38px 36px;
    display:        flex;
    flex-direction: column;
    justify-content:center;
}
.featured .fbody .cat {
    align-self:    flex-start;
    font-size:     .74rem;
    font-weight:   800;
    color:         var(--navy-deep);
    background:    var(--gold);
    padding:       5px 13px;
    border-radius: 30px;
    margin-bottom: 18px;
}
.featured .fbody h2 { margin-bottom: 12px; }
.featured .fbody p  { color: var(--charcoal); margin-bottom: 22px; }
.featured .fbody .meta {
    font-family: Georgia, serif;
    font-style:  italic;
    font-size:   .88rem;
    color:       var(--gray-mid);
}

/* ── Category filter tabs (insights archive) ─────────────────── */
.cats {
    display:   flex;
    flex-wrap: wrap;
    gap:       10px;
    margin-bottom: 36px;
}
.cats button, .cats a {
    font-family:   inherit;
    font-size:     .9rem;
    border:        1.4px solid var(--line);
    background:    var(--white);
    color:         var(--charcoal);
    padding:       9px 18px;
    border-radius: 30px;
    cursor:        pointer;
    transition:    .2s;
    text-decoration: none;
    display:       inline-block;
}
.cats button:hover, .cats a:hover { border-color: var(--gold); }
.cats button.active, .cats a.current-cat, .cats a.active {
    background:    var(--navy);
    color:         #fff;
    border-color:  var(--navy);
}

/* ── Service detail blocks (services page) ───────────────────── */
.svc {
    display:       grid;
    grid-template-columns: 64px 1fr;
    gap:           24px;
    padding:       42px 0;
    border-bottom: 1px solid var(--line);
}
.svc:last-of-type { border-bottom: none; }

.svc-ico {
    width:         64px;
    height:        64px;
    border-radius: 16px;
    background:    var(--navy);
    display:       flex;
    align-items:   center;
    justify-content:center;
    flex-shrink:   0;
}
.svc-ico svg {
    width:          32px;
    height:         32px;
    stroke:         #fff;
    fill:           none;
    stroke-width:   1.5;
    stroke-linecap: round;
    stroke-linejoin:round;
}

.svc h3 { font-size: 1.4rem; margin-bottom: 6px; }

.gap-tag {
    font-size:   .86rem;
    color:       var(--gold);
    font-family: Georgia, serif;
    font-style:  italic;
    margin-bottom: 14px;
}

.svc-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap:     24px;
    margin-top: 18px;
}
.svc-cols h5 {
    font-size:      .82rem;
    letter-spacing: .08em;
    color:          var(--gray-mid);
    text-transform: uppercase;
    font-family:    Georgia, serif;
    font-style:     italic;
    font-weight:    400;
    margin-bottom:  10px;
}

.ul { list-style: none; }
.ul li {
    position:           relative;
    padding-inline-start: 22px;
    font-size:          .96rem;
    color:              var(--charcoal);
    margin-bottom:      6px;
}
.ul li::before {
    content:      "";
    position:     absolute;
    inset-inline-start: 0;
    top:          .75em;
    width:        7px;
    height:       7px;
    border-radius:50%;
    background:   var(--gold);
    transform:    translateY(-50%);
}

.svc-cta { margin-top: 24px; }

/* ── Research product cards ──────────────────────────────────── */
.prod {
    background:     var(--white);
    border:         1px solid var(--line);
    border-radius:  18px;
    padding:        30px 28px;
    display:        flex;
    flex-direction: column;
    transition:     transform .22s, box-shadow .28s, border-color .2s;
}
.prod:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: rgba(202,177,144,.5); }

.prod .ptop {
    display:     flex;
    align-items: center;
    gap:         14px;
    margin-bottom: 16px;
}
.prod .ptop .ico { margin-bottom: 0; width: 50px; height: 50px; border-radius: 12px; }
.prod .ptop .ico svg { width: 24px; height: 24px; }

.prod .cadence {
    font-size:      .78rem;
    color:          var(--gold);
    font-family:    Georgia, serif;
    font-style:     italic;
    border:         1px solid rgba(202,177,144,.5);
    border-radius:  30px;
    padding:        3px 12px;
    margin-inline-start: auto;
    white-space:    nowrap;
}

.prod h3    { font-size: 1.2rem; margin-bottom: 9px; }
.prod p     { font-size: .95rem; color: var(--charcoal); flex: 1; }

.prod .who {
    margin-top:   14px;
    font-size:    .85rem;
    color:        var(--gray-mid);
    border-top:   1px dashed var(--line);
    padding-top:  12px;
}
.prod .who b { color: var(--navy); }

.prod .pcta { margin-top: 18px; }
.prod .pcta a {
    display:     inline-flex;
    align-items: center;
    gap:         7px;
    font-weight: 800;
    font-size:   .92rem;
    color:       var(--navy);
}
.prod .pcta svg {
    width:        15px;
    height:       15px;
    stroke:       var(--gold);
    fill:         none;
    stroke-width: 2.2;
}

/* ── Training program chips ──────────────────────────────────── */
.courses {
    margin-top:    20px;
    background:    var(--cream);
    border-radius: 14px;
    padding:       22px 24px;
}
.courses b { display: block; margin-bottom: 12px; }

.course-chips {
    display:   flex;
    flex-wrap: wrap;
    gap:       9px;
}
.course-chips span {
    font-size:     .86rem;
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 30px;
    padding:       7px 15px;
}

/* ── Values cards ────────────────────────────────────────────── */
.val {
    background:    var(--white);
    border:        1px solid var(--line);
    border-top:    3px solid var(--gold);
    border-radius: 14px;
    padding:       26px 22px;
}
.val .vk { font-family: Georgia, serif; font-style: italic; color: var(--gold); font-size: .85rem; }
.val h4  { font-size: 1.18rem; margin: 6px 0 8px; }
.val p   { font-size: .92rem; color: var(--charcoal); }

/* ── Vision / Mission blocks ─────────────────────────────────── */
.vm {
    background:    var(--navy);
    color:         #fff;
    border-radius: 18px;
    padding:       38px 34px;
    position:      relative;
    overflow:      hidden;
}
.vm::after {
    content:    "";
    position:   absolute;
    inset-inline-start: -30px;
    top:        -30px;
    width:      130px;
    height:     130px;
    border-radius:50%;
    background: radial-gradient(circle, rgba(202,177,144,.18), transparent 70%);
}
.vm .vk { font-family: Georgia, serif; font-style: italic; color: var(--gold-soft); font-size: .88rem; letter-spacing: .1em; }
.vm h3  { font-size: 1.5rem; margin: 10px 0 12px; color: #fff; }
.vm p   { color: #cdd5e0; font-size: 1.02rem; }

/* ── Method steps ────────────────────────────────────────────── */
.step {
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 16px;
    padding:       28px 24px;
    position:      relative;
}
.step .sn {
    font-family:   Georgia, serif;
    font-style:    italic;
    font-size:     1rem;
    color:         var(--gold);
    border:        1.5px solid var(--gold);
    width:         38px;
    height:        38px;
    border-radius: 50%;
    display:       flex;
    align-items:   center;
    justify-content:center;
    margin-bottom: 16px;
}
.step h4 { font-size: 1.1rem; margin-bottom: 6px; }
.step p  { font-size: .92rem; color: var(--charcoal); }

/* ── Network / Expertise cards ───────────────────────────────── */
.net {
    background:    rgba(255, 255, 255, .04);
    border:        1px solid rgba(255, 255, 255, .10);
    border-radius: 16px;
    padding:       28px 26px;
}
.net .tier {
    font-family:    Georgia, serif;
    font-style:     italic;
    font-size:      .78rem;
    letter-spacing: .12em;
    color:          var(--gold-soft);
    text-transform: uppercase;
}
.net h4     { color: #fff; font-size: 1.18rem; margin: 10px 0 8px; }
.net p      { font-size: .93rem; color: #bcc7d4; }
.net .fields{ margin-top: 14px; display: flex; flex-wrap: wrap; gap: 7px; }
.net .fields span {
    font-size:     .78rem;
    background:    rgba(255, 255, 255, .07);
    border:        1px solid rgba(255, 255, 255, .13);
    border-radius: 20px;
    padding:       4px 11px;
    color:         #cdd5e0;
}

/* ── Contact form card ───────────────────────────────────────── */
.formcard {
    background:    var(--white);
    border:        1px solid var(--line);
    border-radius: 20px;
    padding:       38px 36px;
    box-shadow:    var(--shadow-sm);
}
.formcard h3    { font-size: 1.4rem; margin-bottom: 6px; }
.formcard .fdesc{ color: var(--gray-mid); font-size: .95rem; margin-bottom: 26px; }

.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field     { margin-bottom: 16px; }
.field label {
    display:     block;
    font-size:   .88rem;
    font-weight: 800;
    margin-bottom: 7px;
    color:       var(--navy);
}
.field label .req { color: var(--gold); }
.field input,
.field select,
.field textarea {
    width:      100%;
    font-family:inherit;
    font-size:  .97rem;
    color:      var(--navy);
    background: var(--cream-2);
    border:     1.4px solid var(--line);
    border-radius:12px;
    padding:    13px 15px;
    transition: .2s;
    line-height:1.6;
}
.field input:focus,
.field select:focus,
.field textarea:focus {
    outline:    none;
    border-color: var(--gold);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(202,177,144,.18);
}
.field textarea { resize: vertical; min-height: 120px; }
.formcard .btn  { width: 100%; margin-top: 8px; justify-content: center; }
.form-note {
    font-size:  .82rem;
    color:      var(--gray-mid);
    margin-top: 14px;
    text-align: center;
}

/* CF7 reset to match design */
.wpcf7-form .wpcf7-text,
.wpcf7-form .wpcf7-email,
.wpcf7-form .wpcf7-tel,
.wpcf7-form .wpcf7-select,
.wpcf7-form .wpcf7-textarea {
    width:      100%;
    font-family:inherit;
    font-size:  .97rem;
    color:      var(--navy);
    background: var(--cream-2);
    border:     1.4px solid var(--line);
    border-radius:12px;
    padding:    13px 15px;
    transition: .2s;
    line-height:1.6;
}
.wpcf7-form .wpcf7-text:focus,
.wpcf7-form .wpcf7-email:focus,
.wpcf7-form .wpcf7-textarea:focus {
    outline:    none;
    border-color: var(--gold);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(202,177,144,.18);
}
.wpcf7-form .wpcf7-textarea { resize: vertical; min-height: 120px; }
.wpcf7-form .wpcf7-submit   { font-family: inherit; }
.wpcf7-response-output      { border-radius: 10px !important; margin-top: 14px !important; }
.wpcf7-not-valid-tip        { font-size: .82rem; color: #c0392b; margin-top: 4px; }

/* ── Contact aside (info + map placeholder) ──────────────────── */
.contact-aside { display: grid; gap: 18px; }

.cinfo {
    background:    var(--navy);
    color:         #fff;
    border-radius: 18px;
    padding:       30px 30px;
}
.cinfo h4 { font-size: 1.15rem; margin-bottom: 18px; color: #fff; }
.cinfo .crow {
    display:     flex;
    gap:         14px;
    align-items: flex-start;
    margin-bottom: 18px;
}
.cinfo .crow:last-child { margin-bottom: 0; }
.cinfo .ci {
    flex:          0 0 auto;
    width:         40px;
    height:        40px;
    border-radius: 10px;
    background:    rgba(202,177,144,.16);
    display:       flex;
    align-items:   center;
    justify-content:center;
}
.cinfo .ci svg {
    width:          19px;
    height:         19px;
    stroke:         var(--gold);
    fill:           none;
    stroke-width:   1.8;
    stroke-linecap: round;
    stroke-linejoin:round;
}
.cinfo .ct b    { display: block; font-size: .96rem; }
.cinfo .ct span { font-size: .88rem; color: #aebccd; }

/* Map placeholder card */
.mapcard {
    border-radius: 18px;
    overflow:      hidden;
    border:        1px solid var(--line);
    background:    linear-gradient(160deg, #e7ebf0, #d6dde6);
    height:        200px;
    position:      relative;
    display:       flex;
    align-items:   center;
    justify-content:center;
}
.mapcard::before {
    content:    "";
    position:   absolute;
    inset:      0;
    background:
        linear-gradient(rgba(20,37,59,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(20,37,59,.06) 1px, transparent 1px);
    background-size: 26px 26px;
}
.mapcard .pin {
    position:   relative;
    z-index:    2;
    text-align: center;
    color:      var(--navy);
}
.mapcard .pin svg {
    width:  34px;
    height: 34px;
    margin: 0 auto 6px;
    stroke: var(--gold);
    fill:   var(--navy);
    stroke-width: 1.4;
}
.mapcard .pin b { font-size: .95rem; }

/* ── Confirmation / success message ─────────────────────────── */
.confirm {
    display:    none;
    text-align: center;
    padding:    30px 10px;
}
.confirm.show { display: block; }
.confirm .ok {
    width:         66px;
    height:        66px;
    border-radius: 50%;
    background:    rgba(202,177,144,.18);
    border:        1.5px solid var(--gold);
    display:       flex;
    align-items:   center;
    justify-content:center;
    margin:        0 auto 20px;
}
.confirm .ok svg {
    width:          30px;
    height:         30px;
    stroke:         var(--gold);
    fill:           none;
    stroke-width:   2.4;
    stroke-linecap: round;
    stroke-linejoin:round;
}
.confirm h3 { font-size: 1.4rem; margin-bottom: 10px; }
.confirm p  { color: var(--charcoal); }

/* ================================================================
   CF7 form tabs  (contact page — switches between two forms)
   ================================================================ */
.form-tabs {
    display:       flex;
    gap:           4px;
    background:    var(--cream);
    padding:       4px;
    border-radius: 14px 14px 0 0;
    border:        1px solid var(--line);
    border-bottom: none;
}
.form-tab {
    flex:          1;
    font-family:   inherit;
    font-size:     .96rem;
    font-weight:   800;
    background:    transparent;
    border:        none;
    padding:       11px 18px;
    border-radius: 10px;
    cursor:        pointer;
    color:         var(--gray-mid);
    transition:    background .18s, color .18s;
    white-space:   nowrap;
}
.form-tab:hover  { background: var(--white); color: var(--navy); }
.form-tab.active { background: var(--white); color: var(--navy); box-shadow: 0 1px 4px rgba(0,0,0,.08); }

/* Panel visibility — toggled by forms.js */
[data-form-panel] { display: block; }
[data-form-panel][hidden] { display: none; }

/* Remove top border-radius from formcard when inside a tab panel */
[data-form-panel] .formcard {
    border-top-left-radius:  0;
    border-top-right-radius: 0;
}

/* ================================================================
   CF7 field-level validation states
   ================================================================ */

/* Highlight invalid fields */
.wpcf7-form-control.wpcf7-not-valid {
    border-color: #e74c3c !important;
    background:   #fff8f8 !important;
    box-shadow:   0 0 0 3px rgba(231, 76, 60, .12) !important;
}
.wpcf7-not-valid-tip {
    display:    block;
    font-size:  .82rem;
    color:      #c0392b;
    margin-top: 5px;
    padding-inline-start: 2px;
}

/* Valid fields (after blur/submission attempt) */
.wpcf7-form-control.wpcf7-validates-as-required:not(.wpcf7-not-valid):not(:placeholder-shown) {
    border-color: rgba(39, 174, 96, .5);
}

/* ================================================================
   CF7 response output (success / error banners)
   ================================================================ */
.wpcf7-response-output {
    margin:        16px 0 0 !important;
    padding:       14px 18px !important;
    border-radius: 10px !important;
    font-size:     .94rem !important;
    border:        none !important;
    line-height:   1.7;
}

/* Success */
.wpcf7-form.sent .wpcf7-response-output {
    background:  rgba(39, 174, 96, .10) !important;
    border-inline-start: 3px solid #27ae60 !important;
    color:       #1a7a3c !important;
}

/* Server error / mail not sent */
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.aborted .wpcf7-response-output {
    background:  rgba(231, 76, 60, .09) !important;
    border-inline-start: 3px solid #e74c3c !important;
    color:       #922b21 !important;
}

/* Validation error (fields missing) */
.wpcf7-form.invalid .wpcf7-response-output {
    background:  rgba(241, 196, 15, .12) !important;
    border-inline-start: 3px solid #f0ad4e !important;
    color:       #7d6608 !important;
}

/* Spam */
.wpcf7-form.spam .wpcf7-response-output {
    background:  rgba(149, 165, 166, .15) !important;
    border-inline-start: 3px solid #95a5a6 !important;
    color:       #4a5568 !important;
}

/* ================================================================
   CF7 submit button — input[type=submit] override to match .btn-gold
   ================================================================ */
input.wpcf7-submit {
    display:        inline-flex;
    align-items:    center;
    gap:            9px;
    font-family:    inherit;
    font-size:      .96rem;
    font-weight:    800;
    padding:        13px 26px;
    border-radius:  40px;
    border:         none;
    cursor:         pointer;
    transition:     background .2s, transform .15s;
    width:          100%;
    justify-content:center;
    margin-top:     8px;
}
input.wpcf7-submit.btn-gold {
    background:  var(--gold);
    color:       var(--navy-deep);
    box-shadow:  0 14px 30px -16px rgba(202, 177, 144, .90);
}
input.wpcf7-submit.btn-gold:hover {
    background:  var(--gold-soft);
    transform:   translateY(-2px);
}
input.wpcf7-submit[disabled],
input.wpcf7-submit[aria-busy="true"] {
    opacity:    .65;
    cursor:     not-allowed;
    transform:  none;
}

/* ================================================================
   CF7 AJAX loading spinner — hidden while not submitting
   ================================================================ */
.wpcf7 .ajax-loader {
    display:        none !important; /* Replaced by button disabled state */
}

/* ================================================================
   CF7 select field — ensure consistent padding with text inputs
   ================================================================ */
.wpcf7-form select.wpcf7-select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2314253B' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: left 14px center;
    padding-inline-end: 38px;
}
[dir="rtl"] .wpcf7-form select.wpcf7-select {
    background-position: right 14px center;
    padding-inline-end: 15px;
    padding-inline-start: 38px;
}

/* ================================================================
   LTR input direction for email/tel/URL fields (both RTL and LTR pages)
   ================================================================ */
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"] {
    direction:  ltr;
    text-align: right; /* keep caret at right edge for Arabic UX */
}
[dir="ltr"] .wpcf7-form input[type="email"],
[dir="ltr"] .wpcf7-form input[type="tel"],
[dir="ltr"] .wpcf7-form input[type="url"] {
    text-align: left;
}

/* ================================================================
   Single product detail — responsive two-column layout
   (NICE-06 fix: replaces inline grid-template-columns:260px 1fr)
   ================================================================ */
.product-detail-grid {
    display:     grid;
    grid-template-columns: 260px 1fr;
    gap:         48px;
    align-items: start;
}
@media (max-width: 760px) {
    .product-detail-grid {
        grid-template-columns: 1fr;
    }
}
