/* ===== Base ===== */
:root{
  --gold-900:#3a2500;
  --gold-700:#b8860b;
  --gold-500:#d4a017;
  --gold-300:#f0c040;
  --navy-700:#1a2744;
  --navy-500:#263460;
  --navy-400:#3a4f8c;
  --grad: linear-gradient(135deg,#1a2744 0%,#263460 45%,#b8860b 100%);
  --grad-soft: linear-gradient(135deg,#f0f2f8 0%,#fdf8e8 100%);
  --text:#1a2030;
  --text-sub:#4a5060;
  --line:#e3e6ee;
  --bg-soft:#f7f8fc;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Noto Sans JP",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--text);
  line-height:1.9;
  background:#fff;
  -webkit-font-smoothing:antialiased;
  word-break:normal;
  overflow-wrap:anywhere;
  line-break:strict;
}
p{
  word-break:normal;
  overflow-wrap:break-word;
  line-break:strict;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* ===== Header ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
.site-header.scrolled{box-shadow:0 4px 20px rgba(26,39,68,.08)}
.header-inner{
  max-width:1200px;margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo-text{
  font-size:22px;font-weight:900;letter-spacing:.12em;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-family:"Noto Sans JP",sans-serif;
}
.brand-name{
  font-weight:700;font-size:15px;
  color:var(--navy-700);
  letter-spacing:.04em;
}
.nav{display:flex;gap:28px}
.nav a{
  font-size:14px;font-weight:500;color:var(--text);
  position:relative;padding:6px 0;transition:color .2s;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--grad);transition:width .3s;
}
.nav a:hover{color:var(--navy-700)}
.nav a:hover::after{width:100%}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy-900);transition:.3s}

/* ===== Hero ===== */
.hero{
  position:relative;min-height:78vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;color:#fff;padding-top:72px;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:var(--grad);
}
.hero-bg::before,.hero-bg::after{
  content:"";position:absolute;border-radius:50%;
  background:rgba(255,255,255,.08);filter:blur(40px);
}
.hero-bg::before{width:500px;height:500px;top:-100px;left:-100px}
.hero-bg::after{width:600px;height:600px;bottom:-200px;right:-150px;background:rgba(212,160,23,.2)}
.hero-inner{position:relative;z-index:1;text-align:center;padding:40px 24px}
.hero-sub{
  font-size:clamp(13px,1.8vw,16px);font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.75);margin-bottom:20px;
  animation:fadeUp .8s ease both;
}
.hero-title{
  font-size:clamp(32px,7vw,72px);font-weight:900;
  letter-spacing:.05em;line-height:1.45;
  text-shadow:0 4px 30px rgba(0,0,0,.2);
  animation:fadeUp 1s ease both .15s;
  word-break:keep-all;
  overflow-wrap:break-word;
}
.hero-title .nowrap{display:inline-block;white-space:nowrap}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

/* ===== Sections ===== */
.section{padding:100px 24px}
.section-dark{
  background:linear-gradient(135deg,#0f1a35 0%,#1a2744 50%,#3a2500 100%);
  color:#fff;
}
.section-soft{background:var(--bg-soft)}
.container{max-width:1100px;margin:0 auto}
.sec-title{
  font-size:clamp(24px,3.5vw,32px);font-weight:700;
  margin-bottom:48px;padding-bottom:16px;
  border-bottom:3px solid transparent;
  border-image:var(--grad) 1;
  display:inline-block;
}
.sec-title-light{color:#fff;border-image:linear-gradient(135deg,#f0c040,#d4a017) 1}
.sec-title-mt{margin-top:64px}

/* ===== Greeting ===== */
.greeting-layout{max-width:900px}
.greeting-text p{margin-bottom:1.2em;color:var(--text-sub)}
.greeting-name{
  margin-top:1.6em;font-size:15px;color:var(--text);
}
.greeting-name strong{font-size:18px;font-weight:700}

/* ===== Philosophy ===== */
.philosophy-text{font-size:clamp(16px,1.8vw,19px);line-height:2.1;max-width:900px}
.philosophy-text p{margin-bottom:1.5em}
.philosophy-text p:first-child{
  font-size:clamp(17px,2vw,21px);font-weight:500;
  color:#f0d070;
}

/* ===== Business ===== */
.biz-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:32px;
}
.biz-card{
  background:#fff;padding:40px 32px;border-radius:14px;
  border-top:5px solid transparent;
  border-image:var(--grad) 1;
  box-shadow:0 8px 30px rgba(26,39,68,.08);
  transition:transform .3s, box-shadow .3s;
}
.biz-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(26,39,68,.15)}
.biz-heading{
  font-size:19px;font-weight:700;margin-bottom:20px;
  color:var(--navy-700);
}
.biz-card p{margin-bottom:1em;color:var(--text-sub);font-size:15px}

/* ===== Company ===== */
.company-table{max-width:900px;border-top:1px solid var(--line)}
.company-row{
  display:grid;grid-template-columns:200px 1fr;gap:24px;
  padding:24px 8px;border-bottom:1px solid var(--line);
}
.company-row dt{
  font-weight:700;color:var(--navy-700);
  position:relative;padding-left:18px;
}
.company-row dt::before{
  content:"";position:absolute;left:0;top:.7em;
  width:8px;height:8px;border-radius:50%;
  background:var(--grad);
}
.company-row dd{color:var(--text-sub)}

/* ===== Footer ===== */
.site-footer{
  background:var(--navy-700);padding:40px 24px;
  display:flex;justify-content:center;
}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:8px}
.footer-logo-text{
  font-size:28px;font-weight:900;letter-spacing:.18em;
  color:rgba(255,255,255,.9);
  font-family:"Noto Sans JP",sans-serif;
}
.footer-copy{
  font-size:13px;color:rgba(255,255,255,.55);letter-spacing:.06em;
}

/* ===== Scroll reveal ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s, transform .8s}
.reveal.visible{opacity:1;transform:none}

/* ===== Responsive ===== */
@media (max-width: 820px){
  .nav{
    position:fixed;top:68px;left:0;right:0;
    background:#fff;flex-direction:column;gap:0;
    border-top:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .3s;
  }
  .nav.open{max-height:400px;box-shadow:0 8px 20px rgba(0,0,0,.1)}
  .nav a{padding:16px 24px;border-bottom:1px solid var(--line)}
  .nav a::after{display:none}
  .nav-toggle{display:flex}
  .brand-name{font-size:13px}
  .brand-logo-text{font-size:18px}
  .section{padding:70px 20px}
  .greeting-layout{grid-template-columns:1fr;gap:28px}
  .greeting-photo{align-items:center}
  .photo-placeholder{width:200px;height:250px}
  .company-row{grid-template-columns:1fr;gap:8px;padding:18px 4px}
  .company-row dt{font-size:14px}

  .hero{min-height:64vh;padding-top:80px}
  .hero-title{
    font-size:clamp(30px,9vw,44px);
    line-height:1.55;letter-spacing:.03em;
  }
  .greeting-text br,
  .philosophy-text br,
  .biz-card p br{display:none}
  .greeting-text p,
  .biz-card p{line-height:1.95;font-size:15px}
  .philosophy-text{font-size:16px;line-height:2}
  .philosophy-text p:first-child{font-size:17px}
  .sec-title{margin-bottom:32px;font-size:22px}
}

@media (max-width: 480px){
  .header-inner{padding:12px 16px;gap:12px}
  .brand-name{display:none}
  .brand-logo-text{font-size:16px}
  .hero-title{font-size:clamp(28px,8.5vw,38px)}
  .section{padding:60px 16px}
  .biz-card{padding:28px 22px}
}
