/* ============================================================
   CompTIA A+ Cyber Study Guide — Online Companion
   ArcLight Press · erictomchik.com
   ============================================================ */

/* --- Reset & Base ------------------------------------------ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:        #0a0e17;
  --bg-card:   #111827;
  --bg-card2:  #1a2234;
  --border:    #1e293b;
  --accent:    #06b6d4;  /* cyan-500 */
  --accent2:   #0891b2;  /* cyan-600 */
  --accent-glow: rgba(6,182,212,.15);
  --green:     #10b981;
  --red:       #ef4444;
  --orange:    #f59e0b;
  --text:      #e2e8f0;
  --text-muted:#94a3b8;
  --text-dim:  #64748b;
  --font:      'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mono:      'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;
  --radius:    12px;
  --max-w:     1200px;
}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:#22d3ee}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--bg)}

/* --- Typography -------------------------------------------- */
h1,h2,h3,h4{font-weight:700;line-height:1.25;color:#f1f5f9}
h1{font-size:2.5rem;letter-spacing:-.02em}
h2{font-size:1.75rem;margin-bottom:1rem}
h3{font-size:1.25rem;margin-bottom:.75rem}
p{margin-bottom:1rem}

/* --- Layout ------------------------------------------------ */
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}

@media(max-width:900px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  h1{font-size:1.75rem}
}

/* --- Navigation -------------------------------------------- */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(10,14,23,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:.75rem 0;
}
.nav .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.nav-brand{
  font-weight:800;font-size:1.15rem;
  color:#f1f5f9;
  display:flex;align-items:center;gap:.5rem;
}
.nav-brand .icon{color:var(--accent);font-size:1.3rem}
.nav-links{display:flex;gap:.15rem;flex-wrap:wrap}
.nav-links a{
  padding:.45rem .85rem;
  border-radius:8px;
  font-size:.85rem;
  font-weight:500;
  color:var(--text-muted);
  transition:all .2s;
}
.nav-links a:hover,.nav-links a.active{
  background:var(--accent-glow);
  color:var(--accent);
}

/* Mobile nav toggle */
.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer}
@media(max-width:768px){
  .nav-toggle{display:block}
  .nav-links{
    display:none;flex-direction:column;width:100%;
    padding-top:.5rem;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:.6rem .85rem}
}

/* --- Hero -------------------------------------------------- */
.hero{
  padding:5rem 0 4rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 50% 0%, rgba(6,182,212,.12) 0%, transparent 70%),
    radial-gradient(ellipse 400px 300px at 80% 100%, rgba(16,185,129,.08) 0%, transparent 70%);
  pointer-events:none;
}
.hero h1{margin-bottom:.75rem;position:relative}
.hero .subtitle{font-size:1.2rem;color:var(--text-muted);max-width:640px;margin:0 auto 2rem;position:relative}
.hero .badge{
  display:inline-block;
  background:var(--accent-glow);
  border:1px solid var(--accent);
  color:var(--accent);
  padding:.35rem 1rem;
  border-radius:20px;
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  margin-bottom:1.5rem;
  position:relative;
}
.hero .cta-group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}

/* --- Buttons ----------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.7rem 1.5rem;
  border-radius:8px;
  font-size:.9rem;font-weight:600;
  cursor:pointer;border:none;
  transition:all .2s;
}
.btn-primary{background:var(--accent);color:var(--bg)}
.btn-primary:hover{background:#22d3ee;color:var(--bg);transform:translateY(-1px);box-shadow:0 4px 20px rgba(6,182,212,.3)}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}

/* --- Cards ------------------------------------------------- */
.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.5rem;
  transition:all .25s;
}
.card:hover{
  border-color:var(--accent);
  box-shadow:0 0 30px rgba(6,182,212,.08);
  transform:translateY(-2px);
}
.card-icon{
  width:48px;height:48px;
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;
  margin-bottom:1rem;
  background:var(--accent-glow);
  color:var(--accent);
}
.card h3{margin-bottom:.5rem}
.card p{color:var(--text-muted);font-size:.9rem;margin-bottom:0}

/* Chapter cards */
.chapter-card{position:relative;overflow:hidden}
.chapter-card .ch-num{
  font-size:.75rem;font-weight:700;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:.35rem;
}
.chapter-card .ch-domain{
  font-size:.75rem;
  color:var(--text-dim);
  margin-top:.5rem;
  padding-top:.5rem;
  border-top:1px solid var(--border);
}

/* --- Section Styling --------------------------------------- */
.section{padding:4rem 0}
.section-header{text-align:center;margin-bottom:3rem}
.section-header p{color:var(--text-muted);max-width:600px;margin:0 auto}
.section-alt{background:var(--bg-card)}

/* --- Reference Tables -------------------------------------- */
.ref-table{width:100%;border-collapse:collapse;font-size:.88rem}
.ref-table th{
  text-align:left;padding:.7rem 1rem;
  background:var(--bg-card2);
  color:var(--accent);
  font-weight:600;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  border-bottom:2px solid var(--accent);
}
.ref-table td{
  padding:.6rem 1rem;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}
.ref-table tr:hover td{background:rgba(6,182,212,.04)}
.ref-table code{
  background:var(--bg-card2);
  padding:.15rem .4rem;
  border-radius:4px;
  font-family:var(--mono);
  font-size:.82rem;
  color:var(--green);
}
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}

/* --- Glossary ---------------------------------------------- */
.glossary-search{
  width:100%;max-width:500px;
  padding:.75rem 1rem .75rem 2.75rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:8px;
  color:var(--text);
  font-size:1rem;
  outline:none;
  transition:border-color .2s;
}
.glossary-search:focus{border-color:var(--accent)}
.glossary-search-wrap{position:relative;margin-bottom:2rem;text-align:center}
.glossary-search-wrap .search-icon{
  position:absolute;left:calc(50% - 250px + .85rem);top:50%;
  transform:translateY(-50%);
  color:var(--text-dim);font-size:1.1rem;
}
@media(max-width:600px){
  .glossary-search{max-width:100%}
  .glossary-search-wrap .search-icon{left:.85rem}
}
.glossary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem}
.glossary-item{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.25rem;
}
.glossary-term{
  font-weight:700;font-size:1rem;
  color:var(--accent);
  margin-bottom:.35rem;
}
.glossary-def{font-size:.88rem;color:var(--text-muted);line-height:1.6;margin:0}
.glossary-count{
  text-align:center;
  color:var(--text-dim);
  font-size:.85rem;
  margin-bottom:1.5rem;
}

/* --- Flashcards -------------------------------------------- */
.flashcard-container{
  perspective:1000px;
  max-width:560px;
  margin:0 auto;
}
.flashcard{
  width:100%;min-height:280px;
  position:relative;
  cursor:pointer;
  transform-style:preserve-3d;
  transition:transform .5s ease;
}
.flashcard.flipped{transform:rotateY(180deg)}
.flashcard-face{
  position:absolute;inset:0;
  backface-visibility:hidden;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:2rem;
  border-radius:var(--radius);
  text-align:center;
}
.flashcard-front{
  background:linear-gradient(135deg,var(--bg-card),var(--bg-card2));
  border:2px solid var(--accent);
}
.flashcard-back{
  background:linear-gradient(135deg,#0c2a35,var(--bg-card));
  border:2px solid var(--green);
  transform:rotateY(180deg);
}
.flashcard-front h2{color:var(--accent);font-size:1.5rem}
.flashcard-back p{color:var(--text);font-size:1.05rem;line-height:1.6}
.flashcard-controls{
  display:flex;gap:1rem;justify-content:center;
  margin-top:1.5rem;align-items:center;
}
.flashcard-counter{color:var(--text-muted);font-size:.9rem;min-width:80px;text-align:center}
.flashcard-hint{color:var(--text-dim);font-size:.8rem;margin-top:1rem}

/* --- Quiz -------------------------------------------------- */
.quiz-question{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.5rem;
  margin-bottom:1.5rem;
}
.quiz-question h3{margin-bottom:1rem;font-size:1rem}
.quiz-q-num{color:var(--accent);font-weight:700}
.quiz-options label{
  display:block;
  padding:.65rem 1rem;
  margin-bottom:.5rem;
  border-radius:8px;
  border:1px solid var(--border);
  cursor:pointer;
  transition:all .2s;
  font-size:.9rem;
}
.quiz-options label:hover{border-color:var(--accent);background:var(--accent-glow)}
.quiz-options input{margin-right:.6rem}
.quiz-options label.correct{border-color:var(--green);background:rgba(16,185,129,.1)}
.quiz-options label.incorrect{border-color:var(--red);background:rgba(239,68,68,.08)}
.quiz-explanation{
  margin-top:.75rem;padding:.75rem 1rem;
  background:var(--bg-card2);
  border-radius:8px;
  font-size:.85rem;
  color:var(--text-muted);
  display:none;
}
.quiz-explanation.show{display:block}
.quiz-score{
  text-align:center;padding:2rem;
  background:var(--bg-card);
  border:2px solid var(--accent);
  border-radius:var(--radius);
}
.quiz-score .score-num{font-size:3rem;font-weight:800;color:var(--accent)}
.quiz-progress{
  height:4px;background:var(--border);
  border-radius:2px;margin-bottom:2rem;overflow:hidden;
}
.quiz-progress-bar{height:100%;background:var(--accent);transition:width .3s;border-radius:2px}

/* --- Lab Cards --------------------------------------------- */
.lab-card{position:relative;padding-left:4rem}
.lab-card .lab-num{
  position:absolute;left:0;top:0;
  width:3rem;height:3rem;
  border-radius:10px;
  background:var(--accent-glow);
  border:1px solid var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:var(--accent);
  font-size:1.1rem;
}
.lab-card .lab-chapter{font-size:.75rem;color:var(--text-dim);margin-bottom:.25rem}
.lab-card .lab-skills{
  display:flex;flex-wrap:wrap;gap:.35rem;
  margin-top:.75rem;
}
.lab-card .lab-skills span{
  font-size:.72rem;
  padding:.2rem .55rem;
  border-radius:4px;
  background:var(--bg-card2);
  color:var(--text-dim);
  border:1px solid var(--border);
}

/* --- Domain Progress --------------------------------------- */
.domain-bar{margin-bottom:1.25rem}
.domain-bar .domain-label{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:.35rem}
.domain-bar .domain-name{font-weight:600}
.domain-bar .domain-chapter{color:var(--text-dim)}
.domain-bar .bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.domain-bar .bar-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--green))}

/* --- Tags / Badges ----------------------------------------- */
.tag{
  display:inline-block;
  padding:.2rem .6rem;
  border-radius:4px;
  font-size:.75rem;
  font-weight:600;
}
.tag-cyan{background:rgba(6,182,212,.15);color:var(--accent)}
.tag-green{background:rgba(16,185,129,.15);color:var(--green)}
.tag-orange{background:rgba(245,158,11,.15);color:var(--orange)}

/* --- Footer ------------------------------------------------ */
.footer{
  padding:3rem 0;
  border-top:1px solid var(--border);
  text-align:center;
  color:var(--text-dim);
  font-size:.85rem;
}
.footer a{color:var(--text-muted)}
.footer .footer-brand{font-weight:700;color:var(--text-muted);margin-bottom:.5rem;display:block}

/* --- Utilities --------------------------------------------- */
.text-center{text-align:center}
.text-muted{color:var(--text-muted)}
.mt-1{margin-top:1rem}
.mt-2{margin-top:2rem}
.mb-2{margin-bottom:2rem}
.hidden{display:none}

/* --- Scroll animations ------------------------------------- */
.fade-in{opacity:0;transform:translateY(20px);transition:all .5s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* --- Print ------------------------------------------------- */
@media print{
  .nav,.footer,.btn,.flashcard-controls,.quiz-options input{display:none}
  body{background:#fff;color:#000}
  .card,.glossary-item,.quiz-question{border:1px solid #ccc;break-inside:avoid}
}

/* --- Clickable chapter cards -------------------------------- */
.card-link{text-decoration:none;color:inherit;display:block;transition:transform .2s}
.card-link:hover{transform:translateY(-3px);color:inherit}
.card-link:hover .card{border-color:var(--accent);box-shadow:0 8px 25px rgba(6,182,212,.15)}
.card-link .card{cursor:pointer}
.chapter-link{color:inherit !important;text-decoration:none}
.chapter-link:hover{color:var(--accent) !important}

/* --- Glossary alpha filter ---------------------------------- */
.glossary-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}
.glossary-alpha-filter{display:flex;flex-wrap:wrap;gap:.35rem}
.alpha-btn{
  background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);
  padding:.3rem .55rem;border-radius:6px;cursor:pointer;font-size:.8rem;
  font-family:var(--font);font-weight:600;transition:all .2s;
}
.alpha-btn:hover,.alpha-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}

/* --- Interactive terminal ----------------------------------- */
.terminal-wrap{
  background:#0d1117;border:1px solid #30363d;border-radius:10px;
  overflow:hidden;margin:1.5rem 0;box-shadow:0 4px 20px rgba(0,0,0,.4);
}
.terminal-titlebar{
  background:#161b22;padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;
  border-bottom:1px solid #30363d;
}
.terminal-dot{width:12px;height:12px;border-radius:50%;display:inline-block}
.terminal-dot.red{background:#ff5f57}
.terminal-dot.yellow{background:#febc2e}
.terminal-dot.green{background:#28c840}
.terminal-title{color:#8b949e;font-size:.8rem;margin-left:.5rem;font-family:var(--mono)}
.terminal-body{
  padding:1rem 1.25rem;font-family:var(--mono);font-size:.85rem;
  line-height:1.6;max-height:400px;overflow-y:auto;color:#c9d1d9;
}
.terminal-body .output{color:#8b949e;white-space:pre-wrap}
.terminal-body .success{color:#3fb950}
.terminal-body .error{color:#f85149}
.terminal-body .info{color:#58a6ff}
.terminal-body .warning{color:#d29922}
.terminal-input-line{display:flex;align-items:center;margin-top:.25rem}
.terminal-prompt{color:#3fb950;margin-right:.5rem;white-space:nowrap;user-select:none}
.terminal-input{
  background:none;border:none;color:#c9d1d9;font-family:var(--mono);
  font-size:.85rem;flex:1;outline:none;caret-color:var(--accent);
}
.terminal-hint{
  padding:.75rem 1.25rem;background:#161b22;border-top:1px solid #30363d;
  font-size:.8rem;color:#8b949e;display:flex;align-items:center;gap:.5rem;
}
.terminal-hint .hint-icon{font-size:1rem}
.terminal-task{
  background:var(--bg-card2);border:1px solid var(--border);border-radius:8px;
  padding:1rem 1.25rem;margin:.75rem 0;font-size:.9rem;
}
.terminal-task .task-num{
  display:inline-block;background:var(--accent);color:var(--bg);
  width:22px;height:22px;line-height:22px;text-align:center;border-radius:50%;
  font-size:.75rem;font-weight:700;margin-right:.5rem;
}
.terminal-task.completed{border-color:var(--green);background:rgba(16,185,129,.05)}
.terminal-task.completed .task-num{background:var(--green)}
.lab-progress{
  display:flex;align-items:center;gap:.75rem;margin:1rem 0;
}
.lab-progress-bar{
  flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;
}
.lab-progress-fill{
  height:100%;background:linear-gradient(90deg,var(--accent),var(--green));
  border-radius:3px;transition:width .4s;
}
.lab-progress-text{font-size:.8rem;color:var(--text-muted);white-space:nowrap}

/* --- Chapter Grid Layout ----------------------------------- */
.chapter-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-bottom:2.5rem}
.part-label{color:var(--accent);margin-bottom:.15rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700}
.part-title{margin-bottom:1.25rem;font-size:1.35rem;font-weight:700}
.chapter-card h3{font-size:.95rem;line-height:1.35;margin-bottom:.5rem}
.chapter-card p{font-size:.82rem;line-height:1.5;color:var(--text-muted);margin-bottom:.75rem}
@media(max-width:700px){
  .chapter-grid{grid-template-columns:1fr}
}
