:root{
  --burg:#6b1a2a;--burg2:#8b2439;--burg3:#4a0f1c;
  --gold:#c9922a;--gold2:#e8b84b;--gold3:#f5d98a;
  --cream:#fdf8f0;--cream2:#f7efe0;
  --ink:#1a0a0f;--ink2:#3d1a22;--muted:#7a5060;
  --border:rgba(107,26,42,0.18);--border2:rgba(107,26,42,0.32);
  --shadow:0 4px 32px rgba(107,26,42,0.13);
  --r:10px;--r-lg:18px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Lato',sans-serif;background:var(--cream);color:var(--ink);min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at 0% 0%,rgba(107,26,42,.07) 0%,transparent 55%),
             radial-gradient(ellipse at 100% 100%,rgba(201,146,42,.07) 0%,transparent 55%);}
body>*{position:relative;z-index:1}

/* ── NAV ── */
nav{display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;height:68px;background:rgba(253,248,240,.94);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:300}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo-mark{width:38px;height:38px;background:var(--burg);border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:1rem;color:var(--gold3);font-weight:700}
.logo-text{font-family:'Cinzel',serif;font-size:1.25rem;font-weight:600;color:var(--burg);letter-spacing:.04em}
.logo-sub{font-size:.65rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:1px}
.nav-r{display:flex;align-items:center;gap:1.5rem}
.nav-r a{font-size:.85rem;color:var(--ink2);text-decoration:none;transition:color .2s}
.nav-r a:hover{color:var(--burg)}
.nav-cta{background:var(--burg);color:var(--gold3)!important;font-family:'Cinzel',serif;font-size:.78rem;font-weight:600;padding:.45rem 1.1rem;border-radius:8px;letter-spacing:.05em;transition:background .2s!important}
.nav-cta:hover{background:var(--burg2)!important}

/* ── HERO ── */
.hero{text-align:center;padding:5rem 1.5rem 3rem;max-width:860px;margin:0 auto}
.hero-eye{display:inline-flex;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;animation:rise .7s ease both}
.hero-eye::before,.hero-eye::after{content:'✦';font-size:.6rem;opacity:.7}
.hero h1{font-family:'Cinzel',serif;font-size:clamp(2.2rem,5.5vw,4.2rem);font-weight:700;line-height:1.06;color:var(--burg);animation:rise .7s ease .08s both}
.hero h1 span{display:block;font-family:'Great Vibes',cursive;font-size:clamp(2.6rem,6vw,4.8rem);color:var(--gold);font-weight:400;line-height:1.1;margin-top:.2rem}
.hero p{font-size:1rem;color:var(--muted);max-width:560px;margin:1.2rem auto 0;line-height:1.75;font-weight:300;animation:rise .7s ease .2s both}
.hstats{display:flex;align-items:center;justify-content:center;gap:1.8rem;margin-top:2rem;animation:rise .7s ease .28s both;flex-wrap:wrap}
.hs{text-align:center}
.hs-n{font-family:'Cinzel',serif;font-size:1.4rem;font-weight:600;color:var(--burg)}
.hs-l{font-size:.7rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}
.hs-d{width:1px;height:30px;background:var(--border2)}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ── SECTION ── */
.sec{max-width:1180px;margin:0 auto;padding:3.5rem 1.5rem}
.sec-tag{text-align:center;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem;display:block}
.sec-title{font-family:'Cinzel',serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:600;color:var(--burg);text-align:center;line-height:1.2}
.sec-sub{text-align:center;color:var(--muted);font-size:.92rem;margin-top:.5rem;font-weight:300}

/* ── TEMPLATE GRID ── */
.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:.9rem;margin-top:2rem}
.tpl-card{border:2px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:all .22s;background:white;position:relative}
.tpl-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--shadow)}
.tpl-card.selected{border-color:var(--burg);box-shadow:0 0 0 3px rgba(107,26,42,.13)}
.tpl-preview{height:145px;overflow:hidden;position:relative}
.tpl-name{padding:.5rem .7rem;font-family:'Cinzel',serif;font-size:.7rem;font-weight:600;color:var(--burg);letter-spacing:.04em;text-align:center;border-top:1px solid var(--border)}
.tpl-badge{position:absolute;top:6px;right:6px;font-size:.58rem;padding:2px 6px;border-radius:100px;font-weight:600;letter-spacing:.04em;z-index:2}
.b-classic{background:rgba(201,146,42,.2);color:#7a4a00}
.b-photo1{background:rgba(107,26,42,.18);color:var(--burg)}
.b-photo2{background:rgba(26,60,107,.18);color:#1a3c6b}
.b-new{background:rgba(40,140,80,.18);color:#1a5a30}
.thumb{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px;text-align:center}
.t-mn{font-family:'Cinzel',serif;font-size:6.5px;letter-spacing:1.5px}
.t-gv{font-family:'Great Vibes',cursive;font-size:12px}
.t-dt{font-size:6px;letter-spacing:1px;opacity:.52;margin-top:1px}

/* ── EDITOR LAYOUT ── */
.editor-wrap{max-width:1200px;margin:2rem auto 0;padding:0 1.5rem;display:grid;grid-template-columns:400px 1fr;gap:2rem;align-items:start}
@media(max-width:960px){.editor-wrap{grid-template-columns:1fr}}

/* ── FORM PANEL ── */
.form-panel{background:white;border:1px solid var(--border2);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);position:sticky;top:84px}
.fp-hdr{background:var(--burg);color:var(--cream);padding:1rem 1.3rem;font-family:'Cinzel',serif;font-size:.92rem;font-weight:600;letter-spacing:.04em;display:flex;align-items:center;gap:8px}
.fp-body{padding:1.2rem;max-height:calc(100vh - 190px);overflow-y:auto}
.fp-body::-webkit-scrollbar{width:4px}
.fp-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.fsec{margin-bottom:1.3rem}
.fsec-title{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:.7rem;display:flex;align-items:center;gap:6px}
.fsec-title::after{content:'';flex:1;height:1px;background:rgba(201,146,42,.22)}
.fg{margin-bottom:.8rem}
.fl{display:block;font-size:.76rem;color:var(--muted);margin-bottom:.28rem;letter-spacing:.02em}
.fi,.fsel,.fta{width:100%;background:var(--cream2);border:1px solid var(--border2);border-radius:8px;padding:.55rem .8rem;color:var(--ink);font-family:'Lato',sans-serif;font-size:.88rem;outline:none;transition:border-color .2s}
.fi:focus,.fsel:focus,.fta:focus{border-color:var(--gold)}
.fi::placeholder,.fta::placeholder{color:#b8a090}
.fsel option{background:white}
.fta{min-height:76px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}

/* ── PHOTO UPLOAD BLOCKS ── */
.photo-upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.photo-upload-grid.single{grid-template-columns:1fr}
.ubox{border:2px dashed var(--border2);border-radius:10px;cursor:pointer;transition:all .2s;overflow:hidden;background:var(--cream2);position:relative}
.ubox:hover{border-color:var(--gold);background:rgba(201,146,42,.04)}
.ubox.has{border-style:solid;border-color:var(--burg)}
.ubox input{display:none}
.ubox-inner{padding:.85rem .7rem;text-align:center}
.ubox-icon{font-size:1.6rem;margin-bottom:.3rem;display:block}
.ubox-label{font-size:.7rem;font-weight:500;color:var(--burg);display:block;margin-bottom:.15rem}
.ubox-hint{font-size:.65rem;color:var(--muted);line-height:1.4}
.ubox-prev{position:relative}
.ubox-prev img{width:100%;height:90px;object-fit:cover;display:block}
.ubox-rm{position:absolute;top:5px;right:5px;background:rgba(0,0,0,.65);color:white;border:none;border-radius:50%;width:20px;height:20px;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.ubox-rm:hover{background:rgba(107,26,42,.9)}
.upload-note{font-size:.68rem;color:var(--muted);margin-top:.35rem;font-style:italic}

/* ── ACTION BUTTONS ── */
.gen-btn{width:100%;background:var(--burg);color:var(--gold3);border:none;border-radius:10px;padding:.82rem;font-family:'Cinzel',serif;font-size:.95rem;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:all .2s;margin-top:.5rem}
.gen-btn:hover{background:var(--burg2)}
.dl-btn{width:100%;background:var(--gold);color:var(--ink);border:none;border-radius:10px;padding:.72rem;font-family:'Cinzel',serif;font-size:.88rem;font-weight:700;letter-spacing:.05em;cursor:pointer;transition:all .2s;margin-top:.55rem}
.dl-btn:hover{background:var(--gold2)}
.share-row{display:flex;gap:.45rem;margin-top:.45rem}
.sh-btn{flex:1;background:var(--cream2);border:1px solid var(--border2);color:var(--muted);font-size:.75rem;padding:.5rem;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center}
.sh-btn:hover{border-color:var(--burg);color:var(--burg)}

/* ── PREVIEW PANEL ── */
.preview-panel{display:flex;flex-direction:column;gap:1rem}
.preview-toolbar{display:flex;align-items:center;justify-content:space-between;background:white;border:1px solid var(--border);border-radius:var(--r);padding:.65rem 1rem;flex-wrap:wrap;gap:.5rem}
.tb-label{font-size:.76rem;color:var(--muted);letter-spacing:.03em}
.tb-btns{display:flex;gap:.4rem}
.tb-btn{background:var(--cream2);border:1px solid var(--border2);color:var(--ink2);font-family:'Lato',sans-serif;font-size:.73rem;padding:.32rem .75rem;border-radius:7px;cursor:pointer;transition:all .15s}
.tb-btn:hover{border-color:var(--burg);color:var(--burg)}
.tb-btn.on{background:var(--burg);color:var(--gold3);border-color:var(--burg)}
.canvas-wrap{background:white;border:1px solid var(--border2);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;padding:1.8rem;min-height:580px}
#cardWrap{width:100%;max-width:500px;border-radius:8px;overflow:hidden;box-shadow:0 8px 48px rgba(107,26,42,.25);position:relative;transition:all .4s}

/* ── LOADING ── */
.lov{display:none;position:absolute;inset:0;background:rgba(253,248,240,.93);z-index:10;flex-direction:column;align-items:center;justify-content:center;gap:1rem;border-radius:8px}
.lov.show{display:flex}
.spin{width:38px;height:38px;border:3px solid var(--border2);border-top-color:var(--burg);border-radius:50%;animation:sp 1s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.lov-txt{font-family:'Cinzel',serif;font-size:.82rem;color:var(--burg);letter-spacing:.06em}

/* ═══════════════════════════════════════
   CARD BASE STYLES
═══════════════════════════════════════ */
.croot{min-height:700px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.cin{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.2rem 2rem;gap:.88rem;position:relative;z-index:3;text-align:center}
.c-ml{font-family:'Noto Sans Malayalam',sans-serif;font-size:.82rem;letter-spacing:.06em}
.c-dv{display:flex;align-items:center;gap:8px;width:82%}
.c-dv::before,.c-dv::after{content:'';flex:1;height:1px}
.c-tag{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase}
.c-bride,.c-groom{font-family:'Great Vibes',cursive;font-size:clamp(1.7rem,5vw,2.8rem);line-height:1.1}
.c-amp{font-family:'IM Fell English',serif;font-style:italic;font-size:1.35rem;display:block;margin:.05rem 0}
.c-evt{border-radius:10px;padding:.82rem 1.2rem;width:100%}
.c-etitle{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:.38rem}
.c-date{font-family:'IM Fell English',serif;font-size:1.3rem;font-style:italic}
.c-time{font-size:.76rem;margin-top:.2rem;font-weight:300}
.c-venue{font-family:'IM Fell English',serif;font-size:.95rem;font-style:italic}
.c-addr{font-size:.7rem;margin-top:.16rem}
.c-host{font-size:.7rem;font-weight:300}
.c-note{font-size:.68rem;font-style:italic;margin-top:-.12rem}
.c-btm{font-family:'Noto Sans Malayalam',sans-serif;font-size:.7rem;padding:.68rem;text-align:center;letter-spacing:.04em}
.cborder{position:absolute;inset:12px;border:1px solid rgba(255,255,255,.15);pointer-events:none;z-index:1}
.cc{position:absolute;font-size:1.2rem;z-index:2}
.cc-tl{top:6px;left:8px}.cc-tr{top:6px;right:8px}.cc-bl{bottom:6px;left:8px}.cc-br{bottom:6px;right:8px}

/* ── CLASSIC CARD THEMES ── */
.t1{background:linear-gradient(160deg,#4a0f1c,#6b1a2a,#4a0f1c)}
.t1 .c-ml,.t1 .c-btm{color:rgba(245,217,138,.48)} .t1 .c-dv::before,.t1 .c-dv::after{background:rgba(201,146,42,.3)} .t1 .c-dv span,.t1 .cc{color:rgba(201,146,42,.52)}
.t1 .c-tag{color:rgba(245,217,138,.4)} .t1 .c-bride,.t1 .c-groom{color:#f5d98a} .t1 .c-amp{color:rgba(232,184,75,.68)}
.t1 .c-evt{background:rgba(255,255,255,.06);border:1px solid rgba(201,146,42,.17)} .t1 .c-etitle{color:rgba(232,184,75,.72)}
.t1 .c-date{color:#fdf8f0} .t1 .c-time{color:rgba(253,248,240,.52)} .t1 .c-venue{color:#e8c97a} .t1 .c-addr,.t1 .c-host,.t1 .c-note{color:rgba(253,248,240,.36)}
.t1 .c-btm{border-top:1px solid rgba(201,146,42,.1)}

.t2{background:linear-gradient(160deg,#fffdf7,#fdf5e4,#fffdf7)}
.t2::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23c9922a' fill-opacity='0.04'%3E%3Cpath d='M20 20c2 0 3-1 3-3s-1-3-3-3-3 1-3 3 1 3 3 3zm0-10c2 0 3-1 3-3s-1-3-3-3-3 1-3 3 1 3 3 3z'/%3E%3C/g%3E%3C/svg%3E")}
.t2 .gb1{position:absolute;inset:10px;border:2px solid rgba(201,146,42,.38);pointer-events:none;z-index:1}
.t2 .gb2{position:absolute;inset:15px;border:1px solid rgba(201,146,42,.16);pointer-events:none;z-index:1}
.t2 .cc{color:rgba(201,146,42,.4)} .t2 .c-ml{color:rgba(107,26,42,.36)} .t2 .c-dv::before,.t2 .c-dv::after{background:rgba(107,26,42,.17)} .t2 .c-dv span{color:rgba(107,26,42,.33)}
.t2 .c-tag{color:rgba(107,26,42,.28)} .t2 .c-bride,.t2 .c-groom{color:var(--burg)} .t2 .c-amp{color:var(--gold)}
.t2 .c-evt{background:rgba(107,26,42,.04);border:1px solid rgba(107,26,42,.08)} .t2 .c-etitle{color:var(--gold)}
.t2 .c-date{color:var(--burg)} .t2 .c-time,.t2 .c-venue,.t2 .c-addr,.t2 .c-host,.t2 .c-note{color:var(--muted)}
.t2 .c-btm{color:rgba(107,26,42,.26);border-top:1px solid rgba(107,26,42,.07)}

.t3{background:linear-gradient(160deg,#0d2218,#1a3a2a,#0d2218)}
.t3 .c-ml,.t3 .c-btm{color:rgba(245,217,138,.43)} .t3 .c-dv::before,.t3 .c-dv::after{background:rgba(201,146,42,.26)} .t3 .c-dv span,.t3 .cc{color:rgba(201,146,42,.47)}
.t3 .c-tag{color:rgba(245,217,138,.36)} .t3 .c-bride,.t3 .c-groom{color:#f5d98a} .t3 .c-amp{color:rgba(232,184,75,.62)}
.t3 .c-evt{background:rgba(255,255,255,.055);border:1px solid rgba(201,146,42,.15)} .t3 .c-etitle{color:rgba(232,184,75,.68)}
.t3 .c-date{color:#e8f5ee} .t3 .c-time,.t3 .c-addr,.t3 .c-host,.t3 .c-note{color:rgba(232,245,238,.42)} .t3 .c-venue{color:#c8e6d4}
.t3 .c-btm{border-top:1px solid rgba(201,146,42,.08)}

.t4{background:linear-gradient(160deg,#1a0d2a,#2a1a3a,#1a0d2a)}
.t4 .c-ml,.t4 .c-btm{color:rgba(200,180,245,.4)} .t4 .c-dv::before,.t4 .c-dv::after{background:rgba(167,139,250,.22)} .t4 .c-dv span,.t4 .cc{color:rgba(167,139,250,.4)}
.t4 .c-tag{color:rgba(200,180,245,.3)} .t4 .c-bride,.t4 .c-groom{color:#d4b8f5} .t4 .c-amp{color:rgba(167,139,250,.6)}
.t4 .c-evt{background:rgba(167,139,250,.07);border:1px solid rgba(167,139,250,.15)} .t4 .c-etitle{color:rgba(167,139,250,.7)}
.t4 .c-date{color:#ede8ff} .t4 .c-time,.t4 .c-addr,.t4 .c-host,.t4 .c-note{color:rgba(237,232,255,.4)} .t4 .c-venue{color:#c8b4f5}
.t4 .c-btm{border-top:1px solid rgba(167,139,250,.08)}

.t5{background:linear-gradient(160deg,#fdf0f5,#fce8ef,#fdf0f5)}
.t5 .gb1{position:absolute;inset:10px;border:2px solid rgba(212,96,138,.3);pointer-events:none;z-index:1}
.t5 .gb2{position:absolute;inset:15px;border:1px solid rgba(212,96,138,.14);pointer-events:none;z-index:1}
.t5 .cc{color:rgba(212,96,138,.36)} .t5 .c-ml{color:rgba(180,60,110,.34)} .t5 .c-dv::before,.t5 .c-dv::after{background:rgba(212,96,138,.23)} .t5 .c-dv span{color:rgba(212,96,138,.4)}
.t5 .c-tag{color:rgba(180,60,110,.28)} .t5 .c-bride,.t5 .c-groom{color:#b83c6e} .t5 .c-amp{color:#d4608a}
.t5 .c-evt{background:rgba(212,96,138,.052);border:1px solid rgba(212,96,138,.11)} .t5 .c-etitle{color:#d4608a}
.t5 .c-date{color:#8b1a42} .t5 .c-time,.t5 .c-addr,.t5 .c-host,.t5 .c-note{color:rgba(139,26,66,.48)} .t5 .c-venue{color:#b83c6e}
.t5 .c-btm{color:rgba(180,60,110,.22);border-top:1px solid rgba(212,96,138,.08)}

.t6{background:linear-gradient(160deg,#090910,#141422,#090910)}
.t6 .c-ml,.t6 .c-btm{color:rgba(245,217,138,.32)} .t6 .c-dv::before,.t6 .c-dv::after{background:rgba(232,184,75,.18)} .t6 .c-dv span,.t6 .cc{color:rgba(232,184,75,.3)}
.t6 .c-tag{color:rgba(232,184,75,.28)} .t6 .c-bride,.t6 .c-groom{color:#e8d4a0} .t6 .c-amp{color:rgba(232,184,75,.5)}
.t6 .c-evt{background:rgba(232,184,75,.05);border:1px solid rgba(232,184,75,.11)} .t6 .c-etitle{color:rgba(232,184,75,.6)}
.t6 .c-date{color:#f0ecff} .t6 .c-time,.t6 .c-addr,.t6 .c-host,.t6 .c-note{color:rgba(240,236,255,.36)} .t6 .c-venue{color:#d0c8e8}
.t6 .c-btm{border-top:1px solid rgba(232,184,75,.07)}

/* ── PHOTO CARD PARTS ── */
/* Banner */
.photo-banner{width:100%;height:250px;overflow:hidden;position:relative;flex-shrink:0}
.photo-banner img{width:100%;height:100%;object-fit:cover}
/* Split */
.split-wrap{display:flex;width:100%;height:260px;flex-shrink:0}
.split-half{flex:1;overflow:hidden;position:relative}
.split-half img{width:100%;height:100%;object-fit:cover}
.split-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(107,26,42,.42),rgba(201,146,42,.25))}
.split-ov2{position:absolute;inset:0;background:linear-gradient(225deg,rgba(201,146,42,.28),rgba(107,26,42,.4))}
.split-ctr{width:76px;background:var(--burg);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:2}
.split-txt{font-family:'Great Vibes',cursive;font-size:1.3rem;color:var(--gold3);writing-mode:vertical-rl}
/* Ring */
.ring{width:115px;height:115px;border-radius:50%;overflow:hidden;margin:0 auto .2rem}
.ring img{width:100%;height:100%;object-fit:cover}
/* Arch */
.arch-photo{width:145px;height:185px;border-radius:100px 100px 0 0;overflow:hidden;margin:0 auto .2rem}
.arch-photo img{width:100%;height:100%;object-fit:cover}
/* Dual circles */
.dual-circles{display:flex;justify-content:center;align-items:center;gap:.9rem;margin-bottom:.15rem}
.dc{width:90px;height:90px;border-radius:50%;overflow:hidden}
.dc img{width:100%;height:100%;object-fit:cover}
.dc .npc{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.7rem}
.dc-amp{font-family:'Great Vibes',cursive;font-size:1.4rem;color:var(--gold)}
/* Full BG */
.photo-bg{position:absolute;inset:0;z-index:0}
.photo-bg img{width:100%;height:100%;object-fit:cover}
.photo-bg .ov{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(26,10,15,.52),rgba(26,10,15,.76))}
/* No-photo placeholders */
.nop{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem}
.nop span{font-size:2rem}
.nop p{font-size:.68rem;letter-spacing:.06em;text-align:center;padding:0 .8rem;opacity:.45}
/* Diamond pair */
.diamond-pair{display:flex;justify-content:center;gap:.7rem;margin-bottom:.15rem}
.diamond-frame{width:88px;height:88px;overflow:hidden;position:relative;transform:rotate(45deg);border-radius:4px}
.diamond-frame img{width:100%;height:100%;object-fit:cover;transform:rotate(-45deg) scale(1.5)}
.diamond-frame .npc{transform:rotate(-45deg);width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
/* Oval pair */
.oval-pair{display:flex;justify-content:center;gap:1rem;margin-bottom:.2rem}
.oval-frame{width:80px;height:110px;border-radius:50px;overflow:hidden}
.oval-frame img{width:100%;height:100%;object-fit:cover}
.oval-frame .npc{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
/* Side portrait */
.side-portrait{width:100%;display:flex;flex-shrink:0}
.sp-photo{width:45%;overflow:hidden;position:relative}
.sp-photo img{width:100%;height:100%;object-fit:cover}
.sp-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;gap:.7rem;text-align:center}
/* Top & Bottom banner */
.top-banner{width:100%;height:200px;overflow:hidden;position:relative;flex-shrink:0}
.top-banner img{width:100%;height:100%;object-fit:cover}
.bot-banner{width:100%;height:160px;overflow:hidden;position:relative;flex-shrink:0;margin-top:auto}
.bot-banner img{width:100%;height:100%;object-fit:cover}

/* ── HOW & PRICING ── */
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1.8rem}
.how-card{background:white;border:1px solid var(--border);border-radius:var(--r-lg);padding:1.4rem 1.1rem;text-align:center}
.how-n{font-family:'Cinzel',serif;font-size:2rem;font-weight:700;color:var(--burg);opacity:.13;line-height:1}
.how-title{font-weight:500;color:var(--ink2);margin:.45rem 0 .25rem;font-size:.92rem}
.how-desc{font-size:.8rem;color:var(--muted);line-height:1.6;font-weight:300}
.price-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.8rem}
.price-card{background:white;border:1px solid var(--border2);border-radius:var(--r-lg);padding:1.6rem 1.4rem;text-align:center}
.price-card.feat{background:var(--burg);border-color:var(--burg)}
.price-amt{font-family:'Cinzel',serif;font-size:2.3rem;font-weight:700;color:var(--burg)}
.price-card.feat .price-amt{color:var(--gold3)}
.price-per{font-size:.75rem;color:var(--muted)}
.price-card.feat .price-per{color:rgba(245,217,138,.5)}
.price-name{font-family:'Cinzel',serif;font-size:.82rem;font-weight:600;letter-spacing:.08em;color:var(--burg);margin-bottom:.9rem;text-transform:uppercase}
.price-card.feat .price-name{color:var(--gold2)}
.price-feats{list-style:none;text-align:left;margin:1rem 0;display:flex;flex-direction:column;gap:.45rem}
.price-feats li{font-size:.8rem;color:var(--muted);display:flex;gap:6px;align-items:flex-start}
.price-card.feat .price-feats li{color:rgba(245,217,138,.6)}
.price-feats li::before{content:'✦';color:var(--gold);font-size:.56rem;margin-top:4px;flex-shrink:0}
.price-card.feat .price-feats li::before{color:var(--gold2)}
.pbtn{width:100%;padding:.68rem;border-radius:9px;font-family:'Cinzel',serif;font-size:.83rem;font-weight:600;letter-spacing:.05em;cursor:pointer;border:none;transition:all .2s}
.pbtn-out{background:transparent;border:1.5px solid var(--burg);color:var(--burg)}
.pbtn-out:hover{background:var(--burg);color:var(--gold3)}
.pbtn-fill{background:var(--gold);color:var(--ink)}
.pbtn-fill:hover{background:var(--gold2)}

/* ── FOOTER ── */
footer{background:var(--burg3);color:rgba(253,248,240,.75);padding:2.5rem 2rem;margin-top:3rem}
.fi2{max-width:1180px;margin:0 auto;display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.fb p{font-size:.83rem;margin-top:.7rem;line-height:1.65;opacity:.58;max-width:260px;font-weight:300}
.fc h4{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold2);margin-bottom:.85rem;font-family:'Cinzel',serif;font-weight:600}
.fc a{display:block;font-size:.82rem;color:rgba(253,248,240,.5);text-decoration:none;margin-bottom:.42rem;transition:color .2s}
.fc a:hover{color:var(--gold3)}
.fb2{max-width:1180px;margin:1.5rem auto 0;padding-top:1.1rem;border-top:1px solid rgba(253,248,240,.09);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.fb2 p{font-size:.72rem;opacity:.36}

/* ── TOAST ── */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(16px);background:var(--burg);color:var(--gold3);font-family:'Cinzel',serif;font-size:.8rem;font-weight:600;padding:.62rem 1.4rem;border-radius:100px;z-index:999;opacity:0;transition:all .3s;pointer-events:none;letter-spacing:.04em;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ══════════════════════════════════════════
   PAYMENT MODAL
══════════════════════════════════════════ */
.pay-overlay{
  display:none;position:fixed;inset:0;z-index:600;
  background:rgba(26,10,15,.62);backdrop-filter:blur(10px);
  align-items:center;justify-content:center;padding:1rem;
}
.pay-overlay.show{display:flex;animation:fadeInPay .22s ease}
@keyframes fadeInPay{from{opacity:0}to{opacity:1}}

.pay-modal{
  background:white;border-radius:22px;width:100%;max-width:420px;
  box-shadow:0 32px 80px rgba(107,26,42,.38),0 0 0 1px rgba(107,26,42,.07);
  position:relative;overflow:hidden;
  animation:slideUpPay .28s cubic-bezier(.22,.88,.26,1) both;
}
@keyframes slideUpPay{from{transform:translateY(28px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Close button */
.pay-close{
  position:absolute;top:12px;right:14px;z-index:2;
  background:rgba(107,26,42,.08);border:none;border-radius:50%;
  width:30px;height:30px;font-size:.8rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:all .18s;
}
.pay-close:hover{background:rgba(107,26,42,.15);color:var(--burg)}

/* Header */
.pay-header{
  background:linear-gradient(135deg,var(--burg3),var(--burg));
  padding:1.4rem 1.6rem 1.3rem;display:flex;align-items:center;gap:12px;
}
.pay-logo-mark{
  width:42px;height:42px;border-radius:10px;
  background:rgba(245,217,138,.18);border:1.5px solid rgba(245,217,138,.3);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cinzel',serif;font-size:1.1rem;color:var(--gold3);font-weight:700;flex-shrink:0;
}
.pay-brand{font-family:'Cinzel',serif;font-size:1rem;font-weight:700;color:var(--gold3);letter-spacing:.04em}
.pay-brand-sub{font-size:.65rem;color:rgba(245,217,138,.5);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}

/* Body */
.pay-body{padding:1.4rem 1.6rem 1.6rem}

/* Card info row */
.pay-card-info{
  display:flex;align-items:center;gap:12px;padding:.9rem 1rem;
  background:var(--cream2);border:1px solid var(--border);border-radius:var(--r);
  margin-bottom:1rem;
}
.pay-card-icon{font-size:1.6rem;flex-shrink:0}
.pay-card-name{font-family:'Cinzel',serif;font-size:.88rem;font-weight:600;color:var(--burg)}
.pay-card-sub{font-size:.7rem;color:var(--muted);margin-top:2px;font-weight:300}

/* Feature list */
.pay-feats{
  list-style:none;margin-bottom:1.1rem;
  display:flex;flex-direction:column;gap:.38rem;
}
.pay-feats li{
  font-size:.78rem;color:var(--ink2);display:flex;align-items:center;gap:8px;
}
.pay-feats li::before{
  content:'✦';color:var(--gold);font-size:.55rem;flex-shrink:0;
}

/* Price row */
.pay-amt-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1rem;background:var(--cream2);border-radius:var(--r);
  border:1px solid var(--border);margin-bottom:1rem;
}
.pay-amt-label{font-size:.8rem;color:var(--muted);font-weight:500}
.pay-amt{font-family:'Cinzel',serif;font-size:1.55rem;font-weight:700;color:var(--burg)}

/* Pay button */
.pay-btn{
  width:100%;background:var(--burg);color:var(--gold3);border:none;
  border-radius:12px;padding:.9rem;
  font-family:'Cinzel',serif;font-size:.95rem;font-weight:700;letter-spacing:.06em;
  cursor:pointer;transition:all .22s;display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 4px 18px rgba(107,26,42,.35);
}
.pay-btn:hover:not(:disabled){background:var(--burg2);transform:translateY(-1px);box-shadow:0 6px 24px rgba(107,26,42,.42)}
.pay-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}
.pay-btn-lock{font-size:1rem}

/* Security note */
.pay-security{
  text-align:center;margin-top:.85rem;
  font-size:.63rem;color:var(--muted);letter-spacing:.04em;opacity:.6;
}

/* Success state */
.pay-success{
  display:none;flex-direction:column;align-items:center;justify-content:center;
  padding:2.8rem 1.6rem;text-align:center;gap:.6rem;
}
.pay-success-icon{font-size:3rem;animation:popIn .4s cubic-bezier(.22,.88,.26,1) both}
@keyframes popIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.pay-success-title{font-family:'Cinzel',serif;font-size:1.15rem;font-weight:700;color:var(--burg)}
.pay-success-msg{font-size:.82rem;color:var(--muted);font-weight:300}
.pay-success-pid{font-size:.68rem;color:var(--muted);opacity:.55;margin-top:.3rem;letter-spacing:.04em;font-family:monospace}

/* ── GOOGLE ADS ── */
.ad-wrap{
  display:flex;flex-direction:column;align-items:center;
  padding:.75rem 1.5rem;margin:0 auto;
}
.ad-leaderboard{max-width:768px}
.ad-rect{max-width:400px}
.ad-label{
  font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);opacity:.55;margin-bottom:.4rem;align-self:center;
}
.ad-placeholder{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;
  background:var(--cream2);border:1.5px dashed var(--border2);border-radius:var(--r);
  transition:border-color .2s;
}
.ad-ph-leaderboard{width:100%;max-width:728px;height:90px}
.ad-ph-rect{width:336px;height:280px;max-width:100%}
.ad-ph-icon{font-size:1.2rem;opacity:.4}
.ad-ph-size{font-size:.68rem;color:var(--muted);font-weight:500;opacity:.6;letter-spacing:.04em}
.ad-ph-note{font-size:.6rem;color:var(--muted);opacity:.4;letter-spacing:.06em;text-transform:uppercase}

@media(max-width:640px){
  nav{padding:0 1rem} .nav-r a:not(.nav-cta){display:none}
  .form-row,.photo-upload-grid{grid-template-columns:1fr}
  .price-cards{grid-template-columns:1fr}
  .canvas-wrap{padding:1rem}
  .tpl-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .ad-ph-leaderboard{height:60px} /* mobile banner */
}
