/* ===== Bokko Public Docs — Landing Styles ===== */

@font-face { font-family: 'Plus Jakarta Sans'; src: url('/fonts/PlusJakartaSans-SemiBold.ttf') format('truetype'); font-weight: 600; font-display: swap; }
@font-face { font-family: 'Plus Jakarta Sans'; src: url('/fonts/PlusJakartaSans-Bold.ttf') format('truetype'); font-weight: 700; font-display: swap; }
@font-face { font-family: 'Plus Jakarta Sans'; src: url('/fonts/PlusJakartaSans-ExtraBold.ttf') format('truetype'); font-weight: 800; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('/fonts/Inter-Regular.ttf') format('truetype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('/fonts/Inter-Medium.ttf') format('truetype'); font-weight: 500; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('/fonts/Inter-SemiBold.ttf') format('truetype'); font-weight: 600; font-display: swap; }

:root {
  --bg: #F7F5F2; --bg-alt: #F0ECE6; --white: #FFFFFF; --dark: #2C3A3B;
  --dark-hover: #3A4B4D; --text-secondary: #6B7280; --accent: #F28B72;
  --accent-light: #FDE8E4; --border: #E5E1DB;
  --font-headline: 'Plus Jakarta Sans', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --radius: 14px; --radius-sm: 8px; --radius-md: 10px; --max-width: 960px;
  --shadow-sm: 0 1px 3px rgba(44,58,59,0.04), 0 1px 2px rgba(44,58,59,0.06);
  --shadow-md: 0 4px 16px rgba(44,58,59,0.06), 0 2px 4px rgba(44,58,59,0.04);
  --header-bg: rgba(247,245,242,0.85);
}

html[data-theme="dark"] {
  --bg: #161B1C; --bg-alt: #1D2425; --white: #222829; --dark: #E8E4DF;
  --dark-hover: #FFFFFF; --text-secondary: #9CA3AF; --accent-light: rgba(242,139,114,0.15);
  --border: rgba(255,255,255,0.1);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3); --shadow-md: 0 4px 16px rgba(0,0,0,0.35);
  --header-bg: rgba(22,27,28,0.92);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: var(--font-body); color: var(--dark); background: var(--bg); line-height: 1.6; -webkit-font-smoothing: antialiased; min-height: 100vh; display: flex; flex-direction: column; }

/* ===== Header ===== */
.docs-pub-header { position: sticky; top: 0; background: var(--header-bg); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); z-index: 100; }
.docs-pub-header-inner { max-width: var(--max-width); margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; height: 56px; }
.docs-pub-logo { display: flex; align-items: center; gap: 8px; text-decoration: none; }
.docs-pub-logo-img { height: 26px; width: auto; }
html[data-theme="dark"] .docs-pub-logo-img { content: url('/logo-dark.png'); }
.docs-pub-logo-badge { font-family: var(--font-headline); font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent); background: var(--accent-light); padding: 2px 8px; border-radius: 4px; }
.docs-pub-nav { display: flex; align-items: center; gap: 12px; }
.docs-pub-internal-link { font-size: 0.85rem; font-weight: 500; color: var(--text-secondary); text-decoration: none; padding: 6px 14px; border: 1px solid var(--border); border-radius: var(--radius-sm); transition: color 0.2s, border-color 0.2s; }
.docs-pub-internal-link:hover { color: var(--dark); border-color: var(--dark); }

/* Theme toggle */
.docs-pub-theme-btn { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: none; background: none; color: var(--text-secondary); cursor: pointer; border-radius: var(--radius-sm); transition: color 0.2s; }
.docs-pub-theme-btn:hover { color: var(--dark); }
.docs-pub-theme-btn .icon-moon { display: none; }
html[data-theme="dark"] .docs-pub-theme-btn .icon-sun { display: none; }
html[data-theme="dark"] .docs-pub-theme-btn .icon-moon { display: block; }

/* ===== Main ===== */
.docs-pub-main { max-width: var(--max-width); margin: 0 auto; padding: 0 24px; flex: 1; width: 100%; }
.docs-pub-hero { text-align: center; padding: 80px 0 48px; }
.docs-pub-hero h1 { font-family: var(--font-headline); font-size: 2.5rem; font-weight: 800; margin-bottom: 12px; }
.docs-pub-hero p { font-size: 1.1rem; color: var(--text-secondary); max-width: 560px; margin: 0 auto; }
.docs-pub-hero-sub { font-size: 0.95rem !important; margin-top: 16px !important; }

/* ===== Cards ===== */
.docs-pub-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; padding-bottom: 80px; }
.docs-pub-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow-sm); transition: box-shadow 0.3s, transform 0.3s; position: relative; }
.docs-pub-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.docs-pub-card h3 { font-family: var(--font-headline); font-size: 1.1rem; font-weight: 700; margin-bottom: 8px; }
.docs-pub-card p { font-size: 0.9rem; color: var(--text-secondary); line-height: 1.5; margin-bottom: 12px; }
.docs-pub-badge { display: inline-block; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--accent); background: var(--accent-light); padding: 3px 10px; border-radius: 4px; }

/* ===== Footer ===== */
.docs-pub-footer { max-width: var(--max-width); margin: 0 auto; padding: 24px; display: flex; align-items: center; gap: 16px; font-size: 0.85rem; color: var(--text-secondary); flex-wrap: wrap; border-top: 1px solid var(--border); width: 100%; }
.docs-pub-footer a { color: var(--text-secondary); text-decoration: none; }
.docs-pub-footer a:hover { color: var(--dark); }

/* ===== Responsive ===== */
@media (max-width: 640px) {
  .docs-pub-hero { padding: 48px 0 32px; }
  .docs-pub-hero h1 { font-size: 1.8rem; }
  .docs-pub-grid { grid-template-columns: 1fr; }
}
