/*
File: style.css
Directory: /includes/
*/

/* CSS Variables for theming */
:root {
    --bg-color: #121212;
    --text-color: #ffffff;
    --text-muted-color: #a3a3a3;
    --card-bg: #242424;
    --card-border: #444;
    --glow-color: #3b82f6; /* Default glow color set to blue */
    --input-bg: #444;
    --input-text: #e0e0e0;
    --error-bg: #4d1a1a;
    --error-border: #cf222e;
    --error-text: #ffc1c1;
}

html.light-theme {
    --bg-color: #f5f5f4;
    --text-color: #292524;
    --text-muted-color: #78716c;
    --card-bg: #ffffff;
    --card-border: #e7e5e4;
    --input-bg: #f5f5f5;
    --input-text: #292524;
    --error-bg: #fde8e8;
    --error-border: #fecaca;
    --error-text: #991b1b;
}

/* Base Styles */
body {  
    font-family: 'Roboto', sans-serif;  
    background-color: var(--bg-color);  
    color: var(--text-color);  
    transition: background-color 0.3s ease, color 0.3s ease;  
}
.font-orbitron { font-family: 'Orbitron', sans-serif; }

/* Custom Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--card-bg); border-radius: 10px; }
::-webkit-scrollbar-thumb { background: #888; border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: #555; }
    
/* Component Styles */
.main-card {  
    background-color: var(--card-bg);  
    border: 1px solid var(--card-border);  
    transition: background-color 0.3s ease, border-color 0.3s ease;  
}
.custom-button {  
    background-color: var(--glow-color);  
    color: white;  
    font-weight: bold;
    border-radius: 0.5rem;
    padding: 0.75rem 1rem;
    transition: all 0.2s;  
    box-shadow: 0 0 10px 0 var(--glow-color);
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.custom-button:hover { filter: brightness(1.2); box-shadow: 0 0 15px 0 var(--glow-color); }
.custom-button:disabled {  
    background-color: var(--card-border);  
    color: var(--text-muted-color);  
    cursor: not-allowed;  
    box-shadow: none;
}
.custom-button-secondary {
     background-color: var(--card-bg);
      color: var(--text-color);
      border: 1px solid var(--card-border);
      box-shadow: none;
}
.custom-button-secondary:hover {
    background-color: var(--input-bg);
    border-color: var(--glow-color);
    color: var(--glow-color);
}
.custom-button-green {
    background-color: #059669;
    box-shadow: 0 0 10px 0 #059669;
}
.custom-button-green:hover {
     box-shadow: 0 0 15px 0 #059669;
}

.title-color { color: var(--glow-color); text-shadow: 0 0 5px var(--glow-color); transition: color 0.3s, text-shadow 0.3s; }
.text-muted { color: var(--text-muted-color); }

/* Main Tabs */
.tab-button { color: var(--text-muted-color); }
.tab-button:hover { color: var(--text-color); border-color: var(--card-border); }
.tab-button.active { color: var(--glow-color); border-color: var(--glow-color) !important; }

/* Folder tabs bar (JS injects a div with .flex bg-gray-100). Ensure it's theme-aware */
#folder-tabs-bar > .flex,
#components-folder-tabs-bar > .flex,
#animations-folder-tabs-bar > .flex {
    background-color: var(--card-bg) !important; /* replace the light bg-gray-100 */
    border: 1px solid var(--card-border);
    color: var(--text-muted-color);
}

/* Folder tab buttons inside the bar */
#folder-tabs-bar button,
#components-folder-tabs-bar button,
#animations-folder-tabs-bar button {
    color: var(--text-muted-color);
    background: transparent;
    border: none;
    padding: 0.35rem 0.6rem;
    margin-right: 0.25rem;
}

#folder-tabs-bar button:hover,
#components-folder-tabs-bar button:hover,
#animations-folder-tabs-bar button:hover {
    color: var(--text-color);
    background-color: rgba(255,255,255,0.03);
}

/* 'All' button style in the bar: keep contrast when dark */
#folder-tabs-bar button[aria-current="true"],
#components-folder-tabs-bar button[aria-current="true"],
#animations-folder-tabs-bar button[aria-current="true"] {
    background-color: var(--glow-color);
    color: #fff;
}

/* Workspace Tabs */
.workspace-tab { color: var(--text-muted-color); border-color: transparent; }
.workspace-tab:hover { color: var(--text-color); }
.workspace-tab.active { color: var(--text-color); background-color: var(--input-bg); border-color: var(--card-border) !important; }

/* Gallery Item */
.gallery-item { position: relative; overflow: hidden; }
.gallery-item .overlay, .gallery-item .checkbox-container { position: absolute; opacity: 0; transition: opacity 0.3s ease; }
.gallery-item:hover .overlay, .gallery-item:hover .checkbox-container { opacity: 1; }
.gallery-item .overlay { bottom: 0; left: 0; right: 0; }
.gallery-item .checkbox-container { top: 8px; right: 8px; }

/* README Modal */
#modal-close-btn {
    background: transparent; border: none; padding: 0; color: var(--text-muted-color); font-size: 2rem; line-height: 1;
    font-weight: bold; transition: all 0.2s ease;
}
#modal-close-btn:hover { color: var(--glow-color); transform: scale(1.1) rotate(90deg); }
#readme-content h2, #readme-content h3 { border-bottom: 1px solid var(--card-border); padding-bottom: 0.5rem; color: var(--glow-color);}
#readme-content .code-block { background-color: var(--bg-color); padding: 1rem; border-radius: 0.5rem; border: 1px solid var(--card-border); overflow-x: auto; }
#readme-content code { font-family: monospace; }
#readme-content li { margin-bottom: 0.5rem; }

/* Theme Switcher */
.theme-changer-container { position: fixed; bottom: 1rem; right: 1rem; display: flex; align-items:center; gap: 0.5rem; padding: 0.5rem; background-color: var(--card-bg); border-radius: 9999px; border: 1px solid var(--card-border); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4); z-index: 50; }
.color-circle { width: 24px; height: 24px; border-radius: 50%; cursor: pointer; border: 2px solid transparent; transition: all 0.2s; }
.color-circle.active { border-color: var(--text-color); transform: scale(1.1); }
#theme-toggle-btn { background-color: transparent; border: none; color: var(--text-muted-color); cursor: pointer; }
#theme-toggle-btn:hover { color: var(--text-color); }
    
/* A checkerboard pattern to show transparency clearly */
.checkerboard {
    background-image:
        linear-gradient(45deg, #555 25%, transparent 25%),
        linear-gradient(-45deg, #555 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #555 75%),
        linear-gradient(-45deg, transparent 75%, #555 75%);
    background-size: 20px 20px;
    background-position: 0 0, 0 10px, 10px -10px, -10px 0px;
    border: 1px solid var(--card-border);
}
html.light-theme .checkerboard {
    background-image:
        linear-gradient(45deg, #e0e0e0 25%, transparent 25%),
        linear-gradient(-45deg, #e0e0e0 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #e0e0e0 75%),
        linear-gradient(-45deg, transparent 75%, #e0e0e0 75%);
}
    
/* Loader */
.loader {
    border: 4px solid var(--card-border);
    border-top: 4px solid var(--glow-color);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
}
@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Admin Panel & Unlock Animations */
#admin-trigger.active { cursor: pointer; }
.admin-modal {
    transition: opacity 0.5s ease, transform 0.5s ease;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
#pattern-lock-modal {
    transition: opacity 0.5s ease, box-shadow 0.3s ease, transform 0.3s ease;
}
#pattern-lock-modal.shake {
    animation: shake 0.5s;
    box-shadow: 0 0 25px rgba(239, 68, 68, 0.8);
}
#pattern-lock-modal.correct {
    box-shadow: 0 0 25px rgba(74, 222, 128, 0.8);
}
@keyframes shake {
  10%, 90% { transform: translate(-51%, -50%); }
  20%, 80% { transform: translate(-49%, -50%); }
  30%, 50%, 70% { transform: translate(-52%, -50%); }
  40%, 60% { transform: translate(-48%, -50%); }
}

#admin-streak {
    position: fixed;
    width: 4px;
    background: var(--glow-color);
    transform-origin: top center;
    transform: rotate(var(--angle)) scaleY(0);
    z-index: 101;
    height: var(--distance);
    box-shadow: 0 0 15px var(--glow-color);
}
#admin-streak.animate {
    animation: streak-anim 0.5s ease-out forwards;
}
@keyframes streak-anim {
    from { transform: rotate(var(--angle)) scaleY(0); }
    to { transform: rotate(var(--angle)) scaleY(1); }
}

#admin-panel-close-btn { font-size: 2rem; line-height: 1; color: var(--text-muted-color); transition: color 0.2s; }
#admin-panel-close-btn:hover { color: var(--error-border); }

#admin-container.red-flash {
    animation: red-flash-anim 0.5s 2;
}
@keyframes red-flash-anim {
    0%, 100% { background-color: transparent; }
    50% { background-color: rgba(200, 0, 0, 0.3); }
}

#admin-panel-modal.build-in {
    transform: translate(-50%, -50%) scale(0.5);
    opacity: 0;
    animation: build-in-anim 0.5s 0.2s forwards;
}

@keyframes build-in-anim {
    to {
        transform: translate(-50%, -50%) scale(1);
        opacity: 1;
    }
}

/* Intrusion Lockout */
#lockout-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.98);
    z-index: 999999;
    cursor: none !important;
    user-select: none !important;
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    -ms-user-select: none !important;
    pointer-events: all !important;
}

#intrusion-modal {
    z-index: 1000000 !important;
}

#intrusion-modal .main-card {
    animation: intrusion-pulse 2s infinite;
}

@keyframes intrusion-pulse {
    0%, 100% { 
        box-shadow: 0 0 20px rgba(207, 34, 46, 0.8);
        border-color: rgba(207, 34, 46, 0.8);
    }
    50% { 
        box-shadow: 0 0 40px rgba(207, 34, 46, 1);
        border-color: rgba(207, 34, 46, 1);
    }
}

/* Toggle Switch Styles */
.toggle-switch {
    position: relative;
    width: 48px;
    height: 24px;
}

.toggle-checkbox {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-label {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #ccc;
    border-radius: 24px;
    transition: 0.3s;
}

.toggle-label:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: white;
    border-radius: 50%;
    transition: 0.3s;
}

.toggle-checkbox:checked + .toggle-label {
    background-color: var(--glow-color, #3b82f6);
}

.toggle-checkbox:checked + .toggle-label:before {
    transform: translateX(24px);
}

.toggle-checkbox:focus + .toggle-label {
    box-shadow: 0 0 1px var(--glow-color, #3b82f6);
}

