/* =========================================================
   アルマ株式会社 ホームページ — スタイルシート
   newspaper / 縦組み新聞風レイアウト
   ========================================================= */

:root{
  --ink:#38342f;        /* 墨（やや薄めの黒）＝サイト内で最も濃い色 */
  --ink-rgb:56,52,47;   /* --ink のRGB（影・テクスチャ等の半透明用） */
  --paper:#E8E8E4;      /* 紙面の地色 */
  --page-bg:#bcbcb9;    /* ページ背景 */
  --gray-d:#4A4843;     /* 濃グレー */
  --gray-m:#3a3833;     /* 本文グレー */
  --gray-l:#9a9a95;     /* 淡グレー */
  --rule:#CFCEC9;       /* 罫線 */
  --mincho:'Shippori Mincho',serif;
  --serif:'Noto Serif JP',serif;
  --playfair:'Playfair Display',serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--page-bg);}

a{color:inherit;text-decoration:none;}

/* 縦組み・縦中横 */
.v{writing-mode:vertical-rl;text-orientation:mixed;}
.up{text-combine-upright:all;}

/* ===== 紙面フレーム ===== */
.paper{
  position:relative;
  max-width:1240px;
  margin:0 auto;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  box-shadow:0 10px 50px rgba(var(--ink-rgb),.22);
}

/* ===== 紙のテクスチャ（グレイン）オーバーレイ ===== */
.grain,.grain-lines,.grain-vignette{
  position:absolute;inset:0;pointer-events:none;z-index:6;
}
.grain{
  mix-blend-mode:multiply;opacity:.13;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%22140%22 height=%22140%22><filter id=%22n%22><feTurbulence type=%22fractalNoise%22 baseFrequency=%220.9%22 numOctaves=%223%22/></filter><rect width=%22100%25%22 height=%22100%25%22 filter=%22url(%23n)%22/></svg>');
}
.grain-lines{
  opacity:.4;
  background-image:repeating-linear-gradient(0deg, rgba(var(--ink-rgb),.022) 0 1px, transparent 1px 3px);
}
.grain-vignette{
  background:radial-gradient(135% 115% at 50% 45%, transparent 60%, rgba(var(--ink-rgb),.13) 100%);
}

/* ===== 共通パーツ ===== */
.btn-solid{
  display:inline-block;background:var(--ink);color:var(--paper);
  font:700 14px/1 var(--mincho);letter-spacing:.08em;padding:15px 34px;
  cursor:pointer;transition:opacity .15s ease;
}
.btn-solid:hover{opacity:.85;}
.btn-outline{
  display:inline-block;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  padding:13px 38px;font:700 15px/1 var(--mincho);letter-spacing:.1em;
  cursor:pointer;transition:background .15s ease,color .15s ease;
}
.btn-outline:hover{background:var(--ink);color:var(--paper);}

/* セクション見出し */
.sechead{
  display:flex;justify-content:space-between;align-items:baseline;
  border-top:4px solid var(--ink);padding-top:10px;margin-bottom:28px;
}
.sec-title{
  font:800 30px/1 var(--mincho);letter-spacing:.06em;display:flex;align-items:center;
}
.sec-bullet{display:inline-block;width:15px;height:15px;background:var(--ink);margin-right:13px;}
.sec-en{font:600 11px/1 var(--playfair);letter-spacing:.24em;color:var(--gray-d);}

/* ===== マストヘッド ===== */
/* 最上部の版面ストリップ（新聞の発行情報風） */
.mast-top{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:7px 36px;border-bottom:1px solid var(--ink);
  font:600 10.5px/1 var(--serif);letter-spacing:.14em;color:var(--gray-d);
}
.mast{
  padding:24px 36px 20px;display:flex;align-items:flex-end;
  justify-content:space-between;gap:30px;
}
.mast-id{display:flex;flex-direction:column;align-items:flex-start;}
.mast-eyebrow{font:700 12px/1 var(--playfair);letter-spacing:.3em;color:var(--gray-d);margin-bottom:14px;}
/* 会社名：二重罫線の枠（新聞の題字ロゴ風） */
.nameplate{
  display:inline-block;
  font:800 76px/1 var(--mincho);letter-spacing:.09em;
  border:2px solid var(--ink);
  box-shadow:inset 0 0 0 3px var(--paper), inset 0 0 0 4px var(--ink);
  padding:12px 24px 16px;
}
.mastinfo{
  border-left:1px solid var(--ink);padding-left:20px;
  display:flex;flex-direction:column;gap:11px;max-width:256px;
}
.mastinfo-lead{font:600 15px/1.7 var(--mincho);color:var(--ink);}

.mast-rule-heavy{margin:0 36px;border-top:3px solid var(--ink);}
.mast-rule-fine{margin:3px 36px 0;border-top:1px solid var(--ink);}

/* ===== ナビゲーション ===== */
.nav{
  padding:8px 36px;display:flex;justify-content:center;gap:18px;
  font:600 12px/1 var(--mincho);letter-spacing:.14em;border-bottom:1px solid var(--ink);
}
.nav-link{color:inherit;transition:color .15s ease;}
.nav-link:hover{color:var(--gray-d);}
.nav-sep{color:var(--gray-l);}

/* ===== ヒーロー（会社案内） ===== */
.hero{border-bottom:4px solid var(--ink);display:flex;align-items:stretch;}
.hero-tx{flex:1;padding:32px 46px 34px 36px;display:flex;flex-direction:column;}
.hero-title{
  background:var(--ink);color:var(--paper);
  font:800 60px/1.34 var(--mincho);letter-spacing:.03em;
  padding:16px 26px;margin-bottom:26px;
}
.hero-lead{
  font:600 20px/1.8 var(--mincho);
  border-top:2px solid var(--ink);border-bottom:1px solid var(--ink);
  padding:17px 0;margin-bottom:28px;
}
.cols{
  column-count:2;column-gap:32px;column-rule:1px solid var(--rule);
  font:400 14.5px/2.0 var(--serif);text-align:justify;
}
.cols-p{margin:0;}
.cols-p2{margin:13px 0 0;text-indent:1em;}
.dropcap{float:left;font:700 46px/.78 var(--mincho);margin:7px 10px 0 0;}

.hero-fig{width:436px;flex-shrink:0;border-left:1px solid var(--ink);position:relative;overflow:hidden;}
.hero-figcaption{
  position:absolute;left:15px;top:16px;writing-mode:vertical-rl;
  font:600 11px/1 var(--serif);letter-spacing:.24em;color:var(--gray-d);z-index:3;
}
.hero-img{
  position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  height:566px;width:auto;filter:grayscale(1) contrast(1.16) brightness(1.02);z-index:1;
}
.hero-dots{
  position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  height:566px;width:401px;mix-blend-mode:multiply;opacity:.5;
  background-image:radial-gradient(rgba(var(--ink-rgb),.95) 30%, transparent 33%);
  background-size:4px 4px;
  -webkit-mask-image:url('person.png');-webkit-mask-size:100% 566px;
  -webkit-mask-position:center bottom;-webkit-mask-repeat:no-repeat;
  mask-image:url('person.png');mask-size:100% 566px;
  mask-position:center bottom;mask-repeat:no-repeat;z-index:1;
}

/* ===== 事業内容（SERVICES） ===== */
.svc-sec{padding:34px 36px 20px;}
.svc{display:flex;gap:0;}
.svc-item{flex:1;padding:0 28px;}
.svc-item:first-child{padding-left:0;}
.svc-item:last-child{padding-right:0;}
.svc-item + .svc-item{border-left:1px solid var(--rule);}
.svc-no{font:700 11px/1 var(--mincho);letter-spacing:.16em;color:var(--gray-l);margin-bottom:14px;}
.svc-h{
  background:#b9b8b2;color:var(--ink);
  -webkit-text-stroke:1.5px rgba(255,255,255,.5);paint-order:stroke fill;
  font:700 23px/1.4 var(--mincho);
  padding:10px 14px;margin-bottom:16px;overflow:hidden;
}
.svc-h .autofit{display:inline-block;max-width:100%;white-space:nowrap;}
.svc-p{font:400 14px/1.95 var(--serif);text-align:justify;}

/* ===== 対応領域（CAPABILITIES） ===== */
.cap-sec{padding:34px 36px 38px;}
.cap-sec .sechead{margin-bottom:14px;}
.cap-intro{
  font:500 13.5px/1.7 var(--serif);color:var(--gray-d);
  border-bottom:1px solid var(--rule);padding-bottom:20px;margin-bottom:6px;
}
.capdom{display:flex;align-items:center;gap:13px;border-top:2px solid var(--ink);padding:12px 0;margin-top:8px;}
.capdom:first-of-type{margin-top:0;}
.capdom-dot{width:9px;height:9px;background:var(--ink);flex-shrink:0;}
.capdom-jp{font:800 16px/1 var(--mincho);letter-spacing:.05em;}
.capdom-en{font:600 10px/1 var(--playfair);letter-spacing:.2em;color:var(--gray-l);}
.capdom-line{flex:1;border-bottom:1px solid var(--rule);}
.caprow{display:flex;align-items:baseline;padding:14px 0 14px 22px;border-bottom:1px solid var(--rule);}
.caprow--last{border-bottom:none;}
.capterm{font:700 16px/1.4 var(--mincho);}
.capterm-sub{font:400 11px/1 var(--serif);color:var(--gray-l);}
.caplead{flex:1;border-bottom:1px dotted var(--gray-l);margin:0 14px;transform:translateY(-5px);}
.capnote{font:400 13px/1.4 var(--serif);color:var(--gray-m);}

/* ===== 選ばれる理由（OUR STRENGTH） ===== */
.str-sec{padding:30px 36px 36px;border-top:3px solid var(--ink);}
.str-sec .sechead{border-top:3px solid var(--ink);padding-top:9px;margin-bottom:26px;}
.str{display:flex;align-items:center;gap:0;height:300px;}
.str-col{flex:1;display:flex;flex-direction:column;justify-content:center;gap:26px;}
.str-col--l{padding-right:30px;}
.str-col--r{padding-left:30px;}
.str-h{font:700 18px/1.5 var(--mincho);margin-bottom:7px;}
.str-no{color:var(--gray-l);}
.str-p{font:400 13px/1.95 var(--serif);text-align:justify;color:var(--gray-m);}
.str-note{border-top:1px solid var(--rule);padding-top:16px;font:400 12px/1.85 var(--serif);color:var(--gray-d);text-align:justify;}
.str-quote{
  padding:0 40px;border-left:1px solid var(--ink);border-right:1px solid var(--ink);
  height:100%;display:flex;flex-direction:row-reverse;align-items:stretch;justify-content:center;gap:8px;
}
.str-quote-line{font:700 30px/1.9 var(--mincho);letter-spacing:.08em;}
.str-quote-line--top{align-self:flex-start;}
.str-quote-line--bottom{align-self:flex-end;}

/* ===== 沿革（CHRONICLE） ===== */
.chron-sec{padding:30px 36px 36px;}
.chron-sec .sechead{border-top:3px solid var(--ink);padding-top:9px;margin-bottom:22px;}
.chron{display:grid;grid-template-columns:repeat(3,1fr);border-top:2px solid var(--ink);}
.chron-item{padding:0 30px;position:relative;}
.chron-item:first-child{padding-left:0;}
.chron-item:last-child{padding-right:0;}
.chron-item + .chron-item{border-left:1px solid var(--rule);}
.chron-dot{position:absolute;top:-7px;width:12px;height:12px;background:var(--ink);}
.chron-item:first-child .chron-dot{left:0;}
.chron-item:not(:first-child) .chron-dot{left:30px;}
.yr{font:800 30px/1.1 var(--playfair);letter-spacing:.01em;padding-top:24px;margin-bottom:14px;}
.yr-dash{font-size:18px;color:var(--gray-l);}
.chron-h{font:700 17px/1.55 var(--mincho);border-top:1px solid var(--rule);padding-top:14px;margin-bottom:8px;}
.chron-p{font:400 13.5px/1.85 var(--serif);color:var(--gray-m);}

/* ===== 会社概要（COMPANY PROFILE） ===== */
.company-sec{padding:34px 36px 40px;}
.company-sec .sechead{margin-bottom:24px;}
.dbox{border:1px solid var(--ink);}
.dbox-head{display:flex;justify-content:space-between;align-items:center;background:var(--ink);color:var(--paper);padding:9px 16px;}
.dbox-head-jp{font:700 12px/1 var(--mincho);letter-spacing:.16em;}
.dbox-head-en{font:600 10px/1 var(--playfair);letter-spacing:.22em;}
.dgrid{display:grid;grid-template-columns:1fr 1fr 1fr;}
.dcell{padding:15px 18px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);}
.dcell:nth-child(3n){border-right:none;}
.dcell--wide{grid-column:1 / -1;border-right:none;border-bottom:none;}
.dcell-label{font:600 11px/1 var(--mincho);letter-spacing:.14em;color:var(--gray-l);margin-bottom:8px;}
.dcell-value{font:600 16px/1.45 var(--mincho);color:var(--ink);}
.dcell-value--tight{letter-spacing:.02em;}
.dcell-value--id{letter-spacing:.04em;}
.dcell-value--biz{font:600 14px/1.5 var(--mincho);text-wrap:pretty;}
.dcell-value--addr{line-height:1.55;}

/* ===== お問い合わせ（CONTACT） ===== */
.contactsec{padding:8px 36px 44px;}
.notice{border:3px double var(--ink);padding:42px 40px;text-align:center;}
.notice-label{font:800 22px/1 var(--mincho);letter-spacing:.4em;margin-bottom:8px;}
.notice-en{font:500 11px/1 var(--playfair);letter-spacing:.26em;margin-bottom:24px;color:var(--gray-d);}
.notice-title{font:700 32px/1.5 var(--mincho);margin-bottom:16px;}
.notice-p{font:400 14px/1.95 var(--serif);max-width:560px;margin:0 auto 28px;color:var(--gray-m);}

/* ===== コロフォン（フッター） ===== */
.colophon{
  border-top:3px solid var(--ink);padding:22px 36px 34px;
  display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;
}
.colophon-name{font:800 26px/1 var(--mincho);letter-spacing:.06em;margin-bottom:10px;}
.colophon-name-en{font:600 14px/1 var(--playfair);letter-spacing:.1em;margin-left:12px;color:var(--gray-d);}
.colophon-tag{font:400 12px/1.8 var(--serif);color:var(--gray-d);}
.colophon-meta{text-align:right;font:500 11px/1.9 var(--serif);letter-spacing:.04em;color:var(--gray-d);}
.colophon-meta a:hover{color:var(--ink);}

/* =========================================================
   レスポンシブ
   ========================================================= */
/* タブレット（〜1000px）：マストヘッド縦積み＋ヒーロー単段で、見出し・会社名を1行に収める */
@media (max-width:1000px){
  .mast{flex-direction:column;align-items:flex-start;gap:14px;}
  .mast br{display:none;}
  .mastinfo{border-left:none;padding-left:0;border-top:1px solid var(--rule);padding-top:12px;max-width:none;width:100%;}
  .hero{flex-direction:column;}
  .hero-fig{width:100%;border-left:none;border-top:1px solid var(--ink);height:400px;}
  .hero-img{height:400px;}
  .hero-dots{height:400px;-webkit-mask-size:100% 400px;mask-size:100% 400px;width:284px;}
  .hero-title{font-size:44px;}
  .hero-title br{display:none;}
}

/* スマホ（〜820px） */
@media (max-width:820px){
  .mast-top{padding:6px 20px;font-size:9px;letter-spacing:.06em;gap:8px;}
  .mast-top span:nth-child(2){display:none;}
  .mast{flex-direction:column;align-items:flex-start;gap:14px;padding:22px 20px 14px;}
  .mast-eyebrow{letter-spacing:.12em;font-size:10px;}
  .mast br{display:none;}
  .nameplate{font-size:34px;letter-spacing:.05em;padding:8px 14px 11px;}
  .mastinfo{border-left:none;padding-left:0;border-top:1px solid var(--rule);padding-top:12px;max-width:none;width:100%;}
  .mastinfo-lead{font-size:13.5px;}
  .nav{flex-wrap:wrap;gap:6px 12px;font-size:11.5px;letter-spacing:.05em;padding:9px 18px;}
  .hero-tx{padding:22px 20px 26px;}
  .hero-title{font-size:29px;line-height:1.5;letter-spacing:.02em;margin-bottom:18px;padding:11px 16px;}
  .hero-lead{font-size:15.5px;line-height:1.85;padding:14px 0;margin-bottom:18px;}
  .hero-lead br{display:none;}
  .cols{column-count:1;font-size:14px;}
  .dropcap{font-size:36px;}
  .sechead{flex-direction:column-reverse;align-items:flex-start;gap:6px;margin-bottom:16px;}
  .sec-title{font-size:21px;}
  .sec-en{letter-spacing:.1em;}
  .svc{flex-direction:column;}
  .svc-item{flex:none;padding:0;margin-top:30px;}
  .svc-item:first-child{margin-top:0;}
  .svc-item + .svc-item{border-left:none;}
  .svc-h{font-size:19px;}
  .svc-h br{display:none;}
  .svc-p{font-size:14px;}
  .caprow{flex-wrap:wrap;padding-left:0;}
  .caplead{display:none;}
  .capnote{width:100%;margin-top:5px;font-size:12.5px;}
  .capdom{flex-wrap:wrap;}
  .str{flex-direction:column;align-items:stretch;height:auto;gap:0;}
  .str-col{padding:18px 0;height:auto;border-left:none;border-right:none;}
  .str-col--l{padding-top:2px;}
  .str-quote{
    border-left:none;border-right:none;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
    display:block;text-align:center;font-size:0;white-space:nowrap;padding:22px 10px;height:auto;
  }
  .str-quote-line{
    writing-mode:horizontal-tb;display:inline-block;vertical-align:baseline;height:auto;
    font-size:15px;line-height:1.65;letter-spacing:.02em;white-space:nowrap;
  }
  .chron{grid-template-columns:1fr;border-top:none;}
  .chron-item{padding:20px 0 0;border-left:none;border-top:1px solid var(--ink);}
  .chron-item .chron-dot{display:none;}
  .yr{padding-top:18px;font-size:23px;margin-bottom:10px;}
  .chron-h{font-size:16px;text-wrap:pretty;}
  .chron-p{font-size:13.5px;}
  .dgrid{grid-template-columns:1fr;}
  .dcell{border-right:none;padding:13px 16px;}
  .dcell-value{font-size:15px;}
  .contactsec{padding:8px 16px 36px;}
  .notice{padding:28px 16px;}
  .notice-label{letter-spacing:.14em;font-size:19px;}
  .notice-title{font-size:18px;}
}

/* =========================================================
   お問い合わせモーダル & フォーム
   ========================================================= */

/* お問い合わせ導線を <button> 化したため、各クラスのUA初期化 */
.btn-solid,.btn-outline{border-width:0;}
.btn-outline{border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);background:transparent;}
/* スクロールロック */
body.modal-open{overflow:hidden;}

/* モーダル */
.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;}
.modal[hidden]{display:none;}
.modal-backdrop{position:absolute;inset:0;background:rgba(var(--ink-rgb),.62);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);}
.modal-dialog{
  position:relative;z-index:1;width:100%;max-width:620px;
  max-height:calc(100vh - 48px);overflow:auto;
  background:var(--paper);color:var(--ink);
  border:3px double var(--ink);box-shadow:0 24px 70px rgba(var(--ink-rgb),.4);
  padding:34px 36px 30px;
  animation:modal-in .22s ease;
}
@keyframes modal-in{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.modal-close{
  position:absolute;top:12px;right:14px;width:34px;height:34px;line-height:1;
  background:none;border:0;cursor:pointer;font:400 26px/1 var(--mincho);color:var(--gray-d);
  transition:color .15s ease;
}
.modal-close:hover{color:var(--ink);}
.modal-head{border-bottom:2px solid var(--ink);padding-bottom:16px;margin-bottom:22px;}
.modal-eyebrow{font:500 11px/1 var(--playfair);letter-spacing:.26em;color:var(--gray-d);margin-bottom:7px;}
.modal-title{font:800 26px/1.2 var(--mincho);letter-spacing:.06em;margin-bottom:12px;}
.modal-lead{font:400 13px/1.85 var(--serif);color:var(--gray-m);}

/* フォーム */
.cform{display:flex;flex-direction:column;gap:16px;}
.cform-row{display:flex;gap:16px;}
.cform-field{display:flex;flex-direction:column;gap:7px;flex:1;min-width:0;}
.cform-label{font:600 12.5px/1 var(--mincho);letter-spacing:.06em;color:var(--ink);display:flex;align-items:center;gap:8px;}
.cform-req{font:700 9.5px/1 var(--serif);letter-spacing:.08em;color:var(--paper);background:var(--ink);padding:3px 6px;font-style:normal;}
.cform-input{
  font:400 15px/1.6 var(--serif);color:var(--ink);
  background:rgba(255,255,255,.5);
  border:1px solid var(--gray-l);padding:11px 13px;width:100%;
  transition:border-color .15s ease,background .15s ease;
}
.cform-input:focus{outline:none;border-color:var(--ink);background:#fff;}
.cform-input:disabled{opacity:.6;}
.cform-textarea{resize:vertical;min-height:150px;}
.cform-alert{font:500 13px/1.7 var(--serif);padding:12px 14px;border:1px solid;}
.cform-alert.is-ok{color:#1f5130;border-color:#2f7d4a;background:rgba(47,125,74,.08);}
.cform-alert.is-ng{color:#7a2420;border-color:#a33b34;background:rgba(163,59,52,.08);}
.cform-actions{display:flex;justify-content:flex-end;gap:12px;align-items:center;margin-top:6px;}
.btn-ghost{
  background:none;border:0;cursor:pointer;
  font:600 13px/1 var(--mincho);letter-spacing:.06em;color:var(--gray-d);padding:13px 18px;
  transition:color .15s ease;
}
.btn-ghost:hover{color:var(--ink);}
.cform-submit{border:0;}
.cform-submit:disabled{opacity:.55;cursor:default;}

@media (max-width:820px){
  .modal{padding:14px;}
  .modal-dialog{padding:26px 20px 22px;max-height:calc(100vh - 28px);}
  .modal-title{font-size:22px;}
  .cform-row{flex-direction:column;gap:16px;}
}
