theme.less 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. //
  2. // Load core variables and mixins
  3. // --------------------------------------------------
  4. @import "variables.less";
  5. @import "mixins.less";
  6. //
  7. // Buttons
  8. // --------------------------------------------------
  9. // Common styles
  10. .btn-default,
  11. .btn-primary,
  12. .btn-success,
  13. .btn-info,
  14. .btn-warning,
  15. .btn-danger {
  16. text-shadow: 0 -1px 0 rgba(0,0,0,.2);
  17. @shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 1px rgba(0,0,0,.075);
  18. .box-shadow(@shadow);
  19. // Reset the shadow
  20. &:active,
  21. &.active {
  22. .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
  23. }
  24. }
  25. // Mixin for generating new styles
  26. .btn-styles(@btn-color: #555;) {
  27. #gradient > .vertical(@start-color: @btn-color; @end-color: darken(@btn-color, 10%));
  28. border-color: darken(@btn-color, 12%);
  29. &:active,
  30. &.active {
  31. background-color: darken(@btn-color, 10%);
  32. border-color: darken(@btn-color, 12%);
  33. }
  34. }
  35. // Common styles
  36. .btn {
  37. // Remove the gradient for the pressed/active state
  38. &:active,
  39. &.active {
  40. background-image: none;
  41. }
  42. }
  43. // Apply the mixin to the buttons
  44. .btn-default { .btn-styles(@btn-default-bg;); text-shadow: 0 1px 0 #fff; border-color: #ccc; }
  45. .btn-primary { .btn-styles(@btn-primary-bg); }
  46. .btn-success { .btn-styles(@btn-success-bg); }
  47. .btn-warning { .btn-styles(@btn-warning-bg); }
  48. .btn-danger { .btn-styles(@btn-danger-bg); }
  49. .btn-info { .btn-styles(@btn-info-bg); }
  50. //
  51. // Images
  52. // --------------------------------------------------
  53. .thumbnail,
  54. .img-thumbnail {
  55. .box-shadow(0 1px 2px rgba(0,0,0,.075));
  56. }
  57. //
  58. // Dropdowns
  59. // --------------------------------------------------
  60. .dropdown-menu > li > a:hover,
  61. .dropdown-menu > li > a:focus,
  62. .dropdown-menu > .active > a,
  63. .dropdown-menu > .active > a:hover,
  64. .dropdown-menu > .active > a:focus {
  65. #gradient > .vertical(@start-color: @dropdown-link-hover-bg; @end-color: darken(@dropdown-link-hover-bg, 5%));
  66. background-color: darken(@dropdown-link-hover-bg, 5%);
  67. }
  68. //
  69. // Navbar
  70. // --------------------------------------------------
  71. // Basic navbar
  72. .navbar {
  73. #gradient > .vertical(@start-color: lighten(@navbar-default-bg, 10%); @end-color: @navbar-default-bg;);
  74. border-radius: @navbar-border-radius;
  75. @shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 5px rgba(0,0,0,.075);
  76. .box-shadow(@shadow);
  77. .navbar-nav > .active > a {
  78. background-color: @navbar-default-bg;
  79. }
  80. }
  81. .navbar-brand,
  82. .navbar-nav > li > a {
  83. text-shadow: 0 1px 0 rgba(255,255,255,.25);
  84. }
  85. // Inverted navbar
  86. .navbar-inverse {
  87. #gradient > .vertical(@start-color: lighten(@navbar-inverse-bg, 10%); @end-color: @navbar-inverse-bg;);
  88. .navbar-nav > .active > a {
  89. background-color: @navbar-inverse-bg;
  90. }
  91. .navbar-brand,
  92. .navbar-nav > li > a {
  93. text-shadow: 0 -1px 0 rgba(0,0,0,.25);
  94. }
  95. }
  96. // Undo rounded corners in static and fixed navbars
  97. .navbar-static-top,
  98. .navbar-fixed-top,
  99. .navbar-fixed-bottom {
  100. border-radius: 0;
  101. }
  102. //
  103. // Alerts
  104. // --------------------------------------------------
  105. // Common styles
  106. .alert {
  107. text-shadow: 0 1px 0 rgba(255,255,255,.2);
  108. @shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 1px 2px rgba(0,0,0,.05);
  109. .box-shadow(@shadow);
  110. }
  111. // Mixin for generating new styles
  112. .alert-styles(@color) {
  113. #gradient > .vertical(@start-color: @color; @end-color: darken(@color, 7.5%));
  114. border-color: darken(@color, 15%);
  115. }
  116. // Apply the mixin to the alerts
  117. .alert-success { .alert-styles(@alert-success-bg); }
  118. .alert-info { .alert-styles(@alert-info-bg); }
  119. .alert-warning { .alert-styles(@alert-warning-bg); }
  120. .alert-danger { .alert-styles(@alert-danger-bg); }
  121. //
  122. // Progress bars
  123. // --------------------------------------------------
  124. // Give the progress background some depth
  125. .progress {
  126. #gradient > .vertical(@start-color: darken(@progress-bg, 4%); @end-color: @progress-bg;)
  127. }
  128. // Mixin for generating new styles
  129. .progress-bar-styles(@color) {
  130. #gradient > .vertical(@start-color: @color; @end-color: darken(@color, 10%));
  131. }
  132. // Apply the mixin to the progress bars
  133. .progress-bar { .progress-bar-styles(@progress-bar-bg); }
  134. .progress-bar-success { .progress-bar-styles(@progress-bar-success-bg); }
  135. .progress-bar-info { .progress-bar-styles(@progress-bar-info-bg); }
  136. .progress-bar-warning { .progress-bar-styles(@progress-bar-warning-bg); }
  137. .progress-bar-danger { .progress-bar-styles(@progress-bar-danger-bg); }
  138. //
  139. // List groups
  140. // --------------------------------------------------
  141. .list-group {
  142. border-radius: @border-radius-base;
  143. .box-shadow(0 1px 2px rgba(0,0,0,.075));
  144. }
  145. .list-group-item.active,
  146. .list-group-item.active:hover,
  147. .list-group-item.active:focus {
  148. text-shadow: 0 -1px 0 darken(@list-group-active-bg, 10%);
  149. #gradient > .vertical(@start-color: @list-group-active-bg; @end-color: darken(@list-group-active-bg, 7.5%));
  150. border-color: darken(@list-group-active-border, 7.5%);
  151. }
  152. //
  153. // Panels
  154. // --------------------------------------------------
  155. // Common styles
  156. .panel {
  157. .box-shadow(0 1px 2px rgba(0,0,0,.05));
  158. }
  159. // Mixin for generating new styles
  160. .panel-heading-styles(@color) {
  161. #gradient > .vertical(@start-color: @color; @end-color: darken(@color, 5%));
  162. }
  163. // Apply the mixin to the panel headings only
  164. .panel-default > .panel-heading { .panel-heading-styles(@panel-default-heading-bg); }
  165. .panel-primary > .panel-heading { .panel-heading-styles(@panel-primary-heading-bg); }
  166. .panel-success > .panel-heading { .panel-heading-styles(@panel-success-heading-bg); }
  167. .panel-info > .panel-heading { .panel-heading-styles(@panel-info-heading-bg); }
  168. .panel-warning > .panel-heading { .panel-heading-styles(@panel-warning-heading-bg); }
  169. .panel-danger > .panel-heading { .panel-heading-styles(@panel-danger-heading-bg); }
  170. //
  171. // Wells
  172. // --------------------------------------------------
  173. .well {
  174. #gradient > .vertical(@start-color: darken(@well-bg, 5%); @end-color: @well-bg;);
  175. border-color: darken(@well-bg, 10%);
  176. @shadow: inset 0 1px 3px rgba(0,0,0,.05), 0 1px 0 rgba(255,255,255,.1);
  177. .box-shadow(@shadow);
  178. }