*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--navy:#1d3461;--navy2:#2a4a7a;--blue:#3a6ea8;--blue-mid:#5a8ec0;--light-blue:#d8eaf5;--lighter-blue:#eef5fb;--white:#fff;--cream:#f4f8fb;--text:#1a2b42;--muted:#5a7082;--gold:#c4903a;--gold2:#daa84e;--border:rgba(58,110,168,0.2);--r:3px}
html{scroll-behavior:smooth}
body{font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;color:var(--text);background:var(--white);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}
.site-banner{width:100%;background:var(--light-blue);line-height:0;display:block}
.site-banner img{width:100%;height:auto;display:block;max-height:84px;object-fit:contain;object-position:center}
nav{background:var(--navy);height:52px;padding:0 4%;display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid var(--blue-mid);position:sticky;top:0;z-index:200}
.nav-links{display:flex;gap:0;list-style:none;height:100%}
.nav-links a{color:rgba(255,255,255,.82);text-decoration:none;font-size:.8rem;font-weight:400;letter-spacing:.04em;padding:0 .9rem;display:flex;align-items:center;border-right:1px solid rgba(255,255,255,.08);transition:background .18s,color .18s}
.nav-links li:first-child a{border-left:1px solid rgba(255,255,255,.08)}
.nav-links a:hover,.nav-links a.active{background:var(--blue);color:#fff}
.nav-right{display:flex;align-items:center;gap:.8rem}
.nav-tel{color:rgba(255,255,255,.55);font-size:.75rem}
.nav-tel a{color:var(--gold2);text-decoration:none;font-weight:700}
.admin-btn{color:rgba(255,255,255,.55);font-size:.78rem;text-decoration:none;background:rgba(255,255,255,.07);padding:.3rem .7rem;border-radius:3px;border:1px solid rgba(255,255,255,.12);cursor:pointer;transition:.2s;white-space:nowrap}
.admin-btn:hover{background:rgba(255,255,255,.15);color:#fff}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.8)}
.mobile-menu{display:none;position:fixed;top:136px;left:0;right:0;background:var(--navy);z-index:199;padding:.8rem 4%;border-bottom:2px solid var(--blue)}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:.6rem 0;color:rgba(255,255,255,.78);text-decoration:none;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.07)}
/* HERO */
#hero{background:linear-gradient(155deg,var(--navy) 0%,var(--navy2) 58%,#2a5080 100%);padding:65px 5% 50px;position:relative;overflow:hidden}
#hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 78% 28%,rgba(58,110,168,.3) 0%,transparent 58%);pointer-events:none}
.hero-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:55px;align-items:center;position:relative;z-index:1}
.hero-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold2);border:1px solid rgba(196,144,58,.45);padding:.28rem .82rem;border-radius:var(--r);margin-bottom:1.4rem}
.hero-title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:clamp(2.1rem,4.2vw,3.5rem);font-weight:700;color:#fff;line-height:1.12;margin-bottom:1.1rem}
.hero-title em{font-style:italic;color:var(--gold2)}
.hero-sub{font-size:.98rem;color:rgba(255,255,255,.66);max-width:470px;margin-bottom:1.9rem;line-height:1.82}
.hero-btns{display:flex;gap:.75rem;flex-wrap:wrap}
.btn-prim{background:var(--blue);color:#fff;text-decoration:none;padding:.78rem 1.7rem;font-weight:700;font-size:.83rem;letter-spacing:.05em;border-radius:var(--r);transition:.2s;border:none;cursor:pointer;display:inline-block;font-family:"Lato",sans-serif}
.btn-prim:hover{background:var(--blue-mid);transform:translateY(-1px)}
.btn-out{border:1px solid rgba(255,255,255,.32);color:rgba(255,255,255,.84);text-decoration:none;padding:.78rem 1.7rem;font-weight:400;font-size:.83rem;border-radius:var(--r);transition:.2s;background:transparent;cursor:pointer;font-family:"Lato",sans-serif}
.btn-out:hover{border-color:var(--gold2);color:var(--gold2)}
.hero-stats{display:flex;flex-wrap:wrap;gap:1.4rem 2.2rem;margin-top:2.8rem;padding-top:1.8rem;border-top:1px solid rgba(255,255,255,.11)}
.stat-num{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.9rem;font-weight:700;color:var(--gold2);display:block;line-height:1.05;white-space:nowrap}
.stat-label{font-size:.7rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em}
.hero-card{background:rgba(255,255,255,.06);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:1.3rem;cursor:pointer;transition:.25s}
.hero-card:hover{border-color:rgba(58,110,168,.6)}
.hero-card-img{width:100%;height:185px;border-radius:4px;overflow:hidden;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.hero-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.hc-tag{font-size:.63rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold2);margin-bottom:.3rem}
.hc-title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.05rem;color:#fff;margin-bottom:.38rem;line-height:1.3}
.hc-meta{font-size:.76rem;color:rgba(255,255,255,.52)}
.hc-price{font-size:1.05rem;font-weight:700;color:var(--gold2);margin-top:.55rem}
/* SECTIONS */
section{padding:70px 5%}
.inner{max-width:1200px;margin:0 auto}
.s-tag{font-size:.67rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:block;margin-bottom:.65rem}
.s-title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:clamp(1.75rem,3.2vw,2.5rem);font-weight:700;color:var(--navy);line-height:1.18;margin-bottom:1rem}
.s-lead{color:var(--muted);font-size:.96rem;max-width:560px;margin:0 auto 2.6rem;line-height:1.8}
.s-center{text-align:center}
.bars{display:flex;align-items:center;gap:4px;margin-bottom:1.2rem}
.bars.c{justify-content:center}
.bar{width:4px;border-radius:2px;background:var(--blue)}
.bar:nth-child(1){height:32px}.bar:nth-child(2){height:24px;opacity:.6}.bar:nth-child(3){height:18px;opacity:.35}
/* PROPS */
#angebote{background:var(--cream)}
.filter-bar{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:2rem}
.filter-btn{background:#fff;border:1px solid var(--border);color:var(--text);padding:.38rem .95rem;border-radius:var(--r);font-size:.79rem;cursor:pointer;transition:.18s;font-family:"Lato",sans-serif}
.filter-btn:hover{background:var(--light-blue)}
.filter-btn.active{background:var(--navy);border-color:var(--navy);color:#fff;font-weight:700}
.props-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.prop-card{background:#fff;border-radius:4px;overflow:hidden;border:1px solid rgba(58,110,168,.12);transition:.25s;cursor:pointer;box-shadow:0 2px 7px rgba(29,52,97,.06)}
.prop-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(29,52,97,.13);border-color:var(--blue-mid)}
.prop-img{width:100%;height:190px;position:relative;overflow:hidden;background:var(--lighter-blue);display:flex;align-items:center;justify-content:center}
.prop-img img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0}
.prop-badge{position:absolute;top:10px;left:10px;font-size:.61rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.26rem .62rem;border-radius:2px;z-index:2}
.badge-kauf{background:var(--navy);color:#fff}.badge-miete{background:var(--blue);color:#fff}.badge-ref{background:#2d6a4f;color:#fff}
.badge-neu{position:absolute;top:10px;right:10px;background:#c0392b;color:#fff;font-size:.58rem;font-weight:700;padding:.24rem .52rem;border-radius:2px;z-index:2}
.prop-body{padding:1rem}
.prop-type{font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:.28rem}
.prop-title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.05rem;font-weight:600;color:var(--navy);margin-bottom:.32rem;line-height:1.3}
.prop-loc{font-size:.78rem;color:var(--muted);margin-bottom:.65rem;display:flex;align-items:center;gap:.28rem}
.prop-feats{display:flex;gap:.85rem;font-size:.76rem;color:var(--muted);margin-bottom:.7rem;flex-wrap:wrap}
.prop-price{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.28rem;font-weight:700;color:var(--navy)}
.no-props{text-align:center;padding:2.5rem;color:var(--muted);grid-column:1/-1}
/* REFERENZEN */
#referenzen{background:var(--navy)}
#referenzen .s-tag{color:var(--gold2)}
#referenzen .s-title{color:#fff}
.ref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:2rem}
.ref-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:5px;overflow:hidden;transition:.25s;cursor:pointer}
.ref-card:hover{border-color:rgba(58,110,168,.6)}
.ref-img{height:148px;background:rgba(255,255,255,.08);overflow:hidden;display:flex;align-items:center;justify-content:center}
.ref-img img{width:100%;height:100%;object-fit:cover;display:block}
.ref-body{padding:.9rem}
.ref-sold{font-size:.6rem;letter-spacing:.13em;text-transform:uppercase;color:var(--gold2);margin-bottom:.27rem}
.ref-title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1rem;color:#fff;margin-bottom:.2rem;line-height:1.3}
.ref-loc{font-size:.75rem;color:rgba(255,255,255,.4)}
/* BEWERTUNGEN */
#bewertungen{background:#fff}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:2rem}
.review-card{background:var(--cream);border-radius:5px;padding:1.4rem;border:1px solid rgba(58,110,168,.1)}
.review-stars{color:var(--gold);font-size:.95rem;margin-bottom:.7rem;letter-spacing:2px}
.review-text{font-size:.87rem;color:var(--text);line-height:1.75;font-style:italic;margin-bottom:.9rem}
.review-author{font-size:.78rem;font-weight:700;color:var(--navy)}
.review-src{font-size:.7rem;color:var(--muted)}
/* ÜBER UNS */
#ueber-uns{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:65px;align-items:center}
.about-img-wrap{position:relative}
.about-img-wrap::before{content:"";position:absolute;top:-15px;left:-15px;width:50%;height:50%;border:2px solid rgba(58,110,168,.35);border-radius:2px}
.about-img{width:100%;aspect-ratio:4/5;border-radius:4px;background:linear-gradient(135deg,var(--navy),var(--navy2));display:flex;align-items:center;justify-content:center;position:relative;z-index:1;overflow:hidden}
.about-img img{width:100%;height:100%;object-fit:cover;display:block}
.about-badge{position:absolute;bottom:22px;right:-22px;background:var(--navy);color:#fff;padding:1rem 1.3rem;border-radius:4px;z-index:2;box-shadow:0 10px 26px rgba(29,52,97,.3);text-align:center}
.about-badge strong{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.9rem;color:var(--gold2);display:block}
.about-badge span{font-size:.68rem;opacity:.62;letter-spacing:.05em}
.about-text p{color:var(--muted);margin-bottom:.95rem;font-size:.96rem;line-height:1.82}
.partner-box{display:inline-flex;align-items:center;gap:.65rem;margin-top:1.1rem;padding:.65rem 1rem;border:1px solid var(--border);border-radius:var(--r);background:#fff;font-size:.82rem;color:var(--muted)}
.partner-box strong{color:var(--navy);font-weight:700}
/* UNSERE EMPFEHLUNG */
#empfehlung{background:var(--cream)}
.empf-card{display:grid;grid-template-columns:300px 1fr;gap:48px;align-items:center;max-width:1000px;margin:2.6rem auto 0;background:#fff;border:1px solid var(--border);border-radius:6px;padding:2.4rem;box-shadow:0 6px 24px rgba(29,52,97,.06)}
.empf-logo{display:flex;align-items:center;justify-content:center;padding:1rem 1.2rem;background:#fff;border:1px solid var(--border);border-radius:5px;transition:.2s}
.empf-logo:hover{border-color:var(--blue);box-shadow:0 3px 12px rgba(29,52,97,.1)}
.empf-logo img{width:100%;height:auto;display:block}
.empf-body h3{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.25rem;color:var(--navy);margin-bottom:.7rem}
.empf-body p{color:var(--muted);font-size:.94rem;line-height:1.8;margin-bottom:.8rem}
.empf-meta{display:flex;flex-wrap:wrap;gap:.6rem 1.6rem;margin-top:1.1rem}
.empf-meta a{color:var(--blue);font-weight:700;font-size:.88rem;text-decoration:none}
.empf-meta a:hover{color:var(--navy);text-decoration:underline}
@media(max-width:640px){.empf-card{grid-template-columns:1fr;gap:26px;padding:1.6rem}}
.info-boxes{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.4rem}
.info-box{background:#fff;border-radius:var(--r);padding:.9rem 1rem;border-left:3px solid var(--blue)}
.info-box strong{display:block;font-size:.8rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}
.info-box span{font-size:.82rem;color:var(--muted)}
/* LEISTUNGEN */
#leistungen{background:#fff}
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.serv-card{background:var(--cream);padding:1.7rem;border-radius:5px;border:1px solid rgba(58,110,168,.1);transition:.25s;position:relative;overflow:hidden}
.serv-card::before{content:"";position:absolute;top:0;left:0;width:3px;height:0;background:var(--blue);transition:height .35s}
.serv-card:hover::before{height:100%}
.serv-icon{width:44px;height:44px;background:var(--lighter-blue);border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.serv-icon svg{width:22px;height:22px;stroke:var(--blue);fill:none;stroke-width:1.6}
.serv-card h3{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.08rem;font-weight:600;color:var(--navy);margin-bottom:.5rem}
.serv-card p{font-size:.87rem;color:var(--muted);line-height:1.75}
/* REGIONEN */
#regionen{background:var(--light-blue);padding:50px 5%}
.reg-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:center}
.rtags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.rtag{background:#fff;border:1px solid rgba(58,110,168,.25);color:var(--navy);padding:.38rem .95rem;border-radius:var(--r);font-size:.81rem;font-weight:700;transition:.18s}
.rtag:hover{background:var(--navy);color:#fff}
/* PORTALE */
#portale{background:var(--cream);padding:45px 5%}
.portale-inner{max-width:1200px;margin:0 auto}
.portale-grid{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:1.5rem}
.portal-box{background:#fff;border:1px solid var(--border);border-radius:5px;padding:1rem 1.5rem;display:flex;align-items:center;gap:.85rem;transition:.2s;text-decoration:none;color:var(--navy)}
.portal-box:hover{border-color:var(--blue);box-shadow:0 3px 12px rgba(29,52,97,.1)}
.portal-icon{width:36px;height:36px;background:var(--lighter-blue);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.portal-icon svg{width:18px;height:18px;stroke:var(--blue);fill:none;stroke-width:1.6}
.portal-name{font-weight:700;font-size:.85rem}
.portal-desc{font-size:.74rem;color:var(--muted)}
/* KONTAKT */
#kontakt{background:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.cd{display:flex;gap:.82rem;margin-bottom:1.2rem;align-items:flex-start}
.cd-icon{width:37px;height:37px;background:var(--navy);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cd-icon svg{width:16px;height:16px;stroke:var(--gold2);fill:none;stroke-width:1.6}
.cd-text strong{display:block;font-weight:700;color:var(--navy);font-size:.87rem;margin-bottom:1px}
.cd-text a,.cd-text span{color:var(--muted);font-size:.86rem;text-decoration:none}
.cd-text a:hover{color:var(--blue)}
.form-box{background:var(--cream);padding:1.7rem;border-radius:5px;border:1px solid rgba(58,110,168,.15)}
.fg{margin-bottom:.95rem}
.fg label{display:block;font-size:.71rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--navy);margin-bottom:.32rem}
.fg input,.fg textarea,.fg select{width:100%;padding:.68rem .82rem;border:1px solid #ccdae8;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.88rem;color:var(--text);background:#fff;outline:none;transition:border-color .18s;appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--blue)}
.fg textarea{height:90px;resize:vertical}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.btn-submit{width:100%;background:var(--navy);color:#fff;border:none;padding:.88rem;font-family:"Lato",sans-serif;font-size:.83rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;border-radius:var(--r);cursor:pointer;transition:.2s}
.btn-submit:hover{background:var(--blue)}
/* LEGAL MODAL */
.legal-modal{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.65);overflow-y:auto;padding:2rem 1rem}
.legal-modal.open{display:block}
.legal-box{background:#fff;border-radius:6px;max-width:780px;margin:0 auto;overflow:hidden}
.legal-head{background:var(--navy);padding:1rem 1.4rem;display:flex;justify-content:space-between;align-items:center}
.legal-head h2{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.2rem;color:#fff}
.legal-close{background:rgba(255,255,255,.1);border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center}
.legal-body{padding:1.8rem;font-size:.88rem;color:var(--text);line-height:1.8}
.legal-body h3{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.05rem;color:var(--navy);margin:1.3rem 0 .5rem}
.legal-body h3:first-child{margin-top:0}
.legal-body p{margin-bottom:.8rem;color:var(--muted)}
.legal-body a{color:var(--blue)}
/* PROP MODAL */
#prop-modal{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.62);overflow-y:auto;padding:2rem 1rem}
#prop-modal.open{display:block}
.modal-box{background:#fff;border-radius:6px;max-width:870px;margin:0 auto;overflow:hidden}
.modal-gallery{position:relative;height:350px;background:var(--lighter-blue);overflow:hidden}
.modal-gallery img,.modal-gallery video,.modal-gallery iframe{width:100%;height:100%;object-fit:cover;display:block;border:none}
.gnav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(29,52,97,.6);color:#fff;border:none;cursor:pointer;width:36px;height:36px;border-radius:50%;font-size:1.15rem;display:flex;align-items:center;justify-content:center;transition:.2s}
.gnav:hover{background:var(--blue)}
.gprev{left:10px}.gnext{right:10px}
.gdots{position:absolute;bottom:9px;left:50%;transform:translateX(-50%);display:flex;gap:5px}
.gdot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.42);cursor:pointer;transition:.2s}
.gdot.active{background:#fff}
.mclose{position:absolute;top:9px;right:9px;background:rgba(0,0,0,.48);color:#fff;border:none;cursor:pointer;width:30px;height:30px;border-radius:50%;font-size:.9rem;display:flex;align-items:center;justify-content:center;z-index:10}
.modal-body{padding:1.7rem}
.modal-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.8rem}
.m-tag{font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:.38rem}
.m-title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.65rem;font-weight:700;color:var(--navy);margin-bottom:.38rem;line-height:1.2}
.m-loc{color:var(--muted);font-size:.86rem;margin-bottom:.9rem}
.m-desc{color:var(--text);font-size:.9rem;line-height:1.85;margin-bottom:1.3rem}
.m-feats{display:grid;grid-template-columns:1fr 1fr;gap:.45rem;margin-bottom:1.1rem}
.mf{display:flex;justify-content:space-between;align-items:center;padding:.42rem .7rem;background:var(--cream);border-radius:var(--r)}
.mf-l{font-size:.75rem;color:var(--muted)}
.mf-v{font-size:.8rem;font-weight:700;color:var(--navy)}
.m-sidebar{border-left:1px solid var(--lighter-blue);padding-left:1.3rem}
.m-price{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.9rem;font-weight:700;color:var(--navy);margin-bottom:.22rem}
.m-plbl{font-size:.71rem;color:var(--muted);margin-bottom:1.2rem}
.mcta{display:block;text-align:center;padding:.78rem 1rem;font-weight:700;font-size:.81rem;border-radius:var(--r);margin-bottom:.55rem;cursor:pointer;border:none;width:100%;font-family:"Lato",sans-serif;text-decoration:none;transition:.2s}
.mcta-a{background:var(--blue);color:#fff}.mcta-a:hover{background:var(--navy)}
.mcta-b{background:var(--navy);color:#fff}.mcta-b:hover{background:var(--blue)}
/* FOOTER */
footer{background:var(--navy);border-top:3px solid var(--blue-mid);padding:48px 5% 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:42px;max-width:1200px;margin:0 auto;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand p{font-size:.81rem;color:rgba(255,255,255,.4);line-height:1.8;max-width:240px;margin-top:.8rem}
.footer-col h4{font-size:.65rem;font-weight:700;letter-spacing:.17em;text-transform:uppercase;color:var(--gold2);margin-bottom:.8rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.38rem}
.footer-col a{color:rgba(255,255,255,.4);text-decoration:none;font-size:.81rem;transition:.18s;cursor:pointer}
.footer-col a:hover{color:var(--gold2)}
.footer-bottom{max-width:1200px;margin:.8rem auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.71rem;color:rgba(255,255,255,.26)}
.footer-bottom a{color:rgba(255,255,255,.26);text-decoration:none;transition:.2s;cursor:pointer}
.footer-bottom a:hover{color:var(--gold2)}
/* PASSWORD MODAL */
#pw-modal{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.72);align-items:center;justify-content:center}
#pw-modal.open{display:flex}
.pw-box{background:#fff;border-radius:8px;width:380px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.pw-head{background:var(--navy);padding:1.1rem 1.4rem;display:flex;align-items:center;gap:.7rem}
.pw-head svg{width:20px;height:20px;stroke:var(--gold2);fill:none;stroke-width:1.6;flex-shrink:0}
.pw-head h3{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.1rem;color:#fff;font-weight:600}
.pw-body{padding:1.6rem}
.pw-body p{font-size:.87rem;color:var(--muted);margin-bottom:1rem;line-height:1.6}
.pw-inp{width:100%;padding:.78rem .9rem;border:1.5px solid #cddae8;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.95rem;color:var(--text);outline:none;transition:border-color .18s;margin-bottom:.75rem}
.pw-inp:focus{border-color:var(--blue)}
.pw-err{color:#c0392b;font-size:.78rem;margin-bottom:.6rem;display:none}
.pw-btns{display:flex;gap:.7rem}
.pw-ok{flex:1;background:var(--navy);color:#fff;border:none;padding:.8rem;font-family:"Lato",sans-serif;font-size:.85rem;font-weight:700;border-radius:var(--r);cursor:pointer;transition:.2s}
.pw-ok:hover{background:var(--blue)}
.pw-cancel{background:var(--cream);color:var(--navy);border:1px solid var(--border);padding:.8rem 1.2rem;font-family:"Lato",sans-serif;font-size:.85rem;font-weight:600;border-radius:var(--r);cursor:pointer}
/* ═══════════════ ADMIN CMS ═══════════════ */
#admin-overlay{display:none;position:fixed;inset:0;z-index:3000;background:#f0f4f8}
#admin-overlay.open{display:flex;flex-direction:column}
.adm-bar{background:var(--navy);height:54px;display:flex;align-items:center;padding:0 1.5rem;gap:1rem;border-bottom:3px solid var(--blue-mid);flex-shrink:0}
.adm-bar-logo{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1rem;color:var(--gold2);font-weight:700;margin-right:auto}
.adm-bar-logo span{font-family:"Lato",sans-serif;font-size:.7rem;color:rgba(255,255,255,.45);font-weight:400;display:block;letter-spacing:.1em;text-transform:uppercase}
.adm-save-btn{background:var(--gold);color:var(--navy);border:none;padding:.5rem 1.4rem;font-family:"Lato",sans-serif;font-size:.82rem;font-weight:700;border-radius:var(--r);cursor:pointer;transition:.2s}
.adm-save-btn:hover{background:var(--gold2)}
.adm-save-btn:disabled{opacity:.5;cursor:not-allowed}
.adm-close-btn{background:rgba(255,255,255,.1);color:#fff;border:none;padding:.5rem 1rem;font-family:"Lato",sans-serif;font-size:.82rem;border-radius:var(--r);cursor:pointer;transition:.2s}
.adm-close-btn:hover{background:rgba(255,255,255,.2)}
.adm-status{font-size:.75rem;color:rgba(255,255,255,.55);min-width:140px;text-align:right}
.adm-main{display:flex;flex:1;overflow:hidden}
/* Sidebar */
.adm-sidebar{width:220px;background:#fff;border-right:1px solid #dde6f0;overflow-y:auto;flex-shrink:0;padding:.8rem 0}
.adm-nav-group{margin-bottom:1rem}
.adm-nav-label{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);padding:.2rem 1.2rem .6rem;display:block}
.adm-nav-item{display:flex;align-items:center;gap:.6rem;padding:.55rem 1.2rem;cursor:pointer;transition:.15s;border-left:3px solid transparent;font-size:.85rem;color:var(--text);user-select:none}
.adm-nav-item:hover{background:var(--cream);color:var(--navy)}
.adm-nav-item.active{background:var(--lighter-blue);border-left-color:var(--blue);color:var(--navy);font-weight:700}
.adm-nav-item svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.6;flex-shrink:0}
/* Content area */
.adm-content{flex:1;overflow-y:auto;padding:2rem 2.5rem}
.adm-panel{display:none}
.adm-panel.active{display:block}
.adm-panel-title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.5rem;color:var(--navy);margin-bottom:.4rem}
.adm-panel-desc{font-size:.85rem;color:var(--muted);margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #dde6f0}
/* Form elements */
.adm-section{background:#fff;border:1px solid #dde6f0;border-radius:6px;padding:1.4rem;margin-bottom:1.4rem}
.adm-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #eef3f8}
.adm-field{margin-bottom:1rem}
.adm-field label{display:block;font-size:.73rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);margin-bottom:.32rem}
.adm-field label small{font-weight:400;letter-spacing:0;text-transform:none;color:var(--muted);font-size:.7rem;margin-left:.4rem}
.adm-inp,.adm-ta,.adm-sel{width:100%;padding:.65rem .85rem;border:1px solid #cddae8;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.88rem;color:var(--text);background:#fff;outline:none;transition:border-color .18s}
.adm-inp:focus,.adm-ta:focus,.adm-sel:focus{border-color:var(--blue)}
.adm-ta{min-height:90px;resize:vertical;line-height:1.6}
.adm-ta.tall{min-height:200px}
.adm-ta.code{font-family:monospace;font-size:.82rem;min-height:160px}
.adm-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.adm-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
/* Card editor (services, reviews, stats) */
.card-list{display:flex;flex-direction:column;gap:.7rem}
.card-item{background:var(--cream);border:1px solid #dde6f0;border-radius:5px;overflow:hidden}
.card-item-head{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;cursor:pointer;user-select:none}
.card-item-head:hover{background:#e8eff7}
.card-item-num{background:var(--blue);color:#fff;width:22px;height:22px;border-radius:50%;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.card-item-label{font-weight:700;font-size:.85rem;color:var(--navy);flex:1}
.card-item-actions{display:flex;gap:.4rem}
.ci-btn{background:none;border:1px solid #cddae8;color:var(--muted);width:26px;height:26px;border-radius:3px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:.15s}
.ci-btn:hover{background:#fff;border-color:var(--blue);color:var(--blue)}
.ci-btn.del:hover{border-color:#e74c3c;color:#e74c3c}
.card-item-body{padding:0 1rem 1rem;display:none}
.card-item-body.open{display:block}
/* Tag list editor */
.tag-editor{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.6rem;padding:.5rem;border:1px solid #cddae8;border-radius:var(--r);min-height:44px;background:#fff}
.tag-chip{background:var(--lighter-blue);border:1px solid var(--border);color:var(--navy);padding:.25rem .6rem;border-radius:var(--r);font-size:.78rem;display:flex;align-items:center;gap:.3rem}
.tag-chip button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.75rem;padding:0;line-height:1}
.tag-chip button:hover{color:#e74c3c}
.tag-add-row{display:flex;gap:.5rem;margin-top:.4rem}
/* Media chips */
.media-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.media-chip{background:var(--lighter-blue);border-radius:3px;padding:.25rem .5rem;font-size:.72rem;display:flex;align-items:center;gap:.3rem;color:var(--navy)}
.media-chip button{background:none;border:none;cursor:pointer;color:#b00;font-size:.78rem;padding:0}
.media-previews{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.media-prev{position:relative;width:70px;height:52px;border-radius:3px;overflow:hidden;background:var(--lighter-blue);border:1px solid var(--border)}
.media-prev img{width:100%;height:100%;object-fit:cover}
.media-prev button{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.6);color:#fff;border:none;width:16px;height:16px;border-radius:50%;cursor:pointer;font-size:.6rem;display:flex;align-items:center;justify-content:center}
/* Action buttons */
.adm-add-btn{background:var(--lighter-blue);border:1px dashed var(--blue);color:var(--blue);padding:.55rem 1rem;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;width:100%;transition:.15s;margin-top:.5rem}
.adm-add-btn:hover{background:var(--light-blue)}
.adm-del-row{background:#fee2e2;border:1px solid #fca5a5;color:#b91c1c;padding:.45rem .9rem;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.78rem;font-weight:700;cursor:pointer;transition:.15s}
.adm-del-row:hover{background:#fca5a5}
/* Properties table in admin */
.prop-table{width:100%;border-collapse:collapse;font-size:.82rem}
.prop-table th{text-align:left;padding:.6rem .8rem;background:var(--cream);border-bottom:2px solid #dde6f0;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);white-space:nowrap}
.prop-table td{padding:.65rem .8rem;border-bottom:1px solid #eef3f8;vertical-align:middle}
.prop-table tr:hover td{background:#fafcff}
.prop-status{display:inline-block;padding:.18rem .55rem;border-radius:2px;font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.ps-kauf{background:var(--navy);color:#fff}
.ps-miete{background:var(--blue);color:#fff}
.ps-ref{background:#2d6a4f;color:#fff}
.tbl-btn{padding:.3rem .65rem;border-radius:var(--r);border:none;font-size:.72rem;font-weight:700;cursor:pointer;font-family:"Lato",sans-serif}
.tbl-edit{background:var(--navy);color:#fff}.tbl-edit:hover{background:var(--blue)}
.tbl-del{background:#fee2e2;color:#b00}.tbl-del:hover{background:#fca5a5}
/* Prop form drawer */
#prop-form-wrap{display:none;background:#fff;border:1px solid #dde6f0;border-radius:6px;padding:1.4rem;margin-top:1.2rem}
#prop-form-wrap.open{display:block}
/* Settings – color picker row */
.color-row{display:flex;align-items:center;gap:.8rem}
.color-row input[type=color]{width:44px;height:34px;border:1px solid #cddae8;border-radius:var(--r);cursor:pointer;padding:2px}
.color-row span{font-size:.82rem;color:var(--muted)}
/* Toolbar for rich text */
.rt-toolbar{display:flex;gap:.3rem;margin-bottom:.4rem;flex-wrap:wrap}
.rt-btn{background:var(--cream);border:1px solid #cddae8;color:var(--navy);padding:.25rem .55rem;border-radius:2px;font-size:.75rem;font-weight:700;cursor:pointer;font-family:monospace}
.rt-btn:hover{background:var(--light-blue)}
/* Notice */
.adm-notice{padding:.65rem 1rem;border-radius:var(--r);font-size:.82rem;margin-bottom:1rem;display:none}
.adm-notice.ok{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.adm-notice.err{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
/* Responsive */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr}.hero-img-side{display:none}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:38px}
  .props-grid,.ref-grid,.serv-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .modal-grid{grid-template-columns:1fr}
  .m-sidebar{border-left:none;padding-left:0;border-top:1px solid var(--lighter-blue);padding-top:1.2rem}
  .reg-inner{grid-template-columns:1fr}
  .adm-sidebar{width:180px}
}
@media(max-width:640px){
  .nav-links{display:none}.hamburger{display:flex}
  .props-grid,.ref-grid,.serv-grid,.reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .fg-row,.adm-row,.adm-row3{grid-template-columns:1fr}
  .about-badge{right:8px}
  .info-boxes{grid-template-columns:1fr}
  .adm-main{flex-direction:column}
  .adm-sidebar{width:100%;border-right:none;border-bottom:1px solid #dde6f0;overflow-x:auto;overflow-y:hidden;white-space:nowrap;padding:.5rem;display:flex;gap:.3rem}
  .adm-nav-group{display:inline-flex;gap:.2rem;margin:0}
  .adm-nav-label{display:none}
  .adm-nav-item{border-left:none;border-bottom:3px solid transparent;border-radius:4px;padding:.45rem .8rem;font-size:.78rem}
  .adm-nav-item.active{border-left:none;border-bottom-color:var(--blue)}
}

/* ═══════════ UPLOAD WIDGET ═══════════ */
.upload-zone{border:2px dashed var(--border);border-radius:6px;padding:1.8rem;text-align:center;cursor:pointer;transition:.2s;background:var(--cream);position:relative}
.upload-zone:hover,.upload-zone.drag{border-color:var(--blue);background:var(--lighter-blue)}
.upload-zone.drag{border-style:solid}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upload-zone p{font-size:.85rem;color:var(--muted);margin:.3rem 0}
.upload-zone strong{font-size:.9rem;color:var(--navy)}
.upload-progress{height:4px;background:var(--light-blue);border-radius:2px;margin-top:.6rem;overflow:hidden;display:none}
.upload-progress-bar{height:100%;background:var(--blue);width:0%;transition:width .3s}
.upload-tabs{display:flex;gap:0;margin-bottom:.8rem;border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.upload-tab{flex:1;padding:.5rem;text-align:center;font-size:.78rem;font-weight:700;cursor:pointer;background:#fff;color:var(--muted);border:none;font-family:"Lato",sans-serif;transition:.15s}
.upload-tab.active{background:var(--navy);color:#fff}

/* ═══════════ ADMIN LOGIN PAGE ═══════════ */
.login-page{min-height:100vh;background:linear-gradient(155deg,var(--navy),var(--navy2));display:flex;align-items:center;justify-content:center;padding:2rem}
.login-card{background:#fff;border-radius:10px;width:420px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.35)}
.login-card-head{background:var(--navy);padding:2rem 2rem 1.5rem}
.login-card-head img{height:50px;width:auto;max-width:280px;object-fit:contain;display:block;margin-bottom:1rem}
.login-card-head h1{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.3rem;color:#fff;font-weight:700}
.login-card-head p{font-size:.8rem;color:rgba(255,255,255,.55);margin-top:.3rem}
.login-card-body{padding:2rem}
.login-field{margin-bottom:1rem}
.login-field label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--navy);margin-bottom:.35rem}
.login-field input{width:100%;padding:.82rem .95rem;border:1.5px solid #cddae8;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.95rem;outline:none;transition:border-color .18s}
.login-field input:focus{border-color:var(--blue)}
.login-btn{width:100%;background:var(--navy);color:#fff;border:none;padding:.95rem;font-family:"Lato",sans-serif;font-size:.9rem;font-weight:700;border-radius:var(--r);cursor:pointer;transition:.2s;margin-top:.5rem}
.login-btn:hover{background:var(--blue)}
.login-error{color:#c0392b;font-size:.8rem;margin-top:.5rem;display:none}
.login-footer{text-align:center;padding:.8rem;background:var(--cream);font-size:.72rem;color:var(--muted)}

/* ═══════════ AI ASSISTANT ═══════════ */
.ai-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:.35rem .75rem;border-radius:var(--r);font-size:.72rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap;font-family:"Lato",sans-serif;transition:.2s;margin-top:.3rem}
.ai-btn:hover{opacity:.88;transform:translateY(-1px)}
.ai-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2}
.ai-modal{display:none;position:fixed;inset:0;z-index:4000;background:rgba(0,0,0,.65);align-items:center;justify-content:center;padding:1rem}
.ai-modal.open{display:flex}
.ai-box{background:#fff;border-radius:8px;width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}
.ai-box-head{background:linear-gradient(135deg,#6366f1,#8b5cf6);padding:1rem 1.4rem;display:flex;align-items:center;gap:.6rem;justify-content:space-between}
.ai-box-head h3{color:#fff;font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-size:1.1rem}
.ai-box-head button{background:rgba(255,255,255,.15);border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.9rem}
.ai-body{padding:1.2rem;overflow-y:auto;flex:1}
.ai-provider-row{display:flex;gap:.5rem;margin-bottom:.9rem}
.ai-prov-btn{flex:1;padding:.5rem;border:1.5px solid #ddd;border-radius:var(--r);background:#fff;cursor:pointer;font-family:"Lato",sans-serif;font-size:.8rem;font-weight:700;transition:.15s}
.ai-prov-btn.active{border-color:#6366f1;background:#f0f0ff;color:#6366f1}
.ai-prompt{width:100%;padding:.7rem .85rem;border:1px solid #cddae8;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.87rem;resize:vertical;height:80px;outline:none;margin-bottom:.6rem}
.ai-prompt:focus{border-color:#6366f1}
.ai-result{background:var(--cream);border-radius:var(--r);padding:.9rem;font-size:.87rem;line-height:1.75;min-height:60px;margin-bottom:.8rem;white-space:pre-wrap;border:1px solid #dde6f0;display:none}
.ai-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.ai-run-btn{background:#6366f1;color:#fff;border:none;padding:.65rem 1.3rem;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.83rem;font-weight:700;cursor:pointer;transition:.2s}
.ai-run-btn:hover{background:#4f46e5}
.ai-insert-btn{background:var(--navy);color:#fff;border:none;padding:.65rem 1.3rem;border-radius:var(--r);font-family:"Lato",sans-serif;font-size:.83rem;font-weight:700;cursor:pointer;transition:.2s;display:none}
.ai-spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin-right:.4rem;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══════════ EXPOSÉ DOWNLOAD ═══════════ */
.expose-modal{display:none;position:fixed;inset:0;z-index:3500;background:rgba(0,0,0,.65);align-items:center;justify-content:center;padding:1rem}
.expose-modal.open{display:flex}
.expose-box{background:#fff;border-radius:8px;width:540px;overflow:hidden}
.expose-head{background:var(--navy);padding:1.1rem 1.4rem;display:flex;justify-content:space-between;align-items:center}
.expose-head h3{font-family:"Playfair Display",Georgia,"Times New Roman",serif;color:#fff;font-size:1.1rem}
.expose-body{padding:1.5rem}
.expose-consent{background:var(--cream);border:1px solid var(--border);border-radius:var(--r);padding:1rem;margin-bottom:1rem;font-size:.83rem;color:var(--muted);line-height:1.7;max-height:200px;overflow-y:auto}
.expose-check-row{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.7rem;font-size:.84rem;color:var(--text)}
.expose-check-row input{margin-top:3px;flex-shrink:0}
.expose-dl-btn{width:100%;background:var(--navy);color:#fff;border:none;padding:.9rem;font-family:"Lato",sans-serif;font-size:.85rem;font-weight:700;border-radius:var(--r);cursor:pointer;transition:.2s}
.expose-dl-btn:hover{background:var(--blue)}
.expose-dl-btn:disabled{opacity:.4;cursor:not-allowed}

/* ═══════════ USERS PANEL ═══════════ */
.user-table{width:100%;border-collapse:collapse;font-size:.82rem}
.user-table th{text-align:left;padding:.6rem .8rem;background:var(--cream);border-bottom:2px solid #dde6f0;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.user-table td{padding:.65rem .8rem;border-bottom:1px solid #eef3f8}
.role-badge{display:inline-block;padding:.18rem .55rem;border-radius:2px;font-size:.65rem;font-weight:700;text-transform:uppercase}
.role-admin{background:#fef3c7;color:#92400e}
.role-editor{background:#dbeafe;color:#1e40af}
.role-viewer{background:#d1fae5;color:#065f46}

/* ═══════════ PORTAL EXPORT ═══════════ */
.portal-export-btn{display:flex;align-items:center;gap:.6rem;padding:.7rem 1.2rem;border:1px solid var(--border);border-radius:var(--r);background:#fff;cursor:pointer;font-family:"Lato",sans-serif;font-size:.83rem;font-weight:700;color:var(--navy);transition:.18s;width:100%}
.portal-export-btn:hover{border-color:var(--blue);background:var(--lighter-blue)}
.portal-export-btn svg{width:18px;height:18px;stroke:var(--blue);fill:none;stroke-width:1.6;flex-shrink:0}

/* ═══════════ ENERGY CERTIFICATE ═══════════ */
.energy-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.3rem .8rem;border-radius:var(--r);font-size:.75rem;font-weight:700;background:var(--lighter-blue);color:var(--navy);border:1px solid var(--border);margin-top:.3rem}
.energy-class-A{background:#00a651;color:#fff}
.energy-class-B{background:#50b848;color:#fff}
.energy-class-C{background:#bed630;color:#333}
.energy-class-D{background:#fff200;color:#333}
.energy-class-E{background:#ffb800;color:#333}
.energy-class-F{background:#f7941d;color:#fff}
.energy-class-G{background:#f15a22;color:#fff}
.energy-class-H{background:#ed1c24;color:#fff}

/* ═══════════ RESPONSIVE ADDITIONS ═══════════ */
@media(max-width:640px){
  .login-card{width:100%;max-width:420px}
  .ai-box{width:100%}
  .expose-box{width:100%}
}

/* ═══ MEDIEN-THUMBNAILS / GALERIE ═══ */
#media-lib{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.7rem}
.file-thumb{width:100%;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.07);display:flex;flex-direction:column;position:relative}
.file-thumb img{width:100%;height:72px;object-fit:cover;display:block;background:#eef2f7}
.file-thumb-pdf{min-height:72px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:#eef2f7}
.file-thumb-label{font-size:.62rem;padding:.28rem .4rem;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;color:var(--text);font-weight:600}
.file-thumb-del{position:absolute;top:3px;right:3px;background:rgba(220,38,38,.92);color:#fff;border:none;border-radius:3px;width:18px;height:18px;font-size:.7rem;line-height:1;cursor:pointer;padding:0}

/* ═══ IMPORT PANEL ═══ */
.imp-tab{transition:all .18s}
.imp-tab:hover{color:var(--navy)!important}
#import-cards{display:flex;flex-wrap:wrap;gap:.5rem}
#import-cards .file-thumb{width:90px}

