:root{
  --pm-navy:#0B1B3A;
  --pm-navy2:#07152f;
  --pm-white:#ffffff;
  --pm-line:rgba(255,255,255,.15);
  --pm-pill:rgba(255,255,255,.12);
  --pm-btn:#4C82FF;
  --pm-btnGhost:rgba(255,255,255,.12);
}

.pm-wrap{ max-width: 1440px; margin: 0 auto; padding: 18px 0; }

.pm-hero{
  background: var(--pm-navy);
  padding: 32px 24px 28px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.12);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.pm-logo img{
  width: 190px;
  display: block;
  margin: 0 auto 18px;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,0.22));
}

.pm-title{ max-width: 980px; margin: 0 auto 10px; }

.pm-title h1{
  margin: 0;
  font-size: clamp(46px, 5vw, 82px);
  letter-spacing: 0.12em;
  font-weight: 950;
  text-transform: uppercase;
  color: var(--pm-white);
}

.pm-tagline{
  margin: 10px 0 0;
  font-size: clamp(18px, 2vw, 24px);
  opacity: 0.9;
  color: var(--pm-white);
}

.pm-dogstrip{
  margin: 28px auto 20px;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 14px;
  max-width: 1200px;
  align-items: end;
  transition: opacity 250ms ease;
}

.pm-fade{ opacity: 0.20; }

.pm-dog{ text-align: center; position: relative; }

.pm-dog img{
  width: 100%;
  height: 190px;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.15);
  box-shadow: 0 18px 45px rgba(0,0,0,0.25);
}

.pm-bandana{
  position: relative;
  margin: -36px auto 0;
  width: calc(100% - 20px);
  height: 40px;
  background: rgba(11,27,58,.80);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(6px);
}

.pm-bandana img{ max-height: 26px; max-width: 92%; object-fit: contain; }

.pm-dogname{
  margin-top: 10px;
  font-size: 14px;
  font-weight: 850;
  letter-spacing: 0.02em;
  opacity: 0.95;
  color: var(--pm-white);
}

.pm-cta{ display:flex; justify-content:center; margin-top: 8px; }

.pm-btn{
  padding: 14px 32px;
  font-size: 18px;
  border-radius: 999px;
  font-weight: 900;
  background: var(--pm-btn);
  border: none;
  color: var(--pm-white);
  cursor: pointer;
  box-shadow: 0 16px 45px rgba(0,0,0,0.25);
  transition: transform 120ms ease, filter 120ms ease;
}
.pm-btn:hover{ transform: translateY(-1px); filter: brightness(1.02); }
.pm-btn:active{ transform: translateY(0px); }

.pm-btn-ghost{ background: var(--pm-btnGhost); border: 1px solid rgba(255,255,255,0.14); box-shadow:none; }

/* Modal */
.pm-panel{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.60);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 18px;
  z-index: 9999;
}
.pm-panel[hidden]{ display:none; }

.pm-panel-inner{
  width: min(1000px, 96vw);
  background: var(--pm-navy2);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 22px;
  padding: 20px;
  box-shadow: 0 26px 70px rgba(0,0,0,0.45);
  color: var(--pm-white);
}

.pm-panel-inner h2{ margin: 4px 0 14px; font-size: 22px; letter-spacing: .01em; }

.pm-grid{ display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.pm-grid label{ display:flex; flex-direction:column; gap: 6px; font-weight: 800; opacity: 0.98; }
.pm-grid select{
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.20);
  background: rgba(255,255,255,0.07);
  color: white;
  outline: none;
}

.pm-actions{ display:flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }

.pm-results{ margin-top: 18px; }
.pm-tier{ margin: 18px 0 10px; font-weight: 950; letter-spacing: 0.02em; }

.pm-cards{ display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }

.pm-card{
  display:block;
  text-decoration:none;
  color:white;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 18px;
  overflow:hidden;
  background: rgba(255,255,255,0.06);
  transition: transform 120ms ease, filter 120ms ease;
}
.pm-card:hover{ transform: translateY(-1px); filter: brightness(1.02); }
.pm-card img{ width:100%; height:180px; object-fit:cover; display:block; }
.pm-cardbody{ padding: 12px; }
.pm-cardtitle{ font-weight: 950; font-size: 18px; letter-spacing:.01em; }
.pm-carddesc{ opacity: 0.90; margin-top: 6px; font-size: 14px; line-height: 1.35; }
.pm-cardcta{ margin-top: 10px; font-weight: 900; opacity: 0.95; }

.pm-flags{ display:flex; gap:8px; margin-top:10px; flex-wrap:wrap; }
.pm-flags span{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  background: var(--pm-pill);
  border: 1px solid rgba(255,255,255,0.16);
}

.pm-attribution{
  margin-top: 26px;
  padding-top: 14px;
  font-size: 13px;
  line-height: 1.5;
  opacity: 0.85;
  border-top: 1px solid var(--pm-line);
  text-align: center;
}
.pm-attribution a{ color: #9db8ff; font-weight: 800; text-decoration: none; }
.pm-attribution a:hover{ text-decoration: underline; }

@media (max-width: 1100px){
  .pm-dogstrip{
    display:flex;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    gap: 14px;
    padding-bottom: 10px;
  }
  .pm-dog{ min-width:160px; scroll-snap-align:start; }
  .pm-grid{ grid-template-columns: 1fr; }
  .pm-cards{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
