@charset "utf-8";

body{
  background:var(--jh-bg, #f6f7f9);
}

.p-privacy{
  padding:0 14px calc(76px + env(safe-area-inset-bottom));
}

.pv-hero{
  margin:12px 0 12px;
  padding:24px 20px 20px;
  border:1px solid #e5e7eb;
  border-radius:24px;
  background:linear-gradient(135deg, #fff 0%, #f7fbff 100%);
  box-shadow:0 10px 28px rgba(15, 23, 42, .06);
}
.pv-kicker{
  margin:0 0 8px;
  color:#2563eb;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
}
.pv-hero h1{
  margin:0;
  color:#111827;
  font-size:27px;
  line-height:1.18;
  letter-spacing:-.045em;
}
.pv-hero__desc{
  margin:12px 0 0;
  color:#4b5563;
  font-size:14px;
  font-weight:600;
  line-height:1.75;
  word-break:keep-all;
}
.pv-date{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
  margin:18px 0 0;
}
.pv-date>div{
  display:grid;
  gap:4px;
  padding:12px;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:#fff;
}
.pv-date dt{
  color:#6b7280;
  font-size:11px;
  font-weight:800;
}
.pv-date dd{
  margin:0;
  color:#111827;
  font-size:13px;
  font-weight:900;
}

.pv-summary{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
  margin:0 0 12px;
}
.pv-summary-card{
  min-width:0;
  padding:14px;
  border:1px solid #e5e7eb;
  border-radius:18px;
  background:#fff;
}
.pv-summary-card .material-symbols-outlined{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  margin-bottom:10px;
  border-radius:12px;
  background:#eff6ff;
  color:#2563eb;
  font-size:20px;
}
.pv-summary-card strong{
  display:block;
  color:#111827;
  font-size:13px;
  font-weight:900;
  letter-spacing:-.025em;
}
.pv-summary-card p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12px;
  font-weight:600;
  line-height:1.55;
  word-break:keep-all;
}

.pv-anchor{
  position:sticky;
  top:calc(54px + env(safe-area-inset-top));
  z-index:20;
  display:flex;
  gap:8px;
  margin:0 -14px 14px;
  padding:8px 14px;
  overflow-x:auto;
  background:rgba(246, 247, 249, .92);
  backdrop-filter:blur(10px);
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.pv-anchor::-webkit-scrollbar{display:none;}
.pv-anchor a{
  flex:0 0 auto;
  padding:9px 12px;
  border:1px solid #e5e7eb;
  border-radius:999px;
  background:#fff;
  color:#374151;
  font-size:12px;
  font-weight:900;
  text-decoration:none;
  white-space:nowrap;
}

.pv-card{
  scroll-margin-top:112px;
  margin:0 0 12px;
  padding:18px;
  border:1px solid #e5e7eb;
  border-radius:22px;
  background:#fff;
  box-shadow:0 8px 22px rgba(15, 23, 42, .045);
}
.pv-intro{
  display:grid;
  gap:8px;
  border-color:#dbeafe;
  background:#f8fbff;
}
.pv-card p{
  margin:0;
  color:#374151;
  font-size:14px;
  font-weight:600;
  line-height:1.75;
  word-break:keep-all;
}
.pv-card p + p{margin-top:10px;}
.pv-card__head{
  display:grid;
  grid-template-columns:auto minmax(0, 1fr);
  align-items:start;
  gap:10px;
  margin:0 0 12px;
}
.pv-section-num{
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  margin:0;
  border-radius:12px;
  background:#111827;
  color:#fff !important;
  font-size:12px !important;
  font-weight:900 !important;
  line-height:1 !important;
}
.pv-card h2{
  margin:2px 0 0;
  color:#111827;
  font-size:19px;
  line-height:1.35;
  letter-spacing:-.04em;
}
.pv-card__desc{
  margin-bottom:12px !important;
  color:#4b5563 !important;
}

.pv-table-wrap{
  margin-top:12px;
  overflow:auto;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:#fff;
  -webkit-overflow-scrolling:touch;
}
.pv-table{
  width:100%;
  min-width:860px;
  border-collapse:separate;
  border-spacing:0;
}
.pv-table--compact{min-width:680px;}
.pv-table th,
.pv-table td{
  padding:13px 12px;
  border-bottom:1px solid #edf0f4;
  border-right:1px solid #edf0f4;
  vertical-align:top;
  color:#374151;
  font-size:12px;
  font-weight:600;
  line-height:1.65;
  word-break:keep-all;
}
.pv-table thead th{
  position:sticky;
  top:0;
  z-index:1;
  background:#f9fafb;
  color:#111827;
  font-weight:900;
  text-align:left;
}
.pv-table tbody th{
  width:140px;
  background:#fcfcfd;
  color:#111827;
  font-weight:900;
  text-align:left;
}
.pv-table tr:last-child th,
.pv-table tr:last-child td{border-bottom:0;}
.pv-table th:last-child,
.pv-table td:last-child{border-right:0;}

.pv-note-list,
.pv-browser-box ul{
  display:grid;
  gap:8px;
  margin:14px 0 0;
  padding:0;
  list-style:none;
}
.pv-note-list li,
.pv-browser-box li{
  position:relative;
  padding-left:15px;
  color:#4b5563;
  font-size:13px;
  font-weight:600;
  line-height:1.65;
  word-break:keep-all;
}
.pv-note-list li::before,
.pv-browser-box li::before{
  content:"";
  position:absolute;
  left:0;
  top:.7em;
  width:5px;
  height:5px;
  border-radius:50%;
  background:#2563eb;
}

.pv-consign-list{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.pv-consign{
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:#fcfcfd;
}
.pv-consign strong{
  color:#111827;
  font-size:14px;
  font-weight:900;
}
.pv-consign dl,
.pv-officer{
  display:grid;
  gap:8px;
  margin:0;
}
.pv-consign dl>div,
.pv-officer>div{
  display:grid;
  grid-template-columns:82px minmax(0, 1fr);
  gap:10px;
  align-items:start;
}
.pv-consign dt,
.pv-officer dt{
  color:#6b7280;
  font-size:12px;
  font-weight:900;
}
.pv-consign dd,
.pv-officer dd{
  margin:0;
  color:#374151;
  font-size:13px;
  font-weight:700;
  line-height:1.55;
  word-break:keep-all;
}
.pv-officer a{color:#2563eb;text-decoration:none;}
.pv-callout{
  margin-top:14px !important;
  padding:12px 14px;
  border:1px solid #fde68a;
  border-radius:16px;
  background:#fffbeb;
  color:#92400e !important;
  font-size:13px !important;
}

.pv-ordered{
  display:grid;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
  counter-reset:pvOrder;
}
.pv-ordered li{
  counter-increment:pvOrder;
  display:grid;
  grid-template-columns:34px minmax(0, 1fr);
  gap:10px;
  padding:13px;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:#fcfcfd;
}
.pv-ordered li::before{
  content:counter(pvOrder);
  grid-column:1;
  grid-row:1 / span 2;
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  border-radius:10px;
  background:#eff6ff;
  color:#2563eb;
  font-size:12px;
  font-weight:900;
}
.pv-ordered b{
  grid-column:2;
  display:block;
  margin-bottom:4px;
  color:#111827;
  font-size:14px;
  font-weight:900;
}
.pv-ordered span{
  grid-column:2;
  min-width:0;
  color:#4b5563;
  font-size:13px;
  font-weight:600;
  line-height:1.65;
  word-break:keep-all;
}

.pv-chip-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:12px 0;
  padding:0;
  list-style:none;
}
.pv-chip-list li{
  padding:8px 11px;
  border-radius:999px;
  background:#eff6ff;
  color:#1d4ed8;
  font-size:12px;
  font-weight:900;
}

.pv-security-grid{
  display:grid;
  gap:10px;
}
.pv-security-grid article,
.pv-browser-box{
  padding:14px;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:#fcfcfd;
}
.pv-security-grid strong,
.pv-browser-box strong{
  display:block;
  margin-bottom:6px;
  color:#111827;
  font-size:14px;
  font-weight:900;
}
.pv-security-grid p{
  font-size:13px;
  line-height:1.65;
}
.pv-browser-box{
  margin:12px 0;
}
.pv-browser-box ul{margin-top:8px;}

.pv-remedy-list{
  display:grid;
  gap:9px;
  margin-top:12px;
}
.pv-remedy-list a{
  display:grid;
  gap:3px;
  padding:13px 14px;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:#fcfcfd;
  text-decoration:none;
}
.pv-remedy-list b{
  color:#111827;
  font-size:14px;
  font-weight:900;
}
.pv-remedy-list span{
  color:#4b5563;
  font-size:12px;
  font-weight:700;
}

.pv-history{
  display:grid;
  gap:8px;
  margin-top:12px;
  padding:14px;
  border-radius:16px;
  background:#f9fafb;
}
.pv-history span{
  color:#374151;
  font-size:13px;
  font-weight:800;
}
.pv-history a{
  color:#2563eb;
  font-size:13px;
  font-weight:900;
  text-decoration:none;
}

@media (min-width: 768px){
  .p-privacy{
    max-width:920px;
    margin:0 auto;
    padding:24px 24px 96px;
  }
  .pv-hero{padding:32px;}
  .pv-hero h1{font-size:34px;}
  .pv-summary{grid-template-columns:repeat(4, minmax(0, 1fr));}
  .pv-anchor{top:0;margin-left:-24px;margin-right:-24px;padding-left:24px;padding-right:24px;}
  .pv-card{padding:24px;}
  .pv-security-grid{grid-template-columns:repeat(3, minmax(0, 1fr));}
}
