/* =========================================
   FORMS & INPUTS (WOOCOMMERCE & CUSTOM)
   ========================================= */

/* --- EINGABEFELDER (Clean & Modern) --- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
    background-color: #ffffff !important;
    border: 1px solid #1a1a1a !important; /* Black border, 1px */
    border-radius: 30px !important;
    padding: 15px 20px !important;
    font-size: 14px !important;
    color: var(--color-dark) !important;
    transition: all 0.3s ease;
    box-shadow: none !important;
    appearance: none; /* Remove default arrow for select */
    -webkit-appearance: none;
}

/* Custom Arrow for standard Select */
.woocommerce form .form-row select {
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%231a1a1a%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 20px center;
    background-size: 12px auto;
    padding-right: 40px !important;
}

.woocommerce form .form-row textarea {
    border-radius: 20px !important;
}

/* Fokus Effekt */
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    background-color: #ffffff !important;
    border-color: var(--color-dark) !important;
    box-shadow: 0 5px 15px rgba(0,0,0,0.05) !important;
    outline: none;
}

/* --- SELECT2 CUSTOMIZATION (WooCommerce Dropdowns) --- */
.select2-container .select2-selection--single {
    height: 54px !important; /* Match input height roughly (padding + font + border) */
    background-color: #ffffff !important;
    border: 1px solid #1a1a1a !important;
    border-radius: 30px !important;
    padding: 12px 20px !important;
    outline: none !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 28px !important;
    color: var(--color-dark) !important;
    padding-left: 0 !important;
    font-size: 14px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 52px !important;
    right: 15px !important;
    width: 20px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: #1a1a1a transparent transparent transparent !important;
    border-width: 6px 5px 0 5px !important;
    margin-top: -3px !important;
}

.select2-dropdown {
    border: 1px solid #1a1a1a !important;
    border-radius: 12px !important;
    overflow: hidden;
    margin-top: 5px;
    box-shadow: 0 5px 20px rgba(0,0,0,0.1) !important;
}

.select2-search__field {
    border-radius: 20px !important;
    padding: 8px 15px !important;
    border: 1px solid #e5e5e5 !important;
}

/* Labels (Visually Hidden but Accessible) - EXCLUDING Checkboxes/Radios */
.woocommerce form .form-row label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/* Restore visibility for checkbox and radio labels */
.woocommerce form .form-row label.checkbox,
.woocommerce form .form-row label.radio,
.woocommerce form .form-row.terms label,
.woocommerce form .form-row.woocommerce-terms-and-conditions-wrapper label {
    position: static !important;
    width: auto !important;
    height: auto !important;
    margin: 0 0 5px 0 !important;
    overflow: visible !important;
    clip: auto !important;
    display: inline-block !important;
}

/* --- BUTTONS (Allgemein) --- */
.checkout-button,
#place_order,
button[name="woocommerce_checkout_place_order"],
.suc-btn-primary,
.wcp-submit-btn {
    background-color: var(--color-dark) !important;
    color: #fff !important;
    padding: 20px 40px !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 14px !important;
    border: 1px solid var(--color-dark) !important;
    transition: all 0.3s ease !important;
    margin-top: 20px;
    cursor: pointer;
}

.checkout-button:hover,
#place_order:hover,
.suc-btn-primary:hover,
.wcp-submit-btn:hover {
    background-color: transparent !important;
    color: var(--color-dark) !important;
    transform: translateY(-2px);
}

/* --- CUSTOM PRICE FORM (WCP) --- */
.wcp-form {
    width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    padding: 100px 20px !important;
    box-sizing: border-box;
    
    background-color: var(--color-light) !important;
    background-image: 
        linear-gradient(var(--color-light) 2px, transparent 2px),
        linear-gradient(90deg, var(--color-light) 2px, transparent 2px),
        linear-gradient(rgba(0,0,0,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,0,0,0.03) 1px, transparent 1px);
    background-size: 100px 100px, 100px 100px, 20px 20px, 20px 20px;
    background-position: -2px -2px, -2px -2px, -1px -1px, -1px -1px;
    
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: none !important;
}

.wcp-label {
    font-family: var(--font-primary);
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 11px;
    color: var(--color-grey);
    margin-bottom: 30px;
    background: #fff;
    padding: 5px 15px;
    border: 1px solid #ddd;
    border-radius: 20px;
    align-self: center;
}

.wcp-input-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: none !important;
    margin-bottom: 40px;
    width: auto !important;
    max-width: 100%;
}

.wcp-currency {
    order: 2;
    font-size: 40px;
    font-weight: 300;
    color: var(--color-dark);
    margin-left: 10px;
    opacity: 0.4;
}

.wcp-input.text {
    order: 1;
    background: transparent !important;
    border: none !important;
    font-size: clamp(60px, 10vw, 100px) !important;
    font-weight: 700 !important;
    color: var(--color-dark) !important;
    text-align: right;
    width: auto !important;
    min-width: 100px;
    outline: none !important;
    padding: 0 !important;
    line-height: 1;
    height: auto !important;
    font-family: var(--font-primary) !important;
}

.wcp-input.text::placeholder {
    color: #ccc; font-size: 0.4em; transform: translateY(-10px); text-align: center;
}

.wcp-submit-btn {
    min-width: 280px;
    align-self: center;
}

@media only screen and (max-width: 768px) {
    .wcp-form { padding: 60px 15px !important; }
}
