.hc-generator-wrapper{text-align:center}
.hc-generator-form{width:100%;margin:0 auto;font-family:inherit;font-size:.95rem;max-width:980px;padding:22px 26px;border:1px solid rgba(0,0,0,.06);border-radius:8px;background-color:#e7eaf6;box-shadow:0 8px 22px rgba(0,0,0,.06);display:flex;flex-direction:column;align-items:center;gap:0}
.hc-generator-title{font-size:1.15rem;font-weight:600;margin-bottom:8px}
.hc-generator-text{color:#555;line-height:1.4;margin-bottom:14px}
.hc-generator-form label{font-weight:500;font-size:.95rem;margin-bottom:8px;text-align:center}
.hc-generator-row{width:100%;max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:10px;align-items:stretch}
.hc-generator-input{width:100%;height:44px;padding:8px 12px;border-radius:10px;border:1px solid #d6d6d6;font-size:1rem;font-family:inherit;box-sizing:border-box;text-align:left;background:#fff}
.hc-generator-input:focus{outline:none;border-color:#4da3ff;box-shadow:0 0 0 1px rgba(77,163,255,.25)}
.hc-generator-button{height:44px;padding:0 18px;border-radius:10px;border:none;background:#4da3ff;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;font-family:inherit;width:100%}
.hc-generator-button:hover{background:#2f8bf5}
@media(min-width:768px){.hc-generator-wrapper{padding:26px 18px}.hc-generator-row{flex-direction:row;align-items:center;gap:12px}.hc-generator-input{flex:1}.hc-generator-button{width:auto;white-space:nowrap}}
@media(min-width:1100px){.hc-generator-form{padding:26px 32px}.hc-generator-row{max-width:780px}}
@keyframes border-glow{0%,100%{box-shadow:0 0 8px rgba(255,180,50,.9),0 0 12px rgba(255,180,50,.6),inset 0 0 5px rgba(255,180,50,.3)}50%{box-shadow:0 0 15px rgba(255,180,50,1),0 0 20px rgba(255,180,50,.8),inset 0 0 8px rgba(255,180,50,.4)}}
.promo-tile{animation:border-glow 2.5s ease-in-out infinite;border:3px solid rgba(255,180,50,.6)}
.hc-input-wrap{position:relative;width:100%}
.hc-input-wrap .hc-generator-input{width:100%}
.hc-caret{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:1px;height:1.1em;background:#111;opacity:0;pointer-events:none}
@keyframes hc-caret-blink{0%,49%{opacity:1}50%,100%{opacity:0}}
.hc-input-wrap.hc-caret-on:not(.hc-has-value) .hc-caret{opacity:1;animation:hc-caret-blink 1s step-end infinite}
.hc-upload-section{width:100%;max-width:720px;margin:0 auto;padding-top:20px}
.hc-or-divider{display:flex;align-items:center;gap:14px;margin-bottom:10px;font-size:.8rem;color:#aaa;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.hc-or-divider::before,.hc-or-divider::after{content:"";flex:1;height:1px;background:rgba(0,0,0,.12)}
.hc-upload-text{color:#555;font-size:.88rem;margin-bottom:16px;line-height:1.4;text-align:center}
.hc-upload-preview-row{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.hc-upload-gif{max-width:280px;width:100%;border-radius:10px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.hc-upload-button{display:inline-flex;align-items:center;justify-content:center;padding:11px 28px;border-radius:10px;border:1px solid #d0d0d0;background:#fff;color:#444;font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s,box-shadow .15s;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.hc-upload-button:hover{background:#f8f8f8;border-color:#b0b0b0;box-shadow:0 2px 8px rgba(0,0,0,.1)}
@media(max-width:520px){.hc-upload-preview-row{flex-direction:column;gap:14px}.hc-upload-gif{max-width:260px}}