Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

tabs.css

Same filename in this branch
  1. 11.1.x core/profiles/demo_umami/themes/umami/css/components/navigation/tabs/tabs.css
  2. 11.1.x core/profiles/demo_umami/themes/umami/css/components/regions/tabs/tabs.css
  3. 11.1.x core/themes/olivero/css/components/tabs.css
  4. 11.1.x core/themes/starterkit_theme/css/components/tabs.css
/*
 * DO NOT EDIT THIS FILE.
 * See the following change record for more information,
 * https://www.drupal.org/node/3084859
 * @preserve
 */

/**
 * Tabs.
 */

:root {
  /**
  * Tabs.
  */
  --tabs-border-radius-size: var(--base-border-radius);
  --tabs--hover-height: 0.1875rem;
  --tabs--focus-height: 0.1875rem;
  --tabs--active-height: 0.1875rem;
  --tabs-link-height: 3rem; /* 48px */
  --tabs-secondary-link-height: 2.5rem; /* 40px */
  --tabs-base-border: 1px solid var(--color-gray-200);
  --tabs-base-shadow: 0 2px 0.25rem rgba(0, 0, 0, 0.1);
  --tabs-trigger-border: 1px solid rgba(216, 217, 224, 0.8);
  --tabs--hover-bg-color: var(--color-bgblue-active);
}

.tabs-wrapper > nav {
  width: 100%;
}

.tabs {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0 0 var(--space-l) 0;
  border: var(--tabs-base-border);
  border-radius: var(--tabs-border-radius-size);
  box-shadow: var(--tabs-base-shadow);
}

.tabs__tab {
  position: relative;
  border-bottom: var(--tabs-base-border);
  background-color: var(--color-gray-025);
  font-size: var(--font-size-s);
  font-weight: bold;
}

.tabs__tab:not(.is-active) {
  display: none;
}

.tabs__tab:last-child {
  border-bottom: 0;
}

.tabs__tab.is-active {
  display: flex;
  justify-content: space-between;
  background-color: var(--color-white);
  box-shadow: var(--tabs-base-shadow);
}

.tabs__tab.is-active:focus::before {
  top: calc(var(--tabs--focus-height) * -1);
  height: calc(var(--tabs-link-height) + 2px);
}

.tabs__tab.is-active::before {
  z-index: 2;
  top: -1px;
  inset-inline-start: -1px;
  width: var(--tabs--active-height);
  height: calc(100% + 2px);
  border-inline-start: var(--tabs--active-height) solid var(--color-absolutezero);
  border-top-left-radius: var(--tabs-border-radius-size);
}

.tabs__link {
  position: relative;
  display: flex;
  overflow: hidden;
  flex-grow: 1;
  align-items: center;
  box-sizing: border-box;
  min-height: var(--tabs-link-height);
  padding: var(--space-s) var(--space-l);
  -webkit-text-decoration: none;
  text-decoration: none;
  color: var(--color-gray-800);
  line-height: 1.2rem;
}

.tabs__link:focus {
  min-height: calc(var(--tabs-link-height) + var(--tabs--focus-height) - 1px);
  margin: -1px;
  padding-inline-start: calc(var(--space-l) - var(--tabs--focus-height) + 1px);
  -webkit-text-decoration: none;
  text-decoration: none;
  color: var(--color-gray-800);
  border: var(--tabs--focus-height) solid var(--color-focus);
  border-radius: var(--tabs-border-radius-size);
  outline: none;
  box-shadow: none;
}

.tabs__link:hover {
  -webkit-text-decoration: none;
  text-decoration: none;
  color: var(--color-text);
}

.tabs__link.is-active {
  z-index: 1;
  flex-grow: 1;
  color: var(--color-absolutezero);
}

.tabs__link.is-active:focus {
  margin: -1px 0;
  padding-right: var(--space-l);
  padding-left: var(--space-l);
  border-inline-start: none;
  border-radius: 0;
}

.tabs__link.is-active:hover {
  color: var(--color-text);
}

.tabs__link:not(.is-active):focus {
  z-index: 3;
}

/* Active and hover indicator. */

.tabs__tab::before,
.tabs__link::before {
  position: absolute;
  display: block;
  content: "";
}

.tabs.is-open .tabs__tab.is-active::before {
  border-bottom-left-radius: 0;
}

.tabs--secondary .tabs__tab:not(.is-active) {
  display: block;
}

.tabs.is-open > .tabs__tab {
  display: flex;
}

.tabs__trigger {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: var(--tabs-link-height);
  padding-right: 1px;
  text-align: center;
  border-inline-start: var(--tabs-trigger-border);
}

.tabs__trigger:focus {
  padding-right: 0;
  border: var(--tabs--focus-height) solid var(--color-focus);
  border-radius: var(--tabs-border-radius-size);
  box-shadow: none;
}

@media screen and (min-width: 48em) {
  .tabs-wrapper {
    display: flex;
  }

  .tabs-wrapper--secondary {
    position: relative;
  }
  .is-horizontal .tabs {
    flex-direction: row;
    align-items: flex-end;
    width: auto;
    margin: 0;
    border: 0;
    box-shadow: none;
  }
  .is-horizontal .tabs--secondary {
    overflow: hidden;
    margin: calc(calc(var(--tabs--focus-height) + 0.1875rem) * -1) calc(calc(var(--tabs--focus-height) + 0.1875rem) * -1) 0;
    padding: calc(var(--tabs--focus-height) + 0.1875rem) calc(var(--tabs--focus-height) + 0.1875rem) 0;
    border-radius: 0;
  }
  .is-horizontal .tabs--secondary::after {
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    content: "";
    border-bottom: 1px solid var(--color-gray-200);
  }
  .is-horizontal .tabs--secondary .tabs__tab {
    font-size: var(--font-size-s);
  }
  .is-horizontal .tabs--secondary .tabs__link {
    min-height: var(--tabs-secondary-link-height);
    padding-top: var(--space-xs);
    padding-bottom: var(--space-xs);
  }
  .is-horizontal .tabs--secondary .tabs__link:focus {
    min-height: var(--tabs-secondary-link-height);
  }
  .is-horizontal .tabs__tab {
    display: block;
    border-top: none;
    border-bottom: none;
    background: none;
    font-size: var(--font-size-base);
  }
  .is-horizontal .tabs__tab.is-active {
    order: 0;
    background: none;
    box-shadow: none;
  }
  .is-horizontal .tabs__tab.is-active::before {
    content: none;
  }
  .is-horizontal .tabs__tab .tabs__link.is-active::before {
    border-radius: 0;
  }
  .is-horizontal .tabs__link {
    padding-right: 2rem;
    padding-left: 2rem;
    border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  }
  .is-horizontal .tabs__link:focus {
    min-height: var(--tabs-link-height);
    margin: 0;
    padding-right: 2rem;
    padding-left: 2rem;
    color: var(--color-text);
    border: none;
    border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
    outline: 2px dotted transparent;
    box-shadow:
      0 0 0 2px var(--color-white),
      0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  }
  .is-horizontal .tabs__link:hover {
    color: var(--color-absolutezero-hover);
    background: var(--tabs--hover-bg-color);
  }
  .is-horizontal .tabs__link.is-active::before {
    top: auto;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: var(--tabs--active-height);
    border-right: none;
    border-bottom: var(--tabs--active-height) solid var(--color-absolutezero);
    border-left: none;
  }
  .is-horizontal .tabs__trigger {
    display: none;
  }
  .is-horizontal .tabs--primary .tabs__link:focus {
    box-shadow:
      0 0 0 2px var(--color-gray-050),
      0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  }
}

File

core/themes/claro/css/components/tabs.css

View source
  1. /*
  2. * DO NOT EDIT THIS FILE.
  3. * See the following change record for more information,
  4. * https://www.drupal.org/node/3084859
  5. * @preserve
  6. */
  7. /**
  8. * Tabs.
  9. */
  10. :root {
  11. /**
  12. * Tabs.
  13. */
  14. --tabs-border-radius-size: var(--base-border-radius);
  15. --tabs--hover-height: 0.1875rem;
  16. --tabs--focus-height: 0.1875rem;
  17. --tabs--active-height: 0.1875rem;
  18. --tabs-link-height: 3rem; /* 48px */
  19. --tabs-secondary-link-height: 2.5rem; /* 40px */
  20. --tabs-base-border: 1px solid var(--color-gray-200);
  21. --tabs-base-shadow: 0 2px 0.25rem rgba(0, 0, 0, 0.1);
  22. --tabs-trigger-border: 1px solid rgba(216, 217, 224, 0.8);
  23. --tabs--hover-bg-color: var(--color-bgblue-active);
  24. }
  25. .tabs-wrapper > nav {
  26. width: 100%;
  27. }
  28. .tabs {
  29. display: flex;
  30. flex-direction: column;
  31. width: 100%;
  32. margin: 0 0 var(--space-l) 0;
  33. border: var(--tabs-base-border);
  34. border-radius: var(--tabs-border-radius-size);
  35. box-shadow: var(--tabs-base-shadow);
  36. }
  37. .tabs__tab {
  38. position: relative;
  39. border-bottom: var(--tabs-base-border);
  40. background-color: var(--color-gray-025);
  41. font-size: var(--font-size-s);
  42. font-weight: bold;
  43. }
  44. .tabs__tab:not(.is-active) {
  45. display: none;
  46. }
  47. .tabs__tab:last-child {
  48. border-bottom: 0;
  49. }
  50. .tabs__tab.is-active {
  51. display: flex;
  52. justify-content: space-between;
  53. background-color: var(--color-white);
  54. box-shadow: var(--tabs-base-shadow);
  55. }
  56. .tabs__tab.is-active:focus::before {
  57. top: calc(var(--tabs--focus-height) * -1);
  58. height: calc(var(--tabs-link-height) + 2px);
  59. }
  60. .tabs__tab.is-active::before {
  61. z-index: 2;
  62. top: -1px;
  63. inset-inline-start: -1px;
  64. width: var(--tabs--active-height);
  65. height: calc(100% + 2px);
  66. border-inline-start: var(--tabs--active-height) solid var(--color-absolutezero);
  67. border-top-left-radius: var(--tabs-border-radius-size);
  68. }
  69. .tabs__link {
  70. position: relative;
  71. display: flex;
  72. overflow: hidden;
  73. flex-grow: 1;
  74. align-items: center;
  75. box-sizing: border-box;
  76. min-height: var(--tabs-link-height);
  77. padding: var(--space-s) var(--space-l);
  78. -webkit-text-decoration: none;
  79. text-decoration: none;
  80. color: var(--color-gray-800);
  81. line-height: 1.2rem;
  82. }
  83. .tabs__link:focus {
  84. min-height: calc(var(--tabs-link-height) + var(--tabs--focus-height) - 1px);
  85. margin: -1px;
  86. padding-inline-start: calc(var(--space-l) - var(--tabs--focus-height) + 1px);
  87. -webkit-text-decoration: none;
  88. text-decoration: none;
  89. color: var(--color-gray-800);
  90. border: var(--tabs--focus-height) solid var(--color-focus);
  91. border-radius: var(--tabs-border-radius-size);
  92. outline: none;
  93. box-shadow: none;
  94. }
  95. .tabs__link:hover {
  96. -webkit-text-decoration: none;
  97. text-decoration: none;
  98. color: var(--color-text);
  99. }
  100. .tabs__link.is-active {
  101. z-index: 1;
  102. flex-grow: 1;
  103. color: var(--color-absolutezero);
  104. }
  105. .tabs__link.is-active:focus {
  106. margin: -1px 0;
  107. padding-right: var(--space-l);
  108. padding-left: var(--space-l);
  109. border-inline-start: none;
  110. border-radius: 0;
  111. }
  112. .tabs__link.is-active:hover {
  113. color: var(--color-text);
  114. }
  115. .tabs__link:not(.is-active):focus {
  116. z-index: 3;
  117. }
  118. /* Active and hover indicator. */
  119. .tabs__tab::before,
  120. .tabs__link::before {
  121. position: absolute;
  122. display: block;
  123. content: "";
  124. }
  125. .tabs.is-open .tabs__tab.is-active::before {
  126. border-bottom-left-radius: 0;
  127. }
  128. .tabs--secondary .tabs__tab:not(.is-active) {
  129. display: block;
  130. }
  131. .tabs.is-open > .tabs__tab {
  132. display: flex;
  133. }
  134. .tabs__trigger {
  135. display: flex;
  136. flex-shrink: 0;
  137. align-items: center;
  138. justify-content: center;
  139. width: var(--tabs-link-height);
  140. padding-right: 1px;
  141. text-align: center;
  142. border-inline-start: var(--tabs-trigger-border);
  143. }
  144. .tabs__trigger:focus {
  145. padding-right: 0;
  146. border: var(--tabs--focus-height) solid var(--color-focus);
  147. border-radius: var(--tabs-border-radius-size);
  148. box-shadow: none;
  149. }
  150. @media screen and (min-width: 48em) {
  151. .tabs-wrapper {
  152. display: flex;
  153. }
  154. .tabs-wrapper--secondary {
  155. position: relative;
  156. }
  157. .is-horizontal .tabs {
  158. flex-direction: row;
  159. align-items: flex-end;
  160. width: auto;
  161. margin: 0;
  162. border: 0;
  163. box-shadow: none;
  164. }
  165. .is-horizontal .tabs--secondary {
  166. overflow: hidden;
  167. margin: calc(calc(var(--tabs--focus-height) + 0.1875rem) * -1) calc(calc(var(--tabs--focus-height) + 0.1875rem) * -1) 0;
  168. padding: calc(var(--tabs--focus-height) + 0.1875rem) calc(var(--tabs--focus-height) + 0.1875rem) 0;
  169. border-radius: 0;
  170. }
  171. .is-horizontal .tabs--secondary::after {
  172. position: absolute;
  173. bottom: 0;
  174. left: 0;
  175. display: block;
  176. width: 100%;
  177. content: "";
  178. border-bottom: 1px solid var(--color-gray-200);
  179. }
  180. .is-horizontal .tabs--secondary .tabs__tab {
  181. font-size: var(--font-size-s);
  182. }
  183. .is-horizontal .tabs--secondary .tabs__link {
  184. min-height: var(--tabs-secondary-link-height);
  185. padding-top: var(--space-xs);
  186. padding-bottom: var(--space-xs);
  187. }
  188. .is-horizontal .tabs--secondary .tabs__link:focus {
  189. min-height: var(--tabs-secondary-link-height);
  190. }
  191. .is-horizontal .tabs__tab {
  192. display: block;
  193. border-top: none;
  194. border-bottom: none;
  195. background: none;
  196. font-size: var(--font-size-base);
  197. }
  198. .is-horizontal .tabs__tab.is-active {
  199. order: 0;
  200. background: none;
  201. box-shadow: none;
  202. }
  203. .is-horizontal .tabs__tab.is-active::before {
  204. content: none;
  205. }
  206. .is-horizontal .tabs__tab .tabs__link.is-active::before {
  207. border-radius: 0;
  208. }
  209. .is-horizontal .tabs__link {
  210. padding-right: 2rem;
  211. padding-left: 2rem;
  212. border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  213. }
  214. .is-horizontal .tabs__link:focus {
  215. min-height: var(--tabs-link-height);
  216. margin: 0;
  217. padding-right: 2rem;
  218. padding-left: 2rem;
  219. color: var(--color-text);
  220. border: none;
  221. border-radius: var(--tabs-border-radius-size) var(--tabs-border-radius-size) 0 0;
  222. outline: 2px dotted transparent;
  223. box-shadow:
  224. 0 0 0 2px var(--color-white),
  225. 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  226. }
  227. .is-horizontal .tabs__link:hover {
  228. color: var(--color-absolutezero-hover);
  229. background: var(--tabs--hover-bg-color);
  230. }
  231. .is-horizontal .tabs__link.is-active::before {
  232. top: auto;
  233. right: 0;
  234. bottom: 0;
  235. left: 0;
  236. width: 100%;
  237. height: var(--tabs--active-height);
  238. border-right: none;
  239. border-bottom: var(--tabs--active-height) solid var(--color-absolutezero);
  240. border-left: none;
  241. }
  242. .is-horizontal .tabs__trigger {
  243. display: none;
  244. }
  245. .is-horizontal .tabs--primary .tabs__link:focus {
  246. box-shadow:
  247. 0 0 0 2px var(--color-gray-050),
  248. 0 0 0 calc(var(--tabs--focus-height) + 2px) var(--color-focus);
  249. }
  250. }
RSS feed
Powered by Drupal