/* 縁分映像 - 映像制作会社 demo site */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@500;600;700&family=Noto+Sans+JP:wght@400;500;700;900&display=swap');

:root{
  --navy:#0B2545;
  --navy-deep:#071A33;
  --blue:#1467D9;
  --blue-bright:#2E8CFF;
  --cyan:#00C2D1;
  --sky:#EEF5FF;
  --sky-2:#DCEBFF;
  --text:#152238;
  --text-soft:#5B6B80;
  --white:#FFFFFF;
  --radius:16px;
  --radius-sm:10px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic Medium","Yu Gothic",sans-serif;
  color:var(--text);
  background:var(--white);
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px;}
.font-en{font-family:"Oswald","Noto Sans JP",sans-serif;letter-spacing:.03em;}

.demo-flag{
  text-align:center;font-size:.78rem;color:#fff;background:var(--navy-deep);padding:7px;letter-spacing:.03em;
}

/* header */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(11,37,69,.97);
  backdrop-filter:blur(6px);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:16px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand-mark{
  width:44px;height:44px;border-radius:12px;flex:0 0 auto;
  background:linear-gradient(135deg,var(--blue-bright),var(--cyan));
  display:flex;align-items:center;justify-content:center;
  font-family:"Oswald",sans-serif;font-weight:700;color:#fff;font-size:1.1rem;
}
.brand-name{font-family:"Oswald",sans-serif;font-weight:600;font-size:1.15rem;color:#fff;letter-spacing:.04em;line-height:1.3;}
.brand-name span{display:block;font-size:.66rem;font-weight:400;color:#9FC0EA;letter-spacing:.1em;font-family:"Noto Sans JP",sans-serif;}

nav.main-nav ul{display:flex;gap:2px;flex-wrap:wrap;align-items:center;}
nav.main-nav a{
  display:inline-block;padding:10px 14px;border-radius:999px;font-size:.86rem;font-weight:500;
  color:#D7E6FA;transition:background .2s,color .2s;
}
nav.main-nav a:hover,nav.main-nav a.active{background:var(--blue-bright);color:#fff;}
.nav-cta{
  background:var(--cyan) !important;color:var(--navy-deep) !important;font-weight:700 !important;
  padding:10px 20px !important;margin-left:6px;
}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer;}
.nav-toggle span{width:24px;height:2px;background:#fff;border-radius:2px;}
@media(max-width:900px){
  nav.main-nav{
    position:absolute;top:100%;left:0;right:0;background:var(--navy);
    flex-direction:column;padding:10px 24px 20px;display:none;
  }
  nav.main-nav.open{display:block;}
  nav.main-nav ul{flex-direction:column;align-items:stretch;}
  nav.main-nav a{padding:12px 10px;}
  .nav-toggle{display:flex;}
}

/* hero */
.hero{
  position:relative;overflow:hidden;min-height:560px;display:flex;align-items:center;
  background:linear-gradient(120deg,rgba(7,26,51,.92),rgba(20,103,217,.72)),
    url("https://images.pexels.com/photos/30396798/pexels-photo-30396798/free-photo-of-professional-film-crew-in-action-on-set.jpeg?auto=compress&cs=tinysrgb&w=1600") center/cover;
  padding:110px 0 90px;color:#fff;
}
.hero .wrap{position:relative;z-index:2;}
.hero-copy{max-width:660px;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);color:#fff;font-weight:700;font-size:.8rem;
  padding:7px 18px;border-radius:999px;margin-bottom:22px;border:1px solid rgba(255,255,255,.25);letter-spacing:.05em;
}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--cyan);}
.hero-copy h1{
  font-size:clamp(1.8rem,4vw,2.7rem);line-height:1.55;margin:0 0 20px;font-weight:900;
}
.hero-copy h1 .accent{color:var(--cyan);}
.hero-copy p{color:#D7E6FA;font-size:1rem;max-width:52ch;margin:0 0 30px;}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;}
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:15px 30px;border-radius:999px;font-weight:700;
  font-size:.94rem;transition:transform .15s, box-shadow .15s;
}
.btn-primary{background:var(--cyan);color:var(--navy-deep);box-shadow:0 10px 24px rgba(0,194,209,.35);}
.btn-secondary{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.4);}
.btn:hover{transform:translateY(-2px);}
.hero-stats{display:flex;gap:36px;margin-top:48px;flex-wrap:wrap;}
.hero-stats .stat b{display:block;font-family:"Oswald",sans-serif;font-size:1.9rem;color:var(--cyan);}
.hero-stats .stat span{font-size:.78rem;color:#B9CFE9;}

/* section generic */
section{padding:88px 0;}
.section-title{text-align:center;margin-bottom:48px;}
.section-title .tag{
  display:inline-block;color:var(--blue);font-family:"Oswald",sans-serif;font-weight:600;font-size:.85rem;
  letter-spacing:.18em;margin-bottom:12px;
}
.section-title h2{font-size:clamp(1.4rem,2.8vw,2rem);color:var(--navy);margin:0;font-weight:900;}
.section-title p{color:var(--text-soft);margin-top:14px;font-size:.94rem;max-width:56ch;margin-left:auto;margin-right:auto;}
.bg-soft{background:var(--sky);}
.bg-navy{background:var(--navy);color:#fff;}
.bg-navy .section-title h2{color:#fff;}
.bg-navy .section-title p{color:#B9CFE9;}

/* about */
.about-grid{display:flex;gap:56px;align-items:center;flex-wrap:wrap;}
.about-photo{flex:1 1 380px;min-width:280px;}
.about-photo img{border-radius:var(--radius);box-shadow:0 20px 44px rgba(11,37,69,.18);}
.about-text{flex:1 1 380px;min-width:280px;}
.about-text .tag{color:var(--blue);font-family:"Oswald",sans-serif;font-weight:600;font-size:.85rem;letter-spacing:.14em;}
.about-text h2{font-size:clamp(1.3rem,2.6vw,1.8rem);color:var(--navy);margin:14px 0 20px;font-weight:900;}
.about-text p{color:var(--text-soft);font-size:.95rem;margin-bottom:16px;}
.about-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.about-list li{background:var(--sky-2);color:var(--blue);font-weight:700;font-size:.82rem;padding:8px 16px;border-radius:999px;}

/* service cards */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;}
@media(max-width:900px){.grid-3{grid-template-columns:1fr 1fr;}.grid-2{grid-template-columns:1fr;}}
@media(max-width:640px){.grid-3{grid-template-columns:1fr;}}

.service-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 10px 28px rgba(11,37,69,.08);
  transition:transform .2s, box-shadow .2s;
}
.service-card:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(11,37,69,.16);}
.service-photo{width:100%;height:170px;object-fit:cover;}
.service-body{padding:24px 24px 28px;}
.service-num{font-family:"Oswald",sans-serif;color:var(--blue-bright);font-weight:700;font-size:.85rem;margin-bottom:10px;}
.service-card h3{font-size:1.08rem;color:var(--navy);margin:0 0 10px;font-weight:700;}
.service-card p{color:var(--text-soft);font-size:.88rem;margin:0;}

/* works / portfolio */
.work-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 10px 28px rgba(11,37,69,.08);
  transition:transform .2s, box-shadow .2s;
}
.work-card:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(11,37,69,.16);}
.work-thumb{position:relative;height:190px;overflow:hidden;}
.work-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s;}
.work-card:hover .work-thumb img{transform:scale(1.06);}
.play-badge{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(0deg,rgba(7,26,51,.55),rgba(7,26,51,.05));
}
.play-badge::after{
  content:"";width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.92);
  clip-path:polygon(35% 25%,35% 75%,75% 50%);
}
.work-cat{
  position:absolute;top:14px;left:14px;background:var(--cyan);color:var(--navy-deep);font-size:.72rem;font-weight:700;
  padding:5px 14px;border-radius:999px;z-index:2;
}
.work-body{padding:20px 22px 24px;}
.work-body .client{font-size:.76rem;color:var(--blue);font-weight:700;letter-spacing:.05em;}
.work-body h3{font-size:1.02rem;color:var(--navy);margin:8px 0 10px;font-weight:700;}
.work-body p{font-size:.85rem;color:var(--text-soft);margin:0;}

.works-toolbar{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:40px;}
.filter-btn{
  background:#fff;border:1px solid var(--sky-2);color:var(--text-soft);font-weight:700;font-size:.84rem;
  padding:9px 20px;border-radius:999px;cursor:pointer;transition:.2s;
}
.filter-btn:hover{border-color:var(--blue-bright);color:var(--blue);}
.filter-btn.active{background:var(--blue);color:#fff;border-color:var(--blue);}

/* strengths */
.strength-card{
  background:#fff;border-radius:var(--radius);padding:32px 28px;box-shadow:0 10px 28px rgba(11,37,69,.08);
  border-top:4px solid var(--cyan);
}
.strength-card .num{
  font-family:"Oswald",sans-serif;font-size:2rem;color:var(--sky-2);font-weight:700;line-height:1;margin-bottom:14px;
  -webkit-text-stroke:1.5px var(--blue-bright);color:transparent;
}
.strength-card h3{font-size:1.05rem;color:var(--navy);margin:0 0 10px;font-weight:700;}
.strength-card p{color:var(--text-soft);font-size:.88rem;margin:0;}

/* flow */
.flow-list{max-width:820px;margin:0 auto;}
.flow-item{display:flex;gap:24px;padding:26px 0;border-bottom:1px solid var(--sky-2);}
.flow-item:last-child{border-bottom:0;}
.flow-step{
  flex:0 0 60px;height:60px;border-radius:50%;background:var(--navy);color:var(--cyan);
  display:flex;align-items:center;justify-content:center;font-family:"Oswald",sans-serif;font-weight:700;font-size:1.2rem;
}
.flow-text h3{margin:6px 0 8px;color:var(--navy);font-size:1.02rem;}
.flow-text p{margin:0;color:var(--text-soft);font-size:.88rem;}

/* testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media(max-width:900px){.testi-grid{grid-template-columns:1fr;}}
.testi-card{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:0 10px 24px rgba(11,37,69,.06);}
.testi-quote{color:var(--blue-bright);font-family:"Oswald",sans-serif;font-size:1.8rem;line-height:1;margin-bottom:10px;}
.testi-card p{font-size:.9rem;color:var(--text);margin:0 0 16px;}
.testi-card .who{font-size:.8rem;color:var(--blue);font-weight:700;}
.testi-card .who span{display:block;color:var(--text-soft);font-weight:400;font-size:.78rem;margin-top:2px;}

/* company table */
.info-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 10px 28px rgba(11,37,69,.08);}
.info-table tr{border-bottom:1px solid var(--sky-2);}
.info-table tr:last-child{border-bottom:0;}
.info-table th,.info-table td{padding:18px 24px;text-align:left;font-size:.9rem;}
.info-table th{background:var(--sky);color:var(--navy);font-weight:700;width:180px;}
.info-table td{color:var(--text-soft);}

/* CTA band */
.cta-band{
  background:linear-gradient(120deg,var(--navy),var(--blue));color:#fff;text-align:center;padding:70px 0;
}
.cta-band h2{margin:0 0 12px;font-size:clamp(1.3rem,2.6vw,1.8rem);font-weight:900;}
.cta-band p{margin:0 0 30px;color:#D7E6FA;}

/* footer */
footer{background:var(--navy-deep);color:#B9CFE9;padding:56px 0 24px;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px;}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;}}
footer h4{color:#fff;font-size:.92rem;margin:0 0 16px;letter-spacing:.05em;}
footer p,footer li{font-size:.85rem;color:#89A3C2;}
footer li{padding:5px 0;}
footer a:hover{color:#fff;}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.footer-bottom{text-align:center;margin-top:40px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:.78rem;color:#5E7699;}

/* inner page hero */
.page-hero{
  background:linear-gradient(120deg,var(--navy),var(--blue));padding:64px 0;text-align:center;color:#fff;
}
.page-hero .tag{color:var(--cyan);font-weight:700;font-size:.85rem;letter-spacing:.16em;font-family:"Oswald",sans-serif;}
.page-hero h1{font-size:clamp(1.6rem,3.2vw,2.2rem);margin:10px 0 0;font-weight:900;}
.page-hero p{color:#D7E6FA;margin-top:14px;font-size:.92rem;}

/* contact form */
.contact-layout{display:flex;gap:44px;flex-wrap:wrap;}
.form-box{
  flex:1 1 460px;background:#fff;border-radius:var(--radius);padding:40px;box-shadow:0 10px 28px rgba(11,37,69,.08);
}
.contact-side{flex:0 1 320px;min-width:260px;}
.contact-side .side-card{background:var(--sky);border-radius:var(--radius);padding:28px;margin-bottom:20px;}
.contact-side .side-card h4{color:var(--navy);margin:0 0 10px;font-size:.95rem;}
.contact-side .side-card p{color:var(--text-soft);font-size:.88rem;margin:0;}
.contact-side .side-card a{color:var(--blue);font-weight:700;}
.form-row{margin-bottom:22px;}
.form-row label{display:block;font-weight:700;font-size:.86rem;color:var(--navy);margin-bottom:8px;}
.required{color:#E4483A;font-size:.72rem;font-weight:700;margin-left:6px;}
.form-row input[type=text],.form-row input[type=email],.form-row input[type=tel],.form-row select,.form-row textarea{
  width:100%;padding:13px 16px;border:1.5px solid var(--sky-2);border-radius:var(--radius-sm);font-size:.9rem;
  font-family:inherit;background:var(--sky);color:var(--text);
}
.form-row textarea{min-height:130px;resize:vertical;}
.form-row select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--blue) 50%),linear-gradient(135deg,var(--blue) 50%,transparent 50%);background-position:calc(100% - 20px) 22px,calc(100% - 15px) 22px;background-size:5px 5px,5px 5px;background-repeat:no-repeat;}
.checkbox-row{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;color:var(--text-soft);}
.form-note{background:var(--sky);border-radius:var(--radius-sm);padding:16px 20px;font-size:.82rem;color:var(--text-soft);margin-bottom:26px;}
.submit-btn{width:100%;justify-content:center;border:0;cursor:pointer;background:var(--blue);color:#fff;box-shadow:0 10px 24px rgba(20,103,217,.3);}
.submit-btn:hover{background:var(--blue-bright);}

/* faq */
.faq-item{background:#fff;border-radius:var(--radius-sm);padding:20px 24px;margin-bottom:14px;box-shadow:0 6px 18px rgba(11,37,69,.06);}
.faq-item h4{margin:0 0 8px;color:var(--navy);font-size:.92rem;display:flex;gap:10px;}
.faq-item h4 .q{color:var(--cyan);font-family:"Oswald",sans-serif;}
.faq-item p{margin:0;color:var(--text-soft);font-size:.86rem;padding-left:26px;}
