:root{
  --black:#0b0b0b;
  --white:#ffffff;
  --section-bg:#f5f3ff;
  --purple:#6d8dec;
  --cta:#6d8dec;
  --hover:#4f73d8;
  --accent:#ffe66d;
  --ink:var(--black);
  --muted:rgba(11,11,11,0.66);
  --line:rgba(20,17,23,0.12);
  --shadow:0 28px 80px rgba(48,24,128,0.18);
  --container-padding:20px;
  --max-width:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{min-height:100%}
body{
  margin:0;
  font-family:"Noto Sans JP",sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.75;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit}
button,input,textarea{font:inherit}
.container{width:min(100% - calc(var(--container-padding) * 2),var(--max-width));margin:0 auto}

.site-header{
  position:sticky;
  top:0;
  z-index:30;
  background:rgba(255,255,255,0.9);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(18px);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.logo{display:inline-flex;align-items:center;text-decoration:none}
.logo img{display:block;width:116px;height:auto}
.nav{display:flex;align-items:center;gap:8px;font-size:0.9rem;font-weight:800}
.nav a{display:none;text-decoration:none;padding:8px 10px;border-radius:999px;white-space:nowrap}
.nav-cta{display:inline-flex!important;background:var(--cta);color:var(--white);box-shadow:0 12px 28px rgba(109,141,236,0.28)}
.nav-cta:hover{background:var(--hover)}

.hero{
  position:relative;
  overflow:hidden;
  min-height:760px;
  display:grid;
  place-items:center;
  padding:88px 0 42px;
  background:
    linear-gradient(90deg,rgba(255,255,255,0.18),rgba(255,255,255,0.86) 42%,rgba(255,255,255,0.56) 64%,rgba(255,255,255,0.04)),
    radial-gradient(circle at 50% 55%,rgba(255,255,255,0.98) 0%,rgba(255,255,255,0.9) 18%,rgba(255,255,255,0.45) 38%,rgba(255,255,255,0) 58%),
    url("assets/optimized/hero-backyard-desktop.jpg");
  background-size:cover;
  background-position:center;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,0.1),rgba(255,255,255,0.28));
  pointer-events:none;
}
.hero-overlay{position:relative;z-index:1;width:100%}
.hero-content{
  display:grid;
  justify-items:center;
  text-align:center;
  min-width:0;
}
.eyebrow{
  margin:0 0 12px;
  color:var(--purple);
  font-size:0.74rem;
  font-weight:900;
  letter-spacing:0.08em;
}
h1,.section-title,h3,p{overflow-wrap:anywhere}
h1{
  margin:0;
  max-width:900px;
  color:var(--black);
  font-size:clamp(2.4rem,5.4vw,4.25rem);
  line-height:1.42;
  letter-spacing:0;
}
h1 span{color:var(--purple)}
.hero-lead{
  max-width:720px;
  margin:34px 0 0;
  color:var(--black);
  font-size:clamp(1.35rem,2.4vw,2rem);
  font-weight:900;
  line-height:1.65;
}
.hero-benefits{
  display:grid;
  grid-template-columns:repeat(3,minmax(120px,1fr));
  gap:30px;
  width:min(720px,100%);
  margin:28px auto 0;
}
.hero-benefit{
  display:grid;
  justify-items:center;
  align-content:start;
  gap:10px;
  color:var(--black);
  font-size:1.08rem;
  font-weight:900;
  line-height:1.35;
}
.benefit-icon{
  width:54px;
  height:54px;
  object-fit:contain;
}
.hero-time{
  margin:32px 0 10px;
  color:var(--black);
  font-size:clamp(1.35rem,2.2vw,1.9rem);
  font-weight:900;
  line-height:1.2;
}
.hero-actions{display:flex;justify-content:center;margin-top:12px}
.hero-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:22px;
  min-width:min(560px,calc(100vw - 40px));
  min-height:86px;
  padding:20px 46px;
  border-radius:999px;
  background:#f1a772;
  color:var(--white);
  box-shadow:0 18px 46px rgba(180,106,52,0.24);
  text-decoration:none;
  font-size:clamp(1.18rem,2vw,1.68rem);
  font-weight:900;
  letter-spacing:0.02em;
  line-height:1.2;
}
.hero-cta::after{
  content:"›";
  display:inline-block;
  color:var(--white);
  font-size:1.18em;
  font-weight:700;
  line-height:1;
  transform:translateY(-1px);
}
.hero-cta:hover{filter:brightness(0.96)}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:13px 20px;
  border:2px solid transparent;
  border-radius:999px;
  font-weight:900;
  text-decoration:none;
  cursor:pointer;
}
.button.primary{background:var(--cta);color:var(--white);box-shadow:0 18px 36px rgba(109,141,236,0.32)}
.button.primary:hover{background:var(--hover)}
.button.secondary{background:var(--white);border-color:var(--line);color:var(--ink)}

.section{padding:76px 0}
.section-heading{max-width:760px;margin-bottom:30px}
.center-heading{margin-left:auto;margin-right:auto;text-align:center}
.section-title{
  margin:0;
  color:var(--black);
  font-size:clamp(2rem,3.4vw,3rem);
  line-height:1.16;
  letter-spacing:0;
}
.section-copy{margin:18px 0 0;color:var(--muted);font-weight:500}

.intro-section{
  padding:62px 0 58px;
  background:linear-gradient(180deg,var(--white) 0%,#f8f9ff 100%);
}
.intro-content{
  max-width:820px;
  margin:0 auto;
  text-align:center;
}
.intro-copy{
  max-width:720px;
  margin:22px auto 0;
  color:var(--muted);
  font-size:1.04rem;
  font-weight:700;
  line-height:2;
}
.intro-copy p{margin:0}
.intro-copy p + p{margin-top:10px}
.intro-copy strong{
  color:var(--purple);
  font-weight:900;
}

.comparison-section{background:var(--white)}
.comparison-section .section-copy{margin-left:auto;margin-right:auto;max-width:620px;text-align:center}
.comparison-note{
  max-width:800px;
  margin:0 auto 22px;
  color:var(--muted);
  text-align:center;
  font-weight:700;
}
.comparison-table-wrap{
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:28px;
  background:var(--white);
  box-shadow:0 22px 64px rgba(11,11,11,0.08);
}
.comparison-table{
  width:100%;
  border-collapse:collapse;
  table-layout:fixed;
}
.comparison-table th,
.comparison-table td{
  padding:18px 20px;
  border-bottom:1px solid var(--line);
  text-align:left;
  vertical-align:middle;
}
.comparison-table tr:last-child th,
.comparison-table tr:last-child td{border-bottom:0}
.comparison-table thead th{
  color:var(--muted);
  background:rgba(11,11,11,0.03);
  font-size:0.86rem;
  font-weight:900;
}
.comparison-table thead .looplet-column{
  color:var(--purple);
  background:rgba(109,141,236,0.14);
}
.comparison-table tbody th{
  width:22%;
  color:var(--black);
  font-weight:900;
}
.comparison-table td{
  color:var(--muted);
  font-weight:800;
}
.comparison-table .looplet-column{
  color:var(--black);
  background:rgba(109,141,236,0.08);
}
.comparison-mobile-blocks{display:none}
.status-icon{
  display:inline-grid;
  place-items:center;
  width:22px;
  height:22px;
  margin-right:10px;
  border-radius:999px;
  font-size:0.78rem;
  font-weight:900;
  line-height:1;
}
.traditional-icon{
  border:1px solid rgba(11,11,11,0.18);
  color:rgba(11,11,11,0.42);
  background:var(--white);
}
.looplet-icon{
  color:var(--white);
  background:var(--purple);
}
.comparison-message{
  position:relative;
  overflow:hidden;
  margin-top:22px;
  padding:44px 48px 46px;
  border:1px solid #e1e7ff;
  border-radius:28px;
  background:
    radial-gradient(circle at 10% 12%,rgba(109,141,236,0.16),transparent 26%),
    linear-gradient(135deg,#eef2ff 0%,#f8f9ff 100%);
  color:var(--black);
  box-shadow:0 18px 48px rgba(77,98,170,0.08);
  text-align:center;
}
.comparison-message::after{
  content:"";
  position:absolute;
  right:42px;
  top:34px;
  width:9px;
  height:9px;
  border-radius:999px;
  background:rgba(109,141,236,0.5);
  box-shadow:
    18px 20px 0 rgba(109,141,236,0.18),
    -18px 26px 0 rgba(255,255,255,0.9);
}
.message-label{
  position:relative;
  z-index:1;
  margin:0 0 14px;
  color:var(--purple);
  font-size:0.78rem;
  font-weight:900;
  letter-spacing:0.08em;
}
.message-main{
  position:relative;
  z-index:1;
  margin:0;
  color:#101426;
  font-size:clamp(2.5rem,4vw,3.25rem);
  line-height:1.4;
  font-weight:800;
}
.message-main span{color:#5f7bef}
.message-sub{
  position:relative;
  z-index:1;
  max-width:720px;
  margin:18px auto 0;
  color:var(--muted);
  font-size:0.98rem;
  line-height:1.8;
  font-weight:700;
}

.workload-section{
  background:
    radial-gradient(circle at 88% 24%, rgba(255,230,109,0.7), transparent 22%),
    var(--section-bg);
}
.workload-layout{display:grid;gap:30px;align-items:center}
.workload-copy{max-width:640px}
.time-visual{
  position:relative;
  min-height:380px;
  overflow:hidden;
  border-radius:32px;
  background:linear-gradient(135deg,var(--black),var(--cta) 58%,var(--purple));
  box-shadow:var(--shadow);
}
.time-visual::before{
  content:"";
  position:absolute;
  right:-48px;
  top:-42px;
  width:260px;
  height:260px;
  border:34px solid rgba(255,230,109,0.68);
  border-radius:50%;
}
.clock-mark{
  position:absolute;
  left:28px;
  top:26px;
  color:rgba(255,255,255,0.16);
  font-size:4.2rem;
  line-height:1;
  font-weight:900;
}
.person-card{
  position:absolute;
  width:min(74%,280px);
  padding:18px;
  border:1px solid rgba(255,255,255,0.24);
  border-radius:20px;
  background:rgba(255,255,255,0.12);
  color:var(--white);
  backdrop-filter:blur(10px);
}
.person-card span{display:block;color:var(--accent);font-size:0.76rem;font-weight:900}
.person-card strong{display:block;margin-top:6px;font-size:1.06rem;line-height:1.45}
.busy-card{left:28px;bottom:130px}
.calm-card{right:28px;bottom:34px;background:rgba(255,255,255,0.22)}

.scenes-section{
  padding-top:72px;
  padding-bottom:78px;
  background:#fbfcff;
}
.scenes-section .section-heading{
  max-width:760px;
  margin-bottom:22px;
}
.scene-groups{
  display:grid;
  gap:30px;
  max-width:900px;
  margin:0 auto;
}
.scene-group{
  display:grid;
  justify-items:center;
  gap:14px;
}
.scene-group h3{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin:0;
  color:var(--muted);
  font-size:1.06rem;
  line-height:1.4;
  font-weight:900;
  letter-spacing:0;
  text-align:center;
}
.scene-group-scenes h3{color:#f1a772}
.scene-group-recommend h3{color:var(--purple)}
.scene-tags{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  max-width:760px;
  margin:0 auto;
  padding:0;
  list-style:none;
}
.scene-tags li{
  padding:12px 20px;
  border:1px solid #f1a772;
  border-radius:999px;
  background:#fff7f2;
  color:#3f2414;
  font-size:1.02rem;
  line-height:1.3;
  font-weight:600;
}
.js .scene-tags li,
.js .recommend-list li{
  opacity:0;
  transform:translateY(12px);
  transition:
    opacity 0.45s cubic-bezier(0.22,1,0.36,1),
    transform 0.45s cubic-bezier(0.22,1,0.36,1);
  transition-delay:var(--scene-delay,0s);
}
.js .scene-tags li.is-visible,
.js .recommend-list li.is-visible{
  opacity:1;
  transform:translateY(0);
}
.recommend-list{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  max-width:860px;
  margin:0 auto;
  padding:0;
  list-style:none;
}
.recommend-list li{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:50px;
  padding:12px 18px;
  border:1px solid #dde5ff;
  border-radius:999px;
  background:var(--white);
  color:#101426;
  font-size:1rem;
  line-height:1.3;
  font-weight:600;
}
.recommend-list span{
  flex:0 0 auto;
  display:grid;
  place-items:center;
  width:20px;
  height:20px;
  border-radius:999px;
  background:#eef2ff;
  color:#5f7bef;
  font-size:0.74rem;
  font-weight:900;
}
.scene-footer{
  display:grid;
  justify-items:center;
  gap:14px;
  margin-top:28px;
  text-align:center;
}
.scene-footer p{
  margin:0;
  color:var(--muted);
  font-weight:700;
}
.scene-footer .button{
  min-height:44px;
  padding:10px 18px;
  font-size:0.92rem;
}

.steps-section{background:var(--section-bg)}
.steps-section .section-heading{margin-bottom:34px}
.steps{
  display:grid;
  gap:18px;
  margin:0;
  padding:0;
  list-style:none;
}
.steps li{
  display:flex;
  flex-direction:column;
  min-height:278px;
  padding:28px;
  border:1px solid rgba(108,59,255,0.16);
  border-radius:26px;
  background:var(--white);
  box-shadow:0 16px 36px rgba(48,24,128,0.08);
}
.js .steps li{
  opacity:0;
  transform:translateY(16px);
  transition:
    opacity 0.45s cubic-bezier(0.22,1,0.36,1),
    transform 0.45s cubic-bezier(0.22,1,0.36,1);
  transition-delay:var(--step-delay,0s);
}
.js .steps li.is-visible{
  opacity:1;
  transform:translateY(0);
}
.step-number{
  display:grid;
  place-items:center;
  width:68px;
  height:68px;
  border-radius:18px;
  background:var(--purple);
  color:var(--white);
  font-size:1.34rem;
  font-weight:900;
  line-height:1;
}
.steps h3{margin:22px 0 10px;font-size:1.24rem;line-height:1.35}
.steps p{margin:0;color:var(--muted);font-weight:700;line-height:1.75}

.feature-section{
  overflow:hidden;
  background:var(--white);
}
.feature-section .section-heading{max-width:780px}
.feature-carousel-wrap{
  position:relative;
}
.feature-carousel{
  display:flex;
  gap:28px;
  overflow-x:auto;
  padding:6px 0 18px;
  scroll-padding-left:0;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;
}
.feature-arrow{
  position:absolute;
  top:50%;
  z-index:2;
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border:1px solid #e1e7ff;
  border-radius:999px;
  background:rgba(255,255,255,0.94);
  color:var(--purple);
  box-shadow:0 14px 30px rgba(77,98,170,0.14);
  cursor:pointer;
  transform:translateY(-50%);
  transition:
    opacity 0.2s ease,
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}
.feature-arrow::before{
  content:"";
  display:block;
  width:12px;
  height:12px;
  border-top:4px solid currentColor;
  border-right:4px solid currentColor;
}
.feature-arrow-prev::before{transform:translateX(2px) rotate(-135deg)}
.feature-arrow-next::before{transform:translateX(-2px) rotate(45deg)}
.feature-arrow:hover{
  background:var(--purple);
  color:var(--white);
  transform:translateY(-50%) scale(1.04);
}
.feature-arrow:disabled{
  opacity:0.32;
  cursor:default;
  pointer-events:none;
}
.feature-arrow-prev{left:-18px}
.feature-arrow-next{right:-18px}
.feature-card{
  flex:0 0 min(390px,calc(100vw - 48px));
  display:flex;
  flex-direction:column;
  height:540px;
  padding:18px;
  border:1px solid #e1e7ff;
  border-radius:24px;
  background:var(--white);
  box-shadow:0 18px 42px rgba(77,98,170,0.08);
  scroll-snap-align:start;
}
.js .feature-card{
  opacity:0;
  transform:translateY(16px);
  transition:
    opacity 0.45s cubic-bezier(0.22,1,0.36,1),
    transform 0.45s cubic-bezier(0.22,1,0.36,1);
  transition-delay:var(--feature-delay,0s);
}
.js .feature-card.is-visible{
  opacity:1;
  transform:translateY(0);
}
.feature-number{
  margin:0 0 14px;
  color:var(--purple);
  font-size:1.12rem;
  font-weight:800;
  letter-spacing:0.06em;
  line-height:1;
}
.feature-media{
  position:relative;
  display:grid;
  place-items:center;
  aspect-ratio:3 / 2;
  flex:0 0 auto;
  border-radius:18px;
  background:#f5f7ff;
  overflow:hidden;
}
.feature-media img{
  display:block;
  width:100%;
  height:100%;
  padding:10px;
  object-fit:contain;
}
.feature-media.is-missing::after{
  content:"IMAGE";
  color:rgba(11,11,11,0.26);
  font-size:0.9rem;
  font-weight:900;
  letter-spacing:0.12em;
}
.feature-body{
  display:flex;
  flex:1;
  flex-direction:column;
  min-height:0;
  padding-top:18px;
}
.feature-card h3{
  display:-webkit-box;
  min-height:3.2em;
  margin:0 0 8px;
  color:var(--ink);
  font-size:1.16rem;
  line-height:1.4;
  overflow:hidden;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
}
.feature-description{
  display:-webkit-box;
  margin:0;
  color:var(--muted);
  font-size:0.9rem;
  font-weight:700;
  line-height:1.72;
  overflow:hidden;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:4;
}
.feature-spec{
  display:inline-flex;
  align-self:flex-start;
  margin:12px 0 0;
  padding:6px 10px;
  border:1px solid rgba(109,141,236,0.2);
  border-radius:999px;
  background:#f5f7ff;
  color:var(--purple);
  font-size:0.78rem;
  font-weight:900;
  line-height:1.4;
}
.feature-cta{
  display:grid;
  justify-items:center;
  gap:16px;
  margin-top:34px;
  text-align:center;
}
.feature-cta p{
  margin:0;
  color:var(--muted);
  font-size:0.96rem;
  font-weight:700;
  line-height:1.7;
}

.price-section{background:var(--black);color:var(--white)}
.price-section .section-title{color:var(--white)}
.price-section .section-copy{color:rgba(255,255,255,0.72)}
.price-grid{display:grid;gap:24px;align-items:center}
.price-card{
  padding:28px;
  border-radius:28px;
  background:var(--white);
  color:var(--black);
  box-shadow:0 26px 60px rgba(0,0,0,0.25);
}
.price-label{margin:0;color:var(--purple);font-weight:900}
.price-main{margin:8px 0 0;line-height:1}
.price-main strong{font-size:3.5rem}
.price-main span{margin-left:6px;font-weight:900}
.price-note{margin:14px 0 0;color:var(--muted);font-weight:700}

.faq-section{background:var(--section-bg)}
.faq-grid{display:grid;gap:24px}
.faq{display:grid;gap:10px}
.faq details{
  border:1px solid rgba(108,59,255,0.16);
  border-radius:20px;
  background:var(--white);
  overflow:hidden;
}
.faq summary{
  cursor:pointer;
  padding:18px 20px;
  font-weight:900;
}
.faq p{margin:0;padding:0 20px 18px;color:var(--muted);font-weight:600}

.form-section{background:var(--white);padding-bottom:94px}
.form-layout{display:grid;gap:28px}
.form-intro{max-width:560px}
.form-memo{
  margin-top:24px;
  padding:20px;
  border-radius:24px;
  background:var(--section-bg);
}
.form-memo h3{margin:0 0 8px;font-size:1rem}
.form-memo ul{margin:0;padding-left:1.2rem;color:var(--muted);font-weight:700}
.loan-form{
  display:grid;
  gap:12px;
  padding:18px;
  border:1px solid rgba(108,59,255,0.16);
  border-radius:28px;
  background:var(--section-bg);
}
.loan-form label{display:flex;flex-direction:column;font-size:0.92rem;font-weight:900}
.loan-form input,.loan-form textarea{
  width:100%;
  margin-top:7px;
  padding:13px 14px;
  border:1px solid rgba(20,17,23,0.12);
  border-radius:16px;
  background:var(--white);
  color:var(--ink);
}
.loan-form textarea{resize:vertical}
.fee-estimate{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  padding:18px;
  border:1px solid rgba(109,141,236,0.22);
  border-radius:20px;
  background:linear-gradient(135deg,rgba(255,255,255,0.92),rgba(238,242,255,0.92));
}
.fee-estimate span{
  display:block;
  color:var(--purple);
  font-size:0.82rem;
  font-weight:900;
  letter-spacing:0.04em;
}
.fee-estimate strong{
  display:block;
  margin-top:4px;
  color:var(--black);
  font-size:clamp(1.35rem,3vw,2rem);
  line-height:1.25;
  font-weight:900;
}
.fee-estimate.is-placeholder strong{
  color:rgba(11,11,11,0.46);
  font-size:clamp(1rem,2vw,1.18rem);
  font-weight:800;
}
.fee-estimate p{
  max-width:320px;
  margin:0;
  color:var(--muted);
  font-size:0.86rem;
  line-height:1.6;
  font-weight:700;
}
.form-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:12px;
  margin-top:4px;
}
.form-status{font-size:0.92rem;color:var(--muted);font-weight:800}

.site-footer{padding:32px 0;color:var(--white);background:var(--black)}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}
.footer-company{
  color:var(--white);
  font-weight:900;
  text-decoration:none;
  white-space:nowrap;
}
.footer-inner small{
  text-align:right;
  overflow-wrap:anywhere;
}
.page-top-button{
  position:fixed;
  right:32px;
  bottom:32px;
  z-index:40;
  display:grid;
  place-items:center;
  width:56px;
  height:56px;
  border-radius:999px;
  background:var(--purple);
  color:var(--white);
  box-shadow:0 18px 34px rgba(109,141,236,0.34);
  text-decoration:none;
  font-size:1.35rem;
  font-weight:900;
  line-height:1;
}
.page-top-button:hover{background:var(--hover)}

a:focus,button:focus,input:focus,textarea:focus,summary:focus{
  outline:3px solid var(--accent);
  outline-offset:3px;
}

@media(min-width:720px){
  .nav a{display:inline-flex}
  .hero{padding:96px 0 46px}
  .section:not(.comparison-section) .section-title{white-space:nowrap}
  .workload-layout{grid-template-columns:minmax(0,0.86fr) minmax(360px,1.14fr)}
  .steps{grid-template-columns:repeat(4,1fr)}
  .price-grid{grid-template-columns:1fr 360px}
  .faq-grid{grid-template-columns:0.6fr 1.4fr}
  .form-layout{grid-template-columns:0.78fr 1.22fr;align-items:start}
  .loan-form{grid-template-columns:repeat(2,1fr);padding:24px}
  .full-field,.form-actions{grid-column:1 / -1}
  .form-actions{flex-direction:row;align-items:center}
}

@media(min-width:1040px){
  .section{padding:104px 0}
  .hero{min-height:820px}
}

@media(max-width:719px){
  .nav{display:none}
  .hero{
    min-height:720px;
    padding:78px 0 36px;
    background:
      linear-gradient(90deg,rgba(255,255,255,0.28),rgba(255,255,255,0.88) 44%,rgba(255,255,255,0.58) 70%,rgba(255,255,255,0.08)),
      radial-gradient(circle at 50% 55%,rgba(255,255,255,0.98) 0%,rgba(255,255,255,0.9) 18%,rgba(255,255,255,0.45) 38%,rgba(255,255,255,0) 58%),
      url("assets/optimized/hero_SP.jpg"),
      url("assets/optimized/hero-backyard-desktop.jpg");
    background-size:cover;
    background-position:center;
  }
  h1{
    width:min(100%,22rem);
    max-width:22rem;
    font-size:clamp(2rem,8.4vw,2.25rem);
    line-height:1.34;
    word-break:normal;
    overflow-wrap:normal;
    line-break:strict;
  }
  .hero-lead{
    width:min(100%,21rem);
    max-width:21rem;
    margin-top:22px;
    font-size:1.14rem;
    line-height:1.68;
    word-break:normal;
    overflow-wrap:normal;
    line-break:strict;
  }
  .hero-benefits{grid-template-columns:1fr;gap:10px;width:min(20rem,100%);margin-top:20px}
  .hero-benefit{grid-template-columns:40px 1fr;gap:8px;justify-items:start;align-items:center;text-align:left;font-size:0.9rem;line-height:1.32}
  .benefit-icon{width:40px;height:40px;font-size:1.4rem}
  .hero-time{margin:22px 0 8px;font-size:1.16rem}
  .hero-actions{margin-top:8px;width:100%}
  .hero-cta{width:calc(100% - 48px);max-width:360px;min-width:0;gap:14px;min-height:66px;padding:16px 24px;font-size:1rem;letter-spacing:0.01em}
  .intro-section{padding:48px 0 44px}
  .intro-content{max-width:22rem}
  .intro-copy{
    max-width:21rem;
    margin-top:18px;
    font-size:0.94rem;
    line-height:1.9;
  }
  .section-title{font-size:1.9rem;line-height:1.2}
  .comparison-section .section-heading{max-width:100%}
  .comparison-section .section-title{
    width:auto;
    max-width:none;
    font-size:1.9rem;
    margin-left:auto;
    margin-right:auto;
  }
  .comparison-section .section-copy,
  .comparison-note{
    width:min(100%,17rem);
    max-width:17rem;
    font-size:0.9rem;
  }
  .comparison-section .section-title,
  .comparison-section .section-copy,
  .comparison-note{
    overflow-wrap:anywhere;
    word-break:break-all;
    line-break:anywhere;
  }
  .comparison-table-wrap{display:none}
  .comparison-mobile-blocks{
    display:grid;
    gap:16px;
  }
  .comparison-mobile-list{
    overflow:hidden;
    border:1px solid var(--line);
    border-radius:24px;
    background:var(--white);
    box-shadow:0 18px 48px rgba(11,11,11,0.07);
  }
  .comparison-mobile-list h3{
    margin:0;
    padding:20px 18px;
    border-bottom:1px solid var(--line);
    background:rgba(11,11,11,0.03);
    color:var(--muted);
    font-size:1.08rem;
    line-height:1.35;
    font-weight:900;
  }
  .comparison-mobile-list ul{
    margin:0;
    padding:0;
    list-style:none;
  }
  .comparison-mobile-list li{
    display:flex;
    align-items:center;
    gap:14px;
    min-height:72px;
    padding:18px;
    border-bottom:1px solid var(--line);
    color:var(--muted);
    font-size:1.02rem;
    line-height:1.45;
    font-weight:900;
  }
  .comparison-mobile-list li:last-child{border-bottom:0}
  .comparison-mobile-list .status-icon{
    flex:0 0 auto;
    width:28px;
    height:28px;
    margin-right:0;
    font-size:0.9rem;
  }
  .looplet-list{
    background:rgba(109,141,236,0.08);
    border-color:rgba(109,141,236,0.22);
  }
  .looplet-list h3{
    color:var(--purple);
    background:rgba(109,141,236,0.12);
  }
  .looplet-list li{
    color:var(--black);
    border-color:rgba(109,141,236,0.14);
  }
  .comparison-message{padding:30px 20px;border-radius:24px}
  .comparison-message::after{right:22px;top:22px}
  .message-label{margin-bottom:12px;font-size:0.72rem}
  .message-main{font-size:1.78rem;line-height:1.42}
  .message-sub{font-size:0.88rem;line-height:1.75}
  .scenes-section{padding-top:56px;padding-bottom:62px}
  .scene-groups{gap:24px}
  .scene-group{justify-items:start}
  .scene-group h3{justify-content:flex-start;text-align:left;font-size:1rem}
  .scene-tags,
  .recommend-list{justify-content:flex-start;max-width:none;gap:8px}
  .scene-tags li{padding:10px 14px;font-size:0.92rem}
  .recommend-list li{min-height:46px;padding:10px 12px;font-size:0.88rem}
  .recommend-list span{width:18px;height:18px;font-size:0.68rem}
  .scene-footer{margin-top:22px}
  .time-visual{min-height:340px}
  .person-card{width:78%}
  .steps li{min-height:auto;padding:24px}
  .step-number{width:60px;height:60px;font-size:1.18rem}
  .feature-carousel{gap:18px;padding-bottom:14px}
  .feature-arrow{width:40px;height:40px}
  .feature-arrow::before{width:10px;height:10px;border-width:3px}
  .feature-arrow-prev{left:4px}
  .feature-arrow-next{right:4px}
  .feature-carousel{
    margin-left:calc(var(--container-padding) * -1);
    margin-right:calc(var(--container-padding) * -1);
    padding-left:calc(var(--container-padding) + 22px);
    padding-right:calc(var(--container-padding) + 22px);
    scroll-padding-left:calc(var(--container-padding) + 22px);
    scroll-padding-right:calc(var(--container-padding) + 22px);
  }
  .feature-card{
    flex-basis:calc(100vw - 88px);
    height:490px;
    padding:16px;
    scroll-snap-align:center;
  }
  .feature-number{font-size:1rem;margin-bottom:12px}
  .feature-media{aspect-ratio:3 / 2;flex-basis:auto}
  .feature-media img{padding:8px}
  .feature-body{padding-top:16px}
  .feature-card h3{font-size:1.08rem}
  .feature-description{font-size:0.86rem;line-height:1.7}
  .feature-cta{margin-top:28px}
  .fee-estimate{align-items:flex-start;flex-direction:column}
  .fee-estimate p{max-width:none}
  .footer-inner{align-items:flex-start;gap:8px}
  .footer-inner small{text-align:left}
}

@media(max-width:420px){
  :root{--container-padding:16px}
  .header-inner{padding:12px 0}
  .nav{font-size:0.82rem}
  .hero{min-height:700px;padding:74px 0 34px}
  h1{width:min(100%,21rem);max-width:21rem;font-size:clamp(1.92rem,8.2vw,2.12rem)}
  .hero-lead{width:min(100%,20rem);max-width:20rem;font-size:1.06rem}
  .comparison-section .section-title{width:auto;max-width:none;font-size:1.9rem}
  .comparison-section .section-copy,
  .comparison-note{
    width:min(100%,18rem);
    max-width:18rem;
    font-size:0.9rem;
  }
  .section{padding:62px 0}
  .price-main strong{font-size:2.8rem}
  .page-top-button{width:52px;height:52px;right:32px;bottom:32px}
}

@media(prefers-reduced-motion:reduce){
  .js .scene-tags li,
  .js .recommend-list li,
  .js .steps li,
  .js .feature-card{
    opacity:1;
    transform:none;
    transition:none;
  }
}
