@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400&family=IBM+Plex+Mono:wght@400&display=swap";:root{--color-bg: #161616;--color-surface: #1e1e1e;--color-surface-alt: #222222;--color-border: #333333;--color-text-primary: #f4f0e8;--color-text-secondary: #7a7570;--color-accent: #c8954a;--color-accent-dim: rgba(200, 149, 74, .15);--status-verwendet-bg: #1e1e2e;--status-verwendet-text: #6070a0;--color-error: #a05050;--font-serif: "Cormorant Garamond", Georgia, serif;--font-mono: "IBM Plex Mono", "Courier New", monospace;--transition-fast: .12s ease;--transition-mid: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-mono);background-color:var(--color-bg);background-image:radial-gradient(ellipse at 70% 0%,rgba(200,149,74,.06) 0%,transparent 50%),radial-gradient(ellipse at 10% 85%,rgba(60,80,120,.07) 0%,transparent 45%);color:var(--color-text-primary);min-height:100vh}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;opacity:.04;background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");background-size:180px 180px}@keyframes login-appear{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login{min-height:100vh;display:flex;align-items:center;justify-content:center}.login__box{display:flex;flex-direction:column;gap:1.25rem;width:100%;max-width:340px;padding:0 1.5rem;animation:login-appear .5s ease both}.login__box h1{font-family:var(--font-serif);font-size:4.5rem;font-weight:300;letter-spacing:.08em;text-align:center;color:var(--color-text-primary);line-height:1;margin-bottom:1.5rem}.login__box input{background:transparent;border:none;border-bottom:1px solid var(--color-border);border-radius:0;padding:.6rem 0;font-size:.8rem;font-family:var(--font-mono);color:var(--color-text-primary);letter-spacing:.04em;transition:border-color var(--transition-fast);width:100%}.login__box input::placeholder{color:var(--color-text-secondary);text-transform:uppercase;font-size:.72rem;letter-spacing:.1em}.login__box input:focus{outline:none;border-bottom-color:var(--color-accent)}.login__box button{width:100%;padding:.75rem 1rem;background:var(--color-accent);border:none;border-radius:0;color:#0a0a0a;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;margin-top:.5rem;transition:opacity var(--transition-fast)}.login__box button:hover:not(:disabled){opacity:.85}.login__box button:disabled{opacity:.35;cursor:default}.login__error{font-size:.72rem;color:var(--color-error);text-align:center;letter-spacing:.05em}.app{max-width:1400px;margin:0 auto;padding:2rem 1.5rem 4rem}header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem;padding-bottom:1.25rem;border-bottom:1px solid var(--color-border)}header h1{font-family:var(--font-mono);font-size:.72rem;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:var(--color-text-primary)}.app__actions{display:flex;gap:.75rem;align-items:center}.app__action-btn{background:none;border:1px solid var(--color-border);border-radius:0;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary);cursor:pointer;padding:.35rem .85rem;transition:color var(--transition-fast),border-color var(--transition-fast)}.app__action-btn:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.app__action-btn--active{color:var(--color-accent);border-color:var(--color-accent)}.app__action-btn--upload{background:var(--color-accent);border-color:var(--color-accent);color:#0a0a0a}.app__action-btn--upload:hover{opacity:.85;color:#0a0a0a;border-color:var(--color-accent)}.app__error{font-size:.72rem;color:var(--color-error);margin-bottom:1rem;letter-spacing:.04em}.views{display:flex;gap:1.5rem;margin-bottom:2rem;border-bottom:1px solid var(--color-border);padding-bottom:1rem}.views__tab{background:none;border:none;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-secondary);cursor:pointer;padding:0;transition:color var(--transition-fast)}.views__tab--active{color:var(--color-accent)}.views__tab:hover:not(.views__tab--active){color:var(--color-text-primary)}.upload-area{position:relative}.upload-area--dragging:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:2px dashed var(--color-accent);border-radius:4px;background:var(--color-accent-dim);z-index:10;pointer-events:none}.upload-area__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);z-index:11;pointer-events:none}@keyframes gallery-item-appear{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:2px;margin-top:10px}.gallery__item{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:var(--color-surface);border-radius:5px;animation:gallery-item-appear .4s ease both;animation-delay:calc(var(--i, 0) * 40ms)}.gallery__item img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.94);transition:transform var(--transition-mid),filter var(--transition-mid)}.gallery__item:hover img{transform:scale(1.02);filter:brightness(1)}.gallery__badge{position:absolute;top:.4rem;right:.4rem;font-family:var(--font-mono);font-size:.58rem;letter-spacing:.06em;text-transform:uppercase;padding:.18rem .45rem;border-radius:2px}.gallery__badge--verwendet{background:var(--status-verwendet-bg);color:var(--status-verwendet-text)}.plannings{display:flex;flex-direction:column;gap:1px}.plannings__new{display:flex;gap:.75rem;margin-bottom:2rem;align-items:flex-end}.plannings__new input{flex:1;background:transparent;border:none;border-bottom:1px solid var(--color-border);border-radius:0;padding:.5rem 0;font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-primary);letter-spacing:.04em;transition:border-color var(--transition-fast)}.plannings__new input::placeholder{color:var(--color-text-secondary);text-transform:uppercase;font-size:.72rem;letter-spacing:.1em}.plannings__new input:focus{outline:none;border-bottom-color:var(--color-accent)}.plannings__new button{background:var(--color-accent);border:none;border-radius:0;color:#0a0a0a;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:.5rem 1.25rem;cursor:pointer;white-space:nowrap;transition:opacity var(--transition-fast)}.plannings__new button:hover{opacity:.85}.plannings__empty{font-family:var(--font-mono);font-size:.72rem;color:var(--color-text-secondary);letter-spacing:.06em;padding:2rem 0;text-align:center}.planning{background:var(--color-surface);border:1px solid var(--color-border);padding:1.25rem;transition:opacity var(--transition-mid)}.planning+.planning{margin-top:1px}.planning--completed{opacity:.4}.planning__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.planning__name{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.06em;color:var(--color-text-primary)}.planning__actions{display:flex;gap:.75rem;flex-shrink:0}.planning__btn{background:none;border:none;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;padding:0;transition:color var(--transition-fast)}.planning__btn--complete{color:var(--color-text-secondary)}.planning__btn--complete:hover{color:var(--color-accent)}.planning__btn--delete{color:var(--color-text-secondary)}.planning__btn--delete:hover{color:#c06060}.planning__images{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.planning__thumb{position:relative;width:72px;height:72px;border-radius:3px;overflow:hidden;flex-shrink:0}.planning__thumb img{width:100%;height:100%;object-fit:cover;display:block}.planning__remove{position:absolute;top:2px;right:2px;background:#000000bf;border:none;color:var(--color-text-primary);width:18px;height:18px;border-radius:2px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);font-family:var(--font-mono);padding:0}.planning__thumb:hover .planning__remove{opacity:1}.planning__add{background:none;border:1px dashed var(--color-border);border-radius:3px;width:72px;height:72px;color:var(--color-text-secondary);font-family:var(--font-mono);font-size:.6rem;letter-spacing:.05em;cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast);flex-shrink:0}.planning__add:hover{border-color:var(--color-accent);color:var(--color-accent)}.picker{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e0;display:flex;align-items:center;justify-content:center;z-index:200}.picker__dialog{background:var(--color-surface);border:1px solid var(--color-border);width:90vw;max-width:900px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.picker__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.picker__title{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-secondary)}.picker__close{background:none;border:none;color:var(--color-text-secondary);font-family:var(--font-mono);font-size:1rem;cursor:pointer;padding:0;transition:color var(--transition-fast);line-height:1}.picker__close:hover{color:var(--color-text-primary)}.picker__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));grid-auto-rows:minmax(110px,auto);gap:4px;padding:1rem;overflow-y:auto;align-content:start}.picker__item{position:relative;width:100%;padding-top:100%;overflow:hidden;cursor:pointer;border-radius:3px;border:2px solid transparent;transition:border-color var(--transition-fast)}.picker__item img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.85);transition:filter var(--transition-fast)}.picker__item:hover img{filter:brightness(1)}.picker__item--selected{border-color:var(--color-accent)}.picker__item--selected img{filter:brightness(1)}@keyframes modal-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;display:flex;align-items:center;justify-content:center;z-index:100}.modal__dialog{display:flex;max-width:1100px;width:95vw;max-height:92vh;background:var(--color-surface);border:1px solid var(--color-border);border-radius:0;overflow:hidden;position:relative;animation:modal-in .15s ease both}.modal__close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--color-text-secondary);width:2rem;height:2rem;cursor:pointer;font-size:1.1rem;z-index:10;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);transition:color var(--transition-fast);padding:0}.modal__close:hover{color:var(--color-text-primary)}.modal__nav{position:absolute;top:50%;left:0;right:240px;transform:translateY(-50%);display:flex;justify-content:space-between;padding:0 1rem;pointer-events:none;z-index:10}.modal__nav button{pointer-events:all;background:#0e0e0eb3;border:1px solid var(--color-border);color:var(--color-text-secondary);width:2.25rem;height:2.25rem;border-radius:0;cursor:pointer;font-size:1rem;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast),border-color var(--transition-fast)}.modal__nav button:hover{color:var(--color-text-primary);border-color:var(--color-accent)}.modal__nav button:disabled{opacity:.15;cursor:default}.modal__image{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;min-width:0;background:#0c0c0c}.modal__image img{max-width:100%;max-height:92vh;object-fit:contain;display:block}.modal__meta{width:240px;flex-shrink:0;padding:2.5rem 1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;border-left:1px solid var(--color-border);overflow-y:auto;background:var(--color-surface-alt)}.modal__filename{font-family:var(--font-mono);font-size:.7rem;color:var(--color-text-primary);word-break:break-all;letter-spacing:.03em;line-height:1.5;margin-bottom:1rem}.modal__plannings{flex:1}.modal__plannings-label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:.6rem}.modal__planning-tag{font-family:var(--font-mono);font-size:.72rem;color:var(--color-text-primary);padding:.3rem .5rem;border:1px solid var(--color-border);margin-bottom:4px;letter-spacing:.03em}.modal__planning-tag--completed{opacity:.5;text-decoration:line-through}.modal__plannings-empty{font-family:var(--font-mono);font-size:.68rem;color:var(--color-text-secondary);letter-spacing:.04em}.modal__delete{margin-top:auto;padding:.5rem .75rem;background:none;border:1px solid transparent;color:#804040;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);border-radius:0}.modal__delete:hover{color:#c06060;border-color:#c06060}@media (max-width: 600px){.app{padding:1rem .75rem 3rem}header{margin-bottom:1.25rem}.views{margin-bottom:1.5rem}.gallery{grid-template-columns:repeat(3,1fr);gap:2px}.gallery__item{aspect-ratio:1}.planning__header{flex-direction:column;align-items:flex-start;gap:.5rem}.picker__grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));grid-auto-rows:minmax(90px,auto)}.modal{align-items:flex-end;background:#000000eb}.modal__dialog{flex-direction:column;width:100vw;max-width:100vw;max-height:95vh;border-radius:0;border-bottom:none;border-left:none;border-right:none;animation:none}.modal__image{max-height:45vh;flex:none}.modal__image img{max-height:45vh}.modal__nav{right:0;top:22vh}.modal__meta{width:100%;border-left:none;border-top:1px solid var(--color-border);padding:1rem;flex-direction:row;flex-wrap:wrap;gap:.5rem;overflow-y:auto;max-height:50vh;background:var(--color-surface)}.modal__filename{width:100%;margin-bottom:0}.modal__plannings{width:100%}.modal__delete{width:100%;margin-top:.25rem;text-align:center}.modal__close{top:.5rem;right:.5rem}}
