/* ===== REBODHIV — スマホ枠 + 横メニュー レイアウト ===== */
:root{
  --green:#004b3c;
  --green-deep:#00352b;
  --green-light:#005a47;
  --cream:#fafdfb;
  --bg:#e7efea;
  --text:#1f2d29;
  --muted:#6b7d77;
  --line:rgba(0,75,60,.14);
  --font-en:'Jost','futura-pt',sans-serif;
  --font-jp:'Noto Sans JP',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
body{font-family:var(--font-jp);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

/* ===== レイアウト（PC：左メニュー / 中央スマホ枠 / 右縦書き）===== */
.layout{display:flex;justify-content:center;align-items:flex-start;max-width:1180px;margin:0 auto;min-height:100vh}

.side-left{position:sticky;top:0;height:100vh;width:250px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;padding:48px 40px}
.side-left .logo img{width:152px}
.side-left .tagline{font-family:var(--font-en);font-size:10px;letter-spacing:.2em;color:var(--muted);margin:16px 0 52px;line-height:1.8}
.menu li{margin-bottom:24px}
.menu a{font-family:var(--font-en);font-size:14px;letter-spacing:.18em;color:var(--green);position:relative;display:inline-block}
.menu a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--green);transition:width .35s ease}
.menu a:hover::after{width:100%}
.side-left .sns{display:flex;gap:16px;margin-top:52px}
.side-left .sns a{font-family:var(--font-en);font-size:10px;letter-spacing:.14em;color:var(--muted)}
.side-left .sns a:hover{color:var(--green)}

.side-right{position:sticky;top:0;height:100vh;width:190px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:48px 0}
.side-right .vertical{writing-mode:vertical-rl;font-family:var(--font-en);font-size:10px;letter-spacing:.32em;color:var(--muted)}

/* ===== スマホ枠 ===== */
.phone{width:440px;max-width:100%;flex-shrink:0;background:var(--cream);box-shadow:0 30px 90px rgba(0,53,43,.18);min-height:100vh;overflow:hidden;position:relative}

/* ===== HERO ===== */
.hero{background:linear-gradient(165deg,var(--green-light),var(--green-deep));color:#fff;min-height:92vh;display:flex;flex-direction:column;justify-content:center;padding:56px 36px;position:relative;overflow:hidden}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0}
.hero > *:not(#hero-canvas):not(.hero-brand){position:relative;z-index:1}
.hero-brand{position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:165%;max-width:none;opacity:.12;pointer-events:none;line-height:0}
.hero-brand img{width:100%;display:block}
.hero-kicker{font-family:var(--font-en);font-size:9px;letter-spacing:.26em;color:rgba(255,255,255,.68);display:block;margin-bottom:26px}
.hero h1{font-size:31px;line-height:1.55;font-weight:500;margin-bottom:22px;letter-spacing:.02em}
.hero h1 .b{font-weight:700}
.hero-sub{font-size:12.5px;line-height:2.1;color:rgba(255,255,255,.8);margin-bottom:38px}
.hero-actions{display:flex;flex-direction:column;gap:16px;align-items:flex-start;position:relative;z-index:2}
.btn-primary{background:#fff;color:var(--green);padding:15px 32px;border-radius:40px;font-family:var(--font-jp);font-size:13px;font-weight:500;transition:transform .2s,box-shadow .2s}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.18)}
.hero-link{font-size:12px;letter-spacing:.05em;color:rgba(255,255,255,.85)}
.hero-link:hover{color:#fff}

/* ===== セクション共通 ===== */
.sec{padding:68px 36px}
.sec-label{font-family:var(--font-en);font-size:44px;font-weight:200;color:var(--green);letter-spacing:.02em;line-height:1;margin-bottom:10px}
.sec-title{font-size:22px;font-weight:600;line-height:1.6;margin-bottom:26px;color:var(--green)}

.about p:not(.sec-label){font-size:13.5px;line-height:2.15;color:var(--text);margin-bottom:18px}
.about .ph-img{margin-top:30px;border-radius:12px}

/* ===== SERVICE（できること）===== */
.service-list{margin-top:6px}
.service-item{display:flex;gap:20px;padding:26px 0;border-bottom:1px solid var(--line)}
.service-item:last-child{border-bottom:none;padding-bottom:0}
.service-item:first-child{padding-top:6px}
.service-num{font-family:var(--font-en);font-size:22px;font-weight:300;color:var(--green);letter-spacing:.04em;line-height:1.4;flex-shrink:0;width:34px}
.service-name{font-size:16px;font-weight:600;color:var(--green);margin-bottom:10px;letter-spacing:.02em}
.service-desc{font-size:13px;line-height:2.05;color:var(--text)}

/* ===== WORKS（丸枠）===== */
.works-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px 24px;margin-top:10px}
.work-item{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.work-name{font-size:12px;letter-spacing:.04em;color:var(--green);font-weight:500;line-height:1.5}
.work-circle{width:100%;aspect-ratio:1/1;border-radius:50%;overflow:hidden;background:#eef3f1;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(0,53,43,.13);transition:transform .35s ease,box-shadow .35s ease}
.work-item:hover .work-circle{transform:translateY(-5px) scale(1.03);box-shadow:0 16px 34px rgba(0,53,43,.2)}
.work-circle img{width:100%;height:100%;object-fit:cover}
.work-circle-ph{font-family:var(--font-en);font-size:32px;font-weight:300;color:var(--green);background:linear-gradient(160deg,#dce9e4,#eef3f1)}
.works-more{display:inline-block;margin-top:36px;font-family:var(--font-en);font-size:12px;letter-spacing:.14em;color:var(--green);border-bottom:1px solid var(--green);padding-bottom:3px}

/* ===== CONTACT ===== */
.contact{background:#fff}
.contact-lead{font-size:13px;line-height:2;color:var(--muted);margin-bottom:30px}
.form-group{margin-bottom:22px}
.form-group label{display:block;font-size:12px;color:var(--muted);margin-bottom:8px;letter-spacing:.04em}
.form-group label span{color:#c0563a;margin-left:2px}
.form-group input,.form-group textarea{width:100%;border:none;border-bottom:1px solid var(--line);background:transparent;padding:9px 2px;font-family:var(--font-jp);font-size:14px;color:var(--text);transition:border-color .25s}
.form-group input::placeholder,.form-group textarea::placeholder{color:#b8c4bf}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--green)}
.form-group textarea{resize:vertical}
.form-submit{width:100%;background:var(--green);color:#fff;border:none;padding:17px;border-radius:40px;font-family:var(--font-jp);font-size:14px;letter-spacing:.04em;margin-top:10px;cursor:pointer;transition:background .25s}
.form-submit:hover{background:var(--green-deep)}

/* ===== スマホ枠フッター ===== */
.ph-footer{background:var(--green-deep);color:rgba(255,255,255,.55);text-align:center;padding:30px;font-family:var(--font-en);font-size:10px;letter-spacing:.22em}
.ph-footer img{width:108px;margin:0 auto 16px;opacity:.9}

/* ===== WORKS 詳細ページ ===== */
.work-hero{padding:50px 36px 38px;background:linear-gradient(165deg,var(--green-light),var(--green-deep));color:#fff}
.back-link{display:inline-block;font-family:var(--font-en);font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.78);margin-bottom:26px}
.back-link:hover{color:#fff}
.wh-label{font-family:var(--font-en);font-size:10px;letter-spacing:.24em;color:rgba(255,255,255,.62);display:block;margin-bottom:12px}
.wh-title{font-size:30px;font-weight:600;line-height:1.3;margin-bottom:8px}
.wh-sub{font-size:13px;color:rgba(255,255,255,.82);margin-bottom:30px}
.wh-main{border-radius:16px;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.22)}
.work-detail{padding:60px 36px}
.work-detail p{font-size:13.5px;line-height:2.15;color:var(--text);margin-bottom:18px}
.wd-meta{display:flex;flex-wrap:wrap;gap:9px;margin:26px 0 10px}
.wd-tag{font-family:var(--font-en);font-size:10px;letter-spacing:.08em;color:var(--green);border:1px solid var(--line);border-radius:30px;padding:6px 14px}
.wd-gallery{display:flex;flex-direction:column;gap:18px;margin-top:30px}
.wd-gallery img{border-radius:12px;width:100%;box-shadow:0 10px 28px rgba(0,53,43,.1)}
.work-cta{padding:54px 36px;text-align:center;background:#fff;border-top:1px solid var(--line)}
.work-cta p{font-size:14px;line-height:1.9;color:var(--green);font-weight:500;margin-bottom:24px}
.wd-link{display:inline-block;margin-top:4px;font-family:var(--font-en);font-size:12px;letter-spacing:.04em;color:var(--green);border-bottom:1px solid var(--green);padding-bottom:2px}
.wd-scope{margin-top:26px}
.wd-scope-title{font-family:var(--font-en);font-size:10px;letter-spacing:.16em;color:var(--muted);margin-bottom:8px}
.wd-scope li{font-size:13px;color:var(--text);padding:9px 0;border-bottom:1px solid var(--line)}

/* ===== モバイル用トップバー & ドロワー（PCでは非表示）===== */
.m-topbar{display:none}
.drawer{display:none}

/* ===== レスポンシブ ===== */
@media(max-width:980px){
  .side-left,.side-right{display:none}
  .layout{display:block;max-width:100%}
  .phone{width:100%;box-shadow:none;min-height:auto}

  .m-topbar{display:flex;justify-content:space-between;align-items:center;padding:15px 22px;position:fixed;top:0;left:0;right:0;background:transparent;z-index:30;transition:background .35s ease}
  .m-topbar.scrolled{background:var(--green)}
  .m-topbar .m-logo img{width:118px}
  .m-burger{width:30px;height:20px;position:relative;background:none;border:none;cursor:pointer}
  .m-burger span{display:block;position:absolute;left:0;width:100%;height:2px;background:#fff;border-radius:2px}
  .m-burger span:nth-child(1){top:3px}
  .m-burger span:nth-child(2){bottom:3px}

  .drawer{display:flex;position:fixed;inset:0;background:var(--green);flex-direction:column;justify-content:center;padding:44px;z-index:50;transform:translateX(100%);transition:transform .42s cubic-bezier(.7,0,.2,1)}
  .drawer.open{transform:translateX(0)}
  .drawer .d-logo img{width:168px;margin-bottom:44px}
  .drawer-menu li{border-bottom:1px solid rgba(255,255,255,.18)}
  .drawer-menu a{display:block;color:#fff;font-family:var(--font-en);font-size:18px;letter-spacing:.14em;padding:20px 2px}
  .drawer-sns{display:flex;gap:18px;margin-top:40px}
  .drawer-sns a{color:rgba(255,255,255,.8);font-family:var(--font-en);font-size:11px;letter-spacing:.14em}
  .drawer-close{position:absolute;top:18px;right:22px;width:30px;height:30px;background:none;border:none;cursor:pointer}
  .drawer-close::before,.drawer-close::after{content:'';position:absolute;top:14px;left:3px;width:24px;height:2px;background:#fff;border-radius:2px}
  .drawer-close::before{transform:rotate(45deg)}
  .drawer-close::after{transform:rotate(-45deg)}

  .hero{min-height:86vh}
}
@media(max-width:480px){
  .hero h1{font-size:27px}
  .sec{padding:56px 28px}
  .hero{padding:48px 28px}
}

/* ===== SERVICE animated icons ===== */
.service-item{display:block;padding:36px 0;text-align:left}
.service-icon{display:grid;place-items:center;width:88px;height:88px;margin:0 auto 20px;color:var(--green)}
.service-icon svg{width:88px;height:88px;overflow:visible;display:block}
.service-icon .fill{fill:currentColor}
.service-num{display:block;width:auto;font-family:var(--font-en);font-size:15px;font-weight:500;letter-spacing:.12em;color:var(--green);opacity:.8;line-height:1;margin-bottom:10px}
.service-name{font-size:20px;margin-bottom:12px}

/* 01 動画制作 — 再生マーク＋プログレス */
.ic-play{transform-box:fill-box;transform-origin:center;animation:icPlay 2.4s ease-in-out infinite}
@keyframes icPlay{0%,100%{transform:scale(1);opacity:.92}50%{transform:scale(1.13);opacity:1}}
.ic-prog{transform-box:fill-box;transform-origin:left center;animation:icProg 2.4s ease-in-out infinite}
@keyframes icProg{0%{transform:scaleX(0);opacity:1}68%{transform:scaleX(1);opacity:1}100%{transform:scaleX(1);opacity:0}}

/* 02 Meta広告 — 伸びる棒グラフ */
.ic-bar{transform-box:fill-box;transform-origin:bottom;animation:icBar 2.2s ease-in-out infinite}
.ic-bar.b2{animation-delay:.16s}
.ic-bar.b3{animation-delay:.32s}
@keyframes icBar{0%,100%{transform:scaleY(.34)}46%{transform:scaleY(1)}}

/* 03 LP制作 — 組み上がるブロック＋スクロール */
.ic-line{transform-box:fill-box;animation:icLine 2.8s ease-in-out infinite}
.ic-line.l2{animation-delay:.2s}
.ic-line.l3{animation-delay:.4s}
.ic-line.l4{animation-delay:.6s}
@keyframes icLine{0%{opacity:0;transform:translateY(3px)}22%,82%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(-2px)}}
.ic-scroll{transform-box:fill-box;animation:icScroll 2.8s ease-in-out infinite}
@keyframes icScroll{0%,100%{transform:translateY(0);opacity:.35}50%{transform:translateY(11px);opacity:1}}

/* 04 SNS発信の相談 — 広がる共鳴の波 */
.ic-wave{transform-box:fill-box;transform-origin:center;animation:icWave 2.6s ease-out infinite}
.ic-wave.w2{animation-delay:.85s}
.ic-wave.w3{animation-delay:1.7s}
@keyframes icWave{0%{transform:scale(.18);opacity:0}18%{opacity:.85}100%{transform:scale(1);opacity:0}}
.ic-core{transform-box:fill-box;transform-origin:center;animation:icCore 2.6s ease-in-out infinite}
@keyframes icCore{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}

/* ===== ABOUT: TikTok profile block ===== */
.about-sns{margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.about-sns-head{display:flex;align-items:center;gap:18px}
.about-sns-avatar{width:84px;height:84px;border-radius:50%;object-fit:cover;flex-shrink:0}
.about-sns-id{display:flex;flex-direction:column;gap:5px}
.about-sns-name{font-size:21px;font-weight:600;color:var(--green);letter-spacing:.02em}
.about-sns-handle{font-family:var(--font-en);font-size:13px;color:var(--muted);letter-spacing:.04em}
.about-sns-desc{margin-top:16px;font-size:12.5px;line-height:1.95;color:var(--muted)}
.about-sns-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:18px;padding:15px 24px;border-radius:999px;background:var(--green);color:#fff;font-size:14px;font-weight:600;letter-spacing:.04em;text-decoration:none;transition:background .3s ease,transform .3s ease}
.about-sns-btn:hover{background:var(--green-deep);transform:translateY(-2px)}
