/*
========================================
Document Page & Filter Styles
========================================
*/

/*
----------------------------------------
Form & Filter Bar
----------------------------------------
*/
.form-item__dropdown select {
    padding-left: 10px;
    padding: 0px;
    padding-left: 10px;
}

.form-item__dropdown {
    min-height: 53px;
}

.form-item__textfield {
    height: 55px;
}

.filter-button {
    background-color: #001489;
    color: white;
    padding: 8px;
}

#edit_subsites_list_chosen {
    width: 100% !important;
}

/* Filter <details> summary button */
.filter-documents-wrapper summary .filter-button {
    position: relative;
    display: inline-block;
    background-color: #001489;
    padding: 0.75rem 2.5rem 0.75rem 1rem; /* Right padding for arrow space */
    border-radius: 6px;
    font-size: 1.2rem;
    font-weight: 500;
    width: 22%;
}

/* Filter button ">" arrow */
.filter-documents-wrapper summary .filter-button::after {
    content: "❯";
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.5rem;
    transition: transform 0.3s ease;
    color: white; /* match your theme */
}

/* Rotate arrow when <details> is open */
.filter-documents-wrapper[open] summary .filter-button::after {
    transform: translateY(-50%) rotate(90deg);
}

.custom-select-arrow {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg fill='black' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 0.7em center;
    background-size: 1.5em; /* Bigger arrow */
    padding-right: 3em;     /* More space for arrow */
}

.filter-form-container {
    display: flex;
    gap: 20px; /* Space between fields */
    align-items: center;
}

.filter-form-container .form-item {
    flex: 1;
}

/*
----------------------------------------
Page Structure & Headers
----------------------------------------
*/
main {
    padding-left: 50px;
    padding-right: 50px;
}

.search-section, .documents-section {
    margin-bottom: 20px;
}

.search-section form {
    background-color: #dad0d0;
    padding: 15px;
    border-radius: 5px;
}

.search-section h2 {
    background-color: aqua;
    padding: 15px;
}

.category-description {
    padding: 20px;
    margin-bottom: 20px;
    background-color: white;
}

.document-section-header {
    display: block;
    background-image: linear-gradient(to right, #001489, #017dbb);
    color: white;
    padding-left: 40px;
    padding-right: 40px;
    padding-top: 10px;
    padding-bottom: 10px;
    margin-bottom: 20px;
}

.document-section-header h2 {
    color: white;
    display: block;
    margin-top: 10px;
    font-weight: bold;
    font-size: 3rem;
}

/*
----------------------------------------
Pill Buttons & Headings
----------------------------------------
*/
.pill-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 24px;
    font-size: 1rem;
    font-weight: 500;
    background-color: #0052a6;
    color: white;
    border: none;
    border-radius: 9999px;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
}

.pill-button:hover {
    background-color: #001489;
}

.pill-button svg {
    width: 20px;
    height: 20px;
    margin-right: 8px;
}

.pill-heading {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 24px;
    font-weight: 500;
    background-color: #017dbb;
    color: white;
    border-radius: 9999px;
    background-image: linear-gradient(to right, #002892, #0076b6);
}

/*
----------------------------------------
Accordion (media-list.html.twig)
----------------------------------------
*/
.accordion-header {    
    padding: 1.25rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;  /* Pushes arrow to right */
    cursor: pointer;
    color: #001489;
    background-color: #cccccc;
    font-size: 1.4rem;
    margin: 0;
    position: relative;
    padding-right: 4rem;
    transition: all .3s ease-in-out;
}

.accordion-content {
    display: none; /* Default is closed */
    padding: 20px;
    border-top: 1px solid #ddd;
    background-color: white;
    font-size: 17px;
}

.accordion-content .file-info {
    display: none;
    color:#a0a0a0;
    font-size: 65%;
}

.accordion-content li:has(> .file-info):hover .file-info {
    display: inline;
}

.accordion-content .first-level {
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 20px;
}

.accordion-item.active > .accordion-content {
    display: block;
}

.accordion-header.level-1 {
    background-color: #e9e9e9;
    font-weight: normal;
    padding-left: 20px;
}

/* Shared arrow style */
.accordion-header .arrow {
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-right: 8px;
    border: solid #333;
    border-width: 2px 2px 0 0;
    transform: rotate(45deg);
    transition: transform 0.3s ease;
}

.accordion-item.active > .accordion-header .arrow {
    transform: rotate(135deg);
}

.first-arrow {
    border-color: #001489;
}

.second-arrow {
    border-color: #555;
}

/*
----------------------------------------
Document Group (media-list.html.twig)
----------------------------------------
*/
.document-group {
    display: inline-block;
    border-radius: 5px;
    margin-bottom: 10px;
    padding-bottom: 1px;
}

.document-group h5 {
    font-weight: bold;
}

.document-group span {
    font-size: 70%;
    color: #a0a0a0ff;
}

.document-group div ul {
    float: left;
    padding-right: 10px;
}

.document-group h3 {
    padding: 10px;
    background-color: #001489;
    color: white;
}

.document-group .tags span {
    margin: 2px;
    padding-left: 10px;
    padding-right: 10px;
    border-radius: 25px;
    color: white;
    background-color: #7fa9ae;
}

.document-group ul {
    list-style-position: outside;
}

/*
----------------------------------------
Media Landing Page (media-landing.html.twig)
----------------------------------------
*/
.category-select {
   font-size: 30px;
   background-color: white;
   text-align: center;
   padding: 20px;
   margin-bottom: 20px;
}

.grid-container {
   display: flex;
   flex-wrap: wrap;
   justify-content: flex-start;
   gap: 20px;
   max-width: 1200px;
   margin: auto;
}

.grid-item {
   flex: 0 1 calc(25% - 20px);
   min-width: 220px;
   box-sizing: border-box;
   background-color: #ffffff;
   border-radius: 12px;
   box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
   overflow: hidden;
   display: flex;
   flex-direction: column;
   transition: all .2s ease-in-out;
   cursor: pointer;
}

.grid-item a:hover {
   text-decoration: none;
}

.grid-item:hover {
   transform: scale(1.05);
   box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.grid-item img {
   width: 100%;
   height: auto;
   display: block;
   padding: 70px;
   padding-top: 5px;
   padding-bottom: 5px;
}

.grid-item h2 {
   color: #1276be;
   padding: 10px;
   margin-left: 5px;
   margin-right: 5px;
}

.item-text {
   padding: 15px;
   text-align: center;
   font-weight: 500;
   color: #ffffff;
   margin: 0;
   flex-grow: 1;
   display: flex;
   align-items: center;
   justify-content: center;
}

.documents-landing-container {
   display: flex;
   flex-direction: row;
}

.documents-landing-container .container-items {
   flex-basis: 220px;
}

/* Responsive Grid */
@media (max-width: 900px) {
   .grid-item {
         flex: 1 1 calc(50% - 20px);
   }
}

@media (max-width: 600px) {
   body {
         padding: 10px;
   }
   .grid-container {
         gap: 15px;
   }
   .grid-item {
         flex: 1 1 100%;
   }
}

/*
----------------------------------------
Media Transversal Page (media-transversal.html.twig)
----------------------------------------
*/
.department-wrapper {
  margin-top: 10px;
}

.department-header {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 8px;
}

.toggle-departments {
  background-color: #001489;
  color: white;
  padding: 8px 12px;
  cursor: pointer;
  font-size: 0.95rem;
  margin: 0px 20px 20px 0px;
}

.hidden {
  display: none;
}

.after-category-tag {
  display: inline-block;
  padding: 0.4em 0.8em;
  background-color: #f0f0f0;
  color: #333;
  border-radius: 999px;
  font-size: 0.9em;
  margin-left: 10px;
  margin-top: 10px;
  margin-bottom: 20px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

/*
----------------------------------------
Generic Category List (media-generic.html.twig & media-transversal.html.twig)
----------------------------------------
*/
.container {
  column-gap: 30px;
}

.category {
  display: inline-block;
  width: 100%;
  margin-bottom: 30px;
  box-sizing: border-box;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);
  background-color: #f9f9f9;
  break-inside: avoid; /* For column layouts */
}

/* Column layout for transversal page */
.media-transversal-page .container {
  column-count: 2;
}
.media-transversal-page .category {
  display: block; /* Not inline-block */
}


.category h2 {
  font-size: 18px;
  color: #333;
  margin-bottom: 10px;
  background:#1276be;
  color:white;
  padding: 10px 15px;
}

.category ul {
  padding: 20px; /* More padding */
  list-style-position: outside;
}

.category li {
  margin-left: 30px;
  margin-bottom: 10px;
}

.category a {
  text-decoration: none;
  color: #1276be;
}

.category .see-more {
  float: right;
  background-color:#001489;
  padding:6px;
}

.category .see-more a{
  color:white;
  padding:10px;
}