index.styl 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. .admin
  2. display: flex
  3. flex-direction: column
  4. min-height: 100vh
  5. background-color: $gray-50
  6. .dark &
  7. background-color: $gray-900
  8. .admin__header
  9. background-color: $white
  10. box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1)
  11. position: sticky
  12. top: 0
  13. z-index: 50
  14. border-bottom: 1px solid $gray-200
  15. .dark &
  16. background-color: $gray-800
  17. border-bottom-color: $gray-700
  18. .admin__header-content
  19. display: flex
  20. align-items: center
  21. justify-content: space-between
  22. padding: 1rem 1.5rem
  23. max-width: 1200px
  24. margin: 0 auto
  25. .admin__brand
  26. display: flex
  27. align-items: center
  28. gap: 0.75rem
  29. .admin__logo
  30. width: 2rem
  31. height: 2rem
  32. object-fit: contain
  33. .admin__company-name
  34. font-size: 1.25rem
  35. font-weight: bold
  36. color: $gray-900
  37. .dark &
  38. color: $white
  39. .admin__domain-info
  40. font-size: 0.875rem
  41. color: $gray-600
  42. background-color: $gray-100
  43. padding: 0.25rem 0.75rem
  44. border-radius: 0.375rem
  45. .dark &
  46. color: $gray-400
  47. background-color: $gray-700
  48. .admin__user-menu
  49. display: flex
  50. align-items: center
  51. gap: 0.5rem
  52. .admin__theme-toggle
  53. padding: 0.5rem
  54. border-radius: 0.375rem
  55. background-color: $gray-100
  56. color: $gray-600
  57. transition: all 0.2s ease-in-out
  58. border: none
  59. cursor: pointer
  60. &:hover
  61. background-color: $gray-200
  62. .dark &
  63. background-color: $gray-700
  64. color: $gray-300
  65. &:hover
  66. background-color: $gray-600
  67. .admin__nav
  68. background-color: $white
  69. box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1)
  70. border-bottom: 1px solid $gray-200
  71. position: sticky
  72. top: 64px
  73. z-index: 40
  74. .dark &
  75. background-color: $gray-800
  76. border-bottom-color: $gray-700
  77. .admin__nav-content
  78. display: flex
  79. gap: 0
  80. overflow-x: auto
  81. padding: 0 1.5rem
  82. max-width: 1200px
  83. margin: 0 auto
  84. &::-webkit-scrollbar
  85. display: none
  86. -ms-overflow-style: none
  87. scrollbar-width: none
  88. .admin__nav-item
  89. display: flex
  90. align-items: center
  91. gap: 0.5rem
  92. padding: 0.75rem 1rem
  93. color: $gray-600
  94. text-decoration: none
  95. transition: all 0.2s ease-in-out
  96. border: none
  97. background: none
  98. cursor: pointer
  99. white-space: nowrap
  100. border-bottom: 2px solid transparent
  101. &:hover
  102. color: $gray-900
  103. background-color: $gray-50
  104. .dark &
  105. color: $white
  106. background-color: $gray-700
  107. .admin__nav-item--active
  108. color: $primary-600
  109. border-bottom-color: $primary-600
  110. background-color: $primary-50
  111. .dark &
  112. color: $primary-400
  113. border-bottom-color: $primary-400
  114. background-color: $primary-900
  115. &:hover
  116. color: $primary-700
  117. background-color: $primary-100
  118. .dark &
  119. color: $primary-300
  120. background-color: $primary-800
  121. .admin__nav-item--inactive
  122. color: $gray-600
  123. .dark &
  124. color: $gray-400
  125. .admin__nav-icon
  126. width: 1.25rem
  127. height: 1.25rem
  128. flex-shrink: 0
  129. .admin__nav-text
  130. font-weight: 500
  131. font-size: 0.875rem
  132. .admin__main
  133. flex: 1
  134. padding: 1.5rem
  135. .admin__content
  136. max-width: 1200px
  137. margin: 0 auto
  138. // Mobile styles
  139. @media (max-width: 768px)
  140. .admin__header-content
  141. padding: 0.75rem 1rem
  142. flex-wrap: wrap
  143. gap: 0.5rem
  144. .admin__brand
  145. order: 1
  146. .admin__domain-info
  147. order: 3
  148. width: 100%
  149. text-align: center
  150. margin-top: 0.5rem
  151. .admin__user-menu
  152. order: 2
  153. .admin__nav-content
  154. padding: 0 1rem
  155. gap: 0
  156. .admin__nav-item
  157. padding: 0.75rem 0.5rem
  158. font-size: 0.875rem
  159. .admin__nav-text
  160. font-size: 0.8rem
  161. .admin__main
  162. padding: 1rem
  163. // Small mobile devices
  164. @media (max-width: 480px)
  165. .admin__company-name
  166. font-size: 1.1rem
  167. .admin__nav-item
  168. padding: 0.5rem 0.25rem
  169. .admin__nav-icon
  170. width: 1rem
  171. height: 1rem
  172. .admin__nav-text
  173. font-size: 0.75rem