/* =========================================================
   Fun Coffee — Top Page Specific
   ========================================================= */

/* ---------- HERO ---------- */
.hero{
  position:relative;
  height:600px;
  background:
    linear-gradient(180deg,rgba(42,31,23,.25) 0%,rgba(42,31,23,.55) 100%),
    url('https://images.unsplash.com/photo-1559056199-641a0ac8b55e?w=1600&q=80') center/cover no-repeat;
  display:flex;
  align-items:center;
  color:#fff;
}
.hero-inner{
  max-width:1280px;
  margin:0 auto;
  padding:0 24px;
  width:100%;
}
.hero-content{
  max-width:560px;
}
.hero-tag{
  font-family:var(--font-sans);
  font-size:11px;letter-spacing:.4em;
  color:#f0d4a8;
  text-transform:uppercase;
  margin-bottom:16px;
}
.hero-title{
  font-family:var(--font-serif);
  font-size:54px;
  font-weight:500;
  line-height:1.2;
  letter-spacing:.02em;
  margin-bottom:16px;
}
.hero-sub{
  font-size:15px;
  line-height:1.9;
  margin-bottom:32px;
  color:#f0e6d6;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Concept Strip ---------- */
.concept-strip{
  background:var(--c-coffee-50);
  padding:32px 0;
  border-bottom:1px solid var(--c-line);
}
.concept-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  text-align:center;
}
.concept-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.concept-icon{
  width:40px;height:40px;
  color:var(--c-coffee-700);
}
.concept-title{
  font-size:13px;font-weight:700;
  color:var(--c-coffee-900);
}
.concept-desc{
  font-size:11px;color:var(--c-muted);
  line-height:1.6;
}

/* ---------- Categories ---------- */
.cat-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.cat-card{
  position:relative;
  aspect-ratio:1/1.1;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--c-coffee-100);
}
.cat-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;
}
.cat-card:hover img{transform:scale(1.06)}
.cat-card::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(42,31,23,.7) 100%);
}
.cat-info{
  position:absolute;
  left:20px;bottom:20px;
  color:#fff;
  z-index:2;
}
.cat-name-en{
  font-family:var(--font-serif);
  font-size:22px;
  font-weight:500;
  line-height:1.2;
}
.cat-name-jp{
  font-size:12px;
  letter-spacing:.1em;
  margin-top:4px;
  color:#f0d4a8;
}

/* ---------- Sale Banner ---------- */
.sale-banner{
  background:linear-gradient(135deg,var(--c-coffee-900),var(--c-coffee-700));
  color:#fff;
  padding:48px 0;
  position:relative;
  overflow:hidden;
}
.sale-banner::before{
  content:"SALE";
  position:absolute;
  top:-30px;right:-20px;
  font-family:var(--font-serif);
  font-size:200px;
  color:rgba(255,255,255,.05);
  font-weight:700;
  letter-spacing:-.04em;
}
.sale-inner{
  display:flex;justify-content:space-between;align-items:center;gap:32px;
  position:relative;z-index:1;flex-wrap:wrap;
}
.sale-text h3{
  font-family:var(--font-serif);
  font-size:32px;
  margin-bottom:8px;
  font-weight:500;
}
.sale-text p{color:#f0d4a8;font-size:13px}

/* ---------- Brand Story ---------- */
.story{
  background:var(--c-coffee-50);
  padding:96px 0;
}
.story-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.story-img{
  aspect-ratio:4/5;
  background:var(--c-coffee-100);
  border-radius:var(--radius);
  overflow:hidden;
}
.story-img img{width:100%;height:100%;object-fit:cover}
.story-content .section-tag{text-align:left}
.story-content .section-title{
  text-align:left;
  margin-bottom:24px;
}
.story-content p{
  color:var(--c-coffee-700);
  line-height:2;
  margin-bottom:16px;
  font-size:14px;
}
.story-cta{margin-top:24px}

/* ---------- SNS ---------- */
.sns-section{padding:80px 0}
.sns-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:8px;
}
.sns-item{
  aspect-ratio:1/1;
  background:var(--c-coffee-100);
  border-radius:4px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
}
.sns-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .3s ease;
}
.sns-item:hover img{transform:scale(1.08)}
.sns-item::after{
  content:"";
  position:absolute;inset:0;
  background:rgba(42,31,23,0);
  transition:background .2s;
}
.sns-item:hover::after{background:rgba(42,31,23,.3)}
.sns-icon{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  color:#fff;
  opacity:0;
  z-index:2;
  transition:opacity .2s;
}
.sns-item:hover .sns-icon{opacity:1}

/* ---------- Startup Support ---------- */
.startup-intro{
  background:
    linear-gradient(90deg,rgba(42,31,23,.92) 0%,rgba(42,31,23,.78) 50%,rgba(42,31,23,.55) 100%),
    url('https://images.unsplash.com/photo-1453614512568-c4024d13c247?w=1600&q=80') center/cover no-repeat;
  color:#fff;
  padding:88px 0;
  position:relative;
  overflow:hidden;
}
.startup-intro::after{
  content:"STARTUP";
  position:absolute;
  right:-30px;bottom:-50px;
  font-family:var(--font-serif);
  font-size:240px;
  color:rgba(255,255,255,.04);
  font-weight:700;
  letter-spacing:-.04em;
  line-height:1;
}
.startup-intro-inner{max-width:680px;position:relative;z-index:1}
.startup-intro .section-tag{color:#f0d4a8;text-align:left;margin-bottom:14px}
.startup-intro h2{
  font-family:var(--font-serif);
  font-size:46px;font-weight:500;
  line-height:1.25;
  letter-spacing:.02em;
  margin-bottom:20px;
}
.startup-intro h2 .accent{color:#f0d4a8}
.startup-intro .lead{
  font-size:15px;
  line-height:2;
  color:#f0e6d6;
  margin-bottom:28px;
}
.startup-badges{
  display:flex;flex-wrap:wrap;gap:10px;
  margin-bottom:32px;
}
.startup-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  padding:6px 14px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.05em;
  color:#fff;
}

/* ---------- Steps ---------- */
.steps{
  padding:96px 0;
  background:var(--c-cream);
}
.step-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:16px;
}
.step-card{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius);
  padding:32px 24px;
  position:relative;
  transition:transform .2s,box-shadow .2s;
}
.step-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.step-num{
  position:absolute;
  top:-16px;left:24px;
  background:var(--c-accent);
  color:#fff;
  width:36px;height:36px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);
  font-size:18px;
  font-weight:600;
}
.step-card-title{
  font-size:16px;
  font-weight:700;
  color:var(--c-coffee-900);
  margin-top:8px;margin-bottom:10px;
}
.step-card-en{
  font-family:var(--font-sans);
  font-size:10px;
  letter-spacing:.2em;
  color:var(--c-accent);
  text-transform:uppercase;
  margin-bottom:14px;
}
.step-card-desc{
  font-size:13px;
  color:var(--c-coffee-700);
  line-height:1.8;
}

/* ---------- Starter Packs ---------- */
.starter{
  background:var(--c-bg);
  padding:96px 0;
}
.starter-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.starter-card{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s;
}
.starter-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.starter-card.featured{
  border-color:var(--c-accent);
  box-shadow:0 8px 24px rgba(201,123,63,.15);
}
.starter-card.featured::before{
  content:"おすすめ";
  position:absolute;
  top:14px;right:14px;
  background:var(--c-accent);
  color:#fff;
  font-size:11px;
  font-weight:700;
  padding:4px 12px;
  border-radius:999px;
  letter-spacing:.05em;
  z-index:2;
}
.starter-img{
  aspect-ratio:16/9;
  background:var(--c-coffee-50);
  overflow:hidden;
}
.starter-img img{width:100%;height:100%;object-fit:cover}
.starter-body{padding:28px 24px;flex:1;display:flex;flex-direction:column}
.starter-tag{
  font-family:var(--font-sans);
  font-size:10px;letter-spacing:.25em;
  color:var(--c-accent);
  text-transform:uppercase;
  margin-bottom:10px;
}
.starter-name{
  font-family:var(--font-serif);
  font-size:22px;
  font-weight:500;
  color:var(--c-coffee-900);
  margin-bottom:6px;
}
.starter-name-jp{
  font-size:13px;color:var(--c-muted);margin-bottom:18px;
  letter-spacing:.05em;
}
.starter-price{
  font-size:13px;color:var(--c-muted);
  margin-bottom:20px;
}
.starter-price strong{
  display:block;
  font-size:28px;color:var(--c-coffee-900);
  font-weight:700;
  font-family:var(--font-sans);
  letter-spacing:-.02em;
  line-height:1.2;
}
.starter-price strong small{
  font-size:13px;color:var(--c-muted);font-weight:400;margin-left:4px;
}
.starter-list{
  list-style:none;padding:0;margin:0 0 24px;
  flex:1;
}
.starter-list li{
  font-size:13px;
  color:var(--c-coffee-700);
  padding:7px 0;
  border-bottom:1px dashed var(--c-line);
  position:relative;
  padding-left:22px;
}
.starter-list li::before{
  content:"";
  position:absolute;
  left:0;top:11px;
  width:14px;height:8px;
  border-left:2px solid var(--c-accent);
  border-bottom:2px solid var(--c-accent);
  transform:rotate(-45deg);
}
.starter-list li:last-child{border-bottom:none}

/* ---------- Testimonials ---------- */
.testimonials{
  background:var(--c-coffee-50);
  padding:96px 0;
}
.test-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.test-card{
  background:#fff;
  border-radius:var(--radius);
  padding:28px;
  position:relative;
}
.test-card::before{
  content:"\201C";
  position:absolute;
  top:8px;left:18px;
  font-family:var(--font-serif);
  font-size:80px;
  color:var(--c-coffee-100);
  line-height:1;
}
.test-text{
  font-size:14px;
  color:var(--c-coffee-700);
  line-height:1.9;
  margin-bottom:20px;
  position:relative;z-index:1;
  padding-top:8px;
}
.test-author{
  display:flex;
  align-items:center;
  gap:12px;
  padding-top:18px;
  border-top:1px solid var(--c-line);
}
.test-avatar{
  width:44px;height:44px;
  border-radius:50%;
  background:var(--c-coffee-100);
  overflow:hidden;
  flex-shrink:0;
}
.test-avatar img{width:100%;height:100%;object-fit:cover}
.test-meta{flex:1}
.test-name{
  font-size:13px;font-weight:700;
  color:var(--c-coffee-900);
}
.test-role{
  font-size:11px;color:var(--c-muted);margin-top:2px;
  letter-spacing:.05em;
}

/* ---------- Support CTA ---------- */
.support-cta{
  background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-accent-dark) 100%);
  color:#fff;
  padding:64px 0;
  text-align:center;
}
.support-cta h3{
  font-family:var(--font-serif);
  font-size:34px;
  font-weight:500;
  margin-bottom:12px;
  line-height:1.3;
}
.support-cta p{
  color:#fce8d6;
  margin-bottom:28px;
  font-size:14px;
  line-height:1.8;
}
.support-cta-buttons{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}
.support-cta .btn-primary{background:#fff;color:var(--c-accent-dark)}
.support-cta .btn-primary:hover{background:var(--c-coffee-900);color:#fff}

/* ---------- B2B Banner ---------- */
.b2b{
  background:
    linear-gradient(90deg,rgba(42,31,23,.85) 0%,rgba(42,31,23,.5) 60%,rgba(42,31,23,0) 100%),
    url('https://images.unsplash.com/photo-1497935586351-b67a49e012bf?w=1600&q=80') center/cover no-repeat;
  padding:80px 0;
  color:#fff;
}
.b2b-content{max-width:520px}
.b2b h3{
  font-family:var(--font-serif);
  font-size:36px;
  font-weight:500;
  margin-bottom:16px;
}
.b2b p{
  color:#f0e6d6;
  line-height:1.9;
  margin-bottom:24px;
}

/* ---------- Newsletter ---------- */
.newsletter{
  background:var(--c-coffee-50);
  padding:64px 0;
  text-align:center;
}
.newsletter h3{
  font-family:var(--font-serif);
  font-size:28px;
  color:var(--c-coffee-900);
  margin-bottom:8px;
}
.newsletter p{
  color:var(--c-muted);
  margin-bottom:24px;
  font-size:13px;
}
.newsletter-form{
  display:flex;
  max-width:520px;
  margin:0 auto;
  gap:8px;
}
.newsletter-form input{
  flex:1;
  padding:14px 16px;
  border:1px solid var(--c-line);
  background:#fff;
  border-radius:4px;
  font-family:inherit;
  font-size:13px;
  color:var(--c-text);
}
.newsletter-form input:focus{
  outline:none;
  border-color:var(--c-coffee-700);
}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .hero{height:500px}
  .hero-title{font-size:40px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .concept-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .sns-grid{grid-template-columns:repeat(4,1fr)}
  .step-grid{grid-template-columns:repeat(2,1fr);gap:28px 20px}
  .starter-grid{grid-template-columns:1fr;max-width:540px;margin:0 auto}
  .test-grid{grid-template-columns:1fr;max-width:600px;margin:0 auto}
  .startup-intro h2{font-size:36px}
}
@media(max-width:768px){
  .hero{height:440px}
  .hero-title{font-size:32px;line-height:1.25}
  .hero-sub{font-size:13px;margin-bottom:24px}
  .hero-cta{gap:10px}
  .concept-grid{gap:18px}
  .concept-title{font-size:12px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .cat-name-en{font-size:18px}
  .sale-text h3{font-size:24px}
  .sale-banner::before{font-size:120px;top:-10px;right:-10px}
  .story{padding:64px 0}
  .story-grid{grid-template-columns:1fr;gap:32px}
  .story-img{aspect-ratio:4/3}
  .sns-grid{grid-template-columns:repeat(3,1fr)}
  .b2b{padding:56px 0;background-position:right center}
  .b2b h3{font-size:26px}
  .newsletter h3{font-size:22px}
  .newsletter-form{flex-direction:column;padding:0 16px}

  .startup-intro{padding:64px 0}
  .startup-intro h2{font-size:28px;line-height:1.3}
  .startup-intro .lead{font-size:13px}
  .startup-intro::after{font-size:140px;right:-15px;bottom:-30px}
  .steps{padding:64px 0}
  .step-grid{grid-template-columns:1fr;gap:24px}
  .starter{padding:64px 0}
  .starter-body{padding:24px 20px}
  .starter-name{font-size:20px}
  .starter-price strong{font-size:24px}
  .testimonials{padding:64px 0}
  .test-card{padding:24px 22px}
  .support-cta h3{font-size:24px}
  .support-cta{padding:48px 0}
}
