/* ORDER.CSS – complete updated file */

:root {
  --order-bg: #f5f1ea;
  --order-card: rgba(255, 255, 255, 0.34);
  --order-card-solid: #f8f4ee;
  --order-border: rgba(155, 115, 72, 0.18);
  --order-text: #2f231a;
  --order-text-soft: rgba(47, 35, 26, 0.72);
  --order-muted: rgba(47, 35, 26, 0.5);
  --order-accent: #9b7348;
  --order-accent-soft: rgba(155, 115, 72, 0.12);
  --order-available: #5e775d;
  --order-booked: #9a7d6a;
}

/* Shared eyebrow normalization */
.order-eyebrow,
.order-summary__eyebrow,
.df-order-guard__eyebrow{
  margin: 0 0 10px !important;
  font-family: Inter, Arial, sans-serif !important;
  font-size: 0.78rem !important;
  line-height: 1.2 !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #6f6258 !important;
}

.order-page {
  background: var(--order-bg);
}

.order-page .footer {
  margin-top: 0;
}

.df-order-guard {
  padding: 56px 0 110px;
}

.df-order-guard__outer {
  max-width: 1180px;
}

.df-order-guard__inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 42px 34px;
  border: 1px solid var(--order-border);
  border-radius: 24px;
  background: var(--order-card);
  backdrop-filter: blur(6px);
  text-align: center;
}

.df-order-guard__eyebrow {
  margin: 0 0 10px;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--order-accent);
  font-weight: 600;
}

.df-order-guard__title {
  margin: 0 0 16px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(2.6rem, 4.4vw, 4rem);
  line-height: 1.02;
  font-weight: 500;
  color: var(--order-text);
  text-wrap: balance;
}

.df-order-guard__text {
  max-width: 620px;
  margin: 0 auto 28px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.15rem, 1.7vw, 1.45rem);
  line-height: 1.5;
  font-style: italic;
  color: var(--order-text-soft);
}

.df-order-guard__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  border: 0;
  background: var(--order-accent);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  transition: opacity 0.18s ease;
}

.df-order-guard__cta:hover {
  opacity: 0.9;
}

.order-hero {
  padding: 44px 0 52px;
  max-width: 1180px;
}

.order-eyebrow {
  margin: 0 0 8px;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--order-accent);
  font-weight: 600;
}

.order-hero h1 {
  margin: 0 0 18px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(3rem, 4.6vw, 4.15rem);
  line-height: 1.02;
  font-weight: 500;
  color: var(--order-text);
  max-width: 1120px;
  text-wrap: balance;
}

.order-intro {
  max-width: 980px;
  margin: 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.2rem, 1.7vw, 1.55rem);
  line-height: 1.48;
  font-style: italic;
  color: var(--order-text-soft);
  text-wrap: balance;
}

.order-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) 360px;
  gap: 44px;
  align-items: start;
  padding-bottom: 100px;
}

.order-main {
  display: flex;
  flex-direction: column;
  gap: 34px;
}

.order-section {
  padding: 0 0 6px;
}

.order-section__head {
  margin-bottom: 18px;
}

.order-section__head h2 {
  margin: 0 0 6px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(2rem, 2.6vw, 2.8rem);
  line-height: 1.02;
  font-weight: 500;
  color: var(--order-text);
}

.order-section__head p {
  margin: 0;
  max-width: 720px;
  color: var(--order-text-soft);
  font-size: 1rem;
  line-height: 1.6;
}

.order-eircode-row {
  display: flex;
  gap: 12px;
  align-items: center;
}

.order-input {
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--order-border);
  background: transparent;
  padding: 16px 0 14px;
  font-size: 1rem;
  color: var(--order-text);
  font-family: inherit;
}

.order-input:focus {
  outline: none;
  border-bottom-color: var(--order-accent);
}

.order-input::placeholder {
  color: rgba(47, 35, 26, 0.46);
}

.order-area-result {
  margin-top: 10px;
  color: var(--order-text);
  font-weight: 500;
}

.order-day-list,
.order-slot-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.order-day,
.order-slot {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 16px 0;
  border: 0;
  border-bottom: 1px solid var(--order-border);
  background: transparent;
  color: var(--order-text);
  text-align: left;
  cursor: pointer;
  transition: opacity 0.18s ease, color 0.18s ease, background 0.18s ease;
}

.order-day:hover,
.order-slot:hover {
  opacity: 0.78;
}

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

.order-day__name {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.8rem;
  line-height: 1.05;
  color: inherit;
}

.order-slot {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.8rem;
  line-height: 1.05;
}

.order-day__status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.order-day__status::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

.order-day__status.is-available {
  color: var(--order-available);
}

.order-day__status.is-available::before {
  background: var(--order-available);
  box-shadow: 0 0 0 4px rgba(94, 119, 93, 0.12);
}

.order-day__status.is-booked {
  color: var(--order-booked);
}

.order-day__status.is-booked::before {
  background: var(--order-booked);
  box-shadow: 0 0 0 4px rgba(154, 125, 106, 0.12);
}

.order-day__badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(155, 115, 72, 0.12);
  color: var(--order-accent);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.order-day.is-next .order-day__name,
.order-day.is-selected .order-day__name,
.order-slot.is-selected {
  color: var(--order-accent);
}

.order-day.is-selected .order-day__status {
  color: var(--order-accent);
}

.order-day.is-selected .order-day__status::before {
  background: var(--order-accent);
  box-shadow: 0 0 0 4px rgba(155, 115, 72, 0.12);
}

.order-day[data-available="true"]:hover {
  background: rgba(94, 119, 93, 0.05);
}

.order-day[disabled],
.order-day[data-available="false"],
.order-slot[disabled],
.order-slot[data-available="false"] {
  cursor: default;
  opacity: 0.6;
}

.order-slot[disabled],
.order-slot[data-available="false"] {
  background: rgba(255, 255, 255, 0.28);
  color: var(--order-muted);
}

.order-slot[disabled]:hover,
.order-slot[data-available="false"]:hover {
  background: rgba(255, 255, 255, 0.28);
  transform: none;
}

.order-slot__status {
  font-family: "Montserrat", Arial, sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--order-booked);
}

.order-note {
  margin: 16px 0 0;
  color: var(--order-text-soft);
  font-size: 0.95rem;
}

.order-check {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  color: var(--order-text);
}

.order-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--order-accent);
}

.order-optional-block{
  padding:0 0 28px;
}

.order-optional-block + .order-optional-block{
  padding-top:28px;
  border-top:1px solid rgba(155,115,72,0.16);
}

.order-section__head--compact{
  margin-bottom:16px;
}

.order-section__head h3{
  margin:0 0 12px;
  max-width:none;
  font-family:Inter, Arial, sans-serif;
  font-size:0.78rem;
  line-height:1.2;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#9b7348;
}

.order-check-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}

.order-check-list .order-check span{
  font-family:Georgia, "Times New Roman", serif;
  font-style:italic;
  font-size:1.05rem;
  color:#5A473B;
}

.order-check-list .order-check{
  background:rgba(255,255,255,0.38);
  border-color:rgba(155,115,72,0.24);
}

.order-check--primary span{
  font-style:normal;
  font-family:"Inter", Arial, sans-serif;
  font-weight:600;
}

.order-check--primary{
  margin-bottom:2px;
}

.order-check:has(input:disabled){
  cursor:not-allowed;
  opacity:0.58;
}

.order-options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.order-option {
  padding: 11px 18px;
  border: 1px solid var(--order-border);
  border-radius: 999px;
  background: transparent;
  color: var(--order-text);
  font-size: 0.95rem;
  cursor: pointer;
  transition: all 0.18s ease;
}

.order-option:hover {
  border-color: rgba(155, 115, 72, 0.36);
}

.order-option.is-selected {
  background: var(--order-accent-soft);
  border-color: rgba(155, 115, 72, 0.4);
  color: var(--order-accent);
}

.order-summary {
  position: sticky;
  top: 154px;
  padding: 26px;
  border: 1px solid var(--order-border);
  border-radius: 22px;
  background: var(--order-card);
  backdrop-filter: blur(6px);
}

.order-summary__eyebrow {
  margin: 0 0 8px;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--order-accent);
  font-weight: 600;
}

.order-summary h2 {
  margin: 0 0 18px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 2.3rem;
  line-height: 1;
  font-weight: 500;
  color: var(--order-text);
}

.order-summary__body {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.order-summary__row {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--order-border);
}

.order-summary__row--total div {
  font-weight: 700;
}

.order-summary__label {
  display: block;
  margin-bottom: 6px;
  color: var(--order-accent);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 600;
}

.order-summary__row div {
  color: var(--order-text);
  line-height: 1.6;
}

.order-summary__cart {
  margin-top: 2px;
}

.order-summary__empty {
  margin: 0;
  color: var(--order-text-soft);
  font-size: 1rem;
  line-height: 1.5;
}

.order-summary__cart-item + .order-summary__cart-item {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--order-border);
}

.order-summary__cart-main,
.order-summary__cart-sub {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.order-summary__cart-main {
  margin-bottom: 2px;
}

.order-summary__cart-name {
  color: var(--order-text);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.4;
}

.order-summary__cart-qty {
  color: var(--order-text);
  font-weight: 600;
  white-space: nowrap;
}

.order-summary__cart-sub {
  color: var(--order-text-soft);
  font-size: 0.92rem;
  line-height: 1.4;
}

.order-summary__cart-line-total {
  color: var(--order-text);
  font-weight: 600;
  white-space: nowrap;
}

.order-summary__actions {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 24px;
}

.order-link {
  color: var(--order-text-soft);
  text-decoration: none;
}

.order-button,
.order-button-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  border: 0;
  background: var(--order-accent);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.18s ease;
}

.order-button:hover,
.order-button-secondary:hover {
  opacity: 0.9;
}

.order-button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.order-summary__note {
  margin-top: 10px;
  color: var(--order-text-soft);
  font-size: 0.95rem;
}

@media (max-width: 980px) {
  .order-layout {
    grid-template-columns: 1fr;
  }

  .order-summary {
    position: static;
  }
}

@media (max-width: 768px) {
  .df-order-guard {
    padding: 34px 0 80px;
  }

  .df-order-guard__inner {
    padding: 34px 22px;
  }

  .order-hero {
    padding: 28px 0 34px;
  }

  .order-section__head h2 {
    font-size: 2.2rem;
  }

  .order-day,
  .order-slot {
    align-items: flex-start;
    flex-direction: column;
  }

  .order-day__name,
  .order-slot {
    font-size: 1.45rem;
  }

  .order-eircode-row {
    flex-direction: column;
    align-items: stretch;
  }

  .order-day__name-wrap {
    gap: 10px;
  }
}

   ORDER PAGE V2 — PREMIUM EDITORIAL CHECKOUT
   ========================================================= */

.order-page{
  background:
    radial-gradient(circle at 88% 8%, rgba(184,146,69,0.08), transparent 34%),
    linear-gradient(180deg, #f8f4ee 0%, #f5f1ea 100%) !important;
  position: relative;
  overflow: hidden;
}

.order-page::before{
  content:"";
  position:absolute;
  right:-110px;
  top:120px;
  width:420px;
  height:420px;
  background-image:url('/images/icon_trays.png');
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  opacity:0.035;
  pointer-events:none;
}

.page-content{
  position:relative;
  z-index:1;
}

.order-hero{
  padding: 78px 0 48px;
  max-width: 1180px;
}

.order-eyebrow,
.order-step-label,
.order-summary__eyebrow{
  font-family:"Inter", Arial, sans-serif;
  color:#9b7348;
  letter-spacing:0.16em;
  text-transform:uppercase;
  font-weight:600;
}

.order-step-label{
  margin:0 0 10px;
  font-size:0.72rem;
  color:rgba(47,35,26,0.42) !important;
}

.order-hero h1{
  max-width: 860px;
  font-size: clamp(3.4rem, 6.8vw, 6.8rem);
  line-height:0.92;
  letter-spacing:-0.035em;
  margin-bottom:24px;
}

.order-intro{
  max-width: 780px;
  font-size: clamp(1.35rem, 2vw, 1.8rem);
  line-height:1.45;
}

.order-trust-strip{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:28px;
}

.order-trust-strip span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 14px;
  border:1px solid rgba(155,115,72,0.18);
  border-radius:999px;
  background:rgba(255,255,255,0.34);
  color:rgba(47,35,26,0.72);
  font-family:"Inter", Arial, sans-serif;
  font-size:0.86rem;
  font-weight:500;
}

.order-layout{
  grid-template-columns:minmax(0, 1fr) minmax(360px, 430px);
  gap:56px;
}

.order-layout.is-summary-hidden{
  grid-template-columns:minmax(0, 860px);
}

.order-main{
  gap:28px;
}

.order-section{
  padding:30px 0 32px;
  border-bottom:1px solid rgba(155,115,72,0.16);
  border-radius:18px;
  transition:background 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, padding 0.22s ease;
}

.order-section:first-child{
  padding-top:0;
}

.order-section.is-active-step{
  padding:30px 22px 32px;
  border-color:rgba(184,146,69,0.36);
  background:rgba(255,255,255,0.32);
  box-shadow:0 18px 42px rgba(63,43,31,0.08);
}

.order-section:first-child.is-active-step{
  padding-top:30px;
}

.order-section.is-active-step .order-step-label{
  color:rgba(47,35,26,0.42) !important;
}

.order-section__head h2{
  font-size:clamp(2.25rem, 3vw, 3.2rem);
  letter-spacing:-0.025em;
}

.order-section__head p{
  font-family:"Inter", Arial, sans-serif;
  color:rgba(47,35,26,0.68);
}

.order-button,
.order-button-secondary{
  min-height:54px;
  padding:0 26px;
  border-radius:16px;
  background:#B89245;
  font-family:"Inter", Arial, sans-serif;
  box-shadow:0 14px 30px rgba(63,43,31,0.12);
}

.order-button-secondary{
  white-space:nowrap;
}

.order-day,
.order-slot{
  padding:18px;
  border:1px solid rgba(155,115,72,0.16);
  border-radius:18px;
  background:rgba(255,255,255,0.22);
  box-shadow:0 10px 26px rgba(63,43,31,0.035);
}

.order-day:hover,
.order-slot:hover{
  opacity:1;
  background:rgba(255,255,255,0.42);
  transform:translateY(-1px);
}

.order-day.is-selected,
.order-slot.is-selected{
  border-color:rgba(184,146,69,0.45);
  background:rgba(184,146,69,0.11);
}

.order-day{
  display:flex;
  flex-direction:column;
  align-items:stretch;
}

.order-day__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  width:100%;
}

.order-window-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}

.order-window{
  min-height:44px;
  padding:0 16px;
  border:1px solid rgba(155,115,72,0.18);
  border-radius:14px;
  background:rgba(255,255,255,0.32);
  color:#2f231a;
  font-family:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  font-size:1rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:10px;
  transition:background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.order-window:hover{
  background:rgba(255,255,255,0.52);
  transform:translateY(-1px);
}

.order-window.is-selected{
  border-color:rgba(184,146,69,0.52);
  background:rgba(184,146,69,0.14);
  color:#9b7348;
}

.order-window[disabled],
.order-window[data-available="false"]{
  cursor:default;
  opacity:0.58;
  color:var(--order-muted);
}

.order-window[disabled]:hover,
.order-window[data-available="false"]:hover{
  background:rgba(255,255,255,0.32);
  transform:none;
}

.order-window span + span{
  color:var(--order-booked);
  font-size:0.78rem;
  text-transform:uppercase;
  letter-spacing:0.08em;
}

.order-window-list__empty{
  margin:0;
  color:var(--order-text-soft);
  font-family:"Inter", Arial, sans-serif;
  font-size:0.95rem;
}

.order-availability-panel{
  margin:0 0 18px;
  padding:20px;
  border:1px solid rgba(155,115,72,0.22);
  border-radius:18px;
  background:rgba(255,255,255,0.36);
}

.order-availability-panel[hidden]{
  display:none;
}

.order-availability-panel__eyebrow{
  margin:0 0 8px;
  font-family:"Inter", Arial, sans-serif;
  font-size:0.76rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:#9b7348;
}

.order-availability-panel__text{
  margin:0;
  color:rgba(47,35,26,0.76);
  font-size:1rem;
  line-height:1.55;
}

.order-availability-panel__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}

.order-delivery-help{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(155,115,72,0.16);
  color:var(--order-text-soft);
}

.order-delivery-help__title{
  margin:0 0 6px;
  color:var(--order-accent);
  font-family:"Inter", Arial, sans-serif;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.12em;
  line-height:1.25;
  text-transform:uppercase;
}

.order-delivery-help__text{
  margin:0 0 7px;
  color:var(--order-text);
  font-size:1rem;
  line-height:1.5;
}

.order-delivery-help__links{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  margin:0;
  font-family:"Inter", Arial, sans-serif;
  font-size:0.92rem;
  line-height:1.35;
}

.order-delivery-help__links a{
  color:var(--order-accent);
  font-weight:700;
  text-decoration:none;
}

.order-delivery-help__links a:hover{
  opacity:0.85;
}

.order-check{
  padding:18px;
  border:1px solid rgba(155,115,72,0.16);
  border-radius:18px;
  background:rgba(255,255,255,0.22);
  font-family:"Inter", Arial, sans-serif;
}

.order-option{
  min-height:46px;
  padding:0 18px;
  border-radius:14px;
  font-family:"Inter", Arial, sans-serif;
  background:rgba(255,255,255,0.20);
}

.order-summary{
  top:118px;
  padding:34px;
  border-radius:28px;
  background:rgba(248,244,238,0.72);
  border-color:rgba(155,115,72,0.22);
  backdrop-filter:blur(10px);
  box-shadow:0 22px 60px rgba(63,43,31,0.08);
}

.order-summary[hidden]{
  display:none;
}

.order-summary h2{
  font-size:clamp(3rem, 4vw, 4.2rem);
  letter-spacing:-0.035em;
}

.order-summary__row{
  padding:18px 0;
  border-bottom:1px solid rgba(155,115,72,0.18);
}

.order-summary__label{
  font-family:"Inter", Arial, sans-serif;
  font-size:0.78rem;
  letter-spacing:0.16em;
}

.order-summary__actions{
  margin-top:26px;
}

#goCheckout{
  width:100%;
  min-height:58px;
  border-radius:16px;
}

.order-summary__note,
.order-link{
  font-family:"Inter", Arial, sans-serif;
}

@media (max-width: 980px){
  .order-layout{
    grid-template-columns:1fr;
    gap:34px;
  }

  .order-summary{
    position:static;
  }
}

@media (max-width: 768px){
  .order-page::before{
    width:240px;
    height:240px;
    right:-90px;
    top:130px;
  }

  .order-hero{
    padding:44px 0 34px;
  }

  .order-hero h1{
    font-size:clamp(3rem, 16vw, 4.4rem);
    max-width:8ch;
  }

  .order-intro{
    font-size:1.24rem;
    max-width:28ch;
  }

  .order-button-secondary{
    width:100%;
    border-radius:18px;
  }

  .order-summary{
    padding:28px 24px;
    border-radius:24px;
  }

  .order-summary h2{
    font-size:3.6rem;
  }

  .order-section{
    scroll-margin-top:92px;
  }

  .order-section.is-active-step{
    padding:24px 16px 26px;
    margin-left:-16px;
    margin-right:-16px;
    border-radius:18px;
  }

  .order-section:first-child.is-active-step{
    padding-top:24px;
  }
}

/* =========================================================
   ORDER MANUAL REQUEST — CUSTOMER DETAILS + SUCCESS PAGE
   ========================================================= */

.order-customer-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px 24px;
}
.order-field--full{ grid-column:1 / -1; }
.order-input--textarea{ resize:vertical; min-height:96px; line-height:1.55; }
.order-summary__row #summaryCustomer,
.order-summary__row #summaryContact{ word-break:break-word; }

.order-summary__contact-line{
  display:flex;
  align-items:flex-start;
  gap:10px;
  line-height:1.5;
}

.order-summary__contact-line + .order-summary__contact-line{
  margin-top:8px;
}

.order-summary__contact-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 34px;
  min-width:34px;
  height:24px;
  border-radius:999px;
  background:rgba(155,115,72,0.12);
  color:#9b7348;
  font-family:Inter, Arial, sans-serif;
  font-size:0.72rem;
  font-weight:700;
  line-height:1;
}

.order-summary__detail-line{
  display:grid;
  grid-template-columns:minmax(96px, 0.42fr) minmax(0, 1fr);
  gap:12px;
  align-items:start;
  line-height:1.5;
  padding:10px 0 0;
}

.order-summary__detail-line + .order-summary__detail-line{
  margin-top:10px;
  border-top:1px solid rgba(155,115,72,0.12);
}

.order-summary__detail-label{
  color:rgba(63,44,34,0.58);
  font-family:Inter, Arial, sans-serif;
  font-size:0.72rem;
  font-weight:600;
  letter-spacing:0.10em;
  text-transform:uppercase;
}

.order-summary__detail-value{
  color:#3f2c22;
  font-family:Georgia, "Times New Roman", serif;
  font-size:1rem;
  line-height:1.5;
  word-break:break-word;
}

.order-summary__row > .order-summary__label{
  margin-bottom:12px !important;
  color:#9b7348 !important;
  font-family:Inter, Arial, sans-serif !important;
  font-size:0.84rem !important;
  font-weight:700 !important;
  letter-spacing:0.18em !important;
  text-transform:uppercase !important;
}

@media (max-width:768px){
  .order-summary__detail-line{
    grid-template-columns:1fr;
    gap:3px;
  }
}

/* Match Orders title with the main site title system */
.order-hero h1{
  margin: 0 0 14px !important;
  max-width: 22ch !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-size: 34px !important;
  line-height: 1.18 !important;
  font-weight: 500 !important;
  letter-spacing: -0.02em !important;
  color: #3f2c22 !important;
  text-wrap: balance;
}

@media (min-width: 1025px){
  .order-hero h1{
    font-size: clamp(46px, 4vw, 68px) !important;
    line-height: 1.08 !important;
    margin-bottom: 16px !important;
  }
}

@media (max-width: 768px){
  .order-hero h1{
    max-width: 22ch !important;
    font-size: 32px !important;
    line-height: 1.18 !important;
  }
}

.order-eyebrow{
  margin: 0 0 14px !important;
  font-family: Inter, Arial, sans-serif !important;
  font-size: 0.85rem !important;
  line-height: 1.2 !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #6e6258 !important;
}

.order-intro{
  max-width: 70ch !important;
  margin: 0 !important;
  color: #5A473B !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  font-style: normal !important;
  text-wrap: normal !important;
}

@media (max-width: 768px){
  .order-intro{
    width: 100% !important;
    max-width: none !important;
    font-size: 18px !important;
    line-height: 1.6 !important;
  }
}

/* Match order step titles with the main site title system */
.order-section__head h2{
  margin: 0 0 14px !important;
  max-width: 22ch !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-size: 34px !important;
  line-height: 1.18 !important;
  font-weight: 500 !important;
  letter-spacing: -0.02em !important;
  color: #3f2c22 !important;
  text-wrap: balance;
}

@media (min-width: 1025px){
  .order-section__head h2{
    font-size: clamp(46px, 4vw, 68px) !important;
    line-height: 1.08 !important;
    margin-bottom: 16px !important;
  }
}

@media (max-width: 768px){
  .order-section__head h2{
    max-width: 22ch !important;
    font-size: 32px !important;
    line-height: 1.18 !important;
  }

  .order-section__head h3{
    font-size: 0.78rem;
    line-height: 1.2;
  }
}

/* Match order step body copy with the main intro copy */
.order-section__head p{
  max-width: 70ch !important;
  margin: 0 !important;
  color: #5A473B !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  font-style: normal !important;
  text-wrap: normal !important;
}

@media (max-width: 768px){
  .order-section__head p{
    width: 100% !important;
    max-width: none !important;
    font-size: 18px !important;
    line-height: 1.6 !important;
  }
}

.order-summary__note{
  color: #5A473B !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  font-style: normal !important;
}

.order-success-page{ min-height:70vh; }
.order-success-hero{ padding:78px 0 36px; max-width:920px; }
.order-success-hero h1{
  margin: 0 0 14px !important;
  max-width: 22ch !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-size: 34px !important;
  line-height: 1.18 !important;
  font-weight: 500 !important;
  letter-spacing: -0.02em !important;
  color: #3f2c22 !important;
  text-wrap: balance;
}

.order-success-hero .order-intro{
  max-width: 70ch !important;
  margin: 0 !important;
  color: #5A473B !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  font-style: normal !important;
  text-wrap: normal !important;
}
.order-success-card{
  max-width:860px;
  margin:0 0 100px;
  padding:34px;
  border:1px solid rgba(155,115,72,0.22);
  border-radius:28px;
  background:rgba(248,244,238,0.74);
  box-shadow:0 22px 60px rgba(63,43,31,0.08);
}
.order-success-card h2{
  margin:0 0 24px;
  font-family:"Cormorant Garamond", Georgia, serif;
  font-size:clamp(2.8rem, 4vw, 4.2rem);
  line-height:1;
  font-weight:500;
}
.order-success-reference{
  display:inline-flex;
  margin-bottom:22px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(184,146,69,0.14);
  color:#9b7348;
  font-family:"Inter", Arial, sans-serif;
  font-weight:600;
}
.order-success-block{ padding:18px 0; border-top:1px solid rgba(155,115,72,0.18); }
.order-success-block p{ margin:0 0 8px; line-height:1.6; }
.order-success-line{ display:flex; justify-content:space-between; gap:18px; padding:8px 0; }
.order-success-line--total{ margin-top:8px; padding-top:14px; border-top:1px solid rgba(155,115,72,0.18); font-size:1.15rem; }
.order-success-actions{ display:flex; flex-wrap:wrap; gap:16px; align-items:center; margin-top:24px; }

@media (max-width:768px){
  .order-customer-grid{ grid-template-columns:1fr; gap:14px; }
  .order-success-hero{ padding:44px 0 28px; }
  .order-success-hero h1{
    max-width: 22ch !important;
    font-size: 32px !important;
    line-height: 1.18 !important;
  }
  .order-success-hero .order-intro{
    width: 100% !important;
    max-width: none !important;
    font-size: 18px !important;
    line-height: 1.6 !important;
  }
  .order-success-card{ padding:28px 22px; border-radius:24px; margin-bottom:72px; }
}

@media (min-width:1025px){
  .order-success-hero h1{
    font-size: clamp(46px, 4vw, 68px) !important;
    line-height: 1.08 !important;
    margin-bottom: 16px !important;
  }
}

/* =========================================================
   ORDER DESKTOP - wide pattern, visible steps, sticky summary
   ========================================================= */
@media (min-width:1025px){
  .order-page{
    background:#f7f3ee !important;
  }

  .order-hero-pattern{
    width:100vw !important;
    height:clamp(420px, 30vw, 620px) !important;
    margin-left:calc(50% - 50vw) !important;
    margin-right:calc(50% - 50vw) !important;
    margin-bottom:46px !important;
    background:#efe6d8 url("/images/order-abstract-pattern-desktop.png") center center / cover no-repeat !important;
  }

  .order-hero{
    max-width:none !important;
    padding:38px 42px 42px !important;
    margin:0 auto 54px !important;
    border-radius:18px !important;
    background:#efe6d8 !important;
    text-align:center !important;
  }

  .order-eyebrow{
    margin:0 0 12px !important;
    font-family:Inter, Arial, sans-serif !important;
    font-size:16px !important;
    line-height:1.2 !important;
    letter-spacing:0.16em !important;
    font-weight:600 !important;
    text-transform:uppercase !important;
    color:#6f6258 !important;
  }

  .order-hero h1{
    max-width:none !important;
    margin:0 auto 18px !important;
    font-family:"Cormorant Garamond", Georgia, serif !important;
    font-size:clamp(46px, 4vw, 68px) !important;
    line-height:1.08 !important;
    font-weight:500 !important;
    letter-spacing:-0.01em !important;
    color:#3f2c22 !important;
    text-align:center !important;
  }

  .order-intro{
    max-width:760px !important;
    margin:0 auto !important;
    font-family:Georgia, "Times New Roman", serif !important;
    font-size:19px !important;
    line-height:1.6 !important;
    font-weight:400 !important;
    color:#5A473B !important;
    text-align:center !important;
    font-style:normal !important;
  }

  .order-layout,
  .order-layout.is-summary-hidden{
    display:grid !important;
    grid-template-columns:minmax(0, 1fr) minmax(360px, 430px) !important;
    gap:56px !important;
    align-items:start !important;
    padding-bottom:100px !important;
  }

  #deliveryWrap,
  #slotWrap,
  #addressWrap,
  #customerWrap,
  #optionalWrap{
    display:block !important;
  }

  .order-summary,
  .order-summary[hidden]{
    display:block !important;
    position:sticky !important;
    top:118px !important;
    visibility:visible !important;
  }

  .order-section{
    scroll-margin-top:118px !important;
  }
}

/* Final shared eyebrow normalization */
.order-eyebrow,
.order-summary__eyebrow,
.df-order-guard__eyebrow{
  margin: 0 0 10px !important;
  font-family: Inter, Arial, sans-serif !important;
  font-size: 0.78rem !important;
  line-height: 1.2 !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #6f6258 !important;
}
/* Order hero aligned with Delivery & Support */
.order-hero-pattern{
  position: relative !important;
  display: block !important;
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  background:
    linear-gradient(rgba(239, 230, 216, 0.88), rgba(239, 230, 216, 0.88)),
    url("/images/logo.png") center center / 360px auto no-repeat,
    #efe6d8 !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: center center, center center, center center !important;
  overflow: hidden !important;
}

.order-hero-pattern::after,
.order-hero-pattern::before{
  content: "" !important;
  position: absolute !important;
  aspect-ratio: 1 / 1 !important;
  background: url("/images/icon_trays.png") center center / contain no-repeat !important;
  pointer-events: none !important;
}

.order-hero-pattern::after{
  left: clamp(34px, 5vw, 76px) !important;
  bottom: clamp(28px, 4vw, 58px) !important;
}

.order-hero-pattern::before{
  right: clamp(34px, 5vw, 76px) !important;
  top: clamp(28px, 4vw, 58px) !important;
}

@media (min-width: 1025px){
  .order-hero-pattern{
    height: clamp(420px, 30vw, 620px) !important;
    margin-bottom: 46px !important;
    background-size: auto, 360px auto, auto !important;
  }

  .order-hero-pattern::after,
  .order-hero-pattern::before{
    width: clamp(92px, 9vw, 138px) !important;
    opacity: 0.16 !important;
  }
}

@media (max-width: 768px){
  .order-hero-pattern{
    height: auto !important;
    max-height: 420px !important;
    aspect-ratio: 1.7 / 1 !important;
    margin-bottom: 28px !important;
    background-size: auto, 250px auto, auto !important;
  }

  .order-hero-pattern::after,
  .order-hero-pattern::before{
    width: 82px !important;
    opacity: 0.14 !important;
  }

  .order-hero-pattern::after{
    left: 22px !important;
    bottom: 20px !important;
  }

  .order-hero-pattern::before{
    right: 22px !important;
    top: 20px !important;
  }
}

/* Order guard uses the same hero when the order form is hidden */
.df-order-guard{
  padding-top: 0 !important;
}

.df-order-guard::before{
  content: "" !important;
  position: relative !important;
  display: block !important;
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  background:
    linear-gradient(rgba(239, 230, 216, 0.88), rgba(239, 230, 216, 0.88)),
    url("/images/logo.png") center center / 360px auto no-repeat,
    #efe6d8 !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: center center, center center, center center !important;
}

@media (min-width: 1025px){
  .df-order-guard::before{
    height: clamp(420px, 30vw, 620px) !important;
    margin-bottom: 46px !important;
    background-size: auto, 360px auto, auto !important;
  }
}

@media (max-width: 768px){
  .df-order-guard::before{
    height: auto !important;
    max-height: 420px !important;
    aspect-ratio: 1.7 / 1 !important;
    margin-bottom: 28px !important;
    background-size: auto, 250px auto, auto !important;
  }
}

/* Mobile: remove the top hero image/pattern */
@media (max-width: 768px){
  .order-hero{
    padding-top: 34px !important;
  }

  .df-order-guard__inner{
    margin-top: 34px !important;
  }

  .order-hero-pattern,
  .df-order-guard::before{
    display: none !important;
    content: none !important;
  }
}
