/* =========================================================
   Kitchen Concept — Editorial Portfolio Single Page
   Scoped under .kcp-portfolio-story
   Tokens: --kp-* (no collision with product --kcp-*)
   ========================================================= */

:root {
  --kp-bronze:    #b8956a;
  --kp-graphite:  #38332e;
  --kp-taupe:     #f3efe9;
  --kp-taupe2:    #ece6dd;
  --kp-taupe-brd: #d9d0c5;
  --kp-text:      #8a7f74;
  --kp-ink:       #1e1a16;
  --kp-white:     #fdfcfa;
  --kp-fe:        'Cormorant Garamond', Georgia, serif;
  --kp-fu:        'Montserrat', sans-serif;
  --kp-ease:      cubic-bezier(0.16, 1, 0.3, 1);
  --kp-r:         20px;
}

/* ── Reset ───────────────────────────────────────────────── */
.kcp-portfolio-story *,
.kcp-portfolio-story *::before,
.kcp-portfolio-story *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
.kcp-portfolio-story {
  font-family: var(--kp-fu);
  color: var(--kp-graphite);
  background: var(--kp-white);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
.kcp-portfolio-story img { display: block; max-width: 100%; }

/* ── Utilities ───────────────────────────────────────────── */
.kp-clip {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1.2s var(--kp-ease);
}
.kp-clip.is-on { clip-path: inset(0 0 0% 0); }

.kp-rise {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s var(--kp-ease), transform 0.9s var(--kp-ease);
}
.kp-rise.is-on { opacity: 1; transform: none; }

.kp-scale {
  opacity: 0;
  transform: scale(0.96);
  transition: opacity 1s var(--kp-ease), transform 1s var(--kp-ease);
}
.kp-scale.is-on { opacity: 1; transform: scale(1); }

.kp-stagger > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s var(--kp-ease), transform 0.8s var(--kp-ease);
}
.kp-stagger.is-on > *:nth-child(1) { opacity:1; transform:none; transition-delay:0s; }
.kp-stagger.is-on > *:nth-child(2) { opacity:1; transform:none; transition-delay:.12s; }
.kp-stagger.is-on > *:nth-child(3) { opacity:1; transform:none; transition-delay:.24s; }
.kp-stagger.is-on > *:nth-child(4) { opacity:1; transform:none; transition-delay:.36s; }
.kp-stagger.is-on > *:nth-child(5) { opacity:1; transform:none; transition-delay:.48s; }
.kp-stagger.is-on > *:nth-child(6) { opacity:1; transform:none; transition-delay:.60s; }

.kp-zoom { overflow: hidden; }
.kp-zoom img { transition: transform 2.4s var(--kp-ease); }
.kp-zoom:hover img { transform: scale(1.05); }

.kp-frame {
  border-radius: var(--kp-r);
  overflow: hidden;
  background: var(--kp-taupe2);
  position: relative;
}
.kp-frame img { width:100%; height:100%; object-fit:cover; display:block; }

.kp-zoom-btn {
  position: absolute;
  bottom: 14px; right: 14px;
  width: 32px; height: 32px;
  border: none; border-radius: 50%;
  background: rgba(30,26,22,.56);
  color: var(--kp-white);
  font-size: 15px; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .25s ease;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.kp-frame:hover .kp-zoom-btn { opacity: 1; }

/* ── Animations ──────────────────────────────────────────── */
@keyframes kpHeroOpen {
  from { clip-path: inset(4% 42% 4% 4% round 20px); transform: scale(1.06); }
  to   { clip-path: inset(0% 0% 0% 0% round 0px);  transform: scale(1); }
}
@keyframes kpRise {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:none; }
}
@keyframes kpLinePulse {
  0%,100% { opacity:.3; }
  50%     { opacity:1; }
}

/* ── ① HERO ──────────────────────────────────────────────── */
.kp-hero {
  display: grid;
  grid-template-columns: 1fr 42%;
  min-height: 100vh;
  background: var(--kp-ink);
  overflow: hidden;
  position: relative;
}
.kp-hero__left {
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 80px 72px 80px 80px;
  position: relative; z-index: 2;
}
.kp-hero__number {
  position: absolute; top: 48px; left: 80px;
  font-size: 9px; font-weight: 500;
  letter-spacing: .26em; text-transform: uppercase;
  color: rgba(255,255,255,.2);
}
.kp-hero__eyebrow {
  display: flex; align-items: center; gap: 14px;
  font-size: 10px; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--kp-bronze);
  margin-bottom: 24px;
  opacity:0; animation: kpRise .8s .5s var(--kp-ease) forwards;
}
.kp-hero__eyebrow-line { width:36px; height:1px; background:var(--kp-bronze); flex-shrink:0; }
.kp-hero__title {
  font-family: var(--kp-fe);
  font-size: clamp(40px,4.8vw,70px);
  font-weight: 300; line-height: 1.08;
  color: var(--kp-white);
  margin-bottom: 28px;
  opacity:0; animation: kpRise .9s .7s var(--kp-ease) forwards;
}
.kp-hero__title em { font-style:italic; color:rgba(255,255,255,.52); }
.kp-hero__desc {
  font-size: 14px; font-weight: 300; line-height: 1.8;
  color: rgba(255,255,255,.42);
  max-width: 400px; margin-bottom: 48px;
  opacity:0; animation: kpRise .8s .9s var(--kp-ease) forwards;
}
.kp-hero__meta {
  display: flex; gap: 44px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.08);
  opacity:0; animation: kpRise .8s 1.1s var(--kp-ease) forwards;
}
.kp-hero__meta-item { display:flex; flex-direction:column; gap:6px; }
.kp-hero__meta-label {
  font-size:9px; letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.25);
}
.kp-hero__meta-val {
  font-family:var(--kp-fe); font-size:18px; font-weight:300;
  font-style:italic; color:rgba(255,255,255,.65);
}
.kp-hero__right { position:relative; overflow:hidden; }
.kp-hero__photo {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  animation: kpHeroOpen 1.8s var(--kp-ease) forwards;
}
.kp-hero__overlay {
  position:absolute; inset:0;
  background: linear-gradient(to right,rgba(30,26,22,.5) 0%,transparent 40%);
}
.kp-hero__scroll {
  position:absolute; bottom:36px; left:80px;
  display:flex; align-items:center; gap:12px;
  opacity:0; animation: kpRise .7s 1.4s ease forwards;
}
.kp-hero__scroll span {
  font-size:9px; letter-spacing:.26em; text-transform:uppercase;
  color:rgba(255,255,255,.22);
}
.kp-hero__scroll-line {
  width:40px; height:1px;
  background: linear-gradient(to right,var(--kp-bronze),transparent);
  animation: kpLinePulse 2.4s ease-in-out infinite;
}

/* ── DIVIDER ─────────────────────────────────────────────── */
.kp-divider { height:1px; background:var(--kp-taupe-brd); margin:0; }

/* ── ② INTRO ─────────────────────────────────────────────── */
.kp-intro { padding:96px 80px 80px; max-width:800px; margin:0 auto; text-align:center; }
.kp-intro__lead {
  font-family:var(--kp-fe);
  font-size:clamp(20px,2.2vw,27px);
  font-weight:300; line-height:1.72; color:var(--kp-graphite);
}
.kp-intro__lead p { margin-bottom:1em; }
.kp-intro__lead p:last-child { margin-bottom:0; }

/* ── ③ DIPTYCH ───────────────────────────────────────────── */
.kp-diptych { padding:0 80px; margin-bottom:128px; }
.kp-diptych__grid {
  display:grid; grid-template-columns:58fr 42fr;
  gap:14px; align-items:start;
}
.kp-diptych__a { height:760px; }
.kp-diptych__right {
  padding-top:110px;
  display:flex; flex-direction:column; gap:36px;
}
.kp-diptych__b { height:480px; }
.kp-diptych__text {
  font-family:var(--kp-fe);
  font-size:clamp(16px,1.5vw,20px);
  font-weight:300; font-style:italic;
  line-height:1.8; color:var(--kp-text);
}

/* ── ④ PULL QUOTE ────────────────────────────────────────── */
.kp-quote { padding:56px 80px 64px; display:flex; align-items:center; gap:44px; }
.kp-quote__rule {
  width:2px; height:68px; background:var(--kp-bronze); flex-shrink:0;
  transform:scaleY(0); transform-origin:top;
  transition:transform .8s var(--kp-ease);
}
.kp-quote.is-on .kp-quote__rule { transform:scaleY(1); }
.kp-quote__text {
  font-family:var(--kp-fe);
  font-size:clamp(22px,2.6vw,38px);
  font-weight:300; font-style:italic; line-height:1.45;
  color:var(--kp-graphite); max-width:680px;
}

/* ── ⑤ FOCAL + TEXT ──────────────────────────────────────── */
.kp-focal-pair {
  display:grid; grid-template-columns:40% 1fr;
  gap:72px; align-items:center;
  padding:0 80px; margin-bottom:140px;
}
.kp-focal-pair__text {
  font-family:var(--kp-fe);
  font-size:clamp(18px,1.8vw,26px);
  font-weight:300; line-height:1.75;
  color:var(--kp-graphite);
}
.kp-focal-pair__text p { margin:0; }
.kp-focal__wrap {
  height:680px;
  border-radius:var(--kp-r); overflow:hidden;
  background:var(--kp-taupe2); position:relative;
}
.kp-focal__wrap img {
  width:100%; height:100%; object-fit:cover; display:block;
  transform:scale(1.07); transition:transform 2.4s var(--kp-ease);
}
.kp-focal__wrap.is-on img { transform:scale(1); }

/* ── ⑥ TRIPTYCH ──────────────────────────────────────────── */
.kp-triptych { padding:0 80px; margin-bottom:140px; }
.kp-triptych__grid {
  display:grid; grid-template-columns:1fr 1fr 1fr;
  gap:14px; align-items:start;
}
.kp-triptych__a { height:640px; }
.kp-triptych__b { height:720px; margin-top:-56px; }
.kp-triptych__c { height:580px; margin-top:64px; }
.kp-triptych__grid .kp-frame {
  clip-path:inset(0 0 100% 0);
  transition:clip-path 1.1s var(--kp-ease);
}
.kp-triptych__grid.is-on .kp-frame:nth-child(1) { clip-path:inset(0 0 0% 0); transition-delay:0s; }
.kp-triptych__grid.is-on .kp-frame:nth-child(2) { clip-path:inset(0 0 0% 0); transition-delay:.14s; }
.kp-triptych__grid.is-on .kp-frame:nth-child(3) { clip-path:inset(0 0 0% 0); transition-delay:.28s; }
.kp-triptych__caption {
  margin-top:36px; padding:0 4px;
  font-size:13px; font-weight:300; line-height:1.8;
  color:var(--kp-text); max-width:560px;
}

/* Triptych adaptive columns for fewer photos */
.kp-triptych--1 .kp-triptych__grid { grid-template-columns: 1fr; max-width: 52%; margin: 0 auto; }
.kp-triptych--2 .kp-triptych__grid { grid-template-columns: 1fr 1fr; }
.kp-triptych--2 .kp-triptych__b    { height: 680px; margin-top: -40px; }

/* ── ⑦ GALLERY EXPAND ───────────────────────────────────── */
.kp-gallery-more { padding:0 80px; margin-bottom:100px; }
.kp-gallery-more__btn-wrap { display:flex; justify-content:center; padding-bottom:52px; }
.kp-more-btn {
  font-family:var(--kp-fu); font-size:10px; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase;
  background:transparent; border:1px solid var(--kp-taupe-brd);
  color:var(--kp-graphite); padding:15px 42px; border-radius:50px;
  cursor:pointer; transition:border-color .3s ease,color .3s ease;
}
.kp-more-btn:hover { border-color:var(--kp-bronze); color:var(--kp-bronze); }
.kp-extra {
  display:grid; grid-template-rows:0fr; overflow:hidden;
  transition:grid-template-rows .9s var(--kp-ease),margin-top .9s var(--kp-ease);
  margin-top:0;
}
.kp-extra.is-open { grid-template-rows:1fr; margin-top:14px; }
.kp-extra__inner { min-height:0; overflow:hidden; }
.kp-extra__grid {
  display:grid; grid-template-columns:repeat(12,1fr);
  grid-auto-rows:72px; gap:14px;
}
.kp-extra-g { grid-column:1/5;  grid-row:1/9;  }
.kp-extra-h { grid-column:5/13; grid-row:1/6;  }
.kp-extra-i { grid-column:5/9;  grid-row:6/11; }
.kp-extra-j { grid-column:9/13; grid-row:6/11; }
.kp-extra-k { grid-column:1/5;  grid-row:9/14; }
.kp-extra-l { grid-column:5/13; grid-row:11/14;}

/* ── ⑧ SPECS ─────────────────────────────────────────────── */
.kp-specs { background:var(--kp-taupe); padding:80px; }
.kp-specs__head {
  display:flex; justify-content:space-between; align-items:baseline;
  border-bottom:1px solid var(--kp-taupe-brd);
  padding-bottom:24px; margin-bottom:40px;
}
.kp-specs__title { font-family:var(--kp-fe); font-size:26px; font-weight:300; color:var(--kp-graphite); }
.kp-specs__brand { font-size:9px; letter-spacing:.22em; text-transform:uppercase; color:var(--kp-text); }
.kp-specs__cards { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.kp-sc { background:var(--kp-white); padding:28px 24px 32px; }
.kp-sc__l { font-size:9px; letter-spacing:.22em; text-transform:uppercase; color:var(--kp-text); margin-bottom:10px; }
.kp-sc__v { font-family:var(--kp-fe); font-size:20px; font-weight:300; color:var(--kp-graphite); line-height:1.2; }

/* ── ⑨ ATTRIBUTION ───────────────────────────────────────── */
.kp-attribution { padding:0 80px 88px; }
.kp-attribution__inner {
  border-top:1px solid var(--kp-taupe-brd);
  padding-top:28px;
  display:flex; gap:64px; flex-wrap:wrap;
}
.kp-attr-label {
  font-size:9px; font-weight:400; letter-spacing:.2em;
  text-transform:uppercase; color:var(--kp-text); margin-bottom:5px;
}
.kp-attr-value { font-size:13px; font-weight:300; color:var(--kp-graphite); line-height:1.5; }

/* ── ⑩ RELATED PROJECTS ──────────────────────────────────── */
.kp-related { padding:0 80px 128px; }
.kp-related__head {
  padding:80px 0 28px;
  border-bottom:1px solid var(--kp-taupe-brd);
  margin-bottom:44px;
  display:flex; justify-content:space-between; align-items:baseline;
}
.kp-related__label {
  font-size:9px; font-weight:400; letter-spacing:.24em;
  text-transform:uppercase; color:var(--kp-text);
}
.kp-related__all {
  font-size:10px; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--kp-bronze);
  text-decoration:none; transition:opacity .25s ease;
}
.kp-related__all:hover { opacity:.7; }
.kp-related__grid {
  display:grid; grid-template-columns:56fr 44fr;
  gap:20px; align-items:start;
}
.kp-rp-card { text-decoration:none; display:block; }
.kp-rp-card__photo {
  border-radius:var(--kp-r); overflow:hidden; background:var(--kp-taupe2);
}
.kp-rp-card__photo img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform 1.1s var(--kp-ease);
}
.kp-rp-card:hover .kp-rp-card__photo img { transform:scale(1.03); }
.kp-rp-card:nth-child(1) .kp-rp-card__photo { height:480px; }
.kp-rp-card:nth-child(2) .kp-rp-card__photo { height:360px; margin-top:88px; }
.kp-rp-card__body { padding-top:20px; }
.kp-rp-card__meta {
  font-size:9px; font-weight:400; letter-spacing:.2em;
  text-transform:uppercase; color:var(--kp-text); margin-bottom:8px;
}
.kp-rp-card__title {
  font-family:var(--kp-fe); font-size:22px; font-weight:300;
  color:var(--kp-graphite); margin-bottom:14px; line-height:1.2;
}
.kp-rp-card__cta {
  font-size:10px; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--kp-bronze);
  display:inline-flex; align-items:center; gap:10px;
  transition:gap .35s var(--kp-ease);
}
.kp-rp-card:hover .kp-rp-card__cta { gap:18px; }

/* ── ⑪ CONSULT ───────────────────────────────────────────── */
.kp-consult {
  padding:100px 80px;
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center;
}
.kp-consult__eyebrow {
  font-size:9px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--kp-bronze); margin-bottom:20px;
}
.kp-consult__title {
  font-family:var(--kp-fe); font-size:clamp(32px,3.5vw,50px);
  font-weight:300; line-height:1.12; color:var(--kp-graphite); margin-bottom:20px;
}
.kp-consult__sub {
  font-size:14px; font-weight:300; line-height:1.85;
  color:var(--kp-text); margin-bottom:36px;
}
.kp-consult__opts { display:flex; flex-direction:column; gap:2px; }
.kp-consult__opt {
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 20px; background:var(--kp-taupe); border-radius:10px;
  text-decoration:none; color:var(--kp-graphite);
  font-size:13px; font-weight:400; transition:background .25s ease;
}
.kp-consult__opt:hover { background:var(--kp-taupe2); }
.kp-consult__opt-arr { color:var(--kp-bronze); font-size:16px; }
.kp-consult__form {
  background:var(--kp-taupe); border-radius:var(--kp-r); padding:40px;
}
/* CF7 overrides */
.kp-consult__form .wpcf7 input[type="text"],
.kp-consult__form .wpcf7 input[type="tel"],
.kp-consult__form .wpcf7 input[type="email"],
.kp-consult__form .wpcf7 textarea {
  width:100%; background:var(--kp-white);
  border:1px solid var(--kp-taupe-brd); border-radius:10px;
  padding:14px 18px; font-family:var(--kp-fu); font-size:13px;
  color:var(--kp-graphite); outline:none;
  transition:border-color .2s ease; margin-bottom:10px;
  box-shadow:none; -webkit-appearance:none;
}
.kp-consult__form .wpcf7 input:focus,
.kp-consult__form .wpcf7 textarea:focus { border-color:var(--kp-bronze); }
.kp-consult__form .wpcf7 input[type="submit"] {
  width:100%; border:none; border-radius:50px; padding:15px;
  background:var(--kp-bronze); font-family:var(--kp-fu);
  font-size:11px; font-weight:500; letter-spacing:.14em;
  text-transform:uppercase; color:#1a0f00; cursor:pointer;
  transition:opacity .25s ease; margin-top:4px;
}
.kp-consult__form .wpcf7 input[type="submit"]:hover { opacity:.85; }

/* ── LIGHTBOX ────────────────────────────────────────────── */
dialog.kp-lightbox {
  border:none; padding:0; margin:0;
  width:100vw; height:100dvh;
  max-width:100vw; max-height:100dvh;
  background:rgba(10,8,5,.97);
  display:none; align-items:center; justify-content:center;
  position:fixed; inset:0;
}
dialog.kp-lightbox[open] { display:flex; }
dialog.kp-lightbox::backdrop { background:rgba(10,8,5,.9); }
.kp-lightbox__img-wrap {
  max-width:90vw; max-height:90dvh;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .3s ease;
}
.kp-lightbox__img-wrap.kp-lb-loading { opacity:0; }
.kp-lightbox__img {
  max-width:90vw; max-height:90dvh;
  object-fit:contain; border-radius:4px;
}
.kp-lightbox__close,
.kp-lightbox__prev,
.kp-lightbox__next {
  position:fixed; background:rgba(255,255,255,.08);
  border:none; color:rgba(255,255,255,.7);
  cursor:pointer; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s ease,color .2s ease;
  font-family:var(--kp-fu); z-index:10;
}
.kp-lightbox__close:hover,
.kp-lightbox__prev:hover,
.kp-lightbox__next:hover { background:rgba(255,255,255,.15); color:#fff; }
.kp-lightbox__close { top:24px; right:24px; width:40px; height:40px; font-size:18px; }
.kp-lightbox__prev  { left:24px; top:50%; transform:translateY(-50%); width:48px; height:48px; font-size:28px; }
.kp-lightbox__next  { right:24px; top:50%; transform:translateY(-50%); width:48px; height:48px; font-size:28px; }

/* ── MOBILE ──────────────────────────────────────────────── */
@media (max-width: 768px) {

  .kp-hero { grid-template-columns:1fr; position:relative; }
  .kp-hero__right { position:absolute; inset:0; z-index:0; }
  .kp-hero__overlay {
    background: linear-gradient(to top,
      rgba(30,26,22,.92) 0%,
      rgba(30,26,22,.5)  50%,
      rgba(30,26,22,.15) 100%
    );
  }
  .kp-hero__left {
    position:relative; z-index:1; justify-content:flex-end;
    padding:40px 24px 56px; min-height:100dvh;
  }
  .kp-hero__number { left:24px; top:40px; }
  .kp-hero__title  { font-size:clamp(36px,9vw,54px); }
  .kp-hero__desc   { max-width:100%; font-size:13px; }
  .kp-hero__meta   { gap:24px; flex-wrap:wrap; }
  .kp-hero__scroll { left:24px; }

  .kp-diptych        { padding:0 24px; margin-bottom:72px; }
  .kp-focal-pair     { padding:0 24px; margin-bottom:72px; grid-template-columns:1fr; gap:36px; }
  .kp-triptych       { padding:0 24px; margin-bottom:72px; }
  .kp-gallery-more   { padding:0 24px; margin-bottom:72px; }
  .kp-specs          { padding:56px 24px; }
  .kp-attribution    { padding:0 24px 56px; }
  .kp-related        { padding:0 24px 80px; }
  .kp-related__head  { padding-top:56px; }
  .kp-consult        { padding:72px 24px; grid-template-columns:1fr; gap:48px; }

  .kp-diptych__grid  { grid-template-columns:1fr; gap:10px; }
  .kp-diptych__right { padding-top:0; }
  .kp-diptych__a     { height:480px; }
  .kp-diptych__b     { height:360px; }

  .kp-focal__wrap { height:480px; }

  .kp-triptych__grid {
    display:flex; overflow-x:scroll;
    scroll-snap-type:x mandatory; gap:10px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none; align-items:stretch;
  }
  .kp-triptych__grid::-webkit-scrollbar { display:none; }
  .kp-triptych__a,.kp-triptych__b,.kp-triptych__c {
    flex:0 0 78vw; height:520px; margin-top:0; scroll-snap-align:start;
  }
  .kp-triptych__grid .kp-frame { clip-path:none !important; }

  .kp-extra__grid {
    display:grid; grid-template-columns:1fr 1fr;
    grid-auto-rows:260px; gap:10px;
  }
  .kp-extra-g,.kp-extra-h,.kp-extra-i,
  .kp-extra-j,.kp-extra-k,.kp-extra-l {
    grid-column:auto; grid-row:auto; height:260px;
  }

  .kp-specs__cards { grid-template-columns:1fr 1fr; }

  .kp-attribution__inner { flex-direction:column; gap:24px; }

  .kp-related__grid { grid-template-columns:1fr; }
  .kp-rp-card:nth-child(1) .kp-rp-card__photo { height:380px; }
  .kp-rp-card:nth-child(2) .kp-rp-card__photo { height:320px; margin-top:0; }
}
