/*
 * ECEID Portal – Global Styles
 *
 * Keep this theme lean. Prefer small, reusable components.
 */

:root{
  /* ECEID primary brand */
  --ea-brand:#003b95;

  /* CTA accent (keep as-is) */
  --ea-accent:#f37021;
  --ea-accent-700:#d65f17;
  --ea-text:#1b2430;
  --ea-muted:#6b7280;
  --ea-border:#e5e7eb;
  --ea-bg:#f6f7f8;
  --ea-card:#ffffff;
  /* Match the main site container width */
  --ea-container:1345px;
  --ea-radius:6px;
  --ea-shadow:0 8px 22px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html{scrollbar-gutter:stable}
body{
  margin:0;
  font-family:Roboto,system-ui,-apple-system,Segoe UI,Arial,sans-serif;
  color:var(--ea-text);
  background:#fff;
  line-height:1.6;
}

img{max-width:100%;height:auto;display:block}

a{color:inherit}
a:hover{text-decoration:none}

.container{max-width:var(--ea-container);margin:0 auto;padding:0 24px}

.ea-sr-only{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0;border:0;height:1px;width:1px;overflow:hidden}

/* ===== Header ===== */
.ea-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:#fff;
  border-bottom:1px solid var(--ea-border);
}
.ea-header__inner{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:16px;
  /* Match main website header rhythm */
  padding:16px 0;
  min-height:76px;
}

/* Match main website logo size */
.ea-header__logo img{max-height:50px;width:auto}

/* Keep menu near logo (left-aligned header) */
.ea-header__brand{margin-left:-4px}
.ea-nav{margin-left:18px}

/* Align header container padding with main website */
.ea-header .container{padding-left:15px;padding-right:15px}

.ea-nav{display:flex;align-items:center}
.ea-nav__list{
  list-style:none;
  display:flex;
  gap:18px;
  margin:0;
  padding:0;
  align-items:center;
}
.ea-nav__list a{
  text-decoration:none;
  font-weight:600;
  opacity:.92;
}
.ea-nav__list a:hover{opacity:1;text-decoration:underline}

.ea-nav__toggle{
  display:none;
  border:1px solid var(--ea-border);
  background:#fff;
  color:var(--ea-text);
  border-radius:999px;
  padding:8px 12px;
  cursor:pointer;
}

.ea-header__actions{display:flex;align-items:center;gap:10px;margin-left:auto}

/* ===== Buttons ===== */
.ea-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 16px;
  border-radius:var(--ea-radius);
  text-decoration:none;
  font-weight:700;
  border:1px solid transparent;
  cursor:pointer;
  transition:filter .15s ease, background .15s ease;
}
.ea-btn--primary{background:var(--ea-accent);color:#fff}
.ea-btn--primary:hover{background:var(--ea-accent-700);filter:brightness(.98)}
.ea-btn--secondary{background:#fff3ea;color:var(--ea-text);border-color:#ffd7bf}
.ea-btn--secondary:hover{background:#ffe9d6}
.ea-btn--ghost{background:transparent;color:var(--ea-text);border-color:var(--ea-border)}
.ea-btn--ghost:hover{background:#f8fafc}

/* ===== Forms ===== */
.ea-form{display:flex;flex-direction:column;gap:12px;max-width:620px}
.ea-form__label{font-weight:700}
.ea-form__req{color:#ef4444}
.ea-form__input{
  width:100%;
  padding:11px 12px;
  border:1px solid var(--ea-border);
  border-radius:var(--ea-radius);
  font-size:16px;
  background:#fff;
}
.ea-form__input:focus{outline:2px solid rgba(0,59,149,.25);border-color:#9fb8e6}
.ea-form__remember{display:flex;gap:8px;align-items:center;color:var(--ea-muted);font-size:14px}
.ea-form__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}

/* Two-column rows for related fields */
.ea-form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* Radio groups */
.ea-form__radios{display:flex;flex-wrap:wrap;gap:10px}
.ea-form__radio{display:flex;gap:8px;align-items:center}

@media (max-width: 560px){
  .ea-form__row{grid-template-columns:1fr}
}

/* Improve spacing inside card-based forms (Create Account uses .ea-card wrappers) */
.ea-card .ea-form__label{display:block;margin:0 0 6px}
.ea-card .ea-form__input{margin:0 0 12px}

/* Create Account page layout: form + right-side ACF content */
.ea-create-account{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:28px;align-items:start}
.ea-create-account__card{padding:16px}
.ea-create-account__img{border-radius:var(--ea-radius);margin:0 0 12px}
.ea-create-account__sidebar-title{margin:0 0 8px;font-size:18px}
.ea-create-account__sidebar-content{margin:0;color:var(--ea-muted)}

@media (max-width: 980px){
  .ea-create-account{grid-template-columns:1fr}
}

/* ===== Alerts ===== */
.ea-alert{
  border:1px solid;
  padding:12px 14px;
  border-radius:var(--ea-radius);
  margin:0 0 14px;
}
.ea-alert--error{border-color:#fecaca;background:#fff1f2;color:#7f1d1d}
.ea-alert--success{border-color:#bbf7d0;background:#f0fdf4;color:#065f46}

/* ===== Content / Pages ===== */
.ea-content{min-height:60vh}
.ea-page{padding:32px 0 64px}
.ea-page__intro{max-width:720px;color:var(--ea-muted)}

.ea-article{padding:32px 0 64px}
.ea-article__title{margin:0 0 10px}
.ea-article__meta{color:var(--ea-muted);font-size:14px}

.ea-card{background:var(--ea-card);border:1px solid var(--ea-border);border-radius:var(--ea-radius);padding:16px;margin:16px 0}
.ea-card__title{margin:0 0 8px;font-size:18px}
.ea-card__title a{text-decoration:none}
.ea-card__title a:hover{text-decoration:underline}

.ea-loop{padding:24px 0 48px}

/* ===== Footer ===== */
.ea-footer{
  background:#000A1B;
  color:#fff;
  margin-top:48px;
}
.ea-footer__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px;
  padding:32px 24px;
}
.ea-footer__heading{
  margin:0 0 12px;
  font-size:18px;
  font-weight:800;
  border-top:3px solid rgba(255,255,255,.2);
  padding-top:10px;
}
.ea-footer__menu{list-style:none;margin:0;padding:0}
.ea-footer__menu li{margin:10px 0}
.ea-footer__menu a{color:#fff;text-decoration:none;opacity:.9}
.ea-footer__menu a:hover{opacity:1;text-decoration:underline}

.ea-footer__legal{
  border-top:1px solid rgba(255,255,255,.2);
  padding:18px 24px 26px;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  font-size:14px;
}
.ea-footer__links{display:flex;gap:14px;flex-wrap:wrap}
.ea-footer__links a{color:#fff;text-decoration:none;opacity:.9;font-weight:700}
.ea-footer__links a:hover{opacity:1;text-decoration:underline}

/* ===== Responsive ===== */
@media (max-width: 900px){
  .ea-footer__grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width: 780px){
  .ea-nav__toggle{display:inline-flex}
  .ea-nav{display:none;position:absolute;left:0;right:0;top:72px;background:#fff;border-bottom:1px solid var(--ea-border)}
  .ea-nav.is-open{display:block}
  .ea-nav__list{flex-direction:column;align-items:flex-start;padding:14px 24px}
}

@media (max-width: 560px){
  .ea-footer__grid{grid-template-columns:1fr}
}

/* ===== RTL ===== */
html[dir="rtl"] .ea-form__actions{justify-content:flex-start}
html[dir="rtl"] .ea-nav__list{direction:rtl}

/* ===== Create Account: Autocomplete ===== */
.ea-is-hidden{display:none!important}

.ea-autocomplete{
  position:relative;
}

.ea-autocomplete__panel{
  position:relative;
}

#ea_partner_school_results{
  margin-top:6px;
  border:1px solid var(--ea-border);
  border-radius:var(--ea-radius);
  background:#fff;
  box-shadow:var(--ea-shadow);
  max-height:240px;
  overflow:auto;
}

.ea-autocomplete__list{list-style:none;margin:0;padding:6px 0}

.ea-autocomplete__item{
  padding:10px 12px;
  cursor:pointer;
  border-bottom:1px solid #f1f5f9;
}
.ea-autocomplete__item:last-child{border-bottom:none}
.ea-autocomplete__item:hover{background:#f8fafc}

.ea-autocomplete__loading,
.ea-autocomplete__empty{
  padding:10px 12px;
  color:var(--ea-muted);
}


/* ===== Dashboard ===== */
.ea-dashboard-hero{
  background:linear-gradient(135deg,#003b95,#002f76);
  color:#fff;
  padding:26px 0 24px;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.ea-dashboard-hero__title{
  margin:0;
  font-size:clamp(28px,3.2vw,44px);
  font-weight:900;
  letter-spacing:.2px;
}
.ea-dashboard{
  padding:28px 0 64px;
}
.ea-dashboard__grid{
  display:grid;
  /* Sidebar (left) + main content (right) */
  grid-template-columns:392px minmax(0,1fr);
  gap:28px;
  align-items:start;
}

/* Dashboard – left sidebar (Membership Tools) */
.ea-dashboard__sidebar{
  position: sticky;
  top: 92px;
  align-self: start;
}

.ea-related{
  margin: 0 0 2rem 0;
}

.ea-related__title{
  color: #111827;
  font-size: .875rem;
  font-weight: 600;
  margin: 0;
  padding: 0 0 .75rem 0;
  border-bottom: 1px solid #e5e7eb;
}

.ea-related__item{
  border-top: 0;
  border-bottom: 1px solid #e5e7eb;
}

.ea-related__link{
  align-items: center;
  display: grid;
  gap: .25rem;
  grid-template-columns: 1fr var(--ea-sidebar-icon-col);
  justify-content: space-between;
  padding: 1.25rem 0;
  text-decoration: none;
  color: var(--ea-text);
  font-weight: 500;
}

.ea-related__link:hover{
  color: var(--ea-accent);
}

.ea-related__linkText{
  min-width: 0;
}

.ea-related__linkIcon{
  justify-self: end;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  height: 1.75rem;
  padding: 0;
  background: transparent;
  border-radius: 0;
  color: var(--ea-brand);
}

.ea-related__link:hover .ea-related__linkIcon{
  color: var(--ea-brand);
}

.ea-related__linkIcon svg{
  width: 1.75rem;
  height: 1.75rem;
  display: block;
}

/* Accordion (used for menu items that have children) */
.ea-accordion{
  --ea-accordion-height-closed: 3rem;
  background: #fff;
  height: var(--ea-accordion-height-closed);
  overflow: hidden;
  transition: height .18s ease;
}

.ea-accordion[open]{
  height: fit-content;
}

.ea-accordion__summary{
  align-items: center;
  cursor: pointer;
  display: grid;
  grid-auto-flow: column;
  justify-items: start;
  list-style: none;
  outline-offset: 2px;
  padding: .5rem 0;
  user-select: none;
}

.ea-accordion__summary::-webkit-details-marker{
  display: none;
}

.ea-accordion__heading{
  min-width: 0;
  padding: .25rem 0;
  margin: 0;
  font-weight: 500;
}

.ea-accordion__iconWrapper{
  display: grid;
  justify-self: end;
  padding: .5rem;
}

.ea-accordion__icon{
  aspect-ratio: 1;
  color: var(--ea-green);
  height: 1em;
  width: 1em;
  transition: transform .18s ease;
}

.ea-accordion[open] .ea-accordion__icon{
  transform: rotate(90deg);
}

.ea-accordion__content{
  padding: 0 .5rem 1.5rem;
}

.ea-related__sublist{
  list-style: none;
  margin: 0;
  padding: 0;
}

.ea-related__subitem + .ea-related__subitem{
  border-top: 1px solid #e5e7eb;
}

.ea-related__sublink{
  align-items: center;
  display: grid;
  gap: .25rem;
  grid: auto / auto auto;
  justify-content: space-between;
  padding: .75rem 0;
  text-decoration: none;
  color: var(--ea-text);
  font-weight: 400;
  font-size: .95rem;
}

.ea-related__sublink:hover{
  color: var(--ea-accent);
}

.ea-related__sublinkIcon{
  background: rgba(11, 58, 57, 0.10);
  border-radius: 1.5rem;
  display: grid;
  height: 1.5rem;
  width: 1.5rem;
  padding: .375rem;
  place-items: center;
  color: var(--ea-green);
}

.ea-related__sublink:hover .ea-related__sublinkIcon{
  background: rgba(11, 58, 57, 0.14);
}

.ea-related__sublinkIcon svg{
  width: 100%;
  height: 100%;
  display: block;
}

/* Shell loading (animated placeholders) */
.ea-shell-skeleton{display:none;}

html.ea-js.ea-shell-loading .ea-shell-skeleton{display:block;}
html.ea-js.ea-shell-loading .ea-shell-content{display:none !important;}

.ea-skeleton{
  background: linear-gradient(90deg, rgba(15, 23, 42, 0.06) 0%, rgba(15, 23, 42, 0.10) 50%, rgba(15, 23, 42, 0.06) 100%);
  background-size: 200% 100%;
  animation: ea-skeleton-shimmer 1.2s ease-in-out infinite;
  border-radius: 8px;
}

@keyframes ea-skeleton-shimmer{
  0%{background-position: 200% 0;}
  100%{background-position: -200% 0;}
}

.ea-skeleton--line{height: 12px;}
.ea-skeleton--title{height: 18px;}
.ea-skeleton--banner{height: 86px; border-radius: var(--ea-radius);}
.ea-skeleton--message{height: 54px; border-radius: var(--ea-radius);}
.ea-skeleton--button{height: 40px; width: 128px; border-radius: 10px;}


/* Banner-style message (dashboard_banner ACF field) */
.ea-dashboard__messages{margin: 0 0 18px 0;}

.ea-message{
  border: 1px solid #c7d2fe;
  background: #eef2ff;
  color: #0f172a;
  border-radius: var(--ea-radius);
  padding: 14px 44px 14px 14px;
  position: relative;
}

.ea-message__close{
  position: absolute;
  top: 10px;
  right: 10px;
  border: 0;
  background: transparent;
  font-size: 18px;
  cursor: pointer;
  line-height: 1;
  width: 30px;
  height: 30px;
  border-radius: 999px;
}

.ea-message__close:hover{
  background: rgba(15, 23, 42, 0.06);
}

.ea-message__body p{margin: 0 0 10px 0;}
.ea-message__body p:last-child{margin-bottom: 0;}

@media (max-width: 980px){
  .ea-dashboard__grid{grid-template-columns:1fr}
  .ea-dashboard__sidebar{position: static; top: auto;}
}

.ea-banner{
  border:1px solid #c7d2fe;
  background:#eef2ff;
  color:#0f172a;
  border-radius:var(--ea-radius);
  padding:14px 14px;
  margin:0 0 18px;
  position:relative;
}
.ea-banner__close{
  position:absolute;
  top:10px;
  right:10px;
  border:0;
  background:transparent;
  font-size:18px;
  cursor:pointer;
  line-height:1;
  color:#0f172a;
  opacity:.7;
}
.ea-banner__close:hover{opacity:1}
.ea-banner__title{
  font-weight:900;
  margin:0 24px 6px 0;
}
.ea-banner__text{
  margin:0;
  color:#334155;
}

.ea-dashboard-cards{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.ea-dashboard-cards .ea-card{margin:0}
@media (max-width: 980px){
  .ea-dashboard-cards{grid-template-columns:1fr}
}

.ea-profile-mini__meta{
  color:var(--ea-muted);
  font-size:13px;
  font-weight:500;
}

/* Header avatar */
.ea-avatar-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid var(--ea-border);
  background:#fff;
  overflow:hidden;
}
.ea-avatar-link img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.ea-avatar-fallback{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:var(--ea-brand);
  background:#f0fdf4;
}


/* Account dropdown menu (header) */
.ea-account{
  position:relative;
  display:inline-flex;
  align-items:center;
}
.ea-account__toggle{
  cursor:pointer;
  padding:0;
  border:0;
  background:transparent;
}

.imd-drop-menu{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  width:290px;
  max-width:calc(100vw - 24px);
  background:#fff;
  border:1px solid var(--ea-border);
  border-radius:16px;
  box-shadow:0 18px 48px rgba(15, 23, 42, 0.18);
  overflow:hidden;
  display:none;
  z-index:999;
}
.imd-drop-menu.is-open{display:block;}

.imd-drop-menu__header{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 14px;
  border-bottom:1px solid var(--ea-border);
  background:#fff;
}
.imd-drop-menu__avatar{
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid var(--ea-border);
  background:#fff;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.imd-drop-menu__avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.imd-drop-menu__name{
  font-weight:900;
  font-size:16px;
  line-height:1.1;
}
.imd-drop-menu__meta{
  margin-top:2px;
  color:var(--ea-muted);
  font-weight:600;
  font-size:12px;
}

.imd-drop-menu__body{padding:8px 0;}

.imd-drop-menu__list{
  list-style:none;
  margin:0;
  padding:0;
}
.imd-drop-menu__list li{margin:0;}
.imd-drop-menu__list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 14px;
  color:var(--ea-text);
  text-decoration:none;
  font-weight:700;
}
.imd-drop-menu__list a:hover{
  background:#f8fafc;
}

.imd-drop-menu__logout{
  display:block;
  padding:10px 14px;
  border-top:1px solid var(--ea-border);
  text-decoration:none;
  font-weight:800;
  color:#b91c1c;
}
.imd-drop-menu__logout:hover{
  background:#fef2f2;
}


/* Simple input helper (used in profile) */
.ea-input{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--ea-border);
  border-radius:10px;
  outline:none;
}
.ea-input:focus{
  border-color:var(--ea-brand);
  box-shadow:0 0 0 3px rgba(245,130,32,.15);
}


/* =========================================================
   PATCH3 (ECEID): Layout + Membership Tools refinements
   - Global container width: 1345px
   - Sidebar icons aligned in one vertical column (main + sub)
   - Clear separators between all items
   ========================================================= */

/* Global: keep the portal layout consistent across templates */
.container{
  max-width:1345px;
}

/* Membership Tools sidebar: align chevrons + arrow circles */
.ea-related{
  --ea-sidebar-icon-col:3rem;
  --ea-sidebar-icon-pad:.25rem;
  --ea-sidebar-row-height:3rem;
}

/* Unify layout: text column + fixed icon column */
.ea-accordion__summary,
.ea-related__link,
.ea-related__sublink{
  display:grid;
  grid-template-columns:1fr var(--ea-sidebar-icon-col);
  align-items:center;
  column-gap:1rem;
}

/* Make borders/separators consistent */
.ea-accordion,
.ea-related__link,
.ea-related__subitem,
.ea-related__subitem + .ea-related__subitem{
  border-color:var(--ea-border) !important;
}

/* Ensure every subitem has a divider (including first) */
.ea-related__subitem{
  border-top:1px solid var(--ea-border);
}

/* Remove visual drift caused by padding differences */
.ea-accordion__summary,
.ea-related__link,
.ea-related__sublink{
  padding-right:var(--ea-sidebar-icon-pad);
}

/* Main (accordion) chevron placement */
.ea-accordion__iconWrapper{
  padding:0;
  justify-self:end;
  width:var(--ea-sidebar-icon-col);
  display:flex;
  align-items:center;
  justify-content:flex-end;
}

/* Slightly larger chevron */
.ea-accordion__icon{
  width:22px;
  height:22px;
  color:var(--ea-brand);
}

/* Link + sublink icon placement: keep on the same vertical rule */
.ea-related__linkIcon,
.ea-related__sublinkIcon{
  justify-self:end;
}

/* Top-level (leaf) items: keep the chevron plain (no circle) */
.ea-related__linkIcon{
  width:100%;
  height:100%;
  padding:0;
  background:transparent;
  border-radius:0;
  color:var(--ea-brand);
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.ea-related__linkIcon svg{
  width:22px !important;
  height:22px !important;
  display:block !important;
}

/* Sub-items: circular arrow (slightly larger for readability) */
.ea-related__sublinkIcon{
  width:2.25rem;
  height:2.25rem;
  padding:.5rem;
  background:rgba(0,59,149,.10);
  border-radius:999px;
  color:var(--ea-brand);
}

/* Make SVG fill the circle consistently */
.ea-related__sublinkIcon svg{
  width:100% !important;
  height:100% !important;
  display:block !important;
}

/* Keep top-level items visually consistent with accordion rows */
.ea-related__link{
  min-height:var(--ea-sidebar-row-height);
  padding-top:0;
  padding-bottom:0;
}

/* Remove extra indentation so icons align in one vertical rule */
.ea-accordion__content{
  padding-left:0;
  padding-right:0;
}

.ea-related__sublink{
  padding:1rem 0 1rem 1rem;
}


/* PATCH3: avoid double line directly under the sidebar title */
.ea-related__title + .ea-accordion,
.ea-related__title + .ea-related__link{
  border-top:0;
}
