/* engine.css — uzuzスワイプ共通エンジン（構造・装飾・部品）。色は skin の var() 参照。触らない。 */
/* ============================================================
   style.css — uzuz.jp 風スワイプ（モバイル特化）
   白基調・グリーン・幾何学フラット図形・特大ボールド見出し・カラーブロック・数字バッジ
   骨格（deck/panel/snap）は共通、装飾は“ぼかし”ではなく“幾何学フラット”。
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;height:100%;-webkit-text-size-adjust:100%}
body{background:var(--paper);color:var(--ink);font-family:var(--body);overflow:hidden;
  -webkit-font-smoothing:antialiased;font-feature-settings:"palt"}
img{display:block;max-width:100%}a{color:inherit;text-decoration:none}

.app{position:relative;max-width:var(--maxw);height:100dvh;margin-inline:auto;overflow:hidden;background:var(--paper)}

/* 幾何学フラット装飾（固定・奥） */
.geo{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.geo i{position:absolute;display:block}
.geo .ring{width:240px;height:240px;border:2px solid var(--green);border-radius:50%;top:-70px;right:-70px;opacity:.5;animation:spin 40s linear infinite}
.geo .ringy{width:140px;height:140px;border:2px dashed var(--yellow);border-radius:50%;bottom:12%;left:-50px;opacity:.7;animation:spin 30s linear infinite reverse}
.geo .dotgrid{width:120px;height:120px;bottom:18%;right:18px;opacity:.5;
  background-image:radial-gradient(var(--green) 2px,transparent 2px);background-size:16px 16px}
.geo .blobY{width:70px;height:70px;background:var(--yellow);border-radius:42% 58% 60% 40%/45% 45% 55% 55%;top:16%;left:20px;opacity:.9;animation:float 7s ease-in-out infinite}
.geo .blobG{width:46px;height:46px;background:var(--green);border-radius:50%;top:60%;right:30px;opacity:.85;animation:float 6s ease-in-out infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

/* デッキ */
.deck{position:relative;z-index:1;height:100dvh;overflow-y:scroll;scroll-snap-type:y mandatory;scroll-behavior:smooth;scrollbar-width:none}
.deck::-webkit-scrollbar{display:none}
.panel{height:100dvh;scroll-snap-align:start;scroll-snap-stop:always;position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 26px;gap:16px}
.panel>*{flex:0 0 auto}
.panel--mint{background:var(--mint)}
/* グラデ背景＋ソフトな光（4枚目などデザイン強化面） */
.panel--grad{background:linear-gradient(165deg,#eafaf1 0%,#d5f0e2 55%,#bfe9d4 100%);padding:30px 26px;gap:10px}
.panel--grad .ulist{gap:8px}
.panel--grad .ulist li{padding-top:12px;padding-bottom:12px}
.panel--grad .sub2{font-size:.84rem;line-height:1.55}
.panel--grad::before{content:"";position:absolute;z-index:0;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(27,191,115,.4),transparent 70%);top:-50px;right:-70px;filter:blur(6px)}
.panel--grad::after{content:"";position:absolute;z-index:0;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,210,63,.5),transparent 70%);bottom:-40px;left:-60px;filter:blur(8px)}
.panel--grad>*{position:relative;z-index:1}
/* 1日の流れの写真 */
.day-photo{width:100%;max-width:360px;aspect-ratio:16/9;border-radius:16px;overflow:hidden;border:3px solid var(--ink);margin-top:4px}
.day-photo img{width:100%;height:100%;object-fit:cover}
.panel--green{background:var(--green);color:var(--white)}
.panel--green .kick{color:var(--white)}
.panel--green .kick::before{background:var(--white)}
.panel--form{justify-content:flex-start;overflow-y:auto;padding-top:8vh;padding-bottom:104px}

/* 追従ボタン（TOP / エントリー） */
.fab{position:fixed;bottom:0;left:50%;transform:translateX(-50%);z-index:20;width:100%;max-width:var(--maxw);
  display:grid;grid-template-columns:1fr 2fr;gap:9px;padding:10px 12px calc(12px + env(safe-area-inset-bottom))}
.fab a{display:flex;align-items:center;justify-content:center;gap:.35em;cursor:pointer;
  font-family:var(--disp);font-weight:900;font-size:1rem;padding:14px 0;border-radius:999px;
  border:2.5px solid var(--ink);box-shadow:3px 3px 0 var(--ink);transition:transform .12s,box-shadow .12s}
.fab a:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.fab__top{background:var(--white);color:var(--ink)}
.fab__top svg{width:17px;height:17px;stroke:var(--ink);fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.fab__entry{background:var(--green);color:#fff}

/* テキスト */
.kick{display:inline-flex;align-items:center;gap:.6em;font-family:var(--disp);font-weight:900;
  letter-spacing:.12em;font-size:.78rem;color:var(--green-d)}
.kick::before{content:"";width:26px;height:3px;border-radius:3px;background:var(--green)}
.h{font-family:var(--disp);font-weight:900;line-height:1.28;margin:0;letter-spacing:-.01em;
  font-size:clamp(1.8rem,8.5vw,2.6rem)}
.h--big{font-size:clamp(2.4rem,12vw,3.6rem);line-height:1.16}
.h .g{color:var(--green)}
.h .mark{background:linear-gradient(transparent 58%, var(--yellow) 58%);padding:0 .05em}
.sub{color:var(--muted);font-size:clamp(.9rem,3.6vw,1rem);line-height:1.85;max-width:28ch;margin:0 auto}
.panel--green .sub{color:rgba(255,255,255,.92)}

/* 英字大見出し（uzuzっぽい） */
.big-en{font-family:var(--disp);font-weight:900;font-size:clamp(2.6rem,15vw,4.4rem);line-height:.95;letter-spacing:-.02em}
.big-en .o{-webkit-text-stroke:2px var(--ink);color:transparent}

/* 表紙 */
.cover__photo{width:100%;max-width:420px;aspect-ratio:16/10;border-radius:var(--r);overflow:hidden;border:3px solid var(--ink);
  box-shadow:6px 6px 0 var(--ink)}
.cover__photo img{width:100%;height:100%;object-fit:cover}
/* 要約パネルの写真 */
.sum-photo{width:100%;max-width:340px;aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink)}
.sum-photo img{width:100%;height:100%;object-fit:cover}
/* 箇条書きリスト（囲いなし・パネル4） */
.blist{display:grid;gap:13px;width:100%;max-width:340px;text-align:left;margin:0;padding:0}
.blist li{list-style:none;position:relative;padding-left:30px;font-size:1.06rem;font-weight:700;line-height:1.55}
.blist li::before{content:"";position:absolute;left:3px;top:.5em;width:14px;height:14px;border-radius:50%;background:var(--green);border:2px solid var(--ink)}
/* 仕事内容：番号なし・詰める */
.cards--work{gap:9px}
.cards--work .ucard{padding:13px 16px}
.cards--work .ucard b{font-size:.98rem;margin-bottom:2px}
.cards--work .ucard span{font-size:.82rem;line-height:1.5}
.badge-float{position:absolute;background:var(--yellow);color:var(--ink);font-family:var(--disp);font-weight:900;
  border-radius:50%;width:84px;height:84px;display:grid;place-content:center;text-align:center;font-size:.82rem;line-height:1.2;
  transform:rotate(-10deg);box-shadow:0 10px 22px -8px rgba(16,40,46,.4)}

/* カード（フラット・太枠） */
.cards{display:grid;gap:12px;width:100%;max-width:380px}
.ucard{background:var(--white);border:2px solid var(--ink);border-radius:var(--r);padding:16px 18px;text-align:left;
  display:flex;gap:14px;align-items:center;box-shadow:5px 5px 0 var(--ink)}
.ucard .no{flex:0 0 auto;width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;
  display:grid;place-content:center;font-family:var(--disp);font-weight:900}
.ucard b{display:block;font-family:var(--disp);font-weight:900;font-size:1.02rem}
.ucard span{color:var(--muted);font-size:.82rem}
/* 黄マーカー強調 */
.mk{background:linear-gradient(transparent 58%, var(--yellow) 0);font-weight:700;padding:0 .08em}

/* === 強み：番号バッジ・カラーアクセントのカード === */
.cards--str{gap:13px;max-width:370px}
.scard{position:relative;display:flex;align-items:center;gap:15px;background:var(--white);
  border:2.5px solid var(--ink);border-radius:18px;padding:16px 18px;box-shadow:5px 5px 0 var(--ink);text-align:left}
.scard__no{flex:0 0 auto;width:48px;height:48px;border-radius:14px;display:grid;place-content:center;
  font-family:var(--disp);font-weight:900;font-size:1.55rem;color:#fff;background:var(--green);
  border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink)}
.scard:nth-child(2) .scard__no{background:var(--yellow);color:var(--ink)}
.scard:nth-child(3) .scard__no{background:var(--ink)}
.scard__b b{display:block;font-family:var(--disp);font-weight:900;font-size:1.08rem;line-height:1.3;margin-bottom:2px}
.scard__b span{color:var(--muted);font-size:.84rem;line-height:1.5}

/* === 仕事内容：左カラーバーのコンパクトカード === */
.cards--work2{gap:10px;max-width:380px}
.wcard{position:relative;background:var(--white);border:2px solid var(--ink);border-radius:14px;
  padding:12px 15px 12px 19px;box-shadow:4px 4px 0 var(--ink);text-align:left;overflow:hidden}
.wcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:7px;background:var(--green)}
.wcard:nth-child(2)::before{background:var(--yellow)}
.wcard:nth-child(3)::before{background:var(--green-d)}
.wcard:nth-child(4)::before{background:var(--ink)}
.wcard b{display:block;font-family:var(--disp);font-weight:900;font-size:.98rem;margin-bottom:2px}
.wcard span{color:var(--muted);font-size:.82rem;line-height:1.5}

/* === パネル4：こんな人におすすめ（カード＋強い締め） === */
.fitlist{display:grid;gap:11px;width:100%;max-width:360px}
.fit{display:flex;align-items:center;gap:13px;background:var(--white);border:2.5px solid var(--ink);
  border-radius:16px;padding:14px 16px;box-shadow:4px 4px 0 var(--ink);text-align:left}
.fit__ic{flex:0 0 auto;width:36px;height:36px;border-radius:50%;background:var(--green);
  display:grid;place-content:center;border:2px solid var(--ink)}
.fit__ic svg{width:19px;height:19px;stroke:#fff;fill:none;stroke-width:3.4;stroke-linecap:round;stroke-linejoin:round}
.fit:nth-child(2) .fit__ic{background:var(--yellow)}
.fit:nth-child(2) .fit__ic svg{stroke:var(--ink)}
.fit b{font-family:var(--disp);font-weight:900;font-size:.98rem;line-height:1.32;letter-spacing:-.01em}
.closer{width:100%;max-width:372px;background:var(--ink);color:#fff;border-radius:20px;
  padding:22px 18px;box-shadow:6px 6px 0 var(--green);margin-top:6px}
.closer p{margin:0;font-family:var(--disp);font-weight:900;font-size:1.04rem;line-height:1.7;text-align:center;letter-spacing:-.01em}
.closer .yo{color:var(--yellow)}
.panel--grad{padding-block:24px}

/* 数字バッジ（uzuz名物） */
.badges{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:360px}
.bdg{display:grid;justify-items:center;gap:4px}
.bdg__c{width:118px;height:118px;border-radius:50%;display:grid;place-content:center;
  border:3px solid var(--ink);background:var(--white)}
.bdg:nth-child(2) .bdg__c{background:var(--mint)}
.bdg:nth-child(3) .bdg__c{background:var(--yellow)}
.bdg:nth-child(4) .bdg__c{background:var(--green);color:#fff}
.bdg__n{font-family:var(--disp);font-weight:900;font-size:2.1rem;line-height:1}
.bdg__n small{font-size:.42em}
.bdg__l{font-size:.8rem;font-weight:700}

/* リスト */
.ulist{display:grid;gap:10px;width:100%;max-width:380px;text-align:left}
.ulist li{list-style:none;background:var(--white);border:2px solid var(--ink);border-radius:12px;
  padding:13px 16px 13px 44px;position:relative;font-weight:700;font-size:.95rem}
.ulist li::before{content:"";position:absolute;left:16px;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:var(--green)}

/* 丸写真（インタビュー的） */
.face{width:120px;height:120px;border-radius:50%;object-fit:cover;border:5px solid var(--white);box-shadow:0 14px 30px -14px rgba(16,40,46,.5)}

/* ボタン */
.pill{display:inline-flex;align-items:center;gap:.5em;font-family:var(--disp);font-weight:900;font-size:1.15rem;
  padding:16px 38px;border-radius:999px;background:var(--ink);color:#fff;box-shadow:6px 6px 0 var(--green);transition:transform .15s}
.pill:active{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--green)}
.panel--green .pill{background:var(--white);color:var(--ink);box-shadow:6px 6px 0 var(--navy)}

/* ドット・ナビ */
.dots{position:fixed;top:50%;right:14px;transform:translateY(-50%);z-index:5;display:grid;gap:9px}
.dots button{width:9px;height:9px;border-radius:50%;border:2px solid var(--ink);padding:0;cursor:pointer;background:transparent;transition:all .3s}
.dots button.on{background:var(--yellow);border-color:var(--ink);height:22px;border-radius:6px}

/* 要約チップ */
.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:360px}
.chip{font-family:var(--disp);font-weight:900;font-size:.82rem;padding:.5em 1em;border-radius:999px;
  border:2px solid var(--ink);background:var(--white)}
.chip--g{background:var(--green);color:#fff;border-color:var(--green)}
.chip--y{background:var(--yellow)}
.lead{font-size:clamp(.95rem,4vw,1.08rem);font-weight:700;line-height:1.9;max-width:24ch;margin:0 auto}

/* 会社紹介（概要） */
.ovw{width:100%;max-width:380px;display:grid;gap:14px}
.ovw__fig{border-radius:var(--r);overflow:hidden;border:3px solid var(--ink);aspect-ratio:16/10}
.ovw__fig img{width:100%;height:100%;object-fit:cover}
.ovw__t{text-align:left;font-size:.92rem;line-height:1.9;color:var(--ink)}

/* 1日の流れ（タイムライン・フラット） */
.tl{display:grid;gap:12px;width:100%;max-width:360px;text-align:left;position:relative;padding-left:22px}
.tl::before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--green)}
.tl li{list-style:none;position:relative}
.tl li::before{content:"";position:absolute;left:-22px;top:.45em;width:12px;height:12px;border-radius:50%;background:var(--green);border:2px solid var(--paper)}
.tl time{font-family:var(--disp);font-weight:900;color:var(--green-d);margin-right:.6em}
.tl b{font-weight:700}

/* 応募フォーム（uzuzフラット） */
.uform{width:100%;max-width:360px;display:grid;gap:12px;text-align:left}
.uform .f label{display:block;font-family:var(--disp);font-weight:900;font-size:.82rem;margin-bottom:.3em}
.uform .f input,.uform .f textarea{width:100%;padding:13px;border:2px solid var(--ink);border-radius:12px;font:inherit;background:var(--white);resize:vertical}
.uform .f input:focus,.uform .f textarea:focus{outline:3px solid var(--green);outline-offset:0;border-color:var(--green)}
.uform .cs{display:flex;gap:.5em;align-items:flex-start;font-size:.8rem;color:var(--muted)}
.uform button{font-family:var(--disp);font-weight:900;font-size:1.1rem;padding:15px;border:none;cursor:pointer;
  border-radius:999px;background:var(--green);color:#fff;box-shadow:5px 5px 0 var(--ink)}
.uform button:active{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink)}
.uform .note{font-size:.78rem;color:var(--muted);text-align:center;margin:2px 0 0}
.uform .opt{font-weight:500;color:var(--muted);font-size:.7em}
.btn-line{display:inline-flex;align-items:center;justify-content:center;gap:.4em;font-family:var(--disp);font-weight:900;
  font-size:1rem;padding:13px;border-radius:999px;background:#06C755;color:#fff;box-shadow:5px 5px 0 var(--ink)}
.line-box{margin-top:18px;padding-top:18px;border-top:2px dashed var(--ink);display:grid;gap:10px;text-align:center}
.line-box p{margin:0;font-size:.84rem;font-weight:700}

/* サブ見出し・ラベル */
.sub2{font-weight:700;color:var(--green-d);font-size:.95rem;margin:0;max-width:26ch}
.label{display:inline-block;font-family:var(--disp);font-weight:900;color:var(--green-d);font-size:.92rem}

/* 募集要項スペック（スクロール内） */
.spec{width:100%;max-width:420px;display:grid;gap:0;text-align:left}
.spec .row{padding:11px 2px;border-bottom:1.5px solid rgba(16,40,46,.16)}
.spec .row:last-child{border-bottom:none}
.spec .k{display:block;font-family:var(--disp);font-weight:900;font-size:.8rem;color:var(--green-d);margin-bottom:2px}
.spec .v{margin:0;font-size:.85rem;line-height:1.6}

/* スクロール可パネル（情報量が多い面：募集要項・仕事内容など） */
.panel--scroll{justify-content:flex-start;overflow-y:auto;padding-top:7vh;padding-bottom:46px}
.ucard--col{align-items:flex-start}

/* キュー */
.cue{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:2;color:var(--muted);
  font-family:var(--disp);font-weight:900;font-size:.66rem;letter-spacing:.2em;display:grid;justify-items:center;gap:4px;animation:bounce 1.8s ease-in-out infinite}
.cue svg{width:20px;height:20px;stroke:var(--ink);fill:none;stroke-width:2.5}
@keyframes bounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}

/* 登場アニメ */
.anim{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s cubic-bezier(.2,.7,.2,1)}
.panel.active .anim{opacity:1;transform:none}
.panel.active .anim:nth-child(2){transition-delay:.07s}
.panel.active .anim:nth-child(3){transition-delay:.14s}
.panel.active .anim:nth-child(4){transition-delay:.21s}
@media(prefers-reduced-motion:reduce){.anim{opacity:1;transform:none}.geo i,.cue{animation:none}.deck{scroll-behavior:auto}}

/* ============================================================
   セクション磨き（TOP / 悩み / 私たちについて / 1日の流れ）
   ============================================================ */

/* --- TOP：写真＋フローティングバッジ --- */
.cover{position:relative;width:100%;max-width:420px;margin-inline:auto}
.cover .badge-float{top:-16px;right:-6px;width:90px;height:90px;font-size:.86rem;
  border:2.5px solid var(--ink);box-shadow:4px 4px 0 var(--ink)}

/* --- TOP：締めメッセージ強調 --- */
.cover-msg{font-family:var(--disp);font-weight:900;color:var(--ink);text-align:center;margin:0;
  font-size:clamp(1rem,4.2vw,1.16rem);line-height:1.85;max-width:none;white-space:nowrap}

/* --- 悩み：吹き出し風カード＋大きな締め --- */
.wishlist{display:grid;gap:11px;width:100%;max-width:352px}
.wish{position:relative;background:var(--white);border:2.5px solid var(--ink);border-radius:16px;
  padding:14px 16px 14px 48px;box-shadow:4px 4px 0 var(--ink);text-align:left;
  font-family:var(--disp);font-weight:900;font-size:1rem;line-height:1.4}
.wish::before{content:"\201C";position:absolute;left:15px;top:14px;font-family:Georgia,serif;
  font-weight:900;font-size:2.2rem;color:var(--green);line-height:.6}
.wish:nth-child(even)::before{color:var(--green-d)}
.bigcloser{margin-top:8px;text-align:center;font-family:var(--disp);font-weight:900;
  font-size:clamp(1.32rem,6.2vw,1.72rem);line-height:1.5}
.bigcloser .g{color:var(--green)}

/* --- 私たちについて：数字スタッツ --- */
.stats{display:flex;width:100%;max-width:360px;background:var(--white);border:2.5px solid var(--ink);
  border-radius:16px;box-shadow:4px 4px 0 var(--ink);padding:13px 4px}
.stat{flex:1;text-align:center;padding:0 4px}
.stat+.stat{border-left:2px dashed rgba(16,40,46,.2)}
.stat b{display:block;font-family:var(--disp);font-weight:900;font-size:1.62rem;color:var(--green-d);line-height:1.08}
.stat b small{font-size:.5em;margin-left:1px}
.stat span{font-size:.72rem;font-weight:700;color:var(--muted)}

