heart 0.0.1.pre

Sign up to get free protection for your applications and to get access to all the features.
Files changed (358) hide show
  1. data/MIT-LICENSE +21 -0
  2. data/README.rdoc +3 -0
  3. data/Rakefile +40 -0
  4. data/app/assets/images/heart/add.png +0 -0
  5. data/app/assets/images/heart/bluestar.png +0 -0
  6. data/app/assets/images/heart/bricks.png +0 -0
  7. data/app/assets/images/heart/bricks_off.png +0 -0
  8. data/app/assets/images/heart/chart_bar.png +0 -0
  9. data/app/assets/images/heart/chart_bar_off.png +0 -0
  10. data/app/assets/images/heart/chart_curve.png +0 -0
  11. data/app/assets/images/heart/chart_curve_off.png +0 -0
  12. data/app/assets/images/heart/chart_line.png +0 -0
  13. data/app/assets/images/heart/chart_line_off.png +0 -0
  14. data/app/assets/images/heart/chart_pie.png +0 -0
  15. data/app/assets/images/heart/chart_pie_off.png +0 -0
  16. data/app/assets/images/heart/collapse.png +0 -0
  17. data/app/assets/images/heart/dashboard.png +0 -0
  18. data/app/assets/images/heart/delete.png +0 -0
  19. data/app/assets/images/heart/disk.png +0 -0
  20. data/app/assets/images/heart/expand.png +0 -0
  21. data/app/assets/images/heart/jp.png +0 -0
  22. data/app/assets/images/heart/page_white_excel.png +0 -0
  23. data/app/assets/images/heart/paintcan.png +0 -0
  24. data/app/assets/images/heart/paintcan_off.png +0 -0
  25. data/app/assets/images/heart/pencil.png +0 -0
  26. data/app/assets/images/heart/picture.png +0 -0
  27. data/app/assets/images/heart/table.png +0 -0
  28. data/app/assets/images/heart/tag.png +0 -0
  29. data/app/assets/images/heart/tooltip/columnBg.png +0 -0
  30. data/app/assets/images/heart/tooltip/columnTop.gif +0 -0
  31. data/app/assets/images/heart/tooltip/tipBtm.png +0 -0
  32. data/app/assets/images/heart/tooltip/tipBtm280.png +0 -0
  33. data/app/assets/images/heart/tooltip/tipBtm280b.png +0 -0
  34. data/app/assets/images/heart/tooltip/tipMid.png +0 -0
  35. data/app/assets/images/heart/tooltip/tipMid280.png +0 -0
  36. data/app/assets/images/heart/tooltip/tipMid280b.png +0 -0
  37. data/app/assets/images/heart/tooltip/tipMid280g.png +0 -0
  38. data/app/assets/images/heart/tooltip/tipMid280w.png +0 -0
  39. data/app/assets/images/heart/tooltip/tipTop.png +0 -0
  40. data/app/assets/images/heart/tooltip/tipTop280.png +0 -0
  41. data/app/assets/images/heart/tooltip/tipTop280b.png +0 -0
  42. data/app/assets/images/heart/us.png +0 -0
  43. data/app/assets/images/heart/zoom.png +0 -0
  44. data/app/assets/images/heart/zoom_off.png +0 -0
  45. data/app/assets/javascripts/heart/application.js +201 -0
  46. data/app/assets/javascripts/heart/flot/jquery.colorhelpers.min.js +1 -0
  47. data/app/assets/javascripts/heart/flot/jquery.flot.annotate.js +136 -0
  48. data/app/assets/javascripts/heart/flot/jquery.flot.crosshair.min.js +1 -0
  49. data/app/assets/javascripts/heart/flot/jquery.flot.fillbetween.js +183 -0
  50. data/app/assets/javascripts/heart/flot/jquery.flot.growing.js +140 -0
  51. data/app/assets/javascripts/heart/flot/jquery.flot.js +2651 -0
  52. data/app/assets/javascripts/heart/flot/jquery.flot.navigate.js +336 -0
  53. data/app/assets/javascripts/heart/flot/jquery.flot.pie.js +751 -0
  54. data/app/assets/javascripts/heart/flot/jquery.flot.resize.js +60 -0
  55. data/app/assets/javascripts/heart/flot/jquery.flot.selection.min.js +1 -0
  56. data/app/assets/javascripts/heart/flot/jquery.flot.stack.min.js +1 -0
  57. data/app/assets/javascripts/heart/flot/jquery.flot.symbols.js +85 -0
  58. data/app/assets/javascripts/heart/flot/jquery.flot.threshold.min.js +1 -0
  59. data/app/assets/javascripts/heart/heart.js +664 -0
  60. data/app/assets/javascripts/heart/jquery-1-5-2.js +16 -0
  61. data/app/assets/javascripts/heart/jquery-ui-1.8.7.custom.min.js +781 -0
  62. data/app/assets/javascripts/heart/jquery.betterTooltip.js +108 -0
  63. data/app/assets/javascripts/heart/json2.js +480 -0
  64. data/app/assets/stylesheets/heart/application.css +13 -0
  65. data/app/assets/stylesheets/heart/bluetrip/css/ie.css +29 -0
  66. data/app/assets/stylesheets/heart/bluetrip/css/print.css +46 -0
  67. data/app/assets/stylesheets/heart/bluetrip/css/screen.css +321 -0
  68. data/app/assets/stylesheets/heart/bluetrip/images/grid.png +0 -0
  69. data/app/assets/stylesheets/heart/bluetrip/images/grid.psd +0 -0
  70. data/app/assets/stylesheets/heart/bluetrip/images/icons/cross.png +0 -0
  71. data/app/assets/stylesheets/heart/bluetrip/images/icons/doc.png +0 -0
  72. data/app/assets/stylesheets/heart/bluetrip/images/icons/email.png +0 -0
  73. data/app/assets/stylesheets/heart/bluetrip/images/icons/external.png +0 -0
  74. data/app/assets/stylesheets/heart/bluetrip/images/icons/feed.png +0 -0
  75. data/app/assets/stylesheets/heart/bluetrip/images/icons/im.png +0 -0
  76. data/app/assets/stylesheets/heart/bluetrip/images/icons/information.png +0 -0
  77. data/app/assets/stylesheets/heart/bluetrip/images/icons/key.png +0 -0
  78. data/app/assets/stylesheets/heart/bluetrip/images/icons/pdf.png +0 -0
  79. data/app/assets/stylesheets/heart/bluetrip/images/icons/tick.png +0 -0
  80. data/app/assets/stylesheets/heart/bluetrip/images/icons/visited.png +0 -0
  81. data/app/assets/stylesheets/heart/bluetrip/images/icons/xls.png +0 -0
  82. data/app/assets/stylesheets/heart/bluetrip/images/test-small.jpg +0 -0
  83. data/app/assets/stylesheets/heart/buttons.css +821 -0
  84. data/app/assets/stylesheets/heart/heart.css.erb +480 -0
  85. data/app/assets/stylesheets/heart/start/images/ui-bg_flat_55_999999_40x100.png +0 -0
  86. data/app/assets/stylesheets/heart/start/images/ui-bg_flat_75_aaaaaa_40x100.png +0 -0
  87. data/app/assets/stylesheets/heart/start/images/ui-bg_glass_45_0078ae_1x400.png +0 -0
  88. data/app/assets/stylesheets/heart/start/images/ui-bg_glass_55_f8da4e_1x400.png +0 -0
  89. data/app/assets/stylesheets/heart/start/images/ui-bg_glass_75_79c9ec_1x400.png +0 -0
  90. data/app/assets/stylesheets/heart/start/images/ui-bg_gloss-wave_45_e14f1c_500x100.png +0 -0
  91. data/app/assets/stylesheets/heart/start/images/ui-bg_gloss-wave_50_6eac2c_500x100.png +0 -0
  92. data/app/assets/stylesheets/heart/start/images/ui-bg_gloss-wave_75_2191c0_500x100.png +0 -0
  93. data/app/assets/stylesheets/heart/start/images/ui-bg_inset-hard_100_fcfdfd_1x100.png +0 -0
  94. data/app/assets/stylesheets/heart/start/images/ui-icons_0078ae_256x240.png +0 -0
  95. data/app/assets/stylesheets/heart/start/images/ui-icons_056b93_256x240.png +0 -0
  96. data/app/assets/stylesheets/heart/start/images/ui-icons_d8e7f3_256x240.png +0 -0
  97. data/app/assets/stylesheets/heart/start/images/ui-icons_e0fdff_256x240.png +0 -0
  98. data/app/assets/stylesheets/heart/start/images/ui-icons_f5e175_256x240.png +0 -0
  99. data/app/assets/stylesheets/heart/start/images/ui-icons_f7a50d_256x240.png +0 -0
  100. data/app/assets/stylesheets/heart/start/images/ui-icons_fcd113_256x240.png +0 -0
  101. data/app/assets/stylesheets/heart/start/jquery-ui-1.8.7.custom.css +572 -0
  102. data/app/controllers/heart/annotations_controller.rb +22 -0
  103. data/app/controllers/heart/application_controller.rb +21 -0
  104. data/app/controllers/heart/dashboards_controller.rb +85 -0
  105. data/app/controllers/heart/images_controller.rb +19 -0
  106. data/app/controllers/heart/metrics_controller.rb +35 -0
  107. data/app/helpers/heart/application_helper.rb +13 -0
  108. data/app/helpers/heart/dashboards_helper.rb +106 -0
  109. data/app/models/heart/annotation.rb +19 -0
  110. data/app/models/heart/application.rb +5 -0
  111. data/app/models/heart/dashboard.rb +6 -0
  112. data/app/models/heart/image.rb +5 -0
  113. data/app/models/heart/isometric.rb +8 -0
  114. data/app/models/heart/metric.rb +138 -0
  115. data/app/views/heart/annotations/create.js.haml +1 -0
  116. data/app/views/heart/annotations/description.js.haml +2 -0
  117. data/app/views/heart/dashboards/_annotation.haml +13 -0
  118. data/app/views/heart/dashboards/_dashblock.haml +17 -0
  119. data/app/views/heart/dashboards/_dashboard_form.html.haml +89 -0
  120. data/app/views/heart/dashboards/_graph_options.html.haml +24 -0
  121. data/app/views/heart/dashboards/_heart_form.html.haml +100 -0
  122. data/app/views/heart/dashboards/default.html.haml +32 -0
  123. data/app/views/heart/dashboards/edit.html.haml +14 -0
  124. data/app/views/heart/dashboards/flotit.js.haml +6 -0
  125. data/app/views/heart/dashboards/index.html.haml +19 -0
  126. data/app/views/heart/dashboards/new.html.haml +3 -0
  127. data/app/views/heart/dashboards/show.html.haml +65 -0
  128. data/app/views/heart/metrics/cache.html.haml +3 -0
  129. data/app/views/heart/metrics/fetch.html.haml +2 -0
  130. data/app/views/heart/metrics/index.html.haml +12 -0
  131. data/app/views/heart/metrics/show.html.haml +25 -0
  132. data/app/views/layouts/heart_engine.html.haml +88 -0
  133. data/config/cucumber.yml +8 -0
  134. data/config/locales/en.yml +63 -0
  135. data/config/locales/ja.yml +63 -0
  136. data/config/routes.rb +25 -0
  137. data/db/migrate/20130902050854_create_heart_metrics.rb +16 -0
  138. data/db/migrate/20130902051427_create_heart_isometrics.rb +9 -0
  139. data/db/migrate/20130902080256_create_heart_dashboards.rb +13 -0
  140. data/db/migrate/20130902080823_create_heart_annotations.rb +10 -0
  141. data/db/migrate/20130902081206_create_heart_images.rb +11 -0
  142. data/lib/heart/engine.rb +22 -0
  143. data/lib/heart/version.rb +3 -0
  144. data/lib/heart.rb +4 -0
  145. data/lib/tasks/cucumber.rake +65 -0
  146. data/lib/tasks/heart_tasks.rake +85 -0
  147. data/test/dummy/README.rdoc +261 -0
  148. data/test/dummy/Rakefile +7 -0
  149. data/test/dummy/app/assets/javascripts/application.js +15 -0
  150. data/test/dummy/app/assets/stylesheets/application.css +13 -0
  151. data/test/dummy/app/controllers/application_controller.rb +3 -0
  152. data/test/dummy/app/helpers/application_helper.rb +2 -0
  153. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  154. data/test/dummy/config/application.rb +59 -0
  155. data/test/dummy/config/boot.rb +10 -0
  156. data/test/dummy/config/database.yml +21 -0
  157. data/test/dummy/config/environment.rb +5 -0
  158. data/test/dummy/config/environments/development.rb +37 -0
  159. data/test/dummy/config/environments/production.rb +67 -0
  160. data/test/dummy/config/environments/test.rb +37 -0
  161. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  162. data/test/dummy/config/initializers/inflections.rb +15 -0
  163. data/test/dummy/config/initializers/mime_types.rb +5 -0
  164. data/test/dummy/config/initializers/secret_token.rb +7 -0
  165. data/test/dummy/config/initializers/session_store.rb +8 -0
  166. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  167. data/test/dummy/config/locales/en.yml +5 -0
  168. data/test/dummy/config/routes.rb +4 -0
  169. data/test/dummy/config.ru +4 -0
  170. data/test/dummy/db/development.sqlite3 +0 -0
  171. data/test/dummy/db/migrate/20130902083555_create_heart_metrics.heart.rb +17 -0
  172. data/test/dummy/db/migrate/20130902083556_create_heart_isometrics.heart.rb +10 -0
  173. data/test/dummy/db/migrate/20130902083557_create_heart_dashboards.heart.rb +14 -0
  174. data/test/dummy/db/migrate/20130902083558_create_heart_annotations.heart.rb +11 -0
  175. data/test/dummy/db/migrate/20130902083559_create_heart_images.heart.rb +12 -0
  176. data/test/dummy/db/migrate/20130902083560_create_heart_configurations.heart.rb +12 -0
  177. data/test/dummy/db/migrate/20130902084029_add_posts_new_to_metrics.rb +10 -0
  178. data/test/dummy/db/schema.rb +76 -0
  179. data/test/dummy/db/test.sqlite3 +0 -0
  180. data/test/dummy/features/dashboards/overview.feature +39 -0
  181. data/test/dummy/features/language_switching.feature +12 -0
  182. data/test/dummy/features/link_to_this.feature +6 -0
  183. data/test/dummy/features/metrics/exporting.feature +13 -0
  184. data/test/dummy/features/metrics/fetching.feature +0 -0
  185. data/test/dummy/features/metrics/graphing.feature +13 -0
  186. data/test/dummy/features/metrics/summing.feature +0 -0
  187. data/test/dummy/features/step_definitions/dashboard_steps.rb +76 -0
  188. data/test/dummy/features/step_definitions/exporting_steps.rb +24 -0
  189. data/test/dummy/features/step_definitions/generic_steps.rb.example +101 -0
  190. data/test/dummy/features/step_definitions/graphing_steps.rb +37 -0
  191. data/test/dummy/features/step_definitions/language_switching_steps.rb +26 -0
  192. data/test/dummy/features/step_definitions/link_to_steps.rb +12 -0
  193. data/test/dummy/features/support/env.rb +64 -0
  194. data/test/dummy/features/support/factories.rb +16 -0
  195. data/test/dummy/features/support/hooks.rb +3 -0
  196. data/test/dummy/features/support/world_extensions.rb +1 -0
  197. data/test/dummy/log/development.log +549 -0
  198. data/test/dummy/log/test.log +19866 -0
  199. data/test/dummy/public/404.html +26 -0
  200. data/test/dummy/public/422.html +26 -0
  201. data/test/dummy/public/500.html +25 -0
  202. data/test/dummy/public/favicon.ico +0 -0
  203. data/test/dummy/script/rails +6 -0
  204. data/test/dummy/tmp/cache/assets/B7A/D60/sprockets%2F12305388866122331aea456101382236 +0 -0
  205. data/test/dummy/tmp/cache/assets/BE3/050/sprockets%2F0421426926cdd29806245aa078142462 +0 -0
  206. data/test/dummy/tmp/cache/assets/C3E/2A0/sprockets%2Fe37f35746618667d995a3587734e1f14 +0 -0
  207. data/test/dummy/tmp/cache/assets/C4F/0C0/sprockets%2Fb0695bc459d01217161ae9028368b856 +0 -0
  208. data/test/dummy/tmp/cache/assets/C57/200/sprockets%2F2e442476c863f14144881e259b1b597a +0 -0
  209. data/test/dummy/tmp/cache/assets/C61/A80/sprockets%2F7f20dd76170d803754a3085694f669e6 +0 -0
  210. data/test/dummy/tmp/cache/assets/C6B/710/sprockets%2F61a084f53ca308b115c54491f5b38120 +0 -0
  211. data/test/dummy/tmp/cache/assets/C76/680/sprockets%2Fb72c325230e403c89a229efd94013438 +0 -0
  212. data/test/dummy/tmp/cache/assets/C7D/AD0/sprockets%2Fa702e8b86f4697101583ea24307b7a53 +0 -0
  213. data/test/dummy/tmp/cache/assets/C81/4B0/sprockets%2F115a9d464b8720982880ad4926aaf505 +0 -0
  214. data/test/dummy/tmp/cache/assets/C83/670/sprockets%2F125f9496da25b06ace8951e752253273 +0 -0
  215. data/test/dummy/tmp/cache/assets/C86/DC0/sprockets%2F26269d2349fba3c41619fe3e88363044 +0 -0
  216. data/test/dummy/tmp/cache/assets/CA6/170/sprockets%2F6e0bb6a54c8f40c3419b183772c73331 +0 -0
  217. data/test/dummy/tmp/cache/assets/CAF/B10/sprockets%2F68ee8201881a1c1d3d987490e5015ed0 +0 -0
  218. data/test/dummy/tmp/cache/assets/CB6/080/sprockets%2F735f5d59ce0703357780bf4a574490ca +0 -0
  219. data/test/dummy/tmp/cache/assets/CB6/490/sprockets%2Fc4b6a866f5d3627d2a186e2095e60717 +0 -0
  220. data/test/dummy/tmp/cache/assets/CB9/9E0/sprockets%2F7a20a269f11f7331c8a56908c68f18d9 +0 -0
  221. data/test/dummy/tmp/cache/assets/CBB/950/sprockets%2F575827e14ba8d9920284eae267874ca1 +0 -0
  222. data/test/dummy/tmp/cache/assets/CBE/3A0/sprockets%2F73bdae55823e56e6f3796265941b36d1 +0 -0
  223. data/test/dummy/tmp/cache/assets/CC2/A70/sprockets%2F99163775fcea80cf5530f8808188e40b +0 -0
  224. data/test/dummy/tmp/cache/assets/CCB/970/sprockets%2F472690f680dd7d91690ebf603f7685e8 +0 -0
  225. data/test/dummy/tmp/cache/assets/CCB/CA0/sprockets%2F9b705933be3255cfd4938a9c99146e69 +0 -0
  226. data/test/dummy/tmp/cache/assets/CCF/FE0/sprockets%2Fea0015147c89d0181ba9460464bbf08c +0 -0
  227. data/test/dummy/tmp/cache/assets/CD1/1C0/sprockets%2F675a331d19ae21eaa532b27aa7606955 +0 -0
  228. data/test/dummy/tmp/cache/assets/CD1/320/sprockets%2Fb09e869800e3e0a0d7805d4c1c7113d1 +0 -0
  229. data/test/dummy/tmp/cache/assets/CD5/1C0/sprockets%2F9a8012934e9d2f70a66c43310e3e44ab +0 -0
  230. data/test/dummy/tmp/cache/assets/CD7/270/sprockets%2F3bc51cb676bca1416770598d28109fa0 +0 -0
  231. data/test/dummy/tmp/cache/assets/CE0/E50/sprockets%2F9814922a41a67b828e462b31accb38f8 +0 -0
  232. data/test/dummy/tmp/cache/assets/CE3/A70/sprockets%2F87a37405e84d5a30dd672cf6148ec119 +0 -0
  233. data/test/dummy/tmp/cache/assets/CE4/050/sprockets%2F21d0ae6e0a782753af4ed2492e959671 +0 -0
  234. data/test/dummy/tmp/cache/assets/CE4/D80/sprockets%2Fa98448b0f9e10bf393a552d26664d7a3 +0 -0
  235. data/test/dummy/tmp/cache/assets/CE7/F80/sprockets%2F7715072387d4d8e6193c2ffda13a375f +0 -0
  236. data/test/dummy/tmp/cache/assets/CE8/890/sprockets%2F394187006c387afef0429558db43bf4e +0 -0
  237. data/test/dummy/tmp/cache/assets/CE8/CE0/sprockets%2F5c698abb053124d9a5421666bf75c8f8 +0 -0
  238. data/test/dummy/tmp/cache/assets/CF1/7B0/sprockets%2Fa447299b5fa19244e6a281825f9e77dc +0 -0
  239. data/test/dummy/tmp/cache/assets/CF1/CD0/sprockets%2Fd06db0e7d91462ed5ea64694583797e2 +0 -0
  240. data/test/dummy/tmp/cache/assets/CF2/070/sprockets%2Fca7b20d93194b5827d9d57837578b6db +0 -0
  241. data/test/dummy/tmp/cache/assets/CF2/C20/sprockets%2F7b5779909f4f5440c9d0874af23d63db +0 -0
  242. data/test/dummy/tmp/cache/assets/CF4/B20/sprockets%2F604291e761acf24ffb2998f369b176e8 +0 -0
  243. data/test/dummy/tmp/cache/assets/CF6/220/sprockets%2F06bd95eb7a76f96eb2d8c54782607745 +0 -0
  244. data/test/dummy/tmp/cache/assets/CFD/E70/sprockets%2F6cb7d8f69c8c4e1f246868d46f017639 +0 -0
  245. data/test/dummy/tmp/cache/assets/D00/5C0/sprockets%2F9abbd043d031592a556306748dbaeb26 +0 -0
  246. data/test/dummy/tmp/cache/assets/D02/000/sprockets%2F842565584accd26c5572aa1d15b3bb35 +0 -0
  247. data/test/dummy/tmp/cache/assets/D02/7C0/sprockets%2Fa4900a35834e0ab16a2ae17b6887a66d +0 -0
  248. data/test/dummy/tmp/cache/assets/D04/920/sprockets%2F5830c0ccdb2a54d7848283d21f44e2a4 +0 -0
  249. data/test/dummy/tmp/cache/assets/D05/FC0/sprockets%2Fd06631201fe7c8760eea1e3ffd351191 +0 -0
  250. data/test/dummy/tmp/cache/assets/D06/8C0/sprockets%2Faae533655b6c51d0b999ce29015c4c03 +0 -0
  251. data/test/dummy/tmp/cache/assets/D0B/350/sprockets%2F58255cc783163fa49e6caa32e01af293 +0 -0
  252. data/test/dummy/tmp/cache/assets/D0E/560/sprockets%2Ffb853b302b8b8338911fd212f3e9d65a +0 -0
  253. data/test/dummy/tmp/cache/assets/D0F/340/sprockets%2F81d96cf056d0ab1856c588f181b21fe0 +0 -0
  254. data/test/dummy/tmp/cache/assets/D18/460/sprockets%2Fb0145de92306b4c1bedc53aa0030e522 +0 -0
  255. data/test/dummy/tmp/cache/assets/D19/710/sprockets%2F90db64737e5b2ef37757b1cc2e52909d +0 -0
  256. data/test/dummy/tmp/cache/assets/D1C/270/sprockets%2F1475adbe1d4ec03f947d379865d477b3 +0 -0
  257. data/test/dummy/tmp/cache/assets/D27/770/sprockets%2Fa10a1cef30d33ecec13933b36280c548 +0 -0
  258. data/test/dummy/tmp/cache/assets/D27/7B0/sprockets%2F6401357b67027ace91aae0cbcf5e4021 +0 -0
  259. data/test/dummy/tmp/cache/assets/D2B/700/sprockets%2Fe90d34a411e79a9d1b510ae04c80e04e +0 -0
  260. data/test/dummy/tmp/cache/assets/D34/100/sprockets%2F504aeb3e34faa21a7c9fa726264934d3 +0 -0
  261. data/test/dummy/tmp/cache/assets/D35/560/sprockets%2Fa79fc4b2a2293acaa002547e93d9704e +0 -0
  262. data/test/dummy/tmp/cache/assets/D35/F80/sprockets%2Ffb91b5a46525f11e9f6658a0daa005d4 +0 -0
  263. data/test/dummy/tmp/cache/assets/D38/A70/sprockets%2F56d65a0db0739f5f1a215bde93528f0a +0 -0
  264. data/test/dummy/tmp/cache/assets/D3A/A50/sprockets%2F1edbcb279564b5c4a85c13aa6940b279 +0 -0
  265. data/test/dummy/tmp/cache/assets/D3B/A10/sprockets%2F2cecd599ad2374ea47112715ae70ea49 +0 -0
  266. data/test/dummy/tmp/cache/assets/D3B/CF0/sprockets%2F4cac58b5d3abf581ca5857583017d3e1 +0 -0
  267. data/test/dummy/tmp/cache/assets/D3B/EF0/sprockets%2F996d2466d00c1bacc4351f87e2d5e62a +0 -0
  268. data/test/dummy/tmp/cache/assets/D3E/410/sprockets%2F4d2270e9821b7d9658df04c4adbdf214 +0 -0
  269. data/test/dummy/tmp/cache/assets/D43/FC0/sprockets%2F7f972ba9de00917d116bfc1c7126e8d6 +0 -0
  270. data/test/dummy/tmp/cache/assets/D4A/E50/sprockets%2Fa876a03aed98118f76cac6e916ff5423 +0 -0
  271. data/test/dummy/tmp/cache/assets/D4B/310/sprockets%2F3402fd809cbee959fdb8db9950a37342 +0 -0
  272. data/test/dummy/tmp/cache/assets/D4C/E60/sprockets%2Fcd389726cc723176e5547ac75cc3fbc8 +0 -0
  273. data/test/dummy/tmp/cache/assets/D52/590/sprockets%2Fae4195e4fc883e26b828d9c7b525ff42 +0 -0
  274. data/test/dummy/tmp/cache/assets/D52/730/sprockets%2Fd92d03a100128cafe40eb231c3c77ba9 +0 -0
  275. data/test/dummy/tmp/cache/assets/D53/4E0/sprockets%2F6b5c3667b962d3740c9de6a5b9bfc948 +0 -0
  276. data/test/dummy/tmp/cache/assets/D59/B40/sprockets%2F29c73ae2b2a2dcf81b5210703eeed252 +0 -0
  277. data/test/dummy/tmp/cache/assets/D5A/5F0/sprockets%2Fa03a93be0c8545371de91a5cab10fe52 +0 -0
  278. data/test/dummy/tmp/cache/assets/D5D/820/sprockets%2F60c2f35af5ce8dc4ab2a724043fd0373 +0 -0
  279. data/test/dummy/tmp/cache/assets/D5D/C10/sprockets%2Fa56376015a3d663ddeb1c90e3faa901b +0 -0
  280. data/test/dummy/tmp/cache/assets/D5E/030/sprockets%2Fb709d4ed36a3b17b21a42a66ae0098fb +0 -0
  281. data/test/dummy/tmp/cache/assets/D5F/6D0/sprockets%2Ff1f0426663c9048eceaa032dc3f05b5c +0 -0
  282. data/test/dummy/tmp/cache/assets/D64/540/sprockets%2F8b24e4230a33d44ed39d3d4ca015f7ff +0 -0
  283. data/test/dummy/tmp/cache/assets/D66/7D0/sprockets%2F6d2be390800b01686b6aeb7bba686c7b +0 -0
  284. data/test/dummy/tmp/cache/assets/D68/7F0/sprockets%2F35b0c94f2372250feee3c76a8bad07d4 +0 -0
  285. data/test/dummy/tmp/cache/assets/D69/F50/sprockets%2F0fe620b4cef107c5b770d70c5bbe6839 +0 -0
  286. data/test/dummy/tmp/cache/assets/D6A/630/sprockets%2F0e159a9bce743e35c180d0eceac52487 +0 -0
  287. data/test/dummy/tmp/cache/assets/D6F/120/sprockets%2F09730b5eed71a1971eb1ed85f0cd8c28 +0 -0
  288. data/test/dummy/tmp/cache/assets/D73/5A0/sprockets%2F726af59d1d3774cebabf5011f2a9955f +0 -0
  289. data/test/dummy/tmp/cache/assets/D76/410/sprockets%2F3ba75e6fe03df5d227c7e7a54be98720 +0 -0
  290. data/test/dummy/tmp/cache/assets/D76/750/sprockets%2F4422ff4ebec16419ef79a9a9d3f530f0 +0 -0
  291. data/test/dummy/tmp/cache/assets/D78/460/sprockets%2Ff8b234b2bfb694b85d927c693aba7d54 +0 -0
  292. data/test/dummy/tmp/cache/assets/D79/4F0/sprockets%2F0323ebeae0a56602aa023c9bb268b3ab +0 -0
  293. data/test/dummy/tmp/cache/assets/D7B/AF0/sprockets%2Fe1e0818c824997cffe5e04f2bff31e26 +0 -0
  294. data/test/dummy/tmp/cache/assets/D94/590/sprockets%2F95f6b48a4415cb3ab8acc4e0da36750d +0 -0
  295. data/test/dummy/tmp/cache/assets/D99/890/sprockets%2F783e81abd4c0cf96b0642acde9b7202f +0 -0
  296. data/test/dummy/tmp/cache/assets/D9A/FB0/sprockets%2F4bd1e3c2f82a72a0d6f8935ed92aeb60 +0 -0
  297. data/test/dummy/tmp/cache/assets/D9E/A00/sprockets%2Fdb6bd6ed1be390eb760409309a6d79ad +0 -0
  298. data/test/dummy/tmp/cache/assets/D9F/6D0/sprockets%2F6da6b2d77e0c546c69a3bb1720f9b9cd +0 -0
  299. data/test/dummy/tmp/cache/assets/DA1/050/sprockets%2F082944b24f4e6533ce0ce9fa64fadf5b +0 -0
  300. data/test/dummy/tmp/cache/assets/DA5/3B0/sprockets%2Fc5e9c4c0d3563ae2b49bf7cd67f458b1 +0 -0
  301. data/test/dummy/tmp/cache/assets/DAA/300/sprockets%2Ff4ebcefbb66ce3f58d70987c6123523e +0 -0
  302. data/test/dummy/tmp/cache/assets/DB1/C10/sprockets%2Fddabb257ba3637433fc7729f79fe6c9e +0 -0
  303. data/test/dummy/tmp/cache/assets/DB1/C90/sprockets%2Fdf909d50d7a568a1bc9dd9e47baf4973 +0 -0
  304. data/test/dummy/tmp/cache/assets/DB9/800/sprockets%2Fbd0a2a66976fd5ef12be3ac3e22d100e +0 -0
  305. data/test/dummy/tmp/cache/assets/DC2/1D0/sprockets%2F548c5a2d07c2b3db2eea9a24e2e25c9c +0 -0
  306. data/test/dummy/tmp/cache/assets/DC3/C30/sprockets%2F45d3db961ffaa14a7acb04d139f3ae93 +0 -0
  307. data/test/dummy/tmp/cache/assets/DC8/180/sprockets%2F44add687b1c02f2afd55b3dc9d58a04f +0 -0
  308. data/test/dummy/tmp/cache/assets/DCB/0A0/sprockets%2Ffec15e165ae6e45fe4d36b903fccf103 +0 -0
  309. data/test/dummy/tmp/cache/assets/DCC/6C0/sprockets%2F1dd6adb3594e3cf84ce35ea45114ead9 +0 -0
  310. data/test/dummy/tmp/cache/assets/DCD/350/sprockets%2F0a1ad87bab5ab47f377d5f87736acdd2 +0 -0
  311. data/test/dummy/tmp/cache/assets/DCD/ED0/sprockets%2Fe3e1abc488563aa8c2d44c9b8b5b2f6c +0 -0
  312. data/test/dummy/tmp/cache/assets/DD1/620/sprockets%2F3c34c92afb93cab6ab8f1640683ee8fd +0 -0
  313. data/test/dummy/tmp/cache/assets/DD2/2B0/sprockets%2Fcb959dcb42fe971fef3b07705a4de60b +0 -0
  314. data/test/dummy/tmp/cache/assets/DD4/DB0/sprockets%2Fd16e7fa5788cebf2c0335cfb5a94d5b5 +0 -0
  315. data/test/dummy/tmp/cache/assets/DDA/140/sprockets%2F9dab37c1f47e99ba86bf306fbed67c23 +0 -0
  316. data/test/dummy/tmp/cache/assets/DF0/C50/sprockets%2Fc3dee69afa21d4462d0fda717c2f5a1b +0 -0
  317. data/test/dummy/tmp/cache/assets/DF3/CE0/sprockets%2Fd413b4fcbf2a3afe3a2f96fb3b22349f +0 -0
  318. data/test/dummy/tmp/cache/assets/DF5/020/sprockets%2Ffdbfbdaa7be9bc2fa2824455b9f36200 +0 -0
  319. data/test/dummy/tmp/cache/assets/DFB/120/sprockets%2F56abeace37f20e8ed908bb19c26c73ca +0 -0
  320. data/test/dummy/tmp/cache/assets/DFE/9D0/sprockets%2Fdfd5d12ea923dd88dd2fb5c56c2a6a73 +0 -0
  321. data/test/dummy/tmp/cache/assets/E04/670/sprockets%2Fe9e9c736dab1268ea76aed2ba1cf51f9 +0 -0
  322. data/test/dummy/tmp/cache/assets/E11/620/sprockets%2Fb79efcee1bf9f7559d26cc36bcbd6481 +0 -0
  323. data/test/dummy/tmp/cache/assets/E15/B10/sprockets%2F8fded28e5dfea96f7f42212ee4de8d82 +0 -0
  324. data/test/dummy/tmp/cache/assets/E1E/A70/sprockets%2F4a6f52c1cf40efaf040aabe5eca74c86 +0 -0
  325. data/test/dummy/tmp/cache/assets/E2F/B60/sprockets%2F9e9f03eab43fa8aeeb4aa97f1dff2171 +0 -0
  326. data/test/dummy/tmp/cache/assets/E3E/D60/sprockets%2F51bfcacbab0f9acbbcd331e31e095c40 +0 -0
  327. data/test/dummy/tmp/cache/assets/E4E/FE0/sprockets%2Fee2cecebeb842cdbbcfc530d13d50546 +0 -0
  328. data/test/dummy/tmp/cache/assets/E50/170/sprockets%2Faa1cd6441f82b0f9bfa1baffe5ce3c81 +0 -0
  329. data/test/dummy/tmp/cache/assets/E54/7B0/sprockets%2F7eba769afbacdcd2b019e3ae52fdb093 +0 -0
  330. data/test/dummy/tmp/cache/assets/E6C/5E0/sprockets%2F48dce5eee43c4ec8f9daa25a7fb847be +0 -0
  331. data/test/dummy/tmp/cache/assets/E86/5D0/sprockets%2Fec1c00efc9e5ebfa6c0576eb1ddfd60d +0 -0
  332. data/test/dummy/tmp/cache/assets/E8A/510/sprockets%2F4dcf2d4f6fbfe6af61adafbed37240a8 +0 -0
  333. data/test/dummy/tmp/cache/assets/E91/E50/sprockets%2F6caf6f973c4dfd0a94ca97da0cbfb8da +0 -0
  334. data/test/dummy/tmp/cache/assets/F0C/2E0/sprockets%2Fbcad47aa7a1eda0cc0fdc3eac6cb99fd +0 -0
  335. data/test/fixtures/heart/annotations.yml +11 -0
  336. data/test/fixtures/heart/configurations.yml +11 -0
  337. data/test/fixtures/heart/dashboards.yml +11 -0
  338. data/test/fixtures/heart/images.yml +11 -0
  339. data/test/fixtures/heart/isometrics.yml +11 -0
  340. data/test/fixtures/heart/metrics.yml +11 -0
  341. data/test/functional/heart/annotations_controller_test.rb +9 -0
  342. data/test/functional/heart/dashboards_controller_test.rb +9 -0
  343. data/test/functional/heart/images_controller_test.rb +9 -0
  344. data/test/functional/heart/metrics_controller_test.rb +9 -0
  345. data/test/heart_test.rb +7 -0
  346. data/test/integration/navigation_test.rb +10 -0
  347. data/test/test_helper.rb +15 -0
  348. data/test/unit/heart/annotation_test.rb +9 -0
  349. data/test/unit/heart/configuration_test.rb +9 -0
  350. data/test/unit/heart/dashboard_test.rb +9 -0
  351. data/test/unit/heart/image_test.rb +9 -0
  352. data/test/unit/heart/isometric_test.rb +9 -0
  353. data/test/unit/heart/metric_test.rb +9 -0
  354. data/test/unit/helpers/heart/annotations_helper_test.rb +6 -0
  355. data/test/unit/helpers/heart/dashboards_helper_test.rb +6 -0
  356. data/test/unit/helpers/heart/images_helper_test.rb +6 -0
  357. data/test/unit/helpers/heart/metrics_helper_test.rb +6 -0
  358. metadata +791 -0
@@ -0,0 +1,821 @@
1
+ /*
2
+ http://ubuwaits.github.com/css3-buttons/
3
+ Copyright (c) 2011 Chad Mazzola
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
22
+ */
23
+
24
+
25
+ /* general styles */
26
+ body {
27
+ text-rendering: optimizeLegibility;
28
+ }
29
+
30
+ button:hover {
31
+ cursor: pointer;
32
+ }
33
+
34
+ a::-moz-focus-inner, button::-moz-focus-inner {
35
+ border:0;
36
+ }
37
+
38
+ /* minimal
39
+ *******************************************************************************/
40
+ button.minimal {
41
+ background: #e3e3e3;
42
+ border: 1px solid #bbb;
43
+ -moz-border-radius: 3px;
44
+ -webkit-border-radius: 3px;
45
+ border-radius: 3px;
46
+ -moz-box-shadow: inset 0 0 1px 1px #f6f6f6;
47
+ -webkit-box-shadow: inset 0 0 1px 1px #f6f6f6;
48
+ box-shadow: inset 0 0 1px 1px #f6f6f6;
49
+ color: #333;
50
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
51
+ font-size: 12px;
52
+ font-weight: bold;
53
+ line-height: 1;
54
+ padding: 8px 0 9px;
55
+ text-align: center;
56
+ text-shadow: 0 1px 0 #fff;
57
+ width: 150px;
58
+ }
59
+
60
+ button.minimal:hover {
61
+ background: #d9d9d9;
62
+ -moz-box-shadow: inset 0 0 1px 1px #eaeaea;
63
+ -webkit-box-shadow: inset 0 0 1px 1px #eaeaea;
64
+ box-shadow: inset 0 0 1px 1px #eaeaea;
65
+ color: #222;
66
+ cursor: pointer;
67
+ }
68
+
69
+ button.minimal:active {
70
+ background: #d0d0d0;
71
+ -moz-box-shadow: inset 0 0 1px 1px #e3e3e3;
72
+ -webkit-box-shadow: inset 0 0 1px 1px #e3e3e3;
73
+ box-shadow: inset 0 0 1px 1px #e3e3e3;
74
+ color: #000;
75
+ }
76
+
77
+ /* clean gray
78
+ *******************************************************************************/
79
+ button.clean-gray {
80
+ background: #eee;
81
+ background: -moz-linear-gradient(top, #eee 0%, #ccc 100%);
82
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#eee), to(#ccc));
83
+ border: 1px solid #ccc;
84
+ border-bottom: 1px solid #bbb;
85
+ -moz-border-radius: 3px;
86
+ -webkit-border-radius: 3px;
87
+ border-radius: 3px;
88
+ color: #333;
89
+ font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Verdana, sans-serif;
90
+ font-size: 11px;
91
+ font-weight: bold;
92
+ line-height: 1;
93
+ padding: 8px 0;
94
+ text-align: center;
95
+ text-shadow: 0 1px 0 #eee;
96
+ width: 150px;
97
+ }
98
+
99
+ button.clean-gray:hover {
100
+ background: #ddd;
101
+ background: -moz-linear-gradient(top, #ddd 0%, #bbb 100%);
102
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#ddd), to(#bbb));
103
+ border: 1px solid #bbb;
104
+ border-bottom: 1px solid #999;
105
+ cursor: pointer;
106
+ text-shadow: 0 1px 0 #ddd;
107
+ }
108
+
109
+ button.clean-gray:active {
110
+ border: 1px solid #aaa;
111
+ border-bottom: 1px solid #888;
112
+ -moz-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
113
+ -webkit-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
114
+ box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
115
+ }
116
+
117
+ /* cupid green (inspired by okcupid.com)
118
+ *******************************************************************************/
119
+ button.cupid-green {
120
+ background: #7fbf4d;
121
+ background: -moz-linear-gradient(top, #7fbf4d 0%, #63a62f 100%);
122
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#7fbf4d), to(#63a62f));
123
+ border: 1px solid #63a62f;
124
+ border-bottom: 1px solid #5b992b;
125
+ -moz-border-radius: 3px;
126
+ -webkit-border-radius: 3px;
127
+ border-radius: 3px;
128
+ -moz-box-shadow: inset 0 1px 0 0 #96ca6d;
129
+ -webkit-box-shadow: inset 0 1px 0 0 #96ca6d;
130
+ box-shadow: inset 0 1px 0 0 #96ca6d;
131
+ color: #fff;
132
+ font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Verdana, sans-serif;
133
+ font-size: 11px;
134
+ font-weight: bold;
135
+ line-height: 1;
136
+ padding: 7px 0 8px 0;
137
+ text-align: center;
138
+ text-shadow: 0 -1px 0 #4c9021;
139
+ width: 150px;
140
+ }
141
+
142
+ button.cupid-green:hover {
143
+ background: #76b347;
144
+ background: -moz-linear-gradient(top, #76b347 0%, #5e9e2e 100%);
145
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#76b347), to(#5e9e2e));
146
+ -moz-box-shadow: inset 0 1px 0 0 #8dbf67;
147
+ -webkit-box-shadow: inset 0 1px 0 0 #8dbf67;
148
+ box-shadow: inset 0 1px 0 0 #8dbf67;
149
+ cursor: pointer;
150
+ }
151
+
152
+ button.cupid-green:active {
153
+ border: 1px solid #5b992b;
154
+ border-bottom: 1px solid #538c27;
155
+ -moz-box-shadow: inset 0 0 8px 4px #548c29, 0 1px 0 0 #eee;
156
+ -webkit-box-shadow: inset 0 0 8px 4px #548c29, 0 1px 0 0 #eee;
157
+ box-shadow: inset 0 0 8px 4px #548c29, 0 1px 0 0 #eee;
158
+ }
159
+
160
+ /* cupid blue (inspired by okcupid.com)
161
+ *******************************************************************************/
162
+ button.cupid-blue {
163
+ background: #d7e5f5;
164
+ background: -moz-linear-gradient(top, #d7e5f5 0%, #cbe0f5 100%);
165
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#d7e5f5), to(#cbe0f5));
166
+ border-top: 1px solid #abbbcc;
167
+ border-left: 1px solid #a7b6c7;
168
+ border-bottom: 1px solid #a1afbf;
169
+ border-right: 1px solid #a7b6c7;
170
+ -moz-border-radius: 12px;
171
+ -webkit-border-radius: 12px;
172
+ border-radius: 12px;
173
+ -moz-box-shadow: inset 0 1px 0 0 #fff;
174
+ -webkit-box-shadow: inset 0 1px 0 0 #fff;
175
+ box-shadow: inset 0 1px 0 0 #fff;
176
+ color: #1a3e66;
177
+ font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Verdana, sans-serif;
178
+ font-size: 11px;
179
+ font-weight: normal;
180
+ line-height: 1;
181
+ padding: 6px 0 7px 0;
182
+ text-align: center;
183
+ text-shadow: 0 1px 1px #fff;
184
+ width: 150px;
185
+ }
186
+
187
+ button.cupid-blue:hover {
188
+ background: #ccd9e8;
189
+ background: -moz-linear-gradient(top, #ccd9e8 0%, #c1d4e8 100%);
190
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#ccd9e8), to(#c1d4e8));
191
+ border-top: 1px solid #a1afbf;
192
+ border-left: 1px solid #9caaba;
193
+ border-bottom: 1px solid #96a3b3;
194
+ border-right: 1px solid #9caaba;
195
+ -moz-box-shadow: inset 0 1px 0 0 #f2f2f2;
196
+ -webkit-box-shadow: inset 0 1px 0 0 #f2f2f2;
197
+ box-shadow: inset 0 1px 0 0 #f2f2f2;
198
+ color: #163659;
199
+ cursor: pointer;
200
+ }
201
+
202
+ button.cupid-blue:active {
203
+ border: 1px solid #8c98a7;
204
+ -moz-box-shadow: inset 0 0 4px 2px #abbccf, 0 0 1px 0 #eee;
205
+ -webkit-box-shadow: inset 0 0 4px 2px #abbccf, 0 0 1px 0 #eee;
206
+ box-shadow: inset 0 0 4px 2px #abbccf, 0 0 1px 0 #eee;
207
+ }
208
+
209
+ /* blue pill (inspired by iTunes)
210
+ As of 19 Sep 2010 there is a bug in Chrome/Win affecting this button:
211
+ http://code.google.com/p/chromium/issues/detail?id=29427
212
+ *******************************************************************************/
213
+ button.blue-pill {
214
+ background: #a5b8da;
215
+ background: -moz-linear-gradient(top, #a5b8da 0%, #7089b3 100%);
216
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#a5b8da), to(#7089b3));
217
+ border-top: 1px solid #758fba;
218
+ border-right: 1px solid #6c84ab;
219
+ border-bottom: 1px solid #5c6f91;
220
+ border-left: 1px solid #6c84ab;
221
+ -moz-border-radius: 18px;
222
+ -webkit-border-radius: 18px;
223
+ border-radius: 18px;
224
+ -moz-box-shadow: inset 0 1px 0 0 #aec3e5;
225
+ -webkit-box-shadow: inset 0 1px 0 0 #aec3e5;
226
+ box-shadow: inset 0 1px 0 0 #aec3e5;
227
+ color: #fff;
228
+ font-family: "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Verdana, sans-serif;
229
+ font-size: 11px;
230
+ font-weight: bold;
231
+ line-height: 1;
232
+ padding: 8px 0 8px 0;
233
+ text-align: center;
234
+ text-shadow: 0 -1px 1px #64799e;
235
+ text-transform: uppercase;
236
+ width: 150px;
237
+ }
238
+
239
+ button.blue-pill:hover {
240
+ background: #9badcc;
241
+ background: -moz-linear-gradient(top, #9badcc 0%, #687fa6 100%);
242
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#9badcc), to(#687fa6));
243
+ border-top: 1px solid #6d86ad;
244
+ border-right: 1px solid #647a9e;
245
+ border-bottom: 1px solid #546685;
246
+ border-left: 1px solid #647a9e;
247
+ -moz-box-shadow: inset 0 1px 0 0 #a5b9d9;
248
+ -webkit-box-shadow: inset 0 1px 0 0 #a5b9d9;
249
+ box-shadow: inset 0 1px 0 0 #a5b9d9;
250
+ cursor: pointer;
251
+ }
252
+
253
+ button.blue-pill:active {
254
+ border: 1px solid #546685;
255
+ -moz-box-shadow: inset 0 0 8px 2px #7e8da6, 0 1px 0 0 #eee;
256
+ -webkit-box-shadow: inset 0 0 8px 2px #7e8da6, 0 1px 0 0 #eee;
257
+ box-shadow: inset 0 0 8px 2px #7e8da6, 0 1px 0 0 #eee;
258
+ }
259
+
260
+ /* dribbble (inspired by dribbble.com)
261
+ *******************************************************************************/
262
+ button.dribbble {
263
+ background: #F26895;
264
+ background: -moz-linear-gradient(top, #F26895 0, #F26895 50%, #F15587 50%, #F15587 100%);
265
+ background: -webkit-gradient(linear, 0% 50%, 0% 51%, from(#F26895), to(#F15587));
266
+ border: 0;
267
+ -moz-border-radius: 6px;
268
+ -webkit-border-radius: 6px;
269
+ border-radius: 6px;
270
+ color: #fcfcfc;
271
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
272
+ font-size: 16px;
273
+ font-weight: bold;
274
+ line-height: 1;
275
+ padding: 10px 0 12px 0;
276
+ text-align: center;
277
+ text-shadow: 0px -1px 1px #a64767;
278
+ width: 150px;
279
+ }
280
+
281
+ button.dribbble:hover {
282
+ background: #e2558b;
283
+ background: -moz-linear-gradient(top, #e2558b 0, #e2558b 50%, #df3e7b 50%, #df3e7b 100%);
284
+ background: -webkit-gradient(linear, 0% 50%, 0% 51%, from(#e2558b), to(#df3e7b));
285
+ cursor: pointer;
286
+ }
287
+
288
+ button.dribbble:active {
289
+ background: #c94477;
290
+ background: -moz-linear-gradient(top, #c94477 0, #c94477 50%, #c22b65 50%, #c22b65 100%);
291
+ background: -webkit-gradient(linear, 0% 50%, 0% 51%, from(#c94477), to(#c22b65));
292
+ }
293
+
294
+ /* slick black
295
+ *******************************************************************************/
296
+ button.slick-black {
297
+ background: #111;
298
+ background: -moz-linear-gradient(top,
299
+ rgba(50, 50, 50, 0.9) 0%,
300
+ rgba(30, 30, 30, 0.9) 50%,
301
+ rgba(20, 20, 20, 0.9) 50%,
302
+ rgba(0, 0, 0, 0.9) 100%);
303
+ background: -webkit-gradient(linear, 0 0, 0 100%,
304
+ color-stop(0, rgba(50, 50, 50, 0.9)),
305
+ color-stop(0.5, rgba(30, 30, 30, 0.9)),
306
+ color-stop(0.5, rgba(20, 20, 20, 0.9)),
307
+ color-stop(1, rgba(0, 0, 0, 0.9)));
308
+ border: 0;
309
+ -moz-border-radius: 4px;
310
+ -webkit-border-radius: 4px;
311
+ border-radius: 4px;
312
+ -moz-box-shadow: inset 1px 1px 1px 0px rgba(135, 135, 135, 0.1), inset -1px -1px 1px 0px rgba(135, 135, 135, 0.1);
313
+ -webkit-box-shadow: inset 1px 1px 1px 0px rgba(135, 135, 135, 0.1), inset -1px -1px 1px 0px rgba(135, 135, 135, 0.1);
314
+ box-shadow: inset 1px 1px 1px 0px rgba(135, 135, 135, 0.1), inset -1px -1px 1px 0px rgba(135, 135, 135, 0.1);
315
+ color: #fff;
316
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
317
+ font-size: 22px;
318
+ font-weight: lighter;
319
+ line-height: 1;
320
+ padding: 12px 0;
321
+ text-shadow: 0px -1px 1px rgba(0, 0, 0, .8), 0 1px 1px rgba(255, 255, 255, 0.3);
322
+ width: 150px;
323
+ }
324
+
325
+ button.slick-black:hover {
326
+ background: #222;
327
+ background: -moz-linear-gradient(top,
328
+ rgba(70, 70, 70, 0.9) 0%,
329
+ rgba(50, 50, 50, 0.9) 50%,
330
+ rgba(40, 40, 40, 0.9) 50%,
331
+ rgba(20, 20, 20, 0.9) 100%);
332
+ background: -webkit-gradient(linear, 0 0, 0 100%,
333
+ color-stop(0, rgba(70, 70, 70, 0.9)),
334
+ color-stop(0.5, rgba(50, 50, 50, 0.9)),
335
+ color-stop(0.5, rgba(40, 40, 40, 0.9)),
336
+ color-stop(1, rgba(20, 20, 20, 0.9)));
337
+ cursor: pointer;
338
+ }
339
+
340
+ button.slick-black:active {
341
+ background: #000;
342
+ background: -moz-linear-gradient(top,
343
+ rgba(30, 30, 30, 0.9) 0%,
344
+ rgba(20, 20, 20, 0.9) 50%,
345
+ rgba(10, 10, 10, 0.9) 50%,
346
+ rgba(0, 0, 0, 0.9) 100%);
347
+ background: -webkit-gradient(linear, 0 0, 0 100%,
348
+ color-stop(0, rgba(30, 30, 30, 0.9)),
349
+ color-stop(0.5, rgba(20, 20, 20, 0.9)),
350
+ color-stop(0.5, rgba(10, 10, 10, 0.9)),
351
+ color-stop(1, rgba(0, 0, 0, 0.9)));
352
+ }
353
+
354
+ /* thoughtbot (inspired by thoughtbot.com)
355
+ *******************************************************************************/
356
+ button.thoughtbot {
357
+ background: #c63929;
358
+ background: -moz-linear-gradient(top, #ee432e 0%, #c63929 50%, #b51700 50%, #891100 100%);
359
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #ee432e), color-stop(0.5, #c63929), color-stop(0.5, #b51700), color-stop(1, #891100));
360
+ border: 1px solid #951100;
361
+ -moz-border-radius: 5px;
362
+ -webkit-border-radius: 5px;
363
+ border-radius: 5px;
364
+ -moz-box-shadow: inset 0px 0px 0px 1px rgba(255, 115, 100, 0.4), 0 1px 3px #333;
365
+ -webkit-box-shadow: inset 0px 0px 0px 1px rgba(255, 115, 100, 0.4), 0 1px 3px #333;
366
+ box-shadow: inset 0px 0px 0px 1px rgba(255, 115, 100, 0.4), 0 1px 3px #333;
367
+ color: #fff;
368
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
369
+ font-size: 20px;
370
+ font-weight: bold;
371
+ line-height: 1;
372
+ padding: 12px 0 14px 0;
373
+ text-align: center;
374
+ text-shadow: 0px -1px 1px rgba(0, 0, 0, .8);
375
+ width: 150px;
376
+ }
377
+
378
+ button.thoughtbot:hover {
379
+ background: #cb0500;
380
+ background: -moz-linear-gradient(top, #f37873 0%, #db504d 50%, #cb0500 50%, #a20601 100%);
381
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #f37873), color-stop(0.5, #db504d), color-stop(0.5, #cb0500), color-stop(1, #a20601));
382
+ cursor: pointer;
383
+ }
384
+
385
+ button.thoughtbot:active {
386
+ background: #b30300;
387
+ background: -moz-linear-gradient(top, #d43c28 0%, #ad3224 50%, #9c1500 50%, #700d00 100%);
388
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #d43c28), color-stop(0.5, #ad3224), color-stop(0.5, #9c1500), color-stop(1, #700d00));
389
+ -moz-box-shadow: inset 0px 0px 0px 1px rgba(255, 115, 100, 0.4);
390
+ -webkit-box-shadow: inset 0px 0px 0px 1px rgba(255, 115, 100, 0.4);
391
+ box-shadow: inset 0px 0px 0px 1px rgba(255, 115, 100, 0.4);
392
+ }
393
+
394
+ /* punch
395
+ *******************************************************************************/
396
+ button.punch {
397
+ background: #4162a8;
398
+ border-top: 1px solid #38538c;
399
+ border-right: 1px solid #1f2d4d;
400
+ border-bottom: 1px solid #151e33;
401
+ border-left: 1px solid #1f2d4d;
402
+ -moz-border-radius: 4px;
403
+ -webkit-border-radius: 4px;
404
+ border-radius: 4px;
405
+ -moz-box-shadow: inset 0 1px 10px 1px #5c8bee, 0px 1px 0 #1d2c4d, 0 6px 0px #1f3053, 0 8px 4px 1px #111;
406
+ -webkit-box-shadow: inset 0 1px 10px 1px #5c8bee, 0px 1px 0 #1d2c4d, 0 6px 0px #1f3053, 0 8px 4px 1px #111;
407
+ box-shadow: inset 0 1px 10px 1px #5c8bee, 0px 1px 0 #1d2c4d, 0 6px 0px #1f3053, 0 8px 4px 1px #111;
408
+ color: #fff;
409
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
410
+ font-size: 20px;
411
+ font-weight: bold;
412
+ line-height: 1;
413
+ margin-bottom: 10px;
414
+ padding: 10px 0 12px 0;
415
+ text-align: center;
416
+ text-shadow: 0px -1px 1px #1e2d4d;
417
+ width: 150px;
418
+ -webkit-background-clip: padding-box;
419
+ }
420
+
421
+ button.punch:hover {
422
+ -moz-box-shadow: inset 0 0px 20px 1px #87adff, 0px 1px 0 #1d2c4d, 0 6px 0px #1f3053, 0 8px 4px 1px #111;
423
+ -webkit-box-shadow: inset 0 0px 20px 1px #87adff, 0px 1px 0 #1d2c4d, 0 6px 0px #1f3053, 0 8px 4px 1px #111;
424
+ box-shadow: inset 0 0px 20px 1px #87adff, 0px 1px 0 #1d2c4d, 0 6px 0px #1f3053, 0 8px 4px 1px #111;
425
+ cursor: pointer;
426
+ }
427
+
428
+ button.punch:active {
429
+ -moz-box-shadow: inset 0 1px 10px 1px #5c8bee, 0 1px 0 #1d2c4d, 0 2px 0 #1f3053, 0 4px 3px 0 #111;
430
+ -webkit-box-shadow: inset 0 1px 10px 1px #5c8bee, 0 1px 0 #1d2c4d, 0 2px 0 #1f3053, 0 4px 3px 0 #111;
431
+ box-shadow: inset 0 1px 10px 1px #5c8bee, 0 1px 0 #1d2c4d, 0 2px 0 #1f3053, 0 4px 3px 0 #111;
432
+ margin-top: 58px;
433
+ }
434
+
435
+ /* blue candy (inspired by Apple iOS buttons)
436
+ *******************************************************************************/
437
+ button.blue-candy {
438
+ background: #2260dd;
439
+ background: -moz-linear-gradient(top, #779be9 0%, #376fe0 50%, #2260dd 50%, #2463de 100%);
440
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #779be9), color-stop(0.5, #376fe0), color-stop(0.5, #2260dd), color-stop(1, #2463de));
441
+ -moz-border-radius: 3px;
442
+ -webkit-border-radius: 3px;
443
+ border-radius: 3px;
444
+ color: #fff;
445
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
446
+ font-size: 12px;
447
+ font-weight: bold;
448
+ line-height: 1;
449
+ padding: 10px 0 12px 0;
450
+ text-align: center;
451
+ text-shadow: 0px -1px 1px #2c4d93;
452
+ width: 150px;
453
+ -webkit-background-clip: padding-box;
454
+ }
455
+
456
+ button.blue-candy:hover {
457
+ background: #1d55c4;
458
+ background: -moz-linear-gradient(top, #6989cf 0%, #3263c7 50%, #1d55c4 50%, #1d55c4 100%);
459
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #6989cf), color-stop(0.5, #3263c7), color-stop(0.5, #1d55c4), color-stop(1, #1d55c4));
460
+ -webkit-background-clip: padding-box;
461
+ cursor: pointer;
462
+ }
463
+
464
+ button.blue-candy:active {
465
+ background: #1a4aab;
466
+ background: -moz-radial-gradient(50% 31% 0deg,circle cover, rgba(38, 76, 153, 0.4), rgba(11, 23, 46, 0.4)),
467
+ -moz-linear-gradient(top, #5c78b5 0%, #2b57ad 50%, #1a4aab 50%, #1b4bab 100%);
468
+ background: -webkit-gradient(radial, 50% 20%, 75, 50% 50%, 0, from(rgba(38, 76, 153, 0.4)), to(rgba(11, 23, 46, 0.4))),
469
+ -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #5c78b5), color-stop(0.5, #2b57ad), color-stop(0.5, #1a4aab), color-stop(1, #1b4bab));
470
+ color: #ddd;
471
+ -webkit-background-clip: padding-box;
472
+ }
473
+
474
+ /* purple candy
475
+ *******************************************************************************/
476
+ button.purple-candy {
477
+ background: #6021de;
478
+ background: -moz-linear-gradient(top, #9e76e8 0%, #7038e0 50%, #6021de 50%, #6224de 100%);
479
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #9e76e8), color-stop(0.5, #7038e0), color-stop(0.5, #6021de), color-stop(1, #6224de));
480
+ -moz-border-radius: 3px;
481
+ -webkit-border-radius: 3px;
482
+ border-radius: 3px;
483
+ color: #fff;
484
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
485
+ font-size: 12px;
486
+ font-weight: bold;
487
+ line-height: 1;
488
+ padding: 10px 0 12px 0;
489
+ text-align: center;
490
+ text-shadow: 0px -1px 1px #473569;
491
+ width: 150px;
492
+ -webkit-background-clip: padding-box;
493
+ }
494
+
495
+ button.purple-candy:hover {
496
+ background: #551dc4;
497
+ background: -moz-linear-gradient(top, #8d69cf 0%, #6332c7 50%, #551dc4 50%, #561fc4 100%);
498
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #8d69cf), color-stop(0.5, #6332c7), color-stop(0.5, #551dc4), color-stop(1, #561fc4));
499
+ -webkit-background-clip: padding-box;
500
+ cursor: pointer;
501
+ }
502
+
503
+ button.purple-candy:active {
504
+ background: #4a1aab;
505
+ background: -moz-radial-gradient(50% 31% 0deg,circle cover, rgba(38, 76, 153, 0.4), rgba(11, 23, 46, 0.4)),
506
+ -moz-linear-gradient(top, #7b5cb5 0%, #572bad 50%, #4a1aab 50%, #4b1bab 100%);
507
+ background: -webkit-gradient(radial, 50% 20%, 75, 50% 50%, 0, from(rgba(38, 76, 153, 0.4)), to(rgba(11, 23, 46, 0.4))),
508
+ -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #7b5cb5), color-stop(0.5, #572bad), color-stop(0.5, #4a1aab), color-stop(1, #4b1bab));
509
+ color: #ddd;
510
+ -webkit-background-clip: padding-box;
511
+ }
512
+
513
+ /* shiny blue (inspired by rdio iphone interface)
514
+ *******************************************************************************/
515
+ button.shiny-blue {
516
+ background: #2463de;
517
+ background: -moz-linear-gradient(top, #759ae9 0%, #376fe0 50%, #1a5ad9 50%, #2463de 100%);
518
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #759ae9), color-stop(0.5, #376fe0), color-stop(0.5, #1a5ad9), color-stop(1, #2463de));
519
+ border-top: 1px solid #1f58cc;
520
+ border-right: 1px solid #1b4db3;
521
+ border-bottom: 1px solid #174299;
522
+ border-left: 1px solid #1b4db3;
523
+ -moz-border-radius: 4px;
524
+ -webkit-border-radius: 4px;
525
+ border-radius: 4px;
526
+ -moz-box-shadow: inset 0 0 2px 0 rgba(57, 140, 255, 0.8);
527
+ -webkit-box-shadow: inset 0 0 2px 0 rgba(57, 140, 255, 0.8);
528
+ box-shadow: inset 0 0 2px 0 rgba(57, 140, 255, 0.8);
529
+ color: #fff;
530
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
531
+ font-size: 12px;
532
+ font-weight: bold;
533
+ padding: 7px 0;
534
+ text-shadow: 0 -1px 1px #1a5ad9;
535
+ width: 150px;
536
+ }
537
+
538
+ button.shiny-blue:hover {
539
+ background: #0d53de;
540
+ background: -moz-linear-gradient(top, #5d89e8 0%, #2261e0 50%, #044bd9 50%, #0d53de 100%);
541
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #5d89e8), color-stop(0.5, #2261e0), color-stop(0.5, #044bd9), color-stop(1, #0d53de));
542
+ cursor: pointer;
543
+ }
544
+
545
+ button.shiny-blue:active {
546
+ border-top: 1px solid #1b4db3;
547
+ border-right: 1px solid #174299;
548
+ border-bottom: 1px solid #133780;
549
+ border-left: 1px solid #174299;
550
+ -moz-box-shadow: inset 0 0 5px 2px #1a47a0, 0 1px 0 #eee;
551
+ -webkit-box-shadow: inset 0 0 5px 2px #1a47a0, 0 1px 0 #eee;
552
+ box-shadow: inset 0 0 5px 2px #1a47a0, 0 1px 0 #eee;
553
+ }
554
+
555
+ /* download itunes
556
+ I wrote a blog post about creating this button:
557
+ http://robots.thoughtbot.com/post/2718077289/make-css3-buttons-like-a-boss
558
+ *******************************************************************************/
559
+ a.download-itunes, button.download-itunes {
560
+ background: #377ad0;
561
+ background: -moz-linear-gradient(top, #52a8e8 0%, #377ad0 100%);
562
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#52a8e8), to(#377ad0));
563
+ border-top: 1px solid #4081af;
564
+ border-right: 1px solid #2e69a3;
565
+ border-bottom: 1px solid #20559a;
566
+ border-left: 1px solid #2e69a3;
567
+ -moz-border-radius: 16px;
568
+ -webkit-border-radius: 16px;
569
+ border-radius: 16px;
570
+ -moz-box-shadow: inset 0 1px 0 0 #72b9eb, 0 1px 2px 0 #b3b3b3;
571
+ -webkit-box-shadow: inset 0 1px 0 0 #72b9eb, 0 1px 2px 0 #b3b3b3;
572
+ color: #fff;
573
+ font-family: "lucida grande", sans-serif;
574
+ font-size: 11px;
575
+ font-weight: normal;
576
+ line-height: 1;
577
+ padding: 3px 0 5px 0;
578
+ text-align: center;
579
+ text-shadow: 0 -1px 1px #3275bc;
580
+ width: 112px;
581
+ -webkit-background-clip: padding-box;
582
+ }
583
+
584
+ a.download-itunes:hover, button.download-itunes:hover {
585
+ background: #206bcb;
586
+ background: -moz-linear-gradient(top, #3e9ee5 0%, #206bcb 100%);
587
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#3e9ee5), to(#206bcb));
588
+ border-top: 1px solid #2a73a6;
589
+ border-right: 1px solid #165899;
590
+ border-bottom: 1px solid #07428f;
591
+ border-left: 1px solid #165899;
592
+ -moz-box-shadow: inset 0 1px 0 0 #62b1e9;
593
+ -webkit-box-shadow: inset 0 1px 0 0 #62b1e9;
594
+ color: #fff;
595
+ cursor: pointer;
596
+ text-shadow: 0 -1px 1px #1d62ab;
597
+ -webkit-background-clip: padding-box;
598
+ }
599
+
600
+ a.download-itunes:active, button.download-itunes:active {
601
+ background: #3282d3;
602
+ border: 1px solid #154c8c;
603
+ border-bottom: 1px solid #0e408e;
604
+ -moz-box-shadow: inset 0 0 6px 3px #1657b5, 0 1px 0 0 #fff;
605
+ -webkit-box-shadow: inset 0 0 6px 3px #1657b5, 0 1px 0 0 #fff;
606
+ color: #fff;
607
+ text-shadow: 0 -1px 1px #2361a4;
608
+ -webkit-background-clip: padding-box;
609
+ }
610
+
611
+ button[disabled].download-itunes,
612
+ button[disabled].download-itunes:hover,
613
+ button[disabled].download-itunes:active {
614
+ background: #dadada;
615
+ background: -moz-linear-gradient(top, #f3f3f3 0%, #dadada 100%);
616
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#dadada), to(#f3f3f3));
617
+ border-top: 1px solid #c5c5c5;
618
+ border-right: 1px solid #cecece;
619
+ border-bottom: 1px solid #d9d9d9;
620
+ border-left: 1px solid #cecece;
621
+ color: #8f8f8f;
622
+ box-shadow: none;
623
+ -moz-box-shadow: none;
624
+ -webkit-box-shadow: none;
625
+ cursor: not-allowed;
626
+ text-shadow: 0 -1px 1px #ebebeb;
627
+ }
628
+
629
+ a.download-itunes::-moz-focus-inner, button.download-itunes::-moz-focus-inner {
630
+ border: 0;
631
+ padding: 0;
632
+ }
633
+
634
+ /* skip (inspired by okcupid iphone interface)
635
+ *******************************************************************************/
636
+ button.skip {
637
+ background: #36518f;
638
+ background: -moz-linear-gradient(top, #8c9cbf 0%, #546a9e 50%, #36518f 50%, #3d5691 100%);
639
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #8c9cbf), color-stop(0.5, #546a9e), color-stop(0.5, #36518f), color-stop(1, #3d5691));
640
+ border: 1px solid #172d6e;
641
+ border-bottom: 1px solid #0e1d45;
642
+ -moz-border-radius: 5px;
643
+ -webkit-border-radius: 5px;
644
+ border-radius: 5px;
645
+ -moz-box-shadow: inset 0 1px 0 0 #b1b9cb;
646
+ -webkit-box-shadow: inset 0 1px 0 0 #b1b9cb;
647
+ box-shadow: inset 0 1px 0 0 #b1b9cb;
648
+ color: #fff;
649
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
650
+ font-size: 16px;
651
+ font-weight: bold;
652
+ padding: 7px 0 8px 0;
653
+ text-decoration: none;
654
+ text-align: center;
655
+ text-shadow: 0 -1px 1px #000f4d;
656
+ width: 150px;
657
+ }
658
+
659
+ button.skip:hover {
660
+ background: #2f477d;
661
+ background: -moz-linear-gradient(top, #7f8dad 0%, #4a5e8c 50%, #2f477d 50%, #364c80 100%);
662
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #7f8dad), color-stop(0.5, #4a5e8c), color-stop(0.5, #2f477d), color-stop(1, #364c80));
663
+ cursor: pointer;
664
+ }
665
+
666
+ button.skip:active {
667
+ -moz-box-shadow: inset 0 0 20px 0 #1d2845, 0 1px 0 #fff;
668
+ -webkit-box-shadow: inset 0 0 20px 0 #1d2845, 0 1px 0 #fff;
669
+ box-shadow: inset 0 0 20px 0 #1d2845, 0 1px 0 #fff;
670
+ cursor: pointer;
671
+ }
672
+
673
+ /* minimal indent (inspired by okcupid iphone interface)
674
+ *******************************************************************************/
675
+ button.minimal-indent {
676
+ background: #d2d2d2;
677
+ background: -moz-linear-gradient(top, #f3f3f3 0%, #dddddd 50%, #d2d2d2 50%, #dfdfdf 100%);
678
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #f3f3f3), color-stop(0.5, #dddddd), color-stop(0.5, #d2d2d2), color-stop(1, #dfdfdf));
679
+ border-right: 1px solid #dfdfdf;
680
+ border-bottom: 1px solid #b4b4b4;
681
+ border-right: 1px solid #dfdfdf;
682
+ -moz-border-radius: 5px;
683
+ -webkit-border-radius: 5px;
684
+ border-radius: 5px;
685
+ -moz-box-shadow: inset 0 1px 0 0 #fff, 0 1px 0 0 #d5d5d5, 0 -1px 2px 1px #efefef;
686
+ -webkit-box-shadow: inset 0 1px 0 0 #fff, 0 1px 0 0 #d5d5d5, 0 -1px 2px 1px #efefef;
687
+ box-shadow: inset 0 1px 0 0 #fff, 0 1px 0 0 #d5d5d5, 0 -1px 2px 1px #efefef;
688
+ color: #666666;
689
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
690
+ font-size: 16px;
691
+ font-weight: bold;
692
+ margin: 0;
693
+ padding: 7px 0;
694
+ text-shadow: 0 1px 1px #fff;
695
+ width: 150px;
696
+ }
697
+
698
+ button.minimal-indent:hover {
699
+ background: #c4c4c4;
700
+ background: -moz-linear-gradient(top, #e5e5e5 0%, #d1d1d1 50%, #c4c4c4 50%, #b8b8b8 100%);
701
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #e5e5e5), color-stop(0.5, #d1d1d1), color-stop(0.5, #c4c4c4), color-stop(1, #b8b8b8));
702
+ -webkit-box-shadow: inset 0 1px 0 0 #f2f2f2, 0 1px 0 0 #c9c9c9, 0 -1px 2px 1px #e3e3e3;
703
+ }
704
+
705
+ button.minimal-indent:active {
706
+ -moz-box-shadow: inset 0 0 30px 0 #999, 0 1px 0 0 #fff;
707
+ -webkit-box-shadow: inset 0 0 30px 0 #999, 0 1px 0 0 #fff;
708
+ box-shadow: inset 0 0 30px 0 #999, 0 1px 0 0 #fff;
709
+ }
710
+
711
+ div.indent {
712
+ background: #e2e2e2;
713
+ background: -moz-linear-gradient(top, #e2e2e2 0%, #fafafa 100%);
714
+ background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#e2e2e2), to(#fafafa));
715
+ -moz-border-radius: 8px;
716
+ -webkit-border-radius: 8px;
717
+ border-radius: 8px;
718
+ margin: 50px auto 0;
719
+ padding: 10px 0;
720
+ width: 170px;
721
+ }
722
+
723
+ /* webkit badge
724
+ *******************************************************************************/
725
+ button.webkit-badge {
726
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #ee432e), color-stop(0.5, #c63929), color-stop(0.5, #b51700), color-stop(1, #891100));
727
+ color: #fff;
728
+ font-family: "hoefler text", georgia, serif;
729
+ font-size: 30px;
730
+ font-style: italic;
731
+ font-weight: lighter;
732
+ height: 88px;
733
+ line-height: 1;
734
+ padding: 0;
735
+ text-align: center;
736
+ text-shadow: 0px -1px 1px #3d0700;
737
+ width: 150px;
738
+ -webkit-mask-image: url("../images/badge.png");
739
+ -webkit-mask-position: left top;
740
+ -webkit-mask-repeat: no-repeat;
741
+ }
742
+
743
+ button.webkit-badge:hover {
744
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #f37873), color-stop(0.5, #db504d), color-stop(0.5, #cb0500), color-stop(1, #a20601));
745
+ cursor: pointer;
746
+ }
747
+
748
+ button.webkit-badge:active {
749
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #d43c28), color-stop(0.5, #ad3224), color-stop(0.5, #9c1500), color-stop(1, #700d00));
750
+ }
751
+
752
+ /* webkit seal
753
+ *******************************************************************************/
754
+ button.webkit-seal {
755
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #9e76e8), color-stop(1, #6224de));
756
+ color: #fff;
757
+ height: 90px;
758
+ color: #fff;
759
+ font-family: "helvetica neue", helvetica, arial, sans-serif;
760
+ font-size: 13px;
761
+ font-weight: bold;
762
+ line-height: 1;
763
+ padding: 0;
764
+ text-align: center;
765
+ text-shadow: 0px -1px 1px #473569;
766
+ width: 150px;
767
+ -webkit-mask-image: url("../images/seal.png");
768
+ -webkit-mask-position: center center;
769
+ -webkit-mask-repeat: no-repeat;
770
+ }
771
+
772
+ button.webkit-seal:hover {
773
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #8d69cf), color-stop(1, #561fc4));
774
+ cursor: pointer;
775
+ }
776
+
777
+ button.webkit-seal:active {
778
+ background: -webkit-gradient(radial, 50% 50%, 40, 50% 50%, 0, from(rgba(38, 76, 153, 0.2)), to(rgba(11, 23, 46, 0.2))), -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #7b5cb5), color-stop(1, #4b1bab));
779
+ }
780
+
781
+ /* webkit check
782
+ *******************************************************************************/
783
+ button.webkit-check {
784
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #779be9), color-stop(1, #2463de));
785
+ color: #fff;
786
+ height: 88px;
787
+ line-height: 1;
788
+ padding: 0;
789
+ text-align: center;
790
+ text-indent: -9999px;
791
+ text-shadow: 0px -1px 1px #3d0700;
792
+ width: 150px;
793
+ -webkit-mask-image: url("../images/check.png");
794
+ -webkit-mask-position: center center;
795
+ -webkit-mask-repeat: no-repeat;
796
+ }
797
+
798
+ button.webkit-check:hover {
799
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #6989cf), color-stop(1, #1d55c4));
800
+ cursor: pointer;
801
+ }
802
+
803
+ button.webkit-check:active {
804
+ background: -webkit-gradient(linear, 0 0, 0 100%, color-stop(0, #5c78b5), color-stop(1, #1b4bab));
805
+ }
806
+
807
+ /* disabled button styles
808
+ works with this markup: <button disabled="disabled">Submit</button>
809
+ *******************************************************************************/
810
+ button[disabled],
811
+ button[disabled]:hover,
812
+ button[disabled]:active {
813
+ background: #999;
814
+ border: 0;
815
+ box-shadow: none;
816
+ -moz-box-shadow: none;
817
+ -webkit-box-shadow: none;
818
+ color: #aaa;
819
+ cursor: not-allowed;
820
+ text-shadow: none;
821
+ }