@import"https://fonts.googleapis.com/css2?family=Lora:wght@400;500;600&display=swap";:root{--color-bg-primary: #fafaf9;--color-bg-secondary: #ffffff;--color-text-primary: #1a1a1a;--color-text-secondary: #525252;--color-border: #e7e5e4;--color-accent: #78716c;--header-bg: transparent;--header-bg-scrolled: rgba(250, 250, 249, .95);--header-text: #1a1a1a;--header-shadow: rgba(0, 0, 0, .05);--font-serif: "Lora", Georgia, serif;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 32px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--letter-spacing-normal: 0;--letter-spacing-wide: .05em;--letter-spacing-wider: .1em;--space-xs: 8px;--space-sm: 12px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--header-height: 80px;--max-width: 1400px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--skeleton-base: #e0e0e0;--skeleton-highlight: #f5f5f5;--skeleton-shimmer: rgba(255, 255, 255, .4);--skeleton-text: rgba(0, 0, 0, .1);--skeleton-text-subtle: rgba(0, 0, 0, .08)}@mixin dark-theme{ --color-bg-primary: #1c1917; --color-bg-secondary: #292524; --color-text-primary: #fafaf9; --color-text-secondary: #d6d3d1; --color-border: #44403c; --color-accent: #a8a29e; --header-bg: transparent; --header-bg-scrolled: rgba(28, 25, 23, .55); --header-text: #fafaf9; --header-shadow: rgba(0, 0, 0, .3); --skeleton-base: #1a1a1a; --skeleton-highlight: #2d2d2d; --skeleton-shimmer: rgba(255, 255, 255, .05); --skeleton-text: rgba(255, 255, 255, .1); --skeleton-text-subtle: rgba(255, 255, 255, .08); }@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg-primary: #1c1917;--color-bg-secondary: #292524;--color-text-primary: #fafaf9;--color-text-secondary: #d6d3d1;--color-border: #44403c;--color-accent: #a8a29e;--header-bg: transparent;--header-bg-scrolled: rgba(28, 25, 23, .55);--header-text: #fafaf9;--header-shadow: rgba(0, 0, 0, .3);--skeleton-base: #1a1a1a;--skeleton-highlight: #2d2d2d;--skeleton-shimmer: rgba(255, 255, 255, .05);--skeleton-text: rgba(255, 255, 255, .1);--skeleton-text-subtle: rgba(255, 255, 255, .08)}}:root[data-theme=dark]{--color-bg-primary: #1c1917;--color-bg-secondary: #292524;--color-text-primary: #fafaf9;--color-text-secondary: #d6d3d1;--color-border: #44403c;--color-accent: #a8a29e;--header-bg: transparent;--header-bg-scrolled: rgba(28, 25, 23, .55);--header-text: #fafaf9;--header-shadow: rgba(0, 0, 0, .3);--skeleton-base: #1a1a1a;--skeleton-highlight: #2d2d2d;--skeleton-shimmer: rgba(255, 255, 255, .05);--skeleton-text: rgba(255, 255, 255, .1);--skeleton-text-subtle: rgba(255, 255, 255, .08)}:root[data-theme=light]{--color-bg-primary: #fafaf9;--color-bg-secondary: #ffffff;--color-text-primary: #1a1a1a;--color-text-secondary: #525252;--color-border: #e7e5e4;--color-accent: #78716c;--header-bg: transparent;--header-bg-scrolled: rgba(250, 250, 249, .95);--header-text: #1a1a1a;--header-shadow: rgba(0, 0, 0, .05);--skeleton-base: #e0e0e0;--skeleton-highlight: #f5f5f5;--skeleton-shimmer: rgba(255, 255, 255, .4);--skeleton-text: rgba(0, 0, 0, .1);--skeleton-text-subtle: rgba(0, 0, 0, .08)}html{box-sizing:border-box;font-size:var(--font-size-base)}*,*:before,*:after{box-sizing:inherit}body{margin:0;padding:0;font-family:var(--font-sans);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-link{padding:var(--spacing-2, .5rem) var(--spacing-4, 1rem);background:var(--accent-primary, #0066cc);color:#fff;text-decoration:none;border-radius:var(--border-radius, 8px);font-weight:var(--font-weight-medium, 500);transition:all var(--transition-speed, .2s);font-size:var(--font-size-sm, .875rem)}.login-link:hover{background:var(--accent-hover, #0052a3);transform:translateY(-1px)}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:var(--spacing-2, .5rem);padding:var(--spacing-2, .5rem);background:transparent;border:1px solid var(--border-color, #ddd);border-radius:var(--border-radius, 8px);cursor:pointer;transition:all var(--transition-speed, .2s)}.user-menu-button:hover{background:var(--bg-secondary, #f9f9f9);border-color:var(--accent-primary, #0066cc)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-primary, #0066cc);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold, 700);font-size:var(--font-size-sm, .875rem)}.user-email{font-size:var(--font-size-sm, .875rem);color:var(--header-text);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{position:absolute;top:calc(100% + var(--spacing-2, .5rem));right:0;min-width:200px;background:var(--bg-secondary, #f9f9f9);border:1px solid var(--border-color, #ddd);border-radius:var(--border-radius, 8px);box-shadow:0 4px 6px #0000001a;z-index:1000}.user-menu-header{padding:var(--spacing-3, .75rem)}.user-menu-email{font-size:var(--font-size-sm, .875rem);color:var(--text-secondary, #666666);margin:0;word-break:break-all}.user-menu-divider{height:1px;background:var(--border-color, #ddd);margin:var(--spacing-2, .5rem) 0}.user-menu-nav{padding:var(--spacing-2, .5rem)}.user-menu-item{display:block;width:100%;padding:var(--spacing-2, .5rem) var(--spacing-3, .75rem);text-align:left;text-decoration:none;color:var(--text-primary, #1a1a1a);background:transparent;border:none;border-radius:var(--border-radius, 8px);cursor:pointer;transition:background var(--transition-speed, .2s);font-size:var(--font-size-sm, .875rem)}.user-menu-item:hover{background:var(--bg-primary, #ffffff)}.user-menu-logout{color:#c33}.user-menu-logout:hover{background:#fee}@media(max-width:768px){.user-email{display:none}.user-menu-dropdown{right:-10px}}.header{position:fixed;top:0;left:0;right:0;z-index:100;background-color:var(--header-bg);transition:background-color var(--transition-normal),box-shadow var(--transition-normal)}.header.scrolled{background-color:var(--header-bg-scrolled);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px var(--header-shadow)}.header-container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-xl);height:var(--header-height);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md, 1rem)}.header-container.nav-centered{justify-content:center}.desktop-nav{display:none}@media(min-width:768px){.desktop-nav{display:block}}.nav-list{display:flex;list-style:none;margin:0;padding:0;gap:var(--space-2xl)}.nav-item{position:relative}.nav-link{font-family:var(--font-serif);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);letter-spacing:var(--letter-spacing-wide);color:var(--header-text);text-decoration:none;text-transform:uppercase;transition:opacity var(--transition-fast);padding:var(--space-xs) 0;position:relative;display:inline-block}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background-color:var(--header-text);transition:width var(--transition-normal)}.nav-link:hover{opacity:.7}.nav-link:hover:after{width:100%}.mobile-menu-button{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:var(--space-sm);margin-left:auto}@media(min-width:768px){.mobile-menu-button{display:none}}.hamburger{display:block;width:28px;height:20px;position:relative}.hamburger .line{position:absolute;left:0;width:100%;height:2px;background-color:var(--header-text);transition:all var(--transition-normal)}.hamburger .line:nth-child(1){top:0}.hamburger .line:nth-child(2){top:50%;transform:translateY(-50%)}.hamburger .line:nth-child(3){bottom:0}.hamburger.active .line:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}.hamburger.active .line:nth-child(2){opacity:0}.hamburger.active .line:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}.mobile-nav{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background-color:var(--color-bg-primary);z-index:99;animation:fadeIn var(--transition-normal);overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(min-width:768px){.mobile-nav{display:none}}.mobile-nav-list{list-style:none;margin:0;padding:var(--space-2xl) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-md)}.mobile-nav-item{border-bottom:1px solid var(--color-border)}.mobile-nav-item:last-child{border-bottom:none}.mobile-nav-link{display:block;padding:var(--space-lg) 0;font-family:var(--font-serif);font-size:var(--font-size-xl);font-weight:var(--font-weight-normal);letter-spacing:var(--letter-spacing-wide);color:var(--color-text-primary);text-decoration:none;text-transform:uppercase;text-align:center;transition:opacity var(--transition-fast);min-height:48px;display:flex;align-items:center;justify-content:center}.mobile-nav-link:hover{opacity:.7}.hero{position:relative;width:100%;height:70vh;max-height:900px;background-size:cover;background-position:center center;background-repeat:no-repeat;overflow:hidden}.hero--contain{background-size:contain}@media(min-width:768px){.hero{height:80vh}}.hero-overlay{position:absolute;inset:0;background:#0000004d}.hero-content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:0 1rem}.hero-title{font-size:2.5rem;font-weight:300;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.5);letter-spacing:1px}@media(min-width:768px){.hero-title{font-size:4rem}}.hero-subtitle{margin-top:1rem;font-size:1.25rem;font-weight:300;color:#ffffffe6;max-width:700px;text-shadow:0 1px 4px rgba(0,0,0,.4)}@media(min-width:768px){.hero-subtitle{font-size:1.75rem}}.hero-skeleton{background:linear-gradient(135deg,var(--skeleton-base) 0%,var(--skeleton-highlight) 100%);position:relative;overflow:hidden}.hero-skeleton-shimmer{position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--skeleton-shimmer) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.hero-title-skeleton{width:300px;max-width:80%;height:2.5rem;background:var(--skeleton-text);border-radius:4px}@media(min-width:768px){.hero-title-skeleton{width:400px;height:4rem}}.hero-subtitle-skeleton{margin-top:1rem;width:250px;max-width:70%;height:1.25rem;background:var(--skeleton-text-subtle);border-radius:4px}@media(min-width:768px){.hero-subtitle-skeleton{width:350px;height:1.75rem}}.masonry-gallery{--masonry-columns: 3;--masonry-gap: 16px;column-count:var(--masonry-columns);column-gap:var(--masonry-gap);padding:var(--space-lg);max-width:var(--max-width);margin:0 auto}.masonry-gallery>*{break-inside:avoid;margin-bottom:var(--masonry-gap);display:block}@media(max-width:1024px){.masonry-gallery{column-count:2!important}}@media(max-width:600px){.masonry-gallery{column-count:1!important;padding:var(--space-md)}}.photo-thumbnail{position:relative;cursor:pointer;overflow:hidden;background-color:var(--skeleton-base);transition:transform .2s ease,box-shadow .2s ease}.photo-thumbnail:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026}.photo-thumbnail img{width:100%;height:auto;display:block}.photo-thumbnail-skeleton{position:relative;aspect-ratio:1 / 1;background:linear-gradient(135deg,var(--skeleton-base) 0%,var(--skeleton-highlight) 100%);overflow:hidden}.photo-thumbnail-skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--skeleton-shimmer) 50%,transparent 100%);animation:thumbnail-shimmer 1.5s infinite}@keyframes thumbnail-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.modal-backdrop{position:fixed;inset:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{position:relative;max-width:90vw;max-height:90vh;background-color:#fff;padding:20px;box-shadow:0 8px 32px #0000004d}.modal-close{position:absolute;top:10px;right:10px;background:#0009;color:#fff;border:none;font-size:32px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background-color .2s ease;z-index:1001}.modal-close:hover{background-color:#000c}.modal-zoom-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#000000b3;padding:8px 12px;border-radius:24px;z-index:1001}.modal-zoom-controls button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-zoom-controls button:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80}.modal-zoom-controls button:disabled{opacity:.4;cursor:not-allowed}.modal-zoom-level{color:#fff;font-size:14px;font-weight:500;min-width:50px;text-align:center}.modal-figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:12px}.modal-image-container{overflow:hidden;position:relative;max-width:100%;max-height:calc(90vh - 100px);display:flex;align-items:center;justify-content:center}.modal-image-container.zoomed{cursor:grab}.modal-figure img{max-width:100%;max-height:calc(90vh - 100px);height:auto;display:block;transition:transform .1s ease-out;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.modal-copyright{color:#666;font-size:14px;font-style:italic;text-align:center}@media(max-width:768px){.modal-content{padding:12px}.modal-close{top:5px;right:5px;width:36px;height:36px;font-size:28px}}.about-loading{text-align:center;padding:var(--space-2xl);color:var(--color-text-secondary);font-size:var(--font-size-lg)}.about-container{max-width:var(--max-width);margin:0 auto;padding:var(--space-2xl) var(--space-xl)}.about-section{margin-bottom:var(--space-2xl)}.about-section:last-child{margin-bottom:0}.about-heading{font-family:var(--font-serif);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-lg);letter-spacing:var(--letter-spacing-wide)}.about-text{font-family:var(--font-sans);font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.about-text:last-child{margin-bottom:0}.about-list{list-style:none;padding:0;margin:0}.about-list-item{font-family:var(--font-sans);font-size:var(--font-size-lg);color:var(--color-text-secondary);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);transition:color var(--transition-fast)}.about-list-item:last-child{border-bottom:none}.about-list-item:before{content:"•";color:var(--color-accent);font-weight:700;display:inline-block;width:1.5em}.about-cta{text-align:center;padding:var(--space-2xl);background-color:var(--color-bg-secondary);border-radius:8px;margin-top:var(--space-2xl)}.about-cta-button{display:inline-block;margin-top:var(--space-lg);padding:var(--space-md) var(--space-2xl);background-color:var(--color-accent);color:var(--color-bg-primary);text-decoration:none;font-family:var(--font-serif);font-size:var(--font-size-lg);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;border-radius:4px;transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.about-cta-button:hover{background-color:var(--color-text-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media(max-width:768px){.about-container{padding:var(--space-xl) var(--space-md)}.about-heading{font-size:var(--font-size-xl)}.about-text,.about-list-item{font-size:var(--font-size-base)}.about-cta{padding:var(--space-xl) var(--space-lg)}}.gallery-card{position:relative;cursor:pointer;overflow:hidden;border-radius:4px;transition:transform var(--transition-normal),box-shadow var(--transition-normal);background-color:var(--color-bg-secondary)}.gallery-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.gallery-card-image-wrapper{position:relative;width:100%}.gallery-card-image{width:100%;height:auto;display:block;object-fit:cover}.gallery-card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.4) 50%,transparent 100%);padding:var(--space-lg);color:#fff;transform:translateY(0);transition:transform var(--transition-normal)}.gallery-card:hover .gallery-card-overlay{transform:translateY(-4px)}.gallery-card-title{font-family:var(--font-serif);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-xs) 0;letter-spacing:var(--letter-spacing-wide)}.gallery-card-count{font-family:var(--font-sans);font-size:var(--font-size-base);margin:0;opacity:.9;text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);font-size:14px}@media(prefers-color-scheme:dark){.gallery-card{background-color:var(--color-bg-secondary)}}.gallery-view{min-height:100vh;padding-top:var(--space-xl)}.gallery-view-header{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg) var(--space-xl);text-align:center}.gallery-view-back-button{background:none;border:1px solid var(--color-border);color:var(--color-text-primary);padding:var(--space-sm) var(--space-lg);font-family:var(--font-sans);font-size:var(--font-size-base);cursor:pointer;border-radius:4px;transition:all var(--transition-fast);margin-bottom:var(--space-lg)}.gallery-view-back-button:hover{background-color:var(--color-bg-secondary);border-color:var(--color-accent)}.gallery-view-title{font-family:var(--font-serif);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-sm) 0;letter-spacing:var(--letter-spacing-wide)}.gallery-view-count{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0;text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);font-size:14px}@media(max-width:768px){.gallery-view-header{padding:0 var(--space-md) var(--space-lg)}.gallery-view-title{font-size:var(--font-size-xl)}}.portfolio-page{min-height:100vh;background-color:var(--color-bg-primary)}.portfolio-page-header{text-align:center;padding:var(--space-2xl) var(--space-lg);max-width:800px;margin:0 auto}.portfolio-page-title{font-family:var(--font-serif);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-md) 0;letter-spacing:var(--letter-spacing-wide)}.portfolio-page-subtitle{font-family:var(--font-sans);font-size:var(--font-size-lg);color:var(--color-text-secondary);margin:0}.portfolio-page-loading,.portfolio-page-empty,.portfolio-page-error{text-align:center;padding:var(--space-2xl);font-family:var(--font-sans);color:var(--color-text-secondary)}.portfolio-page-error{color:#dc2626;background-color:#fee2e2;border-radius:4px;max-width:600px;margin:0 auto var(--space-lg)}@media(max-width:768px){.portfolio-page-header{padding:var(--space-xl) var(--space-md)}.portfolio-page-title{font-size:var(--font-size-xl)}.portfolio-page-subtitle{font-size:var(--font-size-base)}}.contact-container{max-width:var(--max-width);margin:0 auto;padding:var(--space-2xl) var(--space-xl)}.contact-content{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-2xl);align-items:start}.contact-info{position:sticky;top:calc(var(--header-height) + var(--space-lg))}.contact-heading{font-family:var(--font-serif);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-lg);letter-spacing:var(--letter-spacing-wide)}.contact-text{font-family:var(--font-sans);font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.contact-details{margin-top:var(--space-2xl);padding-top:var(--space-2xl);border-top:1px solid var(--color-border)}.contact-detail-item{margin-bottom:var(--space-lg)}.contact-detail-item:last-child{margin-bottom:0}.contact-detail-label{font-family:var(--font-serif);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.contact-detail-value{font-family:var(--font-sans);font-size:var(--font-size-lg);color:var(--color-text-secondary);margin:0}.contact-form-section{background-color:var(--color-bg-secondary);padding:var(--space-2xl);border-radius:8px;box-shadow:var(--shadow-sm)}.contact-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-label{font-family:var(--font-sans);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-normal)}.form-input,.form-textarea{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast)}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #78716c1a}.form-textarea{resize:vertical;min-height:150px;line-height:1.6}.form-submit{font-family:var(--font-serif);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-bg-primary);background-color:var(--color-accent);border:none;border-radius:4px;padding:var(--space-md) var(--space-2xl);cursor:pointer;transition:all var(--transition-normal);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;margin-top:var(--space-md)}.form-submit:hover:not(:disabled){background-color:var(--color-text-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.form-submit:disabled{opacity:.6;cursor:not-allowed}.form-note{font-family:var(--font-sans);font-size:14px;color:var(--color-text-secondary);margin:0;text-align:center}.form-success{padding:var(--space-md);background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;color:#155724;font-family:var(--font-sans);font-size:var(--font-size-base);text-align:center}.form-error{padding:var(--space-md);background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;font-family:var(--font-sans);font-size:var(--font-size-base);text-align:center}@media(prefers-color-scheme:dark){.form-label{color:var(--color-text-primary)}.form-input,.form-textarea{color:var(--color-text-primary);background-color:var(--color-bg-primary);border-color:var(--color-border)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-secondary)}.form-success{background-color:#1e4620;border-color:#2d6930;color:#a3d9a5}.form-error{background-color:#4a1e1e;border-color:#6d2c2c;color:#f5c2c7}}:root[data-theme=dark] .form-label{color:var(--color-text-primary)}:root[data-theme=dark] .form-input,:root[data-theme=dark] .form-textarea{color:var(--color-text-primary);background-color:var(--color-bg-primary);border-color:var(--color-border)}:root[data-theme=dark] .form-input::placeholder,:root[data-theme=dark] .form-textarea::placeholder{color:var(--color-text-secondary)}:root[data-theme=dark] .form-success{background-color:#1e4620;border-color:#2d6930;color:#a3d9a5}:root[data-theme=dark] .form-error{background-color:#4a1e1e;border-color:#6d2c2c;color:#f5c2c7}@media(max-width:1024px){.contact-content{grid-template-columns:1fr;gap:var(--space-xl)}.contact-info{position:static}.contact-details{margin-top:var(--space-xl);padding-top:var(--space-xl)}}@media(max-width:768px){.contact-container{padding:var(--space-xl) var(--space-md)}.contact-form-section{padding:var(--space-lg)}.contact-heading{font-size:var(--font-size-xl)}.contact-text,.contact-detail-value{font-size:var(--font-size-base)}.form-submit{width:100%}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary, #ffffff);padding:var(--spacing-4, 1rem)}.login-container{width:100%;max-width:420px}.login-card{background:var(--bg-secondary, #f9f9f9);border-radius:var(--border-radius, 8px);padding:var(--spacing-8, 2rem);box-shadow:0 4px 6px #0000001a}.login-title{font-family:var(--font-primary, "Segoe UI", sans-serif);font-size:var(--font-size-2xl, 2rem);font-weight:var(--font-weight-bold, 700);color:var(--text-primary, #1a1a1a);margin-bottom:var(--spacing-2, .5rem);text-align:center}.login-subtitle{color:var(--text-secondary, #666666);text-align:center;margin-bottom:var(--spacing-6, 1.5rem);font-size:var(--font-size-base, 1rem)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-4, 1rem)}.login-error{background:#fee;color:#c33;padding:var(--spacing-3, .75rem);border-radius:var(--border-radius, 8px);font-size:var(--font-size-sm, .875rem);border:1px solid #fcc}.form-group{display:flex;flex-direction:column;gap:var(--spacing-2, .5rem)}.form-label{font-weight:var(--font-weight-medium, 500);color:var(--text-primary, #1a1a1a);font-size:var(--font-size-sm, .875rem)}.form-input{padding:var(--spacing-3, .75rem);border:1px solid var(--border-color, #ddd);border-radius:var(--border-radius, 8px);font-size:var(--font-size-base, 1rem);font-family:var(--font-secondary, "Segoe UI", sans-serif);background:var(--bg-primary, #ffffff);color:var(--text-primary, #1a1a1a);transition:border-color var(--transition-speed, .2s)}.form-input:focus{outline:none;border-color:var(--accent-primary, #0066cc);box-shadow:0 0 0 3px #0066cc1a}.form-input:disabled{opacity:.6;cursor:not-allowed}.login-button{padding:var(--spacing-3, .75rem) var(--spacing-6, 1.5rem);background:var(--accent-primary, #0066cc);color:#fff;border:none;border-radius:var(--border-radius, 8px);font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-medium, 500);cursor:pointer;transition:all var(--transition-speed, .2s);margin-top:var(--spacing-2, .5rem)}.login-button:hover:not(:disabled){background:var(--accent-hover, #0052a3);transform:translateY(-1px);box-shadow:0 2px 4px #0003}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.login-card{padding:var(--spacing-6, 1.5rem)}.login-title{font-size:var(--font-size-xl, 1.5rem)}}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize;letter-spacing:.5px}.status-badge--pending{background-color:#fef3c7;color:#92400e}.status-badge--published{background-color:#d1fae5;color:#065f46}.status-badge--archived{background-color:#e5e7eb;color:#374151}@media(prefers-color-scheme:dark){.status-badge--pending{background-color:#78350f;color:#fef3c7}.status-badge--published{background-color:#064e3b;color:#d1fae5}.status-badge--archived{background-color:#374151;color:#e5e7eb}}.photo-card{position:relative;background-color:var(--color-bg-secondary);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all var(--transition-normal);display:flex;flex-direction:column;height:100%}.photo-card:hover{box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.photo-card--selected{outline:3px solid var(--color-accent);outline-offset:2px}.photo-card-checkbox{position:absolute;top:var(--space-sm);left:var(--space-sm);z-index:10;background-color:#ffffffe6;border-radius:4px;padding:4px;box-shadow:var(--shadow-sm)}.photo-card-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;margin:0}@media(prefers-color-scheme:dark){.photo-card-checkbox{background-color:#1c1917e6}}.photo-card-image-wrapper{position:relative;width:100%;padding-top:66.67%;background-color:var(--color-bg-primary);cursor:pointer;overflow:hidden}.photo-card-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform var(--transition-normal)}.photo-card-image-wrapper:hover .photo-card-image{transform:scale(1.05)}.photo-card-overlay{position:absolute;top:var(--space-sm);right:var(--space-sm);z-index:1}.photo-card-content{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);flex-grow:1}.photo-card-title{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.photo-card-meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;font-size:.875rem;color:var(--color-text-secondary)}.photo-card-date{color:var(--color-text-secondary)}.photo-card-gallery{padding:2px 8px;background-color:var(--color-bg-primary);border-radius:4px;font-size:.75rem;font-weight:500;color:var(--color-accent)}.photo-card-description{margin:0;font-size:.875rem;color:var(--color-text-secondary);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.photo-card-actions{display:flex;gap:var(--space-xs);margin-top:auto;padding-top:var(--space-sm)}.photo-card-button{flex:1;padding:var(--space-sm) var(--space-md);border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.photo-card-button:hover{transform:translateY(-1px)}.photo-card-button--primary{background-color:#10b981;color:#fff}.photo-card-button--primary:hover{background-color:#059669}.photo-card-button--secondary{background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border)}.photo-card-button--secondary:hover{background-color:var(--color-border)}.photo-card-button--danger{background-color:#ef4444;color:#fff}.photo-card-button--danger:hover{background-color:#dc2626}@media(max-width:768px){.photo-card-actions{flex-direction:column}.photo-card-button{width:100%}}.confirm-dialog-backdrop{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.confirm-dialog{background-color:var(--color-bg-secondary);border-radius:8px;max-width:500px;width:100%;box-shadow:var(--shadow-md);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.confirm-dialog-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.confirm-dialog-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.confirm-dialog-content{padding:var(--space-lg)}.confirm-dialog-content p{margin:0;color:var(--color-text-secondary);line-height:1.6}.confirm-dialog-actions{padding:var(--space-lg);border-top:1px solid var(--color-border);display:flex;gap:var(--space-sm);justify-content:flex-end}.confirm-dialog-button{padding:var(--space-sm) var(--space-lg);border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.confirm-dialog-button:hover{transform:translateY(-1px)}.confirm-dialog-button--cancel{background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border)}.confirm-dialog-button--cancel:hover{background-color:var(--color-border)}.confirm-dialog-button--confirm{color:#fff}.confirm-dialog-button--danger{background-color:#ef4444}.confirm-dialog-button--danger:hover{background-color:#dc2626}.confirm-dialog-button--warning{background-color:#f59e0b}.confirm-dialog-button--warning:hover{background-color:#d97706}.confirm-dialog-button--info{background-color:#3b82f6}.confirm-dialog-button--info:hover{background-color:#2563eb}@media(max-width:768px){.confirm-dialog{margin:var(--space-md)}.confirm-dialog-actions{flex-direction:column-reverse}.confirm-dialog-button{width:100%}}.edit-modal-backdrop{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.edit-modal{background-color:var(--color-bg-secondary);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000004d;display:flex;flex-direction:column}.edit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.edit-modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.edit-modal-close{background:none;border:none;font-size:2rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all var(--transition-fast)}.edit-modal-close:hover{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.edit-modal-close:disabled{opacity:.5;cursor:not-allowed}.edit-modal-content{padding:var(--space-lg);flex-grow:1;overflow-y:auto}.edit-preview{margin-bottom:var(--space-lg);border-radius:8px;overflow:hidden;background-color:var(--color-bg-primary)}.edit-preview-image{width:100%;height:auto;display:block;max-height:300px;object-fit:contain}.edit-form{display:flex;flex-direction:column;gap:var(--space-md)}.edit-form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.edit-form-label{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.edit-form-required{color:#ef4444}.edit-form-input,.edit-form-textarea{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:6px;font-size:1rem;font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-secondary);transition:all var(--transition-fast)}.edit-form-input:focus,.edit-form-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a}.edit-form-input:disabled,.edit-form-textarea:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-bg-primary)}.edit-form-textarea{resize:vertical;min-height:80px}.edit-form-hint{margin:0;font-size:.75rem;color:var(--color-text-secondary)}.edit-error{background-color:#fee2e2;border:1px solid #ef4444;border-radius:6px;padding:var(--space-md);margin-top:var(--space-md);color:#991b1b;font-size:.875rem;font-weight:500}.edit-progress{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);margin-top:var(--space-md);background-color:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:6px;color:var(--color-text-primary);font-size:.875rem;font-weight:500}.edit-progress-spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:edit-spinner .6s linear infinite}@keyframes edit-spinner{to{transform:rotate(360deg)}}.edit-progress p{margin:0}.edit-modal-actions{display:flex;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--color-border)}.edit-modal-button{flex:1;padding:var(--space-sm) var(--space-lg);border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.edit-modal-button:hover{transform:translateY(-1px)}.edit-modal-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.edit-modal-button--cancel{background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border)}.edit-modal-button--cancel:hover{background-color:var(--color-border)}.edit-modal-button--save{background-color:#3b82f6;color:#fff}.edit-modal-button--save:hover{background-color:#2563eb}@media(max-width:768px){.edit-modal-backdrop{padding:0}.edit-modal{max-width:100%;max-height:100vh;border-radius:0}.edit-modal-content{padding:var(--space-md)}.edit-modal-actions{flex-direction:column-reverse}.edit-modal-button{width:100%}}@media(prefers-color-scheme:dark){.edit-modal-backdrop{background-color:#000000d9}.edit-error{background-color:#7f1d1d;border-color:#dc2626;color:#fecaca}.edit-progress{background-color:#3b82f626;border-color:#3b82f666}}.batch-upload-modal-backdrop{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.batch-upload-modal{background-color:var(--color-bg-secondary);border-radius:8px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.batch-upload-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.batch-upload-header h2{font-family:var(--font-serif);font-size:var(--font-size-xl);color:var(--color-text-primary);margin:0}.batch-upload-close{background:none;border:none;font-size:32px;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.batch-upload-close:hover{color:var(--color-text-primary)}.batch-upload-close:disabled{opacity:.5;cursor:not-allowed}.batch-upload-content{padding:var(--space-lg);overflow-y:auto;flex:1}.file-select-area{text-align:center;padding:var(--space-2xl);border:2px dashed var(--color-border);border-radius:8px;margin-bottom:var(--space-lg)}.file-input-hidden{display:none}.file-select-button{display:inline-block;padding:var(--space-md) var(--space-xl);background-color:var(--color-accent);color:var(--color-bg-primary);border-radius:4px;cursor:pointer;font-family:var(--font-sans);font-size:var(--font-size-base);transition:all var(--transition-fast)}.file-select-button:hover{background-color:var(--color-text-primary)}.file-count{margin-top:var(--space-md);color:var(--color-text-secondary);font-family:var(--font-sans)}.gallery-select-area{margin-bottom:var(--space-lg);padding:var(--space-md);background-color:var(--color-bg-primary);border-radius:4px}.gallery-select-label{display:block;font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.gallery-select-dropdown{width:100%;padding:var(--space-sm) var(--space-md);font-family:var(--font-sans);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:4px;background-color:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer}.gallery-select-dropdown:focus{outline:none;border-color:var(--color-accent)}.new-gallery-input{width:100%;margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);font-family:var(--font-sans);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:4px;background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.new-gallery-input:focus{outline:none;border-color:var(--color-accent)}.new-gallery-input::placeholder{color:var(--color-text-secondary)}.upload-progress-bar-container{position:relative;width:100%;height:40px;background-color:var(--color-bg-primary);border-radius:4px;overflow:hidden;margin-bottom:var(--space-lg)}.upload-progress-bar{height:100%;background-color:var(--color-accent);transition:width var(--transition-normal)}.upload-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-sans);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.upload-list{max-height:300px;overflow-y:auto;margin-bottom:var(--space-lg)}.upload-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);border-bottom:1px solid var(--color-border);font-family:var(--font-sans);font-size:14px}.upload-item:last-child{border-bottom:none}.upload-filename{color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:var(--space-md)}.upload-status{color:var(--color-text-secondary);white-space:nowrap}.upload-success .upload-status{color:#2d6930}.upload-failed .upload-status{color:#c33}.upload-failed-actions{text-align:center;padding:var(--space-lg);background-color:#fee;border-radius:4px;margin-bottom:var(--space-lg)}.upload-failed-message{color:#721c24;font-family:var(--font-sans);margin-bottom:var(--space-md)}.batch-upload-actions{display:flex;justify-content:flex-end;gap:var(--space-md)}.btn-primary,.btn-secondary,.btn-retry{padding:var(--space-sm) var(--space-lg);border-radius:4px;font-family:var(--font-sans);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast);border:none}.btn-primary{background-color:var(--color-accent);color:var(--color-bg-primary)}.btn-primary:hover:not(:disabled){background-color:var(--color-text-primary)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:transparent;color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-bg-primary)}.btn-retry{background-color:#721c24;color:#fff}.btn-retry:hover{background-color:#5a1419}@media(prefers-color-scheme:dark){.upload-success .upload-status{color:#a3d9a5}.upload-failed-actions{background-color:#4a1e1e;border-color:#6d2c2c}.upload-failed-message{color:#f5c2c7}}.assign-gallery-modal-backdrop{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.assign-gallery-modal{background-color:var(--color-bg-secondary);border-radius:8px;width:90%;max-width:450px;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.assign-gallery-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.assign-gallery-header h2{font-family:var(--font-serif);font-size:var(--font-size-xl);color:var(--color-text-primary);margin:0}.assign-gallery-close{background:none;border:none;font-size:32px;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.assign-gallery-close:hover{color:var(--color-text-primary)}.assign-gallery-content{padding:var(--space-lg)}.assign-gallery-description{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0 0 var(--space-lg) 0}.assign-gallery-content .gallery-select-area{margin-bottom:var(--space-lg);padding:var(--space-md);background-color:var(--color-bg-primary);border-radius:4px}.assign-gallery-content .gallery-select-label{display:block;font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.assign-gallery-content .gallery-select-dropdown{width:100%;padding:var(--space-sm) var(--space-md);font-family:var(--font-sans);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:4px;background-color:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer}.assign-gallery-content .gallery-select-dropdown:focus{outline:none;border-color:var(--color-accent)}.assign-gallery-content .new-gallery-input{width:100%;margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);font-family:var(--font-sans);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:4px;background-color:var(--color-bg-secondary);color:var(--color-text-primary);box-sizing:border-box}.assign-gallery-content .new-gallery-input:focus{outline:none;border-color:var(--color-accent)}.assign-gallery-content .new-gallery-input::placeholder{color:var(--color-text-secondary)}.assign-gallery-actions{display:flex;justify-content:flex-end;gap:var(--space-md)}.assign-gallery-actions .btn-primary,.assign-gallery-actions .btn-secondary{padding:var(--space-sm) var(--space-lg);border-radius:4px;font-family:var(--font-sans);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast);border:none}.assign-gallery-actions .btn-primary{background-color:var(--color-accent);color:var(--color-bg-primary)}.assign-gallery-actions .btn-primary:hover:not(:disabled){background-color:var(--color-text-primary)}.assign-gallery-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.assign-gallery-actions .btn-secondary{background-color:transparent;color:var(--color-text-primary);border:1px solid var(--color-border)}.assign-gallery-actions .btn-secondary:hover{background-color:var(--color-bg-primary)}.hero-settings-backdrop{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.hero-settings-modal{background-color:var(--color-bg-secondary);border-radius:12px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000004d;display:flex;flex-direction:column}.hero-settings-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.hero-settings-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.hero-settings-close{background:none;border:none;font-size:2rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all var(--transition-fast)}.hero-settings-close:hover{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.hero-settings-close:disabled{opacity:.5;cursor:not-allowed}.hero-settings-content{padding:var(--space-lg);flex-grow:1;overflow-y:auto}.hero-settings-loading{text-align:center;padding:var(--space-xl);color:var(--color-text-secondary)}.hero-settings-form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-lg)}.hero-settings-label{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.hero-settings-required{color:#ef4444}.hero-settings-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:6px;font-size:1rem;font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-secondary);transition:all var(--transition-fast)}.hero-settings-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a}.hero-settings-input:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-bg-primary)}.hero-settings-hint{margin:0;font-size:.75rem;color:var(--color-text-secondary)}.hero-settings-selected-preview{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);background-color:var(--color-bg-primary);border-radius:8px;margin-bottom:var(--space-md)}.hero-settings-selected-preview img{width:60px;height:60px;object-fit:cover;border-radius:4px}.hero-settings-selected-title{font-size:.875rem;color:var(--color-text-primary);font-weight:500}.hero-settings-no-photos{text-align:center;padding:var(--space-lg);color:var(--color-text-secondary);background-color:var(--color-bg-primary);border-radius:8px}.hero-settings-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-sm);max-height:300px;overflow-y:auto;padding:var(--space-sm);background-color:var(--color-bg-primary);border-radius:8px}.hero-settings-photo-option{position:relative;aspect-ratio:1;cursor:pointer;border-radius:6px;overflow:hidden;border:2px solid transparent;transition:all var(--transition-fast)}.hero-settings-photo-option:hover{border-color:var(--color-accent);transform:scale(1.02)}.hero-settings-photo-option.selected{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.hero-settings-photo-option img{width:100%;height:100%;object-fit:cover}.hero-settings-photo-check{position:absolute;top:4px;right:4px;width:24px;height:24px;background-color:#3b82f6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.hero-settings-error{background-color:#fee2e2;border:1px solid #ef4444;border-radius:6px;padding:var(--space-md);margin-top:var(--space-md);color:#991b1b;font-size:.875rem;font-weight:500}.hero-settings-actions{display:flex;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--color-border)}.hero-settings-button{flex:1;padding:var(--space-sm) var(--space-lg);border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.hero-settings-button:hover{transform:translateY(-1px)}.hero-settings-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.hero-settings-button--cancel{background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border)}.hero-settings-button--cancel:hover{background-color:var(--color-border)}.hero-settings-button--save{background-color:#3b82f6;color:#fff}.hero-settings-button--save:hover{background-color:#2563eb}@media(max-width:768px){.hero-settings-backdrop{padding:0}.hero-settings-modal{max-width:100%;max-height:100vh;border-radius:0}.hero-settings-content{padding:var(--space-md)}.hero-settings-photo-grid{grid-template-columns:repeat(3,1fr)}.hero-settings-actions{flex-direction:column-reverse}.hero-settings-button{width:100%}}@media(prefers-color-scheme:dark){.hero-settings-backdrop{background-color:#000000d9}.hero-settings-error{background-color:#7f1d1d;border-color:#dc2626;color:#fecaca}}.about-settings-backdrop{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.about-settings-modal{background-color:var(--color-bg-secondary);border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000004d;display:flex;flex-direction:column}.about-settings-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.about-settings-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.about-settings-close{background:none;border:none;font-size:2rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all var(--transition-fast)}.about-settings-close:hover{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.about-settings-close:disabled{opacity:.5;cursor:not-allowed}.about-settings-content{padding:var(--space-lg);flex-grow:1;overflow-y:auto}.about-settings-loading{text-align:center;padding:var(--space-xl);color:var(--color-text-secondary)}.about-settings-form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-lg)}.about-settings-label{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.about-settings-required{color:#ef4444}.about-settings-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:6px;font-size:1rem;font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-secondary);transition:all var(--transition-fast)}.about-settings-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a}.about-settings-input:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-bg-primary)}.about-settings-textarea{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:6px;font-size:1rem;font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-secondary);transition:all var(--transition-fast);resize:vertical;min-height:100px}.about-settings-textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a}.about-settings-textarea:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-bg-primary)}.about-settings-hint{margin:0;font-size:.75rem;color:var(--color-text-secondary)}.about-settings-selected-preview{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);background-color:var(--color-bg-primary);border-radius:8px;margin-bottom:var(--space-md)}.about-settings-selected-preview img{width:60px;height:60px;object-fit:cover;border-radius:4px}.about-settings-selected-title{font-size:.875rem;color:var(--color-text-primary);font-weight:500}.about-settings-no-photos{text-align:center;padding:var(--space-lg);color:var(--color-text-secondary);background-color:var(--color-bg-primary);border-radius:8px}.about-settings-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-sm);max-height:200px;overflow-y:auto;padding:var(--space-sm);background-color:var(--color-bg-primary);border-radius:8px}.about-settings-photo-option{position:relative;aspect-ratio:1;cursor:pointer;border-radius:6px;overflow:hidden;border:2px solid transparent;transition:all var(--transition-fast)}.about-settings-photo-option:hover{border-color:var(--color-accent);transform:scale(1.02)}.about-settings-photo-option.selected{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.about-settings-photo-option img{width:100%;height:100%;object-fit:cover}.about-settings-photo-check{position:absolute;top:4px;right:4px;width:20px;height:20px;background-color:#3b82f6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.about-settings-sections-header{display:flex;justify-content:space-between;align-items:center}.about-settings-add-section{padding:var(--space-xs) var(--space-sm);background-color:#10b981;color:#fff;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.about-settings-add-section:hover{background-color:#059669}.about-settings-add-section:disabled{opacity:.5;cursor:not-allowed}.about-settings-no-sections{text-align:center;padding:var(--space-lg);color:var(--color-text-secondary);background-color:var(--color-bg-primary);border-radius:8px;border:2px dashed var(--color-border)}.about-settings-sections-list{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-sm)}.about-settings-section-card{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;padding:var(--space-md)}.about-settings-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.about-settings-section-number{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.about-settings-section-actions{display:flex;gap:var(--space-xs)}.about-settings-section-action{width:28px;height:28px;padding:0;background-color:var(--color-bg-secondary);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:4px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.about-settings-section-action:hover:not(:disabled){background-color:var(--color-border);color:var(--color-text-primary)}.about-settings-section-action:disabled{opacity:.3;cursor:not-allowed}.about-settings-section-action--danger:hover:not(:disabled){background-color:#fee2e2;border-color:#ef4444;color:#dc2626}.about-settings-section-fields{display:flex;flex-direction:column;gap:var(--space-sm)}.about-settings-error{background-color:#fee2e2;border:1px solid #ef4444;border-radius:6px;padding:var(--space-md);margin-top:var(--space-md);color:#991b1b;font-size:.875rem;font-weight:500}.about-settings-actions{display:flex;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--color-border)}.about-settings-button{flex:1;padding:var(--space-sm) var(--space-lg);border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.about-settings-button:hover{transform:translateY(-1px)}.about-settings-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.about-settings-button--cancel{background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border)}.about-settings-button--cancel:hover{background-color:var(--color-border)}.about-settings-button--save{background-color:#3b82f6;color:#fff}.about-settings-button--save:hover{background-color:#2563eb}@media(max-width:768px){.about-settings-backdrop{padding:0}.about-settings-modal{max-width:100%;max-height:100vh;border-radius:0}.about-settings-content{padding:var(--space-md)}.about-settings-photo-grid{grid-template-columns:repeat(4,1fr)}.about-settings-sections-header{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.about-settings-add-section{width:100%}.about-settings-actions{flex-direction:column-reverse}.about-settings-button{width:100%}}@media(prefers-color-scheme:dark){.about-settings-backdrop{background-color:#000000d9}.about-settings-error{background-color:#7f1d1d;border-color:#dc2626;color:#fecaca}.about-settings-section-action--danger:hover:not(:disabled){background-color:#7f1d1d;border-color:#dc2626;color:#fecaca}}.contact-settings-backdrop{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.contact-settings-modal{background-color:var(--color-bg-secondary);border-radius:12px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000004d;display:flex;flex-direction:column}.contact-settings-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.contact-settings-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.contact-settings-close{background:none;border:none;font-size:2rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all var(--transition-fast)}.contact-settings-close:hover{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.contact-settings-close:disabled{opacity:.5;cursor:not-allowed}.contact-settings-content{padding:var(--space-lg);flex-grow:1;overflow-y:auto}.contact-settings-loading{text-align:center;padding:var(--space-xl);color:var(--color-text-secondary)}.contact-settings-form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-lg)}.contact-settings-label{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.contact-settings-required{color:#ef4444}.contact-settings-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:6px;font-size:1rem;font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-secondary);transition:all var(--transition-fast)}.contact-settings-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a}.contact-settings-input:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-bg-primary)}.contact-settings-hint{margin:0;font-size:.75rem;color:var(--color-text-secondary)}.contact-settings-selected-preview{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);background-color:var(--color-bg-primary);border-radius:8px;margin-bottom:var(--space-md)}.contact-settings-selected-preview img{width:60px;height:60px;object-fit:cover;border-radius:4px}.contact-settings-selected-title{font-size:.875rem;color:var(--color-text-primary);font-weight:500}.contact-settings-no-photos{text-align:center;padding:var(--space-lg);color:var(--color-text-secondary);background-color:var(--color-bg-primary);border-radius:8px}.contact-settings-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-sm);max-height:300px;overflow-y:auto;padding:var(--space-sm);background-color:var(--color-bg-primary);border-radius:8px}.contact-settings-photo-option{position:relative;aspect-ratio:1;cursor:pointer;border-radius:6px;overflow:hidden;border:2px solid transparent;transition:all var(--transition-fast)}.contact-settings-photo-option:hover{border-color:var(--color-accent);transform:scale(1.02)}.contact-settings-photo-option.selected{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}.contact-settings-photo-option img{width:100%;height:100%;object-fit:cover}.contact-settings-photo-check{position:absolute;top:4px;right:4px;width:24px;height:24px;background-color:#3b82f6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.contact-settings-error{background-color:#fee2e2;border:1px solid #ef4444;border-radius:6px;padding:var(--space-md);margin-top:var(--space-md);color:#991b1b;font-size:.875rem;font-weight:500}.contact-settings-actions{display:flex;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--color-border)}.contact-settings-button{flex:1;padding:var(--space-sm) var(--space-lg);border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.contact-settings-button:hover{transform:translateY(-1px)}.contact-settings-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.contact-settings-button--cancel{background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border)}.contact-settings-button--cancel:hover{background-color:var(--color-border)}.contact-settings-button--save{background-color:#3b82f6;color:#fff}.contact-settings-button--save:hover{background-color:#2563eb}@media(max-width:768px){.contact-settings-backdrop{padding:0}.contact-settings-modal{max-width:100%;max-height:100vh;border-radius:0}.contact-settings-content{padding:var(--space-md)}.contact-settings-photo-grid{grid-template-columns:repeat(3,1fr)}.contact-settings-actions{flex-direction:column-reverse}.contact-settings-button{width:100%}}@media(prefers-color-scheme:dark){.contact-settings-backdrop{background-color:#000000d9}.contact-settings-error{background-color:#7f1d1d;border-color:#dc2626;color:#fecaca}}.general-settings-backdrop{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.general-settings-modal{background-color:var(--color-bg-secondary);border-radius:8px;width:90%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}.general-settings-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.general-settings-header h2{font-family:var(--font-serif);font-size:var(--font-size-xl);color:var(--color-text-primary);margin:0}.general-settings-close{background:none;border:none;font-size:32px;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.general-settings-close:hover{color:var(--color-text-primary)}.general-settings-close:disabled{opacity:.5;cursor:not-allowed}.general-settings-content{padding:var(--space-lg);overflow-y:auto;flex:1}.general-settings-loading{text-align:center;padding:var(--space-2xl);color:var(--color-text-secondary);font-family:var(--font-sans)}.general-settings-form-group{margin-bottom:var(--space-lg)}.general-settings-label{display:block;font-family:var(--font-serif);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-xs)}.general-settings-hint{font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-md) 0}.theme-options{display:flex;flex-direction:column;gap:var(--space-sm)}.theme-option{display:block;cursor:pointer}.theme-option input{position:absolute;opacity:0;pointer-events:none}.theme-option-content{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border:2px solid var(--color-border);border-radius:8px;transition:all var(--transition-fast)}.theme-option:hover .theme-option-content{border-color:var(--color-accent)}.theme-option.selected .theme-option-content{border-color:var(--color-accent);background-color:var(--color-bg-primary)}.theme-option-icon{display:flex;align-items:center;color:var(--color-text-secondary);flex-shrink:0}.theme-option.selected .theme-option-icon{color:var(--color-accent)}.theme-option-label{font-family:var(--font-sans);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);min-width:60px}.theme-option-description{font-family:var(--font-sans);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-left:auto}.general-settings-error{padding:var(--space-md);background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;font-family:var(--font-sans);font-size:var(--font-size-sm);margin-top:var(--space-md)}.general-settings-actions{display:flex;justify-content:flex-end;gap:var(--space-md);padding:var(--space-lg);border-top:1px solid var(--color-border)}.general-settings-button{padding:var(--space-sm) var(--space-xl);border-radius:4px;font-family:var(--font-sans);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast);border:none}.general-settings-button--cancel{background-color:transparent;color:var(--color-text-primary);border:1px solid var(--color-border)}.general-settings-button--cancel:hover:not(:disabled){background-color:var(--color-bg-primary)}.general-settings-button--save{background-color:var(--color-accent);color:var(--color-bg-primary)}.general-settings-button--save:hover:not(:disabled){background-color:var(--color-text-primary)}.general-settings-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.theme-option-content{flex-wrap:wrap}.theme-option-description{width:100%;margin-left:calc(24px + var(--space-md));margin-top:var(--space-xs)}}.admin-dashboard{max-width:var(--max-width);margin:0 auto;padding:var(--space-xl) var(--space-md);min-height:calc(100vh - var(--header-height))}.admin-dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.admin-dashboard-header h1{margin:0;font-size:2rem;font-weight:700;color:var(--color-text-primary)}.admin-dashboard-upload-button{padding:var(--space-sm) var(--space-lg);background-color:#10b981;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.admin-dashboard-upload-button:hover{background-color:#059669;transform:translateY(-1px)}.admin-dashboard-header-actions{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.selection-count{font-size:1rem;font-weight:600;color:var(--color-accent);padding:var(--space-sm)}.btn-select-all{padding:var(--space-sm) var(--space-md);background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-select-all:hover{background-color:var(--color-border);transform:translateY(-1px)}.btn-bulk-action{padding:var(--space-sm) var(--space-md);background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-bulk-action:hover{background-color:#2563eb;transform:translateY(-1px)}.admin-dashboard-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-xl);border-bottom:2px solid var(--color-border)}.admin-dashboard-tab{padding:var(--space-md) var(--space-lg);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:1rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.admin-dashboard-tab:hover{color:var(--color-text-primary);background-color:var(--color-bg-primary)}.admin-dashboard-tab--active{color:var(--color-text-primary);border-bottom-color:var(--color-accent)}.admin-dashboard-filters{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);align-items:flex-start;flex-wrap:wrap}.admin-dashboard-search{position:relative;flex:1;min-width:300px;max-width:500px}.admin-dashboard-search-input{width:100%;padding:var(--space-sm) var(--space-md);padding-right:40px;border:1px solid var(--color-border);border-radius:6px;font-size:1rem;transition:all var(--transition-fast)}.admin-dashboard-search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a}.admin-dashboard-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--color-text-secondary);font-size:24px;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.admin-dashboard-search-clear:hover{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.admin-dashboard-search-results{margin-bottom:var(--space-md);font-size:.875rem;color:var(--color-text-secondary);font-style:italic}.admin-dashboard-gallery-select{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:6px;font-size:1rem;min-width:200px;background-color:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.admin-dashboard-gallery-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a}.admin-dashboard-gallery-select:hover{border-color:var(--color-text-secondary)}.admin-dashboard-error{background-color:#fee2e2;border:1px solid #ef4444;border-radius:6px;padding:var(--space-md);margin-bottom:var(--space-lg);display:flex;justify-content:space-between;align-items:center;gap:var(--space-md)}.admin-dashboard-error p{margin:0;color:#991b1b;font-weight:500}.admin-dashboard-error button{padding:var(--space-xs) var(--space-sm);background-color:#fff;color:#991b1b;border:1px solid #ef4444;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background-color var(--transition-fast)}.admin-dashboard-error button:hover{background-color:#fef2f2}.admin-dashboard-loading,.admin-dashboard-empty{text-align:center;padding:var(--space-2xl);color:var(--color-text-secondary)}.admin-dashboard-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.admin-dashboard-empty p{margin:0;font-size:1.125rem}.admin-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}@media(max-width:768px){.admin-dashboard{padding:var(--space-lg) var(--space-sm)}.admin-dashboard-header{flex-direction:column;align-items:stretch}.admin-dashboard-upload-button{width:100%}.admin-dashboard-header-actions{flex-direction:column;align-items:stretch}.btn-select-all,.btn-bulk-action{width:100%}.selection-count{text-align:center}.admin-dashboard-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-dashboard-tab{white-space:nowrap}.admin-dashboard-grid{grid-template-columns:1fr;gap:var(--space-md)}.admin-dashboard-error{flex-direction:column;align-items:stretch}.admin-dashboard-error button{width:100%}}@media(prefers-color-scheme:dark){.admin-dashboard-error{background-color:#7f1d1d;border-color:#dc2626}.admin-dashboard-error p{color:#fecaca}.admin-dashboard-error button{background-color:#1f2937;color:#fecaca;border-color:#dc2626}.admin-dashboard-error button:hover{background-color:#374151}}.admin-dashboard-settings{padding:var(--space-lg) 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.admin-settings-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:var(--space-xl)}.admin-settings-card h3{margin:0 0 var(--space-sm) 0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.admin-settings-card p{margin:0 0 var(--space-lg) 0;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}
