:root{--color-primary:#1a1a1a;--color-primary-light:#2d2d2d;--color-primary-dark:#000;--color-accent-gold:#8b4513;--color-accent-gold-light:sienna;--color-accent-gold-dark:#654321;--color-bg-primary:#fff;--color-bg-secondary:#f8f8f8;--color-bg-card:#fff;--color-text-primary:#1a1a1a;--color-text-secondary:#4a4a4a;--color-text-muted:#6b6b6b;--color-taupe-light:#e5e5e5;--color-taupe-medium:#9a9a9a;--color-taupe-dark:#1a1a1a;--color-border:#d0d0d0;--shadow-sm:0 2px 4px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.12);--shadow-lg:0 8px 24px rgba(0,0,0,.16);--font-primary:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Arial",sans-serif;--font-heading:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Arial",sans-serif;--font-body:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Arial",sans-serif;--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--spacing-xl:3rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--color-bg-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.01em}body,h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);font-weight:400}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.2;margin-bottom:var(--spacing-sm);letter-spacing:-.02em}h1{font-size:2.5rem;letter-spacing:-.03em}h1,h2{color:var(--color-text-primary);font-weight:400}h2{font-size:2rem}h2,h3{letter-spacing:-.02em}h3{font-size:1.5rem;font-weight:400}a{color:var(--color-primary-dark);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.btn{display:inline-block;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:center;font-family:var(--font-primary)}.btn-primary{background:var(--color-primary-dark);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-primary:active:not(:disabled){background:var(--color-primary-dark)}.btn-primary:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.btn-secondary{background:var(--color-taupe-medium);color:#fff;box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--color-taupe-dark);box-shadow:var(--shadow-md);transform:translateY(-2px)}.form-group{margin-bottom:var(--spacing-md)}.form-label{position:absolute;left:0;top:1rem;font-size:1rem;color:var(--color-text-muted);pointer-events:none;transition:all .3s ease;transform-origin:left top;margin-bottom:0;font-weight:400}.form-input.has-value+.form-label,.form-input:focus+.form-label,.form-input:not(:placeholder-shown)+.form-label,.form-label.has-value,.form-select.has-value+.form-label,.form-select:focus+.form-label,.form-select:not([value=""])+.form-label,.form-textarea.has-value+.form-label,.form-textarea:focus+.form-label,.form-textarea:not(:placeholder-shown)+.form-label{transform:translateY(-1.5rem) scale(.85);color:var(--color-primary)}.form-group>.form-label:first-child,.form-section-label{position:static;display:block;margin-bottom:var(--spacing-sm);margin-top:0;padding-top:0;font-weight:500;color:var(--color-text-primary);pointer-events:auto;transform:none;font-size:.875rem;line-height:1.5}.form-input::placeholder,.form-textarea::placeholder{color:transparent}.form-helper{font-size:.875rem;color:var(--color-text-muted);margin-top:var(--spacing-xs);line-height:1.4}.form-helper-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:.7rem;font-weight:700;font-style:italic;margin-left:var(--spacing-xs);cursor:help;position:relative;vertical-align:middle;line-height:1;transition:all .2s ease}.form-helper-icon:hover{background:var(--color-primary-dark);transform:scale(1.1)}.form-helper-icon:hover:after{content:attr(data-tooltip);bottom:calc(100% + 8px);background:var(--color-text-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:8px;font-size:.85rem;white-space:normal;max-width:280px;width:max-content;z-index:10000;box-shadow:0 4px 12px rgba(0,0,0,.3);line-height:1.4;text-align:left}.form-helper-icon:hover:after,.form-helper-icon:hover:before{position:absolute;left:50%;transform:translateX(-50%);pointer-events:none}.form-helper-icon:hover:before{content:"";bottom:calc(100% + 2px);border:6px solid transparent;border-top:6px solid var(--color-text-primary);z-index:10001}.form-input,.form-select,.form-textarea{width:100%;padding:1rem 0 .5rem;font-size:1rem;font-family:var(--font-primary);border:none;border-bottom:2px solid var(--color-border);border-radius:0;background:transparent;color:var(--color-text-primary);transition:all .3s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-bottom-color:var(--color-primary);border-bottom-width:3px}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:transparent;cursor:not-allowed;opacity:.5}.form-textarea{resize:vertical;min-height:100px;padding-top:.75rem;padding-bottom:.375rem}.form-group:has(.form-textarea){margin-bottom:var(--spacing-sm)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0 center;padding-right:2rem}.card{background:var(--color-bg-card);border-radius:12px;padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all .3s ease}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card:active{transform:scale(.98)}.card h3,.card h4,.card h5{margin-top:0}.artist-card{display:block;text-decoration:none;color:inherit;overflow:hidden;border-radius:0;background:transparent;border:none;box-shadow:none;transition:opacity .2s ease}.artist-card:hover{opacity:1;transform:none;box-shadow:none}.artist-card:hover .card-title{opacity:.6}.artist-card .card-image{height:400px;position:relative;overflow:hidden;background-color:transparent;margin-bottom:var(--spacing-md)}.artist-card .card-image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(139,69,19,.15),rgba(107,67,33,.1) 50%,rgba(26,26,26,.2));mix-blend-mode:multiply;pointer-events:none;z-index:1}.artist-card .card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.artist-card:hover .card-image img{transform:none}.artist-card .card-content{padding:0;background:transparent;margin-top:var(--spacing-sm)}.artist-card .card-title{color:var(--color-text-primary);margin:0;font-size:1rem;font-weight:400;letter-spacing:-.01em;text-transform:none}.artist-card .card-description{color:var(--color-text-secondary);font-size:.875rem;line-height:1.6;font-weight:300;margin:.5rem 0 0;opacity:.7}.alert{padding:var(--spacing-sm) var(--spacing-md);border-radius:8px;margin-bottom:var(--spacing-md);border-left:4px solid}.alert-success{background:#f0f9f0;border-color:#4caf50;color:#2e7d32}.alert-error{background:#fff5f5;border-color:#f44336;color:#c62828}.alert-info{background:transparent;border:none;color:var(--color-text-primary);padding:0}.grid{display:grid;grid-gap:var(--spacing-md);gap:var(--spacing-md)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:calc(var(--spacing-xl) * 2);row-gap:calc(var(--spacing-xl) * 1.5)}.hero{background:var(--color-bg-primary);padding:0;text-align:center;position:relative;overflow:hidden;width:100vw;height:100vh;min-height:100vh;display:flex;align-items:center;justify-content:center;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%)}.hero,.hero-rotating{transition:background 1.5s ease-in-out}.hero-rotating{background-size:cover;background-position:50%;background-repeat:no-repeat}.hero-rotating .hero-content{position:relative;z-index:2}.hero-overlay{z-index:1;transition:background 1.5s ease-in-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.hero-content{position:relative;z-index:1;width:100%;max-width:1200px;padding:0 var(--spacing-md)}.hero h1{color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.hero h1,.hero p{text-shadow:none;transition:text-shadow 1s ease-in-out}.hero p{color:var(--color-text-secondary);font-size:1.25rem;max-width:600px;margin:0 auto}.nav{background:var(--color-primary-dark);border-bottom:2px solid var(--color-accent-gold);padding:var(--spacing-sm) 0;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md);overflow:visible}.nav a{color:#fff}.nav-links a{color:hsla(0,0%,100%,.95)}.nav-links a:hover{color:var(--color-accent-gold-light)}.nav-container{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md);position:relative}.nav-actions-wrapper{position:absolute;top:var(--spacing-sm);right:var(--spacing-md);z-index:101;display:flex;align-items:center;gap:var(--spacing-sm)}.nav-logo{z-index:101}.nav-menu-wrapper{position:relative}.mobile-menu-toggle{display:flex;flex-direction:column;justify-content:space-around;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:0;z-index:101;transition:all .3s ease}.hamburger-line{width:28px;height:3px;background:#fff;border-radius:2px;transition:all .3s ease;transform-origin:center}.mobile-menu-toggle:hover .hamburger-line{background:var(--color-accent-gold-light)}.hamburger-line.open:first-child{transform:rotate(45deg) translate(8px,8px)}.hamburger-line.open:nth-child(2){opacity:0;transform:translateX(-20px)}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}.nav-content{display:flex;align-items:center;gap:var(--spacing-lg);transition:all .3s ease}@media (min-width:769px){.nav-content{position:absolute;top:100%;right:0;background:var(--color-primary-dark);flex-direction:column;align-items:flex-start;padding:var(--spacing-lg);min-width:250px;box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease;gap:var(--spacing-md);margin-top:var(--spacing-sm);border-radius:8px}.nav-content.mobile-open,.nav-menu-wrapper:hover .nav-content{opacity:1;visibility:visible;transform:translateY(0)}.nav-content .nav-links{flex-direction:column;width:100%;gap:var(--spacing-sm);align-items:flex-start;padding-top:0;border-top:1px solid hsla(0,0%,100%,.2);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.nav-content .nav-links a{width:100%;padding:var(--spacing-xs) 0;font-size:.9rem}.nav-content .nav-auth-authenticated,.nav-content .nav-auth-buttons{width:100%;flex-direction:column;align-items:stretch;gap:var(--spacing-xs)}}.nav-links{display:flex;gap:var(--spacing-lg);list-style:none;margin:0;padding:0}.nav-links a{font-weight:500;padding:var(--spacing-xs) 0;position:relative;transition:color .2s ease}.nav-links a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-accent-gold);transition:width .3s ease}.nav-links a:hover:after{width:100%}.nav-auth-authenticated,.nav-auth-links{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.nav-auth-buttons{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.section{padding:var(--spacing-xl) 0}.section-title{text-align:left;margin-bottom:var(--spacing-xl)}.section-title h2{font-family:var(--font-heading);color:var(--color-text-primary);text-align:left;font-weight:400;letter-spacing:-.02em;margin-bottom:var(--spacing-sm)}.section-title p{text-align:center;color:var(--color-text-secondary)}.search-filter-wrapper{display:grid;grid-template-columns:1fr auto;grid-gap:var(--spacing-md);gap:var(--spacing-md);align-items:end}.search-input-wrapper{flex:1 1;min-width:0}.search-button-wrapper{display:flex;align-items:flex-end}.keyword-filters{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;margin-right:-4px;margin-left:-4px;padding-left:4px;padding-right:4px}.keyword-filters::-webkit-scrollbar{height:4px}.keyword-filters::-webkit-scrollbar-track{background:transparent}.keyword-filters::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}@media (max-width:768px){:root{--color-primary:#1a1a1a;--color-primary-light:#2d2d2d;--color-primary-dark:#000;--color-accent-gold:#8b4513;--color-accent-gold-light:sienna;--color-accent-gold-dark:#654321;--color-bg-primary:#fff;--color-bg-secondary:#f8f8f8;--color-bg-card:#fff;--color-text-primary:#1a1a1a;--color-text-secondary:#4a4a4a;--color-text-muted:#6b6b6b;--color-taupe-light:#e5e5e5;--color-taupe-medium:#9a9a9a;--color-taupe-dark:#1a1a1a;--color-border:#d0d0d0;--shadow-sm:0 2px 4px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.12);--shadow-lg:0 8px 24px rgba(0,0,0,.16)}h1{font-size:2rem}h2{font-size:1.75rem}.nav-container{flex-direction:column;gap:var(--spacing-sm)}.nav-links{flex-wrap:wrap;justify-content:center}.grid-3{grid-template-columns:1fr}}.spinner{border-top:3px solid var(--color-border);border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.img-responsive{max-width:100%;height:auto;border-radius:8px}.img-cover{width:100%;height:100%;object-fit:cover;border-radius:8px}.text-center{text-align:center}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}@media (max-width:768px){html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{overflow-x:hidden}}:focus-visible{outline:2px solid var(--color-primary)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease-out;overflow-y:auto}.modal-content{background:var(--color-bg-card);max-width:50vw;width:45%;min-width:400px;margin:auto;box-shadow:0 20px 60px rgba(0,0,0,.3);border:1px solid var(--color-border);animation:slideUp .3s ease-out;max-height:calc(100vh - 2rem);box-sizing:border-box;z-index:10001;flex-shrink:0}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gold-accent{border-color:var(--color-accent-gold)}.gold-accent:hover{border-color:var(--color-accent-gold-dark);box-shadow:0 0 0 2px var(--color-accent-gold-light)}::selection{background:var(--color-accent-gold-light);color:var(--color-text-primary)}.accent-gold{color:var(--color-accent-gold)}.bg-emerald{background:var(--color-primary);color:#fff}.bg-taupe{background:var(--color-taupe-light)}.music-pattern{position:relative;overflow:hidden}.music-pattern:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(212,175,55,.03) 0,rgba(212,175,55,.03) 20px),repeating-linear-gradient(-45deg,transparent,transparent 10px,rgba(13,115,119,.03) 0,rgba(13,115,119,.03) 20px);pointer-events:none;z-index:0}.music-pattern>*{position:relative;z-index:1}.decorative-border{position:relative;padding:var(--spacing-lg);border:2px solid var(--color-accent-gold);border-radius:12px;background:var(--color-bg-primary)}.decorative-border:after,.decorative-border:before{content:"♪";position:absolute;color:var(--color-accent-gold);font-size:1.5rem;opacity:.3}.decorative-border:before{top:-12px;left:var(--spacing-md)}.decorative-border:after,.decorative-border:before{background:var(--color-bg-primary);padding:0 var(--spacing-xs)}.decorative-border:after{bottom:-12px;right:var(--spacing-md)}@media (max-width:1200px){.container{max-width:100%;padding:0 var(--spacing-md)}}@media (max-width:992px){h1{font-size:2.25rem}h2{font-size:1.875rem}.hero{min-height:100vh;height:100vh;padding:0}.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){:root{--spacing-xs:0.375rem;--spacing-sm:0.75rem;--spacing-md:1.25rem;--spacing-lg:1.75rem;--spacing-xl:2.5rem}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.375rem}.mobile-menu-toggle{display:flex}.nav-container{flex-wrap:wrap;padding:var(--spacing-sm) var(--spacing-md);padding-right:calc(48px + 32px + var(--spacing-sm) + var(--spacing-md) * 2)}.nav-actions-wrapper{top:var(--spacing-sm);right:var(--spacing-md);gap:var(--spacing-xs)}.nav-content{position:fixed;top:0;right:-100%;width:85%;max-width:320px;height:100vh;background:var(--color-primary-dark);flex-direction:column;align-items:flex-start;padding:calc(60px + var(--spacing-lg)) var(--spacing-lg) var(--spacing-lg);box-shadow:-4px 0 20px rgba(0,0,0,.3);overflow-y:auto;transition:right .3s cubic-bezier(.4,0,.2,1);gap:var(--spacing-lg);z-index:100}.mobile-menu-close{display:none!important}@media (max-width:768px){.mobile-menu-close{display:flex!important;position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:transparent;border:1px solid hsla(0,0%,100%,.3);border-radius:50%;width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer;color:hsla(0,0%,100%,.9);font-size:1.5rem;line-height:1;transition:all .2s ease;z-index:102}.mobile-menu-close:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.5)}.mobile-menu-close:active{background:hsla(0,0%,100%,.2)}}.nav-content.mobile-open{right:0}.nav-content.mobile-open:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:-1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.nav-links{flex-direction:column;width:100%;gap:var(--spacing-md);align-items:flex-start;padding-top:var(--spacing-md);border-top:1px solid hsla(0,0%,100%,.2)}.nav-links li{width:100%}.nav-links a{display:block;width:100%;padding:var(--spacing-sm) 0;font-size:1.1rem}.nav-links a:after{display:none}.nav-auth-authenticated{gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid hsla(0,0%,100%,.2)}.nav-auth-authenticated,.nav-auth-links{flex-direction:column;width:100%;align-items:flex-start}.nav-auth-links{gap:var(--spacing-sm)}.btn-nav-logout,.nav-auth-links a{width:100%;justify-content:flex-start}.nav-auth-buttons{flex-direction:column;width:100%;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid hsla(0,0%,100%,.2)}.btn-nav-login,.btn-nav-signup{width:100%;justify-content:center;padding:.75rem 1.25rem;font-size:1rem}.nav-auth-icon-button{width:44px!important;height:44px!important;min-width:44px;min-height:44px}.nav-auth-icon-button+div[style*="position: absolute"]{right:0!important;left:auto!important;min-width:200px!important;max-width:calc(100vw - 2rem)}.hero{min-height:50vh;padding:var(--spacing-lg) 0}.hero h1{font-size:1.75rem;line-height:1.2}.hero h1,.hero p{padding:0 var(--spacing-sm)}.hero p{font-size:1rem}.grid-2,.grid-3{grid-template-columns:1fr;gap:var(--spacing-md)}.card{padding:var(--spacing-md)}.btn{padding:.75rem 1.5rem;font-size:1rem;min-height:44px}.modal-content{max-width:calc(100vw - 2rem);width:calc(100vw - 2rem);padding:var(--spacing-md);margin:0;max-height:calc(100vh - 2rem);overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:16px;box-sizing:border-box}.modal-overlay{padding:var(--spacing-sm);align-items:center;justify-content:center;background:rgba(0,0,0,.6)}.toast-container{right:var(--spacing-md);left:var(--spacing-md);max-width:none;width:auto}.toast{min-height:44px;font-size:.9375rem;padding:var(--spacing-sm) var(--spacing-md)}.form-input,.form-select,.form-textarea{padding:.75rem 1rem;font-size:1rem;min-height:44px}.search-filter-wrapper{grid-template-columns:1fr;gap:var(--spacing-sm)}.search-button-wrapper{align-items:stretch}.btn-clear{width:100%;justify-content:center}.keyword-filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding:var(--spacing-xs) 0;margin:var(--spacing-xs) -4px 0;padding-left:4px;padding-right:4px}.keyword-filters button{flex-shrink:0;white-space:nowrap;min-width:-moz-fit-content;min-width:fit-content}.btn,a.btn,button{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.artist-card .card-image{height:220px}.artist-card .card-title{font-size:1.125rem}.artist-card .card-description{font-size:.9375rem}.card:active{transform:scale(.98)}.cta-buttons-wrapper .btn,.hero-cta-btn{width:auto;min-width:200px}.cta-buttons-wrapper{justify-content:center}.pagination-wrapper{flex-wrap:wrap;gap:var(--spacing-xs)}.pagination-wrapper button{min-width:44px;height:44px;padding:0 var(--spacing-sm)}.pricing-package-card{padding:var(--spacing-sm)!important}.pricing-package-card>div[style*=flex]{flex-direction:column;gap:var(--spacing-xs)!important}.pricing-package-card>div[style*=flex]>div[style*=flex][style*=justify-content]{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.pricing-package-card strong{font-size:.9375rem}.pricing-package-card span[style*=fontSize][style*="1.25rem"]{font-size:1rem}}@media (max-width:480px){:root{--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem}h1{font-size:1.625rem;line-height:1.2}h2{font-size:1.5rem}h2,h3{line-height:1.3}h3{font-size:1.25rem}.nav-container{padding:var(--spacing-sm);padding-right:calc(48px + 32px + var(--spacing-xs) + var(--spacing-sm) * 2)}.nav-actions-wrapper{top:var(--spacing-sm);right:var(--spacing-sm);gap:var(--spacing-xs)}.nav-logo{font-size:1.25rem}.nav-content{width:90%;max-width:280px;padding:calc(50px + var(--spacing-md)) var(--spacing-md) var(--spacing-md)}.hero{min-height:45vh;padding:var(--spacing-md) 0}.hero h1{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.hero p{font-size:.9375rem;line-height:1.5}.hero .btn{padding:.75rem 1.5rem;font-size:.9375rem;width:auto;display:inline-block}.card{padding:var(--spacing-md);border-radius:12px}.btn{padding:.75rem 1.25rem;font-size:.9375rem;min-height:44px}.container{padding:0 var(--spacing-md)}.section{padding:var(--spacing-lg) 0}.section-title h2{font-size:1.5rem}.section-title p{font-size:.9375rem}}.skeleton{background:linear-gradient(90deg,var(--color-border) 25%,hsla(34,29%,83%,.5) 50%,var(--color-border) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1em;margin-bottom:.5em}.skeleton-title{height:1.5em;width:60%;margin-bottom:1em}.skeleton-avatar{width:100px;height:100px;border-radius:50%}.skeleton-card{padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:12px;background:var(--color-bg-card)}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.spinner-large{border-top:4px solid var(--color-border);border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite}.spinner-small{border-top:2px solid var(--color-border);border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:16px;height:16px;animation:spin .8s linear infinite}.progress-bar{width:100%;height:4px;background:var(--color-border);border-radius:2px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;background:var(--color-primary);border-radius:2px;animation:progress-animation 2s ease-in-out infinite;transition:width .3s ease}@keyframes progress-animation{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.error-boundary{padding:var(--spacing-xl);text-align:center;background:var(--color-bg-card);border-radius:12px;border:2px solid #f44336;margin:var(--spacing-lg)}.error-icon{font-size:3rem;margin-bottom:var(--spacing-md);color:#f44336}.error-retry-btn{margin-top:var(--spacing-md)}.form-group{position:relative}.form-input-error,.form-select-error,.form-textarea-error{border-color:#f44336!important;box-shadow:0 0 0 3px rgba(244,67,54,.1)!important}.form-input-success,.form-select-success,.form-textarea-success{border-color:#4caf50!important;box-shadow:0 0 0 3px rgba(76,175,80,.1)!important}.form-group-sleek{position:relative;margin-bottom:var(--spacing-lg);width:100%;box-sizing:border-box}.form-input-sleek{width:100%;padding:1rem 0 .5rem;font-size:1rem;font-family:var(--font-primary);border:none;border-bottom:2px solid var(--color-border);background:transparent;color:var(--color-text-primary);transition:all .3s ease;outline:none;box-sizing:border-box;min-width:0;overflow:visible}.form-input-sleek:focus{border-bottom-color:var(--color-primary);border-bottom-width:3px}.form-input-sleek.has-value+.form-label-sleek,.form-input-sleek:focus+.form-label-sleek,.form-input-sleek:not(:placeholder-shown)+.form-label-sleek,.form-label-sleek.has-value{transform:translateY(-1.5rem) scale(.85);color:var(--color-primary)}.form-label-sleek{position:absolute;left:0;top:1rem;font-size:1rem;color:var(--color-text-muted);pointer-events:none;transition:all .3s ease;transform-origin:left top;white-space:nowrap;overflow:visible;max-width:100%}.form-input-sleek::placeholder{color:transparent}.form-validation-icon{position:absolute;right:0;top:1rem;width:20px;height:20px;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:opacity .3s ease}.form-validation-icon.valid{color:#4caf50}.form-validation-icon.valid:before{content:"✓";font-size:18px;font-weight:700}.form-validation-icon.invalid{color:#f44336}.form-validation-icon.invalid:before{content:"✕";font-size:18px;font-weight:700}.form-group-sleek.has-error .form-input-sleek{border-bottom-color:#f44336}.form-group-sleek.has-success .form-input-sleek{border-bottom-color:#4caf50}.form-group-sleek.has-error .form-label-sleek{color:#f44336}.form-group-sleek.has-success .form-label-sleek{color:#4caf50}.form-error-message-sleek{color:#c62828;font-size:.875rem;margin-top:.5rem;margin-left:0;display:flex;align-items:center;gap:.25rem;line-height:1.4}.form-error-message-sleek:before{content:"⚠";font-size:.875rem;flex-shrink:0}.form-select-sleek{width:100%;font-size:1rem;font-family:var(--font-primary);border:none;border-bottom:2px solid var(--color-border);background:transparent;color:var(--color-text-primary);transition:all .3s ease;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23483c32' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0 top 50%;padding:1rem 1.5rem .5rem 0}.form-select-sleek:focus{border-bottom-color:var(--color-primary);border-bottom-width:3px}.form-select-sleek.has-value+.form-label-sleek,.form-select-sleek.has-value+.form-label-sleek.has-value,.form-select-sleek:focus+.form-label-sleek,.form-select-sleek:focus+.form-label-sleek.has-value{transform:translateY(-1.5rem) scale(.85);color:var(--color-primary)}.password-reset-link{color:var(--color-primary);font-size:.875rem;text-decoration:none;margin-top:var(--spacing-xs);display:inline-block;transition:color .2s ease}.password-reset-link:hover{color:var(--color-primary-dark);text-decoration:underline}.modal-content{position:relative;background:var(--color-bg-secondary);border-radius:16px;padding:var(--spacing-xl);width:90%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.floating-search-toggle{position:fixed;top:100px;right:var(--spacing-md);z-index:998;width:56px;height:56px;border-radius:50%;background:var(--color-primary-dark);border:2px solid var(--color-accent-gold);color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative}.floating-search-toggle:hover{transform:scale(1.1);box-shadow:0 8px 24px rgba(10,93,97,.3)}.filter-badge{position:absolute;top:-4px;right:-4px;background:#f44336;color:#fff;border-radius:50%;width:20px;height:20px;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.floating-search-panel{position:fixed;top:80px;right:var(--spacing-md);width:380px;max-height:calc(100vh - 120px);z-index:999;opacity:0;transform:translateY(-20px) scale(.95);pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.floating-search-panel.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}.floating-search-content{background:var(--color-bg-secondary);border-radius:12px;padding:var(--spacing-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);max-height:calc(100vh - 120px);overflow-y:auto}.floating-search-content::-webkit-scrollbar{width:6px}.floating-search-content::-webkit-scrollbar-track{background:transparent}.floating-search-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.search-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.close-search-panel{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-muted);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-search-panel:hover{background:var(--color-bg-primary);color:var(--color-text-primary)}.search-panel-overlay{display:none}@media (max-width:768px){.floating-search-toggle{top:auto;bottom:var(--spacing-md);right:var(--spacing-md);width:56px;height:56px}.floating-search-panel{top:auto;bottom:0;right:0;left:0;width:100%;max-height:75vh;transform:translateY(100%);border-radius:0;border-top-left-radius:20px;border-top-right-radius:20px}.floating-search-panel.open{transform:translateY(0)}.floating-search-content{border-radius:0;border-top-left-radius:20px;border-top-right-radius:20px;max-height:75vh;padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + 8px);position:relative}.floating-search-content:before{content:"";position:absolute;top:12px;left:50%;transform:translateX(-50%);width:40px;height:4px;background:var(--color-border);border-radius:2px}.search-panel-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:998;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.form-error-message{color:#c62828;font-size:.875rem;margin-top:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-xs)}.form-error-message:before{content:"⚠";font-size:1rem}.form-success-message{color:#2e7d32;font-size:.875rem;margin-top:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-xs)}.form-success-message:before{content:"✓";font-size:1rem;font-weight:700}.form-char-count{font-size:.75rem;color:var(--color-text-muted);text-align:right;margin-top:var(--spacing-xs)}.form-char-count.warning{color:#ff9800}.form-char-count.error{color:#f44336}@keyframes success-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.success-animation{animation:success-pulse .5s ease-in-out}.toast-container{position:fixed;top:80px;right:var(--spacing-md);z-index:10000;flex-direction:column;max-width:400px;width:calc(100% - 2 * var(--spacing-md))}.toast,.toast-container{display:flex;gap:var(--spacing-sm)}.toast{padding:var(--spacing-md);border-radius:8px;box-shadow:var(--shadow-lg);align-items:center;animation:slideInRight .3s ease-out;border-left:4px solid}.toast-success{background:#f0f9f0;border-color:#4caf50;color:#2e7d32}.toast-error{background:#fff5f5;border-color:#f44336;color:#c62828}.toast-info{background:#e8f5f6;border-color:var(--color-primary);color:var(--color-primary-dark)}@keyframes slideInRight{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px;border-radius:4px}.responsive-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--spacing-md);gap:var(--spacing-md)}@media (max-width:768px){.responsive-grid-2{grid-template-columns:1fr}}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:.25rem;gap:.25rem;margin-bottom:var(--spacing-md)}.calendar-day-header{padding:var(--spacing-xs);text-align:center;font-weight:600;color:var(--color-text-secondary);font-size:.875rem;background:transparent;border-radius:4px}.calendar-day{padding:.25rem;border:none;background:transparent;color:var(--color-text-primary);cursor:pointer;border-radius:6px;min-height:32px;position:relative;transition:all .2s ease;font-size:.8rem}.calendar-day:hover:not(:disabled){background:rgba(13,115,119,.1);color:var(--color-text-primary)}.calendar-day.selected{background:var(--color-primary);color:#fff;font-weight:600}.calendar-day.has-availability{background:rgba(139,69,19,.08)}.calendar-day.has-booking{background:rgba(244,67,54,.05)}.calendar-day.past{background:transparent;color:var(--color-text-muted);cursor:not-allowed;opacity:.5}.calendar-day-empty{min-height:32px}.time-slots-panel{animation:slideUp .3s ease-out}.pricing-package-card{transition:all .2s ease;cursor:pointer}.pricing-package-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.pricing-package-card.selected{border-color:var(--color-primary)!important;background:rgba(13,115,119,.05)!important}.pricing-package-card input[type=radio]{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary)}@media (max-width:768px){.calendar-grid{gap:.2rem}.calendar-day{min-height:28px}.calendar-day,.calendar-day-header{font-size:.7rem;padding:.2rem}.time-slots-panel{padding:var(--spacing-sm)}.time-slots-panel>div[style*=grid-template-columns]{grid-template-columns:1fr!important;gap:var(--spacing-xs)!important}}@media print{.btn,.footer,.modal-overlay,.nav{display:none!important}body{background:#fff;color:#000}.card{box-shadow:none;border:1px solid #ccc}}