/**
 * TextPilot – Layout
 * Page shell, sidebar, footer, section helpers, responsive breakpoints.
 */

/* ── Page Shell ───────────────────────────────────────────────────────── */
.page-wrapper { background: var(--tp-bg); }

.page-header {
  background: var(--tp-surface);
  border-bottom: 1px solid var(--tp-border);
  padding: .9rem 1.5rem;
  box-shadow: 0 1px 0 var(--tp-border-light), 0 2px 12px rgba(0,0,0,.04);
}
.page-pretitle {
  font-size: .6rem; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--tp-text-muted);
}
.page-title {
  font-size: 1.4rem; font-weight: 800;
  letter-spacing: -.045em; color: var(--tp-text); line-height: 1.2;
}
h3, .h3 { font-weight: 700; letter-spacing: -.025em; color: var(--tp-text); }

/* ── Sidebar ──────────────────────────────────────────────────────────── */
.navbar-vertical {
  background: var(--tp-nav-bg) !important;
  border-right: 1px solid var(--tp-nav-border) !important;
  box-shadow: 4px 0 24px rgba(0,0,0,.18) !important;
}
.navbar-vertical .navbar-brand-autodark {
  padding: .75rem 0 1rem;
  border-bottom: 1px solid var(--tp-nav-border);
}
.navbar-vertical .nav-link {
  color: var(--tp-nav-text);
  border-radius: 8px;
  font-size: .84rem; font-weight: 500;
  padding: .5rem .75rem;
  margin: 1px 6px;
  transition: background .12s, color .12s;
}
.navbar-vertical .nav-link:hover {
  background: rgba(37,99,235,.10);
  color: var(--tp-nav-text-hover);
}
.navbar-vertical .nav-link.active {
  background: var(--tp-nav-active) !important;
  color: #fff !important;
  font-weight: 600;
  box-shadow: 0 2px 10px rgba(37,99,235,.40), 0 1px 3px rgba(37,99,235,.20) !important;
}
.navbar-vertical .nav-link.active i,
.navbar-vertical .nav-link.active .nav-link-icon i { color: #fff !important; opacity: 1 !important; }
.navbar-vertical .nav-link-icon i { color: var(--tp-nav-muted); font-size: 1.2rem; }
.navbar-vertical .nav-link:hover .nav-link-icon i { color: var(--tp-nav-text-hover); }
.navbar-vertical .nav-link.active .nav-link-icon i { font-size: 1.2rem; }
.navbar-vertical .nav-item > .nav-link.text-uppercase {
  color: var(--tp-nav-muted) !important;
  font-size: .57rem !important; font-weight: 900 !important;
  letter-spacing: .15em !important;
  padding-top: 1.5rem; padding-bottom: .3rem;
  margin: 0 6px; cursor: default;
}
.navbar-vertical .navbar-toggler { border-color: var(--tp-nav-border); color: var(--tp-nav-text); }
.navbar-vertical .dropdown-menu {
  background: var(--tp-nav-surface);
  border: 1px solid var(--tp-nav-border);
  box-shadow: var(--shadow-lg); border-radius: var(--tp-radius);
}
.navbar-vertical .dropdown-item { color: var(--tp-nav-text); }
.navbar-vertical .dropdown-item:hover { background: rgba(255,255,255,.07); color: var(--tp-nav-text-hover); }
.navbar-vertical .dropdown-divider { border-color: var(--tp-nav-border); }
.navbar-vertical .border-top { border-color: var(--tp-nav-border) !important; }

/* Logo */
.tp-logo-mark {
  width: 34px; height: 34px;
  background: linear-gradient(135deg, #18CDE2 0%, #0EAEC1 55%, #0990A3 100%);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; color: #fff; font-size: 15px; flex-shrink: 0;
  box-shadow: 0 0 0 1px rgba(14,174,193,.3), 0 2px 10px rgba(14,174,193,.5), 0 1px 0 rgba(255,255,255,.2) inset;
}
.tp-logo-text        { font-size: 17px; font-weight: 800; color: #fff; letter-spacing: -.45px; }
.tp-logo-text-accent { color: var(--tp-brand); }
.tp-avatar-brand     { background-color: var(--tp-brand) !important; }

/* Quota meter */
.tp-sidebar-quota {
  padding: .625rem .875rem .5rem;
  border-top: 1px solid var(--tp-nav-border);
}
.tp-sidebar-quota-header { display: flex; justify-content: space-between; margin-bottom: 7px; }
.tp-sidebar-quota-label  {
  font-size: .58rem; color: var(--tp-nav-muted);
  text-transform: uppercase; letter-spacing: .09em; font-weight: 800;
}
.tp-sidebar-quota-value  { font-size: .58rem; color: var(--tp-nav-text); font-weight: 700; }
.tp-sidebar-quota-track  {
  height: 4px; background: rgba(255,255,255,.12);
  border-radius: 99px; overflow: hidden;
}
.tp-sidebar-quota-fill {
  height: 100%; width: var(--pct, 0%);
  background: linear-gradient(90deg, #0EAEC1, #18CDE2);
  border-radius: 99px; transition: width .5s;
}
.tp-sidebar-quota-fill--warn   { background: linear-gradient(90deg, #D97706, var(--tp-warning)); }
.tp-sidebar-quota-fill--danger { background: linear-gradient(90deg, #DC2626, var(--tp-danger)); }
.tp-sidebar-quota-warn { font-size: .65rem; color: #F87171; margin-top: 5px; font-weight: 600; }

/* User block */
.tp-sidebar-user {
  padding: .875rem 1rem .75rem;
  background: rgba(0,0,0,.15);
  border-top: 1px solid var(--tp-nav-border) !important;
}
.tp-sidebar-username { font-size: .84rem; font-weight: 700; color: var(--tp-nav-text-hover); letter-spacing: -.02em; }

/* Plan badges */
.tp-plan {
  display: inline-flex; align-items: center;
  padding: 2px 9px; border-radius: 20px;
  font-size: .67rem; font-weight: 700; letter-spacing: .01em;
}
.tp-plan--starter { background: rgba(100,116,139,.1); color: #64748b; }
.tp-plan--pro     { background: linear-gradient(135deg, rgba(14,174,193,.12), rgba(14,174,193,.06)); color: #0B8FA0; border: 1px solid rgba(14,174,193,.22); }
.tp-plan--agency  { background: linear-gradient(135deg, rgba(139,92,246,.13), rgba(139,92,246,.06)); color: #7c3aed; border: 1px solid rgba(139,92,246,.22); }
.badge-plan-starter { background: rgba(100,116,139,.1); color: #64748b; }
.badge-plan-pro     { background: rgba(14,174,193,.12);  color: #0B8FA0; }
.badge-plan-agency  { background: rgba(139,92,246,.12);  color: #7c3aed; }

/* Trial banner */
.trial-banner {
  display: none; margin: .5rem .75rem;
  padding: .5rem .875rem; border-radius: 7px;
  font-size: .75rem; font-weight: 600;
  background: rgba(245,158,11,.08); color: #92400e;
  border: 1px solid rgba(245,158,11,.22);
}
.trial-banner.visible { display: block; }

/* Theme toggle */
.tp-theme-toggle { cursor: pointer; }
.tp-theme-toggle:hover { background: var(--tp-bg) !important; color: var(--tp-text) !important; }

/* ── Footer ───────────────────────────────────────────────────────────── */
.footer         { border-top: 1px solid var(--tp-border-light); background: var(--tp-surface); }
.tp-footer-text { font-size: .75rem; color: var(--tp-text-muted); }

/* ── Section Labels ───────────────────────────────────────────────────── */
.tp-section-label {
  font-size: .6rem; font-weight: 900;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--tp-text-muted); white-space: nowrap;
}
.tp-section-rule { flex: 1; height: 1px; background: var(--tp-border-light); }

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 991px) {
  .page-header   { padding: 12px 16px; }
  .tp-hero-title { font-size: 1.3rem; }
  .tp-kpi-number { font-size: 1.9rem; }
  .tp-stat-icon  { width: 46px; height: 46px; }
  .tp-chart-area { height: 180px; }
}
@media (max-width: 767px) {
  .tp-hero-illus { width: 100px; height: 100px; }
  .tp-hero-title { font-size: 1.2rem; }
  .tp-kpi-number { font-size: 1.65rem; }
  .card-body     { padding: 1rem; }
  .page-header .btn { display: none; }
  .page-header .btn:first-child { display: inline-flex; }
  .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}
@media (max-width: 575px) {
  .tp-hero-illus { display: none !important; }
  .tp-hero-title { font-size: 1.15rem; }
  .tp-kpi-number { font-size: 1.5rem; letter-spacing: -.04em; }
  .tp-stat-icon  { width: 42px; height: 42px; border-radius: 12px; }
  .tp-stat-icon i { font-size: 1.2rem; }
  .tp-chart-area { height: 160px; }
  .container-fluid { padding-left: 12px; padding-right: 12px; }
  .row.g-3 { --bs-gutter-x: 12px; --bs-gutter-y: 10px; }
  .btn { min-height: 38px; }
  .btn-sm { min-height: 32px; padding: .4rem .95rem; }
}

/* ── Dark Mode: Layout ────────────────────────────────────────────────── */
[data-theme="dark"] body         { background: var(--tp-bg); color: var(--tp-text); }
[data-theme="dark"] .page-wrapper { background: var(--tp-bg); }
[data-theme="dark"] .page-header  { background: var(--tp-surface); border-bottom-color: var(--tp-border); }
[data-theme="dark"] .page-title   { color: var(--tp-text); }
[data-theme="dark"] .page-pretitle { color: var(--tp-text-muted); }
[data-theme="dark"] h3, [data-theme="dark"] .h3 { color: var(--tp-text); }
[data-theme="dark"] .tp-section-label { color: var(--tp-text-muted); }
[data-theme="dark"] .tp-section-rule  { background: var(--tp-border); }

[data-theme="dark"] .navbar-vertical  { background: var(--tp-surface) !important; border-right-color: var(--tp-border) !important; }
[data-theme="dark"] .navbar-vertical .nav-link { color: var(--tp-text-secondary); }
[data-theme="dark"] .navbar-vertical .nav-link:hover { background: rgba(255,255,255,.05); color: var(--tp-text); }
[data-theme="dark"] .navbar-vertical .nav-link.active { background: var(--tp-nav-active) !important; color: #fff !important; box-shadow: 0 2px 10px rgba(37,99,235,.45), 0 1px 3px rgba(37,99,235,.2) !important; }
[data-theme="dark"] .navbar-vertical .nav-link-icon i { color: var(--tp-text-muted); }
[data-theme="dark"] .navbar-vertical .nav-item > .nav-link.text-uppercase { color: var(--tp-text-muted) !important; }
[data-theme="dark"] .navbar-vertical .dropdown-menu { background: #1E2438; border-color: var(--tp-border); }
[data-theme="dark"] .navbar-vertical .border-top { border-color: var(--tp-border) !important; }
[data-theme="dark"] .tp-sidebar-quota-track { background: var(--tp-border); }
[data-theme="dark"] .tp-sidebar-user { background: linear-gradient(180deg, #1A1F2E 0%, #141828 100%); border-top-color: var(--tp-border) !important; }
[data-theme="dark"] .tp-sidebar-username { color: var(--tp-text); }
[data-theme="dark"] .tp-logo-text  { color: var(--tp-text); }
[data-theme="dark"] .trial-banner  { background: rgba(245,158,11,.1); border-color: rgba(245,158,11,.25); }
[data-theme="dark"] .tp-theme-toggle:hover { background: rgba(255,255,255,.05) !important; color: var(--tp-text) !important; }
[data-theme="dark"] .tp-plan--starter { background: rgba(100,116,139,.15); color: #8899AE; }
[data-theme="dark"] .tp-plan--pro     { background: rgba(14,174,193,.15); border-color: rgba(14,174,193,.25); }
[data-theme="dark"] .tp-plan--agency  { background: rgba(139,92,246,.15); border-color: rgba(139,92,246,.25); }
[data-theme="dark"] .footer { background: var(--tp-surface); border-top-color: var(--tp-border); }
[data-theme="dark"] .tp-footer-text { color: var(--tp-text-muted); }
