/* ═══════════════════════════════════════════
   바로라이프 style.css v4.0
═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans KR',sans-serif;background:#f5f7fa;color:#222;line-height:1.6;}

:root{
  --primary:#1a5276;
  --accent:#e67e22;
  --green:#27ae60;
  --amber:#d4a017;
  --light:#eaf2fb;
  --card:#ffffff;
  --border:#d5e8f5;
  --sub:#5d6d7e;
  --danger:#c0392b;
  --success:#27ae60;
  --admin-bar:#0d2137;
}

::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px;}

/* ── 관리자 배너 ── */
.admin-bar{background:var(--admin-bar);color:#7fb3d3;text-align:center;font-size:.78rem;padding:.35rem;display:none;}
.admin-bar.show{display:block;}

/* ── HEADER ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fff;border-bottom:2px solid var(--border);box-shadow:0 2px 12px rgba(26,82,118,.1);}
.header-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem;height:64px;display:flex;align-items:center;gap:1.5rem;}
.header-logo{height:38px;cursor:pointer;flex-shrink:0;}
.header-logo-text{font-size:1.35rem;font-weight:900;color:var(--primary);cursor:pointer;flex-shrink:0;letter-spacing:-.5px;}

.desktop-nav{display:flex;align-items:center;flex:1;}
.nav-link{padding:.42rem .85rem;font-size:.88rem;font-weight:500;color:var(--sub);text-decoration:none;border-radius:6px;transition:color .2s,background .2s;cursor:pointer;white-space:nowrap;border:none;background:none;}
.nav-link:hover{color:var(--primary);background:var(--light);}
.nav-link.active{color:var(--primary);font-weight:700;background:var(--light);}

.header-actions{display:flex;align-items:center;gap:.6rem;margin-left:auto;flex-shrink:0;}
.btn-admin-login{padding:.4rem 1rem;font-size:.82rem;font-weight:600;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .2s;}
.btn-admin-login:hover{background:#154360;}
.btn-admin-logout{padding:.4rem .9rem;font-size:.82rem;font-weight:600;background:transparent;color:var(--danger);border:1.5px solid var(--danger);border-radius:6px;cursor:pointer;transition:all .2s;}
.btn-admin-logout:hover{background:var(--danger);color:#fff;}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;margin-left:auto;border:none;background:none;}
.hamburger span{display:block;width:24px;height:2px;background:var(--primary);border-radius:2px;transition:all .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-nav{display:none;flex-direction:column;background:#fff;border-top:1px solid var(--border);padding:.5rem 0 1rem;}
.mobile-nav.open{display:flex;}
.mobile-nav .nav-link{padding:.75rem 1.5rem;border-radius:0;border-bottom:1px solid #f0f4f8;}

@media(max-width:900px){
  .desktop-nav{display:none;}
  .hamburger{display:flex;}
}

/* ── APP / 섹션 ── */
#app{padding-top:64px;}
.section{display:none;min-height:calc(100vh - 64px);padding:2.5rem 1.5rem 5rem;}
.section.active{display:block;}
.section-inner{max-width:1280px;margin:0 auto;}

.section-title{font-size:1.6rem;font-weight:700;color:var(--primary);margin-bottom:.3rem;}
.section-sub{color:var(--sub);font-size:.95rem;margin-bottom:1.5rem;}

.divider{width:48px;height:4px;background:var(--accent);border-radius:2px;margin:.5rem 0 1.8rem;}

/* ── 홈 히어로 ── */
#sec-home{padding:0;}
.hero-wrap{position:relative;width:100%;min-height:520px;overflow:hidden;background:linear-gradient(135deg,#0d2137 0%,#1a5276 60%,#2980b9 100%);display:flex;align-items:center;justify-content:center;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s;background-size:cover;background-position:center;}
.hero-slide.active{opacity:1;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,33,55,.55),rgba(13,33,55,.25));}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding:3.5rem 1.5rem;}
.hero-eyebrow{font-size:.8rem;letter-spacing:2.5px;text-transform:uppercase;color:#a9cce3;margin-bottom:.75rem;}
.hero-title{font-size:clamp(1.8rem,4vw,3.2rem);font-weight:900;line-height:1.2;margin-bottom:1rem;}
.hero-desc{font-size:1.05rem;color:#d6eaf8;max-width:540px;margin:0 auto 2rem;}
.hero-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent);color:#fff;font-size:1rem;font-weight:700;padding:.8rem 2.2rem;border-radius:8px;cursor:pointer;border:none;transition:background .2s,transform .1s;}
.hero-cta:hover{background:#ca6f1e;transform:translateY(-2px);}
.hero-dots{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);display:flex;gap:.4rem;z-index:3;}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;border:none;transition:background .3s;}
.hero-dot.active{background:#fff;}
.hero-admin-btn{position:absolute;top:1rem;right:1rem;z-index:10;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:.8rem;padding:.4rem .85rem;border-radius:6px;cursor:pointer;display:none;}
.hero-admin-btn.show{display:block;}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.35;}

/* ── 홈 본문 ── */
.home-body{padding:3rem 1.5rem 5rem;}
.home-body .section-inner{max-width:1280px;margin:0 auto;}

/* ── 블록 (홈 섹션 단위) ── */
.block{margin-bottom:4.5rem;}
.block-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem;}
.block-title{font-size:1.4rem;font-weight:700;color:var(--primary);margin-top:.3rem;}
.block-sub{font-size:.9rem;color:var(--sub);margin-top:.2rem;}
.block-actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;}
.block-tag{display:inline-block;font-size:.72rem;font-weight:700;padding:.2rem .7rem;border-radius:20px;letter-spacing:.5px;text-transform:uppercase;}
.tag-blue {background:#d6eaf8;color:#1a5276;}
.tag-green{background:#d5f5e3;color:#1e8449;}
.tag-amber{background:#fef9e7;color:#9a7d0a;border:1px solid #f9e79f;}

.btn-more{padding:.4rem 1rem;font-size:.82rem;font-weight:600;color:var(--primary);background:var(--light);border:1.5px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap;}
.btn-more:hover{background:var(--primary);color:#fff;border-color:var(--primary);}

/* 소개 블록 */
.block-overview{background:linear-gradient(135deg,#f0f6fd 0%,#e8f5f0 100%);border-radius:16px;padding:2.5rem;border:1.5px solid var(--border);}
.overview-inner{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem;}
.overview-text{font-size:.95rem;color:#444;line-height:1.9;}
.why-grid{display:flex;flex-direction:column;gap:.85rem;}
.why-card{background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:1.1rem 1.2rem;position:relative;}
.why-card h4{font-size:.95rem;font-weight:700;color:var(--primary);margin-bottom:.25rem;}
.why-card p{font-size:.85rem;color:#555;}
.why-icon{font-size:1.4rem;margin-bottom:.35rem;}

/* ── 정보 박스 ── */
.info-box{border-radius:10px;padding:1rem 1.25rem;font-size:.88rem;line-height:1.7;}
.info-blue {background:#dbeafe;border-left:4px solid #2563eb;color:#1e3a5f;}
.info-green{background:#d1fae5;border-left:4px solid #059669;color:#064e3b;}
.info-amber{background:#fef3c7;border-left:4px solid #d97706;color:#78350f;}

/* ── 카드 ── */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem;}

.company-card{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:1.5rem;transition:box-shadow .2s,transform .15s;position:relative;}
.company-card:hover{box-shadow:0 8px 28px rgba(26,82,118,.14);transform:translateY(-3px);}
.card-highlight{border-color:#3498db;box-shadow:0 0 0 3px rgba(52,152,219,.15);}

.card-admin-row{display:flex;gap:.3rem;margin-bottom:.75rem;flex-wrap:wrap;}
.card-header{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:.75rem;}
.card-logo{width:48px;height:48px;border-radius:10px;background:var(--light);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;}
.card-name{font-size:1.05rem;font-weight:700;color:#1a2e3b;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;}
.card-meta{font-size:.78rem;color:var(--sub);margin-top:.15rem;}
.badge-rec{font-size:.68rem;font-weight:700;padding:.15rem .5rem;border-radius:20px;background:#3498db;color:#fff;white-space:nowrap;}
.card-desc{font-size:.85rem;color:#555;line-height:1.6;margin-bottom:.85rem;}
.card-badges{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.85rem;}
.badge{font-size:.72rem;font-weight:600;padding:.22rem .6rem;border-radius:20px;}
.badge-blue{background:#d6eaf8;color:#1a5276;}
.card-features{font-size:.84rem;color:var(--sub);margin-bottom:1rem;list-style:none;}
.card-features li{padding:.18rem 0;display:flex;align-items:baseline;gap:.4rem;}
.card-features li::before{content:"•";color:var(--accent);}
.card-price{font-size:1.2rem;font-weight:700;color:var(--primary);margin-bottom:.85rem;}
.card-price span{font-size:.78rem;font-weight:400;color:var(--sub);}
.card-actions{display:flex;gap:.6rem;}
.btn-detail{flex:1;padding:.5rem;background:var(--primary);color:#fff;border:none;border-radius:7px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;}
.btn-detail:hover{background:#154360;}
.btn-compare{flex:1;padding:.5rem;background:transparent;color:var(--primary);border:1.5px solid var(--primary);border-radius:7px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;}
.btn-compare:hover{background:var(--light);}

/* ── 비교 테이블 ── */
.compare-table-wrap{overflow-x:auto;}
.compare-table{width:100%;border-collapse:collapse;font-size:.86rem;}
.compare-table th{background:var(--primary);color:#fff;padding:.75rem 1rem;text-align:left;white-space:nowrap;}
.compare-table td{padding:.6rem 1rem;border-bottom:1px solid var(--border);vertical-align:top;}
.compare-table tr:nth-child(even) td{background:#f5f9fd;}
.compare-table tr:hover td{background:var(--light);}
.chk-yes{color:var(--success);font-weight:700;}
.chk-no{color:#bdc3c7;}

/* ── VOC ── */
.voc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;}
.voc-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:1.25rem;position:relative;}
.voc-stars{color:#f1c40f;font-size:1rem;margin-bottom:.5rem;}
.voc-text{font-size:.87rem;color:#444;line-height:1.65;margin-bottom:.75rem;}
.voc-author{font-size:.78rem;color:var(--sub);font-weight:600;}

/* ── 관리자 대시보드 ── */
.admin-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:2rem;}
.stat-card{background:var(--light);border:1px solid var(--border);border-radius:10px;padding:1.25rem;text-align:center;}
.stat-num{font-size:2.2rem;font-weight:700;color:var(--primary);}
.stat-label{font-size:.78rem;color:var(--sub);margin-top:.2rem;}

.admin-panel{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;}
.admin-panel-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;}
.admin-panel-title{font-size:1rem;font-weight:700;color:var(--primary);}
.upload-label{display:block;font-size:.82rem;font-weight:600;color:#555;margin-bottom:.4rem;}

.img-list-item{display:flex;align-items:center;gap:.85rem;padding:.75rem;border:1px solid var(--border);border-radius:8px;margin-bottom:.6rem;background:#fafcfe;flex-wrap:wrap;}
.img-thumb{width:72px;height:48px;object-fit:cover;border-radius:5px;background:#e8edf2;flex-shrink:0;}
.img-meta{flex:1;font-size:.82rem;min-width:120px;}
.img-meta strong{display:block;font-size:.88rem;}
.img-meta span{color:var(--sub);}

/* ── FOOTER ── */
.site-footer{background:#0d2137;color:#7fb3d3;padding:3rem 1.5rem 2rem;}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;}
.footer-col h4{color:#fff;font-size:.9rem;margin-bottom:.75rem;}
.footer-col p,.footer-col a{font-size:.82rem;color:#7fb3d3;line-height:1.9;text-decoration:none;display:block;}
.footer-col a:hover{color:#fff;}
.footer-bottom{text-align:center;font-size:.75rem;color:#4a6e86;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #1a3a52;}

/* ── 모달 ── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem;}
.modal-backdrop.hidden{display:none;}
.modal{background:#fff;border-radius:14px;padding:2rem;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.modal-title{font-size:1.15rem;font-weight:700;color:var(--primary);margin-bottom:1.5rem;}
.modal label{display:block;font-size:.82rem;font-weight:600;color:#555;margin-top:.9rem;margin-bottom:.3rem;}
.modal input,.modal select,.modal textarea{width:100%;padding:.6rem .85rem;border:1.5px solid var(--border);border-radius:7px;font-size:.9rem;font-family:inherit;outline:none;transition:border-color .2s;}
.modal input:focus,.modal select:focus,.modal textarea:focus{border-color:var(--primary);}
.modal textarea{min-height:85px;resize:vertical;}
.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}

/* ── 버튼 공통 ── */
.btn-save{padding:.55rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:7px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;}
.btn-save:hover{background:#154360;}
.btn-cancel{padding:.55rem 1.2rem;background:transparent;color:#666;border:1.5px solid #ccc;border-radius:7px;font-size:.9rem;cursor:pointer;}
.btn-cancel:hover{background:#f5f5f5;}
.add-btn{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;padding:.5rem 1.2rem;background:var(--primary);color:#fff;border:none;border-radius:7px;cursor:pointer;transition:background .2s;white-space:nowrap;}
.add-btn:hover{background:#154360;}
.edit-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;padding:.3rem .75rem;border:1.5px solid var(--primary);color:var(--primary);background:transparent;border-radius:5px;cursor:pointer;transition:all .15s;white-space:nowrap;}
.edit-btn:hover{background:var(--primary);color:#fff;}
.del-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;padding:.3rem .75rem;border:1.5px solid var(--danger);color:var(--danger);background:transparent;border-radius:5px;cursor:pointer;transition:all .15s;white-space:nowrap;}
.del-btn:hover{background:var(--danger);color:#fff;}

/* ── 토스트 ── */
#toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(80px);background:#1a2e3b;color:#fff;padding:.7rem 1.5rem;border-radius:8px;font-size:.88rem;z-index:3000;opacity:0;transition:all .3s;pointer-events:none;white-space:nowrap;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ── 유틸 ── */
.hidden{display:none!important;}
.text-muted{color:var(--sub);font-size:.85rem;}
.flex-between{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;}

/* ── 반응형 ── */
@media(max-width:768px){
  .cards-grid{grid-template-columns:1fr;}
  .section{padding:1.5rem 1rem 3rem;}
  .home-body{padding:2rem 1rem 3rem;}
  .footer-inner{grid-template-columns:1fr;}
  .overview-inner{grid-template-columns:1fr;}
  .admin-stats{grid-template-columns:repeat(2,1fr);}
  .form-grid{grid-template-columns:1fr;}
  .block-overview{padding:1.5rem;}
}


/* ═══════════════════════════════════════════════════════════
   비교표 — 선불/후불 섹션 분리
═══════════════════════════════════════════════════════════ */
.compare-section { margin-bottom: 2.5rem; }
.compare-section-head {
  display: flex;
  align-items: center;
  gap: .85rem;
  margin-bottom: 1rem;
}
.compare-section-sub {
  font-size: .85rem;
  color: var(--sub);
}
.compare-badge {
  display: inline-block;
  font-size: .8rem;
  font-weight: 700;
  padding: .3rem .9rem;
  border-radius: 20px;
  letter-spacing: .5px;
  white-space: nowrap;
}
.badge-blue-lg  { background: #1a5276; color: #fff; }
.badge-green-lg { background: #1e8449; color: #fff; }
.compare-divider {
  border: none;
  border-top: 2px dashed var(--border);
  margin: 2rem 0;
}

/* ═══════════════════════════════════════════════════════════
   고객 선택 상품 — 용품 테이블 카드
═══════════════════════════════════════════════════════════ */
.custom-card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 1.4rem;
  transition: box-shadow .2s, transform .15s;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.custom-card:hover { box-shadow: 0 8px 28px rgba(26,82,118,.13); transform: translateY(-2px); }

.custom-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .2rem;
}
.custom-card-left {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
}

/* 용품 테이블 */
.item-table-wrap {
  overflow-x: auto;
  border-radius: 8px;
  border: 1px solid var(--border);
  margin-bottom: .85rem;
}
.item-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .82rem;
}
.item-table th {
  background: #f0f5fb;
  color: var(--primary);
  font-weight: 700;
  padding: .45rem .6rem;
  text-align: left;
  border-bottom: 1.5px solid var(--border);
  white-space: nowrap;
}
.item-table td {
  padding: .38rem .6rem;
  border-bottom: 1px solid #eef2f7;
  vertical-align: middle;
  white-space: nowrap;
}
.item-table tr:last-child td { border-bottom: none; }
.item-table .col-cat   { width: 70px; }
.item-table .col-name  { min-width: 130px; white-space: normal; }
.item-table .col-price { width: 90px;  text-align: right; }
.item-table .col-qty   { width: 90px;  text-align: center; }
.item-table .col-sub   { width: 90px;  text-align: right; font-weight: 600; color: var(--primary); }
.item-table .col-act   { width: 36px;  text-align: center; }

.cat-row td { background: #f7fafd; font-size: .75rem; font-weight: 700; color: #2c6fa8; padding: .3rem .6rem; letter-spacing: .5px; }
.cat-label  { color: #2c6fa8; }

.total-row td { background: #eaf2fb; font-weight: 700; border-top: 2px solid var(--primary); }
.total-label  { text-align: right; color: var(--primary); padding-right: 1rem; }
.total-val    { color: var(--primary); font-size: 1rem; text-align: right; }

/* 수량 컨트롤 */
.qty-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .25rem;
}
.qty-btn {
  width: 22px; height: 22px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--primary);
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
  flex-shrink: 0;
  padding: 0;
  line-height: 1;
}
.qty-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.qty-val {
  min-width: 22px;
  text-align: center;
  font-weight: 700;
  font-size: .88rem;
  color: #1a2e3b;
}
.del-btn-sm {
  width: 22px; height: 22px;
  border-radius: 4px;
  border: 1px solid var(--danger);
  background: transparent;
  color: var(--danger);
  font-size: .75rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
  padding: 0;
}
.del-btn-sm:hover { background: var(--danger); color: #fff; }

/* 행 추가 패널 */
.add-item-panel {
  background: #f0f9f4;
  border: 1.5px dashed #27ae60;
  border-radius: 8px;
  padding: .75rem;
  margin-bottom: .75rem;
}
.add-item-row {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  align-items: center;
}
.ai-sel, .ai-inp {
  padding: .35rem .55rem;
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: .8rem;
  font-family: inherit;
  outline: none;
  transition: border-color .2s;
}
.ai-sel:focus, .ai-inp:focus { border-color: var(--primary); }
.add-item-btn {
  padding: .35rem .85rem;
  background: var(--success);
  color: #fff;
  border: none;
  border-radius: 5px;
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .2s;
}
.add-item-btn:hover { background: #1e8449; }

/* 카탈로그 모달 목록 */
.catalog-group { margin-bottom: 1rem; }
.catalog-group-title {
  font-size: .78rem;
  font-weight: 700;
  color: var(--primary);
  background: var(--light);
  padding: .3rem .75rem;
  border-radius: 5px;
  margin-bottom: .4rem;
  letter-spacing: .5px;
}
.catalog-item-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem .5rem;
  border-bottom: 1px solid #f0f4f8;
}
.catalog-name  { flex: 1; font-size: .85rem; }
.catalog-price { font-size: .82rem; color: var(--primary); font-weight: 600; white-space: nowrap; min-width: 80px; text-align: right; }

/* 홈 custom-grid 카드 크기 조정 */
#home-custom-grid.cards-grid { grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); }
#sec-custom-grid.cards-grid  { grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); }

@media(max-width:600px){
  #home-custom-grid.cards-grid,
  #sec-custom-grid.cards-grid { grid-template-columns: 1fr; }
  .add-item-row { flex-direction: column; align-items: stretch; }
  .ai-sel, .ai-inp { width: 100%; }
}


/* ═══════════════════════════════════════════════════════════
   고객 선택 상품 — 섹션 전폭 카드 레이아웃
═══════════════════════════════════════════════════════════ */
.custom-sec-grid {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

/* 카드 내 테이블 컬럼 너비 조정 */
.item-table .col-no    { width: 40px;  text-align: center; color: var(--sub); font-size: .78rem; }
.item-table .col-cat2  { width: 72px;  font-size: .8rem; color: var(--sub); }
.item-table .col-name  { min-width: 160px; white-space: normal; }
.item-table .col-price { width: 100px; text-align: right; }
.item-table .col-qty   { width: 96px;  text-align: center; }
.item-table .col-sub   { width: 100px; text-align: right; font-weight: 700; color: var(--primary); }
.item-table .col-act   { width: 34px;  text-align: center; }

/* 카드 하단 버튼 */
.card-bottom-actions {
  display: flex;
  gap: .75rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 1rem;
  padding-top: .85rem;
  border-top: 1px solid var(--border);
}
.btn-reset {
  padding: .5rem 1.1rem;
  background: transparent;
  color: var(--sub);
  border: 1.5px solid #ccc;
  border-radius: 7px;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.btn-reset:hover { border-color: var(--primary); color: var(--primary); }

/* 행 추가 패널 개선 */
.add-item-panel {
  background: #f0f9f4;
  border: 1.5px dashed #27ae60;
  border-radius: 10px;
  padding: 1rem 1.1rem;
  margin-bottom: .85rem;
}
.add-item-panel-title {
  font-size: .82rem;
  font-weight: 700;
  color: #1e8449;
  margin-bottom: .65rem;
}
.add-item-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: flex-end;
}
.ai-field {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  flex: 1;
  min-width: 80px;
}
.ai-label {
  font-size: .72rem;
  font-weight: 600;
  color: #555;
}
.ai-sel, .ai-inp {
  padding: .38rem .55rem;
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: .82rem;
  font-family: inherit;
  outline: none;
  transition: border-color .2s;
  width: 100%;
  height: 34px;
}
.ai-sel:focus, .ai-inp:focus { border-color: #27ae60; }
.add-item-btn {
  padding: 0 1rem;
  height: 34px;
  background: #27ae60;
  color: #fff;
  border: none;
  border-radius: 5px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .2s;
  align-self: flex-end;
}
.add-item-btn:hover { background: #1e8449; }

/* ═══════════════════════════════════════════════════════════
   커스텀 빌더 (나만의 상품 구성)
═══════════════════════════════════════════════════════════ */
.custom-builder-wrap {
  margin-top: 3rem;
  background: #fff;
  border: 2px solid #1a5276;
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 4px 24px rgba(26,82,118,.1);
}
.custom-builder-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: 1.25rem;
}
.custom-builder-title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: .2rem;
}
.custom-builder-sub {
  font-size: .88rem;
  color: var(--sub);
}

/* 빌더 입력 행 */
.builder-input-row {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: flex-end;
  background: #f5f9fd;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 1rem 1.1rem;
  margin-bottom: 1.25rem;
}
.bi-field {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  flex: 1;
  min-width: 90px;
}
.bi-field.bi-cat   { flex: 0 0 90px; }
.bi-field.bi-qty   { flex: 0 0 72px; }
.bi-field.bi-price { flex: 0 0 120px; }
.bi-field.bi-name  { flex: 2; min-width: 160px; }
.bi-field.bi-preset { flex: 2; min-width: 200px; }
.bi-field.bi-add   { flex: 0 0 auto; }
.bi-label {
  font-size: .73rem;
  font-weight: 600;
  color: #555;
}
.bi-sel, .bi-inp {
  padding: .42rem .65rem;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  font-size: .88rem;
  font-family: inherit;
  outline: none;
  height: 38px;
  transition: border-color .2s;
  width: 100%;
}
.bi-sel:focus, .bi-inp:focus { border-color: var(--primary); }
.builder-add-btn {
  height: 38px;
  padding: 0 1.2rem;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 7px;
  font-size: .88rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .2s;
}
.builder-add-btn:hover { background: #154360; }

/* 빌더 테이블 */
.builder-table-wrap {
  overflow-x: auto;
  border-radius: 10px;
  border: 1.5px solid var(--border);
  margin-bottom: 1.25rem;
}
.builder-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}
.builder-table th {
  background: var(--primary);
  color: #fff;
  padding: .6rem .85rem;
  text-align: left;
  white-space: nowrap;
}
.builder-table td {
  padding: .55rem .85rem;
  border-bottom: 1px solid #eef2f7;
  vertical-align: middle;
}
.builder-table tr:last-child td { border-bottom: none; }

.bt-no    { width: 46px;  text-align: center; color: var(--sub); }
.bt-cat   { width: 80px;  }
.bt-name  { min-width: 160px; white-space: normal; }
.bt-price { width: 110px; text-align: right; }
.bt-qty   { width: 100px; text-align: center; }
.bt-sub   { width: 110px; text-align: right; font-weight: 700; color: var(--primary); }
.bt-act   { width: 36px;  text-align: center; }

.builder-empty {
  text-align: center;
  color: #aaa;
  padding: 2.5rem;
  font-size: .9rem;
}

.builder-total-row td { background: #eaf2fb; border-top: 2px solid var(--primary); }
.builder-total-label {
  text-align: right;
  font-weight: 700;
  color: var(--primary);
  font-size: 1rem;
  padding-right: 1rem;
}
.builder-total-val {
  font-size: 1.35rem;
  font-weight: 900;
  color: var(--primary);
  text-align: right;
}

.builder-bottom {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}
.builder-note {
  font-size: .78rem;
  color: var(--sub);
}

/* 카테고리 소계 행 */
.cat-total-row td {
  background: #f0f7ff;
  font-weight: 700;
  padding: .35rem .85rem;
  border-top: 1px dashed var(--border);
}
.cat-total-label {
  text-align: right;
  color: #2c6fa8;
  font-size: .8rem;
  padding-right: 1rem;
}
.cat-total-val {
  text-align: right;
  color: #2c6fa8;
  font-size: .85rem;
}

/* 최종 합계 행 */
.total-row td { background: #dbeafe; border-top: 2.5px solid var(--primary); }
.total-label {
  text-align: right;
  font-weight: 700;
  color: var(--primary);
  font-size: .9rem;
  padding-right: 1rem;
}
.total-val {
  font-size: 1.15rem;
  font-weight: 900;
  color: var(--primary);
  text-align: right;
}

/* 홈 섹션 커스텀 그리드 — 기존 3열 유지 */
#home-custom-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.25rem;
}

@media(max-width:768px){
  .custom-builder-wrap { padding: 1.25rem; }
  .builder-input-row { padding: .75rem; }
  .bi-field.bi-cat,
  .bi-field.bi-qty,
  .bi-field.bi-price { flex: 1 1 45%; }
  .bi-field.bi-name,
  .bi-field.bi-preset { flex: 1 1 100%; }
  .builder-total-val { font-size: 1.1rem; }
}
