/* ============================================================
   GEXYRAL DPP public pages
   Scope: /dpp public layout + /dpp/passport.php report page
   Version: 20260516-dpp-report-v1
============================================================ */
.dpp-page{
  --dpp-max:1280px;
  --dpp-gap:16px;
  --dpp-card:#ffffff;
  --dpp-soft:#f8fafc;
  --dpp-line:#e2e8f0;
  --dpp-ink:#0f172a;
  --dpp-muted:#64748b;
  --dpp-blue:#2563eb;
  --dpp-green:#059669;
  --dpp-amber:#d97706;
  --dpp-shadow:0 18px 48px rgba(15,23,42,.075);
}
.dpp-page .gx-header__inner,
.dpp-shell,
.dpp-public-nav{
  width:min(var(--dpp-max),calc(100% - 32px));
  margin-left:auto;
  margin-right:auto;
}
.dpp-shell{padding:18px 0 56px;}
.dpp-public-nav{margin-top:14px;}
.dpp-page .gx-header__inner{gap:16px;}
.dpp-page .dpp-header-nav{justify-content:center;gap:4px;}
.dpp-page .dpp-header-nav>a{
  height:38px;
  padding:0 11px;
  font-size:13px;
  border-radius:999px;
  color:#334155;
}
.dpp-page .dpp-header-nav>a:hover,
.dpp-page .dpp-header-nav>a.is-active{
  background:#eef6ff;
  color:#1d4ed8;
  box-shadow:inset 0 0 0 1px #bfdbfe;
}

/* DPP public entrance navigation */
.gex-dpp-linkbox{
  width:100%;
  margin:0 auto 18px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(226,232,240,.96);
  border-radius:22px;
  box-shadow:0 14px 34px rgba(15,23,42,.06);
  padding:16px;
}
.gex-dpp-linkbox-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:12px;}
.gex-dpp-linkbox-title{margin:0;font-size:16px;font-weight:900;color:#111827;letter-spacing:-.01em;}
.gex-dpp-linkbox-desc{margin:5px 0 0;color:#64748b;line-height:1.65;font-size:13px;max-width:820px;}
.gex-dpp-linkbox-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;}
.gex-dpp-linkbox a,
.gex-dpp-linkbox span.gex-dpp-disabled{
  display:flex;
  flex-direction:column;
  gap:5px;
  min-height:74px;
  text-decoration:none;
  border:1px solid #e5e7eb;
  border-radius:16px;
  padding:13px 14px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  color:#111827;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease;
}
.gex-dpp-linkbox a:hover{transform:translateY(-2px);border-color:#93c5fd;background:#eff6ff;box-shadow:0 12px 24px rgba(37,99,235,.08);}
.gex-dpp-linkbox .active{border-color:#2563eb;background:#eff6ff;box-shadow:inset 0 0 0 1px rgba(37,99,235,.12);}
.gex-dpp-linkbox .gex-dpp-disabled{opacity:.58;cursor:not-allowed;}
.gex-dpp-linkbox-label{display:block;font-weight:900;font-size:14px;line-height:1.25;}
.gex-dpp-linkbox-small{display:block;color:#64748b;line-height:1.45;font-size:12px;}
.gex-dpp-linkbox-hint{display:block;margin-top:2px;color:#9a3412;font-size:12px;}

/* Published DPP report */
.dpp-public-report{display:grid;gap:16px;}
.dpp-report-hero{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);
  gap:18px;
  align-items:stretch;
  background:linear-gradient(135deg,#f0fdf4 0%,#ffffff 52%,#eff6ff 100%);
  border:1px solid #bbf7d0;
  border-radius:28px;
  box-shadow:var(--dpp-shadow);
  padding:24px;
  margin:0 0 2px;
}
.dpp-report-hero h1{font-size:clamp(28px,3.2vw,46px);line-height:1.08;margin:12px 0 12px;letter-spacing:-.04em;color:#0f172a;max-width:820px;}
.dpp-report-hero .dpp-subtitle{font-size:15px;line-height:1.82;color:#475569;max-width:820px;}
.dpp-report-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.dpp-report-hero__status{display:grid;gap:12px;}
.dpp-status-ribbon{
  border-radius:22px;
  padding:16px;
  border:1px solid #fed7aa;
  background:#fff7ed;
  color:#92400e;
}
.dpp-status-ribbon--ok{border-color:#bbf7d0;background:#ecfdf5;color:#065f46;}
.dpp-status-ribbon span{display:inline-flex;border-radius:999px;padding:4px 9px;background:rgba(255,255,255,.72);font-size:12px;font-weight:900;border:1px solid currentColor;opacity:.86;}
.dpp-status-ribbon strong{display:block;margin:10px 0 6px;font-size:19px;line-height:1.3;color:inherit;}
.dpp-status-ribbon em{display:block;font-style:normal;font-size:13px;line-height:1.65;color:inherit;opacity:.88;}
.dpp-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.dpp-kpi-card{background:rgba(255,255,255,.88);border:1px solid rgba(226,232,240,.95);border-radius:18px;padding:14px;box-shadow:0 10px 24px rgba(15,23,42,.045);}
.dpp-kpi-card span{display:block;font-size:12px;font-weight:850;color:#64748b;margin-bottom:7px;}
.dpp-kpi-card strong{display:block;font-size:30px;line-height:1.05;color:#0f172a;letter-spacing:-.035em;}
.dpp-kpi-card small{font-size:15px;color:#64748b;margin-left:3px;}
.dpp-kpi-card em{display:block;font-style:normal;font-size:12px;color:#64748b;margin-top:7px;line-height:1.45;}
.dpp-report-overview{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:stretch;}
.dpp-report-card{margin:0;}
.dpp-section-head span,.dpp-tabs-head span{display:inline-flex;border-radius:999px;padding:5px 9px;background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;font-size:12px;font-weight:900;}
.dpp-section-head h2,.dpp-tabs-head h2{margin:9px 0 11px;font-size:clamp(18px,2vw,24px);line-height:1.25;color:#0f172a;}
.dpp-note-ok{background:#ecfdf5;border-color:#bbf7d0;color:#065f46;}
.dpp-mini-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px;}
.dpp-mini-list>div,.dpp-info-list>div{border:1px solid #edf2f7;background:#f8fafc;border-radius:15px;padding:12px;min-width:0;}
.dpp-mini-list span,.dpp-info-list span{display:block;font-size:12px;color:#64748b;margin-bottom:5px;}
.dpp-mini-list strong,.dpp-info-list strong{display:block;color:#0f172a;font-size:14px;line-height:1.45;word-break:break-word;}
.dpp-info-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.dpp-tabs-card{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:26px;box-shadow:var(--dpp-shadow);padding:18px;}
.dpp-tabs-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;padding:2px 2px 14px;border-bottom:1px solid #edf2f7;margin-bottom:14px;}
.dpp-tabs-head p{margin:0;color:#64748b;font-size:13px;line-height:1.65;max-width:520px;}
.dpp-tab-nav{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-bottom:16px;}
.dpp-tab-nav button{appearance:none;border:1px solid #dbe3ef;background:#f8fafc;color:#334155;border-radius:15px;padding:11px 10px;font-size:13px;font-weight:900;line-height:1.2;cursor:pointer;transition:.18s ease;}
.dpp-tab-nav button:hover{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8;}
.dpp-tab-nav button.is-active{background:#0f172a;border-color:#0f172a;color:#fff;box-shadow:0 12px 24px rgba(15,23,42,.16);}
.dpp-tab-panel{display:none;animation:dppFadeIn .18s ease;}
.dpp-tab-panel.is-active{display:block;}
@keyframes dppFadeIn{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}}
.dpp-panel-grid{display:grid;gap:14px;}
.dpp-panel-block{border:1px solid #edf2f7;border-radius:20px;background:#fbfdff;padding:15px;}
.dpp-panel-block h3{margin:0 0 12px;font-size:16px;line-height:1.35;color:#0f172a;}
.dpp-empty-text{margin:0;color:#64748b;line-height:1.75;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:16px;padding:16px;}
.dpp-unified-status-wrap{margin-top:14px;}
.dpp-disclaimer-box{margin-top:14px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:18px;padding:15px;line-height:1.68;}
.dpp-disclaimer-box strong{display:block;margin-bottom:8px;color:#78350f;}
.dpp-disclaimer-box p{margin:6px 0 0;}

/* Width consistency and cards */
.dpp-page .dpp-card,
.dpp-page .dpp-hero,
.dpp-page .card,
.dpp-page .hero{box-shadow:var(--dpp-shadow);}
.dpp-page .dpp-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));}

@media(max-width:1180px){
  .gex-dpp-linkbox-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .dpp-report-hero{grid-template-columns:1fr;}
  .dpp-report-overview{grid-template-columns:1fr;}
  .dpp-tab-nav{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media(max-width:900px){
  .dpp-page .dpp-header-nav{display:none;}
  .dpp-tabs-head{display:block;}
  .dpp-tabs-head p{margin-top:6px;max-width:none;}
}
@media(max-width:720px){
  .dpp-page .gx-header__inner,
  .dpp-shell,
  .dpp-public-nav{width:calc(100% - 22px);}
  .dpp-shell{padding:14px 0 44px;}
  .dpp-public-nav{margin-top:10px;overflow:visible;display:block;white-space:normal;padding-bottom:0;}
  .gex-dpp-linkbox{border-radius:18px;padding:13px;margin-bottom:12px;}
  .gex-dpp-linkbox-head{display:block;margin-bottom:10px;}
  .gex-dpp-linkbox-desc{font-size:12px;}
  .gex-dpp-linkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
  .gex-dpp-linkbox a,.gex-dpp-linkbox span.gex-dpp-disabled{min-height:auto;padding:11px;border-radius:14px;}
  .gex-dpp-linkbox-small{display:none;}
  .dpp-report-hero{padding:16px;border-radius:22px;gap:14px;}
  .dpp-report-hero h1{font-size:clamp(24px,8vw,34px);}
  .dpp-report-actions .dpp-btn{width:100%;}
  .dpp-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .dpp-kpi-card{padding:12px;border-radius:16px;}
  .dpp-kpi-card strong{font-size:25px;}
  .dpp-mini-list,.dpp-info-list{grid-template-columns:1fr;}
  .dpp-tabs-card{padding:14px;border-radius:22px;}
  .dpp-tab-nav{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
  .dpp-tab-nav button{padding:12px 8px;border-radius:14px;}
  .dpp-page .dpp-grid{grid-template-columns:1fr;}
}
@media(max-width:430px){
  .dpp-page .gx-header__inner,
  .dpp-shell,
  .dpp-public-nav{width:calc(100% - 16px);}
  .gex-dpp-linkbox-grid{grid-template-columns:1fr 1fr;}
  .dpp-report-hero,.dpp-tabs-card,.dpp-card{border-radius:18px;}
}

/* Demo DPP report sync */
.gx-demo-dpp-report .gx-demo-field-meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:10px;
}
.gx-demo-dpp-report .gx-demo-field-meta span{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:4px 8px;
  background:#eef6ff;
  color:#1d4ed8;
  border:1px solid #bfdbfe;
  font-size:11px;
  font-weight:850;
  line-height:1.2;
}
.gx-demo-dpp-report .gx-demo-field-card .dpp-value{
  font-weight:760;
  line-height:1.58;
}
@media(max-width:720px){
  .gx-demo-dpp-report .gx-demo-field-meta span{font-size:10px;padding:4px 7px;}
}

/* Demo DPP safe in-page navigation */
.gx-demo-dpp-navbox{
  width:100%;
  margin:0 auto 18px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(226,232,240,.96);
  border-radius:24px;
  box-shadow:0 14px 34px rgba(15,23,42,.06);
  padding:18px;
}
.gx-demo-dpp-navbox__head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px;}
.gx-demo-dpp-navbox__head span,.gx-demo-dpp-navgroup__title{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:5px 10px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1d4ed8;
  font-size:12px;
  font-weight:900;
}
.gx-demo-dpp-navbox__head h2{margin:9px 0 6px;font-size:18px;line-height:1.25;color:#0f172a;letter-spacing:-.01em;}
.gx-demo-dpp-navbox__head p{margin:0;color:#64748b;font-size:13px;line-height:1.68;max-width:860px;}
.gx-demo-dpp-navgroup{display:grid;gap:10px;margin-top:12px;}
.gx-demo-dpp-navgroup--tech{padding-top:12px;border-top:1px dashed #e2e8f0;}
.gx-demo-dpp-navgroup__title{width:max-content;background:#f8fafc;color:#475569;border-color:#e2e8f0;}
.gx-demo-dpp-navgrid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;}
.gx-demo-dpp-navgrid--tech{grid-template-columns:repeat(4,minmax(0,1fr));}
.gx-demo-dpp-navitem{
  appearance:none;
  -webkit-appearance:none;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  gap:6px;
  width:100%;
  min-height:82px;
  text-align:left;
  text-decoration:none;
  border:1px solid #e5e7eb;
  border-radius:16px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  color:#111827;
  padding:13px 14px;
  cursor:pointer;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease;
}
.gx-demo-dpp-navitem:hover{transform:translateY(-2px);border-color:#93c5fd;background:#eff6ff;box-shadow:0 12px 24px rgba(37,99,235,.08);}
.gx-demo-dpp-navitem strong{font-size:14px;line-height:1.25;font-weight:900;}
.gx-demo-dpp-navitem span{font-size:12px;line-height:1.45;color:#64748b;}
.gx-demo-dpp-navitem:focus-visible{outline:3px solid rgba(37,99,235,.22);outline-offset:2px;}
.gx-demo-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:18px;}
.gx-demo-modal.is-open{display:flex;}
.gx-demo-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.48);backdrop-filter:blur(5px);}
.gx-demo-modal__panel{position:relative;width:min(520px,100%);background:#fff;border:1px solid #e2e8f0;border-radius:24px;box-shadow:0 30px 90px rgba(15,23,42,.24);padding:22px;}
.gx-demo-modal__badge{display:inline-flex;border-radius:999px;padding:5px 10px;background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;font-size:12px;font-weight:900;}
.gx-demo-modal__panel h3{margin:12px 38px 8px 0;font-size:20px;line-height:1.28;color:#0f172a;letter-spacing:-.02em;}
.gx-demo-modal__panel p{margin:0;color:#475569;line-height:1.76;font-size:14px;}
.gx-demo-modal__close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;font-size:22px;line-height:1;cursor:pointer;}
body.gx-demo-modal-open{overflow:hidden;}
@media(max-width:980px){
  .gx-demo-dpp-navgrid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .gx-demo-dpp-navgrid--tech{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:720px){
  .gx-demo-dpp-navbox{border-radius:18px;padding:13px;margin-bottom:12px;}
  .gx-demo-dpp-navbox__head{display:block;margin-bottom:10px;}
  .gx-demo-dpp-navbox__head h2{font-size:16px;}
  .gx-demo-dpp-navbox__head p{font-size:12px;}
  .gx-demo-dpp-navgrid,.gx-demo-dpp-navgrid--tech{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
  .gx-demo-dpp-navitem{min-height:auto;padding:12px;border-radius:14px;}
  .gx-demo-dpp-navitem span{display:none;}
  .gx-demo-modal{align-items:flex-end;padding:0;}
  .gx-demo-modal__panel{width:100%;border-radius:24px 24px 0 0;padding:20px 18px calc(20px + env(safe-area-inset-bottom));max-height:76vh;overflow:auto;}
}
