:root{
  --bg:#efe7db;
  --paper:#fdfaf6;
  --paper-tint:#f8f2ea;
  --ink:#382213;
  --gold:#d29a5c;
  --gold-deep:#9b5f24;
  --line:#e2c89f;
}

*{margin:0;padding:0;box-sizing:border-box}
body{
  background:
    radial-gradient(circle at 16% 14%, rgba(255,255,255,0.56) 0%, rgba(255,255,255,0) 40%),
    radial-gradient(circle at 84% 84%, rgba(186,132,80,0.18) 0%, rgba(186,132,80,0) 45%),
    repeating-linear-gradient(135deg, rgba(130,90,55,0.028) 0px, rgba(130,90,55,0.028) 2px, rgba(0,0,0,0) 2px, rgba(0,0,0,0) 13px),
    var(--bg);
  min-height:100vh;
  display:flex;
  justify-content:center;
  align-items:center;
  padding:2rem;
  animation:pageFade 900ms ease-out both;
}
.page-shell{
  width:min(100%, 560px);
}
.card{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.7) 0%, rgba(255,255,255,0) 45%),
    linear-gradient(0deg, rgba(248,242,234,0.72), rgba(248,242,234,0.72)),
    var(--paper);
  max-width:460px;
  width:100%;
  position:relative;
  box-shadow:
    0 36px 68px rgba(95,62,33,0.2),
    0 8px 22px rgba(95,62,33,0.14);
  border-radius:4px;
  border:1px solid rgba(177,136,92,0.25);
  overflow:hidden;
  transform:translateY(20px) scale(0.985);
  opacity:0;
  animation:cardIn 850ms cubic-bezier(.2,.7,.2,1) 120ms forwards;
}
.card::before{
  content:"";
  position:absolute;
  inset:-60% -40% auto;
  height:200px;
  background:linear-gradient(100deg, rgba(255,255,255,0) 20%, rgba(255,255,255,0.48) 50%, rgba(255,255,255,0) 80%);
  transform:translateX(-120%);
  animation:cardSheen 4.8s ease-in-out 1.2s infinite;
  pointer-events:none;
  z-index:1;
}
.card::after{
  content:"";
  position:absolute;
  inset:7px;
  border:0.7px solid rgba(210,154,92,0.34);
  pointer-events:none;
  z-index:2;
}
.border-frame{
  position:absolute;
  inset:10px;
  border:1px solid rgba(201,145,84,0.78);
  pointer-events:none;
  z-index:3;
}
.border-frame::before,
.border-frame::after{
  content:"";
  position:absolute;
  width:42px;
  height:42px;
  border:1px solid rgba(213,160,101,0.88);
  opacity:.75;
}
.border-frame::before{
  top:-1px;
  left:-1px;
  border-right:none;
  border-bottom:none;
}
.border-frame::after{
  right:-1px;
  bottom:-1px;
  border-left:none;
  border-top:none;
}
.border-frame-inner::before,
.border-frame-inner::after{
  content:"";
  position:absolute;
  width:22px;
  height:22px;
  border:0.55px solid rgba(230,192,142,0.7);
}
.border-frame-inner::before{
  top:-1px;
  right:-1px;
  border-left:none;
  border-bottom:none;
}
.border-frame-inner::after{
  left:-1px;
  bottom:-1px;
  border-right:none;
  border-top:none;
}
.border-frame-inner{
  position:absolute;
  inset:14px;
  border:0.55px solid rgba(230,192,142,0.9);
  pointer-events:none;
  z-index:3;
}
.photo-wrap{
  width:100%;
  height:320px;
  overflow:hidden;
  position:relative;
}
.photo-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 15%;
  display:block;
  filter:sepia(16%) saturate(84%) contrast(1.02);
  transform:scale(1.06);
  animation:imageSettle 1200ms ease-out 280ms forwards;
}
.photo-fade{
  position:absolute;
  bottom:0;left:0;right:0;
  height:160px;
  background:linear-gradient(to bottom, transparent 0%, #fdfaf6 100%);
}
.content{
  padding:0 2.9rem 2.8rem;
  text-align:center;
  position:relative;
  z-index:2;
}
.content > *{
  opacity:0;
  transform:translateY(14px);
  animation:revealUp 700ms ease forwards;
}
.content > *:nth-child(1){animation-delay:260ms}
.content > *:nth-child(2){animation-delay:340ms}
.content > *:nth-child(3){animation-delay:420ms}
.content > *:nth-child(4){animation-delay:500ms}
.content > *:nth-child(5){animation-delay:580ms}
.content > *:nth-child(6){animation-delay:660ms}
.content > *:nth-child(7){animation-delay:740ms}
.content > *:nth-child(8){animation-delay:820ms}
.content > *:nth-child(9){animation-delay:900ms}
.content > *:nth-child(10){animation-delay:980ms}
.bismi{
  font-family:'Scheherazade New', serif;
  font-size:23px;
  color:#7d4e2d;
  direction:rtl;
  line-height:2;
  margin-bottom:0.1rem;
}
.occasion-ar{
  font-family:'Scheherazade New', serif;
  font-size:18px;
  color:#a47443;
  direction:rtl;
  line-height:1.9;
  margin-bottom:0.75rem;
}
.occasion-en{
  font-family:'Tenor Sans', sans-serif;
  font-size:10px;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:#8d5522;
  margin-bottom:1rem;
}
.thin-rule{
  display:flex;
  align-items:center;
  gap:12px;
  margin:0.65rem 0 1.55rem;
}
.thin-rule-spaced{margin-top:1.2rem}
.rule-line{height:0.7px;flex:1;background:var(--line)}
.rule-diamond{
  width:7px;height:7px;
  background:var(--gold);
  transform:rotate(45deg);
  flex-shrink:0;
  animation:diamondPulse 2.6s ease-in-out infinite;
}
.names-block{
  margin-bottom:0.45rem;
}
.name{
  font-family:'Bodoni Moda', serif;
  font-size:54px;
  font-weight:400;
  color:var(--gold-deep);
  background:linear-gradient(165deg, #f6d9ac 8%, #d79f61 42%, #995c22 78%, #f2c98f 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:0 1px 0 rgba(255,235,206,0.32), 0 8px 16px rgba(128,77,36,0.18);
  letter-spacing:0.05em;
  line-height:1.12;
  display:block;
  animation:foilShimmer 6.2s ease-in-out infinite;
}
.name-amp{
  font-family:'Bodoni Moda', serif;
  font-style:italic;
  font-size:21px;
  color:var(--gold);
  display:block;
  margin:0.34rem 0;
  letter-spacing:0.14em;
  text-shadow:0 4px 12px rgba(134,81,39,0.2);
}
.details-wrap{
  margin:1.5rem 0 0;
  display:flex;
  flex-direction:column;
  gap:0.78rem;
}
.detail-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  padding:0.88rem 0.55rem;
  border:0.7px solid rgba(201,145,84,0.52);
  background:linear-gradient(180deg, rgba(255,255,255,0.56), rgba(255,255,255,0.18));
}
.dl{
  font-family:'Tenor Sans', sans-serif;
  font-size:9px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:#a9692a;
}
.dv{
  font-family:'Bodoni Moda', serif;
  font-size:20px;
  font-weight:400;
  color:var(--ink);
  letter-spacing:0.02em;
  line-height:1.35;
}
.dv-sub{
  font-family:'Tenor Sans', sans-serif;
  font-size:13px;
  color:#91633d;
  margin-top:1px;
}
.map-link{
  font-family:'Tenor Sans', sans-serif;
  font-size:9px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold-deep);
  text-decoration:none;
  border:0.8px solid #cf9757;
  border-radius:999px;
  padding:0.34rem 0.76rem;
  margin-top:5px;
  display:inline-block;
  background:rgba(255,251,246,0.86);
  transition:color .25s ease, border-color .25s ease, transform .25s ease, background-color .25s ease;
}
.map-link:hover{
  color:#6f3f16;
  border-color:var(--gold);
  background:rgba(255,250,244,1);
  transform:translateY(-1px);
}
.map-link:focus-visible{
  outline:1px dashed #b98955;
  outline-offset:4px;
}
.ayah-wrap{
  border-top:0.8px solid rgba(201,145,84,0.62);
  border-bottom:0.8px solid rgba(201,145,84,0.62);
  padding:1.1rem 0.5rem;
  margin:1.55rem 0 1.28rem;
}
.ayah-ar{
  font-family:'Scheherazade New', serif;
  font-size:18px;
  color:#6e4426;
  direction:rtl;
  line-height:2.15;
  margin-bottom:0.34rem;
}
.ayah-en{
  font-family:'Bodoni Moda', serif;
  font-style:italic;
  font-size:12px;
  color:#8f6a43;
  line-height:1.8;
}
.ayah-ref{
  font-size:11px;
  color:#a5672c;
}
.rsvp-wrap{text-align:center}
.rsvp-wrap .dl{margin-bottom:3px}
.rsvp-wrap .dv{font-size:18px}

@keyframes pageFade{
  from{opacity:0}
  to{opacity:1}
}

@keyframes cardIn{
  from{opacity:0;transform:translateY(20px) scale(0.985)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

@keyframes imageSettle{
  from{transform:scale(1.06)}
  to{transform:scale(1)}
}

@keyframes revealUp{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes diamondPulse{
  0%,100%{opacity:.7;transform:rotate(45deg) scale(1)}
  50%{opacity:1;transform:rotate(45deg) scale(1.15)}
}

@keyframes foilShimmer{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

@keyframes cardSheen{
  0%,55%{transform:translateX(-120%)}
  100%{transform:translateX(140%)}
}

@media (max-width:540px){
  body{padding:1rem}
  .photo-wrap{height:286px}
  .content{padding:0 1.5rem 2.1rem}
  .name{font-size:44px}
  .dv{font-size:18px}
  .ayah-ar{font-size:16px;line-height:2.05}
  .occasion-en{font-size:9px;letter-spacing:0.22em}
  .detail-item{padding:0.8rem 0.45rem}
  .border-frame::before,
  .border-frame::after{width:34px;height:34px}
  .border-frame-inner::before,
  .border-frame-inner::after{width:18px;height:18px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}
