/* ============================================
   HEROPICTURES 共通スタイル（全ページ共有）
   ============================================ */
:root{
  --font-jp:'Noto Sans JP', sans-serif;
  --font-jp-serif:'Noto Serif JP', serif;
  --font-en:'Space Grotesk', sans-serif;
  --font-display:'Syne', sans-serif;
  --font-mono:'JetBrains Mono', monospace;

  --y:#EAFE53;
  --g:#E4E4E4;
  --i:#0C00AC;
  --i-dark:#06005A;
  --i-deep:#080076;
  --i-mid:#0A0090;

  --gutter:clamp(20px,3vw,40px);
  --easing:cubic-bezier(.2,.8,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{
  background:var(--i);color:var(--g);
  font-family:var(--font-jp);font-weight:400;font-size:14px;line-height:1.85;
  -webkit-font-smoothing:antialiased;letter-spacing:.01em;overflow-x:hidden;
  word-break:auto-phrase;line-break:strict;
}
a{color:inherit;text-decoration:none;}
::selection{background:var(--y);color:var(--i);}

/* Brand banner — clarifies NEWHERO operates HEROPICTURES */
.brand-banner{
  position:fixed;top:0;left:0;right:0;z-index:210;height:26px;
  background:var(--y);color:var(--i);
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;text-decoration:none;font-weight:600;
  border-bottom:1px solid rgba(12,0,172,.18);
  transition:background .25s var(--easing);
}
.brand-banner:hover{background:#fff;}
.brand-banner .ar{font-family:var(--font-display);font-weight:700;}
@media(max-width:560px){.brand-banner{font-size:9.5px;letter-spacing:.14em;}}

/* Side rail */
.rail{
  position:fixed;left:0;top:26px;bottom:0;width:48px;z-index:30;
  border-right:1px solid rgba(234,254,83,.35);
  display:flex;flex-direction:column;justify-content:space-between;align-items:center;
  padding:20px 0;background:var(--i);
}
.rail .vmark{writing-mode:vertical-rl;font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;color:var(--y);}
.rail .vmark b{color:var(--g);font-weight:400;}
.rail .dot{width:8px;height:8px;background:var(--y);border-radius:50%;}
.rail .vsmall{writing-mode:vertical-rl;font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;color:var(--g);opacity:.7;}
@media(max-width:780px){.rail{display:none;}}

/* Topbar */
.topbar{
  position:fixed;top:26px;left:48px;right:0;z-index:200;
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 28px;
  border-bottom:1px solid rgba(234,254,83,.35);
  background:rgba(12,0,172,.92);backdrop-filter:blur(10px);
  font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;color:var(--g);
}
.topbar .brand,.topbar a.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;}
.topbar .brand img.logo,.topbar a.brand img.logo{height:18px;width:auto;display:block;filter:brightness(0) invert(1);}
.topbar .by-newhero{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;
  color:rgba(234,254,83,.7);text-transform:uppercase;
  border:1px solid rgba(234,254,83,.3);padding:4px 10px;
  text-decoration:none;transition:all .25s var(--easing);
  display:inline-flex;align-items:center;gap:6px;margin-left:18px;
}
.topbar .by-newhero:hover{color:var(--i);background:var(--y);border-color:var(--y);}
.topbar .by-newhero .ext{font-size:9px;}
@media(max-width:560px){.topbar .by-newhero{display:none;}}
.topbar nav{display:none;}
.topbar .r{display:none;}
@media(max-width:780px){.topbar{left:0;}}

/* ── Hamburger ── */
.ham-btn{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  cursor:pointer;background:none;border:none;padding:8px;
  width:40px;height:40px;flex-shrink:0;
}
.ham-btn span{
  display:block;width:22px;height:1.5px;
  background:var(--y);
  transition:transform .35s var(--easing), opacity .25s var(--easing);
  transform-origin:center;
}
.ham-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.ham-btn.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.ham-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* ── Nav Overlay (右スライドパネル / コンパクト) ── */
.nav-overlay{
  position:fixed;top:0;right:0;bottom:0;width:min(380px,88vw);z-index:190;
  background:var(--i-deep);
  border-left:1px solid rgba(234,254,83,.3);
  box-shadow:-30px 0 60px rgba(0,0,0,.4);
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:96px 36px 40px;
  transform:translateX(100%);transition:transform .4s var(--easing);
  opacity:1;pointer-events:none;
}
.nav-overlay.open{transform:translateX(0);pointer-events:all;}
.nav-overlay .ov-nav{display:flex;flex-direction:column;gap:0;}
.nav-overlay .ov-nav a{
  font-family:var(--font-display);
  font-size:24px;
  font-weight:700;color:var(--y);
  letter-spacing:-.005em;line-height:1.3;
  opacity:.5;
  transition:opacity .2s var(--easing), padding-left .2s var(--easing);
  border-bottom:1px solid rgba(234,254,83,.15);
  padding:12px 0;
  display:block;
}
.nav-overlay .ov-nav a:hover{opacity:1;padding-left:8px;}
.nav-overlay .ov-nav a.current{opacity:1;}
.nav-overlay .ov-sub{
  margin-top:28px;padding-top:22px;border-top:1px solid rgba(234,254,83,.18);
  display:flex;flex-direction:column;gap:12px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;
}
.nav-overlay .ov-sub a{
  color:var(--g);border-bottom:1px solid rgba(234,254,83,.25);
  padding-bottom:2px;transition:color .2s var(--easing);align-self:flex-start;
}
.nav-overlay .ov-sub a:hover{color:var(--y);}
.nav-overlay .ov-sub span{color:var(--g);}
@media(max-width:480px){
  .nav-overlay{width:100vw;border-left:none;}
}

body{padding-left:48px;}
@media(max-width:780px){body{padding-left:0;}}

/* Patterns */
.pattern-dots{background-color:var(--i-dark);background-image:radial-gradient(rgba(234,254,83,.12) 1px, transparent 1px);background-size:20px 20px;}
.pattern-stripes{background-color:var(--i-deep);background-image:repeating-linear-gradient(135deg, transparent 0 14px, rgba(234,254,83,.04) 14px 15px);}
.pattern-hgrid{background-color:var(--i-mid);background-image:linear-gradient(0deg, rgba(234,254,83,.06) 1px, transparent 1px);background-size:100% 32px;}
.pattern-cross-wrap{background-color:var(--i-dark);position:relative;}
.pattern-cross-wrap::before{content:"";position:absolute;inset:0;background-image:linear-gradient(0deg, rgba(234,254,83,.14) 1px, transparent 1px),linear-gradient(90deg, rgba(234,254,83,.14) 1px, transparent 1px);background-size:48px 48px;pointer-events:none;mask-image:radial-gradient(circle at center, #000 30%, transparent 75%);}
.pattern-radial{background:radial-gradient(circle at 50% 100%, rgba(234,254,83,.18), transparent 60%),var(--i);}

/* Page hero */
section.page-hero{
  position:relative;padding:140px 28px 80px;
  border-bottom:1px solid rgba(234,254,83,.35);
}
.page-hero .container{max-width:1280px;margin:0 auto;}
.page-hero .crumb{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--g);
  display:flex;gap:10px;align-items:center;margin-bottom:32px;
}
.page-hero .crumb a:hover{color:var(--y);}
.page-hero .crumb .sep{color:rgba(234,254,83,.3);}
.page-hero .label{
  font-family:var(--font-display);font-size:11px;letter-spacing:.22em;color:var(--y);font-weight:500;
  text-transform:uppercase;display:inline-block;margin-bottom:18px;
}
.page-hero h1{
  font-family:var(--font-jp-serif);font-weight:500;
  font-size:clamp(32px,5vw,64px);line-height:1.4;letter-spacing:.02em;
  max-width:24ch;margin-bottom:24px;color:var(--y);
}
.page-hero h1 em{font-style:italic;color:var(--g);}
.page-hero .lede{font-size:15px;color:var(--g);font-weight:300;max-width:48ch;line-height:1.95;}

/* Section */
section.s{padding:96px 28px;border-top:1px solid rgba(234,254,83,.35);}
.container{max-width:1280px;margin:0 auto;}
.s-head{display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:16px;margin-bottom:48px;}
.s-head .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--y);}
.s-head h2{font-family:var(--font-jp-serif);font-weight:500;font-size:clamp(24px,3vw,40px);line-height:1.55;color:var(--y);max-width:24ch;}

/* Atoms */
.btn-y{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;background:var(--y);color:var(--i);
  font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;
  transition:background .25s var(--easing);
}
.btn-y:hover{background:#fff;}
.btn-line{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border:1px solid var(--y);color:var(--y);
  font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;
}
.btn-line:hover{background:var(--y);color:var(--i);}

/* Footer */
footer{padding:48px 28px 28px;border-top:1px solid rgba(234,254,83,.35);background:var(--i);}
.foot{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:3fr 1fr 1fr 1fr;gap:32px;}
@media(max-width:780px){.foot{grid-template-columns:1fr 1fr;}}
.foot .brand img{height:20px;width:auto;display:block;filter:brightness(0) invert(1);margin-bottom:14px;}
.foot p{font-size:12px;color:var(--g);max-width:32ch;font-weight:300;}
.foot h5{font-family:var(--font-display);font-size:11px;letter-spacing:.22em;color:var(--y);margin-bottom:12px;font-weight:500;text-transform:uppercase;}
.foot a{display:block;font-size:12px;color:var(--g);padding:4px 0;}
.foot a:hover{color:var(--y);}
.copy{margin-top:32px;display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--g);letter-spacing:.12em;border-top:1px solid rgba(234,254,83,.35);padding-top:18px;flex-wrap:wrap;gap:12px;max-width:1200px;margin-left:auto;margin-right:auto;}

.reveal{opacity:0;transform:translateY(20px);transition:all 1s var(--easing);}
.reveal.in{opacity:1;transform:none;}

/* === HEROPICTURES detail enhancements === */
.hp-callout{
  border-left:2px solid var(--y);padding:18px 0 18px 28px;
  font-family:var(--font-jp-serif);font-size:clamp(17px,2vw,20px);
  font-weight:400;line-height:1.7;color:var(--g);max-width:64ch;margin:32px 0;
}
.hp-callout b{color:var(--y);font-weight:500;}

.hp-grid{display:grid;gap:1px;background:rgba(234,254,83,.18);border:1px solid rgba(234,254,83,.18);}
.hp-grid.cols-2{grid-template-columns:repeat(2,1fr);}
.hp-grid.cols-3{grid-template-columns:repeat(3,1fr);}
.hp-grid.cols-4{grid-template-columns:repeat(4,1fr);}
@media(max-width:900px){.hp-grid.cols-3,.hp-grid.cols-4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.hp-grid.cols-2,.hp-grid.cols-3,.hp-grid.cols-4{grid-template-columns:1fr;}}
.hp-grid > div{background:var(--i-deep);padding:28px 24px;}
.hp-grid > div .num,.hp-grid > div .ctx-label{
  display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;
  color:var(--y);text-transform:uppercase;margin-bottom:14px;font-weight:500;
}
.hp-grid > div h4{font-family:var(--font-jp-serif);font-size:17px;color:var(--y);font-weight:500;line-height:1.55;margin-bottom:8px;letter-spacing:.02em;}
.hp-grid > div p{font-size:13.5px;color:var(--g);font-weight:300;line-height:1.85;}

.hp-process{list-style:none;padding:0;margin:0;}
.hp-process > li{
  display:grid;grid-template-columns:140px 1fr;gap:24px;
  padding:30px 0;border-top:1px solid rgba(234,254,83,.18);
}
.hp-process > li:last-child{border-bottom:1px solid rgba(234,254,83,.18);}
.hp-process .step{font-family:var(--font-display);font-size:11px;letter-spacing:.22em;color:var(--y);font-weight:600;padding-top:6px;text-transform:uppercase;}
.hp-process h4{font-family:var(--font-jp-serif);font-size:18px;color:var(--y);font-weight:500;line-height:1.55;letter-spacing:.02em;margin-bottom:8px;}
.hp-process p{font-size:14px;color:var(--g);font-weight:300;line-height:1.85;max-width:60ch;}
@media(max-width:600px){.hp-process > li{grid-template-columns:1fr;gap:8px;}}

.hp-principle{padding:32px 28px;background:rgba(0,0,0,.25);border:1px solid rgba(234,254,83,.18);}
.hp-principle .num{display:block;font-family:var(--font-display);font-size:11px;letter-spacing:.22em;color:var(--y);font-weight:600;margin-bottom:18px;text-transform:uppercase;}
.hp-principle h4{font-family:var(--font-jp-serif);font-size:19px;color:var(--y);font-weight:500;line-height:1.55;margin-bottom:10px;letter-spacing:.02em;}
.hp-principle p{font-size:14px;color:var(--g);font-weight:300;line-height:1.85;}

.hp-grid-card-wrap{display:grid;gap:18px;}
.hp-grid-card-wrap.cols-2{grid-template-columns:repeat(2,1fr);}
.hp-grid-card-wrap.cols-3{grid-template-columns:repeat(3,1fr);}
.hp-grid-card-wrap.cols-4{grid-template-columns:repeat(4,1fr);}
@media(max-width:900px){.hp-grid-card-wrap.cols-3,.hp-grid-card-wrap.cols-4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.hp-grid-card-wrap.cols-2,.hp-grid-card-wrap.cols-3,.hp-grid-card-wrap.cols-4{grid-template-columns:1fr;}}

.hp-ba{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid rgba(234,254,83,.18);}
@media(max-width:780px){.hp-ba{grid-template-columns:1fr;}}
.hp-ba > div{padding:32px 28px;}
.hp-ba > div:first-child{border-right:1px solid rgba(234,254,83,.18);}
@media(max-width:780px){.hp-ba > div:first-child{border-right:none;border-bottom:1px solid rgba(234,254,83,.18);}}
.hp-ba h5{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;color:var(--y);font-weight:500;margin-bottom:18px;text-transform:uppercase;}
.hp-ba ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:12px;}
.hp-ba li{font-size:14px;color:var(--g);line-height:1.85;font-weight:300;padding-left:18px;position:relative;}
.hp-ba li::before{content:"";position:absolute;left:0;top:14px;width:8px;height:1px;background:var(--y);opacity:.7;}

.hp-faq{display:flex;flex-direction:column;}
.hp-faq details{border-top:1px solid rgba(234,254,83,.18);padding:24px 0;}
.hp-faq details:last-of-type{border-bottom:1px solid rgba(234,254,83,.18);}
.hp-faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-jp-serif);font-size:17px;color:var(--y);font-weight:500;line-height:1.55;gap:24px;}
.hp-faq summary::-webkit-details-marker{display:none;}
.hp-faq summary::after{content:"+";font-family:var(--font-display);font-size:24px;color:var(--y);font-weight:300;flex-shrink:0;}
.hp-faq details[open] summary::after{content:"−";}
.hp-faq details p{margin-top:14px;font-size:14px;color:var(--g);font-weight:300;line-height:1.95;max-width:64ch;}

.hp-deliverable{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;padding:18px 0;border-top:1px solid rgba(234,254,83,.18);}
.hp-deliverable:last-child{border-bottom:1px solid rgba(234,254,83,.18);}
.hp-deliverable .ico{width:42px;height:42px;border:1px solid rgba(234,254,83,.4);display:grid;place-items:center;font-family:var(--font-display);font-size:12px;color:var(--y);font-weight:600;flex-shrink:0;}
.hp-deliverable h5{font-family:var(--font-jp-serif);font-size:16px;color:var(--y);font-weight:500;line-height:1.55;margin-bottom:4px;letter-spacing:.02em;}
.hp-deliverable p{font-size:13px;color:var(--g);font-weight:300;line-height:1.8;max-width:60ch;}

.hp-shead{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start;margin-bottom:48px;}
@media(max-width:780px){.hp-shead{grid-template-columns:1fr;gap:12px;margin-bottom:32px;text-align:center;}.hp-shead h2{margin-left:auto;margin-right:auto;}}
.hp-shead .s-num{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;color:var(--y);font-weight:500;text-transform:uppercase;padding-top:8px;white-space:nowrap;}
.hp-shead h2{font-family:var(--font-jp-serif);font-size:clamp(24px,3vw,40px);color:var(--y);font-weight:500;line-height:1.5;letter-spacing:.02em;max-width:24ch;}

.hp-pill-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.hp-pill{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;color:var(--y);border:1px solid rgba(234,254,83,.4);padding:6px 12px;text-transform:uppercase;}

/* === Site search (HEROPICTURES skin) === */
.search-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border:1px solid rgba(234,254,83,.4);border-radius:50%;
  background:transparent;color:var(--y);cursor:pointer;padding:0;flex-shrink:0;
  transition:border-color .25s var(--easing), color .25s var(--easing), background .25s var(--easing);
}
.search-btn:hover{border-color:var(--y);background:var(--y);color:var(--i);}
.search-btn svg{display:block;}
.mob-search-link{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--g);text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;border-bottom:1px solid rgba(234,254,83,.25);padding-bottom:2px;}
.mob-search-link::before{content:"⌕";font-size:14px;}
.mob-search-link:hover{color:var(--y);}

.search-modal{position:fixed;inset:0;z-index:400;display:none;}
.search-modal.open{display:block;}
.search-backdrop{position:absolute;inset:0;background:rgba(6,0,90,.7);backdrop-filter:blur(6px);}
.search-panel{
  position:relative;max-width:760px;margin:80px auto 0;
  background:var(--i-deep);border:1px solid rgba(234,254,83,.35);
  box-shadow:0 24px 64px rgba(0,0,0,.4);
  display:flex;flex-direction:column;max-height:calc(100vh - 120px);
}
@media(max-width:780px){.search-panel{margin:0;max-height:100vh;height:100vh;}}
.search-bar{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid rgba(234,254,83,.3);}
.search-bar-icon{color:var(--y);flex-shrink:0;}
.search-input{
  flex:1;border:none;outline:none;background:transparent;
  font-family:inherit;font-size:17px;color:var(--y);padding:6px 0;
  font-weight:400;letter-spacing:.01em;
}
.search-input::placeholder{color:rgba(234,254,83,.45);}
.search-lang{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;color:var(--g);text-transform:uppercase;cursor:pointer;flex-shrink:0;user-select:none;}
.search-lang input{margin:0;cursor:pointer;accent-color:var(--y);}
@media(max-width:560px){.search-lang span{display:none;}}
.search-close{
  background:none;border:none;font-size:24px;line-height:1;color:var(--g);
  cursor:pointer;padding:4px 8px;flex-shrink:0;transition:color .2s;
}
.search-close:hover{color:var(--y);}
.search-status{padding:14px 24px;font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--g);text-transform:uppercase;border-bottom:1px solid rgba(234,254,83,.18);}
.search-results{overflow-y:auto;flex:1;}
.search-results:empty{display:none;}
.sr-item{
  display:block;padding:18px 24px;border-bottom:1px solid rgba(234,254,83,.18);
  text-decoration:none;color:var(--g);transition:background .15s var(--easing);
}
.sr-item:last-child{border-bottom:none;}
.sr-item:hover, .sr-item.active{background:rgba(234,254,83,.06);}
.sr-item .sr-meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--y);text-transform:uppercase;margin-bottom:6px;font-weight:500;}
.sr-item .sr-url{color:var(--g);opacity:.6;font-weight:400;margin-left:8px;}
.sr-item .sr-title{font-family:var(--font-jp-serif);font-size:17px;font-weight:500;line-height:1.5;margin:0 0 6px;letter-spacing:.02em;color:var(--y);}
.sr-item .sr-snip{font-size:13px;color:var(--g);line-height:1.7;font-weight:300;margin:0;}
.sr-item mark{background:rgba(234,254,83,.25);color:var(--y);padding:0 2px;font-weight:500;}

/* ── WORKS Case Modal ── */
.modal-ov{position:fixed;inset:0;z-index:400;display:none;}
.modal-ov.open{display:block;}
.modal-ov::before{content:"";position:absolute;inset:0;background:rgba(6,0,90,.78);backdrop-filter:blur(6px);}
.modal-box{
  position:relative;max-width:680px;margin:7vh auto 0;
  background:var(--i-deep);border:1px solid rgba(234,254,83,.35);
  box-shadow:0 24px 64px rgba(0,0,0,.45);
  max-height:86vh;overflow-y:auto;
}
.modal-close{
  position:absolute;top:14px;right:14px;z-index:2;
  background:none;border:1px solid rgba(234,254,83,.3);
  width:36px;height:36px;font-size:20px;line-height:1;color:var(--g);
  cursor:pointer;transition:color .2s,border-color .2s,background .2s;
  display:flex;align-items:center;justify-content:center;
}
.modal-close:hover{color:var(--i);background:var(--y);border-color:var(--y);}
.modal-inner{padding:48px 40px 40px;}
@media(max-width:560px){.modal-inner{padding:40px 24px 28px;}.modal-box{margin:0;min-height:100vh;max-height:none;}}
.modal-tag{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;color:var(--y);
  text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;margin-bottom:16px;
}
.modal-tag::before{content:"";width:7px;height:7px;background:var(--y);}
.modal-title{
  font-family:var(--font-jp-serif);font-weight:500;color:var(--y);
  font-size:clamp(22px,3vw,30px);line-height:1.5;letter-spacing:-.005em;margin-bottom:14px;
}
.modal-client{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;color:var(--g);opacity:.8;margin-bottom:24px;}
.modal-desc{font-size:14px;color:var(--g);line-height:1.95;font-weight:300;margin-bottom:32px;}
.dl-zone{border-top:1px solid rgba(234,254,83,.25);padding-top:28px;}
.dl-zone h4{font-family:var(--font-jp-serif);font-weight:500;color:var(--y);font-size:16px;margin-bottom:8px;}
.dl-zone > p{font-size:13px;color:var(--g);opacity:.8;line-height:1.75;font-weight:300;margin-bottom:20px;}
#dlForm{display:flex;flex-direction:column;gap:12px;}
#dlForm input{
  background:rgba(0,0,0,.25);border:1px solid rgba(234,254,83,.3);
  padding:13px 14px;color:var(--g);font-family:var(--font-jp);font-size:14px;
  transition:border-color .2s;
}
#dlForm input::placeholder{color:rgba(228,228,228,.45);}
#dlForm input:focus{outline:none;border-color:var(--y);}
.dl-btn{
  background:var(--y);color:var(--i);border:none;padding:14px 20px;
  font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;font-weight:600;
  cursor:pointer;transition:background .2s;margin-top:4px;
}
.dl-btn:hover{background:#fff;}
.dl-btn:disabled{opacity:.6;cursor:default;}
.dl-success{
  display:none;border-top:1px solid rgba(234,254,83,.25);padding-top:24px;
  font-family:var(--font-jp-serif);color:var(--y);font-size:15px;line-height:1.9;
}
