/* ============================================================
   form4.css – 온라인 상담 예약 위자드 (form4.php)
   Namespaced under .rv-wrap to avoid Gnuboard CSS conflicts
   ============================================================ */

/* ─── CSS Variables (global) ─── */
:root{
  --g1:#1a6b4a; --g2:#27ae60; --g3:#e8f5ee; --g4:#f0faf4;
  --border:#dce8e1; --text:#1a2e22; --sub:#6b8c78;
  --orange:#e67e22; --blue:#2563eb; --red:#e74c3c;
  --white:#fff; --shadow:0 2px 16px rgba(26,107,74,.09);
}

/* ─── HERO ─── */
.rv-wrap .hero{background:linear-gradient(135deg,#0d3d24 0%,var(--g1) 55%,var(--g2) 100%);padding:50px 20px 44px;text-align:center;color:#fff;position:relative;overflow:hidden}
.rv-wrap .hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(255,255,255,.06) 0%,transparent 60%)}
.rv-wrap .hero-chip{display:inline-block;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);border-radius:20px;padding:5px 16px;font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:14px;position:relative}
.rv-wrap .hero h1{font-size:26px;font-weight:900;margin-bottom:8px;position:relative}
.rv-wrap .hero p{font-size:13px;opacity:.82;position:relative}

/* ─── STEPPER ─── */
.rv-wrap .sp-wrap{background:var(--white);border-bottom:1px solid var(--border);z-index:290;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.rv-wrap .sp{display:flex;max-width:860px;margin:0 auto;padding:0 16px}
.rv-wrap .sp-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 2px 10px;position:relative;opacity:.38;transition:opacity .25s}
.rv-wrap .sp-item.active{opacity:1}
.rv-wrap .sp-item.done{opacity:.75;cursor:pointer}
.rv-wrap .sp-item.done:hover{opacity:1}
.rv-wrap .sp-item:not(:last-child)::after{content:'';position:absolute;right:0;top:46%;width:1px;height:40%;background:#cde0d4}
.rv-wrap .sp-num{width:27px;height:27px;border-radius:50%;background:#d5e8dc;color:#5a8a6a;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:4px;transition:all .25s}
.rv-wrap .sp-item.active .sp-num{background:var(--g1);color:#fff;box-shadow:0 0 0 3px rgba(26,107,74,.18)}
.rv-wrap .sp-item.done .sp-num{background:var(--g2);color:#fff}
.rv-wrap .sp-lbl{font-size:10.5px;font-weight:700;color:#4a7a5a;text-align:center;line-height:1.3}
.rv-wrap .sp-item.active .sp-lbl{color:var(--g1);font-weight:900}

/* ─── MAIN WRAP ─── */
.rv-wrap .main{padding:26px 16px 100px}

/* ─── PANEL ─── */
.rv-wrap .panel{display:none}
.rv-wrap .panel.active{display:block;animation:fadeUp .3s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ─── CARD ─── */
.rv-wrap .card{background:var(--white);border-radius:18px;border:1px solid var(--border);padding:26px 22px;margin-bottom:14px;box-shadow:var(--shadow)}
.rv-wrap .card-ttl{font-size:16px;font-weight:900;color:#0a2e18;display:flex;align-items:center;gap:8px;margin-bottom:5px}
.rv-wrap .card-ico{width:30px;height:30px;background:var(--g3);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.rv-wrap .card-sub{font-size:12px;color:var(--sub);margin-bottom:18px}

/* ─── STEP1: 서비스 카드 ─── */
.rv-wrap .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
.rv-wrap .svc-card{border:2px solid var(--border);border-radius:15px;padding:18px 14px 16px;cursor:pointer;background:#fafcfb;transition:all .2s;position:relative}
.rv-wrap .svc-card:hover{border-color:var(--g1);background:var(--g3);transform:translateY(-2px);box-shadow:0 6px 18px rgba(26,107,74,.10)}
.rv-wrap .svc-card.sel{border-color:var(--g1);background:var(--g3);box-shadow:0 0 0 3px rgba(26,107,74,.13)}
.rv-wrap .svc-card.sel::after{content:'\2713';position:absolute;top:10px;right:12px;width:20px;height:20px;border-radius:50%;background:var(--g1);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}
.rv-wrap .svc-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:10px;font-weight:800;color:#fff;margin-bottom:10px}
.rv-wrap .b-counsel{background:var(--g1)} .rv-wrap .b-pkg{background:var(--orange)} .rv-wrap .b-test{background:var(--blue)} .rv-wrap .b-adhd{background:#7c3aed} .rv-wrap .b-child{background:#0891b2} .rv-wrap .b-cpkg{background:#0d9488}
.rv-wrap .svc-card h4{font-size:14px;font-weight:900;color:#0a2e18;margin-bottom:5px}
.rv-wrap .svc-card p{font-size:11.5px;color:var(--sub);line-height:1.6;margin-bottom:7px}
.rv-wrap .svc-card .sp-price{font-size:13px;font-weight:700;color:var(--g1)}
.rv-wrap .detail-lnk{display:inline-block;margin-top:7px;font-size:11px;color:var(--g1);font-weight:700;background:rgba(26,107,74,.08);border-radius:20px;padding:3px 9px;transition:all .2s}
.rv-wrap .detail-lnk:hover{background:rgba(26,107,74,.16)}

/* ─── STEP2: 상담사 ─── */
.rv-wrap .dr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.rv-wrap .dr-card{border:2px solid var(--border);border-radius:13px;padding:15px 12px;cursor:pointer;text-align:center;transition:all .2s;background:var(--white)}
.rv-wrap .dr-card:hover{border-color:var(--g1);background:var(--g3)}
.rv-wrap .dr-card.sel{border-color:var(--g1);background:var(--g3);box-shadow:0 0 0 3px rgba(26,107,74,.12)}
.rv-wrap .dr-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--g3),#b2dfcc);margin:0 auto 7px;display:flex;align-items:center;justify-content:center;font-size:20px;border:2px solid #c5e0cf}
.rv-wrap .dr-name{font-size:13px;font-weight:700;color:#0a2e18}
.rv-wrap .dr-role{font-size:11px;color:var(--sub);margin-top:2px}
.rv-wrap .dr-info-box{margin-top:10px;padding:9px 14px;background:var(--g3);border-radius:10px;font-size:12px;color:var(--g1);font-weight:700;display:none}

/* ─── 달력 + 시간 ─── */
.rv-wrap .cal-time-wrap{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:2px}
.rv-wrap .cal-box{border:1.5px solid var(--border);border-radius:14px;overflow:hidden;width:100%;min-width:0}
.rv-wrap .cal-nav-bar{display:flex;align-items:center;justify-content:space-between;background:var(--g1);padding:14px 18px;color:#fff}
.rv-wrap .cal-nav-bar h3{font-size:17px;font-weight:800;color:#fff;margin:0}
.rv-wrap .cal-nav-btn{width:34px;height:34px;background:rgba(255,255,255,.18);border:none;color:#fff;border-radius:8px;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.rv-wrap .cal-nav-btn:hover{background:rgba(255,255,255,.32)}
.rv-wrap .cal-table{width:100%;border-collapse:collapse}
.rv-wrap .cal-table thead th{background:var(--g4);padding:10px 0;text-align:center;font-size:13px;font-weight:700;color:var(--sub)}
.rv-wrap .cal-table thead th:first-child{color:var(--red)}
.rv-wrap .cal-table thead th:last-child{color:var(--blue)}
.rv-wrap .cal-table tbody td{text-align:center;padding:7px 3px}
.rv-wrap .cd{display:inline-flex;width:38px;height:38px;border-radius:10px;align-items:center;justify-content:center;font-size:14px;font-weight:500;color:#ccc}
.rv-wrap td.avail{cursor:pointer}
.rv-wrap td.avail .cd{background:var(--g3);color:#0a2e18;font-weight:700}
.rv-wrap td.avail:hover .cd{background:var(--g1);color:#fff;transform:scale(1.08)}
.rv-wrap td.avail.picked .cd{background:var(--g1);color:#fff;box-shadow:0 2px 10px rgba(26,107,74,.35)}
.rv-wrap td.today-mark .cd{border:2px solid var(--g2);background:rgba(39,174,96,.12);font-weight:900}
.rv-wrap .cal-foot{padding:11px 16px;background:#f8fcf9;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:13px}
.rv-wrap .cal-foot .dot{width:10px;height:10px;background:var(--g3);border:1.5px solid var(--g1);border-radius:50%;display:inline-block;margin-right:5px}
.rv-wrap #picked-date-txt{font-size:14px;font-weight:700;color:var(--g1)}

/* 시간 */
.rv-wrap .time-box{border:1.5px solid var(--border);border-radius:14px;overflow:hidden;width:100%;min-width:0}
.rv-wrap .time-hd{background:var(--g1);padding:14px 18px;color:#fff;font-size:16px;font-weight:800}
.rv-wrap .time-bd{padding:20px 20px}
.rv-wrap .t-sec{font-size:14px;font-weight:800;color:var(--sub);letter-spacing:.06em;margin:16px 0 10px}
.rv-wrap .t-sec:first-child{margin-top:0}
.rv-wrap .t-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.rv-wrap .t-btn{padding:14px 10px;border-radius:12px;border:1.5px solid var(--border);background:var(--white);font-size:15px;font-weight:700;color:#3a5f47;cursor:pointer;transition:all .18s;text-align:center}
.rv-wrap .t-btn:hover{border-color:var(--g1);background:var(--g3);transform:translateY(-1px)}
.rv-wrap .t-btn.on{background:var(--g1);color:#fff;border-color:var(--g1);box-shadow:0 3px 12px rgba(26,107,74,.3);transform:translateY(-1px)}
.rv-wrap .t-ph{font-size:14px;color:#b0c0b8;text-align:center;padding:36px 0}

/* 이미 기본이 1fr 1fr — 900px 미디어쿼리 불필요 */

/* ─── STEP3: 항목·쿠폰 ─── */
.rv-wrap .i-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.rv-wrap .i-tab{padding:6px 13px;border-radius:999px;border:1.5px solid var(--border);background:var(--white);font-size:12px;font-weight:700;color:var(--sub);cursor:pointer;transition:all .18s;white-space:nowrap}
.rv-wrap .i-tab:hover{border-color:var(--g1);color:var(--g1)}
.rv-wrap .i-tab.on{background:var(--g1);color:#fff;border-color:var(--g1)}
.rv-wrap .i-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.rv-wrap .i-card{border:2px solid var(--border);border-radius:13px;padding:13px 12px;cursor:pointer;background:var(--white);transition:all .18s;position:relative}
.rv-wrap .i-card:hover{border-color:var(--g1);background:#fafdf9}
.rv-wrap .i-card.on{border-color:var(--g1);background:var(--g3);box-shadow:0 0 0 3px rgba(26,107,74,.10)}
.rv-wrap .i-card.hi{background:linear-gradient(135deg,#f0fdf4,#e8f9f0)}
.rv-wrap .i-ck{position:absolute;top:11px;right:11px;width:19px;height:19px;border-radius:50%;border:2px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;transition:all .2s}
.rv-wrap .i-card.on .i-ck{background:var(--g1);border-color:var(--g1);color:#fff}
.rv-wrap .rec-bdg{position:absolute;top:-8px;left:11px;background:var(--orange);color:#fff;font-size:9.5px;font-weight:800;padding:2px 9px;border-radius:999px}
.rv-wrap .save-bdg{position:absolute;top:-8px;right:11px;background:var(--blue);color:#fff;font-size:9.5px;font-weight:800;padding:2px 9px;border-radius:999px}
.rv-wrap .i-name{font-size:13px;font-weight:800;color:#0a2e18;padding-right:26px;margin-bottom:3px;line-height:1.3}
.rv-wrap .i-price{font-size:14px;font-weight:900;color:var(--g1)}
.rv-wrap .i-meta{font-size:11px;color:var(--sub);margin-top:2px}
.rv-wrap .i-note{font-size:11px;color:var(--sub);margin-top:9px;padding:9px 11px;background:var(--g4);border-radius:9px;border-left:3px solid #a7d9ba}

/* 합산 */
.rv-wrap .tot-bar{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;background:var(--g4);border:1.5px solid #c5e0cf;border-radius:12px;margin-top:16px}
.rv-wrap .tot-lbl{font-size:13px;font-weight:800;color:#0a2e18}
.rv-wrap .tot-val{font-size:17px;font-weight:900;color:var(--g1)}

/* 쿠폰 */
.rv-wrap .coupon-wrap{margin-top:11px;padding:16px;background:var(--white);border:1.5px solid var(--border);border-radius:12px}
.rv-wrap .coupon-row{display:flex;gap:9px;align-items:center}
.rv-wrap .cp-input{flex:1;height:42px;border:1.5px solid var(--border);border-radius:9px;padding:0 13px;font-size:13px;font-family:'Noto Sans KR',sans-serif;font-weight:600;color:var(--text);outline:none;transition:border-color .2s}
.rv-wrap .cp-input:focus{border-color:var(--g1);box-shadow:0 0 0 3px rgba(26,107,74,.08)}
.rv-wrap .cp-input::placeholder{color:#b5c8bd}
.rv-wrap .cp-btn{height:42px;padding:0 16px;background:var(--g1);color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:800;cursor:pointer;transition:background .2s;white-space:nowrap}
.rv-wrap .cp-btn:hover{background:#155a3d}
.rv-wrap .cp-result{display:flex;gap:18px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:12.5px}
.rv-wrap .cp-result span{color:var(--sub)}
.rv-wrap .cp-result b{color:var(--g1);font-weight:900}
.rv-wrap .cp-final{color:#0a2e18!important;font-size:14px!important;font-weight:900!important}
.rv-wrap .cp-applied{background:var(--g3);border-radius:8px;padding:6px 12px;font-size:12px;color:var(--g1);font-weight:700;margin-top:8px;display:none}

/* ─── STEP4: 정보입력 ─── */
.rv-wrap .fg{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:13px}
.rv-wrap .fgroup{display:flex;flex-direction:column;gap:5px}
.rv-wrap .fgroup label{font-size:12.5px;font-weight:800;color:#1a3528}
.rv-wrap .fgroup label .req{color:var(--red);margin-left:2px}
.rv-wrap .f-inp,.rv-wrap .f-sel,.rv-wrap .f-ta{width:100%;height:46px;border:1.5px solid var(--border);border-radius:11px;padding:0 13px;font-size:13.5px;font-family:'Noto Sans KR',sans-serif;font-weight:500;color:var(--text);background:var(--white);outline:none;transition:border-color .2s}
.rv-wrap .f-inp:focus,.rv-wrap .f-sel:focus,.rv-wrap .f-ta:focus{border-color:var(--g1);box-shadow:0 0 0 3px rgba(26,107,74,.08)}
.rv-wrap .f-inp.err{border-color:var(--red)}
.rv-wrap .f-inp::placeholder,.rv-wrap .f-ta::placeholder{color:#b5c8bd}
.rv-wrap .f-ta{height:95px;padding:11px 13px;resize:vertical;line-height:1.6}
.rv-wrap .ferr{font-size:11.5px;color:var(--red);font-weight:600;display:none;margin-top:2px}
.rv-wrap .ferr.show{display:block}

/* 개인정보 */
.rv-wrap .priv-wrap{border:1.5px solid var(--border);border-radius:13px;overflow:hidden;margin-top:2px}
.rv-wrap .priv-hd{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;cursor:pointer;background:#f8fcf9;user-select:none}
.rv-wrap .priv-hd:hover{background:var(--g3)}
.rv-wrap .priv-left{display:flex;align-items:center;gap:9px}
.rv-wrap .priv-chk{width:19px;height:19px;accent-color:var(--g1);cursor:pointer}
.rv-wrap .priv-lbl{font-size:13.5px;font-weight:700;color:var(--text)}
.rv-wrap .priv-req{background:var(--red);color:#fff;font-size:9.5px;font-weight:800;padding:2px 6px;border-radius:4px;margin-right:5px}
.rv-wrap .priv-tgl{font-size:11.5px;color:var(--sub);font-weight:700;background:none;border:1px solid var(--border);border-radius:6px;padding:3px 9px;cursor:pointer;transition:all .2s}
.rv-wrap .priv-tgl:hover{border-color:var(--g1);color:var(--g1)}
.rv-wrap .priv-body{display:none;padding:14px 16px;border-top:1px solid var(--border);background:var(--white);font-size:11.5px;color:#4a6455;line-height:1.8}
.rv-wrap .priv-tbl{width:100%;border-collapse:collapse;margin-top:8px}
.rv-wrap .priv-tbl th,.rv-wrap .priv-tbl td{border:1px solid var(--border);padding:7px 11px;font-size:11.5px}
.rv-wrap .priv-tbl th{background:var(--g4);font-weight:700}
.rv-wrap .priv-err{font-size:11.5px;color:var(--red);font-weight:600;display:none;padding:5px 16px 8px}
.rv-wrap .priv-err.show{display:block}

/* ─── STEP5: 확인·결제 ─── */
.rv-wrap .confirm-box{background:var(--g4);border:1.5px solid #c5e0cf;border-radius:15px;padding:20px;margin-bottom:14px}
.rv-wrap .confirm-ttl{font-size:13.5px;font-weight:900;color:#0a2e18;margin-bottom:12px;padding-bottom:9px;border-bottom:1px solid #d0e8d8}
.rv-wrap .c-row{display:flex;align-items:flex-start;gap:9px;margin-bottom:8px;font-size:13px}
.rv-wrap .c-row:last-child{margin-bottom:0}
.rv-wrap .c-key{min-width:82px;color:var(--sub);font-weight:700;flex-shrink:0}
.rv-wrap .c-val{color:#0a2e18;font-weight:700;flex:1}
.rv-wrap .c-price{color:var(--g1)!important;font-size:15px!important;font-weight:900!important}

/* 결제수단 */
.rv-wrap .pay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:6px}
.rv-wrap .pay-card{border:2px solid var(--border);border-radius:12px;padding:14px 10px;cursor:pointer;text-align:center;transition:all .2s;background:var(--white)}
.rv-wrap .pay-card:hover{border-color:var(--g1);background:var(--g3)}
.rv-wrap .pay-card.sel{border-color:var(--g1);background:var(--g3);box-shadow:0 0 0 3px rgba(26,107,74,.12)}
.rv-wrap .pay-ico{font-size:22px;margin-bottom:5px}
.rv-wrap .pay-name{font-size:12.5px;font-weight:700;color:#0a2e18}
.rv-wrap .pay-desc{font-size:10.5px;color:var(--sub);margin-top:2px}

/* 환불 */
.rv-wrap .refund-box{background:#fff8f0;border:1.5px solid #f0d9b8;border-radius:12px;padding:14px 16px;margin-bottom:14px}
.rv-wrap .refund-ttl{font-size:12.5px;font-weight:800;color:#8b5e1e;margin-bottom:9px}
.rv-wrap .r-row{display:flex;justify-content:space-between;font-size:12px;margin-bottom:5px}
.rv-wrap .r-row:last-child{margin-bottom:0}
.rv-wrap .r-c{color:#6b5a40} .rv-wrap .r-v{font-weight:800;color:#8b5e1e}

/* ─── 버튼 ─── */
.rv-wrap .btn-row{display:flex;gap:9px;margin-top:18px}
.rv-wrap .btn-p{flex:1;min-width:80px;height:50px;background:var(--white);border:2px solid var(--g1);border-radius:13px;color:var(--g1);font-size:14px;font-weight:800;cursor:pointer;transition:all .2s}
.rv-wrap .btn-p:hover{background:var(--g3)}
.rv-wrap .btn-n{flex:2;min-width:140px;height:50px;background:var(--g1);border:none;border-radius:13px;color:#fff;font-size:15px;font-weight:900;cursor:pointer;transition:all .2s;box-shadow:0 3px 12px rgba(26,107,74,.28)}
.rv-wrap .btn-n:hover{background:#155a3d;box-shadow:0 5px 16px rgba(26,107,74,.38)}
.rv-wrap .btn-sub{width:100%;height:56px;background:linear-gradient(135deg,var(--g1) 0%,#0f4c32 100%);border:none;border-radius:15px;color:#fff;font-size:17px;font-weight:900;cursor:pointer;transition:all .2s;box-shadow:0 5px 18px rgba(26,107,74,.33);margin-top:4px}
.rv-wrap .btn-sub:hover{background:linear-gradient(135deg,#155a3d 0%,#0a3524 100%)}

/* ─── 에러 메시지 ─── */
.rv-wrap .err-box{display:none;color:var(--red);font-size:12.5px;margin-top:11px;padding:9px 13px;background:#fff5f5;border-radius:8px;border-left:3px solid var(--red)}
.rv-wrap .err-box.show{display:block}

/* ─── 결제 모달 ─── */
.rv-wrap .pm-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:9000;align-items:center;justify-content:center;padding:20px}
.rv-wrap .pm-overlay.open{display:flex}
.rv-wrap .pm-box{background:var(--white);border-radius:22px;max-width:440px;width:100%;overflow:hidden;box-shadow:0 18px 56px rgba(0,0,0,.22);animation:popIn .3s ease}
@keyframes popIn{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.rv-wrap .pm-hd{padding:22px 24px;color:#fff;text-align:center}
.rv-wrap .pm-hd.card-hd{background:linear-gradient(135deg,var(--g1),var(--g2))}
.rv-wrap .pm-hd.bank-hd{background:linear-gradient(135deg,#1e40af,#2563eb)}
.rv-wrap .pm-hd.vbank-hd{background:linear-gradient(135deg,#374151,#6b7280)}
.rv-wrap .pm-hd h3{font-size:17px;font-weight:900;margin-bottom:3px}
.rv-wrap .pm-hd p{font-size:12px;opacity:.82}
.rv-wrap .pm-body{padding:22px 22px 16px}
.rv-wrap .pm-amount{text-align:center;margin-bottom:20px;padding:14px;background:var(--g4);border-radius:11px}
.rv-wrap .pm-amount .albl{font-size:11.5px;color:var(--sub);font-weight:600;margin-bottom:3px}
.rv-wrap .pm-amount .aval{font-size:30px;font-weight:900;color:var(--g1)}
.rv-wrap .pm-fg{margin-bottom:12px}
.rv-wrap .pm-fg label{font-size:12px;font-weight:700;color:#1a3528;display:block;margin-bottom:5px}
.rv-wrap .pm-inp{width:100%;height:42px;border:1.5px solid var(--border);border-radius:9px;padding:0 13px;font-size:13px;font-family:'Noto Sans KR',sans-serif;font-weight:500;outline:none;transition:border-color .2s}
.rv-wrap .pm-inp:focus{border-color:var(--g1)}
.rv-wrap .pm-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.rv-wrap .bank-info{background:var(--g4);border-radius:10px;padding:13px;margin-bottom:14px}
.rv-wrap .bi-row{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:5px}
.rv-wrap .bi-row:last-child{margin-bottom:0}
.rv-wrap .bi-k{color:var(--sub)} .rv-wrap .bi-v{font-weight:700;color:#0a2e18}
.rv-wrap .pm-ft{padding:0 22px 22px;display:flex;gap:9px}
.rv-wrap .pm-cancel{flex:1;height:46px;background:var(--white);border:2px solid var(--border);border-radius:11px;color:#666;font-size:13px;font-weight:700;cursor:pointer}
.rv-wrap .pm-confirm{flex:2;height:46px;background:var(--g1);border:none;border-radius:11px;color:#fff;font-size:14px;font-weight:800;cursor:pointer;box-shadow:0 3px 12px rgba(26,107,74,.28)}
.rv-wrap .pm-confirm:hover{background:#155a3d}
.rv-wrap .pm-confirm.kakao-btn{background:#f9e000;color:#3a1d1d}

/* ─── 완료 모달 ─── */
.rv-wrap .done-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:9001;align-items:center;justify-content:center;padding:20px}
.rv-wrap .done-overlay.open{display:flex}
.rv-wrap .done-box{background:var(--white);border-radius:22px;padding:38px 30px;max-width:400px;width:100%;text-align:center;box-shadow:0 18px 56px rgba(0,0,0,.22);animation:popIn .3s ease}
.rv-wrap .done-ico{width:68px;height:68px;background:var(--g3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 18px}
.rv-wrap .done-box h3{font-size:20px;font-weight:900;color:#0a2e18;margin-bottom:9px}
.rv-wrap .done-box p{font-size:13.5px;color:var(--sub);line-height:1.7;margin-bottom:7px}
.rv-wrap .done-tel{font-size:15px;font-weight:900;color:var(--g1);margin-bottom:22px}
.rv-wrap .done-close{width:100%;height:46px;background:var(--g1);border:none;border-radius:11px;color:#fff;font-size:15px;font-weight:800;cursor:pointer}
.rv-wrap .done-close:hover{background:#155a3d}

/* ─── RESPONSIVE ─── */
@media(max-width:640px){
  .rv-wrap .svc-grid{grid-template-columns:1fr 1fr}
  .rv-wrap .cal-time-wrap{grid-template-columns:1fr}
  .rv-wrap .i-grid{grid-template-columns:1fr}
  .rv-wrap .fg{grid-template-columns:1fr}
  .rv-wrap .pay-grid{grid-template-columns:1fr 1fr}
  .rv-wrap .btn-row{flex-direction:column}
  .rv-wrap .btn-p,.rv-wrap .btn-n{flex:none;width:100%}
  .rv-wrap .hero h1{font-size:22px}
  .rv-wrap .card{padding:20px 15px}
  .rv-wrap .sp-lbl{font-size:9.5px}
}
