/* ========================================= */
/*   DASHBOARD VIEW (Landing)                */
/* ========================================= */

.landing-area {
    overflow-y: auto !important; 
    -webkit-overflow-scrolling: touch;
    padding-bottom: 3rem; 
    
    /* REFACTOR: Use Flexbox to control visual order of cards */
    display: flex;
    flex-direction: column;
    gap: 0;
}

.landing-area .btn { white-space: nowrap; }

/* Desktop Visual Reordering */
@media (min-width: 768px) {
    /* Force Chart to be visual first */
    #chart-card { order: -1; }
    /* Install card should be high up if visible */
    .pwa-install-card { order: -2; }
}

/* Mobile View Filtering (Bottom Nav Logic) */
@media (max-width: 767px) {
    .landing-area { padding-bottom: 100px !important; }
    .tab-practice .group-resources { display: none !important; }
    .tab-resources .group-practice { display: none !important; }
    /* Hide Audio Toggle on Mobile Header */
    .header-controls .audio-toggle-btn { display: none !important; }
}

@media (min-width: 768px) {
    .group-practice, .group-resources { display: block !important; }
}

/* --- CHART --- */
.chart-header-screen { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; width: 100%; }
.chart-header-screen h3 { margin: 0; font-size: var(--fs-h3); color: var(--text-main); font-weight: 800; }
.print-only-header, .print-only-footer { display: none; }

/* Grid */
.syllabics-grid { display: grid; gap: 8px; width: 100%; }
.grid-header { display: flex; align-items: flex-end; justify-content: center; text-align: center; padding-bottom: 0.5rem; font-family: var(--font-english); font-size: var(--fs-sm); font-weight: 800; color: var(--text-muted); margin-bottom: 0.25rem; }

.grid-item {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    border-radius: 12px; padding: 0.4rem 0;
    transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
    border: 2px solid transparent; cursor: pointer; position: relative;
    height: 100%; min-height: 56px;
}
.grid-item.empty { cursor: default; pointer-events: none; border: none; min-height: 0; }
.grid-item.empty:hover { background-color: transparent; transform: none; box-shadow: none; }

.grid-item.copied { background-color: var(--c-green) !important; transform: scale(1.1) !important; z-index: 20; box-shadow: 0 4px 10px rgba(0, 122, 51, 0.4); }
.grid-item.copied .symbol, .grid-item.copied .pronounce { color: white !important; }

@media (hover: hover) {
    .grid-item:hover { background-color: var(--c-yellow); box-shadow: var(--shadow-hover); transform: translateY(-4px) scale(1.05); z-index: 10; }
}

.symbol { font-family: var(--font-syllabic); font-size: var(--fs-syl-grid); font-weight: 700; color: var(--text-main); line-height: 1.1; }
.pronounce { font-size: var(--fs-sm); color: var(--c-blue); font-weight: 800; }

@media (max-width: 600px) {
    .syllabics-grid { gap: 3px; }
    .grid-item { border-radius: 8px; min-height: 48px; padding: 0.25rem 0; }
    .grid-header { font-size: 0.75rem; }
    .symbol { font-size: 1.25rem; }
    .pronounce { font-size: 0.7rem; letter-spacing: -0.5px; }
}

/* --- GRIDS --- */
.resources-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--gap-md); }
.button-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--gap-lg); margin-bottom: 2rem; }
@media (max-width: 600px) { .button-grid { grid-template-columns: 1fr; } }

/* --- CARD FOOTERS --- */
.card-footer { display: flex; align-items: center; border-top: var(--border-width) solid var(--border-subtle); padding-top: var(--gap-lg); gap: var(--gap-md); margin-top: auto; flex-wrap: wrap; }
.toggle-btn { flex: 0 0 auto; margin-right: auto; }
.button-group-right { display: flex; gap: var(--gap-sm); align-items: center; flex-wrap: wrap; flex: 0 1 auto; justify-content: flex-end; }

@media (max-width: 850px) {
    .card-footer { flex-direction: column; align-items: stretch; gap: 1.5rem; }
    .toggle-btn { width: 100%; margin-right: 0; justify-content: space-between; }
    .button-group-right { width: 100%; margin-left: 0; flex-direction: column; align-items: stretch; gap: 1rem; }
    .button-group-right .btn { width: 100%; display: flex; flex: 1 1 auto; }
}

/* --- LEGAL FOOTER --- */
.legal-footer { margin-top: 2rem; padding-top: 1.5rem; border-top: var(--border-width) solid var(--border-subtle); display: flex; flex-direction: column; gap: 0.5rem; text-align: center; color: var(--text-muted); font-size: 0.75rem; font-weight: 700; font-family: var(--font-english); opacity: 0.8; }
.legal-footer p { margin: 0; }
.legal-footer a { color: var(--c-blue); text-decoration: none; font-weight: 800; transition: opacity 0.2s; }
.legal-footer a:hover { text-decoration: underline; opacity: 0.8; }