/* iosapps.claudepanel.de — verspieltes Public-Frontend */

:root{
  --c-cream:#FFF6EC;
  --c-cream-2:#FFEFD8;
  --c-pink:#FFB1C8;
  --c-peach:#FFB57A;
  --c-mint:#A8E5C8;
  --c-sky:#B9E0FF;
  --c-lilac:#D4B8FF;
  --c-ink:#2A2436;
  --c-ink-soft:#5C5470;
  --c-border:rgba(42,36,54,0.10);
  --shadow-card:0 14px 40px -18px rgba(42,36,54,0.25), 0 2px 6px -2px rgba(42,36,54,0.08);
  --radius:22px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','SF Pro Rounded',system-ui,Roboto,Helvetica,Arial,sans-serif;
  color:var(--c-ink);
  background:
    radial-gradient(ellipse at 12% 0%, var(--c-cream-2) 0%, transparent 55%),
    radial-gradient(ellipse at 95% 15%, #FFE2E9 0%, transparent 55%),
    linear-gradient(180deg, var(--c-cream) 0%, #FFFBF5 100%);
  min-height:100vh;
  overflow-x:hidden;
  font-size:17px;
  line-height:1.55;
  padding-bottom:140px;
}

/* === floating blobs === */
.bg-blobs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:0.55;animation:float 18s ease-in-out infinite}
.b1{width:520px;height:520px;background:var(--c-pink);top:-180px;left:-120px}
.b2{width:420px;height:420px;background:var(--c-mint);top:30%;right:-130px;animation-delay:-4s}
.b3{width:380px;height:380px;background:var(--c-sky);bottom:-120px;left:20%;animation-delay:-8s}
.b4{width:340px;height:340px;background:var(--c-lilac);top:55%;left:5%;animation-delay:-12s;opacity:0.4}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-20px) scale(1.08)}
  66%{transform:translate(-20px,30px) scale(0.95)}
}

/* === layout === */
.page-head, .source-card, .apps-wrap, .page-foot{
  position:relative;z-index:1;
  max-width:980px;margin:0 auto;padding:0 24px;
}

.page-head{padding-top:72px;text-align:center}
.page-head h1{
  font-size:54px;font-weight:800;margin:0 0 8px;
  letter-spacing:-1.5px;
  background:linear-gradient(135deg,#FF7AA8 0%,#FFB57A 50%,#FFD56A 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-head h1 .emoji{
  -webkit-text-fill-color:initial;color:initial;
  display:inline-block;animation:bounce 2.4s ease-in-out infinite;margin-left:8px;
}
@keyframes bounce{
  0%,100%{transform:translateY(0) rotate(-6deg)}
  50%{transform:translateY(-10px) rotate(6deg)}
}
.page-head .sub{
  font-size:18px;color:var(--c-ink-soft);margin:0 auto;max-width:560px;
}

/* === source card === */
.source-card{margin-top:42px}
.source-card-inner{
  background:rgba(255,255,255,0.78);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:22px 26px;
  box-shadow:var(--shadow-card);
}
.source-label{font-weight:600;font-size:14px;color:var(--c-ink-soft);margin-bottom:12px;letter-spacing:0.3px}
.source-row{display:flex;gap:10px;align-items:center}
.source-row input{
  flex:1;border:1.5px solid var(--c-border);background:#fff;border-radius:14px;
  padding:12px 16px;font-size:15px;color:var(--c-ink);font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  outline:none;transition:border-color 0.2s;
}
.source-row input:focus{border-color:var(--c-peach)}
.source-hint{font-size:13px;color:var(--c-ink-soft);margin-top:10px}

/* === buttons === */
.btn{
  font-family:inherit;font-size:15px;font-weight:600;
  border:none;cursor:pointer;
  padding:11px 22px;border-radius:14px;
  transition:transform 0.12s ease, box-shadow 0.2s ease, background 0.2s ease;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(0.98)}
.btn-primary{
  background:linear-gradient(135deg,#FF8FB8 0%,#FFB57A 100%);
  color:#fff;
  box-shadow:0 6px 16px -6px rgba(255,143,184,0.6), inset 0 1px 0 rgba(255,255,255,0.4);
}
.btn-primary:hover{box-shadow:0 10px 22px -8px rgba(255,143,184,0.7), inset 0 1px 0 rgba(255,255,255,0.4)}
.btn-primary:disabled{opacity:0.55;cursor:not-allowed;transform:none}
.btn-ghost{background:transparent;color:var(--c-ink-soft);border:1.5px solid var(--c-border)}
.btn-ghost:hover{background:rgba(42,36,54,0.04);color:var(--c-ink)}
.btn.ok{background:linear-gradient(135deg,#7BD9B0 0%,#A8E5C8 100%);color:#1d4734}

/* === apps section === */
.apps-wrap{margin-top:54px}
.apps-head{display:flex;align-items:baseline;gap:14px;margin-bottom:22px}
.apps-head h2{font-size:28px;font-weight:700;margin:0;letter-spacing:-0.5px}
.apps-count{font-size:14px;color:var(--c-ink-soft);font-weight:500}
.apps-grid{
  display:grid;gap:18px;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
}
.loading, .empty{
  grid-column:1/-1;text-align:center;padding:60px 20px;
  color:var(--c-ink-soft);font-size:16px;
  background:rgba(255,255,255,0.5);border:1.5px dashed var(--c-border);border-radius:var(--radius);
}
.empty .emoji-big{font-size:48px;display:block;margin-bottom:14px}
.empty .empty-hint{font-size:14px;margin-top:8px;opacity:0.8}

/* === app card === */
.app-card{
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:20px;
  box-shadow:var(--shadow-card);
  display:flex;flex-direction:column;gap:14px;
  transition:transform 0.18s ease, box-shadow 0.18s ease;
}
.app-card:hover{transform:translateY(-3px);box-shadow:0 22px 50px -22px rgba(42,36,54,0.32), 0 2px 6px -2px rgba(42,36,54,0.08)}
.app-top{display:flex;gap:14px;align-items:center}
.app-icon{
  width:64px;height:64px;border-radius:16px;
  background:linear-gradient(135deg,#FFD56A,#FF8FB8);
  display:flex;align-items:center;justify-content:center;font-size:30px;
  flex:0 0 64px;
  box-shadow:0 4px 10px -4px rgba(42,36,54,0.25);
  background-size:cover;background-position:center;
}
.app-info{flex:1;min-width:0}
.app-name{font-weight:700;font-size:18px;color:var(--c-ink);margin:0 0 2px;letter-spacing:-0.3px}
.app-sub{font-size:13px;color:var(--c-ink-soft);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.app-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--c-ink-soft)}
.app-meta .chip{background:rgba(42,36,54,0.06);padding:3px 9px;border-radius:999px;font-weight:500}
.app-desc{font-size:14px;color:var(--c-ink-soft);margin:0;line-height:1.5}
.app-actions{display:flex;gap:8px;margin-top:auto}
.app-actions .btn{flex:1;font-size:14px;padding:9px 14px}

/* === FAB (Floating "+" Button) === */
.fab{
  position:fixed;bottom:32px;right:32px;z-index:10;
  width:64px;height:64px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(135deg,#FF7AA8,#FFB57A);
  color:#fff;font-size:34px;font-weight:300;line-height:1;
  box-shadow:0 14px 30px -8px rgba(255,143,184,0.7), 0 4px 10px -2px rgba(42,36,54,0.15);
  display:flex;align-items:center;justify-content:center;
  transition:transform 0.18s ease, box-shadow 0.18s ease;
}
.fab:hover{transform:scale(1.08) rotate(90deg);box-shadow:0 18px 38px -8px rgba(255,143,184,0.8), 0 4px 12px -2px rgba(42,36,54,0.18)}
.fab:active{transform:scale(0.96)}

/* === modal === */
.modal{
  position:fixed;inset:0;z-index:50;
  background:rgba(42,36,54,0.45);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:fadeIn 0.18s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal[hidden]{display:none}
.modal-card{
  background:#fff;border-radius:24px;
  width:100%;max-width:480px;max-height:92vh;overflow:auto;
  padding:32px;position:relative;
  box-shadow:0 32px 80px -16px rgba(42,36,54,0.4);
  animation:popIn 0.22s cubic-bezier(0.4,0,0.2,1);
}
@keyframes popIn{from{transform:scale(0.92);opacity:0}to{transform:scale(1);opacity:1}}
.modal-card h3{font-size:24px;font-weight:700;margin:0 0 6px;letter-spacing:-0.4px}
.modal-sub{color:var(--c-ink-soft);font-size:14px;margin:0 0 22px}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;border-radius:50%;border:none;background:rgba(42,36,54,0.06);
  color:var(--c-ink);font-size:22px;cursor:pointer;line-height:1;
  transition:background 0.15s;
}
.modal-close:hover{background:rgba(42,36,54,0.12)}

/* === form === */
.field{display:block;margin-bottom:14px}
.field .lbl{display:block;font-size:13px;font-weight:600;color:var(--c-ink-soft);margin-bottom:6px}
.field .lbl small{font-weight:500;opacity:0.7;margin-left:4px}
.field input[type="text"],
.field input[type="password"],
.field textarea{
  width:100%;border:1.5px solid var(--c-border);background:#FFF;
  border-radius:12px;padding:11px 14px;font-size:15px;color:var(--c-ink);font-family:inherit;
  outline:none;transition:border-color 0.18s, box-shadow 0.18s;
}
.field input:focus, .field textarea:focus{
  border-color:var(--c-peach);
  box-shadow:0 0 0 4px rgba(255,181,122,0.18);
}
.field textarea{resize:vertical;min-height:74px}
.file-field input[type="file"]{display:none}
.file-field{
  border:1.5px dashed var(--c-border);border-radius:14px;padding:18px;
  background:#FFFBF5;cursor:pointer;text-align:center;
  transition:border-color 0.18s, background 0.18s;
}
.file-field:hover{border-color:var(--c-peach);background:#FFF6EC}
.file-field .lbl{margin-bottom:6px;text-align:center}
.file-name{display:block;font-size:13px;color:var(--c-ink-soft);margin-top:4px;word-break:break-all}

.up-msg{
  padding:12px 14px;border-radius:12px;font-size:14px;margin-bottom:14px;
  background:#FFE2E9;color:#A8334F;border:1px solid #F4B5C4;
}
.up-msg.ok{background:#DFF5E9;color:#1d6e44;border-color:#A8E5C8}

.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.modal-actions .btn{padding:10px 20px}

.progress{margin-top:14px;height:6px;background:rgba(42,36,54,0.08);border-radius:999px;overflow:hidden}
.progress .bar{height:100%;width:0%;background:linear-gradient(90deg,#FF8FB8,#FFB57A);transition:width 0.18s ease}

/* === footer === */
.page-foot{
  margin-top:60px;text-align:center;color:var(--c-ink-soft);font-size:13px;opacity:0.7;
}

/* === mobile === */
@media (max-width:640px){
  body{font-size:16px;padding-bottom:120px}
  .page-head{padding-top:48px}
  .page-head h1{font-size:42px}
  .page-head .sub{font-size:16px}
  .source-row{flex-direction:column;align-items:stretch}
  .source-row .btn{width:100%}
  .apps-grid{grid-template-columns:1fr}
  .fab{width:56px;height:56px;bottom:20px;right:20px;font-size:28px}
  .modal-card{padding:24px}
}

@media (prefers-reduced-motion:reduce){
  .blob, .page-head h1 .emoji{animation:none}
  .app-card, .fab, .btn, .source-row input{transition:none}
}
