@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600&family=Crimson+Pro:ital,wght@0,400;0,600;1,400&display=swap');

.dgbsub-wrap {
    max-width: 680px;
    margin: 0 auto;
    font-family: 'Crimson Pro', Georgia, serif;
    color: #e8dfc8;
}

.dgbsub-header { text-align: center; margin-bottom: 2rem; }
.dgbsub-divider { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; color: #4a3828; font-size: 18px; }
.dgbsub-divider::before, .dgbsub-divider::after { content: ''; flex: 1; height: 1px; background: linear-gradient(90deg, transparent, #4a3828, transparent); }
.dgbsub-header h2 { font-family: 'Cinzel', Georgia, serif; font-size: 22px; font-weight: 600; letter-spacing: .15em; color: #a82424; text-transform: uppercase; margin: 0 0 6px; }
.dgbsub-header p { font-style: italic; font-size: 14px; color: #8a7860; margin: 0; }

.dgbsub-form fieldset { background: #1c1812; border: 1px solid #35291e; border-radius: 6px; padding: 1.4rem 1.4rem 1rem; margin-bottom: 1rem; }
.dgbsub-form legend { font-family: 'Cinzel', Georgia, serif; font-size: 9px; letter-spacing: .2em; color: #c8963c; text-transform: uppercase; padding: 0 8px; }
.dgbsub-field { margin-bottom: 14px; }
.dgbsub-field:last-child { margin-bottom: 0; }
.dgbsub-field > label { display: block; font-family: 'Cinzel', Georgia, serif; font-size: 8.5px; letter-spacing: .18em; color: #8a7860; text-transform: uppercase; margin-bottom: 5px; }
.dgbsub-field label em { font-style: italic; letter-spacing: 0; font-size: 11px; color: #5a4a38; }
.req { color: #a82424; margin-left: 2px; }
.dgbsub-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

.dgbsub-form input[type="text"], .dgbsub-form textarea, .dgbsub-form select {
    width: 100%; background: #13110e; border: 1px solid #35291e; border-radius: 3px; padding: 9px 11px;
    color: #e8dfc8; font-family: 'Crimson Pro', Georgia, serif; font-size: 15px; outline: none;
    transition: border-color .18s; -webkit-appearance: none; appearance: none; box-sizing: border-box;
}
.dgbsub-form input:focus, .dgbsub-form textarea:focus, .dgbsub-form select:focus { border-color: #4a3828; }
.dgbsub-form input.err, .dgbsub-form select.err { border-color: #8b1a1a; }
.dgbsub-form input::placeholder, .dgbsub-form textarea::placeholder { color: #35291e; font-style: italic; }
.dgbsub-form textarea { resize: vertical; line-height: 1.55; }
.dgbsub-form select { cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%234a3828'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 11px center; padding-right: 30px; }
.dgbsub-err { display: block; font-size: 12px; color: #c44a4a; font-style: italic; margin-top: 4px; }

.dgbsub-haunt-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; }
.dgbsub-haunt-btn { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 8px 4px 7px; background: #13110e; border: 1px solid #35291e; border-radius: 3px; color: #5a4a38; font-family: 'Cinzel', Georgia, serif; font-size: 8px; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; transition: all .14s; user-select: none; }
.dgbsub-haunt-btn input[type="radio"] { display: none; }
.dgbsub-haunt-btn:hover { border-color: #4a3828; color: #c8b898; }
.dgbsub-haunt-btn.checked { border-color: #8b1a1a; color: #d46060; background: #1a0a0a; }
.dgbsub-haunt-icon { font-size: 16px; }

.dgbsub-intensity { display: flex; align-items: center; gap: 7px; margin-top: 4px; }
.dgbsub-dot-label { cursor: pointer; }
.dgbsub-dot-label input[type="radio"] { display: none; }
.dgbsub-dot { display: block; width: 26px; height: 26px; border-radius: 50%; border: 1px solid #35291e; background: #13110e; transition: all .14s; }
.dgbsub-dot.lit { background: #8b1a1a; border-color: #6b1010; }
.dgbsub-int-label { font-style: italic; font-size: 13px; color: #8a7860; margin-left: 4px; }

.dgbsub-submit-btn { display: block; width: 100%; background: #8b1a1a; border: none; border-radius: 4px; padding: 14px; color: #f0ddd0; font-family: 'Cinzel', Georgia, serif; font-size: 10px; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; cursor: pointer; transition: background .18s; margin-top: .5rem; }
.dgbsub-submit-btn:hover { background: #a82424; }

.dgbsub-success { max-width: 480px; margin: 3rem auto; text-align: center; background: #1c1812; border: 1px solid #35291e; border-radius: 6px; padding: 2.5rem 2rem; font-family: 'Crimson Pro', Georgia, serif; }
.dgbsub-success-icon { font-size: 40px; margin-bottom: 1rem; }
.dgbsub-success h3 { font-family: 'Cinzel', Georgia, serif; font-size: 15px; letter-spacing: .18em; color: #a82424; text-transform: uppercase; margin: 0 0 8px; }
.dgbsub-success p { font-style: italic; font-size: 14px; color: #8a7860; line-height: 1.6; margin: 0 0 1.5rem; }
.dgbsub-btn-ghost { display: inline-block; background: transparent; border: 1px solid #35291e; border-radius: 3px; padding: 9px 20px; color: #8a7860; font-family: 'Cinzel', Georgia, serif; font-size: 9px; letter-spacing: .15em; text-transform: uppercase; text-decoration: none; transition: all .18s; }
.dgbsub-btn-ghost:hover { border-color: #4a3828; color: #c8b898; }
