diff --git "a/app.py" "b/app.py" --- "a/app.py" +++ "b/app.py" @@ -1,4 +1,3 @@ - import os import io import base64 @@ -474,7 +473,6 @@ SYNKRIS_LOOK_TEMPLATE = ''' --border: #333333; --input-bg: #111111; } - body { font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif; background-color: var(--bg); @@ -486,17 +484,15 @@ body { align-items: flex-start; min-height: 100vh; } - .container { background-color: var(--card-bg); width: 100%; - max-width: 1200px; + max-width: 900px; padding: 35px; border-radius: 20px; border: 1px solid #222; box-shadow: 0 0 40px rgba(204, 255, 0, 0.08); } - h1 { text-align: center; color: var(--primary); @@ -507,7 +503,6 @@ h1 { letter-spacing: 2px; text-shadow: 0 0 10px rgba(204, 255, 0, 0.3); } - p.subtitle { text-align: center; color: var(--text-secondary); @@ -515,7 +510,6 @@ p.subtitle { font-size: 0.9rem; letter-spacing: 0.5px; } - .mode-selector { display: grid; grid-template-columns: repeat(3, 1fr); @@ -525,7 +519,6 @@ p.subtitle { padding: 5px; border: 1px solid var(--border); } - .mode-btn { padding: 12px 10px; background-color: transparent; @@ -539,39 +532,38 @@ p.subtitle { text-transform: uppercase; letter-spacing: 0.5px; } - .mode-btn.active { background-color: var(--primary); color: #000; box-shadow: 0 0 15px rgba(204, 255, 0, 0.4); transform: scale(1.02); } - -.form-main-grid { +.section-title { + color: var(--primary); + font-weight: 600; + text-transform: uppercase; + letter-spacing: 1px; + font-size: 1rem; + margin-top: 30px; + margin-bottom: 15px; + padding-bottom: 8px; + border-bottom: 1px solid var(--border); +} +.form-grid { display: grid; grid-template-columns: 1fr 1fr; - gap: 25px; + gap: 22px; } - -.form-group { - display: flex; - flex-direction: column; -} - +.full-width { grid-column: span 2; } +.form-group { display: flex; flex-direction: column; } label, .checkbox-label { font-weight: 600; margin-bottom: 8px; font-size: 0.8rem; - color: var(--primary); + color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.8px; } - -label i { - margin-right: 6px; - font-size: 0.9em; -} - select, textarea, input[type="text"] { padding: 12px 14px; border: 1px solid var(--border); @@ -584,36 +576,18 @@ select, textarea, input[type="text"] { width: 100%; box-sizing: border-box; } - -select:disabled, textarea:disabled, input[type="text"]:disabled, input[type="checkbox"]:disabled + label { - background-color: #222; - opacity: 0.5; - cursor: not-allowed; -} - - select:focus, textarea:focus, input[type="text"]:focus { border-color: var(--primary); box-shadow: 0 0 10px rgba(204, 255, 0, 0.2); } - -textarea { - resize: vertical; - min-height: 80px; - font-family: inherit; -} - -.btn-container { - margin-top: 40px; - text-align: center; -} - +textarea { resize: vertical; min-height: 80px; font-family: inherit; } +.btn-container { margin-top: 35px; text-align: center; } .action-btn { background-image: var(--primary-gradient); color: #000; border: none; - padding: 18px 40px; - font-size: 1.2rem; + padding: 16px 30px; + font-size: 1.1rem; font-weight: 800; border-radius: 12px; cursor: pointer; @@ -623,32 +597,16 @@ textarea { display: flex; justify-content: center; align-items: center; - gap: 15px; + gap: 12px; text-transform: uppercase; } - .action-btn:hover { - transform: scale(1.01); + transform: scale(1.02); box-shadow: 0 0 30px rgba(204, 255, 0, 0.6); } - -.action-btn:active { - transform: scale(0.99); -} - -select option { - background-color: #000; - color: #fff; -} - -.form-mode { - display: none; -} - -.form-mode.active { - display: contents; -} - +select option { background-color: #000; color: #fff; } +.form-mode { display: none; } +.form-mode.active { display: contents; } .checkbox-container { display: flex; align-items: center; @@ -656,75 +614,29 @@ select option { border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; - margin-bottom: 10px; -} -.checkbox-container input[type=\"checkbox\"] { - margin-right: 10px; -} - -.sub-mode-selector { - display: flex; - justify-content: center; - background-color: #000; - border-radius: 10px; - padding: 4px; - border: 1px solid var(--border); - margin-bottom: 25px; -} -.sub-mode-btn { - flex: 1; - padding: 9px 15px; - background: transparent; - border: none; - color: var(--text-secondary); - font-size: 0.8rem; - font-weight: 600; cursor: pointer; - border-radius: 7px; - transition: all 0.3s ease; - text-transform: uppercase; } -.sub-mode-btn.active { - background-color: var(--primary); - color: #000; - box-shadow: 0 0 10px rgba(204, 255, 0, 0.3); -} -.sub-form-mode { - display: none; -} -.sub-form-mode.active { - display: contents; -} - -.style-grid, .aspect-ratio-grid { +.checkbox-container input[type="checkbox"] { margin-right: 10px; } +.hidden { display: none; } +.style-grid { display: grid; + grid-template-columns: 1fr 1fr; gap: 10px; } - -.style-grid { - grid-template-columns: repeat(2, 1fr); -} - .style-btn { - padding: 10px 10px; + padding: 12px 10px; background-color: var(--input-bg); border: 1px solid var(--border); color: var(--text-secondary); - font-size: 0.8rem; + font-size: 0.85rem; font-weight: 600; cursor: pointer; border-radius: 8px; transition: all 0.3s ease; text-align: center; width: 100%; - word-break: break-word; } - -.style-btn:hover { - border-color: var(--primary); - color: var(--text); -} - +.style-btn:hover { border-color: var(--primary); color: var(--text); } .style-btn.active { background-color: var(--primary); color: #000; @@ -732,7 +644,9 @@ select option { box-shadow: 0 0 10px rgba(204, 255, 0, 0.3); } .aspect-ratio-grid { + display: grid; grid-template-columns: repeat(4, 1fr); + gap: 10px; } .aspect-ratio-btn { display: flex; @@ -750,66 +664,31 @@ select option { border-radius: 8px; transition: all 0.3s ease; text-align: center; - height: 90px; -} -.aspect-ratio-btn .preview { - background: #333; - border-radius: 3px; - transition: background-color 0.3s ease; -} -.aspect-ratio-btn:hover { - border-color: var(--primary); - color: var(--text); + height: 70px; } +.aspect-ratio-btn .preview { background: #333; border-radius: 3px; transition: background-color 0.3s ease; } .aspect-ratio-btn.active { background-color: var(--primary); color: #000; border-color: var(--primary); box-shadow: 0 0 10px rgba(204, 255, 0, 0.3); } -.aspect-ratio-btn.active .preview { - background: #000; -} - -.full-width-group { - grid-column: span 2; -} - -@media (max-width: 1100px) { - .form-main-grid { - grid-template-columns: 1fr; - } - .full-width-group { - grid-column: span 1; - } +.aspect-ratio-btn.active .preview { background: #000; } +@media (max-width: 768px) { + .form-grid, .style-grid { grid-template-columns: 1fr; } + .full-width { grid-column: span 1; } + .container { padding: 20px; } + h1 { font-size: 1.8rem; } } - -@media (max-width: 600px) { - .container { - padding: 20px; - } - h1 { - font-size: 1.8rem; - } - .mode-selector { - grid-template-columns: 1fr; - gap: 5px; - } - .action-btn { - padding: 16px 20px; - font-size: 1rem; - } - .style-grid { - grid-template-columns: 1fr; - } +@media (max-width: 480px) { + .mode-selector { grid-template-columns: 1fr; gap: 5px; } }
-ГЕНЕРАТОР ПРОМПТОВ ДЛЯ GOOGLE GEMINI (Image Generation)
+PROMPT GENERATOR & LAUNCHER