/* ==========================================================================
   Ariel & Shirel — Wedding invitation
   Refined design: layered backgrounds, gold accents, polished buttons,
   subtle motion, soft hover states.
   ========================================================================== */

:root{
  --beige:#efe8da;
  --beige-2:#e8dec9;
  --cream:#faf6ec;
  --paper:#fcf8ee;
  --paper-2:#f5efdf;
  --sage:#8fa384;
  --sage-dark:#5a6e54;
  --sage-mid:#778a6e;
  --sage-light:#b8c8ad;
  --sage-deep:#3f5039;
  --sage-night:#2e3d2a;
  --olive:#7a8a5c;
  --gold:#b59a64;
  --gold-warm:#c9b07d;
  --gold-light:#dfc99b;
  --ink:#3a4636;

  --shadow-card: 0 40px 80px -28px rgba(58,70,54,.36), 0 12px 28px -12px rgba(58,70,54,.18);
  --shadow-btn: 0 12px 24px -10px rgba(63,80,57,.55), 0 2px 4px -2px rgba(63,80,57,.28);
  --shadow-btn-hover: 0 18px 32px -14px rgba(63,80,57,.65), 0 4px 8px -3px rgba(63,80,57,.35);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box; -webkit-tap-highlight-color:transparent}
html,body{margin:0; padding:0; max-width:100%; overflow-x:hidden}
html{ -webkit-text-size-adjust:100%; text-size-adjust:100%; }
body{
  font-family:"Cormorant","Cormorant Garamond","Frank Ruhl Libre",serif;
  color:var(--ink);
  min-height:100vh;
  min-height:100dvh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  background:
    radial-gradient(circle at 50% -10%, #fcfaf3 0%, #faf6ec 50%, #f3ebd9 100%);
  background-attachment: fixed;
  position:relative;
}

/* Body est volontairement clair (l'inverse de la carte) */
body::before{ display:none; }
/* Paper grain */
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .55 0 0 0 0 .5 0 0 0 0 .4 0 0 0 .045 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.7; mix-blend-mode:multiply;
}

/* RTL */
html[dir="rtl"] body{ font-family:"Frank Ruhl Libre","Cormorant Garamond",serif; }
html[dir="rtl"] .parents,
html[dir="rtl"] .row-fr,
html[dir="rtl"] .row-he{ direction:rtl; }

/* ============ COVER ============ */
.cover{
  position:fixed; inset:0;
  display:flex; align-items:center; justify-content:center;
  padding: env(safe-area-inset-top) 18px env(safe-area-inset-bottom);
  background:
    linear-gradient(180deg, rgba(252,248,238,.72), rgba(252,248,238,.84)),
    url("assets/bg-pattern.jpeg") center top / 540px auto repeat var(--beige);
  z-index:80;
  transition: opacity 1s var(--ease), visibility 1s;
}
.cover.hidden{opacity:0; visibility:hidden}

.cover-deco{ position:absolute; pointer-events:none; opacity:.6; width: clamp(180px, 36vw, 320px); }
.cover-deco.tl{top:-2vh; left:-6vw; transform:rotate(-12deg)}
.cover-deco.br{bottom:-2vh; right:-6vw; transform:rotate(168deg)}

.arch{
  position:relative;
  width: 100%;
  max-width: 360px;
  aspect-ratio: 3/3.7;
  border:1.5px solid var(--sage-mid);
  border-radius:50% 50% 6px 6px / 42% 42% 6px 6px;
  background: linear-gradient(180deg, #fff 0%, var(--paper) 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding: 28px 28px 30px;
  box-shadow: var(--shadow-card);
}
/* Inner gold filigree */
.arch::before{
  content:""; position:absolute; inset:8px;
  border:1px solid rgba(181,154,100,.35);
  border-radius:inherit;
  pointer-events:none;
}

/* Logo image — PNG transparent */
.logo-img{
  display:block;
  height:auto;
  user-select:none;
  -webkit-user-drag:none;
  position:relative; z-index:2;
}
.logo-cover{
  width: clamp(180px, 56vw, 240px);
  margin: 6px auto 14px;
  filter: drop-shadow(0 6px 16px rgba(63,80,57,.10));
}
.logo-card{
  width: clamp(140px, 38vw, 180px);
  margin: -10px auto 6px;
  filter: drop-shadow(0 3px 8px rgba(63,80,57,.06));
}

.lang-row{display:flex; gap:10px; margin: 6px 0 22px; position:relative; z-index:1}
.lang-btn{
  min-height:36px;
  padding:7px 22px; border-radius:999px;
  font-family:"Cormorant Garamond",serif; font-size:13px;
  letter-spacing:3px; text-transform:uppercase; cursor:pointer;
  border:1px solid var(--sage-mid); background:transparent; color:var(--sage-deep);
  transition: all .3s var(--ease);
}
.lang-btn:hover{ border-color:var(--sage-deep); color:var(--sage-deep); transform:translateY(-1px); }
.lang-btn.active{ background:var(--sage-mid); color:#fff; border-color:var(--sage-mid); }

.open-btn{
  min-height:48px;
  padding:14px 32px; border-radius:999px;
  background: linear-gradient(180deg, var(--sage-dark), var(--sage-deep));
  color:#fff;
  border:none; cursor:pointer;
  font-family:"Cormorant Garamond",serif;
  font-size:12px; letter-spacing:4px; text-transform:uppercase;
  box-shadow: var(--shadow-btn);
  transition: transform .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);
  position:relative; z-index:1;
}
.open-btn:hover{ transform:translateY(-2px); box-shadow: var(--shadow-btn-hover); background: linear-gradient(180deg, var(--sage-deep), var(--sage-night)); }
.open-btn:active{transform:translateY(0)}

/* ============ STAGE ============ */
.stage{
  position:relative; z-index:2;
  width:100%;
  display:flex; flex-direction:column; align-items:center;
  padding: calc(env(safe-area-inset-top) + 14px) 12px calc(env(safe-area-inset-bottom) + 90px);
}

.switcher{
  position:sticky;
  top: calc(env(safe-area-inset-top) + 10px);
  display:flex; gap:4px; padding:4px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  border:1px solid rgba(143,163,132,.35);
  border-radius:999px;
  z-index:30;
  margin-bottom:22px;
  box-shadow: 0 10px 28px -12px rgba(63,80,57,.30);
}
.switcher button{
  border:none; background:transparent; cursor:pointer;
  min-height:38px;
  padding:9px 22px; border-radius:999px;
  font-family:"Cormorant Garamond", serif;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  color:var(--sage-deep);
  transition: all .35s var(--ease);
}
.switcher button.active{
  background: linear-gradient(180deg, var(--sage-dark), var(--sage-deep));
  color:#fff;
  box-shadow: 0 6px 14px -6px rgba(63,80,57,.5);
}

.card{
  position:relative;
  width:100%;
  max-width: 460px;
  background:
    linear-gradient(180deg, rgba(252,248,238,.78), rgba(252,248,238,.88)),
    url("assets/bg-pattern.jpeg") center top/520px auto repeat var(--paper);
  border-radius:8px;
  box-shadow: var(--shadow-card);
  padding: 38px 26px 56px;
  overflow:hidden;
  isolation:isolate;
}
/* Gold inner frame */
.card::before{
  content:""; position:absolute; inset:14px;
  border:1px solid rgba(181,154,100,.22);
  border-radius:4px;
  pointer-events:none;
  z-index:1;
}

/* Watercolor washes */
.wash{ position:absolute; pointer-events:none; z-index:0; border-radius:50%; filter:blur(40px); }
.wash.w1{width:280px;height:280px;background:rgba(143,163,132,.32); top:-60px; left:-90px;}
.wash.w2{width:320px;height:320px;background:rgba(143,163,132,.26); bottom:-90px; right:-110px;}
.wash.w3{width:200px;height:200px;background:rgba(181,154,100,.10); top:50%; left:30%;}
.wash.w4{width:200px;height:200px;background:rgba(120,140,108,.18); top:30%; right:-50px;}

/* Botanicals */
.botanical{ position:absolute; pointer-events:none; z-index:1; width: 165px; height:auto; opacity:.85; }
.bot-tr{ top:-50px; right:-70px; }
.bot-bl{ bottom:-60px; left:-70px; transform: rotate(180deg)}
.bot-shabbat-tl{ top:-50px; left:-70px; transform: scaleX(-1)}
.bot-shabbat-br{ bottom:-60px; right:-70px; transform: scaleX(-1) rotate(180deg)}

/* Hebrew quote — sur arc de cercle, RTL via path direction */
.arc-text{
  position:relative; z-index:2;
  width: 100%;
  max-width: 360px;
  margin: 0 auto -14px;
}
.arc-text svg{ display:block; width:100%; height:auto; overflow:visible; }
.arc-text text{
  font-family:"Frank Ruhl Libre", serif;
  font-size: 16px;
  letter-spacing: 1px;
  fill: var(--sage-deep);
  font-weight: 500;
  /* La source est pré-inversée caractère par caractère.
     bidi-override empêche le navigateur de re-réordonner → l'ordre source est respecté
     quel que soit le navigateur (Chrome/Safari iOS). Path L→R → ר à droite. */
  direction: ltr;
  unicode-bidi: bidi-override;
}


/* Parents — compactés */
.parents{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1fr 1fr; gap: 4px 22px;
  text-align:center;
  margin-bottom: 16px; padding: 0 4px;
  align-items:end;
}
.parents .col{display:flex; flex-direction:column; gap: 4px;}
.parents .col.left{ justify-content:flex-end; }
.parents .p{
  font-family:"Cormorant Garamond", serif;
  font-size:13px; color:var(--sage-deep);
  letter-spacing:.6px; line-height:1.4;
  font-weight:500; font-style:italic;
  white-space: nowrap;
  margin: 0;
}
.parents .p .mr{ font-style:normal; letter-spacing:1.5px; color:var(--sage-mid); margin-right:3px; font-size:.95em; }

.intro{
  position:relative; z-index:2; text-align:center;
  font-family:"Cormorant", serif;
  font-style:italic; font-weight:300;
  font-size:15px; color:var(--sage-deep);
  line-height:1.65;
  margin: 12px 0 16px; padding: 0 4px;
}
.ornament{
  position:relative; z-index:2; text-align:center;
  color:var(--gold); margin: 12px 0; font-size:14px; letter-spacing:14px;
}

/* Couple names */
.couple{ position:relative; z-index:2; text-align:center; margin: 4px 0 6px; }
.couple.two-col .row-fr{
  display:grid; grid-template-columns: 1fr auto 1fr;
  align-items:center; column-gap: 4px; line-height:1; width:100%;
}
.couple.two-col .row-he{
  display:grid; grid-template-columns: 1fr 1fr;
  align-items:start; margin-top:8px;
}
.couple .name-fr{
  font-family:"Tangerine", cursive;
  font-size: clamp(58px, 17vw, 80px);
  line-height:1; color:var(--sage-deep);
  font-weight:700; white-space: nowrap;
}
/* En hébreu, le nom Ariel/Shirel devient אריאל/שיראל — un script ne fonctionne pas,
   on bascule sur une serif hébraïque élégante. */
html[dir="rtl"] .couple .name-fr{
  font-family:"Frank Ruhl Libre", serif;
  font-size: clamp(40px, 12vw, 56px);
  font-weight: 500;
}
.couple .row-fr > .name-fr:first-child{ text-align:right; padding-right:2px; }
.couple .row-fr > .name-fr:last-child{ text-align:left; padding-left:2px; }
.couple .amp{
  font-family:"Pinyon Script", cursive;
  background: linear-gradient(180deg, var(--gold-light), var(--gold));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  font-weight:400;
  font-size: clamp(34px, 10vw, 48px);
  transform:translateY(-4px); line-height:1;
}
.couple .name-he{
  font-family:"Frank Ruhl Libre", serif;
  font-size: 18px; color:var(--sage-deep);
  direction:rtl; letter-spacing:.5px;
  font-weight:400; text-align:center;
  white-space:nowrap;
}

/* Decorative divider */
.divider{
  position:relative; z-index:2;
  width:90px; height:1px;
  background: linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
  margin: 24px auto;
}
.divider::before, .divider::after{
  content:""; position:absolute; top:50%;
  width:6px; height:6px; border-radius:50%;
  background: var(--gold); transform:translateY(-50%);
  box-shadow: 0 0 0 3px rgba(181,154,100,.18);
}
.divider::before{left:-9px}
.divider::after{right:-9px}

.event-line{
  position:relative; z-index:2; text-align:center;
  font-family:"Cormorant Garamond", serif;
  font-style:italic; font-weight:400;
  font-size:14px; color:var(--sage-mid);
  letter-spacing:.5px;
  margin:8px 0 8px; padding: 0 6px;
  line-height:1.55;
}
.shabbat-pretitle{
  font-size:17px !important; letter-spacing:6px !important;
  text-transform:uppercase; font-style:normal !important;
  color:var(--gold) !important;
  font-weight:600 !important;
  margin: 12px 0 10px !important;
}

.date{ position:relative; z-index:2; text-align:center; margin: 8px 0 10px; }
.date .fr{
  font-family:"Cormorant Garamond", serif;
  font-size: clamp(15px, 4.6vw, 18px);
  color:var(--sage-deep);
  letter-spacing: 2px; text-transform:uppercase; font-weight:500;
  white-space:nowrap;
}
.date .fr-narrow{
  letter-spacing: 1.2px;
  font-size: clamp(13px, 3.9vw, 16px);
}
.date .he{
  font-family:"Frank Ruhl Libre", serif;
  font-size:15px; color:var(--sage-mid);
  margin-top:6px; direction:rtl; letter-spacing:1px;
}

.place{
  position:relative; z-index:2; text-align:center;
  font-family:"Cormorant Garamond", serif; color:var(--ink);
  margin: 22px 0 14px; line-height:1.7;
}
.place .name{
  font-family:"Cinzel", "Cormorant Garamond", serif;
  font-size: clamp(18px, 5vw, 22px);
  letter-spacing: 4px; text-transform:uppercase; color:var(--sage-deep);
  font-weight:500;
}
.place .addr{
  font-size:13.5px; letter-spacing:1px; color:var(--sage-mid);
  margin-top:6px; font-style:italic;
}

.time{
  position:relative; z-index:2; text-align:center;
  font-family:"Cormorant Garamond", serif;
  font-size:14px; color:var(--ink);
  margin: 14px 0 24px; line-height:1.7; font-style:italic;
}
.time strong{font-weight:600; font-style:normal;}

.waze-row{position:relative; z-index:2; text-align:center; margin-top:8px}
.waze{
  display:inline-flex; align-items:center; gap:10px;
  min-height:48px; padding: 13px 26px;
  background: linear-gradient(180deg, var(--sage-dark), var(--sage-deep));
  color:#fff;
  font-family:"Cormorant Garamond", serif;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  border-radius:999px; text-decoration:none;
  box-shadow: var(--shadow-btn);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
  position:relative; overflow:hidden;
}
.waze::after{
  content:""; position:absolute; top:0; left:-100%; width:50%; height:100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transition: left .8s var(--ease);
  pointer-events:none;
}
.waze:hover{ transform:translateY(-2px); box-shadow: var(--shadow-btn-hover); background: linear-gradient(180deg, var(--sage-deep), var(--sage-night)); }
.waze:hover::after{ left: 120%; }
.waze:active{transform:translateY(0)}
.waze svg{width:16px;height:16px; flex-shrink:0}

/* RSVP */
.rsvp{
  position:relative; z-index:2;
  margin: 36px 0 6px; padding-top:24px;
  border-top:1px solid rgba(181,154,100,.3);
}
.rsvp h3{
  text-align:center;
  font-family:"Tangerine", cursive; font-weight:700;
  font-size: clamp(46px, 13vw, 58px);
  color:var(--sage-deep); margin: 0 0 4px; line-height:1;
}
.rsvp .sub{
  text-align:center;
  font-family:"Cormorant Garamond",serif;
  font-style:italic; font-size:13px;
  color:var(--sage-mid);
  margin: 0 0 22px; letter-spacing:.5px; padding: 0 4px;
}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.form-field{display:flex; flex-direction:column; gap:6px;}
.form-field label{
  font-family:"Cormorant Garamond", serif;
  font-size:11px; letter-spacing:2px; text-transform:uppercase;
  color:var(--sage-mid);
}
.form-field input,
.form-field textarea,
.form-field select{
  border:none; border-bottom:1.5px solid var(--sage-mid);
  background:transparent;
  font-family:"Cormorant Garamond", serif;
  font-size:15px; color:var(--ink);
  padding:8px 2px; outline:none; width:100%;
  transition: border-color .25s var(--ease), background .25s;
  border-radius:0; -webkit-appearance:none; appearance:none;
}
.form-field textarea{resize:vertical; min-height:64px}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{
  border-color:var(--sage-deep);
  background: rgba(255,255,255,.45);
}
.full{grid-column:1/-1;}

/* Custom toggle pills (oui/non) */
.toggle-group{
  display:flex; flex-wrap:wrap; gap:10px; margin-top:8px;
}
.toggle-pill{
  flex: 1 1 auto;
  min-height:46px;
  padding: 12px 18px;
  border:1.5px solid var(--sage-mid);
  border-radius:999px;
  background: rgba(255,255,255,.6);
  font-family:"Cormorant Garamond", serif;
  font-size:13px; letter-spacing:.6px;
  color:var(--sage-deep);
  cursor:pointer;
  text-align:center;
  display:inline-flex; align-items:center; justify-content:center;
  transition: all .3s var(--ease);
  user-select:none;
  position:relative;
}
.toggle-pill:hover{ border-color:var(--sage-deep); background:rgba(255,255,255,.85); transform:translateY(-1px); }
.toggle-group input[type="radio"]:checked + .toggle-pill{
  background: linear-gradient(180deg, var(--sage-dark), var(--sage-deep));
  color:#fff;
  border-color:var(--sage-deep);
  box-shadow: 0 8px 18px -8px rgba(63,80,57,.55), inset 0 0 0 1px rgba(255,255,255,.15);
}
.toggle-group input[type="radio"]:focus-visible + .toggle-pill{
  outline: 2px solid var(--gold); outline-offset:2px;
}
.toggle-group input[type="radio"]:checked + .toggle-pill::before{
  content:"✓"; margin-right:8px; font-size:13px; opacity:.85;
}

.send{
  margin-top: 26px; width:100%;
  min-height:50px; padding:15px;
  background: linear-gradient(180deg, var(--sage-dark), var(--sage-deep));
  color:#fff;
  border:none; border-radius:999px; cursor:pointer;
  font-family:"Cormorant Garamond", serif;
  font-size:12px; letter-spacing:4px; text-transform:uppercase;
  box-shadow: var(--shadow-btn);
  transition: transform .3s var(--ease), background .3s var(--ease), opacity .3s, box-shadow .3s var(--ease);
  position:relative; overflow:hidden;
}
.send::after{
  content:""; position:absolute; top:0; left:-100%; width:50%; height:100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent);
  transition: left .8s var(--ease);
  pointer-events:none;
}
.send:hover{ transform:translateY(-2px); box-shadow: var(--shadow-btn-hover); background: linear-gradient(180deg, var(--sage-deep), var(--sage-night)); }
.send:hover::after{ left: 120%; }
.send:active{transform:translateY(0)}
.send[disabled]{opacity:.6; cursor:not-allowed; transform:none}

.form-msg{
  text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-style:italic; color:var(--sage-deep);
  margin-top:14px; display:none;
  font-size:14px;
}
.form-msg.error{ color:#a64646 }
.form-msg.show{ display:block; animation: fadein .5s var(--ease); }

/* Auto-Saturday hint */
.auto-hint{
  display:none;
  margin-top:8px;
  font-family:"Cormorant Garamond", serif;
  font-style:italic;
  font-size:12px;
  color:var(--gold);
  letter-spacing:.5px;
  padding-left:4px;
}
.auto-hint.show{ display:block; animation: fadein .35s var(--ease); }

/* Paracha line (Shabbat) */
.paracha{
  position:relative; z-index:2;
  text-align:center;
  font-family:"Cormorant Garamond", serif;
  font-size: 18px;
  letter-spacing: 3px;
  color: var(--gold);
  margin: 8px 0 16px;
  text-transform: uppercase;
  font-weight: 600;
}

/* In Memoriam — z"l grandparents, now placed between Waze and RSVP */
.memoriam{
  position:relative; z-index:2;
  margin: 28px auto 4px;
  padding: 18px 8px 0;
  max-width: 380px;
  text-align:center;
  font-family:"Cormorant Garamond", serif;
  font-style:italic;
  font-size: 12.5px;
  line-height:1.75;
  color:var(--sage-mid);
  letter-spacing:.3px;
  border-top: 1px solid rgba(181,154,100,.25);
}
.memoriam.memoriam-inline{
  margin-top: 26px;
  margin-bottom: 6px;
}
.memoriam .zl{
  font-style:normal;
  letter-spacing:.5px;
  color:var(--gold);
  font-size:.92em;
  margin:0 1px;
}

/* Panels */
.panel{display:none; animation:fadein .6s var(--ease)}
.panel.active{display:block}
@keyframes fadein{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none}}

.footer{
  margin-top:30px; text-align:center;
  font-family:"Cormorant Garamond", serif;
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  color:var(--sage-mid); opacity:.85;
  padding-bottom: env(safe-area-inset-bottom);
}

/* Music button — refined floating pill */
.music{
  position:fixed;
  bottom: calc(env(safe-area-inset-bottom) + 22px);
  left: 18px;
  z-index:40;
  width:52px; height:52px; border-radius:50%;
  background: linear-gradient(180deg, var(--sage-dark), var(--sage-deep));
  color:#fff;
  border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 12px 26px -10px rgba(63,80,57,.55), 0 2px 4px -2px rgba(63,80,57,.3);
  transition: transform .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);
}
.music:hover{ transform:scale(1.08); background: linear-gradient(180deg, var(--sage-deep), var(--sage-night)); box-shadow: 0 18px 32px -10px rgba(63,80,57,.65), 0 4px 8px -3px rgba(63,80,57,.4); }
.music:active{transform:scale(.94)}
.music.playing{
  background: linear-gradient(180deg, var(--gold-light), var(--gold));
}
.music.playing::after{
  content:""; position:absolute; inset:-6px;
  border-radius:50%;
  border:1.5px solid var(--gold);
  animation: pulse 1.8s var(--ease) infinite;
  pointer-events:none;
}
@keyframes pulse{
  0%{ transform:scale(.9); opacity:.65 }
  70%{ transform:scale(1.25); opacity:0 }
  100%{ transform:scale(1.25); opacity:0 }
}

/* Responsive */
@media (max-width: 420px){
  .stage{ padding-left:10px; padding-right:10px; }
  .card{ padding: 32px 22px 52px; }
  .card::before{ inset:10px; }
  .botanical{ width: 145px; opacity:.78; }
  .bot-tr{ top:-44px; right:-58px; }
  .bot-bl{ bottom:-52px; left:-58px; }
  .bot-shabbat-tl{ top:-44px; left:-58px; }
  .bot-shabbat-br{ bottom:-52px; right:-58px; }
  .monogram{ font-size: 56px; margin-bottom:22px; }
  .parents{ gap: 12px 16px; }
  .parents .p{ font-size:11px; letter-spacing:.3px; }
  .parents .p .mr{ letter-spacing:1px; font-size:.92em }
  .arc-text text{ font-size:11.5px; letter-spacing:1.5px; }
  .ornament{ letter-spacing:10px; font-size:13px; }
  .date .fr{ letter-spacing:1.5px; }
  .place .name{ letter-spacing: 3px; }
  .form-row{ gap:12px; }
  .toggle-pill{ font-size:12.5px; padding: 10px 14px; }
}
@media (max-width: 360px){
  .card{ padding: 28px 18px 46px; }
  .botanical{ width: 130px; }
  .parents .p{ font-size:10px; letter-spacing:.2px; }
  .parents .p .mr{ letter-spacing:.8px; }
  .place .name{ letter-spacing: 2.5px; }
  .place .addr{ font-size:12.5px; }
}
