/* ============================================================
   Garden Paper Mart Academy — Shared Stylesheet
   Cambridge O Level Accounting (7707)
   Version 1.0 — 2026
   Primary:    Dark Teal     #004d40
   Accent:     Amber         #ff8f00
   Mid tone:   Teal          #00695c
   Light bg:   Teal tint     #f0faf8
   Dark bg:    Deep Teal     #002a22
   ============================================================ */

/* ── RESET & BASE ───────────────────────────────────────────── */
* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: Georgia, 'Times New Roman', serif;
    background: #f0faf8;
    color: #1a1a1a;
    line-height: 1.8;
}

/* ── HEADER ─────────────────────────────────────────────────── */
header {
    background: linear-gradient(135deg, #002a22 0%, #004d40 60%, #00695c 100%);
    color: white;
    padding: 24px 30px;
    border-bottom: 4px solid #ff8f00;
}
.breadcrumb { font-size: 13px; margin-bottom: 8px; }
.breadcrumb a { color: #80cbc4; text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; color: white; }
header h1 { font-size: 27px; font-weight: bold; letter-spacing: 0.5px; }
header p.subtitle { color: #80cbc4; font-size: 14px; margin-top: 6px; }

/* ── MAIN CONTAINER ─────────────────────────────────────────── */
.container { max-width: 900px; margin: 30px auto; padding: 0 20px 60px; }

/* ── SECTIONS ───────────────────────────────────────────────── */
section {
    background: white;
    border-radius: 8px;
    padding: 24px 28px;
    margin-bottom: 24px;
    box-shadow: 0 1px 5px rgba(0,77,64,0.09);
    border-top: 3px solid #004d40;
}

/* ── HEADINGS ───────────────────────────────────────────────── */
h2 {
    color: #004d40;
    font-size: 20px;
    margin-bottom: 14px;
    border-bottom: 2px solid #b2dfdb;
    padding-bottom: 8px;
}
h3 { color: #00695c; font-size: 17px; margin: 18px 0 10px; }
h4 { color: #004d40; margin-bottom: 6px; }

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
p  { margin-bottom: 12px; }
ul, ol { margin: 10px 0 12px 22px; }
li { margin-bottom: 6px; }
strong { color: #004d40; }

/* ── TABLES ─────────────────────────────────────────────────── */
table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 14px;
    font-size: 15px;
}
th {
    background: #004d40;
    color: white;
    padding: 10px 14px;
    text-align: left;
    border: 1px solid #00695c;
}
td {
    padding: 10px 14px;
    border: 1px solid #b2dfdb;
    vertical-align: top;
}
tr:nth-child(even) td { background: #e8f5e9; }

/* ── ACCOUNTING TABLE (T-ACCOUNT / LEDGER STYLE) ────────────── */
.ledger-table {
    width: 100%;
    border-collapse: collapse;
    margin: 14px 0;
    font-family: 'Courier New', monospace;
    font-size: 14px;
}
.ledger-table th {
    background: #004d40;
    color: white;
    padding: 8px 12px;
    text-align: center;
    border: 2px solid #002a22;
}
.ledger-table td {
    padding: 7px 12px;
    border: 1px solid #004d40;
    background: white;
}
.ledger-table .dr-side { background: #e8f5e9; }
.ledger-table .cr-side { background: #fff8e1; }
.ledger-table .total-row td { background: #004d40; color: white; font-weight: bold; border-top: 3px double #002a22; }
.ledger-table .balance-row td { background: #fff3e0; font-weight: bold; color: #004d40; }
.ledger-double { border-bottom: 3px double #004d40 !important; }

/* ── KEY CONCEPT BOX ────────────────────────────────────────── */
.key-concept {
    background: #e0f2f1;
    padding: 13px 17px;
    border-left: 5px solid #004d40;
    margin: 14px 0;
    border-radius: 0 6px 6px 0;
    font-size: 15px;
}
.key-concept strong { color: #004d40; }

/* ── FORMULA / RULE BOX ─────────────────────────────────────── */
.formula-box {
    background: #e0f2f1;
    border: 2px solid #00695c;
    border-radius: 8px;
    padding: 16px 22px;
    margin: 14px 0;
}
.formula-box h4 {
    color: #004d40;
    margin-bottom: 10px;
    font-size: 15px;
    border-bottom: 1px solid #b2dfdb;
    padding-bottom: 6px;
}
.formula-box .formula {
    font-size: 16px;
    font-weight: bold;
    color: #002a22;
    font-family: 'Times New Roman', Georgia, serif;
    margin: 8px 0;
    background: #b2dfdb;
    padding: 8px 14px;
    border-radius: 4px;
    display: block;
    border-left: 3px solid #004d40;
}

/* ── AMBER RULE BOX ─────────────────────────────────────────── */
.rule-box {
    background: #fff8e1;
    padding: 13px 17px;
    border-left: 5px solid #ff8f00;
    margin: 14px 0;
    border-radius: 0 6px 6px 0;
    font-size: 14px;
}
.rule-box strong { color: #e65100; }

/* ── WORKED EXAMPLE BOX ─────────────────────────────────────── */
.worked-example {
    background: #f0faf8;
    border: 1px solid #80cbc4;
    border-radius: 8px;
    padding: 16px 20px;
    margin: 16px 0;
}
.worked-example h4 {
    color: #004d40;
    font-size: 15px;
    margin-bottom: 10px;
    border-bottom: 1px solid #b2dfdb;
    padding-bottom: 6px;
}
.worked-example .step {
    display: flex;
    gap: 12px;
    margin-bottom: 10px;
    font-size: 14px;
    align-items: flex-start;
}
.step-num {
    background: #004d40;
    color: white;
    border-radius: 50%;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: bold;
    flex-shrink: 0;
    margin-top: 2px;
}
.step-content { flex: 1; line-height: 1.7; }
.step-content .acc {
    font-family: 'Courier New', monospace;
    background: #e0f2f1;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 13px;
    display: inline-block;
    margin: 2px 0;
    color: #002a22;
}

/* ── TIP BOX ────────────────────────────────────────────────── */
.tip-box {
    background: #fff8e1;
    padding: 13px 17px;
    border-left: 5px solid #ff8f00;
    margin: 14px 0;
    border-radius: 0 6px 6px 0;
    font-size: 14px;
}
.tip-box strong { color: #e65100; }

/* ── WARN BOX ───────────────────────────────────────────────── */
.warn-box {
    background: #fce4ec;
    padding: 13px 17px;
    border-left: 5px solid #c62828;
    margin: 14px 0;
    border-radius: 0 6px 6px 0;
    font-size: 14px;
}
.warn-box strong { color: #b71c1c; }

/* ── MEMORY BOX ─────────────────────────────────────────────── */
.memory-box {
    background: #fff3e0;
    border: 1px solid #ffcc02;
    border-radius: 8px;
    padding: 14px 18px;
    margin: 14px 0;
    font-size: 14px;
}
.memory-box h4 { color: #e65100; margin-bottom: 8px; font-size: 14px; }

/* ── ACCOUNTING EQUATION HIGHLIGHT ─────────────────────────── */
.equation-box {
    background: #004d40;
    color: white;
    border-radius: 8px;
    padding: 18px 24px;
    text-align: center;
    margin: 16px 0;
    font-size: 20px;
    font-weight: bold;
    font-family: 'Times New Roman', serif;
    letter-spacing: 1px;
}
.equation-box span { color: #ff8f00; }

/* ── CARD AMBER ─────────────────────────────────────────────── */
.card-amber {
    background: #fff8e1;
    border: 1px solid #ffcc02;
    border-radius: 6px;
    padding: 14px 16px;
}
.card-amber h4 { color: #e65100; margin-bottom: 6px; }

/* ── PREREQ BANNER ──────────────────────────────────────────── */
.prereq-banner {
    background: #fff8e1;
    border: 1px solid #ffcc02;
    border-radius: 8px;
    padding: 14px 18px;
    margin-bottom: 20px;
    font-size: 14px;
    color: #5d4037;
}
.prereq-banner strong { color: #e65100; }

/* ── GRID LAYOUTS ───────────────────────────────────────────── */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 14px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; margin-top: 14px; }

/* ── CARDS ──────────────────────────────────────────────────── */
.card {
    background: #e0f2f1;
    border: 1px solid #80cbc4;
    border-radius: 6px;
    padding: 14px 16px;
}
.card h4 { color: #004d40; margin-bottom: 6px; font-size: 15px; }

/* ── DIAGRAM BOX ────────────────────────────────────────────── */
.diagram-box {
    background: #f0faf8;
    border: 2px dashed #80cbc4;
    border-radius: 8px;
    padding: 18px;
    text-align: center;
    margin: 14px 0;
}

/* ── PROGRESS BAR ───────────────────────────────────────────── */
.lesson-progress {
    background: white;
    border-radius: 8px;
    padding: 14px 20px;
    margin-bottom: 20px;
    box-shadow: 0 1px 5px rgba(0,77,64,0.08);
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    font-size: 13px;
    color: #555;
}
.progress-bar-wrap {
    flex: 1;
    background: #b2dfdb;
    border-radius: 20px;
    height: 8px;
    min-width: 120px;
}
.progress-bar-fill {
    background: linear-gradient(90deg, #004d40, #ff8f00);
    height: 8px;
    border-radius: 20px;
}

/* ── SYLLABUS REF BADGE ─────────────────────────────────────── */
.syllabus-ref {
    display: inline-block;
    background: #004d40;
    color: white;
    font-size: 11px;
    padding: 2px 10px;
    border-radius: 20px;
    margin-left: 8px;
    vertical-align: middle;
    font-weight: bold;
}
.syllabus-ref-amber {
    display: inline-block;
    background: #ff8f00;
    color: #002a22;
    font-size: 11px;
    padding: 2px 10px;
    border-radius: 20px;
    margin-left: 8px;
    vertical-align: middle;
    font-weight: bold;
}

/* ── EXAM PRACTICE SECTION ──────────────────────────────────── */
.quiz-section {
    background: #e0f2f1;
    padding: 24px 28px;
    border-radius: 8px;
    margin-bottom: 24px;
    border-top: 3px solid #ff8f00;
}
.quiz-section h3 { color: #004d40; margin-bottom: 14px; }

.q-block {
    background: white;
    border-radius: 6px;
    padding: 16px 20px;
    margin-bottom: 16px;
    border: 1px solid #80cbc4;
}
.q-block p { margin-bottom: 6px; }

.answer {
    background: #fff8e1;
    border-radius: 4px;
    padding: 10px 14px;
    margin-top: 10px;
    border-left: 3px solid #ff8f00;
    font-size: 14px;
}
.answer .math-ans {
    font-family: 'Courier New', monospace;
    background: #b2dfdb;
    padding: 2px 8px;
    border-radius: 4px;
    font-weight: bold;
    color: #002a22;
    font-size: 14px;
}

.exam-tip {
    background: #fff3e0;
    border-radius: 4px;
    padding: 10px 14px;
    margin-top: 8px;
    border-left: 3px solid #ff8f00;
    font-size: 13px;
}

/* ── NAVIGATION BUTTONS ─────────────────────────────────────── */
.lesson-nav {
    text-align: center;
    margin-top: 10px;
    display: flex;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
}
.btn {
    display: inline-block;
    background: #004d40;
    color: white;
    padding: 12px 28px;
    border-radius: 6px;
    text-decoration: none;
    font-size: 15px;
    transition: background 0.15s;
}
.btn:hover { background: #002a22; }

.btn-amber {
    display: inline-block;
    background: #ff8f00;
    color: #002a22;
    padding: 12px 28px;
    border-radius: 6px;
    text-decoration: none;
    font-size: 15px;
    font-weight: bold;
    transition: background 0.15s;
}
.btn-amber:hover { background: #e65100; color: white; }

.btn-outline {
    display: inline-block;
    background: white;
    color: #004d40;
    border: 2px solid #004d40;
    padding: 11px 28px;
    border-radius: 6px;
    text-decoration: none;
    font-size: 15px;
    transition: background 0.15s;
}
.btn-outline:hover { background: #e0f2f1; }

/* ── FOOTER ─────────────────────────────────────────────────── */
footer {
    text-align: center;
    padding: 20px;
    color: #666;
    font-size: 13px;
    border-top: 1px solid #b2dfdb;
    background: white;
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width: 600px) {
    .grid-2, .grid-3 { grid-template-columns: 1fr; }
    header h1 { font-size: 20px; }
    .container { padding: 0 12px 40px; }
    .ledger-table { font-size: 12px; }
}