*{box-sizing:border-box;margin:0;padding:0;font-family:Times New Roman,Times,serif}body{background:#fff}.grid-container{display:grid;grid-template-rows:auto 1fr auto;background:#fff;min-height:100vh}.header{display:flex;background:#fff;justify-content:center;align-items: center;width:100%;height:60px;padding:0 2rem}.brand{position:absolute;white-space:nowrap;font-size:1.2rem;left:50%;transform:translate(-50%)}.shop{white-space:nowrap;margin-left:auto;margin-right:20vw;font-size:1.2rem}a:link,a:visited,a:hover,a:active{text-decoration:none;color:#000}.logout-btn{cursor:pointer;background:#fff;border:1px solid #333;padding:.5rem 1rem;font-family:Times New Roman,Times,serif;font-size:.9rem}.logout-btn:hover{background:#f5f5f5}.landing{background:#fff;min-height:calc(100vh - 60px - 3rem);padding:1.5rem 2rem 2rem}.collection-title{text-align:center;margin-bottom:1.5rem;font-size:1rem;font-weight:400}.card-row{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;max-width:900px;margin-bottom:2rem;margin-left:auto;margin-right:auto}.divider{display:flex;text-align:center;align-items: center;max-width:900px;margin:1.75rem auto}.divider:before,.divider:after{content:"";border-bottom:1px dashed #333;flex:1}.divider:not(:empty):before{margin-right:.75em}.divider:not(:empty):after{margin-left:.75em}.divider span{font-size:.95rem}.filter-section{display:flex;align-items: flex-start;gap:1rem;max-width:900px;margin:0 auto}.filter-button{cursor:pointer;background:#fff;border:1px solid #333;flex-shrink:0;padding:5px 14px;transition:background .2s;font-family:Times New Roman,Times,serif;font-size:.85rem}.filter-button:hover{background:#f5f5f5}.shop-grid{display:grid;grid-template-columns:repeat(5,1fr);flex:1;gap:.75rem}.shop-card{aspect-ratio:1;display:flex;position:relative;background:#d9d9d9;border:1px solid #c6c6c6;flex-direction:column;justify-content:flex-start;align-items: flex-start;width:100%;padding:.75rem;transition:transform .2s,box-shadow .2s}.shop-card:hover{transform:translateY(-3px);box-shadow:0 3px 10px #0000001f}.shop-card-name{margin-bottom:3px;font-size:.85rem;font-weight:500}.shop-card-badge{margin-bottom:6px;font-size:.6rem;font-weight:600}.shop-card-location{opacity:.8;position:absolute;font-size:.65rem;bottom:.75rem;left:.75rem}@media (max-width:900px){.shop-card{padding:.6rem}.shop-card-name{font-size:.8rem}.shop-card-location{font-size:.6rem}}@media (max-width:600px){.shop-card{padding:.5rem}.shop-card-name{font-size:.75rem}.shop-card-badge,.shop-card-location{font-size:.55rem}}.footer{display:flex;background:#fff;justify-content:flex-start;align-items: center;padding:1rem 2rem}.footer-text{user-select:none;-moz-user-select:none;font-size:1rem;font-weight:500}a:link,a:visited,a:hover,a:active{text-decoration:none;color:#000}.login-container{display:flex;background:#f5f5f5;justify-content:center;align-items: center;min-height:100vh}.login-box{background:#fff;border-radius:8px;width:100%;max-width:400px;padding:3rem;box-shadow:0 2px 10px #0000001a}.login-title{text-align:center;margin-bottom:.5rem;font-size:1.5rem}.login-subtitle{text-align:center;opacity:.7;margin-bottom:2rem;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-input{border:1px solid #ddd;border-radius:4px;padding:.75rem;font-family:Times New Roman,Times,serif;font-size:1rem}.login-button{color:#fff;cursor:pointer;background:#333;border:none;border-radius:4px;padding:.75rem;font-family:Times New Roman,Times,serif;font-size:1rem}.login-button:hover{background:#555}.login-button:disabled{cursor:not-allowed;background:#999}.login-error{color:#d32f2f;text-align:center;font-size:.9rem}.switch-text{text-align:center;margin-top:.5rem;font-size:.9rem}.switch-link{color:#333;text-decoration:underline;cursor:pointer;font-weight:700}.switch-link:hover{color:#555}
