/*
 * Portfolio Page — portfolio.css
 * モバイルファースト (375px 基準 → min-width:768px でPC拡張)
 * bukiyou-theme / page-portfolio.php
 */

/* ============ CUSTOM PROPERTIES ============ */
:root{
  --wall:#1c1b1a;
  --wall-deep:#161514;
  --bg:#0a0a0a;
  --bg-2:#0b0b0c;
  --ink:#f5f5f5;
  --ink-dim:#8a8a8a;
  --ink-faint:#454545;
  --gold:#d4a853;
  --line:rgba(245,245,245,0.08);
  --ease:cubic-bezier(.4,0,.2,1);
  --grotesk:'Space Grotesk',sans-serif;
  --jp:'Noto Sans JP',sans-serif;
  --gutter:24px;
  --section-gap:160px;
}

/* ============ RESET ============ */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--wall);
  color:var(--ink);
  font-family:var(--jp);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.7;
}

/* Gallery wall: top light wash + heavy vignette */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  background:
    radial-gradient(120% 60% at 50% -8%, rgba(255,255,255,0.045), transparent 55%),
    radial-gradient(150% 130% at 50% 50%, transparent 60%, rgba(0,0,0,0.4) 100%);
}

::selection{background:var(--gold);color:#0a0a0a;}

.wrap{
  position:relative;z-index:2;
  max-width:1180px;
  margin:0 auto;
  padding:0 var(--gutter);
}

/* ============ TOP BAR ============ */
.topbar{
  position:absolute;top:0;left:0;right:0;
  z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px var(--gutter);
}
.mark{
  font-family:var(--grotesk);font-weight:700;
  font-size:15px;letter-spacing:.16em;line-height:.92;
}
.mark span{display:block;}
.mark span:last-child{color:var(--gold);}
.topnav{
  display:none;
  gap:34px;
  font-family:var(--grotesk);font-size:11px;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-dim);
}
.topnav a{color:inherit;text-decoration:none;transition:color .2s var(--ease);}
.topnav a:hover{color:var(--ink);}

/* ============ HERO ============ */
.hero{
  position:relative;z-index:2;
  min-height:100vh;min-height:100svh;
  display:flex;flex-direction:column;
  justify-content:center;align-items:center;
  text-align:center;
  padding:120px var(--gutter) 90px;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;z-index:0;
  top:-16%;left:50%;transform:translateX(-50%);
  width:120%;height:116%;
  background:radial-gradient(ellipse 24% 62% at 50% 16%, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.04) 36%, transparent 64%);
  filter:blur(26px);pointer-events:none;
}
.hero::after{
  content:"";
  position:absolute;z-index:0;
  top:50%;left:50%;
  width:132vw;height:110vh;
  transform:translate(-50%,-50%);
  background:
    radial-gradient(ellipse 46% 40% at 50% 43%, rgba(255,255,255,0.085) 0%, transparent 60%),
    radial-gradient(126% 98% at 50% 37%, transparent 47%, rgba(0,0,0,0.66) 100%);
  pointer-events:none;
}
.hero-kicker{
  position:relative;z-index:2;
  font-family:var(--grotesk);font-size:11px;
  letter-spacing:.46em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:40px;
}
.hero-name{
  position:relative;z-index:2;
  font-family:var(--grotesk);font-weight:700;
  font-size:clamp(64px,19vw,212px);
  line-height:.82;letter-spacing:-0.04em;text-transform:lowercase;
  background:linear-gradient(176deg,#ffffff 3%,#f0ede7 22%,#9c978d 58%,#4c483f 83%,#2c2925 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 6px 60px rgba(245,240,228,0.16));
}
.hero-sub{
  position:relative;z-index:2;
  margin-top:40px;
  font-family:var(--jp);font-weight:400;
  font-size:14px;letter-spacing:.34em;color:var(--ink-dim);
}
.hero-sub .dot{color:var(--gold);margin:0 12px;}
.hero-lead{
  position:relative;z-index:2;
  margin-top:46px;max-width:26ch;
  font-family:var(--jp);font-weight:300;
  font-size:12.5px;line-height:1.9;color:var(--ink-faint);
  letter-spacing:.04em;text-wrap:balance;
}
.hero-cta{
  position:relative;z-index:2;
  margin-top:32px;
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--grotesk);font-size:12px;letter-spacing:.16em;
  color:#0a0a0a;background:var(--gold);
  text-decoration:none;
  padding:15px 26px;border-radius:999px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
  box-shadow:0 10px 30px -10px rgba(212,168,83,.5);
}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 16px 38px -12px rgba(212,168,83,.6);}
.hero-cta .arr{width:26px;height:1px;background:#0a0a0a;position:relative;transition:width .25s var(--ease);}
.hero-cta:hover .arr{width:38px;}
.hero-cta .arr::after{
  content:"";position:absolute;right:0;top:-3px;
  width:7px;height:7px;
  border-top:1px solid #0a0a0a;border-right:1px solid #0a0a0a;
  transform:rotate(45deg);
}
.hero-foot{
  position:absolute;bottom:34px;left:0;right:0;z-index:2;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--gutter);
}
.socials{display:flex;flex-direction:column;gap:14px;}
.socials a{
  width:18px;height:18px;color:var(--ink-faint);
  transition:color .2s ease;
}
.socials a:hover{color:var(--gold);}
.socials svg{width:100%;height:100%;display:block;}
.scroll-cue{
  font-family:var(--grotesk);font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink-faint);writing-mode:vertical-rl;
  display:flex;align-items:center;gap:12px;
}
.scroll-cue::after{
  content:"";width:1px;height:46px;
  background:linear-gradient(var(--ink-faint),transparent);
}

/* ============ SECTION HEADINGS ============ */
.section{padding-top:var(--section-gap);}
.sec-label{
  font-family:var(--grotesk);font-size:11px;
  letter-spacing:.36em;text-transform:uppercase;
  color:var(--gold);
  display:flex;align-items:center;gap:14px;
  margin-bottom:18px;
}
.sec-label::before{content:"";width:36px;height:1px;background:var(--gold);opacity:.6;}
.sec-title{
  font-family:var(--grotesk);font-weight:600;
  font-size:clamp(34px,9vw,64px);
  line-height:1;letter-spacing:-0.02em;
}

/* ============ GALLERY ============ */
.gallery{display:flex;flex-direction:column;gap:var(--section-gap);margin-top:72px;}
.piece{position:relative;}
.piece::before{
  content:"";
  position:absolute;left:50%;top:-55%;
  width:155%;height:210%;
  transform:translateX(-50%);
  background:radial-gradient(ellipse 62% 50% at 50% 50%, rgba(245,247,252,0.085) 0%, rgba(240,243,250,0.035) 40%, rgba(255,255,255,0.012) 60%, transparent 76%);
  pointer-events:none;z-index:0;
}
.exhibit{position:relative;width:100%;max-width:680px;margin:0 auto;}
.exhibit.portrait{max-width:430px;}
.exhibit::before{
  content:"";
  position:absolute;left:50%;top:-26%;
  width:165%;height:165%;transform:translateX(-50%);
  background:
    radial-gradient(ellipse 48% 42% at 50% 33%, rgba(231,237,248,0.55) 0%, rgba(222,230,245,0.22) 28%, transparent 56%),
    radial-gradient(ellipse 92% 82% at 50% 46%, rgba(255,255,255,0.17) 0%, rgba(255,255,255,0.055) 44%, transparent 76%);
  filter:blur(11px);pointer-events:none;z-index:0;
}
.exhibit::after{
  content:"";
  position:absolute;left:50%;bottom:-5%;
  width:90%;height:17%;transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 50% at 50% 0%, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.34) 36%, transparent 74%);
  filter:blur(13px);pointer-events:none;z-index:0;
}
.panel{
  position:relative;z-index:1;
  width:100%;aspect-ratio:4/3;
  background:#070707;border-radius:7px;overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.7),
    inset 0 1px 0 rgba(255,255,255,.11),
    inset 0 0 0 1px rgba(255,255,255,.022),
    inset 0 -1px 0 rgba(0,0,0,.6),
    0 14px 30px -12px rgba(0,0,0,.8),
    0 50px 80px -34px rgba(0,0,0,.95);
}
.panel.portrait{aspect-ratio:3/4;}
.panel::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:5;
  background:
    radial-gradient(ellipse 78% 64% at 50% 38%, rgba(255,255,255,0.075) 0%, transparent 56%),
    radial-gradient(ellipse 125% 105% at 50% 52%, transparent 54%, rgba(0,0,0,0.46) 100%);
}

/* ---- carousel ---- */
.carousel{
  position:absolute;inset:0;z-index:1;
  display:flex;overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;-ms-overflow-style:none;
  -webkit-overflow-scrolling:touch;cursor:grab;
}
.carousel.dragging{cursor:grabbing;scroll-snap-type:none;scroll-behavior:auto;user-select:none;}
.carousel.dragging *{pointer-events:none;}
.carousel::-webkit-scrollbar{display:none;}
.slide{
  position:relative;flex:0 0 100%;
  scroll-snap-align:center;
  display:flex;align-items:center;justify-content:center;
}
.slide.web{padding:clamp(14px,4.6%,38px);}

/* swipe hint */
.swipe-hint{
  position:absolute;left:50%;bottom:12px;transform:translateX(-50%);
  z-index:6;pointer-events:none;
  display:flex;align-items:center;gap:7px;
  font-family:var(--grotesk);font-size:9px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(245,245,245,.5);transition:opacity .4s var(--ease);
}
.swipe-hint svg{width:26px;height:14px;}
.panel.seen .swipe-hint{opacity:0;}

/* dots */
.dots{display:flex;gap:7px;justify-content:center;margin-top:20px;position:relative;z-index:2;}
.dots button{
  width:6px;height:6px;padding:0;border:none;border-radius:50%;
  background:var(--ink-faint);cursor:pointer;
  transition:background .25s var(--ease),width .25s var(--ease);
}
.dots button.on{background:var(--gold);width:18px;border-radius:3px;}

/* ---- phone exhibit ---- */
.phone{
  height:92%;
  aspect-ratio:250/512;
  border-radius:30px;
  background:linear-gradient(165deg,#1a1a1a,#0c0c0c 60%);
  padding:2.4%;
  box-shadow:
    0 2px 4px rgba(0,0,0,.6),
    0 26px 50px -18px rgba(0,0,0,.92),
    0 0 0 1px rgba(245,245,245,.06) inset,
    0 0 0 1px rgba(0,0,0,.6);
}
.phone-screen{
  position:relative;width:100%;height:100%;
  border-radius:23px;overflow:hidden;background:#F5F1E8;
}
.notch{
  position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:64px;height:18px;background:#000;border-radius:10px;z-index:3;
}
.phone-screen img{
  width:100%;height:100%;object-fit:cover;display:block;
}

/* ---- browser exhibit ---- */
.browser{
  width:100%;height:100%;
  display:flex;flex-direction:column;
  border-radius:9px;overflow:hidden;
  border:1px solid rgba(245,245,245,.07);
  background:#0d0d0e;
  box-shadow:0 24px 50px -26px rgba(0,0,0,.85);
}
.browser-bar{
  flex:none;display:flex;align-items:center;gap:7px;
  padding:11px 14px;background:#141416;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.dot3{width:10px;height:10px;border-radius:50%;background:#2e2e31;}
.url{
  margin-left:12px;flex:1;
  background:#0a0a0b;border-radius:6px;
  padding:5px 12px;
  font-family:var(--grotesk);font-size:10px;letter-spacing:.04em;color:var(--ink-faint);
}
.browser-screen{
  flex:1;min-height:0;background:var(--bg-2);overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.browser-screen img{
  width:100%;height:100%;object-fit:cover;display:block;
}

/* placeholder when no screenshot is set */
.slide-placeholder{
  width:100%;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  color:var(--ink-faint);
  font-family:var(--grotesk);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
}
.slide-placeholder::before{
  content:"";
  width:40px;height:1px;background:var(--ink-faint);display:block;
}

/* ---- museum placard ---- */
.placard{
  text-align:center;max-width:520px;margin:30px auto 0;
}
.placard .num{
  font-family:var(--grotesk);font-weight:500;
  font-size:12px;letter-spacing:.32em;color:var(--gold);
}
.placard .name{
  font-family:var(--grotesk);font-weight:600;
  font-size:clamp(28px,8vw,42px);
  line-height:1.04;letter-spacing:-0.01em;margin-top:12px;
}
.placard .kind{
  font-family:var(--jp);font-weight:400;
  font-size:12px;letter-spacing:.22em;color:var(--ink-dim);margin-top:9px;
}
.placard .role{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--jp);font-weight:400;font-size:12px;letter-spacing:.04em;
  color:var(--ink);margin-top:14px;
}
.placard .role span{
  font-family:var(--grotesk);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--line);border-radius:999px;padding:3px 9px;
}
.placard .desc{
  font-size:14px;color:var(--ink-dim);font-weight:300;
  line-height:1.85;margin-top:16px;
}
.placard .tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:20px;}
.tag{
  font-family:var(--grotesk);
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-dim);border:1px solid var(--line);
  border-radius:999px;padding:6px 13px;
}
.proj-link{
  display:inline-flex;align-items:center;gap:10px;
  justify-content:center;
  margin-top:26px;
  font-family:var(--grotesk);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;
}
.proj-link .arr{
  width:30px;height:1px;background:var(--gold);position:relative;transition:width .25s ease;
}
.proj-link:hover .arr{width:46px;}
.proj-link .arr::after{
  content:"";position:absolute;right:0;top:-3px;
  width:7px;height:7px;
  border-top:1px solid var(--gold);border-right:1px solid var(--gold);
  transform:rotate(45deg);
}

/* ============ CONTACT ============ */
.contact{
  position:relative;
  margin-top:var(--section-gap);
  padding:120px var(--gutter) 64px;
  overflow:hidden;
}
.contact::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--line),transparent);
}
.contact::after{
  content:"";position:absolute;left:50%;top:2%;
  width:140%;height:80%;transform:translateX(-50%);
  pointer-events:none;
  background:radial-gradient(ellipse 42% 46% at 50% 30%, rgba(231,237,248,0.13), transparent 62%);
  filter:blur(10px);
}
.contact-inner{position:relative;z-index:2;max-width:620px;margin:0 auto;}

.contact-head{text-align:center;}
.contact-kicker{
  font-family:var(--grotesk);font-size:11px;letter-spacing:.4em;
  text-transform:uppercase;color:var(--gold);
}
.contact-h{
  font-family:var(--jp);font-weight:500;
  font-size:clamp(25px,5.6vw,40px);line-height:1.4;letter-spacing:.01em;
  margin-top:22px;text-wrap:balance;
}
.contact-lead{
  margin:20px auto 0;max-width:38ch;
  font-family:var(--jp);font-weight:300;font-size:14px;line-height:1.95;color:var(--ink-dim);
  text-wrap:pretty;
}

.form-panel{
  position:relative;margin-top:52px;
  padding:clamp(26px,6%,46px) clamp(22px,6%,44px) clamp(28px,6%,42px);
  background:linear-gradient(168deg,#101010,#070707 70%);
  border-radius:8px;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.7),
    inset 0 1px 0 rgba(255,255,255,.10),
    inset 0 0 0 1px rgba(255,255,255,.02),
    inset 0 -1px 0 rgba(0,0,0,.6),
    0 16px 34px -14px rgba(0,0,0,.82),
    0 54px 84px -36px rgba(0,0,0,.95);
  overflow:hidden;
}
.form-panel::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 52% at 50% -8%, rgba(255,255,255,0.06), transparent 58%);
}
.form-panel > *{position:relative;z-index:1;}

.form-status{
  display:flex;align-items:center;gap:11px;
  font-family:var(--jp);font-size:12px;letter-spacing:.06em;color:var(--ink-dim);
  padding-bottom:26px;margin-bottom:30px;
  border-bottom:1px solid var(--line);
}
.status-dot{
  width:7px;height:7px;border-radius:50%;background:#6fae7d;flex:none;
  box-shadow:0 0 0 0 rgba(111,174,125,.6);
  animation:pulse 2.8s var(--ease) infinite;
}
@keyframes pulse{
  0%  {box-shadow:0 0 0 0   rgba(111,174,125,.5);}
  70% {box-shadow:0 0 0 7px rgba(111,174,125,0);}
  100%{box-shadow:0 0 0 0   rgba(111,174,125,0);}
}
@media(prefers-reduced-motion:reduce){.status-dot{animation:none;}}

.field-row{display:flex;flex-direction:column;}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:30px;}
.flabel{
  font-family:var(--grotesk);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-faint);
}
.form input,.form textarea{
  font-family:var(--jp);font-size:15px;color:var(--ink);
  background:transparent;border:none;border-radius:0;
  border-bottom:1px solid var(--line);
  padding:7px 1px;width:100%;
  transition:border-color .25s var(--ease);
  -webkit-appearance:none;appearance:none;
}
.form input::placeholder,.form textarea::placeholder{color:var(--ink-faint);}
.form input:focus,.form textarea:focus{outline:none;border-bottom-color:var(--gold);}
.form textarea{resize:vertical;min-height:84px;line-height:1.8;}
.form input.invalid,.form textarea.invalid{border-bottom-color:#A05545;}

.chips{display:flex;flex-wrap:wrap;gap:8px 26px;padding-top:2px;}
.chip{
  font-family:var(--jp);font-size:14px;color:var(--ink-faint);
  background:none;border:none;border-radius:0;padding:4px 0 6px;cursor:pointer;
  position:relative;letter-spacing:.02em;white-space:nowrap;
  transition:color .2s var(--ease);
}
.chip::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--gold);transition:width .25s var(--ease);
}
.chip:hover{color:var(--ink-dim);}
.chip.on{color:var(--ink);}
.chip.on::after{width:100%;}

.form-foot{
  display:flex;flex-direction:column;gap:24px;align-items:flex-start;
  margin-top:6px;padding-top:28px;border-top:1px solid var(--line);
}
.form-note{font-family:var(--jp);font-size:12px;line-height:1.8;color:var(--ink-faint);}
.form-note a{
  color:var(--ink-dim);text-decoration:none;
  border-bottom:1px solid var(--ink-faint);padding-bottom:1px;
  transition:color .2s ease,border-color .2s ease;
}
.form-note a:hover{color:var(--gold);border-color:var(--gold);}
.submit{
  display:inline-flex;align-items:center;gap:16px;
  font-family:var(--grotesk);font-size:13px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);background:none;border:none;cursor:pointer;padding:2px 0;
}
.submit .arr{width:40px;height:1px;background:var(--gold);position:relative;transition:width .3s var(--ease);}
.submit:hover .arr{width:60px;}
.submit .arr::after{
  content:"";position:absolute;right:0;top:-3px;
  width:7px;height:7px;
  border-top:1px solid var(--gold);border-right:1px solid var(--gold);
  transform:rotate(45deg);
}

.form-done{
  display:flex;flex-direction:column;align-items:center;gap:18px;
  text-align:center;padding:24px 0 8px;
  font-family:var(--jp);font-size:14px;line-height:1.9;color:var(--ink-dim);
}
.done-mark{
  width:46px;height:46px;border-radius:50%;
  border:1px solid var(--gold);color:var(--gold);
  display:flex;align-items:center;justify-content:center;font-size:20px;
}

.contact-foot{
  margin-top:84px;padding-top:30px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:24px;align-items:center;text-align:center;
}
.end-socials{display:flex;justify-content:center;gap:22px;}
.end-socials a{
  font-family:var(--grotesk);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);text-decoration:none;transition:color .2s ease;
}
.end-socials a:hover{color:var(--ink);}
.end-foot{
  font-family:var(--grotesk);font-size:10px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--ink-faint);
}

/* ============ OTTER CHARACTER ============ */
.otter-stage {
  position: relative;
  z-index: 2;
  width: clamp(160px, 44vw, 300px);
  margin: 0 auto 8px;
  perspective: 700px;
  perspective-origin: 50% 35%;
}

/* walk-in wrapper: CSS アニメだけ担当 */
.otter-walk {
  width: 100%;
  animation: otterWalkIn 1.5s cubic-bezier(.22,1,.36,1) both;
}

@keyframes otterWalkIn {
  0% {
    transform: translateX(110vw) scale(0.68);
    opacity: 0;
  }
  18% { opacity: 1; }
  72% {
    transform: translateX(0) scale(1.07);
  }
  84% {
    transform: translateX(0) scale(0.96);
  }
  92% {
    transform: translateX(0) scale(1.02);
  }
  100% {
    transform: translateX(0) scale(1);
    opacity: 1;
  }
}

/* otter img: JS の tilt + float だけ担当 */
.otter-char {
  width: 100%;
  display: block;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  transform-origin: center 80%;    /* 足元付近を支点にして自然な傾き */
  will-change: transform;
  filter:
    drop-shadow(0 12px 40px rgba(0,0,0,0.7))
    drop-shadow(0  4px 12px rgba(0,0,0,0.45));
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}

@media(min-width:768px){
  .otter-stage {
    width: clamp(220px, 26vw, 360px);
    margin-bottom: 16px;
  }
}

/* ============ DESKTOP (min-width: 768px) ============ */
@media(min-width:768px){
  :root{--gutter:56px;--section-gap:240px;}
  .topnav{display:flex;}
  .hero-sub{font-size:15px;}
  .exhibit{max-width:760px;}
  .exhibit.portrait{max-width:470px;}
  .placard .desc{font-size:15px;}
  .field-row{flex-direction:row;}
  .field-row .field{flex:1;}
  .form-foot{flex-direction:row;justify-content:space-between;align-items:center;}
  .contact-foot{flex-direction:row;justify-content:space-between;}
}

@media(min-width:1024px){
  :root{--gutter:64px;}
  .exhibit{max-width:820px;}
}
