/* ============================================================
   AVT Tools — ptn02 プレシジョン・ダーク（発光する道具箱）
   共通スタイル: index.html / pdf.html
   ============================================================ */

/* ---------- design tokens ---------- */
:root{
  --bg:#0B0D14;                 /* 背景 */
  --surface:#14171F;            /* カード面 */
  --surface-2:#10131B;          /* 入力面 */
  --ink-panel:#1A1F2C;          /* ミニビジュアル内の面 */
  --border:#262B38;
  --border-hi:rgba(91,140,255,.55);
  --text:#E8EAF2;
  --text-sub:#8B92A8;
  --ink:#5A637C;                /* ミニビジュアル線色（hoverでglowへ） */
  --accent:#5B8CFF;
  --glow:#63E2FF;
  --violet:#6B4CFF;
  --danger:#FF6B7A;
  --ok:#5BE49B;
  --font-head:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;
  --font-body:"Noto Sans JP","Hiragino Kaku Gothic ProN",sans-serif;
  --font-en:"Inter","Helvetica Neue",Arial,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;
  --radius:16px;
  --ease:cubic-bezier(.16,1,.3,1);
  --bounce:cubic-bezier(.34,1.56,.64,1);
}

/* ---------- base ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{color-scheme:dark}
body{background:var(--bg);color:var(--text);font:400 15px/1.8 var(--font-body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
ul{list-style:none}
:focus-visible{outline:2px solid var(--glow);outline-offset:3px}
.mono{font-family:var(--font-mono)}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}

/* ---------- 背景オーロラ＋ノイズ ---------- */
.aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none}
.aurora i{position:absolute;border-radius:50%;filter:blur(90px)}
.aurora .a1{width:680px;height:560px;left:-180px;top:-220px;background:radial-gradient(closest-side,rgba(107,76,255,.5),transparent);animation:drift1 28s ease-in-out infinite alternate}
.aurora .a2{width:560px;height:460px;left:26%;top:-260px;background:radial-gradient(closest-side,rgba(91,140,255,.36),transparent);animation:drift2 34s ease-in-out infinite alternate}
.aurora .a3{width:440px;height:380px;right:-140px;top:-160px;background:radial-gradient(closest-side,rgba(99,226,255,.15),transparent);animation:drift3 24s ease-in-out infinite alternate}
@keyframes drift1{to{transform:translate(70px,50px) scale(1.08)}}
@keyframes drift2{to{transform:translate(-64px,44px) scale(1.12)}}
@keyframes drift3{to{transform:translate(-44px,60px)}}
.noise{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-size:160px}

/* ---------- ページロード・リビール（stagger） ---------- */
.js .rv{opacity:0}
.js .is-ready .rv{opacity:1;animation:rise .7s var(--ease) backwards;animation-delay:calc(var(--i,0)*65ms)}
@keyframes rise{from{opacity:0;transform:translateY(16px)}}

/* ---------- ヘッダー ---------- */
.site-header{padding-block:44px;position:relative}
.head-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:64px}
.logo{display:inline-flex;align-items:center;gap:12px}
.logo-mark{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;color:#fff;flex:none;background:linear-gradient(135deg,var(--violet),var(--accent) 55%,var(--glow));box-shadow:0 0 20px rgba(91,140,255,.45),inset 0 1px 0 rgba(255,255,255,.35)}
.logo-name{font:700 19px var(--font-en);letter-spacing:.01em}
.head-deco{display:flex;gap:20px;color:var(--ink);font:500 13px var(--font-mono);user-select:none}
.catch{font:700 clamp(34px,2.4vw + 22px,54px)/1.32 var(--font-head);letter-spacing:.02em}
.catch em{font-style:normal;background:linear-gradient(115deg,var(--accent) 20%,var(--glow) 80%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.catch-sub{margin-top:16px;color:var(--text-sub);font-size:15.5px;max-width:42em}
.badges{margin-top:30px;display:flex;gap:12px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:9px;padding:7px 16px;border:1px solid var(--border);border-radius:999px;font:500 12.5px/1.6 var(--font-body);color:var(--text);background:rgba(20,23,31,.6);backdrop-filter:blur(6px)}
.badge i{width:6px;height:6px;border-radius:50%;background:var(--glow);box-shadow:0 0 8px var(--glow);flex:none}

/* ---------- ベントーグリッド ---------- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(200px,auto);gap:16px;padding-bottom:76px}
.card.b-pdf{grid-column:span 5;grid-row:span 2}
.card.b-img,.card.b-diff,.card.b-csv{grid-column:span 4}
.card.b-date{grid-column:span 5}

/* ---------- ツールカード ---------- */
.card{position:relative;grid-column:span 3;display:flex;flex-direction:column;gap:13px;padding:22px 22px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .3s var(--ease),box-shadow .3s var(--ease),transform .12s ease}
.card::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .35s;background:radial-gradient(260px circle at var(--mx,50%) var(--my,20%),rgba(99,226,255,.13),rgba(91,140,255,.07) 45%,transparent 72%)}
.card:hover{border-color:var(--border-hi);box-shadow:0 0 0 1px rgba(91,140,255,.22),0 18px 44px -18px rgba(91,140,255,.35)}
.card:hover::after{opacity:1}
.card:active{transform:translateY(2px) scale(.995)}
.card:active::after{opacity:1;background:radial-gradient(300px circle at var(--mx,50%) var(--my,20%),rgba(99,226,255,.24),rgba(91,140,255,.13) 45%,transparent 75%)}
.card h3{font:500 16px/1.4 var(--font-head)}
.card .desc{font-size:12.5px;line-height:1.7;color:var(--text-sub)}
.card-go{position:absolute;top:16px;right:16px;width:28px;height:28px;border:1px solid rgba(99,226,255,.4);border-radius:50%;display:grid;place-items:center;color:var(--glow);opacity:0;transform:translate(-4px,4px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.card:hover .card-go,.card:focus-visible .card-go{opacity:1;transform:none}

/* ---------- ミニビジュアル共通 ---------- */
.vis{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;color:var(--ink);transition:color .35s}
.vis svg{height:100%;max-height:118px;width:100%;max-width:250px}
.b-pdf .vis svg{max-height:195px;max-width:310px}
.card:hover .vis,.card:focus-visible .vis{color:var(--glow)}
.card:hover .vis svg{filter:drop-shadow(0 0 6px rgba(99,226,255,.4))}
.svg-mono{font:500 11px var(--font-mono);fill:currentColor;letter-spacing:.02em}
.svg-mono-lg{font:500 14px var(--font-mono);fill:currentColor}
.mv{transform-box:fill-box;transform-origin:center;transition:transform .5s var(--ease),opacity .5s var(--ease)}

/* PDF: 散らばったページが1つに束ねられる */
.b-pdf .pg1{transform:translate(-38px,10px) rotate(-8deg)}
.b-pdf .pg3{transform:translate(38px,10px) rotate(8deg)}
.b-pdf .pg2{transform:translateY(3px)}
.b-pdf:hover .pg1,.b-pdf:hover .pg2,.b-pdf:hover .pg3{transform:none}
.b-pdf .bind{opacity:0;transform:scaleX(.4)}
.b-pdf:hover .bind{opacity:1;transform:none;transition-delay:.18s}

/* 画像編集: 背景がフェードして透過チェッカーが現れる */
.b-img .bgfill{transition:opacity .5s var(--ease)}
.b-img:hover .bgfill{opacity:0}
.b-img:hover .sun{transform:translate(4px,-4px)}

/* 画像圧縮: 3枚がZIPへ吸い込まれる */
.b-comp:hover .im1{transform:translate(42px,60px) scale(.3);opacity:.85}
.b-comp:hover .im2{transform:translate(0,60px) scale(.3);opacity:.85}
.b-comp:hover .im3{transform:translate(-42px,60px) scale(.3);opacity:.85}
.b-comp .chev{transition:transform .4s var(--ease),opacity .4s}
.b-comp:hover .chev{transform:translateY(4px);opacity:1}

/* 絵文字: スマイルが弾み、グリッドが点灯 */
.b-emoji .cel{opacity:.4;transition:opacity .35s}
.b-emoji:hover .cel{opacity:.85}
.b-emoji:hover .cel:nth-of-type(2n){transition-delay:.09s}
.b-emoji .face{transition:transform .5s var(--bounce)}
.b-emoji:hover .face{transform:scale(1.18)}

/* 差分比較: 赤行と緑行が入れ替わる */
.b-diff:hover .del{transform:translateY(20px);opacity:.3}
.b-diff:hover .add{transform:translateY(-20px)}

/* テキスト整形: ばらばらの行幅が揃う */
.b-fmt .bar{transform-box:fill-box;transform-origin:left center;transform:scaleX(var(--w,1));transition:transform .5s var(--ease)}
.b-fmt:hover .bar{transform:scaleX(.9)}

/* 文字コード変換: 相互変換の矢印が反転 */
.b-cs:hover .arr{transform:rotate(180deg)}
.b-cs .chip2{opacity:.5;transition:opacity .4s}
.b-cs .chip1{transition:opacity .4s}
.b-cs:hover .chip2{opacity:1}
.b-cs:hover .chip1{opacity:.5}

/* エンコード変換: 変換後の文字が順に浮かび上がる */
.b-enc .el{opacity:.3;transition:opacity .35s}
.b-enc:hover .el{opacity:1}
.b-enc:hover .el:nth-of-type(2){transition-delay:.07s}
.b-enc:hover .el:nth-of-type(3){transition-delay:.14s}
.b-enc:hover .el:nth-of-type(4){transition-delay:.21s}
.b-enc:hover .earr{transform:translateX(5px)}

/* QR: モジュールが再描画のように明滅 */
@keyframes qrf{0%,100%{opacity:1}50%{opacity:.15}}
.b-qr .qm{transition:opacity .3s}
.b-qr:hover .qm{animation:qrf 1s linear infinite}
.b-qr:hover .qm:nth-of-type(3n){animation-delay:.33s}
.b-qr:hover .qm:nth-of-type(3n+1){animation-delay:.66s}

/* CSV: 行ハイライトが上から下へ流れる */
@keyframes csvhl{0%{transform:translateY(0)}45%{transform:translateY(21px)}90%,100%{transform:translateY(42px)}}
.b-csv .hl{opacity:0;transition:opacity .3s}
.b-csv:hover .hl{opacity:1;animation:csvhl 1.8s var(--ease) infinite}

/* リネーム: 拡張子チップが差し替わる */
.b-ren .exb{opacity:0;transform:translateY(9px)}
.b-ren:hover .exa{opacity:0;transform:translateY(-9px)}
.b-ren:hover .exb{opacity:1;transform:none}

/* 日付・営業日: 期間バーが伸び、終端がシアンに点灯 */
.b-date .range{transform:scaleX(.32);transform-origin:left center;transform-box:fill-box;transition:transform .55s var(--ease)}
.b-date:hover .range{transform:none}
.b-date .edot{opacity:0;transition:opacity .3s .28s}
.b-date:hover .edot{opacity:1;filter:drop-shadow(0 0 5px var(--glow))}

/* ---------- フッター ---------- */
.site-footer{border-top:1px solid var(--border);padding:36px 0 60px;position:relative}
.site-footer::before{content:"";position:absolute;top:-1px;left:0;width:240px;height:1px;background:linear-gradient(90deg,var(--glow),transparent)}
.foot-note{display:flex;gap:11px;align-items:flex-start;color:var(--text-sub);font-size:13px;max-width:56em}
.foot-note svg{flex:none;color:var(--glow);margin-top:5px}
.foot-sub{margin-top:8px;padding-left:29px;font-size:12.5px;color:var(--text-sub)}

/* ============================================================
   下層 pdf.html
   ============================================================ */
.topbar{display:flex;align-items:center;justify-content:space-between;padding-block:26px 8px}
.back{display:inline-flex;align-items:center;gap:9px;padding:8px 16px 8px 13px;border:1px solid var(--border);border-radius:999px;color:var(--text-sub);font:500 13.5px var(--font-body);transition:color .25s,border-color .25s,box-shadow .25s}
.back .back-arr{display:inline-block;transition:transform .3s var(--ease);font-family:var(--font-en)}
.back:hover{color:var(--text);border-color:var(--border-hi);box-shadow:0 0 18px -6px rgba(91,140,255,.5)}
.back:hover .back-arr{transform:translateX(-3px)}

.pdf-main{max-width:880px;margin:0 auto;padding-bottom:80px}
.page-title{margin:34px 0 30px}
.page-title h1{font:700 clamp(30px,3vw,40px)/1.3 var(--font-head);letter-spacing:.02em}
.page-title .sub{display:flex;align-items:center;gap:11px;margin-top:8px;color:var(--text-sub);font-size:14px}
.page-title .sub::before{content:"";width:26px;height:2px;border-radius:1px;background:linear-gradient(90deg,var(--accent),var(--glow));flex:none}

/* タブ（発光アンダーラインがスライド） */
.tabs{position:relative;display:flex;gap:6px;border-bottom:1px solid var(--border);margin-bottom:28px}
.tab{position:relative;padding:11px 22px 14px;border-radius:9px 9px 0 0;color:var(--text-sub);font:500 15px var(--font-head);transition:color .25s,background .25s}
.tab:hover{color:var(--text);background:rgba(91,140,255,.06)}
.tab[aria-selected="true"]{color:var(--text)}
.tab-ind{position:absolute;bottom:-1px;left:0;height:2px;width:60px;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--glow));box-shadow:0 0 10px rgba(99,226,255,.85),0 0 24px rgba(99,226,255,.4);transition:transform .35s var(--ease),width .35s var(--ease)}

.mode-pane{display:none}
.mode-pane.is-on{display:block;animation:fadeup .45s var(--ease)}
@keyframes fadeup{from{opacity:0;transform:translateY(10px)}}
.mode-pane h2{font:700 26px/1.4 var(--font-head)}
.mode-pane p{margin-top:6px;color:var(--text-sub);font-size:14px}

/* ドロップゾーン */
.drop{position:relative;overflow:hidden;margin-top:26px;display:flex;flex-direction:column;align-items:center;gap:12px;padding:46px 20px 42px;border:1.5px dashed #333A4C;border-radius:var(--radius);background:rgba(20,23,31,.55);cursor:pointer;text-align:center;transition:border-color .3s,box-shadow .3s,background .3s,transform .3s var(--ease)}
.drop::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .35s;background:radial-gradient(300px circle at var(--mx,50%) var(--my,40%),rgba(99,226,255,.1),transparent 70%)}
.drop p{color:var(--text-sub);font-size:14px}
.drop .d-ico{color:var(--ink);transition:color .3s,transform .35s var(--ease)}
.drop:hover,.drop.is-drag{border-color:var(--glow);background:rgba(99,226,255,.04);box-shadow:0 0 0 1px rgba(99,226,255,.22),0 0 46px -12px rgba(99,226,255,.45)}
.drop:hover::after,.drop.is-drag::after{opacity:1}
.drop:hover .d-ico,.drop.is-drag .d-ico{color:var(--glow);transform:translateY(-3px)}
.drop.is-drag{transform:scale(1.006)}
.drop:active{transform:scale(.998)}

/* ファイル一覧 */
.file-list{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.file-row{display:grid;grid-template-columns:auto auto 1fr auto auto;align-items:center;gap:13px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:border-color .25s,opacity .3s,transform .3s var(--ease)}
.file-row:hover{border-color:rgba(91,140,255,.45)}
.file-row.is-in{animation:rowin .45s var(--ease) backwards}
@keyframes rowin{from{opacity:0;transform:translateY(10px)}}
.file-row.is-out{opacity:0;transform:translateX(26px)}
.f-handle{color:var(--ink);cursor:grab;display:grid;place-items:center}
.f-ico{color:var(--accent);display:grid;place-items:center}
.f-name{font:500 13px var(--font-mono);color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.f-meta{font:400 12px var(--font-mono);color:var(--text-sub);white-space:nowrap}
.f-acts{display:flex;gap:7px}
.fbtn{padding:6px 11px;border:1px solid var(--border);border-radius:8px;font:500 12px var(--font-body);color:var(--text-sub);transition:color .2s,border-color .2s,transform .1s}
.fbtn:hover{color:var(--text);border-color:var(--accent)}
.fbtn:active{transform:translateY(1px)}
.fbtn-x:hover{color:var(--danger);border-color:rgba(255,107,122,.55)}

/* オプション行 */
.opts{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:26px;padding:20px 22px;background:rgba(20,23,31,.55);border:1px solid var(--border);border-radius:var(--radius)}
.opt-label{display:block;margin-bottom:8px;font:500 12px var(--font-body);color:var(--text-sub)}
.txt{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font:500 13px var(--font-mono);min-width:280px;transition:border-color .25s,box-shadow .25s}
.txt:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(91,140,255,.18)}

/* トグル（ON時ブルー発光） */
.switch{display:inline-flex;align-items:center;gap:12px;cursor:pointer;padding-bottom:2px}
.switch input{position:absolute;opacity:0;width:46px;height:26px;cursor:pointer}
.switch .track{position:relative;width:46px;height:26px;border-radius:13px;background:#20242F;border:1px solid #323848;flex:none;transition:background .3s,border-color .3s,box-shadow .3s}
.switch .track::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--text-sub);transition:transform .3s var(--bounce),background .3s}
.switch input:checked+.track{background:linear-gradient(135deg,#3E63D6,var(--accent));border-color:var(--accent);box-shadow:0 0 16px rgba(91,140,255,.55)}
.switch input:checked+.track::after{transform:translateX(20px);background:#fff}
.switch input:focus-visible+.track{outline:2px solid var(--glow);outline-offset:3px}
.sw-label{font:500 13.5px var(--font-body);color:var(--text)}

/* 実行ボタン */
.actions{margin-top:26px;display:flex;justify-content:flex-end}
.btn-primary{font:700 15px var(--font-head);color:#0B0D14;background:linear-gradient(135deg,var(--accent),#7BA4FF);border-radius:12px;padding:14px 42px;box-shadow:0 4px 26px -6px rgba(91,140,255,.55);transition:filter .25s,box-shadow .25s,transform .12s}
.btn-primary:hover{filter:brightness(1.09);box-shadow:0 6px 32px -6px rgba(91,140,255,.75)}
.btn-primary:active{transform:translateY(2px);box-shadow:0 2px 12px -4px rgba(91,140,255,.5)}
.btn-sm{padding:11px 26px;font-size:14px}

/* 結果カード（成功のシアングロー） */
.result{position:relative;overflow:hidden;margin-top:24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:20px 24px;border:1px solid rgba(99,226,255,.4);border-radius:var(--radius);background:linear-gradient(180deg,rgba(99,226,255,.07),rgba(20,23,31,.92));box-shadow:0 0 48px -12px rgba(99,226,255,.4)}
.result[hidden]{display:none}
.result:not([hidden]){animation:pop .5s var(--ease)}
@keyframes pop{from{opacity:0;transform:translateY(12px) scale(.985)}}
.r-ico{width:40px;height:40px;border-radius:50%;flex:none;display:grid;place-items:center;color:var(--glow);background:rgba(99,226,255,.12);box-shadow:0 0 18px rgba(99,226,255,.35)}
.r-line{flex:1;min-width:220px;font-size:14px;color:var(--text)}
.r-line strong{font:700 15px var(--font-head)}
.r-line .mono{font-size:13px}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .js .rv{opacity:1}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media (max-width:1023px){
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:minmax(190px,auto)}
  .card,.card.b-img,.card.b-diff,.card.b-csv{grid-column:span 1}
  .card.b-pdf,.card.b-date{grid-column:span 2}
  .card.b-pdf{grid-row:span 1}
  .b-pdf .vis svg{max-height:150px}
  .head-top{margin-bottom:48px}
}
@media (max-width:600px){
  .wrap{padding:0 18px}
  .bento{grid-template-columns:1fr;grid-auto-rows:minmax(180px,auto)}
  .card.b-pdf,.card.b-date{grid-column:span 1}
  .head-deco{display:none}
  .head-top{margin-bottom:36px}
  .catch{font-size:29px}
  .catch-sub{font-size:14px}
  .site-header{padding-top:30px}
  .tab{padding:10px 14px 13px;font-size:14px}
  .file-row{grid-template-columns:auto auto 1fr;row-gap:9px}
  .f-meta{grid-column:3;justify-self:end}
  .f-acts{grid-column:1/-1;justify-content:flex-end}
  .opts{flex-direction:column;align-items:stretch}
  .txt{min-width:0;width:100%}
  .actions{justify-content:stretch}
  .actions .btn-primary{width:100%}
  .result{gap:12px}
}

/* screen-reader only (視覚的に隠して読み上げにだけ渡す) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
