@font-face{font-family:'Jost';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/jost-v20-latin-300.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:italic;font-weight:300;font-display:swap;src:url('../fonts/jost-v20-latin-300italic.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/jost-v20-latin-regular.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/jost-v20-latin-500.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/jost-v20-latin-600.woff2') format('woff2');}
:root,[data-theme="dark"]{--c-bg:#0A0A0A;--c-bg-alt:#111111;--c-bg-card:#181818;--c-text:#E8E4DF;--c-text-muted:#8A8580;--c-text-dim:#5A5550;--c-accent:#C8A97E;--c-accent-light:#D4BC9A;--c-accent-dark:#A08060;--c-border:#2A2520;--c-border-light:#3A3530;--c-white:#FAFAF8;--c-error:#E06050;--c-success:#60B080;--c-header-bg:rgba(10,10,10,0.92);--font-display:'Jost','Century Gothic','Avant Garde',sans-serif;--font-body:'Jost','Century Gothic',-apple-system,sans-serif;}
[data-theme="light"]{--c-bg:#F5F3F0;--c-bg-alt:#EDEAE6;--c-bg-card:#FFFFFF;--c-text:#2A2520;--c-text-muted:#6A6560;--c-text-dim:#9A9590;--c-accent:#A08060;--c-accent-light:#C8A97E;--c-accent-dark:#806040;--c-border:#D5D0CA;--c-border-light:#E5E0DA;--c-white:#1A1A18;--c-error:#C04030;--c-success:#408060;--c-header-bg:rgba(245,243,240,0.92);}
:root{--space-xs:0.5rem;--space-sm:1rem;--space-md:2rem;--space-lg:4rem;--space-xl:8rem;--space-2xl:12rem;--radius:2px;--transition:0.4s cubic-bezier(0.25,0.46,0.45,0.94);--transition-fast:0.2s ease;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%;}
body{font-family:var(--font-body);background:var(--c-bg);color:var(--c-text);line-height:1.7;font-weight:300;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
::selection{background:var(--c-accent);color:var(--c-bg);}
:focus-visible{outline:2px solid var(--c-accent);outline-offset:4px;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--c-accent);text-decoration:none;transition:color var(--transition-fast);}
a:hover,a:focus{color:var(--c-accent-light);}
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--c-accent);color:var(--c-bg);padding:0.75rem 1.5rem;z-index:10000;font-weight:600;border-radius:var(--radius);}
.skip-link:focus{top:1rem;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:300;line-height:1.15;letter-spacing:0.02em;}
.section-label{font-family:var(--font-body);font-size:0.7rem;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:var(--c-accent);margin-bottom:var(--space-sm);display:block;}
.section-title{font-size:clamp(2.2rem,5vw,4.5rem);margin-bottom:var(--space-md);color:var(--c-white);}
.container{max-width:1400px;margin:0 auto;padding:0 clamp(1.5rem,4vw,4rem);}
section{padding:var(--space-xl) 0;}
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.5rem 0;transition:all var(--transition);background:transparent;}
.site-header.scrolled{background:var(--c-header-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:0.8rem 0;border-bottom:1px solid var(--c-border);}
.header-inner{display:flex;align-items:center;justify-content:space-between;}
.logo{font-family:var(--font-display);font-size:1.5rem;font-weight:300;color:var(--c-white);letter-spacing:0.08em;text-transform:none;text-decoration:none;display:inline-block;position:relative;padding:0 0 0.15em 0;line-height:1;}
.logo::before,.logo::after{content:'';position:absolute;left:-0.15em;height:1.5px;background:currentColor;}
.logo::before{top:0.08em;left:0.30em;width:calc(100% + 0.8em);}
.logo::after{bottom:0.28em;left:-1.8em;width:calc(100% + 1.7em);}
.main-nav{display:flex;align-items:center;gap:2.5rem;}
.main-nav a{font-size:0.75rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--c-text-muted);text-decoration:none;position:relative;padding:0.3rem 0;transition:color var(--transition-fast);}
.main-nav a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--c-accent);transition:width var(--transition);}
.main-nav a:hover,.main-nav a:focus{color:var(--c-white);}
.main-nav a:hover::after,.main-nav a:focus::after{width:100%;}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:0.5rem;z-index:1100;}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--c-white);margin:6px 0;transition:all 0.3s;}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.nav-toggle.active span:nth-child(2){opacity:0;}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:0;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 80%,rgba(200,169,126,0.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(200,169,126,0.04) 0%,transparent 50%),var(--c-bg);}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(200,169,126,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(200,169,126,0.03) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);}
.hero-content{position:relative;z-index:2;padding-top:6rem;}
.hero-eyebrow{font-family:var(--font-body);font-size:0.7rem;font-weight:600;letter-spacing:0.4em;text-transform:uppercase;color:var(--c-accent);margin-bottom:2rem;display:flex;align-items:center;gap:1rem;}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--c-accent);}
.hero h1{font-size:clamp(3rem,8vw,7rem);color:var(--c-white);margin-bottom:2rem;max-width:900px;}
.hero h1 em{font-style:italic;color:var(--c-accent);}
.hero-subtitle{font-size:1.1rem;color:var(--c-text-muted);max-width:550px;margin-bottom:3rem;line-height:1.8;}
.hero-cta{display:inline-flex;align-items:center;gap:1rem;font-size:0.75rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--c-bg);background:var(--c-accent);padding:1rem 2.5rem;border:none;cursor:pointer;transition:all var(--transition);text-decoration:none;}
.hero-cta:hover,.hero-cta:focus{background:var(--c-accent-light);color:var(--c-bg);transform:translateY(-2px);}
.hero-cta svg{width:16px;height:16px;transition:transform var(--transition);}
.hero-cta:hover svg{transform:translateX(4px);}
.hero-scroll{position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.5rem;color:var(--c-text-dim);font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;animation:scrollBounce 2s infinite;}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0);}
50%{transform:translateX(-50%) translateY(8px);}}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--c-accent),transparent);}
#leistungen{background:var(--c-bg);border-top:1px solid var(--c-border);}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1px;background:var(--c-border);margin-top:var(--space-lg);}
.service-card{background:var(--c-bg);padding:3rem 2.5rem;transition:all var(--transition);position:relative;overflow:hidden;}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:var(--c-accent);transform:scaleX(0);transform-origin:left;transition:transform var(--transition);}
.service-card:hover{background:var(--c-bg-card);}
.service-card:hover::before{transform:scaleX(1);}
.service-icon{font-size:2rem;margin-bottom:1.5rem;display:block;color:var(--c-accent);opacity:0.7;}
.service-card h3{font-size:1.5rem;color:var(--c-white);margin-bottom:1rem;}
.service-card p{color:var(--c-text-muted);font-size:0.9rem;line-height:1.7;}
#portfolio{background:var(--c-bg-alt);}
.portfolio-filter{display:flex;justify-content:center;gap:0.5rem;margin-top:var(--space-lg);flex-wrap:wrap;}
.portfolio-filter button{background:transparent;border:1px solid rgba(200,169,126,0.3);color:var(--c-text-muted);padding:0.6rem 1.5rem;font-family:var(--font-body);font-size:0.85rem;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;transition:all var(--transition);}
.portfolio-filter button:hover,.portfolio-filter button.active{background:var(--c-accent);border-color:var(--c-accent);color:var(--c-bg);}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:300px;gap:4px;margin-top:var(--space-md);}
.portfolio-item{position:relative;overflow:hidden;background:var(--c-bg-card);cursor:pointer;transition:transform 0.3s ease;}
.portfolio-item.hidden{display:none;}
.portfolio-item.large{grid-column:span 2;grid-row:span 2;}
.portfolio-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.6s ease,filter 0.3s ease,opacity 0.4s ease;filter:saturate(0.85);opacity:0;}
.portfolio-item img.loaded{opacity:1;}
.portfolio-item::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,var(--c-bg-card) 30%,rgba(200,169,126,0.08) 50%,var(--c-bg-card) 70%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;z-index:1;transition:opacity 0.4s ease;}
.portfolio-item.img-loaded::before{opacity:0;pointer-events:none;}
@keyframes shimmer{0%{background-position:200% 0;}
100%{background-position:-200% 0;}}
.portfolio-item:hover img{transform:scale(1.06);filter:saturate(1);}
@media (hover:none){.portfolio-item:hover img{transform:none;}}
.portfolio-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,0.85),transparent 50%);display:flex;align-items:flex-end;padding:1.5rem;opacity:0;transition:opacity var(--transition);}
.portfolio-item:hover .portfolio-overlay{opacity:1;}
.portfolio-overlay-text h4{font-size:1.1rem;color:var(--c-white);margin-bottom:0.2rem;}
.portfolio-overlay-text p{font-size:0.7rem;color:var(--c-accent);letter-spacing:0.1em;text-transform:uppercase;}
.lightbox{display:none;position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,0.97);align-items:center;justify-content:center;padding:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);touch-action:pan-y;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:82vh;object-fit:contain;border:2px solid rgba(200,169,126,0.3);user-select:none;-webkit-user-drag:none;}
.lightbox-close{position:absolute;top:0.8rem;right:1rem;background:rgba(0,0,0,0.5);border:1px solid rgba(200,169,126,0.3);border-radius:50%;color:var(--c-white);font-size:1.8rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;z-index:10001;-webkit-tap-highlight-color:transparent;}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(200,169,126,0.2);border:1px solid rgba(200,169,126,0.4);color:var(--c-white);font-size:1.8rem;padding:1rem 1.2rem;cursor:pointer;transition:background var(--transition);line-height:1;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;}
.lightbox-nav:hover{background:rgba(200,169,126,0.5);}
.lightbox-prev{left:0.5rem;}
.lightbox-next{right:0.5rem;}
.lightbox-caption{position:absolute;bottom:0.8rem;left:50%;transform:translateX(-50%);color:var(--c-accent);font-family:var(--font-display);font-size:0.95rem;font-style:italic;letter-spacing:0.05em;text-align:center;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lightbox-counter{position:absolute;top:1rem;left:1rem;color:rgba(255,255,255,0.5);font-size:0.8rem;font-family:var(--font-body);letter-spacing:0.1em;}
@media (max-width:768px){.lightbox{padding:0;}
.lightbox img{max-width:100vw;max-height:75vh;border:none;}
.lightbox-nav{background:rgba(0,0,0,0.4);border:none;font-size:1.4rem;padding:1.5rem 0.8rem;}
.lightbox-prev{left:0;border-radius:0 8px 8px 0;}
.lightbox-next{right:0;border-radius:8px 0 0 8px;}
.lightbox-close{top:0.5rem;right:0.5rem;}
.lightbox-caption{font-size:0.8rem;bottom:0.5rem;}}
#kontakt{background:var(--c-bg-alt);border-top:1px solid var(--c-border);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-top:var(--space-lg);}
.contact-info h3{font-size:1.8rem;color:var(--c-white);margin-bottom:2rem;}
.contact-detail{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:flex-start;}
.contact-detail svg{width:20px;height:20px;color:var(--c-accent);flex-shrink:0;margin-top:2px;}
.contact-detail-text{color:var(--c-text-muted);font-size:0.9rem;}
.contact-detail-text strong{color:var(--c-text);display:block;font-weight:500;margin-bottom:0.2rem;}
.btn-save-contact{display:inline-flex;align-items:center;gap:0.5rem;margin-top:1.5rem;padding:0.7rem 1.5rem;font-family:var(--font-body);font-size:0.75rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--c-accent);background:transparent;border:1px solid var(--c-accent);cursor:pointer;transition:all var(--transition-fast);}
.btn-save-contact:hover{background:var(--c-accent);color:var(--c-bg);}
.contact-form{background:var(--c-bg-card);padding:3rem;border:1px solid var(--c-border);}
.form-group{margin-bottom:1.5rem;}
.form-group label{display:block;font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:0.5rem;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:0.9rem 1rem;background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);font-family:var(--font-body);font-size:0.9rem;transition:border-color var(--transition-fast);border-radius:var(--radius);}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--c-accent);outline:none;}
.form-group textarea{min-height:140px;resize:vertical;}
.form-checkbox{display:flex;gap:0.75rem;align-items:flex-start;margin-bottom:1.5rem;}
.form-checkbox input[type="checkbox"]{width:18px;height:18px;accent-color:var(--c-accent);flex-shrink:0;margin-top:2px;}
.form-checkbox label{font-size:0.8rem;color:var(--c-text-muted);line-height:1.5;cursor:pointer;}
.form-checkbox label a{color:var(--c-accent);text-decoration:underline;}
.btn-submit{display:inline-flex;align-items:center;gap:0.75rem;font-family:var(--font-body);font-size:0.75rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--c-bg);background:var(--c-accent);padding:1rem 2.5rem;border:none;cursor:pointer;transition:all var(--transition);width:100%;justify-content:center;}
.btn-submit:hover,.btn-submit:focus{background:var(--c-accent-light);transform:translateY(-1px);}
.btn-submit:disabled{opacity:0.5;cursor:not-allowed;transform:none;}
.site-footer{background:var(--c-bg);border-top:1px solid var(--c-border);padding:var(--space-lg) 0 var(--space-md);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:var(--space-lg);}
.footer-brand .logo{margin-bottom:1rem;}
.footer-brand p{color:var(--c-text-muted);font-size:0.85rem;max-width:300px;}
.footer-col h4{font-family:var(--font-body);font-size:0.7rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--c-text);margin-bottom:1.5rem;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:0.75rem;}
.footer-col ul li a{color:var(--c-text-muted);font-size:0.85rem;transition:color var(--transition-fast);}
.footer-col ul li a:hover,.footer-col ul li a:focus{color:var(--c-accent);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-md);border-top:1px solid var(--c-border);font-size:0.75rem;color:var(--c-text-dim);}
.footer-bottom a{color:var(--c-text-muted);}
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--c-bg-card);border-top:1px solid var(--c-border);padding:2rem;z-index:9999;transform:translateY(100%);transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94);backdrop-filter:blur(20px);}
.cookie-banner.visible{transform:translateY(0);}
.cookie-banner-inner{max-width:1400px;margin:0 auto;}
.cookie-banner h3{font-family:var(--font-display);font-size:1.3rem;color:var(--c-white);margin-bottom:0.75rem;}
.cookie-banner p{color:var(--c-text-muted);font-size:0.85rem;margin-bottom:1.5rem;max-width:700px;line-height:1.6;}
.cookie-options{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;}
.cookie-option{display:flex;align-items:center;gap:0.5rem;font-size:0.8rem;color:var(--c-text-muted);}
.cookie-option input[type="checkbox"]{accent-color:var(--c-accent);}
.cookie-option input[disabled]{opacity:0.6;}
.cookie-buttons{display:flex;gap:1rem;flex-wrap:wrap;}
.cookie-btn{font-family:var(--font-body);font-size:0.72rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;padding:0.75rem 1.8rem;border:none;cursor:pointer;transition:all var(--transition-fast);}
.cookie-btn.primary{background:var(--c-accent);color:var(--c-bg);}
.cookie-btn.primary:hover{background:var(--c-accent-light);}
.cookie-btn.secondary{background:transparent;color:var(--c-text-muted);border:1px solid var(--c-border);}
.cookie-btn.secondary:hover{border-color:var(--c-accent);color:var(--c-accent);}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:10000;display:none;align-items:center;justify-content:center;padding:2rem;overflow-y:auto;}
.modal-overlay.active{display:flex;}
.modal{background:var(--c-bg);border:1px solid var(--c-border);max-width:900px;width:100%;max-height:85vh;overflow-y:auto;padding:3rem 4rem;position:relative;}
.modal-close{position:sticky;top:0;float:right;background:var(--c-bg-card);border:1px solid var(--c-border);color:var(--c-text);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;z-index:2;transition:all var(--transition-fast);}
.modal-close:hover{background:var(--c-accent);color:var(--c-bg);}
.modal h2{font-size:2.2rem;color:var(--c-white);margin-bottom:2rem;padding-right:3rem;}
.modal h3{font-size:1.3rem;color:var(--c-accent);margin-top:2rem;margin-bottom:0.75rem;}
.modal h4{font-size:1.1rem;color:var(--c-text);margin-top:1.5rem;margin-bottom:0.5rem;}
.modal p,.modal ul,.modal li{color:var(--c-text-muted);font-size:0.9rem;line-height:1.8;margin-bottom:0.75rem;}
.modal ul{padding-left:1.5rem;margin-bottom:1rem;}
.modal li{margin-bottom:0.4rem;}
.modal address{font-style:normal;line-height:1.8;color:var(--c-text-muted);}
.legal-update{font-size:0.8rem;color:var(--c-text-dim);margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--c-border);}
.admin-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:20000;display:none;overflow-y:auto;padding:2rem;}
.admin-overlay.active{display:block;}
.admin-panel{max-width:1000px;margin:0 auto;background:var(--c-bg);border:1px solid var(--c-border);min-height:90vh;}
.admin-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:var(--c-bg-card);border-bottom:1px solid var(--c-border);}
.admin-header h2{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--c-white);letter-spacing:0.1em;}
.admin-close{background:none;border:1px solid var(--c-border);color:var(--c-text);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);}
.admin-close:hover{background:var(--c-error);color:white;border-color:var(--c-error);}
.admin-tabs{display:flex;border-bottom:1px solid var(--c-border);overflow-x:auto;}
.admin-tab{padding:1rem 1.5rem;font-size:0.75rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--c-text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;}
.admin-tab:hover{color:var(--c-text);}
.admin-tab.active{color:var(--c-accent);border-bottom-color:var(--c-accent);}
.admin-content{padding:2rem;}
.admin-section{display:none;}
.admin-section.active{display:block;}
.admin-section h3{font-family:var(--font-body);font-size:0.85rem;font-weight:600;color:var(--c-white);margin-bottom:1.5rem;padding-bottom:0.75rem;border-bottom:1px solid var(--c-border);}
.admin-field{margin-bottom:1.5rem;}
.admin-field label{display:block;font-size:0.72rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:0.4rem;}
.admin-field input,.admin-field textarea,.admin-field select{width:100%;padding:0.75rem 1rem;background:var(--c-bg-card);border:1px solid var(--c-border);color:var(--c-text);font-family:var(--font-body);font-size:0.85rem;border-radius:var(--radius);}
.admin-field input:focus,.admin-field textarea:focus{border-color:var(--c-accent);outline:none;}
.admin-field textarea{min-height:100px;resize:vertical;}
.admin-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.admin-btn{font-family:var(--font-body);font-size:0.72rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:0.75rem 2rem;border:none;cursor:pointer;transition:all var(--transition-fast);margin-right:0.75rem;margin-top:0.5rem;}
.admin-btn.save{background:var(--c-accent);color:var(--c-bg);}
.admin-btn.save:hover{background:var(--c-accent-light);}
.admin-btn.reset{background:transparent;border:1px solid var(--c-border);color:var(--c-text-muted);}
.admin-btn.reset:hover{border-color:var(--c-error);color:var(--c-error);}
.admin-status{display:inline-flex;align-items:center;gap:0.4rem;font-size:0.75rem;padding:0.4rem 0.8rem;border-radius:20px;margin-top:0.5rem;}
.admin-status.success{background:rgba(96,176,128,0.1);color:var(--c-success);}
.admin-status.error{background:rgba(224,96,80,0.1);color:var(--c-error);}
.admin-preview{background:var(--c-bg-card);border:1px solid var(--c-border);padding:1.5rem;margin-top:1rem;font-size:0.85rem;color:var(--c-text-muted);}
.admin-divider{border:none;border-top:1px solid var(--c-border);margin:2rem 0;}
.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.8s cubic-bezier(0.25,0.46,0.45,0.94),transform 0.8s cubic-bezier(0.25,0.46,0.45,0.94);}
.reveal.visible{opacity:1;transform:translateY(0);}
@media (max-width:1024px){.contact-grid{grid-template-columns:1fr;}
.footer-grid{grid-template-columns:1fr 1fr;gap:2rem;}
.portfolio-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:220px;gap:3px;}
.portfolio-item.large{grid-column:span 2;grid-row:span 1;}}
@media (max-width:768px){.nav-toggle{display:block;}
.main-nav{position:fixed;top:0;right:-100%;width:80%;max-width:400px;height:100vh;background:var(--c-bg-card);flex-direction:column;justify-content:center;padding:2rem;transition:right 0.4s;border-left:1px solid var(--c-border);}
.main-nav.open{right:0;}
.main-nav a{font-size:1rem;padding:0.75rem 0;}
.portfolio-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px;gap:2px;}
.portfolio-item.large{grid-column:span 1;}
.portfolio-overlay{opacity:1;background:linear-gradient(to top,rgba(10,10,10,0.75),transparent 40%);}
.portfolio-overlay-text h4{font-size:0.85rem;}
.portfolio-overlay-text p{font-size:0.6rem;}
.services-grid{grid-template-columns:1fr;}
.footer-grid{grid-template-columns:1fr;}
.footer-bottom{flex-direction:column;gap:0.75rem;text-align:center;}
.modal{padding:2rem;}
.admin-row{grid-template-columns:1fr;}
.cookie-banner{padding:1.5rem;}}
.theme-toggle{background:none;border:1px solid var(--c-border);color:var(--c-text-muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);padding:0;}
.theme-toggle:hover{border-color:var(--c-accent);color:var(--c-accent);}
.theme-toggle svg{width:18px;height:18px;}
.theme-toggle .icon-moon,[data-theme="light"] .theme-toggle .icon-sun{display:none;}
[data-theme="light"] .theme-toggle .icon-moon{display:block;}
[data-theme="dark"] .theme-toggle .icon-sun{display:block;}
@media print{.site-header,.cookie-banner,.hero-scroll,.modal-overlay,.admin-overlay{display:none !important;}
body{background:white;color:black;}}
