/**
 * @file
 * Subtheme specific CSS.
 */

/* ==========================================================================
   1. Fonts & Variables
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');

:root {
  --scolio-primary: #0056b3;
  /* Professional Medical Blue */
  --scolio-primary-dark: #004494;
  --scolio-secondary: #17a2b8;
  /* Healing Teal */
  --scolio-accent: #e83e8c;
  /* Soft accent if needed */
  --scolio-bg-light: #f8f9fa;
  --scolio-text-dark: #333333;
  --scolio-border: #dee2e6;
  --scolio-success: #28a745;
  --font-base: 'Roboto', sans-serif;
}

body {
  font-family: var(--font-base);
  color: var(--scolio-text-dark);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--scolio-primary);
  font-weight: 700;
}

/* ==========================================================================
   2. Header & Navigation
   ========================================================================== */
/* Ensure the branding area looks good */
.region-header .site-branding a {
  text-decoration: none;
}

/* Primary Navigation Bar Styles */
#navbar-main {
  background-color: var(--scolio-primary) !important;
  /* Override conflicting styles */
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

#navbar-main .navbar-brand img,
.region-header .site-branding img {
  max-height: 45px;
  width: auto;
  object-fit: contain;
  transition: all 0.3s ease;
}

#navbar-main .navbar-brand:hover img {
  transform: translateY(-1px);
}

#navbar-main .navbar-nav .nav-item {
  margin-right: 5px;
}

#navbar-main .navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.9) !important;
  /* High contrast */
  font-weight: 500;
  padding: 0.75rem 1rem;
  transition: all 0.2s ease-in-out;
  border-radius: 4px;
}

#navbar-main .navbar-nav .nav-link:hover,
#navbar-main .navbar-nav .nav-link:focus {
  background-color: rgba(255, 255, 255, 0.15);
  color: #fff !important;
}

#navbar-main .navbar-nav .nav-link.is-active,
#navbar-main .navbar-nav .nav-item.active .nav-link {
  background-color: rgba(255, 255, 255, 0.25);
  color: #fff !important;
  font-weight: 700;
}

/* ==========================================================================
   3. Fieldsets & Details
   ========================================================================== */
fieldset:not(.field-group-fieldset),
/* Standard fieldsets */
.field-group-fieldset,
details {
  background-color: #fff;
  border: 1px solid var(--scolio-border);
  border-radius: 0.25rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

/* Legend styling for Fieldsets */
fieldset>legend {
  float: none;
  /* Reset Bootstrap float */
  width: auto;
  padding: 0 0.5rem;
  margin-bottom: 0.5rem;
  font-size: 1.25rem;
  /* font-weight: 600; */
  color: var(--scolio-primary);
  border-bottom: none;
}

/* Summary styling for Details */
details>summary {
  padding: 0.75rem 1rem;
  margin: -1.5rem -1.5rem 1.5rem -1.5rem;
  /* Stretch to edges */
  background-color: var(--scolio-bg-light);
  border-bottom: 1px solid var(--scolio-border);
  font-weight: 600;
  color: var(--scolio-primary-dark);
  cursor: pointer;
  outline: none;
  border-radius: 0.25rem 0.25rem 0 0;
}

details[open]>summary {
  border-bottom-color: var(--scolio-border);
  margin-bottom: 1.5rem;
  /* Ensure content spacing when open */
}

details>summary:hover {
  background-color: #e9ecef;
}

/* Nested fieldsets spacing */
fieldset fieldset {
  margin-top: 1rem;
  background-color: var(--scolio-bg-light);
}

/* ==========================================================================
   4. Local Task Tabs (Drupal Tabs)
   ========================================================================== */
.tabs-wrapper {
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--scolio-border);
}

ul.tabs.primary {
  display: flex;
  flex-wrap: wrap;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}

ul.tabs.primary li {
  margin-bottom: -1px;
  margin-right: 0.25rem;
}

ul.tabs.primary li a {
  display: block;
  padding: 0.75rem 1.25rem;
  border: 1px solid transparent;
  border-top-left-radius: 0.25rem;
  border-top-right-radius: 0.25rem;
  color: var(--scolio-primary);
  text-decoration: none;
  background-color: transparent;
  font-weight: 500;
}

ul.tabs.primary li a:hover,
ul.tabs.primary li a:focus {
  border-color: #e9ecef #e9ecef #dee2e6;
  background-color: #e9ecef;
}

ul.tabs.primary li a.is-active {
  color: #495057;
  background-color: #fff;
  border-color: var(--scolio-border) var(--scolio-border) #fff;
  font-weight: 700;
}

/* ==========================================================================
   5. Exposed Filters
   ========================================================================== */
.views-exposed-form {
  background-color: var(--scolio-bg-light);
  border: 1px solid var(--scolio-border);
  border-radius: 0.25rem;
  padding: 1.5rem;
  margin-bottom: 2rem;
}

/* Exposed Filters - Improved spacing and alignment */
.views-exposed-form .js-form-item {
  background-color: #fff;
  border: 1px solid var(--scolio-border);
  border-radius: 0.5rem;
  padding: 1rem;
  margin-bottom: 0;
  margin-right: 0;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.views-exposed-form .js-form-item:hover {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  transform: translateY(-1px);
}

.views-exposed-form fieldset {
  margin-bottom: 0;
  margin-right: 0;
  border: none;
  padding: 0;
}

.views-exposed-form .d-flex.flex-wrap {
  gap: 1.5rem;
  align-items: flex-start;
}

.views-exposed-form label,
.views-exposed-form fieldset legend {
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 4px;
  margin-bottom: 0.75rem;
  display: inline-block;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  float: none;
  width: auto;
}

/* Align submit/action buttons with the bottom of inputs */
.views-exposed-form .form-actions {
  margin-top: 0;
  margin-bottom: 0;
  padding-bottom: 0.1rem;
  display: flex;
  align-items: flex-end;
}

/* Ensure all date fieldsets in exposed forms are compact, grouped and inline */
.views-exposed-form fieldset.js-form-item {
  border: 1px dashed var(--scolio-secondary);
  padding: 0.75rem 1rem;
  margin: 0;
  background: rgba(23, 162, 184, 0.05);
  /* Very light teal background for grouping */
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05);
  border-radius: 0.5rem;
}

.views-exposed-form fieldset.js-form-item .fieldset-wrapper {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.views-exposed-form fieldset.js-form-item .js-form-item {
  margin-bottom: 0;
  background: transparent;
  border: none;
  padding: 0;
  box-shadow: none;
}

.views-exposed-form fieldset.js-form-item legend {
  margin-bottom: 0.5rem;
  background: var(--scolio-secondary);
  color: #fff !important;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.7rem;
}

/* Specific styling for inline filters if they exist */
.views-exposed-form.form--inline .form-item {
  margin-right: 1rem;
}

/* Make filter inputs look solid */
.views-exposed-form input.form-text,
.views-exposed-form select,
.form-control,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="date"],
input[type="number"],
select,
textarea {
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  padding: 0.5rem 0.75rem;
  background-color: #fff;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  width: 100%;
  /* Standard Bootstrap-like width */
}

/* Focus states */
.views-exposed-form input.form-text:focus,
.views-exposed-form select:focus,
input:focus,
select:focus,
textarea:focus {
  border-color: var(--scolio-secondary);
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(23, 162, 184, 0.25);
}

/* Unified Form Labels - Ensure all labels use the theme blue and modern uppercase style */
.node-form label,
.node-form legend,
.field__label,
.form-item label {
  color: var(--scolio-primary-dark) !important;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.03em;
  margin-bottom: 0.5rem;
  display: block;
}

/* Paragraph Items Consistency (Imaging/Radiology) */
.field--widget-paragraphs .paragraphs-subform {
  border: 1px solid var(--scolio-border);
  border-radius: 0.5rem;
  padding: 1.5rem;
  margin-bottom: 1rem;
  background-color: #fff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}

.field--widget-paragraphs .paragraph-form-top {
  margin-bottom: 1rem;
}

/* Fix Paragraph Title visibility on blue background */
.field--widget-paragraphs h4.label,
.field--widget-paragraphs .paragraph-form-top h4.label,
.field--widget-paragraphs .paragraph-type-label {
  color: #ffffff !important;
  margin-bottom: 0;
}

/* Hide Content and Behavior tabs in paragraphs */
.paragraphs-tabs,
.field-multiple-table .paragraphs-tabs,
.field--widget-paragraphs .nav-tabs {
  display: none !important;
}

/* Improved Dropdowns */
.form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 16px 12px;
  background-color: #ffffff !important;
}

/* Vertical Tabs Improvements (Bootstrap 5 aesthetics) */
.vertical-tabs {
  display: flex;
  border: none;
  background: #fff;
  border-radius: 0.75rem;
  overflow: hidden;
  margin-top: 2rem;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  /* Modern soft shadow */
}

.vertical-tabs__menu {
  flex: 0 0 280px;
  background-color: #f8f9fa;
  /* Explicitly use light bg */
  border-right: 1px solid var(--scolio-border);
  list-style: none;
  padding: 1.5rem 0;
  margin: 0;
}

.vertical-tabs__menu-item {
  border: none !important;
  background: none !important;
  position: relative;
  margin-bottom: 0.25rem;
}

.vertical-tabs__menu-item a {
  display: flex;
  align-items: center;
  padding: 0.75rem 1.5rem;
  color: #495057;
  text-decoration: none;
  font-weight: 500;
  border-left: 4px solid transparent;
  transition: all 0.2s ease-in-out;
  font-size: 0.9rem;
}

/* Active tab state */
.vertical-tabs__menu-item.is-selected a {
  background-color: #ffffff;
  color: var(--scolio-primary);
  border-left-color: var(--scolio-primary);
  font-weight: 700;
  box-shadow: 5px 0 15px rgba(0, 86, 179, 0.05);
  z-index: 1;
}

/* Hover state */
.vertical-tabs__menu-item a:hover:not(.is-selected) {
  background-color: rgba(0, 86, 179, 0.05);
  color: var(--scolio-primary);
}

/* Base icon styling for Vertical Tabs */
.vertical-tabs__menu-item a::before {
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  margin-right: 12px;
  font-size: 1rem;
  width: 20px;
  text-align: center;
  opacity: 0.7;
}

/* Specific Icons for ScolioHeal Patient Form */
/* 1. Personal & Demographic Details */
.vertical-tabs__menu-item:nth-child(1) a::before,
.vertical-tabs__menu-item a[href*="personal-demographic-detai"]::before {
  content: "\f007";
}

/* 2. Family Information */
.vertical-tabs__menu-item:nth-child(2) a::before,
.vertical-tabs__menu-item a[href*="family-information"]::before {
  content: "\f2bb";
}

/* 3. Identity & Socioeconomic Details */
.vertical-tabs__menu-item:nth-child(3) a::before,
.vertical-tabs__menu-item a[href*="identity-socioeconomic-de"]::before {
  content: "\f47d";
}

/* 4. Clinical */
.vertical-tabs__menu-item:nth-child(4) a::before,
.vertical-tabs__menu-item a[href*="clinical"]::before {
  content: "\f0f1";
}

/* 5. Admission Details */
.vertical-tabs__menu-item:nth-child(5) a::before,
.vertical-tabs__menu-item a[href*="admission-details"]::before {
  content: "\f46c";
}

/* 6. Media Upload */
.vertical-tabs__menu-item:nth-child(6) a::before,
.vertical-tabs__menu-item a[href*="media-upload"]::before {
  content: "\f03e";
}

/* Clinical Eval Icons */
/* Surgical Execution */
.vertical-tabs__menu-item:nth-child(6) a::before,
.vertical-tabs__menu-item a[href*="surgical-execution"]::before {
  content: "\f0ad";
}

/* Immediate Postoperative Data */
.vertical-tabs__menu-item:nth-child(7) a::before,
.vertical-tabs__menu-item a[href*="immediate-postoperative-da"]::before {
  content: "\f470";
}

.vertical-tabs__panes {
  flex: 1;
  padding: 2rem;
  background-color: #fff;
  min-height: 400px;
}

/* Horizontal Tabs (Patient Page) */
.field-group-tabs-wrapper .horizontal-tabs-list {
  border-bottom: 2px solid var(--scolio-border);
  margin-bottom: 1.5rem;
  padding-left: 0;
  display: flex;
}

.horizontal-tab-button {
  list-style: none;
  margin-bottom: -2px;
}

.horizontal-tab-button a {
  display: block;
  padding: 1rem 1.5rem;
  color: var(--scolio-text-dark);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  font-weight: 600;
  transition: color 0.15s, border-color 0.15s;
}

.horizontal-tab-button a:hover {
  color: var(--scolio-primary);
  border-bottom-color: var(--scolio-border);
}

.horizontal-tab-button.selected a {
  color: var(--scolio-primary);
  border-bottom-color: var(--scolio-primary);
}

/* Move Sidebar to bottom in node edit form */
.layout-region-node-main,
.layout-region-node-secondary {
  width: 100% !important;
  flex: 0 0 100% !important;
  max-width: 100% !important;
}

.node-form .layout-region-node-secondary {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 2px solid var(--scolio-border);
}

/* ==========================================================================
   6. Data Tables (Phase 2)
   ========================================================================== */
table.table {
  background-color: #fff;
  border-radius: 0.25rem;
  overflow: hidden;
  /* For rounded corners on header */
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  margin-bottom: 2rem;
}

table.table thead th {
  background-color: var(--scolio-primary);
  color: #fff;
  border-bottom: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  padding: 1rem;
  vertical-align: middle;
}

table.table thead th a {
  color: #fff !important;
  text-decoration: none;
}

table.table tbody td {
  padding: 1rem;
  vertical-align: middle;
  border-top: 1px solid var(--scolio-border);
  color: var(--scolio-text-dark);
}

table.table tbody tr:hover {
  background-color: rgba(0, 86, 179, 0.03);
}

/* ==========================================================================
   7. Node Field Displays (Phase 2)
   ========================================================================== */
.node .field {
  margin-bottom: 1rem;
}

/* Label styling - Universal application for all field labels */
.node .field__label,
.node .field--label-above .field__label,
.node .field--label-inline .field__label,
.node .field--label-hidden .field__label {
  font-weight: 700;
  color: var(--scolio-primary-dark);
  font-size: 0.95rem;
  margin-bottom: 0.4rem;
  display: block;
  text-transform: none;
}

/* Inline label handling overrides */
.node .field--label-inline .field__label {
  display: inline-block;
  margin-right: 0.75rem;
  margin-bottom: 0;
}

.node .field--label-inline .field__items,
.node .field--label-inline .field__item {
  display: inline-block;
}

/* Field items/values */
.node .field__item {
  color: var(--scolio-text-dark);
  line-height: 1.6;
}

/* Special handling for text fields to look like "values" */
.node .field--type-text-long .field__item,
.node .field--type-text-with-summary .field__item {
  background-color: transparent;
}

/* Date fields */
.node .field--type-datetime .field__item,
.node .field--type-created .field__item {
  font-family: 'Roboto', sans-serif;
  color: #666;
}

/* ==========================================================================
   8. General Aesthetic Enhancements (Materia)
   ========================================================================== */
/* Add depth to main content area similar to Material cards */
.region-content {
  /* Only apply card style if not already inside a specific container that handles it */
  animation: fadeIn 0.5s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Improve button aesthetics defined by Bootstrap/Materia */
.btn {
  border-radius: 4px;
  /* Slight rounding */
  text-transform: uppercase;
  font-weight: 500;
  letter-spacing: 0.05em;
  padding: 0.5rem 1.25rem;
  box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12), 0 3px 1px -2px rgba(0, 0, 0, 0.2);
  transition: all 0.3s cubic-bezier(.25, .8, .25, 1);
}

.btn:hover {
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25), 0 10px 10px rgba(0, 0, 0, 0.22);
}

/* Add a subtle background pattern or texture to the body if using Materia's flat style */
body {
  background-color: #f4f5f7;
  /* Very light cool gray */
}

/* Main container focus */
#main-wrapper .container {
  background-color: #fff;
  padding-top: 2rem;
  padding-bottom: 2rem;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
  min-height: 80vh;
  margin-top: 2rem;
  margin-bottom: 2rem;
  border-radius: 4px;
}

/* ==========================================================================
   9. Quicktabs Custom Aesthetics
   ========================================================================== */
.quicktabs-wrapper.tabsbar {
  margin: 2rem 0;
}

.quicktabs-wrapper.tabsbar .quicktabs-tabs.list-group {
  flex-direction: row;
  border: none;
  border-bottom: 2px solid var(--scolio-border);
  background: transparent;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  padding: 0;
}

.quicktabs-wrapper.tabsbar .quicktabs-tabs .list-group-item {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}

.quicktabs-wrapper.tabsbar .quicktabs-tabs .list-group-item a {
  display: block;
  padding: 0.75rem 1.5rem;
  color: var(--scolio-text-dark);
  text-decoration: none;
  font-weight: 600;
  border-radius: 0.5rem 0.5rem 0 0;
  border: 1px solid transparent;
  border-bottom: none;
  transition: all 0.3s ease;
  background-color: var(--scolio-bg-light);
  margin-bottom: -2px;
  /* Overlap the border */
}

.quicktabs-wrapper.tabsbar .quicktabs-tabs .list-group-item.active a,
.quicktabs-wrapper.tabsbar .quicktabs-tabs .list-group-item a.active,
.quicktabs-wrapper.tabsbar .quicktabs-tabs .list-group-item.active a.quicktabs-loaded {
  color: #fff !important;
  background-color: var(--scolio-primary) !important;
  border-color: var(--scolio-primary) !important;
}

.quicktabs-wrapper.tabsbar .quicktabs-tabs .list-group-item a:hover:not(.active) {
  background-color: #e2e6ea;
  color: var(--scolio-primary);
}

/* Patient Contributions UI Improvement */
#quicktabs-patient_contributions {
  background: #fff;
  padding: 1.5rem;
  border-radius: 0.75rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  border: 1px solid var(--scolio-border);
}

#quicktabs-patient_contributions .quicktabs-tabs {
  border-bottom: 2px solid var(--scolio-primary);
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
}

#quicktabs-patient_contributions .quicktabs-tabs .list-group-item a {
  background: transparent;
  color: var(--scolio-text-dark);
  font-weight: 600;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 4px;
}

#quicktabs-patient_contributions .quicktabs-tabs .list-group-item.active a {
  background: var(--scolio-primary) !important;
  color: #fff !important;
}

@media (max-width: 768px) {
  .quicktabs-wrapper.tabsbar .quicktabs-tabs.list-group {
    flex-direction: column;
    border-bottom: none;
  }

  .quicktabs-wrapper.tabsbar .quicktabs-tabs .list-group-item a {
    border-radius: 0.25rem;
    margin-bottom: 0.5rem;
    border: 1px solid var(--scolio-border);
  }
}
