/* Granite Peak Roast — packaging viewer. Scoped case-brand styles; zero Lofty tokens. */
:root {
  --gr: #3b3a36;
  --sn: #f2ede4;
  --kraft: #c9b896;
  --band: #a9542f; /* the one plate that swaps */
}
* { box-sizing: border-box; margin: 0; }
body {
  font-family: "Arial Narrow", -apple-system, "Segoe UI", sans-serif;
  background: var(--sn);
  color: var(--gr);
  line-height: 1.55;
}
h1, h2, h3 { font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
:focus-visible { outline: 3px solid var(--gr); outline-offset: 2px; }

.gp-header { text-align: center; padding: 44px 24px 26px; border-bottom: 3px solid var(--gr); }
.gp-mark { width: 110px; display: block; margin: 0 auto 8px; }
.gp-header h1 { font-size: 26px; letter-spacing: 0.12em; }
.gp-sub { font-size: 14px; opacity: 0.8; }

.gp-section { max-width: 880px; margin: 0 auto; padding: 40px 24px; border-bottom: 1px solid rgba(59,58,54,.3); }
.gp-section h2 { font-size: 19px; margin-bottom: 14px; }

.gp-controls { display: flex; gap: 28px; flex-wrap: wrap; margin-bottom: 22px; }
.gp-ctrl-label { display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 6px; }
.gp-btnrow { display: flex; gap: 6px; flex-wrap: wrap; }
.gp-btn {
  font: 700 13px/1 "Arial Narrow", sans-serif;
  letter-spacing: 0.04em;
  padding: 11px 14px;
  background: #fff;
  border: 2px solid var(--gr);
  color: var(--gr);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.gp-btn[data-roast]::before { content: ""; width: 12px; height: 12px; background: var(--chip); border: 1px solid var(--gr); }
.gp-btn.is-on { background: var(--gr); color: var(--sn); }

/* ---------- the 3D bag ---------- */
.gp-stage { perspective: 1100px; display: grid; place-items: center; padding: 10px 0 6px; }
.gp-bag {
  position: relative;
  width: 240px;
  height: 320px;
  transform-style: preserve-3d;
  transition: transform 0.7s cubic-bezier(0.3, 0.9, 0.3, 1);
}
.gp-bag[data-face="front"] { transform: rotateY(0deg); }
.gp-bag[data-face="back"] { transform: rotateY(180deg); }
@media (prefers-reduced-motion: reduce) { .gp-bag { transition: none; } }
.gp-face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  background: var(--kraft);
  border: 2px solid var(--gr);
  border-radius: 6px 6px 10px 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-shadow: 8px 10px 0 rgba(59, 58, 54, 0.25);
}
.gp-back { transform: rotateY(180deg); padding: 22px 18px; align-items: stretch; }
.gp-band {
  width: 100%;
  background: var(--band);
  text-align: left;
  padding: 9px 0 9px 14px; /* roast name sits left of the centered crest patch */
  margin-top: 54px;
  transition: background 0.3s;
}
.gp-band span { color: var(--sn); font-weight: 700; font-size: 15px; letter-spacing: 0.1em; }
.gp-crest { width: 120px; margin-top: -96px; background: var(--kraft); position: relative; z-index: 2; padding: 6px 10px 0; }
.gp-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 46px;
  height: 46px;
  border: 2px solid var(--gr);
  border-radius: 50%;
  background: var(--sn);
  display: grid;
  place-content: center;
  line-height: 1;
  font-weight: 700;
  font-size: 12px;
  text-align: center;
}
.gp-badge span:last-child { font-size: 9px; letter-spacing: 0.18em; }
.gp-origin { margin-top: 84px; font-size: 12px; opacity: 0.85; }
.gp-contours {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 110px;
  opacity: 0.25;
  background:
    radial-gradient(140% 90px at 50% 130%, transparent 54px, var(--gr) 54px, var(--gr) 56px, transparent 56px),
    radial-gradient(140% 110px at 50% 140%, transparent 70px, var(--gr) 70px, var(--gr) 72px, transparent 72px),
    radial-gradient(140% 130px at 50% 150%, transparent 86px, var(--gr) 86px, var(--gr) 88px, transparent 88px);
}
.gp-back h3 { font-size: 14px; margin-bottom: 10px; }
.gp-ladder { list-style: none; padding: 0; margin: 0 0 16px; }
.gp-ladder li { display: flex; justify-content: space-between; font-size: 12.5px; padding: 7px 0; border-bottom: 1px dashed var(--gr); }
.gp-mapzone { border: 2px dashed var(--gr); padding: 12px; text-align: center; font-size: 11px; }
.gp-roastdate { margin-top: 6px; opacity: 0.8; }
.gp-note { margin-top: 16px; font-size: 13.5px; max-width: 56ch; }

/* ---------- zooms ---------- */
.gp-zoom { margin: 18px 0 0; border: 2px solid var(--gr); background: #fff; }
.gp-zoom-art { height: 200px; background: var(--kraft); display: grid; place-items: center; position: relative; overflow: hidden; }
.gp-zoom figcaption { padding: 12px 16px; font-size: 13px; border-top: 2px solid var(--gr); }

/* ---------- shelf ---------- */
.gp-shelf { display: grid; gap: 18px; margin-top: 16px; }
.gp-shelf-row {
  display: flex;
  gap: 10px;
  align-items: end;
  padding: 12px;
  background: #fff;
  border: 2px solid var(--gr);
  border-bottom-width: 8px;
}
.gp-mini { width: 72px; height: 104px; border: 1.5px solid var(--gr); border-radius: 3px 3px 6px 6px; position: relative; display: grid; place-items: end center; padding-bottom: 6px; }
.gp-mini span { font-size: 9px; font-weight: 700; letter-spacing: 0.08em; }
.gp-mini-nat { background: #26211f; }
.gp-mini-nat2 { background: #3d2c28; }
.gp-mini-kraft { background: var(--kraft); color: var(--gr); }
.gp-mini-new { background: var(--kraft); color: var(--gr); }
.gp-mini-new::before {
  content: "";
  position: absolute;
  top: 26px;
  left: 0;
  right: 0;
  height: 18px;
  background: var(--band);
}
.gp-mini-new::after {
  content: "";
  position: absolute;
  top: 4px;
  left: 50%;
  translate: -50% 0;
  width: 34px;
  height: 20px;
  background:
    linear-gradient(45deg, transparent 44%, var(--gr) 44%, var(--gr) 56%, transparent 56%) left 4px bottom / 16px 14px no-repeat,
    linear-gradient(-45deg, transparent 44%, var(--gr) 44%, var(--gr) 56%, transparent 56%) right 4px bottom / 16px 14px no-repeat;
}

.gp-footer { text-align: center; padding: 26px; font-size: 12px; opacity: 0.75; }
