:root {
  --page-max-width: 720px;
  --page-padding-x: 20px;
  --page-padding-top: 48px;
  --page-padding-bottom: 64px;
  --text-color: #2c241d;
  --background-color: #fbf8f3;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--background-color);
  color: var(--text-color);
}

.policy-page {
  max-width: var(--page-max-width);
  margin: 0 auto;
  padding: var(--page-padding-top) var(--page-padding-x) var(--page-padding-bottom);
}

.policy-page h1 {
  font-family: "Cormorant Garamond", serif;
  font-size: 36px;
  line-height: 1.1;
  font-weight: 500;
  margin: 0 0 24px;
}

.policy-page h2 {
  font-family: "Cormorant Garamond", serif;
  font-size: 24px;
  line-height: 1.2;
  font-weight: 500;
  margin: 40px 0 12px;
}

.policy-page p,
.policy-page li {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  line-height: 1.65;
  font-weight: 400;
}

.policy-page p {
  margin: 0 0 16px;
}

.policy-page ul {
  margin: 0 0 16px;
  padding-left: 20px;
}

.policy-page li {
  margin-bottom: 8px;
}

.policy-page strong {
  font-weight: 600;
}

@media (max-width: 768px) {
  :root {
    --page-padding-x: 18px;
    --page-padding-top: 36px;
    --page-padding-bottom: 56px;
  }

  .policy-page h1 {
    font-size: 32px;
    margin-bottom: 20px;
  }

  .policy-page h2 {
    font-size: 22px;
    margin-top: 32px;
    margin-bottom: 10px;
  }

  .policy-page p,
  .policy-page li {
    font-size: 15px;
    line-height: 1.65;
  }
}


/* =========================================================
   DOLCE FORNO — DELIVERY & SUPPORT PAGE ENHANCEMENTS
   ========================================================= */

.delivery-support-page{
  background: #fbf8f3;
}

.policy-page{
  max-width: none;
  margin: 0;
  padding: 0 0 80px;
  background: #fbf8f3;
}

.policy-page-inner{
  width: min(820px, calc(100% - 40px));
  margin: 0 auto;
}

.policy-hero{
  padding: 160px 0 36px;
  background: linear-gradient(to bottom, rgba(251,248,243,0.98), rgba(251,248,243,1));
}

.policy-kicker{
  font-family: Inter, Arial, sans-serif;
  font-size: 0.85rem;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #6e6258;
  margin: 0 0 14px;
  text-align: left;
}

.policy-page h1{
  max-width: 22ch;
  margin: 0 0 14px;
  text-align: left;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 34px;
  line-height: 1.18;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: #3f2c22;
}

.policy-page .policy-lead{
  max-width: 70ch;
  margin: 0;
  text-align: left;
  color: #5A473B;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6;
}

.policy-content{
  padding-top: 12px;
}

.policy-section{
  background: #f3e8dc;
  border: 1px solid rgba(184,146,69,0.24);
  border-radius: 22px;
  padding: 30px 30px 24px;
  margin-bottom: 18px;
  box-shadow: 0 12px 30px rgba(63,43,31,0.06);
}

.policy-section h2{
  margin-top: 0;
}

.policy-section p,
.policy-section li{
  color: #5A473B;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6;
}

.policy-section p:last-child,
.policy-section ul:last-child{
  margin-bottom: 0;
}

@media (max-width: 768px){
  .policy-page{
    padding-bottom: 64px;
  }

  .policy-page-inner{
    width: min(820px, calc(100% - 28px));
  }

  .policy-hero{
    padding: 124px 0 24px;
  }

  .policy-section{
    border-radius: 18px;
    padding: 22px 20px 18px;
    margin-bottom: 14px;
  }

  .policy-kicker{
    margin-bottom: 12px;
  }
}

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

@media (max-width: 768px){
  .policy-page h1{
    font-size: 32px;
    line-height: 1.18;
  }
}
