/* ===== FORM FIELDS ===== */
.form-group{margin-bottom:18px}
.form-group label{
  display:block;font-size:10px;font-weight:800;
  letter-spacing:1.4px;text-transform:uppercase;
  color:var(--t3);margin-bottom:8px;
}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:13px 16px;
  background:var(--input-bg);
  border:1.5px solid var(--border);
  border-radius:var(--r2);
  color:var(--t1);font-size:14px;font-family:var(--f);
  transition:border-color .2s,box-shadow .2s,background .2s;
  outline:none;
}
.form-group input::placeholder{color:var(--t3)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--gold);
  background:var(--input-focus);
  box-shadow:0 0 0 3px var(--gold-d);
}
.form-group select{color-scheme:light dark}
.form-group select option{background:var(--card);color:var(--t1)}

/* ===== BUTTONS ===== */
.btn-primary{
  width:100%;padding:14px;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-l) 100%);
  color:#FFF;border:none;border-radius:var(--r2);
  font-size:14px;font-weight:800;font-family:var(--f);
  letter-spacing:.5px;cursor:pointer;
  box-shadow:0 4px 18px var(--gold-glow);
  transition:transform .2s,box-shadow .2s;
}
body.dark-mode .btn-primary{color:#0b1a2a}
.btn-primary:hover{
  transform:translateY(-1px);
  background:var(--gold-l);
  box-shadow:0 8px 28px var(--gold-glow);
}
.btn-primary:active{transform:translateY(0)}

.btn-secondary{
  background:var(--over-h);color:var(--t2);
  border:1px solid var(--border);padding:7px 14px;
  border-radius:var(--r1);cursor:pointer;
  font-size:12px;font-weight:700;font-family:var(--f);
  transition:var(--transition);
}
.btn-secondary:hover{background:var(--over);color:var(--t1);border-color:var(--border-s)}

.doc-toggle-btn{
  background:transparent;color:var(--t3);border:none;
  padding:8px 18px;font-size:13px;font-weight:600;
  font-family:var(--f);cursor:pointer;transition:all .2s var(--ease);
  position:relative;
}
.doc-toggle-btn:hover{color:var(--t1);}
.doc-toggle-btn.active{color:var(--gold);background:var(--gold-d);}
.doc-toggle-badge{
  display:inline-block;margin-left:8px;min-width:18px;padding:1px 6px;
  font-size:11px;font-weight:700;line-height:1.5;
  background:var(--red,#c42b22);color:#fff;border-radius:9px;
  vertical-align:middle;
}

.btn-danger{
  background:var(--red-d);color:var(--red);
  border:1px solid rgba(196,43,34,.28);padding:7px 14px;
  border-radius:var(--r1);cursor:pointer;
  font-size:12px;font-weight:700;font-family:var(--f);
  transition:var(--transition);
}
.btn-danger:hover{background:rgba(196,43,34,.18)}

.btn-accent{
  background:var(--gold-d);color:var(--gold);
  border:1px solid rgba(196,162,78,.28);
  padding:8px 18px;border-radius:var(--r1);cursor:pointer;
  font-size:12px;font-weight:800;font-family:var(--f);
  letter-spacing:.3px;transition:var(--transition);
}
.btn-accent:hover{background:rgba(196,162,78,.2);box-shadow:0 0 12px var(--gold-glow)}

/* ===== iOS INSTALL BANNER (PWA add-to-home-screen prompt) =====
   Top sticky banner shown only to iOS Safari users since Apple blocks
   beforeinstallprompt. Hidden by default; .show flips display + triggers
   the slide-down animation. Snoozes 30 days on dismiss. */
.ios-install-banner{
  position:fixed;left:12px;right:12px;z-index:10000;
  max-width:480px;margin:0 auto;
  background:var(--card);
  border-radius:14px;
  box-shadow:0 8px 28px rgba(0,0,0,.18),0 1px 0 rgba(255,255,255,.04) inset;
  border:1px solid var(--border-s,var(--border));
  padding:12px 14px;
  display:none;
  font-family:var(--f);
}
.ios-install-banner.show{display:block}
.ios-install-banner-top{
  top:8px;
  animation:iosBannerSlideDown .35s cubic-bezier(.2,.9,.3,1);
}
@keyframes iosBannerSlideDown{
  from{transform:translateY(-130%);opacity:0}
  to{transform:translateY(0);opacity:1}
}
.ios-install-content{
  display:flex;gap:12px;align-items:center;
}
.ios-install-icon{
  flex-shrink:0;width:42px;height:42px;
  border-radius:10px;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-l) 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(196,162,78,.28);
  overflow:hidden;
}
.ios-install-icon img{width:30px;height:30px;filter:brightness(0) invert(1)}
.ios-install-text{flex:1;min-width:0}
.ios-install-title{
  font-weight:700;font-size:14px;color:var(--t1);
  margin:0;line-height:1.3;
}
.ios-install-hint{
  font-size:12px;color:var(--t2);
  margin-top:2px;line-height:1.4;
}
.ios-install-share-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:5px;
  background:rgba(0,122,255,.13);color:#007AFF;
  font-size:13px;font-weight:700;
  vertical-align:middle;margin:0 1px;line-height:1;
}
.ios-install-actions{
  display:flex;gap:6px;align-items:center;flex-shrink:0;
}
.ios-install-forever{
  font-size:11px;font-weight:600;font-family:var(--f);
  padding:6px 10px;border-radius:8px;
  border:1px solid var(--border-s,var(--border));
  background:var(--card);color:var(--t2);
  cursor:pointer;white-space:nowrap;
  transition:background .15s,color .15s;
}
.ios-install-forever:hover{background:var(--surface);color:var(--t1)}
.install-banner-action{
  font-size:12px;font-weight:700;font-family:var(--f);
  padding:7px 14px;border-radius:8px;
  border:none;cursor:pointer;white-space:nowrap;color:#FFF;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-l) 100%);
  box-shadow:0 2px 8px rgba(196,162,78,.32);
  transition:transform .15s,box-shadow .15s;
}
.install-banner-action:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(196,162,78,.4)}
.install-banner-action:active{transform:translateY(0)}
.ios-install-dismiss{
  width:30px;height:30px;flex-shrink:0;
  border:none;background:transparent;
  color:var(--t3);font-size:22px;line-height:1;
  border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f);
}
.ios-install-dismiss:hover{background:var(--surface);color:var(--t1)}

