body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Segoe UI,Roboto,Helvetica Neue,sans-serif;margin:0;overflow-x:hidden;padding:0;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root,:root[data-theme=light]{--bg:#fff5f5;--bg-light:#fee2e2;--text:#1a1a1a;--text-muted:#6b5c5c;--primary:#dc2626;--accent:#ef4444;--border:#dc26261f;--shadow:0 2px 12px #dc26261a;--header-bg:#fff0f0f2;--header-border:#dc26261a}:root[data-theme=dark]{--bg:#000;--bg-light:#1a1a1a;--text:#fff;--text-muted:#aaa;--primary:#ef4444;--accent:#f87171;--border:#ffffff1a;--shadow:0 3px 10px #0000004d;--header-bg:#0a0a0a;--header-border:#ffffff14}*{box-sizing:border-box}#root,body,html{height:100%;margin:0}img{display:block;max-width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff5f5;background:var(--bg);color:#1a1a1a;color:var(--text);font-family:Inter,Segoe UI,Roboto,Helvetica Neue,sans-serif;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:0 2rem}.main-content{flex:1 1;padding:3rem 0}h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#dc2626,#ef4444);background:linear-gradient(135deg,var(--primary) 0,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;letter-spacing:-1px;margin:0 0 1rem}h2{color:#1a1a1a;color:var(--text);font-size:clamp(1.6rem,3.5vw,2.4rem);margin:0 0 .5rem}h2,h3{font-weight:700}h3{font-size:1.2rem}h3,p{margin:0}p{line-height:1.7}.lead{font-size:1.1rem}.lead,.muted{color:#6b5c5c;color:var(--text-muted)}.muted{font-size:.95rem}.btn{border:2px solid #0000;display:inline-flex;font-family:inherit;font-size:1rem;padding:.85rem 1.75rem;text-decoration:none;transition:all .2s ease;white-space:nowrap}.btn.primary{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 12px #dc262633}.btn.primary:hover{box-shadow:0 6px 16px #dc26264d;filter:brightness(1.05)}.btn.primary:active{box-shadow:0 2px 8px #dc262633;transform:scale(.98)}.btn.outline{background:#0000;border-color:#dc2626;border-color:var(--primary);box-shadow:none;color:#dc2626;color:var(--primary)}.btn.outline:hover{background:#dc26260f}.btn.outline:active{transform:scale(.98)}.btn.small{font-size:.9rem}.site-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff0f0f2;background:var(--header-bg);border-bottom:1px solid #dc26261a;border-bottom:1px solid var(--header-border);box-shadow:0 1px 3px #00000014;position:sticky;top:0;z-index:100}.header-inner{gap:2rem;justify-content:space-between;padding:1.2rem 0}.brand,.header-inner{align-items:center;display:flex}.brand{color:#1a1a1a;color:var(--text);font-weight:700;gap:.75rem}.logo{align-items:center;display:flex;height:60px;justify-content:center;width:60px}.logo-img{max-height:100%;max-width:100%;object-fit:contain}.sitename-group{display:flex;flex-direction:column;gap:.2rem}.sitename{font-size:1.1rem;font-weight:700;line-height:1;text-decoration:none;transition:all .3s}:root[data-theme=light] .sitename{color:#1a1a1a;color:var(--text)}:root[data-theme=light] .sitename:hover{color:#dc2626;color:var(--primary)}:root[data-theme=dark] .sitename{color:#1a1a1a;color:var(--text)}:root[data-theme=dark] .sitename:hover{color:#ef4444;color:var(--accent)}.main-nav{align-items:center;display:flex;gap:2rem}.main-nav a{border-bottom:2px solid #0000;color:#6b5c5c;color:var(--text-muted);font-weight:500;text-decoration:none;transition:all .3s}.main-nav a.active,.main-nav a:hover{border-bottom-color:#dc2626;border-bottom-color:var(--primary);color:#dc2626;color:var(--primary)}.header-actions{align-items:center;display:flex;gap:1rem}.login-btn{font-size:.9rem;padding:.6rem 1.2rem}.user-btn,.user-menu{align-items:center;display:flex}.user-btn{background:#fee2e2;background:var(--bg-light);border:2px solid #dc26261f;border:2px solid var(--border);border-radius:30px;cursor:pointer;font-family:inherit;gap:.5rem;padding:.4rem .8rem .4rem .4rem;transition:all .3s ease}.user-btn:hover{background:#dc26260d;border-color:#dc2626;border-color:var(--primary)}.user-avatar-small{align-items:center;background:linear-gradient(135deg,#dc2626,#ef4444);background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:32px;justify-content:center;width:32px}.user-name{color:#1a1a1a;color:var(--text);font-size:.9rem;font-weight:600}.login-prompt{padding:4rem 2rem;text-align:center}.login-prompt h2{margin-bottom:1rem}.login-prompt p{color:#6b5c5c;color:var(--text-muted);margin-bottom:2rem}.theme-toggle{align-items:center;display:flex;gap:.3rem}.theme-toggle button{background:#0000;border:1px solid #dc26261f;border:1px solid var(--border);border-radius:6px;color:#6b5c5c;color:var(--text-muted);cursor:pointer;font-size:.8rem;font-weight:600;padding:.4rem .7rem;transition:all .3s}.theme-toggle button.active{background:#dc2626;background:var(--primary);border-color:#dc2626;border-color:var(--primary);color:#fff}.theme-toggle button:hover{border-color:#dc2626;border-color:var(--primary);color:#dc2626;color:var(--primary)}.hero{display:none}.page-hero{align-items:center;display:flex;height:50vh;justify-content:center;max-height:500px;min-height:350px;overflow:hidden;position:relative;width:100%}.page-hero-compact{height:35vh;max-height:350px;min-height:250px}.page-hero-img{inset:0;position:absolute;z-index:0}.page-hero-img img{display:block;height:100%;object-fit:cover;width:100%}.page-hero-overlay{background:linear-gradient(180deg,#0003 0,#0000008c);inset:0;position:absolute;z-index:1}.page-hero-content{animation:fadeInUp .8s ease-out;color:#fff;padding:2rem;position:relative;text-align:center;z-index:2}.page-hero-tag{font-size:.85rem;font-weight:500;letter-spacing:3px;margin-bottom:1rem;opacity:.8;text-transform:uppercase}.page-hero-title{-webkit-text-fill-color:#fff;background:none;color:#fff;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.1;margin:0 0 1rem;text-shadow:0 2px 30px #0000004d}.page-hero-sub{font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:600px;opacity:.9}.photo-hero{align-items:center;display:flex;height:100vh;justify-content:center;min-height:600px;overflow:hidden;position:relative;width:100%}.photo-hero-img{inset:0;position:absolute;z-index:0}.photo-hero-img img{display:block;height:100%;object-fit:cover;width:100%}.photo-hero-overlay{background:linear-gradient(180deg,#00000026 0,#00000059 50%,#0009);inset:0;position:absolute;z-index:1}.photo-hero-content{animation:fadeInUp 1.2s ease-out;color:#fff;max-width:800px;padding:2rem;position:relative;text-align:center;z-index:2}.hero-logo{animation:fadeInUp .8s ease-out;display:block;filter:brightness(0) invert(1) drop-shadow(0 4px 20px rgba(0,0,0,.3));height:140px;margin:0 auto 1.5rem;object-fit:contain;width:140px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.photo-hero-tag{font-size:.95rem;font-weight:500;letter-spacing:3px;margin-bottom:1.5rem;opacity:.85;text-transform:uppercase}.photo-hero-title{-webkit-text-fill-color:#fff;background:none;color:#fff;font-size:clamp(2.5rem,7vw,5rem);font-weight:800;line-height:1.1;margin:0 0 1.5rem;text-shadow:0 2px 40px #0000004d}.photo-hero-sub{font-size:1.15rem;line-height:1.6;margin-bottom:2.5rem;opacity:.9}.photo-hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.btn-light{background:#fff;border:none;border-radius:50px;box-shadow:0 4px 20px #00000026;color:#1a1a1a;font-size:1rem;font-weight:600;padding:1rem 2.5rem;text-decoration:none;transition:all .3s ease}.btn-light:hover{box-shadow:0 8px 30px #0003;transform:translateY(-2px)}.btn-ghost{background:#0000;border:2px solid #fff9;border-radius:50px;color:#fff;font-size:1rem;font-weight:600;padding:1rem 2.5rem;text-decoration:none;transition:all .3s ease}.btn-ghost:hover{background:#ffffff26;border-color:#fff}.portfolio-section{background:linear-gradient(135deg,#fff5f5,#fee2e2);background:linear-gradient(135deg,var(--bg) 0,var(--bg-light) 100%);padding:5rem 1.5rem}.portfolio-section:nth-child(2n){background:#fff5f5;background:var(--bg)}.portfolio-inner{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1300px}.portfolio-reverse .portfolio-inner{direction:rtl}.portfolio-reverse .portfolio-inner>*{direction:ltr}.portfolio-image img{aspect-ratio:3/4;border-radius:6px;display:block;object-fit:cover;width:100%}.portfolio-text h2{color:#1a1a1a;color:var(--text);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;margin-bottom:1rem}.portfolio-text p{color:#6b5c5c;color:var(--text-muted);font-size:1.1rem;line-height:1.7}@media (max-width:768px){.portfolio-section{padding:3.5rem 1rem}.portfolio-inner{gap:2rem;grid-template-columns:1fr}.portfolio-reverse .portfolio-inner{direction:ltr}.portfolio-image img{aspect-ratio:4/3}}@media (max-width:480px){.portfolio-section{padding:2.5rem .75rem}}.featured-work{margin:0 auto;max-width:1400px;padding:6rem 2rem}.featured-header{margin-bottom:4rem;text-align:center}.featured-header h2{color:#1a1a1a;color:var(--text);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;margin-bottom:.75rem}.featured-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.featured-item{aspect-ratio:1;border-radius:4px;overflow:hidden;position:relative}.featured-item.large{aspect-ratio:auto;grid-column:span 2;grid-row:span 2}.featured-item.wide{aspect-ratio:2/1;grid-column:span 2}.featured-item img{display:block;height:100%;object-fit:cover;transition:transform .6s ease,filter .4s ease;width:100%}.featured-item:hover img{filter:brightness(.9);transform:scale(1.05)}.featured-cta{margin-top:3rem;text-align:center}.about-photographer{background:linear-gradient(180deg,#fee2e2,#fff5f5);background:linear-gradient(180deg,var(--bg-light) 0,var(--bg) 100%);padding:5rem 1.5rem}.about-inner{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1300px}.about-image{aspect-ratio:3/4;border-radius:6px;line-height:0;overflow:hidden}.about-image img{display:block;height:100%;object-fit:cover;width:100%}.about-text h2{font-size:2rem;font-weight:700;margin-bottom:1.5rem}.about-text h2,.about-text p{color:#1a1a1a;color:var(--text)}.about-text p{font-size:1.1rem;line-height:1.8}@media (max-width:768px){.page-hero{height:40vh;min-height:280px}.page-hero-compact{height:30vh;min-height:200px}.page-hero-title{font-size:clamp(1.6rem,6vw,2.5rem)}.photo-hero{height:85vh;min-height:500px}.hero-logo{height:100px;margin:0 auto 1rem;width:100px}.photo-hero-title{font-size:clamp(2rem,8vw,3rem)}.featured-work{padding:4rem 1rem}.featured-grid{gap:.5rem;grid-template-columns:repeat(2,1fr)}.featured-item.large{aspect-ratio:16/9;grid-column:span 2;grid-row:span 1}.featured-item.wide{grid-column:span 2}.about-inner{gap:2rem;grid-template-columns:1fr}.about-image{aspect-ratio:16/9}.about-photographer{padding:4rem 1.5rem}.footer-grid{gap:2rem;grid-template-columns:1fr}}@media (max-width:480px){.photo-hero{height:75vh;min-height:400px}.featured-grid{grid-template-columns:1fr 1fr}.photo-hero-buttons{align-items:center;flex-direction:column}.btn-ghost,.btn-light{max-width:280px;text-align:center;width:100%}.page-hero{height:35vh;min-height:220px}.page-hero-compact{height:25vh;min-height:180px}.contact-content,.impressum-content{padding:2rem 0}}.btn-hero,.hero-buttons{display:none}.btn-primary{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 10px 30px #dc262640;color:#fff}.btn-primary:hover{box-shadow:0 15px 40px #dc262659;transform:translateY(-2px)}:root[data-theme=dark] .btn-primary{box-shadow:0 10px 30px #ef44444d}:root[data-theme=dark] .btn-primary:hover{box-shadow:0 15px 40px #ef444466}.btn-secondary{background:#0000;border:2px solid #dc26261f;border:2px solid var(--border);box-shadow:none;color:#1a1a1a;color:var(--text)}.btn-secondary:hover{background:#dc262614;border-color:#dc2626;border-color:var(--primary);color:#dc2626;color:var(--primary)}:root[data-theme=dark] .btn-secondary:hover{background:#ef44441a}.btn-icon{transition:transform .3s ease}.btn-primary:hover .btn-icon{transform:translateX(4px)}.section-header{animation:slideIn .8s ease;margin-bottom:3rem;text-align:center}.section-header h2{color:#1a1a1a;color:var(--text);margin-bottom:.5rem}.section-header p{color:#6b5c5c;color:var(--text-muted)}.gallery{padding:0}.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0}.photo-card{animation:slideIn .6s ease;background:#fee2e2;background:var(--bg-light);border:1px solid #dc26261f;border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden;transition:all .3s ease}.photo-card:hover{border-color:#dc2626;border-color:var(--primary);box-shadow:0 12px 24px #0000001f;transform:translateY(-6px) scale(1.02)}.photo-placeholder{align-items:center;aspect-ratio:1;background:linear-gradient(135deg,#dc262614,#ef44440a);color:#6b5c5c;color:var(--text-muted);display:flex;font-weight:700;justify-content:center;width:100%}.photo-card img{height:100%;object-fit:cover;width:100%}.photo-card .caption{color:#6b5c5c;color:var(--text-muted);font-size:.95rem;padding:1rem}.services{border-bottom:1px solid #dc26261f;border-bottom:1px solid var(--border);border-top:1px solid #dc26261f;border-top:1px solid var(--border);padding:4rem 0}.service-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:2rem 0}.service-card{animation:slideIn .6s ease;background:#fee2e2;background:var(--bg-light);border:2px solid #dc26261f;border:2px solid var(--border);border-radius:16px;box-shadow:0 4px 12px #00000014;padding:2.5rem 2rem;text-align:center;transition:all .3s ease}.service-card:hover{border-color:#dc2626;border-color:var(--primary);box-shadow:0 16px 40px #dc262633;transform:translateY(-8px) scale(1.02)}.service-icon{font-size:2.5rem;margin-bottom:1rem}.service-card h3{color:#1a1a1a;color:var(--text);font-size:1.3rem;margin:0 0 1rem}.service-card p{color:#6b5c5c;color:var(--text-muted);font-size:1rem;line-height:1.6;margin:.75rem 0}.price{color:#ef4444;color:var(--accent);font-size:1.3rem;font-weight:700;margin:1rem 0}.contact{padding:4rem 0}.contact-social-heading{margin-top:2rem}.form-message{font-weight:600}.form-message-success{color:#10b981}.form-message-error{color:#ef4444}.contact-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fee2e2;background:var(--bg-light);border:2px solid #dc26261f;border:2px solid var(--border);border-radius:12px;padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#1a1a1a;margin-bottom:.5rem}.form-group input,.form-group textarea{background:#fff5f5;border:1px solid #dc26261f;border:1px solid var(--border);border-radius:8px;color:#1a1a1a;padding:.9rem;transition:all .3s}.form-group input:focus,.form-group textarea:focus{background:#fff5f5;background:var(--bg);border-color:#dc2626;box-shadow:0 0 12px #dc262626}.form-actions{display:flex;gap:1rem}.form-actions .btn{flex:1 1}.impressum{padding:3rem 0}.impressum h2{margin-bottom:1rem}.legal{margin-top:2rem}.legal h3{margin-bottom:.75rem;margin-top:1.5rem}.legal p{color:#6b5c5c;color:var(--text-muted);line-height:1.8}.modal-backdrop{background:#03061799;inset:0;padding:1rem}.modal{background:#fee2e2;background:var(--bg-light);border:1px solid #dc26261f;border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px #0006;max-width:500px;width:100%}.modal-header{border-bottom:1px solid #dc26261f;border-bottom:1px solid var(--border);padding:1.5rem}.modal .close{background:#0000;border:0;color:#1a1a1a;color:var(--text);cursor:pointer;font-size:1.5rem;transition:all .3s}.modal .close:hover{color:#ef4444;color:var(--accent)}.modal-body{padding:2rem}.modal-body form{display:flex;flex-direction:column;gap:1.5rem}.modal-body label{display:block;font-weight:600;margin-bottom:.5rem}.modal-body input{background:#ffffff0d;border:1px solid #dc26261f;border:1px solid var(--border);border-radius:8px;color:#1a1a1a;color:var(--text);font-family:inherit;padding:.9rem;width:100%}.dashboard{padding:2rem 0}.dashboard-header{border-bottom:2px solid #dc26261f;border-bottom:2px solid var(--border);margin-bottom:2rem;padding-bottom:1.5rem}.dashboard-header h2{margin:0}.dashboard-card{background:#fee2e2;background:var(--bg-light);border:1px solid #dc26261f;border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 12px #dc26261a;box-shadow:var(--shadow);margin-bottom:2rem;padding:2rem}.dashboard-card h3{color:#dc2626;color:var(--primary);margin-top:0}.profile-info{display:flex;flex-direction:column;gap:.75rem}.profile-info p{color:#1a1a1a;color:var(--text);margin:0}.profile-info strong{display:block;font-size:.85rem;font-weight:500}.empty-state,.profile-info strong{color:#6b5c5c;color:var(--text-muted)}.empty-state{margin:1rem 0}.empty-state a{color:#dc2626}.bookings-list,.invoices-list{display:flex;flex-direction:column;gap:1rem}.booking-item,.invoice-item{align-items:center;background:#ffffff08;border-left:4px solid #dc2626;border-left:4px solid var(--primary);border-radius:8px;display:flex;justify-content:space-between;padding:1.5rem}.booking-info strong,.invoice-info strong{display:block;margin-bottom:.5rem}.booking-info p,.invoice-info p{color:#6b5c5c;color:var(--text-muted);font-size:.9rem;margin:.25rem 0}.booking-status,.invoice-status{align-items:center;display:flex}.status{background:#dc262633;border-radius:20px;color:#dc2626;color:var(--primary);font-size:.85rem;font-weight:600;padding:.5rem 1rem}.status.pending{background:#fbbf2433;color:#fbbf24}.status.completed,.status.confirmed{background:#22c55e33;color:#22c55e}.status.unpaid{background:#ef444433;color:#ef4444}.status.paid{background:#22c55e33;color:#22c55e}.alert{border-left:4px solid;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.alert.error{background:#ef44441a;border-color:#ef4444;color:#ef4444}.modal-tabs{border-bottom:1px solid #dc26261f;border-bottom:1px solid var(--border);gap:1rem;margin-bottom:2rem}.tab{background:#0000;color:#6b5c5c;color:var(--text-muted);font-weight:600;padding:.75rem 1rem;position:relative;transition:all .3s}.tab:hover{color:#1a1a1a;color:var(--text)}.tab.active{color:#dc2626}.tab.active:after{background:#dc2626;background:var(--primary);bottom:-1rem;content:"";height:2px;left:0;position:absolute;right:0}.modal-login .form-group{display:flex;flex-direction:column;gap:.5rem}.modal-login label{font-size:.95rem;font-weight:600}.modal-login input{background:#fee2e2;background:var(--bg-light);border:1px solid #dc26261f;border:1px solid var(--border);border-radius:8px;color:#1a1a1a;color:var(--text);font-family:inherit;padding:.85rem;transition:all .3s}.modal-login input:focus{border-color:#dc2626;border-color:var(--primary);box-shadow:0 0 0 3px #dc26261a;outline:none}.modal-login .message{border-radius:8px;margin-top:1rem;padding:1rem;text-align:center}.modal-login .message.success{background:#22c55e33;color:#22c55e}.modal-login .message.error{background:#ef444433;color:#ef4444}.back-to-login,.forgot-password-link{margin-top:1rem;text-align:center}.link-btn{background:#0000;border:none;color:#dc2626;color:var(--primary);cursor:pointer;font-weight:600;text-decoration:underline;transition:all .3s}.link-btn:hover{color:#ef4444;color:var(--accent);opacity:.8}.link-btn:disabled{cursor:not-allowed;opacity:.5}.forgot-help-text{color:#6b5c5c;color:var(--text-muted);font-size:.9rem;margin:1rem 0;text-align:center}.reset-password{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:2rem 0}.reset-card{background:#fee2e2;background:var(--bg-light);border:1px solid #dc26261f;border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 12px #dc26261a;box-shadow:var(--shadow);max-width:400px;padding:2.5rem;width:100%}.reset-card h2{color:#dc2626;color:var(--primary);margin-top:0;text-align:center}.reset-card .form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.reset-card label{font-size:.95rem;font-weight:600}.reset-card input{background:#fee2e2;background:var(--bg-light);border:1px solid #dc26261f;border:1px solid var(--border);border-radius:8px;color:#1a1a1a;color:var(--text);font-family:inherit;padding:.85rem;transition:all .3s}.reset-card input:focus{border-color:#dc2626;border-color:var(--primary);box-shadow:0 0 0 3px #dc26261a;outline:none}.reset-card .message{border-radius:8px;font-weight:600;margin:1rem 0;padding:1rem;text-align:center}.reset-card .message.success{background:#22c55e33;color:#22c55e}.reset-card .message.error{background:#ef444433;color:#ef4444}.reset-help{border-top:1px solid #dc26261f;border-top:1px solid var(--border);margin-top:2rem;padding-top:2rem;text-align:center}.reset-help p{color:#6b5c5c;color:var(--text-muted);font-size:.9rem;margin:0 0 1rem}.modal-close{background:#0000;color:#1a1a1a;color:var(--text);font-size:1.5rem;right:1rem;top:1rem;transition:all .3s}.modal-close:hover{color:#ef4444;color:var(--accent)}.site-footer{background:#1a1a1a;color:#fff;margin-top:auto;padding:4rem 0 0;width:100%}.footer-grid{grid-gap:3rem;border-bottom:1px solid #ffffff1a;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr;padding-bottom:3rem}.footer-brand{display:flex;flex-direction:column;gap:.5rem}.footer-logo-link{color:#fff!important;font-size:1.3rem;font-weight:700;text-decoration:none;transition:opacity .3s}.footer-logo-link:hover{opacity:.8}.footer-tagline{color:#ffffff80;font-size:.9rem;margin:0}.footer-contact,.footer-nav{display:flex;flex-direction:column;gap:.5rem}.footer-contact h4,.footer-nav h4{color:#fff;font-size:.9rem;font-weight:600;letter-spacing:1px;margin:0 0 .5rem;text-transform:uppercase}.footer-contact a,.footer-nav a{color:#fff9;font-size:.9rem;text-decoration:none;transition:color .3s}.footer-contact a:hover,.footer-nav a:hover{color:#fff}.footer-location{color:#ffffff80;font-size:.85rem;margin-top:.25rem}.footer-bottom{padding:1.5rem 0;text-align:center}.footer-bottom p{color:#fff6;font-size:.85rem;margin:0}.contact-content{padding:4rem 0}.impressum-content{flex:1 1;padding:3rem 0}.impressum-content .legal h3{color:#1a1a1a;color:var(--text);margin-bottom:.75rem;margin-top:2rem}.impressum-content .legal p{color:#6b5c5c;color:var(--text-muted);line-height:1.8}.impressum-content .legal a{color:#dc2626;color:var(--primary);text-decoration:none}@media (max-width:900px){.gallery-grid,.service-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.container{padding:0 1.5rem}.header-inner{flex-wrap:wrap;gap:1rem}.main-nav{border-top:1px solid #dc26261f;border-top:1px solid var(--border);gap:1rem;margin-top:1rem;order:3;padding-top:1rem;width:100%}.hero{min-height:60vh;padding:3rem 1.5rem}.hero-inner{text-align:center}.hero-actions{justify-content:center}.gallery-grid{grid-template-columns:1fr}.section-header{margin-bottom:2rem}.footer-grid{gap:2rem;grid-template-columns:1fr}.footer-inner{flex-direction:column;text-align:center}}@media (max-width:600px){.container{padding:0 1rem}h1{font-size:1.8rem}h2{font-size:1.4rem}.hero{min-height:50vh;padding:2rem 1rem}.hero-actions{flex-direction:column;width:100%}.hero-actions .btn{width:100%}.main-nav{gap:.5rem}.main-nav a{font-size:.9rem}.service-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.modal{width:95%}.modal-body{padding:1.5rem}.footer-inner{gap:1rem}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.login-container{animation:slideIn .3s ease-out;background:#fff5f5;background:var(--bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:40px;width:100%}@media (max-width:600px){.login-container{padding:30px 20px}}.leistungen-content{padding:4rem 0 2rem}.section-intro{margin-bottom:3rem;text-align:center}.section-intro h2{color:var(--text);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;margin-bottom:.5rem}.section-intro p{color:var(--text-muted);font-size:1.05rem}.service-grid-photo{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}.service-card-photo{background:var(--bg-light);border:2px solid var(--border);border-radius:14px;cursor:pointer;overflow:hidden;position:relative;transition:all .35s ease}.service-card-photo:hover{border-color:var(--primary);box-shadow:0 20px 50px #0000001f;transform:translateY(-6px)}.service-card-photo.selected{border-color:var(--primary);box-shadow:0 0 0 3px #dc262626,0 16px 40px #0000001a}.service-card-image{aspect-ratio:16/10;line-height:0;overflow:hidden;position:relative;width:100%}.service-card-image img{display:block;height:100%;object-fit:cover;transition:transform .6s ease;width:100%}.service-card-photo:hover .service-card-image img{transform:scale(1.06)}.service-card-overlay{background:linear-gradient(0deg,#00000040 0,#0000 50%);inset:0;pointer-events:none;position:absolute}.service-selected-badge{background:var(--primary);border-radius:20px;color:#fff;font-size:.8rem;font-weight:700;letter-spacing:.02em;padding:.35rem .9rem;position:absolute;right:1rem;top:1rem;z-index:2}.service-card-body{padding:1.5rem 1.5rem 1.75rem}.service-card-body h3{color:var(--text);font-size:1.25rem;font-weight:700;margin:0 0 .6rem}.service-card-body p{color:var(--text-muted);font-size:.95rem;line-height:1.65;margin:0 0 1rem}.service-tag{background:#dc262614;border-radius:20px;color:var(--primary);display:inline-block;font-size:.8rem;font-weight:600;padding:.35rem .9rem}.anfrage-section{background:linear-gradient(180deg,var(--bg-light) 0,var(--bg) 100%);padding:4rem 0 5rem}.anfrage-layout{grid-gap:3rem;align-items:start;display:grid;gap:3rem;grid-template-columns:1.6fr 1fr}.anfrage-form-wrapper{background:var(--bg);border:1px solid var(--border);border-radius:16px;box-shadow:0 4px 24px #0000000f;padding:2.5rem}.anfrage-header{margin-bottom:2rem}.anfrage-header h2{color:var(--text);font-size:1.6rem;font-weight:700;margin-bottom:.4rem}.anfrage-header p{color:var(--text-muted);font-size:.95rem}.anfrage-form .form-row-2{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.anfrage-form .form-group{margin-bottom:1.25rem}.anfrage-form label{color:var(--text);display:block;font-size:.9rem;font-weight:600;margin-bottom:.4rem}.anfrage-form input,.anfrage-form select,.anfrage-form textarea{appearance:none;background:var(--bg-light);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:.95rem;padding:.85rem 1rem;transition:all .25s ease;width:100%}.anfrage-form select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath fill='%236b7280' d='M1.4 0 6 4.6 10.6 0 12 1.4l-6 6-6-6z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;padding-right:2.5rem}.anfrage-form input:focus,.anfrage-form select:focus,.anfrage-form textarea:focus{background:var(--bg);border-color:var(--primary);box-shadow:0 0 0 3px #dc26261a;outline:none}.anfrage-form input::placeholder,.anfrage-form textarea::placeholder{color:var(--text-muted);opacity:.6}.form-status{border-radius:10px;font-size:.9rem;font-weight:600;margin-bottom:1.25rem;padding:.85rem 1.2rem}.form-status-success{background:#10b9811a;border:1px solid #10b98133;color:#10b981}.form-status-error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}.anfrage-submit{border-radius:12px;font-size:1rem;padding:1rem;width:100%}.anfrage-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:6rem}.sidebar-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;box-shadow:0 2px 12px #0000000a;padding:1.75rem}.sidebar-card h3{border-bottom:1px solid var(--border);color:var(--text);font-size:1rem;font-weight:700;margin:0 0 1.25rem;padding-bottom:.75rem}.sidebar-item{margin-bottom:1rem}.sidebar-item:last-child{margin-bottom:0}.sidebar-label{color:var(--text-muted);display:block;font-size:.8rem;font-weight:600;letter-spacing:.5px;margin-bottom:.25rem;text-transform:uppercase}.sidebar-item a{color:var(--primary);font-size:.95rem;font-weight:600;text-decoration:none;transition:color .2s}.sidebar-item a:hover{color:var(--accent)}.sidebar-list{list-style:none;margin:0;padding:0}.sidebar-list li{border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.9rem;padding:.5rem 0 .5rem 1rem;position:relative}.sidebar-list li:last-child{border-bottom:none}.sidebar-list li:before{background:var(--primary);border-radius:50%;content:"";height:5px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:5px}@media (max-width:900px){.service-grid-photo{grid-template-columns:repeat(2,1fr)}.anfrage-layout{grid-template-columns:1fr}.anfrage-sidebar{flex-direction:row;position:static}.sidebar-card{flex:1 1}}@media (max-width:600px){.service-grid-photo{grid-template-columns:1fr}.leistungen-content{padding:3rem 0 1rem}.anfrage-form-wrapper{padding:1.75rem}.anfrage-form .form-row-2{grid-template-columns:1fr}.anfrage-sidebar{flex-direction:column}.anfrage-section{padding:3rem 0 4rem}}:root[data-theme=dark] .service-card-photo{background:#1a1a1a;border-color:#ffffff14}:root[data-theme=dark] .service-card-photo:hover{border-color:var(--primary);box-shadow:0 20px 50px #0006}:root[data-theme=dark] .anfrage-form-wrapper{background:#111;border-color:#ffffff14}:root[data-theme=dark] .anfrage-form input,:root[data-theme=dark] .anfrage-form select,:root[data-theme=dark] .anfrage-form textarea{background:#1a1a1a;border-color:#ffffff1a}:root[data-theme=dark] .sidebar-card{background:#111;border-color:#ffffff14}:root[data-theme=dark] .service-tag{background:#ef444426}.user-dashboard{margin:0 auto;max-width:900px;padding:2rem 0}.dashboard-header{background:var(--bg-light);border-radius:16px;box-shadow:var(--shadow);justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 2rem}.dashboard-header,.user-info{align-items:center;display:flex}.user-info{gap:1rem}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:56px;justify-content:center;width:56px}.user-details h2{-webkit-text-fill-color:var(--text);background:none;font-size:1.4rem;margin:0 0 .25rem}.user-email{color:var(--text-muted);font-size:.9rem}.dashboard-tabs{background:var(--bg-light);border-radius:12px;display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem}.tab-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 1.5rem;transition:all .3s ease}.tab-btn:hover{background:#dc26261a;background:rgba(var(--primary-rgb,220,38,38),.1);color:var(--text)}.tab-btn.active{background:var(--primary);color:#fff}.tab-badge{background:#fff3;border-radius:10px;font-size:.8rem;padding:.15rem .5rem}.tab-btn:not(.active) .tab-badge{background:var(--primary);color:#fff}.tab-badge.unread{animation:pulse 2s infinite;background:#ef4444;color:#fff}.dashboard-content{background:var(--bg-light);border-radius:16px;box-shadow:var(--shadow);min-height:400px;padding:1.5rem}.empty-state,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:40px;margin-bottom:1rem;width:40px}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:var(--text);margin:0 0 .5rem}.empty-state p{color:var(--text-muted)}.empty-state a{color:var(--primary);text-decoration:underline}.bookings-list{display:flex;flex-direction:column;gap:1rem}.booking-card{background:var(--bg);border-left:4px solid var(--border);border-radius:12px;padding:1.25rem;transition:transform .2s ease}.booking-card:hover{transform:translateX(4px)}.booking-card.status-confirmed{border-left-color:#22c55e}.booking-card.status-pending{border-left-color:#f59e0b}.booking-card.status-rejected{border-left-color:#ef4444}.booking-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.booking-header h3{font-size:1.1rem;margin:0}.status-badge{border-radius:20px;font-size:.8rem;padding:.25rem .75rem}.status-badge.confirmed{background:#22c55e26;color:#22c55e}.status-badge.pending{background:#f59e0b26;color:#f59e0b}.status-badge.rejected{background:#ef444426;color:#ef4444}.booking-details p{color:var(--text-muted);font-size:.95rem;margin:.5rem 0}.booking-date{color:var(--text-muted)!important;font-size:.85rem!important;margin-top:1rem!important}.chat-section{display:flex;flex-direction:column;height:500px}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:1rem;overflow-y:auto;padding:1rem}.chat-message{animation:fadeIn .3s ease;max-width:80%}.chat-message.from-user{align-self:flex-end}.chat-message.from-admin{align-self:flex-start}.message-content{border-radius:16px;padding:1rem 1.25rem;position:relative}.from-user .message-content{background:linear-gradient(135deg,var(--primary),var(--accent));border-bottom-right-radius:4px;color:#fff}.from-admin .message-content{background:var(--bg);border-bottom-left-radius:4px;color:var(--text)}.message-content p{line-height:1.5;margin:0 0 .5rem}.message-time{font-size:.75rem;opacity:.7}.chat-input-form{background:var(--bg);border-radius:12px;display:flex;gap:.75rem;margin-top:1rem;padding:1rem}.chat-input-form input{background:var(--bg-light);border:2px solid var(--border);border-radius:8px;color:var(--text);flex:1 1;font-size:1rem;padding:.875rem 1rem;transition:border-color .3s ease}.chat-input-form input:focus{border-color:var(--primary);outline:none}.chat-input-form input::placeholder{color:var(--text-muted)}.chat-input-form .btn{white-space:nowrap}@media (max-width:768px){.user-dashboard{padding:1rem}.dashboard-header{gap:1rem;text-align:center}.dashboard-header,.dashboard-tabs,.user-info{flex-direction:column}.chat-message{max-width:90%}.chat-section{height:400px}}.admin-login{align-items:center;background:linear-gradient(135deg,#d82537,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.denied-container,.login-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:3rem 2rem;width:100%}.denied-container h1,.login-container h1{color:#1a1a1a;margin:0 0 2rem;text-align:center}.denied-container p{color:#666;margin:1rem 0 0;text-align:center}.login-form{gap:1.5rem}.login-form,.login-form .form-group{display:flex;flex-direction:column}.login-form label{color:#333;font-weight:600;margin-bottom:.5rem}.login-form input{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease}.login-form input:focus{border-color:#d82537;box-shadow:0 0 0 3px #d825371a;outline:none}.admin-dashboard{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:2rem 1rem}.admin-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin:0 auto 2rem;max-width:1200px}.admin-header h1{color:#1a1a1a;margin:0}.logout-btn{white-space:nowrap}.admin-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1400px}@media (max-width:1024px){.admin-grid{grid-template-columns:1fr}}.admin-section{background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000014;padding:2rem}.section-title{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.section-title h2{color:#1a1a1a;font-size:1.5rem;margin:0}.badge{background:linear-gradient(135deg,#d82537,#764ba2);border-radius:20px;color:#fff;font-size:.9rem;font-weight:600;padding:.5rem 1rem}.empty-state{color:#999;font-style:italic;padding:2rem;text-align:center}.bookings-list,.contacts-list{display:flex;flex-direction:column;gap:1.5rem}.booking-item,.contact-item{background:#f8f9fa;border-left:4px solid #d82537;border-radius:12px;padding:1.5rem;transition:all .3s ease}.booking-item.status-confirmed{border-left-color:#10b981}.booking-item:hover,.contact-item:hover{box-shadow:0 5px 20px #0000001a}.item-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.item-title h3{color:#1a1a1a;font-size:1.1rem;margin:0 0 .25rem}.service-label{color:#d82537;font-size:.85rem;font-weight:600;margin:0;text-transform:uppercase}.item-meta{text-align:right}.status-badge{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:600;margin-bottom:.5rem;padding:.4rem .8rem}.status-badge.status-pending{background:#fef3c7;color:#92400e}.status-badge.status-confirmed{background:#dcfce7;color:#166534}.timestamp{color:#999;font-size:.85rem;margin:0}.item-content{background:#fff;border-radius:8px;margin-bottom:1rem;padding:1rem}.item-content p{color:#333;line-height:1.5;margin:.5rem 0}.item-content a{color:#d82537;font-weight:500;text-decoration:none}.item-content a:hover{text-decoration:underline}.item-content strong{color:#1a1a1a}.message{color:#666;font-style:italic;margin-top:.5rem}.item-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn.small{border-radius:6px;font-size:.85rem;padding:.5rem 1rem}.btn.danger{background:#ef4444;border:none;color:#fff}.btn.danger:hover{background:#dc2626}.contact-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.contact-title h3{color:#1a1a1a;font-size:1.1rem;margin:0 0 .25rem}.contact-content{background:#fff;border-radius:8px;margin-bottom:1rem;padding:1rem}.contact-content p{color:#333;line-height:1.5;margin:.5rem 0}.contact-content a{color:#d82537;font-weight:500;text-decoration:none}.blocked-section{background:linear-gradient(135deg,#fff9e6,#fff0cc);border-top:3px solid #f59e0b;grid-column:1/-1}.blocked-section .section-title{border-bottom-color:#fcd34d}.block-form{background:#fff;border-radius:12px;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media (max-width:640px){.form-row{grid-template-columns:1fr}}.block-form .form-group{display:flex;flex-direction:column}.block-form label{color:#333;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.block-form input{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease}.block-form input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a;outline:none}.blocked-dates-list{display:flex;flex-direction:column;gap:1rem}.blocked-date-item{align-items:center;background:#fff;border-left:4px solid #f59e0b;border-radius:12px;display:flex;justify-content:space-between;padding:1.5rem;transition:all .3s ease}.blocked-date-item:hover{box-shadow:0 5px 20px #0000001a}.date-info{flex:1 1}.blocked-date-item .date{color:#1a1a1a;font-size:1.1rem;font-weight:600;margin:0}.blocked-date-item .reason{color:#666;font-size:.9rem;margin:.25rem 0 0}[data-theme=dark] .admin-dashboard{background:linear-gradient(135deg,#1a1a1a,#2d2d2d)}[data-theme=dark] .admin-section{background:#2d2d2d}[data-theme=dark] .admin-header h1,[data-theme=dark] .section-title h2{color:#e0e0e0}[data-theme=dark] .section-title{border-bottom-color:#404040}[data-theme=dark] .booking-item,[data-theme=dark] .contact-item{background:#3a3a3a}[data-theme=dark] .contact-content,[data-theme=dark] .item-content{background:#353535}[data-theme=dark] .contact-content p,[data-theme=dark] .contact-title h3,[data-theme=dark] .item-content p,[data-theme=dark] .item-content strong,[data-theme=dark] .item-title h3,[data-theme=dark] .service-label{color:#e0e0e0}[data-theme=dark] .message{color:#b0b0b0}[data-theme=dark] .login-container{background:#2d2d2d}[data-theme=dark] .login-container h1,[data-theme=dark] .login-form label{color:#e0e0e0}[data-theme=dark] .login-form input{background:#3a3a3a;border-color:#404040;color:#e0e0e0}[data-theme=dark] .blocked-section{background:linear-gradient(135deg,#3d3200,#4a3f00)}[data-theme=dark] .blocked-section .section-title{border-bottom-color:#640}[data-theme=dark] .block-form{background:#3a3a3a}[data-theme=dark] .block-form label{color:#e0e0e0}[data-theme=dark] .block-form input{background:#2d2d2d;border-color:#404040;color:#e0e0e0}[data-theme=dark] .block-form input:focus{border-color:#f59e0b}[data-theme=dark] .blocked-date-item{background:#3a3a3a}[data-theme=dark] .blocked-date-item .date{color:#e0e0e0}[data-theme=dark] .blocked-date-item .reason{color:#b0b0b0}.calendar-layout{display:flex;flex-direction:column;gap:1.5rem}.cal-stats-bar{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.cal-stat{background:#f8f9fa;border-radius:12px;padding:1.25rem;text-align:center;transition:all .3s ease}.cal-stat:hover{box-shadow:0 4px 15px #00000014}.cal-stat-num{display:block;font-size:2rem;font-weight:800;line-height:1.2}.cal-stat-booking{color:#3b82f6}.cal-stat-blocked{color:#ef4444}.cal-stat-available{color:#10b981}.cal-stat-label{color:#666;display:block;font-size:.85rem;margin-top:.25rem}.cal-main{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 340px;min-height:480px}.cal-grid-wrapper{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;padding:1.5rem}.cal-header{gap:1rem;margin-bottom:1.25rem}.cal-header,.cal-nav-btn{align-items:center;display:flex}.cal-nav-btn{background:none;border:2px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:1.3rem;height:36px;justify-content:center;transition:all .2s;width:36px}.cal-nav-btn:hover{background:#fef2f2;border-color:#d82537;color:#d82537}.cal-month-title{color:#1a1a1a;flex:1 1;font-size:1.3rem;font-weight:700;margin:0;text-align:center}.cal-today-btn{font-size:.85rem!important}.cal-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.cal-day-header{color:#888;font-size:.8rem;font-weight:700;letter-spacing:.05em;padding:.5rem 0;text-align:center;text-transform:uppercase}.cal-cell{align-items:center;aspect-ratio:1;background:#fafafa;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:3px;justify-content:center;min-height:52px;position:relative;transition:all .2s ease}.cal-cell:hover{background:#f0f0f0;transform:scale(1.05);z-index:1}.cal-cell.cal-empty{background:#0000;cursor:default}.cal-cell.cal-empty:hover{transform:none}.cal-day-num{color:#333;font-size:.95rem;font-weight:600;line-height:1}.cal-cell.cal-past{opacity:.45}.cal-cell.cal-today{background:#fef2f2;border:2px solid #d82537}.cal-cell.cal-today .cal-day-num{color:#d82537;font-weight:800}.cal-cell.cal-selected{background:#d82537;box-shadow:0 4px 12px #d825374d}.cal-cell.cal-selected .cal-day-num{color:#fff}.cal-cell.cal-blocked{background:#fef2f2}.cal-cell.cal-blocked .cal-day-num{color:#dc2626}.cal-cell.cal-selected.cal-blocked{background:#dc2626}.cal-dots{align-items:center;display:flex;gap:3px;height:8px}.cal-dot{border-radius:50%;display:inline-block;flex-shrink:0;height:7px;width:7px}.cal-dot-booking{background:#3b82f6}.cal-dot-available{background:#10b981}.cal-dot-booked{background:#f59e0b}.cal-dot-blocked{background:#ef4444}.cal-cell.cal-selected .cal-dot-booking{background:#93c5fd}.cal-cell.cal-selected .cal-dot-available{background:#6ee7b7}.cal-cell.cal-selected .cal-dot-booked{background:#fcd34d}.cal-cell.cal-selected .cal-dot-blocked{background:#fca5a5}.cal-legend{border-top:1px solid #f0f0f0;display:flex;flex-wrap:wrap;gap:1.25rem;justify-content:center;margin-top:1rem;padding-top:1rem}.cal-legend-item{align-items:center;color:#666;display:flex;font-size:.8rem;gap:.4rem}.cal-detail{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;max-height:600px;overflow-y:auto;padding:1.5rem;transition:all .3s ease}.cal-detail-header{align-items:flex-start;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.75rem}.cal-detail-header h3{color:#1a1a1a;font-size:1.05rem;font-weight:700;line-height:1.4;margin:0}.cal-detail-close{background:none;border:none;color:#999;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:color .2s}.cal-detail-close:hover{color:#d82537}.cal-detail-section{margin-bottom:1.25rem}.cal-detail-section h4{color:#555;font-size:.9rem;font-weight:700;margin:0 0 .75rem}.cal-detail-card{background:#f8f9fa;border-left:4px solid #e0e0e0;border-radius:10px;margin-bottom:.5rem;padding:.85rem 1rem;transition:all .2s ease}.cal-detail-card:hover{box-shadow:0 2px 8px #0000000f}.cal-card-booking{border-left-color:#3b82f6}.cal-card-booking.status-confirmed{border-left-color:#10b981}.cal-card-booking.status-cancelled,.cal-card-booking.status-rejected{border-left-color:#ef4444;opacity:.7}.cal-card-slot{border-left-color:#10b981}.cal-card-slot.booked{border-left-color:#f59e0b}.cal-card-blocked{background:#fef2f2;border-left-color:#ef4444}.cal-card-top{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.cal-card-top strong{color:#333;font-size:.9rem}.cal-card-sub{color:#666;font-size:.82rem;margin:.3rem 0 0}.cal-card-note{background:#00000008;border-radius:6px;color:#888;font-size:.82rem;font-style:italic;margin:.4rem 0 0;padding:.4rem .6rem}.cal-actions{border-top:1px solid #f0f0f0;padding-top:.75rem}.cal-block-form{gap:.75rem}.cal-block-form,.cal-block-form .form-group{display:flex;flex-direction:column}.cal-block-form label{color:#555;font-size:.82rem;font-weight:600;margin-bottom:.3rem}.cal-block-form input{border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;padding:.6rem .75rem;transition:border-color .2s}.cal-block-form input:focus{border-color:#d82537;outline:none}.cal-detail-empty{color:#999;padding:2rem 1rem;text-align:center}.cal-detail-empty p{font-size:.9rem;margin:0}.cal-upcoming{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;padding:1.5rem}.cal-upcoming h3{color:#1a1a1a;font-size:1.1rem;font-weight:700;margin:0 0 1rem}.cal-upcoming-list{display:flex;flex-direction:column;gap:.5rem}.cal-upcoming-item{align-items:flex-start;background:#f8f9fa;border-radius:10px;cursor:pointer;display:flex;gap:1rem;padding:.85rem 1rem;transition:all .2s ease}.cal-upcoming-item:hover{background:#f0f0f0;box-shadow:0 2px 8px #0000000f}.cal-upcoming-date{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;min-width:44px;padding:.4rem .5rem}.cal-upcoming-day{color:#1a1a1a;font-size:1.3rem;font-weight:800;line-height:1}.cal-upcoming-weekday{color:#888;font-size:.7rem;font-weight:600;text-transform:uppercase}.cal-upcoming-info{display:flex;flex:1 1;flex-direction:column;gap:.3rem}.cal-up-tag{border-radius:6px;display:inline-block;font-size:.82rem;padding:.2rem .5rem}.cal-up-tag.booking{background:#eff6ff;color:#1e40af}.cal-up-tag.booking.status-confirmed{background:#ecfdf5;color:#065f46}.cal-up-tag.booking.status-rejected{background:#fef2f2;color:#991b1b}.cal-up-tag.available{background:#ecfdf5;color:#065f46}.cal-up-tag.booked{background:#fffbeb;color:#92400e}.cal-up-tag.blocked{background:#fef2f2;color:#991b1b}[data-theme=dark] .cal-stats-bar .cal-stat{background:#2d2d2d}[data-theme=dark] .cal-stat-label{color:#999}[data-theme=dark] .cal-grid-wrapper{background:#2d2d2d;box-shadow:0 2px 12px #0003}[data-theme=dark] .cal-month-title{color:#e0e0e0}[data-theme=dark] .cal-nav-btn{border-color:#555;color:#ccc}[data-theme=dark] .cal-nav-btn:hover{background:#d825371a;border-color:#d82537;color:#d82537}[data-theme=dark] .cal-day-header{color:#777}[data-theme=dark] .cal-cell{background:#353535}[data-theme=dark] .cal-cell:hover{background:#444}[data-theme=dark] .cal-cell.cal-empty{background:#0000}[data-theme=dark] .cal-day-num{color:#ddd}[data-theme=dark] .cal-cell.cal-today{background:#d8253726;border-color:#d82537}[data-theme=dark] .cal-cell.cal-today .cal-day-num{color:#ff6b7a}[data-theme=dark] .cal-cell.cal-blocked{background:#ef444426}[data-theme=dark] .cal-cell.cal-blocked .cal-day-num{color:#f87171}[data-theme=dark] .cal-legend{border-top-color:#444}[data-theme=dark] .cal-legend-item{color:#999}[data-theme=dark] .cal-detail{background:#2d2d2d;box-shadow:0 2px 12px #0003}[data-theme=dark] .cal-detail-header{border-bottom-color:#444}[data-theme=dark] .cal-detail-header h3{color:#e0e0e0}[data-theme=dark] .cal-detail-section h4{color:#bbb}[data-theme=dark] .cal-detail-card{background:#3a3a3a}[data-theme=dark] .cal-card-top strong{color:#e0e0e0}[data-theme=dark] .cal-card-sub{color:#aaa}[data-theme=dark] .cal-card-note{background:#ffffff0a;color:#999}[data-theme=dark] .cal-card-blocked{background:#ef44441f}[data-theme=dark] .cal-actions{border-top-color:#444}[data-theme=dark] .cal-block-form label{color:#bbb}[data-theme=dark] .cal-block-form input{background:#353535;border-color:#555;color:#e0e0e0}[data-theme=dark] .cal-block-form input:focus{border-color:#d82537}[data-theme=dark] .cal-detail-empty{color:#777}[data-theme=dark] .cal-upcoming{background:#2d2d2d;box-shadow:0 2px 12px #0003}[data-theme=dark] .cal-upcoming h3{color:#e0e0e0}[data-theme=dark] .cal-upcoming-item{background:#353535}[data-theme=dark] .cal-upcoming-item:hover{background:#3f3f3f}[data-theme=dark] .cal-upcoming-date{background:#2d2d2d;border-color:#555}[data-theme=dark] .cal-upcoming-day{color:#e0e0e0}[data-theme=dark] .cal-up-tag.booking{background:#3b82f626;color:#93c5fd}[data-theme=dark] .cal-up-tag.booking.status-confirmed{background:#10b98126;color:#6ee7b7}[data-theme=dark] .cal-up-tag.booking.status-rejected{background:#ef444426;color:#fca5a5}[data-theme=dark] .cal-up-tag.available{background:#10b98126;color:#6ee7b7}[data-theme=dark] .cal-up-tag.booked{background:#f59e0b26;color:#fcd34d}[data-theme=dark] .cal-up-tag.blocked{background:#ef444426;color:#fca5a5}@media (max-width:900px){.cal-main{grid-template-columns:1fr}.cal-detail{max-height:none}.cal-stats-bar{grid-template-columns:1fr}}@media (max-width:640px){.cal-grid-wrapper{padding:1rem}.cal-cell{min-height:40px}.cal-day-num{font-size:.8rem}.cal-dot{height:5px;width:5px}.cal-legend{gap:.75rem}.cal-legend-item{font-size:.72rem}}.admin-tabs{background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000000d;display:flex;gap:.5rem;margin:0 auto 1.5rem;max-width:1200px;padding:.5rem}.admin-tab{align-items:center;background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 1.5rem;transition:all .3s ease}.admin-tab:hover{background:#f0f0f0;color:#333}.admin-tab.active{background:linear-gradient(135deg,#d82537,#764ba2);color:#fff}.admin-tab .tab-badge{background:#fff3;border-radius:10px;font-size:.8rem;padding:.15rem .5rem}.admin-tab:not(.active) .tab-badge{background:#d82537;color:#fff}.admin-tab .tab-badge.unread{animation:pulse 2s infinite;background:#ef4444}.admin-content{margin:0 auto;max-width:1200px}.admin-chat-container{grid-gap:1.5rem;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000014;display:grid;gap:1.5rem;grid-template-columns:300px 1fr;height:600px;overflow:hidden}.chat-sidebar{background:#f8f9fa;border-right:1px solid #e0e0e0;display:flex;flex-direction:column}.chat-sidebar h3{border-bottom:1px solid #e0e0e0;color:#333;font-size:1.1rem;margin:0;padding:1.5rem}.empty-chat{color:#999;font-style:italic;padding:2rem;text-align:center}.conversation-list{flex:1 1;overflow-y:auto}.conversation-item{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;gap:.75rem;padding:1rem 1.5rem;transition:background .2s ease}.conversation-item:hover{background:#e9ecef}.conversation-item.active{background:linear-gradient(135deg,#d825371a,#764ba21a);border-left:3px solid #d82537}.conversation-item.unread{background:#fff3cd}.conv-avatar{align-items:center;background:linear-gradient(135deg,#d82537,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:700;height:42px;justify-content:center;width:42px}.conv-info{flex:1 1;min-width:0}.conv-name{color:#333;font-weight:600}.conv-email,.conv-name{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-email{color:#999;font-size:.8rem}.unread-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:.75rem;font-weight:700;padding:.2rem .5rem}.chat-main{display:flex;flex-direction:column;height:100%}.no-chat-selected{align-items:center;color:#999;display:flex;flex:1 1;flex-direction:column;justify-content:center}.no-chat-selected span{font-size:4rem;margin-bottom:1rem}.chat-header{background:#fafafa;border-bottom:1px solid #e0e0e0;padding:1rem 1.5rem}.chat-user-info{gap:1rem}.chat-avatar,.chat-user-info{align-items:center;display:flex}.chat-avatar{background:linear-gradient(135deg,#d82537,#764ba2);border-radius:50%;color:#fff;font-size:1.2rem;font-weight:700;height:48px;justify-content:center;width:48px}.chat-user-info h3{color:#333;font-size:1.1rem;margin:0}.chat-user-info p{color:#999;font-size:.85rem;margin:0}.chat-messages-admin{display:flex;flex:1 1;flex-direction:column;gap:1rem;overflow-y:auto;padding:1.5rem}.admin-chat-message{max-width:75%}.admin-chat-message.from-user{align-self:flex-start}.admin-chat-message.from-admin{align-self:flex-end}.message-bubble{border-radius:16px;padding:.875rem 1.25rem;position:relative}.from-user .message-bubble{background:#f0f0f0;border-bottom-left-radius:4px;color:#333}.from-admin .message-bubble{background:linear-gradient(135deg,#d82537,#764ba2);border-bottom-right-radius:4px;color:#fff}.message-bubble p{line-height:1.5;margin:0 0 .5rem}.msg-time{font-size:.7rem;opacity:.7}.admin-chat-input{background:#fafafa;border-top:1px solid #e0e0e0;display:flex;gap:.75rem;padding:1rem 1.5rem}.admin-chat-input input{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:1rem;padding:.875rem 1rem;transition:border-color .3s ease}.admin-chat-input input:focus{border-color:#d82537;outline:none}.admin-chat-input .btn{padding:.875rem 1.5rem}@media (max-width:768px){.admin-tabs{flex-wrap:wrap}.admin-tab{flex:1 1 45%;font-size:.9rem;padding:.75rem}.admin-chat-container{grid-template-columns:1fr;height:auto}.chat-sidebar{border-bottom:1px solid #e0e0e0;border-right:none;max-height:200px}.chat-main{min-height:400px}}[data-theme=dark] .admin-tabs{background:#2d2d2d}[data-theme=dark] .admin-tab{color:#b0b0b0}[data-theme=dark] .admin-tab:hover{background:#3a3a3a;color:#e0e0e0}[data-theme=dark] .admin-chat-container{background:#2d2d2d}[data-theme=dark] .chat-sidebar{background:#252525;border-color:#404040}[data-theme=dark] .chat-sidebar h3{border-color:#404040;color:#e0e0e0}[data-theme=dark] .conversation-item{border-color:#404040}[data-theme=dark] .conversation-item:hover{background:#3a3a3a}[data-theme=dark] .conv-name{color:#e0e0e0}[data-theme=dark] .chat-header{background:#252525;border-color:#404040}[data-theme=dark] .chat-user-info h3{color:#e0e0e0}[data-theme=dark] .from-user .message-bubble{background:#3a3a3a;color:#e0e0e0}[data-theme=dark] .admin-chat-input{background:#252525;border-color:#404040}[data-theme=dark] .admin-chat-input input{background:#3a3a3a;border-color:#404040;color:#e0e0e0}.gallery-dropzone{background:#fafafa;border:3px dashed #d0d0d0;border-radius:16px;cursor:pointer;padding:3rem 2rem;text-align:center;transition:all .3s ease}.gallery-dropzone:hover{background:#fff5f5;border-color:#d82537}.gallery-dropzone.drag-over{background:#d825370d;border-color:#d82537;transform:scale(1.01)}.gallery-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.gallery-card{background:#f8f9fa;border:2px solid #0000;border-radius:12px;overflow:hidden;transition:all .3s ease}.gallery-card:hover{border-color:#d82537;box-shadow:0 8px 25px #0000001f}.gallery-img-wrap{aspect-ratio:4/3;overflow:hidden;position:relative}.gallery-img-wrap img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.gallery-card:hover .gallery-img-wrap img{transform:scale(1.05)}.gallery-overlay{align-items:center;background:#00000080;display:flex;gap:.75rem;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .3s ease}.gallery-card:hover .gallery-overlay{opacity:1}.gallery-card-info{padding:.75rem 1rem}.gallery-card-title{color:#333;font-size:.9rem;font-weight:600;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 25px 60px #0000004d;max-height:90vh;max-width:560px;overflow-y:auto;padding:2rem;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.modal-header h3{font-size:1.3rem;margin:0}.grafana-embed,.portainer-embed{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.portainer-embed{background:#f8f9fa}[data-theme=dark] .portainer-embed{background:#1a1a1a;border-color:#444}[data-theme=dark] .gallery-dropzone{background:#2a2a2a;border-color:#444}[data-theme=dark] .gallery-dropzone:hover{background:#3a2020;border-color:#d82537}[data-theme=dark] .gallery-card{background:#3a3a3a}[data-theme=dark] .gallery-card-title{color:#e0e0e0}[data-theme=dark] .modal-content{background:#2d2d2d;color:#e0e0e0}[data-theme=dark] .modal-content input,[data-theme=dark] .modal-content select,[data-theme=dark] .modal-content textarea{background:#3a3a3a;border-color:#555;color:#e0e0e0}[data-theme=dark] .grafana-embed{border-color:#444}.docker-container-list{display:flex;flex-direction:column;gap:.75rem}.docker-container-card{background:var(--bg);border:1px solid var(--border);border-left:4px solid #999;border-radius:10px;padding:1rem 1.25rem;transition:all .2s ease}.docker-container-card.running{border-left-color:#22c55e}.docker-container-card.exited{border-left-color:#ef4444;opacity:.85}.docker-container-card.restarting{border-left-color:#f59e0b}.docker-container-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.docker-container-info{align-items:center;display:flex;gap:.75rem}.docker-state-icon{font-size:1.1rem}.docker-container-name{color:var(--text);display:block;font-size:.95rem}.docker-container-image{color:var(--text-muted);display:block;font-size:.78rem;margin-top:2px}.docker-container-ports{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}.docker-port-badge{background:#dc262614;border:1px solid #dc262626;border-radius:4px;color:var(--primary);font-family:Consolas,Monaco,monospace;font-size:.72rem;padding:2px 8px}.docker-container-actions{border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.4rem;padding-top:.5rem}.docker-container-actions .btn{font-size:.78rem;padding:.3rem .6rem}.docker-modal-wide{max-width:900px;width:95vw}.docker-logs-container{max-height:60vh;overflow-y:auto;padding:1rem}.docker-logs{background:#0d1117;border-radius:8px;color:#c9d1d9;font-family:Consolas,Monaco,Courier New,monospace;font-size:.78rem;line-height:1.5;margin:0;padding:1rem;white-space:pre-wrap;word-break:break-all}.docker-stat-bar{background:var(--bg-light);border:1px solid var(--border);border-radius:12px;height:24px;overflow:hidden;width:100%}.docker-stat-fill{background:linear-gradient(90deg,#22c55e,#f59e0b);border-radius:12px;height:100%;min-width:2%;transition:width .5s ease}.docker-stat-fill.memory{background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.docker-env-list{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto}.docker-env-item{background:var(--bg-light);border-radius:4px;color:var(--text-muted);display:block;font-family:Consolas,Monaco,monospace;font-size:.75rem;padding:4px 8px;word-break:break-all}.docker-env-hidden{background:#dc26260f;color:var(--primary);font-style:italic}.admin-success{background:#22c55e1a;border:1px solid #22c55e33;border-radius:8px;color:#16a34a}.admin-error,.admin-success{font-size:.9rem;padding:.75rem 1rem}.admin-error{align-items:center;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#dc2626;display:flex;justify-content:space-between}[data-theme=dark] .docker-container-card{background:#1a1a1a;border-color:#ffffff1a}[data-theme=dark] .docker-port-badge{background:#ef44441f;border-color:#ef444440}[data-theme=dark] .docker-env-item{background:#2a2a2a}[data-theme=dark] .docker-env-hidden{background:#ef44441a}[data-theme=dark] .admin-success{background:#22c55e26;border-color:#22c55e4d;color:#4ade80}[data-theme=dark] .admin-error{background:#ef444426;border-color:#ef44444d;color:#f87171}@media (max-width:768px){.docker-container-header{align-items:flex-start;flex-direction:column;gap:.5rem}.docker-container-actions{gap:.3rem}.docker-container-actions .btn{font-size:.72rem;padding:.25rem .5rem}.docker-modal-wide{border-radius:0;max-width:100vw;width:100vw}}.tracing-tab{display:flex;flex-direction:column;gap:1rem}.tracing-controls{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:12px;padding:1rem 1.5rem}.tracing-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.tracing-filter-group{align-items:center;display:flex;gap:.5rem}.tracing-filter-group label{color:#666;color:var(--text-muted,#666);font-size:.85rem;font-weight:600}.tracing-filter-group select{background:#fff;background:var(--bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:6px;color:#1a1a1a;color:var(--text,#1a1a1a);font-size:.85rem;padding:.4rem .8rem}.tracing-iframe-container{background:#1a1a2e;border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:12px;overflow:hidden}.tracing-iframe{border:none;height:calc(100vh - 280px);min-height:600px;width:100%}.tracing-list{display:flex;flex-direction:column;gap:.5rem}.trace-card{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-left:4px solid #22c55e;border-radius:10px;padding:1rem 1.25rem;transition:transform .15s,box-shadow .15s}.trace-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.trace-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.trace-operation{color:#1a1a1a;color:var(--text,#1a1a1a);font-weight:600}.trace-duration,.trace-operation{font-family:JetBrains Mono,monospace;font-size:.95rem}.trace-duration{font-weight:700}.trace-meta{color:#666;color:var(--text-muted,#666);display:flex;font-size:.8rem;gap:1.5rem}.trace-link{color:#dc2626;color:var(--primary,#dc2626);font-weight:600;text-decoration:none}.trace-link:hover{text-decoration:underline}.trace-id{color:#999;color:var(--text-muted,#999);font-family:JetBrains Mono,monospace;font-size:.72rem;margin-top:.25rem}.grafana-tab{display:flex;flex-direction:column;gap:1rem}.grafana-controls{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:12px;padding:1rem 1.5rem}.grafana-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.grafana-iframe-container{background:#181b1f;border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:12px;overflow:hidden}.grafana-iframe{border:none;height:calc(100vh - 260px);min-height:700px;width:100%}.portainer-tab{display:flex;flex-direction:column;gap:1rem}.portainer-controls{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:12px;padding:1rem 1.5rem}.portainer-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.portainer-iframe-container{background:#1a1a2e;border:1px solid #e5e7eb;border:1px solid var(--border,#e5e7eb);border-radius:12px;overflow:hidden}.portainer-iframe{border:none;height:calc(100vh - 260px);min-height:700px;width:100%}[data-theme=dark] .grafana-controls,[data-theme=dark] .portainer-controls,[data-theme=dark] .trace-card,[data-theme=dark] .tracing-controls{background:#1e1e2e;background:var(--card-bg,#1e1e2e);border-color:#333;border-color:var(--border,#333)}[data-theme=dark] .tracing-filter-group select{background:#121212;background:var(--bg,#121212);border-color:#333;border-color:var(--border,#333);color:#e0e0e0;color:var(--text,#e0e0e0)}@media (max-width:768px){.grafana-toolbar,.portainer-toolbar,.tracing-toolbar{align-items:stretch;flex-direction:column}.grafana-iframe,.portainer-iframe,.tracing-iframe{height:calc(100vh - 320px);min-height:500px}.trace-header{align-items:flex-start;flex-direction:column;gap:.25rem}.trace-meta{flex-wrap:wrap;gap:.5rem}}.admin-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;overflow-x:auto;scrollbar-width:thin}.admin-tab{flex:0 0 auto!important;font-size:.9rem!important;min-width:fit-content;padding:.75rem 1rem!important;white-space:nowrap}.admin-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.admin-card{background:#f8f9fa;border-left:4px solid #d82537;border-radius:12px;padding:1.5rem;transition:all .3s ease}.admin-card:hover{box-shadow:0 5px 20px #0000001a}.admin-card.inactive{border-left-color:#999;opacity:.6}.admin-card-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.admin-card-price{color:#d82537;font-size:1.5rem;font-weight:700;white-space:nowrap}.admin-slug{color:#999;display:inline-block;font-family:monospace;font-size:.8rem}.admin-card-desc{color:#555;font-size:.9rem;line-height:1.5;margin:0 0 .75rem}.admin-card-meta{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.admin-card-meta span{font-size:.8rem}.featured-tag{background:#fef3c7;border-radius:4px;color:#92400e;font-weight:600;padding:.15rem .5rem}.admin-card-includes{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.include-tag{color:#10b981;font-size:.85rem}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;font-size:.95rem;width:100%}.admin-table th{border-bottom:2px solid #e0e0e0;color:#333;font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.admin-table td{border-bottom:1px solid #f0f0f0;padding:.75rem;vertical-align:middle}.admin-table tr:hover td{background:#f8f9fa}.admin-table .row-inactive td{opacity:.5}.coupon-code{background:#f0f0f0;border-radius:4px;font-family:monospace;font-size:.95rem;font-weight:700;letter-spacing:.05em;padding:.25rem .75rem}.text-danger{color:#ef4444!important}.role-select{border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;padding:.4rem .6rem;transition:all .2s ease}.role-select.role-admin{background:#dcfce7;border-color:#86efac;color:#166534}.role-select.role-user{background:#f3f4f6;border-color:#d1d5db;color:#4b5563}.role-select:hover{border-color:#d82537}.testimonials-list{display:flex;flex-direction:column;gap:1.5rem}.testimonial-item{background:#f8f9fa;border-left:4px solid #10b981;border-radius:12px;padding:1.5rem;transition:all .3s ease}.testimonial-item.pending{background:#fffbeb;border-left-color:#f59e0b}.testimonial-item.featured{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-left-color:#f59e0b}.testimonial-item:hover{box-shadow:0 5px 20px #00000014}.testimonial-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.star-rating{letter-spacing:2px}.testimonial-text{background:#fff;border-radius:8px;margin-bottom:.75rem;padding:1rem}.testimonial-text p{color:#333;font-style:italic;line-height:1.6;margin:0}.testimonial-status{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.blog-list{display:flex;flex-direction:column;gap:1.5rem}.blog-item{background:#f8f9fa;border-left:4px solid #10b981;border-radius:12px;padding:1.5rem;transition:all .3s ease}.blog-item.draft{border-left-color:#f59e0b;opacity:.85}.blog-item:hover{box-shadow:0 5px 20px #00000014}.blog-item-main{display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:.75rem}.blog-item-info{flex:1 1}.blog-item-meta{min-width:140px;text-align:right}.blog-excerpt{color:#666;font-size:.9rem;line-height:1.5;margin:.5rem 0 0}.blog-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.blog-tag{background:#e0e7ff;border-radius:4px;color:#3730a3;font-size:.8rem;font-weight:500;padding:.2rem .6rem}.client-galleries-list{display:flex;flex-direction:column;gap:1.5rem}.client-gallery-item{background:#f8f9fa;border-left:4px solid #6366f1;border-radius:12px;padding:1.5rem;transition:all .3s ease}.client-gallery-item.expired{border-left-color:#ef4444;opacity:.7}.client-gallery-item.inactive{opacity:.6}.client-gallery-item:hover{box-shadow:0 5px 20px #00000014}.cg-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.cg-access-code{align-items:center;display:flex;gap:.5rem;margin-bottom:.25rem}.cg-access-code code{background:#e0e7ff;border-radius:4px;color:#3730a3;font-weight:700;padding:.25rem .75rem}.btn-icon{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;transition:transform .2s}.btn-icon:hover{transform:scale(1.2)}.cg-meta{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.availability-groups{display:flex;flex-direction:column;gap:1.5rem}.availability-date-group{background:#f8f9fa;border-radius:12px;padding:1.25rem}.availability-date-label{border-bottom:2px solid #e0e0e0;color:#333;font-size:1rem;margin:0 0 .75rem;padding-bottom:.5rem}.availability-slots{display:flex;flex-direction:column;gap:.5rem}.availability-slot{align-items:center;background:#fff;border-radius:8px;display:flex;gap:1rem;padding:.75rem 1rem;transition:all .2s ease}.availability-slot:hover{box-shadow:0 2px 10px #0000000f}.availability-slot.booked{background:#fef3c7;opacity:.7}.slot-time{align-items:center;display:flex;flex:1 1;gap:.75rem}.slot-time-range{color:#333;font-size:1rem;font-weight:600;min-width:140px}.slot-notes{color:#666;flex:1 1;font-size:.85rem}.health-indicator{align-items:center;background:#f8f9fa;border-radius:12px;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;text-align:center}[data-theme=dark] .admin-card{background:#3a3a3a}[data-theme=dark] .admin-card-desc,[data-theme=dark] .admin-card-header h3{color:#e0e0e0}[data-theme=dark] .admin-card-price{color:#ff6b7a}[data-theme=dark] .admin-slug{color:#888}[data-theme=dark] .admin-table th{border-bottom-color:#404040;color:#e0e0e0}[data-theme=dark] .admin-table td{border-bottom-color:#333}[data-theme=dark] .admin-table tr:hover td{background:#333}[data-theme=dark] .coupon-code{background:#404040;color:#e0e0e0}[data-theme=dark] .role-select{background:#3a3a3a;border-color:#555;color:#e0e0e0}[data-theme=dark] .role-select.role-admin{background:#1a3a1a;border-color:#2d5a2d;color:#86efac}[data-theme=dark] .testimonial-item{background:#3a3a3a}[data-theme=dark] .testimonial-item.pending{background:#3d3200}[data-theme=dark] .testimonial-item.featured{background:linear-gradient(135deg,#3d3200,#4a3f00)}[data-theme=dark] .testimonial-text{background:#2d2d2d}[data-theme=dark] .testimonial-text p{color:#d0d0d0}[data-theme=dark] .blog-item{background:#3a3a3a}[data-theme=dark] .blog-item h3{color:#e0e0e0}[data-theme=dark] .blog-excerpt{color:#b0b0b0}[data-theme=dark] .blog-tag{background:#2d3055;color:#a5b4fc}[data-theme=dark] .client-gallery-item{background:#3a3a3a}[data-theme=dark] .cg-access-code code{background:#2d3055;color:#a5b4fc}[data-theme=dark] .availability-date-group{background:#3a3a3a}[data-theme=dark] .availability-date-label{border-bottom-color:#555;color:#e0e0e0}[data-theme=dark] .availability-slot{background:#2d2d2d}[data-theme=dark] .availability-slot.booked{background:#3d3200}[data-theme=dark] .slot-time-range{color:#e0e0e0}[data-theme=dark] .health-indicator{background:#3a3a3a}[data-theme=dark] .health-indicator strong{color:#e0e0e0}@media (max-width:768px){.admin-cards-grid{grid-template-columns:1fr}.admin-card-header,.blog-item-main{flex-direction:column}.blog-item-meta{min-width:0;min-width:auto;text-align:left}.cg-header,.testimonial-header{flex-direction:column}.availability-slot{flex-wrap:wrap}.form-row{grid-template-columns:1fr!important}}.health-dot{border-radius:50%;display:inline-block;height:16px;margin-bottom:.5rem;width:16px}.health-dot.online{background:#10b981;box-shadow:0 0 8px #10b98166}.health-dot.offline{background:#ef4444;box-shadow:0 0 8px #ef444466}.modal-backdrop{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);bottom:0;right:0}.modal{animation:slideIn .3s ease-out;background:var(--bg);border-radius:16px;box-shadow:0 25px 50px #00000026;max-width:520px;overflow:hidden;width:90%}.modal-login{position:relative}.modal-login:before{background:linear-gradient(135deg,var(--primary) 0,#b91c1c 100%);content:"";height:140px;left:0;position:absolute;right:0;top:0;z-index:0}.modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;position:absolute;right:20px;top:20px;transition:all .2s;width:40px;z-index:10}.modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.modal-login h2{color:#fff;font-size:28px;font-weight:700;margin:0;padding:30px 30px 0;position:relative;z-index:1}.modal-login-subtitle{color:#ffffffe6;font-size:14px;padding:8px 30px 30px;position:relative;z-index:1}.modal-content-inner{padding:40px 30px;position:relative;z-index:1}.modal-tabs{border-bottom:2px solid var(--border);display:flex;gap:0;margin-bottom:30px}.tab{background:none;border:none;border-bottom:3px solid #0000;color:var(--text);cursor:pointer;flex:1 1;font-size:15px;font-weight:500;margin-bottom:-2px;padding:12px;transition:all .2s}.tab.active,.tab:hover{color:var(--primary)}.tab.active{border-bottom-color:var(--primary)}.social-login{display:flex;gap:12px;margin-bottom:25px}.social-btn{align-items:center;background:var(--bg-light);border:2px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:600;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s}.social-btn:hover{background:var(--primary);border-color:var(--primary);box-shadow:0 8px 16px #dc262633;color:#fff;transform:translateY(-2px)}.social-btn svg{height:18px;width:18px}.divider{align-items:center;color:var(--text);display:flex;gap:12px;margin:25px 0;opacity:.6}.divider:after,.divider:before{background:var(--border);content:"";flex:1 1;height:1px}.divider span{font-size:13px;font-weight:500}.form-group{margin-bottom:16px}.form-group label{color:var(--text);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group textarea{background:var(--bg);border:2px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:15px;padding:12px 14px;transition:all .2s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #dc26261a;outline:none}.form-group input::placeholder{color:var(--text);opacity:.5}.password-input-group{position:relative;width:100%}.password-input-group input{padding-right:45px}.password-toggle{align-items:center;background:none;border:none;color:var(--text);cursor:pointer;display:flex;justify-content:center;opacity:.6;padding:6px 8px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:opacity .2s}.password-toggle:hover{color:var(--primary);opacity:1}.password-toggle:disabled{cursor:not-allowed;opacity:.3}.password-toggle svg{stroke-width:2;height:20px;width:20px}.input-with-status{align-items:center;display:flex;position:relative}.input-with-status input{flex:1 1;padding-right:40px}.status-icon{animation:pulse .5s ease;font-size:18px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.checking{animation:spin 1s linear infinite}@keyframes pulse{0%{transform:translateY(-50%) scale(1)}50%{transform:translateY(-50%) scale(1.1)}to{transform:translateY(-50%) scale(1)}}@keyframes spin{0%{transform:translateY(-50%) rotate(0deg)}to{transform:translateY(-50%) rotate(1turn)}}.password-match-indicator{align-items:center;color:var(--text);display:flex;font-size:13px;gap:8px;margin-top:6px;opacity:.7}.password-match-indicator.valid{color:#10b981}.password-match-indicator.invalid{color:#ef4444}.message{animation:slideIn .2s ease;border-radius:10px;font-size:14px;font-weight:500;margin-bottom:16px;padding:12px 16px}.message.success{background:#10b9811a;border:1px solid #10b98133;color:#10b981}.message.error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}.btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s}.btn.primary{background:linear-gradient(135deg,var(--primary) 0,#b91c1c 100%);color:#fff;margin-bottom:12px;width:100%}.btn.primary:hover:not(:disabled){box-shadow:0 10px 25px #dc26264d;transform:translateY(-2px)}.btn:disabled{cursor:not-allowed;opacity:.6}.forgot-link{color:var(--primary);display:inline-block;font-size:13px;font-weight:600;margin-bottom:16px;text-decoration:none;transition:opacity .2s}.forgot-link:hover{opacity:.8}.modal-footer{color:var(--text);font-size:14px;margin-top:16px;opacity:.7;text-align:center}.modal-footer button{background:none;border:none;color:var(--primary);cursor:pointer;font-weight:600;margin-left:4px;padding:0;transition:opacity .2s}.modal-footer button:hover{opacity:.8}.modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}:root[data-theme=dark] .modal-backdrop{background:#00000080}@media (max-width:600px){.modal{width:95%}.modal-login h2{font-size:24px}.modal-content-inner{padding:30px 20px}.social-login{flex-direction:column}.social-btn{justify-content:center}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cookie-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;bottom:0;left:0;right:0;top:0;z-index:9998}.cookie-banner,.cookie-overlay{pointer-events:auto;position:fixed}.cookie-banner{animation:scaleIn .3s ease-in-out;background:var(--bg);border:2px solid var(--primary);border-radius:12px;box-shadow:0 10px 40px #0006;color:var(--text);left:50%;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;top:50%;transform:translate(-50%,-50%);width:90%;z-index:9999}@keyframes scaleIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.cookie-content{display:flex;flex-direction:column;gap:1.5rem}.cookie-text{flex:1 1}.cookie-text h3{color:var(--primary);font-size:1.2rem;margin:0 0 1rem}.cookie-text p{font-size:.95rem;line-height:1.5;margin:.5rem 0}.cookie-text ul{list-style-position:inside;margin:.5rem 0 1rem 1.5rem;padding:0}.cookie-text li{font-size:.9rem;margin:.25rem 0}.cookie-notice{background:rgba(var(--primary-rgb),.1);border-left:3px solid var(--primary);border-radius:4px;font-size:.85rem;margin:1rem 0 0!important;padding:.75rem}.cookie-notice a{color:var(--primary);text-decoration:underline}.cookie-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-end}.cookie-buttons .btn{border:none;border-radius:4px;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.cookie-buttons .btn-primary{background:var(--primary);color:#fff}.cookie-buttons .btn-primary:hover{filter:brightness(1.1);transform:translateY(-2px)}.cookie-buttons .btn-secondary{background:#0000;border:2px solid var(--text-muted);color:var(--text)}.cookie-buttons .btn-secondary:hover{background:var(--text-muted);color:var(--bg)}@media (max-width:768px){.cookie-banner{max-height:85vh;padding:1.5rem;width:95%}.cookie-text h3{font-size:1.1rem}.cookie-text p{font-size:.9rem}.cookie-buttons{flex-direction:column;justify-content:stretch}.cookie-buttons .btn{flex:1 1}}@media (max-width:480px){.cookie-banner{border-radius:8px;max-height:80vh;padding:1rem;width:96%}.cookie-content{gap:1rem}.cookie-text h3{font-size:1rem;margin-bottom:.5rem}.cookie-text li,.cookie-text p{font-size:.85rem}.cookie-buttons{flex-direction:column;gap:.75rem}.cookie-buttons .btn{font-size:.9rem;padding:.65rem 1rem}}.wallpapers-page{margin:0 auto;max-width:1300px;padding:3rem 1.5rem 5rem}.wallpapers-intro{margin:0 auto 3rem;max-width:650px;text-align:center}.wallpapers-intro p{color:var(--text-muted);font-size:1.1rem;line-height:1.7}.wallpapers-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.wallpaper-card{background:var(--bg-light);border:1px solid var(--border);border-radius:10px;cursor:pointer;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.wallpaper-card:hover{box-shadow:0 12px 40px #0000001f;transform:translateY(-4px)}.wallpaper-img{aspect-ratio:3/4;line-height:0;overflow:hidden;position:relative}.wallpaper-img img{display:block;height:100%;object-fit:cover;transition:transform .5s ease;width:100%}.wallpaper-card:hover .wallpaper-img img{transform:scale(1.05)}.wallpaper-hover{align-items:center;background:#0000004d;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .3s ease}.wallpaper-card:hover .wallpaper-hover{opacity:1}.wallpaper-zoom{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:2px solid #fffc;border-radius:6px;color:#fff;font-size:.95rem;font-weight:600;padding:.5rem 1.2rem}.wallpaper-info{align-items:center;display:flex;justify-content:space-between;padding:.8rem 1rem}.wallpaper-title{color:var(--text);font-size:.95rem;font-weight:600}.wallpaper-download{align-items:center;background:#0000;border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;font-size:1.1rem;height:34px;justify-content:center;transition:all .2s ease;width:34px}.wallpaper-download:hover{background:var(--primary);border-color:var(--primary);color:#fff}.wallpaper-lightbox{align-items:center;animation:fadeIn .2s ease;background:#000000e6;display:flex;inset:0;justify-content:center;padding:2rem;position:fixed;z-index:9999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{align-items:center;display:flex;flex-direction:column;max-height:90vh;max-width:90vw}.lightbox-content img{border-radius:8px;max-height:78vh;max-width:100%;object-fit:contain}.lightbox-bar{align-items:center;display:flex;gap:1.5rem;margin-top:1.2rem}.lightbox-title{color:#fff;font-size:1rem;font-weight:600}.lightbox-download-btn{font-size:.9rem;padding:.5rem 1.5rem}.lightbox-close{align-items:center;background:#0000;border:1px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.lightbox-close:hover{background:#ffffff26}@media (max-width:768px){.wallpapers-page{padding:2rem 1rem 4rem}.wallpapers-grid{gap:1rem;grid-template-columns:repeat(2,1fr)}.wallpaper-lightbox{padding:1rem}.lightbox-content img{max-height:70vh}}@media (max-width:480px){.wallpapers-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.wallpaper-info{padding:.6rem .8rem}.wallpaper-title{font-size:.85rem}}
/*# sourceMappingURL=main.02d79a0c.css.map*/