
@import url('https://fonts.googleapis.com/css2?family=Great+Vibes&family=Playfair+Display:wght@400;500;600;700&family=Montserrat:wght@300;400;500;600;700;800&family=Forum&family=Cormorant+Garamond:wght@400;500;600;700&family=Pinyon+Script&display=swap');

:root{
  --app-bg:#f7f3f2;
  --surface:#fff;
  --ink:#241f25;
  --muted:#796f75;
  --line:#eadcdb;
  --primary:#d87283;
  --primary2:#9e4f61;
  --dark:#201923;
  --shadow:0 18px 44px rgba(103,55,67,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--app-bg);color:var(--ink);font-family:Montserrat,system-ui,sans-serif}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
button{border:0;cursor:pointer}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:11px 17px;font-size:14px;font-weight:800;transition:.18s;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 12px 24px rgba(160,78,96,.22)}
.btn-soft{background:#fff;border:1px solid var(--line);color:var(--primary2)}
.btn-dark{background:var(--dark);color:#fff}
.btn-danger{background:#fff1f2;color:#b91c1c;border:1px solid #fecdd3}
.pill{display:inline-flex;align-items:center;gap:7px;border-radius:999px;border:1px solid var(--line);background:#fff;padding:7px 12px;font-size:12px;font-weight:800;color:var(--primary2)}
.pill:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--primary)}

.topbar{position:sticky;top:0;z-index:40;min-height:68px;background:rgba(255,250,249,.94);border-bottom:1px solid var(--line);backdrop-filter:blur(14px);display:flex;align-items:center}
.navrow{display:flex;justify-content:space-between;align-items:center;gap:18px}
.logo{font-family:Playfair Display,serif;font-size:28px;font-weight:700;color:#7c4a55;letter-spacing:-.03em}
.logo span{color:#d87283}
.nav{display:flex;gap:22px;font-size:14px;font-weight:700;color:#665b62}
.nav a:hover{color:var(--primary2)}
.nav-actions{display:flex;gap:10px}

.hero{padding:58px 0 44px;background:radial-gradient(circle at 80% 10%,rgba(216,114,131,.14),transparent 38%),linear-gradient(180deg,#fff,#fff8f7)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-family:Playfair Display,serif;font-size:clamp(2.3rem,4.2vw,4.1rem);line-height:1.1;letter-spacing:-.04em;margin:16px 0 14px;font-weight:700}
.hero h1 span{color:#d87283}
.lead{color:var(--muted);font-size:16.5px;line-height:1.76;max-width:650px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.hero-preview{background:#fff;border:1px solid var(--line);border-radius:30px;padding:14px;box-shadow:var(--shadow)}
.hero-preview .template-stage{height:640px;border-radius:24px;overflow:hidden}

.section{padding:48px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:24px}
.section-head h2,.page-title h1{font-family:Playfair Display,serif;font-size:clamp(2rem,3vw,2.9rem);line-height:1.1;margin:10px 0;font-weight:700;letter-spacing:-.03em}
.section p,.page-title p{color:var(--muted);line-height:1.7}
.grid{display:grid;gap:18px}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:24px;box-shadow:0 14px 34px rgba(103,55,67,.08);overflow:hidden}
.card-pad{padding:22px}
.template-card .template-stage{height:360px}
.tpl-body{padding:16px}
.tpl-body h3{font-family:Playfair Display,serif;font-size:22px;margin:0 0 6px}
.tpl-body p{font-size:13.5px;color:var(--muted);margin:0}
.tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:12px}.tag{padding:6px 10px;border-radius:999px;background:#fff7f7;border:1px solid var(--line);font-size:12px;font-weight:750;color:var(--primary2)}
.tpl-actions{display:flex;gap:8px;margin-top:13px}.tpl-actions .btn{flex:1;padding:9px 11px;font-size:13px}

/* AUTH + DASHBOARD */
.auth-shell{min-height:100vh;display:grid;grid-template-columns:1fr .92fr;background:linear-gradient(135deg,#fff,#fff4f3)}
.auth-left{display:flex;align-items:center;justify-content:center;padding:42px}.auth-left .template-stage{width:min(430px,100%);height:740px;border-radius:30px;overflow:hidden;box-shadow:var(--shadow)}
.auth-card{width:min(460px,calc(100% - 28px));align-self:center;justify-self:center;background:#fff;border:1px solid var(--line);border-radius:26px;padding:30px;box-shadow:var(--shadow)}
.auth-card h1{font-family:Playfair Display,serif;font-size:35px;margin:0 0 8px}
.form{display:grid;gap:13px;margin-top:18px}
.field{display:flex;flex-direction:column;gap:7px}label{font-size:13px;font-weight:800;color:#665b62}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px 13px;outline:none;color:var(--ink)}
textarea{min-height:92px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(216,114,131,.1)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.full{grid-column:1/-1}

.app-layout{min-height:100vh;display:grid;grid-template-columns:278px 1fr;background:#f7f3f2}
.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#211b25,#151017);color:#ded8dc;padding:18px;display:flex;flex-direction:column}
.side-logo{font-family:Playfair Display,serif;font-size:28px;font-weight:700;margin:12px 0 24px;color:#fff}
.side-logo span{color:#f0a1ad}
.side-nav{display:grid;gap:8px}.side-nav a,.side-nav button{width:100%;justify-content:flex-start;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#ded8dc}
.side-nav .active{background:linear-gradient(135deg,#d87283,#9e4f61);color:#fff}
.side-footer{margin-top:auto;color:#a79aa4;font-size:12px;line-height:1.6}
.main{padding:24px}.main-inner{width:min(1120px,100%);margin:0 auto}
.page-title{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px}
.notice{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;padding:13px 15px;border-radius:16px;margin-bottom:16px;font-size:14px}
.row{display:flex;justify-content:space-between;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:15px;margin-bottom:12px}.row small{display:block;color:var(--muted);margin-top:5px}
.dash-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.quick{display:flex;gap:14px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px;margin-bottom:12px}
.iconbox{width:48px;height:48px;border-radius:15px;background:#fff0f1;display:grid;place-items:center;color:#b45668}
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.menu-card{background:linear-gradient(135deg,#d87283,#9e4f61);color:#fff;border-radius:18px;padding:18px;min-height:112px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 12px 28px rgba(158,79,97,.18)}
.editor-grid{display:grid;grid-template-columns:1fr 360px;gap:18px}
.preview-panel{position:sticky;top:24px;align-self:start}
.preview-phone{background:#151017;border-radius:34px;padding:10px;width:310px;margin:0 auto;box-shadow:0 18px 40px rgba(0,0,0,.25)}
.preview-screen{height:560px;overflow:auto;border-radius:25px;background:#fff}
.preview-screen .public-invite{width:100%;box-shadow:none}
.preview-screen .template-stage{height:650px}
.tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tab{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 13px;font-size:13px;font-weight:800;color:var(--muted)}.tab.active{background:#241f25;color:#fff}
.empty{padding:28px;text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:18px;background:#fff}
.code{font-family:ui-monospace,monospace;background:#fff7f7;border:1px solid var(--line);border-radius:12px;padding:8px;font-size:12px;overflow:auto}

/* LAYERED TEMPLATE ENGINE */
.template-stage{
  --bg:'';--back:'';--char:'';--front:'';
  --name-font:"Playfair Display";--title-font:"Montserrat";--body-font:"Montserrat";
  --name-color:#7a4653;--title-color:#6f4a4e;--body-color:#5f5359;--button-bg:#b45c70;--button-text:#fff;
  position:relative;width:100%;height:100%;min-height:620px;overflow:hidden;background:#fff;color:var(--body-color);isolation:isolate;
}
.layer{position:absolute;inset:0;pointer-events:none}
.layer-bg{z-index:1;background-image:var(--bg);background-size:cover;background-position:center top}
.layer-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.2))}
.layer-back-frame{z-index:3;background-image:var(--back);background-size:84% 72%;background-position:center 95px;background-repeat:no-repeat;opacity:.98}
.layer-character{z-index:4;background-image:var(--char);background-size:var(--char-size,62%) auto;background-position:var(--char-x,center) var(--char-y,145px);background-repeat:no-repeat;filter:drop-shadow(0 18px 30px rgba(45,25,29,.15))}
.layer-front{z-index:6;background-image:var(--front);background-size:100% 100%;background-position:center;background-repeat:no-repeat}
.layer-text{z-index:7;position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;text-align:center;padding:62px 34px 34px;pointer-events:auto}
.tpl-eyebrow{font-family:var(--title-font);font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:var(--title-color);font-weight:700;margin-top:4px}
.tpl-title{font-family:var(--title-font);font-size:17px;letter-spacing:.14em;text-transform:uppercase;color:var(--title-color);font-weight:600;margin-top:6px}
.tpl-names{font-family:var(--name-font);font-size:clamp(4.6rem,14vw,7.7rem);line-height:.86;color:var(--name-color);margin-top:auto;margin-bottom:14px;letter-spacing:-.04em;text-shadow:0 8px 22px rgba(255,255,255,.72)}
.tpl-sub{font-family:var(--body-font);font-size:14px;line-height:1.72;max-width:470px;color:var(--body-color);font-weight:500;background:rgba(255,255,255,.46);border-radius:18px;padding:10px 14px;backdrop-filter:blur(2px)}
.tpl-info{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:min(520px,100%);margin:15px auto 12px}
.tpl-info-item{background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.78);border-radius:18px;padding:11px 8px;box-shadow:0 8px 20px rgba(80,50,58,.08)}
.tpl-info-item svg{width:23px;height:23px;margin:0 auto 6px;color:var(--name-color)}
.tpl-info-item b{display:block;font-family:var(--title-font);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--title-color);margin-bottom:4px}
.tpl-info-item span{font-family:var(--body-font);font-size:12px;line-height:1.35;color:var(--body-color)}
.tpl-cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--button-bg);color:var(--button-text);border-radius:999px;padding:13px 28px;font-family:var(--title-font);font-size:17px;font-weight:700;box-shadow:0 16px 32px rgba(80,44,55,.22);border:1px solid rgba(255,255,255,.45)}
.tpl-cta svg{width:24px;height:24px}

/* category tweaks */
.template-stage.jawa .tpl-names{font-size:clamp(4.2rem,13vw,6.6rem)}
.template-stage.khitan .tpl-names{font-size:clamp(3.7rem,12vw,6rem)}
.template-stage.aqiqah .tpl-names{font-size:clamp(3.8rem,12vw,6.4rem)}
.template-stage.birthday .tpl-names{font-size:clamp(4.2rem,13vw,7rem)}
.template-stage.birthday .tpl-sub{max-width:440px}

/* Public invite */
.public-wrap{min-height:100vh;background:#eee0d8;padding:24px 0}
.public-invite{width:min(560px,100%);margin:0 auto;background:#fff;box-shadow:0 24px 70px rgba(60,36,38,.2);overflow:hidden}
.public-invite .template-stage{height:100vh;min-height:820px}
.inv-section{padding:38px 24px;text-align:center;background:#fff9f5;border-top:1px solid rgba(120,80,80,.12)}
.inv-section:nth-child(even){background:#f8f0e8}
.inv-section h3{font-family:Playfair Display,serif;font-size:34px;margin:0 0 18px;color:#6a4250}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.info-box{background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:18px;padding:14px;text-align:center}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.photo{height:135px;border-radius:18px;background:linear-gradient(135deg,#fff,#e8d1c7);position:relative;overflow:hidden}.photo:before{content:"";position:absolute;left:35%;top:20%;width:44px;height:44px;border-radius:50%;background:rgba(120,80,90,.15)}.photo:after{content:"";position:absolute;left:24%;bottom:0;width:80px;height:66px;border-radius:44px 44px 10px 10px;background:rgba(120,80,90,.12)}
.music-fab{position:fixed;right:18px;bottom:20px;z-index:80;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:#fff;color:#9e4f61;box-shadow:0 12px 30px rgba(40,20,30,.18);border:1px solid var(--line)}
.music-fab svg{width:25px;height:25px}.music-fab.playing{background:linear-gradient(135deg,#d87283,#9e4f61);color:#fff}
.toast{position:fixed;right:18px;bottom:18px;background:#241f25;color:#fff;border-radius:16px;padding:13px 16px;box-shadow:var(--shadow);opacity:0;transform:translateY(10px);transition:.18s;z-index:120}.toast.show{opacity:1;transform:translateY(0)}

@media(max-width:1080px){
  .hero-grid,.auth-shell,.app-layout,.dash-grid,.editor-grid{grid-template-columns:1fr}
  .sidebar{height:auto;position:static}.side-footer{display:none}.nav{display:none}
  .g4{grid-template-columns:repeat(2,1fr)}.g3,.menu-grid{grid-template-columns:repeat(2,1fr)}
  .preview-panel{position:static}.preview-phone{width:min(330px,100%)}
}
@media(max-width:760px){
  .container{width:min(1180px,calc(100% - 24px))}
  .nav-actions .btn-soft{display:none}
  .hero{padding:34px 0}.hero h1{font-size:2.35rem}.lead{font-size:15.5px}
  .g4,.g3,.form-grid,.info-grid,.menu-grid,.tpl-info{grid-template-columns:1fr}
  .section-head,.page-title,.row{display:block}.row .btn,.row .actions{margin-top:10px}
  .main{padding:16px}.auth-left{display:none}.auth-card{margin:24px auto}
  .public-wrap{padding:0}.public-invite{width:100%}.public-invite .template-stage{min-height:760px}
  .layer-character{background-size:var(--char-size-mobile,82%) auto;background-position:var(--char-x-mobile,center) var(--char-y-mobile,145px)}
  .layer-back-frame{background-size:94% 72%}
  .tpl-names{font-size:4.2rem}
}

/* modal preview */
.modal-wrap{position:fixed;inset:0;z-index:150;display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(25,18,25,.62);backdrop-filter:blur(6px)}
.modal-dialog{position:relative;width:min(620px,calc(100% - 28px));max-height:calc(100vh - 28px);overflow:auto;margin:14px auto;background:#fff;border-radius:26px;box-shadow:0 30px 90px rgba(0,0,0,.28)}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;border-bottom:1px solid var(--line)}
.modal-head button{width:38px;height:38px;border-radius:50%;background:#fff0f1;color:#9e4f61;font-size:24px}
.modal-dialog .public-wrap{padding:0;background:#fff}
.modal-dialog .public-invite{width:100%;box-shadow:none}
.modal-dialog .public-invite .template-stage{min-height:760px;height:820px}
.svg-icon img{display:inline-block}


/* HOME PROFESSIONAL LANDING — layered engine only for invitation templates */
.brand-logo{display:flex;align-items:center;flex:0 0 auto}
.brand-logo img{height:42px;width:auto;max-width:184px;object-fit:contain;display:block}
.home-topbar{min-height:72px;background:rgba(255,250,249,.96)}
.landing-home{background:linear-gradient(180deg,#fff,#fff8f7)}
.home-hero{
  position:relative;
  overflow:hidden;
  padding:58px 0 54px;
  background:
    radial-gradient(circle at 82% 14%,rgba(216,114,131,.15),transparent 34%),
    radial-gradient(circle at 4% 72%,rgba(201,163,94,.13),transparent 28%),
    linear-gradient(180deg,#fff,#fff8f7);
}
.home-hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center}
.home-copy h1{
  font-family:Playfair Display,serif;
  font-size:clamp(2.2rem,4.1vw,4rem);
  line-height:1.12;
  letter-spacing:-.04em;
  margin:16px 0 14px;
  color:#4a3139;
}
.home-copy h1 span{color:#d87283}
.home-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px;max-width:640px}
.home-stats div{background:rgba(255,255,255,.86);border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 8px 22px rgba(103,55,67,.06)}
.home-stats b{display:block;font-size:21px;color:#a45366}
.home-stats span{font-size:12.5px;color:var(--muted)}
.home-visual{position:relative;min-height:640px;display:grid;place-items:center}
.home-phone-card{
  width:min(360px,92%);
  min-height:610px;
  border-radius:42px;
  padding:13px;
  background:#211b25;
  box-shadow:0 30px 80px rgba(103,55,67,.22);
  transform:rotate(1deg);
}
.phone-top{width:92px;height:8px;border-radius:99px;background:#4d414c;margin:8px auto 12px}
.home-app-preview{
  min-height:560px;
  border-radius:31px;
  overflow:hidden;
  padding:22px;
  background:
    radial-gradient(circle at 80% 5%,rgba(216,114,131,.22),transparent 32%),
    linear-gradient(180deg,#fff8f7,#f6e2df);
}
.preview-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;color:#553b43}
.preview-nav span{font-size:12px;font-weight:800;color:#047857;background:#ecfdf5;border:1px solid #bbf7d0;padding:6px 10px;border-radius:999px}
.preview-banner{
  border-radius:26px;
  padding:24px;
  color:#fff;
  background:linear-gradient(135deg,#d87283,#9e4f61);
  box-shadow:0 20px 42px rgba(160,78,96,.25);
}
.preview-banner small{display:block;text-transform:uppercase;letter-spacing:.16em;opacity:.82}
.preview-banner strong{display:block;font-family:Playfair Display,serif;font-size:34px;line-height:1;margin:12px 0 6px}
.preview-banner p{margin:0;opacity:.9}
.preview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px}
.preview-grid div{height:96px;border-radius:22px;background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.9);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;font-weight:800;color:#6f4a4e}
.preview-grid b{font-size:13px}
.float-card{
  position:absolute;
  width:230px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:22px;
  padding:16px;
  box-shadow:0 18px 44px rgba(103,55,67,.12);
}
.float-card b{display:block;color:#4a3139;margin-bottom:6px}
.float-card span{display:block;color:var(--muted);font-size:12.5px;line-height:1.5}
.float-card.one{left:0;top:74px}
.float-card.two{right:0;bottom:74px}
.section-head.center{display:block;text-align:center;max-width:800px;margin-inline:auto}
.home-section.soft{background:#fff1f0}
.home-section .card h3{font-family:Playfair Display,serif;font-size:22px}
@media(max-width:1080px){
  .home-hero-grid{grid-template-columns:1fr;gap:28px}
  .home-visual{min-height:560px}
  .float-card.one{left:10px}.float-card.two{right:10px}
}
@media(max-width:760px){
  .brand-logo img{height:36px;max-width:154px}
  .home-hero{padding:36px 0}
  .home-copy h1{font-size:2.35rem}
  .home-stats{grid-template-columns:1fr}
  .home-visual{min-height:auto;padding:20px 0 74px}
  .home-phone-card{width:min(330px,96%);min-height:540px}
  .home-app-preview{min-height:500px}
  .float-card{position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;margin:12px auto 0;width:min(330px,96%)}
}


/* V4.2 Wevitation-like product flow (original MomenKita styling) */
.wv-header{
  position:sticky;top:0;z-index:50;min-height:72px;
  background:rgba(255,255,255,.94);backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(234,220,219,.86);
  display:flex;align-items:center;
}
.wv-nav{display:flex;align-items:center;justify-content:space-between;gap:22px}
.wv-menu{display:flex;align-items:center;gap:19px;font-size:13.5px;font-weight:750;color:#61575f}
.wv-menu a:hover{color:#a45366}
.wv-actions{display:flex;align-items:center;gap:10px}
.btn-disabled{background:#f4eeee!important;border:1px solid #eadcdb!important;color:#9a8b91!important;cursor:not-allowed!important;box-shadow:none!important}
.btn-disabled:hover{transform:none!important}
.wv-home{background:#fff}
.wv-hero{
  position:relative;overflow:hidden;padding:72px 0 54px;
  background:
    radial-gradient(circle at 82% 12%,rgba(216,114,131,.17),transparent 32%),
    radial-gradient(circle at 16% 86%,rgba(201,163,94,.13),transparent 30%),
    linear-gradient(180deg,#fff,#fff8f7 68%,#fff);
}
.wv-hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:52px;align-items:center}
.wv-kicker{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--line);background:#fff;border-radius:999px;
  padding:7px 12px;font-size:12px;font-weight:850;color:#a45366;letter-spacing:.02em;
}
.wv-kicker:before{content:"";width:7px;height:7px;border-radius:50%;background:#d87283}
.wv-hero-copy h1{
  font-family:Playfair Display,serif;
  font-size:clamp(2.45rem,4.6vw,4.6rem);
  line-height:1.06;letter-spacing:-.05em;
  color:#3c3036;margin:18px 0 14px;
}
.wv-hero-copy p{font-size:17px;line-height:1.78;color:#756870;max-width:660px;margin:0}
.wv-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.wv-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px;max-width:650px}
.wv-metrics div{border:1px solid var(--line);background:rgba(255,255,255,.84);border-radius:20px;padding:16px;box-shadow:0 10px 24px rgba(103,55,67,.06)}
.wv-metrics b{display:block;font-size:23px;color:#a45366}.wv-metrics span{font-size:12.5px;color:var(--muted)}
.wv-hero-visual{position:relative;min-height:660px;display:grid;place-items:center}
.wv-phone{width:338px;height:628px;background:#201923;border-radius:44px;padding:14px;box-shadow:0 34px 90px rgba(60,38,47,.28);position:relative;z-index:3}
.wv-phone-notch{width:96px;height:8px;border-radius:99px;background:#4d414c;margin:8px auto 12px}
.wv-phone-screen{
  height:570px;border-radius:32px;overflow:hidden;
  background:linear-gradient(180deg,#fff8f7,#ead0ca);
  padding:28px;text-align:center;position:relative;
}
.wv-phone-screen:before{content:"";position:absolute;inset:16px;border:1px solid rgba(255,255,255,.82);border-radius:26px}
.wv-mini-logo{position:relative;z-index:2;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:#a45366;font-weight:850}
.wv-mini-title{position:relative;z-index:2;font-family:Playfair Display,serif;font-size:52px;line-height:.95;margin:64px 0 10px;color:#7c4a55}
.wv-mini-sub{position:relative;z-index:2;color:#76636a}
.wv-mini-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:90px 0 24px}
.wv-mini-grid i{height:78px;border-radius:18px;background:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.9)}
.wv-phone-screen button{position:relative;z-index:2;border:0;background:linear-gradient(135deg,#d87283,#9e4f61);color:#fff;border-radius:999px;padding:13px 24px;font-weight:850}
.wv-stack-card{
  position:absolute;width:190px;height:280px;border-radius:28px;box-shadow:0 22px 50px rgba(90,55,65,.18);
  background:linear-gradient(150deg,#fff8f7,#d7b0a9);border:1px solid rgba(255,255,255,.8);display:flex;align-items:end;justify-content:center;padding:20px;color:#704752;font-weight:850
}
.wv-stack-card.card-a{left:18px;top:54px;transform:rotate(-9deg)}
.wv-stack-card.card-b{right:18px;top:92px;transform:rotate(8deg);background:linear-gradient(150deg,#f7fbf5,#c3d2b7);color:#4f684d}
.wv-stack-card.card-c{left:36px;bottom:58px;transform:rotate(7deg);background:linear-gradient(150deg,#fff5df,#c79a51);color:#704716}
.wv-section{padding:62px 0}
.wv-section-head{display:flex;justify-content:space-between;align-items:end;gap:22px;margin-bottom:28px}
.wv-section-head.center{display:block;text-align:center;max-width:840px;margin-inline:auto}
.wv-section-head h2,.wv-gift h2{
  font-family:Playfair Display,serif;font-size:clamp(2rem,3.4vw,3.35rem);
  line-height:1.1;letter-spacing:-.035em;margin:12px 0;color:#3c3036;
}
.wv-section-head p,.wv-gift p{color:var(--muted);line-height:1.7}
.wv-feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.wv-feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.wv-feature-card{
  background:#fff;border:1px solid var(--line);border-radius:26px;padding:24px;box-shadow:0 12px 32px rgba(103,55,67,.07)
}
.wv-feature-card h3{font-family:Playfair Display,serif;font-size:22px;margin:14px 0 8px;color:#3c3036}
.wv-feature-card p{color:var(--muted);line-height:1.65;margin:0}
.wv-icon{width:50px;height:50px;border-radius:17px;background:#fff0f1;color:#a45366;display:grid;place-items:center;font-weight:900}
.wv-impact{background:#fff8f7}
.wv-impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.wv-impact-grid div{background:#fff;border:1px solid var(--line);border-radius:28px;padding:28px;text-align:center;box-shadow:0 12px 32px rgba(103,55,67,.06)}
.wv-impact-grid b{display:block;font-size:34px;color:#a45366;font-family:Playfair Display,serif}
.wv-impact-grid span{color:var(--muted)}
.wv-theme-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.wv-theme-card{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;padding-bottom:14px;box-shadow:0 12px 32px rgba(103,55,67,.07)}
.wv-theme-card>div{height:250px;overflow:hidden}
.wv-theme-card .template-stage{min-height:540px;height:540px;transform:scale(.48);transform-origin:top center;width:208%;margin-left:-54%}
.wv-theme-card b{display:block;padding:12px 12px 5px;font-size:13px}
.wv-theme-card a{display:block;padding:0 12px;color:#a45366;font-size:12px;font-weight:850}
.wv-gift{background:linear-gradient(180deg,#fff,#fff8f7)}
.wv-gift-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:30px;align-items:center}
.wv-gift-cards{display:grid;gap:14px}
.wv-gift-cards article{display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:0 12px 32px rgba(103,55,67,.07)}
.wv-gift-cards span{width:50px;height:50px;border-radius:17px;background:#fff0f1;display:grid;place-items:center}
.wv-gift-cards b{display:block}.wv-gift-cards p{margin:4px 0 0;color:var(--muted)}
.wv-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.wv-step{background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px;text-align:center;box-shadow:0 12px 32px rgba(103,55,67,.07)}
.wv-step b{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;margin:0 auto 14px;background:linear-gradient(135deg,#d87283,#9e4f61);color:#fff}
.wv-step span{font-weight:850;color:#3c3036}
.wv-features{background:#fff8f7}
.wv-price-section{background:#fff}
.wv-price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.wv-price-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px;box-shadow:0 14px 36px rgba(103,55,67,.08);position:relative}
.wv-price-card.popular{border:2px solid #d87283;transform:translateY(-8px)}
.wv-price-card>span{display:inline-flex;border-radius:999px;background:#fff0f1;color:#a45366;padding:6px 10px;font-size:12px;font-weight:850}
.wv-price-card h3{font-family:Playfair Display,serif;font-size:28px;margin:14px 0 8px}
.wv-price{font-family:Playfair Display,serif;font-size:38px;color:#a45366;margin-bottom:8px}
.wv-price-card p{color:var(--muted)}
.wv-price-card ul{padding-left:18px;color:var(--muted);line-height:1.9}
.wv-faq{background:#fff8f7}
.wv-faq-list{max-width:850px;margin:0 auto;display:grid;gap:12px}
.wv-faq-list details{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px}
.wv-faq-list summary{font-weight:850;cursor:pointer}
.wv-faq-list p{color:var(--muted);line-height:1.7}

/* auth like app login */
.wv-auth-page{
  min-height:100vh;display:grid;place-items:center;position:relative;
  padding:32px;background:
    radial-gradient(circle at 15% 10%,rgba(216,114,131,.18),transparent 34%),
    radial-gradient(circle at 85% 90%,rgba(201,163,94,.15),transparent 34%),
    linear-gradient(180deg,#fff,#fff8f7);
}
.wv-auth-brand{text-align:center;margin-bottom:18px}
.wv-auth-brand .brand-logo{justify-content:center}.wv-auth-brand .brand-logo img{height:44px}
.wv-auth-brand p{color:var(--muted);font-size:13px}
.wv-auth-card{width:min(430px,100%);background:#fff;border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:0 22px 60px rgba(103,55,67,.14)}
.wv-auth-card h1{font-family:Playfair Display,serif;font-size:38px;line-height:1.05;text-align:center;margin:0 0 22px}
.wv-auth-card h1 span{color:#d87283}
.wv-auth-row{text-align:right;font-size:13px}
.wv-divider{display:flex;align-items:center;gap:12px;color:#9a8b91;font-size:12px;font-weight:850;letter-spacing:.08em;margin:4px 0}
.wv-divider:before,.wv-divider:after{content:"";height:1px;background:var(--line);flex:1}
.wv-auth-foot{position:absolute;bottom:16px;color:#9a8b91;font-size:12px}

/* setup / subscribe */
.wv-setup-page{min-height:calc(100vh - 72px);background:#faf7f6;padding:34px 0 56px}
.wv-setup-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:22px}
.wv-setup-steps div{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;font-weight:850;color:#8a7c84;text-align:center}
.wv-setup-steps .active{background:linear-gradient(135deg,#d87283,#9e4f61);color:#fff}
.wv-setup-grid{display:grid;grid-template-columns:1fr 380px;gap:22px;align-items:start}
.wv-setup-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:26px;box-shadow:0 14px 36px rgba(103,55,67,.08)}
.wv-setup-card h1{font-family:Playfair Display,serif;font-size:36px;margin:14px 0 6px}
.wv-setup-card p{color:var(--muted)}
.wv-setup-preview{border-radius:28px;overflow:hidden;box-shadow:0 20px 54px rgba(103,55,67,.14);height:700px}
.wv-setup-preview .template-stage{height:700px}

/* dashboard */
.wv-dash-top{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:18px}
.wv-dash-top h1{font-family:Playfair Display,serif;font-size:38px;margin:0}
.wv-dash-top p{color:var(--muted);margin:5px 0 0}
.wv-dash-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0}
.wv-dash-cards div{background:#fff;border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:0 12px 30px rgba(103,55,67,.07)}
.wv-dash-cards b{display:block;font-family:Playfair Display,serif;font-size:34px;color:#a45366}
.wv-dash-cards span{color:var(--muted);font-size:13px}

@media(max-width:1120px){
  .wv-menu{display:none}
  .wv-hero-grid,.wv-gift-grid,.wv-setup-grid{grid-template-columns:1fr}
  .wv-feature-grid,.wv-price-grid{grid-template-columns:repeat(2,1fr)}
  .wv-theme-strip{grid-template-columns:repeat(3,1fr)}
  .wv-steps{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:760px){
  .wv-nav{gap:12px}.wv-actions .btn-soft{display:none}
  .wv-hero{padding:42px 0}.wv-hero-copy h1{font-size:2.55rem}
  .wv-metrics,.wv-feature-row,.wv-feature-grid,.wv-impact-grid,.wv-price-grid,.wv-steps,.wv-dash-cards,.wv-setup-steps{grid-template-columns:1fr}
  .wv-hero-visual{min-height:540px}.wv-phone{width:min(320px,94%);height:570px}.wv-phone-screen{height:510px}
  .wv-stack-card{display:none}
  .wv-theme-strip{grid-template-columns:repeat(2,1fr)}
  .wv-section{padding:42px 0}.wv-section-head,.wv-dash-top{display:block}
  .wv-setup-preview{height:620px}.wv-setup-preview .template-stage{height:620px}
}


/* V4.3 Premium Inner Editable Invitation */
.premium-public-wrap{
  background:
    radial-gradient(circle at top, color-mix(in srgb, var(--inv-accent) 16%, transparent), transparent 42%),
    linear-gradient(180deg,#f6efed,#efe3df);
  padding:28px 0;
}
.premium-public{
  width:min(560px,100%);
  border-radius:34px;
  overflow:hidden;
  background:#fffaf7;
  box-shadow:0 30px 85px rgba(70,38,45,.25);
  border:1px solid rgba(255,255,255,.8);
}
.premium-cover .template-stage{
  height:100vh;
  min-height:860px;
}
.template-stage.has-user-photo .layer-character{
  background-size:var(--char-size-user,76%) auto;
  background-position:center var(--char-y-user,160px);
  filter:drop-shadow(0 20px 32px rgba(40,22,28,.22));
}
.premium-section{
  position:relative;
  padding:48px 28px;
  text-align:center;
  background:
    radial-gradient(circle at 92% 5%, color-mix(in srgb, var(--inv-accent) 9%, transparent), transparent 28%),
    linear-gradient(180deg,#fffaf7,#fff4f1);
  border-top:1px solid rgba(130,85,85,.12);
  color:var(--inv-body);
}
.premium-section:nth-of-type(even){
  background:
    radial-gradient(circle at 0% 80%, color-mix(in srgb, var(--inv-accent) 10%, transparent), transparent 28%),
    linear-gradient(180deg,#fff,#fff8f4);
}
.premium-section:before,.premium-section:after{
  content:"";
  position:absolute;
  width:130px;height:130px;
  pointer-events:none;
  opacity:.33;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--inv-accent) 45%, white), transparent 62%);
  filter:blur(18px);
}
.premium-section:before{left:-60px;top:20px}
.premium-section:after{right:-60px;bottom:20px}
.section-ornament{
  color:#c89a55;
  font-size:22px;
  margin-bottom:10px;
  position:relative;
  z-index:1;
}
.premium-section h3{
  position:relative;
  z-index:1;
  font-family:Playfair Display,serif;
  font-size:34px;
  line-height:1.12;
  color:#3f272d;
  margin:0 0 18px;
  letter-spacing:-.02em;
}
.premium-section h3:after{
  content:"";
  display:block;
  width:120px;
  height:18px;
  margin:8px auto 0;
  background:
    linear-gradient(90deg,transparent,#c89a55,transparent);
  mask:linear-gradient(#000,#000) center/100% 1px no-repeat;
  opacity:.7;
}
.premium-section p{
  position:relative;
  z-index:1;
  color:var(--inv-body);
  line-height:1.8;
  max-width:440px;
  margin:0 auto 18px;
  font-size:14.5px;
}
.intro-section blockquote{
  position:relative;
  z-index:1;
  margin:26px auto 0;
  padding:24px 22px;
  border-radius:24px;
  border:1px solid rgba(200,154,85,.28);
  background:rgba(255,255,255,.62);
  color:#5f4c51;
  line-height:1.75;
  font-family:Cormorant Garamond,serif;
  font-size:20px;
  box-shadow:0 14px 34px rgba(90,55,65,.08);
}
.intro-section blockquote span{
  display:block;
  font-size:48px;
  height:24px;
  color:var(--inv-accent);
  opacity:.5;
}
.intro-section blockquote small{
  display:block;
  font-family:Montserrat,sans-serif;
  font-size:12px;
  color:var(--inv-title);
  margin-top:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.couple-photo{
  position:relative;
  z-index:1;
  width:min(360px,100%);
  height:360px;
  border-radius:32px;
  overflow:hidden;
  margin:0 auto 24px;
  border:1px solid rgba(200,154,85,.38);
  background:#f7ece8;
  box-shadow:0 20px 46px rgba(70,38,45,.13);
}
.couple-photo:after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:38%;
  background:linear-gradient(0deg,rgba(255,250,247,.94),transparent);
  pointer-events:none;
}
.couple-photo img,.gallery-slot img,.photo-placeholder{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.photo-placeholder,.gallery-slot{
  display:grid;
  place-items:center;
  color:color-mix(in srgb, var(--inv-accent) 70%, #fff);
  background:
    radial-gradient(circle at 75% 20%,rgba(255,255,255,.8),transparent 32%),
    linear-gradient(135deg,#fff7f4,#ead6d0);
  font-weight:800;
}
.couple-names{
  position:relative;
  z-index:1;
  display:grid;
  gap:12px;
}
.couple-names h4{
  font-family:Playfair Display,serif;
  font-size:28px;
  color:var(--inv-title);
  margin:0 0 6px;
}
.couple-names p{
  font-size:13px;
  margin:0 auto;
}
.couple-names .amp{
  width:64px;height:64px;border-radius:50%;
  display:grid;place-items:center;
  margin:2px auto;
  background:#fff6ee;
  color:#c89a55;
  border:1px solid rgba(200,154,85,.4);
  font-family:Great Vibes,cursive;
  font-size:38px;
}
.premium-info-list{
  position:relative;
  z-index:1;
  display:grid;
  gap:16px;
  margin-top:20px;
}
.premium-info-list div{
  display:grid;
  grid-template-columns:58px 1fr;
  grid-template-areas:"icon title" "icon text";
  gap:2px 16px;
  text-align:left;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(200,154,85,.22);
  border-radius:24px;
  padding:18px;
  box-shadow:0 12px 28px rgba(90,55,65,.07);
}
.premium-info-list img{
  grid-area:icon;
  width:52px;height:52px;
  padding:13px;
  border-radius:50%;
  color:var(--inv-accent);
  background:color-mix(in srgb, var(--inv-accent) 12%, white);
}
.premium-info-list b{
  grid-area:title;
  font-family:Playfair Display,serif;
  color:#3f272d;
  font-size:20px;
}
.premium-info-list span{
  grid-area:text;
  line-height:1.55;
  font-size:13.5px;
  color:var(--inv-body);
}
.premium-map-btn,.premium-cta,.premium-soft-btn{
  position:relative;
  z-index:1;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  border:0;
  text-decoration:none;
  border-radius:999px;
  padding:13px 24px;
  font-weight:850;
  box-shadow:0 16px 35px rgba(90,55,65,.15);
}
.premium-map-btn,.premium-cta{
  color:#fff;
  background:var(--inv-cta);
}
.premium-soft-btn{
  margin-top:18px;
  background:#fff;
  color:var(--inv-title);
  border:1px solid rgba(200,154,85,.28);
}
.event-cards{
  position:relative;
  z-index:1;
  display:grid;
  gap:16px;
}
.event-cards article{
  display:grid;
  grid-template-columns:66px 1fr;
  gap:16px;
  align-items:center;
  text-align:left;
  background:rgba(255,255,255,.75);
  border:1px solid rgba(200,154,85,.25);
  border-radius:24px;
  padding:18px;
  box-shadow:0 12px 30px rgba(90,55,65,.07);
}
.event-icon{
  width:58px;height:58px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--inv-cta);
  color:#fff;
  box-shadow:0 10px 22px rgba(90,55,65,.14);
}
.event-cards h4{
  font-family:Playfair Display,serif;
  font-size:22px;
  margin:0 0 4px;
  color:#3f272d;
}
.event-cards p{
  margin:0;
  font-size:13px;
  line-height:1.55;
  text-align:left;
}
.premium-gallery-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  grid-template-rows:130px 130px 130px;
  gap:10px;
  margin:20px auto;
}
.gallery-slot{
  border-radius:18px;
  overflow:hidden;
  min-height:120px;
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 10px 22px rgba(90,55,65,.08);
}
.gallery-slot:first-child{
  grid-row:span 2;
}
.gallery-slot:nth-child(4){
  grid-column:span 2;
}
.editor-gallery .gallery-slot:first-child,.editor-gallery .gallery-slot:nth-child(4){
  grid-row:auto;
  grid-column:auto;
}
.editor-gallery .premium-gallery-grid{
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:none;
}
.story-list{
  position:relative;
  z-index:1;
  display:grid;
  gap:18px;
  max-width:440px;
  margin:0 auto;
}
.story-item{
  display:grid;
  grid-template-columns:54px 1fr;
  gap:16px;
  text-align:left;
}
.story-dot{
  width:50px;height:50px;border-radius:50%;
  display:grid;place-items:center;
  background:color-mix(in srgb, var(--inv-accent) 15%, white);
  border:1px solid rgba(200,154,85,.28);
  color:var(--inv-title);
  font-weight:900;
}
.story-item b{
  display:block;
  font-family:Playfair Display,serif;
  font-size:20px;
  color:#3f272d;
}
.story-item small{
  display:block;
  color:var(--inv-accent);
  font-weight:800;
  margin:4px 0;
}
.story-item p{
  text-align:left;
  margin:0;
  font-size:13.5px;
}
.account-list{
  position:relative;
  z-index:1;
  display:grid;
  gap:14px;
  margin:20px 0;
}
.account-card{
  display:grid;
  grid-template-columns:82px 1fr;
  gap:14px;
  align-items:center;
  text-align:left;
  background:rgba(255,255,255,.74);
  border:1px solid rgba(200,154,85,.25);
  border-radius:22px;
  padding:18px;
  box-shadow:0 12px 30px rgba(90,55,65,.07);
}
.bank-logo{
  min-height:54px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#fff;
  color:#1555a2;
  font-weight:900;
  border:1px solid #e8e1df;
}
.account-card b{
  display:block;
  font-size:20px;
  color:#3f272d;
}
.account-card span{
  display:block;
  color:var(--inv-body);
  font-size:13px;
  margin-top:3px;
}
.account-card button{
  grid-column:1/-1;
  justify-self:center;
  border:0;
  border-radius:999px;
  background:color-mix(in srgb, var(--inv-accent) 13%, white);
  color:var(--inv-title);
  font-weight:850;
  padding:10px 16px;
}
.gift-address{
  position:relative;
  z-index:1;
  background:#fff;
  border-radius:20px;
  padding:16px;
  border:1px solid rgba(200,154,85,.25);
}
.gift-address b,.gift-address span{
  display:block;
}
.gift-address span{
  color:var(--inv-body);
  margin-top:6px;
  line-height:1.6;
}
.premium-form{
  position:relative;
  z-index:1;
  text-align:left;
  margin:18px 0;
}
.closing-section{
  background:
    radial-gradient(circle at top, color-mix(in srgb, var(--inv-accent) 34%, transparent), transparent 42%),
    linear-gradient(160deg, color-mix(in srgb, var(--inv-accent) 74%, #5d2d3a), #5d2d3a);
  color:#fff;
}
.closing-section h3{
  color:#fff;
  font-family:Great Vibes,cursive;
  font-size:42px;
}
.closing-section p{
  color:rgba(255,255,255,.9);
}
.social-row{
  display:flex;
  justify-content:center;
  gap:12px;
  margin:20px 0;
  position:relative;
  z-index:1;
}
.social-row button,.social-row a{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:800;
}
.premium-player-inline{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:52px 1fr 32px;
  align-items:center;
  gap:12px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.24);
  border-radius:999px;
  padding:10px 14px;
  text-align:left;
}
.premium-player-inline button{
  width:44px;height:44px;border-radius:50%;
  border:0;
  background:#fff;
  color:var(--inv-title);
}
.premium-player-inline b,.premium-player-inline span{
  display:block;
}
.premium-player-inline span{
  color:rgba(255,255,255,.75);
  font-size:12px;
}
@media(max-width:620px){
  .premium-public-wrap{padding:0}
  .premium-public{border-radius:0;width:100%;box-shadow:none}
  .premium-cover .template-stage{min-height:780px}
  .premium-section{padding:40px 22px}
  .premium-gallery-grid{grid-template-rows:110px 110px 110px}
  .account-card{grid-template-columns:1fr;text-align:center}
  .bank-logo{width:110px;margin:0 auto}
}


/* V4.4 Ready-to-use functional additions */
.demo-login-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:760px;margin:0 auto}
.demo-mini{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.demo-mini button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px;font-weight:800;color:#9e4f61}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:0 12px 30px rgba(103,55,67,.07)}
.stat-card b{display:block;font-family:Playfair Display,serif;font-size:34px;color:#a45366}
.stat-card span{color:var(--muted);font-size:13px}
.checkout-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:22px;align-items:start}
.checkout-grid .template-stage{height:640px;min-height:640px;border-radius:24px;overflow:hidden}
.admin-sidebar{background:linear-gradient(180deg,#111827,#0b1020)}
.admin-layout .menu-card{background:linear-gradient(135deg,#111827,#334155)}
.tpl-info-item img{width:23px;height:23px;margin:0 auto 6px;color:var(--name-color)}
.tpl-cta img{width:24px;height:24px;filter:brightness(0) invert(1)}
.template-card .template-stage .layer-character{opacity:.95}
.preview-screen .public-wrap{padding:0;background:#fff}
.preview-screen .premium-public{width:100%;box-shadow:none;border-radius:0}
.preview-screen .premium-cover .template-stage{height:620px;min-height:620px}
.preview-screen .premium-section{padding:32px 20px}
.preview-screen .premium-section h3{font-size:28px}
.preview-screen .premium-gallery-grid{grid-template-rows:86px 86px 86px}
.code{word-break:break-all;white-space:normal}
.field small{color:var(--muted);font-size:12px;margin-top:4px;display:block}
.wv-setup-steps{grid-template-columns:repeat(4,1fr)}
.btn-disabled{background:#f4eeee!important;border:1px solid #eadcdb!important;color:#9a8b91!important;cursor:not-allowed!important;box-shadow:none!important}
.btn-disabled:hover{transform:none!important}
@media(max-width:900px){
  .checkout-grid,.demo-login-grid{grid-template-columns:1fr}
  .wv-setup-steps{grid-template-columns:1fr}
}


/* V4.6 REAL TEMPLATE PREVIEW — preview card renders full real cover, not cropped skeleton */
.real-template-thumb{
  position:relative;
  height:520px;
  overflow:hidden;
  border-radius:28px 28px 0 0;
  background:#f8efed;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.6);
}
.real-template-thumb:before{
  content:"";
  position:absolute;
  inset:12px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.8);
  pointer-events:none;
  z-index:4;
}
.real-template-inner{
  position:absolute;
  left:50%;
  top:0;
  width:720px;
  height:1030px;
  transform:translateX(-50%) scale(.505);
  transform-origin:top center;
}
.real-template-thumb .template-stage{
  width:720px;
  height:1030px!important;
  min-height:1030px!important;
  border-radius:34px;
  overflow:hidden;
  box-shadow:none;
}
.template-card .template-stage{
  height:1030px!important;
}
.wv-theme-card{
  padding-bottom:14px;
}
.wv-theme-card>div.real-template-thumb{
  height:360px;
}
.wv-theme-card .real-template-inner{
  transform:translateX(-50%) scale(.35);
}
.wv-theme-card .template-stage{
  min-height:1030px!important;
  height:1030px!important;
  width:720px!important;
  margin-left:0!important;
}
.wv-theme-card .template-stage{
  transform:none!important;
}

/* stronger premium cover rendering */
.template-stage{
  position:relative;
  background:#fff;
  isolation:isolate;
}
.template-stage:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:
    radial-gradient(circle at 50% 8%,rgba(255,255,255,.62),transparent 28%),
    linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.28) 52%,rgba(255,255,255,.62));
  pointer-events:none;
}
.template-stage:after{
  content:"";
  position:absolute;
  inset:20px;
  z-index:8;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.75);
  box-shadow:
    inset 0 0 0 1px rgba(201,154,85,.18),
    inset 0 0 70px rgba(255,255,255,.28);
  pointer-events:none;
}
.layer-bg{
  background-size:cover!important;
  transform:scale(1.02);
}
.layer-back-frame{
  z-index:3!important;
  background-size:92% 92%!important;
  background-position:center top!important;
  filter:drop-shadow(0 22px 34px rgba(50,25,31,.17));
  opacity:.98;
}
.layer-character{
  z-index:5!important;
  background-size:var(--char-size,72%) auto!important;
  background-position:var(--char-x,center) var(--char-y,205px)!important;
  filter:
    drop-shadow(0 22px 38px rgba(35,18,22,.25))
    drop-shadow(0 -8px 18px rgba(255,255,255,.4))!important;
}
.layer-front{
  z-index:9!important;
  background-size:100% 100%!important;
  filter:drop-shadow(0 -12px 20px rgba(255,255,255,.18));
}
.layer-text{
  z-index:10!important;
  padding:68px 44px 40px!important;
  display:grid!important;
  grid-template-rows:auto auto auto 1fr auto auto auto;
  align-items:center!important;
  justify-items:center!important;
  pointer-events:auto;
}
.tpl-eyebrow{
  font-size:13px!important;
  letter-spacing:.32em!important;
  font-weight:850!important;
  margin-top:0!important;
  text-shadow:0 1px 0 rgba(255,255,255,.65);
}
.tpl-title{
  font-size:15px!important;
  letter-spacing:.19em!important;
  margin-top:6px!important;
}
.tpl-names{
  font-size:92px!important;
  max-width:620px;
  line-height:.86!important;
  margin:22px 0 0!important;
  text-shadow:
    0 2px 0 rgba(255,255,255,.55),
    0 12px 24px rgba(56,28,35,.16)!important;
}
.tpl-sub{
  align-self:end;
  max-width:500px!important;
  margin:0 0 10px!important;
  padding:14px 18px!important;
  border:1px solid rgba(255,255,255,.55);
  background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(255,255,255,.45))!important;
  box-shadow:0 12px 24px rgba(80,45,55,.08);
  backdrop-filter:blur(4px);
}
.tpl-info{
  width:min(560px,100%)!important;
  gap:12px!important;
  margin:8px 0 16px!important;
}
.tpl-info-item{
  min-height:96px;
  border-radius:22px!important;
  background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(255,255,255,.58))!important;
  border:1px solid rgba(255,255,255,.82)!important;
  box-shadow:
    0 12px 28px rgba(70,38,46,.09),
    inset 0 0 0 1px rgba(201,154,85,.14)!important;
}
.tpl-info-item img{
  width:25px!important;
  height:25px!important;
  opacity:.9;
}
.tpl-info-item b{
  letter-spacing:.12em;
  font-size:12px!important;
}
.tpl-info-item span{
  font-size:12px!important;
  line-height:1.35;
}
.tpl-cta{
  min-width:310px!important;
  border-radius:999px!important;
  padding:17px 26px!important;
  font-size:22px!important;
  font-family:Playfair Display,serif!important;
  font-weight:700!important;
  box-shadow:
    0 18px 42px rgba(85,42,55,.22),
    inset 0 0 0 2px rgba(255,255,255,.26),
    inset 0 0 0 1px rgba(201,154,85,.36)!important;
}
.tpl-cta:after{
  content:"›";
  font-size:32px;
  line-height:0;
  margin-left:6px;
}
.tpl-cta img{
  width:24px!important;
  height:24px!important;
}

/* category-specific premium preview composition */
.template-stage.wedding .layer-character{background-position:center 250px!important;background-size:74% auto!important}
.template-stage.wedding .tpl-names{margin-top:18px!important}
.template-stage.wedding .tpl-sub{margin-bottom:18px!important}
.template-stage.jawa .layer-character{background-position:center 145px!important;background-size:82% auto!important}
.template-stage.jawa .tpl-names{font-size:86px!important;color:#7a4814!important;margin-top:500px!important}
.template-stage.jawa .tpl-sub{margin-top:8px!important;background:rgba(255,247,225,.72)!important}
.template-stage.jawa .tpl-eyebrow,.template-stage.jawa .tpl-title{color:#7a4814!important}
.template-stage.khitan .layer-character{background-position:center 140px!important;background-size:72% auto!important}
.template-stage.khitan .tpl-names{font-size:86px!important;margin-top:430px!important}
.template-stage.khitan .tpl-sub{background:rgba(255,255,255,.18)!important;color:var(--body-color)!important}
.template-stage.aqiqah .layer-character{background-position:center 120px!important;background-size:78% auto!important}
.template-stage.aqiqah .tpl-names{font-size:82px!important;margin-top:430px!important}
.template-stage.birthday .layer-character{background-position:center 150px!important;background-size:72% auto!important}
.template-stage.birthday .tpl-names{font-size:96px!important;margin-top:430px!important}

/* smaller text inside template cards but still full cover */
.real-template-thumb .tpl-eyebrow{font-size:13px!important}
.real-template-thumb .tpl-title{font-size:15px!important}
.real-template-thumb .tpl-names{font-size:92px!important}
.real-template-thumb .tpl-sub{font-size:14px!important}
.real-template-thumb .tpl-info-item span{font-size:12px!important}
.real-template-thumb .tpl-cta{font-size:22px!important}

@media(max-width:900px){
  .real-template-thumb{height:470px}
  .real-template-inner{transform:translateX(-50%) scale(.456)}
}
@media(max-width:620px){
  .real-template-thumb{height:430px}
  .real-template-inner{transform:translateX(-50%) scale(.418)}
  .wv-theme-card>div.real-template-thumb{height:340px}
}


/* V4.7 PREMIUM MASTER TEMPLATE — rose & sage asset-based editable template */
.layer-ornament{
  z-index:8;
  background-image:var(--ornament);
  background-size:100% 100%;
  background-position:center;
  background-repeat:no-repeat;
  pointer-events:none;
}

.real-template-thumb{
  height:560px!important;
  background:#f7efec!important;
  border-radius:30px 30px 0 0!important;
}
.real-template-inner{
  width:720px!important;
  height:1030px!important;
  transform:translateX(-50%) scale(var(--preview-scale,.545))!important;
}
.wv-theme-card>div.real-template-thumb{
  height:390px!important;
}
.wv-theme-card .real-template-inner{
  transform:translateX(-50%) scale(.382)!important;
}
.real-template-thumb .template-stage{
  width:720px!important;
  height:1030px!important;
  min-height:1030px!important;
  border-radius:36px!important;
}
.template-card .template-stage{
  height:1030px!important;
}

.template-stage.premium-master{
  position:relative;
  background:#fff7f4;
  isolation:isolate;
  border-radius:36px;
}
.template-stage.premium-master .layer-bg{
  z-index:1;
  background-size:cover!important;
  background-position:center!important;
  transform:none!important;
}
.template-stage.premium-master:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.82), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.18) 45%, rgba(255,255,255,.42) 72%, rgba(255,255,255,.22));
  pointer-events:none;
}
.template-stage.premium-master .layer-back-frame{
  z-index:3!important;
  background-size:100% 100%!important;
  background-position:center!important;
  filter:drop-shadow(0 24px 34px rgba(58,30,38,.20));
  opacity:1!important;
}
.template-stage.premium-master .layer-character{
  z-index:5!important;
  background-size:var(--char-size,74%) auto!important;
  background-position:var(--char-x,center) var(--char-y,305px)!important;
  background-repeat:no-repeat!important;
  filter:
    drop-shadow(0 26px 42px rgba(35,18,22,.28))
    drop-shadow(0 -8px 18px rgba(255,255,255,.42))!important;
  opacity:1!important;
}
.template-stage.premium-master.has-user-photo .layer-character{
  background-size:82% auto!important;
  background-position:center 285px!important;
}
.template-stage.premium-master .layer-front{
  z-index:9!important;
  background-size:100% 100%!important;
  background-position:center!important;
  opacity:1!important;
  filter:drop-shadow(0 -12px 18px rgba(255,255,255,.18));
}
.template-stage.premium-master:after{
  content:"";
  position:absolute;
  inset:20px;
  z-index:12;
  border-radius:34px;
  pointer-events:none;
  border:1px solid rgba(255,255,255,.62);
  box-shadow:inset 0 0 0 1px rgba(199,151,78,.20);
}
.template-stage.premium-master .layer-text{
  z-index:10!important;
  display:grid!important;
  grid-template-rows:auto auto auto 1fr auto auto auto!important;
  justify-items:center!important;
  align-items:center!important;
  padding:72px 42px 44px!important;
  pointer-events:auto;
}
.template-stage.premium-master .tpl-eyebrow{
  font-size:13px!important;
  letter-spacing:.34em!important;
  text-transform:uppercase;
  font-weight:900!important;
  margin:0!important;
  text-shadow:0 1px 0 rgba(255,255,255,.7);
}
.template-stage.premium-master .tpl-title{
  font-size:15px!important;
  letter-spacing:.2em!important;
  font-weight:700!important;
  margin-top:8px!important;
  text-transform:uppercase;
}
.template-stage.premium-master .tpl-names{
  font-size:90px!important;
  line-height:.88!important;
  max-width:620px;
  margin:20px 0 0!important;
  text-shadow:0 2px 0 rgba(255,255,255,.55), 0 12px 24px rgba(56,28,35,.14)!important;
  letter-spacing:-.045em!important;
}
.template-stage.premium-master .tpl-sub{
  align-self:end!important;
  max-width:480px!important;
  margin:0 0 12px!important;
  font-size:14px!important;
  line-height:1.58!important;
  padding:14px 18px!important;
  border-radius:18px!important;
  color:var(--body-color)!important;
  background:rgba(255,255,255,.56)!important;
  border:1px solid rgba(255,255,255,.62);
  box-shadow:0 12px 24px rgba(80,45,55,.08);
  backdrop-filter:blur(4px);
}
.template-stage.premium-master .tpl-info{
  width:min(550px,100%)!important;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px!important;
  margin:4px 0 18px!important;
}
.template-stage.premium-master .tpl-info-item{
  min-height:92px!important;
  border-radius:22px!important;
  background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(255,255,255,.54))!important;
  border:1px solid rgba(255,255,255,.84)!important;
  box-shadow:0 13px 26px rgba(55,34,40,.08), inset 0 0 0 1px rgba(199,151,78,.10)!important;
}
.template-stage.premium-master .tpl-info-item img{
  width:25px!important;
  height:25px!important;
}
.template-stage.premium-master .tpl-info-item b{
  font-size:11.5px!important;
  letter-spacing:.15em!important;
}
.template-stage.premium-master .tpl-info-item span{
  font-size:12px!important;
  line-height:1.32!important;
}
.template-stage.premium-master .tpl-cta{
  min-width:310px!important;
  border-radius:999px!important;
  padding:17px 28px!important;
  font-family:Playfair Display,serif!important;
  font-size:24px!important;
  line-height:1!important;
  box-shadow:
    0 18px 42px rgba(85,42,55,.24),
    inset 0 0 0 2px rgba(255,255,255,.24),
    inset 0 0 0 1px rgba(201,154,85,.44)!important;
}
.template-stage.premium-master .tpl-cta:after{
  content:"›";
  font-size:34px;
  margin-left:4px;
  line-height:0;
}
.template-stage.premium-master .tpl-cta img{
  width:24px!important;
  height:24px!important;
}

/* Rose composition like the user's reference */
.template-stage.rose-master .layer-character{
  background-size:73% auto!important;
  background-position:center 312px!important;
}
.template-stage.rose-master .tpl-names{
  color:#b75f70!important;
  font-size:93px!important;
}
.template-stage.rose-master .tpl-sub{
  background:rgba(255,247,245,.62)!important;
}
.template-stage.rose-master .tpl-cta{
  background:linear-gradient(135deg,#a9475d,#d88795 48%,#944258)!important;
}

/* Sage composition like the user's reference */
.template-stage.sage-master .layer-character{
  background-size:75% auto!important;
  background-position:center 300px!important;
}
.template-stage.sage-master .tpl-names{
  color:#5f735a!important;
  font-size:92px!important;
}
.template-stage.sage-master .tpl-title,
.template-stage.sage-master .tpl-eyebrow{
  color:#5d7557!important;
}
.template-stage.sage-master .tpl-sub{
  background:rgba(255,255,249,.54)!important;
}
.template-stage.sage-master .tpl-cta{
  background:linear-gradient(135deg,#748a65,#4e674b 58%,#3f583c)!important;
}

.template-card .real-template-thumb,
.wv-theme-card .real-template-thumb{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.65);
}
@media(max-width:760px){
  .real-template-thumb{height:500px!important}
  .real-template-inner{transform:translateX(-50%) scale(.485)!important}
  .wv-theme-card>div.real-template-thumb{height:355px!important}
  .wv-theme-card .real-template-inner{transform:translateX(-50%) scale(.345)!important}
}


/* V4.8 PREMIUM CARD RENDERER — template cards no longer use old flat cover renderer */
.premium-template-card{
  position:relative;
  height:640px;
  overflow:hidden;
  border-radius:30px 30px 0 0;
  isolation:isolate;
  background:#f8edea;
}
.premium-template-card:after{
  content:"";
  position:absolute;
  inset:14px;
  border-radius:26px;
  z-index:20;
  pointer-events:none;
  border:1px solid rgba(255,255,255,.72);
  box-shadow:inset 0 0 0 1px rgba(201,154,85,.20);
}
.pc-layer{position:absolute;inset:0;pointer-events:none}
.pc-bg{
  z-index:1;
  background-image:var(--pc-bg);
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
}
.pc-pattern{
  z-index:2;
  background:
    radial-gradient(circle at 50% 9%,rgba(255,255,255,.84),transparent 30%),
    linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.22) 50%,rgba(255,255,255,.55) 78%,rgba(255,255,255,.22));
}
.pc-back{
  z-index:3;
  background-image:var(--pc-back);
  background-size:108% 108%;
  background-position:center top;
  background-repeat:no-repeat;
  filter:drop-shadow(0 18px 26px rgba(58,30,38,.22));
}
.pc-char{
  z-index:5;
  background-image:var(--pc-char);
  background-size:var(--pc-char-size) auto;
  background-position:center var(--pc-char-y);
  background-repeat:no-repeat;
  filter:
    drop-shadow(0 18px 32px rgba(35,18,22,.30))
    drop-shadow(0 -8px 14px rgba(255,255,255,.34));
}
.pc-front{
  z-index:8;
  background-image:var(--pc-front);
  background-size:108% 108%;
  background-position:center top;
  background-repeat:no-repeat;
  filter:drop-shadow(0 -10px 20px rgba(255,255,255,.14));
}
.pc-orn{
  z-index:9;
  background-image:var(--pc-orn);
  background-size:100% 100%;
  background-repeat:no-repeat;
  background-position:center;
}
.pc-content{
  position:absolute;
  inset:0;
  z-index:12;
  display:grid;
  grid-template-rows:auto auto 1fr auto auto auto auto;
  justify-items:center;
  text-align:center;
  padding:48px 28px 30px;
}
.pc-top{display:grid;gap:5px;text-transform:uppercase}
.pc-top span{
  font-family:Montserrat,sans-serif;
  font-size:11px;
  font-weight:900;
  letter-spacing:.34em;
  color:var(--pc-title);
}
.pc-top small{
  font-family:Montserrat,sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  color:var(--pc-title);
}
.pc-content h3{
  font-family:Playfair Display,serif;
  color:var(--pc-name);
  font-size:64px;
  line-height:.88;
  letter-spacing:-.045em;
  margin:18px 0 0;
  max-width:92%;
  text-shadow:0 2px 0 rgba(255,255,255,.55),0 10px 18px rgba(60,30,40,.13);
}
.pc-desc{
  align-self:end;
  max-width:390px;
  margin-bottom:9px;
  padding:11px 15px;
  border-radius:16px;
  color:var(--pc-body);
  font-size:12.5px;
  line-height:1.5;
  background:rgba(255,255,255,.60);
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 8px 18px rgba(70,38,46,.07);
  backdrop-filter:blur(3px);
}
.pc-info{
  width:min(430px,100%);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-bottom:12px;
}
.pc-info div{
  min-height:76px;
  padding:9px 6px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(255,255,255,.58));
  border:1px solid rgba(255,255,255,.82);
  box-shadow:0 10px 22px rgba(55,34,40,.08), inset 0 0 0 1px rgba(201,154,85,.10);
}
.pc-info img{width:22px;height:22px;margin:0 auto 4px}
.pc-info b{
  display:block;
  text-transform:uppercase;
  font-size:9.5px;
  letter-spacing:.13em;
  color:var(--pc-title);
}
.pc-info span{
  display:block;
  margin-top:4px;
  font-size:10px;
  color:var(--pc-body);
  line-height:1.25;
}
.pc-cta{
  border:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  min-width:248px;
  min-height:52px;
  border-radius:999px;
  color:#fff;
  background:var(--pc-btn);
  font-family:Playfair Display,serif;
  font-size:20px;
  box-shadow:0 16px 34px rgba(85,42,55,.25), inset 0 0 0 2px rgba(255,255,255,.23), inset 0 0 0 1px rgba(201,154,85,.45);
}
.pc-cta img{width:22px;height:22px;filter:brightness(0) invert(1)}
.pc-template-name{
  margin-top:16px;
  font-family:Playfair Display,serif;
  font-size:24px;
  color:var(--pc-name);
}
.pc-demo{margin-top:7px;color:var(--pc-name);font-weight:900;font-size:15px}
.template-card .premium-template-card{height:640px}
.wv-theme-card .premium-template-card{height:430px}
.wv-theme-card .pc-content{padding:32px 18px 22px}
.wv-theme-card .pc-content h3{font-size:42px}
.wv-theme-card .pc-char{background-size:74% auto;background-position:center 155px}
.wv-theme-card .pc-desc{max-width:300px;font-size:10px;padding:8px 10px}
.wv-theme-card .pc-info{max-width:320px;gap:6px}
.wv-theme-card .pc-info div{min-height:58px;padding:6px 4px}
.wv-theme-card .pc-info img{width:16px;height:16px}
.wv-theme-card .pc-info b{font-size:7.5px}
.wv-theme-card .pc-info span{font-size:8px}
.wv-theme-card .pc-cta{min-width:190px;min-height:42px;font-size:15px}
.wv-theme-card .pc-template-name{font-size:18px;margin-top:9px}
.wv-theme-card .pc-demo{font-size:12px}
.premium-template-card.wedding-rose .pc-char,
.premium-template-card.rose-master .pc-char{background-size:72% auto;background-position:center 218px}
.premium-template-card.wedding-sage .pc-char,
.premium-template-card.sage-master .pc-char{background-size:74% auto;background-position:center 210px}
.premium-template-card.wedding-jawa .pc-char{background-size:80% auto;background-position:center 185px}
.premium-template-card.khitan-emerald .pc-char,
.premium-template-card.khitan-navy .pc-char,
.premium-template-card.khitan-blue .pc-char{background-size:72% auto;background-position:center 180px}
.premium-template-card.aqiqah-blue .pc-char,
.premium-template-card.aqiqah-pink .pc-char,
.premium-template-card.birthday-princess .pc-char,
.premium-template-card.birthday-rainbow .pc-char{background-size:74% auto;background-position:center 172px}
.template-card .real-template-thumb,.wv-theme-card .real-template-thumb{display:none!important}
@media(max-width:760px){
  .premium-template-card{height:590px}
  .pc-content h3{font-size:52px}
  .pc-info{gap:6px}
  .pc-cta{min-width:220px}
}


/* V4.9 REAL IMAGE LAYERED TEMPLATE
   Semua preview/cover memakai <img> nyata: background, arch, subject orang, front floral.
*/
.real-layer-template{
  position:relative;
  width:100%;
  height:1030px;
  min-height:1030px;
  overflow:hidden;
  border-radius:34px;
  isolation:isolate;
  background:#f8edea;
  box-shadow:0 22px 60px rgba(80,45,55,.18);
}
.real-layer-template img{
  display:block;
  user-select:none;
  -webkit-user-drag:none;
}
.rl-bg,.rl-arch,.rl-subject,.rl-front{
  position:absolute;
  pointer-events:none;
}
.rl-bg{
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
}
.rl-light{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 10%,rgba(255,255,255,.82),transparent 32%),
    linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.18) 46%,rgba(255,255,255,.48) 78%,rgba(255,255,255,.16));
}
.rl-arch{
  left:0;
  top:0;
  width:100%;
  height:100%;
  object-fit:contain;
  z-index:3;
  filter:drop-shadow(0 18px 28px rgba(58,30,38,.22));
}
.rl-subject{
  left:50%;
  top:300px;
  width:74%;
  max-height:60%;
  object-fit:contain;
  transform:translateX(-50%);
  z-index:5;
  filter:
    drop-shadow(0 26px 42px rgba(35,18,22,.30))
    drop-shadow(0 -8px 18px rgba(255,255,255,.42));
}
.rl-front{
  left:0;
  top:0;
  width:100%;
  height:100%;
  object-fit:contain;
  z-index:8;
  filter:drop-shadow(0 -10px 18px rgba(255,255,255,.18));
}
.rl-content{
  position:absolute;
  inset:0;
  z-index:10;
  display:grid;
  grid-template-rows:auto auto auto 1fr auto auto;
  justify-items:center;
  text-align:center;
  padding:68px 42px 44px;
  pointer-events:auto;
}
.rl-kicker{
  color:var(--rl-title);
  font-family:Montserrat,sans-serif;
  text-transform:uppercase;
  font-weight:900;
  font-size:13px;
  letter-spacing:.34em;
  text-shadow:0 1px 0 rgba(255,255,255,.75);
}
.rl-title{
  margin-top:7px;
  color:var(--rl-title);
  font-family:Montserrat,sans-serif;
  text-transform:uppercase;
  font-weight:700;
  font-size:15px;
  letter-spacing:.18em;
}
.rl-content h1{
  color:var(--rl-name);
  font-family:Playfair Display,serif;
  font-size:92px;
  line-height:.88;
  letter-spacing:-.045em;
  margin:20px 0 0;
  max-width:680px;
  text-shadow:0 2px 0 rgba(255,255,255,.62),0 12px 24px rgba(56,28,35,.15);
}
.rl-opening{
  align-self:end;
  max-width:500px;
  margin:0 0 12px;
  padding:14px 18px;
  border-radius:18px;
  color:var(--rl-body);
  font-size:14px;
  line-height:1.58;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 12px 24px rgba(80,45,55,.08);
  backdrop-filter:blur(4px);
}
.rl-info{
  width:min(560px,100%);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin:4px 0 18px;
}
.rl-info div{
  min-height:96px;
  padding:11px 8px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(255,255,255,.58));
  border:1px solid rgba(255,255,255,.84);
  box-shadow:0 13px 26px rgba(55,34,40,.08), inset 0 0 0 1px rgba(201,154,85,.10);
}
.rl-info img{
  width:25px;
  height:25px;
  margin:0 auto 5px;
}
.rl-info b{
  display:block;
  color:var(--rl-title);
  text-transform:uppercase;
  font-size:11.5px;
  letter-spacing:.15em;
}
.rl-info span{
  display:block;
  margin-top:5px;
  color:var(--rl-body);
  font-size:12px;
  line-height:1.32;
}
.rl-cta{
  border:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-width:310px;
  min-height:62px;
  border-radius:999px;
  color:var(--rl-btn-text);
  background:var(--rl-btn);
  font-family:Playfair Display,serif;
  font-size:24px;
  cursor:pointer;
  box-shadow:
    0 18px 42px rgba(85,42,55,.24),
    inset 0 0 0 2px rgba(255,255,255,.24),
    inset 0 0 0 1px rgba(201,154,85,.44);
}
.rl-cta img{
  width:24px;
  height:24px;
  filter:brightness(0) invert(1);
}

/* Thumbnail/card view */
.real-template-thumb-v9{
  height:640px;
  overflow:hidden;
  border-radius:30px 30px 0 0;
  background:#f8edea;
}
.real-template-thumb-v9 .real-layer-template{
  width:100%;
  height:640px;
  min-height:640px;
  border-radius:30px 30px 0 0;
  box-shadow:none;
}
.real-template-thumb-v9 .rl-content{
  padding:42px 28px 30px;
  grid-template-rows:auto auto auto 1fr auto auto;
}
.real-template-thumb-v9 .rl-kicker{font-size:11px}
.real-template-thumb-v9 .rl-title{font-size:11px}
.real-template-thumb-v9 .rl-content h1{
  font-size:64px;
  max-width:92%;
  margin-top:16px;
}
.real-template-thumb-v9 .rl-subject{
  top:210px;
  width:74%;
  max-height:62%;
}
.real-template-thumb-v9 .rl-opening{
  max-width:390px;
  font-size:12.5px;
  padding:11px 15px;
}
.real-template-thumb-v9 .rl-info{
  width:min(430px,100%);
  gap:8px;
  margin-bottom:12px;
}
.real-template-thumb-v9 .rl-info div{
  min-height:76px;
  padding:9px 6px;
  border-radius:18px;
}
.real-template-thumb-v9 .rl-info img{width:22px;height:22px}
.real-template-thumb-v9 .rl-info b{font-size:9.5px}
.real-template-thumb-v9 .rl-info span{font-size:10px}
.real-template-thumb-v9 .rl-cta{
  min-width:248px;
  min-height:52px;
  font-size:20px;
}
.template-card .real-template-thumb-v9{height:640px}
.wv-theme-card .real-template-thumb-v9{
  height:430px;
  border-radius:28px;
}
.wv-theme-card .real-template-thumb-v9 .real-layer-template{
  height:430px;
  min-height:430px;
  border-radius:28px;
}
.wv-theme-card .rl-content{
  padding:30px 18px 22px;
}
.wv-theme-card .rl-kicker{font-size:8px}
.wv-theme-card .rl-title{font-size:8px}
.wv-theme-card .rl-content h1{font-size:42px;margin-top:9px}
.wv-theme-card .rl-subject{top:145px;width:75%}
.wv-theme-card .rl-opening{
  max-width:300px;
  font-size:10px;
  padding:8px 10px;
  margin-bottom:7px;
}
.wv-theme-card .rl-info{
  max-width:320px;
  gap:6px;
}
.wv-theme-card .rl-info div{
  min-height:58px;
  padding:6px 4px;
  border-radius:14px;
}
.wv-theme-card .rl-info img{width:16px;height:16px}
.wv-theme-card .rl-info b{font-size:7.5px}
.wv-theme-card .rl-info span{font-size:8px}
.wv-theme-card .rl-cta{
  min-width:190px;
  min-height:42px;
  font-size:15px;
}

/* Per-template image placement so subject/foto benar-benar kelihatan */
.real-layer-template.wedding-rose .rl-subject{top:300px;width:72%}
.real-layer-template.wedding-sage .rl-subject{top:296px;width:74%}
.real-layer-template.wedding-jawa .rl-subject{top:280px;width:78%}
.real-layer-template.khitan-emerald .rl-subject,
.real-layer-template.khitan-navy .rl-subject,
.real-layer-template.khitan-blue .rl-subject{top:245px;width:70%}
.real-layer-template.aqiqah-blue .rl-subject,
.real-layer-template.aqiqah-pink .rl-subject,
.real-layer-template.birthday-princess .rl-subject,
.real-layer-template.birthday-rainbow .rl-subject{top:235px;width:70%}

.real-template-thumb-v9 .real-layer-template.wedding-rose .rl-subject{top:210px;width:72%}
.real-template-thumb-v9 .real-layer-template.wedding-sage .rl-subject{top:205px;width:74%}
.real-template-thumb-v9 .real-layer-template.wedding-jawa .rl-subject{top:190px;width:78%}
.real-template-thumb-v9 .real-layer-template.khitan-emerald .rl-subject,
.real-template-thumb-v9 .real-layer-template.khitan-navy .rl-subject,
.real-template-thumb-v9 .real-layer-template.khitan-blue .rl-subject{top:176px;width:70%}
.real-template-thumb-v9 .real-layer-template.aqiqah-blue .rl-subject,
.real-template-thumb-v9 .real-layer-template.aqiqah-pink .rl-subject,
.real-template-thumb-v9 .real-layer-template.birthday-princess .rl-subject,
.real-template-thumb-v9 .real-layer-template.birthday-rainbow .rl-subject{top:166px;width:70%}

/* Hide older renderer thumbnails if any remain */
.real-template-thumb,
.premium-template-card{
  display:none!important;
}

@media(max-width:760px){
  .real-template-thumb-v9{height:590px}
  .real-template-thumb-v9 .real-layer-template{height:590px;min-height:590px}
  .real-template-thumb-v9 .rl-content h1{font-size:52px}
  .rl-content h1{font-size:64px}
  .rl-info{gap:6px}
  .rl-cta{min-width:220px}
}
