html, body {
  overflow-x: hidden;
}
    :root {
      --gold:       #CBA36B;
      --gold-light: #dfc49a;
      --gold-dark:  #a07d4a;
      --clr-ink:    #18272E;
      --dark:       #1C2F36;
      --dark-2:     #243840;
      --cream:      #FAF6F0;
      --cream-2:    #f0e9de;
      --white:      #ffffff;
      --text:       #2a2a2a;
      --text-light: #556068;
      --text-muted: #7a8d93;
      --error: #c0392b;
      --shadow-card: 0 24px 80px rgba(24, 39, 46, 0.13);
      --shadow-badge: 0 8px 32px rgba(201, 160, 90, 0.35);
      --clr-parchment:  #F5EFE4;
      --clr-parchment2: #EDE5D8;

      --transition: 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    }

    html { scroll-behavior: smooth; }

    /* ── BUTOANE — animatie slide stanga-dreapta ── */
    .btn-gold {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: var(--gold);
      color: var(--white);
      padding: 16px 30px;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      text-decoration: none;
      transition: color 0.35s cubic-bezier(0.4,0,0.2,1);
      border: none;
      cursor: pointer;
      position: relative;
      overflow: hidden;
    }

    .btn-gold::before {
      content: '';
      position: absolute;
      inset: 0;
      background: var(--white);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
    }

    .btn-gold:hover::before { transform: scaleX(1); }
    .btn-gold:hover { color: var(--gold); }
    .btn-gold span { position: relative; z-index: 1; }
    .btn-gold-full { width: 100%; }


    .btn-gold-2::before{
      background: var(--dark);
      color: var(--white) !important;
    }

    .btn-gold-2:hover { color: var(--white) !important; }

    /* ── HERO ── */
    .herolf{
      background: #FAF6F0;
      padding: 0px;
    }

    .herolf-banner-wrap{
      padding: 140px 0 70px 0;
    }

    @media(max-width: 767px){
      .herolf-banner-wrap{
        padding: 120px 0 70px 0;
      }
    }

    .herolf-banner-wrap img { width: 100%; object-fit: contain; }

    .herolf-content {
      background: linear-gradient(135deg, var(--dark) 0%, var(--dark-2) 60%, #0a1a1f 100%);
      padding: 70px 0 70px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }

    .herolf-content::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at 50% 0%, rgba(203,163,107,.15) 0%, transparent 70%);
      pointer-events: none;
    }

    .herolf-content .eyebrow {
      font-weight: 500;
      font-size: 15px;
      line-height: 20px;
      letter-spacing: 1px;
      color: var(--gold);
      text-transform: uppercase;
      margin-bottom: 14px;
    }

    .herolf-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 40px;
      font-weight: 400;
      color: var(--white);
      line-height: 1.1;
      margin-bottom: 18px;
    }
    @media(max-width: 767px){
      .herolf-title{
        font-size: 35px;
      }
    }

    .herolf-title font { 
      color: var(--gold); 
    }

    .herolf-sub {
      font-size: 16px;
      font-weight: 400;
      color: rgba(255,255,255,.6);
      line-height: 1.75;
    }

    .herolf-meta {
      font-size: 14px;
      color: rgba(255,255,255,.5);
      margin-top: 18px;
      display: block;
      position: relative;
    }

    .herolf-sold-out {
      font-family: 'DM Sans', sans-serif;
      letter-spacing: 3px;
      font-size: 13px;
      font-weight: 500;
      color: var(--gold);
    }

    /* ── DESPRE (SEC. 2) ── */
    .section-about-wrap { background: #FAF6F0; padding: 70px 0px; }


    
    /* ── PREMIU (SEC. 3) ── */
    .section-prize { background: var(--dark); padding: 70px 0px; }
    .prize-header{
      padding-bottom: 30px;
    }
    .prize-header-lead {
      color: rgba(255,255,255,.6);
      font-style: normal;
      font-weight: 400;
      font-size: 16px;
      max-width: 700px;
      margin: 0 auto;
      line-height: 1.5;
    }

    .prize-header-lead strong { color: var(--gold); font-weight: 600; }

    .prize-sublabel {
      font-family: 'DM Sans', sans-serif;
      font-size: 11px;
      font-weight: 600;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--gold);
      text-align: center;
      margin-bottom: 32px;
      display: block;
    }

    .prize-item {
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(203,163,107,.15);
      padding: 20px 20px;
      text-align: center;
      transition: all 0.3s;
    }

    .prize-item:hover {
      background: rgba(203,163,107,.08);
      border-color: rgba(203,163,107,.4);
      transform: translateY(-4px);
    }

    .prize-icon {  
      width: 60px;
      filter: invert(96%) sepia(19%) saturate(4917%) hue-rotate(304deg) brightness(85%) contrast(86%);
      margin-bottom: 15px;
    }

    .prize-item h4 {
      color: var(--white);
      font-size: 18px;
      font-weight: 500;
      margin-bottom: 8px;
    }

    .prize-item p {
      color: rgba(255,255,255,.6);
      font-size: 15px;
      line-height: 1.5;
      font-weight: 300;
      margin-bottom: 0px;
    }

    .prize-exclude-box {
      margin: 48px auto 0;
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(203,163,107,.2);
      padding: 30px 30px;
    }

    .prize-exclude-text {
      color: rgba(255,255,255,.6);
      font-size: 16px;
      line-height: 1.5;
      font-weight: 400;
      margin-bottom: 0px;
    }

    .prize-cta { text-align: center; margin-top: 50px; }

    .prize-note {
      color: rgba(255,255,255,.5);
      font-size: 14px;
      font-weight: 400;
      margin-top: 20px;
      display: block;
    }

    /* ── CUM PARTICIPI (SEC. 4) ── */
    .section-how { background: var(--cream); padding: 70px 0px; }

    .steps { display: grid; grid-template-columns: 1fr 1fr 1fr; position: relative; }

    .steps::before {
      content: '';
      position: absolute;
      top: 40px;
      left: 16.66%; right: 16.66%;
      height: 1px;
      background: linear-gradient(90deg, var(--gold), rgba(203,163,107,.25), var(--gold));
    }

    .step { padding: 0 40px; text-align: center; }

    .step-num {
      width: 64px; height: 64px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);
      color: var(--white);
      font-size: 24px;
      font-weight: 400;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 20px;
      position: relative;
      z-index: 1;
    }

    .step h3 {
      font-size: 18px;
      font-weight: 500;
      color: var(--dark);
      margin-bottom: 14px;
    }

    .step p {
      font-size: 15px;
      font-weight: 400;
      color: var(--text-light);
      line-height: 1.5;
    }

    .how-cta { text-align: center; margin-top: 50px; }

    @media(max-width: 767px){
      .how-cta{
        margin-top: 20px;
      }
    }

    /* ── BENEFICII SEARĂ (SEC. 5) ── */
    .section-benefits { background: var(--cream); padding: 70px 0px; }


    .benefits-list { list-style: none; margin-top: 20px; padding-left: 0px;}

    .benefits-list li {
      display: flex;
      align-items: center;
      gap: 16px;
      padding: 10px 0;
      border-bottom: 1px solid var(--cream-2);
      font-size: 16px;
      font-weight: 400;
      line-height: 1.5;
      color: var(--text);
    }

    .benefits-list li:last-child { border-bottom: none; }

    .benefits-list .check {
      width: 26px; height: 26px;
      background: linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);
      color: var(--white);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      font-size: 12px;
      font-weight: 700;
    }

    .benefits-visual {
      background: var(--dark);
      padding: 30px;
      text-align: center;
    }

    .price-tag {
      font-size: 40px;
      font-weight: 400;
      color: var(--gold);
      line-height: 1;
    }

    .price-label {
      color: rgba(255,255,255,.6);
      font-size: 14px;
      font-weight: 400;
      letter-spacing: 3px;
      text-transform: uppercase;
      margin-bottom: 20px;
      display: block;
    }

    .price-divider {
      width: 64px; height: 1px;
      background: var(--gold);
      margin: 0 auto 20px;
      opacity: .5;
    }

    .price-access {
      color: rgba(255,255,255,.6);
      font-size: 16px;
      font-weight: 400;
      line-height: 1.5;
    }

    .price-access strong { color: var(--white); font-weight: 500; font-style: normal; }

    .price-note {
      color: rgba(255,255,255,.5);
      font-size: 14px;
      font-weight: 400;
      margin-top: 32px;
      line-height: 1.5;
      display: block;
    }

    .benefits-btn-wrap { margin-top: 32px; }

    /* ── POVEȘTI (SEC. 6) ── */
    .section-stories { background: var(--cream); padding: 70px 0px; }
    .couple-card {
      background: var(--white);
      margin-bottom: 50px;
      overflow: hidden;
      box-shadow: 0 2px 24px rgba(28,47,54,.07);
    }

    .couple-top { display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; }

    .couple-info { padding: 30px 30px; display: flex; flex-direction: column; justify-content: center; }

    .story-year-badge {
      display: inline-block;
      background: linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);
      color: var(--white);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 3px;
      padding: 6px 16px;
      margin-bottom: 20px;
      align-self: flex-start;
    }

    .couple-info h3 {
      font-family: 'Cormorant Garamond', serif;
      font-size: 25px;
      font-weight: 500;
      color: var(--dark);
      margin-bottom: 15px;
    }

    .couple-info p {
      font-size: 16px;
      font-weight: 400;
      line-height: 1.5;
      margin-bottom: 0px;
    }

    .couple-event-owl {
      background: var(--dark-2);
      min-height: 420px;
      overflow: hidden;
      position: relative;
    }

    .couple-event-owl .owl-item img {
      width: 100%; height: 420px;
      object-fit: cover;
      background: var(--dark-2);
      display: block;
    }

    .couple-wedding-wrap {
      border-top: 2px solid var(--cream);
      background: var(--dark);
      padding: 8px 0;
    }

    .wed-label {
      text-align: center;
      font-size: 15px;
      font-weight: 500;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--gold);
      padding: 12px 24px 12px;
      display: block;
    }

    .couple-wedding-owl .owl-item img {
      width: 100%; height: 300px;
      object-fit: cover;
      background: var(--dark-2);
      display: block;
      padding: 4px;
    }

    .couple-event-owl .owl-nav {
      position: absolute;
      top: 50%; transform: translateY(-50%);
      width: 100%;
      display: flex !important;
      justify-content: space-between;
      padding: 0 8px;
      pointer-events: none;
    }
    .couple-event-owl .owl-nav button { pointer-events: all; }
    .couple-event-owl .owl-dots,
    .couple-wedding-owl .owl-dots { padding: 8px 0 4px; }

    .owl-carousel .owl-nav button.owl-prev,
    .owl-carousel .owl-nav button.owl-next {
      background: rgba(28,47,54,.85) !important;
      border: 1px solid rgba(203,163,107,.35) !important;
      color: var(--gold) !important;
      width: 40px; height: 40px;
      border-radius: 0 !important;
      font-size: 18px !important;
      line-height: 1 !important;
      transition: all 0.3s;
      margin: 0 2px;
    }
    .owl-carousel .owl-nav button.owl-prev:hover,
    .owl-carousel .owl-nav button.owl-next:hover {
      background: var(--gold) !important;
      color: var(--dark) !important;
    }
    .owl-carousel .owl-dots .owl-dot span {
      background: rgba(255,255,255,.3) !important;
      width: 7px; height: 7px;
      transition: all 0.3s;
    }
    .owl-carousel .owl-dots .owl-dot.active span,
    .owl-carousel .owl-dots .owl-dot:hover span {
      background: var(--gold) !important;
      width: 20px;
      border-radius: 4px;
    }

    /* ── PARTENERI (SEC. 7) ── */
    .section-partners { background: var(--dark); padding: 100px 40px; }
    .partners-inner { max-width: 1200px; margin: 0 auto; }
    .partners-header { text-align: center; margin-bottom: 60px; }

    .partners-header-sub {
      color: rgba(255,255,255,.45);
      font-family: 'DM Sans', sans-serif;
      font-size: 17px;
      font-weight: 300;
      font-style: italic;
      margin-top: 16px;
      display: block;
    }

    .partners-slider-wrap { position: relative; overflow: hidden; }

    .partners-track {
      display: flex;
      gap: 24px;
      transition: transform 0.5s ease;
    }

    .partner-card {
      flex-shrink: 0;
      width: calc(20% - 20px);
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(203,163,107,.15);
      padding: 32px 24px;
      text-align: center;
      transition: all 0.3s;
    }

    .partner-card:hover {
      background: rgba(203,163,107,.06);
      border-color: rgba(203,163,107,.35);
    }

    .partner-logo {
      width: 80px; height: 80px;
      margin: 0 auto 16px;
      background: rgba(255,255,255,.06);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
    }

    .partner-logo img {
      width: 100%; height: 100%;
      object-fit: contain;
      filter: brightness(0) invert(1);
      opacity: .7;
      transition: opacity 0.3s;
    }

    .partner-card:hover .partner-logo img { opacity: 1; }

    .partner-logo-placeholder {
      width: 44px; height: 44px;
      background: rgba(203,163,107,.2);
      border-radius: 50%;
    }

    .partner-name {
      color: rgba(255,255,255,.65);
      font-family: 'DM Sans', sans-serif;
      font-size: 13px;
      font-weight: 400;
      letter-spacing: 1px;
    }

    .partners-nav {
      display: flex;
      justify-content: center;
      gap: 12px;
      margin-top: 36px;
    }

    .partners-nav button {
      background: rgba(203,163,107,.1);
      border: 1px solid rgba(203,163,107,.3);
      color: var(--gold);
      width: 44px; height: 44px;
      cursor: pointer;
      transition: all 0.3s;
      font-size: 18px;
    }

    .partners-nav button:hover { background: var(--gold); color: var(--dark); }

    /* ── DETALII (SEC. 8) ── */
    .section-details { background: var(--cream); padding: 70px 0px; }

    .details-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }

    .detail-item {
      background: var(--white);
      padding: 30px 30px;
      text-align: center;
      border-bottom: 3px solid var(--gold);
      box-shadow: 0 2px 16px rgba(28,47,54,.06);
    }

    .detail-icon { 
      width: 60px;
      filter: invert(96%) sepia(19%) saturate(4917%) hue-rotate(304deg) brightness(85%) contrast(86%);
      margin-bottom: 16px;
    }

    .detail-item h4 {
      font-size: 16px;
      font-weight: 600;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--dark);
      margin-bottom: 10px;
    }

    .detail-item p {
      font-size: 15px;
      font-weight: 500;
      color: var(--gold);
      line-height: 1.55;
      margin-bottom: 0px !important; 
    }

    .detail-item small {
      display: block;
      font-size: 14px;
      font-weight: 400;
      color: var(--text-muted);
      margin-top: 6px;
      margin-bottom: 0px;
    }

    /* ── FAQ (SEC. 9) ── */
    .section-faq { background: var(--white); padding: 70px 0px; }
    .faq-item { border-bottom: 1px solid var(--cream-2); }

    .faq-question {
      width: 100%;
      background: none;
      border: none;
      padding: 20px 0;
      display: flex;
      align-items: center;
      justify-content: space-between;
      cursor: pointer;
      gap: 24px;
      text-align: left;
    }

    .faq-question h3 {
      font-size: 17px;
      font-weight: 500;
      color: var(--dark);
    }

    .faq-icon {
      width: 30px; height: 30px;
      background: var(--cream-2);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      color: var(--gold);
      font-size: 20px;
      line-height: 30px;
      transition: all 0.3s;
    }

    .faq-item.open .faq-icon { background: var(--gold); color: var(--dark); transform: rotate(45deg); }

    .faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s ease; }
    .faq-item.open .faq-answer { max-height: 400px; }

    .faq-answer p {
      font-size: 16px;
      font-weight: 400;
      line-height: 1.5;
      margin-bottom: 15px;
    }

    .faq-answer p strong { color: var(--dark); font-weight: 600; }

    .faq-pdf { text-align: center; margin-top: 48px; }

    .faq-pdf a {
      color: var(--gold);
      font-size: 16px;
      font-weight: 500;
      letter-spacing: 1px;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      transition: color 0.3s;
    }

    .faq-pdf a:hover { color: var(--dark); }

    /* ── CTA FINAL (SEC. 10) — cu imagine background ── */
    .section-cta-final {
      position: relative;
      padding: 140px 40px;
      text-align: center;
      overflow: hidden;
    }

    .section-cta-final::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: url('cta1.jpg'); /* pune imaginea ta */
      background-size: cover;
      background-position: center;
      z-index: 0;
    }

    .section-cta-final::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(28,47,54,.90) 0%, rgba(10,20,24,.78) 100%);
      z-index: 1;
    }

    .cta-final-inner {
      position: relative;
      z-index: 2;
      max-width: 700px;
      margin: 0 auto;
    }

    .cta-final-lead {
      font-size: 16px;
      font-weight: 400;
      color: rgba(255,255,255,.6);
      margin-bottom: 30px;
      line-height: 1.5;
      display: block;
    }

    .cta-final-note {
      font-size: 14px;
      letter-spacing: 2px;
      color: rgba(255,255,255,.5);
      margin-top: 20px;
      display: block;
    }

    .cta-sold-out {
      letter-spacing: 3px;
      font-size: 14px;
      font-weight: 400;
      color: var(--gold);
    }


    /* ── RESPONSIVE ── */
    @media (max-width: 1100px) {
      .prize-grid { grid-template-columns: repeat(3, 1fr); }
      .section-about, .benefits-inner { grid-template-columns: 1fr; gap: 48px; }
      .partner-card { width: calc(33.33% - 16px); }
    }

    @media (max-width: 768px) {
      .section-cta-final::before { background-attachment: scroll; }
      .steps { grid-template-columns: 1fr; }
      .steps::before { display: none; }
      .step { padding: 20px 0; }
      .prize-grid { grid-template-columns: repeat(2, 1fr); }
      .prize-exclude-box { padding: 28px 24px; }
      .details-grid { grid-template-columns: 1fr; }
      .partner-card { width: calc(50% - 12px); }
      .couple-top { grid-template-columns: 1fr; }
      .couple-info { padding: 30px 25px; }
      .couple-event-owl { min-height: 280px; }
      .couple-event-owl .owl-item img { height: 280px; }
      .couple-event-owl .slide-placeholder { height: 280px; }
      .couple-wedding-owl .owl-item img { height: 220px; }
      .couple-wedding-owl .slide-placeholder { height: 220px; }
    }

    @media (max-width: 480px) {
      .prize-grid { grid-template-columns: 1fr 1fr; }
      .partner-card { width: calc(50% - 12px); }
    }


  .herolf-banner-wrap{
      padding: 140px 0 70px 0;
      background: var(--cream);
    }

    @media(max-width: 767px){
      .herolf-banner-wrap{
        padding: 120px 0 70px 0;
      }
    }

    .checkout-wrap {
     display: grid;
     grid-template-columns: 1fr 400px;
     gap: 48px;
     align-items: start;
}
 .form-section {
     background: var(--white);
}
 .form-header {
     background: var(--dark);
     padding: 25px 25px;
}
 .form-header p {
     font-size: 15px;
     letter-spacing: 2px;
     color: var(--gold);
     text-transform: uppercase;
     margin-bottom: 8px;
}
 .form-header h1 {
     font-family: 'Cormorant Garamond', serif;
     color: var(--white);
     font-size: 25px;
}
 .form-body {
     padding: 20px;
}
 .form-group-title {
     font-size: 15px;
     letter-spacing: 1px;
     text-transform: uppercase;
     color: var(--gold);
     margin-bottom: 20px;
     padding-bottom: 10px;
     border-bottom: 1px solid var(--cream-2);
}
 .form-grid {
     display: grid;
     grid-template-columns: 1fr 1fr;
     gap: 20px;
}
 .field {
     display: flex;
     flex-direction: column;
     gap: 6px;
}
 .field.span2 {
     grid-column: 1 / -1;
}
 label {
     font-size: 13px;
     font-weight: 500;
     letter-spacing: 1.5px;
     text-transform: uppercase;
     color: var(--text-light);
}
 label .req {
     color: var(--gold);
}
 input[type="text"], input[type="email"], input[type="tel"], input[type="password"], select {
     width: 100%;
     padding: 10px 16px;
     border: 1.5px solid #e0d9cf;
     background: var(--cream);
     font-size: 15px;
     color: var(--text);
     outline: none;
     transition: border-color 0.3s;
     -webkit-appearance: none;
}
 select {
     background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23CBA36B' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
     background-repeat: no-repeat;
     background-position: right 16px center;
     padding-right: 40px;
     cursor: pointer;
}
 input:focus, select:focus {
     border-color: var(--gold);
     background: var(--white);
}
input::placeholder {
  color: rgba(0,0,0,0.6);
}
 .field-error {
     font-size: 12px;
     color: var(--error);
     display: none;
}
 .field.has-error .field-error {
     display: block;
}
 .field.has-error input, .field.has-error select {
     border-color: var(--error);
}
 .form-divider {
     margin: 20px 0;
     border: none;
     border-top: 1px solid var(--cream-2);
}
 .checkbox-wrap {
     display: flex;
     align-items: flex-start;
     gap: 12px;
     cursor: pointer;
     margin-bottom: 32px;
}
 .checkbox-wrap input[type="checkbox"] {
     width: 16px;
     height: 16px;
     min-width: 16px;
     accent-color: var(--gold);
     cursor: pointer;
     margin-top: 2px;
}
 .checkbox-wrap p {
     font-size: 15px;
     line-height: 1.6;
     color: var(--text-light);
     text-transform: none;
     margin-bottom: 0px;
}
 .checkbox-wrap a {
     color: var(--gold);
     text-decoration: none;
}
 .checkbox-wrap a:hover {
     text-decoration: underline;
}

 .secure-note {
     text-align: center;
     margin-top: 16px;
     font-size: 14px;
     color: var(--text-light);
     letter-spacing: 1px;
}
 .global-error {
     background: #ffeaea;
     border-left: 4px solid var(--error);
     padding: 16px 20px;
     margin-bottom: 24px;
     font-size: 15px;
     color: var(--error);
     display: none;
}
 .global-error.show {
     display: block;
}
/* ORDER SUMMARY */
 .order-summary {
     position: sticky;
     top: 24px;
}
 .summary-box {
     background: var(--dark);
     padding: 25px 20px;
}
 .summary-box .summary-label {
     font-size: 15px;
     letter-spacing: 2px;
     color: var(--gold);
     text-transform: uppercase;
     margin-bottom: 15px;
}
 .summary-ticket {
     background: rgba(203,163,107,0.08);
     border: 1px solid rgba(203,163,107,0.2);
     padding: 20px;
     margin-bottom: 24px;
}
 .summary-ticket h3 {
     font-family: 'Cormorant Garamond', serif;
     color: var(--white);
     font-size: 22px;
     margin-bottom: 20px;
}
 .summary-row {
     display: flex;
     justify-content: space-between;
     align-items: center;
     padding: 10px 0;
     border-bottom: 1px solid rgba(255,255,255,0.06);
}
 .summary-row:last-child {
     border-bottom: none;
}
 .summary-row span:first-child {
     color: rgba(255,255,255,0.6);
     font-size: 14px;
     letter-spacing: 1px;
}
 .summary-row span:last-child {
     color: var(--white);
     font-size: 15px;
}
 .summary-total {
     display: flex;
     justify-content: space-between;
     align-items: center;
     padding-top: 10px;
     border-top: 1px solid rgba(203,163,107,0.3);
}
 .summary-total .total-label {
     font-size: 14px;
     letter-spacing: 2px;
     color: var(--gold);
     text-transform: uppercase;
}
 .summary-total .total-price {
     font-size: 25px;
     color: var(--gold);
}
 .summary-total .total-price small {
     font-size: 16px;
     color: rgba(255,255,255,0.5);
}
 .summary-includes {
     margin-top: 15px;
     padding-top: 20px;
     border-top: 1px solid rgba(255,255,255,0.07);
}
 .summary-includes p {
     font-size: 14px;
     letter-spacing: 2px;
     color: var(--gold);
     text-transform: uppercase;
     margin-bottom: 10px;
}
 .summary-includes ul {
     list-style: none;
     padding: 0px;
}
 .summary-includes li {
     color: rgba(255,255,255,0.6);
     font-size: 14px;
     padding: 6px 0;
     display: flex;
     align-items: center;
     gap: 8px;
}
 .summary-includes li::before {
     content: '✓';
     color: var(--gold);
     font-size: 14px;
}
 .summary-euplatesc {
     margin-top: 24px;
     display: flex;
     align-items: center;
     justify-content: center;
     gap: 12px;
     padding: 16px;
     background: rgba(255,255,255,0.03);
}
 .summary-euplatesc span {
     color: rgba(255,255,255,0.4);
     font-size: 13px;
     letter-spacing: 1px;
}
 @media (max-width: 900px) {
     .checkout-wrap {
         grid-template-columns: 1fr;
    }
     .order-summary {
         position: static;
    }
     .form-grid {
         grid-template-columns: 1fr;
    }
     .field.span2 {
         grid-column: auto;
        padding: 14px 20px;
    }
}


    .confirmation-page {
      background-color: var(--cream);
      min-height: 100vh;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 140px 0 70px 0;
      background-image:
        radial-gradient(ellipse at 20% 0%, rgba(201,160,90,0.08) 0%, transparent 60%),
        radial-gradient(ellipse at 80% 100%, rgba(24,39,46,0.06) 0%, transparent 60%);
    }

    @media(max-width: 767px){
      .confirmation-page {
        padding: 120px 0 70px 0;
      }
    }

    /* ─── Card ───────────────────────────────────────────────── */
    .confirmation-card {
      background: var(--white);
      max-width: 600px;
      width: 100%;
      box-shadow: var(--shadow-card);
      overflow: hidden;
      animation: card-rise 0.6s cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    @keyframes card-rise {
      from { opacity: 0; transform: translateY(28px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ─── Card › Hero ────────────────────────────────────────── */
    .confirmation-card__hero {
      background: var(--clr-ink);
      padding: 40px 20px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }

    .confirmation-card__hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background: repeating-linear-gradient(
        -45deg,
        rgba(255,255,255,0.015) 0px,
        rgba(255,255,255,0.015) 1px,
        transparent 1px,
        transparent 12px
      );
      pointer-events: none;
    }

    /* ─── Card › Hero › Badge ────────────────────────────────── */
    .hero-badge {
      width: 72px;
      height: 72px;
      background: linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 100%);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 24px;
      box-shadow: var(--shadow-badge);
      animation: badge-pop 0.5s 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) both;
    }

    @keyframes badge-pop {
      from { opacity: 0; transform: scale(0.5); }
      to   { opacity: 1; transform: scale(1); }
    }

    .hero-badge__icon {
      font-size: 28px;
      color: var(--clr-ink);
      line-height: 1;
    }

    /* ─── Card › Hero › Titles ───────────────────────────────── */
    .hero-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 30px;
      font-weight: 600;
      color: var(--white);
      letter-spacing: 2px;
      margin-bottom: 0px;
    }
    @media(max-width: 767px){
      .hero-title{
        font-size: 25px;
      }
    }

    /* ─── Card › Body ────────────────────────────────────────── */
    .confirmation-card__body {
      padding: 20px;
    }

    /* ─── Email note ─────────────────────────────────────────── */
    .email-note {
      font-size: 16px;
      color: var(--muted);
      line-height: 1.5;
      margin-bottom: 20px;
      text-align: center;
    }

    .email-note__address {
      color: var(--clr-ink);
      font-weight: 500;
    }

    /* ─── Order summary ──────────────────────────────────────── */
    .order-summary {
      background: var(--clr-parchment);
      border: 1px solid var(--clr-parchment2);
      border-radius: var(--radius-sm);
      overflow: hidden;
      margin-bottom: 0px;
    }

    .order-summary__row {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      gap: 16px;
      padding: 13px 20px;
      border-bottom: 1px solid var(--clr-parchment2);
      font-size: 15px;
    }

    .order-summary__row:last-child {
      border-bottom: none;
    }

    .order-summary__label {
      color: var(--clr-muted);
      font-weight: 400;
      white-space: nowrap;
    }

    .order-summary__value {
      font-weight: 600;
      color: var(--clr-ink);
      text-align: right;
    }

    .order-summary__value--accent {
      color: var(--gold);
      font-size: 16px;
    }

    /* ─── Actions ────────────────────────────────────────────── */
    .confirmation-actions {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 20px;
    }
    @media (max-width: 520px) {
      .confirmation-card__hero  { padding: 40px 28px 36px; }
      .confirmation-card__body  { padding: 32px 24px 36px; }
      .hero-title               { font-size: 26px; }
      .order-summary__row       { flex-direction: column; gap: 3px; }
      .order-summary__value     { text-align: left; }
    }

 /* ── TOMBOLA PREMII SECUNDARE ── */
.section-tombola {
  background: var(--dark);
  padding: 70px 0;
}

.tombola-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 10px;
}

.tombola-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(203,163,107,.15);
  padding: 30px 30px;
  text-align: center;
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
}

.tombola-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--gold), var(--gold-dark));
}

.tombola-card:hover {
  background: rgba(203,163,107,.07);
  border-color: rgba(203,163,107,.35);
  transform: translateY(-4px);
}

.tombola-qty {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--gold);
  color: var(--dark);
  font-size: 20px;
  font-weight: 700;
  border-radius: 50%;
  margin: 0 auto 25px;
}

.tombola-discount {
  font-size: 40px;
  font-weight: 300;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 5px;
}

.tombola-discount-label {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  margin-bottom: 10px;
  display: block;
}

.tombola-divider {
  width: 40px;
  height: 1px;
  background: rgba(203,163,107,.3);
  margin: 0 auto 20px;
}

.tombola-desc {
  font-size: 14px;
  font-weight: 400;
  color: rgba(255,255,255,.5);
  line-height: 1.5;
  margin-bottom: 0px;
}

.tombola-prizes-note {
  text-align: center;
  margin-top: 30px;
  font-size: 14px;
  color: rgba(255,255,255,.5);
  letter-spacing: 1px;
  margin-bottom: 0px;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .tombola-grid { grid-template-columns: 1fr; gap: 16px; }
  .tombola-discount {
    font-size: 35px;
  }
}


/* ── Checkout extras ── */
    .ticket-selector {
      border: 1.5px solid #e2e8f0;
      border-radius: 6px;
      padding: 10px 15px;
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      background: #FAF6F0;
      transition: border-color 0.2s, background 0.2s;
    }
    .ticket-selector.has-qty {
      border-color: #CBA36B;
      background: rgba(203,163,107,.05);
    }
    .ticket-selector.couple-fixed {
      border-color: #CBA36B;
      background: rgba(203,163,107,.05);
    }
    .ticket-selector-info { flex: 1; }
    .ticket-selector-name { font-weight: 600; font-size: 15px; color: #1C2F36; }
    .ticket-selector-desc { font-size: 12px; color: #64748b; margin-top: 2px; }
    .ticket-selector-price { font-size: 16px; font-weight: 700; color: #CBA36B; white-space: nowrap; }
    .ticket-selector-avail { font-size: 11px; color: #94a3b8; margin-top: 2px; text-align: right; }

    .qty-control {
      display: flex;
      align-items: center;
      gap: 0;
      border: 1.5px solid #e2e8f0;
      border-radius: 0px;
      overflow: hidden;
    }
    .qty-btn {
      width: 30px; height: 30px;
      background: #f8fafc;
      border: none;
      cursor: pointer;
      font-size: 18px;
      font-weight: 300;
      color: #1C2F36;
      transition: background 0.2s;
      display: flex; align-items: center; justify-content: center;
      line-height: 1;
    }
    .qty-btn:hover { background: #CBA36B; color: #fff; }
    .qty-btn:disabled { opacity: 0.3; cursor: default; }
    .qty-input {
      width: 44px; height: 30px;
      border: none; border-left: 1.5px solid #e2e8f0; border-right: 1.5px solid #e2e8f0;
      text-align: center;
      font-size: 14px; font-weight: 600;
      background: #fff;
      outline: none;
    }

    .couple-badge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: rgba(203,163,107,.15);
      color: #a07d4a;
      font-size: 12px;
      font-weight: 600;
      padding: 4px 10px;
      border-radius: 20px;
    }

    .cart-total-line {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 10px 0;
      border-top: 1px solid #1C2F36;
      margin-top: 0px;
    }
    .cart-total-label { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #1C2F36; }
    .cart-total-amount { font-size: 18px; font-weight: 700; color: #CBA36B; }

    .cart-error { color: #e74c3c; font-size: 13px; margin-top: 8px; }

    .account-box {
      background: rgba(203,163,107,.05);
      border: 1px solid #CBA36B;
      border-radius: 6px;
      padding: 20px;
      margin-top: 16px;
    }
    .account-box-title { font-size: 18px; font-weight: 600; color: #1C2F36; margin-bottom: 4px; }
    .account-box-sub   { font-size: 15px; color: #64748b; margin-bottom: 16px; line-height: 1.5; }
    .account-logged    { display: flex; align-items: center; gap: 10px; }
    .account-avatar    { width: 36px; height: 36px; background: #CBA36B; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; color: #1C2F36; font-size: 14px; flex-shrink: 0; }