/* =====================================================
   3D AR Viewer — Mura-lab.info
   ===================================================== */

:root {
  /* JS で window.innerWidth/Height から計算し直す変数 */
  --vw: 1vw;   /* JSから window.innerWidth*0.01+'px' でセット */
  --vh: 1vh;   /* JSから window.innerHeight*0.01+'px' でセット */

  --fs-base:   clamp(11px, calc(var(--vw) * 1.8), 15px);
  --fs-sm:     clamp(10px, calc(var(--vw) * 1.5), 13px);
  --fs-lg:     clamp(13px, calc(var(--vw) * 2.2), 17px);
  --btn-pad-v: clamp(5px,  calc(var(--vh) * 1.2),  10px);
  --btn-pad-h: clamp(8px,  calc(var(--vw) * 1.5),  14px);
  --btn-gap:   clamp(3px,  calc(var(--vw) * 0.6),   8px);
  --radius:    6px;
}

*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  overflow: hidden;
  background: #000;
  font-family: 'Hiragino Kaku Gothic ProN', 'Noto Sans JP', system-ui, sans-serif;
  font-size: var(--fs-base);
  color: #0f0;
  width: 100%;
  height: 100%;
}

/* ---- スタート画面 --------------------------------- */
#startOverlay {
  position: fixed;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #000;
  z-index: 9999;
}
#startImage {
  max-width: min(80vw, 480px);
  max-height: 80vh;
  object-fit: contain;
  cursor: pointer;
  box-shadow: 0 0 24px rgba(0,255,0,0.3);
  border-radius: 16px;
  transition: transform .2s;
}
#startImage:hover { transform: scale(1.03); }

/* ---- ドロップゾーン ------------------------------ */
#dropZone {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px dashed rgba(0,255,0,0.5);
  color: rgba(0,255,0,0.75);
  background: rgba(0,0,0,0.55);
  font-size: var(--fs-lg);
  z-index: 9;
  pointer-events: auto;
}

/* ---- モデル読み込みボタン エリア ----------------- */
#modelControls {
  position: absolute;
  top: clamp(6px,1.5vh,14px);
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
}
#modelControls button {
  padding: var(--btn-pad-v) var(--btn-pad-h);
  font-size: var(--fs-base);
  background: #1a1a1a;
  color: #0f0;
  border: 1px solid #0f0;
  border-radius: var(--radius);
  cursor: pointer;
}
#modelControls button:hover { background: #0f0; color: #000; }

/* ---- 操作ボタンエリア (bgControls) --------------- */
#bgControls {
  position: absolute;
  top: clamp(6px,1.5vh,14px);
  left: 50%;
  transform: translateX(-50%);
  display: none;           /* JSで flex に切り替え */
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--btn-gap);
  z-index: 10;
  max-width: 98vw;
  padding: 0 4px;
}

/* ---- 共通ボタンスタイル -------------------------- */
#bgControls button {
  padding: var(--btn-pad-v) var(--btn-pad-h);
  font-size: var(--fs-sm);
  border-radius: var(--radius);
  border: 1px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  text-align: center;
  transition: filter .15s, transform .1s;
  line-height: 1.3;
}
#bgControls button:hover  { filter: brightness(1.2); }
#bgControls button:active { transform: scale(0.97); }

.btn-default {
  background: #222;
  color: #0f0;
  border-color: #0f0 !important;
}
.btn-accent {
  background: #ffe600;
  color: #000;
  font-weight: bold;
}
.btn-orange {
  background: #ff8c00;
  color: #000;
  font-weight: bold;
}
.btn-color {
  background: linear-gradient(135deg, #dbeafe 0%, #fde68a 40%, #fecdd3 70%, #d1fae5 100%);
  color: #333;
  font-weight: bold;
  border: 2px solid rgba(0,0,0,0.2) !important;
}
.btn-color:hover { filter: brightness(1.08) !important; }

/* ---- 統計パネル ----------------------------------
   bgControls の外（body直下）に position:fixed で表示
   ボタンの下・画面中央に重ねて出す
   -------------------------------------------------- */
#statsPanel {
  display: none;
  position: fixed;
  /* ボタン行の高さ分だけ下げる（ボタン最大高さ約64px + 余白） */
  top: clamp(70px, 12vh, 100px);
  left: 50%;
  transform: translateX(-50%);
  /* 幅: スマホは画面幅の92%、PCは最大600px */
  width: min(92vw, 600px);
  box-sizing: border-box;
  background: rgba(0,0,0,0.92);
  color: #fff;
  font-size: clamp(13px, 3.2vw, 16px);
  line-height: 1.9;
  padding: 16px 20px;
  border-radius: 10px;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 75vh;
  overflow-y: auto;
  z-index: 9999;
  user-select: text;
  cursor: text;
  box-shadow: 0 4px 24px rgba(0,0,0,0.7);
}
/* ダブルクリックで閉じる ヒント表示 */
#statsPanel::after {
  content: '（ダブルクリックで閉じる）';
  display: block;
  margin-top: 10px;
  font-size: 0.8em;
  color: rgba(255,255,255,0.45);
  text-align: right;
}

/* ---- ビデオ -------------------------------------- */
video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  pointer-events: none;
}

/* ---- キャンバス ----------------------------------
   alpha:true のためcanvas自体は透明
   カメラ背景時は video(z:1) の上に canvas(z:5) を重ねて合成
   -------------------------------------------------- */
canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: none;
  z-index: 5;
  pointer-events: auto;
  /* alpha:true なので背景透過でvideoが透けて見える */
  background: transparent;
}

/* ====================================================
   レスポンシブ調整
   ==================================================== */

/* タブレット縦 (768px以下) */
@media (max-width: 768px) {
  :root {
    --fs-sm: clamp(9px, 2vw, 12px);
    --btn-pad-v: clamp(4px, 1vh, 8px);
    --btn-pad-h: clamp(6px, 1.8vw, 11px);
    --btn-gap: clamp(2px, 0.5vw, 6px);
  }
  #bgControls {
    top: clamp(4px, 1vh, 10px);
  }
  #statsPanel {
    top: clamp(60px, 11vh, 90px);
  }
}

/* スマホ縦 (480px以下) */
@media (max-width: 480px) {
  :root {
    --fs-sm: clamp(9px, 2.5vw, 11px);
    --btn-pad-v: 4px;
    --btn-pad-h: 7px;
    --btn-gap: 3px;
  }
  #bgControls {
    top: 4px;
    max-width: 100vw;
    padding: 0 2px;
  }
  #bgControls button {
    font-size: clamp(9px, 2.5vw, 11px);
    white-space: normal;
    word-break: keep-all;
    min-width: clamp(48px, 14vw, 70px);
    max-width: 22vw;
    line-height: 1.3;
  }
  #statsPanel {
    top: clamp(80px, 18vw, 110px);
    font-size: clamp(12px, 3.5vw, 15px);
  }
}

/* 横向き & 低背 (高さ480px以下) — スマホ横向き */
@media (max-height: 480px) {
  #bgControls { top: 2px; }
  :root {
    --btn-pad-v: 3px;
    /* 横向きでは vw が大きくなりすぎるため fs-sm を固定 */
    --fs-sm: 11px;
    --btn-pad-h: 8px;
    --btn-gap: 4px;
  }
  #statsPanel {
    top: 44px;
    max-height: 70vh;
    /* 横向きは幅を広く */
    width: min(70vw, 560px);
  }
}

/* 大画面 (1200px以上) */
@media (min-width: 1200px) {
  :root {
    --fs-base: 15px;
    --fs-sm:   13px;
    --fs-lg:   17px;
    --btn-pad-v: 9px;
    --btn-pad-h: 14px;
  }
}
