/* ═══ Fondograf Unified Layout ═══
   Shared across: stock pages, reports, screener, prognoz, dividendy
   Landing page has its own styles (marketing-specific)
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg-0:#0a0e14;--bg-1:#0d1117;--bg-2:#161b22;--bg-3:#1c2129;
  --border:#21262d;--border-h:#30363d;
  --text-0:#e6edf3;--text-1:#c9d1d9;--text-2:#8b949e;--text-3:#484f58;
  --accent:#58a6ff;--accent-h:#79c0ff;--accent-dim:rgba(88,166,255,0.12);
  --green:#238636;--green-h:#2ea043;--green-dim:rgba(35,134,54,0.12);
  --red:#f85149;--red-dim:rgba(248,81,73,0.12);
  --yellow:#d29922;--yellow-dim:rgba(210,153,34,0.12);
  --purple:#bc56dd;--purple-dim:rgba(188,86,221,0.12);
  --orange:#f0883e;--orange-dim:rgba(240,136,62,0.12);
  --mono:'JetBrains Mono',monospace;
  --sans:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --radius:10px;
  --header-h:56px;
}

html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--bg-0);color:var(--text-1);
  font-size:15px;line-height:1.6;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  padding-top:var(--header-h);
}
a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent-h)}

/* ─── STICKY HEADER ─── */
.ts-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(10,14,20,0.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  height:var(--header-h);
}
.ts-header-inner{
  max-width:1120px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  height:100%;
}
.ts-logo{font-size:19px;font-weight:800;color:var(--text-0);letter-spacing:-.5px;white-space:nowrap}
.ts-logo span{color:var(--accent)}
.ts-logo:hover{color:var(--text-0);text-decoration:none}

.ts-nav{display:flex;align-items:center;gap:20px}
.ts-nav a{color:var(--text-2);font-size:14px;font-weight:500;transition:color .15s;white-space:nowrap}
.ts-nav a:hover{color:var(--text-0);text-decoration:none}
.ts-nav a.active{color:var(--text-0)}
.ts-nav-divider{width:1px;height:20px;background:var(--border)}
.ts-nav-login{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--accent-dim);color:var(--accent)!important;
  padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;
  border:1px solid rgba(88,166,255,0.2);cursor:pointer;transition:all .15s;
}
.ts-nav-login:hover{background:rgba(88,166,255,0.18);color:var(--accent-h)!important}
.ts-user-info{display:none;align-items:center;gap:8px;font-size:13px;color:var(--text-2)}
.ts-user-name{color:var(--text-1);font-weight:600}
.ts-user-plan{
  font-family:var(--mono);font-size:11px;padding:2px 8px;border-radius:4px;
  background:var(--green-dim);color:var(--green-h);font-weight:500;
}
.ts-user-plan.free{background:var(--border);color:var(--text-3)}
.ts-logout{
  background:none;border:1px solid var(--border);color:var(--text-2);
  padding:4px 10px;border-radius:6px;font-size:12px;cursor:pointer;
  font-family:var(--sans);transition:all .15s;
}
.ts-logout:hover{border-color:var(--text-3);color:var(--text-1)}

/* Mobile menu button */
.ts-mobile-btn{
  display:none;background:none;border:none;cursor:pointer;
  width:32px;height:32px;position:relative;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
}
.ts-mobile-btn span{
  display:block;width:20px;height:2px;background:var(--text-2);
  border-radius:1px;transition:all .2s;
}
.ts-mobile-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ts-mobile-btn.open span:nth-child(2){opacity:0}
.ts-mobile-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav dropdown */
.ts-mobile-nav{
  display:none;position:fixed;top:var(--header-h);left:0;right:0;
  background:var(--bg-1);border-bottom:1px solid var(--border);
  padding:16px 24px;z-index:999;
}
.ts-mobile-nav.open{display:flex;flex-direction:column;gap:12px}
.ts-mobile-nav a{
  color:var(--text-1);font-size:15px;font-weight:500;
  padding:8px 0;border-bottom:1px solid var(--border);
}
.ts-mobile-nav a:last-child{border-bottom:none}

@media(max-width:768px){
  .ts-nav{display:none}
  .ts-mobile-btn{display:flex}
  body{padding-top:var(--header-h)}
}

/* ─── BREADCRUMB ─── */
.ts-breadcrumb{
  padding:12px 0;font-size:13px;color:var(--text-3);
  max-width:1120px;margin:0 auto;padding-left:24px;padding-right:24px;
}
.ts-breadcrumb a{color:var(--text-2);font-weight:500}
.ts-breadcrumb a:hover{color:var(--accent)}
.ts-breadcrumb .sep{margin:0 6px;color:var(--text-3)}

/* ─── PAGE CONTAINER ─── */
.ts-container{max-width:1120px;margin:0 auto;padding:0 24px}

/* ─── TABLE OF CONTENTS ─── */
.ts-toc{
  position:sticky;top:calc(var(--header-h) + 16px);
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 20px;margin-bottom:24px;
  max-height:calc(100vh - var(--header-h) - 32px);overflow-y:auto;
}
.ts-toc-title{
  font-family:var(--mono);font-size:11px;color:var(--text-3);
  letter-spacing:1.5px;text-transform:uppercase;margin-bottom:12px;font-weight:600;
}
.ts-toc a{
  display:block;color:var(--text-2);font-size:13px;line-height:1.4;
  padding:4px 0 4px 0;transition:all .15s;
  border-left:2px solid transparent;padding-left:10px;
}
.ts-toc a:hover{color:var(--text-0);text-decoration:none}
.ts-toc a.active{color:var(--accent);border-left-color:var(--accent)}
.ts-toc a.depth-3{padding-left:22px;font-size:12px}

/* Inline TOC (within content, for mobile or pages without sidebar) */
.ts-toc-inline{
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 20px;margin-bottom:24px;
}
.ts-toc-inline .ts-toc-title{margin-bottom:10px}
.ts-toc-inline a{
  display:inline-block;color:var(--text-2);font-size:13px;
  padding:3px 10px;margin:2px 4px 2px 0;
  border-radius:6px;background:var(--bg-3);transition:all .15s;
}
.ts-toc-inline a:hover{color:var(--text-0);background:var(--border);text-decoration:none}

/* ─── TWO-COLUMN LAYOUT (content + sidebar TOC) ─── */
.ts-layout{
  display:grid;
  grid-template-columns:1fr 220px;
  gap:32px;
  max-width:1120px;
  margin:0 auto;
  padding:0 24px;
  align-items:start;
}
.ts-layout-main{min-width:0}
.ts-layout-sidebar{position:relative}

@media(max-width:960px){
  .ts-layout{grid-template-columns:1fr;gap:0}
  .ts-layout-sidebar{display:none}
  /* Show inline TOC on mobile instead */
  .ts-toc-inline.desktop-hidden{display:block!important}
}
@media(min-width:961px){
  .ts-toc-inline.desktop-hidden{display:none!important}
}

/* ─── FOOTER ─── */
.ts-footer{
  margin-top:64px;
  border-top:1px solid var(--border);
  background:var(--bg-1);
  padding:48px 0 32px;
}
.ts-footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;
  max-width:1120px;margin:0 auto;padding:0 24px;
}
.ts-footer-brand{color:var(--text-2);font-size:13px;line-height:1.6}
.ts-footer-brand .ts-logo{margin-bottom:12px;display:inline-block}
.ts-footer h4{
  font-size:12px;font-weight:700;color:var(--text-0);
  text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;
  font-family:var(--mono);
}
.ts-footer-links{display:flex;flex-direction:column;gap:8px}
.ts-footer-links a{color:var(--text-2);font-size:13px;transition:color .15s}
.ts-footer-links a:hover{color:var(--text-0)}
.ts-footer-bottom{
  max-width:1120px;margin:32px auto 0;padding:16px 24px 0;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--text-3);
}

@media(max-width:768px){
  .ts-footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .ts-footer-bottom{flex-direction:column;gap:8px;text-align:center}
}
@media(max-width:480px){
  .ts-footer-grid{grid-template-columns:1fr}
}

/* ─── DISCLAIMER ─── */
.ts-disclaimer{
  max-width:1120px;margin:0 auto;padding:16px 24px;
  font-size:11px;color:var(--text-3);line-height:1.5;
}

/* ─── COMMON CONTENT STYLES ─── */
.ts-section{margin-bottom:32px}
.ts-section h2{
  font-size:20px;font-weight:700;color:var(--text-0);
  margin-bottom:16px;letter-spacing:-.3px;
  scroll-margin-top:calc(var(--header-h) + 16px);
}
.ts-section h3{
  font-size:16px;font-weight:600;color:var(--text-0);
  margin-bottom:12px;
}
.ts-card{
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:16px;
}

/* ─── STOCK SUBNAV (tab bar for stock subpages) ─── */
.stock-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  padding: 0;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
}
.stock-subnav a,
.stock-subnav .active {
  padding: 10px 16px;
  color: var(--text-2);
  text-decoration: none;
  display: inline-block;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.15s;
  white-space: nowrap;
}
.stock-subnav a:hover {
  color: var(--text-0);
  text-decoration: none;
}
.stock-subnav .active {
  color: var(--text-0);
  font-weight: 600;
  border-bottom-color: var(--accent);
}

/* ─── UTILITY ─── */
.ts-badge{
  display:inline-block;font-family:var(--mono);font-size:12px;
  padding:2px 8px;border-radius:4px;font-weight:600;
}
.ts-badge-green{background:var(--green-dim);color:var(--green-h)}
.ts-badge-red{background:var(--red-dim);color:var(--red)}
.ts-badge-yellow{background:var(--yellow-dim);color:var(--yellow)}
.ts-badge-accent{background:var(--accent-dim);color:var(--accent)}
