/* ======================================================================
   株式会社CIMA / CIMA inc. — コーポレートサイト
   トンマナ: ロゴ準拠（太陽の赤・大地の緑・海の青／ネイビー文字／温かく自然体）
   ====================================================================== */
:root{
  --navy:#0B3A57;        /* 見出し・本文の濃色 */
  --navy-deep:#072A40;
  --ink:#33312e;         /* 本文 */
  --muted:#6f6a63;       /* 補足テキスト */
  --sun:#E0432F;         /* 太陽（赤） */
  --land:#6FA021;        /* 大地（緑） */
  --sea:#3090D0;         /* 海（青） */
  --link:#005080;
  --bg:#FBF9F4;          /* 温かいクリーム */
  --bg-alt:#F2EEE5;
  --surface:#ffffff;
  --line:#e7e1d6;
  --shadow:0 10px 40px rgba(11,58,87,.07);
  --maxw:1080px;
  --radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic Medium",sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.85;
  letter-spacing:.02em;-webkit-font-smoothing:antialiased;font-size:15px;
}
a{color:inherit;text-decoration:none;transition:.25s}
p{text-wrap:pretty}            /* 行末に「す。」等が1〜2字だけ残る“孤立行”を防ぐ */
img{max-width:100%;display:block}
.serif{font-family:"Shippori Mincho","Noto Serif JP",serif;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.accent-rule{display:flex;height:5px;width:64px;border-radius:5px;overflow:hidden;margin:0 0 22px}
.accent-rule i{flex:1}
.accent-rule i:nth-child(1){background:var(--sun)}
.accent-rule i:nth-child(2){background:var(--land)}
.accent-rule i:nth-child(3){background:var(--sea)}
.eyebrow{font-size:12px;letter-spacing:.22em;color:var(--sea);font-weight:700;text-transform:uppercase;margin-bottom:12px}
.section{padding:56px 0}
.section h2{font-size:clamp(26px,4.2vw,38px);color:var(--navy);font-weight:700;line-height:1.4}
.section h2 .en{display:block;font-size:13px;letter-spacing:.2em;color:var(--muted);font-weight:600;margin-top:8px}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,249,244,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;gap:24px;height:72px}
.brand img{height:38px;width:auto}
.nav{margin-left:auto;display:flex;align-items:center;gap:30px}
.nav a{font-size:13.5px;font-weight:500;color:var(--navy)}
.nav a:hover{color:var(--sea)}
.nav .cta{background:var(--navy);color:#fff;padding:10px 20px;border-radius:999px;font-weight:600}
.nav .cta:hover{background:var(--sea)}
.hamburger{display:none;margin-left:auto;background:none;border:0;font-size:26px;color:var(--navy);cursor:pointer}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;
  background:
   radial-gradient(1200px 520px at 80% -10%, rgba(48,144,208,.16), transparent 60%),
   radial-gradient(900px 480px at 8% 0%, rgba(224,67,47,.10), transparent 55%),
   linear-gradient(180deg,#fff 0%,var(--bg) 70%);}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;
  padding-top:84px;padding-bottom:96px}
.hero h1{font-size:clamp(30px,5.4vw,52px);line-height:1.45;color:var(--navy);font-weight:700;letter-spacing:.03em;margin-top:22px}
.hero h1 b{color:var(--sun);font-weight:700}
.hero p.lead{margin-top:26px;font-size:16px;color:var(--ink);max-width:34em}
.hero .actions{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:999px;font-weight:600;font-size:14.5px}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--sea);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--navy);color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff}
.hero-logo{justify-self:center;text-align:center}
.hero-logo img{width:min(300px,72vw);margin:0 auto;filter:drop-shadow(0 18px 36px rgba(11,58,87,.12))}

/* ===== Services ===== */
.services{background:var(--surface)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:34px 22px;
  transition:.3s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px}
.card svg{width:28px;height:28px}
.card.s1 .ic{background:rgba(224,67,47,.12)} .card.s1 svg{stroke:var(--sun)}
.card.s2 .ic{background:rgba(111,160,33,.14)} .card.s2 svg{stroke:var(--land)}
.card.s3 .ic{background:rgba(48,144,208,.14)} .card.s3 svg{stroke:var(--sea)}
.card h3{font-size:18px;color:var(--navy);font-weight:700;margin-bottom:12px;
  letter-spacing:-0.035em;white-space:nowrap}
.card p{font-size:14px;color:var(--muted);line-height:1.9}

/* ===== Message ===== */
.message{background:var(--bg-alt)}
.message .inner{max-width:760px}
.message p{font-size:16px;line-height:2.1;color:var(--ink);margin-top:18px}
.message .sign{margin-top:26px;color:var(--navy);font-weight:600}
.message .sign small{display:block;color:var(--muted);font-weight:400;font-size:12.5px;letter-spacing:.15em}

/* ===== Company ===== */
.company{background:var(--surface)}
.table{margin-top:44px;border-top:1px solid var(--line)}
.table .row{display:grid;grid-template-columns:200px 1fr;gap:16px;padding:20px 6px;border-bottom:1px solid var(--line)}
.table .row dt{font-weight:700;color:var(--navy);font-size:14px}
.table .row dd{color:var(--ink);font-size:15px}
.table .row dd .en{color:var(--muted);font-size:13px;margin-left:8px}

/* ===== Contact ===== */
.contact{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-alt) 100%);text-align:center}
.contact h2{color:var(--navy)}
.contact p{max-width:34em;margin:18px auto 0;color:var(--ink)}
.contact .addr{margin-top:30px;color:var(--muted);font-weight:500;font-size:13.5px}
/* form */
.form{max-width:620px;margin:36px auto 0;text-align:left;display:grid;gap:18px}
.form .field{display:flex;flex-direction:column;gap:7px}
.form label{font-size:13px;font-weight:700;color:var(--navy)}
.form label .req{color:#fff;background:var(--sun);margin-left:8px;font-size:10px;font-weight:700;
  padding:1px 7px;border-radius:999px;vertical-align:middle;letter-spacing:.05em}
.form input,.form textarea{font-family:inherit;font-size:15px;color:var(--ink);background:var(--surface);
  border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;width:100%;transition:.2s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--sea);box-shadow:0 0 0 3px rgba(48,144,208,.14)}
.form textarea{resize:vertical;min-height:150px;line-height:1.8}
.form .submit{justify-self:center;margin-top:8px;min-width:200px;justify-content:center}
.form .note{font-size:12px;color:var(--muted);text-align:center;line-height:1.7;max-width:none}
@media(max-width:860px){.form .submit{width:100%}}

/* ===== Footer ===== */
.site-footer{background:var(--navy-deep);color:#cfe0ea}
.site-footer .wrap{padding:54px 24px 30px;display:flex;flex-wrap:wrap;gap:30px;align-items:flex-start;justify-content:space-between}
.site-footer .f-brand img{height:54px;background:rgba(255,255,255,.96);padding:10px 14px;border-radius:12px}
.site-footer .f-links{display:flex;gap:26px;flex-wrap:wrap;font-size:13.5px}
.site-footer a:hover{color:#fff}
.site-footer .copy{width:100%;border-top:1px solid rgba(255,255,255,.12);margin-top:26px;padding-top:20px;
  font-size:12px;color:#8fb0c4;letter-spacing:.1em}

/* ===== Legal page ===== */
.legal{padding:64px 0 80px}
.legal .doc{max-width:800px;margin:0 auto;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:48px 44px}
.legal h1{font-size:26px;color:var(--navy);margin-bottom:6px}
.legal .lead{color:var(--muted);font-size:14px;margin-bottom:30px}
.legal h2{font-size:17px;color:var(--navy);margin:30px 0 10px;padding-left:12px;border-left:4px solid var(--sea)}
.legal p,.legal li{font-size:14px;color:var(--ink);line-height:1.95}
.legal ul,.legal ol{margin:8px 0 8px 1.4em}
.legal .back{display:inline-block;margin-top:30px;color:var(--link);font-weight:600}

/* ===== reveal ===== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===== responsive ===== */
@media(max-width:860px){
  .hero .wrap{grid-template-columns:1fr;text-align:center;padding-top:56px;padding-bottom:64px}
  .hero .actions{justify-content:center}
  .hero-logo{order:-1}
  .hero-logo img{width:min(220px,60vw)}
  .cards{grid-template-columns:1fr}
  .nav{display:none}
  .nav.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;
    background:var(--surface);border-bottom:1px solid var(--line);padding:18px 24px;gap:18px}
  .nav.open .cta{text-align:center}
  .hamburger{display:block}
  .table .row{grid-template-columns:1fr;gap:4px;padding:16px 4px}
  .section{padding:40px 0}
}

/* ===== Case Study（支援事例） ===== */
.case{background:var(--bg-alt)}
.case-card{margin-top:6px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);display:grid;grid-template-columns:1fr 1.08fr;overflow:hidden}
.case-main{padding:32px 38px;border-right:1px solid var(--line);display:flex;flex-direction:column}
.case-badges{display:flex;flex-wrap:wrap;gap:9px}
.case-tag{display:inline-block;font-size:11.5px;font-weight:700;letter-spacing:.03em;color:var(--sun);
  background:#FBEAE6;border:1px solid #F0D2CB;border-radius:999px;padding:5px 14px}
.case-tag-client{color:var(--sea);background:#E8F2FB;border-color:#CFE4F5}
.case-card h3{font-size:clamp(20px,2.6vw,27px);color:var(--navy);font-weight:700;line-height:1.45;margin:16px 0 14px}
.case-lead{color:var(--ink);font-size:14.5px;line-height:1.95}
.case-role{margin-top:auto;font-size:12.5px;color:var(--muted);font-weight:600;padding-top:14px;border-top:1px dashed var(--line)}
.case-grid{padding:32px 34px;display:grid;grid-template-columns:1fr 1fr;gap:22px 26px;align-content:start}
.case-item{position:relative;padding-left:16px}
.case-item::before{content:"";position:absolute;left:0;top:7px;width:7px;height:7px;border-radius:2px;background:var(--sun)}
.case-item:nth-child(1)::before{background:var(--sea)}
.case-item:nth-child(2)::before{background:var(--sea)}
.case-item:nth-child(3)::before{background:var(--land)}
.case-item:nth-child(4)::before{background:var(--sun)}
.case-item h4{font-size:14px;color:var(--navy);font-weight:700;margin-bottom:6px;line-height:1.5}
.case-item p{font-size:12.5px;color:var(--muted);line-height:1.8}
.case-client{font-size:16.5px;font-weight:700;letter-spacing:.02em;color:var(--sun)}
.case-client .nb{white-space:nowrap}
.case-logos{display:flex;align-items:center;gap:36px;flex-wrap:wrap;margin:8px 0 2px}
.case-logos img{width:auto;opacity:1}
.case-logos img[alt="株式会社OFFICE YAGI"]{height:104px}
.case-logos img[alt="THE CHALLENGE RACE"]{height:66px}
@media(max-width:760px){
  .case-card{grid-template-columns:1fr}
  .case-main{border-right:none;border-bottom:1px solid var(--line);padding:30px 24px}
  .case-grid{grid-template-columns:1fr;padding:26px 24px}
  .case-logos{gap:18px;flex-wrap:nowrap}
  .case-logos img[alt="株式会社OFFICE YAGI"]{height:78px}
  .case-logos img[alt="THE CHALLENGE RACE"]{height:48px}
}
