{{ toastMessage }}
家具と家電のレンタル ・サブスク CLAS (クラス)
メニュー

家具と家電の

レンタル・サブスク

カート {{ cartQuantity }}
{{ categoriesBarTitle }}

全国配送対応アイテム

2026/03/10

/* PT Engine親要素のoverflow解除(sticky有効化) */ .SectionComponent, .HtmlComponent, .HtmlComponent > div { overflow: visible !important; } /* ============================================ Design Tokens ============================================ */ :root { --primary: #D96C45; --primary-dark: #C45A35; --primary-light: #FDF0EC; --secondary: #3A8E7B; --secondary-dark: #2E7565; --secondary-light: #E8F4F0; --navy: #2D312F; --bg: #FFFFFF; --warm-bg: #F5F3F0; --card-bg: #F2F3F2; --text: #323630; --text-light: #979E94; --text-mid: #646B61; --border: #CBCFC9; --border-light: #E5E7E4; --font: futura-pt, arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "YakuHanJP", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif; --radius: 8px; --radius-md: 10px; --radius-pill: 100px; } * { margin: 0; padding: 0; box-sizing: border-box; } html { font-size: 10px; } body { font-family: var(--font); background: var(--warm-bg); color: var(--text); } /* ============================================ Header (Sticky) ============================================ */ .nw-header { background: var(--bg); padding: 12px 16px; position: sticky; top: 0; z-index: 50; border-bottom: 1px solid var(--border-light); display: flex; align-items: center; gap: 12px; } .nw-header-back { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; color: var(--navy); font-size: 18px; text-decoration: none; cursor: pointer; } .nw-header-title { font-size: 14px; font-weight: 700; color: var(--navy); letter-spacing: 0.05em; } /* ============================================ Hero ============================================ */ .nw-hero { background: url('https://d3sschy81elrav.cloudfront.net/p/f800d8fb83d0e4dbd555f9073fefcda3') center center / cover no-repeat; padding: 40px 20px 32px; position: relative; overflow: hidden; } .nw-hero::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(45,49,47,0.55) 0%, rgba(45,49,47,0) 100%); } .nw-hero > * { position: relative; z-index: 1; } .nw-hero-badge { display: inline-block; background: rgba(255,255,255,0.2); color: #fff; font-size: 10px; font-weight: 700; letter-spacing: 0.1em; padding: 3px 10px; border-radius: var(--radius-pill); margin-bottom: 12px; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); } .nw-hero-title { color: #fff; font-size: 18px; font-weight: 700; line-height: 1.5; letter-spacing: 0.03em; margin-bottom: 8px; text-shadow: 0 1px 8px rgba(0,0,0,0.3); } .nw-hero-sub { color: #fff; font-size: 15px; font-weight: 600; line-height: 1.8; text-shadow: 0 1px 6px rgba(0,0,0,0.3); } /* ============================================ Benefit Bar ============================================ */ .nw-benefit-section { background: #d6cfc2; padding: 16px 0; } .nw-benefit-inner { display: flex; gap: 8px; padding-left: 16px; padding-right: 8px; overflow-x: auto; -webkit-overflow-scrolling: touch; } .nw-benefit-inner::-webkit-scrollbar { display: none; } .nw-benefit-item { flex-shrink: 0; background: var(--warm-bg); border-radius: var(--radius-md); padding: 8px; display: flex; flex-direction: column; align-items: center; text-align: center; min-width: 88px; gap: 2px; cursor: pointer; transition: opacity 0.15s; } .nw-benefit-item:active { opacity: 0.7; } .nw-benefit-icon { width: 24px; height: 24px; margin-bottom: 2px; } .nw-benefit-icon img { width: 100%; height: 100%; object-fit: contain; } .nw-benefit-title { font-weight: 700; font-size: 10px; color: var(--navy); letter-spacing: 0.5px; line-height: 1.5; white-space: nowrap; } .nw-benefit-note { font-weight: 400; font-size: 10px; color: #72777a; letter-spacing: 0.5px; line-height: 1.5; white-space: nowrap; } /* Benefit Modal */ .bm-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.45); z-index: 9999; opacity: 0; visibility: hidden; transition: opacity 0.25s, visibility 0.25s; display: flex; align-items: flex-end; justify-content: center; } .bm-overlay.open { opacity: 1; visibility: visible; } .bm-sheet { background: #fff; border-radius: 16px 16px 0 0; width: 100%; max-width: 402px; max-height: 82vh; overflow-y: auto; transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1); padding: 0 0 32px; } .bm-overlay.open .bm-sheet { transform: translateY(0); } .bm-handle { display: flex; justify-content: center; padding: 12px 0 8px; position: sticky; top: 0; background: #fff; z-index: 1; border-radius: 16px 16px 0 0; } .bm-handle span { width: 36px; height: 4px; border-radius: 2px; background: #d1d5db; } .bm-close { position: sticky; top: 8px; float: right; margin-right: 16px; margin-top: -28px; width: 32px; height: 32px; border: none; background: var(--card-bg); border-radius: 50%; font-size: 18px; color: var(--text); cursor: pointer; display: flex; align-items: center; justify-content: center; z-index: 2; } .bm-body { padding: 0 20px; } .bm-title { font-size: 18px; font-weight: 700; color: var(--text); text-align: center; margin-bottom: 4px; } .bm-title-line { width: 40px; height: 2px; background: var(--primary); margin: 0 auto 16px; border-radius: 1px; } .bm-subtitle { font-size: 13px; font-weight: 600; color: var(--primary); text-align: center; margin-bottom: 8px; } .bm-text { font-size: 13px; line-height: 1.9; color: var(--text); margin-bottom: 16px; } .bm-text strong { font-weight: 600; } .bm-note { font-size: 11px; color: var(--text-light); margin-top: 8px; } .bm-section-label { font-size: 14px; font-weight: 700; color: var(--text); margin: 20px 0 6px; display: flex; align-items: center; gap: 8px; } .bm-section-label::before { content: ''; width: 3px; height: 16px; background: var(--primary); border-radius: 2px; } .bm-plan-name { font-size: 12px; font-weight: 600; color: var(--text-mid); text-align: center; margin: 12px 0 6px; } .bm-table { width: 100%; border-collapse: collapse; margin-bottom: 8px; font-size: 11px; } .bm-table th, .bm-table td { padding: 6px 8px; text-align: center; border: 1px solid var(--border-light); } .bm-table th { background: var(--card-bg); font-weight: 600; font-size: 10px; color: var(--text-mid); } .bm-table td { color: var(--text); } .bm-table .bm-highlight { background: var(--primary-light); font-weight: 700; color: var(--primary); } .bm-badge { display: inline-block; background: var(--primary); color: #fff; font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 3px; vertical-align: middle; } .bm-table th .bm-badge { display: block; margin: 4px auto 0; } .bm-steps { display: flex; flex-direction: column; gap: 12px; margin: 16px 0; } .bm-step { display: flex; gap: 12px; align-items: flex-start; } .bm-step-num { flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%; background: var(--primary); color: #fff; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; margin-top: 2px; } .bm-step-content { flex: 1; } .bm-step-title { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 2px; } .bm-step-desc { font-size: 12px; color: var(--text-mid); line-height: 1.7; } .bm-points { display: flex; flex-direction: column; gap: 8px; margin: 12px 0 16px; } .bm-point { background: var(--card-bg); border-radius: 8px; padding: 10px 14px; font-size: 12px; color: var(--text); line-height: 1.6; } .bm-point strong { color: var(--primary); font-weight: 700; } .bm-plan-select { background: var(--card-bg); border-radius: 10px; padding: 14px 16px; margin-bottom: 16px; } .bm-plan-select-title { font-size: 11px; font-weight: 600; color: var(--text-mid); text-align: center; margin-bottom: 10px; } .bm-radio { display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; font-size: 12px; color: var(--text); line-height: 1.5; } .bm-radio + .bm-radio { border-top: 1px solid var(--border-light); } .bm-radio-dot { flex-shrink: 0; width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--border); margin-top: 1px; position: relative; } .bm-radio-dot.checked { border-color: var(--secondary); } .bm-radio-dot.checked::after { content: ''; position: absolute; inset: 3px; border-radius: 50%; background: var(--secondary); } .bm-radio strong { font-weight: 600; font-size: 13px; } .bm-radio-sub { font-size: 10px; color: var(--text-light); } .bm-cta { display: block; text-align: center; margin: 20px auto 0; padding: 12px 24px; background: var(--primary); color: #fff !important; border-radius: 30px; font-size: 13px; font-weight: 700; text-decoration: none; max-width: 280px; } .bm-cta:active { opacity: 0.85; } .bm-examples { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; } .bm-example { background: var(--card-bg); border-radius: 8px; padding: 10px 14px; font-size: 12px; color: var(--text); line-height: 1.5; } /* ============================================ Progress Bar (まとめ割) ============================================ */ .nw-progress { background: var(--bg); padding: 14px 16px 12px; position: sticky; top: 56px; z-index: 40; border-bottom: 1px solid var(--border-light); } .nw-progress-label { font-size: 11px; font-weight: 700; color: var(--navy); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; } .nw-progress-label-icon { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; background: var(--primary); color: #fff; border-radius: 50%; font-size: 9px; font-weight: 700; } .nw-progress-track { display: flex; align-items: center; gap: 0; } .nw-progress-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--border-light); flex-shrink: 0; z-index: 1; } .nw-progress-dot.current { background: var(--primary); width: 12px; height: 12px; box-shadow: 0 0 0 3px rgba(217,108,69,0.2); } .nw-progress-bar-seg { flex: 1; height: 3px; background: var(--border-light); } .nw-progress-labels { display: flex; justify-content: space-between; margin-top: 5px; } .nw-progress-step-label { font-size: 9px; color: var(--text-light); text-align: center; line-height: 1.3; flex: 1; } .nw-progress-step-label:first-child { text-align: left; } .nw-progress-step-label:last-child { text-align: right; } .nw-progress-step-label strong { display: block; font-size: 10px; color: var(--primary); } /* ============================================ Set Navigation Pills (Sticky) ============================================ */ .nw-set-nav { background: var(--warm-bg); padding: 10px 8px; position: sticky; top: 104px; z-index: 39; border-bottom: 1px solid var(--border-light); } .nw-set-pills { display: flex; gap: 8px; overflow-x: auto; -webkit-overflow-scrolling: touch; padding: 0 8px; } .nw-set-pills::-webkit-scrollbar { display: none; } .nw-set-pill { flex-shrink: 0; border-radius: 50px; padding: 4px 12px; font-size: 11px; font-weight: 700; line-height: 180%; letter-spacing: 0.03em; background: #e3e5e5; color: var(--navy); border: none; cursor: pointer; white-space: nowrap; transition: all 0.2s; text-decoration: none; } .nw-set-pill.active { background: var(--navy); color: #fff; } /* ============================================ Content ============================================ */ .nw-content { padding: 0 0 80px; } .nw-loading { text-align: center; padding: 40px 16px; color: var(--text-light); font-size: 12px; } /* ============================================ Set Section ============================================ */ .nw-set-section { padding: 32px 0 24px; margin-bottom: 64px; background: var(--bg); scroll-margin-top: 160px; } .nw-set-header { margin: 0 16px 4px; padding-left: 16px; border-left: 3px solid var(--secondary); } .nw-set-title { font-size: 16px; font-weight: 700; color: var(--navy); line-height: 1.5; letter-spacing: 0.03em; } .nw-set-copy { font-size: 12px; font-weight: 400; color: var(--text-mid); line-height: 1.6; margin-top: 2px; } /* ============================================ Carousel (横スクロール + +接続) ============================================ */ .nw-carousel-wrap { margin: 14px 0 0; overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; } .nw-carousel-wrap::-webkit-scrollbar { display: none; } .nw-carousel { display: inline-flex; align-items: flex-start; gap: 0; } .nw-carousel::before, .nw-carousel::after { content: ''; flex-shrink: 0; width: 16px; } .nw-carousel-item { scroll-snap-align: start; flex-shrink: 0; width: 130px; } .nw-carousel-card { background: none; border-radius: var(--radius); overflow: hidden; border: none; text-decoration: none; color: inherit; display: block; } .nw-carousel-card-img { width: 100%; aspect-ratio: 1; background: #e8ddd4; display: flex; align-items: center; justify-content: center; overflow: hidden; border-radius: var(--radius); } .nw-carousel-card-img img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); } .nw-carousel-card-info { padding: 6px 2px 4px; } .nw-carousel-card-name { font-size: 10px; font-weight: 400; color: var(--text); line-height: 1.4; margin-bottom: 3px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; } .nw-carousel-card-price { font-size: 13px; font-weight: 400; color: var(--navy); } .nw-carousel-card-price small { font-size: 9px; font-weight: 400; color: var(--text-light); } /* Plus connector — 画像の中央に配置 */ .nw-plus { flex-shrink: 0; width: 28px; display: flex; align-items: flex-start; justify-content: center; padding-top: calc(130px / 2 - 10px); /* 画像高さの半分 - 円半径 */ font-size: 12px; font-weight: 700; color: var(--text-mid); } .nw-plus span { display: flex; align-items: center; justify-content: center; width: 20px; height: 20px; background: var(--border-light); border-radius: 50%; } /* ============================================ Set Total Bar ============================================ */ .nw-set-total { margin: 12px 16px 0; padding: 10px 14px; background: var(--warm-bg); border: 1px solid var(--border-light); border-radius: var(--radius); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 6px; } .nw-set-section:last-child { margin-bottom: 0; } .nw-set-total-price { font-size: 13px; font-weight: 400; color: var(--text-mid); } .nw-set-total-price strong { font-size: 18px; font-weight: 400; color: var(--navy); } .nw-set-total-discount { font-size: 11px; font-weight: 700; color: var(--primary); background: var(--primary-light); padding: 3px 10px; border-radius: var(--radius-pill); } /* ============================================ More Toggle + Expandable Grid ============================================ */ .nw-more-toggle { display: block; margin: 12px 16px 0; padding: 8px 16px; background: none; border: 1px dashed var(--border); border-radius: var(--radius-pill); color: var(--text-mid); font-size: 12px; font-weight: 600; font-family: var(--font); text-align: center; cursor: pointer; transition: all 0.2s; width: calc(100% - 32px); } .nw-more-toggle:hover { border-color: var(--border); color: var(--text); } .nw-more-toggle.open { border-style: solid; border-color: var(--border); color: var(--text); } .nw-more-grid { display: none; grid-template-columns: 1fr 1fr; gap: 8px; padding: 12px 16px 0; } .nw-more-grid.open { display: grid; } /* Grid card (smaller) */ .nw-g-card { background: var(--bg); border-radius: var(--radius); overflow: hidden; border: 1.5px solid var(--border-light); transition: all 0.2s; text-decoration: none; color: inherit; display: block; } .nw-g-card:hover { border-color: var(--secondary); } .nw-g-card-img { width: 100%; aspect-ratio: 1; background: var(--card-bg); display: flex; align-items: center; justify-content: center; overflow: hidden; } .nw-g-card-img img { width: 100%; height: 100%; object-fit: cover; } .nw-g-card-info { padding: 8px 8px 6px; } .nw-g-card-name { font-size: 10px; font-weight: 700; color: var(--text); line-height: 1.4; margin-bottom: 4px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; } .nw-g-card-price { font-size: 14px; font-weight: 700; color: var(--navy); } .nw-g-card-price small { font-size: 10px; font-weight: 400; color: var(--text-light); } /* ============================================ Section CTA ============================================ */ .nw-set-cta { display: block; margin: 12px 16px 0; padding: 10px 16px; border-radius: var(--radius-pill); background: var(--bg); color: var(--primary) !important; font-size: 12px; font-weight: 700; border: 1px solid var(--primary); text-align: center; text-decoration: none !important; transition: all 0.2s; } .nw-set-cta:hover { background: var(--primary-light); } /* ============================================ Crowdfund Grid — 2段横スクロール(wizard v2準拠) ============================================ */ .nw-cf-section { padding: 32px 0 24px; margin-bottom: 64px; background: var(--warm-bg); scroll-margin-top: 160px; } .nw-cf-header { padding: 0 16px 16px; } .nw-cf-title { font-size: 16px; font-weight: 700; color: var(--text); line-height: 1.5; margin-bottom: 6px; } .nw-cf-title::after { content: ''; display: block; width: 40px; height: 2px; background: var(--secondary); margin-top: 8px; border-radius: 1px; } .nw-cf-copy { font-size: 13px; color: var(--text-mid); line-height: 1.8; } .nw-cf-grid { display: grid; grid-template-rows: 1fr 1fr; grid-auto-flow: column; grid-auto-columns: 160px; gap: 8px; padding: 0 16px; overflow-x: auto; -webkit-overflow-scrolling: touch; } .nw-cf-grid::-webkit-scrollbar { display: none; } .nw-cf-card { background: var(--bg); border-radius: var(--radius); overflow: hidden; border: 1.5px solid var(--border-light); transition: all 0.2s; text-decoration: none; color: inherit; display: block; } .nw-cf-card:hover { border-color: var(--secondary); } .nw-cf-card-img { width: 100%; aspect-ratio: 1; background: #f0ece6; display: flex; align-items: center; justify-content: center; overflow: hidden; } .nw-cf-card-img img { width: 100%; height: 100%; object-fit: cover; } .nw-cf-card-info { padding: 8px 8px 6px; } .nw-cf-card-name { font-size: 10px; font-weight: 700; color: var(--text); line-height: 1.4; margin-bottom: 4px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; } .nw-cf-card-price { font-size: 14px; font-weight: 700; color: var(--navy); } .nw-cf-card-price small { font-size: 10px; font-weight: 400; color: var(--text-light); } .nw-cf-card-badge { display: inline-block; margin-top: 4px; font-size: 9px; font-weight: 600; color: var(--primary); border: 1px solid var(--primary); border-radius: 20px; padding: 2px 8px; } /* ============================================ Bottom CTA ============================================ */ .nw-bottom-cta { display: block; margin: 32px 16px 0; padding: 14px 16px; border-radius: var(--radius-pill); background: var(--primary); color: #fff !important; font-size: 14px; font-weight: 700; text-align: center; text-decoration: none; letter-spacing: 0.05em; transition: all 0.2s; } .nw-bottom-cta:hover { background: var(--primary-dark); } /* ============================================ Back FAB ============================================ */ .nw-back-fab { position: fixed; bottom: 84px; left: 16px; z-index: 100; display: flex; align-items: center; justify-content: center; width: 64px; height: 64px; border-radius: 50%; background: var(--primary); color: #fff !important; font-size: 11px; font-weight: 700; line-height: 1.3; text-align: center; text-decoration: none; box-shadow: 0 4px 16px rgba(0,0,0,0.2); transition: transform 0.2s, box-shadow 0.2s; } .nw-back-fab:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.25); background: var(--primary-dark); } /* ============================================ PC Responsive — min-width: 768px ============================================ */ @media (min-width: 768px) { body { display: flex; flex-direction: column; align-items: center; } .nw-header, .nw-hero, .nw-progress, .nw-set-nav, .nw-content { max-width: 1280px; width: 100%; } .nw-header { padding: 14px 40px; } .nw-header-title { font-size: 16px; } /* Hero */ .nw-hero { padding: 48px 60px 36px; } .nw-hero-badge { font-size: 11px; padding: 4px 14px; } .nw-hero-title { font-size: 24px; } .nw-hero-sub { font-size: 16px; } /* Benefit Bar */ .nw-benefit-section { max-width: 1280px; width: 100%; margin: 0 auto; } .nw-benefit-inner { justify-content: center; gap: 10px; padding: 0 40px; } /* Progress Bar */ .nw-progress { padding: 16px 40px 14px; top: 60px; } .nw-progress-label { font-size: 12px; } .nw-progress-step-label { font-size: 10px; } .nw-progress-step-label strong { font-size: 11px; } /* Navigation Pills */ .nw-set-nav { padding: 12px 32px; top: 112px; } .nw-set-pills { padding: 0 8px; } .nw-set-pill { font-size: 12px; padding: 5px 16px; } /* Content */ .nw-content { padding: 0 0 100px; } /* Set Section — カード型コンテナ(白) */ .nw-set-section { margin: 0 40px 64px; padding: 28px 24px 20px; background: var(--bg); border: 1px solid var(--border-light); border-radius: 16px; } .nw-set-header { margin: 0 0 8px; padding-left: 16px; } .nw-set-title { font-size: 20px; } .nw-set-copy { font-size: 14px; margin-top: 4px; } /* Carousel — セクションpadding内で表示 */ .nw-carousel-wrap { margin: 14px 0 0; } .nw-carousel::before, .nw-carousel::after { width: 0; } .nw-carousel-item { width: 200px; } .nw-carousel-card-info { padding: 8px 4px 6px; } .nw-carousel-card-name { font-size: 12px; } .nw-carousel-card-price { font-size: 15px; } .nw-carousel-card-price small { font-size: 10px; } /* Plus — 画像サイズに追従 */ .nw-plus { width: 36px; padding-top: calc(200px / 2 - 12px); } .nw-plus span { width: 24px; height: 24px; font-size: 14px; } /* Set Total Bar — カード内ベージュ背景 */ .nw-set-total { margin: 16px 0 0; padding: 14px 20px; background: var(--warm-bg); border: none; border-radius: 10px; } .nw-set-total-price { font-size: 14px; } .nw-set-total-price strong { font-size: 20px; } .nw-set-total-discount { font-size: 12px; } /* More Toggle + Grid */ .nw-more-toggle { margin: 16px 0 0; width: 100%; font-size: 13px; } .nw-more-grid { grid-template-columns: repeat(4, 1fr); padding: 16px 0 0; } .nw-g-card-name { font-size: 11px; } .nw-g-card-price { font-size: 15px; } /* Section CTA — 中央寄せ */ .nw-set-cta { margin: 16px auto 0; font-size: 13px; padding: 12px 20px; max-width: 400px; width: 100%; } /* Crowdfund / Grid Section — PC: カード型(ベージュ) */ .nw-cf-section { padding: 28px 24px 20px; margin: 0 40px 64px; background: var(--warm-bg); border-radius: 16px; } .nw-cf-header { padding: 0 0 20px; } .nw-cf-title { font-size: 20px; } .nw-cf-copy { font-size: 14px; } .nw-cf-grid { grid-auto-columns: 200px; gap: 12px; padding: 0; } .nw-cf-card-name { font-size: 11px; } .nw-cf-card-price { font-size: 15px; } .nw-cf-card-badge { font-size: 10px; padding: 3px 10px; } /* Bottom CTA */ .nw-bottom-cta { margin: 40px auto 0; max-width: 480px; padding: 16px 24px; font-size: 15px; } /* Back FAB — コンパクト維持 */ .nw-back-fab { bottom: 40px; } } /* ============================================ PC Wide — min-width: 1024px カルーセル+合計バー横並びグリッド ============================================ */ @media (min-width: 1024px) { .nw-hero { padding: 56px 80px 40px; } .nw-hero-title { font-size: 28px; } .nw-hero-sub { font-size: 18px; } /* Benefit Bar — PC: 中央寄せ、均等配置 */ .nw-benefit-section { padding: 20px 0; } .nw-benefit-inner { max-width: 960px; margin: 0 auto; justify-content: center; gap: 12px; padding: 0 40px; } .nw-benefit-item { min-width: 100px; padding: 10px 12px; } /* Set Section — グリッドレイアウト */ .nw-set-section { display: grid; grid-template-columns: 1fr 220px; gap: 0 20px; max-width: 960px; margin: 0 auto 64px; padding: 28px 28px 24px; } .nw-set-header { grid-column: 1 / -1; } .nw-carousel-wrap { grid-column: 1; } /* Plus — グリッド内で少し詰める */ .nw-plus { width: 32px; } /* Total Bar — 右カラム縦型カード、高さはカルーセルに合わせる */ .nw-set-total { grid-column: 2; margin: 14px 0 0; flex-direction: column; align-items: center; justify-content: center; text-align: center; align-self: stretch; gap: 10px; padding: 24px 12px; border-radius: 12px; } /* フル幅要素 */ .nw-more-toggle { grid-column: 1 / -1; width: 100%; } .nw-more-grid { grid-column: 1 / -1; grid-template-columns: repeat(5, 1fr); } .nw-set-cta { grid-column: 1 / -1; } .nw-cf-grid { grid-auto-columns: 220px; } } #id { visibility: visible !important; }

この記事をシェアする