/* === DESIGN TOKENS === */
:root {
  --color-bg: #FAF7F2;
  --color-bg-warm: #F5F0E8;
  --color-bg-code: #1E1E2E;
  --color-text: #2C2A28;
  --color-text-secondary: #6B6560;
  --color-text-muted: #9E9790;
  --color-border: #E5DFD6;
  --color-border-light: #EEEBE5;
  --color-surface: #FFFFFF;
  --color-surface-warm: #FDF9F3;
  --color-accent: #2D8B55;
  --color-accent-hover: #24704A;
  --color-accent-light: #E8F5EE;
  --color-accent-muted: #5DAE7A;
  --color-success: #2D8B55;
  --color-success-light: #E8F5EE;
  --color-error: #C93B3B;
  --color-error-light: #FDE8E8;
  --color-info: #2A7B9B;
  --color-info-light: #E4F2F7;
  --color-warning: #D4A843;
  --color-warning-light: #FDF6E3;
  --color-actor-1: #2D8B55;
  --color-actor-2: #2A7B9B;
  --color-actor-3: #7B6DAA;
  --color-actor-4: #D4A843;
  --color-actor-5: #D94F30;
  --font-display: 'Bricolage Grotesque', Georgia, serif;
  --font-body: 'DM Sans', -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
  --text-xs: 0.75rem; --text-sm: 0.875rem; --text-base: 1rem;
  --text-lg: 1.125rem; --text-xl: 1.25rem; --text-2xl: 1.5rem;
  --text-3xl: 1.875rem; --text-4xl: 2.25rem; --text-5xl: 3rem;
  --leading-tight: 1.15; --leading-snug: 1.3; --leading-normal: 1.6;
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem;
  --space-5: 1.25rem; --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem;
  --space-12: 3rem; --space-16: 4rem; --space-20: 5rem;
  --content-width: 860px; --nav-height: 56px;
  --radius-sm: 8px; --radius-md: 12px; --radius-lg: 16px; --radius-full: 9999px;
  --shadow-sm: 0 1px 2px rgba(44,42,40,0.05);
  --shadow-md: 0 4px 12px rgba(44,42,40,0.08);
  --shadow-lg: 0 8px 24px rgba(44,42,40,0.1);
  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --duration-fast: 150ms; --duration-normal: 300ms; --duration-slow: 500ms;
}
/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);
  line-height:var(--leading-normal);font-size:var(--text-base)}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}
pre,code{white-space:pre-wrap;word-break:break-word;overflow-x:hidden}
a{color:var(--color-accent);text-decoration:none}
a:hover{text-decoration:underline}

/* === NAV === */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:rgba(250,247,242,0.95);
  backdrop-filter:blur(12px);z-index:1000;border-bottom:1px solid var(--color-border-light)}
.nav-inner{max-width:var(--content-width);margin:0 auto;height:100%;display:flex;
  align-items:center;justify-content:space-between;padding:0 var(--space-6)}
.nav-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);color:var(--color-text)}
.nav-title a{color:inherit}
.nav-links{display:flex;gap:var(--space-4);font-size:var(--text-sm)}
.nav-links a{color:var(--color-text-secondary);font-weight:500}
.nav-links a:hover{color:var(--color-accent);text-decoration:none}
.nav-links a.current{color:var(--color-accent);font-weight:600}

/* === PAGE LAYOUT === */
.page{padding-top:calc(var(--nav-height) + var(--space-10));padding-bottom:var(--space-20);
  max-width:var(--content-width);margin:0 auto;padding-left:var(--space-6);padding-right:var(--space-6)}
.page-header{margin-bottom:var(--space-12)}
.page-number{font-family:var(--font-display);font-size:var(--text-5xl);font-weight:800;
  color:var(--color-accent);opacity:0.15;line-height:1;display:block}
.page-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:700;
  line-height:var(--leading-tight);margin-top:var(--space-2)}
.page-subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);margin-top:var(--space-3);max-width:600px}

/* === DIATAXIS TABS === */
.diataxis-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:var(--space-10);
  overflow-x:auto;-webkit-overflow-scrolling:touch}
.diataxis-tab{padding:var(--space-3) var(--space-5);font-family:var(--font-display);font-weight:600;
  font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;border:none;background:none;
  border-bottom:3px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all var(--duration-fast)}
.diataxis-tab:hover{color:var(--color-text)}
.diataxis-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}
.diataxis-tab .tab-icon{margin-right:var(--space-2)}
.diataxis-panel{display:none}
.diataxis-panel.active{display:block}

/* === SECTION HEADINGS === */
h2{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-6);
  line-height:var(--leading-snug)}
h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--space-4);
  line-height:var(--leading-snug)}
p{margin-bottom:var(--space-4)}
p:last-child{margin-bottom:0}

/* === TUTORIAL STEP === */
.tutorial-step{border-left:3px solid var(--color-accent);padding:var(--space-6);margin-bottom:var(--space-6);
  background:var(--color-surface);border-radius:0 var(--radius-md) var(--radius-md) 0;box-shadow:var(--shadow-sm)}
.tutorial-step-number{font-family:var(--font-display);font-weight:800;color:var(--color-accent);
  font-size:var(--text-xs);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:var(--space-2)}
.tutorial-step h3{margin-bottom:var(--space-3)}
.tutorial-step .expected-result{background:var(--color-success-light);padding:var(--space-3) var(--space-4);
  border-radius:var(--radius-sm);font-size:var(--text-sm);margin-top:var(--space-4);
  border-left:3px solid var(--color-success)}
.tutorial-step .expected-result strong{color:var(--color-success)}

/* === HOW-TO RECIPE === */
.howto-recipe{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-6);
  margin-bottom:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}
.howto-recipe h3{display:flex;align-items:center;gap:var(--space-3)}
.howto-recipe h3::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--color-accent);flex-shrink:0}
.howto-list{list-style:none;counter-reset:howto}
.howto-list li{counter-increment:howto;padding:var(--space-3) 0;padding-left:var(--space-8);
  position:relative;border-bottom:1px solid var(--color-border-light);font-size:var(--text-sm)}
.howto-list li:last-child{border-bottom:none}
.howto-list li::before{content:counter(howto);position:absolute;left:0;width:24px;height:24px;
  border-radius:50%;background:var(--color-accent-light);color:var(--color-accent);font-weight:700;
  font-size:var(--text-xs);display:flex;align-items:center;justify-content:center;font-family:var(--font-display)}

/* === CODE BLOCKS === */
.code-block{background:var(--color-bg-code);color:#CDD6F4;padding:var(--space-5);border-radius:var(--radius-md);
  font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.7;margin:var(--space-4) 0;
  position:relative;overflow-x:hidden}
.code-block .filename{position:absolute;top:var(--space-2);right:var(--space-3);font-size:var(--text-xs);
  color:var(--color-text-muted);opacity:0.6;letter-spacing:0.05em}
.code-keyword{color:#CBA6F7}.code-string{color:#A6E3A1}.code-function{color:#89B4FA}
.code-comment{color:#6C7086}.code-number{color:#FAB387}.code-property{color:#F9E2AF}
.code-operator{color:#94E2D5}.code-decorator{color:#F9E2AF}

/* === TRANSLATION BLOCKS === */
.translation-block{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius-md);
  overflow:hidden;box-shadow:var(--shadow-md);margin:var(--space-6) 0}
.translation-code{background:var(--color-bg-code);color:#CDD6F4;padding:var(--space-5);
  font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.7;position:relative;overflow-x:hidden}
.translation-code pre,.translation-code code{white-space:pre-wrap;word-break:break-word;overflow-x:hidden}
.translation-english{background:var(--color-surface-warm);padding:var(--space-5);font-size:var(--text-sm);
  line-height:1.7;border-left:3px solid var(--color-accent)}
.translation-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:0.1em;
  opacity:0.5;display:block;margin-bottom:var(--space-3)}
.tl{margin-bottom:var(--space-3);padding-left:var(--space-3);border-left:2px solid var(--color-border-light)}

/* === REFERENCE TABLE === */
.ref-table{width:100%;border-collapse:collapse;margin:var(--space-4) 0;font-size:var(--text-sm)}
.ref-table th{text-align:left;padding:var(--space-3) var(--space-4);background:var(--color-bg-warm);
  font-family:var(--font-display);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;
  letter-spacing:0.05em;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}
.ref-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);
  vertical-align:top}
.ref-table tr:hover td{background:var(--color-surface-warm)}
.ref-table code{font-family:var(--font-mono);font-size:var(--text-xs);background:var(--color-bg-code);
  color:#CBA6F7;padding:2px 6px;border-radius:4px}

/* === CALLOUT === */
.callout{display:flex;gap:var(--space-4);padding:var(--space-5);border-radius:var(--radius-md);margin:var(--space-6) 0}
.callout-accent{background:var(--color-accent-light);border-left:4px solid var(--color-accent)}
.callout-info{background:var(--color-info-light);border-left:4px solid var(--color-info)}
.callout-warning{background:var(--color-warning-light);border-left:4px solid var(--color-warning)}
.callout-error{background:var(--color-error-light);border-left:4px solid var(--color-error)}
.callout-icon{font-size:1.3rem;flex-shrink:0;line-height:1}
.callout-content{flex:1}
.callout-title{font-family:var(--font-display);font-weight:600;display:block;margin-bottom:var(--space-1)}
.callout-content p{font-size:var(--text-sm);color:var(--color-text-secondary)}

/* === CARDS === */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-4);margin:var(--space-6) 0}
.card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-5);
  box-shadow:var(--shadow-sm);border-top:3px solid var(--color-border)}
.card h4{font-family:var(--font-display);font-weight:600;margin-bottom:var(--space-2)}
.card p{font-size:var(--text-sm);color:var(--color-text-secondary)}

/* === BADGE LIST === */
.badge-list{display:flex;flex-direction:column;gap:var(--space-2);margin:var(--space-4) 0}
.badge-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);
  border:1px solid var(--color-border-light);border-radius:var(--radius-sm);font-size:var(--text-sm)}
.badge-code{font-family:var(--font-mono);font-size:var(--text-xs);background:var(--color-bg-code);color:#CBA6F7;
  padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);white-space:nowrap}

/* === FILE TREE === */
.file-tree{font-family:var(--font-mono);font-size:var(--text-sm);background:var(--color-surface);
  padding:var(--space-5);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin:var(--space-4) 0}
.ft-item{padding:var(--space-1) var(--space-3);border-left:2px solid var(--color-border-light);margin-left:var(--space-4)}
.ft-item.folder>.ft-name{color:var(--color-accent);font-weight:600}
.ft-name{margin-right:var(--space-2)}
.ft-desc{color:var(--color-text-secondary);font-family:var(--font-body);font-size:var(--text-xs)}
.ft-children{margin-left:var(--space-4)}

/* === QUIZ === */
.quiz{margin:var(--space-6) 0}
.quiz-block{margin-bottom:var(--space-6);padding:var(--space-5);background:var(--color-surface);
  border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
.quiz-q{font-family:var(--font-display);font-weight:600;font-size:var(--text-lg);margin-bottom:var(--space-4)}
.quiz-scenario{background:var(--color-bg-warm);padding:var(--space-4);border-radius:var(--radius-sm);
  margin-bottom:var(--space-4);font-size:var(--text-sm);border-left:3px solid var(--color-warning)}
.quiz-opts{display:flex;flex-direction:column;gap:var(--space-2)}
.quiz-opt{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);
  border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);
  cursor:pointer;width:100%;transition:all var(--duration-fast);font-family:var(--font-body);
  font-size:var(--text-sm);text-align:left}
.quiz-opt:hover{border-color:var(--color-accent-muted)}
.quiz-opt.selected{border-color:var(--color-accent);background:var(--color-accent-light)}
.quiz-opt.correct{border-color:var(--color-success);background:var(--color-success-light)}
.quiz-opt.wrong{border-color:var(--color-error);background:var(--color-error-light)}
.quiz-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--color-border);flex-shrink:0;
  transition:all var(--duration-fast)}
.quiz-opt.selected .quiz-radio{border-color:var(--color-accent);background:var(--color-accent);
  box-shadow:inset 0 0 0 3px #fff}
.quiz-fb{max-height:0;overflow:hidden;opacity:0;transition:max-height var(--duration-normal),opacity var(--duration-normal)}
.quiz-fb.show{max-height:300px;opacity:1;padding:var(--space-3);margin-top:var(--space-3);
  border-radius:var(--radius-sm);font-size:var(--text-sm)}
.quiz-fb.ok{background:var(--color-success-light);color:#1a6e3e}
.quiz-fb.no{background:var(--color-error-light);color:var(--color-error)}
.quiz-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-sm);font-family:var(--font-display);
  font-weight:600;cursor:pointer;font-size:var(--text-sm);border:none;margin-right:var(--space-2);margin-top:var(--space-4)}
.quiz-btn.primary{background:var(--color-accent);color:#fff}
.quiz-btn.primary:hover{background:var(--color-accent-hover)}
.quiz-btn.secondary{background:var(--color-border-light);color:var(--color-text)}

/* === CHAT WINDOW === */
.chat-window{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md);
  overflow:hidden;margin:var(--space-6) 0}
.chat-msgs{padding:var(--space-5);min-height:180px;max-height:400px;overflow-y:auto}
.chat-msg{display:flex;gap:var(--space-3);margin-bottom:var(--space-3)}
.chat-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:var(--text-xs);flex-shrink:0}
.chat-bub{background:var(--color-bg);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);
  border-top-left-radius:4px;max-width:80%;font-size:var(--text-sm)}
.chat-name{font-weight:600;font-size:var(--text-xs);display:block;margin-bottom:2px}
.chat-bub p{margin:0}
.chat-ctrl{padding:var(--space-3) var(--space-5);background:var(--color-bg);border-top:1px solid var(--color-border-light);
  display:flex;gap:var(--space-2);align-items:center}
.chat-ctrl button{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--color-border);
  background:var(--color-surface);cursor:pointer;font-size:var(--text-xs);font-family:var(--font-body)}
.chat-ctrl button:hover{border-color:var(--color-accent)}
.chat-ctrl .chat-prog{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:auto}
.chat-typing{display:none;gap:var(--space-3);padding:0 var(--space-5) var(--space-3);align-items:center}
.typing-dots{display:flex;gap:4px}
.typing-dot{width:7px;height:7px;border-radius:50%;background:var(--color-text-muted);animation:bounce 1.4s infinite}
.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* === TERMS / TOOLTIPS === */
.term{border-bottom:1.5px dashed var(--color-accent-muted);cursor:pointer}
.term:hover{border-bottom-color:var(--color-accent);color:var(--color-accent)}
.term-tip{position:fixed;background:var(--color-bg-code);color:#CDD6F4;padding:var(--space-3) var(--space-4);
  border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:var(--font-body);line-height:var(--leading-normal);
  width:max(200px,min(320px,80vw));box-shadow:var(--shadow-lg);pointer-events:none;opacity:0;
  transition:opacity var(--duration-fast);z-index:10000}
.term-tip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--color-bg-code)}
.term-tip.show{opacity:1}
.term-tip.flip::after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--color-bg-code)}

/* === PAGINATION === */
.page-nav{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-10);
  margin-top:var(--space-10);border-top:1px solid var(--color-border)}
.page-nav a{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);
  font-weight:600;font-size:var(--text-sm);color:var(--color-accent);padding:var(--space-3) var(--space-5);
  border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:all var(--duration-fast)}
.page-nav a:hover{background:var(--color-accent-light);border-color:var(--color-accent);text-decoration:none}
.page-nav .spacer{flex:1}

/* === LANGUAGE SWITCHER === */
.lang-switch{display:flex;gap:2px;background:var(--color-border-light);border-radius:var(--radius-sm);padding:2px;margin-left:var(--space-4)}
.lang-btn{padding:4px 10px;border:none;background:transparent;border-radius:6px;font-family:var(--font-body);
  font-size:var(--text-xs);font-weight:600;cursor:pointer;color:var(--color-text-muted);transition:all var(--duration-fast)}
.lang-btn:hover{color:var(--color-text)}
.lang-btn.active{background:var(--color-surface);color:var(--color-accent);box-shadow:var(--shadow-sm)}

/* === RESPONSIVE === */
@media(max-width:768px){
  :root{--text-4xl:1.875rem;--text-5xl:2.25rem}
  .translation-block{grid-template-columns:1fr}
  .translation-english{border-left:none;border-top:3px solid var(--color-accent)}
  .card-grid{grid-template-columns:1fr}
  .diataxis-tabs{gap:0}
  .diataxis-tab{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}
}
@media(max-width:480px){
  .page{padding-left:var(--space-4);padding-right:var(--space-4)}
  .nav-links{display:none}
}
