/**
 * Order Process Styling for netclusive.de
 * Zentrale Styles für alle Bestellseiten
 *
 * Design Principles:
 * - Konsistente visuelle Hierarchie
 * - Wiederverwendbare Komponenten
 * - netclusive Markenfarben (#0b65ae, #494c53)
 * - Mobile-first responsive design
 * - Optimierte Accessibility (WCAG 2.1 AA)
 */

/* Smooth scrolling behavior */
html {
    scroll-behavior: smooth;
}

/* ========================================
   CSS Variables
   ======================================== */

/* NOTE: CSS Variables werden zentral in base.css definiert.
   Diese Datei verwendet Variablen aus base.css. */

/* ========================================
   Container
   ======================================== */

.order-container {
    max-width: 100%;
    margin: 0;
    padding: 2rem 0;
}

/* ========================================
   Hero Section
   ======================================== */

.order-hero {
    text-align: center;
    padding: var(--order-spacing-2xl) var(--order-spacing-xl);
    background: linear-gradient(135deg, #ffffff 0%, #f0f4f8 100%);
    border: 1px solid #e1e8ed;
    border-radius: var(--order-radius-lg);
    margin-bottom: var(--order-spacing-2xl);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.order-hero h1 {
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--order-text);
    margin: 0 0 var(--order-spacing-xs) 0;
    letter-spacing: -0.02em;
}

.order-hero h2 {
    font-size: 1.25rem;
    font-weight: 400;
    color: var(--order-text-secondary);
    margin: 0 0 var(--order-spacing-md) 0;
}

.order-hero-desc {
    font-size: 0.9375rem;
    color: var(--order-text-secondary);
    line-height: 1.6;
    max-width: 700px;
    margin: 0 auto;
}

.order-hero-desc a {
    color: var(--order-primary);
    text-decoration: underline;
    font-weight: 600;
    transition: color var(--order-transition-fast);
}

.order-hero-desc a:hover {
    color: var(--order-primary-active);
}

/* Progress Indicator */
.order-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--order-spacing-xs);
    font-size: 0.875rem;
    color: var(--order-text-secondary);
    margin-top: var(--order-spacing-md);
}

.order-progress-step {
    display: flex;
    align-items: center;
    gap: var(--order-spacing-xs);
}

.order-progress-dot {
    width: 8px;
    height: 8px;
    background: var(--order-primary);
    border-radius: 50%;
    flex-shrink: 0;
}

/* ========================================
   Cards
   ======================================== */

.order-card {
    background: var(--order-bg-card);
    border-radius: var(--order-radius-lg);
    box-shadow: var(--order-shadow-md);
    overflow: hidden;
    margin-bottom: var(--order-spacing-lg);
}

.order-card-body {
    padding: var(--order-spacing-2xl);
}

/* ========================================
   Data Sections
   ======================================== */

.data-sections {
    display: grid;
    gap: var(--order-spacing-lg);
}

.data-section {
    background: var(--order-bg-section);
    border: 2px solid var(--order-border);
    border-radius: var(--order-radius-md);
    overflow: hidden;
    transition: all var(--order-transition-normal);
}

.data-section:hover {
    border-color: var(--order-border-hover);
    box-shadow: var(--order-shadow-hover);
}

.data-section-header {
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
    border-bottom: 2px solid var(--order-border);
    padding: 1.25rem var(--order-spacing-lg);
    display: flex;
    align-items: center;
    gap: var(--order-spacing-md);
}

.data-section-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background: var(--order-bg-info);
    border: 2px solid var(--order-primary);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.data-section-icon svg {
    width: 20px;
    height: 20px;
    stroke: var(--order-primary);
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.data-section-title {
    flex: 1;
    margin: 0;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--order-primary);
    letter-spacing: -0.01em;
}

.data-section-body {
    padding: 1.75rem var(--order-spacing-lg);
}

/* Data Grid */
.data-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--order-spacing-lg);
}

.data-item {
    display: flex;
    flex-direction: column;
    gap: var(--order-spacing-xs);
}

.data-label {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--order-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.data-value {
    font-size: 1rem;
    color: var(--order-text);
    font-weight: 500;
    line-height: 1.5;
    word-break: break-word;
}

.data-value.highlight {
    font-family: 'Courier New', Consolas, monospace;
    font-weight: 700;
    color: var(--order-primary);
    font-size: 1.25rem;
    background: var(--order-bg-info);
    padding: 0.625rem var(--order-spacing-md);
    border-radius: var(--order-radius-sm);
    border: 2px solid var(--order-primary);
    display: inline-block;
    letter-spacing: 0.05em;
}

.data-value-empty {
    color: var(--order-text-muted);
    font-style: italic;
}

/* ========================================
   Buttons (Order-specific overrides)
   ======================================== */

/* Increase specificity to override form styles */
.order-container .btn,
.order-container button.btn,
.order-container a.btn {
    height: 56px !important;
    padding: 0 2.5rem !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    border-radius: 10px !important;
    cursor: pointer;
    transition: all var(--order-transition-smooth) !important;
    border: 2px solid transparent !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.625rem !important;
    text-decoration: none !important;
    letter-spacing: 0.01em !important;
    position: relative;
    overflow: hidden;
    white-space: nowrap;
    box-sizing: border-box;
}

.order-container .btn svg,
.order-container button.btn svg,
.order-container a.btn svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    flex-shrink: 0;
}

/* Ripple Effect */
.order-container .btn::before,
.order-container button.btn::before,
.order-container a.btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.25) 0%, rgba(255, 255, 255, 0) 70%);
    transform: translate(-50%, -50%);
    transition: width 400ms ease, height 400ms ease;
}

.order-container .btn:hover::before,
.order-container button.btn:hover::before,
.order-container a.btn:hover::before {
    width: 500px;
    height: 500px;
}

/* Primary Button */
.order-container .btn-primary,
.order-container button.btn-primary,
.order-container a.btn-primary {
    color: #ffffff !important;
    background: linear-gradient(135deg, var(--order-primary) 0%, var(--order-primary-active) 100%) !important;
    border: none !important;
    box-shadow: 0 4px 12px rgba(11, 101, 174, 0.25) !important;
}

.order-container .btn-primary:hover,
.order-container button.btn-primary:hover,
.order-container a.btn-primary:hover {
    box-shadow: 0 8px 24px rgba(11, 101, 174, 0.35) !important;
    background: linear-gradient(135deg, var(--order-primary) 0%, var(--order-primary-active) 100%) !important;
}

.order-container .btn-primary:active,
.order-container button.btn-primary:active,
.order-container a.btn-primary:active {
    /* Active state - no vertical movement */
}

/* Secondary Button */
.order-container .btn-secondary,
.order-container button.btn-secondary,
.order-container a.btn-secondary {
    color: var(--order-primary) !important;
    background: #ffffff !important;
    border-color: var(--order-primary) !important;
    box-shadow: none !important;
}

.order-container .btn-secondary:hover,
.order-container button.btn-secondary:hover,
.order-container a.btn-secondary:hover {
    background: var(--order-bg-info) !important;
    box-shadow: 0 4px 12px rgba(11, 101, 174, 0.15) !important;
    color: var(--order-primary) !important;
}

.order-container .btn-secondary:active,
.order-container button.btn-secondary:active,
.order-container a.btn-secondary:active {
    /* Active state - no vertical movement */
}

/* Button Group */
.btn-group {
    display: flex;
    gap: var(--order-spacing-md);
}

/* ========================================
   Actions Bar
   ======================================== */

.actions-bar {
    margin-top: var(--order-spacing-2xl);
    padding-top: var(--order-spacing-xl);
    border-top: 2px solid var(--order-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--order-spacing-lg);
}

.action-hint {
    flex: 1;
    font-size: 0.875rem;
    color: var(--order-text-secondary);
    line-height: 1.5;
}

.actions-buttons {
    display: flex;
    gap: var(--order-spacing-md);
    flex-shrink: 0;
}

/* ========================================
   Notice Boxes
   ======================================== */

.notice-box {
    padding: var(--order-spacing-lg);
    border-radius: var(--order-radius-md);
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
    margin-bottom: var(--order-spacing-xl);
}

.notice-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 1rem;
    line-height: 1;
}

.notice-content {
    flex: 1;
    font-size: 0.9375rem;
    line-height: 1.6;
}

.notice-content strong {
    font-weight: 700;
}

.notice-content a {
    text-decoration: underline;
    text-decoration-thickness: 2px;
    font-weight: 700;
}

/* Warning Notice */
.notice-warning {
    background: linear-gradient(135deg, var(--order-warning-bg) 0%, #ffe8a1 100%);
    border: 2px solid var(--order-warning);
    color: #664d03;
}

.notice-warning .notice-icon {
    background: var(--order-warning);
    color: #000;
}

.notice-warning .notice-content strong {
    color: #000;
}

.notice-warning .notice-content a {
    color: #664d03;
}

/* Error Notice */
.notice-error {
    background: var(--order-error-bg);
    border: 2px solid var(--order-error);
    color: #7f1d1d;
}

.notice-error .notice-icon {
    background: var(--order-error);
    color: #fff;
}

.notice-error .notice-content a {
    color: #7f1d1d;
}

/* Info Notice */
.notice-info {
    background: var(--order-bg-info);
    border: 2px solid var(--order-primary);
    color: #084675;
}

.notice-info .notice-icon {
    background: var(--order-primary);
    color: #fff;
}

.notice-info .notice-content a {
    color: var(--order-primary);
}

/* ========================================
   Form Card (Universal Card für Formulare)
   ======================================== */

.order-form-card {
    background: var(--order-bg-card);
    border: 1px solid var(--order-border);
    border-radius: var(--order-radius-md);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    margin-bottom: var(--order-spacing-xl);
}

.order-form-card h3 {
    background: linear-gradient(135deg, var(--order-primary) 0%, var(--order-primary-active) 100%);
    color: #ffffff;
    padding: 1.25rem var(--order-spacing-xl);
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: var(--order-spacing-sm);
}

.order-form-card h3 svg {
    width: 24px;
    height: 24px;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.order-form-desc {
    color: var(--order-text-secondary);
    line-height: 1.6;
    margin-bottom: var(--order-spacing-xl);
    padding: 0 var(--order-spacing-xl);
    padding-top: var(--order-spacing-xl);
}

/* First form element after h3 needs top padding when no .order-form-desc exists */
.order-form-card h3 + .form-group,
.order-form-card h3 + .form-row {
    padding-top: var(--order-spacing-xl);
}

.order-form-desc a {
    color: var(--order-primary);
    font-weight: 600;
    text-decoration: underline;
}

.order-form-desc a:hover {
    color: var(--order-primary-active);
}

/* ========================================
   Form Elements
   ======================================== */

.order-form-card .form-group:not(.form-row > .form-group),
.order-form-card .error-box,
.order-form-card .info-box,
.order-form-card .ssl-notice,
.order-form-card .form-help-box,
.order-form-card .form-hint,
.order-form-card .payment-info-box,
.order-form-card .payment-rhythm-display,
.order-form-card .form-actions,
.order-form-card > form > input[type="submit"],
.order-form-card > form > button {
    margin-left: var(--order-spacing-xl);
    margin-right: var(--order-spacing-xl);
}

/* First element after h3 header needs top spacing */
.order-form-card h3 + .form-group,
.order-form-card h3 + .form-row,
.order-form-card h3 + .error-box,
.order-form-card h3 + .info-box {
    margin-top: var(--order-spacing-xl);
}

/* Form rows get padding unless they are nested inside a form-group */
.order-form-card .form-row {
    margin-left: var(--order-spacing-xl);
    margin-right: var(--order-spacing-xl);
}

/* But form-groups inside form-rows don't get additional padding */
.order-form-card .form-row > .form-group {
    margin-left: 0;
    margin-right: 0;
}

/* And form-rows nested inside form-groups don't get padding either */
.order-form-card .form-group .form-row {
    margin-left: 0;
    margin-right: 0;
}

.order-form-card .form-group:last-child {
    margin-bottom: var(--order-spacing-xl);
}

.form-group {
    margin-bottom: var(--order-spacing-md);
}

.form-group label {
    display: block;
    font-weight: 600;
    color: var(--order-text);
    margin-bottom: var(--order-spacing-xs);
    font-size: 0.9375rem;
}

.form-group label.required::after {
    content: " *";
    color: var(--order-error);
    font-weight: 700;
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="password"],
.form-group input[type="tel"],
.form-group input[type="number"],
.form-group input[type="date"],
.form-group select,
.form-group textarea {
    width: 100%;
    height: 44px;
    padding: 0 var(--order-spacing-md);
    font-size: 1rem;
    font-family: inherit;
    color: var(--order-text);
    background: var(--order-bg-card);
    border: 2px solid var(--order-border);
    border-radius: var(--order-radius-sm);
    transition: var(--order-transition-fast);
    box-sizing: border-box;
}

.form-group textarea {
    height: auto;
    min-height: 100px;
    padding: var(--order-spacing-sm) var(--order-spacing-md);
    resize: vertical;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--order-primary);
    box-shadow: 0 0 0 3px rgba(11, 101, 174, 0.1);
}

/* Improved focus visible for keyboard navigation */
.form-group input:focus-visible,
.form-group select:focus-visible,
.form-group textarea:focus-visible {
    outline: 3px solid var(--order-primary);
    outline-offset: 2px;
}

.form-group input:disabled,
.form-group select:disabled,
.form-group textarea:disabled {
    background: var(--order-bg-section);
    color: var(--order-text-muted);
    cursor: not-allowed;
    opacity: 0.6;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--order-text-muted);
}

.form-help {
    display: block;
    font-size: 0.8125rem;
    color: var(--order-text-secondary);
    margin-top: 0.25rem;
    line-height: 1.4;
}

/* Form help spanning full width in grid rows */
.form-help-fullwidth {
    grid-column: 1 / -1;
    margin-top: calc(-1 * var(--order-spacing-md) + 0.25rem);
}

/* Reduce form-row bottom margin when followed by form-help */
.form-group > .form-row {
    margin-bottom: 0.25rem;
}

/* Form Row (Multi-Column Layout) */
.form-row {
    display: grid;
    gap: var(--order-spacing-md);
    margin-bottom: var(--order-spacing-md);
}

/* Remove margin from form-groups inside form-rows to prevent double spacing */
.form-row > .form-group,
.order-form-card .form-row > .form-group {
    margin-bottom: 0 !important;
}

.form-row.cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.form-row.cols-3 {
    grid-template-columns: repeat(3, 1fr);
}

.form-row.cols-4 {
    grid-template-columns: repeat(4, 1fr);
}

/* Radio Buttons & Checkboxes */
.form-radio,
.form-checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--order-spacing-sm);
    margin-bottom: var(--order-spacing-sm);
    cursor: pointer;
    transition: var(--order-transition-fast);
}

.form-radio:hover,
.form-checkbox:hover {
    opacity: 0.8;
}

.form-radio input[type="radio"],
.form-checkbox input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin-top: 2px;
    cursor: pointer;
    accent-color: var(--order-primary);
}

.form-radio input[type="radio"]:focus-visible,
.form-checkbox input[type="checkbox"]:focus-visible {
    outline: 3px solid var(--order-primary);
    outline-offset: 3px;
}

.form-radio label,
.form-checkbox label {
    flex: 1;
    cursor: pointer;
    font-weight: 400;
    color: var(--order-text);
    margin: 0;
}

/* Form validation states */
.form-group input:invalid:not(:placeholder-shown),
.form-group select:invalid:not(:placeholder-shown),
.form-group textarea:invalid:not(:placeholder-shown) {
    border-color: var(--order-warning);
}

.form-group input:valid:not(:placeholder-shown),
.form-group select:valid:not(:placeholder-shown),
.form-group textarea:valid:not(:placeholder-shown) {
    border-color: #10b981;
}

/* ========================================
   Error Handling
   ======================================== */

/* Consistent alert box styling (matches info-box pattern) */
.error-box {
    background: var(--order-error-bg);
    border-left: 4px solid var(--order-error);
    border-radius: var(--order-radius-sm);
    padding: var(--order-spacing-lg);
    padding-left: 3rem;
    margin-bottom: var(--order-spacing-lg);
    color: #7f1d1d;
    font-size: 0.9375rem;
    line-height: 1.6;
    position: relative;
}

.error-box::before {
    content: "";
    position: absolute;
    left: var(--order-spacing-md);
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='12'/%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
}

.error-box strong {
    color: #000;
    font-weight: 700;
}

.error-box ul {
    margin: var(--order-spacing-sm) 0 0 0;
    padding-left: var(--order-spacing-lg);
}

.error-box li {
    margin-bottom: var(--order-spacing-xs);
}

/* Input Error State */
.form-group.has-error input,
.form-group.has-error select,
.form-group.has-error textarea {
    border-color: var(--order-error);
    background: var(--order-error-bg);
}

.form-group.has-error .form-help {
    color: var(--order-error);
}

/* ========================================
   Form Actions
   ======================================== */

.form-actions {
    display: flex;
    gap: var(--order-spacing-md);
    justify-content: flex-end;
    margin-top: var(--order-spacing-2xl);
    margin-bottom: var(--order-spacing-xl);
}

/* When back button exists, spread buttons to edges */
.form-actions:has(.btn-secondary) {
    justify-content: space-between;
}

.form-actions input[type="submit"],
.form-actions input[type="button"],
.form-actions button {
    height: 56px !important;
    padding: 0 2.5rem !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    border-radius: 10px !important;
    cursor: pointer;
    transition: all var(--order-transition-smooth) !important;
    border: 2px solid transparent !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    letter-spacing: 0.01em !important;
    box-sizing: border-box;
    color: #ffffff !important;
    background: linear-gradient(135deg, var(--order-primary) 0%, var(--order-primary-active) 100%) !important;
    box-shadow: 0 4px 12px rgba(11, 101, 174, 0.25) !important;
}

.form-actions input[type="submit"]:hover,
.form-actions input[type="button"]:hover,
.form-actions button:hover {
    box-shadow: 0 8px 24px rgba(11, 101, 174, 0.35) !important;
}

.form-actions input[type="submit"]:active,
.form-actions input[type="button"]:active,
.form-actions button:active {
    /* Active state - no vertical movement */
}

/* ========================================
   Customer Check Section
   ======================================== */

.customer-check-section {
    background: var(--order-bg-card);
    border: 1px solid var(--order-border);
    border-radius: var(--order-radius-md);
    padding: var(--order-spacing-xl);
    margin-bottom: var(--order-spacing-xl);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.customer-check-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--order-text);
    margin: 0 0 var(--order-spacing-lg) 0;
    display: flex;
    align-items: center;
    gap: var(--order-spacing-sm);
}

.customer-check-title svg {
    width: 24px;
    height: 24px;
    stroke: var(--order-primary);
    stroke-width: 2;
}

.customer-check-options {
    display: flex;
    flex-direction: row;
    gap: var(--order-spacing-md);
}

.customer-check-option {
    flex: 1;
    display: flex;
    align-items: center;
    gap: var(--order-spacing-sm);
    padding: var(--order-spacing-md);
    background: var(--order-bg-section);
    border: 2px solid var(--order-border);
    border-radius: var(--order-radius-sm);
    cursor: pointer;
    transition: var(--order-transition-fast);
}

.customer-check-option:hover {
    border-color: var(--order-primary);
    background: var(--order-bg-info);
}

.customer-check-option input[type="radio"] {
    width: 20px;
    height: 20px;
    accent-color: var(--order-primary);
    flex-shrink: 0;
}

.customer-check-option label {
    flex: 1;
    cursor: pointer;
    font-weight: 600;
    color: var(--order-text);
    line-height: 1.4;
    margin: 0;
}

/* ========================================
   Utility Classes
   ======================================== */

/* Hidden State */
.hidden {
    display: none !important;
}

/* Form Row Layouts (specific variants) */
.form-row-street {
    grid-template-columns: 1fr auto;
}

.form-row-city {
    grid-template-columns: auto 1fr;
}

.form-row-phone {
    grid-template-columns: 150px 1fr;
}

/* Small Input Fields */
.form-group input.input-small {
    width: 80px;
}

.form-group input.input-medium {
    width: 120px;
}

/* Form Note (Pflichtfeld-Hinweis) */
.form-note {
    font-size: 0.875rem;
    color: var(--order-text-secondary);
    margin-top: var(--order-spacing-lg);
    text-align: right;
    padding-right: var(--order-spacing-xl);
}

.form-note .required-mark {
    color: var(--order-error);
    font-weight: 700;
}

/* Layer Transitions (für dynamische Formularbereiche) */
.form-layer-transition {
    animation: fadeIn 0.3s ease-in-out;
    overflow: hidden;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Conditional Form Fields */
.conditional-field {
    transition: all var(--order-transition-fast);
}

/* ========================================
   Responsive Design
   ======================================== */

@media (max-width: 768px) {
    .order-hero h1 {
        font-size: 1.75rem;
    }

    .order-hero h2 {
        font-size: 1.125rem;
    }

    .order-card-body {
        padding: var(--order-spacing-xl) var(--order-spacing-lg);
    }

    .data-section-body {
        padding: var(--order-spacing-lg) 1.25rem;
    }

    .data-grid {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }

    .actions-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .action-hint {
        text-align: center;
    }

    .actions-buttons {
        flex-direction: column-reverse;
    }

    .order-container .btn,
    .order-container button.btn,
    .order-container a.btn {
        width: 100% !important;
        justify-content: center !important;
    }

    .form-row.cols-2,
    .form-row.cols-3,
    .form-row.cols-4,
    .form-row-street,
    .form-row-city,
    .form-row-phone {
        grid-template-columns: 1fr;
    }

    .form-group input.input-small,
    .form-group input.input-medium {
        width: 100%;
    }

    .customer-check-options {
        flex-direction: column;
    }

    .form-actions {
        flex-direction: column;
    }

    .form-actions input[type="submit"],
    .form-actions input[type="button"],
    .form-actions button {
        width: 100%;
    }

    .order-form-card h3 {
        padding: var(--order-spacing-md);
        font-size: 1rem;
    }

    .order-form-desc {
        padding: var(--order-spacing-md);
    }
}

@media (max-width: 480px) {
    .order-hero {
        padding: var(--order-spacing-xl) var(--order-spacing-lg);
    }

    .order-hero h1 {
        font-size: 1.5rem;
    }

    .order-card-body {
        padding: var(--order-spacing-lg) var(--order-spacing-md);
    }

    .data-section-header {
        padding: var(--order-spacing-md) 1.25rem;
    }

    .data-section-body {
        padding: 1.25rem var(--order-spacing-md);
    }

    .order-container .btn,
    .order-container button.btn,
    .order-container a.btn {
        height: 52px !important;
        padding: 0 1.75rem !important;
        font-size: 0.9375rem !important;
    }
}

/* ========================================
   Summary Page Specific Styles
   ======================================== */

/* Intro text for summary page */
.order-intro-text {
    text-align: center;
    color: var(--order-text-secondary);
    font-size: 1.0625rem;
    line-height: 1.6;
    margin-bottom: var(--order-spacing-2xl);
    padding: 0 var(--order-spacing-md);
}

.order-intro-text + form .order-form-card:first-of-type {
    margin-top: var(--order-spacing-lg);
}

/* Legal section with checkboxes */
.summary-legal {
    background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
    border: 1px solid var(--order-border);
    border-bottom: 2px solid var(--order-border);
}

.summary-legal .summary-card-header {
    background: linear-gradient(135deg, #475569 0%, #334155 100%);
}

.summary-legal .checkbox-section {
    padding: 0;
    margin: 0;
    background: transparent;
    border: none;
    border-left: none;
    border-radius: 0;
    border-bottom: 1px solid var(--order-border);
}

.summary-legal .checkbox-section:last-child {
    border-bottom: none;
}

.summary-legal .checkbox-section label {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: var(--order-spacing-lg) var(--order-spacing-xl);
    cursor: pointer;
    transition: background-color 150ms ease;
    margin: 0;
}

.summary-legal .checkbox-section label:hover {
    background-color: rgba(11, 101, 174, 0.03);
}

/* Summary form actions - more prominent */
.form-actions-summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--order-spacing-lg);
    padding: var(--order-spacing-xl) 0;
    margin-top: var(--order-spacing-lg);
}

.form-actions-summary .btn-primary {
    flex-grow: 1;
    max-width: 320px;
}

@media (max-width: 576px) {
    .form-actions-summary {
        flex-direction: column-reverse;
    }

    .form-actions-summary .btn {
        width: 100%;
        max-width: none;
    }

    .summary-legal .checkbox-section label {
        padding: var(--order-spacing-md);
    }
}

/* ========================================
   SMS Verification
   ======================================== */

.sms-verify-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--order-spacing-lg);
    background: linear-gradient(135deg, var(--order-primary) 0%, #0952a0 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sms-verify-icon svg {
    width: 32px;
    height: 32px;
    stroke: white;
}

.sms-verify-icon--error {
    background: linear-gradient(135deg, #dc2626 0%, #991b1b 100%);
}

.sms-verify-icon--warning {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.sms-code-group {
    max-width: 320px;
    margin: var(--order-spacing-xl) auto;
    text-align: center;
}

.sms-code-group label {
    display: block;
    margin-bottom: var(--order-spacing-sm);
}

.sms-code-input-wrapper {
    position: relative;
}

.sms-code-input {
    width: 100%;
    padding: var(--order-spacing-lg) var(--order-spacing-xl);
    font-size: 2rem;
    font-weight: 700;
    text-align: center;
    letter-spacing: 0.5rem;
    border: 2px solid var(--order-border);
    border-radius: var(--order-radius-md);
    transition: border-color 200ms ease, box-shadow 200ms ease;
    font-family: var(--font-mono, 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace);
}

.sms-code-input:focus {
    outline: none;
    border-color: var(--order-primary);
    box-shadow: 0 0 0 3px rgba(11, 101, 174, 0.15);
}

.sms-code-input::placeholder {
    color: #cbd5e1;
    letter-spacing: 0.5rem;
}

.sms-resend-section {
    text-align: center;
    margin-top: var(--order-spacing-2xl);
    padding-top: var(--order-spacing-xl);
    border-top: 1px solid var(--order-border);
}

.sms-resend-section p {
    margin: 0 0 var(--order-spacing-sm);
    color: var(--order-text-secondary);
    font-size: 0.9375rem;
}

.resend-form {
    display: inline-block;
}

.resend-countdown {
    color: var(--order-text-secondary);
    font-size: 0.875rem;
}

.resend-countdown #countdown {
    font-weight: 600;
    color: var(--order-primary);
}

.form-actions-back {
    margin-top: var(--order-spacing-xl);
    text-align: center;
}

.sms-expiry-hint {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: var(--order-spacing-md);
    font-size: 0.875rem;
    color: var(--order-text-secondary);
}

.sms-expiry-hint svg {
    flex-shrink: 0;
}

.sms-help-text {
    margin-top: var(--order-spacing-md);
    font-size: 0.8125rem;
    color: var(--order-text-secondary);
}

.sms-help-text a {
    color: var(--order-primary);
}

/* Mobile adjustments for SMS verification */
@media (max-width: 576px) {
    .sms-code-input {
        font-size: 1.5rem;
        letter-spacing: 0.3rem;
        padding: var(--order-spacing-md) var(--order-spacing-lg);
    }

    .sms-code-input::placeholder {
        letter-spacing: 0.3rem;
    }

    .sms-verify-icon {
        width: 56px;
        height: 56px;
    }

    .sms-verify-icon svg {
        width: 28px;
        height: 28px;
    }
}

/* SMS Verify Card - Centered form layout */
.sms-verify-card {
    max-width: 480px;
    margin: 0 auto;
    padding: var(--order-spacing-2xl);
    background: var(--order-bg-card);
    border-radius: var(--order-radius-lg);
    box-shadow: var(--order-shadow-sm);
    text-align: center;
}

.sms-verify-desc {
    margin: 0 0 var(--order-spacing-lg);
    font-size: 1rem;
    color: var(--order-text-secondary);
    line-height: 1.6;
}

.sms-verify-card .btn-primary {
    width: 100%;
    max-width: 320px;
}

.sms-verify-back {
    margin-top: var(--order-spacing-xl);
    padding-top: var(--order-spacing-lg);
    border-top: 1px solid var(--order-border);
}

@media (max-width: 576px) {
    .sms-verify-card {
        padding: var(--order-spacing-lg);
        margin: 0 var(--order-spacing-sm);
    }
}

/* ========================================
   Form Hint (Info text below form rows)
   ======================================== */

.order-form-card .form-hint {
    display: block;
    font-size: 0.8125rem;
    color: var(--order-text-secondary);
    line-height: 1.4;
    margin: -0.75rem 0 1rem 0;
}

/* ========================================
   Payment Rhythm Display
   ======================================== */

.payment-rhythm-display {
    padding: var(--order-spacing-lg);
    background: var(--order-bg-info);
    border: 2px solid var(--order-primary);
    border-radius: var(--order-radius-md);
    text-align: center;
    margin-bottom: var(--order-spacing-xl);
}

.payment-rhythm-label {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--order-primary);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    margin-bottom: var(--order-spacing-xs);
}

.payment-rhythm-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--order-text);
}

