:root{
    --ivory:        #F6EFDD;
    --ivory-2:      #FBF6E9;
    --parchment:    #EFE6CC;
    --navy:         #0E2148;
    --navy-2:       #16305F;
    --navy-deep:    #0A1936;
    --gold:         #B8893E;
    --gold-soft:    #D4AF6A;
    --gold-bright:  #E8C97C;
    --ink:          #2A2418;
    --ink-soft:     #5B5240;
    --line:         rgba(184,137,62,.35);
    --line-soft:    rgba(184,137,62,.18);
    --shadow:       0 10px 40px -18px rgba(14,33,72,.35), 0 2px 6px -2px rgba(14,33,72,.10);
  }

  *,*::before,*::after{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;
    font-family:'Inter',system-ui,sans-serif;
    color:var(--ink);
    background:var(--ivory);
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    line-height:1.6;
  }
  /* subtle parchment texture */
  body::before{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
    background:
      radial-gradient(ellipse at 10% 0%, rgba(212,175,106,.10), transparent 60%),
      radial-gradient(ellipse at 90% 100%, rgba(14,33,72,.06), transparent 55%);
  }
  main, header, footer, nav { position:relative; z-index:1; }

  h1,h2,h3,h4{
    font-family:'Cormorant Garamond', 'Garamond', serif;
    font-weight:500;
    color:var(--navy);
    letter-spacing:.005em;
    margin:0;
    line-height:1.08;
  }
  p{margin:0}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}

  /* ---------- shared ornaments ---------- */
  .eyebrow{
    font-family:'Inter',sans-serif;
    font-size:11px;
    font-weight:600;
    letter-spacing:.32em;
    text-transform:uppercase;
    color:var(--gold);
    display:inline-flex;
    align-items:center;
    gap:14px;
  }
  .eyebrow::before, .eyebrow::after{
    content:"";
    width:36px;height:1px;
    background:linear-gradient(90deg,transparent,var(--gold),transparent);
  }
  .eyebrow.left::before{display:none}
  .eyebrow.left{padding-left:0}

  .rule-gold{
    height:1px;
    background:linear-gradient(90deg,transparent,var(--gold) 20%,var(--gold) 80%,transparent);
    margin:0 auto;
  }

  .gold-diamond{
    display:inline-block;width:6px;height:6px;
    background:var(--gold);transform:rotate(45deg);
    margin:0 14px;vertical-align:middle;
  }

  /* ---------- nav ---------- */
  .topbar{
    position:sticky;top:0;z-index:50;
    background:rgba(246,239,221,.85);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom:1px solid var(--line-soft);
  }
  .nav-inner{
    max-width:1240px;margin:0 auto;
    padding:14px 32px;
    display:flex;align-items:center;justify-content:space-between;gap:20px;
  }
  .brand{
    display:flex;align-items:center;gap:12px;
    font-family:'Cormorant Garamond',serif;
    color:var(--navy);
  }
  .brand .crest{
    width:34px;height:34px;border:1px solid var(--gold);
    display:grid;place-items:center;color:var(--gold);
    font-size:16px;
  }
  .brand-text{display:flex;flex-direction:column;line-height:1.1}
  .brand-text .b1{font-size:13px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-family:'Inter',sans-serif;font-weight:600}
  .brand-text .b2{font-size:18px;color:var(--navy);font-style:italic}
  .nav-links{display:flex;gap:6px}
  .nav-links a{
    font-size:13px;font-weight:500;
    padding:8px 14px;border-radius:999px;
    color:var(--navy);
    transition:background .2s,color .2s;
  }
  .nav-links a:hover{background:var(--navy);color:var(--ivory-2)}
  .nav-links a.active{color:var(--gold)}
  .nav-cta{
    display:inline-flex;align-items:center;gap:8px;
    padding:10px 18px;border-radius:999px;
    background:var(--navy);color:var(--ivory-2);
    font-size:13px;font-weight:600;letter-spacing:.04em;
    border:1px solid var(--navy);
    box-shadow:inset 0 0 0 1px rgba(212,175,106,.45);
    transition:transform .15s, background .2s;
  }
  .nav-cta:hover{background:var(--navy-2);transform:translateY(-1px)}
  .nav-burger{display:none;background:none;border:1px solid var(--line);padding:8px 10px;border-radius:8px;color:var(--navy);cursor:pointer}
  .nav-burger svg{display:block}

  @media (max-width: 960px){
    .nav-links, .nav-cta{display:none}
    .nav-burger{display:inline-flex}
    .nav-inner{padding:12px 18px}
    .nav-links.open{
      display:flex;flex-direction:column;gap:0;
      position:absolute;top:100%;left:0;right:0;
      background:var(--ivory-2);border-bottom:1px solid var(--line);
      padding:8px 18px 16px;
    }
    .nav-links.open a{padding:12px 8px;border-bottom:1px solid var(--line-soft);border-radius:0}
  }

  /* ---------- hero ---------- */
  .hero{
    position:relative;
    padding:0 0 56px;
    overflow:hidden;
    background:
      linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(246,239,221,.86) 28%, var(--ivory) 100%);
  }
  .hero-inner{
    width:min(1720px, 100vw);
    max-width:none;
    margin:0 auto;
  }
  .hero-banner{
    position:relative;
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    overflow:hidden;
    box-shadow:0 24px 64px -42px rgba(14,33,72,.42);
  }
  .hero-banner::after{
    content:"";position:absolute;inset:0;
    box-shadow:
      inset 0 -1px 0 rgba(184,137,62,.28),
      inset 0 24px 48px -36px rgba(255,255,255,.22);
    pointer-events:none;
  }
  .hero-banner img{
    width:100%;
    display:block;
  }

  .hero-meta{
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
    gap:28px;
    margin-top:28px;
    max-width:1180px;
    margin-left:auto;
    margin-right:auto;
  }
  .hero-meta .mline{
    height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
  }
  .hero-meta .mcenter{
    display:flex;align-items:center;gap:12px;
    color:var(--navy);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;
  }

  .hero-cta{
    display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:28px;
    max-width:1180px;
    margin-left:auto;
    margin-right:auto;
  }
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:14px 26px;
    border-radius:999px;
    font-size:14px;font-weight:600;letter-spacing:.04em;
    cursor:pointer;border:1px solid transparent;
    transition:transform .15s, background .2s, color .2s, border-color .2s;
    font-family:'Inter',sans-serif;
  }
  .btn-primary{
    background:var(--navy);color:var(--ivory-2);
    border-color:var(--navy);
    box-shadow:inset 0 0 0 1px rgba(212,175,106,.55), 0 12px 28px -16px rgba(14,33,72,.5);
  }
  .btn-primary:hover{background:var(--navy-2);transform:translateY(-1px)}
  .btn-gold{
    background:linear-gradient(180deg,var(--gold-soft),var(--gold));
    color:var(--navy-deep);
    border-color:var(--gold);
  }
  .btn-gold:hover{transform:translateY(-1px)}
  .btn-ghost{
    background:transparent;color:var(--navy);
    border-color:var(--gold);
  }
  .btn-ghost:hover{background:var(--navy);color:var(--ivory-2);border-color:var(--navy)}
  .btn .ic{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}

  .hero-quick{
    display:flex;flex-wrap:wrap;gap:24px 36px;justify-content:center;
    margin-top:24px;
    color:var(--ink-soft);font-size:13px;
    max-width:1180px;
    margin-left:auto;
    margin-right:auto;
  }
  .hero-quick .qi{display:inline-flex;align-items:center;gap:8px}
  .hero-quick .qi svg{color:var(--gold)}

  @media (max-width:720px){
    .hero{padding:0 0 44px}
    .hero-inner{width:100vw}
    .hero-meta{grid-template-columns:1fr;gap:14px}
    .hero-meta .mline{display:none}
    .hero-meta .mcenter{font-size:18px;justify-content:center}
  }

  /* ---------- generic section ---------- */
  section{padding:96px 24px;position:relative}
  .container{max-width:1180px;margin:0 auto}
  .section-head{text-align:center;margin-bottom:56px}
  .section-head h2{
    font-size:clamp(34px,5vw,56px);
    margin-top:14px;
  }
  .section-head .sub{
    margin-top:14px;
    font-family:'Cormorant Garamond',serif;font-style:italic;
    color:var(--ink-soft);font-size:20px;
    max-width:640px;margin-left:auto;margin-right:auto;
  }

  /* ---------- about ---------- */
  .about{
    background:
      linear-gradient(180deg, var(--ivory) 0%, var(--ivory-2) 100%);
    border-top:1px solid var(--line-soft);
    border-bottom:1px solid var(--line-soft);
  }
  .about-grid{
    display:grid;
    grid-template-columns: 1.1fr 1fr;
    gap:64px;align-items:center;
  }
  .about-copy h2{font-size:clamp(36px,4.5vw,54px);margin-top:18px}
  .about-copy p{margin-top:24px;font-size:17px;color:var(--ink-soft);max-width:520px}
  .about-copy .pull{
    margin-top:32px;padding:24px 28px;
    border-left:2px solid var(--gold);
    background:rgba(255,255,255,.5);
    font-family:'Cormorant Garamond',serif;font-style:italic;
    font-size:22px;color:var(--navy);
    line-height:1.4;
  }
  .about-art{
    position:relative;aspect-ratio: 2/3;
    border:1px solid var(--line);
    box-shadow: var(--shadow);
    overflow:hidden;
    background:var(--parchment);
  }
  .about-art img{width:100%;height:100%;object-fit:cover;object-position:center top}
  .about-art .corner{
    position:absolute;width:36px;height:36px;border:1.5px solid var(--gold);
  }
  .about-art .corner.tl{top:14px;left:14px;border-right:none;border-bottom:none}
  .about-art .corner.tr{top:14px;right:14px;border-left:none;border-bottom:none}
  .about-art .corner.bl{bottom:14px;left:14px;border-right:none;border-top:none}
  .about-art .corner.br{bottom:14px;right:14px;border-left:none;border-top:none}

  @media (max-width:880px){
    .about-grid{grid-template-columns:1fr;gap:40px}
    .about-art{max-width:480px;margin:0 auto;aspect-ratio:2/3;width:100%}
  }

  /* ---------- atrações ---------- */
  .speakers{background:var(--ivory)}
  .speakers-grid{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:24px;
  }
  .sp-card{
    position:relative;
    background:linear-gradient(180deg,#fff,var(--ivory-2));
    border:1px solid var(--line-soft);
    padding:36px 32px;
    display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;
    transition:transform .25s, box-shadow .25s, border-color .25s;
  }
  .sp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}
  .sp-card .corner{position:absolute;width:18px;height:18px;border:1px solid var(--gold)}
  .sp-card .corner.tl{top:8px;left:8px;border-right:none;border-bottom:none}
  .sp-card .corner.br{bottom:8px;right:8px;border-left:none;border-top:none}
  .sp-portrait{
    width:112px;
    height:112px;
    border-radius:50%;
    border:1px solid rgba(184,137,62,.72);
    background:
      radial-gradient(circle at 50% 22%, rgba(255,255,255,.82), rgba(255,255,255,.12) 70%),
      linear-gradient(180deg, var(--ivory-2), var(--parchment));
    box-shadow:
      inset 0 0 0 6px rgba(255,255,255,.74),
      0 10px 26px -18px rgba(14,33,72,.55);
    overflow:hidden;
    flex-shrink:0;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0;
  }
  .sp-portrait img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 28%;
    display:block;
  }
  .sp-card h3{font-size:26px}
  .sp-card .role{
    margin-top:6px;font-size:11px;font-weight:600;letter-spacing:.28em;
    text-transform:uppercase;color:var(--gold);
  }
  .sp-card .desc{margin-top:14px;color:var(--ink-soft);font-size:15px}
  .sp-card .day{
    margin-top:14px;display:inline-flex;align-items:center;gap:8px;
    font-size:12px;color:var(--navy);
    padding:5px 12px;border:1px solid var(--line);border-radius:999px;
    background:rgba(255,255,255,.6);
  }
  .sp-card .day .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
  @media (max-width:720px){
    .speakers-grid{grid-template-columns:1fr}
    .sp-card{grid-template-columns:1fr;text-align:center;justify-items:center}
    .sp-portrait{margin:0 auto}
  }

  /* ---------- programação ---------- */
  .program{
    background:var(--navy);
    color:var(--ivory-2);
    overflow:hidden;
  }
  .program::before{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:
      radial-gradient(ellipse at 0% 0%, rgba(212,175,106,.12), transparent 50%),
      radial-gradient(ellipse at 100% 100%, rgba(212,175,106,.10), transparent 55%);
  }
  .program h2{color:var(--ivory-2)}
  .program .eyebrow{color:var(--gold-bright)}
  .program .eyebrow::before,.program .eyebrow::after{background:linear-gradient(90deg,transparent,var(--gold-bright),transparent)}
  .program .sub{color:rgba(246,239,221,.7)}
  .prog-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:32px;
    margin-top:8px;
  }
  .prog-day{
    border:1px solid rgba(212,175,106,.3);
    background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
    padding:40px 36px;
    position:relative;
  }
  .prog-day .dnum{
    font-family:'Cormorant Garamond',serif;
    font-size:96px;line-height:1;color:var(--gold-bright);
    font-weight:500;letter-spacing:-.02em;
  }
  .prog-day .dlabel{
    margin-top:6px;
    font-size:11px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;
    color:rgba(246,239,221,.6);
  }
  .prog-day h3{
    color:var(--ivory-2);
    font-size:32px;margin-top:16px;
    font-style:italic;font-family:'Cormorant Garamond',serif;
  }
  .prog-day .start{
    margin-top:14px;display:inline-flex;align-items:center;gap:8px;
    font-size:13px;color:var(--gold-bright);
    padding:6px 14px;border:1px solid rgba(212,175,106,.4);border-radius:999px;
  }
  .prog-list{margin-top:28px;list-style:none;padding:0;display:flex;flex-direction:column;gap:0}
  .prog-list li{
    padding:18px 0;
    border-top:1px solid rgba(212,175,106,.18);
    display:grid;grid-template-columns:24px 1fr;gap:14px;align-items:start;
    color:rgba(246,239,221,.92);
    font-size:15px;
  }
  .prog-list li:last-child{border-bottom:1px solid rgba(212,175,106,.18)}
  .prog-list li .marker{
    color:var(--gold-bright);font-family:'Cormorant Garamond',serif;font-size:18px;
    line-height:1.2;
  }
  .prog-list li .t{font-weight:500}
  .prog-list li .d{display:block;margin-top:4px;color:rgba(246,239,221,.6);font-size:13px}

  @media (max-width:880px){
    .prog-grid{grid-template-columns:1fr;gap:20px}
    .prog-day{padding:32px 24px}
    .prog-day .dnum{font-size:72px}
  }

  /* ---------- ingressos ---------- */
  .tickets{background:var(--ivory-2)}
  .tickets-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:28px;
  }
  .tk-card{
    position:relative;
    background:#fff;
    border:1px solid var(--line);
    padding:44px 40px;
    display:flex;flex-direction:column;
    transition:transform .25s, box-shadow .25s;
  }
  .tk-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
  .tk-card.featured{
    background:linear-gradient(180deg,#fff,#FEF8E6);
    border-color:var(--gold);
  }
  .tk-card.featured::before{
    content:"Mais completo";
    position:absolute;top:-12px;left:40px;
    background:var(--navy);color:var(--gold-bright);
    font-size:10px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
    padding:6px 14px;border:1px solid var(--gold);
  }
  .tk-card .corner{position:absolute;width:24px;height:24px;border:1px solid var(--gold)}
  .tk-card .corner.tl{top:10px;left:10px;border-right:none;border-bottom:none}
  .tk-card .corner.tr{top:10px;right:10px;border-left:none;border-bottom:none}
  .tk-card .corner.bl{bottom:10px;left:10px;border-right:none;border-top:none}
  .tk-card .corner.br{bottom:10px;right:10px;border-left:none;border-top:none}

  .tk-label{
    font-size:11px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;
    color:var(--gold);
  }
  .tk-card h3{font-size:34px;margin-top:10px}
  .tk-price{
    margin-top:22px;
    display:flex;align-items:baseline;gap:10px;
    font-family:'Cormorant Garamond',serif;
    color:var(--navy);
  }
  .tk-price .cur{font-size:18px;font-style:italic}
  .tk-price .num{font-size:64px;font-weight:600;letter-spacing:-.02em;line-height:1}
  .tk-price .per{font-size:14px;color:var(--ink-soft);font-family:'Inter',sans-serif;font-style:normal}
  .tk-divider{height:1px;background:var(--line-soft);margin:28px 0}
  .tk-includes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
  .tk-includes li{display:grid;grid-template-columns:18px 1fr;gap:12px;align-items:start;color:var(--ink);font-size:15px}
  .tk-includes li svg{color:var(--gold);margin-top:3px}
  .tk-card .btn{margin-top:34px;justify-content:center}

  @media (max-width:880px){
    .tickets-grid{grid-template-columns:1fr}
    .tk-card{padding:36px 28px}
  }

  /* ---------- video ---------- */
  .video{background:var(--ivory)}
  .video-frame{
    position:relative;aspect-ratio:16/9;width:100%;
    background:var(--navy-deep);
    border:1px solid var(--gold);
    box-shadow: 0 30px 80px -30px rgba(14,33,72,.45);
    overflow:hidden;
  }
  .video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
  .video-frame .placeholder{
    position:absolute;inset:0;display:grid;place-items:center;cursor:pointer;
    background:
      radial-gradient(ellipse at center, rgba(212,175,106,.18), transparent 60%),
      linear-gradient(180deg, rgba(14,33,72,.6), rgba(10,25,54,.85));
    color:var(--ivory-2);
  }
  .video-frame .play{
    width:84px;height:84px;border-radius:50%;
    background:linear-gradient(180deg,var(--gold-soft),var(--gold));
    display:grid;place-items:center;color:var(--navy-deep);
    box-shadow:0 12px 40px -10px rgba(212,175,106,.6);
    transition:transform .2s;
  }
  .video-frame:hover .play{transform:scale(1.06)}
  .video-frame .ph-text{
    position:absolute;bottom:32px;left:32px;right:32px;
    font-family:'Cormorant Garamond',serif;font-style:italic;font-size:22px;
    color:rgba(246,239,221,.9);
  }

  /* ---------- whatsapp ---------- */
  .whatsapp{
    background:linear-gradient(180deg,var(--ivory-2), var(--ivory));
  }
  .wa-card{
    max-width:880px;margin:0 auto;
    background:#fff;
    border:1px solid var(--line);
    padding:60px 56px;
    text-align:center;
    position:relative;
  }
  .wa-card .corner{position:absolute;width:30px;height:30px;border:1px solid var(--gold)}
  .wa-card .corner.tl{top:14px;left:14px;border-right:none;border-bottom:none}
  .wa-card .corner.tr{top:14px;right:14px;border-left:none;border-bottom:none}
  .wa-card .corner.bl{bottom:14px;left:14px;border-right:none;border-top:none}
  .wa-card .corner.br{bottom:14px;right:14px;border-left:none;border-top:none}
  .wa-card h2{font-size:42px;margin-top:14px}
  .wa-card p{margin-top:18px;color:var(--ink-soft);font-size:17px;max-width:520px;margin-left:auto;margin-right:auto}
  .wa-card .actions{margin-top:32px;display:flex;flex-wrap:wrap;justify-content:center;gap:14px}

  /* ---------- local ---------- */
  .local{background:var(--ivory)}
  .local-grid{
    display:grid;grid-template-columns: 1fr 1.2fr; gap:48px;align-items:stretch;
  }
  .local-info{
    background:#fff;border:1px solid var(--line-soft);
    padding:44px 40px;
    display:flex;flex-direction:column;justify-content:center;
    position:relative;
  }
  .local-info h3{font-size:34px;margin-top:10px}
  .addr{
    margin-top:22px;font-size:16px;color:var(--ink-soft);
    line-height:1.6;
  }
  .addr strong{color:var(--ink);font-weight:600;display:block;font-size:17px;margin-bottom:6px;font-family:'Inter',sans-serif}
  .local-meta{margin-top:28px;display:grid;grid-template-columns:1fr;gap:14px}
  .local-meta .mi{
    display:flex;align-items:center;gap:14px;
    padding:14px 16px;border:1px solid var(--line-soft);
    background:var(--ivory-2);
    font-size:14px;
  }
  .local-meta .mi svg{color:var(--gold);flex-shrink:0}
  .local-meta .mi b{color:var(--navy);font-weight:600;display:block;font-family:'Inter',sans-serif}
  .local-meta .mi span{display:block;color:var(--ink-soft);font-size:13px;margin-top:2px}

  .local-map{
    position:relative;
    border:1px solid var(--line-soft);
    overflow:hidden;
    min-height:420px;
    background:var(--parchment);
  }
  .local-map iframe{width:100%;height:100%;border:0;position:absolute;inset:0;filter:sepia(.18) saturate(.9) contrast(.95)}

  @media (max-width:880px){
    .local-grid{grid-template-columns:1fr}
    .local-map{min-height:320px}
  }

  /* ---------- footer ---------- */
  footer{
    background:var(--navy-deep);color:rgba(246,239,221,.85);
    padding:56px 24px 32px;
    border-top:1px solid var(--gold);
  }
  .footer-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px}
  .footer-inner h4{color:var(--gold-bright);font-family:'Inter',sans-serif;font-size:11px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;margin-bottom:18px}
  .footer-inner p,.footer-inner a{font-size:14px;color:rgba(246,239,221,.7);line-height:1.7}
  .footer-inner a:hover{color:var(--gold-bright)}
  .footer-brand .b1{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-bright);font-weight:600}
  .footer-brand .b2{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--ivory-2);margin-top:8px;font-style:italic}
  .footer-brand p{margin-top:14px;max-width:340px}
  .footer-list{display:flex;flex-direction:column;gap:8px}
  .footer-bottom{
    max-width:1180px;margin:48px auto 0;padding-top:24px;
    border-top:1px solid rgba(212,175,106,.2);
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
    font-size:12px;color:rgba(246,239,221,.5);letter-spacing:.04em;
  }
  @media (max-width:720px){
    .footer-inner{grid-template-columns:1fr;gap:32px}
  }

  /* reveal */
  .reveal{opacity:0;transform:translateY(14px);transition:opacity .8s ease, transform .8s ease}
  .reveal.in{opacity:1;transform:none}

  .sp-card.photo-card{
    grid-template-columns:112px 1fr;
    min-height:220px;
    align-items:center;
  }
  .sp-card.photo-card .desc{
    max-width:420px;
  }
  @media (max-width:720px){
    .sp-card.photo-card{grid-template-columns:1fr}
    .sp-card.photo-card .desc{max-width:none}
    .sp-portrait{
      width:120px;
      height:120px;
      margin:0 auto 6px;
    }
  }

/* ============== MODAL DE PRÉ-CADASTRO ============== */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(20,16,8,.72);backdrop-filter:blur(4px)}
.modal-card{position:relative;width:100%;max-width:520px;background:#fff;border:1px solid rgba(184,137,62,.35);padding:36px 32px;box-shadow:0 30px 80px rgba(0,0,0,.35);max-height:92vh;overflow-y:auto}
.modal-card .eyebrow{display:block;margin-bottom:12px}
.modal-card h3{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--ink);margin:0 0 10px;line-height:1.2}
.modal-sub{color:var(--ink-soft);font-size:14px;line-height:1.55;margin:0 0 18px}
.modal-summary{background:rgba(184,137,62,.08);border-left:2px solid var(--gold);padding:10px 14px;margin-bottom:20px;font-size:13px;color:var(--ink)}
.modal-summary strong{color:var(--gold)}
.modal-close{position:absolute;top:10px;right:12px;background:none;border:0;font-size:28px;line-height:1;color:var(--ink-soft);cursor:pointer;padding:4px 10px}
.modal-close:hover{color:var(--gold)}
.field{display:block;margin-bottom:14px}
.field>span{display:block;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px;font-family:'Inter',sans-serif;font-weight:600}
.field input{width:100%;padding:12px 14px;border:1px solid rgba(42,36,24,.18);background:#fafaf7;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);outline:none;transition:border-color .15s}
.field input:focus{border-color:var(--gold);background:#fff}
.field input.invalid{border-color:#c0392b;background:#fff}
.field .err{display:none;font-size:12px;color:#c0392b;margin-top:4px;font-style:normal}
.field .err.show{display:block}
.modal-disclaimer{font-size:12px;color:var(--ink-soft);line-height:1.5;margin:18px 0 16px}
#buySubmit{width:100%;justify-content:center}
#buySubmit[disabled]{opacity:.6;cursor:not-allowed}
body.modal-open{overflow:hidden}
@media (max-width:560px){.modal-card{padding:28px 22px}.modal-card h3{font-size:24px}}
