/* Policy page styles */


/* fixes education theme stuff */
.ac-ul {
    margin-left: 0 !important;
    padding: 1.5em 2em;
    list-style: none;
}

.ac-ul li {
    line-height: 1.5em;
}

/* Single policy styles to match index layout */
.policy-single .policy-number {
    font-weight: 600;
    font-size: 2rem;
    color: #2b2b2b;
    margin-bottom: .5rem;
}

.policy-single .policy-header {
    margin-bottom: 1.6rem;
}

.policy-single .policy-title {
    font-size: 2rem;
    margin: 0 0 .25rem 0;
    text-transform: none;
}

.policy-single .policy-date {
    color: #666;
    font-size: 1.2rem;
    margin-bottom: .5rem;
}

.policy-single .policy-download .btn {
    display: inline-block;
}

.policy-single .policy-description {
    margin: 1rem 0;
}

.policy-single .policy-content {
    margin-top: 1rem;
}

/* Small responsive tweak: stack columns on narrow screens */
@media (max-width: 767px) {
    .policy-single .col-md-1, .policy-single .col-md-11 {
        width: 100%;
        display: block;
    }
    .policy-single .policy-number {
        margin-bottom: .75rem;
    }
}

/* subtle chevron for child items */
.policy-child .policy-title a::before,
.policy-child-orphan .policy-title a::before {
    display: none; /* icon moved to the policy number for child items */
}

.policy-child .policy-title a,
.policy-child-orphan .policy-title a,
.policy-child .policy-title,
.policy-child-orphan .policy-title {
    /* Match parent policy title size for visual parity */
    font-size: 1.8rem;
    font-weight: 700;
}

.policy-parent + .policy-children {
    margin-top: 1rem;
}

.ac-ul li a {
    font-weight: bold;
    text-decoration: underline;
}

.content-container {
    margin-top: 2em;
}

.program-info {
    background-color: #e5e5e5;
    padding: 1em;
    margin-bottom: 0.5em;
}

.program-heading {
    text-transform: none;
    font-weight: 600;
}

.program-info ul, .course-directory ul {
    margin-left: 0px;
    padding-left: 2em;
}

.tab-content ul, .tab-content ol, .type-course ul, .type-course ol {
    margin-left: 0px;
    padding-left: 2em;
}

.apply-more-details {
    padding: 1em;
    border: 1px solid #ccc;
}

.housing-information-button,
.courses-program-button,
.tuition-fees-button,
.apply-online-button,
.directory-main-button,
.directory-bottom-button,
.btn-gen {
    width: 100%;
    color: white;
    display: block;
    text-align: center;
    font-size: 2.8rem;
    padding: 0.3em;
    margin-bottom: 0.5em;
    font-weight: 400;
    line-height: 1.2em;
}

/* Hero styles */
.hero-container {
    margin-bottom: 1em;
}

.alert-container {
    margin-bottom: 1em;
}

.alert-container .bg-info {
    padding: 1em;
    font-weight: 400;
}

.fab, .fa {
    font-family: FontAwesome;
    font-weight: 400;
}

.fa, .fab, .fad, .fal, .far, .fas {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
}

/* Scoped, Bootstrap-3-safe styles for the Policies index */
.policies-index {
  --policies-bg: #ffffff;
  --policies-fg: #0f172a;
  --policies-muted: #6b7280;
  --policies-border: #e5e7eb;
  --policies-accent: #2563eb;
  --policies-accent-fg: #ffffff;
  --policies-badge: #f1f5f9;
  --policies-shadow: 0 1px 2px rgba(0,0,0,.05), 0 2px 8px rgba(0,0,0,.04);
  color: var(--policies-fg);
}

/* Filter bar */
.policies-index .policy-index-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 1rem 2rem; /* row / column gap */
    margin: 1.5rem 0;
    background-color: #003a6a;
    padding: 1.5rem 3rem;
    border-radius: .75rem;
    width: 100%;
    box-sizing: border-box;
}

.policies-index .policy-index-filters label {
  display: flex;
  flex-direction: column;
  font-size: 1.5rem;
  color: rgb(246, 243, 243);
  font-weight: bold;
  margin-bottom: 0;
}

.policies-index .policy-index-filters .policy-filter-field {
    display: flex;
    flex-direction: column;
    flex: 1 1 220px; /* grow, shrink, min width */
    margin-bottom: 0;
}

.policies-index .policy-index-filters .policy-filter-label-text {
    font-size: 1.5rem;
    color: rgb(246, 243, 243);
    font-weight: bold;
    margin-bottom: .3rem;
}

.policies-index .policy-index-filters input[type="search"],
.policies-index .policy-index-filters input[type="date"],
.policies-index .policy-index-filters select {
    border: 1px solid var(--policies-border);
    padding: .5rem .6rem;
    border-radius: .5rem;
    background: #fff;
    color: var(--policies-fg);
    line-height: 1.2;
    width: 100%;
    max-width: 100%;
}

.policies-index .policy-index-filters .policy-filter-submit {
    margin-left: auto; /* pushes button to the right edge */
    border: 1px solid var(--policies-accent);
    background: var(--policies-accent);
    color: var(--policies-accent-fg);
    padding: .55rem 1.2rem;
    border-radius: .5rem;
    cursor: pointer;
    transition: transform .04s ease-in-out, opacity .15s ease;
    font-weight: 600;
    white-space: nowrap;
}

.policies-index .policy-index-filters .policy-filter-submit:hover {
    opacity: .95;
}

.policies-index .policy-index-filters .policy-filter-submit:active {
    transform: translateY(1px);
}

/* Category heading */
.policies-index h2 {
    margin: 1.5rem 0 1rem;
    font-size: 2.6rem;
    font-weight: 600;
    border-top: 2px solid var(--policies-border);
    padding-top: .75rem;
    color: var(--policies-muted);
    text-transform: none !important;
}

/* List + cards */
.policies-index .policy-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: .6rem;
}

/* Meta row */
.policies-index .policy-meta {
    font-size: 1.3rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    width: 100%;
}

.policies-index .policy-badge {
  display: inline-block;
  padding: .15rem .5rem;
  border-radius: 999px;
  background: var(--policies-badge);
  border: 1px solid var(--policies-border);
  font-size: .82rem;
  line-height: 1.2;
  color: #111827;
}


.policies-index .policy-entry {
    border-bottom: none;
    padding-bottom: 1rem;
    margin: 1rem 0;
}

.policies-index .policy-number {
    font-weight: 600;
    font-size: 1.5rem;
    color: #111827;
    margin-right: 1rem;
    text-align: left;
    display: inline-block;
}

.policies-index .policy-title {
    font-weight: bold;
    font-size: 1.8rem;
}

/* Actions */
.policies-index .policy-actions {
  margin-top: .5rem;
}
.policies-index .policy-actions .policies-btn {
  display: inline-block;
  font-size: .88rem;
  padding: .45rem .7rem;
  border-radius: .5rem;
  border: 1px solid var(--policies-border);
  background: #fff;
  color: #111827;
  text-decoration: none;
  transition: background-color .15s ease, border-color .15s ease;
}
.policies-index .policy-actions .policies-btn:hover {
  background: #f9fafb;
  border-color: #d1d5db;
}
.policies-index .policy-actions .policies-btn.is-primary {
  background: var(--policies-accent);
  border-color: var(--policies-accent);
  color: var(--policies-accent-fg);
}
.policies-index .policy-actions .policies-btn.is-primary:hover {
  filter: brightness(0.98);
}

/* Optional description teaser */
.policies-index .policy-desc {
  margin-top: .4rem;
  font-size: .92rem;
  color: #1f2937;
}

/* Print-friendly */
@media print {
  .policies-index .policy-index-filters { display: none !important; }
}

/* Mobile fixes */
@media (max-width: 990px) {
    .main-content-tabs {
        margin-left: 0px !important;
        margin-right: 0px !important;
        margin-bottom: 16px;
    }

    .entry-content {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }
}

@media (max-width: 768px) {
    .entry-content .main-heading {
        margin-top: 60px;
    }

    /* Tighten the filter bar on mobile */
    .policies-index .policy-index-filters {
        flex-direction: column;
        align-items: stretch;
        /* smaller padding + margin so it doesn’t look so tall */
        padding: 0.75rem 1rem;
        margin: 1rem 0;
        gap: 0.75rem; /* less vertical gap between rows */
    }

    /* Override the mb-4 spacing on the form itself */
    .policies-index .policy-index-filters.mb-4 {
        margin-bottom: 1rem !important;
    }

    /* Make fields compact but full width */
    .policies-index .policy-index-filters .policy-filter-field {
        margin-bottom: 0;
        flex: none;
    }

    .policies-index .policy-index-filters .policy-filter-label-text {
        font-size: 1.3rem;
        margin-bottom: 0.2rem;
    }

    .policies-index .policy-index-filters input[type="search"],
    .policies-index .policy-index-filters select {
        padding: 0.45rem 0.6rem;
    }

    /* Button full-width and close to the fields */
    .policies-index .policy-index-filters .policy-filter-submit {
        margin-left: 0;
        width: 100%;
        text-align: center;
        margin-top: 0.2rem;
    }
}