/* =========
   Global Reset and Base
   ========= */
*, *::before, *::after {
    box-sizing: border-box;
}

 html body {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    margin: 0px;
    background: #f4f7f9;
    max-width: 1000px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

h1 {
    font-size: 1.4rem;
}

h2 {
  font-size: 1.2rem;
}


.visually-hidden,
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    clip-path: inset(50%);
    white-space: normal;
    border: 0;
}

.sr-only:focus-visible,
.sr-only:focus,
.sr-only:active {
    position: fixed;
    top: 10px;
    left: 10px;
    width: auto;
    height: auto;
    padding: 1rem 1.5rem;
    margin: 0;
    overflow: visible;
    clip: auto;
    clip-path: none;
    background-color: var(--focus-outline);
    color: #ffffff;
    z-index: 9999;
    text-decoration: none;
    border-radius: 4px;
    outline: 2px solid white;
    white-space: normal;
}

.text_red {
    color: red;
}

html {
    overflow-y: scroll !important;
}

a {
    color: #005a9c; /* Dark blue for all links */
    text-decoration: none;
}
a:hover {
    text-decoration: underline;
}


a:focus-visible {
  outline: 3px solid #ffab00;
  outline-offset: 3px;
}

.row-space {
  margin-top: 2.5rem;
}


.small-note { font-size: 0.85rem; text-align: center; color:#333; }


.block, .block span, .block a {
  display: block;
}

address {
 font-style: normal;
}

.bench-container {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.bench-container img {
  width: 100%;
  max-width: 850px;
  height: auto;
  display: block;
  border-radius: 4px;
}

/* Identify links in running text without relying only on color */
/* Identify links in running text without relying only on color (keep) */
main p a {
  text-decoration: underline;
  text-decoration-thickness: 1.4px;
}
main p a:hover,
main p a:focus {
  text-decoration-thickness: 2px;
}

/* Readability: left align long paragraphs (keep) */
main p { text-align: left; }

/* Accessible paragraph spacing WITH first-line indent */
.pad-paragraph {
  padding-inline: 1rem;      /* scalable side padding */
  margin-block: 0.75rem;     /* vertical rhythm */
  text-indent: 40px;        /* first-line indent (relative to font size) */
  line-height: 1.55;         /* comfortable reading */
  /* Optional: constrain line length for prose */
  /* max-width: 70ch; */
}

/* On narrow screens, trim the indent to avoid cramped first lines */
@media (max-width: 600px) {
  .pad-paragraph {
    text-indent: 20px;   /* or 0 to remove entirely on mobile */
    padding-inline: 0.75rem;
  }
}
/* =========
   Utilities
   ========= */
.photo_border {
    border: 1px solid #999;
    border-radius: 5px;
    padding: 7px;
}

.slides_show {
    display: none;
}

.slides_animate_right {
    position: relative;
    animation: animateright 1s;
    animation-delay: 0s;
    animation-direction: normal;
    animation-duration: 1s;
    animation-fill-mode: none;
    animation-iteration-count: 1;
    animation-name: animateright;
    animation-play-state: running;    
    animation-timing-function: ease;
}

.court_closings {
    background-color: #8a0a26;
    padding-left: 15px;
    padding-right: 15px;
    padding-bottom: 10px;
    margin-top: 0px;
    color: white;
}

.center-text {
	text-align: center;
}

/* =========
   TOP NAV (modernized to Flexbox)
   ========= */
.topnav {

    display: flex;              /* line up items horizontally */
    flex-wrap: nowrap;          /* keep one line on desktop */
    align-items: center;       /* unify item heights */
    justify-content: flex-start;
    background-color: #666;
  
    /* background-color:#34577C; ; */
    /* text-align: center;  — not needed for flex children */
    gap: 0;                     /* adjust if you want spacing between items */
	white-space: normal;
	position: relative;
}

.topnav span {	
    padding: 0;
    margin: 0;
    display: inline;            /* span content remains inline */
}

/* Focus rings for accessibility */
/* .topnav a:focus,
.topnav button:focus,
.dropdown .dropbtn:focus {
    outline: 3px solid #0078D4 !important;
    outline-offset: 2px !important;
    box-shadow: none !important;
} */

.topnav a:focus-visible,
.topnav button:focus-visible,
.dropdown .dropbtn:focus-visible {
    outline: 3px solid #0078D4 !important;
    outline-offset: 2px !important;
    box-shadow: none !important;
}

/* Nav links */
.topnav a {
    /* Remove float in favor of flex layout */
    flex: 0 0 auto;             /* do not grow/shrink unexpectedly */
    display: inline-flex;        /* allow vertical align of text/icons */
    align-items: center;
    color: #f2f2f2;
    text-align: center;
    padding: 10px 8px;          /* slightly tighter to reduce overflow */
    text-decoration: none;
    font-size: 14px;
	;
}


.topnav a,
.topnav .dropbtn {
	
         /* 3/11/26 */ 
  align-items: center;            /* vertical centering of icon + text */
  gap: 0.35rem;                   /* space between icon and text */
  padding: 10px 12px;             /* same touch target across items */
  font-size: 14px;                /* unify */
  line-height: 1;                 /* kill inherited line-height variance */
  color: #f2f2f2;
  white-space: normal;
}

.topnav i.fa { font-size: 13px; line-height: 1; }

/* Buttons inside nav */
.topnav button {
    color: #f2f2f2;
}

/* Active item */
/* .active {
    background-color: blue; 
    color: white;
} */

/* Hamburger icon (hidden by default) */
.topnav .icon {
    display: none;
}


/* Hover styles (consolidated; removes duplicate) */
.topnav a:hover,
.dropdown:hover .dropbtn {
    background-color: #555;
    /* background-color: #2A4562; */
    color: white;
}


/* Dropdown wrapper acts like a nav item */
.dropdown {
    flex: 0 0 auto;             /* keep natural width */
    position: relative;         /* for absolute dropdown content */
    display: inline-flex;
    align-items: stretch;
}

/* Dropdown trigger (button) */
.dropdown .dropbtn {
    font-size: 14px;
    border: none;
    color: #fff;
    padding: 10px 10px;         /* slightly tighter */
    background-color: #666; 
    /* background-color: #34577c; */
    font-family: inherit;
    margin: 0;
}

/* Dropdown content */
.dropdown-content {
    display: none;
    position: absolute;
    left: 0;
    top: 100%;
    background-color: #f9f9f9;
    width: max-content;               /* fit to longest line */
    min-width: 220px;                 /* floor so very short menus don’t look cramped */
    max-width: min(480px, 90vw);
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
    z-index: 9999;
}

/* Allow JS to display the dropdown via a class toggle */
.dropdown-content.show {
    display: block;
}


.dropdown .dropdown-content[hidden] {
  display: none !important;
}


/* Dropdown items */
.dropdown-content a {
    float: none;
    color: black;
    padding: 12px 16px;
    text-decoration: none;
    display: block;
    text-align: left;
}

/* Hover inside dropdown */
.dropdown-content a:hover {
    background-color: #ddd;
    color: black;
}


/* Make focus feel the same as hover inside the menu */
.dropdown-content a:focus-visible {
  background-color: #ddd;
  color: black;
  outline: 2px solid #0078D4;    /* optional: keep consistent outline */
  outline-offset: 2px;
}


/* Show on hover (desktop) */
/* .dropdown:hover .dropdown-content {
    display: block;
} */


.notice {
  display: block;
  font-size: .9rem;
  padding: 0.75rem 1rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  background: #fffceb;          /* subtle highlight */
  color: #222;
}

  .line-row {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      margin-bottom: 0.5rem;
    }

      .bullet {
      display: block;
      height: 2.75rem; /* Matches your 44px preference */
      width: auto;
      aspect-ratio: 1 / 1;
      object-fit: contain;
      flex-shrink: 0;
    }

    .destination {
      line-height: 1.2;
      font-weight: 500;
    }



/* =========
   Header Background Images
   ========= */
/* .header_court_drawing {
    background: url('/courts/AD2/images/cover2025.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/cover2025.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 400px;
  
} */

.header_court_drawing2 {
    background: url('/courts/AD2/images/SepiaCourtDrawing.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/Bench_photo_2021_cover.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_courtroom_clock {
    background: url('/courts/AD2/images/courtroom_clock.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/courtroom_clock.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
}

.header_courtroom {
    background: url('/courts/AD2/images/courtroom_bench.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/courtroom_bench.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_courtroom_0517 {
    background: url('/courts/AD2/images/courtroom_0517.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/courtroom_0517.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_map {
    background: url('/courts/AD2/images/map.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/map.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_calendar {
    background: url('/courts/AD2/images/calendar.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/calendar.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_gavel {
    background: url('/courts/AD2/images/gavel.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/gavel.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
}

.header_ele-art {
    background: url('/courts/AD2/images/ele-art.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/ele-art.gif') !important;
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    width: 100%;
    padding: 2rem 0;
    min-height: 250px;

}

.header_elev-2 {
    background: url('/courts/AD2/images/elev.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/elev.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_bronze-art {
    background: url('/courts/AD2/images/bronze-art.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/bronze-art.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_ceiling-art {
    background: url('/courts/AD2/images/ceiling-art.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/ceiling-art.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_building_front {
    background: url('/courts/AD2/images/building_front.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/building_front.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_1938 {
    background: url('/courts/AD2/images/ADMCMXXXVIII.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/ADMCMXXXVIII.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_pattern {
    background: url('/courts/AD2/images/pattern.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/pattern.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
}

.header_ceiling {
    background: url('/courts/AD2/images/ceiling.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/ceiling.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 225px;
}

.header_front {
    background: url('/courts/AD2/images/front.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/front.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
}

.header_courtroom_entrance {
    background: url('/courts/AD2/images/courtroom_entrance.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/courtroom_entrance.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 225px;
}

.header_attorney_book {
    background: url('/courts/AD2/images/attorney_book.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/attorney_book.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
}

.header_door_frame {
    background: url('/courts/AD2/images/door_frame.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/door_frame.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_141Livingston {
    background: url('/courts/AD2/images/141Livingston.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/141Livingston.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_gavel-c {
    background: url('/courts/AD2/images/gavel-c.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/gavel-c.gif');
    background-attachment: local;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    background-repeat: no-repeat;
    padding: 2rem 0;
    min-height: 225px;
    background-size: cover;

}

.header_cert {
    background: url('/courts/AD2/images/cert.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/cert.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_books {
    background: url('/courts/AD2/images/books.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/books.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;

}

.header_1896-1 {
    background: url('/courts/AD2/images/1896-1.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/1896-1.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
    gap: 1rem;
    padding-right: 2rem;
}  


.header_1896-1 .notice {
  align-self: center;   /* centers the notice horizontally */
  text-align: center;   /* centers the text inside the notice */
  max-width: 120ch;      /* optional: limit line length for readability */
}



.header-action { margin-right: 15px; }



.header_Appellate_Term_1 {
    background: url('/courts/AD2/images/Appellate_Term_1.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/Appellate_Term_1.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_appellate_term_3 {
    background: url('/courts/AD2/images/appellate_term_3.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/appellate_term_3.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
}

.header_justices_of_the_court {
    background: url('/courts/AD2/images/justices_of_the_court-1.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/justices_of_the_court-1.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 300px;
}

.header_scroll-1 {
    background: url('/courts/AD2/images/scroll-1.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/scroll-1.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_2ndH {
    background: url('/courts/AD2/images/2ndH.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/2ndH.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 225px;
}

.header_decisions_papers {
    background: url('/courts/AD2/images/decisions_papers.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/decisions_papers.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
    gap: 1rem;
    padding-right: 2rem;

}

.header_decisions_papers .notice {
  align-self: center;   /* centers the notice horizontally */
  text-align: center;   /* centers the text inside the notice */
  max-width: 120ch;      /* optional: limit line length for readability */
}

.header_window_160226 {
    background: url('/courts/AD2/images/window_160226.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/window_160226.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_column_142503 {
    background: url('/courts/AD2/images/column_142503.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/column_142503.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 250px;
}

.header_Courtroom_1105 {
    background: url('/courts/AD2/images/1000011080.jpg') no-repeat center center local;
    background-image: url('/courts/AD2/images/1000011080.jpg');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_Courtroom_100108 {
    background: url('/courts/AD2/images/Courtroom_100108.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/Courtroom_100108.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_courtroom_wood_art {
    background: url('/courts/AD2/images/courtroom_wood_art.gif') no-repeat center center local;
    background-image: url('/courts/AD2/images/courtroom_wood_art.gif');
    background-attachment: local;
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
    padding: 2rem 0;
    min-height: 200px;
}

.header_image {
    display: block;
    width: 100%;
    text-align: center;
}

/* =========
   Layout Columns & Cards
   ========= */
.container {
    margin-left: auto;
    margin-right: auto;
}


.afc3 {
    /* float: left; */
    width: 30%;
}

.col3 {
    float: left;
    width: 33.3%;
    background-color: #f1f1f1;
    /*padding-left: 10px;
    padding-right: 10px;
    height: 300px; */
}

.leftcolumn {   
    /* float: left; */
    width: 60%;
    background-color: #f1f1f1;
    padding-left: 10px;
    padding-right: 10px;
}


.rightcolumn {
    /* float: left; */
    width: 40%;
    background-color: #f1f1f1;
    padding-left: 10px;
    padding-right: 10px;
}

.footer50 {
    float: left;
    width: 50%;
    /*background-color: #aaa;*/
    padding-left: 15px;
    padding-right: 10px;
}

.equalcolumn {
    /* float: left; */
    width: 50%;
    background-color: #f1f1f1;
    padding-left: 10px;
    padding-right: 10px;
    min-width: 0;   /*4/7/26 */
  
}

.grid-two .equalcolumn {
  width: auto;   /* or 100%, both are fine in a grid */
  min-width: 0;  /* keep this — it’s critical for truncation to work correctly in grid/flex */
}


.card {
    background-color: white;
    /* padding-top: 10px;
    padding-left: 10px;
    padding-right: 10px;
    padding-bottom: 10px; */
    padding: 1.5rem 1rem;
    margin-top: 0px;
    
    
    /* border-radius: 10px; */
}

/* Compact adjustments for Index page only */
.card .cal-container {
    max-width: 600px; /* Limits width for a sidebar or small section */
    box-shadow: none; /* Flattens look for index integration */
}

.card .list-day-header {
    padding: 6px 12px; /* Slimmer headers */
    font-size: 0.85rem;
}

.card .list-events {
    padding: 8px 12px; /* Less empty space */
}

.card .event-list-item {
    font-size: 13px; /* Smaller text */
    padding: 4px 0;   /* Tighter event spacing */
}

.card .list-day-row.today-row {
    border-left-width: 4px; /* Thinner highlight bar */
}

.card .cal-header {
    padding: 10px;
}

.card .cal-title {
    font-size: 0.95rem; /* Smaller month/date range text */
}

.rcard {
    background-color: white;
    border-radius: 10px;
    padding-left: 10px;
    padding-right: 10px;
    /* margin-top: 0px;     */
	padding-bottom: 20px;

    margin: 1rem 0;
}


ol li {
  margin-bottom: 1.75rem
}

.pad { padding: 0.5rem; }
.pad-left { padding-left: 1.5rem; }

.page-title {
  text-align: center;
  max-width: 30rem;
  margin: 0 auto 1rem;
  line-height: 1.4;
}
.rcard .card {
  width: 100%;
  max-height: 37.5rem;
  box-sizing: border-box;   /* prevents 100% + padding overflow */
  overflow-y: auto;         /* vertical scroll only */
  overflow-x: clip;         /* block horizontal overflow (Chrome-friendly) */
  scrollbar-gutter: stable; /* reserve space for vertical scrollbar to prevent micro overflows */
}

/* Valid list + flex column with gap spacing */
.rcard .card ul {
  margin: 0;                    /* remove default top/bottom margins */
  padding-inline-start: 2.5rem;   /* smaller, predictable indent vs default 40px */
  display: flex;
  flex-direction: column;
  gap: 10px;                    /* space between li items (adjust as needed) */
  list-style-position: outside;
}


.rcard h2,
.card h2 {
  font-size: 1.17em;
  font-weight: bold;
  margin-top: .75em;
  margin-bottom: 0.5em;

}

.card h3 {
	font-size: 1.0em;
}

/* Keep long tokens from causing overflow */
.rcard .card li {
  overflow-wrap: anywhere;      /* allows breaking long words/URLs */
  word-break: break-word;
}

/* Defensive: make sure any images inside the list don’t overflow */
.rcard .card img {
  max-width: 100%;
  height: auto;
  display: block;
}


.link-list {
  list-style: none;      /* Remove bullets */
  padding: 0;
  /* margin: 0; */
  margin: 0 auto;
 max-width: 800px;
 white-space: normal;
}


.link-list li {
  margin: .75rem 0 0.75rem;   /* Same spacing as <p> */
}




.link-list li a {

 display: block;
  white-space: normal;
  /* overflow: hidden; */
  /* text-overflow: */
  max-width: 100%;  /* keeps anchor within the column width */
  /* Optional: prevent long tokens from forcing overflow */
  word-break: normal;

}


.link-item {
  display: flex;
  align-items: center;
  margin: 1rem 0;
  gap: 1rem;
  text-align: center;
}


.link-item a {
  display: flex;
  align-items: center;      /* centers vertically */
  justify-content: center;   /* centers horizontally */
  gap: 0.75rem;              /* spacing between image + text */
  text-decoration: none;
  
  margin-inline: auto;
  width: fit-content;             /* keeps the anchor from stretching full width */
  text-decoration: none;

}


.link-item img {
  flex-shrink: 0;
  object-fit: contain; /* forces image to scale inside the box */
  display: block;

}


.link-list.three-cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr)); /* three equal columns */
  gap: 1rem;
}

/* Responsive: stack on small screens (optional) */
@media (max-width: 720px) {
  .link-list.three-cols {
    grid-template-columns: 1fr;
  }
}


/*
.row:after {
    content: "";
    display: table;
    clear: both;
}
*/
.row {
    display: flex;
    flex-wrap: wrap; /* Allows columns to stack on mobile */
    width: 100%;
}

/* =========
   Multi-column Utilities
   ========= */
.multcolumn2 {
    -webkit-column-count: 2; /* Chrome, Safari, Opera */
    -moz-column-count: 2; /* Firefox */
    column-count: 2;
    -webkit-column-width: 200px; /* Chrome, Safari, Opera */
    -moz-column-width: 200px; /* Firefox */
    column-width: 200px;
}

.multcolumn3 {
    -webkit-column-count: 3; /* Chrome, Safari, Opera */
    -moz-column-count: 3; /* Firefox */
    column-count: 3;
    -webkit-column-width: 100px; /* Chrome, Safari, Opera */
    -moz-column-width: 100px; /* Firefox */
    column-width: 100px;
}

@media (max-width: 600px) {
    .leftcolumn, .rightcolumn, .equalcolumn, .col3, .afc3 {   
        width: 100%;
        padding-left: 10px;
        padding-right: 10px;
    }

    .multcolumn2, .multcolumn3 {
        column-count: 1;
        /*column-width:100%;*/
    }
}


@media (max-width: 700px) {
  .rcard .card {
    max-height: 50vh;      /* viewport-relative cap works better at narrow widths */
  }
}


/* =========
   Accessibility Helpers
   ========= */
.skip-link {
    position: absolute;
    top: -100px;
    left: 0;
    background: #003366;
    color: white;
    padding: 10px 20px;
    z-index: 10001;
    text-decoration: none;
    font-weight: bold;
    border: 2px solid #fff;
}
.skip-link:focus { top: 0; }

/* =========
   Banner
   ========= */
/* Mobile-first banner */
.banner {
    display: block;
    width: 100%;
    /* background-image: url("/courts/AD2/images/appellate_division_header_400.gif");  */
    background-image: var(--banner-image-mobile);
    background-size: contain;        /* Show full image */
    background-repeat: no-repeat;    /* Prevent tiling */
    background-position: center;     /* Center image */
    min-height : 100px;             /* Adjust to fit */
    overflow: hidden;
    margin-top: 0;
    margin-bottom: 0;
    position: relative;
    z-index: 10;
}

  .banner .banner-clickable-area {
    position: absolute;
    inset: 0;             /* top/right/bottom/left: 0 */
    display: block;
    cursor: pointer;
    z-index: 11;          /* ensure it sits above background/pseudo elements */
  }

  
/* Visible focus for keyboard users */
.banner .banner-clickable-area:hover,
.banner .banner-clickable-area:focus-visible {
  outline: 3px solid #ffab00;
  outline-offset: -3px; /* inside the banner edge */
}


/* Larger screens */
@media (min-width: 768px) {
    .banner {
        /* background-image: url("/courts/AD2/images/appellate_division_header.gif");  */
        background-image: var(--banner-image-desktop);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
    }

}


/* =========
   FullCalendar list view adjustments
   ========= */
/* In list views (listDay, listWeek, listMonth, listYear), remove event background and border */
.fc-list .fc-event,
.fc-list .fc-list-event {
    background: transparent !important;
    border: 0 !important;
}

/* Remove the colored dot that inherits the event's background color */
.fc-list .fc-event-dot {
    border-color: transparent !important;
    background: transparent !important;
}

/* Ensure text remains readable even if events set textColor: 'white' */
.fc-list .fc-event {
    color: inherit !important;
}

@media screen and (max-width: 995px) {
  .topnav { flex-wrap: wrap; }
  .topnav a:not(:first-child),
  .dropdown .dropbtn { display: none; }
  .topnav a.icon { margin-left: auto; display: inline-flex; align-items: center; }
  /* .topnav .icon { margin-left: auto; display: inline-flex; align-items: center; } */

  .topnav.responsive {
    position: relative;
    padding-top: 40px;
    flex-direction: column;
    display: flex;
    height: auto;
  }
  .topnav.responsive .icon {
    position: absolute; right: 0; top: 0; width: auto !important;
  }
  .topnav.responsive a,
  .topnav.responsive .dropdown { display: block !important; width: 100%; text-align: left; }
  .topnav.responsive .dropdown .dropbtn { display: block !important; width: 100%; text-align: left; background-color: #666; padding: 12px 16px; }
  .topnav.responsive .dropdown-content {
    position: relative; top: 0; width: 100%;
    box-shadow: none;
    background-color: #555;
    /* background-color: #0A3D62;*/
  } 

  
/* NEW: keep closed menus hidden on mobile as well */
.topnav.responsive .dropdown-content[hidden] {
  display: none !important;
}

/* (Optional clarity) when open via JS class, render as block in mobile */
.topnav.responsive .dropdown-content.show {
  display: block;
}

  
  .topnav.responsive .dropdown-content a { color: #fff; padding-left: 30px; }
}

:root {
  --footer-bg: #333333;
  --footer-fg: #ffffff;
  --footer-link: #ffffff;
  --footer-link-hover: #f0f0f0;
  --focus-outline: #0078D4;
  --divider: #4a4a4a;
}



/* Footer container */
.site-footer {
  background-color: var(--footer-bg);
  color: var(--footer-fg);
  /* padding: 2.5rem 1rem; */
  padding: 1rem 1rem;
}

/* Ensure focus visibility inside footer */
.site-footer :focus {
  outline: 2px solid var(--focus-outline);
  outline-offset: 4px;
}

/* Responsive grid */
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 980px) {
  .footer-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Section blocks */
.footer-section {
  border-top: 1px solid var(--divider);
  padding-top: .5rem;
}

@media (min-width: 640px) {
  .footer-section {
    border-top: none;
  }
}

.footer-section h3 {
  margin: 0 0 0.75rem 0;
  font-size: 1.0rem;
  line-height: 1.1;
  color: var(--footer-fg);
  text-transform: uppercase;
  letter-spacing: 0.05rem;
}

/* Link lists */
.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li {
  margin: 0.25rem 0;
}

.footer-links a {
  color: var(--footer-link);
  text-decoration: none;
  font-size: 0.90rem;
  transition: color 0.2s ease;
}

.footer-links a:hover,
.footer-links a:focus {
  text-decoration: underline;
  color: var(--footer-link-hover);
}

/* Icons (Font Awesome or similar) */
.footer-links i[aria-hidden="true"] {
  margin-right: 0.5rem;
  width: 1.2rem;
  text-align: center;
}

/* Footer bottom info block */
.footer-bottom {
  max-width: 1000px;
  margin: 2rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--divider);
  font-size: 0.9rem;
  /* color: #e6e6e6; */
  color:#ffffff;
  text-align: center;
}

.footer-bottom p {
  margin: 0.5rem 0;
}

.footer-bottom a {
  color: var(--footer-link);
}

    /* ------------------ #calendar-list) ------------------ */
#calendar-list {
  --cal-primary: #005a9c;   /* accent blue */
  --cal-border:  #ddd;      /* neutral border */
  --cal-text:    #222;      /* dark text */
  --cal-muted:   #666;      /* muted text */
  --cal-bg:      #fff;      /* surface bg */
  --cal-today-bg:#ffffe0;   /* today highlight (soft yellow) */

  /* spacing tokens */
  --row-pad-y:   6px;
  --row-pad-x:   8px;
  --header-pad-y:6px;
  --header-pad-x:10px;
}

/* ------------------ Container ------------------ */
#calendar-list .cal-container {
  border: 1px solid var(--cal-border);
  border-radius: 6px;
  background: var(--cal-bg);
  box-shadow: none;          /* flatter look for sidebar cards */
  max-width: 600px;          /* fits your index card */
}

/* Ensure the list panel is visible (some global CSS may hide it) */
#calendar-list .list-view-container {
  display: block !important;
  margin-top: 4px;           /* tighten gap between controls and Monday */
}

/* ------------------ Header & Controls ------------------ */
#calendar-list .cal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--header-pad-y) var(--header-pad-x);
  border-bottom: 1px solid var(--cal-border);
}

#calendar-list .cal-title {
  margin: 0;
  font-size: 0.95rem;
  color: var(--cal-text);
}

#calendar-list .cal-btn {
  padding: 4px 8px;
  height: 28px;
  font-size: 11px;
  font-weight: 700;
  color: #222;
  background: #fff;
  border: 1.5px solid #767676;
  border-radius: 4px;
  cursor: pointer;
}

#calendar-list .cal-btn.prev,
#calendar-list .cal-btn.next {
  width: 30px;
  height: 28px;
  line-height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  padding: 0;
}

#calendar-list .today-btn {
  margin-left: 6px;
  padding: 0 10px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

/* Visible focus ring (WCAG 2.4.7) */
#calendar-list .cal-btn:focus-visible,
#calendar-list a:focus-visible {
  outline: 3px solid #ffab00;
  outline-offset: 2px;
}

/* ------------------ Day Rows ------------------ */
#calendar-list .list-day-row {
  padding: var(--row-pad-y) var(--row-pad-x);
   /* border: 1px solid #e0e0e0;    */
  background: var(--cal-bg);
  margin-bottom: 6px;
  border-left: 4px solid transparent; /* neutral default; today will override */
}

/* Strong "today" highlight */
#calendar-list .list-day-row.today-row {
  background: var(--cal-today-bg);
  border-left-color: var(--cal-primary);
}

/* Day header (weekday + date) */
#calendar-list .list-day-header {
  display: flex;
  justify-content: space-between;
  font-weight: 700;
  padding: 4px 8px;
  background: #d1d1d1;
  color: var(--cal-text);
  /* border-bottom: 1px solid var(--cal-border); */
}

/* ------------------ Events List ------------------ */
#calendar-list .list-events {
  padding: 8px 12px;
}

#calendar-list .event-list-item {
  display: flex;
  align-items: center;
  font-size: 13px;
  padding: 2px 0;
  color: #444;
}

#calendar-list .bullet {
  width: 10px; height: 10px; border-radius: 50%;
  display: inline-block; margin-right: 8px; flex-shrink: 0;
}

/* Links: underline for affordance (WCAG 1.4.1 Use of Color) */
#calendar-list .list-events a {
  text-decoration: underline;
  font-weight: 600;
  color: var(--cal-primary);
}

/* No events text */
#calendar-list .no-events {
  color: var(--cal-muted);
  font-style: italic;
  font-size: 0.9rem;
}

/* ------------------ Compact Mode (card) ------------------ */
/* If the calendar sits inside a .card on the index, tighten styles further */
.card #calendar-list .cal-header {
  padding: 6px 10px;
}
.card #calendar-list .cal-title {
  font-size: 0.9rem;
}
.card #calendar-list .cal-btn {
  padding: 4px 8px;
  height: 28px;
  font-size: 11px;
  border: 1.5px solid #767676;
}
.card #calendar-list .cal-btn.prev,
.card #calendar-list .cal-btn.next {
  width: 30px; height: 28px; font-size: 14px; padding: 0;
}
.card #calendar-list .today-btn {
  margin-left: 5px; padding: 0 10px; text-transform: uppercase; letter-spacing: 0.3px;
}

/* ------------------ Responsive Tweaks ------------------ */
@media (max-width: 700px) {
  #calendar-list .cal-title { font-size: 0.9rem; }
  #calendar-list .list-day-header { padding: 4px 6px; }
  #calendar-list .event-list-item { font-size: 12.5px; padding: 3px 0; }
}


   /* ================================
   Appellate Term CSS
   ================================ */


/* Spacing utilities to replace inline styles */
.pt-7 { padding-top: 7px; }
.indent-50 { text-indent: 50px; }
.indent-40 { text-indent: 40px; }

/* Page layout helpers */
.row.bg-light { background-color: #f1f1f1; }
.equalcolumn { padding-top: 20px; padding-bottom: 10px; }

/* Card shells (no fixed height) */
.card {
  background: #fff;
  border-radius: 6px;
  padding: 1rem;
}
.rcard {
  background: #fff;
  border-radius: 6px;
  padding: 1rem;
}


.equalcolumn .card { padding: 0.75rem; }              /* down from 1rem */
.equalcolumn h4.center-text.pt-7 { padding-top: 4px; } /* down from 7px */

/* Skip link (if present elsewhere) */
/* .skip-link:focus {
  position: absolute;
  left: 0.5rem;
  top: 0.5rem;
  z-index: 1000;
  background: #fff;
  color: #000;
  padding: 0.5rem 0.75rem;
  outline: 3px solid var(--focus-outline);
} */

/* Visible focus ring for interactive elements */
a:focus-visible,
button:focus-visible {
  outline: 3px solid var(--focus-outline);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ================================
   Judge Grid — CSS Grid Layout
   Two columns for judges; staff row beneath
   ================================ */

.judge-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(240px, 1fr));
  gap: 32px;

  align-items: start;
  justify-items: center;
  padding: 20px;

  /* Center the whole grid and keep comfortable line length */
  max-width: 900px;
  margin: 0 auto;
  
  justify-content: center;
}

/* Judge profile card */
.profile {
  width: 100%;
  max-width: 300px;      /* caps each card width (no height caps) */
  display: grid;
  justify-items: center;
  text-align: center;
  margin: 0;
}

/* Image wrapper and image */
.image-wrapper { display: block; }
.image-wrapper img {
  border-radius: 50%;
  object-fit: cover;
  display: block;
  margin-bottom: 12px;
  border: 1px solid #ccc;
  width: 135px;
  height: 135px;
  max-width: 100%;
}

/* Headings and links */
.profile h3 {
  font-size: 1rem;
  line-height: 1.3;
  margin: 0 0 8px 0;
}
.profile a {
  color: #004b87;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.profile a:hover { text-decoration: none; color: #002d54; }
.profile a:focus-visible {
  outline: 3px solid var(--focus-outline);
  outline-offset: 3px;
  border-radius: 2px;
}

/* Sub-title / role line */
.title {
  font-size: 0.85rem;
  line-height: 1.5;    /* supports WCAG 1.4.12 spacing adjustments */
  color: #333;
  font-style: italic;
  margin: 0;
  text-align: center;
}

/* Staff row spans full width beneath judges */
.staff-member {
  grid-column: 1 / -1;
  width: 100%;
  text-align: center;

  /* modest spacing without a divider line */
  margin-top: 16px;
  padding-top: 16px;
}
.staff-member .name {
  text-align: center;
  font-weight: bold;
  font-size: 1rem;
  margin: 8px 0 4px;
}
.staff-member .title {
  font-size: 0.95rem;
  font-style: italic;
  margin: 0;
}

/* ================================
   Important Information block
   (no fixed heights; comfortable width)
   ================================ */

.important-info {
  background-color: #fff;
  padding: 0 0 15px;
}
.important-title {
  padding: 0.5rem 0.625rem;
  background-color: var(--accent);
  margin: 0 0 0.5rem;
  color: #000; /* keep good contrast on orange title bar */
}

/* Text list: limit width by characters, not pixels; no height caps */
.important-list {
  max-width: 65ch;        /* ~80 chars line length guideline */
  margin: 0 auto;
}

/* Text spacing resilience */
.important-list,
.important-list p,
.important-list li {
  line-height: 1.5;
  word-spacing: normal;
  letter-spacing: normal;
}

/* ================================
   Calendar panel & small text
   ================================ */

.calendar-body {
  font-size: 0.85rem;     /* replaces inline font-size:11px */
}

/* Prevent horizontal scrolling; allow natural height */
#calendar {
  overflow-x: hidden;
}

/* ================================
   Responsive — single-column at small widths
   ================================ */

@media (max-width: 900px) {
  .judge-grid {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
    gap: 24px;
  }
  .image-wrapper img {
    width: 120px;
    height: 120px;
  }
  .profile h3 { font-size: 1rem; }
  .title { font-size: 0.9rem; }
}

@media (max-width: 480px) {
  .judge-grid {
    grid-template-columns: 1fr;  /* stack to single column (reflow) */
    gap: 20px;
    max-width: 100%;
    padding: 0 1rem;
  }
  .image-wrapper img {
    width: 110px;
    height: 110px;
  }
  .profile h3 { font-size: 1rem; }
  .title { font-size: 0.9rem; }
}