/* static/style.css */
:root {
  --body-bg: #1a1a1a; --text-color: #f5f5f7; --container-bg: #2d2d2d; --border-color: #4a4a4a; --input-bg: #3c3c3c;
  --input-text: #f5f5f7; --button-primary-bg: #0070c9; --button-primary-hover-bg: #005bb5; --button-secondary-bg: #4a4a4a;
  --button-secondary-hover-bg: #5a5a5a; --shadow-color: rgba(0, 0, 0, 0.4); --success-color: #28a745;
  --success-hover: #218838; --danger-color: #dc3545;
}
body { min-height: 100vh; margin: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; background: var(--body-bg); color: var(--text-color); line-height: 1.5; transition: all 0.3s ease; display: flex; flex-direction: column; align-items: center; padding: 30px; box-sizing: border-box; }
.container { width: 100%; max-width: 860px; background-color: var(--container-bg); padding: 24px; border-radius: 14px; border: 1px solid var(--border-color); box-shadow: 0 6px 20px var(--shadow-color); margin-bottom: 24px; box-sizing: border-box; }
.header-layout { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; margin-bottom: 16px; }
.brand-logo { display: block; height: 100px; width: auto; margin: 0; border-radius: 12px; flex-shrink: 0; }
h1 { font-family: 'Press Start 2P', cursive; font-size: 26px; line-height: 1.4; margin: 0; letter-spacing: 1px; }
h2 { font-size: 20px; margin: 0 0 12px 0; }
p.description { 
    margin: 0 0 22px 0; 
    opacity: 0.85; 
    font-size: 0.875rem;
    line-height: 1.6;
}
.description a {
    color: var(--button-primary-bg);
    text-decoration: none;
    font-weight: 600;
}
.description a:hover {
    text-decoration: underline;
}
form label, .video-controls label { display: block; margin-bottom: 8px; font-weight: 600; }
input[type="file"], select, .btn { width: 100%; padding: 12px 14px; margin-bottom: 10px; border-radius: 10px; border: 1px solid var(--border-color); background-color: var(--input-bg); color: var(--input-text); outline: none; transition: all 0.2s ease; box-sizing: border-box; display: block; }
input[type="file"] { max-width: 100%; }
input[type="file"]::file-selector-button { margin-right: 12px; border: 1px solid var(--border-color); background: var(--button-secondary-bg); color: var(--text-color); border-radius: 8px; padding: 8px 12px; cursor: pointer; }
select { appearance: none; background-repeat: no-repeat; background-position: right 12px center; background-size: 16px; padding-right: 40px; }
.btn { text-decoration: none; text-align: center; font-weight: 600; cursor: pointer; }
.btn-primary { background-color: var(--button-primary-bg); color: #fff; border: none; }
.btn-primary:hover { background-color: var(--button-primary-hover-bg); transform: translateY(-1px); }
.btn-secondary { background-color: var(--button-secondary-bg); }
.btn-secondary:hover { background-color: var(--button-secondary-hover-bg); transform: translateY(-1px); }
.btn-success { background-color: var(--success-color); color: #fff; border:none; }
.btn-success:hover { background-color: var(--success-hover); }
.btn-danger { background-color: var(--danger-color); color: #fff; border: none; }
img.result-image { display: block; max-width: 100%; height: auto; border-radius: 12px; border: 1px solid var(--border-color); box-shadow: 0 8px 24px var(--shadow-color); }
.result-toolbar { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.result-toolbar > * { flex: 1; min-width: 150px; }
#video-creator { display: none; }
.video-layout { display: flex; flex-wrap: wrap; gap: 24px; }
.video-canvas-wrapper { flex: 2; min-width: 300px; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.1); border-radius: 12px;}
.video-canvas-wrapper canvas { max-width: 100%; border-radius: 8px; border: 1px solid var(--border-color); }
.video-controls { flex: 1; min-width: 280px; }
.control-group { margin-bottom: 20px; }
.control-group label { opacity: 0.9; }
.control-group input[type="range"] { width: 100%; }
.control-group .value-display { font-weight: bold; margin-left: 8px; }
.aspect-buttons { display: flex; gap: 8px; margin-bottom: 12px; }
.aspect-buttons .btn { flex: 1; padding: 8px; }
.aspect-buttons .btn.active { background: var(--button-primary-bg); color: #fff; }
.toggle-control { display: flex; align-items: center; gap: 10px; }
.toggle-control label { margin-bottom: 0; }
.row { display: flex; gap: 12px; flex-wrap: wrap; }
.row > .col { flex: 1; min-width: 220px; }
body:not(.light-theme) select { background-image: url('data:image/svg+xml;utf8,<svg fill="%23fff" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/></svg>'); }
.site-footer {
    width: 100%;
    max-width: 860px;
    padding: 20px 0;
    margin-top: 20px;
    color: var(--text-color);
    opacity: 0.6;
}
.site-footer hr {
    border: none;
    border-top: 1px solid var(--border-color);
    margin-bottom: 20px;
}
.footer-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
    font-size: 0.8rem; 
}
.footer-content p {
    margin: 0;
}
.footer-links a, .site-footer a {
    color: var(--text-color);
    text-decoration: none;
    transition: opacity 0.2s ease;
}
.footer-links > a {
    margin-left: 16px;
}
.footer-links a:hover, .site-footer a:hover {
    opacity: 0.8;
}
.rendering-placeholder { max-width: 100%; height: auto; border-radius: 12px; }

#menu-toggle {
    position: fixed;
    top: 20px;
    right: 20px;
    width: 30px;
    height: 22px;
    cursor: pointer;
    z-index: 1001;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
#menu-toggle span {
    display: block;
    width: 100%;
    height: 3px;
    background-color: var(--text-color);
    transition: all 0.3s ease;
}
.menu-open #menu-toggle span:nth-child(1) {
    transform: rotate(45deg) translate(7px, 7px);
}
.menu-open #menu-toggle span:nth-child(2) {
    opacity: 0;
}
.menu-open #menu-toggle span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -7px);
}
#menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--body-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s ease, visibility 0.4s ease;
    z-index: 1000;
}
.menu-open #menu {
    opacity: 1;
    visibility: visible;
}
#menu ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
#menu ul li {
    margin: 20px 0;
}
#menu ul li a {
    font-family: 'Press Start 2P', cursive;
    color: var(--text-color);
    text-decoration: none;
    font-size: 24px;
    transition: color 0.3s ease;
}
#menu ul li a:hover {
    color: var(--button-primary-bg);
}

@media (max-width: 768px) {
    .footer-content {
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
    }
    .footer-links > a {
        margin-left: 0;
        margin-right: 16px;
    }

    .footer-links a:last-child {
        margin-right: 0;
    }
}

#loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    display: none; /* Hidden by default */
    justify-content: center;
    align-items: center;
    z-index: 2000;
    color: var(--text-color);
    font-family: 'Press Start 2P', cursive;
    font-size: 20px;
    text-align: center;
}