/* ================================================================
   IMPORTS & RESET
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Vazirmatn:wght@300;400;500;600;700;800;900&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ================================================================
   DESIGN TOKENS
   ================================================================ */
:root{
  /* ── Palette ── */
  --red-900: #4a0000;
  --red-800: #6b0000;
  --red-700: #8b0000;
  --red-600: #a50000;
  --red-500: #c62828;
  --red-400: #e53935;

  --gold-900: #7a5200;
  --gold-700: #a07800;
  --gold-500: #c9a84c;
  --gold-400: #e0c060;
  --gold-300: #f0d880;
  --gold-100: #fdf8ee;

  --ink-900: #0a0a0f;
  --ink-800: #12121a;
  --ink-700: #1c1c28;
  --ink-600: #2a2a3a;
  --ink-400: #4a4a6a;
  --ink-300: #6a6a8a;
  --ink-200: #9a9ab0;
  --ink-100: #c8c8d8;

  --bg-page:   #f7f4ef;
  --bg-card:   #ffffff;
  --bg-card-2: #fdfaf5;

  /* ── Radii ── */
  --r4:4px; --r8:8px; --r12:12px; --r16:16px;
  --r20:20px; --r28:28px; --r-full:9999px;

  /* ── Shadows ── */
  --sh-xs: 0 1px 4px rgba(0,0,0,.06);
  --sh-sm: 0 4px 14px rgba(0,0,0,.08);
  --sh-md: 0 10px 32px rgba(107,0,0,.10);
  --sh-lg: 0 24px 64px rgba(0,0,0,.14);
  --sh-glow: 0 0 40px rgba(139,0,0,.25);

  /* ── Transitions ── */
  --ease: cubic-bezier(.4,0,.2,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
  --t2: .2s; --t3: .3s; --t4: .4s; --t6: .6s;
}

/* ================================================================
   BASE
   ================================================================ */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Vazirmatn',Tahoma,sans-serif;
  background:var(--bg-page);
  color:var(--ink-700);
  line-height:1.8;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:'';
  position:fixed;inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 100% 0%,rgba(139,0,0,.04) 0%,transparent 60%),
    radial-gradient(ellipse 60% 60% at 0% 100%,rgba(201,168,76,.03) 0%,transparent 60%);
  pointer-events:none;z-index:-1;
}
.container{width:100%;max-width:980px;margin:0 auto;padding:0 24px;position:relative}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ================================================================
   HEADER
   ================================================================ */
.site-header{
  position:relative;
  background:var(--ink-900);
  padding:80px 0 64px;
  text-align:center;
  overflow:hidden;
  border-bottom:1px solid rgba(201,168,76,.2);
}
.hdr-bg{position:absolute;inset:0;pointer-events:none}
.hdr-noise{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  opacity:.4;
}
.hdr-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.hdr-glow-1{width:500px;height:500px;background:rgba(139,0,0,.18);top:-200px;left:50%;transform:translateX(-50%)}
.hdr-glow-2{width:300px;height:300px;background:rgba(201,168,76,.08);top:0;right:-100px}
.hdr-glow-3{width:250px;height:250px;background:rgba(139,0,0,.1);bottom:-100px;left:-50px}

/* particles */
.hdr-particles{position:absolute;inset:0;pointer-events:none}
.hdr-particles span{
  position:absolute;
  width:3px;height:3px;
  background:var(--gold-500);
  border-radius:50%;
  opacity:0;
  animation:pfloat 7s infinite;
}
.hdr-particles span:nth-child(1){left:10%;top:25%;animation-delay:0s;animation-duration:6s}
.hdr-particles span:nth-child(2){left:25%;top:65%;animation-delay:1.5s;animation-duration:8s}
.hdr-particles span:nth-child(3){left:45%;top:40%;animation-delay:0.8s;animation-duration:7s}
.hdr-particles span:nth-child(4){left:62%;top:20%;animation-delay:2.2s;animation-duration:6.5s}
.hdr-particles span:nth-child(5){left:75%;top:70%;animation-delay:0.4s;animation-duration:9s}
.hdr-particles span:nth-child(6){left:88%;top:35%;animation-delay:3s;animation-duration:7.5s}
.hdr-particles span:nth-child(7){left:5%;top:55%;animation-delay:1.8s;animation-duration:6s}
.hdr-particles span:nth-child(8){left:52%;top:80%;animation-delay:4s;animation-duration:8s}
@keyframes pfloat{
  0%{opacity:0;transform:translateY(0) scale(1)}
  20%{opacity:.9}
  80%{opacity:.3}
  100%{opacity:0;transform:translateY(-80px) scale(0)}
}

.hdr-inner{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:20px;
}
.hdr-emblem{position:relative;display:inline-flex;align-items:center;justify-content:center;margin-bottom:4px}
.emblem-rings{position:absolute;inset:-16px}
.ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(201,168,76,.25);
  animation:ringspin linear infinite;
}
.r1{inset:0;animation-duration:20s}
.r2{inset:6px;border-color:rgba(201,168,76,.15);animation-duration:30s;animation-direction:reverse}
.r3{inset:12px;border-color:rgba(201,168,76,.08);animation-duration:15s}
@keyframes ringspin{to{transform:rotate(360deg)}}
.emblem-img{
  width:80px;height:80px;
  border-radius:50%;
  border:2px solid rgba(201,168,76,.35);
  padding:6px;
  animation:logopulse 4s ease-in-out infinite;
}
@keyframes logopulse{
  0%,100%{filter:drop-shadow(0 0 12px rgba(201,168,76,.3))}
  50%{filter:drop-shadow(0 0 28px rgba(201,168,76,.65))}
}

.hdr-title{
  font-size:clamp(2rem,5.5vw,3.2rem);
  font-weight:900;
  color:#fff;
  letter-spacing:-.5px;
  text-shadow:0 2px 20px rgba(0,0,0,.4);
  line-height:1.2;
}
.hdr-slogan{
  font-size:clamp(.9rem,2.2vw,1.1rem);
  color:rgba(255,255,255,.55);
  font-weight:300;
  letter-spacing:.3px;
}
.hdr-ornament{display:flex;align-items:center;gap:20px;margin-top:4px}
.orn-l,.orn-r{
  display:block;height:1px;width:100px;
  background:linear-gradient(90deg,transparent,var(--gold-500),transparent);
}
.orn-icon{opacity:.8}

/* ================================================================
   PAGE LAYOUT & SHARED COMPONENTS
   ================================================================ */
.site-main{position:relative;z-index:1}
.page-stack{
  display:flex;flex-direction:column;gap:36px;
  padding:44px 0 80px;
}

/* Reveal animation — only activates when JS adds .js-loaded to body */
body.js-loaded .reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
body.js-loaded .reveal.visible{opacity:1;transform:none}

/* Card */
.card{
  background:var(--bg-card);
  border-radius:var(--r20);
  padding:40px;
  box-shadow:var(--sh-md);
  border:1px solid rgba(0,0,0,.04);
  position:relative;
  overflow:hidden;
  transition:transform var(--t3) var(--ease), box-shadow var(--t3) var(--ease);
}
.card:hover{transform:translateY(-3px);box-shadow:0 20px 56px rgba(107,0,0,.12)}
.card-accent-bar{
  position:absolute;top:0;right:0;left:0;height:3px;
  background:linear-gradient(90deg,var(--red-700),var(--gold-500),var(--red-700));
}

/* Section header */
.sec-header{margin-bottom:24px}
.sec-header.centered{text-align:center}
.sec-header.centered .sec-title::after{left:50%;transform:translateX(-50%);right:auto}
.sec-title{
  font-size:1.55rem;font-weight:800;
  color:var(--ink-800);
  padding-bottom:12px;
  position:relative;
  margin-bottom:8px;
}
.sec-title::after{
  content:'';
  position:absolute;bottom:0;right:0;
  width:48px;height:3px;
  background:linear-gradient(90deg,var(--red-700),var(--gold-500));
  border-radius:var(--r-full);
}
.sec-sub{font-size:.9rem;color:var(--ink-300);line-height:1.6}

/* ================================================================
   COUNTER SECTION
   ================================================================ */
.counter-section{}
.counter-card{
  background:linear-gradient(140deg,var(--red-900) 0%,var(--red-700) 45%,var(--red-800) 100%);
  border-radius:var(--r28);
  padding:44px 32px 52px;
  position:relative;
  overflow:hidden;
  box-shadow:0 16px 48px rgba(107,0,0,.45),inset 0 1px 0 rgba(255,255,255,.05);
}
.cc-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 50%,rgba(201,168,76,.12) 0%,transparent 50%),
    radial-gradient(circle at 80% 20%,rgba(255,255,255,.04) 0%,transparent 40%);
}
.cc-body{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:center;
  gap:40px;flex-wrap:wrap;
}
.cc-icon{color:rgba(255,255,255,.35)}
.cc-nums{display:flex;flex-direction:column;align-items:center;gap:6px}
.cc-label{font-size:.95rem;color:rgba(255,255,255,.7);font-weight:500;letter-spacing:.3px}
.cc-number{
  font-size:clamp(2.8rem,7vw,4.5rem);
  font-weight:900;
  color:#fff;
  line-height:1;
  text-shadow:0 4px 20px rgba(0,0,0,.3);
  font-variant-numeric:tabular-nums;
  letter-spacing:-1px;
}
.cc-sub{font-size:.85rem;color:rgba(255,255,255,.5);font-weight:400}
.cc-deco{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:16px;opacity:.3;
}
.deco-l,.deco-r{height:6px;width:48px;object-fit:contain;filter:brightness(10)}
.cc-diamond{color:var(--gold-300);font-size:1rem}

/* ================================================================
   ABOUT SECTION
   ================================================================ */
.about-quote{
  font-size:1.05rem;
  line-height:2.1;
  color:var(--ink-600);
  text-align:justify;
  border-right:4px solid var(--gold-500);
  padding:16px 20px 16px 0;
  margin:0;
  font-style:normal;
  position:relative;
}
.bq-mark{
  font-size:2.5rem;
  color:var(--gold-500);
  line-height:1;
  opacity:.5;
  font-family:Georgia,serif;
  display:inline;
}
.bq-end{float:left;margin-top:-8px}

/* ================================================================
   CONDITIONS — gallery grid
   ================================================================ */
.conditions-section{
  background:var(--bg-card);
  border-radius:var(--r20);
  padding:40px;
  box-shadow:var(--sh-md);
  border:1px solid rgba(0,0,0,.04);
}
.cond-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
@media(min-width:640px){.cond-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media(min-width:900px){.cond-grid{grid-template-columns:repeat(5,1fr);gap:16px}}

.cond-item{
  position:relative;
  border-radius:var(--r12);
  overflow:hidden;
  box-shadow:var(--sh-sm);
  cursor:pointer;
  transition:transform var(--t3) var(--ease),box-shadow var(--t3) var(--ease);
  background:var(--ink-800);
}
.cond-item:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(107,0,0,.25)}
.cond-item:focus-visible{outline:3px solid var(--gold-500);outline-offset:3px}

.cond-img-wrap{
  position:relative;
  width:100%;
  overflow:hidden;
}
.cond-img{
  width:100%;height:auto;
  display:block;
  transition:transform .5s var(--ease);
}
.cond-item:hover .cond-img{transform:scale(1.04)}

.cond-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(74,0,0,.8) 0%,transparent 60%);
  display:flex;align-items:flex-end;justify-content:center;
  padding-bottom:12px;
  opacity:0;
  transition:opacity var(--t3) var(--ease);
}
.cond-item:hover .cond-overlay,.cond-item:focus .cond-overlay{opacity:1}
.cond-num{
  font-size:2rem;font-weight:900;
  color:rgba(255,255,255,.9);
  text-shadow:0 2px 8px rgba(0,0,0,.5);
}

/* Stamp */
.cond-stamp-wrap{
  position:absolute;top:8px;left:8px;
  z-index:10;
  pointer-events:none;
}
.cond-stamp{
  width:46px;height:46px;
  opacity:0;
  transform:scale(2.5) rotate(-20deg);
  transition:all .3s cubic-bezier(.175,.885,.32,1.275);
  filter:drop-shadow(0 0 10px rgba(200,0,0,.8));
}
.cond-stamp.active{opacity:.92;transform:scale(1) rotate(-8deg)}
.stamp-pulse{
  position:absolute;inset:-4px;
  border-radius:50%;
  border:2px solid rgba(200,0,0,.5);
  opacity:0;
  animation:stamp-ring 1.5s ease-out infinite;
  display:none;
}
.cond-stamp.active~.stamp-pulse{display:block}
@keyframes stamp-ring{
  0%{opacity:.8;transform:scale(.8)}
  100%{opacity:0;transform:scale(1.8)}
}

/* ================================================================
   PLEDGE + REGISTRATION (یکپارچه)
   ================================================================ */
.pledge-reg-section{
  background:var(--ink-900);
  border-radius:var(--r20);
  overflow:hidden;
  position:relative;
  box-shadow:0 16px 48px rgba(0,0,0,.3);
  min-height:380px;
}
.pr-bg{position:absolute;inset:0;pointer-events:none}
.pr-glow{
  position:absolute;
  width:600px;height:600px;
  top:50%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(139,0,0,.25) 0%,transparent 65%);
  filter:blur(30px);
}

/* ── Stage 1: Fingerprint ── */
.pledge-stage{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;
  padding:60px 32px 64px;
  text-align:center;
  gap:16px;
  transition:opacity var(--t4) var(--ease),transform var(--t4) var(--ease);
}
.pledge-stage.hidden{opacity:0;transform:translateY(-20px);pointer-events:none;position:absolute;inset:0}

.pledge-invite{
  font-size:1rem;color:rgba(255,255,255,.55);
  font-weight:400;letter-spacing:.3px;
}
.pledge-headline{
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:900;
  color:#fff;
  text-shadow:0 2px 16px rgba(0,0,0,.4);
  line-height:1.2;
}
.pledge-hint{
  font-size:.88rem;
  color:rgba(255,255,255,.4);
  margin-top:-4px;
}

/* Fingerprint trigger button */
.fp-trigger{
  position:relative;
  width:160px;height:160px;
  border-radius:50%;
  background:none;
  border:none;
  display:flex;align-items:center;justify-content:center;
  margin:12px 0 4px;
  transition:transform var(--t3) var(--spring);
}
.fp-trigger:hover{transform:scale(1.06)}
.fp-trigger:active{transform:scale(.95)}

.fp-rings{position:absolute;inset:0;pointer-events:none}
.fp-ring{
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(201,168,76,.3);
  animation:fpr linear infinite;
}
.fp-r1{inset:0;animation-duration:8s;border-color:rgba(201,168,76,.35)}
.fp-r2{inset:10px;animation-duration:12s;animation-direction:reverse;border-color:rgba(201,168,76,.2)}
.fp-r3{inset:20px;animation-duration:6s;border-color:rgba(201,168,76,.12)}
@keyframes fpr{to{transform:rotate(360deg)}}

.fp-img{
  width:100px;height:100px;
  position:relative;z-index:1;
  filter:drop-shadow(0 0 20px rgba(201,168,76,.5)) drop-shadow(0 0 6px rgba(139,0,0,.6));
  animation:fpglow 3s ease-in-out infinite;
  transition:filter var(--t3);
}
@keyframes fpglow{
  0%,100%{filter:drop-shadow(0 0 16px rgba(201,168,76,.4)) drop-shadow(0 0 6px rgba(139,0,0,.5))}
  50%{filter:drop-shadow(0 0 36px rgba(201,168,76,.8)) drop-shadow(0 0 14px rgba(139,0,0,.8))}
}
.fp-trigger:hover .fp-img{filter:drop-shadow(0 0 40px rgba(201,168,76,.9)) drop-shadow(0 0 18px rgba(200,0,0,.9))}

.fp-scan{
  position:absolute;
  top:50%;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(201,168,76,.8),transparent);
  transform:translateY(-50%);
  animation:scan 2.5s ease-in-out infinite;
  border-radius:var(--r-full);
  pointer-events:none;
}
@keyframes scan{
  0%{top:20%;opacity:0}
  10%{opacity:1}
  90%{opacity:.8}
  100%{top:80%;opacity:0}
}

.fp-caption{
  font-size:.78rem;
  color:rgba(255,255,255,.35);
  letter-spacing:.5px;
  text-transform:uppercase;
}

/* ================================================================
   PLEDGE + REGISTRATION — layout دو ستونه
   ================================================================ */
.pledge-reg-section{
  background:var(--ink-900);
  border-radius:var(--r20);
  overflow:hidden;
  position:relative;
  box-shadow:0 16px 48px rgba(0,0,0,.3);
}
.pr-bg{position:absolute;inset:0;pointer-events:none}
.pr-glow{
  position:absolute;
  width:700px;height:700px;
  top:50%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(139,0,0,.2) 0%,transparent 60%);
  filter:blur(40px);
}

/* دو ستون: اثر انگشت | فرم */
.pr-inner{
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:240px 1fr;
  min-height:480px;
}

/* ستون اثر انگشت */
.pr-left{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px 24px;
  border-left:1px solid rgba(255,255,255,.06);
  text-align:center;
  gap:12px;
  background:rgba(255,255,255,.02);
}
.pledge-invite{
  font-size:.85rem;color:rgba(255,255,255,.45);
  font-weight:400;line-height:1.6;
}
.pledge-headline{
  font-size:1.4rem;font-weight:900;
  color:#fff;line-height:1.3;
  text-shadow:0 2px 12px rgba(0,0,0,.4);
}

/* اثر انگشت */
.fp-area{
  position:relative;
  width:140px;height:140px;
  display:flex;align-items:center;justify-content:center;
  margin:8px 0;
}
.fp-rings{position:absolute;inset:0;pointer-events:none}
.fp-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(201,168,76,.25);
  animation:fpr linear infinite;
}
.fp-r1{inset:0;animation-duration:8s;border-color:rgba(201,168,76,.35)}
.fp-r2{inset:10px;animation-duration:12s;animation-direction:reverse;border-color:rgba(201,168,76,.2)}
.fp-r3{inset:20px;animation-duration:6s;border-color:rgba(201,168,76,.1)}
@keyframes fpr{to{transform:rotate(360deg)}}

.fp-img{
  width:90px;height:90px;
  position:relative;z-index:1;
  filter:drop-shadow(0 0 16px rgba(201,168,76,.45)) drop-shadow(0 0 6px rgba(139,0,0,.5));
  animation:fpglow 3s ease-in-out infinite;
}
@keyframes fpglow{
  0%,100%{filter:drop-shadow(0 0 14px rgba(201,168,76,.4)) drop-shadow(0 0 5px rgba(139,0,0,.4))}
  50%{filter:drop-shadow(0 0 32px rgba(201,168,76,.75)) drop-shadow(0 0 14px rgba(139,0,0,.75))}
}

.fp-scan{
  position:absolute;
  top:20%;left:8px;right:8px;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(201,168,76,.7),transparent);
  border-radius:var(--r-full);
  animation:scan 2.5s ease-in-out infinite;
  pointer-events:none;z-index:2;
}
@keyframes scan{
  0%{top:15%;opacity:0}
  10%{opacity:1}
  90%{opacity:.7}
  100%{top:85%;opacity:0}
}

.fp-caption{
  font-size:.75rem;
  color:rgba(255,255,255,.3);
  letter-spacing:.4px;
}
/* حالت فعال‌سازی هنگام submit */
.fp-img.fp-activated{
  animation:fpActivate .6s ease forwards;
}
@keyframes fpActivate{
  0%{filter:drop-shadow(0 0 14px rgba(201,168,76,.4)) drop-shadow(0 0 5px rgba(139,0,0,.4))}
  40%{filter:drop-shadow(0 0 48px rgba(201,168,76,1)) drop-shadow(0 0 24px rgba(200,0,0,1)) drop-shadow(0 0 60px rgba(255,200,50,.8))}
  100%{filter:drop-shadow(0 0 20px rgba(201,168,76,.6)) drop-shadow(0 0 8px rgba(139,0,0,.6))}
}

/* ستون فرم */
.pr-right{
  padding:36px 36px 40px;
  display:flex;flex-direction:column;
}
.reg-stage-header{margin-bottom:24px}
.reg-title{
  font-size:1.3rem;font-weight:800;
  color:#fff;margin-bottom:4px;
}
.reg-sub{font-size:.85rem;color:rgba(255,255,255,.4)}

/* ── دکمه اثر انگشت submit ── */
.btn-fp-submit{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  gap:14px;
  width:100%;
  padding:16px 24px;
  background:linear-gradient(135deg,rgba(139,0,0,.6) 0%,rgba(100,0,0,.8) 100%);
  border:1.5px solid rgba(201,168,76,.25);
  border-radius:var(--r12);
  cursor:pointer;
  overflow:hidden;
  transition:transform var(--t2) var(--ease),box-shadow var(--t2) var(--ease),border-color var(--t2);
  box-shadow:0 4px 20px rgba(139,0,0,.35);
}
.btn-fp-submit::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(201,168,76,.12),transparent 60%);
  opacity:0;transition:opacity var(--t2);
}
.btn-fp-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(139,0,0,.55);
  border-color:rgba(201,168,76,.5);
}
.btn-fp-submit:hover::before{opacity:1}
.btn-fp-submit:active{transform:translateY(1px)}

.bfp-rings{
  position:relative;width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.bfp-r1,.bfp-r2{
  position:absolute;border-radius:50%;
  border:1px solid rgba(201,168,76,.3);
  animation:fpr linear infinite;
}
.bfp-r1{inset:0;animation-duration:6s}
.bfp-r2{inset:6px;animation-duration:9s;animation-direction:reverse;border-color:rgba(201,168,76,.15)}
.bfp-img{
  width:32px;height:32px;
  position:relative;z-index:1;
  filter:drop-shadow(0 0 8px rgba(201,168,76,.5));
  transition:filter var(--t2);
}
.btn-fp-submit:hover .bfp-img{filter:drop-shadow(0 0 16px rgba(201,168,76,.9))}

.bfp-label{
  display:flex;flex-direction:column;align-items:flex-start;
  position:relative;z-index:1;
}
.btn-fp-submit .btn-txt{
  font-size:1rem;font-weight:700;
  color:#fff;line-height:1;
}
.btn-fp-submit .btn-spin{
  display:none;width:20px;height:20px;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  border-radius:50%;animation:spin .65s linear infinite;
}
.btn-fp-submit.loading .btn-txt{display:none}
.btn-fp-submit.loading .btn-spin{display:block}

/* موبایل: یک ستون */
@media(max-width:700px){
  .pr-inner{grid-template-columns:1fr}
  .pr-left{
    padding:32px 24px 24px;
    border-left:none;
    border-bottom:1px solid rgba(255,255,255,.06);
  }
  .fp-area{width:120px;height:120px}
  .fp-img{width:76px;height:76px}
  .pr-right{padding:24px 20px 32px}
}

/* ── Stage قدیمی حذف شد — layout دو ستونه جایگزین شد ── */

/* Form grid */
.form-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
  margin-bottom:20px;
}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-group label{font-size:.85rem;font-weight:600;color:rgba(255,255,255,.75)}
.req{color:var(--gold-400);margin-right:2px}
.opt{color:rgba(255,255,255,.3);font-weight:400;font-size:.78rem}

/* Inputs */
.inp-wrap{position:relative}
.inp-wrap input,.inp-wrap select,textarea{
  width:100%;
  padding:13px 44px 13px 14px;
  font-family:inherit;font-size:.93rem;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:var(--r8);
  color:#fff;
  outline:none;
  transition:border-color var(--t2) var(--ease),background var(--t2) var(--ease),box-shadow var(--t2) var(--ease);
}
.inp-wrap input::placeholder,textarea::placeholder{color:rgba(255,255,255,.25);font-size:.85rem}
.inp-wrap input:focus,.inp-wrap select:focus,textarea:focus{
  background:rgba(255,255,255,.1);
  border-color:var(--gold-500);
  box-shadow:0 0 0 3px rgba(201,168,76,.15);
}
.inp-icon{
  position:absolute;top:50%;right:14px;transform:translateY(-50%);
  color:rgba(255,255,255,.25);pointer-events:none;
  width:17px;height:17px;
}

.sel-wrap{position:relative}
.sel-wrap select{appearance:none;cursor:pointer;padding-left:36px}
.sel-arrow{
  position:absolute;top:50%;left:12px;transform:translateY(-50%);
  color:rgba(255,255,255,.25);pointer-events:none;
  width:15px;height:15px;
}

/* Textarea */
.ta-group{margin-bottom:24px}
.ta-wrap{position:relative}
textarea{
  min-height:110px;resize:vertical;
  padding:12px 14px 32px;
  line-height:1.7;
}
.char-cnt{
  position:absolute;bottom:10px;left:12px;
  font-size:.73rem;color:rgba(255,255,255,.25);pointer-events:none;
}

/* Primary button */
.btn-primary{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:16px;
  font-family:inherit;font-size:1rem;font-weight:700;
  color:#fff;
  background:linear-gradient(135deg,var(--red-700) 0%,var(--red-500) 100%);
  border:none;border-radius:var(--r8);
  overflow:hidden;
  transition:transform var(--t2) var(--ease),box-shadow var(--t2) var(--ease);
  box-shadow:0 6px 20px rgba(139,0,0,.45);
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--red-500),var(--red-900));
  opacity:0;transition:opacity var(--t2);
}
.btn-primary:hover::before{opacity:1}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(139,0,0,.55)}
.btn-primary:active{transform:translateY(1px)}
.btn-txt,.btn-ico{position:relative;z-index:1}
.btn-ico{width:18px;height:18px;transition:transform var(--t2)}
.btn-primary:hover .btn-ico{transform:translateX(-4px)}
.btn-spin{
  display:none;width:18px;height:18px;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  border-radius:50%;animation:spin .65s linear infinite;
  position:relative;z-index:1;
}
.btn-primary.loading .btn-txt,.btn-primary.loading .btn-ico{display:none}
.btn-primary.loading .btn-spin{display:block}
@keyframes spin{to{transform:rotate(360deg)}}

/* Ghost button */
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 20px;
  font-family:inherit;font-size:.9rem;font-weight:600;
  color:rgba(255,255,255,.6);
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:var(--r8);
  transition:var(--t2);
}
.btn-ghost:hover:not(:disabled){background:rgba(255,255,255,.1);color:#fff}
.btn-ghost:disabled{opacity:.35;cursor:not-allowed}

/* ================================================================
   COMMENTS SECTION
   ================================================================ */
.comments-section{}
.cmt-layout{
  display:flex;gap:28px;align-items:stretch;
}
.cmt-col{flex:0 0 58%;min-width:0}
.cmt-img-col{flex:1;min-width:0}

.cmt-card{
  background:var(--bg-card-2);
  border:1px solid rgba(107,0,0,.1);
  border-radius:var(--r20);
  padding:28px 24px;
  display:flex;flex-direction:column;
  box-shadow:var(--sh-sm);
  height:100%;
}
.cmt-head{text-align:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(107,0,0,.08)}
.cmt-title{
  display:inline-flex;align-items:center;gap:8px;
  font-size:1.3rem;font-weight:800;
  color:var(--red-700);
}

.cmt-scroll{
  flex:1;max-height:400px;overflow-y:auto;
  display:flex;flex-direction:column;gap:14px;
  padding-left:4px;
}
.cmt-scroll::-webkit-scrollbar{width:4px}
.cmt-scroll::-webkit-scrollbar-track{background:transparent}
.cmt-scroll::-webkit-scrollbar-thumb{background:var(--gold-500);border-radius:var(--r-full)}
.cmt-scroll::-webkit-scrollbar-thumb:hover{background:var(--red-700)}

/* Comment card */
.comment-item-card{
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:var(--r12);
  padding:14px;
  transition:border-color var(--t2) var(--ease),box-shadow var(--t2) var(--ease),transform var(--t2) var(--ease);
}
.comment-item-card:hover{
  border-color:rgba(107,0,0,.2);
  box-shadow:0 4px 16px rgba(107,0,0,.07);
  transform:translateY(-1px);
}
.comment-item-header{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:10px;margin-bottom:10px;
  border-bottom:1px dashed #f0f0f0;
}
.commenter-info{display:flex;align-items:center;gap:9px}
.commenter-avatar{
  width:32px;height:32px;
  background:rgba(107,0,0,.08);color:var(--red-700);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.9rem;flex-shrink:0;
}
.commenter-name{font-size:.85rem;font-weight:700;color:var(--ink-700);direction:ltr}
.comment-date-box{display:flex;align-items:center;gap:5px;color:var(--ink-200);font-size:.75rem}
.comment-item-body p{font-size:.88rem;line-height:1.8;color:var(--ink-400);text-align:justify;white-space:pre-line}

.cmt-foot{display:flex;justify-content:center;margin-top:18px}
.btn-more{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--red-700);color:#fff;
  border:none;border-radius:var(--r12);
  padding:10px 22px;font-family:inherit;
  font-size:.88rem;font-weight:700;
  transition:background var(--t2),transform var(--t2);
  box-shadow:0 4px 12px rgba(107,0,0,.3);
}
.btn-more:hover{background:var(--red-500);transform:translateY(-1px)}

/* Comments image */
.cmt-img-frame{
  position:relative;width:100%;height:100%;min-height:280px;
  border-radius:var(--r20);overflow:hidden;
  box-shadow:var(--sh-md);
}
.cmt-img{width:100%;height:100%;object-fit:cover}
.cmt-img-shine{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 50%,rgba(107,0,0,.2) 100%);
}

/* Skeletons */
.cmt-skel{
  padding:14px;border-radius:var(--r12);
  background:#fff;border:1px solid var(--ink-100);
}
.sk-row{display:flex;gap:9px;margin-bottom:10px}
.sk-av{width:32px;height:32px;border-radius:50%;background:#f0eee9;flex-shrink:0;animation:shim 1.6s ease infinite}
.sk-ls{flex:1;display:flex;flex-direction:column;gap:6px;justify-content:center}
.sk-l{height:9px;border-radius:var(--r-full);background:#f0eee9;animation:shim 1.6s ease infinite}
.w100{width:100%}.w75{width:75%}.w60{width:60%}.w40{width:40%}
@keyframes shim{0%{background:#f0eee9}50%{background:#f8f6f2}100%{background:#f0eee9}}

/* ================================================================
   PARTICIPATION SECTION
   ================================================================ */
.part-section{}
.part-card{
  background:var(--bg-card);
  border-radius:var(--r20);
  padding:40px;
  box-shadow:var(--sh-md);
  border:1px solid rgba(0,0,0,.04);
}
.part-quote{
  font-size:1rem;font-weight:700;
  color:var(--red-700);
  text-align:center;line-height:1.9;
  max-width:680px;margin:0 auto 36px;
  padding:18px 24px;
  background:rgba(107,0,0,.04);
  border-radius:var(--r12);
  border:1px solid rgba(107,0,0,.08);
  font-style:normal;
}
.part-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:16px;
}
.part-item a{
  display:block;border-radius:var(--r12);overflow:hidden;
  box-shadow:var(--sh-xs);
  transition:transform var(--t3) var(--spring),box-shadow var(--t3) var(--ease);
}
.part-item a:hover{transform:translateY(-8px) scale(1.03);box-shadow:var(--sh-md)}
.part-item img{width:100%;height:auto;display:block}

/* ================================================================
   MODAL
   ================================================================ */
.modal{
  display:none;
  position:fixed;inset:0;z-index:1000;
  align-items:center;justify-content:center;padding:20px;
}
.modal.visible{display:flex}
.modal-bd{
  position:absolute;inset:0;
  background:rgba(5,0,0,.7);
  backdrop-filter:blur(8px);
}
.modal-box{
  position:relative;
  background:var(--ink-800);
  border:1px solid rgba(201,168,76,.15);
  border-radius:var(--r20);
  padding:40px 36px;
  width:100%;max-width:420px;
  box-shadow:0 32px 80px rgba(0,0,0,.5);
  animation:mboxIn .4s var(--spring);
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;
}
@keyframes mboxIn{
  from{opacity:0;transform:translateY(28px) scale(.95)}
  to{opacity:1;transform:none}
}
.modal-cls{
  position:absolute;top:14px;left:14px;
  width:32px;height:32px;border-radius:50%;
  border:none;background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.5);
  display:flex;align-items:center;justify-content:center;
  transition:background var(--t2),color var(--t2);
}
.modal-cls:hover{background:var(--red-700);color:#fff}
.modal-ico{
  width:60px;height:60px;
  background:rgba(139,0,0,.2);color:var(--gold-400);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(201,168,76,.2);
}
.modal-ttl{font-size:1.2rem;font-weight:800;color:#fff}
.modal-sub{font-size:.88rem;color:rgba(255,255,255,.4)}

.otp-wrap{width:100%}
.otp-wrap input{
  width:100%;text-align:center;
  letter-spacing:14px;font-size:1.8rem;font-weight:800;
  padding:16px 10px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:var(--r8);
  color:#fff;outline:none;
  transition:border-color var(--t2),box-shadow var(--t2);
}
.otp-wrap input:focus{border-color:var(--gold-500);box-shadow:0 0 0 3px rgba(201,168,76,.15)}

.modal-acts{display:grid;grid-template-columns:2fr 1fr;gap:10px;width:100%}

/* ================================================================
   TOAST
   ================================================================ */
.toast{
  position:fixed;bottom:28px;right:28px;
  display:flex;align-items:center;gap:11px;
  padding:14px 18px;
  border-radius:var(--r12);
  background:var(--ink-800);
  color:#fff;
  font-size:.9rem;font-weight:600;
  box-shadow:0 16px 48px rgba(0,0,0,.4);
  z-index:1100;
  max-width:340px;
  border-right:4px solid var(--red-700);
  transform:translateY(72px) scale(.95);
  opacity:0;
  transition:transform .35s var(--spring),opacity .3s;
  pointer-events:none;
}
.toast.show{transform:none;opacity:1;pointer-events:auto}
.toast.success{border-right-color:#4caf50}
.toast.info{border-right-color:#29b6f6}
.toast.error{border-right-color:#ef5350}
.toast-icon{font-size:1rem;flex-shrink:0}
.toast.success .toast-icon::before{content:'✓';color:#4caf50}
.toast.info    .toast-icon::before{content:'ℹ';color:#29b6f6}
.toast.error   .toast-icon::before{content:'✕';color:#ef5350}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{
  background:var(--ink-900);
  border-top:1px solid rgba(201,168,76,.15);
  padding:36px 0;
}
.ftr-inner{
  display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;
}
.ftr-brand{
  display:flex;align-items:center;gap:9px;
  color:rgba(255,255,255,.7);font-weight:700;font-size:.95rem;
}
.ftr-brand img{border-radius:50%;opacity:.7;filter:drop-shadow(0 0 6px rgba(201,168,76,.3))}
.ftr-copy{font-size:.8rem;color:rgba(255,255,255,.3)}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:768px){
  .site-header{padding:56px 0 44px}
  .page-stack{gap:24px;padding:28px 0 56px}
  .card,.conditions-section,.reg-stage,.part-card{padding:24px}
  .counter-card{padding:32px 20px 40px}
  .cc-body{flex-direction:column;gap:20px}
  .cmt-layout{flex-direction:column}
  .cmt-col,.cmt-img-col{flex:none;width:100%}
  .cmt-img-frame{min-height:220px}
  .modal-acts{grid-template-columns:1fr}
  .toast{left:16px;right:16px;bottom:16px;max-width:none}
  .hdr-ornament{display:none}
  .pledge-stage{padding:44px 20px 48px}
  .fp-trigger{width:140px;height:140px}
  .fp-img{width:88px;height:88px}
  .part-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){
  .form-grid{grid-template-columns:1fr}
  .cond-grid{grid-template-columns:repeat(1,1fr)}
  .part-grid{grid-template-columns:repeat(2,1fr)}
  .pledge-headline{font-size:1.7rem}
}

/* ================================================================
   ACCESSIBILITY
   ================================================================ */
:focus-visible{outline:2px solid var(--gold-500);outline-offset:3px;border-radius:4px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
