:root{
  --teal:#0f766e; --teal-d:#0b5a54; --ink:#1f2937; --muted:#6b7280;
  --line:#e5e7eb; --bg:#f7f9f9; --card:#ffffff; --soft:#f0fdfa;
  --radius:14px; --shadow:0 1px 3px rgba(0,0,0,.06),0 8px 24px rgba(15,118,110,.06);
  --maxw:1180px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:'Hiragino Sans','Hiragino Kaku Gothic ProN','Yu Gothic',system-ui,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px;}

/* header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;gap:18px;height:60px;}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.5px;}
.brand .logo{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--teal),#14b8a6);
  display:grid;place-items:center;color:#fff;font-weight:900;font-size:15px;}
.brand b{font-size:17px;} .brand span{color:var(--teal);}
.nav .links{display:flex;gap:18px;margin-left:auto;font-size:14px;font-weight:600;color:var(--muted);}
.nav .links a:hover{color:var(--teal);}
@media(max-width:720px){.nav .links{display:none;}}

/* hero */
.hero{position:relative;overflow:hidden;color:#fff;min-height:560px;height:74vh;max-height:760px;
  background:linear-gradient(135deg,var(--teal) 0%,#0e7490 60%,#155e75 100%);display:flex;align-items:center;}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease;}
.hero-media .slide.on{opacity:1;}
.hero-media video,.hero-media .poster{width:100%;height:100%;object-fit:cover;display:block;}
.hero-grad{position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(8,40,38,.92) 0%,rgba(8,40,38,.72) 38%,rgba(8,40,38,.30) 70%,rgba(8,40,38,.5) 100%);}
.hero-grad::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,30,28,.6),transparent 40%);}
.hero-inner{position:relative;z-index:2;width:100%;}
.kicker{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:800;letter-spacing:3px;
  text-transform:uppercase;opacity:.92;margin-bottom:18px;}
.kicker .kdot{width:8px;height:8px;border-radius:50%;background:#5eead4;box-shadow:0 0 12px #5eead4;}
.hero h1{font-size:clamp(30px,5.4vw,56px);margin:0 0 16px;font-weight:900;line-height:1.18;letter-spacing:.5px;
  text-shadow:0 2px 24px rgba(0,0,0,.35);}
.hero h1 .hl{color:#5eead4;}
.hero p{font-size:clamp(14px,2.3vw,19px);opacity:.95;margin:0 0 26px;max-width:560px;line-height:1.7;text-shadow:0 1px 12px rgba(0,0,0,.3);}
.hero .cta{display:inline-flex;gap:12px;flex-wrap:wrap;}
.btn{display:inline-flex;align-items:center;gap:7px;padding:13px 26px;border-radius:999px;font-weight:800;font-size:15px;border:2px solid transparent;transition:.18s;}
.btn.primary{background:#fff;color:var(--teal);box-shadow:0 8px 24px rgba(0,0,0,.25);} .btn.primary:hover{transform:translateY(-2px);}
.btn.ghost{border-color:rgba(255,255,255,.7);color:#fff;backdrop-filter:blur(2px);} .btn.ghost:hover{background:rgba(255,255,255,.14);}
.hero .stats{display:flex;gap:30px;flex-wrap:wrap;margin-top:32px;}
.hero .stats div{font-size:12.5px;opacity:.88;} .hero .stats b{display:block;font-size:26px;font-weight:900;}
.hero-nowname{position:absolute;right:26px;bottom:60px;z-index:3;font-size:13px;font-weight:700;
  background:rgba(0,0,0,.38);backdrop-filter:blur(4px);padding:7px 16px;border-radius:999px;
  border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;gap:8px;}
.hero-nowname::before{content:"●";color:#f43f5e;font-size:9px;animation:blink 1.4s infinite;}
@keyframes blink{50%{opacity:.3}}
.hero-dots{position:absolute;left:0;right:0;bottom:22px;z-index:3;display:flex;justify-content:center;gap:9px;}
.hero-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.4);cursor:pointer;padding:0;transition:.2s;}
.hero-dots button.on{background:#fff;width:26px;border-radius:5px;}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(255,255,255,.35);background:rgba(0,0,0,.32);backdrop-filter:blur(4px);color:#fff;font-size:28px;
  cursor:pointer;display:grid;place-items:center;line-height:1;transition:.18s;}
.hero-arrow:hover{background:rgba(0,0,0,.55);transform:translateY(-50%) scale(1.06);}
.hero-arrow.prev{left:18px;} .hero-arrow.next{right:18px;}
.spbr{display:none;}
@media(max-width:600px){
  .hero{height:70vh;min-height:440px;max-height:620px;align-items:flex-end;}
  .hero-grad{background:linear-gradient(0deg,rgba(8,30,28,.96) 4%,rgba(8,30,28,.55) 40%,rgba(8,30,28,.08) 66%,transparent 84%);}
  .hero-grad::after{display:none;}
  .hero-inner{padding:0 0 50px;}
  .hero h1{font-size:29px;margin-bottom:12px;}
  .hero p{font-size:13.5px;margin-bottom:18px;}
  .hero .cta{gap:9px;}.btn{padding:11px 18px;font-size:14px;}
  .hero .stats{gap:18px;margin-top:18px;}.hero .stats b{font-size:21px;}
  .hero-nowname{top:13px;bottom:auto;right:12px;}
  .hero-dots{bottom:13px;}
  .hero-arrow{width:38px;height:38px;font-size:23px;}.hero-arrow.prev{left:8px;}.hero-arrow.next{right:8px;}
  .spbr{display:inline;}
}

/* sections */
section{padding:50px 0;}
.shead{display:flex;align-items:end;justify-content:space-between;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.shead h2{font-size:clamp(20px,3.2vw,28px);margin:0;font-weight:800;}
.shead h2 .ac{color:var(--teal);}
.shead p{margin:4px 0 0;color:var(--muted);font-size:14px;}

/* store grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px;}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.18s;}
.card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(15,118,110,.14);}
.card .ph{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,var(--c,#0f766e),#0b3b38);
  display:grid;place-items:center;color:#fff;overflow:hidden;}
.card .ph img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.card .ph .ph-fallback{text-align:center;padding:10px;z-index:1;}
.card .ph .ph-fallback .area{font-size:12px;opacity:.85;letter-spacing:2px;}
.card .ph .ph-fallback .nm{font-size:20px;font-weight:900;margin-top:4px;text-shadow:0 1px 8px rgba(0,0,0,.25);}
.card .ph .badge{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);color:var(--c,#0f766e);
  font-size:11px;font-weight:800;padding:4px 10px;border-radius:999px;z-index:2;}
.card .body{padding:15px 16px 16px;display:flex;flex-direction:column;gap:10px;flex:1;}
.card h3{margin:0;font-size:17px;font-weight:800;}
.card .rec{font-size:12.5px;color:var(--teal);font-weight:700;background:var(--soft);padding:7px 10px;border-radius:9px;}
.kv{display:grid;grid-template-columns:auto 1fr;gap:3px 8px;font-size:12.5px;}
.kv dt{color:var(--muted);white-space:nowrap;} .kv dd{margin:0;font-weight:600;}
.fits{margin:2px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:3px;}
.fits-title{font-size:12px;font-weight:800;color:var(--c,#0f766e);margin-top:2px;}
.fits li{font-size:12px;padding-left:18px;position:relative;}
.fits li::before{content:"✓";position:absolute;left:0;color:var(--c,#0f766e);font-weight:900;}

/* actions: row1 = バニラ求人 + 3 LINE / row2 = 電話 */
.card .actions{margin-top:auto;display:flex;flex-direction:column;gap:8px;}
.actrow1{display:flex;gap:6px;flex-wrap:wrap;}
.actrow1 > *{flex:1 1 calc(50% - 6px);min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:5px;
  font-size:12px;font-weight:700;padding:8px 6px;border-radius:9px;border:1px solid var(--line);white-space:nowrap;}
.actrow1 .vani{background:var(--c,#0f766e);color:#fff;border-color:transparent;}
.actrow1 .line{background:#06C755;color:#fff;border-color:#06C755;}
.actrow1 .line.muted{background:#f1f5f9;color:#9aa3af;border-color:var(--line);cursor:default;}
.actrow1 .line.muted .li rect{fill:#cbd5e1;}
.actrow1 .li{width:15px;height:15px;flex:none;border-radius:4px;}
.actrow1 a:hover{filter:brightness(.95);}
.tel-big{display:flex;align-items:center;justify-content:center;gap:8px;background:#0b3b38;color:#fff;
  font-size:18px;font-weight:800;letter-spacing:.5px;padding:11px;border-radius:10px;}
.tel-big svg{opacity:.9;}
.tel-big:hover{background:#0f766e;}

/* common box */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media(max-width:760px){.twocol{grid-template-columns:1fr;}}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;}
.panel h3{margin:0;background:var(--teal);color:#fff;font-size:15px;padding:12px 16px;}
.panel ol,.panel ul{margin:0;padding:14px 18px 16px 34px;}
.panel li{font-size:14px;margin-bottom:6px;}
.ribbon{background:var(--soft);border:1px solid #cdeee9;border-radius:var(--radius);padding:16px 18px;}
.ribbon .lbl{font-weight:800;color:var(--teal);margin-bottom:4px;}
.ribbon .txt{font-size:14px;}

/* analytics */
.analytics{background:linear-gradient(180deg,#0b3b38,#0f766e);color:#fff;border-radius:20px;padding:26px;}
.analytics .shead{margin-bottom:14px;}
.analytics .shead h2{color:#fff;} .analytics .shead h2 .ac{color:#9beadf;}
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px;}
.period{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);padding:7px 12px;border-radius:999px;flex-wrap:wrap;}
.period .plabel{font-size:13px;font-weight:700;}
.period select{border:none;border-radius:8px;padding:6px 8px;font-size:13px;font-weight:700;color:var(--teal);background:#fff;}
.period .tilde{opacity:.85;}
.applybtn{background:#9beadf;color:#06403a;border:none;border-radius:8px;padding:6px 14px;font-weight:800;cursor:pointer;font-size:13px;}
.applybtn:active{transform:scale(.97);}
.updbtn{margin-left:auto;background:#fff;color:var(--teal);border:none;border-radius:999px;padding:9px 18px;font-weight:800;cursor:pointer;display:inline-flex;gap:7px;align-items:center;}
.updbtn:active{transform:scale(.97);} .updbtn.spin svg{animation:rot .8s linear infinite;}
@keyframes rot{to{transform:rotate(360deg);}}
.chartgrid{display:grid;grid-template-columns:1fr;gap:16px;}
.chartbox{background:#fff;color:var(--ink);border-radius:14px;padding:14px 16px;}
.chartbox h4{margin:0 0 4px;font-size:15px;font-weight:800;}
.chartbox .sub{font-size:11.5px;color:var(--muted);margin:0 0 8px;}
.cwrap{position:relative;height:240px;}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px;}
.tabs button{border:1px solid var(--line);background:#f8fafc;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:700;cursor:pointer;color:var(--muted);}
.tabs button.on{background:var(--teal);color:#fff;border-color:var(--teal);}
.kpis{display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px;color:var(--muted);margin-top:8px;}
.kpis b{color:var(--teal);}

/* analytics explorer (2-up compare) */
.explorer{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.xpanel{border:1px solid var(--line);border-radius:12px;padding:10px 12px;background:#fcfdfd;}
.xctrl{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap;}
.xctrl select{flex:1;min-width:0;border:1px solid var(--line);border-radius:8px;padding:7px 9px;font-size:12.5px;font-weight:700;color:var(--ink);background:#fff;}
.xctrl .xvar{flex:1.6;}
.xc{height:250px;}
.xkpi{margin-top:8px;}
.soonmsg{position:absolute;inset:0;display:none;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  color:var(--muted);font-size:13px;gap:4px;padding:16px;background:repeating-linear-gradient(45deg,#f8fafc,#f8fafc 10px,#f1f5f9 10px,#f1f5f9 20px);border-radius:10px;}
.soonmsg b{color:var(--teal);font-size:15px;} .soonmsg span{font-size:11.5px;}
@media(max-width:760px){.explorer{grid-template-columns:1fr;}}

/* applicant tools */
#tools .shead{margin-bottom:18px;}
.toolgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:820px){.toolgrid{grid-template-columns:1fr;}}
.tool{background:#fff;border-radius:14px;padding:18px;box-shadow:var(--shadow);}
.tool h3{margin:0 0 4px;font-size:16px;font-weight:800;}
.thint{margin:0 0 12px;font-size:12px;color:var(--muted);}
.trow{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;}
.trow label{width:64px;color:var(--muted);font-weight:700;flex:none;}
.trow select{flex:1;border:1px solid var(--line);border-radius:8px;padding:7px 9px;font-size:13px;font-weight:700;background:#fff;}
.simout{background:var(--soft);border-radius:10px;padding:10px 12px;margin:10px 0;}
.simrow{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;padding:3px 0;}
.simrow b{font-size:18px;color:var(--teal);}
.simsub{font-size:10.5px;color:var(--muted);margin-top:4px;}
.tnote{font-size:10.5px;color:#9ca3af;margin:8px 0 0;}
.quiz{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;}
@media(max-width:480px){.quiz{grid-template-columns:1fr;}}
.qq{display:flex;flex-direction:column;gap:3px;}
.qq label{font-size:11.5px;color:var(--muted);font-weight:700;}
.qq select{border:1px solid var(--line);border-radius:8px;padding:7px 8px;font-size:12.5px;background:#fff;}
.qbtn{width:100%;background:var(--teal);color:#fff;border:none;border-radius:10px;padding:11px;font-weight:800;font-size:14px;cursor:pointer;}
.qbtn:active{transform:scale(.99);}
.qresult{margin-top:12px;}
.qres-h{font-weight:800;font-size:13px;margin-bottom:8px;color:var(--teal);}
.qcard{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:4px 10px;border:1px solid var(--line);
  border-left:4px solid var(--c,#0f766e);border-radius:10px;padding:9px 12px;margin-bottom:8px;}
.qcard .qrank{grid-row:1/3;font-size:20px;font-weight:900;color:var(--c,#0f766e);}
.qcard .qname{font-weight:800;font-size:14px;}
.qcard .qarea{font-size:11px;color:var(--muted);text-align:right;}
.qcard .qfit{grid-column:2/4;font-size:11.5px;color:var(--teal);}
/* trust */
.trow2{display:grid;grid-template-columns:78px 1fr 34px;align-items:center;gap:8px;margin-bottom:7px;}
.trow2 .tname{font-size:13px;font-weight:700;}
.trow2 .tbar{height:14px;background:#eef2f1;border-radius:7px;overflow:hidden;}
.trow2 .tfill{height:100%;border-radius:7px;}
.trow2 .tscore{font-size:15px;font-weight:900;color:var(--teal);text-align:right;}
.trow2 .tsub{grid-column:2/4;font-size:10.5px;color:var(--muted);margin-top:-3px;}

/* data login gate */
.datagate{display:flex;justify-content:center;padding:18px 0 6px;}
.gatebox{background:#fff;border-radius:14px;padding:24px 22px;width:min(360px,92%);text-align:center;box-shadow:0 8px 30px rgba(0,0,0,.18);}
.gatebox .gicon{font-size:30px;}
.gatebox h3{margin:6px 0 14px;font-size:16px;color:var(--ink);}
.gatebox input{width:100%;border:1px solid var(--line);border-radius:9px;padding:11px 12px;font-size:14px;margin-bottom:10px;}
.gatebox input:focus{outline:2px solid var(--teal);border-color:var(--teal);}
.gatebox button{width:100%;background:var(--teal);color:#fff;border:none;border-radius:9px;padding:12px;font-weight:800;font-size:15px;cursor:pointer;}
.gatebox button:active{transform:scale(.99);}
.gatebox .gerr{color:#dc2626;font-size:12.5px;margin-top:10px;font-weight:700;}

/* gallery & lightbox */
.card .ph.clickable{cursor:zoom-in;}
.ph-count{position:absolute;right:10px;bottom:10px;background:rgba(0,0,0,.55);color:#fff;font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;z-index:2;}
.thumbs{display:flex;gap:6px;overflow-x:auto;padding:8px 10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;background:#fafafa;border-bottom:1px solid var(--line);}
.thumbs::-webkit-scrollbar{height:5px;}.thumbs::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px;}
.thumb{flex:0 0 auto;width:92px;height:54px;border:1px solid var(--line);border-radius:7px;overflow:hidden;padding:0;cursor:pointer;background:#eef2f1;scroll-snap-align:start;transition:.15s;}
.thumb img{width:100%;height:100%;object-fit:contain;display:block;}
.thumb:hover{border-color:var(--c,#0f766e);transform:translateY(-1px);}
.lb{position:fixed;inset:0;z-index:1000;background:rgba(8,12,16,.93);display:flex;align-items:center;justify-content:center;}
.lb[hidden]{display:none;}
.lb-stage{max-width:92vw;max-height:86vh;display:flex;align-items:center;justify-content:center;}
.lb-img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:8px;box-shadow:0 12px 50px rgba(0,0,0,.55);}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.14);color:#fff;border:none;cursor:pointer;border-radius:50%;width:46px;height:46px;font-size:26px;display:grid;place-items:center;line-height:1;}
.lb-close{top:16px;right:16px;font-size:30px;}
.lb-prev{left:14px;top:50%;transform:translateY(-50%);}.lb-next{right:14px;top:50%;transform:translateY(-50%);}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.28);}
.lb-cap{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:#fff;font-size:13px;background:rgba(0,0,0,.4);padding:5px 14px;border-radius:999px;}
@media(max-width:600px){.lb-prev,.lb-next,.lb-close{width:40px;height:40px;font-size:22px;}}

footer{background:#0b1220;color:#9ca3af;padding:26px 0;font-size:12.5px;margin-top:40px;}
footer b{color:#e5e7eb;}

/* overflow guard (スマホで右に白余白/グラフはみ出しを防止) */
html,body{max-width:100%;overflow-x:hidden;}
.wrap,section,.analytics,.chartgrid,.chartbox,.xpanel,.cols,.twocol,.toolgrid,.cwrap,.xc{min-width:0;max-width:100%;}
.cwrap,.xc{position:relative;overflow:hidden;width:100%;}
.cwrap>canvas,.xc>canvas{position:absolute!important;inset:0;width:100%!important;height:100%!important;}

/* mobile */
@media(max-width:600px){
  section{padding:34px 0;}
  .wrap{padding:0 14px;}
  .analytics{padding:16px;border-radius:16px;}
  .chartbox{padding:12px 10px;}
  .cwrap{height:230px;}
  .xc{height:240px;}
  .tel-big{font-size:17px;}
  .actrow1 > *{flex:1 1 calc(50% - 6px);font-size:11.5px;}
  .toolbar{gap:8px;}
  .updbtn{margin-left:0;width:100%;justify-content:center;}
  .period{width:100%;justify-content:center;}
  .hero .stats{gap:18px;}
  .hero .stats b{font-size:22px;}
}
