/*
 * phylocloud.css  —  Tabler overrides & project-specific styles
 * All layout, components, and utilities come from Tabler/Bootstrap.
 * This file only contains things Tabler does not cover.
 */

/* ── Sticky footer ────────────────────────────────────────────────── */
.page-wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.page-body {
  flex: 1 1 auto;
}

/* ── Navbar dropdown: above everything ───────────────────────────── */
.navbar .dropdown-menu {
  z-index: 9999 !important;
}

/* ── Subheader breadcrumb bars: above page content, below navbar ─── */
/* Subheaders use .navbar.sticky-top but lack .phylo-navbar (main header). */
/* Keeping them at z-index 200 lets the navbar dropdown (effective level
   1030+ from the page-wrapper flex context) render on top of them.     */
.navbar.sticky-top:not(.phylo-navbar) {
  z-index: 200 !important;
}

/* ── Navbar brand icon colour ─────────────────────────────────────── */
.navbar-brand .ti-tree {
  color: var(--color-brand-green);   /* Tabler --tblr-green */
}

/* ── ASCII tree & Newick code blocks ──────────────────────────────── */
.phylo-code {
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 0.82rem;
  line-height: 1.5;
  border-radius: var(--tblr-border-radius);
  padding: 1rem 1.25rem;
  overflow-x: auto;
  white-space: pre;
  margin: 0;
}

.phylo-code--newick {
  background: var(--color-code-light-bg);
  color: var(--color-code-light-fg);
  border: 1px solid var(--color-code-light-border);
}

.phylo-code--ascii {
  background: var(--color-code-dark-bg);
  color: var(--color-code-dark-fg);
  border: 1px solid var(--color-code-dark-border);
}

/* ── Form widgets: make Django-rendered inputs use Bootstrap classes ─ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="file"],
textarea,
select {
  display: block;
  width: 100%;
  padding: .4375rem .75rem;
  font-size: .875rem;
  font-weight: 400;
  line-height: 1.4285714;
  color: var(--color-input-fg);
  background-color: #fff;
  border: 1px solid rgba(98,105,118,.16);
  border-radius: var(--tblr-border-radius-sm);
  transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--color-focus-border);
  box-shadow: 0 0 0 0.2rem var(--color-focus-shadow);
}

input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  margin-top: .2rem;
  cursor: pointer;
  accent-color: var(--color-accent);
}

textarea {
  min-height: 100px;
  resize: vertical;
}

/* ── Hero section vertical padding ───────────────────────────────── */
.hero {
  border-bottom: 1px solid var(--tblr-border-color, #e6e7e9);
  margin-bottom: 2rem;
}

/* ── Compact one-line navbar ──────────────────────────────────────── */
.phylo-navbar {
  padding-top: 0.35rem;
  padding-bottom: 0.35rem;
  min-height: 2.75rem;
}

/* ── Version badge next to brand name ────────────────────────────── */
.phylo-version-badge {
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--color-brand-green);
  background: var(--tblr-primary-lt);
  border-radius: var(--tblr-border-radius-sm);
  padding: 0.1em 0.45em;
  line-height: 1.6;
  align-self: flex-start;
  margin-top: 0.1em;
  opacity: 0.85;
}

/* ── User avatar: initial letter style ───────────────────────────── */
.phylo-avatar {
  background: var(--tblr-primary-lt);
  color: var(--color-brand-green);
  font-size: 0.7rem;
  font-weight: 600;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: 0;
}

/* ── User trigger: subtle hover state ────────────────────────────── */
.phylo-user-trigger {
  border-radius: var(--tblr-border-radius-sm);
  padding: 0.25rem 0.5rem !important;
  transition: background 0.15s;
}

.phylo-user-trigger:hover,
.phylo-user-trigger[aria-expanded="true"] {
  background: var(--color-nav-active-bg);
}

.phylo-chevron {
  font-size: 0.75rem;
  opacity: 0.5;
  transition: transform 0.15s;
}

.phylo-user-trigger[aria-expanded="true"] .phylo-chevron {
  transform: rotate(180deg);
}

/* ── Sign-in link (logged-out state) ─────────────────────────────── */
.phylo-signin-link {
  color: var(--tblr-body-color, #1d273b);
  font-size: 0.875rem;
  text-decoration: none;
  opacity: 0.75;
  transition: opacity 0.15s;
  padding: 0.25rem 0.5rem;
}

.phylo-signin-link:hover {
  opacity: 1;
  color: var(--color-brand-green);
}

/* ── Register button: slightly rounder, restrained ───────────────── */
.phylo-register-btn {
  border-radius: var(--tblr-border-radius-sm);
  padding: 0.25rem 0.75rem;
  font-size: 0.8125rem;
}

/* ── Search highlight ────────────────────────────────────────────── */
mark.phylo-hl {
  background: color-mix(in srgb, var(--color-brand-green) 22%, transparent);
  color: inherit;
  border-radius: 2px;
  padding: 0 1px;
}

/* ── Stat cards (home dashboard) ─────────────────────────────────── */
.phylo-stat-card {
  transition: box-shadow .15s, border-color .15s;
}
.phylo-stat-card:hover {
  box-shadow: 0 2px 10px rgba(0,0,0,.08);
  border-color: var(--tblr-border-color-translucent);
  text-decoration: none;
}

/* ── Auth pages ───────────────────────────────────────────────────── */
.phylo-auth-logo {
  border-radius: 4px;
}

.phylo-auth-icon-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-brand-green) 12%, transparent);
}

/* ── Hero section ─────────────────────────────────────────────────── */
.phylo-hero {
  border-bottom: 1px solid var(--tblr-border-color, #e6e7e9);
  margin-bottom: 2.5rem;
}

.phylo-hero-icon {
  font-size: 3rem;
  color: var(--color-brand-green);
  opacity: 0.85;
}

/* ── Feature cards (gallery-card style) ──────────────────────────── */
.phylo-feature-card {
  border: 1.5px solid var(--tblr-border-color, #e4e4e7);
  border-top: 3px solid transparent;
  border-radius: var(--tblr-border-radius);
  overflow: hidden;
  transition: transform 0.14s ease, box-shadow 0.14s ease;
}

.phylo-feature-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.07);
}

.phylo-feature-card--teal   { border-top-color: var(--color-brand-green); }
.phylo-feature-card--blue   { border-top-color: #206bc4; }
.phylo-feature-card--purple { border-top-color: #ae3ec9; }

/* ── Feature card SVG preview area ───────────────────────────────── */
.phylo-feature-svg {
  background: #f8fafc;
  height: 148px;
  overflow: hidden;
}

.phylo-feature-svg svg {
  display: block;
  width: 100%;
  height: 100%;
}
