﻿:root{
  --bg:#ffffff;
  --text:#111;
  --muted:#6b7280;
  --line:#e5e7eb;
  --shadow: 0 18px 50px rgba(0,0,0,.12);
  --gold:#b88a2a;
  --tag:#ffffff;
  --tagText:#111;
  --radius:18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,"PingFang TC","Microsoft JhengHei",sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 18px}

.hdr{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.hdr__inner{max-width:1180px;margin:0 auto;padding:12px 18px;display:flex;align-items:center;gap:18px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800}
.logo__mark{width:34px;height:34px;border-radius:12px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden}
.logo__img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.nav{display:flex;align-items:center;gap:18px;flex:1}
.nav a{font-size:15px;color:#111;opacity:.86}
.nav a:hover{opacity:1}
.nav a.is-on{opacity:1;font-weight:800}
.searchBar{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:8px 12px;min-width:260px}
.searchBar input{border:0;outline:0;width:100%;font-size:14px}
.iconBtn{border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px 12px;cursor:pointer}
.iconBtn:hover{background:#f9fafb}
.mobileMenuBtn{display:none}
body.no-scroll{overflow:hidden}

.mobileMask{
  position:fixed;inset:0;z-index:90;
  background:rgba(0,0,0,.38);
  opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
.mobileMask.is-on{opacity:1;pointer-events:auto}

.mobileMenu{
  position:fixed;left:0;top:0;bottom:0;z-index:91;
  width:min(320px,84vw);
  background:#fff;
  border-right:1px solid var(--line);
  box-shadow:10px 0 30px rgba(0,0,0,.12);
  transform:translateX(-100%);
  transition:transform .25s ease;
}
.mobileMenu.is-on{transform:translateX(0)}
.mobileMenu__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 14px 10px;border-bottom:1px solid var(--line);
}
.mobileMenu__title{font-size:18px;font-weight:900}
.mobileMenu__nav{display:flex;flex-direction:column;padding:8px 0}
.mobileMenu__nav a{
  padding:14px 16px;
  font-weight:700;
  border-bottom:1px solid #f3f4f6;
}
.mobileTopView{
  margin:14px 14px 18px;
  padding:16px;
  border:1px solid #ece7df;
  border-radius:18px;
  background:linear-gradient(180deg, #fffaf2 0%, #ffffff 100%);
  box-shadow:0 14px 30px rgba(0,0,0,.06);
}
.mobileTopView__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.mobileTopView__eyebrow{
  font-size:11px;
  font-weight:900;
  letter-spacing:1.4px;
  color:#9a7b42;
  text-transform:uppercase;
}
.mobileTopView__title{
  margin-top:4px;
  font-size:22px;
  font-weight:900;
  letter-spacing:.4px;
  color:#1f2937;
}
.mobileTopView__badge{
  min-width:34px;
  height:34px;
  padding:0 10px;
  border-radius:999px;
  background:#111;
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:800;
}
.mobileTopView__list{
  margin-top:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.mobileTopView__item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border:1px solid #efe8da;
  border-radius:14px;
  background:rgba(255,255,255,.92);
  box-shadow:0 6px 18px rgba(17,24,39,.04);
}
.mobileTopView__item:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(17,24,39,.08);
}
.mobileTopView__item.is-static{cursor:default}
.mobileTopView__rank{
  width:28px;
  height:28px;
  border-radius:999px;
  background:#f5ead1;
  color:#8a6728;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  font-weight:900;
  flex:0 0 auto;
}
.mobileTopView__text{
  flex:1;
  min-width:0;
  font-size:14px;
  font-weight:800;
  line-height:1.5;
  color:#111827;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.mobileTopView__meta{
  flex:0 0 auto;
  font-size:12px;
  color:#6b7280;
  font-weight:700;
  white-space:nowrap;
  padding-left:6px;
}

.hero{
  position:relative;height:62vh;min-height:420px;overflow:hidden;
}
.hero__track{height:100%;display:flex;transition:transform .6s ease}
.hero__slide{min-width:100%;height:100%;background-size:cover;background-position:center top;position:relative;cursor:zoom-in}
.hero__slide:focus-visible{
  outline:3px solid rgba(255,255,255,.9);
  outline-offset:-6px;
}
.hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.55), rgba(0,0,0,.08));
}
.hero__content{
  position:absolute;left:0;top:0;bottom:0;
  width:100%;
  max-width:1180px;
  margin:0 auto;
  padding:0 18px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-bottom:34px;
  color:#fff;
}
.hero__title{
  font-size:54px;line-height:1.05;margin:0 0 10px;
  text-shadow: 0 6px 20px rgba(0,0,0,.35);
  letter-spacing:1px;
  font-weight:900;
}
.hero__sub{font-size:18px;margin:0;color:rgba(255,255,255,.86)}
.hero__bar{
  margin-top:18px;
  display:flex;gap:18px;flex-wrap:wrap;
  background:rgba(184,138,42,.80);
  color:#fff;
  padding:14px 16px;border-radius:16px;
}
.hero__bar span{font-weight:700;letter-spacing:1px}

.hero__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:999px;
  border:1px solid rgba(255,255,255,.6);
  background:rgba(0,0,0,.25);
  color:#fff;
  cursor:pointer;
}
.hero__nav:hover{background:rgba(0,0,0,.35)}
.hero__nav--prev{left:14px}
.hero__nav--next{right:14px}
.hero__dots{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);display:flex;gap:8px}
.hero__dots button{
  width:9px;height:9px;border-radius:999px;
  border:1px solid rgba(255,255,255,.55);
  background:rgba(255,255,255,.20);
  cursor:pointer;
}
.hero__dots button.is-on{background:rgba(255,255,255,.86)}

.section{padding:56px 0}
.sectionHead{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}
.sectionHead h2{margin:0;font-size:42px;letter-spacing:1px}
.sectionHead .sub{color:var(--muted);margin-top:8px}
.moreBtn{
  border:1px solid #111;background:#fff;
  padding:12px 16px;border-radius:0;cursor:pointer;
  font-weight:700;
}
.moreBtn:hover{background:#111;color:#fff}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  padding:20px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.articleCard__meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.articleCard__views{
  font-size:13px;
  color:var(--muted);
  font-weight:800;
  white-space:nowrap;
}
.articleLinks{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
  margin-top:12px;
}
.articleLinks__item{
  color:#0f5fcc;
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:3px;
  word-break:break-word;
}
.articleLinks__item:hover{color:#0b4cab}

/* 3) 瘥?銝筑??嚗croll reveal */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.is-in{
  opacity:1;
  transform:translateY(0);
}

/* ???嚗撌血皛? */
.scrollerWrap{position:relative;margin-top:18px}
.scroller{
  display:flex;gap:18px;
  overflow:auto;
  scroll-snap-type:x mandatory;
  padding:8px 6px 16px;
}
.scroller::-webkit-scrollbar{height:8px}
.scroller::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:999px}
.item{
  min-width:340px;
  scroll-snap-align:start;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
  transition:transform .22s ease, box-shadow .22s ease;
}
.item:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.item[data-url]{cursor:pointer}
.item__mediaLink{display:block}
.item__img{position:relative;height:210px;background-size:cover;background-position:center}
.item__body{padding:16px}
.brand{font-weight:900;letter-spacing:1px}
.title{margin-top:8px;font-size:18px;font-weight:700;line-height:1.35}
.productTitleLink{display:block}
.productTitleLink:hover{text-decoration:underline;text-underline-offset:4px}
.price{margin-top:14px;font-size:34px;font-weight:900}
.price small{font-size:14px;color:var(--muted);font-weight:600;margin-left:6px}
.viewBadge{margin-top:8px;color:var(--muted);font-size:13px;font-weight:800}
.metaRow{margin-top:14px;display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
.metaCell{padding:12px 10px;text-align:center;font-weight:700}
.metaCell span{display:block;margin-top:6px;color:var(--muted);font-weight:600;font-size:12px}
.detailBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:14px;
  border:1px solid #111;
  background:#111;
  color:#fff;
  padding:10px 12px;
  font-weight:800;
}
.detailBtn:hover{background:#fff;color:#111}
.compareBtn{
  margin-top:14px;
  border:1px solid #111;background:#fff;
  padding:10px 12px;cursor:pointer;font-weight:800;
}
.compareBtn:hover{background:#111;color:#fff}
.compareBtn.is-on{background:#111;color:#fff}
.compareCard[data-url]{cursor:pointer}
.favBtn{
  margin-top:8px;
  border:1px solid #111;background:#fff;
  padding:10px 12px;cursor:pointer;font-weight:800;
}
.favBtn:hover{background:#111;color:#fff}
.favBtn.is-on{background:#111;color:#fff}
.popularGrid{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:18px;
}
.popularGrid .item{min-width:0}

/* compare */
.compareDock{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);
  z-index:120;display:flex;align-items:center;gap:12px;
  background:rgba(17,17,17,.94);color:#fff;border-radius:999px;
  padding:10px 14px;box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.compareDock__info{font-size:14px;font-weight:700;white-space:nowrap}
.compareDock__go{
  border:1px solid #fff;background:#fff;color:#111;border-radius:999px;
  padding:8px 14px;font-weight:800;cursor:pointer;
}
.compareDock__go[disabled]{opacity:.45;cursor:not-allowed}

.compareMask{
  position:fixed;inset:0;z-index:130;background:rgba(0,0,0,.55);
  display:none;align-items:center;justify-content:center;padding:18px;
}
.compareMask.is-on{display:flex}
.compareModal{
  width:min(1000px,96vw);max-height:90vh;overflow:auto;
  background:#fff;border-radius:16px;padding:18px;position:relative;
}
.compareModal__close{
  position:absolute;right:10px;top:10px;width:36px;height:36px;
  border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;
  font-size:22px;line-height:30px;
}
.compareModal__title{font-size:24px;font-weight:900;margin:2px 0 16px}
.compareCommon{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:14px;background:#fafafa}
.compareCommon__title{font-weight:900;margin-bottom:8px}
.compareCommon__tags{display:flex;gap:8px;flex-wrap:wrap}
.compareGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.compareCard{border:1px solid var(--line);border-radius:12px;padding:12px}
.compareCard__title{font-weight:900;line-height:1.4}
.compareCard__price{margin-top:6px;font-weight:800;color:#111}
.compareCard__tags{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}
.compareTag{
  display:inline-flex;align-items:center;gap:6px;
  background:#f3f4f6;border:1px solid #e5e7eb;color:#111;
  border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;
}
.compareTag.is-common{background:#fff7e0;border-color:#f3d28b}
.compareTag.is-empty{opacity:.7}

/* 4) Hashtag 璅?嚗??典?銝? */
.tags{
  position:absolute;left:12px;top:12px;
  display:flex;flex-wrap:wrap;gap:8px;
  max-width:85%;
}
.tag{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.92);
  color:var(--tagText);
  border:1px solid rgba(17,17,17,.10);
  padding:8px 10px;
  border-radius:999px;
  font-weight:800;
  font-size:13px;
}
.tag:before{
  content:"#";
  font-size:12px;
  opacity:.9;
}

.breadcrumb{
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--muted);
  font-size:14px;
  margin-bottom:18px;
  flex-wrap:wrap;
}
.breadcrumb a{font-weight:800;color:#111}
.breadcrumb a:hover{text-decoration:underline;text-underline-offset:3px}
.alertLine{
  border:1px solid #f1d38a;
  background:#fff8e6;
  color:#7a5600;
  padding:12px 14px;
  font-weight:800;
  margin-bottom:18px;
}
.productHero{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);
  gap:28px;
  align-items:start;
}
.productGallery{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.productGallery img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border:1px solid var(--line);
}
.productGallery img:first-child{grid-column:1/-1}
.productGallery__empty{
  min-height:360px;
  border:1px solid var(--line);
  background:#f9fafb;
  color:var(--muted);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
}
.productInfo{
  position:sticky;
  top:86px;
  border:1px solid var(--line);
  padding:24px;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.productInfo__kicker{
  color:var(--muted);
  font-size:13px;
  font-weight:900;
  letter-spacing:.8px;
}
.productInfo h1{
  margin:10px 0 0;
  font-size:34px;
  line-height:1.25;
}
.productInfo__price{
  margin-top:18px;
  font-size:38px;
  font-weight:900;
}
.productInfo__meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-top:20px;
}
.productInfo__meta div{
  padding:14px 8px;
  text-align:center;
  min-width:0;
}
.productInfo__meta strong{
  display:block;
  font-size:14px;
  word-break:break-word;
}
.productInfo__meta span{
  display:block;
  margin-top:6px;
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
.productInfo__actions{
  display:flex;
  gap:10px;
  margin-top:22px;
  flex-wrap:wrap;
}
.moreBtn--ghost{border-color:var(--line);color:#111;background:#fff}
.productDescription{
  margin-top:42px;
  border-top:1px solid var(--line);
  padding-top:28px;
}
.productDescription h2{
  margin:0;
  font-size:28px;
}
.productDescription__body,
.productDescription p{
  margin-top:16px;
  color:#374151;
  line-height:1.9;
  white-space:normal;
}

/* ?喳瘚桀?敹急嚗閰?LINE/隡啗?/鞈潛頠? */
.fabCol{
  position:fixed;right:18px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:12px;
  z-index:60;
}
.fab{
  width:62px;height:62px;border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;
  cursor:pointer;
}
.fab:hover{transform:translateY(-3px)}
.fab__icon{
  font-size:24px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.favMask{
  position:fixed;inset:0;z-index:140;
  background:rgba(0,0,0,.55);
  display:none;align-items:center;justify-content:center;
  padding:18px;
}
.favMask.is-on{display:flex}
.favModal{
  width:min(760px,96vw);max-height:88vh;overflow:auto;
  background:#fff;border-radius:16px;padding:18px;position:relative;
}
.favModal__close{
  position:absolute;right:10px;top:10px;width:36px;height:36px;
  border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;
  font-size:22px;line-height:30px;
}
.favModal__title{font-size:24px;font-weight:900;margin:2px 0 14px}
.favListEmpty{color:var(--muted)}
.favRow{
  border:1px solid var(--line);border-radius:12px;padding:12px;
  display:flex;align-items:center;gap:10px;margin-bottom:10px;
}
.favRow[data-url]{cursor:pointer}
.favRow__meta{flex:1;min-width:0}
.favRow__type{font-size:12px;color:var(--muted)}
.favRow__title{font-size:16px;font-weight:800;line-height:1.45;word-break:break-word}
.favRow__sub{margin-top:4px;font-size:12px;color:var(--muted)}
.favRow__rm{
  border:1px solid #111;background:#fff;border-radius:10px;
  padding:8px 10px;cursor:pointer;font-weight:800;
}
.favRow__rm:hover{background:#111;color:#fff}

/* 1) 撱??敶? */
.modalMask{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  display:none;
  align-items:center;justify-content:center;
  z-index:100;
}
.modalMask.is-on{display:flex}
.modal{
  width:min(1040px,92vw);
  background:#000;
  border-radius:16px;
  overflow:hidden;
  position:relative;
  box-shadow:0 30px 120px rgba(0,0,0,.45);
}
.modal__img{
  height:min(70vh,620px);
  background-size:cover;background-position:center;
  position:relative;
}
.modalMask--viewer{z-index:120}
.modal--viewer{
  width:min(1200px,94vw);
  background:#111;
}
.modal__img--contain{
  height:min(86vh,820px);
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
}
.modal__close{
  position:absolute;right:12px;top:12px;
  width:42px;height:42px;border-radius:999px;
  border:0;background:rgba(255,255,255,.88);
  cursor:pointer;font-size:18px;font-weight:900;
}
.modal__bottom{
  position:absolute;right:18px;bottom:16px;
  display:flex;align-items:center;gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.modal__views{
  background:rgba(255,255,255,.88);
  color:#111;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(17,17,17,.08);
  font-size:13px;
  font-weight:800;
  line-height:1;
}
.chk{
  display:flex;align-items:center;gap:10px;
  background:rgba(0,0,0,.55);
  color:#fff;
  padding:10px 12px;border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
}
.chk input{width:16px;height:16px}

/* 6) ??撌血皛?蝷?*/
.hint{
  position:absolute;left:50%;top:44%;
  transform:translate(-50%,-50%);
  width:210px;height:210px;
  border-radius:999px;
  background:rgba(0,0,0,.45);
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
  opacity:0;
  transition:opacity .25s ease;
}
.hint.is-on{opacity:1}
.hint__hand{
  font-size:54px;filter:drop-shadow(0 10px 20px rgba(0,0,0,.35));
  animation:handMove 1.6s ease-in-out infinite;
}
.hint__arrow{
  position:absolute;left:50%;top:64%;
  transform:translateX(-50%);
  display:flex;gap:18px;color:#fff;font-weight:900;font-size:18px;
  opacity:.9;
}
@keyframes handMove{
  0%{transform:translateX(-20px) scale(1)}
  50%{transform:translateX(20px) scale(1)}
  100%{transform:translateX(-20px) scale(1)}
}

.pageTitle{padding:26px 0 0}
.pageTitle h1{margin:0;font-size:40px;letter-spacing:1px}
.formGrid{margin-top:18px;display:grid;grid-template-columns:180px 1fr;row-gap:18px;column-gap:16px;align-items:center}
.label{color:#111;font-weight:800}
.input, .select{
  width:100%;
  border:0;
  background:#f3f4f6;
  padding:18px 18px;
  border-radius:0;
  outline:0;
  font-size:16px;
}
.estimateTextarea{resize:vertical;min-height:150px;font-family:inherit;line-height:1.7}
.estimateActions{margin-top:18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.estimateMsg{color:var(--muted);font-weight:800}
.estimateMsg.is-success{color:#047857}
.estimateMsg.is-error{color:#dc2626}
.moreBtn[disabled]{opacity:.55;cursor:not-allowed}
.hr{border-top:1px solid var(--line);margin:24px 0}

/* about.php */
.aboutLayout{
  margin-top:18px;
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:18px;
  align-items:start;
}
.aboutCards{display:grid;gap:14px}
.aboutCard{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:14px;
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.aboutCard__avatar{
  width:62px;height:62px;border-radius:14px;
  overflow:hidden;flex:0 0 auto;border:1px solid var(--line);
}
.aboutCard__avatar img{width:100%;height:100%;object-fit:cover}
.aboutCard__body h3{margin:0;font-size:20px;line-height:1.35}
.aboutCard__body p{margin:10px 0 0;color:#6b7280;line-height:1.8}
.aboutTags{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}
.aboutTag{
  display:inline-flex;align-items:center;
  font-size:12px;font-weight:800;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  background:#fafafa;
}
.aboutSide{position:sticky;top:92px}
.aboutSide__title{margin:0 0 12px;font-size:20px}
.aboutContactList{display:flex;flex-direction:column;gap:10px}
.aboutContact{
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 14px;
  font-weight:800;
  background:#fff;
}
.aboutContact:hover{background:#f9fafb}

/* owner zone */
.ownerHeroSection{padding-top:48px}
.ownerHero{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr);
  gap:24px;
  align-items:stretch;
}
.ownerHero__body{
  border:1px solid var(--line);
  border-radius:18px;
  padding:34px;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.ownerEyebrow{
  color:#9a7b42;
  font-size:12px;
  font-weight:900;
  letter-spacing:1.6px;
  text-transform:uppercase;
}
.ownerHero h1{
  margin:10px 0 14px;
  font-size:48px;
  line-height:1.12;
}
.ownerHero p,
.ownerValue p,
.ownerPrivateTitle p{
  color:#374151;
  line-height:1.9;
  margin:10px 0 0;
}
.ownerHero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:24px;
}
.ownerHero__panel{
  border:1px solid #efe8da;
  border-radius:18px;
  padding:26px;
  background:linear-gradient(180deg,#fffaf2 0%,#fff 100%);
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.ownerLock{
  display:flex;
  align-items:center;
  gap:14px;
  padding-bottom:18px;
  border-bottom:1px solid #efe8da;
}
.ownerLock__icon{
  width:58px;
  height:58px;
  border-radius:16px;
  background:#111;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
}
.ownerLock strong,
.ownerLock span{
  display:block;
}
.ownerLock strong{font-size:20px}
.ownerLock span{margin-top:4px;color:var(--muted);font-weight:800}
.ownerPreviewList{
  margin:20px 0 0;
  padding-left:20px;
  color:#374151;
  line-height:2;
  font-weight:800;
}
.ownerSectionAlt{background:#fafafa}
.ownerFeatureGrid,
.ownerFaqGrid{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.ownerFeatureCard,
.ownerFaq{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:20px;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.ownerFeatureCard h3,
.ownerFaq h3{
  margin:0;
  font-size:20px;
  line-height:1.4;
}
.ownerFeatureCard p,
.ownerFaq p{
  margin:10px 0 0;
  color:#4b5563;
  line-height:1.8;
}
.ownerValue{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:22px;
  align-items:start;
}
.ownerValue h2,
.ownerPrivateBlock h2{
  margin:8px 0 0;
  font-size:34px;
  line-height:1.25;
}
.ownerNoticeBox{
  border:1px solid #f1d38a;
  background:#fff8e6;
  color:#7a5600;
  border-radius:16px;
  padding:20px;
}
.ownerNoticeBox strong{font-size:20px}
.ownerNoticeBox p{color:#7a5600}
.ownerPrivateSection{padding-top:44px}
.ownerLoginCard{
  width:min(560px,100%);
  margin:0 auto;
  border:1px solid var(--line);
  border-radius:18px;
  padding:30px;
  background:#fff;
  box-shadow:0 14px 34px rgba(0,0,0,.08);
}
.ownerLoginCard h1{
  margin:10px 0 12px;
  font-size:34px;
  line-height:1.25;
}
.ownerLoginCard p{
  color:#4b5563;
  line-height:1.8;
}
.ownerLoginForm{
  margin-top:20px;
  display:grid;
  gap:12px;
}
.ownerError{
  margin-top:14px;
  color:#dc2626;
  font-weight:800;
}
.ownerPrivateTitle{padding-top:0}
.ownerPrivateBlock{
  margin-top:28px;
  border-top:1px solid var(--line);
  padding-top:28px;
}
.ownerPromptGrid{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.ownerPromptCard{
  border:1px solid var(--line);
  border-radius:16px;
  padding:18px;
  background:#fff;
  box-shadow:0 8px 22px rgba(0,0,0,.05);
}
.ownerPromptCard--wide{margin-top:14px}
.ownerPromptCard h3{
  margin:0;
  font-size:20px;
  line-height:1.4;
}
.ownerPromptCard p{
  margin:8px 0 12px;
  color:#6b7280;
  line-height:1.7;
}
.ownerPromptCard pre{
  margin:12px 0 0;
  padding:14px 16px;
  border-left:5px solid #e5e7eb;
  background:#fafafa;
  color:#111827;
  font-family:inherit;
  font-size:15px;
  line-height:1.8;
  white-space:pre-wrap;
  word-break:break-word;
}
.copyPromptBtn{
  margin-top:12px;
  border:1px solid #111;
  background:#111;
  color:#fff;
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
  font-weight:900;
}
.copyPromptBtn:hover{background:#fff;color:#111}
.ownerWarning{
  margin-top:12px;
  border:1px solid #f1d38a;
  background:#fff8e6;
  color:#7a5600;
  border-radius:12px;
  padding:12px 14px;
  font-weight:800;
  line-height:1.7;
}
.ownerMaintenanceList{
  margin-top:14px;
  display:grid;
  gap:10px;
}
.ownerMaintenanceList div{
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px 16px;
  background:#fff;
  color:#374151;
  line-height:1.7;
  font-weight:700;
}

@media (max-width: 980px){
  .nav{display:none}
  .searchBar{display:none}
  .mobileMenuBtn{display:inline-flex}
  .hero__title{font-size:40px}
  .grid2{grid-template-columns:1fr}
  .item{min-width:78vw}
  .fabCol{right:10px}
  .aboutLayout{grid-template-columns:1fr}
  .aboutSide{position:static}
  .ownerHero,
  .ownerValue,
  .ownerFeatureGrid,
  .ownerFaqGrid,
  .ownerPromptGrid{grid-template-columns:1fr}
  .ownerHero__body,
  .ownerHero__panel,
  .ownerLoginCard{padding:22px}
  .ownerHero h1{font-size:38px}
  .ownerValue h2,
  .ownerPrivateBlock h2{font-size:28px}
  .ownerFeatureCard,
  .ownerFaq,
  .ownerPromptCard{border-radius:14px}
  .articleCard__meta{display:block}
  .articleCard__views{display:none}
  .productHero{grid-template-columns:1fr}
  .productInfo{position:static}
  .productGallery{grid-template-columns:1fr}
  .productInfo h1{font-size:28px}
  .productInfo__price{font-size:32px}
  .formGrid{grid-template-columns:1fr}
}

/* Supplier map: keep Leaflet tiles visible even if the page inline fallback CSS is stale. */
.leaflet-tile,
.leaflet-tile-loaded{
  visibility:visible !important;
}
.leaflet-container{
  position:relative !important;
}
.leaflet-container img{
  max-width:none !important;
  max-height:none !important;
}

