:root{
  --primary:#ff00cc;
  --secondary:#333399;
  --accent:#00ffff;

  --glass-bg:rgba(255,255,255,0.10);
  --glass-border:rgba(255,255,255,0.18);

  --text-main:#ffffff;
  --text-muted:#e0e0e0;

  --font-heading:'Fredoka',sans-serif;
  --font-body:'Nunito',sans-serif;

  --shadow:0 8px 32px rgba(0,0,0,0.37);
  --radius:20px;

  --panel-bg:rgba(12,12,22,0.86);
  --panel-border:rgba(255,255,255,0.14);

  --safe:#2ecc71;
  --danger:#e74c3c;
}

*{margin:0;padding:0;box-sizing:border-box;}

body{
  font-family:var(--font-body);
  background:linear-gradient(to right,#24243e,#302b63,#0f0c29);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  color:var(--text-main);
  overflow-x:hidden;
  position:relative;
}

button:focus-visible,select:focus-visible,input:focus-visible{
  outline:2px solid rgba(0,255,255,0.85);
  outline-offset:3px;
  border-radius:12px;
}

/* Background Blobs */
.background-blobs{position:absolute;inset:0;overflow:hidden;z-index:-1;pointer-events:none;}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.6;animation:float 10s infinite ease-in-out alternate;}
.blob-1{width:50vw;height:50vw;background:var(--primary);top:-10%;left:-10%;}
.blob-2{width:40vw;height:40vw;background:var(--secondary);bottom:10%;right:-10%;animation-delay:-5s;}
.blob-3{width:30vw;height:30vw;background:var(--accent);bottom:20%;left:30%;animation-duration:15s;}
@keyframes float{0%{transform:translate(0,0);}100%{transform:translate(30px,50px);}}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .blob{animation:none!important;}
  .fade-in,.toast{animation:none!important;}
  .fav-drawer,.drawer-backdrop,.install-sheet{transition:none!important;}
  .skeleton-line::after{animation:none!important;}
}

/* ✅ UUID Chip (top-right) */
.uuid-chip{
  position:fixed;
  top:14px;
  right:14px;
  z-index:10005;

  display:inline-flex;
  align-items:center;
  gap:10px;

  border-radius:999px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(10,10,18,0.35);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);

  padding:8px 12px;
  color:rgba(255,255,255,0.82);

  cursor:pointer;
  user-select:none;

  opacity:0.35;
  transform:translateY(0);
  transition:opacity .18s ease, transform .18s ease, border-color .18s ease, background .18s ease;
  box-shadow:0 12px 30px rgba(0,0,0,0.25);
}

.uuid-chip i{
  color:rgba(0,255,255,0.85);
  filter:drop-shadow(0 0 12px rgba(0,255,255,0.12));
}

.uuid-chip-text{
  font-weight:900;
  font-size:0.82rem;
  letter-spacing:.3px;
  white-space:nowrap;
}

@media (hover:hover) and (pointer:fine){
  .uuid-chip:hover{
    opacity:0.78;
    transform:translateY(-1px);
    border-color:rgba(0,255,255,0.25);
    background:rgba(10,10,18,0.55);
  }
}

.uuid-chip:active{
  transform:scale(0.98);
  opacity:0.9;
}

/* Layout */
.main-wrapper{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:20px;
  width:100%;
}
header{text-align:center;margin-bottom:2vh;}
header h1{
  font-family:var(--font-heading);
  font-size:clamp(2rem,5vw,4rem);
  margin-bottom:0.5rem;
  text-shadow:0 0 10px rgba(255,0,204,0.5);
}
.subtitle{
  font-size:clamp(0.9rem,2vw,1.2rem);
  color:var(--text-muted);
  letter-spacing:1px;
}

.container{
  width:90%;
  z-index:10;
  display:flex;
  flex-direction:column;
  gap:20px;
}
@media (min-width:768px){.container{width:70%;}}
@media (min-width:1024px){.container{width:50%;max-width:900px;}}

/* Card */
.glass-card{
  background:var(--glass-bg);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,3rem);
  box-shadow:var(--shadow);
  min-height:40vh;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:transform .3s ease, box-shadow .3s ease;
}
@media (hover:hover) and (pointer:fine){
  .glass-card:hover{
    transform:translateY(-5px);
    box-shadow:0 12px 40px rgba(0,0,0,0.5);
  }
}

.card-header{
  display:flex;
  justify-content:space-between;
  margin-bottom:1.5rem;
  flex-wrap:wrap;
  gap:10px;
}
.badge{
  padding:5px 12px;
  border-radius:999px;
  font-size:0.8rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.5px;
}
.category-badge{
  background:rgba(0,255,255,0.2);
  color:var(--accent);
  border:1px solid var(--accent);
}
.safety-badge{transition:all .25s ease;}
.safety-safe{
  background:rgba(46,204,113,0.2);
  color:var(--safe);
  border:1px solid var(--safe);
}
.safety-danger{
  background:rgba(231,76,60,0.2);
  color:var(--danger);
  border:1px solid var(--danger);
}

/* Joke text */
.joke-content{
  font-size:clamp(1.2rem,3vw,1.85rem);
  line-height:1.6;
  margin-bottom:1.5rem;
  flex-grow:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.joke-setup{font-weight:900;color:var(--accent);margin-bottom:1rem;}
.joke-delivery{font-weight:400;color:var(--text-main);}
.joke-single{font-weight:800;}

.flags-container{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  min-height:30px;
}
.flag-item{
  font-size:0.75rem;
  background:rgba(255,255,255,0.10);
  padding:4px 10px;
  border-radius:10px;
  color:#ffcc00;
  display:flex;
  align-items:center;
  gap:6px;
}

/* Controls */
.controls-wrapper{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
  gap:12px;
}
.button-group{
  display:flex;
  gap:15px;
  align-items:center;
  justify-content:center;
  width:100%;
  flex-wrap:wrap;
}

/* Main button */
.glow-on-hover{
  flex:1;
  max-width:300px;
  height:60px;
  border:none;
  outline:none;
  color:#fff;
  background:#111;
  cursor:pointer;
  position:relative;
  z-index:0;
  border-radius:12px;
  font-size:1.2rem;
  font-family:var(--font-heading);
  letter-spacing:1px;
  transition:transform .1s;
}
.glow-on-hover:before{
  content:'';
  background:linear-gradient(45deg,#ff0000,#ff7300,#fffb00,#48ff00,#00ffd5,#002bff,#7a00ff,#ff00c8,#ff0000);
  position:absolute;
  top:-2px;left:-2px;
  background-size:400%;
  z-index:-1;
  filter:blur(5px);
  width:calc(100% + 4px);
  height:calc(100% + 4px);
  animation:glowing 20s linear infinite;
  opacity:0;
  transition:opacity .3s ease-in-out;
  border-radius:12px;
}
.glow-on-hover:active{color:#000;transform:scale(0.95);}
.glow-on-hover:active:after{background:transparent;}
@media (hover:hover) and (pointer:fine){
  .glow-on-hover:hover:before{opacity:1;}
}
.glow-on-hover:after{
  z-index:-1;
  content:'';
  position:absolute;
  width:100%;
  height:100%;
  background:#111;
  left:0;top:0;
  border-radius:12px;
}
@keyframes glowing{
  0%{background-position:0 0;}
  50%{background-position:400% 0;}
  100%{background-position:0 0;}
}

/* Icon buttons */
.copy-container{position:relative;display:inline-block;}
.copy-btn{
  width:60px;
  height:60px;
  border-radius:12px;
  border:1px solid var(--glass-border);
  background:rgba(255,255,255,0.10);
  color:var(--text-muted);
  font-size:1.5rem;
  cursor:pointer;
  transition:all .25s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
@media (hover:hover) and (pointer:fine){
  .copy-btn:hover{
    background:rgba(255,255,255,0.20);
    color:#fff;
    transform:translateY(-2px);
  }
}
.copy-btn:active{transform:scale(0.95);}
.copy-btn.locked{
  opacity:0.72;
  transform:scale(0.96);
  pointer-events:none;
  cursor:wait !important;
}

/* Save count badge on bookmark */
.save-count-badge{
  position:absolute;
  top:6px;
  right:6px;
  min-width:18px;
  height:18px;
  padding:0 6px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:#fff;
  font-size:0.72rem;
  font-weight:900;
  display:none;
  align-items:center;
  justify-content:center;
  line-height:18px;
  box-shadow:0 8px 20px rgba(0,0,0,0.35);
}
.save-count-badge.show{display:flex;}
.save-count-badge.bump{animation:bump .18s ease;}
@keyframes bump{from{transform:scale(1);}to{transform:scale(1.12);}}

/* Tooltips */
.tooltip-text{
  visibility:hidden;
  width:190px;
  background-color:var(--primary);
  color:#fff;
  text-align:center;
  border-radius:12px;
  padding:8px 10px;
  position:absolute;
  z-index:2;
  bottom:125%;
  left:50%;
  transform:translateX(-50%);
  opacity:0;
  transition:opacity .25s ease;
  font-size:0.85rem;
  font-weight:900;
  pointer-events:none;
}
.tooltip-text::after{
  content:"";
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  border-width:6px;
  border-style:solid;
  border-color:var(--primary) transparent transparent transparent;
}
@media (hover:hover) and (pointer:fine){
  .copy-container:hover .tooltip-text{visibility:visible;opacity:1;}
}

/* Temp message bubble */
.temp-message{
  position:absolute;
  top:-45px;
  background:rgba(0,0,0,0.82);
  padding:6px 16px;
  border-radius:999px;
  font-size:0.9rem;
  opacity:0;
  transform:translateY(10px);
  transition:all .25s ease;
  pointer-events:none;
  white-space:nowrap;
}
.temp-message.show{opacity:1;transform:translateY(0);}

/* Skeleton */
.skeleton-wrap{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:14px;
  align-items:center;
}
.skeleton-line{
  height:16px;
  width:min(560px,92%);
  border-radius:10px;
  background:rgba(255,255,255,0.12);
  position:relative;
  overflow:hidden;
}
.skeleton-line.short{width:min(380px,72%);}
.skeleton-line.tiny{width:min(240px,56%);}
.skeleton-line::after{
  content:"";
  position:absolute;
  inset:0;
  transform:translateX(-120%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);
  animation:shimmer 1.1s infinite;
}
@keyframes shimmer{0%{transform:translateX(-120%);}100%{transform:translateX(120%);}}

/* Toasts */
.toast-host{
  position:fixed;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:9999;
  pointer-events:none;
}
.toast{
  background:rgba(0,0,0,0.75);
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(10px);
  color:#fff;
  padding:10px 14px;
  border-radius:14px;
  font-size:0.95rem;
  min-width:240px;
  text-align:center;
  animation:toastIn .25s ease;
}
@keyframes toastIn{from{opacity:0;transform:translateY(10px) scale(.98);}to{opacity:1;transform:translateY(0) scale(1);}}

/* Fade-in helper */
.fade-in{animation:fadeIn .5s ease-in;}
@keyframes fadeIn{from{opacity:0;transform:scale(.96);}to{opacity:1;transform:scale(1);}}

/* Premium top row controls */
.quick-controls{
  width:100%;
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:14px;
}

/* Category select wrapper */
.select-wrap{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.07);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 10px 30px rgba(0,0,0,0.25);
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
  position:relative;
}
@media (hover:hover) and (pointer:fine){
  .select-wrap:hover{
    transform:translateY(-1px);
    background:rgba(255,255,255,0.10);
    border-color:rgba(0,255,255,0.28);
  }
}
.select-wrap i{
  color:var(--accent);
  opacity:.95;
  font-size:.95rem;
  filter:drop-shadow(0 0 10px rgba(0,255,255,0.15));
}
.select-label{
  font-size:.85rem;
  font-weight:900;
  letter-spacing:.4px;
  color:rgba(255,255,255,0.75);
}
.select-wrap select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  border:none;
  outline:none;
  background:transparent;
  color:var(--text-main);
  font-family:var(--font-body);
  font-weight:900;
  font-size:.95rem;
  line-height:1;
  padding:8px 34px 8px 6px;
  cursor:pointer;
  min-width:160px;
}
.select-wrap::after{
  content:"▾";
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  font-size:.9rem;
  opacity:.75;
  color:var(--text-muted);
  pointer-events:none;
}
.select-wrap select option{color:#111;}
.select-wrap:focus-within{
  border-color:rgba(0,255,255,0.55);
  box-shadow:0 0 0 4px rgba(0,255,255,0.12), 0 10px 30px rgba(0,0,0,0.25);
}

/* Load by ID */
.id-loader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:8px 10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.07);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 10px 30px rgba(0,0,0,0.25);
}
.id-loader-left{
  display:flex;
  align-items:center;
  gap:8px;
}
.id-loader-left i{
  color:#ffd54a;
  filter:drop-shadow(0 0 10px rgba(255,213,74,0.22));
  font-size:.95rem;
}
.id-input{
  width:72px;
  height:34px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.22);
  color:#fff;
  font-weight:900;
  letter-spacing:1px;
  text-align:center;
  font-size:0.95rem;
  padding:0 10px;
}
.id-input::placeholder{color:rgba(255,255,255,0.35);}
.id-hint{
  font-size:.78rem;
  font-weight:900;
  color:rgba(255,255,255,0.70);
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  padding:4px 8px;
  border-radius:999px;
}
.id-load-btn{
  height:34px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid rgba(0,255,255,0.20);
  background:rgba(0,255,255,0.10);
  color:rgba(255,255,255,0.92);
  font-weight:900;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:transform .18s ease, background .18s ease, border-color .18s ease, opacity .18s ease;
}
@media (hover:hover) and (pointer:fine){
  .id-load-btn:hover{
    transform:translateY(-1px);
    background:rgba(0,255,255,0.16);
    border-color:rgba(0,255,255,0.34);
  }
}
.id-load-btn:active{transform:scale(0.97);}
.id-load-btn.loading{
  opacity:0.75;
  pointer-events:none;
  cursor:wait;
}

/* Drawer toggle */
.fav-drawer-toggle{
  position:fixed;
  top:50%;
  left:14px;
  transform:translateY(-50%);
  width:44px;
  height:78px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(10,10,20,0.55);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:rgba(255,255,255,0.9);
  cursor:pointer;
  z-index:10001;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
}
@media (hover:hover) and (pointer:fine){
  .fav-drawer-toggle:hover{
    transform:translateY(-50%) translateX(2px);
    background:rgba(10,10,20,0.70);
    border-color:rgba(0,255,255,0.22);
  }
}
.fav-drawer-toggle i{font-size:1.05rem;}

/* Drawer + backdrop */
.drawer-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.45);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
  z-index:10000;
}
.drawer-backdrop.show{opacity:1;pointer-events:auto;}

.fav-drawer{
  position:fixed;
  top:0;
  left:0;
  height:100%;
  width:min(410px,92vw);
  background:rgba(12,12,22,0.86);
  border-right:1px solid rgba(255,255,255,0.14);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  transform:translateX(-105%);
  transition:transform .25s ease;
  z-index:10002;
  display:flex;
  flex-direction:column;
}
.fav-drawer.open{transform:translateX(0);}

.fav-drawer-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 14px 12px;
  border-bottom:1px solid rgba(255,255,255,0.10);
}
.fav-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-heading);
  font-size:1.15rem;
  letter-spacing:0.5px;
}
.fav-title i{color:#ffd54a;}
.vault-count{
  margin-left:6px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.14);
  padding:3px 10px;
  border-radius:999px;
  font-size:0.78rem;
  font-weight:900;
  color:rgba(255,255,255,0.92);
}
.fav-actions{display:flex;gap:8px;}

.fav-action-btn{
  width:38px;
  height:38px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.08);
  color:rgba(255,255,255,0.92);
  cursor:pointer;
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
  position:relative;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
@media (hover:hover) and (pointer:fine){
  .fav-action-btn:hover{
    transform:translateY(-1px);
    background:rgba(255,255,255,0.12);
    border-color:rgba(0,255,255,0.18);
  }
}
.fav-action-btn .btn-text{display:none;font-weight:900;font-size:0.78rem;letter-spacing:0.3px;}
.fav-action-btn.confirm{
  background:rgba(231,76,60,0.18);
  border-color:rgba(231,76,60,0.25);
}
.fav-action-btn.confirm i{display:none;}
.fav-action-btn.confirm .btn-text{display:inline-block;}

.fav-list{
  padding:12px;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.fav-empty{
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.06);
  border-radius:18px;
  padding:14px;
  text-align:left;
  color:rgba(255,255,255,0.88);
}

.fav-drawer-footer{
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,0.10);
  color:rgba(255,255,255,0.72);
  font-size:0.88rem;
}

/* Saved cards */
.saved-card{
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  border-radius:18px;
  padding:12px;
  position:relative;
}
.saved-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.saved-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 10px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:900;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(0,0,0,0.18);
  color:rgba(255,255,255,0.90);
}
.pill.safe{
  border-color:rgba(46,204,113,0.25);
  background:rgba(46,204,113,0.10);
}
.pill.spicy{
  border-color:rgba(231,76,60,0.25);
  background:rgba(231,76,60,0.10);
}
.pill.cat{
  border-color:rgba(0,255,255,0.22);
  background:rgba(0,255,255,0.10);
}
.saved-id{
  font-size:0.85rem;
  font-weight:900;
  color:rgba(255,255,255,0.78);
  display:flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
}
.saved-del-btn{
  width:36px;
  height:36px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.08);
  color:rgba(255,255,255,0.90);
  cursor:pointer;
  transition:transform .2s ease, background .2s ease, border-color .2s ease, width .2s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  position:relative;
  overflow:hidden;
}
@media (hover:hover) and (pointer:fine){
  .saved-del-btn:hover{
    transform:translateY(-1px);
    background:rgba(255,255,255,0.12);
    border-color:rgba(231,76,60,0.25);
  }
}
.saved-del-btn:active{transform:scale(0.98);}
.saved-del-btn .btn-text{
  display:none;
  font-weight:900;
  font-size:0.78rem;
  letter-spacing:0.2px;
}
.saved-del-btn.confirm{
  width:96px;
  justify-content:center;
  background:rgba(231,76,60,0.18);
  border-color:rgba(231,76,60,0.30);
}
.saved-del-btn.confirm i{display:none;}
.saved-del-btn.confirm .btn-text{display:inline-block;}

.saved-text{
  white-space:pre-wrap;
  font-size:0.98rem;
  line-height:1.5;
  color:rgba(255,255,255,0.92);
}

.saved-flags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.saved-flag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:0.78rem;
  font-weight:900;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  color:#ffcc00;
}

/* Install sheet */
.install-sheet{
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:10020;
  padding:14px;
  opacity:0;
  transform:translateY(16px);
  pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
}
.install-sheet.show{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.install-sheet-inner{
  max-width:980px;
  margin:0 auto;
  border-radius:20px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(10,10,18,0.82);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:0 16px 60px rgba(0,0,0,0.55);
  padding:14px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.install-left{
  display:flex;
  align-items:center;
  gap:12px;
}
.install-icon{
  width:44px;height:44px;
  border-radius:12px;
  box-shadow:0 10px 25px rgba(0,0,0,0.35);
}
.install-title{
  font-family:var(--font-heading);
  font-size:1.08rem;
  letter-spacing:.3px;
}
.install-sub{
  font-size:0.9rem;
  color:rgba(255,255,255,0.72);
}
.install-actions{display:flex;gap:10px;align-items:center;}
.install-btn{
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.10);
  color:#fff;
  font-weight:900;
  padding:10px 14px;
  cursor:pointer;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.install-btn:active{transform:scale(0.98);}
.install-btn.primary{
  border-color:rgba(0,255,255,0.28);
  background:rgba(0,255,255,0.14);
}
.install-btn.ghost{
  background:rgba(255,255,255,0.06);
}
@media (hover:hover) and (pointer:fine){
  .install-btn:hover{
    transform:translateY(-1px);
    background:rgba(255,255,255,0.12);
    border-color:rgba(0,255,255,0.22);
  }
  .install-btn.primary:hover{
    background:rgba(0,255,255,0.18);
    border-color:rgba(0,255,255,0.35);
  }
}

/* Toast animations */
@keyframes toastIn{from{opacity:0;transform:translateY(10px) scale(.98);}to{opacity:1;transform:translateY(0) scale(1);}}

/* ✅ Improved footer */
.site-footer{
  width:100%;
  margin-top:auto;
  padding:18px 14px 22px;
  border-top:1px solid rgba(255,255,255,0.06);
  background:linear-gradient(180deg, rgba(0,0,0,0.30), rgba(0,0,0,0.55));
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.footer-inner{
  max-width:1100px;
  margin:0 auto;
  display:flex;
  gap:18px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
}

.footer-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-heading);
  font-size:1.05rem;
  letter-spacing:.4px;
}

.footer-brand i{
  color:rgba(0,255,255,0.85);
  filter:drop-shadow(0 0 12px rgba(0,255,255,0.12));
}

.footer-sub{
  margin-top:6px;
  color:rgba(255,255,255,0.72);
  font-size:0.92rem;
  line-height:1.35;
}

.footer-right{
  text-align:right;
  min-width:260px;
}

.footer-meta{
  color:rgba(255,255,255,0.74);
  font-size:0.92rem;
  display:flex;
  gap:10px;
  justify-content:flex-end;
  align-items:center;
  flex-wrap:wrap;
}

.footer-meta .dot{
  opacity:0.5;
}

.footer-mini{
  margin-top:8px;
  color:rgba(255,255,255,0.62);
  font-size:0.84rem;
}

@media (max-width:640px){
  .footer-right{ text-align:left; }
  .footer-meta{ justify-content:flex-start; }
}
