/* CutFlow — Feature Components */
/* ── STICKER / EMOJI OVERLAY PICKER ── */
.sticker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:8px;}
.sticker-btn{
  font-size:20px;text-align:center;padding:4px;border-radius:5px;cursor:pointer;
  background:var(--bg3);border:1px solid transparent;transition:all .12s;line-height:1.4;
}
.sticker-btn:hover{background:var(--surface);border-color:var(--border2);transform:scale(1.15);}

/* ── AUDIO MIXER ── */
.mixer-track{
  display:flex;align-items:center;gap:8px;padding:8px 0;
  border-bottom:1px solid var(--border);
}
.mixer-track:last-child{border-bottom:none;}
.mixer-label{font-size:11px;color:var(--text2);min-width:64px;font-family:var(--mono);font-weight:700;}
.mixer-vol{flex:1;accent-color:var(--accent);}
.mixer-pan{width:60px;accent-color:var(--cyan);}
.mixer-mute{
  width:22px;height:22px;border-radius:4px;
  background:var(--surface);border:1px solid var(--border);
  cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center;
  color:var(--text3);transition:all .15s;flex-shrink:0;
}
.mixer-mute.muted{background:rgba(248,113,113,.15);border-color:var(--red);color:var(--red);}
.mixer-solo{
  width:22px;height:22px;border-radius:4px;
  background:var(--surface);border:1px solid var(--border);
  cursor:pointer;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;
  color:var(--text3);transition:all .15s;flex-shrink:0;font-family:var(--mono);
}
.mixer-solo.active{background:rgba(251,191,36,.15);border-color:var(--amber);color:var(--amber);}
.mixer-db{font-family:var(--mono);font-size:10px;color:var(--text3);min-width:32px;text-align:right;}

/* ── KEYBOARD SHORTCUTS MODAL ── */
.shortcuts-modal{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.75);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.shortcuts-modal.open{display:flex;}
.shortcuts-box{
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:16px;width:580px;max-height:80vh;
  display:flex;flex-direction:column;overflow:hidden;
}
.shortcuts-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  overflow-y:auto;padding:20px;
}
.shortcut-group{margin-bottom:18px;}
.shortcut-group-title{
  font-size:10px;font-weight:700;color:var(--accent);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-family:var(--mono);
}
.shortcut-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px;
}
.shortcut-row:last-child{border-bottom:none;}
.shortcut-desc{color:var(--text2);}
.kbd{
  display:inline-flex;align-items:center;gap:3px;
}
.key{
  background:var(--surface2);border:1px solid var(--border2);border-bottom:2px solid var(--border2);
  border-radius:4px;padding:1px 6px;font-family:var(--mono);font-size:10px;font-weight:700;
  color:var(--text2);min-width:18px;text-align:center;
}

/* ── ONBOARDING TOOLTIP ── */
.onboard{
  position:fixed;inset:0;z-index:800;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
}
.onboard-card{
  background:var(--bg2);border:1px solid var(--accent);
  border-radius:16px;padding:28px 32px;max-width:440px;
  pointer-events:all;text-align:center;
  box-shadow:0 0 0 1px rgba(124,106,247,.2), 0 32px 80px rgba(0,0,0,.6);
  animation:onboardIn .4s cubic-bezier(.34,1.4,.64,1) both;
}
@keyframes onboardIn{from{opacity:0;transform:scale(.88) translateY(20px);}to{opacity:1;transform:none;}}
.onboard-emoji{font-size:48px;margin-bottom:16px;display:block;}
.onboard-title{font-size:22px;font-weight:800;margin-bottom:8px;letter-spacing:-.5px;}
.onboard-sub{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:20px;}
.onboard-steps{
  display:flex;gap:8px;justify-content:center;margin-bottom:22px;flex-wrap:wrap;
}
.onboard-step{
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  padding:8px 12px;font-size:12px;display:flex;align-items:center;gap:6px;color:var(--text2);
}
.onboard-step-num{
  width:20px;height:20px;border-radius:50%;
  background:var(--accent);color:#fff;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}

/* ── RECORDING INDICATOR ── */
.rec-dot{
  width:8px;height:8px;border-radius:50%;background:var(--red);
  animation:recBlink 1s ease-in-out infinite;flex-shrink:0;
}
@keyframes recBlink{0%,100%{opacity:1;}50%{opacity:.2;}}
#rec-badge{
  display:none;align-items:center;gap:6px;
  background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.3);
  border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;
  font-family:var(--mono);color:var(--red);
}
#rec-badge.active{display:flex;}

/* ── CROP OVERLAY ── */
#crop-overlay{
  position:absolute;inset:0;display:none;
  border:2px dashed var(--accent);pointer-events:none;z-index:10;
}
#crop-overlay.visible{display:block;}
.crop-handle{
  position:absolute;width:12px;height:12px;
  background:var(--accent);border-radius:2px;pointer-events:all;cursor:nwse-resize;
}

/* ── COLOR GRADING ── */
.lut-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px;}
.lut-card{
  border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid transparent;
  transition:border-color .15s;aspect-ratio:16/9;position:relative;
}
.lut-card.active{border-color:var(--accent);}
.lut-card .lut-label{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(0,0,0,.6);font-size:9px;font-weight:700;
  color:#fff;text-align:center;padding:2px;font-family:var(--mono);
}
.lut-swatch{width:100%;height:100%;}

/* ── SPEED RAMP ── */
.speed-graph{
  height:60px;background:var(--bg3);border:1px solid var(--border);
  border-radius:6px;margin-bottom:10px;position:relative;overflow:hidden;cursor:crosshair;
}
.speed-graph-line{
  position:absolute;bottom:0;left:0;right:0;
  height:2px;background:var(--accent);
  transform-origin:left center;
}
.speed-keyframe{
  position:absolute;width:10px;height:10px;border-radius:50%;
  background:var(--accent);cursor:grab;transform:translate(-50%,-50%);top:50%;
}

/* ── PROJECT SAVE/LOAD ── */
.project-modal{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.75);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;
}
.project-modal.open{display:flex;}
.project-box{
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:14px;width:480px;max-height:70vh;
  display:flex;flex-direction:column;overflow:hidden;
}
.project-list{overflow-y:auto;padding:10px;}
.project-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-radius:8px;cursor:pointer;
  transition:background .15s;border:1px solid transparent;margin-bottom:4px;
}
.project-item:hover{background:var(--surface);border-color:var(--border);}
.project-item-name{font-size:13px;font-weight:600;}
.project-item-meta{font-size:11px;color:var(--text3);font-family:var(--mono);margin-top:2px;}

/* ── MINI VISUALIZER on timeline audio ── */
@keyframes barAnim{0%,100%{transform:scaleY(.3);}50%{transform:scaleY(1);}}

/* RESPONSIVE */
@media(max-width:900px){
  .right-panel{display:none;}
  :root{--tools-w:44px;}
}

/* ── GOOGLE SIGN-IN BTN ── */
.google-btn{
  width:100%;padding:10px 14px;
  background:var(--bg3);border:1px solid var(--border2);
  border-radius:var(--r);color:var(--text);font-size:13px;font-weight:600;
  font-family:var(--sans);cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-bottom:10px;
}
.google-btn:hover{background:var(--surface);border-color:rgba(255,255,255,.2);}
.google-icon{width:18px;height:18px;flex-shrink:0;}

/* ── FOOTER ── */
#app-footer{
  height:28px;flex-shrink:0;
  background:var(--bg2);
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  gap:16px;
  font-size:11px;color:var(--text3);
  font-family:var(--mono);
}
#app-footer a{color:var(--text3);text-decoration:none;transition:color .15s;}
#app-footer a:hover{color:var(--accent);}
#app-footer .heart{color:var(--red);display:inline-block;animation:hb .9s ease-in-out infinite;}
@keyframes hb{0%,100%{transform:scale(1);}50%{transform:scale(1.25);}}

/* ── LEGAL MODALS ── */
.legal-modal{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.75);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.legal-modal.open{display:flex;}
.legal-box{
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:16px;width:100%;max-width:640px;max-height:82vh;
  display:flex;flex-direction:column;position:relative;overflow:hidden;
}
.legal-box::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent3),var(--accent),var(--cyan));
}
.legal-head{
  padding:24px 28px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0;
}
.legal-title{font-size:20px;font-weight:800;letter-spacing:-.4px;}
.legal-date{font-size:11px;color:var(--text3);margin-top:3px;font-family:var(--mono);}
.legal-close{
  background:var(--surface);border:1px solid var(--border);border-radius:6px;
  width:30px;height:30px;cursor:pointer;font-size:15px;
  display:flex;align-items:center;justify-content:center;color:var(--text2);
  flex-shrink:0;margin-top:2px;
}
.legal-close:hover{background:var(--surface2);color:var(--text);}
.legal-body{padding:24px 28px;overflow-y:auto;font-size:14px;color:var(--text2);line-height:1.8;}
.legal-body::-webkit-scrollbar{width:4px;}
.legal-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
.legal-body h2{font-size:14px;font-weight:700;color:var(--text);margin:22px 0 6px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--mono);}
.legal-body h2:first-child{margin-top:0;}
.legal-body p{margin-bottom:12px;}
.legal-body ul{margin:0 0 12px 18px;}
.legal-body li{margin-bottom:5px;}
.legal-body strong{color:var(--text);font-weight:700;}
.legal-highlight{
  background:rgba(124,106,247,.08);border:1px solid rgba(124,106,247,.2);
  border-left:3px solid var(--accent);border-radius:6px;padding:12px 16px;
  margin-bottom:16px;font-size:13px;
}
/* ── FREE BADGE in header ── */
.header-free-badge {
  font-size: 10px;
  font-weight: 700;
  font-family: var(--mono);
  padding: 3px 8px;
  background: rgba(52,211,153,.12);
  border: 1px solid rgba(52,211,153,.3);
  border-radius: 20px;
  color: var(--green);
  letter-spacing: .04em;
  text-transform: uppercase;
  flex-shrink: 0;
  white-space: nowrap;
}

/* ── FOOTER extras ── */
.footer-sep {
  color: var(--text3);
  font-size: 10px;
}
.footer-free {
  font-size: 11px;
  color: var(--green);
  font-weight: 600;
  font-family: var(--mono);
}

/* ── OLD DRAWER CSS CLASSES (used by v2 tablet drawer, kept for compat) ── */
.d-section {
  font-size: 10px; font-weight: 700; color: var(--text3);
  text-transform: uppercase; letter-spacing: .08em;
  font-family: var(--mono); margin: 12px 0 7px;
  display: flex; align-items: center; gap: 6px;
}
.d-section::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.d-section:first-child { margin-top: 0; }
.d-row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.d-label { font-size: 11px; color: var(--text2); min-width: 68px; font-weight: 600; flex-shrink: 0; }
.d-val { font-family: var(--mono); font-size: 10px; color: var(--text3); min-width: 28px; text-align: right; flex-shrink: 0; }
.d-slider { flex: 1; accent-color: var(--accent); }
.d-btn {
  padding: 8px 10px; background: var(--bg3); border: 1px solid var(--border);
  border-radius: 7px; font-size: 12px; font-weight: 700; color: var(--text2);
  font-family: var(--sans); cursor: pointer; text-align: center; transition: all .15s;
  -webkit-tap-highlight-color: transparent;
}
.d-btn:active { background: var(--surface); }
.d-btn.primary { background: linear-gradient(135deg,var(--accent3),var(--accent)); border-color: transparent; color: #fff; }
.d-btn.danger { color: var(--red); border-color: rgba(248,113,113,.25); }
.d-btn-full { width: 100%; margin-top: 4px; }
.d-btn-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: 8px; }
.d-media-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 10px; }
.d-media-btn {
  background: var(--bg3); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px 6px; display: flex; flex-direction: column;
  align-items: center; gap: 5px; cursor: pointer;
  font-size: 11px; font-weight: 700; color: var(--text2); font-family: var(--sans);
  transition: all .15s;
}
.d-media-btn:active { background: var(--surface); border-color: var(--accent); color: var(--accent); }
.d-media-icon { font-size: 24px; }
.d-filter-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 5px; margin-bottom: 12px; }
.d-filter-grid .filter-card { padding: 5px 3px; font-size: 9px; }
.d-filter-grid .filter-preview { height: 28px; }
.d-mixer-row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.d-mixer-label { font-size: 11px; color: var(--text2); min-width: 60px; font-weight: 600; font-family: var(--mono); }
.d-mixer-vol { flex: 1; accent-color: var(--accent); }
.d-mute {
  width: 24px; height: 24px; border-radius: 4px; background: var(--surface);
  border: 1px solid var(--border); cursor: pointer; font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; color: var(--text3);
  transition: all .15s; flex-shrink: 0;
}
.d-mute.muted { background: rgba(248,113,113,.15); border-color: var(--red); color: var(--red); }
