/* ===== ココグラム｜コラム 共通スタイル（明るい・子ども向け） ===== */
:root{
  --blue:#1E63C6;
  --cyan:#1E8BE0;
  --navy:#0E3A6B;
  --accent:#FBB022;
  --bg:#F4F9FF;
  --card:#ffffff;
  --text:#2A3B4F;
  --muted:#5E7794;
  --line:#dce8f5;
  --warn-bg:#fff7ed;
  --warn-border:#f4a261;
  --ok-bg:#eaf7ef;
  --ok-border:#4CAF7D;
  --radius:18px;
  --maxw:820px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP",Meiryo,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.85;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}

/* header */
.site-header{
  background:#fff;color:var(--navy);
  position:sticky;top:0;z-index:10;
  box-shadow:0 2px 10px rgba(30,99,198,.10);
  border-top:5px solid var(--blue);
}
.site-header .inner{
  max-width:1080px;margin:0 auto;padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.site-header .brand{display:inline-flex;align-items:center;gap:10px;font-weight:800}
.site-header .brand .brand-logo{height:30px;width:auto;display:block}
.site-header .brand .brand-col{color:var(--navy);font-size:1.02rem;font-weight:800;letter-spacing:.02em}
.site-header nav a{color:var(--navy);margin-left:18px;font-size:.92rem;font-weight:700}
.site-header nav a:hover{color:var(--blue);text-decoration:none}

/* hero */
.hero{margin:0 auto;max-width:1000px;background:#fff}
.hero img{width:100%;height:auto;display:block}

/* layout */
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.article{padding-bottom:60px}
.breadcrumb{font-size:.82rem;color:var(--muted);margin:22px 0 8px}
.breadcrumb a{color:var(--muted)}
.cat-tag{
  display:inline-block;background:var(--blue);color:#fff;
  font-size:.74rem;font-weight:700;padding:5px 14px;border-radius:999px;margin:18px 0 10px;
}
h1{font-size:1.74rem;line-height:1.5;margin:.2em 0 .5em;color:var(--navy);font-weight:800}
.meta{font-size:.82rem;color:var(--muted);margin-bottom:24px;border-bottom:1px solid var(--line);padding-bottom:16px}
.lead{font-size:1.04rem;color:#33414f;background:#eaf3fe;border-left:5px solid var(--cyan);padding:16px 18px;border-radius:0 10px 10px 0;margin:24px 0}

h2{
  font-size:1.36rem;color:var(--navy);margin:48px 0 16px;
  padding:10px 0 10px 16px;border-left:7px solid var(--blue);font-weight:800;
}
h3{font-size:1.12rem;color:var(--blue);margin:32px 0 12px;font-weight:700}
p{margin:14px 0}
ul,ol{padding-left:1.4em;margin:14px 0}
li{margin:8px 0}
strong{color:var(--navy)}

/* keypoint（結論ボックス） */
.keypoint{
  background:linear-gradient(0deg,#fff,#eef6ff);
  border:1px solid #cfe2f8;border-left:7px solid var(--accent);
  border-radius:0 14px 14px 0;padding:18px 20px;margin:24px 0;
  box-shadow:0 1px 3px rgba(30,99,198,.07);
}
.keypoint .kp-h{display:block;font-weight:800;color:var(--navy);font-size:.92rem;margin-bottom:6px}
.keypoint .kp-h::before{content:"\2714 ";color:var(--blue)}
.keypoint p{margin:0;font-size:1.0rem;line-height:1.8}

/* author-box */
.author-box{display:flex;gap:16px;align-items:flex-start;background:var(--card);border:1px solid var(--line);
  border-radius:16px;padding:18px 20px;margin:36px 0 0;box-shadow:0 1px 4px rgba(30,99,198,.06)}
.author-box .author-avatar{flex:none;width:64px;height:64px;border-radius:50%;background:var(--blue);
  color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;
  font-weight:800;font-size:.62rem;line-height:1.3;letter-spacing:.02em}
.author-box .author-label{display:inline-block;font-size:.72rem;font-weight:700;color:#fff;
  background:var(--cyan);border-radius:999px;padding:2px 10px;margin-bottom:6px}
.author-box .author-name{margin:0 0 6px;font-size:1.05rem;font-weight:800;color:var(--navy)}
.author-box .author-name a{color:var(--navy)}
.author-box .author-desc{margin:0 0 8px;font-size:.9rem;line-height:1.7;color:var(--muted)}
.author-box .author-link{margin:0;font-size:.86rem;font-weight:700}

/* sources */
.sources{background:#f0f7ff;border:1px solid var(--line);border-radius:14px;padding:18px 22px;margin:30px 0}
.sources h2{border:0;padding:0;margin:0 0 10px;font-size:1.1rem}
.sources ul{margin:0;padding-left:1.2em}
.sources li{margin:6px 0;font-size:.92rem}
.sources .src-note{display:block;margin-top:10px;font-size:.78rem;color:var(--muted)}

/* related */
.related{margin:40px 0 0}
.related > h2{margin-bottom:16px}

/* toc */
.toc{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 24px;margin:28px 0;box-shadow:0 1px 3px rgba(30,99,198,.05);
}
.toc .toc-title{font-weight:800;color:var(--navy);margin-bottom:10px;font-size:1rem}
.toc ol{counter-reset:item;list-style:none;padding-left:0;margin:0}
.toc ol li{counter-increment:item;margin:7px 0;padding-left:32px;position:relative;font-size:.94rem}
.toc ol li::before{
  content:counter(item);position:absolute;left:0;top:1px;
  background:var(--blue);color:#fff;width:24px;height:24px;border-radius:8px;
  font-size:.72rem;display:flex;align-items:center;justify-content:center;font-weight:700;
}

/* in-body figures */
.article figure{margin:26px 0;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px rgba(30,99,198,.06)}
.article figure img{width:100%;height:auto;display:block}
.article figcaption{font-size:.84rem;color:var(--muted);padding:10px 16px;background:#f0f7ff;border-top:1px solid var(--line);text-align:center}
.article .hero{margin:0 auto;max-width:1000px;border:0;border-radius:0;box-shadow:none}

/* campus map（校舎のGoogleマップ） */
.map{margin:18px 0 6px;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px rgba(30,99,198,.06)}
.map iframe{display:block;width:100%;height:340px;border:0}
.map-link{font-size:.86rem;font-weight:700;margin:0 0 8px}

/* tables */
table{width:100%;border-collapse:collapse;margin:22px 0;font-size:.92rem;background:var(--card);border-radius:10px;overflow:hidden;box-shadow:0 1px 3px rgba(30,99,198,.06)}
th,td{border:1px solid var(--line);padding:11px 14px;text-align:left;vertical-align:top}
th{background:var(--blue);color:#fff;font-weight:700}
tbody tr:nth-child(even){background:#f4f9ff}

/* callouts */
.note{border-radius:12px;padding:16px 18px;margin:22px 0;font-size:.95rem}
.note.warn{background:var(--warn-bg);border:1px solid var(--warn-border)}
.note.tip{background:var(--ok-bg);border:1px solid var(--ok-border)}
.note .note-h{font-weight:800;display:block;margin-bottom:6px}
.note.warn .note-h{color:#b45309}
.note.tip .note-h{color:#1f8a52}

/* checklist */
.checklist{list-style:none;padding-left:0}
.checklist li{position:relative;padding-left:30px;margin:10px 0}
.checklist li::before{content:"\2714";position:absolute;left:0;color:var(--blue);font-weight:800}

/* CTA box（無料体験誘導） */
.cta{background:linear-gradient(120deg,#1E63C6,#1E8BE0);color:#fff;border-radius:18px;padding:24px 26px;margin:32px 0;text-align:center;box-shadow:0 6px 18px rgba(30,99,198,.22)}
.cta p{margin:0 0 14px;font-weight:700;font-size:1.08rem}
.cta a{display:inline-block;background:var(--accent);color:#3a2600;font-weight:800;padding:12px 28px;border-radius:999px;font-size:1rem}
.cta a:hover{text-decoration:none;filter:brightness(1.05)}

/* FAQ */
.faq details{background:var(--card);border:1px solid var(--line);border-radius:12px;margin:12px 0;padding:4px 18px}
.faq summary{font-weight:700;cursor:pointer;padding:12px 0;color:var(--navy);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"Q. ";color:var(--blue);font-weight:800}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq details p{padding-bottom:12px}

/* disclaimer */
.disclaimer{font-size:.8rem;color:var(--muted);background:#eef3f9;border-radius:12px;padding:16px 18px;margin:36px 0 0;line-height:1.7}

.backlink{display:inline-block;margin:30px 0 0;font-weight:700}

/* footer */
.site-footer{background:var(--navy);color:#c7d8ee;text-align:center;padding:30px 20px;font-size:.85rem}
.site-footer .footer-logo{height:34px;width:auto;display:block;margin:0 auto 14px;filter:brightness(0) invert(1);opacity:.95}
.site-footer a{color:#9ec5e8}
.site-footer p{margin:6px 0}
.site-footer .footer-links{font-size:.82rem}
.site-footer .footer-links a{margin:0 2px}

/* ===== index page ===== */
.index-hero{background:var(--bg);text-align:center;padding:14px 20px 0}
.index-hero img{max-width:1120px;width:100%;height:auto;margin:0 auto;display:block;border-radius:18px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.cat-section{max-width:1080px;margin:0 auto;padding:18px 20px}
.cat-head{display:flex;align-items:center;gap:12px;margin:46px 0 18px}
.cat-head .num{background:var(--blue);color:#fff;width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;flex:none}
.cat-head h2{border:0;padding:0;margin:0;font-size:1.4rem;color:var(--navy)}
.cat-head .count{color:var(--muted);font-size:.85rem}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 8px rgba(30,99,198,.08);transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 10px 24px rgba(30,99,198,.18)}
.card a.card-link{display:flex;flex-direction:column;height:100%;color:inherit}
.card a.card-link:hover{text-decoration:none}
.card .thumb{aspect-ratio:16/9;overflow:hidden;background:#dfeaf6}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .card-body{padding:16px 18px 20px;flex:1;display:flex;flex-direction:column}
.card .card-title{font-weight:700;color:var(--navy);font-size:1.02rem;line-height:1.5;margin:0 0 10px}
.card .card-more{margin-top:auto;color:var(--blue);font-size:.86rem;font-weight:700}

@media(max-width:600px){
  body{font-size:15px}
  h1{font-size:1.44rem}
  h2{font-size:1.2rem}
}
