/* ============================================
   BARCODENET — Shared Stylesheet
   Typography: Pretendard
   Accent: Teal (logo)
   Corners: Sharp (0–4px)
   ============================================ */

@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css');

:root{
  /* Brand */
  --teal:        #0EA5A5;
  --teal-deep:   #0C8888;
  --teal-soft:   #E6F6F6;
  --navy:        #0F2A3D;     /* deep ink for headlines/accents */

  /* Deep teal-ink (replaces pure black) */
  --ink-deep:    #0F2A30;     /* small surfaces (buttons, text) */
  --ink-wide:    #0F444B;     /* wide surfaces (gradient pair) */

  /* Surface */
  --canvas:      #FFFFFF;
  --canvas-2:    #FAFBFC;
  --surface:     #F4F6F8;
  --surface-2:   #EEF1F4;
  --hairline:    #E5E8EC;
  --hairline-2:  #EFF1F4;

  /* Text */
  --ink:         #0B1620;
  --charcoal:    #2A3642;
  --slate:       #4A5764;
  --steel:       #6B7682;
  --muted:       #9AA3AD;
  --on-dark:     #FFFFFF;

  /* Semantic */
  --error:       #D7263D;
  --warn:        #E0A106;
  --success:     #18A957;

  /* Type */
  --font: 'Pretendard Variable', Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;

  /* Radii (sharp) */
  --r-xs: 1px;
  --r-sm: 2px;
  --r-md: 3px;
  --r-lg: 4px;
  --r-pill: 4px; /* sharp pills */

  /* Shadow */
  --sh-1: 0 1px 2px rgba(15,42,61,.04);
  --sh-2: 0 4px 16px rgba(15,42,61,.06);
  --sh-3: 0 24px 48px -12px rgba(15,42,61,.14);

  /* Container */
  --max:     1240px;
  --pad:     24px;
  --pad-lg:  32px;
}

*,*::before,*::after{box-sizing:border-box;}
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font);
  background:var(--canvas);
  color:var(--ink);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ===== Container ===== */
.container{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
}
@media (min-width:1024px){ .container{ padding:0 var(--pad-lg);} }

/* ===== Type ===== */
.eyebrow{
  font-size:12px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--teal-deep);
}
h1,h2,h3,h4{ margin:0; color:var(--ink); letter-spacing:-.02em; line-height:1.18; font-weight:700; }
h1{ font-size:clamp(34px,5vw,56px); letter-spacing:-.035em; line-height:1.08; }
h2{ font-size:clamp(26px,3.4vw,40px); letter-spacing:-.025em; }
h3{ font-size:clamp(20px,2.4vw,26px); letter-spacing:-.015em; }
h4{ font-size:18px; }
p { margin:0; color:var(--slate); }
.lead{ font-size:clamp(16px,1.6vw,19px); color:var(--slate); line-height:1.55; }

/* ===== Buttons ===== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  height:46px;
  padding:0 22px;
  font-size:14.5px;
  font-weight:600;
  letter-spacing:-.01em;
  border-radius:var(--r-md);
  border:1px solid transparent;
  transition:transform .12s ease, background .15s ease, color .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn--primary{
  background:linear-gradient(135deg, #0F2A30 0%, #0F444B 100%);
  color:#fff;
}
.btn--primary:hover{
  background:linear-gradient(135deg, #0F444B 0%, #0F2A30 100%);
}
.btn--accent { background:var(--teal); color:#fff; }
.btn--accent:hover { background:var(--teal-deep); }
.btn--ghost  { background:transparent; color:var(--ink); border-color:var(--hairline); }
.btn--ghost:hover{ border-color:var(--ink); }
.btn--ondark { background:#fff; color:var(--ink); }
.btn--ondark-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn--ondark-ghost:hover{ border-color:#fff; }
.btn--lg{ height:52px; padding:0 26px; font-size:15px; }
.btn--block{ width:100%; }

/* ===== Header ===== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--hairline);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:68px;
}
.brand{ display:flex; align-items:center; gap:10px; }
.brand img{ height:30px; width:auto; }
.gnb{ display:none; gap:28px; }
.gnb a{
  font-size:14.5px; color:var(--charcoal); font-weight:500;
  position:relative; padding:6px 0;
}
.gnb a.is-active{ color:var(--ink); }
.gnb a.is-active::after{
  content:""; position:absolute; left:0; right:0; bottom:-22px; height:2px; background:var(--teal);
}
.gnb a:hover{ color:var(--ink); }
.gnb .ext::after{ content:" ↗"; color:var(--steel); font-size:12px; }
.nav-right{ display:flex; align-items:center; gap:14px; }
.tel{
  display:none; align-items:center; gap:6px;
  color:var(--ink); font-weight:600; font-size:14.5px;
  font-variant-numeric:tabular-nums;
}
.tel svg{ width:16px; height:16px; color:var(--teal); }
.icon-btn{
  width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center;
  background:transparent; border:1px solid var(--hairline); border-radius:var(--r-md); color:var(--ink);
}
.menu-btn{ display:inline-flex; }
@media (min-width:960px){
  .gnb{ display:flex; }
  .tel{ display:inline-flex; }
  .menu-btn{ display:none; }
  .header-tel-mobile{ display:none; }
}

/* Mobile drawer */
.drawer{
  position:fixed; inset:0; background:#fff; z-index:60;
  transform:translateX(100%); transition:transform .25s ease;
  display:flex; flex-direction:column;
}
.drawer.is-open{ transform:translateX(0); }
.drawer-top{ display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--hairline); }
.drawer nav{ display:flex; flex-direction:column; padding:8px 0; }
.drawer nav a{ padding:18px 24px; font-size:18px; font-weight:600; border-bottom:1px solid var(--hairline-2); }
.drawer-foot{ margin-top:auto; padding:24px; background:var(--surface); }
.drawer-foot .tel-big{ font-size:22px; font-weight:700; color:var(--ink); display:block; }
.drawer-foot .hours{ color:var(--steel); font-size:13px; margin-top:4px; }
.drawer-foot .btn{ margin-top:14px; }

/* ===== Hero shell ===== */
.hero{
  position:relative;
  background:
    radial-gradient(1100px 480px at 80% -10%, rgba(14,165,165,.18), transparent 60%),
    linear-gradient(180deg, #FAFCFC 0%, #FFFFFF 60%);
  overflow:hidden;
  border-bottom:1px solid var(--hairline-2);
}
.hero-inner{ padding:80px 0 88px; }
@media (min-width:768px){ .hero-inner{ padding:104px 0 112px; } }
.hero h1 small{
  display:block; font-size:.42em; font-weight:600; letter-spacing:.02em;
  color:var(--teal-deep); margin-bottom:14px; text-transform:none;
}
.hero .lead{ margin-top:18px; max-width:640px; }
.hero-ctas{ display:flex; gap:10px; margin-top:28px; flex-wrap:wrap; }

/* hero accent grid (decorative barcode-like lines) */
.hero-art{
  position:absolute; right:-40px; top:60px; bottom:60px; width:46%;
  display:none; pointer-events:none;
  background:
    repeating-linear-gradient(90deg,
      rgba(14,165,165,.16) 0 2px, transparent 2px 6px,
      rgba(14,165,165,.16) 6px 9px, transparent 9px 18px,
      rgba(14,165,165,.10) 18px 21px, transparent 21px 32px);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 35%, #000 80%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 35%, #000 80%, transparent 100%);
}
@media (min-width:1024px){ .hero-art{ display:block; } }

.page-hero{
  background:
    radial-gradient(900px 360px at 90% -20%, rgba(14,165,165,.16), transparent 60%),
    #FAFCFC;
  border-bottom:1px solid var(--hairline-2);
  padding:64px 0 56px;
}
@media (min-width:768px){ .page-hero{ padding:88px 0 72px; } }
.page-hero h1{ font-size:clamp(30px,4.4vw,46px); }
.page-hero .lead{ margin-top:14px; max-width:680px; }
.crumbs{ font-size:13px; color:var(--steel); margin-bottom:18px; }
.crumbs a:hover{ color:var(--ink); }

/* ===== Section ===== */
section{ padding:72px 0; }
@media (min-width:768px){ section{ padding:96px 0; } }
.section-head{ max-width:780px; margin-bottom:40px; }
.section-head .eyebrow{ margin-bottom:12px; display:inline-block; }
.section-head h2 + .lead{ margin-top:14px; }
.bg-soft{ background:var(--surface); }
.bg-canvas2{ background:var(--canvas-2); }
.bg-dark{
  background: linear-gradient(135deg, #0F2A30 0%, #0F444B 60%, #0E6868 100%);
  color:#fff;
}
.bg-dark h2, .bg-dark p{ color:#fff; }

/* ===== Stat bar ===== */
.stats{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1px;
  background:var(--hairline);
  border:1px solid var(--hairline);
  border-radius:var(--r-md);
  overflow:hidden;
}
@media (min-width:768px){ .stats{ grid-template-columns:repeat(4,1fr); } }
.stat{ background:#fff; padding:28px 22px; }
.stat .num{ font-size:clamp(28px,3.4vw,36px); font-weight:800; color:var(--ink); letter-spacing:-.02em; line-height:1; }
.stat .num em{ color:var(--teal); font-style:normal; }
.stat .lbl{ display:block; margin-top:8px; font-size:13.5px; color:var(--steel); font-weight:500; }
.stat .ico{ display:inline-flex; width:22px; height:22px; color:var(--teal); margin-bottom:14px; }

/* ===== Cards ===== */
.grid{ display:grid; gap:20px; }
.grid--2{ grid-template-columns:1fr; }
.grid--3{ grid-template-columns:1fr; }
.grid--4{ grid-template-columns:1fr; }
@media (min-width:640px){
  .grid--2{ grid-template-columns:1fr 1fr; }
  .grid--3{ grid-template-columns:1fr 1fr; }
  .grid--4{ grid-template-columns:1fr 1fr; }
}
@media (min-width:1024px){
  .grid--3{ grid-template-columns:repeat(3,1fr); }
  .grid--4{ grid-template-columns:repeat(4,1fr); }
}
.card{
  background:#fff; border:1px solid var(--hairline);
  border-radius:var(--r-md); padding:26px;
  display:flex; flex-direction:column;
  transition:border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.card:hover{ border-color:var(--teal); box-shadow:var(--sh-2); }
.card h3{ margin-bottom:8px; }
.card p{ font-size:14.5px; }
.card .arrow{ margin-top:auto; padding-top:18px; color:var(--ink); font-weight:600; font-size:14px; display:inline-flex; align-items:center; gap:6px; }
.card .arrow::after{ content:"→"; transition:transform .15s ease; }
.card:hover .arrow::after{ transform:translateX(3px); }

.card--problem{ position:relative; padding-left:26px; border-left:3px solid var(--error); }
.card--problem .tag{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; font-weight:700; color:var(--error); letter-spacing:.06em; text-transform:uppercase;
  margin-bottom:14px;
}
.card--problem h3{ font-size:19px; }
.card--problem p{ color:var(--charcoal); }

.feature{
  display:flex; flex-direction:column; gap:14px;
  padding:28px; background:#fff; border:1px solid var(--hairline);
  border-radius:var(--r-md);
}
.feature .ico{
  width:42px; height:42px; border-radius:var(--r-md);
  background:var(--teal-soft); color:var(--teal-deep);
  display:flex; align-items:center; justify-content:center;
}
.feature h4{ font-size:17px; }
.feature p{ font-size:14.5px; }

/* product card */
.pcard{
  background:#fff; border:1px solid var(--hairline);
  border-radius:var(--r-md); overflow:hidden; display:flex; flex-direction:column;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.pcard:hover{ border-color:var(--teal); box-shadow:var(--sh-2); }
.pcard .ph{
  aspect-ratio:4/3; background:var(--surface);
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); font-size:12px;
  position:relative; overflow:hidden;
}
.pcard .ph::before{
  content:""; position:absolute; inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 14px, rgba(15,42,61,.03) 14px 15px);
}
.pcard .ph .tag{
  position:relative; font-family: 'JetBrains Mono', ui-monospace, monospace;
  background:#fff; border:1px solid var(--hairline); padding:6px 10px; border-radius:var(--r-sm);
  letter-spacing:.04em; color:var(--steel);
}
.pcard .body{ padding:22px 22px 24px; display:flex; flex-direction:column; gap:8px; flex:1; }
.pcard .meta{ font-size:12px; font-weight:700; letter-spacing:.08em; color:var(--teal-deep); text-transform:uppercase; }
.pcard h3{ font-size:18px; }
.pcard p{ font-size:14px; color:var(--steel); }
.pcard .arrow{ margin-top:auto; padding-top:14px; color:var(--ink); font-weight:600; font-size:13.5px; }
.pcard .arrow::after{ content:" →"; }

/* testimonial */
.quote{
  background:#fff; border:1px solid var(--hairline);
  border-left:3px solid var(--teal);
  padding:28px 26px; border-radius:var(--r-md);
  display:flex; flex-direction:column; gap:16px;
}
.quote blockquote{
  margin:0; font-size:16px; line-height:1.65; color:var(--charcoal);
  font-weight:500;
}
.quote .who{ font-size:13.5px; color:var(--steel); }
.quote .who strong{ color:var(--ink); font-weight:600; }

/* tables */
.table{
  width:100%; border-collapse:collapse;
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  overflow:hidden;
}
.table th, .table td{
  padding:18px 20px; text-align:left; vertical-align:top;
  border-bottom:1px solid var(--hairline-2);
  font-size:14.5px;
}
.table th{
  background:var(--surface); color:var(--ink);
  font-weight:700; font-size:13px; letter-spacing:.04em; text-transform:uppercase;
  width:140px;
}
.table tr:last-child th, .table tr:last-child td{ border-bottom:none; }
.table td b{ color:var(--ink); font-weight:600; }

/* spec list */
.specs{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.specs li{
  display:flex; gap:12px; font-size:14.5px; color:var(--charcoal);
  padding-left:26px; position:relative;
}
.specs li::before{
  content:""; position:absolute; left:0; top:9px;
  width:14px; height:14px; border-radius:1px;
  background:var(--teal-soft);
  background-image:linear-gradient(135deg, transparent 50%, var(--teal) 50%);
}

/* anchor nav for products */
.anchor-nav{
  position:sticky; top:68px; z-index:30;
  background:#fff; border-bottom:1px solid var(--hairline);
}
.anchor-nav .inner{
  display:flex; gap:6px; overflow-x:auto;
  padding:12px 0;
}
.anchor-nav a{
  flex-shrink:0; padding:10px 16px;
  font-size:14px; font-weight:600; color:var(--steel);
  border:1px solid var(--hairline); border-radius:var(--r-md);
  white-space:nowrap; transition:all .15s ease;
}
.anchor-nav a.is-active, .anchor-nav a:hover{
  color:#fff;
  background:linear-gradient(135deg, #0F2A30 0%, #0F444B 100%);
  border-color:#0F2A30;
}

/* product section */
.psection{ scroll-margin-top:140px; }
.psection + .psection{ border-top:1px solid var(--hairline-2); }

/* product detail layout */
.pdetail{
  display:grid; grid-template-columns:1fr; gap:28px;
  padding:36px 0;
}
@media (min-width:900px){ .pdetail{ grid-template-columns:1fr 1.1fr; gap:48px; } }
.pdetail .img{
  background:var(--surface); border:1px solid var(--hairline);
  border-radius:var(--r-md); aspect-ratio:4/3;
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); font-size:12px;
  position:relative; overflow:hidden;
}
.pdetail .img::before{
  content:""; position:absolute; inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0 14px, rgba(15,42,61,.03) 14px 15px);
}
.pdetail .img .lbl{
  position:relative;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  background:#fff; border:1px solid var(--hairline);
  padding:8px 12px; border-radius:var(--r-sm); letter-spacing:.04em; color:var(--steel);
}
.pdetail .who{
  display:grid; grid-template-columns:80px 1fr; gap:10px 16px;
  margin:18px 0 22px; padding:18px 0;
  border-top:1px solid var(--hairline-2); border-bottom:1px solid var(--hairline-2);
}
.pdetail .who dt{
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--teal-deep); padding-top:2px;
}
.pdetail .who dd{ margin:0; font-size:14.5px; color:var(--charcoal); }
.pdetail h3{ font-size:24px; margin-bottom:6px; }
.pdetail .ctas{ display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; }

/* dark CTA */
.cta-band{ padding:84px 0; }
.cta-band .inner{ display:flex; flex-direction:column; gap:20px; align-items:flex-start; }
.cta-band h2{ max-width:720px; }
.cta-band p{ color:rgba(255,255,255,.78); max-width:640px; font-size:17px; }
.cta-band .btns{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }

/* form */
.form{ display:flex; flex-direction:column; gap:18px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-size:13.5px; font-weight:600; color:var(--ink); }
.field label .req{ color:var(--error); margin-left:4px; }
.field input, .field textarea{
  font:inherit;
  background:#fff;
  border:1px solid var(--hairline);
  border-radius:var(--r-md);
  padding:12px 14px;
  font-size:15px;
  color:var(--ink);
  transition:border-color .15s ease, box-shadow .15s ease;
}
.field input:focus, .field textarea:focus{
  outline:none;
  border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(14,165,165,.15);
}
.field textarea{ min-height:120px; resize:vertical; }
.field .help{ font-size:12.5px; color:var(--steel); }
.form .btn{ margin-top:6px; }
.form-ok{
  background:var(--teal-soft); border:1px solid var(--teal);
  color:var(--teal-deep); padding:14px 16px; border-radius:var(--r-md);
  font-size:14.5px; font-weight:600;
}

/* contact options */
.contact-opts{ display:grid; grid-template-columns:1fr; gap:14px; }
@media (min-width:768px){ .contact-opts{ grid-template-columns:repeat(3,1fr); } }
.contact-opt{
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:24px; display:flex; flex-direction:column; gap:8px;
}
.contact-opt .ico{ width:36px; height:36px; color:var(--teal); }
.contact-opt h4{ font-size:16px; }
.contact-opt .v{ font-size:18px; font-weight:700; color:var(--ink); font-variant-numeric:tabular-nums; }
.contact-opt .h{ font-size:13px; color:var(--steel); margin-top:auto; padding-top:6px; }

/* FAQ */
.faq-cats{ display:flex; gap:8px; overflow-x:auto; padding-bottom:8px; margin-bottom:24px; flex-wrap:wrap; }
.faq-cats > button{
  flex-shrink:0; padding:9px 16px; font-size:13.5px; font-weight:600;
  background:#fff; color:var(--charcoal);
  border:1px solid var(--hairline); border-radius:var(--r-md);
  white-space:nowrap; transition:all .15s ease;
}
.faq-cats > button.is-active{ background:#0F2A30; border-color:#0F2A30; color:#fff; }
.faq-cat, .faq-cat:focus, .faq-cat:focus-within, .faq-cat:target, .faq-cat.is-active{
  background:transparent !important; outline:none !important;
}
.faq-list{ display:flex; flex-direction:column; gap:10px; }
.faq-item{ background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md); overflow:hidden; }
.faq-q{
  width:100%; text-align:left; background:transparent; border:0;
  padding:20px 24px; display:flex; align-items:center; justify-content:space-between; gap:14px;
  font-size:16px; font-weight:600; color:var(--ink);
}
.faq-q .plus{
  width:22px; height:22px; flex-shrink:0; position:relative; color:var(--steel);
}
.faq-q .plus::before, .faq-q .plus::after{
  content:""; position:absolute; left:50%; top:50%; background:currentColor;
  transition:transform .2s ease;
}
.faq-q .plus::before{ width:14px; height:2px; transform:translate(-50%,-50%); }
.faq-q .plus::after{ width:2px; height:14px; transform:translate(-50%,-50%); }
.faq-item.is-open .faq-q{ color:var(--teal-deep); }
.faq-item.is-open .faq-q .plus::after{ transform:translate(-50%,-50%) rotate(90deg); opacity:0; }
.faq-a .pad{ padding:0 24px 22px; border-top:1px solid var(--hairline-2); padding-top:18px; }

/* badge bar - cases page */
.region-table{
  width:100%; border-collapse:collapse;
  background:#fff; border:1px solid var(--hairline);
  border-radius:var(--r-md); overflow:hidden;
}
.region-table th{
  background:linear-gradient(135deg, #0F2A30 0%, #0F444B 100%); color:#fff;
  text-align:left; padding:14px 18px; width:120px;
  font-size:12.5px; letter-spacing:.08em; text-transform:uppercase;
}
.region-table td{
  padding:18px 22px; font-size:15px; color:var(--charcoal);
  border-top:1px solid var(--hairline-2); line-height:1.7;
}

/* ribbons / divider line */
.divline{ height:1px; background:var(--hairline); margin:0; border:0; }

/* footer */
.site-footer{
  background:var(--surface);
  border-top:1px solid var(--hairline);
  padding:64px 0 28px;
  color:var(--slate);
  font-size:13.5px;
}
.site-footer .top{
  display:grid; grid-template-columns:1fr; gap:36px;
  padding-bottom:36px; border-bottom:1px solid var(--hairline);
}
@media (min-width:900px){
  .site-footer .top{ grid-template-columns:1.4fr 1fr 1fr 1fr; }
}
.site-footer .brand img{ height:30px; margin-bottom:14px; }
.site-footer p{ font-size:13.5px; color:var(--slate); }
.site-footer h5{
  font-size:11.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); margin:0 0 14px; font-weight:700;
}
.site-footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.site-footer a:hover{ color:var(--ink); }
.site-footer .biz{
  padding:24px 0 12px; font-size:12.5px; color:var(--steel); line-height:1.85;
}
.site-footer .biz b{ color:var(--charcoal); font-weight:600; }
.site-footer .legal{
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  padding-top:18px; border-top:1px solid var(--hairline);
  font-size:12px; color:var(--muted);
}

/* floating mobile CTA */
.fcta{
  position:fixed; right:18px; bottom:18px; z-index:40;
  display:flex; flex-direction:column; gap:10px; align-items:flex-end;
}
@media (min-width:960px){ .fcta{ display:none; } }
.fcta-main{
  width:56px; height:56px; border-radius:999px;
  background:var(--teal); color:#fff; border:0;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(14,165,165,.4);
}
.fcta-main svg{ width:24px; height:24px; }
.fcta-list{
  display:none; flex-direction:column; gap:8px;
  padding:8px; background:#fff; border:1px solid var(--hairline);
  border-radius:var(--r-md); box-shadow:var(--sh-2);
}
.fcta.is-open .fcta-list{ display:flex; }
.fcta-list a{
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; font-size:14px; font-weight:600;
  color:var(--ink); white-space:nowrap;
}
.fcta-list a svg{ width:16px; height:16px; color:var(--teal); }

/* utility */
.hr-spacer{ height:48px; }
.muted{ color:var(--steel); }
.mono{ font-family:'JetBrains Mono', ui-monospace, monospace; font-size:.92em; }
.callout{
  background:var(--teal-soft); border:1px solid #BFE5E5;
  padding:18px 20px; border-radius:var(--r-md);
  font-size:14.5px; color:var(--charcoal);
}
.callout b{ color:var(--teal-deep); }

/* certificates */
.cert-grid{ display:grid; gap:18px; grid-template-columns:1fr; }
@media (min-width:768px){ .cert-grid{ grid-template-columns:repeat(3,1fr); } }
.cert{
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:22px; display:flex; flex-direction:column; gap:10px;
}
.cert .badge{
  width:fit-content;
  font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--teal-deep); background:var(--teal-soft);
  padding:4px 8px; border-radius:var(--r-sm);
}
.cert h4{ font-size:16px; }
.cert p{ font-size:13.5px; color:var(--steel); }
.cert .num{ font-family:'JetBrains Mono',ui-monospace,monospace; font-size:13px; color:var(--charcoal); }

/* hero deco scanner viz */
.scanner{
  position:relative; aspect-ratio: 5/4;
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:22px; box-shadow:var(--sh-3);
  overflow:hidden;
}
.scanner::after{
  content:""; position:absolute; left:0; right:0; top:0;
  height:2px; background:var(--teal);
  animation: scan 2.6s ease-in-out infinite;
}
@keyframes scan{
  0%,100%{ top:14%; opacity:1; }
  50% { top:86%; opacity:.7; }
}
.scanner .label-mini{
  background:#fff; border:1px solid var(--hairline);
  border-radius:var(--r-sm); padding:14px;
  margin-bottom:12px;
}
.scanner .label-mini .barcode{
  display:flex; align-items:flex-end; gap:1px; height:34px; margin-bottom:8px;
}
.scanner .label-mini .barcode i{
  display:block; background:var(--ink); height:100%; flex-shrink:0;
}
.scanner .label-mini .digits{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px; letter-spacing:.18em; color:var(--charcoal);
}
.scanner .label-mini h5{
  margin:0 0 4px; font-size:13px; color:var(--ink);
}
.scanner .label-mini .meta{
  font-size:11px; color:var(--steel);
}
.scanner-tag{
  position:absolute; top:14px; right:14px;
  font-size:11px; font-family:'JetBrains Mono',ui-monospace,monospace;
  letter-spacing:.1em; color:var(--teal-deep); background:var(--teal-soft);
  padding:5px 9px; border-radius:var(--r-sm); border:1px solid #BFE5E5;
}

/* hero layout */
.hero-grid{
  display:grid; grid-template-columns:1fr; gap:48px; align-items:center;
}
@media (min-width:1024px){
  .hero-grid{ grid-template-columns:1.05fr .95fr; gap:56px; }
}

/* about info grid */
.about-info{
  display:grid; grid-template-columns:1fr; gap:24px;
}
@media (min-width:900px){
  .about-info{ grid-template-columns:1.2fr 1fr; gap:48px; }
}

/* map */
.map-frame{
  background:var(--surface);
  border:1px solid var(--hairline);
  border-radius:var(--r-md);
  aspect-ratio: 16/9;
  position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.map-frame::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(0deg, rgba(14,165,165,.05), rgba(14,165,165,.05)),
    repeating-linear-gradient(0deg, transparent 0 39px, rgba(15,42,61,.06) 39px 40px),
    repeating-linear-gradient(90deg, transparent 0 39px, rgba(15,42,61,.06) 39px 40px);
}
.map-pin{
  position:relative; z-index:2; text-align:center;
}
.map-pin .dot{
  width:18px; height:18px; border-radius:999px;
  background:var(--teal); box-shadow:0 0 0 6px rgba(14,165,165,.25), 0 0 0 14px rgba(14,165,165,.12);
  margin:0 auto 10px;
}
.map-pin .ad{ background:#fff; padding:8px 14px; border:1px solid var(--hairline); border-radius:var(--r-md); font-size:13px; font-weight:600; color:var(--ink); }

/* policy list */
.policy{ display:grid; grid-template-columns:1fr; gap:16px; }
@media (min-width:768px){ .policy{ grid-template-columns:repeat(3,1fr); } }
.policy-item{ background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md); padding:24px; }
.policy-item h4{ font-size:16px; margin-bottom:8px; color:var(--ink); }
.policy-item p{ font-size:14px; color:var(--charcoal); line-height:1.7; }

/* shop link button */
.shop-link::after{ content:" ↗"; opacity:.6; }

/* ===== About page ===== */
.info-table{
  width:100%; border-collapse:collapse;
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md); overflow:hidden;
}
.info-table th, .info-table td{
  padding:16px 22px; text-align:left; border-top:1px solid var(--hairline-2);
  font-size:14.5px; line-height:1.6;
}
.info-table tr:first-child th, .info-table tr:first-child td{ border-top:0; }
.info-table th{
  background:#F7FAFA; color:var(--ink); font-weight:600;
  width:200px; font-size:13px; letter-spacing:.02em;
}
.info-table td{ color:var(--charcoal); }

.cert-img{
  aspect-ratio: 4/5; background:
    repeating-linear-gradient(135deg, #F4F7F8 0 14px, #EBF1F2 14px 28px);
  border-bottom:1px solid var(--hairline);
  display:flex; align-items:center; justify-content:center;
}
.cert-img .ph{ font-family:ui-monospace,Menlo,monospace; font-size:12px; color:var(--steel); letter-spacing:.04em; }

.cert-list{ display:grid; grid-template-columns:1fr; gap:16px; }
@media (min-width:768px){ .cert-list{ grid-template-columns:repeat(2,1fr); } }
.cert-item{
  display:flex; gap:20px; padding:24px;
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
}
.cert-item h4{ font-size:16px; margin:0 0 6px; color:var(--ink); font-weight:700; }
.cert-item p{ font-size:14px; color:var(--charcoal); line-height:1.65; margin:0; }
.cert-mark{
  flex-shrink:0; width:80px; height:80px;
  background:var(--teal); color:#fff;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  font-size:14px; font-weight:800; letter-spacing:.04em; line-height:1.1;
  border-radius:var(--r-sm);
}
.cert-mark span{ font-size:18px; }
.cert-mark--alt{ background:var(--ink); }

.policy-card{
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:32px 28px; position:relative;
}
.policy-card .num-tag{
  display:inline-block; font-family:ui-monospace,Menlo,monospace;
  font-size:12px; color:var(--teal); letter-spacing:.1em; margin-bottom:16px;
  padding:4px 10px; border:1px solid var(--teal); border-radius:2px;
}
.policy-card h3{ font-size:18px; margin:0 0 12px; color:var(--ink); font-weight:700; }
.policy-card p{ font-size:14.5px; color:var(--charcoal); line-height:1.7; margin:0 0 10px; }
.policy-card p.hl{ color:var(--ink); font-weight:500; padding-top:10px; border-top:1px solid var(--hairline-2); margin-top:14px; }

.ph-img--wide{
  aspect-ratio: 16/10; background:
    repeating-linear-gradient(135deg, #EEF3F4 0 16px, #E4ECEE 16px 32px);
  border:1px solid var(--hairline); border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
}
.ph-img--wide .ph{ font-family:ui-monospace,Menlo,monospace; font-size:13px; color:var(--steel); }

/* ===== FAQ ===== */
.faq-shell{
  display:grid; grid-template-columns:1fr; gap:32px;
}
@media (min-width:900px){ .faq-shell{ grid-template-columns:200px 1fr; gap:64px; } }

.faq-side{ position:sticky; top:90px; align-self:start; }
.faq-side-label{
  font-size:12px; font-weight:700; color:var(--ink);
  letter-spacing:.04em; padding-bottom:14px; border-bottom:1px solid var(--hairline);
  margin-bottom:8px;
}
.faq-nav{ display:flex; flex-direction:column; }
.faq-nav a{
  display:block; padding:14px 12px; font-size:14.5px; color:var(--steel);
  border-left:2px solid transparent; transition:all .15s;
}
.faq-nav a:hover{ color:var(--ink); }
.faq-nav a.is-active{ color:var(--teal); border-left-color:var(--teal); font-weight:700; background:#F0FAFA; }
@media (max-width:899px){
  .faq-side{ position:static; }
  .faq-nav{ flex-direction:row; flex-wrap:wrap; gap:6px; }
  .faq-nav a{ padding:8px 14px; border:1px solid var(--hairline); border-left-width:1px; border-radius:2px; }
  .faq-nav a.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }
}

.faq-cat{ padding-top:8px; padding-bottom:48px; }
.faq-cat:first-child{ padding-top:0; }
.faq-cat-head{
  display:flex; align-items:baseline; gap:14px;
  padding-bottom:18px; border-bottom:2px solid var(--ink); margin-bottom:20px;
}
.faq-cat-head h2{ margin:0; font-size:24px; color:var(--ink); font-weight:800; letter-spacing:-.01em; }
.faq-cat-head .cat-en{
  font-family:ui-monospace,Menlo,monospace;
  font-size:11px; letter-spacing:.16em; color:var(--teal); text-transform:uppercase; font-weight:600;
}

.faq-foot{
  margin-top:24px; padding:36px 32px;
  background:#FAFCFC; border:1px solid var(--hairline); border-radius:var(--r-md); text-align:center;
}
.faq-foot h3{ font-size:20px; margin:0 0 8px; color:var(--ink); font-weight:700; }
.faq-foot p{ font-size:14.5px; color:var(--charcoal); margin:0 0 20px; }
.faq-foot .btns{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }

.faq-list{ display:flex; flex-direction:column; gap:8px; }
.faq-item{
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  overflow:hidden;
}
.faq-item summary{
  display:flex; align-items:center; gap:16px;
  padding:22px 24px; cursor:pointer; list-style:none;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item .q-mark{
  flex-shrink:0; width:28px; height:28px; border-radius:50%;
  background:var(--teal); color:#fff; font-weight:700; font-size:13px;
  display:flex; align-items:center; justify-content:center;
}
.faq-item h3{
  flex:1; margin:0; font-size:16px; font-weight:600; color:var(--ink); line-height:1.5;
}
.faq-item .chev{
  width:14px; height:14px; flex-shrink:0;
  border-right:2px solid var(--steel); border-bottom:2px solid var(--steel);
  transform:rotate(45deg); transition:transform .2s; margin-bottom:4px;
}
.faq-item[open] .chev{ transform:rotate(-135deg); margin-bottom:-4px; }
.faq-item[open] summary{ padding-bottom:14px; }
.faq-item:hover{ border-color:var(--teal); }
.faq-a{
  max-height:none; overflow:visible;
  padding:0 24px 22px 56px;
  font-size:15px; color:var(--charcoal); line-height:1.85;
  word-break:keep-all; overflow-wrap:break-word;
  background:transparent;
}
.faq-a p + p{ margin-top:6px; }
.faq-a p{ margin:0; }
@media (max-width:640px){
  .faq-item summary{ padding:16px 16px; gap:10px; }
  .faq-item h3{ font-size:14.5px; line-height:1.55; }
  .faq-item .q-mark{ width:24px; height:24px; font-size:12px; }
  .faq-a{ padding:0 16px 16px 50px; font-size:14px; line-height:1.7; }
  .faq-item[open] summary{ padding-bottom:10px; }
}
@media (max-width:480px){
  .faq-a{ padding:0 14px 14px 14px; }
}

/* FAQ side nav — no heavy shading on hover/active */
.faq-shell{ display:grid; grid-template-columns:200px 1fr; gap:48px; }
@media (max-width:900px){ .faq-shell{ grid-template-columns:1fr; gap:24px; } }
.faq-side-label{
  font-family:ui-monospace,Menlo,monospace; font-size:11px;
  letter-spacing:.12em; color:var(--steel); text-transform:uppercase; margin-bottom:14px;
}
.faq-nav{ display:flex; flex-direction:column; gap:2px; }
.faq-nav a{
  padding:10px 14px; font-size:14.5px; color:var(--charcoal);
  border-left:2px solid transparent; transition:color .15s, border-color .15s;
}
.faq-nav a:hover{ color:var(--teal); }
.faq-nav a.is-active{ color:var(--teal); border-left-color:var(--teal); font-weight:600; background:transparent; }
@media (max-width:900px){
  .faq-side{ position:sticky; top:60px; z-index:5; background:var(--canvas);
    padding:10px 0; border-bottom:1px solid var(--hairline); margin:0 -16px; padding:10px 16px;
  }
  .faq-side-label{ display:none; }
  .faq-nav{ flex-direction:row; gap:6px; overflow-x:auto; scrollbar-width:none; }
  .faq-nav::-webkit-scrollbar{ display:none; }
  .faq-nav a{ flex-shrink:0; padding:8px 14px; border-left:0; border-bottom:2px solid transparent; white-space:nowrap; font-size:14px; }
  .faq-nav a.is-active{ border-left:0; border-bottom-color:var(--teal); }
}

.faq-cat{ margin-bottom:48px; scroll-margin-top:90px; }
.faq-cat-head{ display:flex; align-items:baseline; gap:12px; margin-bottom:18px; padding-bottom:14px; border-bottom:1px solid var(--hairline); }
.faq-cat-head h2{ font-size:22px; margin:0; color:var(--ink); }
.cat-en{ font-family:ui-monospace,Menlo,monospace; font-size:11px; letter-spacing:.12em; color:var(--steel); }
.faq-foot{
  margin-top:64px; padding:48px 32px; text-align:center;
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
}
.faq-foot h3{ font-size:22px; margin:0 0 10px; color:var(--ink); }
.faq-foot p{ color:var(--charcoal); margin:0 0 24px; font-size:15px; }
.faq-foot .btns{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
@media (max-width:640px){
  .faq-foot{ padding:32px 20px; }
  .faq-cat-head h2{ font-size:18px; }
  .faq-cat{ margin-bottom:32px; }
}

/* ===== Global responsive polish ===== */
@media (max-width:900px){
  .gnb{ display:none; }
  .nav-right .tel{ display:none; }
  .nav-right .btn--primary{ display:none; }
  .header-tel-mobile{ display:inline-flex !important; }
  .menu-btn{ display:inline-flex !important; }
}
@media (min-width:901px){
  .header-tel-mobile, .menu-btn{ display:none; }
}
@media (max-width:768px){
  .page-hero h1, h1{ font-size:clamp(26px,7vw,38px); line-height:1.25; }
  .section-head h2, h2{ font-size:clamp(22px,5.5vw,28px); line-height:1.3; }
  .lead{ font-size:15px; }
  .container{ padding-left:18px; padding-right:18px; }
  .pdetail{ grid-template-columns:1fr !important; gap:24px; }
  .pdetail .img{ order:-1; }
  .grid--3, .grid--4{ grid-template-columns:1fr !important; }
  .grid--2{ grid-template-columns:1fr !important; }
  .cta-band .btns{ flex-direction:column; align-items:stretch; }
  .cta-band .btns .btn{ width:100%; }
  .info-table th, .info-table td{ display:block; width:100% !important; padding:10px 16px; }
  .info-table th{ padding-top:14px; border-top:1px solid var(--hairline-2); }
  .info-table td{ padding-bottom:14px; }
  .region-table th, .region-table td{ display:block; width:100% !important; }
  .anchor-nav .inner{ overflow-x:auto; flex-wrap:nowrap; }
  .anchor-nav .inner a{ flex-shrink:0; white-space:nowrap; }
}

/* ===== Contact ===== */
.container--narrow{ max-width:880px; }

.contact-methods{
  display:grid; grid-template-columns:1fr; gap:16px;
}
@media (min-width:768px){ .contact-methods{ grid-template-columns:repeat(3,1fr); } }
.method{
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:32px 28px; text-align:left; transition:all .15s;
  display:flex; flex-direction:column; gap:6px;
}
a.method:hover{ border-color:var(--teal); transform:translateY(-2px); }
.method-icon{
  width:44px; height:44px; color:var(--teal); margin-bottom:14px;
}
.method-icon svg{ width:100%; height:100%; }
.method .kicker{
  font-family:ui-monospace,Menlo,monospace;
  font-size:11px; letter-spacing:.12em; color:var(--steel); text-transform:uppercase;
}
.method h3{ font-size:18px; margin:4px 0 8px; color:var(--ink); font-weight:700; }
.method p{ font-size:13.5px; color:var(--charcoal); line-height:1.65; margin:0; }
.method--featured{ background:var(--ink); color:#fff; border-color:var(--ink); }
.method--featured .method-icon{ color:var(--teal); }
.method--featured .kicker{ color:var(--teal); }
.method--featured h3{ color:#fff; }
.method--featured p{ color:rgba(255,255,255,.7); }

.qform{
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:36px 32px;
}
@media (max-width:640px){ .qform{ padding:24px 20px; } }
.qform-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.field--full{ grid-column:1/-1; }
@media (max-width:640px){ .qform-grid{ grid-template-columns:1fr; } .field--full{ grid-column:auto; } }

.field label{
  display:block; font-size:13px; font-weight:600; color:var(--ink);
  margin-bottom:8px;
}
.field .req{ color:var(--teal); margin-left:2px; }
.field .opt{
  display:inline-block; font-size:11px; font-weight:500; color:var(--steel);
  background:#F2F5F6; padding:2px 8px; border-radius:2px; margin-left:6px;
}
.field input[type=text],
.field input[type=tel],
.field input[type=email],
.field textarea{
  width:100%; padding:12px 14px;
  border:1px solid var(--hairline); border-radius:var(--r-sm);
  font-size:15px; color:var(--ink); background:#fff;
  font-family:inherit; transition:border-color .15s, box-shadow .15s;
}
.field input:focus,
.field textarea:focus{
  outline:none; border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(14,165,165,.15);
}
.field textarea{ resize:vertical; line-height:1.6; }
.field input::placeholder, .field textarea::placeholder{ color:var(--steel); }

.chk-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:10px;
}
@media (min-width:640px){ .chk-grid{ grid-template-columns:repeat(3,1fr); } }
.chk{
  display:flex; align-items:center; gap:10px;
  padding:12px 14px; border:1px solid var(--hairline); border-radius:var(--r-sm);
  cursor:pointer; transition:all .15s; font-size:14px; color:var(--charcoal);
}
.chk:hover{ border-color:var(--teal); }
.chk input{ accent-color:var(--teal); }
.chk:has(input:checked){ border-color:var(--teal); background:#F0FAFA; color:var(--ink); font-weight:500; }
.chk--privacy{ padding:14px 16px; background:#FAFCFC; }

.qform-success{ text-align:center; padding:40px 20px; }
.qform-success .ok-icon{
  width:72px; height:72px; border-radius:50%;
  background:var(--teal); color:#fff;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
}
.qform-success h3{ font-size:22px; margin:0 0 12px; color:var(--ink); }
.qform-success p{ font-size:15px; color:var(--charcoal); line-height:1.7; margin:0; }
.qform-success a{ color:var(--teal); font-weight:600; }

.notes{
  background:#fff; border-left:3px solid var(--teal);
  padding:24px 28px;
}
.notes h3{ font-size:15px; margin:0 0 14px; color:var(--ink); font-weight:700; letter-spacing:.02em; }
.notes ul{ margin:0; padding-left:20px; display:flex; flex-direction:column; gap:8px; }
.notes li{ font-size:14px; color:var(--charcoal); line-height:1.7; }
.notes strong{ color:var(--ink); font-weight:600; }

/* ===== Location page ===== */
.loc-grid{
  display:grid; grid-template-columns:1fr; gap:32px; align-items:start;
}
@media (min-width:900px){ .loc-grid{ grid-template-columns:1fr 1.4fr; gap:48px; } }

.loc-info{ display:flex; flex-direction:column; gap:28px; }
.loc-block{ padding-bottom:24px; border-bottom:1px solid var(--hairline); }
.loc-block:last-of-type{ border-bottom:0; }
.loc-block .kicker{
  font-family:ui-monospace,Menlo,monospace;
  font-size:11px; letter-spacing:.12em; color:var(--teal); text-transform:uppercase;
}
.loc-block h3{ font-size:13px; color:var(--steel); margin:6px 0 10px; font-weight:600; letter-spacing:.02em; }
.loc-block p{ font-size:16px; color:var(--ink); line-height:1.7; margin:0; }

.map-frame{
  position:relative; aspect-ratio:4/3;
  background:#EAF2F4;
  border:1px solid var(--hairline); border-radius:var(--r-md); overflow:hidden;
}
.map-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(15,42,48,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,42,48,.06) 1px, transparent 1px);
  background-size:32px 32px;
}
.map-roads{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, transparent 0 calc(50% - 18px), #fff calc(50% - 18px) calc(50% + 18px), transparent calc(50% + 18px) 100%),
    linear-gradient(180deg, transparent 0 calc(35% - 12px), #fff calc(35% - 12px) calc(35% + 12px), transparent calc(35% + 12px) 100%),
    linear-gradient(180deg, transparent 0 calc(72% - 8px), #fff calc(72% - 8px) calc(72% + 8px), transparent calc(72% + 8px) 100%);
}
.map-pin-big{
  position:absolute; left:50%; top:48%; transform:translate(-50%,-100%);
  display:flex; flex-direction:column; align-items:center;
}
.pin-dot{
  width:24px; height:24px; border-radius:50%;
  background:var(--teal);
  box-shadow:0 0 0 8px rgba(14,165,165,.22), 0 0 0 18px rgba(14,165,165,.10);
  position:relative; margin-bottom:10px;
}
.pin-dot::after{
  content:""; position:absolute; left:50%; bottom:-10px; transform:translateX(-50%);
  width:0; height:0; border-left:8px solid transparent; border-right:8px solid transparent;
  border-top:10px solid var(--teal);
}
.pin-card{
  background:#fff; border:1px solid var(--hairline); border-radius:var(--r-sm);
  padding:10px 14px; box-shadow:0 6px 18px rgba(15,42,48,.12);
  display:flex; flex-direction:column; gap:2px; min-width:200px; text-align:center;
  transform:translateY(-6px);
}
.pin-card strong{ font-size:14px; color:var(--ink); font-weight:700; }
.pin-card span{ font-size:12px; color:var(--steel); }

.map-overlay{
  position:absolute; right:14px; bottom:14px;
}
.btn--sm{ padding:8px 14px; font-size:13px; }

/* History grid */
.history-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px;}
.history-item{display:flex;gap:24px;align-items:center;padding:24px 28px;border:1px solid var(--line);background:#fff;}
.history-item .hy{font-size:22px;font-weight:700;color:var(--brand);letter-spacing:0.02em;font-variant-numeric:tabular-nums;min-width:64px;}
.history-item .hc{display:flex;flex-direction:column;gap:4px;}
.history-item .hc strong{font-size:16px;font-weight:600;color:var(--ink);}
.history-item .hc span{font-size:14px;color:var(--ink-3);}
@media (max-width: 768px){
  .history-grid{grid-template-columns:1fr;gap:10px;}
  .history-item{padding:18px 20px;gap:16px;}
  .history-item .hy{font-size:18px;min-width:50px;}
}

/* Product detail image */
.pdetail .img{padding:0;overflow:hidden;background:#f3f6f7;border:1px solid var(--hairline);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;}
.pdetail .img img{width:100%;height:100%;object-fit:cover;display:block;}

/* Product preview card image */
.pcard .ph{padding:0;overflow:hidden;aspect-ratio:4/3;background:#f3f6f7;}
.pcard .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;}
.pcard:hover .ph img{transform:scale(1.04);}

/* Certificate image */
.cert-img{padding:0;overflow:hidden;background:#f3f6f7;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--hairline);}
.cert-img img{width:100%;height:100%;object-fit:contain;display:block;background:#fff;}

/* Facility wide image */
.ph-img--wide{padding:0;overflow:hidden;background:#0a0f12;aspect-ratio:16/9;position:relative;}
.ph-img--wide img{width:100%;height:100%;object-fit:cover;display:block;}
