:root {
  --ivory:#fcfaf6; --paper:#fffdf9; --sand:#ede3d5; --greige:#d8cec1;
  --brown:#514942; --soft:#756c64; --rose:#b98c82; --rose-deep:#98756e;
  --line:#e7ded4; --shadow:0 12px 32px rgba(73,59,45,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#f5f1eb;color:var(--brown);font-family:"Hiragino Mincho ProN","Yu Mincho",serif;letter-spacing:.04em}
.lp{width:100%;max-width:480px;margin:0 auto;background:var(--ivory);overflow:hidden;box-shadow:0 0 40px rgba(0,0,0,.05)}
img{width:100%;display:block;object-fit:cover}
p{margin:0;line-height:2;font-size:13px}
h1,h2,h3{font-weight:400;margin:0}
.en{font-family:Georgia,"Times New Roman",serif;letter-spacing:.08em}
.small-title{font-size:11px;letter-spacing:.26em;color:#937e6e;text-align:center;margin-bottom:14px}
.sec{padding:64px 26px}
.section-title{font-size:28px;text-align:center;line-height:1.55;letter-spacing:.10em;color:var(--brown)}
.section-sub{text-align:center;margin:15px auto 0;color:var(--soft);max-width:350px}
.label{display:inline-block;padding:6px 14px;border:1px solid var(--greige);background:rgba(255,253,249,.85);font-size:11px;letter-spacing:.2em;color:#887565}
.fade-photo{position:relative}
.fade-photo:after{content:"";position:absolute;left:0;right:0;bottom:0;height:48%;background:linear-gradient(to bottom,transparent,var(--ivory))}
.cta{display:block;border:1px solid var(--rose);background:var(--rose);color:white;text-align:center;padding:18px 14px;border-radius:999px;text-decoration:none;font-family:"Hiragino Sans","Yu Gothic",sans-serif;font-size:17px;font-weight:600;letter-spacing:.08em;box-shadow:0 8px 20px rgba(152,117,110,.18)}
.cta.light{background:transparent;color:var(--brown);border-color:var(--greige);box-shadow:none}
.price-note{font-family:"Hiragino Sans","Yu Gothic",sans-serif;font-size:11px;color:#7d7068;text-align:center;margin-top:13px}
/* hero */
.hero{position:relative;height:100svh;min-height:640px;background:#ddd;overflow:hidden}
.hero img{height:100%;transform:scale(1.12) translateY(-5%);transform-origin:center}
.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,252,246,.12) 0%,rgba(25,22,20,.04) 36%,rgba(26,22,19,.65) 100%)}
.brand{position:absolute;top:43px;left:0;right:0;z-index:2;text-align:center;color:#fff;font-size:25px;letter-spacing:.25em;text-shadow:0 1px 8px rgba(0,0,0,.18)}
.brand img{display:inline-block;width:148px;height:auto;filter:drop-shadow(0 2px 10px rgba(0,0,0,.35))}
.hero-copy{position:absolute;z-index:2;left:23px;right:23px;bottom:95px;color:white;text-align:center}
.hero-copy h1{font-size:29px;line-height:1.9;letter-spacing:.13em;text-shadow:0 2px 10px rgba(0,0,0,.20);margin:0 0 8px}
.hero-copy .lead{font-size:12px;line-height:2.2;margin:24px 0 40px;letter-spacing:.08em}
.hero-copy .cta{background:rgba(181,137,128,.93);border-color:transparent}
.hero-copy .minor{font-size:10px;margin-top:14px;opacity:.92;font-family:"Hiragino Sans","Yu Gothic",sans-serif}
/* trust strip */
.strip{display:grid;grid-template-columns:repeat(3,1fr);padding:26px 10px 24px;background:var(--paper);border-bottom:1px solid var(--line);gap:0}
.strip div{text-align:center;border-right:1px solid var(--line);font-size:11.5px;line-height:1.85;color:#665c56;padding:0 8px;letter-spacing:.04em}
.strip div:last-child{border:none}
.strip span{display:block;font-family:Georgia,"Times New Roman",serif;font-size:11px;letter-spacing:.28em;color:#b98c82;margin-bottom:11px;font-style:italic}
/* concern */
.concern{padding:72px 18px 80px;background:var(--ivory)}
.card{background:var(--paper);border:1px solid var(--line);padding:32px 22px;box-shadow:var(--shadow);border-radius:18px}
.concern .card{padding:44px 22px 40px;box-shadow:0 14px 38px rgba(80,60,55,.10)}
.concern-title{text-align:center;color:var(--brown);font-size:17px;line-height:1.75;letter-spacing:.06em;margin:10px 0 32px;font-weight:500}
.concern-title span{display:inline-block;font-size:24px;margin-top:6px;position:relative;padding-bottom:11px}
.concern-title span:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--rose)}
.wish-list,.pain-list{list-style:none;margin:0;font-size:12.5px;line-height:1.95;letter-spacing:.04em;text-align:left}
.wish-list{margin-bottom:0;padding:22px 20px 18px;background:linear-gradient(180deg,rgba(255,250,244,.7) 0%,rgba(252,245,238,.4) 100%);border-left:2px solid var(--rose);border-radius:0 4px 4px 0;color:#514942}
.pain-list{padding:22px 20px 18px;background:linear-gradient(180deg,rgba(224,204,200,.20) 0%,rgba(224,204,200,.10) 100%);border-left:2px solid #b8404d;border-radius:0 4px 4px 0;color:#5d534c}
.wish-list li,.pain-list li{position:relative;padding:0 0 14px 26px}
.wish-list li:last-child,.pain-list li:last-child{padding-bottom:0}
.wish-list li:before{content:"";position:absolute;left:2px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--rose);box-shadow:0 0 0 3px rgba(185,140,130,.15)}
.wish-list li:after{content:"✓";position:absolute;left:5px;top:3px;color:#fff;font-size:10px;font-weight:700;line-height:1.6}
.pain-list li:before{content:"";position:absolute;left:2px;top:6px;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#c4505e,#8f2a36);box-shadow:0 0 0 3px rgba(143,42,54,.12)}
.pain-list li:after{content:"×";position:absolute;left:5.5px;top:1px;color:#fff;font-size:12px;font-weight:700;line-height:1.6}
.pain-list li strong{color:#8f2a36;font-weight:700;font-size:13.5px;border-bottom:1px dotted #8f2a36;padding:0 1px 1px}
.transition-wrap{text-align:center;margin:0;padding:18px 0 22px;position:relative}
.transition-wrap:before,.transition-wrap:after{content:"";position:absolute;top:50%;width:34%;height:1px;background:linear-gradient(to right,transparent,var(--line))}
.transition-wrap:before{left:0;background:linear-gradient(to right,transparent,var(--line))}
.transition-wrap:after{right:0;background:linear-gradient(to left,transparent,var(--line))}
.transition-tag{position:relative;display:inline-block;font-size:11.5px;letter-spacing:.22em;color:var(--brown);background:#fff;border:1px solid var(--line);padding:9px 22px;box-shadow:0 4px 14px rgba(80,60,55,.10);border-radius:2px;font-weight:500}
/* answer */
.answer{padding:0 0 44px}
.round-label{height:92px;width:92px;border-radius:50%;margin:-44px auto 26px;position:relative;z-index:1;background:var(--paper);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;text-align:center;font-size:13px;line-height:1.65}
.answer .big-photo{height:400px;margin-top:30px}
.answer .big-photo img{height:100%}
.overlay-copy{margin:30px 21px 0;position:relative;background:rgba(252,250,246,.93);padding:27px 18px;text-align:center;box-shadow:var(--shadow)}
.overlay-copy h3{font-size:20px;line-height:1.8;margin-bottom:13px}
/* reason */
.reason-intro{padding:48px 23px 0;text-align:center}
.collage{padding:34px 15px 68px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:170px 230px 170px;gap:8px}
.collage img{height:100%}
.collage .wide{grid-column:1 / 3}
.collage .tall{grid-row:2 / 4}
.why{padding:68px 20px;background:var(--paper)}
.points{display:grid;gap:28px;margin-top:38px}
.point{background:#fffdfb;border:1px solid var(--line);padding:29px 20px 0;border-radius:4px;overflow:hidden}
.point .no{font-family:Georgia,serif;font-size:13px;color:#b79d8c;letter-spacing:.18em;margin-bottom:13px}
.point h3{font-size:20px;line-height:1.65;margin-bottom:15px}
.point p{color:var(--soft);margin-bottom:22px}
.point img{height:228px;margin:0 -20px;width:calc(100% + 40px)}
/* plans */
.plans{padding:72px 20px 56px}
.plan-card{position:relative;background:var(--paper);border:1px solid var(--line);padding:30px 21px 28px;margin-top:28px;box-shadow:var(--shadow)}
.plan-card h3{font-family:Georgia,serif;letter-spacing:.12em;font-size:20px}
.plan-card .amount{font-size:27px;letter-spacing:.08em;margin:9px 0 18px}
.plan-card .amount small{font-size:12px}
/* campaign banner */
.campaign-banner{margin:26px 0 6px;padding:24px 18px 22px;background:linear-gradient(135deg,#fbf6f0 0%,#f3e6dd 100%);border:1px solid #e8d4c8;border-radius:8px;text-align:center;position:relative;overflow:hidden}
.campaign-banner:before{content:"";position:absolute;top:-32px;right:-32px;width:96px;height:96px;border-radius:50%;background:radial-gradient(circle,rgba(185,140,130,.22) 0%,transparent 70%)}
.campaign-banner:after{content:"";position:absolute;bottom:-30px;left:-30px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(185,140,130,.16) 0%,transparent 70%)}
.campaign-banner-en{position:relative;font-family:Georgia,"Times New Roman",serif;font-style:italic;font-size:11px;letter-spacing:.32em;color:var(--rose-deep);margin-bottom:8px}
.campaign-banner-jp{position:relative;font-size:15px;color:var(--brown);letter-spacing:.06em;line-height:1.6}
.campaign-banner-jp strong{color:var(--rose-deep);font-weight:600;border-bottom:1px solid var(--rose);padding-bottom:2px}
.campaign-banner-note{position:relative;font-size:11px;color:#7d6d63;margin-top:12px;line-height:1.9;letter-spacing:.04em}
/* per-card badge */
.plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#b8404d 0%,#8f2a36 100%);color:#fff;font-family:"Hiragino Sans","Yu Gothic",sans-serif;font-size:12px;letter-spacing:.14em;font-weight:700;padding:7px 18px;border-radius:2px;box-shadow:0 6px 16px rgba(143,42,54,.38);white-space:nowrap}
/* price comparison */
.price-wrap{margin:12px 0 18px}
.price-old{font-family:"Hiragino Sans","Yu Gothic",sans-serif;font-size:13px;color:#a59890;letter-spacing:.04em;margin-bottom:3px}
.price-old s{text-decoration:line-through;text-decoration-color:#c0a89e;margin-left:4px}
.plan-card .amount.campaign-amount{color:var(--rose-deep);font-size:32px;letter-spacing:.04em;margin:0;line-height:1.2}
.plan-card .amount.campaign-amount small{color:var(--soft);font-weight:normal;margin-left:6px}
.plan-list{font-family:"Hiragino Sans","Yu Gothic",sans-serif;font-size:12px;line-height:2.25;color:#655d58;margin:0;padding:0;list-style:none}
.plan-list li:before{content:"✓";color:var(--rose);margin-right:12px}
.plan-image{height:190px;margin:-1px 0 28px}
.plan-image img{height:100%}
.options{border-top:1px solid var(--line);margin-top:32px;padding-top:25px;text-align:center;color:var(--soft);font-size:12px;line-height:2.3}
/* gallery */
.gallery{padding:54px 9px;background:var(--paper)}
.gallery h2{margin-bottom:32px}
.masonry{columns:2;column-gap:8px}
.masonry img{margin-bottom:8px;break-inside:avoid}
/* voices */
.voices{padding:72px 23px}
.voice-intro{height:390px;border-radius:200px 200px 0 0;overflow:hidden;margin:30px auto 34px;max-width:330px}
.voice-intro img{height:100%}
.voice{background:#f4e9e3;border-radius:0 58px 58px 0;margin:17px 0;padding:25px 24px 25px 27px;font-size:13px;line-height:2;color:#5c514b}
.voice:nth-of-type(even){border-radius:58px 0 0 58px;text-align:left}
/* timeline */
.timeline{padding:70px 21px;background:var(--paper)}
.time-items{margin-top:44px;display:grid;gap:35px}
.time-row{display:grid;grid-template-columns:105px 1fr;gap:17px;align-items:center}
.time-row:nth-child(even){grid-template-columns:1fr 105px}
.time-row:nth-child(even) .time-text{order:-1;text-align:right}
.time-row img{height:138px;border-radius:3px}
.time{font-family:Georgia,serif;font-size:24px;font-style:italic;color:#76695f;margin-bottom:10px}
.time-text h3{font-size:15px;line-height:1.7}
.time-text p{font-size:11px;color:#7b716b;line-height:1.8;margin-top:8px}
/* process */
.process{padding:72px 23px}
.steps{position:relative;margin-top:44px}
.steps:before{content:"";position:absolute;left:28px;top:28px;bottom:28px;width:1px;background:var(--greige)}
.step{display:grid;grid-template-columns:58px 1fr;gap:17px;position:relative;margin-bottom:35px}
.step-no{width:56px;height:56px;border-radius:50%;background:var(--paper);border:1px solid var(--greige);font-family:Georgia,serif;text-align:center;padding-top:7px;font-size:11px;line-height:1.35;z-index:1}
.step-no b{display:block;font-size:22px;font-weight:400}
.step h3{font-size:17px;line-height:1.7;margin:5px 0 7px}
.step p{font-size:12px;color:var(--soft)}
/* message */
.message{text-align:center;padding:15px 23px 72px}
.message img{height:425px;margin-bottom:35px}
.message h2{font-size:24px;line-height:2;letter-spacing:.12em}
.message h2 span{color:var(--rose-deep)}
/* faq */
.faq{padding:70px 23px;background:var(--paper)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:19px 0;font-size:14px;line-height:1.65;display:flex;justify-content:space-between;gap:12px;color:var(--brown)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary b{font-family:Georgia,serif;color:var(--rose-deep);font-size:20px;font-weight:400;margin-right:9px}
.faq-icon{font-family:Georgia,serif;font-size:18px;color:var(--rose);transition:transform .3s ease;flex-shrink:0}
.faq-item[open] .faq-icon{transform:rotate(45deg)}
.faq-a{display:flex;gap:0;padding:4px 0 22px;font-size:13px;line-height:1.95;color:#6b6258;letter-spacing:.04em;animation:faqFade .35s ease}
.faq-a b{font-family:Georgia,serif;color:var(--rose-deep);font-size:20px;font-weight:400;margin-right:9px;flex-shrink:0;line-height:1.4}
.faq-a p{margin:0}
.faq-a p strong{color:var(--rose-deep);font-weight:600}
@keyframes faqFade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
/* closing */
.closing{position:relative;height:610px;color:white;text-align:center}
.closing img{height:100%}
.closing:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(30,27,25,.18),rgba(30,27,25,.67))}
.closing-inner{position:absolute;z-index:1;left:24px;right:24px;bottom:45px}
.closing h2{font-size:27px;line-height:1.8;letter-spacing:.12em;margin-bottom:16px}
.closing p{font-size:12px;line-height:2.2;margin-bottom:24px}
.footer{padding:28px 15px 94px;text-align:center;background:var(--paper);font-family:"Hiragino Sans","Yu Gothic",sans-serif;font-size:10px;color:#857970}
.footer .foot-brand{font-family:Georgia,serif;letter-spacing:.20em;font-size:18px;color:#6b615b;margin-bottom:14px}
.footer .foot-brand img{display:inline-block;width:96px;height:auto;opacity:.78}
.sticky{position:fixed;left:50%;bottom:calc(12px + env(safe-area-inset-bottom));z-index:10;width:min(calc(100% - 32px),448px);display:block;opacity:0;transform:translate(-50%,18px);pointer-events:none;transition:opacity .6s ease,transform .6s cubic-bezier(.22,.61,.36,1)}
.sticky.show{opacity:1;transform:translate(-50%,0);pointer-events:auto}
.sticky .cta{padding:16px 10px;background:rgba(185,140,130,.96);backdrop-filter:blur(8px);font-size:16px}
/* mid-page CTA wrapper */
.mid-cta{text-align:center;padding:24px 24px;background:var(--ivory)}
/* scroll reveal — gentle float-up */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1.1s cubic-bezier(.22,.61,.36,1),transform 1.1s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.sticky{transition:none}}
/* per-image positioning — keeps the subject framed regardless of container ratio */
img[src$="DSC00011.webp"]{object-position:center 52%}
img[src$="close-embrace.webp"]{object-position:center 22%}
img[src$="lake-embrace.webp"]{object-position:center 78%}
img[src$="field-couple.webp"]{object-position:center 72%}
img[src$="classic-couple.webp"]{object-position:center 45%}
img[src$="tree-couple.webp"]{object-position:center 30%}
img[src$="beach-walk.webp"]{object-position:center 55%}
img[src$="bride-profile.webp"]{object-position:center 30%}
img[src$="classic-stairs.webp"]{object-position:center 55%}
img[src$="field-dance.webp"]{object-position:center 50%}
img[src$="rock-beach.webp"]{object-position:center 55%}
img[src$="brand-visual.webp"]{object-position:center 22%}
img[src$="beach-bride.webp"]{object-position:center 65%}

@media (min-width:700px){
 body{padding:34px 0}
 .lp{max-width:560px;border-radius:4px}
 .hero-copy h1{font-size:33px}
}
