/* style.css */

/* --- Theme Definitions using CSS Variables --- */
:root, html[data-theme='mono'] {
    --bg-color: #121212;
    --card-bg-color: #1e1e1e;
    --text-color: #e0e0e0;
    --heading-color: #ffffff;
    --link-color: #f0f0f0;
    --link-hover-bg: rgba(170, 187, 255, 0.1);
    --link-text-hover-color: #ffffff;
    --accent-color: #f0f0f0;
    --border-color: #444444;
    --card-shadow: 0 1px 3px rgba(0,0,0,0.6);
    --header-font: 'Inter', sans-serif;
    --body-font: 'Inter', sans-serif;
    --button-bg: var(--card-bg-color);
    --button-text: var(--text-color);
    --button-hover-bg: var(--bg-color);
    --button-hover-text: var(--accent-color);
    --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color);
    --button-active-text: var(--bg-color);
    --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color);
    --footer-height: 80px;
    --link-item-font-size-base: 0.875rem;
    --font-scale-multiplier: 1.0;
    --column-width-base: 180px;
}
html[data-theme='forest'] {
    --bg-color: #0a191e; --card-bg-color: #112a30; --text-color: #d8e2e6; --heading-color: #00c9a7;
    --link-color: #00c9a7;
    --link-hover-bg: rgba(0, 201, 167, 0.15);
    --link-text-hover-color: #ffffff;
    --accent-color: #00c9a7;
    --border-color: #00c9a7; --card-shadow: 0 0 12px rgba(0, 0, 0, 0.4), 0 0 8px rgba(0, 201, 167, 0.3);
    --header-font: 'Teko', sans-serif; --body-font: 'Poppins', sans-serif;
    --button-bg: var(--card-bg-color); --button-text: var(--text-color);
    --button-hover-bg: var(--bg-color); --button-hover-text: var(--accent-color); --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color); --button-active-text: var(--bg-color); --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color);
    --link-item-font-size-base: 0.875rem;
}
html[data-theme='purple'] {
    --bg-color: #1a0a2d; --card-bg-color: #2c1a3d; --text-color: #e8e8e8; --heading-color: #ff00ff;
    --link-color: #ff00ff;
    --link-hover-bg: rgba(255, 0, 255, 0.15);
    --link-text-hover-color: #ffffff;
    --accent-color: #ff00ff;
    --border-color: #ff00ff; --card-shadow: 0 0 12px rgba(0, 0, 0, 0.4), 0 0 8px rgba(255, 0, 255, 0.3);
    --header-font: 'Teko', sans-serif; --body-font: 'Poppins', sans-serif;
    --button-bg: var(--card-bg-color); --button-text: var(--text-color);
    --button-hover-bg: var(--bg-color); --button-hover-text: var(--accent-color); --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color); --button-active-text: var(--bg-color); --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color);
    --link-item-font-size-base: 0.875rem;
}
html[data-theme='retro'] {
    --bg-color: #000000; --card-bg-color: #000000; --text-color: #CC8F00; --heading-color: #008000;
    --link-color: #CC8F00;
    --link-hover-bg: #111;
    --link-text-hover-color: darkgray;
    --accent-color: #FFA500;
    --border-color: #FFA500; --card-shadow: none;
    --header-font: 'VT323', monospace; --body-font: 'VT323', monospace;
    --button-bg: var(--card-bg-color); --button-text: var(--text-color);
    --button-hover-bg: #111; --button-hover-text: darkgray; --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color); --button-active-text: #000000; --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color);
    --link-item-font-size-base: 1rem;
}
html[data-theme='sunset'] {
    --bg-color: #0f0c29; --card-bg-color: #24243e; --text-color: #e8e8e8; --heading-color: #ff8c00;
    --link-color: #ff8c00;
    --link-hover-bg: rgba(255, 140, 0, 0.15);
    --link-text-hover-color: #ffffff;
    --accent-color: #ff8c00; --accent-secondary: #e94560;
    --border-color: var(--accent-secondary); --card-shadow: 0 0 15px rgba(0, 0, 0, 0.5), 0 0 10px rgba(233, 69, 96, 0.4);
    --header-font: 'Teko', sans-serif; --body-font: 'Poppins', sans-serif;
    --button-bg: var(--card-bg-color); --button-text: var(--text-color);
    --button-hover-bg: var(--bg-color); --button-hover-text: var(--accent-color); --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color); --button-active-text: var(--bg-color); --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-secondary);
    --link-item-font-size-base: 0.875rem;
}
html[data-theme='pro'] {
    --bg-color: #1f2937; --card-bg-color: #374151; --text-color: #d1d5db; --heading-color: #f3f4f6;
    --link-color: #fbbf24;
    --link-hover-bg: rgba(75, 85, 99, 0.6);
    --link-text-hover-color: #ffffff;
    --accent-color: #fbbf24;
    --border-color: #4b5563; --card-shadow: 0 2px 5px rgba(0,0,0,0.3);
    --header-font: 'Lato', sans-serif; --body-font: 'Lato', sans-serif;
    --button-bg: var(--card-bg-color); --button-text: var(--text-color);
    --button-hover-bg: var(--bg-color); --button-hover-text: var(--accent-color); --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color); --button-active-text: var(--bg-color); --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color);
    --link-item-font-size-base: 0.875rem;
}
html[data-theme='carbon'] {
    --bg-color: #111111; --card-bg-color: #222222; --text-color: #cccccc; --heading-color: #ffffff;
    --link-color: #eeeeee;
    --link-hover-bg: rgba(187, 187, 187, 0.1);
    --link-text-hover-color: #ffffff;
    --accent-color: #bbbbbb;
    --border-color: #555555; --card-shadow: inset 0 0 4px rgba(0,0,0,0.5), 0 1px 1px rgba(0,0,0,0.4);
    --header-font: 'Lato', sans-serif; --body-font: 'Lato', sans-serif;
    --button-bg: var(--card-bg-color); --button-text: var(--text-color);
    --button-hover-bg: var(--bg-color); --button-hover-text: var(--accent-color); --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color); --button-active-text: var(--bg-color); --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color);
    --link-item-font-size-base: 0.875rem;
}
html[data-theme='glow'] {
    --bg-color: #0d1117; --card-bg-color: #161b22; --text-color: #c9d1d9; --heading-color: #58a6ff;
    --link-color: #58a6ff;
    --link-hover-bg: rgba(88, 166, 255, 0.15);
    --link-text-hover-color: #ffffff;
    --accent-color: #58a6ff; --accent-secondary: #1f6feb;
    --border-color: var(--accent-secondary); --card-shadow: 0 0 10px rgba(0,0,0,0.5), 0 0 6px rgba(88, 166, 255, 0.3);
    --header-font: 'Poppins', sans-serif; --body-font: 'Poppins', sans-serif;
    --button-bg: var(--card-bg-color); --button-text: var(--text-color);
    --button-hover-bg: var(--bg-color); --button-hover-text: var(--accent-color); --button-hover-border: var(--accent-color);
    --button-active-bg: var(--accent-color); --button-active-text: var(--bg-color); --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color);
    --link-item-font-size-base: 0.875rem;
}

/* ADDED: Kawaii Delight Theme */
html[data-theme='kawaii-delight'] {
    --bg-color: #fff5fa; /* Very pale pink (Lavender Blush variation) */
    --card-bg-color: #ffffff; /* White cards for clean contrast */
    --text-color: #5c5c5c; /* Soft dark grey text */
    --heading-color: #ff69b4; /* Hot Pink headings */
    --link-color: #48d1cc; /* Medium Turquoise links */
    --link-hover-bg: rgba(72, 209, 204, 0.15); /* Light turquoise background on hover */
    --link-text-hover-color: #008080; /* Darker Teal text on hover */
    --accent-color: #c77dff; /* Soft Purple accent (for buttons, indicators) */
    --border-color: #ffc8dd; /* A slightly darker pastel pink for borders */
    /* Soft pink shadow */
    --card-shadow: 0 4px 12px rgba(255, 105, 180, 0.15), 0 1px 3px rgba(0, 0, 0, 0.05);
    /* Use a soft, rounded font */
    --header-font: 'Nunito', sans-serif;
    --body-font: 'Nunito', sans-serif;
    --button-bg: var(--card-bg-color);
    --button-text: #ff69b4; /* Pink button text */
    --button-hover-bg: var(--bg-color); /* Pale pink bg on hover */
    --button-hover-text: var(--accent-color); /* Purple text on hover */
    --button-hover-border: var(--accent-color); /* Purple border on hover */
    --button-active-bg: var(--accent-color); /* Purple bg when active */
    --button-active-text: #ffffff; /* White text when active */
    --button-active-border: var(--accent-color);
    --indicator-color: var(--accent-color); /* Purple indicator (+/-) */
    --footer-height: 80px;
    --link-item-font-size-base: 0.875rem;
    --font-scale-multiplier: 1.0; /* Inherited, but specified for clarity */
    --column-width-base: 180px; /* Inherited, but specified for clarity */
}


/* --- Base Styles using Variables --- */
body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: var(--bg-color);
    color: var(--text-color);
    font-family: var(--body-font);
    font-size: calc(1rem * var(--font-scale-multiplier));
    transition: background-color 0.3s ease, color 0.3s ease, font-size 0.2s ease-out;
    margin: 0;
    padding-bottom: var(--footer-height);
    box-sizing: border-box;
}
header {
    background-color: var(--card-bg-color);
    box-shadow: var(--card-shadow);
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    margin-bottom: 2rem;
    text-align: center;
}
header h1 {
    color: var(--heading-color);
    font-family: var(--header-font);
    transition: color 0.3s ease, font-size 0.2s ease-out;
    font-size: calc(1.5rem * var(--font-scale-multiplier));
    line-height: 1.2;
    font-weight: 700;
    margin: 0;
}
@media (min-width: 640px) {
    header h1 {
        font-size: calc(1.875rem * var(--font-scale-multiplier));
        line-height: 1.2;
    }
}

/* Custom Container Class */
.container {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
    box-sizing: border-box;
}
@media (min-width: 640px) { .container { max-width: 640px; } }
@media (min-width: 768px) { .container { max-width: 768px; } }
@media (min-width: 1024px) { .container { max-width: 1024px; } }
@media (min-width: 1280px) { .container { max-width: 1280px; } }
@media (min-width: 1536px) { .container { max-width: 1536px; } }
@media (min-width: 1800px) { .container { max-width: 1800px; } }


main {
    flex-grow: 1;
    padding-bottom: 2.5rem;
}

/* --- Category Grid (Multi-column) --- */
#categoryGrid {
    column-width: calc(var(--column-width-base) * var(--font-scale-multiplier));
    column-gap: 1rem;
    width: 100%;
    transition: column-width 0.2s ease-out;
}

/* --- Category Card Styling --- */
.category-card {
    background-color: var(--card-bg-color);
    border: 1px solid var(--border-color);
    box-shadow: var(--card-shadow);
    transition: transform 0.2s ease-in-out, box-shadow 0.3s ease, background-color 0.3s ease-in-out, border-color 0.3s ease, padding 0.3s ease-in-out;
    padding: 1rem;
    border-radius: 0.5rem;
    display: flex;
    flex-direction: column;
    width: 100%;
    margin-bottom: 1rem;
    break-inside: avoid;
    box-sizing: border-box;
    cursor: grab;
}
.category-card:hover {
    transform: translateY(-4px);
}
.category-card h2 {
    color: var(--heading-color);
    border-bottom: 1px solid var(--border-color);
    font-family: var(--header-font);
    transition: color 0.3s ease, border-color 0.3s ease, font-size 0.2s ease-out, padding 0.3s ease-in-out, margin-bottom 0.3s ease-in-out;
    font-size: calc(1.15rem * var(--font-scale-multiplier));
    line-height: 1.2;
    font-weight: 600;
    margin: 0 0 0.75rem 0;
    padding: 0.3rem 20px 0.3rem 5px; /* Symmetrical padding */
    text-align: center;
    position: relative;
    cursor: pointer;
}

/* Collapse/Expand Indicator (+/-) - User Preference */
.category-card h2::after {
    content: '−';
    position: absolute;
    right: 0px;
    top: -0.05em; /* Fine-tuned value */
    font-size: calc(1.2em * var(--font-scale-multiplier));
    font-weight: normal; /* User preference */
    color: var(--indicator-color);
    transition: font-size 0.2s ease-out;
    padding: 0 4px;
    line-height: 1;
    pointer-events: none;
}
.category-card.collapsed h2::after {
    content: '+';
}

/* Styles for the list when card is NOT collapsed */
.category-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
    line-height: calc(1.2rem * var(--font-scale-multiplier));
    padding-top: 0.25rem;
    padding-left: 0.25rem;
    padding-right: 0.25rem;
    padding-bottom: 0.25rem;
    overflow: hidden;
    max-height: 1000px;
    opacity: 1;
    visibility: visible;
    transition: max-height 0.3s ease-out, opacity 0.3s ease-out, visibility 0s linear 0s, padding 0.3s ease-out, margin 0.3s ease-out, line-height 0.2s ease-out;
}

/* Styles for the list when card IS collapsed */
.category-card.collapsed ul {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
    margin-top: 0;
    margin-bottom: 0;
    visibility: hidden;
    transition: max-height 0.3s ease-in, opacity 0.2s ease-in, visibility 0s linear 0.3s, padding 0.3s ease-in, margin 0.3s ease-in;
}

/* --- Styles for Collapsed Card Appearance --- */
.category-card.collapsed {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
    background-color: color-mix(in srgb, var(--card-bg-color) 80%, white 20%);
}

.category-card.collapsed h2 {
    font-size: calc(1rem * var(--font-scale-multiplier));
    margin-bottom: 0;
    padding-top: 0.3rem; /* Match h2 padding */
    padding-bottom: 0.3rem; /* Match h2 padding */
    border-bottom-color: transparent;
}

/* ADDED: Specific collapsed background for Kawaii theme */
html[data-theme='kawaii-delight'] .category-card.collapsed {
     background-color: color-mix(in srgb, var(--card-bg-color) 95%, var(--bg-color) 5%);
}


.category-card ul li + li {
    margin-top: calc(0.125rem * var(--font-scale-multiplier));
}
.category-card ul li a {
    color: var(--link-color);
    padding: 2px 6px;
    border-radius: 3px;
    font-size: calc(var(--link-item-font-size-base) * var(--font-scale-multiplier));
    transition: color 0.2s ease, background-color 0.2s ease, font-size 0.2s ease-out;
    text-decoration: none;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.category-card ul li a:hover {
    background-color: var(--link-hover-bg);
    color: var(--link-text-hover-color);
    text-decoration: none;
}


/* --- Theme Button Styling --- */
#theme-picker span,
#fontsize-controls span {
     color: var(--text-color);
     transition: color 0.3s ease, font-size 0.2s ease-out;
     margin-right: 0.5rem;
     font-weight: 600;
     font-size: calc(0.875rem * var(--font-scale-multiplier));
     line-height: 1.25rem;
     vertical-align: middle;
}

.theme-button {
    background-color: var(--button-bg);
    color: var(--button-text);
    border: 1px solid var(--border-color);
    font-family: var(--body-font);
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, font-size 0.2s ease-out;
    cursor: pointer;
    font-size: calc(0.75rem * var(--font-scale-multiplier));
    line-height: 1rem;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
    margin: 0.25rem;
    border-radius: 0.25rem;
    vertical-align: middle;
}
.theme-button:hover {
    background-color: var(--button-hover-bg);
    color: var(--button-hover-text);
    border-color: var(--button-hover-border);
}
.theme-button.active {
    background-color: var(--button-active-bg);
    color: var(--button-active-text);
    border-color: var(--button-active-border);
    font-weight: 600;
}
.reset-button {
    margin-left: 10px;
}

/* --- Font Size Controls Styling --- */
.fontsize-button {
    background-color: var(--button-bg);
    color: var(--button-text);
    border: 1px solid var(--border-color);
    font-family: var(--body-font);
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, font-size 0.2s ease-out;
    cursor: pointer;
    font-size: calc(1rem * var(--font-scale-multiplier));
    line-height: 1;
    font-weight: bold;
    padding: 0.1rem 0.5rem;
    margin: 0 0.1rem;
    border-radius: 0.25rem;
    min-width: 28px;
    text-align: center;
    vertical-align: middle;
}
.fontsize-button:hover {
    background-color: var(--button-hover-bg);
    color: var(--button-hover-text);
    border-color: var(--button-hover-border);
}
.fontsize-button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background-color: var(--button-bg);
    color: var(--button-text);
    border-color: var(--border-color);
}


/* Footer Styling */
footer {
    background-color: var(--card-bg-color);
    border-top: 1px solid var(--border-color);
    color: var(--text-color);
    transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
    text-align: center;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 100;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: var(--footer-height);
}
#footer-controls-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
    margin-bottom: 0.25rem;
}
#theme-picker {
    margin-bottom: 0;
    margin-right: 5px;
}
#fontsize-controls {
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 5px;
}
footer p {
    opacity: 0.8;
    font-size: calc(0.875rem * var(--font-scale-multiplier));
    line-height: 1.25rem;
    margin-top: 0;
    transition: font-size 0.2s ease-out;
}

/* --- Global Font Styles --- */
body, button {
    font-family: var(--body-font);
}
h1, h2 {
    font-family: var(--header-font);
}

/* Specific font size rules for retro theme */
html[data-theme='retro'] .category-card h2 {
    line-height: 1.3;
    /* Padding inherited */
}
html[data-theme='retro'] .category-card h2::after {
    /* Adjust top for VT323 if needed, otherwise inherits base rule */
    /* top: 0.2em; */
    font-size: calc(1.3em * var(--font-scale-multiplier));
}


/* --- Responsive Adjustments for Columns & Footer --- */
@media (max-width: 900px) {
    #categoryGrid {
        column-width: calc(var(--column-width-base) * var(--font-scale-multiplier));
        column-gap: 0.75rem;
    }
     .category-card {
        margin-bottom: 0.75rem;
    }
    header h1 {
       font-size: calc(1.5rem * var(--font-scale-multiplier));
       line-height: 1.2;
    }
}
@media (max-width: 768px) {
    #categoryGrid {
        column-width: calc(var(--column-width-base) * var(--font-scale-multiplier));
        column-gap: 0.75rem;
    }
    .category-card {
        margin-bottom: 0.75rem;
    }
}
@media (max-width: 600px) {
    #footer-controls-wrapper {
        justify-content: center;
    }
    #theme-picker { margin-right: 0; margin-bottom: 0.25rem;}
    #fontsize-controls { margin-left: 0; margin-top: 0.25rem; }
}
@media (max-width: 500px) {
    #categoryGrid {
        column-width: calc(var(--column-width-base) * var(--font-scale-multiplier));
        column-count: 1;
        column-gap: 0;
    }
    .category-card {
        margin-bottom: 1rem;
    }
     header h1 {
        font-size: calc(1.25rem * var(--font-scale-multiplier));
        line-height: 1.2;
      }
     .category-card h2 {
         font-size: calc(1.125rem * var(--font-scale-multiplier));
         line-height: 1.3;
         padding: 0.3rem 20px 0.3rem 5px; /* Ensure padding matches base */
      }
      .category-card.collapsed h2 {
        font-size: calc(1rem * var(--font-scale-multiplier));
        padding-top: 0.3rem; /* Ensure collapsed padding matches */
        padding-bottom: 0.3rem;
      }
}

/* --- SortableJS Helper Styles --- */
.sortable-ghost {
    opacity: 0.4;
    background-color: var(--accent-color);
    border: 1px dashed var(--border-color);
}

.sortable-chosen,
.sortable-drag {
    opacity: 0.9;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.4), var(--card-shadow);
    cursor: grabbing !important;
}

.category-card.sortable-drag {
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

.category-card {
    cursor: grab;
}
.category-card:active {
    cursor: grabbing;
}