/*
Theme Name: GROW
Theme URI: https://example.com
Description: 株式会社グロー / キャリカク広島駅オフィス（就労継続支援B型）コーポレートテーマ
Author: Freys International & Company
Version: 1.0.0
Text Domain: grow
*/

/* =========================================================
   株式会社グロー / キャリカク広島駅オフィス
   静的プレビュー共通CSS  ── 落ち着いたネイビー×ブラウン×光ゴールド
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif+JP:wght@300;500;700&family=Poppins:wght@300;400;500&display=swap');

:root{
  --navy:#26456E;
  --navy-deep:#1B3354;
  --brown:#7B5C3E;
  --gold:#E0A94B;
  --gold-soft:#F0D9A8;
  --cream:#FBF8F2;
  --cream-2:#F4EEE2;
  --ink:#2A3344;
  --muted:#6B7280;
  --line:#E4DBC9;
  --serif:'Noto Serif JP',serif;
  --sans:'Noto Sans JP',sans-serif;
  --en:'Poppins',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.9;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;transition:color .25s,opacity .25s;}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px;}
.wrap-narrow{max-width:860px;margin:0 auto;padding:0 28px;}

/* 英字ラベル（eyebrow） */
.eyebrow{font-family:var(--en);font-weight:400;font-size:.72rem;letter-spacing:.32em;color:var(--gold);text-transform:uppercase;display:inline-block;}
.eyebrow.navy{color:var(--navy);}

/* セクション見出し（明朝＋光のライン） */
.sec-head{margin-bottom:54px;}
.sec-head .ja{font-family:var(--serif);font-weight:500;font-size:2.05rem;line-height:1.5;color:var(--navy);letter-spacing:.04em;margin-top:10px;position:relative;display:inline-block;}
.sec-head .ja::after{content:"";display:block;width:52px;height:2px;margin-top:18px;
  background:linear-gradient(90deg,var(--gold),rgba(224,169,75,0));}
.sec-head.center{text-align:center;}
.sec-head.center .ja::after{margin-left:auto;margin-right:auto;}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,248,242,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;max-width:1120px;margin:0 auto;}
.brand{display:flex;align-items:center;gap:13px;}
.brand .logo-mark{width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 50% 42%,var(--gold) 0%,var(--gold) 30%,#C98F33 70%);position:relative;flex:none;box-shadow:0 0 0 1px rgba(123,92,62,.25);}
.brand .logo-mark::before{content:"";position:absolute;inset:0;border-radius:50%;
  background:repeating-conic-gradient(from 0deg,rgba(255,255,255,.5) 0deg 3deg,transparent 3deg 22deg);opacity:.5;}
.brand .logo-txt{line-height:1.25;}
.brand .logo-txt b{font-family:var(--serif);font-weight:500;font-size:1.12rem;color:var(--navy);letter-spacing:.06em;display:block;}
.brand .logo-txt span{font-family:var(--en);font-size:.6rem;letter-spacing:.34em;color:var(--brown);text-transform:uppercase;}
.gnav ul{display:flex;list-style:none;gap:30px;align-items:center;}
.gnav a{font-size:.86rem;font-weight:500;color:var(--ink);position:relative;padding:4px 0;}
.gnav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--gold);transition:width .28s;}
.gnav a:hover{color:var(--navy);}
.gnav a:hover::after{width:100%;}
.gnav .nav-cta{background:var(--navy);color:#fff;padding:9px 20px;border-radius:2px;font-weight:500;}
.gnav .nav-cta::after{display:none;}
.gnav .nav-cta:hover{background:var(--navy-deep);color:#fff;}
.menu-btn{display:none;background:none;border:none;cursor:pointer;width:30px;height:22px;position:relative;}
.menu-btn span{position:absolute;left:0;width:100%;height:2px;background:var(--navy);transition:.3s;}
.menu-btn span:nth-child(1){top:0;}
.menu-btn span:nth-child(2){top:10px;}
.menu-btn span:nth-child(3){top:20px;}

/* ---------- Hero（光の地平線） ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--navy-deep) 0%,var(--navy) 55%,#33567E 100%);color:#fff;}
.hero .sun{position:absolute;left:50%;bottom:-260px;transform:translateX(-50%);width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(240,217,168,.95) 0%,rgba(224,169,75,.55) 38%,rgba(224,169,75,0) 70%);
  filter:blur(2px);}
.hero .rays{position:absolute;left:50%;bottom:-30px;transform:translateX(-50%);width:1200px;height:600px;
  background:conic-gradient(from 200deg at 50% 100%,
     transparent 0deg,rgba(240,217,168,.10) 8deg,transparent 16deg,
     rgba(240,217,168,.12) 24deg,transparent 32deg,
     rgba(240,217,168,.10) 40deg,transparent 48deg,
     rgba(240,217,168,.13) 56deg,transparent 64deg,
     rgba(240,217,168,.10) 72deg,transparent 80deg);
  pointer-events:none;}
.hero-inner{position:relative;z-index:2;max-width:1120px;margin:0 auto;padding:120px 28px 150px;}
.hero .eyebrow{color:var(--gold-soft);margin-bottom:26px;}
.hero h1{font-family:var(--serif);font-weight:300;font-size:3.2rem;line-height:1.55;letter-spacing:.06em;margin-bottom:30px;}
.hero h1 b{font-weight:700;color:var(--gold-soft);}
.hero p.lead{font-weight:300;font-size:1.05rem;line-height:2.1;max-width:620px;color:rgba(255,255,255,.86);}
.hero .meta{margin-top:38px;font-family:var(--en);font-size:.74rem;letter-spacing:.22em;color:rgba(255,255,255,.6);display:flex;gap:22px;flex-wrap:wrap;}
.hero-cta{margin-top:44px;display:flex;gap:16px;flex-wrap:wrap;}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 32px;border-radius:2px;font-weight:500;font-size:.92rem;letter-spacing:.04em;transition:.25s;}
.btn-gold{background:var(--gold);color:var(--navy-deep);}
.btn-gold:hover{background:var(--gold-soft);}
.btn-ghost{border:1px solid rgba(255,255,255,.45);color:#fff;}
.btn-ghost:hover{background:rgba(255,255,255,.1);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-deep);color:#fff;}
.btn-line{background:#06C755;color:#fff;}
.btn-line:hover{opacity:.88;color:#fff;}

/* ---------- セクション ---------- */
section{padding:96px 0;}
.bg-cream2{background:var(--cream-2);}
.bg-navy{background:var(--navy);color:#fff;}
.bg-white{background:#fff;}

/* 会社メッセージ（非対称2カラム） */
.split{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center;}
.split.rev{grid-template-columns:1.1fr 1fr;}
.split .photo{position:relative;}
.split .photo img{border-radius:3px;box-shadow:0 18px 50px rgba(27,51,84,.16);}
.split .photo .tag{position:absolute;bottom:-18px;left:-18px;background:#fff;padding:14px 22px;border-left:3px solid var(--gold);box-shadow:0 10px 30px rgba(0,0,0,.1);font-family:var(--serif);font-size:.95rem;color:var(--navy);}
.split .body p{margin-bottom:20px;color:#41495a;}
.split .body p.first{font-family:var(--serif);font-size:1.35rem;line-height:1.95;color:var(--navy);font-weight:500;}

/* 事業（サービス）：横長カード・写真付き・非対称 */
.work-list{display:flex;flex-direction:column;gap:28px;}
.work-row{display:grid;grid-template-columns:200px 1fr;gap:34px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:3px;overflow:hidden;}
.work-row .num{font-family:var(--en);font-weight:300;font-size:2.4rem;color:var(--gold);}
.work-row .ph{height:100%;min-height:160px;}
.work-row .ph img{height:100%;width:100%;object-fit:cover;}
.work-row .txt{padding:30px 34px 30px 0;}
.work-row .txt h3{font-family:var(--serif);font-size:1.3rem;color:var(--navy);margin-bottom:10px;font-weight:500;}
.work-row .txt p{color:#4b5365;font-size:.95rem;}
.work-row .ico{color:var(--brown);font-size:.78rem;letter-spacing:.2em;font-family:var(--en);text-transform:uppercase;margin-bottom:8px;display:block;}

/* 特徴（横線区切り・番号なし、非対称） */
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);}
.feature-cell{padding:40px 36px;border-bottom:1px solid var(--line);}
.feature-cell:nth-child(odd){border-right:1px solid var(--line);}
.feature-cell h3{font-family:var(--serif);font-size:1.18rem;color:var(--navy);margin-bottom:12px;font-weight:500;display:flex;align-items:baseline;gap:12px;}
.feature-cell h3 i{color:var(--gold);font-size:.9rem;}
.feature-cell p{color:#4b5365;font-size:.94rem;}

/* 事業所紹介（キャリカク） */
.facility-hero{position:relative;border-radius:4px;overflow:hidden;}
.facility-hero img{width:100%;height:380px;object-fit:cover;}
.facility-hero .ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(27,51,84,.78),rgba(27,51,84,.15));display:flex;align-items:center;}
.facility-hero .ov .in{padding:0 52px;color:#fff;max-width:560px;}
.facility-hero .ov .in .badge{display:inline-block;background:var(--gold);color:var(--navy-deep);font-size:.72rem;letter-spacing:.12em;padding:5px 14px;border-radius:2px;font-weight:700;margin-bottom:18px;}
.facility-hero .ov .in h3{font-family:var(--serif);font-size:1.9rem;font-weight:500;line-height:1.5;}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px;}
.gallery img{height:200px;width:100%;object-fit:cover;border-radius:3px;}
.gallery .tall{grid-row:span 2;height:auto;}

/* データ（定員・時間など）横並びストリップ */
.datastrip{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:#fff;border:1px solid var(--line);border-radius:3px;overflow:hidden;}
.datastrip .d{padding:30px 24px;text-align:center;border-right:1px solid var(--line);}
.datastrip .d:last-child{border-right:none;}
.datastrip .d .k{font-family:var(--en);font-size:.66rem;letter-spacing:.2em;color:var(--brown);text-transform:uppercase;margin-bottom:10px;}
.datastrip .d .v{font-family:var(--serif);font-size:1.45rem;color:var(--navy);font-weight:500;}
.datastrip .d .v small{font-size:.8rem;color:var(--muted);}

/* フロー（番号は本物のシーケンス） */
.flow{display:flex;flex-direction:column;}
.flow .step{display:grid;grid-template-columns:90px 1fr;gap:30px;padding:34px 0;border-bottom:1px solid var(--line);}
.flow .step:last-child{border-bottom:none;}
.flow .step .n{font-family:var(--en);font-weight:300;font-size:2.6rem;color:var(--gold);line-height:1;position:relative;}
.flow .step .n::after{content:"";display:block;width:1px;height:calc(100% - 10px);background:var(--line);position:absolute;left:18px;top:54px;}
.flow .step:last-child .n::after{display:none;}
.flow .step h3{font-family:var(--serif);font-size:1.25rem;color:var(--navy);margin-bottom:10px;font-weight:500;}
.flow .step p{color:#4b5365;font-size:.95rem;}
.flow .step .note{margin-top:14px;background:var(--cream-2);border-left:2px solid var(--gold);padding:14px 18px;font-size:.88rem;color:#41495a;border-radius:0 3px 3px 0;}
.flow .step .note ul{margin:6px 0 0 18px;}

/* FAQ */
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{padding:22px 4px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--serif);font-weight:500;color:var(--navy);font-size:1.02rem;}
.faq-q::after{content:"+";font-family:var(--en);font-weight:300;font-size:1.5rem;color:var(--gold);transition:transform .3s;}
.faq-item.open .faq-q::after{transform:rotate(45deg);}
.faq-a{display:none;padding:0 4px 24px;color:#4b5365;font-size:.95rem;}
.faq-item.open .faq-a{display:block;}

/* スタッフメッセージ */
.message-block{background:#fff;border:1px solid var(--line);border-radius:4px;padding:54px 56px;position:relative;}
.message-block::before{content:"\201C";position:absolute;top:14px;left:28px;font-family:var(--serif);font-size:5rem;color:var(--gold-soft);line-height:1;}
.message-block p{font-family:var(--serif);font-size:1.18rem;line-height:2.15;color:var(--navy);position:relative;z-index:1;}
.message-block .who{margin-top:26px;font-size:.9rem;color:var(--brown);font-family:var(--en);letter-spacing:.1em;}

/* お知らせ/ブログ */
.news-list{display:flex;flex-direction:column;}
.news-row{display:grid;grid-template-columns:130px 110px 1fr;gap:20px;align-items:center;padding:22px 4px;border-bottom:1px solid var(--line);transition:background .2s;}
.news-row:hover{background:#fff;}
.news-row time{font-family:var(--en);font-size:.82rem;color:var(--muted);letter-spacing:.06em;}
.news-row .cat{font-size:.72rem;color:var(--navy);border:1px solid var(--navy);border-radius:2px;text-align:center;padding:3px 0;letter-spacing:.08em;}
.news-row h4{font-size:.98rem;font-weight:500;color:var(--ink);}

/* アクセス情報 */
.info-table{width:100%;border-collapse:collapse;}
.info-table th{text-align:left;font-family:var(--serif);font-weight:500;color:var(--brown);width:130px;padding:16px 0;vertical-align:top;border-bottom:1px solid var(--line);font-size:.95rem;}
.info-table td{padding:16px 0;border-bottom:1px solid var(--line);color:var(--ink);font-size:.95rem;}
.map-box{width:100%;height:340px;background:var(--cream-2);border:1px dashed var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.9rem;border-radius:3px;}

/* CTA帯 */
.cta-band{background:linear-gradient(120deg,var(--navy-deep),var(--navy));color:#fff;text-align:center;padding:80px 28px;position:relative;overflow:hidden;}
.cta-band .glow{position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:400px;height:300px;background:radial-gradient(circle,rgba(224,169,75,.35),transparent 70%);}
.cta-band h2{font-family:var(--serif);font-weight:300;font-size:2rem;line-height:1.6;margin-bottom:14px;position:relative;}
.cta-band p{color:rgba(255,255,255,.8);margin-bottom:34px;position:relative;}
.cta-band .btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,.82);padding:64px 0 28px;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.13);}
.footer-brand .logo-txt b{font-family:var(--serif);font-size:1.2rem;color:#fff;letter-spacing:.06em;}
.footer-brand p{font-size:.85rem;line-height:2;margin-top:14px;color:rgba(255,255,255,.65);}
.footer-col h4{font-family:var(--en);font-size:.7rem;letter-spacing:.22em;color:var(--gold);margin-bottom:18px;text-transform:uppercase;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:11px;}
.footer-col a{font-size:.86rem;color:rgba(255,255,255,.75);}
.footer-col a:hover{color:#fff;}
.footer-bottom{padding-top:24px;text-align:center;font-family:var(--en);font-size:.7rem;letter-spacing:.1em;color:rgba(255,255,255,.45);}

/* page header（下層ページ） */
.page-head{background:var(--navy);color:#fff;padding:70px 0 64px;position:relative;overflow:hidden;}
.page-head .glow{position:absolute;right:-80px;top:-80px;width:320px;height:320px;background:radial-gradient(circle,rgba(224,169,75,.3),transparent 70%);}
.page-head .eyebrow{color:var(--gold-soft);}
.page-head h1{font-family:var(--serif);font-weight:300;font-size:2.4rem;margin-top:10px;letter-spacing:.05em;position:relative;}

/* preview only banner */
.preview-note{display:none;background:#1B3354;color:#fff;text-align:center;font-size:.78rem;padding:8px;font-family:var(--en);letter-spacing:.1em;}
.preview-note b{color:var(--gold);}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .split,.split.rev{grid-template-columns:1fr;gap:36px;}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:760px){
  .menu-btn{display:block;}
  .gnav{position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;background:var(--cream);box-shadow:-10px 0 40px rgba(0,0,0,.15);transform:translateX(100%);transition:transform .3s;padding:90px 30px 30px;z-index:60;}
  .gnav.open{transform:translateX(0);}
  .gnav ul{flex-direction:column;gap:0;align-items:stretch;}
  .gnav li{border-bottom:1px solid var(--line);}
  .gnav a{display:block;padding:16px 0;}
  .gnav .nav-cta{margin-top:18px;text-align:center;}
  .hero h1{font-size:2.1rem;}
  .hero-inner{padding:80px 28px 110px;}
  section{padding:64px 0;}
  .work-row{grid-template-columns:1fr;}
  .work-row .ph{min-height:200px;}
  .work-row .txt{padding:26px 28px;}
  .feature-grid{grid-template-columns:1fr;}
  .feature-cell:nth-child(odd){border-right:none;}
  .gallery{grid-template-columns:1fr 1fr;}
  .datastrip{grid-template-columns:1fr 1fr;}
  .datastrip .d:nth-child(2){border-right:none;}
  .datastrip .d{border-bottom:1px solid var(--line);}
  .facility-hero .ov .in{padding:0 28px;}
  .facility-hero img{height:320px;}
  .flow .step{grid-template-columns:60px 1fr;gap:18px;}
  .message-block{padding:40px 28px;}
  .news-row{grid-template-columns:90px 1fr;}
  .news-row .cat{display:none;}
}

/* =========================================================
   トップページ刷新（GLUG参考：コーポレート／理念主役／写真スライダー）
   ========================================================= */
/* フルスクリーン写真スライダーヒーロー */
.hero-slider{position:relative;height:88vh;min-height:560px;max-height:820px;overflow:hidden;background:var(--navy-deep);}
.hero-slider .slides{position:absolute;inset:0;}
.hero-slider .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s ease;background-size:cover;background-position:center;animation:kenburns 18s ease-in-out infinite;}
.hero-slider .slide.active{opacity:1;}
@keyframes kenburns{0%{transform:scale(1);}100%{transform:scale(1.08);}}
.hero-slider::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,38,62,.62) 0%,rgba(20,38,62,.40) 45%,rgba(20,38,62,.78) 100%);}
.hero-slider .glow-line{position:absolute;left:0;right:0;bottom:0;height:4px;z-index:3;
  background:linear-gradient(90deg,var(--gold),var(--gold-soft),var(--gold));}
.hero-copy{position:absolute;z-index:2;left:0;right:0;bottom:0;top:0;display:flex;flex-direction:column;justify-content:center;}
.hero-copy .inner{max-width:1120px;margin:0 auto;padding:0 28px;width:100%;color:#fff;}
.hero-copy .en{font-family:var(--en);font-weight:300;font-size:.8rem;letter-spacing:.42em;color:var(--gold-soft);text-transform:uppercase;margin-bottom:30px;display:flex;align-items:center;gap:18px;}
.hero-copy .en::before{content:"";width:46px;height:1px;background:var(--gold);}
.hero-copy h1{font-family:var(--serif);font-weight:300;font-size:3.6rem;line-height:1.5;letter-spacing:.05em;margin-bottom:34px;text-shadow:0 2px 30px rgba(0,0,0,.3);}
.hero-copy h1 b{font-weight:700;}
.hero-copy .sub{font-size:1rem;line-height:2;color:rgba(255,255,255,.9);max-width:540px;font-weight:300;}
.hero-scroll{position:absolute;z-index:3;bottom:30px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-family:var(--en);font-size:.62rem;letter-spacing:.3em;text-align:center;}
.hero-scroll::after{content:"";display:block;width:1px;height:40px;background:rgba(255,255,255,.5);margin:10px auto 0;animation:scrolldown 1.8s ease-in-out infinite;}
@keyframes scrolldown{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4;}50%{transform:scaleY(1);opacity:1;}}
.hero-dots{position:absolute;z-index:3;bottom:34px;right:34px;display:flex;gap:10px;}
.hero-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.45);cursor:pointer;padding:0;transition:.3s;}
.hero-dots button.on{background:var(--gold);width:26px;border-radius:5px;}

/* 会社イントロ帯（理念へつなぐ） */
.intro-band{background:var(--cream);padding:88px 0;}
.intro-band .inner{max-width:900px;margin:0 auto;padding:0 28px;text-align:center;}
.intro-band .lead{font-family:var(--serif);font-weight:300;font-size:1.65rem;line-height:2;color:var(--navy);letter-spacing:.04em;}
.intro-band .lead b{font-weight:500;color:var(--brown);}
.intro-band .desc{margin-top:26px;color:#41495a;font-size:.98rem;line-height:2.05;}

/* Philosophy 主役セクション（GLUG風・大きく） */
.philosophy{position:relative;background:linear-gradient(160deg,var(--navy-deep),var(--navy) 70%);color:#fff;padding:130px 0;overflow:hidden;}
.philosophy .bgglow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:760px;height:760px;border-radius:50%;background:radial-gradient(circle,rgba(224,169,75,.16),transparent 62%);}
.philosophy .inner{position:relative;z-index:2;max-width:1000px;margin:0 auto;padding:0 28px;text-align:center;}
.philosophy .label{font-family:var(--en);font-weight:300;letter-spacing:.4em;font-size:.82rem;color:var(--gold);text-transform:uppercase;margin-bottom:40px;}
.philosophy h2{font-family:var(--serif);font-weight:300;font-size:2.9rem;line-height:1.85;letter-spacing:.08em;}
.philosophy h2 b{font-weight:700;color:var(--gold-soft);}
.philosophy .vision{margin-top:54px;display:inline-block;text-align:left;border-left:2px solid var(--gold);padding:6px 0 6px 30px;}
.philosophy .vision li{list-style:none;font-size:1.02rem;line-height:2.2;color:rgba(255,255,255,.9);font-weight:300;}
.philosophy .vision li::before{content:"—  ";color:var(--gold);}

/* 事業内容：カテゴリ構造（GLUG風） */
.biz-cat{margin-bottom:64px;}
.biz-cat:last-child{margin-bottom:0;}
.biz-cat .cat-head{display:flex;align-items:baseline;gap:20px;margin-bottom:8px;}
.biz-cat .cat-head .en{font-family:var(--en);font-weight:300;font-size:.74rem;letter-spacing:.28em;color:var(--gold);text-transform:uppercase;}
.biz-cat .cat-head h3{font-family:var(--serif);font-weight:500;font-size:1.7rem;color:var(--navy);}
.biz-cat .cat-desc{color:#4b5365;margin-bottom:30px;font-size:.96rem;padding-left:2px;}
.biz-cards{display:grid;grid-template-columns:1fr;gap:0;}
.biz-card{display:grid;grid-template-columns:300px 1fr auto;gap:36px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.3s;}
.biz-card+.biz-card{margin-top:20px;}
.biz-card:hover{box-shadow:0 18px 44px rgba(27,51,84,.13);transform:translateY(-3px);}
.biz-card .ph{height:100%;min-height:210px;}
.biz-card .ph img{height:100%;width:100%;object-fit:cover;}
.biz-card .body{padding:34px 0;}
.biz-card .body .tag{display:inline-block;font-size:.7rem;letter-spacing:.1em;color:var(--brown);border:1px solid var(--line);border-radius:2px;padding:3px 10px;margin-bottom:14px;}
.biz-card .body h4{font-family:var(--serif);font-size:1.45rem;color:var(--navy);font-weight:500;margin-bottom:12px;}
.biz-card .body p{color:#4b5365;font-size:.95rem;max-width:560px;}
.biz-card .go{padding-right:38px;color:var(--navy);font-size:1.4rem;flex:none;}
.biz-card.prep{opacity:.92;}
.biz-card.prep .body h4 span{font-size:.72rem;background:var(--cream-2);color:var(--brown);padding:3px 10px;border-radius:2px;margin-left:10px;vertical-align:middle;letter-spacing:.05em;}

/* 会社案内（拠点写真／GLUG風） */
.office-showcase{display:grid;grid-template-columns:1.3fr 1fr;gap:0;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:#fff;}
.office-showcase .ph img{width:100%;height:100%;object-fit:cover;min-height:340px;}
.office-showcase .body{padding:56px 52px;}
.office-showcase .body .en{font-family:var(--en);letter-spacing:.3em;font-size:.72rem;color:var(--gold);text-transform:uppercase;margin-bottom:12px;}
.office-showcase .body h3{font-family:var(--serif);font-weight:500;font-size:1.7rem;color:var(--navy);margin-bottom:8px;}
.office-showcase .body .place{color:var(--muted);font-size:.9rem;margin-bottom:24px;}
.office-showcase .body .links{display:flex;flex-direction:column;gap:0;margin-top:10px;}
.office-showcase .body .links a{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid var(--line);font-size:.94rem;color:var(--ink);font-weight:500;}
.office-showcase .body .links a:first-child{border-top:1px solid var(--line);}
.office-showcase .body .links a:hover{color:var(--navy);padding-left:6px;}
.office-showcase .body .links a i{color:var(--gold);}

@media(max-width:920px){
  .office-showcase{grid-template-columns:1fr;}
  .biz-card{grid-template-columns:1fr;}
  .biz-card .ph{min-height:200px;}
  .biz-card .body{padding:26px 28px;}
  .biz-card .go{display:none;}
}
@media(max-width:760px){
  .hero-copy h1{font-size:2.1rem;}
  .hero-slider{height:78vh;min-height:480px;}
  .philosophy{padding:80px 0;}
  .philosophy h2{font-size:1.85rem;line-height:1.8;}
  .intro-band .lead{font-size:1.25rem;}
  .hero-dots{right:auto;left:28px;}
}
