/*
 * management-responsive.css
 * Responsive overrides scoped to management.php only.
 * Covers breakpoints: 1024px → 768px → 600px → 480px → 360px
 * All rules are additive — no base styles touched.
 */

/* ============================================================
   BASE — Accordion "Budaya Perusahaan" width fix (all screens)
   main.css sets width: 700px on .accordion-flush .accordion-item
   which causes horizontal overflow. Override to fluid.
   ============================================================ */
/* Accordion items — fluid width */
#nilai-inti-perusahaan .accordion-flush .accordion-item,
#nilai-inti-perusahaan .accordion-flush .accordion-item:first-child {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  box-sizing: border-box;
}
/* accordion-header inherits item width — ensure it doesn't grow wider */
#nilai-inti-perusahaan #accordionCompanyValue .accordion-header {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
/* accordion-button: box-sizing + padding must stay within 100% of header */
#nilai-inti-perusahaan .accordion-button {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  padding: 12px 16px !important;
  white-space: normal !important;
  word-break: break-word;
}
#nilai-inti-perusahaan .accordion-body {
  word-break: break-word;
  box-sizing: border-box;
  width: 100%;
}

/* ============================================================
   PEMEGANG SAHAM — shareholders chart tree layout
   Desktop uses margin-left: -90px on .level-1 to position tree nodes.
   On mobile this pushes nodes 90px off the left edge of the viewport.
   Fix: stack the two level-1 nodes vertically, centered.
   ============================================================ */
@media (max-width: 768px) {
  .shareholders-chart-box {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
  }
  .shareholders-chart-box .level-1-box {
    flex-direction: column !important;
    align-items: center !important;
    margin-left: 0 !important;
    gap: 12px;
    width: 100% !important;
  }
  .shareholders-chart-box .level-1 {
    margin-left: 0 !important;
    width: auto !important;
    justify-content: center;
  }
  .shareholders-chart-box .level-2-box {
    display: flex;
    justify-content: center;
    margin-top: 8px;
  }
  .shareholders-chart-box .level-2 {
    margin-left: 0 !important;
  }
}
/* Ensure the flex container inside budaya stacks on ≤ 1024px */
@media (max-width: 1024px) {
  #nilai-inti-perusahaan .section-about-page-history-timeline-box {
    flex-direction: column !important;
    column-gap: 0 !important;
    row-gap: 24px;
  }
  #nilai-inti-perusahaan .section-about-page-history-timeline {
    padding: 0 40px !important;
  }
  /* Hide the desktop image on the right, show only accordion */
  #nilai-inti-perusahaan .company-value-right {
    display: none !important;
  }
}
@media (max-width: 600px) {
  #nilai-inti-perusahaan .section-about-page-history-timeline {
    padding: 0 16px !important;
  }
  #nilai-inti-perusahaan .section-about-page-company-value.company-value-box {
    padding: 0 !important;
  }
}

/* ============================================================
   BOOTSTRAP LG BREAKPOINT  (≤ 991px)
   col-lg-* cols stack here — hide hero image, center text
   ============================================================ */
@media (max-width: 991px) {
  .huruf_banner {
    text-align: center !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .huruf_banner h1 {
    font-size: 34px !important;
    line-height: 1.25 !important;
  }
  /* Center banner content vertically */
  .banner_man2 .container {
    height: 100% !important;
    min-height: inherit;
  }
  .banner_man2 .row {
    justify-content: center !important;
    align-items: center !important;
    min-height: 280px;
  }
  .banner_man  { height: auto !important; min-height: 320px !important; padding-bottom: 20px; }
  .banner_man2 { height: auto !important; min-height: 280px !important; padding-bottom: 20px; }

  /* History nav: switch vertical pills → horizontal tabs */
  .section-about-page-history-timeline-box .nav.flex-column {
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    gap: 0 !important;
    border-right: none !important;
    border-bottom: 2px solid #c3e0f1;
    padding-bottom: 0;
  }
  .section-about-page-history-timeline-box .nav.nav-pills .nav-link {
    border-right: none !important;
    border-bottom: 3px solid transparent;
    padding: 12px 24px !important;
    font-size: 18px !important;
    white-space: nowrap;
    flex-shrink: 0;
  }
  .section-about-page-history-timeline-box .nav.nav-pills .nav-link.active {
    background: transparent !important;
    color: #0d3f71 !important;
    border-bottom: 3px solid #0d3f71 !important;
  }
  .section-about-page-history-timeline-box .nav.nav-pills .nav-link.active::after {
    display: none !important;
  }

  /* History — stack nav + content vertically */
  .section-about-page-history-timeline-box {
    flex-direction: column !important;
    column-gap: 0 !important;
    row-gap: 20px !important;
  }
  /* Hide mobile floating image — nav tabs already convey timeline */
  .section-about-page-history-timeline-box .image-section-box-mobile {
    display: none !important;
  }
  /* Desktop image inside tab: hide */
  .section-about-page-history-timeline-box-content .image-section-box {
    display: none !important;
  }
  /* Content tab takes full width */
  .section-about-page-history-timeline-box .tab-content {
    width: 100% !important;
    padding: 16px 0 !important;
  }
  .section-about-page-history-timeline-box-content .text-section-box h1 {
    font-size: 44px !important;
  }

  /* Budaya — stack accordion, hide desktop image */
  #nilai-inti-perusahaan .company-value-right {
    display: none !important;
  }
  #nilai-inti-perusahaan .section-about-page-history-timeline-box {
    flex-direction: column !important;
  }
  /* Hide budaya mobile image on tablet — accordion is enough */
  #nilai-inti-perusahaan .image-section-box-mobile {
    display: none !important;
  }

  /* Section title font sizes */
  .label-section-title h4 {
    font-size: 42px !important;
    line-height: 52px !important;
  }
  .label-section-title2 {
    font-size: 42px !important;
    line-height: 52px !important;
    margin-left: 0 !important;
    width: auto !important;
  }
  .visi_misi h2 {
    font-size: 42px !important;
    line-height: 52px !important;
    position: static !important;
    margin: 0 0 12px !important;
    padding-left: 0 !important;
    width: auto !important;
  }

  /* Management heading */
  .management h2 { font-size: 36px !important; padding-left: 32px !important; }
  .management p  { font-size: 22px !important; padding-left: 32px !important; }

  /* Org structure */
  .section-about-page-organizational-structure-container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 48px 32px !important;
  }
  .section-about-page-organizational-structure-container h1 {
    font-size: 36px !important;
    margin-left: 0 !important;
    width: auto !important;
  }
  .section-about-page-organizational-structure-container .organizational-structure-box img,
  .section-about-page-organizational-structure-container > img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin-left: 0 !important;
  }
}

/* ============================================================
   TABLET LANDSCAPE  (≤ 1024px)
   ============================================================ */
@media (max-width: 1024px) {

  /* Hero banner */
  .banner_man  { height: auto !important; min-height: 320px !important; padding-bottom: 20px; }
  .banner_man2 { height: auto !important; min-height: 280px !important; }
  .huruf_banner h1 { font-size: 34px !important; }

  /* History / Company-value timeline padding */
  .section-about-page-history-timeline,
  .section-about-page-history2-timeline2 {
    padding: 0 40px !important;
  }

  /* Shareholders section */
  .section-about-page-shareholders {
    padding: 60px 40px 40px !important;
  }

  /* Vision & Mission container */
  .section-about-page-vision-and-mission-container {
    padding: 0 40px 10px !important;
  }

  /* Organizational structure */
  .section-about-page-organizational-structure-container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 60px 40px !important;
  }
  .section-about-page-organizational-structure-container h1 {
    font-size: 40px !important;
  }
  .section-about-page-organizational-structure-container > img,
  .section-about-page-organizational-structure-container .organizational-structure-box img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin-left: 0 !important;
  }

  /* Management heading */
  .management h2 { font-size: 38px !important; padding-left: 40px !important; }
  .management p  { font-size: 24px !important; padding-left: 40px !important; }
}

/* ============================================================
   TABLET PORTRAIT  (≤ 768px)
   ============================================================ */
@media (max-width: 768px) {

  /* Hero banner */
  .banner_man  { min-height: 260px !important; }
  .banner_man2 { min-height: 220px !important; }
  .huruf_banner h1 { font-size: 28px !important; }

  /* History timeline padding */
  .section-about-page-history-timeline,
  .section-about-page-history2-timeline2 {
    padding: 0 16px !important;
  }
  /* Smaller tab font at 768px */
  .section-about-page-history-timeline-box .nav.nav-pills .nav-link {
    padding: 10px 18px !important;
    font-size: 16px !important;
  }
  .section-about-page-history-timeline-box-content .text-section-box h1 {
    font-size: 36px !important;
  }
  .section-about-page-history-timeline-box-content .text-section-box h6 {
    font-size: 14px !important;
    line-height: 22px !important;
  }

  /* Shareholders section */
  .section-about-page-shareholders {
    padding: 40px 20px 30px !important;
  }
  .section-about-page-shareholders .row {
    flex-direction: column !important;
  }
  .section-about-page-shareholders .col-md-6 {
    width: 100% !important;
    max-width: 100% !important;
  }
  .section-about-page-shareholders .shareholders-chart-box {
    max-width: 100% !important;
    margin: 0 auto;
  }

  /* Vision & Mission — stack the two columns */
  .section-about-page-vision-and-mission {
    overflow: hidden !important;
  }
  .section-about-page-vision-and-mission-container {
    flex-direction: column !important;
    padding: 0 20px 20px !important;
    row-gap: 32px !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }
  .section-about-page-vision-and-mission .label-section {
    width: 100% !important;
    max-width: 100% !important;
    padding-top: 30px !important;
    margin-left: 0 !important;
    float: none !important;
    position: static !important;
  }
  /* Visi box (blue card) */
  .section-about-page-vision-and-mission .label-section.label-section-left .label-section-desc-and-quote {
    width: 100% !important;
    max-width: 100% !important;
    min-width: unset !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    height: auto !important;
    font-size: 18px !important;
    line-height: 28px !important;
    padding: 20px !important;
    box-sizing: border-box !important;
    position: relative !important;
  }
  /* Quote mark — contained, tidak overflow */
  .label-section-quote {
    font-size: 72px !important;
    line-height: 60px !important;
    position: static !important;
    display: block !important;
  }
  .visi_misi h2 {
    font-size: 36px !important;
    line-height: 44px !important;
    position: static !important;
    margin: 0 0 12px 0 !important;
    padding-left: 0 !important;
    width: auto !important;
  }
  .section-about-page-vision-and-mission .label-section .number-primary {
    margin-top: 20px !important;
    margin-left: 0 !important;
    float: none !important;
    max-width: 100% !important;
    position: static !important;
  }
  .section-about-page-vision-and-mission .label-section .number-primary li {
    font-size: 15px !important;
    line-height: 24px !important;
  }
  .label-section-title2 {
    font-size: 36px !important;
    line-height: 44px !important;
    margin-left: 0 !important;
    margin-top: 0 !important;
    width: auto !important;
    padding-bottom: 16px !important;
  }

  /* Organizational structure */
  .section-about-page-organizational-structure-container {
    padding: 40px 20px !important;
  }
  .section-about-page-organizational-structure-container h1 {
    font-size: 30px !important;
    margin-left: 0 !important;
    width: auto !important;
  }

  /* Management heading */
  .management h2 { font-size: 30px !important; padding-left: 20px !important; }
  .management p  { font-size: 20px !important; padding-left: 20px !important; }
}

/* ============================================================
   LARGE PHONE  (≤ 600px)
   ============================================================ */
@media (max-width: 600px) {

  /* Hero banner */
  .banner_man  { min-height: 220px !important; padding-bottom: 0; }
  .banner_man2 { min-height: 180px !important; }
  .huruf_banner h1 { font-size: 24px !important; }

  /* History */
  .section-about-page-history-timeline,
  .section-about-page-history2-timeline2 {
    padding: 0 12px !important;
  }
  .section-about-page-history-timeline-box .nav.nav-pills .nav-link {
    font-size: 14px !important;
    padding: 8px 14px !important;
  }
  .section-about-page-history-timeline-box-content .text-section-box h1 {
    font-size: 30px !important;
  }
  .accordion-button {
    width: 100% !important;
    font-size: 15px !important;
  }

  /* Shareholders */
  .section-about-page-shareholders {
    padding: 32px 16px 24px !important;
    max-width: 100% !important;
  }
  .section-about-page-shareholders .shareholders-chart-box {
    overflow-x: auto;
  }

  /* Vision & Mission */
  .section-about-page-vision-and-mission-container {
    padding: 0 16px 16px !important;
    max-width: 100% !important;
  }
  .section-about-page-vision-and-mission .label-section {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
  }
  .section-about-page-vision-and-mission .label-section.label-section-left .label-section-desc-and-quote {
    width: 100% !important;
    max-width: 100% !important;
    min-width: unset !important;
    margin-left: 0 !important;
    font-size: 16px !important;
    line-height: 26px !important;
    padding: 16px !important;
    box-sizing: border-box !important;
  }
  .visi_misi h2 {
    font-size: 28px !important;
    line-height: 36px !important;
  }
  .label-section-title2 {
    font-size: 28px !important;
    line-height: 36px !important;
  }
  .label-section-quote {
    font-size: 56px !important;
    position: static !important;
    display: block !important;
  }

  /* Org structure */
  .section-about-page-organizational-structure-container {
    padding: 32px 16px !important;
  }
  .section-about-page-organizational-structure-container h1 {
    font-size: 24px !important;
  }

  /* Management heading */
  .management h2 { font-size: 26px !important; padding-left: 16px !important; }
  .management p  { font-size: 18px !important; padding-left: 16px !important; }

  /* Management card grid — 2 cols on phone is fine via Bootstrap col-md-6 */
  .management2 p  { font-size: 15px !important; }
  .management2 h6 { font-size: 12px !important; }

  /* Section headings / label */
  .label-section-title h4 {
    font-size: 30px !important;
    line-height: 40px !important;
  }
}

/* ============================================================
   SMALL PHONE  (≤ 480px)
   ============================================================ */
@media (max-width: 480px) {

  /* Hero */
  .banner_man  { min-height: 240px; }
  .banner_man2 { min-height: 200px; }
  .huruf_banner h1 { font-size: 22px !important; }

  /* Management grid → single column */
  .management2.col-md-6 { width: 100% !important; flex: 0 0 100% !important; max-width: 100% !important; }

  /* Shareholders chart — allow horizontal scroll on very small screens */
  .section-about-page-shareholders .col-md-6:last-child {
    overflow-x: auto;
  }
  .section-about-page-shareholders .shareholders-chart-box {
    min-width: 300px;
  }

  /* Vision/Mission */
  .visi_misi h2 { font-size: 24px !important; }
  .label-section-title2 { font-size: 24px !important; }
  .section-about-page-vision-and-mission .label-section.label-section-left .label-section-desc-and-quote {
    font-size: 14px !important;
    line-height: 22px !important;
  }
  .section-about-page-vision-and-mission .label-section .number-primary li {
    font-size: 13px !important;
    line-height: 22px !important;
    margin-bottom: 16px !important;
  }

  /* Org structure */
  .section-about-page-organizational-structure-container h1 {
    font-size: 20px !important;
  }
}

/* ============================================================
   VERY SMALL PHONE  (≤ 360px)
   ============================================================ */
@media (max-width: 360px) {

  /* Hero */
  .banner_man  { min-height: 200px; }
  .banner_man2 { min-height: 180px; }
  .huruf_banner h1 { font-size: 20px !important; }

  /* Ensure container doesn't overflow */
  .section-about-page-history-timeline,
  .section-about-page-history2-timeline2,
  .section-about-page-vision-and-mission-container,
  .section-about-page-shareholders,
  .section-about-page-organizational-structure-container {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  /* Fix organization structure width (hardcoded 1400px in main.css) */
  .section-about-page-organizational-structure-container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 24px 12px !important;
  }

  .management h2 { font-size: 22px !important; padding-left: 12px !important; }
  .management p  { font-size: 16px !important; padding-left: 12px !important; }
  .management2 p  { font-size: 14px !important; }
  .management2 h6 { font-size: 11px !important; }

  .label-section-title h4 {
    font-size: 24px !important;
    line-height: 32px !important;
  }
  .visi_misi h2 { font-size: 20px !important; line-height: 28px !important; }
}
