/* Profile Links LP — モバイルファースト・最細フォント＋スタイリッシュ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@200;300;400;500&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Noto Sans JP','Hiragino Sans','Yu Gothic',sans-serif;
  background:#fafbfc;
  color:#222;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"palt";
  font-weight:300;
  line-height:1.85;
  letter-spacing:.02em;
}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
img{max-width:100%;display:block}

/* ===== Header ===== */
.hdr{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(20,30,50,.06);
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 20px;
}
.hdr-brand{font-weight:400;font-size:15px;letter-spacing:.06em}
.hdr-cta{background:#1f6feb;color:#fff;padding:8px 18px;border-radius:22px;font-size:13px;font-weight:500;letter-spacing:.04em;box-shadow:0 4px 12px rgba(31,111,235,.22)}

/* ===== Buttons ===== */
.btn{
  display:inline-block;padding:15px 24px;border-radius:14px;
  font-weight:400;font-size:15px;text-align:center;
  transition:transform .2s,box-shadow .2s,filter .2s;
  cursor:pointer;border:0;letter-spacing:.04em;
}
.btn-lg{padding:19px 26px;font-size:16px;display:block;margin:10px auto;max-width:380px}
.btn-primary{
  background:linear-gradient(135deg,#1f6feb 0%,#5b8ef5 100%);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 8px 22px rgba(31,111,235,.28);
}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 12px 28px rgba(31,111,235,.36)}
.btn-ghost{
  background:#fff;color:#1f6feb;
  border:1px solid rgba(31,111,235,.28);
  box-shadow:0 2px 8px rgba(20,30,50,.04);
}
.btn-ghost:hover{transform:translateY(-1px);background:#f5f9ff}
.btn-dark{
  background:linear-gradient(135deg,#1a2233 0%,#2a3548 100%);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 8px 22px rgba(15,25,45,.28);
}
.btn-dark:hover{transform:translateY(-2px);filter:brightness(1.1)}
.btn-dark-ghost{
  background:#fff;color:#1a2233;
  border:1px solid rgba(26,34,51,.22);
}
.btn-dark-ghost:hover{background:#f5f5f7;color:#1a2233}

/* DEMO番号付きボタン */
.btn-demo{display:inline-flex;flex-direction:column;align-items:center;gap:2px;line-height:1.2}
.btn-demo-no{font-size:10px;font-weight:500;letter-spacing:.16em;opacity:.85}
.btn-demo-label{font-size:16px;font-weight:300;letter-spacing:.08em}

.demo-pair{
  display:flex;flex-direction:column;gap:10px;
  max-width:380px;margin:10px auto 0;
}
@media(min-width:500px){.demo-pair{flex-direction:row;max-width:none;justify-content:center}}

/* ===== Hero ===== */
.hero{
  text-align:center;padding:54px 22px 60px;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%,rgba(91,142,245,.16) 0%,transparent 60%),
    linear-gradient(180deg,#fafbfc 0%,#f0f4fa 100%);
  position:relative;overflow:hidden;
}
.hero-tag{
  display:inline-block;background:rgba(31,111,235,.10);color:#1f6feb;
  font-size:11px;font-weight:400;padding:6px 16px;border-radius:20px;
  margin-bottom:22px;letter-spacing:.14em;
}
.hero-h{
  font-size:38px;font-weight:200;letter-spacing:.02em;line-height:1.5;
  margin-bottom:18px;color:#1a2233;
}
.hero-sub{font-size:15px;color:#5b6577;margin-bottom:30px;line-height:1.95;font-weight:300}
.hero-actions{display:flex;flex-direction:column;gap:12px;max-width:300px;margin:0 auto 36px}
@media(min-width:560px){.hero-actions{flex-direction:row;justify-content:center;max-width:none;flex-wrap:wrap}}

/* スマホモックアップ＋紙の名刺（SVG） */
.hero-mock{
  display:flex;justify-content:center;align-items:center;gap:6px;
  margin-top:24px;flex-wrap:nowrap;
}
.biz-card{
  width:200px;height:auto;flex:0 0 auto;
  transform:rotate(-4deg);
  transition:transform .3s ease;
}
.biz-card:hover{transform:rotate(-2deg) translateY(-4px)}
.biz-arrow{width:54px;height:42px;flex:0 0 auto;margin:0 -4px}
.biz-phone{width:120px;height:auto;flex:0 0 auto;transform:rotate(2deg);transition:transform .3s ease}
.biz-phone:hover{transform:rotate(0deg) translateY(-4px)}
.hero-cap{text-align:center;font-size:12px;color:#7a8597;margin-top:24px;letter-spacing:.10em;font-weight:300}

@media(min-width:500px){
  .biz-card{width:260px}
  .biz-phone{width:150px}
  .biz-arrow{width:70px;height:54px}
}

/* ===== Sections ===== */
.sec{padding:64px 22px;max-width:720px;margin:0 auto}
.sec-h{font-size:26px;font-weight:300;text-align:center;margin-bottom:16px;line-height:1.5;letter-spacing:.04em;color:#1a2233}
.sec-lead{font-size:14px;color:#5b6577;text-align:center;margin-bottom:34px;line-height:1.95;font-weight:300}

/* ===== Combo（紙＋デジタル） ===== */
.sec-combo{background:transparent}
.combo2{
  display:grid;grid-template-columns:1fr;gap:14px;
  position:relative;margin-bottom:32px;
}
@media(min-width:560px){
  .combo2{grid-template-columns:1fr 60px 1fr;align-items:stretch}
}
.combo2-card{
  border-radius:22px;padding:32px 24px;
  position:relative;overflow:hidden;
  transition:transform .25s ease;
}
.combo2-card:hover{transform:translateY(-3px)}
.combo2-paper{
  background:#fdfaf2;
  border:1px solid #ece1c4;
}
.combo2-digital{
  background:#f4f8fd;
  border:1px solid rgba(31,111,235,.18);
}
.c2-emoji{font-size:44px;line-height:1;margin-bottom:12px;opacity:.85}
.c2-label{
  display:inline-block;font-size:11px;font-weight:400;letter-spacing:.16em;
  padding:4px 12px;border-radius:14px;margin-bottom:14px;
}
.combo2-paper .c2-label{background:rgba(160,120,0,.10);color:#8b5f00}
.combo2-digital .c2-label{background:rgba(31,111,235,.10);color:#1f6feb}
.c2-headline{font-size:20px;font-weight:300;letter-spacing:.04em;margin-bottom:16px;line-height:1.5}
.combo2-paper .c2-headline{color:#5a3d00}
.combo2-digital .c2-headline{color:#0d3b8f}
.c2-items{display:flex;flex-direction:column;gap:10px}
.c2-items div{
  font-size:13px;font-weight:300;padding-left:18px;position:relative;
  color:rgba(0,0,0,.65);letter-spacing:.02em;
}
.combo2-paper .c2-items div::before{content:"";position:absolute;left:4px;top:9px;width:6px;height:6px;border-radius:50%;background:#a07000;opacity:.5}
.combo2-digital .c2-items div::before{content:"";position:absolute;left:4px;top:9px;width:6px;height:6px;border-radius:50%;background:#1f6feb;opacity:.5}

.combo2-link{
  display:flex;align-items:center;justify-content:center;
  position:relative;flex-direction:column;padding:0;
}
.c2-link-circle{
  width:50px;height:50px;border-radius:50%;
  background:linear-gradient(135deg,#1f6feb,#5b8ef5);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:400;letter-spacing:.06em;
  box-shadow:0 8px 18px rgba(31,111,235,.28);
  z-index:2;flex:0 0 auto;
}
.c2-link-line{display:none}
@media(min-width:560px){
  .c2-link-line{
    display:block;position:absolute;left:0;right:0;top:50%;
    height:1px;background:linear-gradient(90deg,rgba(232,216,168,.5),rgba(31,111,235,.5));
    z-index:1;
  }
}

.combo-final{
  text-align:center;font-size:15px;color:#333;
  line-height:2;font-weight:300;letter-spacing:.03em;
}
.combo-final b{color:#1f6feb;font-weight:400}

/* ===== あなたができること（横スクロールカルーセル）===== */
.sec-can{background:#f6f8fb;padding-left:0;padding-right:0;max-width:none}
.sec-can .sec-h{padding:0 22px}
.sec-can .sec-lead{padding:0 22px}
.can-hint{font-size:11px;color:#9aa4b5;letter-spacing:.16em;display:block;margin-top:4px}

.can-carousel{
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  cursor:grab;
  padding:6px 0 16px;
  user-select:none;-webkit-user-select:none;
}
.can-carousel::-webkit-scrollbar{display:none}
.can-carousel:active{cursor:grabbing}

.can-track{
  display:flex;gap:14px;
  padding:0 22px;
  width:max-content;
}

.can-panel{
  flex:0 0 calc((100vw - 80px) / 3);
  min-height:200px;
  background:#fff;
  border-radius:18px;
  padding:22px 14px;
  display:flex;flex-direction:column;
  align-items:center;text-align:center;
  gap:10px;
  border:1px solid rgba(20,30,50,.04);
  box-shadow:0 2px 8px rgba(20,30,50,.04),0 12px 24px rgba(20,30,50,.04);
  pointer-events:none; /* スワイプ妨害しない */
}
.cp-emoji{font-size:36px;line-height:1;opacity:.85;margin-top:6px}
.cp-t{font-size:13px;font-weight:400;letter-spacing:.04em;line-height:1.4;color:#1a2233}
.cp-d{font-size:11px;font-weight:300;color:#5b6577;line-height:1.65;letter-spacing:.02em}

@media(min-width:560px){
  .can-panel{flex:0 0 200px;min-height:240px}
  .cp-emoji{font-size:42px}
  .cp-t{font-size:14px}
  .cp-d{font-size:12px}
}

/* ===== Pricing ===== */
.sec-price{background:#fff}
.pp{display:flex;flex-direction:column;gap:16px;margin-bottom:30px}
@media(min-width:600px){.pp{flex-direction:row}}
.pp-card{
  flex:1;background:#fff;border-radius:22px;padding:30px 24px;
  border:1px solid rgba(20,30,50,.06);
  box-shadow:0 4px 14px rgba(20,30,50,.04);
  position:relative;text-align:center;
}
.pp-on{
  border-color:rgba(31,111,235,.5);border-width:1.5px;
  box-shadow:0 6px 20px rgba(31,111,235,.12),0 16px 40px rgba(20,30,50,.06);
  transform:scale(1.02);
}
.pp-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#1f6feb,#5b8ef5);color:#fff;
  padding:5px 18px;border-radius:20px;font-size:11px;font-weight:400;
  letter-spacing:.14em;box-shadow:0 4px 10px rgba(31,111,235,.24);white-space:nowrap;
}
.pp-label{font-size:12px;font-weight:400;color:#888;margin-bottom:10px;letter-spacing:.16em}
.pp-price{
  font-size:44px;font-weight:200;color:#1a2233;
  margin-bottom:20px;line-height:1;letter-spacing:.02em;
}
.pp-yen{font-size:22px;margin-right:2px;font-weight:300}
.pp-tax{font-size:12px;color:#888;font-weight:300;margin-left:6px;letter-spacing:.06em}
.pp-feats{text-align:left;display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.pp-feats li{padding-left:22px;position:relative;font-size:13px;line-height:1.7;color:#444;font-weight:300}
.pp-feats li::before{content:"✓";position:absolute;left:0;top:1px;color:#28a745;font-weight:400;font-size:14px}
.pp-note{font-size:11px;color:#9aa4b5;border-top:1px dashed #eef1f5;padding-top:12px;font-weight:300;letter-spacing:.04em}

.pp-design{
  background:#fafafa;
  border:1px dashed #c8a8e8;
  border-radius:18px;padding:22px;
  display:flex;flex-direction:column;gap:18px;
}
.ppd-row{display:flex;gap:14px;align-items:flex-start}
.ppd-row + .ppd-row{padding-top:18px;border-top:1px dashed rgba(200,168,232,.5)}
.ppd-icon{font-size:32px;flex:0 0 auto;opacity:.8}
.ppd-t{font-weight:400;font-size:15px;color:#6a3aa0;margin-bottom:6px;letter-spacing:.04em}
.ppd-d{font-size:13px;color:#555;line-height:1.85;font-weight:300}

/* ===== Flow ===== */
.sec-flow{background:#f6f8fb}
.flow{display:flex;flex-direction:column;gap:12px;max-width:520px;margin:0 auto}
.flow li{
  background:#fff;border-radius:16px;padding:18px 18px;
  display:flex;gap:16px;align-items:flex-start;
  border:1px solid rgba(20,30,50,.04);
  box-shadow:0 2px 6px rgba(20,30,50,.03);
}
.fl-no{
  flex:0 0 auto;width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,#1f6feb,#5b8ef5);color:#fff;
  font-weight:400;font-size:14px;letter-spacing:.04em;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(31,111,235,.24);
}
.flow b{display:block;font-size:15px;font-weight:400;margin-bottom:4px;letter-spacing:.04em}
.flow span{display:block;font-size:13px;color:#5b6577;line-height:1.85;font-weight:300}

/* ===== Who ===== */
.sec-who{background:#fff}
.who{display:flex;flex-direction:column;gap:8px;max-width:480px;margin:0 auto}
.who li{
  background:#f6f8fb;border-radius:14px;padding:16px 18px;
  font-size:14px;font-weight:300;letter-spacing:.02em;
  border:1px solid rgba(20,30,50,.04);
}

/* ===== Contact ===== */
.sec-contact{
  background:
    radial-gradient(ellipse 80% 60% at 50% 100%,rgba(91,142,245,.16) 0%,transparent 60%),
    linear-gradient(180deg,#f0f4fa 0%,#fafbfc 100%);
  text-align:center;padding-bottom:80px;
}
.contact-note{font-size:12px;color:#7a8597;margin-top:26px;line-height:1.95;font-weight:300;letter-spacing:.04em}

/* ===== Footer ===== */
.ftr{
  background:#1a2233;color:#cdd6e2;
  text-align:center;padding:36px 22px 30px;
}
.ftr-brand{font-size:17px;font-weight:300;color:#fff;margin-bottom:16px;letter-spacing:.08em}
.ftr-links{display:flex;justify-content:center;gap:22px;margin-bottom:20px;flex-wrap:wrap}
.ftr-links a{color:#5b8ef5;font-weight:300;font-size:13px;letter-spacing:.04em}
.ftr-copy{font-size:11px;color:#5b6577;letter-spacing:.10em;font-weight:300}

/* ===== Wider ===== */
@media(min-width:760px){
  .hero-h{font-size:48px;font-weight:200}
  .sec-h{font-size:30px}
}
