diff --git "a/app.py" "b/app.py" --- "a/app.py" +++ "b/app.py" @@ -466,14 +466,12 @@ SYNKRIS_LOOK_TEMPLATE = ''' --bg: #000000; --card-bg: #0a0a0a; --primary: #ccff00; - --primary-hover: #b3e600; --primary-gradient: linear-gradient(45deg, #ccff00, #b3e600); --text: #ffffff; --text-secondary: #a1a1a1; --border: #333333; --input-bg: #111111; } - body { font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif; background-color: var(--bg); @@ -485,969 +483,570 @@ body { align-items: flex-start; min-height: 100vh; } - .container { background-color: var(--card-bg); width: 100%; - max-width: 750px; + 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); - margin-top: 0; - margin-bottom: 5px; - font-size: 2.2rem; - text-transform: uppercase; - letter-spacing: 2px; - text-shadow: 0 0 10px rgba(204, 255, 0, 0.3); -} - -p.subtitle { - text-align: center; - color: var(--text-secondary); - margin-bottom: 30px; - font-size: 0.9rem; - letter-spacing: 0.5px; -} - -.mode-selector { - display: grid; - grid-template-columns: repeat(3, 1fr); - margin-bottom: 30px; - background-color: var(--input-bg); - border-radius: 12px; - padding: 5px; - border: 1px solid var(--border); -} - -.mode-btn { - padding: 12px 10px; - background-color: transparent; - border: none; - color: var(--text-secondary); - font-size: 0.85rem; - font-weight: 700; - cursor: pointer; - border-radius: 8px; - transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); - 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-grid { - display: grid; - grid-template-columns: 1fr 1fr; - gap: 22px; -} - -.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); - 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); - border-radius: 8px; - font-size: 1rem; - background-color: var(--input-bg); - color: var(--text); - transition: all 0.3s ease; - outline: none; - 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: 35px; - text-align: center; -} - -.action-btn { - background-image: var(--primary-gradient); - color: #000; - border: none; - padding: 16px 30px; - font-size: 1.1rem; - font-weight: 800; - border-radius: 12px; - cursor: pointer; - width: 100%; - transition: all 0.2s ease; - box-shadow: 0 0 20px rgba(204, 255, 0, 0.4); - display: flex; - justify-content: center; - align-items: center; - gap: 12px; - text-transform: uppercase; -} - -.action-btn:hover { - transform: scale(1.02); - box-shadow: 0 0 30px rgba(204, 255, 0, 0.6); -} - -.action-btn:active { - transform: scale(0.98); -} - -select option { - background-color: #000; - color: #fff; -} - -.form-mode { - display: none; -} - -.form-mode.active { - display: contents; -} - -.checkbox-container { - display: flex; - align-items: center; - background-color: var(--input-bg); - border: 1px solid var(--border); - border-radius: 8px; - padding: 12px 14px; -} - -.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 { - display: grid; - grid-template-columns: 1fr 1fr; - gap: 10px; -} - -.style-btn { - padding: 12px 10px; - background-color: var(--input-bg); - border: 1px solid var(--border); - color: var(--text-secondary); - font-size: 0.85rem; - font-weight: 600; - cursor: pointer; - border-radius: 8px; - transition: all 0.3s ease; - text-align: center; - width: 100%; -} - -.style-btn:hover { - border-color: var(--primary); - color: var(--text); + text-align: center; color: var(--primary); margin-top: 0; margin-bottom: 5px; font-size: 2.2rem; + text-transform: uppercase; letter-spacing: 2px; text-shadow: 0 0 10px rgba(204, 255, 0, 0.3); } - -.style-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-grid { - display: grid; - grid-template-columns: repeat(4, 1fr); - gap: 10px; -} -.aspect-ratio-btn { - display: flex; - flex-direction: column; - align-items: center; - justify-content: center; - gap: 8px; - padding: 10px; - background-color: var(--input-bg); - border: 1px solid var(--border); - color: var(--text-secondary); - font-size: 0.8rem; - font-weight: 600; - cursor: pointer; - 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); -} -.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; -} - +p.subtitle { text-align: center; color: var(--text-secondary); margin-bottom: 30px; font-size: 0.9rem; } +.mode-selector { display: grid; grid-template-columns: 1fr 1fr; margin-bottom: 30px; background-color: var(--input-bg); border-radius: 12px; padding: 5px; border: 1px solid var(--border); } +.mode-btn { padding: 12px 10px; background-color: transparent; border: none; color: var(--text-secondary); font-size: 0.85rem; font-weight: 700; cursor: pointer; border-radius: 8px; transition: all 0.3s; text-transform: uppercase; } +.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-section { display: none; } +.form-section.active { display: block; } +h2.section-title { color: var(--primary); font-size: 1.1rem; text-transform: uppercase; letter-spacing: 1px; border-bottom: 1px solid var(--border); padding-bottom: 10px; margin-top: 30px; margin-bottom: 20px; } +.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; } +.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); text-transform: uppercase; letter-spacing: 0.8px; } +select, textarea, input[type="text"] { width: 100%; box-sizing: border-box; padding: 12px 14px; border: 1px solid var(--border); border-radius: 8px; font-size: 1rem; background-color: var(--input-bg); color: var(--text); transition: all 0.3s ease; outline: none; font-family: inherit; } +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; } +.checkbox-container { display: flex; align-items: center; background-color: var(--input-bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; margin-bottom:10px; } +.checkbox-container input[type="checkbox"] { margin-right: 10px; } +.checkbox-container label { color: var(--text) !important; text-transform: none !important; letter-spacing: 0 !important; margin-bottom: 0; } +.action-btn { background-image: var(--primary-gradient); color: #000; border: none; padding: 16px 30px; font-size: 1.1rem; font-weight: 800; border-radius: 12px; cursor: pointer; width: 100%; transition: all 0.2s ease; box-shadow: 0 0 20px rgba(204, 255, 0, 0.4); display: flex; justify-content: center; align-items: center; gap: 12px; text-transform: uppercase; margin-top: 35px; } +.action-btn:hover { transform: scale(1.02); box-shadow: 0 0 30px rgba(204, 255, 0, 0.6); } +.style-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; } +.style-btn { width: 100%; padding: 12px 10px; background-color: var(--input-bg); border: 1px solid var(--border); color: var(--text-secondary); font-size: 0.85rem; font-weight: 600; cursor: pointer; border-radius: 8px; transition: all 0.3s ease; text-align: center; } +.style-btn:hover { border-color: var(--primary); color: var(--text); } +.style-btn.active { background-color: var(--primary); color: #000; border-color: var(--primary); box-shadow: 0 0 10px rgba(204, 255, 0, 0.3); } +.hidden-fields { display: none; margin-top: 15px; padding-top: 15px; border-top: 1px solid var(--border); } +.model-params-container { border: 1px solid var(--border); border-radius: 10px; padding: 20px; margin-top: 15px; background-color: #000; } +.model-params-container h3 { margin-top: 0; font-size: 1rem; color: var(--text); text-transform: uppercase; letter-spacing: 1px;} @media (max-width: 600px) { - .form-grid { - grid-template-columns: 1fr; - } - .full-width { - grid-column: span 1; - } - .container { - padding: 20px; - } - h1 { - font-size: 1.8rem; - } - .mode-selector { - grid-template-columns: 1fr; - gap: 5px; - } + .form-grid, .style-grid { grid-template-columns: 1fr; } + .full-width { grid-column: span 1; } + .container { padding: 20px; } + h1 { font-size: 1.8rem; } }
-PROMPT GENERATOR & LAUNCHER
+AI FASHION & PRODUCT IMAGE GENERATOR