/*
  Lübecker Bauunternehmen GmbH – modern, clean, animated
*/
:root{
  --bg: #fefefe;
  --surface: #ffffff;
  --text: #1f2937;
  --muted: #6b7280;
  --primary: #dc2626;
  --primary-600: #b91c1c;
  --primary-700: #991b1b;
  --accent: #0ea5e9;
  --card: rgba(255,255,255,0.95);
  --glass: rgba(255,255,255,.85);
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --shadow-lg: 0 20px 50px rgba(0,0,0,.12);
  --border: rgba(0,0,0,.08);
  --radius: 16px;
  --radius-sm: 12px;
  --container: 1200px;
  --gradient-warm: linear-gradient(135deg, #fef3c7 0%, #fed7aa 50%, #fecaca 100%);
  --gradient-cool: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 50%, #93c5fd 100%);
}
*{box-sizing:border-box}
html,body{height:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background: radial-gradient(1200px 800px at 80% -10%, rgba(254,243,199,.4), transparent 60%),
              radial-gradient(900px 700px at 10% -10%, rgba(220,38,38,.08), transparent 60%),
              var(--bg);
  line-height: 1.6;
}
img{max-width:100%;display:block}

.container{width:min(var(--container), 90%); margin-inline:auto}
.center{text-align:center}
.align-center{align-items:center}

/* Header */
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(20px);background:rgba(255,255,255,.92);border-bottom:1px solid var(--border);box-shadow: 0 1px 3px rgba(0,0,0,.05)}
.nav-container{display:flex;justify-content:space-between;align-items:center;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:700}
.brand__mark{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#ef4444);box-shadow: 0 2px 8px rgba(220,38,38,.25)}
.brand__name{font-size:14px;letter-spacing:.3px;color:var(--text);font-weight:600}
@media (max-width: 480px){
  .brand__name{font-size:12px;display:none}
  .brand__mark{width:32px;height:32px}
  .hero__content{padding:20px 8px 20px 8px;margin:0 2px;max-width:calc(100vw - 16px)}
  .hero h1{font-size:clamp(16px, 4.8vw, 22px)}
  .lead{font-size:11px}
  .container{width:98%;padding:0 4px}
  .section{padding:32px 0}
  .intro-card{padding:16px;margin:0 2px}
  .intro-card__title{font-size:clamp(14px, 3.2vw, 18px)}
  .section__title{font-size:clamp(16px, 2vw, 26px)}
  .section__subtitle{font-size:12px}
  .card__body{padding:14px}
  .card__body h3{font-size:14px}
  .card__body p{font-size:11px}
  .btn{font-size:13px;padding:10px 14px}
}
.nav__toggle{display:none;background:none;border:1px solid var(--border);color:var(--text);border-radius:10px;padding:8px 10px}
.nav__menu{list-style:none;display:flex;gap:22px;margin:0;padding:0}
.nav__menu a{color:var(--text);text-decoration:none;font-weight:500;position:relative;transition:.3s}
.nav__menu a::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--primary);transform:scaleX(0);transform-origin:left;transition:.35s}
.nav__menu a:hover::after{transform:scaleX(1)}
@media (max-width: 860px){
  .nav__toggle{display:block}
  .nav__menu{position:fixed;inset:60px 0 auto 0;flex-direction:column;background:var(--surface);border-bottom:1px solid var(--border);padding:18px 20px;transform:translateY(-140%);transition:.35s;box-shadow:var(--shadow)}
  .nav__menu.open{transform:translateY(0)}
}

/* Hero */
.hero{position:relative;min-height:82vh;display:grid;place-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.85) saturate(1.1);animation:heroZoom 20s ease-in-out infinite alternate}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to top, var(--bg) 0%, rgba(0,0,0,.4) 30%, rgba(0,0,0,.6) 70%, rgba(0,0,0,.3) 100%)}
@keyframes heroZoom{0%{transform:scale(1)} 100%{transform:scale(1.05)}}
.hero__content{position:relative;padding-block:8vh;text-align:center;background:rgba(255,255,255,.55);border-radius:24px;backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.4);box-shadow:0 20px 60px rgba(0,0,0,.1);max-width:900px;margin:0 auto;padding:50px 32px 50px 32px}
.hero h1{font-size:clamp(28px, 4.2vw, 48px);margin:0 0 20px;line-height:1.1;color:var(--text)}
.hero .accent{color:var(--primary);font-weight:700}
.lead{font-size:clamp(16px, 1.6vw, 19px);color:var(--muted);max-width:700px;margin:0 auto 32px;font-weight:400;line-height:1.6}
.hero__cta{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.scroll-down{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);width:26px;height:42px;border:2px solid rgba(31,41,55,.4);border-radius:20px}
.scroll-down::after{content:"";position:absolute;top:8px;left:50%;width:6px;height:6px;border-radius:50%;background:var(--text);transform:translateX(-50%);animation:scroll 1.6s infinite}
@keyframes scroll{0%{opacity:1;transform:translate(-50%,0)} 100%{opacity:0;transform:translate(-50%,16px)}}

/* Sections */
.section{padding:72px 0}
.section--alt{background:linear-gradient(180deg, rgba(254,243,199,.15), rgba(254,243,199,.05))}
.section--cta{background: radial-gradient(600px 400px at 10% 10%, rgba(14,165,233,.08), transparent 60%),
              linear-gradient(180deg, rgba(219,234,254,.2), rgba(219,234,254,.05));}
.section__title{font-size:clamp(24px, 3.2vw, 40px);margin:0 0 10px}
.section__subtitle{color:var(--muted);margin:0 0 26px;font-size:18px;font-weight:400}

/* Grids */
.grid{display:grid}
.grid--2col{grid-template-columns:1.1fr .9fr}
.grid--3col{grid-template-columns:repeat(3, 1fr)}
.gap-lg{gap:26px}
.gap-xl{gap:40px}
@media (max-width: 980px){
  .grid--2col{grid-template-columns:1fr}
  .grid--3col{grid-template-columns:1fr}
  .hero__content{padding:32px 24px;margin:0 16px}
  .intro-card{grid-template-columns:1fr;gap:24px}
  .intro-card__image{min-height:250px}
}

/* Intro Card */
.intro-card{display:grid;grid-template-columns:1.2fr 0.8fr;gap:32px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);align-items:center}
.intro-card__title{font-size:clamp(24px, 3vw, 32px);margin:0 0 20px;color:var(--text);line-height:1.2}
.intro-card__text p{color:var(--muted);line-height:1.6;margin-bottom:16px}
.intro-card__text p:last-child{margin-bottom:0}
.intro-card__text strong{color:var(--text);font-weight:600}
.intro-card__image{background-size:cover;background-position:center;border-radius:12px;min-height:300px;transition:transform .6s ease}
.intro-card:hover .intro-card__image{transform:scale(1.02)}

/* About Highlight Box */
.about-highlight-box{display:grid;grid-template-columns:1.2fr 0.8fr;gap:32px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);align-items:center;margin-bottom:40px}
.about-highlight-box__content h3{font-size:clamp(20px, 2.5vw, 28px);margin:0 0 20px;color:var(--primary);font-weight:600}
.about-highlight-box__content p{color:var(--muted);line-height:1.6;margin-bottom:16px}
.about-highlight-box__content p:last-of-type{margin-bottom:24px}
.about-highlight-box__image{background-size:cover;background-position:center;border-radius:12px;min-height:280px;transition:transform .6s ease}
.about-highlight-box:hover .about-highlight-box__image{transform:scale(1.02)}

.highlight-features{display:grid;grid-template-columns:repeat(2, 1fr);gap:16px}
.highlight-feature{display:flex;align-items:center;gap:12px;padding:12px 16px;background:rgba(var(--primary-rgb), 0.08);border-radius:8px;transition:all .3s ease}
.highlight-feature:hover{background:rgba(var(--primary-rgb), 0.12);transform:translateX(4px)}
.highlight-icon{font-size:20px;flex-shrink:0}
.highlight-feature span:last-child{font-weight:500;color:var(--text)}

@media (max-width: 768px){
  .about-highlight-box{grid-template-columns:1fr;gap:24px}
  .highlight-features{grid-template-columns:1fr;gap:12px}
  .hero__content{padding:24px 12px 24px 12px;margin:0 4px;max-width:calc(100vw - 24px)}
  .hero h1{font-size:clamp(18px, 4.4vw, 26px);line-height:1.2;word-wrap:break-word}
  .lead{font-size:12px;line-height:1.5}
  .hero__cta{flex-direction:column;align-items:center;gap:12px}
  .section{padding:40px 0}
  .container{width:min(var(--container), 96%);padding:0 8px}
  .intro-card{padding:20px;margin:0 4px}
  .intro-card__title{font-size:clamp(16px, 4vw, 22px);line-height:1.3}
  .section__title{font-size:clamp(19px, 2.6vw, 32px)}
  .section__subtitle{font-size:14px}
  .card__body h3{font-size:16px}
  .card__body p{font-size:13px}
}

/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card__media{aspect-ratio:16/10;background-size:cover;background-position:center;}
.zoomable{transition:transform .6s ease}
.card:hover .zoomable{transform:scale(1.05)}
.card__body{padding:18px}
.card__body h3{margin:4px 0 8px}
.card__body p{color:var(--muted);line-height:1.6}

/* Buttons */
.btn{--pad:14px 18px;display:inline-flex;align-items:center;gap:10px;padding:var(--pad);border-radius:12px;border:1px solid transparent;color:#fff;text-decoration:none;font-weight:600;letter-spacing:.2px;cursor:pointer;transition:.3s}
.btn--primary{background:linear-gradient(135deg,var(--primary), #ef4444);box-shadow: 0 4px 14px rgba(220,38,38,.25)}
.btn--primary:hover{filter:brightness(1.05)}
.btn--ghost{background:rgba(255,255,255,.1);border-color:var(--border);color:var(--text);backdrop-filter:blur(10px)}
.btn--small{--pad:10px 14px;font-size:14px}

/* Stats */
.stats{justify-items:center}
.stat{background:var(--glass);border:1px solid var(--border);padding:22px 20px;border-radius:var(--radius);text-align:center;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.stat__num{font-size:clamp(28px, 4vw, 52px);font-weight:800;background:linear-gradient(90deg,var(--primary), var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__label{color:var(--muted)}

/* Kontakt */
.contact-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.contact-item{color:var(--text);text-decoration:none;border-bottom:1px dashed var(--border);width:fit-content;font-weight:500}
.contact-form{background:var(--card);border:1px solid var(--border);padding:24px;border-radius:var(--radius);box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input, textarea{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:12px;font:inherit;transition:.3s}
textarea{resize:vertical}
.form-note{color:var(--muted)}
@media (max-width:720px){.form-row{grid-template-columns:1fr}}

/* Footer */
.site-footer{padding:32px 0;border-top:1px solid var(--border);background:linear-gradient(180deg, rgba(254,243,199,.1), rgba(254,243,199,.05))}
.footer-container{display:flex;justify-content:space-between;align-items:center;gap:16px}
.footer-nav{display:flex;gap:16px}
.footer-nav a{color:var(--muted);text-decoration:none}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}
.reveal.reveal--visible{opacity:1;transform:translateY(0)}

/* Utility */
.accent{color:var(--accent)}

/* Page Hero */
.hero--page{min-height:50vh}
.hero--page .hero__content{padding:32px 24px}

/* Service Cards */
.services-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-top:40px}
.service-card{display:grid;grid-template-columns:80px 1fr 200px;gap:24px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);align-items:start}
.service-card__icon{display:grid;place-items:center;width:64px;height:64px;background:linear-gradient(135deg,var(--primary),#ef4444);border-radius:16px;color:white}
.service-card__icon svg{width:32px;height:32px}
.service-card__content h3{margin:0 0 12px;color:var(--text)}
.service-card__content p{color:var(--muted);margin-bottom:16px;line-height:1.5}
.service-list{list-style:none;padding:0;margin:0}
.service-list li{position:relative;padding-left:20px;margin-bottom:8px;color:var(--muted)}
.service-list li::before{content:'✓';position:absolute;left:0;color:var(--primary);font-weight:bold}
.service-card__image{background-size:cover;background-position:center;border-radius:12px;min-height:150px}

/* Process Steps */
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-top:40px}
.step{text-align:center;padding:24px}
.step__number{display:inline-grid;place-items:center;width:48px;height:48px;background:var(--primary);color:white;border-radius:50%;font-weight:700;font-size:18px;margin-bottom:16px}
.step__content h3{margin:0 0 8px}
.step__content p{color:var(--muted);line-height:1.5}

/* CTA Content */
.cta-content{text-align:center;max-width:700px;margin:0 auto}
.cta-buttons{display:flex;justify-content:center;gap:16px;margin-top:24px;flex-wrap:wrap}

/* Lead Text */
.lead-text{font-size:clamp(18px,2vw,22px);color:var(--muted);text-align:center;max-width:800px;margin:0 auto;line-height:1.6}

/* Active Navigation */
.nav__menu a.active{color:var(--primary);font-weight:600}
.nav__menu a.active::after{transform:scaleX(1)}

/* About Section */
.about-content{margin-top:40px}
.about-text{text-align:center;max-width:800px;margin:0 auto 40px}
.about-text p{font-size:clamp(16px,1.8vw,18px);color:var(--muted);line-height:1.6;margin-bottom:20px}
.about-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.feature-card{display:flex;gap:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);align-items:flex-start}
.feature-card__icon{display:grid;place-items:center;width:48px;height:48px;background:linear-gradient(135deg,var(--primary),#ef4444);border-radius:12px;color:white;flex-shrink:0}
.feature-card__icon svg{width:24px;height:24px}
.feature-card__content h3{margin:0 0 8px;color:var(--text);font-size:18px}
.feature-card__content p{color:var(--muted);line-height:1.5;margin:0}

/* Contact Page */
.contact-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;margin-top:40px}
.contact-info h2{margin:0 0 32px;color:var(--text)}
.contact-details{display:flex;flex-direction:column;gap:24px}
.contact-detail{display:flex;gap:16px;align-items:flex-start}
.contact-detail__icon{display:grid;place-items:center;width:48px;height:48px;background:linear-gradient(135deg,var(--primary),#ef4444);border-radius:12px;color:white;flex-shrink:0}
.contact-detail__icon svg{width:24px;height:24px}
.contact-detail__content h3{margin:0 0 4px;color:var(--text);font-size:16px;font-weight:600}
.contact-detail__content p{margin:0;color:var(--muted);line-height:1.5}
.contact-detail__content a{color:var(--text);text-decoration:none;font-weight:500}
.contact-detail__content a:hover{color:var(--primary)}

/* Contact Form Page */
.contact-form-wrapper h2{margin:0 0 24px;color:var(--text)}
.contact-form-page{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.form-group{margin-bottom:20px}
.form-group label{display:block;margin-bottom:6px;color:var(--text);font-weight:500;font-size:14px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:12px 16px;border-radius:12px;font:inherit;transition:.3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(220,38,38,.1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.checkbox-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;font-size:14px;line-height:1.4}
.checkbox-label input[type="checkbox"]{width:auto;margin:0}
.checkmark{width:18px;height:18px;border:2px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.3s}
.checkbox-label input[type="checkbox"]:checked + .checkmark{background:var(--primary);border-color:var(--primary)}
.checkbox-label input[type="checkbox"]:checked + .checkmark::after{content:'✓';color:white;font-size:12px;font-weight:bold}
.btn--large{padding:16px 32px;font-size:16px}

/* Success Message */
.success-message{text-align:center;max-width:600px;margin:0 auto;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:48px 32px;box-shadow:var(--shadow)}
.success-message__icon{display:inline-grid;place-items:center;width:64px;height:64px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;color:white;margin-bottom:24px}
.success-message__icon svg{width:32px;height:32px}
.success-message h2{margin:0 0 16px;color:var(--text)}
.success-message p{color:var(--muted);margin-bottom:32px;line-height:1.6}

/* Responsive */
@media (max-width: 980px){
  .service-card{grid-template-columns:1fr;gap:16px;text-align:center}
  .service-card__image{min-height:200px}
  .process-steps{grid-template-columns:1fr}
  .about-features{grid-template-columns:1fr}
  .feature-card{flex-direction:column;text-align:center;align-items:center}
  .contact-layout{grid-template-columns:1fr;gap:32px}
  .form-row{grid-template-columns:1fr}
  .intro-card{grid-template-columns:1fr;gap:24px;text-align:center}
  .intro-card__image{min-height:250px}
}

/* Legal Pages */
.legal-content{max-width:800px;margin:0 auto}
.legal-section{margin-bottom:40px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.legal-section h2{margin:0 0 20px;color:var(--text);font-size:24px}
.legal-section h3{margin:0 0 16px;color:var(--text);font-size:20px}
.legal-section p{color:var(--muted);line-height:1.6;margin-bottom:16px}
.legal-section a{color:var(--text);text-decoration:none}
.legal-section a:hover{color:var(--primary)}
.info-grid{display:grid;gap:12px;margin-top:16px}
.info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}
.info-item:last-child{border-bottom:none}
.info-item strong{color:var(--text);font-weight:600}
.info-item span{color:var(--muted)}
.contact-info-legal{display:flex;flex-direction:column;gap:20px}
.contact-item-legal{display:flex;gap:16px;align-items:flex-start}
.contact-icon{display:grid;place-items:center;width:40px;height:40px;background:linear-gradient(135deg,var(--primary),#ef4444);border-radius:10px;color:white;flex-shrink:0}
.contact-icon svg{width:20px;height:20px}
.contact-item-legal a{color:var(--text);text-decoration:none;font-weight:500}
.contact-item-legal a:hover{color:var(--primary)}

/* Footer */
.footer{background:var(--dark);color:var(--light);padding:40px 0 20px}
.footer__content{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:32px;margin-bottom:32px}
.footer__section h3, .footer__section h4{margin:0 0 16px;color:var(--light)}
.footer__section p{margin:8px 0;line-height:1.6}

.footer__contact{display:flex;flex-direction:column;gap:12px}
.footer__contact-item{display:flex;align-items:center;gap:12px}
.footer__icon{font-size:16px;width:20px;flex-shrink:0}
.footer__link{color:var(--light);text-decoration:none;cursor:pointer}
.footer__link:hover{color:var(--accent)}

.footer__links{display:flex;flex-direction:column;gap:8px}
.footer__links .footer__link{color:var(--light);text-decoration:none;cursor:pointer;display:block}
.footer__links .footer__link:hover{color:var(--accent)}

.footer__bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:20px;text-align:center;color:var(--muted)}
.footer__credits{margin-top:8px;font-size:14px;opacity:0.8}
.footer__credits .footer__link{font-size:14px}

/* Rental Page Styles */
.rental-layout{display:grid;grid-template-columns:2fr 1fr;gap:40px;margin-top:40px}
.rental-main{display:flex;flex-direction:column;gap:32px}
.rental-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.rental-card h2{margin:0 0 24px;color:var(--text);font-size:28px}
.rental-card h3{margin:0 0 20px;color:var(--text);font-size:22px}
.rental-card p{color:var(--muted);line-height:1.6;margin-bottom:16px}
.rental-card p:last-child{margin-bottom:0}

.rental-price{display:flex;align-items:baseline;gap:12px;margin-bottom:16px}
.price{font-size:32px;font-weight:700;color:var(--primary)}
.price-note{color:var(--muted);font-size:16px}

.rental-location{display:flex;align-items:center;gap:8px;margin-bottom:24px;color:var(--muted)}
.location-icon{font-size:18px}

.fact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.fact{display:flex;flex-direction:column;gap:4px;padding:16px;background:var(--surface);border-radius:8px}
.fact-label{font-size:14px;color:var(--muted);font-weight:500}
.fact-value{font-size:18px;color:var(--text);font-weight:600}

.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:16px}
.feature-item{padding:12px 16px;background:rgba(var(--primary-rgb),0.08);border-radius:8px;color:var(--text);font-weight:500}

.rental-gallery h3{margin:0 0 24px;color:var(--text)}
.gallery-grid{display:grid;grid-template-columns:1fr;gap:16px}
.gallery-item{border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.gallery-item img{width:100%;height:200px;object-fit:cover;transition:transform .3s ease}
.gallery-item:hover img{transform:scale(1.05)}

.rental-contact{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-details{display:flex;flex-direction:column;gap:24px;margin-top:32px}
.contact-detail{display:flex;gap:16px;align-items:flex-start}
.contact-icon{font-size:20px;width:24px;flex-shrink:0}
.contact-detail h4{margin:0 0 4px;color:var(--text);font-size:16px}
.contact-detail p{margin:0;color:var(--muted)}
.contact-detail a{color:var(--text);text-decoration:none;font-weight:500}
.contact-detail a:hover{color:var(--primary)}

.rental-form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.rental-form h3{margin:0 0 24px;color:var(--text)}

.success-message{text-align:center;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:48px;box-shadow:var(--shadow)}
.success-message h2{color:var(--primary);margin:0 0 16px}
.success-message p{color:var(--muted);font-size:18px;margin:0}

@media (max-width: 1024px){
  .rental-layout{grid-template-columns:1fr;gap:32px}
  .rental-contact{grid-template-columns:1fr;gap:32px}
}

@media (max-width: 768px){
  .fact-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
}

/* Cookie Banner */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: saturate(180%) blur(20px);
  border-top: 1px solid var(--border);
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
  padding: 20px 0;
  z-index: 1000;
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.cookie-banner.show {
  transform: translateY(0);
}

.cookie-banner__content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.cookie-banner__text {
  flex: 1;
  min-width: 300px;
}

.cookie-banner__text p {
  margin: 0;
  font-size: 14px;
  color: var(--text);
  line-height: 1.5;
}

.cookie-banner__text a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}

.cookie-banner__text a:hover {
  text-decoration: underline;
}

.cookie-banner__actions {
  display: flex;
  gap: 12px;
  align-items: center;
}

.cookie-btn {
  padding: 10px 20px;
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s ease;
  border: none;
  text-decoration: none;
  display: inline-block;
}

.cookie-btn--accept {
  background: var(--primary);
  color: white;
}

.cookie-btn--accept:hover {
  background: var(--primary-600);
  transform: translateY(-1px);
}

.cookie-btn--decline {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--border);
}

.cookie-btn--decline:hover {
  background: var(--surface);
  color: var(--text);
}

.cookie-btn--settings {
  background: transparent;
  color: var(--primary);
  border: 1px solid var(--primary);
}

.cookie-btn--settings:hover {
  background: var(--primary);
  color: white;
}

@media (max-width: 768px) {
  .cookie-banner__content {
    flex-direction: column;
    text-align: center;
  }
  
  .cookie-banner__text {
    min-width: auto;
  }
  
  .cookie-banner__actions {
    flex-wrap: wrap;
    justify-content: center;
  }
}

/* Process Steps */
.process-steps {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 60px;
  margin-top: 48px;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}

.process-step {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 0;
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  transition: none;
  position: relative;
}

.process-step:hover {
  transform: none;
  box-shadow: none;
}

.process-step__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, var(--primary), #ef4444);
  color: white;
  border-radius: 50%;
  font-weight: 700;
  font-size: 20px;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.3);
  position: relative;
  z-index: 2;
}

.process-step__content {
  flex: 1;
  padding-top: 8px;
}

.process-step__content h3 {
  margin: 0 0 12px 0;
  color: var(--text);
  font-size: 19px;
  font-weight: 600;
  line-height: 1.3;
}

.process-step__content p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6;
}

/* Connecting lines between steps */
.process-step:nth-child(odd):not(:nth-last-child(-n+2))::after {
  content: '';
  position: absolute;
  left: 28px;
  top: 56px;
  width: 2px;
  height: 40px;
  background: linear-gradient(to bottom, var(--primary), transparent);
  z-index: 1;
}

.process-step:nth-child(2)::before {
  content: '';
  position: absolute;
  right: calc(100% + 30px);
  top: 28px;
  width: 60px;
  height: 2px;
  background: linear-gradient(to right, var(--primary), transparent);
  z-index: 1;
}

/* Gallery Grid */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
  margin-top: 48px;
}

.gallery-item {
  background: var(--card);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.gallery-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.gallery-item__image {
  height: 200px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.gallery-item__content {
  padding: 20px;
}

.gallery-item__content h3 {
  margin: 0 0 8px 0;
  color: var(--text);
  font-size: 16px;
  font-weight: 600;
}

.gallery-item__content p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

/* CTA Features */
.cta-features {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 24px;
}

.cta-feature {
  display: flex;
  align-items: center;
  gap: 12px;
}

.cta-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: var(--primary);
  color: white;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .process-steps {
    grid-template-columns: 1fr;
    gap: 32px;
    max-width: none;
  }
  
  .process-step:nth-child(odd):not(:nth-last-child(-n+2))::after {
    left: 28px;
    top: 56px;
    height: 32px;
  }
  
  .process-step:nth-child(2)::before {
    display: none;
  }
  
  .gallery-grid {
    grid-template-columns: 1fr;
  }
}

/* Elevated focus */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:10px}
