:root{
  --fg: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.62);
  --hair: rgba(255,255,255,.14);
  --pad: clamp(18px, 3vw, 42px);
  --radius: 18px;

  --paper: rgba(255,255,255,0.92);
  --paperInk: rgba(0,0,0,0.86);
  --paperMut: rgba(0,0,0,0.55);

  --canH: clamp(280px, 64vh, 760px);
  
  --paperSafeTop: 100px;
  --paperSafeRight: 56px;
  --paperSafeBottom: 44px;
  --paperSafeLeft: 56px;
}

@font-face {
  font-family: "InkToner";
  src: url('../assets/fonts/InktonerRegular.woff2?1') format('woff2'),
       url('../assets/fonts/InktonerRegular.woff?1') format('woff');
}
@font-face{
  font-family:"TCO Brau Mono";
  src:url("../assets/fonts/TCOBrauMono-Regular.woff2") format("woff2"),
      url("../assets/fonts/TCOBrauMono-Regular.woff") format("woff");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

*{ box-sizing:border-box; }
html, body{ height:100%; }

body{
  margin:0;
  color:var(--fg);
  font-family:"TCO Brau Mono", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background:#0b0b0c;
  overflow-x:hidden;
  background: #000 url("../assets/images/grainy_bg.jpg");
  background-size: cover;
  background-position: bottom center;
}

a{ color: var(--fg); text-decoration:none; }
a:hover{ text-decoration: underline; }

.bg{
  position:fixed;
  inset:0;
  z-index:0;
}
.bg__collage{
  position:absolute;
  inset:0;
  background: url("../assets/images/grainy_bg.jpg");
  background-size: cover;
  background-position: bottom center;
  opacity:1;
}
.bg__noise{
  position:absolute;
  inset:-40px;
  opacity:.55;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  background-size:180px 180px;
  mix-blend-mode: overlay;
}

.topbar{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  padding: 14px var(--pad);
  background: transparent;
  backdrop-filter: none;
  pointer-events: none;
}

.topbar__inner{
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 16px;
  pointer-events: auto;
}

.brand{
  justify-self: start;
  display: inline-flex;
  align-items: center;
}

.logo{
  height: 35px;
  width: auto;
  opacity: .92;
}

.nav{
  justify-self: center;
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}

.nav a{
  color: rgba(255,255,255,0.82);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  text-decoration: none;
  background: #000;
  padding: 4px 6px 2px;
  line-height: 1;
}

.nav a:hover{
  color: rgba(255,255,255,0.96);
}

.topbar__spacer{
  justify-self: end;
  width: 35px;   /* match logo feel */
  height: 1px;
}

.page{
  position:relative;
  z-index:10;
  padding: 0;            /* HERO hoitaa itse */
}

.catalog{
  max-width: 1320px;
  margin: 0 auto;
  padding: 22px var(--pad) 40px;   /* siirtyi page->catalog */
}

.catalog__top{
  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(18px, 3vw, 46px);
  align-items: start;
  padding: 18px 0 34px;
}

/* FULL BLEED HERO */
.catalogHero{
  position: relative;
  min-height: 100vh;                 /* ulottuu ylös asti */
  padding: 86px var(--pad) 34px;     /* 86px = topbarin alle tilaa */
  overflow: hidden;
}

.catalogHeroBg{
  position:absolute;
  inset:0;
  z-index:0;
  background-image:
    
    
    url("../assets/images/hero-collage-catalog.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  transform: translateZ(0);
}

.catalogHero::after{
  content:"";
  position:absolute;
  left: -6%;
  right: -6%;
  bottom: -2px;
  height: 327px; /* säädä */
  z-index: 3;
  pointer-events:none;

  background: url("../assets/images/torn-edge-bottom.png?v=1");
  background-size: cover;
  background-position: bottom center;

  /* tekee siitä “paperin” eikä tarraa */
  opacity: 1;
}

/* Inner content stays centered */
.catalogHero__inner{
  position: relative;
  z-index:1;
  max-width: 1320px;
  margin: 0 auto;

  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(18px, 3vw, 46px);
  align-items: start;
}



/* Put the content above the collage */
.paper,
.hero{
  position: relative;
  z-index: 1;
}
.paperStage{
  position: relative;
  min-height: 520px; /* säädä, tai anna sisällön määrätä */
}



.paperStage__shadow,
.paperStage__paper{
  position:absolute;
  inset: 0;
  pointer-events:none;
  background-repeat:no-repeat;
  background-position: left top;
  background-size: 100% 100%; /* 1:1 layoutin muoto */
}

/* Varjo/paksuus */
.paperStage__shadow{
  z-index: 0;
  background-image: url("../assets/images/paper-shadow.png");
  opacity: 0.9;
}

/* Itse paperi (repeämät + rypyt) */
.paperStage__paper{
  z-index: 1;
  background-image: url("../assets/images/paper-shape.png");
  opacity: 1;
}

.paperStage__content{
  position: relative;
  z-index: 2;

  /* SAFE AREA = estää että tekstit menee reunan yli */
  padding:
    var(--paperSafeTop)
    var(--paperSafeRight)
    var(--paperSafeBottom)
    var(--paperSafeLeft);

  color: rgba(0,0,0,0.86);
}

/* Nää sun olemassa olevat paper-tyylit voi keventää pois,
   koska paperin look tulee nyt kuvasta. */

/* Optional: tiny film grain on the hero stage only (not whole page) */
.catalog__top:after{
  content:"";
  position:absolute;
  inset:-40px;
  z-index:0;
  pointer-events:none;
  opacity:.35;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  background-size:180px 180px;
  mix-blend-mode: overlay;
}

.paper{
  position:relative;
  border-radius: 14px;
  padding: clamp(18px, 2.4vw, 28px);
  background: var(--paper);
  color: var(--paperInk);
  overflow:hidden;
  box-shadow: 0 26px 60px rgba(0,0,0,.45);
}
.paper:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.22;
  background:
    radial-gradient(900px 520px at 20% 10%, rgba(0,0,0,0.12), transparent 55%),
    radial-gradient(700px 520px at 80% 70%, rgba(0,0,0,0.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,0.25), rgba(255,255,255,0));
  mix-blend-mode:multiply;
}
.paper:after{
  content:"";
  position:absolute;
  inset:-20px;
  pointer-events:none;
  opacity:.22;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='320' height='320' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  background-size:320px 320px;
  mix-blend-mode:multiply;
}

.paper__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  position:relative;
  z-index:1;
}
.paperGrid{
  display: grid;
  gap: 12px;
}

.paperGrid__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 2px;
}

.paper__kicker{
  font-family: "wordy-diva", sans-serif;
  font-size: 20px;
  letter-spacing: .16em;
  line-height: 15px;
  text-transform: uppercase;
  color: rgba(0,0,0,.75);
  transform: rotate(-2deg);
}

.paper__stamp{
  font-family: "wordy-diva", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 24px;
  line-height: 20px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(0,0,0,0.95);
  padding: 8px 8px;
  transform: rotate(-6deg);
  user-select:none;
  white-space: nowrap;
}
.paper__stamp .smaller{
  position: absolute;
  font-size: 11px;
  transform: rotate(-8deg);
  left:-2px;
}
.paper__titleWrap{
  max-width: 7.2ch;
  transform-origin: left top;
}

.paper__title{
  margin: 6px 0 2px;
  font-family: "InkToner";
  font-synthesis: none;
  text-transform: uppercase;
  letter-spacing: .02em;
  line-height: .88;
  font-size: clamp(44px, 5.2vw, 68px);
  color: rgba(0,0,0,0.90);
}
.paper__lead{
  position:relative;
  z-index:1;
  margin:0 0 10px;
  color: rgba(0,0,0,0.78);
  line-height: 1.55;
  font-size: 14px;
}
.paper__sub{
  position:relative;
  z-index:1;
  margin:0 0 16px;
  color: rgba(0,0,0,0.58);
  line-height: 1.55;
  font-size: 13px;
}
.paper__ingredients{
  position:relative;
  z-index:1;
  margin-top: 6px;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,0.12);
  color: rgba(0,0,0,0.55);
  font-size: 9px;
  line-height: 1.6;
}

.paper__metaRow{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top: 14px;
}
.pill{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 8px 10px;
  border: 1px solid rgba(0,0,0,0.16);
  border-radius: 999px;
  color: rgba(0,0,0,0.65);
  background: rgba(255,255,255,0.35);
}


.hero{
  position:relative;
  min-height: calc(var(--canH) + 60px);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
.hero__canWrap{
  position: relative;
  width: auto;              /* EI viewport-skaalausta */
  display: grid;
  place-items: center;
}

/* Paper under the can */
.hero__paper{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(0);

  /* Paperin koko suhteessa tölkin korkeuteen */
  height: calc(var(--canH) * 1.18);   /* säädä 1.10–1.25 */
  width: auto;

  z-index: 0;
  pointer-events: none;
  user-select: none;
  mix-blend-mode: screen;
  opacity: 0.98;
}

.hero__paper::after{
  content:"";
  position:absolute;
  inset:0;
  opacity:.08;
  pointer-events:none;

  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}

/* Keep can above paper */
.hero__can{
  height: var(--canH);      /* tämä oli ennen hyvä */
  width: auto;
  max-width: 100%;
  transform: translate3d(0,0,0);
  transform: rotate(2deg);
  transition: opacity 140ms ease;
  position: relative;
  z-index: 1;
}

.hero__can.isFade{
  opacity: .0;
}
.hero__tagline{
  margin-top: 12px;
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.80);
}

.sectionTitle{
  margin: 6px 0 16px;
  text-align:center;
  font-family: "InkToner";
  font-synthesis:none;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: clamp(34px, 5vw, 60px);
  color: rgba(255,255,255,0.92);
}

.grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 26px 18px;               /* enemmän ilmaa */
  padding: 10px 0 26px;
}

.card{
  appearance:none;
  border: 0;
  background: transparent;
  padding: 8px 6px 12px;
  cursor:pointer;
  text-align:center;
  color: var(--fg);

  transition: transform 140ms ease, opacity 140ms ease;
}

.card{
  appearance:none;
  border:0;
  background:transparent;
  cursor:pointer;
  color:var(--fg);
  text-align:center;

  /* tärkein: layout lukkoon */
  display: grid;
  grid-template-rows: 260px auto; /* image slot + meta slot */
  align-items: start;

  padding: 8px 6px 12px;
}

.card.isActive{
  transform: translateY(-3px);
}
.card.isActive .card__name{
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 2px;
}

.card__img{
  width:100%;
  height: 260px;                /* isompi */
  display:grid;
  place-items:center;
}

.card__img img{
  height: 250px;                /* isompi */
  width:auto;
  max-width: 100%;
  filter: drop-shadow(0 22px 34px rgba(0,0,0,.60));
  transition: transform 140ms ease;
}

.card:hover .card__img img{
  transform: translateY(-2px) scale(1.02);
}

.card.isActive .card__img img{
  transform: translateY(-2px) scale(1.02);
}





.card__meta{
  margin-top: 10px;
  min-height: clamp(64px, 7vw, 78px);
  display: grid;
  align-content: start;
  gap: 8px;
}
.card__line{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.62);
  text-align:center;
}
.card__name{
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-top: 8px;
  font-family: "InkToner";
  font-synthesis: none;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 18px;                 /* isompi */
  line-height: 1.05;
  min-height: calc(2 * 1.05em);
  color: rgba(255,255,255,0.92);
  text-align:center;
}

.footer{
  margin-top: 24px;
  padding: 22px 0 10px;
  border-top: 1px solid rgba(255,255,255,0.10);
}
.footer__inner{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.footer__title{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.70);
  margin-bottom: 8px;
}
.footer__text{
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,0.74);
}
.footer__text .mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  color: rgba(255,255,255,0.86);
}

@media (max-width: 1180px){
  .grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 940px){
  .grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .card__img{ height: 240px; }
  .card__img img{ height: 230px; }
  .catalogHero__inner{ grid-template-columns: 1fr; }
  .catalogHero{ padding-top: 74px; }
}
@media (max-width: 640px){
  .grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .card__img{ height: 220px; }
  .card__img img{ height: 210px; }
  .hero__paper{
    top: 50%;
    opacity: 0.96;
  }
  .topbar__inner{
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 10px;
  }

  .brand,
  .nav,
  .topbar__spacer{
    justify-self: center;
  }

  .topbar__spacer{
    display: none;
  }

  .nav{
    gap: 10px;
  }

  .nav a{
    font-size: 11px;
  }
  .catalogHero::after{
    bottom: 0px;
    height: 250px;
    background-position: bottom center;
    background-size: 100%;
    background-repeat: no-repeat;
    pointer-events: none;
  }
  
}

.hero{
  display: none;
}

.catalogHero.isProduct .hero{
  display: flex;
}