/* ==============================================
   BANKSCRIPT - MAIN STYLESHEET
   Consolidated and optimized CSS
   ============================================== */

/* ==============================================
   FONT DECLARATIONS
   ============================================== */
@font-face {
  font-family: "Diatype Plus";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("public/fonts/diatypeplusvariable5.woff2") format("woff2");
}

@font-face {
  font-family: "Diatype Plus";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("public/fonts/diatypeplusvariable.woff2") format("woff2");
}

@font-face {
  font-family: "Diatype Plus";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("public/fonts/diatypeplusvariable1.woff2") format("woff2");
}

@font-face {
  font-family: "Diatype Plus";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("public/fonts/diatypeplusvariable2.woff2") format("woff2");
}

/* ==============================================
   CSS CUSTOM PROPERTIES
   ============================================== */
:root {
  /* Layout */
  --layout-padding: 25px;
  --layout-gap-xsmall: 0.25rem;
  --layout-gap-small: 0.5rem;
  --layout-gap-medium: 1rem;
  --layout-gap-large: 1.5rem;
  --layout-gap-midlarge: 4rem;
  --layout-gap-xlarge: 6rem;
  --layout-gap-xxlarge: 8rem;
  
  /* Colors */
  --color-black: #000000;
  --color-white: #ffffff;
  --color-gray-dark: #333333;
  --color-gray-medium: #666666;
  --color-gray-light: #cccccc;
  
  /* Typography */
  --font-family-primary: "Diatype Plus", system-ui, -apple-system, sans-serif;
  --font-size-small: 1rem;
  --font-size-medium: 1rem;
  --font-size-large: 1.25rem;
  --font-size-xlarge: 1.35rem;
  --font-size-xxlarge: 1.5rem;
  --font-size-hero: 2.15rem;
  --line-height-small: 1rem;
  --line-height-medium: 1.25rem;
  --line-height-large: 1.5rem;
  --line-height-xlarge: 1.85rem;
  --line-height-xxlarge: 2rem;
  --line-height-hero: 2.5rem;
  
  /* Animations */
  --transition-fast: 0.3s ease;
  --transition-medium: 0.5s ease;
  --transition-slow: 0.8s ease;
}

/* ==============================================
   RESET & BASE STYLES
   ============================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border-width: 0;
  border-style: solid;
  -webkit-font-smoothing: antialiased;
}

html {
  line-height: 1.15;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-family-primary);
  font-weight: 300;
  font-size: var(--font-size-medium);
  line-height: var(--line-height-medium);
  color: var(--color-white);
  background-color: var(--color-black);
  overflow-x: hidden;
  margin: 0;
  font-style: normal;
  text-decoration: none;
  text-transform: none;
  letter-spacing: normal;
}

p, li, ul, pre, div, h1, h2, h3, h4, h5, h6, figure, blockquote, figcaption {
  margin: 0;
  padding: 0;
}

button {
  background-color: transparent;
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
  cursor: pointer;
  color: inherit;
  border: none;
}

button, select {
  text-transform: none;
}

button, [type="button"], [type="reset"], [type="submit"] {
  -webkit-appearance: button;
  color: inherit;
}

button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focus, [type="button"]:-moz-focus, [type="reset"]:-moz-focus, [type="submit"]:-moz-focus {
  outline: 1px dotted ButtonText;
}

a {
  color: inherit;
  text-decoration: inherit;
}

input {
  padding: 2px 4px;
}

img, video {
  max-width: 100%;
  height: auto;
  display: block;
}

details {
  display: block;
  margin: 0;
  padding: 0;
}

summary::-webkit-details-marker {
  display: none;
}

/* Accordion styles from project.html */
[data-thq="accordion"] [data-thq="accordion-content"] {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-in-out;
  padding: 0;
}

[data-thq="accordion"] details[data-thq="accordion-trigger"][open] + [data-thq="accordion-content"] {
  max-height: 1000vh;
}

details[data-thq="accordion-trigger"][open] summary [data-thq="accordion-icon"] {
  transform: rotate(180deg);
}

/* ==============================================
   LAYOUT COMPONENTS
   ============================================== */
.container {
  width: 100%;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-black);
}

.main-content {
  width: 100vw;
  height: 100vh;
  display: flex;
}

/* ==============================================
   LOAD SECTION
   ============================================== */
.load-section {
  flex: 1;
  width: 50%;
  height: 100%;
  position: relative;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  transition: opacity 0.3s ease-in-out;
  will-change: opacity;
}

.load-section::-webkit-scrollbar {
  display: none;
}

.slideshow {
  width: 100%;
  height: 100%;
  position: relative;
}

.slide {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
  opacity: 0;
  transition: opacity var(--transition-slow);
}

.slide.active {
  opacity: 1;
}

.fade-out {
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}

.fade-in {
  opacity: 1;
  transition: opacity 0.3s ease-in-out;
}


/* ==============================================
   MENU SECTION
   ============================================== */
.menu-section {
  width: 50%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--layout-gap-xxlarge);
  padding: var(--layout-padding);
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.menu-section::-webkit-scrollbar {
  display: none;
}

/* ==============================================
   BRAND SECTION
   ============================================== */
.brand-description {
  order: -1;
}

.description {
  font-size: var(--font-size-xxlarge);
  font-weight: 400;
  line-height: var(--line-height-xxlarge);
  color: var(--color-white);
}

.brand-header {
  display: flex;
  flex-direction: column;
  gap: var(--layout-gap-small);
}

.brand-name {
  font-size: var(--font-size-hero);
  font-weight: 600;
  line-height: var(--line-height-hero);
  color: var(--color-white);
}

.brand-tagline {
  font-size: var(--font-size-hero);
  font-weight: 400;
  line-height: var(--line-height-hero);
  color: var(--color-white);
}

/* ==============================================
   PROJECTS SECTION
   ============================================== */
.projects-list {
  display: flex;
  flex-direction: column;
  gap: var(--layout-gap-large);
}

.project-item {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--layout-gap-large);
  padding-top: var(--layout-gap-medium);
  border-top: 0.25px solid var(--color-gray-dark);
  cursor: pointer;
  transition: border-color var(--transition-medium);
}

.project-item:hover {
  border-top-color: var(--color-gray-light);
}

.project-item:hover .project-title {
  font-variation-settings: "wght" 500;
  transform: translateY(-5px);
}

.project-item:hover .project-tags {
  transform: translateY(-5px);
}

.project-item:hover .project-description {
  transform: translateY(-5px);
}

.project-meta {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.project-title {
  font-size: var(--font-size-xlarge);
  font-variation-settings: "wght" 300;
  transition: font-variation-settings 0.3s ease, transform 0.3s ease;
  line-height: var(--line-height-xlarge);
  color: var(--color-white);
}

.project-tags {
  font-size: var(--font-size-large);
  font-weight: 300;
  transition: transform 0.3s ease;
  color: var(--color-gray-medium);
}

.project-description {
  font-size: var(--font-size-xlarge);
  font-weight: 300;
  transition: transform 0.3s ease;
  line-height: var(--line-height-xlarge);
  color: var(--color-white);
}

/* ==============================================
   FOOTER SECTION
   ============================================== */
.site-footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 5px;
  padding-top: var(--layout-gap-medium);
  border-top: 0.25px solid var(--color-gray-dark);
}

.copyright,
.attribution {
  font-size: var(--font-size-large);
  font-weight: 300;
  line-height: var(--line-height-large);
  color: var(--color-white);
}

/* ==============================================
   PROJECT PAGE STYLES
   ============================================== */
.project-container {
  width: 100%;
  display: flex;
  height: 100%;
  align-items: flex-start;
  flex-direction: column;
  background-color: #000000;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: var(--layout-gap-large);
}

.project-container::-webkit-scrollbar {
  display: none;
}

.proj-detail {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--layout-gap-xlarge);
  padding-left: var(--layout-padding);
  padding-right: var(--layout-padding);
  padding-bottom: var(--layout-padding);
}

.proj-header {
  position: sticky;
  top: 0;
  padding-top: var(--layout-padding);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: -5rem;
}

.project-back-btn {
  color: #ffffff;
  width: 25px;
  height: auto;
  transition: transform 0.3s ease;
}

.project-back-btn:hover {
  transform: scale(1.25);
}

.proj-img,
.proj-vid {
  width: 100%;
  height: auto;
  padding-bottom: 20px;
}

.caption {
  font-size: var(--font-size-small);
  font-weight: 300;
  line-height: var(--line-height-small);
  color: var(--color-gray-medium);
  text-align: center;
}

.media {
  text-align: center;
}

/* ==============================================
   ERROR PAGE STYLES
   ============================================== */

.error-content {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--layout-gap-medium);
  padding: var(--layout-padding);
}

.error-code {
  font-size: var(--font-size-hero);
  font-weight: 600;
  line-height: var(--line-height-hero);
  color: var(--color-white);
}

.error-message {
  font-size: var(--font-size-xlarge);
  font-weight: 300;
  line-height: var(--line-height-xlarge);
  color: var(--color-gray-medium);
}


/* ==============================================
   RESPONSIVE DESIGN
   ============================================== */

/* Large screens (1200px and down) */
@media (max-width: 1200px) {
  :root {
    --font-size-hero: 2rem;
    --font-size-small: 0.85rem;
    --font-size-medium: 1rem;
    --font-size-xxlarge: 1.5rem;
    --font-size-xlarge: 1.25rem;
    --font-size-large: 1.1rem;
    --line-height-hero: 2.25rem;
    --line-height-xxlarge: 1.75rem;
    --line-height-xlarge: 1.6rem;
    --line-height-large: 1.25rem;
  }

  .project-back-btn {
    width: 20px;
    height: 20px;
  }
}

/* Medium screens (991px and down) */
@media (max-width: 991px) {
  :root {
    --font-size-hero: 1.35rem;
    --font-size-xxlarge: 1.15rem;
    --font-size-xlarge: 1rem;
    --font-size-large: 0.85rem;
    --font-size-medium: 0.85rem;
    --line-height-hero: 1.65rem;
    --line-height-xxlarge: 1.35rem;
    --line-height-xlarge: 1.25rem;
    --line-height-large: 1rem;
    --line-height-medium: 1rem;
    --line-height-medium: 0.85rem;
    --layout-gap-xlarge: 3rem;
    --layout-gap-xxlarge: 5rem;
    --layout-padding: 20px;
  }
  
  .proj-detail {
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 20px;
  }

  .proj-header {
    margin-bottom: -2rem;
  }

  .brand-header {
    gap: 0;
  }
}

/* Tablet screens (767px and down) */
@media (max-width: 767px) {
  :root {
    --font-size-hero: 1.5rem;
    --font-size-xxlarge: 1.35rem;
    --font-size-xlarge: 1.15rem;
    --font-size-large: 1rem;
    --font-size-small: 0.85rem;
    --font-size-medium: 0.75rem;
    --line-height-hero: 1.75rem;
    --line-height-xxlarge: 1.5rem;
    --line-height-xlarge: 1.4rem;
    --line-height-large: 1.15rem;
    --line-height-medium: 0.9rem;
    --line-height-small: 0.85rem;
  }
  
  .load-section {
    display: none;
  }
  
  .menu-section {
    width: 100%;
  }
  
  .project-item {
    padding-top: var(--layout-gap-small);
  }
  
  .site-footer {
    padding-top: var(--layout-gap-small);
  }

  .proj-header {
    padding-top: 0;
  }

  .proj-detail {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0;
  }
}

/* Mobile screens (479px and down) */
@media (max-width: 479px) {
  :root {
    --font-size-hero: 1.25rem;
    --font-size-xxlarge: 1rem;
    --font-size-xlarge: 0.85rem;
    --font-size-large: 0.75rem;
    --line-height-hero: 1.5rem;
    --line-height-xxlarge: 1.25rem;
    --line-height-xlarge: 1.15rem;
    --line-height-large: 1rem;
    --layout-padding: 15px;
  }
  
  .menu-section {
    padding: var(--layout-padding);
  }
  
  .site-footer {
    gap: var(--layout-gap-xsmall);
  }

  .proj-img,
  .proj-vid {
    padding-bottom: 10px;
  }

  .project-item {
    gap: var(--layout-gap-medium);
  }
}

/* ==============================================
   ACCESSIBILITY & PERFORMANCE
   ============================================== */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  
  .slide {
    transition: none;
  }
}

/* Focus styles for keyboard navigation */
.project-item:focus-visible {
  outline: 2px solid var(--color-white);
  outline-offset: 2px;
}
