/*
Theme Name:   Binox AGM Child
Theme URI:    https://textelcu.com/
Description:  Child theme of Binox for Textel Credit Union, adds the AGM 2026 Portal section.
Author:       IKAIA / Textel Credit Union
Template:     binox
Version:      0.1.0
Text Domain:  binox-child
*/

/* ------- AGM Portal scope: only applies on pages with .agm-portal wrapper ------- */

.agm-portal {
    --agm-accent:        #263CD9;        /* Textel brand blue */
    --agm-accent-dark:   #1a2ba8;
    --agm-accent-tint:   rgba(38, 60, 217, .08);
    --agm-ink:           #121212;        /* Textel ink (matches body copy in live site) */
    --agm-muted:         #6b7280;
    --agm-soft:          #f5f7fb;
    --agm-line:          #e5e9f0;
    --agm-radius:        12px;
    --agm-gap:           clamp(1rem, 2vw, 1.75rem);
}

.agm-portal h1, .agm-portal h2, .agm-portal h3 { color: var(--agm-ink); }
.agm-portal .container { max-width: 1200px; margin: 0 auto; padding: 0 1.25rem; }

/* ---------- Hero ---------- */
.agm-hero {
    background: linear-gradient(135deg, var(--agm-ink) 0%, #2a3447 100%);
    color: #fff;
    padding: clamp(2.5rem, 6vw, 4.5rem) 0 clamp(2rem, 5vw, 3.5rem);
    margin-bottom: 0;
}
.agm-hero__kicker { letter-spacing: .12em; text-transform: uppercase; font-size: .8rem; opacity: .75; margin-bottom: .5rem; }
.agm-hero__title  { font-size: clamp(1.75rem, 4vw, 2.75rem); line-height: 1.15; margin: 0 0 .75rem; color: #fff; }

/* Welcome-page (hub) hero treatment — larger, more elegant kicker */
.agm-portal--hub .agm-hero__kicker {
    display: inline-flex;
    align-items: center;
    font-size: clamp(1.05rem, 1.9vw, 1.5rem);
    letter-spacing: .26em;
    font-weight: 500;
    opacity: 1;
    margin-bottom: 1.5rem;
    padding-top: 1rem;
    position: relative;
}
.agm-portal--hub .agm-hero__kicker::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 56px;
    height: 1px;
    background: linear-gradient(90deg, var(--agm-accent) 0%, rgba(255, 255, 255, .35) 100%);
}
.agm-hero__lede   { font-size: clamp(1rem, 1.6vw, 1.15rem); max-width: 60ch; opacity: .9; margin: 0; }

/* ---------- Sub-nav ---------- */
.agm-subnav {
    background: #fff;
    border-bottom: 1px solid var(--agm-line);
    position: sticky; top: 0; z-index: 50;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.agm-subnav__list { display: flex; gap: 0; list-style: none; margin: 0; padding: 0; min-width: max-content; }
.agm-subnav__list a {
    display: block; padding: 1rem 1.25rem;
    color: var(--agm-ink); text-decoration: none;
    font-weight: 500; font-size: .95rem;
    border-bottom: 3px solid transparent;
    transition: color .15s, border-color .15s;
}
.agm-subnav__list a:hover { color: var(--agm-accent); }
.agm-subnav__list .is-current a { color: var(--agm-accent); border-bottom-color: var(--agm-accent); }

/* ---------- Section / cards ---------- */
.agm-section { padding: clamp(2rem, 5vw, 3.5rem) 0; }
.agm-section--soft { background: var(--agm-soft); }
.agm-section__title { font-size: clamp(1.4rem, 2.4vw, 1.75rem); margin: 0 0 1.5rem; }
.agm-section__intro { color: var(--agm-muted); max-width: 65ch; margin: 0 0 2rem; }

.agm-grid { display: grid; gap: var(--agm-gap); }
.agm-grid--3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.agm-grid--2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }

.agm-card {
    background: #fff;
    border: 1px solid var(--agm-line);
    border-radius: var(--agm-radius);
    padding: 1.5rem;
    transition: transform .15s, box-shadow .15s;
}
.agm-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.06); }
.agm-card__icon {
    width: 44px; height: 44px; border-radius: 10px;
    background: var(--agm-accent-tint); color: var(--agm-accent);
    display: grid; place-items: center; font-weight: 700; font-size: 1.2rem;
    margin-bottom: .9rem;
}
.agm-card__title { margin: 0 0 .35rem; font-size: 1.1rem; }
.agm-card__body  { color: var(--agm-muted); margin: 0 0 1rem; font-size: .95rem; line-height: 1.55; }
.agm-card__cta   { color: var(--agm-accent); text-decoration: none; font-weight: 600; font-size: .9rem; }
.agm-card__cta::after { content: " \2192"; transition: margin-left .15s; }
.agm-card__cta:hover::after { margin-left: .25rem; }

/* ---------- Countdown ---------- */
.agm-countdown {
    background: #fff; border: 1px solid var(--agm-line);
    border-radius: var(--agm-radius);
    padding: 1.75rem;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem;
    text-align: center;
    max-width: 640px;
    margin: 1.5rem 0;
}
.agm-countdown__unit       { padding: .5rem; }
.agm-countdown__num        { font-size: clamp(1.6rem, 3vw, 2.25rem); font-weight: 700; color: var(--agm-accent); display: block; line-height: 1; }
.agm-countdown__label      { font-size: .8rem; color: var(--agm-muted); text-transform: uppercase; letter-spacing: .08em; margin-top: .35rem; display: block; }
.agm-countdown.is-passed .agm-countdown__num { color: var(--agm-muted); }

/* ---------- Buttons ---------- */
.agm-btn {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .75rem 1.25rem; border-radius: 8px;
    font-weight: 600; font-size: .95rem;
    text-decoration: none; cursor: pointer; border: 0;
    transition: background .15s, transform .1s;
}
.agm-btn--primary { background: var(--agm-accent); color: #fff; }
.agm-btn--primary:hover { filter: brightness(1.08); color: #fff; }
.agm-btn--ghost   { background: transparent; color: var(--agm-accent); border: 1px solid var(--agm-accent); }
.agm-btn--ghost:hover { background: var(--agm-accent-tint); color: var(--agm-accent); }

/* ---------- Document list ---------- */
.agm-doclist { list-style: none; padding: 0; margin: 0; display: grid; gap: .75rem; }
.agm-doclist li {
    display: flex; justify-content: space-between; align-items: center;
    padding: 1rem 1.25rem; background: #fff;
    border: 1px solid var(--agm-line); border-radius: var(--agm-radius);
}
.agm-doclist .doc-meta  { display: flex; flex-direction: column; }
.agm-doclist .doc-title { font-weight: 600; color: var(--agm-ink); }
.agm-doclist .doc-sub   { font-size: .85rem; color: var(--agm-muted); margin-top: .15rem; }
.agm-doclist .doc-empty { color: var(--agm-muted); font-style: italic; }

/* ---------- Forms ---------- */
.agm-form { background: #fff; border: 1px solid var(--agm-line); border-radius: var(--agm-radius); padding: 1.75rem; }
.agm-form__row     { margin-bottom: 1.25rem; }
.agm-form__row--two { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.agm-form label    { display: block; font-weight: 600; font-size: .9rem; margin-bottom: .4rem; color: var(--agm-ink); }
.agm-form input, .agm-form textarea, .agm-form select {
    width: 100%; padding: .65rem .85rem;
    border: 1px solid var(--agm-line); border-radius: 8px;
    font-size: .95rem; font-family: inherit;
    background: #fff;
}
.agm-form input:focus, .agm-form textarea:focus, .agm-form select:focus {
    outline: none; border-color: var(--agm-accent);
    box-shadow: 0 0 0 3px rgba(38, 60, 217, .18);
}
.agm-form textarea { min-height: 120px; resize: vertical; }
.agm-form__note { font-size: .85rem; color: var(--agm-muted); margin-top: .35rem; }
.agm-form__submit { margin-top: .5rem; }
.agm-form__notice { padding: 1rem 1.25rem; border-radius: 8px; margin-bottom: 1rem; }
.agm-form__notice--ok  { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.agm-form__notice--err { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }

/* ---------- FAQ accordion ---------- */
.agm-faq        { display: grid; gap: .75rem; }
.agm-faq__item  { background: #fff; border: 1px solid var(--agm-line); border-radius: var(--agm-radius); overflow: hidden; }
.agm-faq__q     { display: flex; justify-content: space-between; align-items: center; padding: 1.1rem 1.25rem; cursor: pointer; font-weight: 600; color: var(--agm-ink); user-select: none; gap: 1rem; }
.agm-faq__q::after { content: "+"; font-size: 1.4rem; color: var(--agm-accent); transition: transform .2s; line-height: 1; flex: 0 0 auto; }
.agm-faq__item[open] .agm-faq__q::after { transform: rotate(45deg); }
.agm-faq__a     { padding: 0 1.25rem 1.25rem; color: var(--agm-muted); line-height: 1.6; }

/* ---------- Candidates grid ---------- */
.agm-candidates__filters { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.5rem; }
.agm-candidates__filter  { padding: .5rem 1rem; border-radius: 999px; border: 1px solid var(--agm-line); background: #fff; color: var(--agm-ink); font-weight: 500; font-size: .9rem; cursor: pointer; }
.agm-candidates__filter.is-active { background: var(--agm-accent); color: #fff; border-color: var(--agm-accent); }
.agm-candidate          { background: #fff; border: 1px solid var(--agm-line); border-radius: var(--agm-radius); padding: 1.5rem; text-align: center; }
.agm-candidate__photo   { width: 96px; height: 96px; border-radius: 50%; background: var(--agm-soft); margin: 0 auto 1rem; object-fit: cover; display: block; }
.agm-candidate__photo--icon       { display: flex; align-items: center; justify-content: center; }
.agm-candidate__photo--icon svg   { width: 56px; height: 56px; fill: var(--agm-muted); }
.agm-candidate__name    { margin: 0 0 .25rem; font-size: 1.05rem; }
.agm-candidate__role    { font-size: .85rem; color: var(--agm-accent); text-transform: uppercase; letter-spacing: .06em; margin-bottom: .75rem; }
.agm-candidate__bio     { color: var(--agm-muted); font-size: .9rem; line-height: 1.55; }
.agm-candidates__empty  { background: var(--agm-soft); border: 1px dashed var(--agm-line); border-radius: var(--agm-radius); padding: 2rem; text-align: center; color: var(--agm-muted); }

/* ---------- Steps / timeline ---------- */
.agm-steps { list-style: none; padding: 0; margin: 0; counter-reset: step; display: grid; gap: 1rem; }
.agm-steps li { background: #fff; border: 1px solid var(--agm-line); border-radius: var(--agm-radius); padding: 1.25rem 1.25rem 1.25rem 4rem; position: relative; }
.agm-steps li::before { counter-increment: step; content: counter(step); position: absolute; left: 1.25rem; top: 1.25rem; width: 32px; height: 32px; border-radius: 50%; background: var(--agm-accent); color: #fff; display: grid; place-items: center; font-weight: 700; font-size: .9rem; }
.agm-steps h4 { margin: 0 0 .25rem; color: var(--agm-ink); }
.agm-steps p  { margin: 0; color: var(--agm-muted); font-size: .92rem; }

/* ---------- Misc ---------- */
.agm-meta-row { display: flex; flex-wrap: wrap; gap: .75rem; margin: 1.25rem 0 1.75rem; }
.agm-meta-row > div {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    background: linear-gradient(135deg, var(--agm-accent) 0%, var(--agm-accent-dark) 100%);
    border-radius: var(--agm-radius);
    padding: .85rem 1.25rem;
    min-width: 140px;
    box-shadow: 0 2px 6px rgba(38, 60, 217, .18);
    transition: transform .15s, box-shadow .15s;
}
.agm-meta-row > div:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(38, 60, 217, .25);
}
.agm-meta-row .label {
    font-size: .7rem;
    color: rgba(255, 255, 255, .78);
    text-transform: uppercase;
    letter-spacing: .09em;
    font-weight: 600;
}
.agm-meta-row .val {
    font-weight: 600;
    font-size: .95rem;
    color: #fff;
    line-height: 1.35;
}

.agm-callout {
    background: var(--agm-accent-tint);
    border-left: 4px solid var(--agm-accent);
    padding: 1.25rem 1.5rem;
    border-radius: 0 var(--agm-radius) var(--agm-radius) 0;
    margin: 1.5rem 0;
}
.agm-callout p:last-child { margin-bottom: 0; }

/* ---------- Responsive tweaks ---------- */
@media (max-width: 640px) {
    .agm-form__row--two { grid-template-columns: 1fr; }
    .agm-countdown      { grid-template-columns: repeat(2, 1fr); }
}
