:root{
    --max-width: 980px;
    --container-pad: 16px;
    --gap: 12px;
    --accent: #b22222;
    --bg: #fff;
    --muted: #666;
    --radius: 8px;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
}

*{box-sizing: border-box}

body{
    margin:0;
    background:#f6f6f6;
    color:#111;
    display:flex;
    justify-content:center;
    padding:24px;
}

.page{
    width:100%;
    max-width:var(--max-width);
    background:var(--bg);
    border-radius:10px;
    box-shadow:0 6px 20px rgba(0,0,0,0.06);
    display:flex;
    flex-direction:column;
    gap:20px;
    padding:24px;
}

/* Header / Logo */
.site-header{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
}

.logo{
    width:220px;
    height:60px;
    display:block;
    object-fit:contain;
}

h1{
    margin:0;
    font-size:1.3rem;
    color:var(--muted);
    text-align:center;
}

h2{
    margin:0;
    font-size:1.1rem;
    color:var(--muted);
    text-align:center;
}

/* Form layout */
form.order-form{
    display:flex;
    flex-direction:column;
    gap:var(--gap);
}

.row{
    display:flex;
    flex-direction:column;
    gap:8px;
}

/* two columns where appropriate */
.two-cols{
    flex-direction:column;
}

label{
    font-size:0.95rem;
    color:#222;
    display:flex;
    flex-direction:column;
    gap:6px;
}

input[type="text"],
input[type="tel"],
input[type="email"],
input[type="date"],
textarea{
    padding:10px 12px;
    border:1px solid #ddd;
    border-radius:6px;
    font-size:1rem;
    background:#fff;
}

textarea{
    min-height:120px;
    resize:vertical;
}

.inline{
    display: flex;
    align-items: center;
    flex-direction: row;
    gap: 10px;
}

.date-wrap{
    display:flex;
    gap:10px;
    align-items:center;
}

.payment{
    display:flex;
    gap:12px;
    align-items:center;
    flex-wrap:wrap;
}

.checkbox{
    display:flex;
    align-items:center;
    gap:8px;
}

.submit-row{
    display: flex;
    justify-content: center;
}

button[type="submit"]{
    background:var(--accent);
    color:#fff;
    border:none;
    padding:10px 16px;
    border-radius:8px;
    font-size:1rem;
    cursor:pointer;
}

.error {
    color: var(--accent);
    margin-top: 16px;
    font-size: 0.9rem;
}

.error-item {
    padding: 4px 0;
}

.thankyou {
    display:none;
    padding:24px;
    text-align:center;
    display:flex;
    flex-direction:column;
    gap:12px;
    align-items:center;
    justify-content:center;
}
.thankyou.show { display:flex; }

.button-row {
    margin-top: 24px;
    display: flex;
    justify-content: center;
}

.back-button {
    background: var(--accent);
    color: #fff;
    text-decoration: none;
    padding: 10px 16px;
    border-radius: 8px;
    font-size: 1rem;
}

.back-button:hover {
    background: #991c1c;
}

/* Responsive breakpoints: tablet and up -> some rows become two columns */
@media (min-width:600px){
    .two-cols{
        flex-direction:row;
    }
    .two-cols > label{
        flex:1 1 50%;
    }
    .date-wrap{
        align-items:center;
    }
}

@media (min-width:900px){
    body{padding:40px;}
    .logo{width:260px;height:72px}
    form.order-form{
        gap:18px;
    }
    .submit-row{
        justify-content: center;
    }
}