/* ===========================================
   ClipMaster — Hyper-Modern UI v3
   =========================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#050507;
  --surface:#0c0c10;
  --surface2:#111116;
  --surface3:#18181f;
  --border:rgba(255,255,255,.06);
  --border2:rgba(255,255,255,.1);
  --accent:#8b5cf6;
  --accent2:#a78bfa;
  --accent-dim:rgba(139,92,246,.12);
  --accent-glow:rgba(139,92,246,.25);
  --text:#f4f4f7;
  --text2:#9898b0;
  --text3:#555568;
  --green:#34d399;
  --red:#f87171;
  --yellow:#fbbf24;
  --r:12px;
  --r2:8px;
}

html{scroll-behavior:smooth}

body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-height:100vh;
}

.hidden{display:none!important}

/* ---- BG ---- */
.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:60px 60px;
}

.bg-glow{
  position:fixed;border-radius:50%;pointer-events:none;z-index:0;
  filter:blur(120px);opacity:.18;
}
.bg-glow-1{width:600px;height:600px;background:#8b5cf6;top:-200px;left:-150px;animation:glow 20s ease infinite alternate}
.bg-glow-2{width:500px;height:500px;background:#6366f1;bottom:-200px;right:-100px;animation:glow 16s ease infinite alternate-reverse}

@keyframes glow{0%{transform:translate(0,0) scale(1)}100%{transform:translate(30px,20px) scale(1.08)}}

/* ---- NAV ---- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(5,5,7,.75);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}

.nav-inner{
  max-width:800px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;
}

.nav-brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:.95rem;letter-spacing:-.03em}
.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent-glow)}

.nav-right{display:flex;align-items:center;gap:8px}

.usage-pill{
  font-size:.7rem;font-weight:600;
  padding:4px 10px;border-radius:20px;
  background:var(--surface2);border:1px solid var(--border);
  color:var(--text2);
}

.btn-upgrade-sm{
  font-size:.65rem;font-weight:700;letter-spacing:.06em;
  padding:5px 12px;border-radius:6px;border:none;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);
  color:#fff;cursor:pointer;
  transition:box-shadow .2s;
}
.btn-upgrade-sm:hover{box-shadow:0 0 16px var(--accent-glow)}

.btn-settings-nav{
  font-size:1rem;background:none;border:1px solid var(--border);
  color:var(--text2);cursor:pointer;padding:4px 8px;border-radius:6px;
  transition:all .2s;
}
.btn-settings-nav:hover{color:var(--accent2);border-color:var(--accent)}

.cookie-status{
  font-size:.82rem;font-weight:600;padding:8px 12px;
  border-radius:8px;background:var(--surface2);text-align:center;
  margin:8px 0;
}

/* ---- MAIN ---- */
.main{position:relative;z-index:1;max-width:680px;margin:0 auto;padding:0 20px 80px}
.view{padding-top:32px}

/* ---- HERO ---- */
.hero{text-align:center;margin-bottom:32px}
.hero h1{font-size:2rem;font-weight:900;letter-spacing:-.04em;line-height:1.15}
.gradient-text{background:linear-gradient(135deg,#c4b5fd,#8b5cf6,#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{color:var(--text3);font-size:.88rem;margin-top:10px}

/* ---- INPUT CARD ---- */
.input-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  padding:24px;
}

.url-bar{
  display:flex;align-items:center;gap:0;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:4px 4px 4px 14px;
  transition:border-color .25s,box-shadow .25s;
}
.url-bar:focus-within{border-color:rgba(139,92,246,.4);box-shadow:0 0 0 3px var(--accent-dim)}

.url-icon-wrap{width:18px;height:18px;color:var(--text3);flex-shrink:0}
.url-icon-wrap svg{width:18px;height:18px}

.url-bar input{
  flex:1;background:none;border:none;outline:none;
  color:var(--text);font-family:inherit;font-size:.88rem;
  padding:10px 12px;
}
.url-bar input::placeholder{color:var(--text3)}

.btn-go{
  width:42px;height:42px;border-radius:10px;border:none;flex-shrink:0;
  background:var(--accent);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.btn-go svg{width:18px;height:18px}
.btn-go:hover{background:#7c4ddb;box-shadow:0 0 20px var(--accent-glow);transform:scale(1.05)}
.btn-go:active{transform:scale(.97)}

.or-divider{
  display:flex;align-items:center;margin:20px 0;color:var(--text3);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;
}
.or-divider::before,.or-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.or-divider span{padding:0 14px}

.drop-zone{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:28px;border-radius:var(--r);cursor:pointer;
  border:1.5px dashed var(--border);
  transition:all .25s;color:var(--text3);
}
.drop-zone svg{width:28px;height:28px}
.drop-zone span{font-size:.82rem}
.drop-zone:hover,.drop-zone.dragover{border-color:var(--accent);background:var(--accent-dim)}

.batch-zone{margin-top:16px}
.batch-zone textarea{
  width:100%;background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--r2);color:var(--text);font-family:inherit;font-size:.82rem;
  padding:12px;resize:vertical;outline:none;
}
.batch-zone textarea:focus{border-color:rgba(139,92,246,.4)}

.link-btn{
  display:block;margin-top:14px;background:none;border:none;
  color:var(--text3);font-family:inherit;font-size:.78rem;cursor:pointer;
  text-align:center;width:100%;transition:color .2s;
}
.link-btn:hover{color:var(--text2)}

/* ---- LOADING ---- */
.loader-wrap{text-align:center;padding:60px 20px}
.loader-wrap p{color:var(--text2);font-size:.88rem;margin-bottom:8px}

.pulse-loader{display:flex;justify-content:center;gap:6px;margin-bottom:20px}
.pulse-loader div{
  width:10px;height:10px;border-radius:50%;background:var(--accent);
  animation:pulse .8s ease-in-out infinite;
}
.pulse-loader div:nth-child(2){animation-delay:.15s}
.pulse-loader div:nth-child(3){animation-delay:.3s}
@keyframes pulse{0%,100%{transform:scale(.6);opacity:.4}50%{transform:scale(1);opacity:1}}

.prog-track{width:100%;max-width:280px;height:3px;background:var(--surface3);border-radius:2px;margin:0 auto;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;transition:width .4s;width:0}
.prog-ind{width:30%;animation:ind 1.3s ease-in-out infinite}
@keyframes ind{0%{transform:translateX(-120%)}100%{transform:translateX(430%)}}

/* ---- EDITOR ---- */
.editor{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
}

.player-wrap{background:#000;width:100%;overflow:hidden}
.player-wrap video{width:100%;display:block;max-height:360px;object-fit:contain;background:#000}
/* Vertical video (9:16 etc) — taller player, no wasted black bars */
.player-wrap.vertical{max-width:340px;margin:0 auto}
.player-wrap.vertical video{max-height:560px}
/* Square-ish */
.player-wrap.square{max-width:440px;margin:0 auto}
.player-wrap.square video{max-height:440px}

/* Panel */
.panel{
  padding:16px 20px;
  border-bottom:1px solid var(--border);
}
.panel.mini{
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:14px 16px;
}
.panel-head{
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--text2);margin-bottom:10px;display:flex;align-items:center;gap:6px;
}
.ph-icon{color:var(--accent);font-style:normal}

/* Trim */
.trim-area{padding:8px 0}
.trim-track{
  position:relative;height:32px;
  background:var(--surface3);border-radius:6px;cursor:pointer;
  border:1px solid var(--border);
}
.trim-sel{position:absolute;top:0;height:100%;background:linear-gradient(90deg,rgba(139,92,246,.2),rgba(167,139,250,.18));border-radius:6px;pointer-events:none}
.trim-h{
  position:absolute;top:-3px;width:14px;height:38px;
  background:var(--accent);border-radius:4px;cursor:ew-resize;z-index:2;
  display:flex;align-items:center;justify-content:center;
  transition:box-shadow .15s;
}
.trim-h:hover,.trim-h.dragging{box-shadow:0 0 14px var(--accent-glow)}
.trim-h i{display:block;width:2px;height:12px;background:rgba(255,255,255,.5);border-radius:1px;pointer-events:none}
.playhead{position:absolute;top:0;width:2px;height:100%;background:var(--text);opacity:.5;z-index:1;pointer-events:none;transition:left .06s linear}

.time-row{display:flex;justify-content:space-between;align-items:center;margin-top:10px;gap:8px}
.time-row label{text-align:center}
.time-row label span{display:block;font-size:.6rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-weight:600}
.t-input{
  width:66px;text-align:center;
  background:var(--surface3);border:1px solid var(--border);border-radius:6px;
  color:var(--text);font-family:inherit;font-size:.82rem;padding:5px;outline:none;
}
.t-input:focus{border-color:rgba(139,92,246,.4)}
.clip-dur{font-size:1.05rem;font-weight:800;color:var(--accent2);font-family:'Inter',monospace}

/* Tools grid */
.tools-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  padding:16px 20px;
}

.chip-row{display:flex;gap:5px;flex-wrap:wrap}
.chip{
  flex:1;min-width:0;
  padding:7px 4px;border-radius:7px;
  background:transparent;border:1px solid var(--border);
  color:var(--text2);font-family:inherit;font-size:.72rem;font-weight:500;
  cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center;gap:3px;
}
.chip:hover{border-color:var(--accent);color:var(--text)}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px var(--accent-glow)}

.pro-tag{
  font-size:.55rem;font-weight:700;letter-spacing:.04em;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  color:#000;padding:1px 4px;border-radius:3px;
  line-height:1.2;
}

/* Toggles */
.toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--text2);margin-top:4px}
.sw{position:relative;width:36px;height:20px;flex-shrink:0}
.sw input{opacity:0;width:0;height:0;position:absolute}
.sw-s{
  position:absolute;inset:0;background:var(--surface3);border-radius:10px;cursor:pointer;
  transition:background .25s;
}
.sw-s::after{
  content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;
  background:var(--text3);border-radius:50%;transition:all .25s;
}
.sw input:checked+.sw-s{background:var(--accent)}
.sw input:checked+.sw-s::after{transform:translateX(16px);background:#fff}

/* File buttons */
.file-row{margin-top:8px;display:flex;align-items:center;gap:8px}
.btn-file{
  padding:6px 12px;border-radius:6px;
  background:transparent;border:1px solid var(--border);
  color:var(--text3);font-family:inherit;font-size:.7rem;cursor:pointer;
  transition:all .2s;display:flex;align-items:center;gap:4px;
}
.btn-file:hover{border-color:var(--accent);color:var(--text2)}
.file-name{font-size:.7rem;color:var(--green);font-weight:500}

/* Extra tools row */
.extra-tools-row{
  display:flex;gap:8px;padding:8px 20px;flex-wrap:wrap;
}
.btn-tool{
  flex:1;min-width:0;padding:12px 14px;border-radius:10px;
  background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(99,102,241,.08));
  border:1.5px solid rgba(139,92,246,.35);
  color:var(--accent2);font-family:inherit;font-size:.82rem;font-weight:700;
  cursor:pointer;transition:all .2s;text-align:center;
  letter-spacing:-.01em;
}
.btn-tool:hover{border-color:var(--accent);color:#fff;background:linear-gradient(135deg,rgba(139,92,246,.22),rgba(99,102,241,.15));box-shadow:0 0 16px var(--accent-glow)}
.btn-tool.active{border-color:var(--accent);color:#fff;background:linear-gradient(135deg,var(--accent),#6366f1);box-shadow:0 2px 16px var(--accent-glow)}

/* Manual crop overlay — 8-handle rectangle system */
.player-wrap{position:relative}
.crop-overlay-wrap{position:absolute;inset:0;z-index:10;pointer-events:none;overflow:hidden}

/* SVG dark mask (dims outside the crop rect) */
.crop-mask{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.crop-mask path{fill:rgba(0,0,0,.6)}

/* The crop rectangle — visible border */
.crop-rect{
  position:absolute;
  border:2px solid var(--accent);
  box-shadow:0 0 0 1px rgba(0,0,0,.4),inset 0 0 0 1px rgba(0,0,0,.2);
  pointer-events:auto;cursor:move;
  /* Rule of thirds grid */
  background:
    linear-gradient(to right,transparent 33%,rgba(255,255,255,.12) 33%,rgba(255,255,255,.12) calc(33% + 1px),transparent calc(33% + 1px),transparent 66%,rgba(255,255,255,.12) 66%,rgba(255,255,255,.12) calc(66% + 1px),transparent calc(66% + 1px)),
    linear-gradient(to bottom,transparent 33%,rgba(255,255,255,.12) 33%,rgba(255,255,255,.12) calc(33% + 1px),transparent calc(33% + 1px),transparent 66%,rgba(255,255,255,.12) 66%,rgba(255,255,255,.12) calc(66% + 1px),transparent calc(66% + 1px));
}

/* 8 handles — corner + side */
.crop-handle{
  position:absolute;width:18px;height:18px;
  background:var(--accent);border:2px solid #fff;border-radius:3px;
  pointer-events:auto;z-index:14;
  transition:transform .1s,box-shadow .1s;
}
.crop-handle:hover,.crop-handle.dragging{
  transform:scale(1.25);box-shadow:0 0 12px var(--accent-glow);
}

/* Corners */
.crop-h-tl{top:-9px;left:-9px;cursor:nwse-resize}
.crop-h-tr{top:-9px;right:-9px;cursor:nesw-resize}
.crop-h-bl{bottom:-9px;left:-9px;cursor:nesw-resize}
.crop-h-br{bottom:-9px;right:-9px;cursor:nwse-resize}

/* Sides */
.crop-h-t{top:-9px;left:50%;transform:translateX(-50%);cursor:ns-resize;width:32px;height:12px;border-radius:6px}
.crop-h-b{bottom:-9px;left:50%;transform:translateX(-50%);cursor:ns-resize;width:32px;height:12px;border-radius:6px}
.crop-h-l{left:-9px;top:50%;transform:translateY(-50%);cursor:ew-resize;width:12px;height:32px;border-radius:6px}
.crop-h-r{right:-9px;top:50%;transform:translateY(-50%);cursor:ew-resize;width:12px;height:32px;border-radius:6px}

.crop-h-t:hover,.crop-h-b:hover{transform:translateX(-50%) scaleY(1.3)}
.crop-h-l:hover,.crop-h-r:hover{transform:translateY(-50%) scaleX(1.3)}

.crop-info-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 20px}
.crop-dims{font-size:.72rem;color:var(--accent2);font-weight:600;font-family:monospace}

/* Share row */
.share-row{padding:0 20px 16px;text-align:center}
.btn-share{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 20px;border-radius:8px;border:none;
  background:var(--surface2);border:1px solid var(--border);
  color:var(--text2);font-family:inherit;font-size:.78rem;font-weight:600;
  cursor:pointer;transition:all .2s;
}
.btn-share:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}

/* Action row */
.act-row{display:flex;gap:10px;padding:16px 20px}

.btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:6px;
  padding:13px 20px;border-radius:10px;border:none;
  font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;
  transition:all .2s;
}
.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}
.btn-accent{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff}
.btn-accent:hover{box-shadow:0 4px 24px var(--accent-glow);transform:translateY(-1px)}
.btn-accent:active{transform:translateY(0)}
.btn-full{width:100%}

.btn-sm{
  padding:8px 16px;border-radius:8px;border:none;
  background:var(--accent);color:#fff;font-family:inherit;font-size:.8rem;font-weight:600;
  cursor:pointer;margin-top:8px;transition:all .2s;
}
.btn-sm:hover{box-shadow:0 0 16px var(--accent-glow)}

/* ---- PREVIEW ---- */
.preview-card{
  background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;
}
.meta-text{text-align:center;color:var(--text3);font-size:.78rem;padding:12px 20px 0}

/* ---- MODAL ---- */
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px)}
.modal-box{
  position:relative;background:var(--surface);border:1px solid var(--border);
  border-radius:20px;padding:36px;max-width:380px;width:90%;text-align:center;
}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text3);font-size:1.4rem;cursor:pointer}
.modal-badge{
  display:inline-block;margin-bottom:16px;
  font-size:.7rem;font-weight:800;letter-spacing:.1em;
  padding:6px 16px;border-radius:8px;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;
}
.modal-box h2{font-size:1.3rem;font-weight:800;margin-bottom:6px}
.modal-box>p{color:var(--text2);font-size:.85rem;margin-bottom:20px}
.pro-features{list-style:none;text-align:left;margin-bottom:24px}
.pro-features li{
  padding:8px 0;border-bottom:1px solid var(--border);
  font-size:.82rem;color:var(--text2);
}
.pro-features li:last-child{border-bottom:none}
.modal-note{margin-top:12px;font-size:.7rem;color:var(--text3)}

/* ---- TOAST ---- */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:200;
  background:rgba(248,113,113,.1);backdrop-filter:blur(16px);
  border:1px solid rgba(248,113,113,.2);color:#fca5a5;
  padding:10px 18px;border-radius:12px;font-size:.82rem;
  display:flex;align-items:center;gap:10px;
  animation:toastIn .25s ease;
}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.toast-x{background:none;border:none;color:#fca5a5;font-size:1.1rem;cursor:pointer;margin-left:4px}

/* ---- PWA INSTALL BANNER ---- */
.install-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:150;
  padding:12px 16px;
  background:rgba(12,12,16,.92);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-top:1px solid var(--border2);
  animation:slideUp .35s ease;
}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}

.install-banner-inner{
  max-width:680px;margin:0 auto;
  display:flex;align-items:center;gap:12px;
}

.install-icon{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);
  display:flex;align-items:center;justify-content:center;
}
.install-icon svg{width:20px;height:20px;color:#fff}

.install-text{display:flex;flex-direction:column;flex:1;min-width:0}
.install-text strong{font-size:.85rem;font-weight:700;color:var(--text);line-height:1.2}
.install-text span{font-size:.72rem;color:var(--text3);margin-top:1px}

.btn-install{
  padding:8px 18px;border-radius:8px;border:none;flex-shrink:0;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);
  color:#fff;font-family:inherit;font-size:.78rem;font-weight:700;cursor:pointer;
  transition:all .2s;
}
.btn-install:hover{box-shadow:0 0 20px var(--accent-glow);transform:scale(1.03)}

.install-dismiss{
  background:none;border:none;color:var(--text3);font-size:1.3rem;cursor:pointer;
  padding:4px;margin-left:4px;flex-shrink:0;transition:color .2s;
}
.install-dismiss:hover{color:var(--text)}

/* Nav install button */
.btn-install-nav{
  display:flex;align-items:center;gap:4px;
  font-size:.65rem;font-weight:700;letter-spacing:.04em;
  padding:5px 12px;border-radius:6px;border:none;
  background:var(--surface2);border:1px solid var(--accent);
  color:var(--accent2);cursor:pointer;
  transition:all .2s;
}
.btn-install-nav svg{flex-shrink:0}
.btn-install-nav:hover{background:var(--accent-dim);box-shadow:0 0 14px var(--accent-glow)}

/* PWA standalone mode — hide install elements */
@media(display-mode:standalone){
  .install-banner,.btn-install-nav{display:none!important}
}

/* Safe area insets for iOS standalone */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .install-banner{padding-bottom:calc(12px + env(safe-area-inset-bottom))}
  body{padding-bottom:env(safe-area-inset-bottom)}
}

/* ---- RESPONSIVE ---- */
@media(max-width:520px){
  .main{padding:0 14px 60px}
  .hero h1{font-size:1.5rem}
  .tools-grid{grid-template-columns:1fr}
  .act-row{flex-direction:column;padding:12px 16px}
  .btn{flex:unset;width:100%}
  .nav-inner{padding:12px 16px}
}
