/*
  Shared non-Tailwind fallback styles.
  Tailwind is compiled to static/css/tailwind.css via npm scripts.
*/

body {
  font-family: "Inter", sans-serif;
  background-color: #f7f9fc;
  color: #0d1c2e;
}

/* Prevent layout shift when switching between pages with/without vertical scrollbar */
html {
  scrollbar-gutter: stable;
  overflow-x: hidden;
}

/* Fallback for older browsers that do not support scrollbar-gutter */
@supports not (scrollbar-gutter: stable) {
  html {
    overflow-y: scroll;
  }
}

h1,
h2,
h3,
h4,
.headline {
  font-family: "Manrope", sans-serif;
}

/*
  Admin / yatırımcı kabuk + sidebar: konumlandırma yalnızca burada (Tailwind fixed/translate ile çakışma yok).
  Şablon: .pv-admin-layout-shell > … > .pv-admin-layout-main-row > aside.pv-sidebar-nav + main
*/
.pv-admin-layout-shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}
.pv-admin-layout-main-row {
  display: flex;
  flex: 1 1 0%;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
  width: 100%;
  align-self: stretch;
  overflow-x: hidden;
}
/* Sticky üst bar + flex main: yeniden boyutta w-full bazen taşır; sınır ver */
.pv-admin-layout-main-row > main {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}
.pv-admin-layout-main-row > main > header:first-of-type {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}
/* Mobil: drawer; Tailwind sınıfı yok — tek kaynak */
aside.app-sidebar.pv-sidebar-nav {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: 50;
  width: 18rem;
  max-width: min(18rem, 100%);
  transform: translateX(-100%);
  transition: transform 0.2s ease-out;
}
@media (max-width: 1023.98px) {
  .pv-admin-layout-shell:has(#admin-nav-toggle:checked) .pv-admin-layout-main-row > aside.app-sidebar.pv-sidebar-nav,
  .pv-admin-layout-shell:has(#investor-nav-toggle:checked) .pv-admin-layout-main-row > aside.app-sidebar.pv-sidebar-nav {
    transform: translateX(0);
  }
}
@media (min-width: 1024px) {
  /*
    Akış içi sidebar + flex/grid: bazı Chrome sürümlerinde main ~659px’te kalıyordu.
    Masaüstü: sidebar viewport’a sabit, main açık margin + net genişlik (klasik admin).
  */
  .pv-admin-layout-main-row {
    display: block;
    width: 100%;
    min-width: 0;
  }
  aside.app-sidebar.pv-sidebar-nav {
    position: fixed !important;
    top: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    right: auto !important;
    inset: auto !important;
    width: 18rem !important;
    max-width: 18rem !important;
    min-height: 100vh !important;
    height: auto !important;
    z-index: 30 !important;
    transform: none !important;
    transition: none;
  }
  .pv-admin-layout-main-row > main {
    margin-left: 18rem !important;
    width: calc(100% - 18rem) !important;
    min-width: 0 !important;
    max-width: none !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
  }
}

/* Sidebar base layer for layout-critical behavior and safe fallbacks */
.app-sidebar {
  background-color: #f1f4f9;
  border-right: 1px solid #cfd8e4;
  color: #0d1c2e;
}

.material-symbols-outlined {
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

/* Sayfalama satır sayısı: odakta mavi ring / varsayılan form ring kaldır */
select[name="page_size"]:focus,
select[name="page_size"]:focus-visible {
  outline: none;
  box-shadow: none !important;
  --tw-ring-width: 0px;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
}

/* Sidebar shell + nav link safety net */
.app-sidebar nav a,
.app-sidebar .p-6 a {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem 1rem;
  border-radius: 0.75rem;
  transition: background-color 0.15s ease, color 0.15s ease, transform 0.1s ease;
}

.app-nav-link {
  color: #534434;
}

.app-nav-link:hover {
  background-color: rgba(221, 167, 69, 0.1);
}

.app-nav-link-active {
  background-image: linear-gradient(to right, #dda745, #f59e0b);
  color: #fff;
  box-shadow:
    0 10px 15px -3px rgba(221, 167, 69, 0.28),
    0 4px 6px -2px rgba(221, 167, 69, 0.16);
}

.app-nav-link-active:active {
  transform: scale(0.98);
}

/* Layout-critical rule: keep sidebar logo below fixed mobile hamburger button */
@media (max-width: 1023.98px) {
  .sidebar-brand-offset {
    padding-top: 5.5rem !important;
    padding-bottom: 1.75rem !important;
  }
}

/* Veri kaynakları — Diğer manuel satırlar: Yükle / Güncelle aynı minimum kapsül genişliği */
.pv-ds-manual-action-pill {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 9rem;
}

/* Tesisler — enerji köprüsü açıklaması (tailwind.css sırası / önbellekten bağımsız tema mavisi) */
.pv-energy-bridge-detail {
  color: #8abdd9; /* theme tertiary-container */
  font-weight: 600;
}
