242 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
			
		
		
	
	
			242 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
| @use "../../styles/variables.scss" as *;
 | |
| 
 | |
| .search {
 | |
|   min-width: fit-content;
 | |
|   max-width: 14rem;
 | |
|   @media all and ($mobile) {
 | |
|     flex-grow: 0.3;
 | |
|   }
 | |
| 
 | |
|   & > .search-button {
 | |
|     background-color: transparent;
 | |
|     border: 1px var(--lightgray) solid;
 | |
|     border-radius: 4px;
 | |
|     font-family: inherit;
 | |
|     font-size: inherit;
 | |
|     height: 2rem;
 | |
|     padding: 0 1rem 0 0;
 | |
|     display: flex;
 | |
|     align-items: center;
 | |
|     text-align: inherit;
 | |
|     cursor: pointer;
 | |
|     white-space: nowrap;
 | |
|     width: 100%;
 | |
| 
 | |
|     & > p {
 | |
|       display: inline;
 | |
|       color: var(--gray);
 | |
|     }
 | |
| 
 | |
|     & svg {
 | |
|       cursor: pointer;
 | |
|       width: 18px;
 | |
|       min-width: 18px;
 | |
|       margin: 0 0.5rem;
 | |
| 
 | |
|       .search-path {
 | |
|         stroke: var(--darkgray);
 | |
|         stroke-width: 1.5px;
 | |
|         transition: stroke 0.5s ease;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   & > .search-container {
 | |
|     position: fixed;
 | |
|     contain: layout;
 | |
|     z-index: 999;
 | |
|     left: 0;
 | |
|     top: 0;
 | |
|     width: 100vw;
 | |
|     height: 100vh;
 | |
|     overflow-y: auto;
 | |
|     display: none;
 | |
|     backdrop-filter: blur(4px);
 | |
| 
 | |
|     &.active {
 | |
|       display: inline-block;
 | |
|     }
 | |
| 
 | |
|     & > .search-space {
 | |
|       width: 65%;
 | |
|       margin-top: 12vh;
 | |
|       margin-left: auto;
 | |
|       margin-right: auto;
 | |
| 
 | |
|       @media all and not ($desktop) {
 | |
|         width: 90%;
 | |
|       }
 | |
| 
 | |
|       & > * {
 | |
|         width: 100%;
 | |
|         border-radius: 7px;
 | |
|         background: var(--light);
 | |
|         box-shadow:
 | |
|           0 14px 50px rgba(27, 33, 48, 0.12),
 | |
|           0 10px 30px rgba(27, 33, 48, 0.16);
 | |
|         margin-bottom: 2em;
 | |
|       }
 | |
| 
 | |
|       & > input {
 | |
|         box-sizing: border-box;
 | |
|         padding: 0.5em 1em;
 | |
|         font-family: var(--bodyFont);
 | |
|         color: var(--dark);
 | |
|         font-size: 1.1em;
 | |
|         border: 1px solid var(--lightgray);
 | |
| 
 | |
|         &:focus {
 | |
|           outline: none;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       & > .search-layout {
 | |
|         display: none;
 | |
|         flex-direction: row;
 | |
|         border: 1px solid var(--lightgray);
 | |
|         flex: 0 0 100%;
 | |
|         box-sizing: border-box;
 | |
| 
 | |
|         &.display-results {
 | |
|           display: flex;
 | |
|         }
 | |
| 
 | |
|         &[data-preview] > .results-container {
 | |
|           flex: 0 0 min(30%, 450px);
 | |
|         }
 | |
| 
 | |
|         @media all and not ($mobile) {
 | |
|           &[data-preview] {
 | |
|             & .result-card > p.preview {
 | |
|               display: none;
 | |
|             }
 | |
| 
 | |
|             & > div {
 | |
|               &:first-child {
 | |
|                 border-right: 1px solid var(--lightgray);
 | |
|                 border-top-right-radius: unset;
 | |
|                 border-bottom-right-radius: unset;
 | |
|               }
 | |
| 
 | |
|               &:last-child {
 | |
|                 border-top-left-radius: unset;
 | |
|                 border-bottom-left-radius: unset;
 | |
|               }
 | |
|             }
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         & > div {
 | |
|           height: calc(75vh - 12vh);
 | |
|           border-radius: 5px;
 | |
|         }
 | |
| 
 | |
|         @media all and ($mobile) {
 | |
|           flex-direction: column;
 | |
| 
 | |
|           & > .preview-container {
 | |
|             display: none !important;
 | |
|           }
 | |
| 
 | |
|           &[data-preview] > .results-container {
 | |
|             width: 100%;
 | |
|             height: auto;
 | |
|             flex: 0 0 100%;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         & .highlight {
 | |
|           background: color-mix(in srgb, var(--tertiary) 60%, rgba(255, 255, 255, 0));
 | |
|           border-radius: 5px;
 | |
|           scroll-margin-top: 2rem;
 | |
|         }
 | |
| 
 | |
|         & > .preview-container {
 | |
|           flex-grow: 1;
 | |
|           display: block;
 | |
|           overflow: hidden;
 | |
|           font-family: inherit;
 | |
|           color: var(--dark);
 | |
|           line-height: 1.5em;
 | |
|           font-weight: $normalWeight;
 | |
|           overflow-y: auto;
 | |
|           padding: 0 2rem;
 | |
| 
 | |
|           & .preview-inner {
 | |
|             margin: 0 auto;
 | |
|             width: min($pageWidth, 100%);
 | |
|           }
 | |
| 
 | |
|           a[role="anchor"] {
 | |
|             background-color: transparent;
 | |
|           }
 | |
|         }
 | |
| 
 | |
|         & > .results-container {
 | |
|           overflow-y: auto;
 | |
| 
 | |
|           & .result-card {
 | |
|             overflow: hidden;
 | |
|             padding: 1em;
 | |
|             cursor: pointer;
 | |
|             transition: background 0.2s ease;
 | |
|             border-bottom: 1px solid var(--lightgray);
 | |
|             width: 100%;
 | |
|             display: block;
 | |
|             box-sizing: border-box;
 | |
| 
 | |
|             // normalize card props
 | |
|             font-family: inherit;
 | |
|             font-size: 100%;
 | |
|             line-height: 1.15;
 | |
|             margin: 0;
 | |
|             text-transform: none;
 | |
|             text-align: left;
 | |
|             outline: none;
 | |
|             font-weight: inherit;
 | |
| 
 | |
|             &:hover,
 | |
|             &:focus,
 | |
|             &.focus {
 | |
|               background: var(--lightgray);
 | |
|             }
 | |
| 
 | |
|             & > h3 {
 | |
|               margin: 0;
 | |
|             }
 | |
| 
 | |
|             @media all and not ($mobile) {
 | |
|               & > p.card-description {
 | |
|                 display: none;
 | |
|               }
 | |
|             }
 | |
| 
 | |
|             & > ul.tags {
 | |
|               margin-top: 0.45rem;
 | |
|               margin-bottom: 0;
 | |
|             }
 | |
| 
 | |
|             & > ul > li > p {
 | |
|               border-radius: 8px;
 | |
|               background-color: var(--highlight);
 | |
|               padding: 0.2rem 0.4rem;
 | |
|               margin: 0 0.1rem;
 | |
|               line-height: 1.4rem;
 | |
|               font-weight: $boldWeight;
 | |
|               color: var(--secondary);
 | |
| 
 | |
|               &.match-tag {
 | |
|                 color: var(--tertiary);
 | |
|               }
 | |
|             }
 | |
| 
 | |
|             & > p {
 | |
|               margin-bottom: 0;
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 |