
:root {
  --accent:#2563eb; --accent-h:#1d4ed8; --accent-light:#eff6ff;
  --text:#1a1a2e; --muted:#666; --light:#f9f9f9; --border:#e5e7eb; --white:#fff; --dark:#1a1a2e;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:#fff;color:var(--text);font-family:'Noto Sans KR',sans-serif;overflow-x:hidden;word-break:keep-all;}

/* ── 페이지 전환 ── */
.page{display:none;}
.page.active{display:block;}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;width:100%;z-index:500;
  padding:0 40px;height:70px;
  display:flex;align-items:center;justify-content:space-between;
  background:transparent;transition:background .3s,box-shadow .3s;
}
nav.scrolled,nav.solid{background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--border);}
.logo{cursor:pointer;display:flex;align-items:center;}
.logo img{height:42px;}
.nav-links{display:flex;gap:24px;align-items:center;}
.nav-links a{font-size:15px;font-weight:500;color:rgba(255,255,255,.9);text-decoration:none;transition:color .2s;cursor:pointer;}
nav.scrolled .nav-links a, nav.solid .nav-links a{color:var(--text);}
.nav-links a:hover{color:var(--accent)!important;}
.has-sub{position:relative;}
.has-sub:hover .sub-menu{opacity:1;pointer-events:all;transform:translateY(0);}
.sub-menu{
  position:absolute;top:100%;left:0;min-width:140px;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  padding:8px 0;box-shadow:0 8px 24px rgba(0,0,0,.1);
  opacity:0;pointer-events:none;transform:translateY(-6px);
  transition:all .2s;z-index:100;
}
.sub-menu a{display:block;padding:9px 18px;font-size:14px;color:var(--text)!important;font-weight:400;}
.sub-menu a:hover{background:var(--accent-light);color:var(--accent)!important;}
.btn-primary{background:var(--accent)!important;color:#fff!important;padding:9px 22px;border-radius:30px;font-weight:700!important;transition:all .2s;}
.btn-primary:hover{background:var(--accent-h)!important;transform:translateY(-1px);box-shadow:0 5px 12px rgba(37,99,235,.35);}
.btn-dark{background:var(--dark)!important;color:#fff!important;padding:9px 22px;border-radius:30px;font-weight:700!important;transition:all .2s;}
.btn-dark:hover{background:#2f7a52!important;transform:translateY(-1px);}

/* ── 서브페이지 헤더 ── */
.sub-hero{
  margin-top:70px;height:260px;display:flex;align-items:center;justify-content:center;
  text-align:center;position:relative;overflow:hidden;
}
.sub-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.sub-hero-bg::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.55);}
.sub-hero-content{position:relative;z-index:1;}
.sub-hero-label{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:#93c5fd;font-weight:700;margin-bottom:10px;}
.sub-hero h2{font-size:36px;font-weight:900;color:#fff;}

/* ── 섹션 공통 ── */
.inner{width:90%;max-width:1200px;margin:0 auto;}
.sec-deco{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.deco-line{width:40px;height:1px;background:var(--accent);opacity:.5;}
.deco-dot{width:24px;height:8px;background:var(--accent);border-radius:2px;}
.sec-label{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:8px;}
.sec-title{font-size:clamp(28px,4vw,42px);font-weight:900;margin-bottom:12px;line-height:1.2;}
.sec-desc{color:var(--muted);font-size:15px;line-height:1.8;max-width:560px;}

/* ── FOOTER ── */
footer{background:#f9f9f9;padding:70px 40px 40px;}
.footer-wrap{max-width:1200px;margin:0 auto;display:flex;justify-content:space-around;flex-wrap:wrap;gap:40px;}
.footer-box{display:flex;flex-direction:column;}
.footer-box img{width:150px;margin-bottom:18px;}
.footer-box span{color:#333;font-size:14px;line-height:1.8;}
.footer-box h4{color:var(--accent);font-size:11px;font-weight:900;letter-spacing:.15em;text-transform:uppercase;margin-bottom:16px;}
.footer-phone{font-size:24px;font-weight:800;color:#333;text-decoration:none;}
.footer-phone:hover{color:var(--accent);}
.footer-bottom{max-width:1200px;margin:50px auto 0;padding-top:28px;border-top:1px solid var(--border);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);text-align:center;}

/* ════════════════════════════
   HOME
════════════════════════════ */
.hero{position:relative;height:100vh;min-height:680px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;overflow:hidden;}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.5s ease-in-out;}
.slide.active{opacity:1;}
.hero-bg::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.42) 0%,rgba(0,0,0,.62) 60%,rgba(0,0,0,.82) 100%);}
.slide-indicators{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3;}
.slide-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:all .3s;}
.slide-dot.active{background:#fff;width:24px;border-radius:4px;}
.hero-content{position:relative;z-index:2;padding:0 20px;width:100%;max-width:900px;}
.hero-label{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:#93c5fd;font-weight:700;margin-bottom:18px;opacity:0;animation:fadeUp .7s .2s ease forwards;}
.hero h1{font-size:clamp(40px,6vw,72px);font-weight:900;color:#fff;line-height:1.15;margin-bottom:16px;opacity:0;animation:fadeUp .7s .4s ease forwards;}
.hero-sub{font-size:16px;color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:44px;opacity:0;animation:fadeUp .7s .6s ease forwards;}

/* 검색창 */
.search-box{background:#fff;border-radius:80px;padding:12px 12px 12px 36px;display:flex;align-items:center;max-width:860px;width:100%;margin:0 auto;box-shadow:0 12px 50px rgba(0,0,0,.45);opacity:0;animation:fadeUp .7s .8s ease forwards;transition:box-shadow .3s;}
.search-box:focus-within{box-shadow:0 12px 50px rgba(37,99,235,.3),0 0 0 3px rgba(37,99,235,.25);}
.search-divider{width:1px;height:44px;background:#e5e7eb;flex-shrink:0;margin:0 4px;}
.search-field{flex:1;display:flex;flex-direction:column;padding:6px 20px;cursor:pointer;min-width:0;}
.search-field label{font-size:16px;font-weight:900;color:#111;letter-spacing:.03em;white-space:nowrap;margin-bottom:5px;}
.search-field input{border:none;outline:none;background:transparent;font-size:17px;color:#222;font-family:'Noto Sans KR',sans-serif;padding:0;width:100%;font-weight:500;}
.search-field input::placeholder{color:#bbb;font-size:16px;}
.search-field select{border:none;outline:none;background:transparent;font-size:17px;color:#222;font-family:'Noto Sans KR',sans-serif;padding:0;cursor:pointer;width:100%;appearance:none;-webkit-appearance:none;font-weight:500;}
.search-btn{background:var(--accent);color:white;border:none;cursor:pointer;width:68px;height:68px;border-radius:50%;font-size:26px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.search-btn:hover{background:var(--accent-h);transform:scale(1.06);}
.search-tags{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:22px;opacity:0;animation:fadeUp .7s 1s ease forwards;}
.search-tag{background:rgba(255,255,255,.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.35);color:#fff;font-size:14px;font-weight:600;padding:8px 20px;border-radius:30px;cursor:pointer;transition:all .2s;}
.search-tag:hover{background:rgba(255,255,255,.3);}

/* 홈 제품 섹션 */
.home-products{padding:100px 40px;max-width:1400px;margin:0 auto;}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;}

/* 겨울 섹션 */
.winter-sec{margin:0 40px 100px;background:var(--dark);border-radius:24px;overflow:hidden;display:flex;align-items:stretch;min-height:460px;}
.winter-sec-text{flex:1;padding:80px 60px;display:flex;flex-direction:column;justify-content:center;}
.winter-sec .sec-label{color:#93c5fd;}
.winter-sec .sec-title{color:#fff;}
.winter-sec .sec-desc{color:rgba(255,255,255,.6);margin-bottom:28px;}
.winter-cta{background:#fff;color:var(--dark);border:none;cursor:pointer;padding:14px 32px;border-radius:30px;font-family:'Noto Sans KR',sans-serif;font-size:15px;font-weight:700;transition:all .2s;width:fit-content;}
.winter-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,255,255,.2);}
.winter-img{flex:1;min-height:400px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a2a4a,#0d1f3c);padding:40px;}
.winter-img img{width:100%;max-width:420px;height:100%;max-height:380px;object-fit:contain;filter:drop-shadow(0 20px 60px rgba(37,99,235,.4));transition:transform .4s;}
.winter-img:hover img{transform:scale(1.04);}
/* 포트폴리오 섹션 */
.portfolio-sec{padding:80px 40px;max-width:1400px;margin:0 auto;}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;}
.portfolio-card{border-radius:16px;overflow:hidden;position:relative;cursor:pointer;aspect-ratio:4/3;}
.portfolio-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.portfolio-card:hover img{transform:scale(1.06);}
.portfolio-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);display:flex;align-items:flex-end;padding:20px;opacity:0;transition:opacity .3s;}
.portfolio-card:hover .portfolio-overlay{opacity:1;}
.portfolio-overlay span{color:#fff;font-size:14px;font-weight:700;}
.portfolio-view-all{display:inline-flex;align-items:center;gap:8px;margin-top:32px;background:var(--dark);color:#fff;border:none;padding:14px 32px;border-radius:30px;cursor:pointer;font-family:'Noto Sans KR',sans-serif;font-size:14px;font-weight:700;transition:all .2s;}
.portfolio-view-all:hover{background:var(--accent);transform:translateY(-2px);}

/* 안내 */
.notice-sec{margin:0 40px 80px;background:var(--light);border:1px solid var(--border);border-radius:16px;padding:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:40px;}
.notice-item h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:10px;}
.notice-item p{font-size:14px;color:var(--muted);line-height:1.8;}
.notice-item strong{color:var(--text);}

/* ── 검색 결과 오버레이 ── */
#searchOverlay{display:none;position:fixed;inset:0;z-index:600;background:rgba(255,255,255,.98);backdrop-filter:blur(8px);overflow-y:auto;padding:90px 40px 60px;}
#searchOverlay.active{display:block;}
.overlay-header{max-width:1200px;margin:0 auto 28px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:20px;}
.overlay-header h2{font-size:24px;font-weight:700;} .overlay-header h2 span{color:var(--accent);}
.close-btn{background:var(--light);border:1px solid var(--border);color:var(--text);width:42px;height:42px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.close-btn:hover{background:var(--border);}
.overlay-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;}
.no-result{text-align:center;padding:80px 20px;max-width:1200px;margin:0 auto;}
.no-result p{font-size:18px;color:var(--muted);margin-bottom:8px;}
.no-result span{font-size:13px;color:var(--muted);}

/* ── 제품 카드 ── */
.r-card{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:all .3s;cursor:pointer;animation:fadeUp .4s ease both;}
.r-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 32px rgba(37,99,235,.15);}

/* 제이드플래닝 카드 스타일 */
.jade-card { border-color: #d1fae5; }
.jade-card:hover { border-color: #10b981; box-shadow: 0 12px 32px rgba(16,185,129,.15); }
.jade-badge { background: #10b981 !important; }
.jade-spec { color: #10b981 !important; }
.jade-link-btn {
  display: inline-block;
  background: #10b981;
  color: #fff;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: all .2s;
  font-family: 'Noto Sans KR', sans-serif;
}
.jade-link-btn:hover { background: #059669; transform: translateY(-1px); }
.r-card-img{background:linear-gradient(135deg,#f8faff,#eff6ff);height:160px;display:flex;align-items:center;justify-content:center;position:relative;}
.r-card-img img{max-height:120px;max-width:75%;object-fit:contain;transition:transform .3s;filter:drop-shadow(0 4px 10px rgba(0,0,0,.12));}
.r-card:hover .r-card-img img{transform:scale(1.06);}
.r-badge{position:absolute;top:10px;left:10px;background:var(--accent);color:white;font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;}
.r-card-body{padding:18px;}
.r-size{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:4px;}
.r-name{font-size:17px;font-weight:700;color:var(--text);margin-bottom:4px;}
.r-desc{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:14px;}
.r-specs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;}
.r-spec{background:var(--light);border:1px solid var(--border);border-radius:6px;padding:3px 9px;font-size:11px;color:var(--muted);}
.r-price{display:flex;align-items:baseline;gap:4px;}
.r-price-label{font-size:11px;color:var(--muted);}
.r-price-amount{font-size:20px;font-weight:900;color:var(--accent);}
.r-price-unit{font-size:11px;color:var(--muted);}

/* ════════════════════════════
   장바구니
════════════════════════════ */
/* 네비 장바구니 버튼 */
.cart-nav-btn {
  position: relative;
  background: var(--surface, #f3f4f6);
  border: 1.5px solid var(--border);
  color: var(--text);
  width: 42px; height: 42px;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
  flex-shrink: 0;
}
nav.scrolled .cart-nav-btn, nav.solid .cart-nav-btn { background: #f3f4f6; }
.cart-nav-btn:not(nav.scrolled *) { background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.3); color: #fff; }
.cart-nav-btn:hover { background: var(--accent); border-color: var(--accent); color: #fff; transform: scale(1.08); }
#cartCount {
  position: absolute; top: -5px; right: -5px;
  background: #ef4444; color: #fff;
  width: 18px; height: 18px; border-radius: 50%;
  font-size: 10px; font-weight: 800;
  display: flex !important; align-items: center; justify-content: center;
  font-family: 'Noto Sans KR', sans-serif;
  border: 2px solid #fff;
}

/* 상품 상세/수량 모달 */
#productModal {
  display: none; position: fixed; inset: 0; z-index: 700;
  background: rgba(0,0,0,.5); backdrop-filter: blur(4px);
  align-items: center; justify-content: center; padding: 20px;
}
#productModal.active { display: flex; }
.modal-box {
  background: #fff; border-radius: 20px;
  width: 100%; max-width: 480px;
  box-shadow: 0 24px 60px rgba(0,0,0,.2);
  overflow: hidden; animation: fadeUp .3s ease;
}
.modal-img { height: 220px; background: linear-gradient(135deg,#f8faff,#eff6ff); display: flex; align-items: center; justify-content: center; position: relative; }
.modal-img img { max-height: 180px; max-width: 80%; object-fit: contain; filter: drop-shadow(0 4px 12px rgba(0,0,0,.12)); }
.modal-img .modal-badge { position: absolute; top: 12px; left: 12px; background: var(--accent); color: #fff; font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: 20px; }
.modal-img .modal-badge.jade { background: #10b981; }
.modal-body { padding: 24px; }
.modal-cat { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); font-weight: 700; margin-bottom: 6px; }
.modal-name { font-size: 20px; font-weight: 800; color: var(--text); margin-bottom: 8px; }
.modal-desc { font-size: 14px; color: var(--muted); line-height: 1.7; margin-bottom: 20px; }
.modal-divider { height: 1px; background: var(--border); margin-bottom: 20px; }

/* 수량 */
.modal-label { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.qty-wrap { display: flex; align-items: center; gap: 0; border: 1.5px solid var(--border); border-radius: 10px; overflow: hidden; width: fit-content; margin-bottom: 16px; }
.qty-btn { background: var(--light); border: none; width: 40px; height: 40px; font-size: 18px; cursor: pointer; transition: background .2s; color: var(--text); font-family: 'Noto Sans KR', sans-serif; }
.qty-btn:hover { background: var(--accent); color: #fff; }
.qty-input { border: none; outline: none; width: 52px; height: 40px; text-align: center; font-size: 16px; font-weight: 700; font-family: 'Noto Sans KR', sans-serif; color: var(--text); }

/* 날짜 */
.date-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 20px; }
.date-group label { display: block; font-size: 12px; font-weight: 700; color: var(--muted); margin-bottom: 6px; }
.date-group input { width: 100%; padding: 10px 12px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 14px; font-family: 'Noto Sans KR', sans-serif; outline: none; color: var(--text); }
.date-group input:focus { border-color: var(--accent); }

/* 모달 버튼 */
.modal-actions { display: flex; gap: 10px; }
.modal-cart-btn { flex: 1; background: var(--accent); color: #fff; border: none; padding: 14px; border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer; font-family: 'Noto Sans KR', sans-serif; transition: all .2s; }
.modal-cart-btn:hover { background: var(--accent-h); transform: translateY(-1px); }
.modal-close-btn { background: var(--light); color: var(--text); border: 1.5px solid var(--border); padding: 14px 20px; border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer; font-family: 'Noto Sans KR', sans-serif; transition: all .2s; }
.modal-close-btn:hover { background: var(--border); }

/* 장바구니 사이드패널 */
#cartPanel {
  position: fixed; top: 0; right: -420px; width: 400px; height: 100vh;
  background: #fff; z-index: 800;
  box-shadow: -8px 0 40px rgba(0,0,0,.15);
  display: flex; flex-direction: column;
  transition: right .35s cubic-bezier(.4,0,.2,1);
}
#cartPanel.open { right: 0; }
#cartOverlay { display: none; position: fixed; inset: 0; z-index: 799; background: rgba(0,0,0,.3); backdrop-filter: blur(2px); }
#cartOverlay.active { display: block; }

.cart-header { padding: 20px 24px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
.cart-header h3 { font-size: 18px; font-weight: 800; color: var(--text); display: flex; align-items: center; gap: 8px; }
.cart-header h3 svg { color: var(--accent); }
.cart-close { background: var(--light); border: 1px solid var(--border); width: 36px; height: 36px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 16px; transition: all .2s; }
.cart-close:hover { background: var(--border); }

.cart-items { flex: 1; overflow-y: auto; padding: 16px; }
.cart-items::-webkit-scrollbar { width: 4px; }
.cart-items::-webkit-scrollbar-thumb { background: #ddd; border-radius: 2px; }
.cart-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; gap: 12px; color: var(--muted); }
.cart-empty svg { opacity: .3; }
.cart-empty p { font-size: 15px; }

.cart-item { display: flex; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--border); animation: fadeUp .3s ease; }
.cart-item-img { width: 64px; height: 64px; border-radius: 10px; background: linear-gradient(135deg,#f8faff,#eff6ff); display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
.cart-item-img img { width: 100%; height: 100%; object-fit: contain; }
.cart-item-info { flex: 1; min-width: 0; }
.cart-item-name { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cart-item-date { font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.cart-item-qty { font-size: 12px; color: var(--accent); font-weight: 700; }
.cart-item-del { background: none; border: none; cursor: pointer; color: #ccc; font-size: 16px; padding: 4px; transition: color .2s; flex-shrink: 0; }
.cart-item-del:hover { color: #ef4444; }

.cart-footer { padding: 16px 24px; border-top: 1px solid var(--border); flex-shrink: 0; }
.cart-summary { font-size: 13px; color: var(--muted); margin-bottom: 12px; text-align: center; }
.cart-summary strong { color: var(--accent); font-size: 15px; }
.cart-inquiry-btn { width: 100%; background: var(--accent); color: #fff; border: none; padding: 16px; border-radius: 12px; font-size: 16px; font-weight: 700; cursor: pointer; font-family: 'Noto Sans KR', sans-serif; transition: all .2s; display: flex; align-items: center; justify-content: center; gap: 8px; }
.cart-inquiry-btn:hover { background: var(--accent-h); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(37,99,235,.35); }
.cart-clear-btn { width: 100%; background: none; border: 1px solid var(--border); color: var(--muted); padding: 10px; border-radius: 10px; font-size: 13px; cursor: pointer; font-family: 'Noto Sans KR', sans-serif; margin-top: 8px; transition: all .2s; }
.cart-clear-btn:hover { background: #fef2f2; border-color: #ef4444; color: #ef4444; }

/* 담기 성공 토스트 */
#cartToast {
  position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%) translateY(80px);
  background: #1a1a2e; color: #fff;
  padding: 12px 24px; border-radius: 30px;
  font-size: 14px; font-weight: 600;
  font-family: 'Noto Sans KR', sans-serif;
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
  z-index: 9999; transition: transform .3s ease;
  white-space: nowrap;
}
#cartToast.show { transform: translateX(-50%) translateY(0); }

/* r-card 클릭 커서 */
.r-card { cursor: pointer; }

@media(max-width:480px) {
  #cartPanel { width: 100%; right: -100%; }
  .modal-box { margin: 0; border-radius: 16px; }
}

/* ─────────────────── */
════════════════════════════ */
.vision-section { background: #fff; }

/* 슬로건 */
.vision-headline {
  text-align: center;
  padding: 80px 40px 60px;
  background: linear-gradient(180deg, #f8faff 0%, #fff 100%);
}
.vision-main-title {
  font-size: clamp(32px, 4.5vw, 52px);
  font-weight: 900;
  color: var(--text);
  line-height: 1.25;
  margin: 12px 0 20px;
  letter-spacing: -.01em;
}
.vision-main-title::before {
  content: '';
  display: block;
  width: 40px; height: 3px;
  background: var(--accent);
  margin: 0 auto 20px;
  border-radius: 2px;
}
.vision-main-desc {
  font-size: 17px;
  color: var(--muted);
  line-height: 1.9;
}

/* 3대 핵심 가치 카드 */
.vision-values {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 0 40px 80px;
  max-width: 1200px;
  margin: 0 auto;
}
.vision-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  padding: 36px 28px;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}
.vision-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s;
}
.vision-card:hover {
  border-color: var(--accent);
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(37,99,235,.12);
}
.vision-card:hover::before { transform: scaleX(1); }
.vision-icon {
  width: 56px;
  height: 56px;
  margin-bottom: 20px;
  display: block;
}
.vision-icon svg {
  width: 56px;
  height: 56px;
}
.vision-card-label {
  font-size: 10px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 700;
  margin-bottom: 10px;
}
.vision-card-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 14px;
}
.vision-card-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.85;
}

/* 미션 배너 */
.vision-mission {
  background: var(--dark);
  margin: 0;
  padding: 80px 40px;
}
.vision-mission-inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}
.vision-mission-label {
  font-size: 11px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: #93c5fd;
  font-weight: 700;
  margin-bottom: 16px;
}
.vision-mission-title {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 900;
  color: #fff;
  margin-bottom: 20px;
  line-height: 1.2;
}
.vision-mission-desc {
  font-size: 16px;
  color: rgba(255,255,255,.7);
  line-height: 2;
  margin-bottom: 52px;
}
.vision-mission-desc strong { color: #fff; font-weight: 700; }

/* 통계 */
.vision-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}
.v-stat { text-align: center; padding: 0 40px; }
.v-stat-num {
  font-size: 40px;
  font-weight: 900;
  color: #60a5fa;
  line-height: 1;
  margin-bottom: 8px;
  font-family: 'Noto Sans KR', sans-serif;
}
.v-stat-label {
  font-size: 13px;
  color: rgba(255,255,255,.6);
  font-weight: 500;
  letter-spacing: .05em;
}
.v-stat-divider {
  width: 1px;
  height: 48px;
  background: rgba(255,255,255,.15);
  flex-shrink: 0;
}

@media(max-width:768px) {
  .vision-values { grid-template-columns: 1fr; padding: 0 20px 60px; }
  .vision-headline { padding: 60px 20px 40px; }
  .vision-mission { padding: 60px 20px; }
  .v-stat { padding: 0 20px; }
  .v-stat-num { font-size: 30px; }
  .vision-stats { gap: 16px; }
  .v-stat-divider { display: none; }
}

/* ════════════════════════════
   회사소개 - 인사말
════════════════════════════ */
.greet-section{padding:80px 40px;}
.greet-inner{max-width:900px;margin:0 auto;display:flex;gap:60px;align-items:flex-start;}
.greet-img{flex-shrink:0;}
.greet-img img{width:280px;border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.1);}
.greet-text .sec-title{margin-bottom:24px;}
.greet-text p{font-size:16px;color:#444;line-height:2;margin-bottom:20px;}
.greet-sig{font-size:18px;font-weight:700;color:var(--text);margin-top:32px;padding-top:24px;border-top:1px solid var(--border);}

/* ════════════════════════════
   연혁
════════════════════════════ */
.history-section{padding:80px 40px;}
.timeline{max-width:900px;margin:0 auto;}
.timeline-year{margin-bottom:48px;}
.year-label{font-size:32px;font-weight:900;color:var(--accent);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--accent-light);}
.timeline-item{display:flex;gap:24px;padding:12px 0;border-bottom:1px solid var(--border);}
.t-date{font-size:13px;font-weight:700;color:var(--muted);min-width:60px;padding-top:2px;}
.t-content{font-size:15px;color:var(--text);line-height:1.6;}

/* ════════════════════════════
   오시는길
════════════════════════════ */
.map-section{padding:80px 40px;}
.map-wrap{max-width:900px;margin:0 auto;}
.map-box{background:#f0f4ff;border:1px solid var(--border);border-radius:16px;height:400px;display:flex;align-items:center;justify-content:center;margin-bottom:40px;overflow:hidden;}
.map-box iframe{width:100%;height:100%;border:0;}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.info-card{background:var(--light);border:1px solid var(--border);border-radius:12px;padding:24px;}
.info-card h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:12px;}
.info-card p{font-size:15px;color:var(--text);line-height:1.8;}
.info-card a{color:var(--text);text-decoration:none;font-weight:700;font-size:20px;}
.info-card a:hover{color:var(--accent);}

/* ════════════════════════════
   렌탈안내
════════════════════════════ */
.rental-guide{padding:80px 40px;}
.steps{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:0;}
.step{display:flex;gap:32px;padding:40px 0;border-bottom:1px solid var(--border);position:relative;}
.step:last-child{border-bottom:none;}
.step-num{font-size:56px;font-weight:900;color:var(--accent-light);line-height:1;flex-shrink:0;width:80px;text-align:center;}
.step-body h3{font-size:22px;font-weight:700;margin-bottom:12px;color:var(--text);}
.step-body p{font-size:15px;color:var(--muted);line-height:1.8;}
.step-icon{font-size:36px;margin-bottom:8px;}

/* ════════════════════════════
   렌탈제품
════════════════════════════ */
.products-page{padding:60px 40px 80px;}
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;justify-content:center;}
.filter-btn{background:#fff;border:1.5px solid var(--border);color:var(--muted);padding:9px 22px;border-radius:30px;cursor:pointer;font-family:'Noto Sans KR',sans-serif;font-size:14px;font-weight:500;transition:all .2s;}
.filter-btn:hover,.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;}
.search-result-msg{text-align:center;padding:0 0 20px;font-size:14px;color:var(--accent);display:none;}
.search-result-msg.visible{display:block;}

/* ════════════════════════════
   FAQ
════════════════════════════ */
.faq-section{padding:80px 40px;}
.faq-list{max-width:860px;margin:0 auto;}
.faq-item{border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden;}
.faq-q{padding:20px 24px;font-size:16px;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s;}
.faq-q:hover{background:var(--accent-light);}
.faq-q.open{background:var(--accent);color:#fff;}
.faq-q .arrow{font-size:12px;transition:transform .3s;}
.faq-q.open .arrow{transform:rotate(180deg);}
.faq-a{display:none;padding:20px 24px;font-size:15px;color:var(--muted);line-height:1.9;background:#fafcff;border-top:1px solid var(--border);}
.faq-a.open{display:block;}

/* ════════════════════════════
   견적문의
════════════════════════════ */
.inquiry-section{padding:80px 40px;}
.inquiry-wrap{max-width:700px;margin:0 auto;}
.form-group{margin-bottom:20px;}
.form-group label{display:block;font-size:14px;font-weight:700;color:var(--text);margin-bottom:8px;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 18px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;font-family:'Noto Sans KR',sans-serif;outline:none;transition:border .2s;background:#fff;}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.form-group textarea{resize:vertical;min-height:140px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.submit-btn{width:100%;background:var(--accent);color:#fff;border:none;padding:16px;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;font-family:'Noto Sans KR',sans-serif;transition:all .2s;margin-top:8px;}
.submit-btn:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.35);}
.inquiry-info{margin-top:48px;background:var(--light);border-radius:12px;padding:28px;display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.inq-info-item h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:8px;}
.inq-info-item p,.inq-info-item a{font-size:15px;color:var(--text);text-decoration:none;}

/* ════════════════════════════
   갤러리
════════════════════════════ */
/* ── 갤러리 ── */
.gallery-section{padding:60px 40px 80px;}
.gallery-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px;}
.gf-btn{background:#fff;border:1.5px solid var(--border);color:var(--muted);padding:8px 20px;border-radius:30px;cursor:pointer;font-family:'Noto Sans KR',sans-serif;font-size:13px;font-weight:500;transition:all .2s;}
.gf-btn:hover,.gf-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;}
.gallery-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.gallery-card{border-radius:16px;overflow:hidden;background:#fff;border:1px solid var(--border);transition:all .3s;cursor:pointer;}
.gallery-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.12);border-color:var(--accent);}
.gallery-thumb{height:220px;overflow:hidden;position:relative;background:#f1f5f9;}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.gallery-card:hover .gallery-thumb img{transform:scale(1.06);}
.gallery-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#dbeafe);}
.gallery-thumb-placeholder svg{opacity:0.35;}
.gallery-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:4px 10px;border-radius:20px;letter-spacing:.08em;}
.gallery-info{padding:20px;}
.gallery-info h4{font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.4;}
.gallery-info p{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.gallery-meta{display:flex;align-items:center;justify-content:space-between;}
.gallery-date{font-size:12px;color:var(--muted);}
.gallery-more{font-size:12px;font-weight:700;color:var(--accent);}
/* 상세보기 */
.gallery-detail{display:none;max-width:900px;margin:0 auto;}
.gallery-detail.active{display:block;}
.gallery-list-view{display:block;}
.gallery-list-view.hidden{display:none;}
.detail-back{display:inline-flex;align-items:center;gap:8px;background:var(--light);border:1px solid var(--border);color:var(--text);padding:10px 20px;border-radius:30px;cursor:pointer;font-family:'Noto Sans KR',sans-serif;font-size:14px;font-weight:600;margin-bottom:32px;transition:all .2s;}
.detail-back:hover{background:var(--accent);border-color:var(--accent);color:#fff;}
.detail-header{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--border);}
.detail-category{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:8px;}
.detail-title{font-size:28px;font-weight:800;color:var(--text);margin-bottom:12px;line-height:1.3;}
.detail-meta{font-size:13px;color:var(--muted);}
.detail-img-wrap{border-radius:12px;overflow:hidden;margin-bottom:28px;background:#f1f5f9;}
.detail-img-wrap img{width:100%;display:block;}
.detail-img-placeholder{height:400px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#dbeafe);}
.detail-body{font-size:16px;color:#444;line-height:2;margin-bottom:40px;}
.detail-nav{display:flex;justify-content:space-between;padding-top:24px;border-top:1px solid var(--border);}
.detail-nav-btn{display:flex;flex-direction:column;gap:4px;cursor:pointer;padding:12px 0;}
.detail-nav-btn:last-child{text-align:right;}
.detail-nav-label{font-size:11px;color:var(--muted);letter-spacing:.1em;}
.detail-nav-title{font-size:14px;font-weight:700;color:var(--accent);}
.detail-nav-title:hover{text-decoration:underline;}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* ════════════════════════════
   공지사항 (원본 사이트 스타일)
════════════════════════════ */
.notice-board-section { padding: 48px 40px 80px; }
.notice-board-wrap { max-width: 960px; margin: 0 auto; }

/* 게시판 타이틀 바 */
.notice-board-title {
  background: var(--dark);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  padding: 12px 18px;
  letter-spacing: .04em;
  border-radius: 4px 4px 0 0;
}

/* 검색 폼 - 원본처럼 테이블 위에 배치 */
.notice-search-form {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  padding: 16px 0 20px;
  border-bottom: 2px solid var(--dark);
}
.notice-search-form select {
  padding: 8px 10px;
  border: 1px solid #ccc;
  border-right: none;
  font-size: 13px;
  font-family: 'Noto Sans KR', sans-serif;
  outline: none;
  color: var(--text);
  background: #f9f9f9;
  cursor: pointer;
  height: 36px;
}
.notice-search-form input {
  padding: 8px 12px;
  border: 1px solid #ccc;
  font-size: 13px;
  font-family: 'Noto Sans KR', sans-serif;
  outline: none;
  color: var(--text);
  width: 220px;
  height: 36px;
}
.notice-search-form input:focus { border-color: var(--accent); }
.notice-search-form button {
  background: var(--dark);
  color: #fff;
  border: none;
  padding: 0 18px;
  height: 36px;
  font-size: 13px;
  font-weight: 700;
  font-family: 'Noto Sans KR', sans-serif;
  cursor: pointer;
  transition: background .2s;
  white-space: nowrap;
}
.notice-search-form button:hover { background: var(--accent); }

/* 테이블 - 원본처럼 전체 테두리 */
.notice-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #d0d0d0;
  font-size: 14px;
}
.notice-table thead tr { background: #f2f2f2; }
.notice-table thead th {
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 700;
  color: #333;
  text-align: center;
  border: 1px solid #d0d0d0;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
}
.notice-table thead th:nth-child(2) { text-align: center; }
.notice-table thead th:hover { background: #e8e8e8; color: var(--accent); }
.notice-table tbody tr {
  border-bottom: 1px solid #e0e0e0;
  transition: background .12s;
  cursor: pointer;
}
.notice-table tbody tr:hover { background: #f0f6ff; }
.notice-table tbody td {
  padding: 13px 14px;
  font-size: 14px;
  color: #333;
  text-align: center;
  border: 1px solid #e8e8e8;
}
.notice-table tbody td:nth-child(2) {
  text-align: left;
  color: var(--text);
}
.notice-table tbody td.notice-pin-cell {
  font-size: 12px;
  font-weight: 700;
  color: #fff;
}
.notice-pin-badge {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 3px;
  letter-spacing: .05em;
}
.notice-table tbody tr.pinned-row { background: #f7fbff; }
.notice-table tbody tr.pinned-row:hover { background: #e8f2ff; }
.notice-title-link {
  color: var(--text);
  text-decoration: none;
  font-weight: 500;
}
.notice-title-link:hover { color: var(--accent); text-decoration: underline; }

/* 페이지네이션 - 원본처럼 텍스트 링크 스타일 */
.notice-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  margin-top: 24px;
  border: 1px solid #d0d0d0;
}
.pg-btn {
  min-width: 40px;
  height: 38px;
  padding: 0 14px;
  border: none;
  border-right: 1px solid #d0d0d0;
  background: #fff;
  color: #555;
  font-size: 13px;
  font-weight: 500;
  font-family: 'Noto Sans KR', sans-serif;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.pg-btn:last-child { border-right: none; }
.pg-btn:hover { background: var(--accent-light); color: var(--accent); }
.pg-btn.active { background: var(--accent); color: #fff; font-weight: 700; }
.pg-btn:disabled { color: #bbb; cursor: default; background: #fafafa; }

/* 상세보기 */
.notice-detail { display: none; }
.notice-detail.active { display: block; }
.notice-list-view.hidden { display: none; }

.notice-detail-header {
  border-top: 2px solid var(--dark);
  border-bottom: 1px solid #d0d0d0;
  padding: 20px 18px;
  background: #fafafa;
  margin-bottom: 0;
}
.notice-detail-pin {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 3px;
  margin-bottom: 10px;
  letter-spacing: .05em;
}
.notice-detail-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
  line-height: 1.5;
}
.notice-detail-meta {
  display: flex;
  gap: 24px;
  font-size: 13px;
  color: var(--muted);
  flex-wrap: wrap;
}
.notice-detail-body {
  font-size: 15px;
  color: #444;
  line-height: 2;
  padding: 32px 18px 40px;
  min-height: 200px;
  border-bottom: 1px solid #d0d0d0;
}

/* 이전글/다음글 테이블 */
.notice-detail-nav-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #d0d0d0;
  margin: 20px 0 28px;
  font-size: 14px;
}
.notice-detail-nav-table td {
  padding: 12px 16px;
  border-bottom: 1px solid #e8e8e8;
  color: #555;
}
.notice-detail-nav-table td:first-child {
  width: 80px;
  font-weight: 700;
  color: var(--muted);
  background: #f9f9f9;
  text-align: center;
  border-right: 1px solid #d0d0d0;
  font-size: 12px;
}
.notice-detail-nav-table tr:last-child td { border-bottom: none; }
.nd-nav-title {
  cursor: pointer;
  color: var(--text);
}
.nd-nav-title:hover { color: var(--accent); text-decoration: underline; }
.nd-nav-none { color: #bbb; font-style: italic; }

/* 목록 버튼 */
.notice-list-btn {
  display: flex;
  justify-content: center;
  margin-top: 8px;
}
.notice-list-btn button {
  background: var(--dark);
  color: #fff;
  border: none;
  padding: 11px 36px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 700;
  font-family: 'Noto Sans KR', sans-serif;
  cursor: pointer;
  transition: background .2s;
}
.notice-list-btn button:hover { background: var(--accent); }

/* 망보드 크레딧 */
.notice-powered {
  text-align: center;
  font-size: 11px;
  color: #bbb;
  margin-top: 20px;
}
.notice-powered a { color: #bbb; text-decoration: none; }
.notice-powered a:hover { color: var(--accent); }

@media(max-width:768px){
  .notice-board-section { padding: 32px 16px 60px; }
  .notice-search-form { flex-wrap: wrap; gap: 4px; }
  .notice-search-form input { width: 140px; }
  .notice-table thead th:nth-child(3),
  .notice-table tbody td:nth-child(3),
  .notice-table thead th:nth-child(5),
  .notice-table tbody td:nth-child(5) { display: none; }
  .notice-detail-meta { gap: 12px; }
}

/* ── 반응형 ── */
@media(max-width:768px){
  nav{padding:0 16px;}
  .nav-links{display:none;}
  .search-box{flex-direction:column;border-radius:20px;padding:16px;gap:10px;}
  .search-divider{display:none;}
  .search-field{padding:4px 8px;}
  .search-btn{width:100%;border-radius:12px;height:48px;}
  .home-products,.winter-sec,.notice-sec{padding:60px 20px;margin:0 0 40px;}
  .winter-sec{flex-direction:column;padding:40px 20px;margin:0 20px 40px;}
  .notice-sec{grid-template-columns:1fr;padding:28px;margin:0 20px 40px;}
  .greet-inner{flex-direction:column;}
  .greet-img img{width:100%;}
  .info-grid,.form-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:1fr 1fr;} .gallery-section{padding:40px 20px 60px;}
  .portfolio-grid{grid-template-columns:1fr;}
  .portfolio-sec{padding:60px 20px;}
  .winter-sec{flex-direction:column;min-height:auto;}
  .winter-sec-text{padding:50px 30px 30px;}
  .winter-img{min-height:280px;padding:20px;}
  footer{padding:50px 20px 30px;}
}


/* ============================
   style block 2
   ============================ */


/* 챗봇 토글 버튼 */
#chatToggle {
  position: fixed;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 9000;
  width: 64px;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 0;
  transition: all .3s;
  filter: drop-shadow(0 4px 12px rgba(37,99,235,.5));
}
#chatToggle:hover {
  transform: translateY(-50%) scale(1.08);
  filter: drop-shadow(0 6px 18px rgba(37,99,235,.65));
}
#chatToggle .chat-icon { display:flex; align-items:center; justify-content:center; }
#chatToggle .chat-label {
  font-size: 12px;
  font-family: 'Noto Sans KR', sans-serif;
  font-weight: 800;
  color: #fff;
  letter-spacing: .05em;
  background: var(--accent);
  padding: 5px 12px;
  border-radius: 20px;
  box-shadow: 0 2px 10px rgba(37,99,235,.5);
  white-space: nowrap;
  margin-top: 2px;
}
/* 알림 뱃지 */
#chatBadge {
  position: absolute;
  top: -4px; right: -4px;
  width: 18px; height: 18px;
  background: #ef4444;
  border-radius: 50%;
  border: 2px solid #fff;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Noto Sans KR', sans-serif;
  animation: badgePulse 2s infinite;
}
@keyframes badgePulse {
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.2);}
}

/* 챗봇 창 */
#chatWindow {
  position: fixed;
  right: 92px;
  top: 50%;
  transform: translateY(-50%) scale(.92);
  transform-origin: right center;
  z-index: 8999;
  width: 360px;
  max-height: 560px;
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 12px 48px rgba(0,0,0,.18);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transition: all .3s cubic-bezier(.34,1.56,.64,1);
}
#chatWindow.open {
  opacity: 1;
  pointer-events: all;
  transform: translateY(-50%) scale(1);
}

/* 챗봇 헤더 */
.chat-header {
  background: var(--accent);
  padding: 16px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.chat-avatar {
  width: 42px; height: 42px;
  background: rgba(255,255,255,.2);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.chat-header-info { flex: 1; }
.chat-header-name {
  font-size: 15px; font-weight: 800; color: #fff;
  font-family: 'Noto Sans KR', sans-serif;
}
.chat-header-status {
  font-size: 11px; color: rgba(255,255,255,.8);
  font-family: 'Noto Sans KR', sans-serif;
  display: flex; align-items: center; gap: 4px;
}
.status-dot {
  width: 6px; height: 6px;
  background: #4ade80;
  border-radius: 50%;
  animation: blink 2s infinite;
}
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:.4;} }
.chat-close {
  background: rgba(255,255,255,.2);
  border: none; cursor: pointer;
  color: #fff; font-size: 16px;
  width: 30px; height: 30px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.chat-close:hover { background: rgba(255,255,255,.35); }

/* 메시지 영역 */
.chat-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: #f8faff;
}
.chat-body::-webkit-scrollbar { width: 4px; }
.chat-body::-webkit-scrollbar-track { background: transparent; }
.chat-body::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 2px; }

/* 말풍선 */
.msg { display: flex; gap: 8px; align-items: flex-end; animation: msgIn .3s ease; }
@keyframes msgIn { from{opacity:0;transform:translateY(8px);} to{opacity:1;transform:translateY(0);} }
.msg.bot { justify-content: flex-start; }
.msg.user { justify-content: flex-end; }
.msg-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.bubble {
  max-width: 75%;
  padding: 10px 14px;
  border-radius: 16px;
  font-size: 13.5px;
  font-family: 'Noto Sans KR', sans-serif;
  line-height: 1.6;
}
.msg.bot .bubble {
  background: #fff;
  color: #222;
  border-bottom-left-radius: 4px;
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.msg.user .bubble {
  background: var(--accent);
  color: #fff;
  border-bottom-right-radius: 4px;
}

/* 타이핑 인디케이터 */
.typing { display: flex; gap: 4px; padding: 12px 14px; }
.typing span {
  width: 7px; height: 7px; border-radius: 50%;
  background: #aaa; display: inline-block;
  animation: typingDot 1.2s infinite;
}
.typing span:nth-child(2){animation-delay:.2s;}
.typing span:nth-child(3){animation-delay:.4s;}
@keyframes typingDot { 0%,80%,100%{transform:scale(.8);opacity:.5;} 40%{transform:scale(1.1);opacity:1;} }

/* 버튼 선택지 */
.chat-options {
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 4px 0;
}
.opt-btn {
  background: #fff;
  border: 1.5px solid var(--border);
  color: var(--text);
  padding: 9px 14px;
  border-radius: 12px;
  font-size: 13px;
  font-family: 'Noto Sans KR', sans-serif;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  transition: all .18s;
  display: flex;
  align-items: center;
  gap: 8px;
}
.opt-btn:hover {
  background: var(--accent-light);
  border-color: var(--accent);
  color: var(--accent);
}
.opt-btn .opt-icon { font-size: 16px; }

/* 견적문의 버튼 */
.inquiry-btn {
  background: var(--accent);
  color: #fff !important;
  border-color: var(--accent) !important;
  font-weight: 700 !important;
}
.inquiry-btn:hover {
  background: var(--accent-h) !important;
  color: #fff !important;
}

/* 처음으로 버튼 */
.reset-btn {
  background: #f3f4f6;
  border: 1.5px solid #e5e7eb;
  color: #666;
  padding: 8px 14px;
  border-radius: 10px;
  font-size: 12px;
  font-family: 'Noto Sans KR', sans-serif;
  cursor: pointer;
  width: 100%;
  text-align: center;
  margin-top: 4px;
  transition: all .18s;
}
.reset-btn:hover { background: #e5e7eb; color: #333; }

/* 모바일 */
@media(max-width:480px) {
  #chatWindow { right: 10px; width: calc(100vw - 20px); top: auto; bottom: 90px; transform: scale(.92); transform-origin: bottom right; }
  #chatWindow.open { transform: scale(1); }
  #chatToggle { right: 16px; top: auto; bottom: 20px; transform: none; }
  #chatToggle:hover { transform: scale(1.08); }
}
